Compare commits
254 Commits
v2.6.0-RC1
...
v2.9.0
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
9bc5086f24 | ||
|
|
71eefca353 | ||
|
|
1cccd2aa73 | ||
|
|
c5e63ce95b | ||
|
|
ba3607bd87 | ||
|
|
ba526f85a8 | ||
|
|
ecea2a1fb4 | ||
|
|
e2e5687b47 | ||
|
|
198888d554 | ||
|
|
5c0150b81c | ||
|
|
ea4b1677f4 | ||
|
|
38b9d6c231 | ||
|
|
a7fa58b72a | ||
|
|
8e014eaeba | ||
|
|
3c6730ee44 | ||
|
|
a8dec654eb | ||
|
|
f722389f74 | ||
|
|
54518912a3 | ||
|
|
5bf58812a1 | ||
|
|
de364a1ffe | ||
|
|
593bee9a94 | ||
|
|
d431e777a1 | ||
|
|
d3639cf5a0 | ||
|
|
8424910f0e | ||
|
|
ac6780d094 | ||
|
|
bf6f5389d7 | ||
|
|
3c8400ba97 | ||
|
|
8957fde7bd | ||
|
|
a1dc0b38cc | ||
|
|
a25b90ec82 | ||
|
|
315cbaf3c1 | ||
|
|
1ca3c0ade4 | ||
|
|
93224f609f | ||
|
|
cb2f9a91b5 | ||
|
|
865ad612e6 | ||
|
|
19b4f9edd1 | ||
|
|
350553bd86 | ||
|
|
3b45abd604 | ||
|
|
df2f5bb21b | ||
|
|
b1a489fa8f | ||
|
|
9235bf7b73 | ||
|
|
0b35942ef6 | ||
|
|
d5e0687ade | ||
|
|
b54a914c0d | ||
|
|
3e03b127fe | ||
|
|
15f91dc667 | ||
|
|
3e9663bcf4 | ||
|
|
6b4d9e1720 | ||
|
|
d86d15ffe1 | ||
|
|
ba36df0182 | ||
|
|
ac5c8bf531 | ||
|
|
513fa9264b | ||
|
|
8d6a9f6d5b | ||
|
|
8b249f6f92 | ||
|
|
93da8d1229 | ||
|
|
4d3ed84e5c | ||
|
|
4b104c961a | ||
|
|
db367133a8 | ||
|
|
5baf3b1b19 | ||
|
|
6a923375ad | ||
|
|
39b1352d4e | ||
|
|
df9d05bd69 | ||
|
|
ca63e3cae6 | ||
|
|
fe14eaac58 | ||
|
|
5172d95aac | ||
|
|
5e2ab7a37b | ||
|
|
12ff4adc41 | ||
|
|
6e88403685 | ||
|
|
174b209065 | ||
|
|
0d380f9585 | ||
|
|
c249911f9c | ||
|
|
1cc9ef6466 | ||
|
|
6aee513a45 | ||
|
|
66ca992fee | ||
|
|
cd216c7949 | ||
|
|
1f0366335b | ||
|
|
38b4d82e79 | ||
|
|
601c75bccb | ||
|
|
325801b583 | ||
|
|
b1fba48ed1 | ||
|
|
9ab2b5ee60 | ||
|
|
7a5d484932 | ||
|
|
f623368923 | ||
|
|
188ecabd33 | ||
|
|
5326fbf390 | ||
|
|
6ee055adff | ||
|
|
5d66fe0d56 | ||
|
|
378ff98bfb | ||
|
|
01cbb382d1 | ||
|
|
1cba12b934 | ||
|
|
9b8de5efd2 | ||
|
|
01d7a048dd | ||
|
|
da31483c78 | ||
|
|
a22fac8b86 | ||
|
|
fe50daf627 | ||
|
|
711f1808d8 | ||
|
|
23aa41dd8d | ||
|
|
30385a5cc3 | ||
|
|
0145aa3e52 | ||
|
|
97575715a3 | ||
|
|
125800e78a | ||
|
|
606a806d62 | ||
|
|
46b5daed8f | ||
|
|
d1edab2bcf | ||
|
|
2bf972cec6 | ||
|
|
d706dba60a | ||
|
|
8b23197359 | ||
|
|
4f4dcc9071 | ||
|
|
a30b4e1dae | ||
|
|
21aa3ef685 | ||
|
|
a6a9daa8a1 | ||
|
|
5b546ea381 | ||
|
|
be8805e86d | ||
|
|
efe9076c35 | ||
|
|
4a55483f90 | ||
|
|
af336e5ddf | ||
|
|
222674ae1b | ||
|
|
ec684090ae | ||
|
|
c0004dc804 | ||
|
|
d08d64ae27 | ||
|
|
9a9d25f045 | ||
|
|
fdded83221 | ||
|
|
8a98844bac | ||
|
|
a9105f06aa | ||
|
|
ac885295ae | ||
|
|
5a0132e174 | ||
|
|
9daee84f88 | ||
|
|
d7469cf0b7 | ||
|
|
8d8d52adf2 | ||
|
|
c5e44f2a98 | ||
|
|
5c2937c7ec | ||
|
|
a8f1483362 | ||
|
|
5abe7a9909 | ||
|
|
0a3a9a4b20 | ||
|
|
9d4eb1e502 | ||
|
|
51ba962338 | ||
|
|
fef07e3150 | ||
|
|
03a6675359 | ||
|
|
19686da4d8 | ||
|
|
c5997a3511 | ||
|
|
3feb5fd666 | ||
|
|
d3cd3a1a21 | ||
|
|
5e6228b9d6 | ||
|
|
ad526ebf1d | ||
|
|
8de53277e6 | ||
|
|
93fbb3017a | ||
|
|
2e4d1ad3e8 | ||
|
|
109a9affc5 | ||
|
|
9c65813735 | ||
|
|
7d0bdf059d | ||
|
|
93e4b069c4 | ||
|
|
4fe1367651 | ||
|
|
5f5f2fd699 | ||
|
|
c2e0d32e0d | ||
|
|
cab81a3930 | ||
|
|
01395f11a3 | ||
|
|
250c12acf1 | ||
|
|
e23d04c1d0 | ||
|
|
b48955e791 | ||
|
|
e58eb38d53 | ||
|
|
791af9aeba | ||
|
|
67081917a9 | ||
|
|
3a33815096 | ||
|
|
f515bb8e30 | ||
|
|
02fd6d726a | ||
|
|
27ffb31a7c | ||
|
|
5fd9831d6b | ||
|
|
fed085cc4a | ||
|
|
121fee841e | ||
|
|
4c6f03ba14 | ||
|
|
0fb9478675 | ||
|
|
97c2af83fd | ||
|
|
599ba0793c | ||
|
|
6df780dba3 | ||
|
|
a00287ae85 | ||
|
|
c7a300b81e | ||
|
|
5dc507a82e | ||
|
|
8b3e1326b7 | ||
|
|
667f8bc4bd | ||
|
|
6cacebad28 | ||
|
|
e487b68945 | ||
|
|
ffddfa87d2 | ||
|
|
0168301d6b | ||
|
|
1a0b00e989 | ||
|
|
7c2229f3d6 | ||
|
|
541df429ec | ||
|
|
6f9fe6cd5d | ||
|
|
2594a2c5f2 | ||
|
|
2e02d96523 | ||
|
|
a1375f9468 | ||
|
|
777bc0f2aa | ||
|
|
bd0e99309c | ||
|
|
6cb6a60142 | ||
|
|
fc7947394d | ||
|
|
1341e15874 | ||
|
|
f065815df3 | ||
|
|
03ba51e869 | ||
|
|
efd7ef2a9b | ||
|
|
4b90a6e893 | ||
|
|
f5cb4a5a87 | ||
|
|
e3e4aac202 | ||
|
|
5945d02b3d | ||
|
|
0ac192cdc0 | ||
|
|
1b5eb87eef | ||
|
|
46db18d7cd | ||
|
|
30b8665d7d | ||
|
|
c8b3a3b060 | ||
|
|
096da35ff4 | ||
|
|
bd7f3af11c | ||
|
|
2a06021c4a | ||
|
|
bf18bb25ba | ||
|
|
e93f899b76 | ||
|
|
eda73038f6 | ||
|
|
953ca155a4 | ||
|
|
898806f232 | ||
|
|
7d97b19b85 | ||
|
|
d6c587fde6 | ||
|
|
58c9a7805b | ||
|
|
94dd4c84e9 | ||
|
|
2636715f6f | ||
|
|
f9f4624add | ||
|
|
cf441de197 | ||
|
|
158455a528 | ||
|
|
4d2ccec1a8 | ||
|
|
7dad5a9bdb | ||
|
|
cd2ac84c5b | ||
|
|
9735f709e9 | ||
|
|
ae5fd31818 | ||
|
|
2b46ad4a66 | ||
|
|
43d7078cb7 | ||
|
|
18f5d42f00 | ||
|
|
70622b2bb8 | ||
|
|
5b24aea47c | ||
|
|
e97617a0db | ||
|
|
ba63a7033f | ||
|
|
e9db2e1a0d | ||
|
|
d85fef7725 | ||
|
|
543c46bf68 | ||
|
|
73eec53fe4 | ||
|
|
8ad2d67c2c | ||
|
|
442f810688 | ||
|
|
2dca5204ea | ||
|
|
dc2abe2154 | ||
|
|
8c14bb5b3a | ||
|
|
6ec4bc7115 | ||
|
|
9883a40ec6 | ||
|
|
cc647b8108 | ||
|
|
3b0f2a0977 | ||
|
|
dfefe39188 | ||
|
|
7d65e19d29 | ||
|
|
1e16c59743 | ||
|
|
4582cbd133 | ||
|
|
18e4b68c1f | ||
|
|
46a11ebda2 |
178
.clang-format
Normal file
@@ -0,0 +1,178 @@
|
|||||||
|
---
|
||||||
|
Language: Cpp
|
||||||
|
# BasedOnStyle: LLVM
|
||||||
|
AccessModifierOffset: -2
|
||||||
|
AlignAfterOpenBracket: Align
|
||||||
|
AlignArrayOfStructures: None
|
||||||
|
AlignConsecutiveMacros: None
|
||||||
|
AlignConsecutiveAssignments: None
|
||||||
|
AlignConsecutiveBitFields: None
|
||||||
|
AlignConsecutiveDeclarations: None
|
||||||
|
AlignEscapedNewlines: Right
|
||||||
|
AlignOperands: Align
|
||||||
|
AlignTrailingComments: true
|
||||||
|
AllowAllArgumentsOnNextLine: true
|
||||||
|
AllowAllConstructorInitializersOnNextLine: true
|
||||||
|
AllowAllParametersOfDeclarationOnNextLine: true
|
||||||
|
AllowShortEnumsOnASingleLine: true
|
||||||
|
AllowShortBlocksOnASingleLine: Never
|
||||||
|
AllowShortCaseLabelsOnASingleLine: false
|
||||||
|
AllowShortFunctionsOnASingleLine: All
|
||||||
|
AllowShortLambdasOnASingleLine: All
|
||||||
|
AllowShortIfStatementsOnASingleLine: Never
|
||||||
|
AllowShortLoopsOnASingleLine: false
|
||||||
|
AlwaysBreakAfterDefinitionReturnType: None
|
||||||
|
AlwaysBreakAfterReturnType: None
|
||||||
|
AlwaysBreakBeforeMultilineStrings: false
|
||||||
|
AlwaysBreakTemplateDeclarations: MultiLine
|
||||||
|
AttributeMacros:
|
||||||
|
- __capability
|
||||||
|
BinPackArguments: true
|
||||||
|
BinPackParameters: true
|
||||||
|
BraceWrapping:
|
||||||
|
AfterCaseLabel: false
|
||||||
|
AfterClass: false
|
||||||
|
AfterControlStatement: Never
|
||||||
|
AfterEnum: false
|
||||||
|
AfterFunction: false
|
||||||
|
AfterNamespace: false
|
||||||
|
AfterObjCDeclaration: false
|
||||||
|
AfterStruct: false
|
||||||
|
AfterUnion: false
|
||||||
|
AfterExternBlock: false
|
||||||
|
BeforeCatch: false
|
||||||
|
BeforeElse: false
|
||||||
|
BeforeLambdaBody: false
|
||||||
|
BeforeWhile: false
|
||||||
|
IndentBraces: false
|
||||||
|
SplitEmptyFunction: true
|
||||||
|
SplitEmptyRecord: true
|
||||||
|
SplitEmptyNamespace: true
|
||||||
|
BreakBeforeBinaryOperators: None
|
||||||
|
BreakBeforeConceptDeclarations: true
|
||||||
|
BreakBeforeBraces: Attach
|
||||||
|
BreakBeforeInheritanceComma: false
|
||||||
|
BreakInheritanceList: BeforeColon
|
||||||
|
BreakBeforeTernaryOperators: true
|
||||||
|
BreakConstructorInitializersBeforeComma: false
|
||||||
|
BreakConstructorInitializers: BeforeColon
|
||||||
|
BreakAfterJavaFieldAnnotations: false
|
||||||
|
BreakStringLiterals: true
|
||||||
|
ColumnLimit: 100
|
||||||
|
CommentPragmas: '^ IWYU pragma:'
|
||||||
|
CompactNamespaces: false
|
||||||
|
ConstructorInitializerAllOnOneLineOrOnePerLine: false
|
||||||
|
ConstructorInitializerIndentWidth: 4
|
||||||
|
ContinuationIndentWidth: 4
|
||||||
|
Cpp11BracedListStyle: true
|
||||||
|
DeriveLineEnding: true
|
||||||
|
DerivePointerAlignment: false
|
||||||
|
DisableFormat: false
|
||||||
|
EmptyLineAfterAccessModifier: Never
|
||||||
|
EmptyLineBeforeAccessModifier: LogicalBlock
|
||||||
|
ExperimentalAutoDetectBinPacking: false
|
||||||
|
FixNamespaceComments: true
|
||||||
|
ForEachMacros:
|
||||||
|
- foreach
|
||||||
|
- Q_FOREACH
|
||||||
|
- BOOST_FOREACH
|
||||||
|
IfMacros:
|
||||||
|
- KJ_IF_MAYBE
|
||||||
|
IncludeBlocks: Preserve
|
||||||
|
IncludeCategories:
|
||||||
|
- Regex: '^"(llvm|llvm-c|clang|clang-c)/'
|
||||||
|
Priority: 2
|
||||||
|
SortPriority: 0
|
||||||
|
CaseSensitive: false
|
||||||
|
- Regex: '^(<|"(gtest|gmock|isl|json)/)'
|
||||||
|
Priority: 3
|
||||||
|
SortPriority: 0
|
||||||
|
CaseSensitive: false
|
||||||
|
- Regex: '.*'
|
||||||
|
Priority: 1
|
||||||
|
SortPriority: 0
|
||||||
|
CaseSensitive: false
|
||||||
|
IncludeIsMainRegex: '(Test)?$'
|
||||||
|
IncludeIsMainSourceRegex: ''
|
||||||
|
IndentAccessModifiers: false
|
||||||
|
IndentCaseLabels: false
|
||||||
|
IndentCaseBlocks: false
|
||||||
|
IndentGotoLabels: true
|
||||||
|
IndentPPDirectives: None
|
||||||
|
IndentExternBlock: AfterExternBlock
|
||||||
|
IndentRequires: false
|
||||||
|
IndentWidth: 4
|
||||||
|
IndentWrappedFunctionNames: false
|
||||||
|
InsertTrailingCommas: None
|
||||||
|
JavaScriptQuotes: Leave
|
||||||
|
JavaScriptWrapImports: true
|
||||||
|
KeepEmptyLinesAtTheStartOfBlocks: true
|
||||||
|
LambdaBodyIndentation: Signature
|
||||||
|
MacroBlockBegin: ''
|
||||||
|
MacroBlockEnd: ''
|
||||||
|
MaxEmptyLinesToKeep: 1
|
||||||
|
NamespaceIndentation: All
|
||||||
|
ObjCBinPackProtocolList: Auto
|
||||||
|
ObjCBlockIndentWidth: 2
|
||||||
|
ObjCBreakBeforeNestedBlockParam: true
|
||||||
|
ObjCSpaceAfterProperty: false
|
||||||
|
ObjCSpaceBeforeProtocolList: true
|
||||||
|
PenaltyBreakAssignment: 2
|
||||||
|
PenaltyBreakBeforeFirstCallParameter: 19
|
||||||
|
PenaltyBreakComment: 300
|
||||||
|
PenaltyBreakFirstLessLess: 120
|
||||||
|
PenaltyBreakString: 1000
|
||||||
|
PenaltyBreakTemplateDeclaration: 10
|
||||||
|
PenaltyExcessCharacter: 1000000
|
||||||
|
PenaltyReturnTypeOnItsOwnLine: 60
|
||||||
|
PenaltyIndentedWhitespace: 0
|
||||||
|
PointerAlignment: Right
|
||||||
|
PPIndentWidth: -1
|
||||||
|
ReferenceAlignment: Pointer
|
||||||
|
ReflowComments: true
|
||||||
|
ShortNamespaceLines: 1
|
||||||
|
SortIncludes: CaseSensitive
|
||||||
|
SortJavaStaticImport: Before
|
||||||
|
SortUsingDeclarations: true
|
||||||
|
SpaceAfterCStyleCast: false
|
||||||
|
SpaceAfterLogicalNot: false
|
||||||
|
SpaceAfterTemplateKeyword: true
|
||||||
|
SpaceBeforeAssignmentOperators: true
|
||||||
|
SpaceBeforeCaseColon: false
|
||||||
|
SpaceBeforeCpp11BracedList: false
|
||||||
|
SpaceBeforeCtorInitializerColon: true
|
||||||
|
SpaceBeforeInheritanceColon: true
|
||||||
|
SpaceBeforeParens: ControlStatements
|
||||||
|
SpaceAroundPointerQualifiers: Default
|
||||||
|
SpaceBeforeRangeBasedForLoopColon: true
|
||||||
|
SpaceInEmptyBlock: false
|
||||||
|
SpaceInEmptyParentheses: false
|
||||||
|
SpacesBeforeTrailingComments: 1
|
||||||
|
SpacesInAngles: Never
|
||||||
|
SpacesInConditionalStatement: false
|
||||||
|
SpacesInContainerLiterals: true
|
||||||
|
SpacesInCStyleCastParentheses: false
|
||||||
|
SpacesInLineCommentPrefix:
|
||||||
|
Minimum: 1
|
||||||
|
Maximum: -1
|
||||||
|
SpacesInParentheses: false
|
||||||
|
SpacesInSquareBrackets: false
|
||||||
|
SpaceBeforeSquareBrackets: false
|
||||||
|
BitFieldColonSpacing: Both
|
||||||
|
Standard: Latest
|
||||||
|
StatementAttributeLikeMacros:
|
||||||
|
- Q_EMIT
|
||||||
|
StatementMacros:
|
||||||
|
- Q_UNUSED
|
||||||
|
- QT_REQUIRE_VERSION
|
||||||
|
TabWidth: 4
|
||||||
|
UseCRLF: false
|
||||||
|
UseTab: Always
|
||||||
|
WhitespaceSensitiveMacros:
|
||||||
|
- STRINGIZE
|
||||||
|
- PP_STRINGIZE
|
||||||
|
- BOOST_PP_STRINGIZE
|
||||||
|
- NS_SWIFT_NAME
|
||||||
|
- CF_SWIFT_NAME
|
||||||
|
...
|
||||||
|
|
||||||
8
.github/workflows/ci.yml
vendored
@@ -27,7 +27,7 @@ jobs:
|
|||||||
DOCKER_REGISTRY_USERNAME: ucentral
|
DOCKER_REGISTRY_USERNAME: ucentral
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout actions repo
|
- name: Checkout actions repo
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v3
|
||||||
with:
|
with:
|
||||||
repository: Telecominfraproject/.github
|
repository: Telecominfraproject/.github
|
||||||
path: github
|
path: github
|
||||||
@@ -58,11 +58,11 @@ jobs:
|
|||||||
- name: Get base branch name and set as output
|
- name: Get base branch name and set as output
|
||||||
id: get_base_branch
|
id: get_base_branch
|
||||||
run: |
|
run: |
|
||||||
echo ::set-output name=branch::$(echo ${GITHUB_BASE_REF##*/})
|
echo "branch=$(echo ${GITHUB_BASE_REF##*/})" >> $GITHUB_OUTPUT
|
||||||
echo ::set-output name=owgw_branch::$(echo ${GITHUB_BASE_REF##*/} | sed 's/main/master/g')
|
echo "owgw_branch=$(echo ${GITHUB_BASE_REF##*/} | sed 's/main/master/g')" >> $GITHUB_OUTPUT
|
||||||
|
|
||||||
- name: Checkout actions repo
|
- name: Checkout actions repo
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v3
|
||||||
with:
|
with:
|
||||||
repository: Telecominfraproject/.github
|
repository: Telecominfraproject/.github
|
||||||
path: github
|
path: github
|
||||||
|
|||||||
8
.github/workflows/cleanup.yml
vendored
@@ -17,4 +17,10 @@ jobs:
|
|||||||
steps:
|
steps:
|
||||||
- run: |
|
- run: |
|
||||||
export PR_BRANCH_TAG=$(echo ${GITHUB_HEAD_REF#refs/heads/} | tr '/' '-')
|
export PR_BRANCH_TAG=$(echo ${GITHUB_HEAD_REF#refs/heads/} | tr '/' '-')
|
||||||
curl -uucentral:${{ secrets.DOCKER_REGISTRY_PASSWORD }} -X DELETE "https://tip.jfrog.io/artifactory/tip-wlan-cloud-ucentral/owprov/$PR_BRANCH_TAG"
|
|
||||||
|
if [[ ! $PR_BRANCH_TAG =~ (main|master|release-*) ]]; then
|
||||||
|
echo "PR branch is $PR_BRANCH_TAG, deleting Docker image"
|
||||||
|
curl -s -uucentral:${{ secrets.DOCKER_REGISTRY_PASSWORD }} -X DELETE "https://tip.jfrog.io/artifactory/tip-wlan-cloud-ucentral/owprov/$PR_BRANCH_TAG"
|
||||||
|
else
|
||||||
|
echo "PR branch is $PR_BRANCH_TAG, not deleting Docker image"
|
||||||
|
fi
|
||||||
|
|||||||
2
.github/workflows/enforce-jira-issue-key.yml
vendored
@@ -11,7 +11,7 @@ jobs:
|
|||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout actions repo
|
- name: Checkout actions repo
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v3
|
||||||
with:
|
with:
|
||||||
repository: Telecominfraproject/.github
|
repository: Telecominfraproject/.github
|
||||||
path: github
|
path: github
|
||||||
|
|||||||
41
.github/workflows/openapi-pages.yml
vendored
Normal file
@@ -0,0 +1,41 @@
|
|||||||
|
name: Update OpenAPI docs on GitHub Pages
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
paths:
|
||||||
|
- 'openapi/**'
|
||||||
|
branches:
|
||||||
|
- main
|
||||||
|
workflow_dispatch:
|
||||||
|
|
||||||
|
defaults:
|
||||||
|
run:
|
||||||
|
shell: bash
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
docsgen:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
|
||||||
|
- name: Generate static HTML page with docs from OpenAPI definition
|
||||||
|
run: |
|
||||||
|
docker run --rm -v "${PWD}:/local" openapitools/openapi-generator-cli:v6.2.1 generate -i https://raw.githubusercontent.com/Telecominfraproject/wlan-cloud-owprov/main/openapi/owprov.yaml -g html2 --skip-validate-spec -o /local/
|
||||||
|
|
||||||
|
- name: Update OpenAPI docs
|
||||||
|
run: |
|
||||||
|
mkdir tmp-docs
|
||||||
|
mv index.html tmp-docs/index.html
|
||||||
|
mkdir -p ~/.ssh
|
||||||
|
ssh-keyscan -H github.com >> ~/.ssh/known_hosts
|
||||||
|
echo https://tip-automation:${{ secrets.GIT_PUSH_PAT }}@github.com > ~/.git-credentials
|
||||||
|
git config --global credential.helper store
|
||||||
|
git config --global user.email "tip-automation@telecominfraproject.com"
|
||||||
|
git config --global user.name "TIP Automation User"
|
||||||
|
git pull
|
||||||
|
git checkout gh-pages || git checkout -b gh-pages
|
||||||
|
rm -rf docs
|
||||||
|
mv tmp-docs docs
|
||||||
|
git add docs
|
||||||
|
git commit -m'Update OpenAPI docs for GitHub pages'
|
||||||
|
git push --set-upstream origin gh-pages
|
||||||
2
.github/workflows/release.yml
vendored
@@ -17,7 +17,7 @@ jobs:
|
|||||||
HELM_REPO_USERNAME: ucentral
|
HELM_REPO_USERNAME: ucentral
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout uCentral assembly chart repo
|
- name: Checkout uCentral assembly chart repo
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v3
|
||||||
with:
|
with:
|
||||||
path: wlan-cloud-owprov
|
path: wlan-cloud-owprov
|
||||||
|
|
||||||
|
|||||||
190
BUILDING.md
Normal file
@@ -0,0 +1,190 @@
|
|||||||
|
# Building from source
|
||||||
|
In order to build the OWPROV, you will need to install its dependencies, which includes the following:
|
||||||
|
- cmake
|
||||||
|
- boost
|
||||||
|
- POCO 1.10.1 or later
|
||||||
|
- a C++17 compiler
|
||||||
|
- openssl
|
||||||
|
- libpq-dev (PortgreSQL development libraries)
|
||||||
|
- mysql-client (MySQL client)
|
||||||
|
- librdkafka
|
||||||
|
- cppkafka
|
||||||
|
|
||||||
|
The build is done in 2 parts. The first part is to build a local copy of the framework tailored to your environment. This
|
||||||
|
framework is called [Poco](https://github.com/pocoproject/poco). The version used in this project has a couple of fixes
|
||||||
|
from the master copy needed for cmake. Please use the version of this [Poco fix](https://github.com/AriliaWireless/poco). Building
|
||||||
|
Poco may take several minutes depending on the platform you are building on.
|
||||||
|
|
||||||
|
## Ubuntu
|
||||||
|
These instructions have proven to work on Ubuntu 20.4.
|
||||||
|
```bash
|
||||||
|
sudo apt install git cmake g++ libssl-dev libmariadb-dev
|
||||||
|
sudo apt install libpq-dev libaprutil1-dev apache2-dev libboost-all-dev
|
||||||
|
sudo apt install librdkafka-dev // default-libmysqlclient-dev
|
||||||
|
sudo apt install nlohmann-json-dev
|
||||||
|
|
||||||
|
cd ~
|
||||||
|
git clone https://github.com/AriliaWireless/poco --branch poco-tip-v1
|
||||||
|
cd poco
|
||||||
|
mkdir cmake-build
|
||||||
|
cd cmake-build
|
||||||
|
cmake ..
|
||||||
|
cmake --build . --config Release
|
||||||
|
sudo cmake --build . --target install
|
||||||
|
|
||||||
|
cd ~
|
||||||
|
git clone https://github.com/AriliaWireless/cppkafka --branch tip-v1
|
||||||
|
cd cppkafka
|
||||||
|
mkdir cmake-build
|
||||||
|
cd cmake-build
|
||||||
|
cmake ..
|
||||||
|
cmake --build . --config Release
|
||||||
|
sudo cmake --build . --target install
|
||||||
|
|
||||||
|
cd ~
|
||||||
|
git clone https://github.com/AriliaWireless/valijson --branch tip-v1
|
||||||
|
cd valijson
|
||||||
|
mkdir cmake-build
|
||||||
|
cd cmake-build
|
||||||
|
cmake ..
|
||||||
|
cmake --build . --config Release
|
||||||
|
sudo cmake --build . --target install
|
||||||
|
|
||||||
|
git clone https://github.com/fmtlib/fmt --branch 9.0.0 /fmtlib
|
||||||
|
cd fmtlib
|
||||||
|
mkdir cmake-build
|
||||||
|
cd cmake-build
|
||||||
|
cmake ..
|
||||||
|
make
|
||||||
|
make install
|
||||||
|
|
||||||
|
cd ~
|
||||||
|
git clone https://github.com/Telecominfraproject/wlan-cloud-owprov
|
||||||
|
cd wlan-cloud-owprov
|
||||||
|
mkdir cmake-build
|
||||||
|
cd cmake-build
|
||||||
|
cmake ..
|
||||||
|
make -j 8
|
||||||
|
```
|
||||||
|
|
||||||
|
## Fedora
|
||||||
|
The following instructions have proven to work on Fedora 33
|
||||||
|
```bash
|
||||||
|
sudo yum install cmake g++ openssl-devel mysql-devel mysql apr-util-devel boost boost-devel
|
||||||
|
sudo yum install yaml-cpp-devel lua-devel
|
||||||
|
sudo dnf install postgresql.x86_64 librdkafka-devel
|
||||||
|
sudo dnf install postgresql-devel json-devel
|
||||||
|
|
||||||
|
git clone https://github.com/AriliaWireless/poco --branch poco-tip-v1
|
||||||
|
cd poco
|
||||||
|
mkdir cmake-build
|
||||||
|
cd cmake-build
|
||||||
|
cmake ..
|
||||||
|
cmake --build . --config Release
|
||||||
|
sudo cmake --build . --target install
|
||||||
|
|
||||||
|
git clone https://github.com/AriliaWireless/cppkafka --branch tip-v1
|
||||||
|
cd cppkafka
|
||||||
|
mkdir cmake-build
|
||||||
|
cd cmake-build
|
||||||
|
cmake ..
|
||||||
|
cmake --build . --config Release
|
||||||
|
sudo cmake --build . --target install
|
||||||
|
|
||||||
|
cd ~
|
||||||
|
git clone https://github.com/AriliaWireless/valijson --branch tip-v1
|
||||||
|
cd valijson
|
||||||
|
mkdir cmake-build
|
||||||
|
cd cmake-build
|
||||||
|
cmake ..
|
||||||
|
cmake --build . --config Release
|
||||||
|
sudo cmake --build . --target install
|
||||||
|
|
||||||
|
cd ~
|
||||||
|
git clone https://github.com/Telecominfraproject/wlan-cloud-owprov
|
||||||
|
cd wlan-cloud-owprov
|
||||||
|
mkdir cmake-build
|
||||||
|
cd cmake-build
|
||||||
|
cmake ..
|
||||||
|
make
|
||||||
|
```
|
||||||
|
|
||||||
|
## macOS Build
|
||||||
|
The following instructions have proven to work on macOS Big Sur. You need to install [Homebrew](https://brew.sh/). You must also have installed [XCode for OS X](https://www.freecodecamp.org/news/how-to-download-and-install-xcode/).
|
||||||
|
```bash
|
||||||
|
brew install openssl \
|
||||||
|
cmake \
|
||||||
|
libpq \
|
||||||
|
mysql-client \
|
||||||
|
apr \
|
||||||
|
apr-util \
|
||||||
|
boost \
|
||||||
|
yaml-cpp \
|
||||||
|
postgresql \
|
||||||
|
librdkafka \
|
||||||
|
nlohmann-json \
|
||||||
|
fmt
|
||||||
|
|
||||||
|
git clone https://github.com/AriliaWireless/poco --branch poco-tip-v1
|
||||||
|
pushd poco
|
||||||
|
mkdir cmake-build
|
||||||
|
push cmake-build
|
||||||
|
cmake -DOPENSSL_ROOT_DIR=</path/to/openssl> -DENABLE_NETSSL=1 -DENABLE_JWT=1 -DENABLE_CRYPTO=1 ..
|
||||||
|
cmake --build . --config Release
|
||||||
|
sudo cmake --build . --target install
|
||||||
|
popd
|
||||||
|
popd
|
||||||
|
|
||||||
|
git clone https://github.com/AriliaWireless/cppkafka --branch tip-v1
|
||||||
|
pushd cppkafka
|
||||||
|
mkdir cmake-build
|
||||||
|
pushd cmake-build
|
||||||
|
cmake ..
|
||||||
|
cmake --build . --config Release
|
||||||
|
sudo cmake --build . --target install
|
||||||
|
popd
|
||||||
|
popd
|
||||||
|
|
||||||
|
git clone https://github.com/AriliaWireless/valijson --branch tip-v1
|
||||||
|
cd valijson
|
||||||
|
mkdir cmake-build
|
||||||
|
cd cmake-build
|
||||||
|
cmake ..
|
||||||
|
cmake --build . --config Release
|
||||||
|
sudo cmake --build . --target install
|
||||||
|
popd
|
||||||
|
popd
|
||||||
|
|
||||||
|
git clone https://github.com/Telecominfraproject/wlan-cloud-owprov
|
||||||
|
pushd wlan-cloud-owprov
|
||||||
|
mkdir cmake-build
|
||||||
|
pushd cmake-build
|
||||||
|
cmake ..
|
||||||
|
make -j
|
||||||
|
popd
|
||||||
|
popd
|
||||||
|
```
|
||||||
|
|
||||||
|
## Raspberry
|
||||||
|
The build on a rPI takes a while. You can shorten that build time and requirements by disabling all the larger database
|
||||||
|
support. You can build with only SQLite support by not installing the packages for PostgreSQL, and MySQL by
|
||||||
|
adding -DSMALL_BUILD=1 on the cmake build line.
|
||||||
|
|
||||||
|
```bash
|
||||||
|
sudo apt install git cmake g++ libssl-dev libaprutil1-dev apache2-dev libboost-all-dev libyaml-cpp-dev
|
||||||
|
git clone https://github.com/stephb9959/poco
|
||||||
|
cd poco
|
||||||
|
mkdir cmake-build
|
||||||
|
cd cmake-build
|
||||||
|
cmake ..
|
||||||
|
cmake --build . --config Release
|
||||||
|
sudo cmake --build . --target install
|
||||||
|
|
||||||
|
cd ~
|
||||||
|
git clone https://github.com/Telecominfraproject/wlan-cloud-owprov
|
||||||
|
cd wlan-cloud-owprov
|
||||||
|
mkdir cmake-build
|
||||||
|
cd cmake-build
|
||||||
|
cmake -DSMALL_BUILD=1 ..
|
||||||
|
make
|
||||||
|
```
|
||||||
110
CMakeLists.txt
@@ -1,5 +1,5 @@
|
|||||||
cmake_minimum_required(VERSION 3.13)
|
cmake_minimum_required(VERSION 3.13)
|
||||||
project(owprov VERSION 2.6.0)
|
project(owprov VERSION 2.9.0)
|
||||||
|
|
||||||
set(CMAKE_CXX_STANDARD 17)
|
set(CMAKE_CXX_STANDARD 17)
|
||||||
|
|
||||||
@@ -27,12 +27,12 @@ endif()
|
|||||||
|
|
||||||
find_package(Git QUIET)
|
find_package(Git QUIET)
|
||||||
if(GIT_FOUND AND EXISTS "${PROJECT_SOURCE_DIR}/.git")
|
if(GIT_FOUND AND EXISTS "${PROJECT_SOURCE_DIR}/.git")
|
||||||
execute_process(COMMAND ${GIT_EXECUTABLE} describe --always --tags
|
execute_process(COMMAND ${GIT_EXECUTABLE} rev-parse --short HEAD
|
||||||
WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}
|
WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}
|
||||||
RESULT_VARIABLE GIT_RESULT
|
RESULT_VARIABLE GIT_RESULT
|
||||||
OUTPUT_VARIABLE GIT_HASH)
|
OUTPUT_VARIABLE GIT_HASH)
|
||||||
if(NOT GIT_RESULT EQUAL "0")
|
if(NOT GIT_RESULT EQUAL "0")
|
||||||
message(FATAL_ERROR "git describe --always --tags failed with ${GIT_RESULT}")
|
message(FATAL_ERROR "git rev-parse --short HEAD failed with ${GIT_RESULT}")
|
||||||
endif()
|
endif()
|
||||||
string(REGEX REPLACE "\n$" "" GIT_HASH "${GIT_HASH}")
|
string(REGEX REPLACE "\n$" "" GIT_HASH "${GIT_HASH}")
|
||||||
endif()
|
endif()
|
||||||
@@ -40,10 +40,11 @@ endif()
|
|||||||
add_definitions(-DAWS_CUSTOM_MEMORY_MANAGEMENT)
|
add_definitions(-DAWS_CUSTOM_MEMORY_MANAGEMENT)
|
||||||
|
|
||||||
find_package(OpenSSL REQUIRED)
|
find_package(OpenSSL REQUIRED)
|
||||||
|
find_package(ZLIB REQUIRED)
|
||||||
find_package(Poco REQUIRED COMPONENTS Crypto JWT Net Util NetSSL Data DataSQLite)
|
find_package(Poco REQUIRED COMPONENTS Crypto JWT Net Util NetSSL Data DataSQLite)
|
||||||
find_package(nlohmann_json REQUIRED)
|
find_package(nlohmann_json REQUIRED)
|
||||||
find_package(nlohmann_json_schema_validator REQUIRED)
|
|
||||||
find_package(fmt REQUIRED)
|
find_package(fmt REQUIRED)
|
||||||
|
# find_package(valijson REQUIRED)
|
||||||
|
|
||||||
if(SMALL_BUILD)
|
if(SMALL_BUILD)
|
||||||
find_package(Poco REQUIRED COMPONENTS Crypto JWT Net Util NetSSL Data DataSQLite)
|
find_package(Poco REQUIRED COMPONENTS Crypto JWT Net Util NetSSL Data DataSQLite)
|
||||||
@@ -58,6 +59,8 @@ include_directories(/usr/local/include /usr/local/opt/openssl/include src inclu
|
|||||||
|
|
||||||
configure_file(src/ow_version.h.in ${PROJECT_SOURCE_DIR}/src/ow_version.h @ONLY)
|
configure_file(src/ow_version.h.in ${PROJECT_SOURCE_DIR}/src/ow_version.h @ONLY)
|
||||||
|
|
||||||
|
add_definitions(-DPOCO_LOG_DEBUG="1")
|
||||||
|
|
||||||
add_compile_options(-Wall -Wextra)
|
add_compile_options(-Wall -Wextra)
|
||||||
if(ASAN)
|
if(ASAN)
|
||||||
add_compile_options(-fsanitize=address)
|
add_compile_options(-fsanitize=address)
|
||||||
@@ -73,18 +76,63 @@ add_executable(owprov
|
|||||||
src/framework/OpenWifiTypes.h
|
src/framework/OpenWifiTypes.h
|
||||||
src/framework/orm.h
|
src/framework/orm.h
|
||||||
src/framework/StorageClass.h
|
src/framework/StorageClass.h
|
||||||
|
src/framework/MicroServiceErrorHandler.h
|
||||||
|
src/framework/UI_WebSocketClientServer.cpp
|
||||||
|
src/framework/UI_WebSocketClientServer.h
|
||||||
|
src/framework/utils.h
|
||||||
|
src/framework/utils.cpp
|
||||||
|
src/framework/AppServiceRegistry.h
|
||||||
|
src/framework/SubSystemServer.cpp
|
||||||
|
src/framework/SubSystemServer.h
|
||||||
|
src/framework/RESTAPI_utils.h
|
||||||
|
src/framework/UI_WebSocketClientNotifications.cpp
|
||||||
|
src/framework/AuthClient.cpp
|
||||||
|
src/framework/AuthClient.h
|
||||||
|
src/framework/MicroServiceNames.h
|
||||||
|
src/framework/MicroServiceFuncs.h
|
||||||
|
src/framework/OpenAPIRequests.cpp
|
||||||
|
src/framework/OpenAPIRequests.h
|
||||||
|
src/framework/MicroServiceFuncs.cpp
|
||||||
|
src/framework/ALBserver.cpp
|
||||||
|
src/framework/ALBserver.h
|
||||||
|
src/framework/KafkaManager.cpp
|
||||||
|
src/framework/KafkaManager.h
|
||||||
|
src/framework/RESTAPI_RateLimiter.h
|
||||||
|
src/framework/WebSocketLogger.h
|
||||||
|
src/framework/RESTAPI_GenericServerAccounting.h
|
||||||
|
src/framework/CIDR.h
|
||||||
|
src/framework/RESTAPI_Handler.cpp
|
||||||
|
src/framework/RESTAPI_Handler.h
|
||||||
|
src/framework/RESTAPI_ExtServer.h
|
||||||
|
src/framework/RESTAPI_ExtServer.cpp
|
||||||
|
src/framework/RESTAPI_IntServer.cpp
|
||||||
|
src/framework/RESTAPI_IntServer.h
|
||||||
|
src/framework/RESTAPI_SystemCommand.h
|
||||||
|
src/framework/RESTAPI_WebSocketServer.h
|
||||||
|
src/framework/RESTAPI_SystemConfiguration.h
|
||||||
|
src/framework/EventBusManager.cpp
|
||||||
|
src/framework/EventBusManager.h
|
||||||
|
src/framework/RESTAPI_PartHandler.h
|
||||||
|
src/framework/MicroService.cpp
|
||||||
|
src/framework/MicroServiceExtra.h
|
||||||
src/framework/ConfigurationValidator.cpp
|
src/framework/ConfigurationValidator.cpp
|
||||||
src/framework/ConfigurationValidator.h
|
src/framework/ConfigurationValidator.h
|
||||||
src/framework/ow_constants.h
|
src/UI_Prov_WebSocketNotifications.h
|
||||||
src/framework/WebSocketClientNotifications.h
|
src/UI_Prov_WebSocketNotifications.cpp
|
||||||
src/RESTObjects/RESTAPI_SecurityObjects.h src/RESTObjects/RESTAPI_SecurityObjects.cpp
|
src/RESTObjects/RESTAPI_SecurityObjects.h src/RESTObjects/RESTAPI_SecurityObjects.cpp
|
||||||
src/RESTObjects/RESTAPI_ProvObjects.cpp src/RESTObjects/RESTAPI_ProvObjects.h
|
|
||||||
src/RESTObjects/RESTAPI_GWobjects.h src/RESTObjects/RESTAPI_GWobjects.cpp
|
src/RESTObjects/RESTAPI_GWobjects.h src/RESTObjects/RESTAPI_GWobjects.cpp
|
||||||
src/RESTObjects/RESTAPI_FMSObjects.h src/RESTObjects/RESTAPI_FMSObjects.cpp
|
src/RESTObjects/RESTAPI_FMSObjects.h src/RESTObjects/RESTAPI_FMSObjects.cpp
|
||||||
|
src/RESTObjects/RESTAPI_CertObjects.cpp src/RESTObjects/RESTAPI_CertObjects.h
|
||||||
|
src/RESTObjects/RESTAPI_OWLSobjects.cpp src/RESTObjects/RESTAPI_OWLSobjects.h
|
||||||
|
src/RESTObjects/RESTAPI_ProvObjects.cpp src/RESTObjects/RESTAPI_ProvObjects.h
|
||||||
|
src/RESTObjects/RESTAPI_AnalyticsObjects.cpp src/RESTObjects/RESTAPI_AnalyticsObjects.h
|
||||||
|
src/RESTObjects/RESTAPI_SubObjects.cpp src/RESTObjects/RESTAPI_SubObjects.h
|
||||||
|
|
||||||
src/RESTAPI/RESTAPI_routers.cpp
|
src/RESTAPI/RESTAPI_routers.cpp
|
||||||
src/Daemon.cpp src/Daemon.h
|
src/Daemon.cpp src/Daemon.h
|
||||||
src/Dashboard.h src/Dashboard.cpp
|
src/Dashboard.h src/Dashboard.cpp
|
||||||
src/StorageService.cpp src/StorageService.h
|
src/StorageService.cpp src/StorageService.h
|
||||||
|
|
||||||
src/storage/storage_entity.cpp src/storage/storage_entity.h
|
src/storage/storage_entity.cpp src/storage/storage_entity.h
|
||||||
src/storage/storage_policies.cpp src/storage/storage_policies.h
|
src/storage/storage_policies.cpp src/storage/storage_policies.h
|
||||||
src/storage/storage_venue.cpp src/storage/storage_venue.h
|
src/storage/storage_venue.cpp src/storage/storage_venue.h
|
||||||
@@ -94,6 +142,14 @@ add_executable(owprov
|
|||||||
src/storage/storage_management_roles.cpp src/storage/storage_management_roles.h
|
src/storage/storage_management_roles.cpp src/storage/storage_management_roles.h
|
||||||
src/storage/storage_configurations.cpp src/storage/storage_configurations.h
|
src/storage/storage_configurations.cpp src/storage/storage_configurations.h
|
||||||
src/storage/storage_tags.cpp src/storage/storage_tags.h
|
src/storage/storage_tags.cpp src/storage/storage_tags.h
|
||||||
|
src/storage/storage_operataor.cpp src/storage/storage_operataor.h
|
||||||
|
src/storage/storage_sub_devices.cpp src/storage/storage_sub_devices.h
|
||||||
|
src/storage/storage_service_class.cpp src/storage/storage_service_class.h
|
||||||
|
src/storage/storage_maps.cpp src/storage/storage_maps.h
|
||||||
|
src/storage/storage_signup.cpp src/storage/storage_signup.h
|
||||||
|
src/storage/storage_variables.cpp src/storage/storage_variables.h
|
||||||
|
src/storage/storage_overrides.cpp src/storage/storage_overrides.h
|
||||||
|
|
||||||
src/RESTAPI/RESTAPI_entity_handler.cpp src/RESTAPI/RESTAPI_entity_handler.h
|
src/RESTAPI/RESTAPI_entity_handler.cpp src/RESTAPI/RESTAPI_entity_handler.h
|
||||||
src/RESTAPI/RESTAPI_contact_handler.cpp src/RESTAPI/RESTAPI_contact_handler.h
|
src/RESTAPI/RESTAPI_contact_handler.cpp src/RESTAPI/RESTAPI_contact_handler.h
|
||||||
src/RESTAPI/RESTAPI_location_handler.cpp src/RESTAPI/RESTAPI_location_handler.h
|
src/RESTAPI/RESTAPI_location_handler.cpp src/RESTAPI/RESTAPI_location_handler.h
|
||||||
@@ -113,6 +169,13 @@ add_executable(owprov
|
|||||||
src/RESTAPI/RESTAPI_iptocountry_handler.cpp src/RESTAPI/RESTAPI_iptocountry_handler.h
|
src/RESTAPI/RESTAPI_iptocountry_handler.cpp src/RESTAPI/RESTAPI_iptocountry_handler.h
|
||||||
src/RESTAPI/RESTAPI_signup_handler.h src/RESTAPI/RESTAPI_signup_handler.cpp
|
src/RESTAPI/RESTAPI_signup_handler.h src/RESTAPI/RESTAPI_signup_handler.cpp
|
||||||
src/RESTAPI/RESTAPI_asset_server.cpp src/RESTAPI/RESTAPI_asset_server.h
|
src/RESTAPI/RESTAPI_asset_server.cpp src/RESTAPI/RESTAPI_asset_server.h
|
||||||
|
src/RESTAPI/RESTAPI_db_helpers.h
|
||||||
|
src/RESTAPI/RESTAPI_map_handler.cpp src/RESTAPI/RESTAPI_map_handler.h
|
||||||
|
src/RESTAPI/RESTAPI_map_list_handler.cpp src/RESTAPI/RESTAPI_map_list_handler.h
|
||||||
|
src/RESTAPI/RESTAPI_variables_handler.cpp src/RESTAPI/RESTAPI_variables_handler.h
|
||||||
|
src/RESTAPI/RESTAPI_variables_list_handler.cpp src/RESTAPI/RESTAPI_variables_list_handler.h
|
||||||
|
src/RESTAPI/RESTAPI_overrides_handler.cpp src/RESTAPI/RESTAPI_overrides_handler.h
|
||||||
|
|
||||||
src/FindCountry.h
|
src/FindCountry.h
|
||||||
src/sdks/SDK_gw.cpp src/sdks/SDK_gw.h
|
src/sdks/SDK_gw.cpp src/sdks/SDK_gw.h
|
||||||
src/sdks/SDK_prov.cpp src/sdks/SDK_prov.h
|
src/sdks/SDK_prov.cpp src/sdks/SDK_prov.h
|
||||||
@@ -122,26 +185,35 @@ add_executable(owprov
|
|||||||
src/AutoDiscovery.cpp src/AutoDiscovery.h
|
src/AutoDiscovery.cpp src/AutoDiscovery.h
|
||||||
src/ConfigSanityChecker.cpp src/ConfigSanityChecker.h
|
src/ConfigSanityChecker.cpp src/ConfigSanityChecker.h
|
||||||
src/TagServer.cpp src/TagServer.h
|
src/TagServer.cpp src/TagServer.h
|
||||||
src/RESTAPI/RESTAPI_db_helpers.h
|
|
||||||
src/JobController.cpp src/JobController.h
|
src/JobController.cpp src/JobController.h
|
||||||
src/JobRegistrations.cpp
|
src/JobRegistrations.cpp
|
||||||
src/storage/storage_jobs.cpp src/storage/storage_jobs.h
|
|
||||||
src/storage/storage_maps.cpp src/storage/storage_maps.h
|
|
||||||
src/RESTAPI/RESTAPI_map_handler.cpp src/RESTAPI/RESTAPI_map_handler.h
|
|
||||||
src/RESTAPI/RESTAPI_map_list_handler.cpp src/RESTAPI/RESTAPI_map_list_handler.h
|
|
||||||
src/storage/storage_signup.cpp src/storage/storage_signup.h
|
|
||||||
src/Signup.cpp src/Signup.h
|
src/Signup.cpp src/Signup.h
|
||||||
src/DeviceTypeCache.h
|
src/DeviceTypeCache.h
|
||||||
src/storage/storage_variables.cpp src/storage/storage_variables.h
|
src/FileDownloader.cpp src/FileDownloader.h
|
||||||
src/RESTAPI/RESTAPI_variables_handler.cpp src/RESTAPI/RESTAPI_variables_handler.h
|
src/Tasks/VenueConfigUpdater.h
|
||||||
src/RESTAPI/RESTAPI_variables_list_handler.cpp src/RESTAPI/RESTAPI_variables_list_handler.h
|
src/libs/croncpp.h
|
||||||
src/FileDownloader.cpp src/FileDownloader.h src/Tasks/VenueConfigUpdater.h src/Kafka_ProvUpdater.cpp src/Kafka_ProvUpdater.h src/storage/storage_operataor.cpp src/storage/storage_operataor.h src/storage/storage_sub_devices.cpp src/storage/storage_sub_devices.h src/storage/storage_service_class.cpp src/storage/storage_service_class.h src/RESTAPI/RESTAPI_sub_devices_list_handler.cpp src/RESTAPI/RESTAPI_sub_devices_list_handler.h src/RESTAPI/RESTAPI_sub_devices_handler.cpp src/RESTAPI/RESTAPI_sub_devices_handler.h src/RESTAPI/RESTAPI_service_class_list_handler.cpp src/RESTAPI/RESTAPI_service_class_list_handler.h src/RESTAPI/RESTAPI_service_class_handler.cpp src/RESTAPI/RESTAPI_service_class_handler.h src/RESTAPI/RESTAPI_operators_list_handler.cpp src/RESTAPI/RESTAPI_operators_list_handler.h src/RESTAPI/RESTAPI_operators_handler.cpp src/RESTAPI/RESTAPI_operators_handler.h src/storage/storage_op_contacts.cpp src/storage/storage_op_contacts.h src/storage/storage_op_locations.cpp src/storage/storage_op_locations.h src/RESTAPI/RESTAPI_op_contact_list_handler.cpp src/RESTAPI/RESTAPI_op_contact_list_handler.h src/RESTAPI/RESTAPI_op_contact_handler.cpp src/RESTAPI/RESTAPI_op_contact_handler.h src/RESTAPI/RESTAPI_op_location_list_handler.cpp src/RESTAPI/RESTAPI_op_location_list_handler.h src/RESTAPI/RESTAPI_op_location_handler.cpp src/RESTAPI/RESTAPI_op_location_handler.h src/ProvWebSocketClient.cpp src/ProvWebSocketClient.h src/Tasks/VenueRebooter.h src/Tasks/VenueUpgrade.h src/sdks/SDK_fms.cpp src/sdks/SDK_fms.h)
|
src/Kafka_ProvUpdater.cpp src/Kafka_ProvUpdater.h
|
||||||
|
src/RESTAPI/RESTAPI_sub_devices_list_handler.cpp src/RESTAPI/RESTAPI_sub_devices_list_handler.h
|
||||||
|
src/RESTAPI/RESTAPI_sub_devices_handler.cpp src/RESTAPI/RESTAPI_sub_devices_handler.h
|
||||||
|
src/RESTAPI/RESTAPI_service_class_list_handler.cpp src/RESTAPI/RESTAPI_service_class_list_handler.h
|
||||||
|
src/RESTAPI/RESTAPI_service_class_handler.cpp src/RESTAPI/RESTAPI_service_class_handler.h
|
||||||
|
src/RESTAPI/RESTAPI_operators_list_handler.cpp src/RESTAPI/RESTAPI_operators_list_handler.h
|
||||||
|
src/RESTAPI/RESTAPI_operators_handler.cpp src/RESTAPI/RESTAPI_operators_handler.h
|
||||||
|
src/storage/storage_op_contacts.cpp src/storage/storage_op_contacts.h
|
||||||
|
src/storage/storage_op_locations.cpp src/storage/storage_op_locations.h
|
||||||
|
src/RESTAPI/RESTAPI_op_contact_list_handler.cpp src/RESTAPI/RESTAPI_op_contact_list_handler.h
|
||||||
|
src/RESTAPI/RESTAPI_op_contact_handler.cpp src/RESTAPI/RESTAPI_op_contact_handler.h
|
||||||
|
src/RESTAPI/RESTAPI_op_location_list_handler.cpp src/RESTAPI/RESTAPI_op_location_list_handler.h
|
||||||
|
src/RESTAPI/RESTAPI_op_location_handler.cpp src/RESTAPI/RESTAPI_op_location_handler.h
|
||||||
|
src/ProvWebSocketClient.cpp src/ProvWebSocketClient.h
|
||||||
|
src/Tasks/VenueRebooter.h src/Tasks/VenueUpgrade.h
|
||||||
|
src/sdks/SDK_fms.cpp src/sdks/SDK_fms.h
|
||||||
|
src/RESTAPI/RESTAPI_overrides_handler.cpp src/RESTAPI/RESTAPI_overrides_handler.h)
|
||||||
|
|
||||||
target_link_libraries(owprov PUBLIC
|
target_link_libraries(owprov PUBLIC
|
||||||
${Poco_LIBRARIES}
|
${Poco_LIBRARIES}
|
||||||
${MySQL_LIBRARIES}
|
${MySQL_LIBRARIES}
|
||||||
${ZLIB_LIBRARIES}
|
${ZLIB_LIBRARIES}
|
||||||
CppKafka::cppkafka
|
CppKafka::cppkafka
|
||||||
fmt::fmt
|
fmt::fmt)
|
||||||
nlohmann_json_schema_validator)
|
|
||||||
|
|
||||||
|
|||||||
243
CONFIGURATION.md
Normal file
@@ -0,0 +1,243 @@
|
|||||||
|
# OWPROV Configuration
|
||||||
|
Here is the list of parameters you can configure in the `owprov.properties` file.
|
||||||
|
|
||||||
|
## OWPROV Specific Parameters
|
||||||
|
### Default firmware management rules
|
||||||
|
FMS is already integrated with OpenWifi. In order to allow it to upgrade devices automatically, you should
|
||||||
|
set the following values.
|
||||||
|
```properties
|
||||||
|
firmware.updater.upgrade = <true/false>
|
||||||
|
firmware.updater.releaseonly = <true/false>
|
||||||
|
```
|
||||||
|
#### firmware.updater.upgrade
|
||||||
|
Should FMS attempt to upgrade devices by default.
|
||||||
|
|
||||||
|
#### firmware.updater.releaseonly
|
||||||
|
Should only RC software be used during upgrades.
|
||||||
|
|
||||||
|
### Google Map API Key
|
||||||
|
To support geocoding help, you need to configuration the following in the configuration file. Geocoding is used
|
||||||
|
when creating location and when reporting analytics.
|
||||||
|
```properties
|
||||||
|
geocodeapi = google
|
||||||
|
google.apikey = ********************************
|
||||||
|
```
|
||||||
|
|
||||||
|
### IP to Country Parameters
|
||||||
|
The controller has the ability to find the location of the IP of each Access Points. This uses an external IP location service. Currently,
|
||||||
|
the controller supports 3 services. Please note that these services will require to obtain an API key or token, and these may cause you to incur
|
||||||
|
additional fees. Here is the list of the services supported:
|
||||||
|
- ip2location: ip2location.com
|
||||||
|
- ipdata: ipdata.co
|
||||||
|
- ipinfo: ipinfo.io
|
||||||
|
|
||||||
|
```properties
|
||||||
|
iptocountry.default = US
|
||||||
|
iptocountry.provider = ipinfo
|
||||||
|
#iptocountry.provider = ipdata
|
||||||
|
#iptocountry.provider = ip2location
|
||||||
|
iptocountry.ipinfo.token =
|
||||||
|
iptocountry.ipdata.apikey =
|
||||||
|
iptocountry.ip2location.apikey =
|
||||||
|
```
|
||||||
|
|
||||||
|
#### iptocountry.default
|
||||||
|
This is the country code to be used if no information can be found at one of the providers or you have not configured any of the providers.
|
||||||
|
|
||||||
|
#### iptocountry.provider
|
||||||
|
You must select onf of the possible services and the fill the appropriate token or api key parameter.
|
||||||
|
|
||||||
|
## Generic OpenWiFi SDK parameters
|
||||||
|
### REST API External parameters
|
||||||
|
These are the parameters required for the configuration of the external facing REST API server
|
||||||
|
```properties
|
||||||
|
openwifi.restapi.host.0.backlog = 100
|
||||||
|
openwifi.restapi.host.0.security = relaxed
|
||||||
|
openwifi.restapi.host.0.rootca = $OWPROV_ROOT/certs/restapi-ca.pem
|
||||||
|
openwifi.restapi.host.0.address = *
|
||||||
|
openwifi.restapi.host.0.port = 16004
|
||||||
|
openwifi.restapi.host.0.cert = $OWPROV_ROOT/certs/restapi-cert.pem
|
||||||
|
openwifi.restapi.host.0.key = $OWPROV_ROOT/certs/restapi-key.pem
|
||||||
|
openwifi.restapi.host.0.key.password = mypassword
|
||||||
|
```
|
||||||
|
|
||||||
|
#### openwifi.restapi.host.0.backlog
|
||||||
|
This is the number of concurrent REST API calls that maybe be kept in the backlog for processing. That's a good rule of thumb. Never go above 500.
|
||||||
|
#### openwifi.restapi.host.0.rootca
|
||||||
|
This is the root file of your own certificate CA in `pem` format.
|
||||||
|
#### openwifi.restapi.host.0.cert
|
||||||
|
This is your own server certificate in `pem` format..
|
||||||
|
#### openwifi.restapi.host.0.key
|
||||||
|
This is the private key associated with your own certificate in `pem` format.
|
||||||
|
#### openwifi.restapi.host.0.address
|
||||||
|
Leve this a `*` in the case you want to bind to all interfaces on your gateway host or select the address of a single interface.
|
||||||
|
#### openwifi.restapi.host.0.port
|
||||||
|
The port on which the REST API server is listening. By default, this is 16002.
|
||||||
|
#### openwifi.restapi.host.0.security
|
||||||
|
Leave this as `relaxed` for now for devices.
|
||||||
|
#### openwifi.restapi.host.0.key.password
|
||||||
|
If you key file uses a password, please enter it here.
|
||||||
|
|
||||||
|
### REST API Intra microservice parameters
|
||||||
|
The following parameters describe the configuration for the inter-microservice HTTP server. You may use the same certificate/key
|
||||||
|
you are using for your extenral server or another certificate.
|
||||||
|
```properties
|
||||||
|
openwifi.internal.restapi.host.0.backlog = 100
|
||||||
|
openwifi.internal.restapi.host.0.security = relaxed
|
||||||
|
openwifi.internal.restapi.host.0.rootca = $OWPROV_ROOT/certs/restapi-ca.pem
|
||||||
|
openwifi.internal.restapi.host.0.address = *
|
||||||
|
openwifi.internal.restapi.host.0.port = 17004
|
||||||
|
openwifi.internal.restapi.host.0.cert = $OWPROV_ROOT/certs/restapi-cert.pem
|
||||||
|
openwifi.internal.restapi.host.0.key = $OWPROV_ROOT/certs/restapi-key.pem
|
||||||
|
openwifi.internal.restapi.host.0.key.password = mypassword
|
||||||
|
```
|
||||||
|
|
||||||
|
#### openwifi.internal.host.0.backlog
|
||||||
|
This is the number of concurrent REST API calls that maybe be kept in the backlog for processing. That's a good rule of thumb. Never go above 500.
|
||||||
|
#### openwifi.internal.host.0.rootca
|
||||||
|
This is the root file of your own certificate CA in `pem` format.
|
||||||
|
#### openwifi.internal.host.0.cert
|
||||||
|
This is your own server certificate in `pem` format..
|
||||||
|
#### openwifi.internal.host.0.key
|
||||||
|
This is the private key associated with your own certificate in `pem` format.
|
||||||
|
#### openwifi.internal.host.0.address
|
||||||
|
Leve this a `*` in the case you want to bind to all interfaces on your gateway host or select the address of a single interface.
|
||||||
|
#### openwifi.internal.host.0.port
|
||||||
|
The port on which the REST API server is listening. By default, this is 17002.
|
||||||
|
#### openwifi.internal.host.0.security
|
||||||
|
Leave this as `relaxed` for now for devices.
|
||||||
|
#### openwifi.internal.host.0.key.password
|
||||||
|
If you key file uses a password, please enter it here.
|
||||||
|
|
||||||
|
### Microservice information
|
||||||
|
These are different Microservie parameters. Following is a brief explanation.
|
||||||
|
```properties
|
||||||
|
openwifi.service.key = $OWPROV_ROOT/certs/restapi-key.pem
|
||||||
|
openwifi.service.key.password = mypassword
|
||||||
|
openwifi.system.data = $OWPROV_ROOT/data
|
||||||
|
openwifi.system.uri.private = https://localhost:17004
|
||||||
|
openwifi.system.uri.public = https://ucentral.example.com:16004
|
||||||
|
openwifi.system.uri.ui = https://provisionins-ui.example.com
|
||||||
|
openwifi.security.restapi.disable = false
|
||||||
|
openwifi.system.commandchannel = /tmp/app.ucentralprov
|
||||||
|
openwifi.autoprovisioning = true
|
||||||
|
```
|
||||||
|
#### openwifi.service.key
|
||||||
|
From time to time, the microservice must encrypt information. This is the key it should use. You may use the
|
||||||
|
same keey as you RESTAPI or your server.
|
||||||
|
#### openwifi.service.key.password
|
||||||
|
The password for the `openwifi.service.key`
|
||||||
|
#### openwifi.system.data
|
||||||
|
The location of system data. This path must exist.
|
||||||
|
#### openwifi.system.uri.private
|
||||||
|
The URI to reach the controller on the internal port.
|
||||||
|
#### openwifi.system.uri.public
|
||||||
|
The URI to reach the controller from the outside world.
|
||||||
|
#### openwifi.system.uri.ui
|
||||||
|
The URI of the UI to manage this service
|
||||||
|
#### openwifi.security.restapi.disable
|
||||||
|
This allows to disable security for internal and external API calls. This should only be used if the controller
|
||||||
|
sits behind an application load balancer that will actually do TLS. Setting this to `true` disables security.
|
||||||
|
#### openwifi.system.commandchannel
|
||||||
|
The UNIX socket command channel used by this service.
|
||||||
|
#### openwifi.autoprovisioning
|
||||||
|
Allow unknown devices to be provisioned by the system.
|
||||||
|
|
||||||
|
### ALB Support
|
||||||
|
In order to support an application load balancer health check verification, your need to provide the following parameters.
|
||||||
|
```properties
|
||||||
|
alb.enable = true
|
||||||
|
alb.port = 16104
|
||||||
|
```
|
||||||
|
|
||||||
|
### Kafka
|
||||||
|
The controller use Kafka, like all the other microservices. You must configure the kafka section in order for the
|
||||||
|
system to work.
|
||||||
|
```properties
|
||||||
|
openwifi.kafka.group.id = provisioning
|
||||||
|
openwifi.kafka.client.id = provisioning1
|
||||||
|
openwifi.kafka.enable = true
|
||||||
|
openwifi.kafka.brokerlist = my_Kafka.example.com:9092
|
||||||
|
openwifi.kafka.auto.commit = false
|
||||||
|
openwifi.kafka.queue.buffering.max.ms = 50
|
||||||
|
```
|
||||||
|
|
||||||
|
### openwifi.kafka.group.id
|
||||||
|
The group ID is a single word that should identify the type of service tuning. In the case `provisioning`
|
||||||
|
### openwifi.kafka.client.id
|
||||||
|
The client ID is a single service within that group ID. Each participant must have a unique client ID.
|
||||||
|
### openwifi.kafka.enable
|
||||||
|
Kafka should always be enabled.
|
||||||
|
### openwifi.kafka.brokerlist
|
||||||
|
The list of servers where your Kafka server is running. Comma separated.
|
||||||
|
### openwifi.kafka.auto.commit
|
||||||
|
Auto commit flag in Kafka. Leave as `false`.
|
||||||
|
### openwifi.kafka.queue.buffering.max.ms
|
||||||
|
Kafka buffering. Leave as `50`.
|
||||||
|
### Kafka security
|
||||||
|
If you intend to use SSL, you should look into Kafka Connect and specify the certificates below.
|
||||||
|
```properties
|
||||||
|
penwifi.kafka.ssl.ca.location =
|
||||||
|
openwifi.kafka.ssl.certificate.location =
|
||||||
|
openwifi.kafka.ssl.key.location =
|
||||||
|
openwifi.kafka.ssl.key.password =
|
||||||
|
```
|
||||||
|
|
||||||
|
### DB Type
|
||||||
|
The controller supports 3 types of Database. SQLite should only be used for sites with less than 100 APs or for testing in the lab.
|
||||||
|
In order to select which database to use, you must set the `storage.type` value to sqlite, postgresql, or mysql.
|
||||||
|
|
||||||
|
```properties
|
||||||
|
storage.type = sqlite
|
||||||
|
#storage.type = postgresql
|
||||||
|
#storage.type = mysql
|
||||||
|
```
|
||||||
|
|
||||||
|
### Storage SQLite parameters
|
||||||
|
Additional parameters to set for SQLite. The only important one is `storage.type.sqlite.db` which is the database name on disk.
|
||||||
|
```properties
|
||||||
|
storage.type.sqlite.db = provisioning.db
|
||||||
|
storage.type.sqlite.idletime = 120
|
||||||
|
storage.type.sqlite.maxsessions = 128
|
||||||
|
```
|
||||||
|
|
||||||
|
### Storage Postgres
|
||||||
|
Additional parameters to set if you select Postgres for your database. You must specify `host`, `username`, `password`,
|
||||||
|
`database`, and `port`.
|
||||||
|
```properties
|
||||||
|
storage.type.postgresql.maxsessions = 64
|
||||||
|
storage.type.postgresql.idletime = 60
|
||||||
|
storage.type.postgresql.host = localhost
|
||||||
|
storage.type.postgresql.username = provisioning
|
||||||
|
storage.type.postgresql.password = provisioning
|
||||||
|
storage.type.postgresql.database = provisioning
|
||||||
|
storage.type.postgresql.port = 5432
|
||||||
|
storage.type.postgresql.connectiontimeout = 60
|
||||||
|
```
|
||||||
|
|
||||||
|
### Storage MySQL/MariaDB
|
||||||
|
Additional parameters to set if you select mysql for your database. You must specify `host`, `username`, `password`,
|
||||||
|
`database`, and `port`.
|
||||||
|
```properties
|
||||||
|
storage.type.mysql.maxsessions = 64
|
||||||
|
storage.type.mysql.idletime = 60
|
||||||
|
storage.type.mysql.host = localhost
|
||||||
|
storage.type.postgresql.username = provisioning
|
||||||
|
storage.type.postgresql.password = provisioning
|
||||||
|
storage.type.postgresql.database = provisioning
|
||||||
|
storage.type.mysql.port = 3306
|
||||||
|
storage.type.mysql.connectiontimeout = 60
|
||||||
|
```
|
||||||
|
|
||||||
|
### Logging Parameters
|
||||||
|
The microservice provides extensive logging. If you would like to keep logging on disk, set the `logging.type = file`. If you only want
|
||||||
|
console logging, `set logging.type = console`. When selecting file, `logging.path` must exist. `logging.level` sets the
|
||||||
|
basic logging level for the entire controller. `logging.websocket` disables WebSocket logging.
|
||||||
|
|
||||||
|
```properties
|
||||||
|
logging.type = file
|
||||||
|
logging.path = $OWPROV_ROOT/logs
|
||||||
|
logging.level = information
|
||||||
|
logging.asynch = true
|
||||||
|
logging.websocket = false
|
||||||
|
```
|
||||||
38
CONTRIBUTING.md
Normal file
@@ -0,0 +1,38 @@
|
|||||||
|
# How to Contribute
|
||||||
|
|
||||||
|
We'd love to accept your patches and contributions to this project. There are
|
||||||
|
just a few small guidelines you need to follow.
|
||||||
|
|
||||||
|
## Version of C++
|
||||||
|
This project is based on the C++17 standard and compiles as-is on most platforms
|
||||||
|
using either clang or g++. Do not use C++21 or C++23 features for now. Some core
|
||||||
|
libraries used in this project do not support C++21 or C++23 yet.
|
||||||
|
|
||||||
|
## Variable Naming
|
||||||
|
Naming of pretty much anything uses Pascal naming. Longer explicit names using casing.
|
||||||
|
Member variable naming adds a `_` at the end of the vars. Try to
|
||||||
|
keep this standard going. Sometimes you must override a base class function and then of course
|
||||||
|
you need to follow the base class.
|
||||||
|
|
||||||
|
## This is a cmake project
|
||||||
|
This is a cmake project, and you need to adhere to the cmake rules. If you need
|
||||||
|
to add a package to the CMakeList, you need to ensure that the package is available
|
||||||
|
on all required platforms and compiles. Remember that this project runs on Linux, OS X,
|
||||||
|
and the Raspberry PI.
|
||||||
|
|
||||||
|
## Licensed packages
|
||||||
|
When adding a package, you must also state the licensing for the package. MIT, BSD, Apache licenses
|
||||||
|
are acceptable. No commercial licenses are allowed.
|
||||||
|
|
||||||
|
## clang formatting
|
||||||
|
Please format your code using the included `.clang-format` file included in the project.
|
||||||
|
|
||||||
|
```bash
|
||||||
|
clang-format -i --style=<project root>/.clang-format myfile.cpp
|
||||||
|
```
|
||||||
|
|
||||||
|
## Pull Requests
|
||||||
|
All submissions, including submissions by project members, require review. We
|
||||||
|
accept GitHub pull requests. Please create a branch with the Jira name for addressing the issue you are fixing or the
|
||||||
|
feature you are implementing.
|
||||||
|
Create a pull-request from the branch into master.
|
||||||
77
Dockerfile
@@ -1,16 +1,22 @@
|
|||||||
FROM alpine:3.15 AS build-base
|
ARG DEBIAN_VERSION=11.5-slim
|
||||||
|
ARG POCO_VERSION=poco-tip-v2
|
||||||
|
ARG CPPKAFKA_VERSION=tip-v1
|
||||||
|
ARG VALIJASON_VERSION=tip-v1
|
||||||
|
|
||||||
RUN apk add --update --no-cache \
|
FROM debian:$DEBIAN_VERSION AS build-base
|
||||||
|
|
||||||
|
RUN apt-get update && apt-get install --no-install-recommends -y \
|
||||||
make cmake g++ git \
|
make cmake g++ git \
|
||||||
unixodbc-dev postgresql-dev mariadb-dev \
|
libpq-dev libmariadb-dev libmariadbclient-dev-compat \
|
||||||
librdkafka-dev boost-dev openssl-dev \
|
librdkafka-dev libboost-all-dev libssl-dev \
|
||||||
zlib-dev nlohmann-json \
|
zlib1g-dev nlohmann-json3-dev ca-certificates libcurl4-openssl-dev libfmt-dev
|
||||||
curl-dev
|
|
||||||
|
|
||||||
FROM build-base AS poco-build
|
FROM build-base AS poco-build
|
||||||
|
|
||||||
ADD https://api.github.com/repos/stephb9959/poco/git/refs/heads/master version.json
|
ARG POCO_VERSION
|
||||||
RUN git clone https://github.com/stephb9959/poco /poco
|
|
||||||
|
ADD https://api.github.com/repos/AriliaWireless/poco/git/refs/tags/${POCO_VERSION} version.json
|
||||||
|
RUN git clone https://github.com/AriliaWireless/poco --branch ${POCO_VERSION} /poco
|
||||||
|
|
||||||
WORKDIR /poco
|
WORKDIR /poco
|
||||||
RUN mkdir cmake-build
|
RUN mkdir cmake-build
|
||||||
@@ -21,8 +27,10 @@ RUN cmake --build . --target install
|
|||||||
|
|
||||||
FROM build-base AS cppkafka-build
|
FROM build-base AS cppkafka-build
|
||||||
|
|
||||||
ADD https://api.github.com/repos/stephb9959/cppkafka/git/refs/heads/master version.json
|
ARG CPPKAFKA_VERSION
|
||||||
RUN git clone https://github.com/stephb9959/cppkafka /cppkafka
|
|
||||||
|
ADD https://api.github.com/repos/AriliaWireless/cppkafka/git/refs/tags/${CPPKAFKA_VERSION} version.json
|
||||||
|
RUN git clone https://github.com/AriliaWireless/cppkafka --branch ${CPPKAFKA_VERSION} /cppkafka
|
||||||
|
|
||||||
WORKDIR /cppkafka
|
WORKDIR /cppkafka
|
||||||
RUN mkdir cmake-build
|
RUN mkdir cmake-build
|
||||||
@@ -31,29 +39,19 @@ RUN cmake ..
|
|||||||
RUN cmake --build . --config Release -j8
|
RUN cmake --build . --config Release -j8
|
||||||
RUN cmake --build . --target install
|
RUN cmake --build . --target install
|
||||||
|
|
||||||
FROM build-base AS json-schema-validator-build
|
FROM build-base AS valijson-build
|
||||||
|
|
||||||
ADD https://api.github.com/repos/pboettch/json-schema-validator/git/refs/heads/master version.json
|
ARG VALIJASON_VERSION
|
||||||
RUN git clone https://github.com/pboettch/json-schema-validator /json-schema-validator
|
|
||||||
|
|
||||||
WORKDIR /json-schema-validator
|
ADD https://api.github.com/repos/AriliaWireless/valijson/git/refs/tags/${VALIJASON_VERSION} version.json
|
||||||
|
RUN git clone https://github.com/AriliaWireless/valijson --branch ${VALIJASON_VERSION} /valijson
|
||||||
|
|
||||||
|
WORKDIR /valijson
|
||||||
RUN mkdir cmake-build
|
RUN mkdir cmake-build
|
||||||
WORKDIR cmake-build
|
WORKDIR cmake-build
|
||||||
RUN cmake ..
|
RUN cmake ..
|
||||||
RUN make
|
RUN cmake --build . --config Release -j8
|
||||||
RUN make install
|
RUN cmake --build . --target install
|
||||||
|
|
||||||
FROM build-base AS fmtlib-build
|
|
||||||
|
|
||||||
ADD https://api.github.com/repos/fmtlib/fmt/git/refs/heads/master version.json
|
|
||||||
RUN git clone https://github.com/fmtlib/fmt /fmtlib
|
|
||||||
|
|
||||||
WORKDIR /fmtlib
|
|
||||||
RUN mkdir cmake-build
|
|
||||||
WORKDIR cmake-build
|
|
||||||
RUN cmake ..
|
|
||||||
RUN make
|
|
||||||
RUN make install
|
|
||||||
|
|
||||||
FROM build-base AS owprov-build
|
FROM build-base AS owprov-build
|
||||||
|
|
||||||
@@ -66,10 +64,7 @@ COPY --from=poco-build /usr/local/include /usr/local/include
|
|||||||
COPY --from=poco-build /usr/local/lib /usr/local/lib
|
COPY --from=poco-build /usr/local/lib /usr/local/lib
|
||||||
COPY --from=cppkafka-build /usr/local/include /usr/local/include
|
COPY --from=cppkafka-build /usr/local/include /usr/local/include
|
||||||
COPY --from=cppkafka-build /usr/local/lib /usr/local/lib
|
COPY --from=cppkafka-build /usr/local/lib /usr/local/lib
|
||||||
COPY --from=json-schema-validator-build /usr/local/include /usr/local/include
|
COPY --from=valijson-build /usr/local/include /usr/local/include
|
||||||
COPY --from=json-schema-validator-build /usr/local/lib /usr/local/lib
|
|
||||||
COPY --from=fmtlib-build /usr/local/include /usr/local/include
|
|
||||||
COPY --from=fmtlib-build /usr/local/lib /usr/local/lib
|
|
||||||
|
|
||||||
WORKDIR /owprov
|
WORKDIR /owprov
|
||||||
RUN mkdir cmake-build
|
RUN mkdir cmake-build
|
||||||
@@ -77,21 +72,21 @@ WORKDIR /owprov/cmake-build
|
|||||||
RUN cmake ..
|
RUN cmake ..
|
||||||
RUN cmake --build . --config Release -j8
|
RUN cmake --build . --config Release -j8
|
||||||
|
|
||||||
FROM alpine:3.15
|
FROM debian:$DEBIAN_VERSION
|
||||||
|
|
||||||
ENV OWPROV_USER=owprov \
|
ENV OWPROV_USER=owprov \
|
||||||
OWPROV_ROOT=/owprov-data \
|
OWPROV_ROOT=/owprov-data \
|
||||||
OWPROV_CONFIG=/owprov-data
|
OWPROV_CONFIG=/owprov-data
|
||||||
|
|
||||||
RUN addgroup -S "$OWPROV_USER" && \
|
RUN useradd "$OWPROV_USER"
|
||||||
adduser -S -G "$OWPROV_USER" "$OWPROV_USER"
|
|
||||||
|
|
||||||
RUN mkdir /openwifi
|
RUN mkdir /openwifi
|
||||||
RUN mkdir -p "$OWPROV_ROOT" "$OWPROV_CONFIG" && \
|
RUN mkdir -p "$OWPROV_ROOT" "$OWPROV_CONFIG" && \
|
||||||
chown "$OWPROV_USER": "$OWPROV_ROOT" "$OWPROV_CONFIG"
|
chown "$OWPROV_USER": "$OWPROV_ROOT" "$OWPROV_CONFIG"
|
||||||
|
|
||||||
RUN apk add --update --no-cache librdkafka su-exec gettext ca-certificates bash jq curl \
|
RUN apt-get update && apt-get install --no-install-recommends -y \
|
||||||
mariadb-connector-c libpq unixodbc postgresql-client
|
librdkafka++1 gosu gettext ca-certificates bash jq curl wget \
|
||||||
|
libmariadb-dev-compat libpq5 postgresql-client libfmt7
|
||||||
|
|
||||||
COPY readiness_check /readiness_check
|
COPY readiness_check /readiness_check
|
||||||
COPY test_scripts/curl/cli /cli
|
COPY test_scripts/curl/cli /cli
|
||||||
@@ -100,11 +95,13 @@ COPY owprov.properties.tmpl /
|
|||||||
COPY docker-entrypoint.sh /
|
COPY docker-entrypoint.sh /
|
||||||
COPY wait-for-postgres.sh /
|
COPY wait-for-postgres.sh /
|
||||||
RUN wget https://raw.githubusercontent.com/Telecominfraproject/wlan-cloud-ucentral-deploy/main/docker-compose/certs/restapi-ca.pem \
|
RUN wget https://raw.githubusercontent.com/Telecominfraproject/wlan-cloud-ucentral-deploy/main/docker-compose/certs/restapi-ca.pem \
|
||||||
-O /usr/local/share/ca-certificates/restapi-ca-selfsigned.pem
|
-O /usr/local/share/ca-certificates/restapi-ca-selfsigned.crt
|
||||||
|
|
||||||
COPY --from=owprov-build /owprov/cmake-build/owprov /openwifi/owprov
|
COPY --from=owprov-build /owprov/cmake-build/owprov /openwifi/owprov
|
||||||
COPY --from=cppkafka-build /cppkafka/cmake-build/src/lib/* /usr/local/lib
|
COPY --from=cppkafka-build /cppkafka/cmake-build/src/lib/* /usr/local/lib/
|
||||||
COPY --from=poco-build /poco/cmake-build/lib/* /usr/local/lib
|
COPY --from=poco-build /poco/cmake-build/lib/* /usr/local/lib/
|
||||||
|
|
||||||
|
RUN ldconfig
|
||||||
|
|
||||||
EXPOSE 16005 17005 16105
|
EXPOSE 16005 17005 16105
|
||||||
|
|
||||||
|
|||||||
111
README.md
@@ -1,11 +1,23 @@
|
|||||||
# OpenWiFi Provisioning
|
<p align="center">
|
||||||
|
<img src="images/project/logo.svg" width="200"/>
|
||||||
|
</p>
|
||||||
|
|
||||||
## Build from source.
|
# OpenWiFi Provisioning Service (OWPROV)
|
||||||
You need:
|
## What is it?
|
||||||
- https://github.com/pboettch/json-schema-validator.git
|
The OWPROV is a service for the TIP OpenWiFi CloudSDK (OWSDK).
|
||||||
- https://github.com/nlohmann/json.git
|
OWPROV manages groups of access points through the use of entities and vanues. OWPROV, like all other OWSDK microservices, is
|
||||||
|
defined using an OpenAPI definition and uses the ucentral communication protocol to interact with Access Points. To use
|
||||||
|
the OWPROV, you either need to [build it](#building) or use the [Docker version](#docker).
|
||||||
|
|
||||||
build and install them.
|
## OpenAPI
|
||||||
|
You may get static page with OpenAPI docs generated from the definition on [GitHub Page](https://telecominfraproject.github.io/wlan-cloud-owprov/).
|
||||||
|
Also, you may use [Swagger UI](https://petstore.swagger.io/#/) with OpenAPI definition file raw link (i.e. [latest version file](https://raw.githubusercontent.com/Telecominfraproject/wlan-cloud-owprov/main/openapi/owprov.yaml)) to get interactive docs page.
|
||||||
|
|
||||||
|
## Building
|
||||||
|
To build the microservice from source, please follow the instructions in [here](./BUILDING.md)
|
||||||
|
|
||||||
|
## Docker
|
||||||
|
To use the CLoudSDK deployment please follow [here](https://github.com/Telecominfraproject/wlan-cloud-ucentral-deploy)
|
||||||
|
|
||||||
## Root entity
|
## Root entity
|
||||||
It's UUID value is 0000-0000-0000. Its parent entity must be empty.
|
It's UUID value is 0000-0000-0000. Its parent entity must be empty.
|
||||||
@@ -46,24 +58,77 @@ You may modify the following fields in the POST
|
|||||||
- You may include an array of devices UUIDs
|
- You may include an array of devices UUIDs
|
||||||
- Topology and design cannot be set
|
- Topology and design cannot be set
|
||||||
|
|
||||||
## Geocoding
|
#### Expected directory layout
|
||||||
To support geocoding help, you need to configuration the following in the configuration file. Geocoding is used
|
From the directory where your cloned source is, you will need to create the `certs`, `logs`, and `uploads` directories.
|
||||||
when creating location and when reporting analytics.
|
```bash
|
||||||
|
mkdir certs
|
||||||
|
mkdir certs/cas
|
||||||
|
mkdir logs
|
||||||
|
mkdir uploads
|
||||||
```
|
```
|
||||||
geocodeapi = google
|
You should now have the following:
|
||||||
google.apikey = **********************************
|
```text
|
||||||
|
--+-- certs
|
||||||
|
| +--- cas
|
||||||
|
+-- cmake
|
||||||
|
+-- cmake-build
|
||||||
|
+-- logs
|
||||||
|
+-- src
|
||||||
|
+-- test_scripts
|
||||||
|
+-- openapi
|
||||||
|
+-- uploads
|
||||||
|
+-- owsec.properties
|
||||||
```
|
```
|
||||||
Currently, only google Geocoding is supported. Additional methods may be added in the future.
|
|
||||||
|
|
||||||
## Default firmware management rules
|
### Certificate
|
||||||
FMS is already integrated with OpenWifi. In order to allow it to upgrade devices automatically, you should
|
The OWFMS uses a certificate to provide security for the REST API Certificate to secure the Northbound API.
|
||||||
set the following values.
|
|
||||||
```
|
#### The `certs` directory
|
||||||
firmware.updater.upgrade = <true/false>
|
For all deployments, you will need the following `certs` directory, populated with the proper files.
|
||||||
firmware.updater.releaseonly = <true/false>
|
|
||||||
```
|
```text
|
||||||
### firmware.updater.upgrade
|
certs ---+--- restapi-ca.pem
|
||||||
Should FMS attempt to upgrade devices by default.
|
+--- restapi-cert.pem
|
||||||
|
+--- restapi-key.pem
|
||||||
|
```
|
||||||
|
|
||||||
|
## Firewall Considerations
|
||||||
|
| Port | Description | Configurable |
|
||||||
|
|:------|:-----------------------------------------------|:------------:|
|
||||||
|
| 16004 | Default port for REST API Access to the OWPROV | yes |
|
||||||
|
|
||||||
|
### Environment variables
|
||||||
|
The following environment variables should be set from the root directory of the service. They tell the OWGW process where to find
|
||||||
|
the configuration and the root directory.
|
||||||
|
```bash
|
||||||
|
export OWGW_ROOT=`pwd`
|
||||||
|
export OWGW_CONFIG=`pwd`
|
||||||
|
```
|
||||||
|
You can run the shell script `set_env.sh` from the microservice root.
|
||||||
|
|
||||||
|
### OWPROV Service Configuration
|
||||||
|
The configuration is kept in a file called `owprov.properties`. To understand the content of this file,
|
||||||
|
please look [here](https://github.com/Telecominfraproject/wlan-cloud-owprov/blob/main/CONFIGURATION.md)
|
||||||
|
|
||||||
|
## Kafka topics
|
||||||
|
Toe read more about Kafka, follow the [document](https://github.com/Telecominfraproject/wlan-cloud-ucentralgw/blob/main/KAFKA.md)
|
||||||
|
|
||||||
|
## Contributions
|
||||||
|
We need more contributors. Should you wish to contribute,
|
||||||
|
please follow the [contributions](https://github.com/Telecominfraproject/wlan-cloud-ucentralgw/blob/master/CONTRIBUTING.md) document.
|
||||||
|
|
||||||
|
## Pull Requests
|
||||||
|
Please create a branch with the Jira addressing the issue you are fixing or the feature you are implementing.
|
||||||
|
Create a pull-request from the branch into master.
|
||||||
|
|
||||||
|
## Additional OWSDK Microservices
|
||||||
|
Here is a list of additional OWSDK microservices
|
||||||
|
| Name | Description | Link | OpenAPI |
|
||||||
|
| :--- | :--- | :---: | :---: |
|
||||||
|
| OWSEC | Security Service | [here](https://github.com/Telecominfraproject/wlan-cloud-ucentralsec) | [here](https://github.com/Telecominfraproject/wlan-cloud-ucentralsec/blob/main/openpapi/owsec.yaml) |
|
||||||
|
| OWGW | Controller Service | [here](https://github.com/Telecominfraproject/wlan-cloud-ucentralgw) | [here](https://github.com/Telecominfraproject/wlan-cloud-ucentralgw/blob/master/openapi/owgw.yaml) |
|
||||||
|
| OWFMS | Firmware Management Service | [here](https://github.com/Telecominfraproject/wlan-cloud-ucentralfms) | [here](https://github.com/Telecominfraproject/wlan-cloud-ucentralfms/blob/main/openapi/owfms.yaml) |
|
||||||
|
| OWPROV | Provisioning Service | [here](https://github.com/Telecominfraproject/wlan-cloud-owprov) | [here](https://github.com/Telecominfraproject/wlan-cloud-owprov/blob/main/openapi/owprov.yaml) |
|
||||||
|
| OWANALYTICS | Analytics Service | [here](https://github.com/Telecominfraproject/wlan-cloud-analytics) | [here](https://github.com/Telecominfraproject/wlan-cloud-analytics/blob/main/openapi/owanalytics.yaml) |
|
||||||
|
| OWSUB | Subscriber Service | [here](https://github.com/Telecominfraproject/wlan-cloud-userportal) | [here](https://github.com/Telecominfraproject/wlan-cloud-userportal/blob/main/openapi/userportal.yaml) |
|
||||||
|
|
||||||
### firmware.updater.releaseonly
|
|
||||||
Should only RC software be used during upgrades.
|
|
||||||
@@ -1,11 +1,11 @@
|
|||||||
#!/bin/sh
|
#!/bin/bash
|
||||||
set -e
|
set -e
|
||||||
|
|
||||||
if [ "$SELFSIGNED_CERTS" = 'true' ]; then
|
if [ "$SELFSIGNED_CERTS" = 'true' ]; then
|
||||||
update-ca-certificates
|
update-ca-certificates
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [[ "$TEMPLATE_CONFIG" = 'true' && ! -f "$OWPROV_CONFIG"/owprov.properties ]]; then
|
if [[ "$TEMPLATE_CONFIG" = 'true' ]]; then
|
||||||
RESTAPI_HOST_ROOTCA=${RESTAPI_HOST_ROOTCA:-"\$OWPROV_ROOT/certs/restapi-ca.pem"} \
|
RESTAPI_HOST_ROOTCA=${RESTAPI_HOST_ROOTCA:-"\$OWPROV_ROOT/certs/restapi-ca.pem"} \
|
||||||
RESTAPI_HOST_PORT=${RESTAPI_HOST_PORT:-"16005"} \
|
RESTAPI_HOST_PORT=${RESTAPI_HOST_PORT:-"16005"} \
|
||||||
RESTAPI_HOST_CERT=${RESTAPI_HOST_CERT:-"\$OWPROV_ROOT/certs/restapi-cert.pem"} \
|
RESTAPI_HOST_CERT=${RESTAPI_HOST_CERT:-"\$OWPROV_ROOT/certs/restapi-cert.pem"} \
|
||||||
@@ -24,6 +24,7 @@ if [[ "$TEMPLATE_CONFIG" = 'true' && ! -f "$OWPROV_CONFIG"/owprov.properties ]];
|
|||||||
SYSTEM_URI_PRIVATE=${SYSTEM_URI_PRIVATE:-"https://localhost:17005"} \
|
SYSTEM_URI_PRIVATE=${SYSTEM_URI_PRIVATE:-"https://localhost:17005"} \
|
||||||
SYSTEM_URI_PUBLIC=${SYSTEM_URI_PUBLIC:-"https://localhost:16005"} \
|
SYSTEM_URI_PUBLIC=${SYSTEM_URI_PUBLIC:-"https://localhost:16005"} \
|
||||||
SYSTEM_URI_UI=${SYSTEM_URI_UI:-"http://localhost"} \
|
SYSTEM_URI_UI=${SYSTEM_URI_UI:-"http://localhost"} \
|
||||||
|
SECURITY_RESTAPI_DISABLE=${SECURITY_RESTAPI_DISABLE:-"false"} \
|
||||||
KAFKA_ENABLE=${KAFKA_ENABLE:-"true"} \
|
KAFKA_ENABLE=${KAFKA_ENABLE:-"true"} \
|
||||||
KAFKA_BROKERLIST=${KAFKA_BROKERLIST:-"localhost:9092"} \
|
KAFKA_BROKERLIST=${KAFKA_BROKERLIST:-"localhost:9092"} \
|
||||||
KAFKA_SSL_CA_LOCATION=${KAFKA_SSL_CA_LOCATION:-""} \
|
KAFKA_SSL_CA_LOCATION=${KAFKA_SSL_CA_LOCATION:-""} \
|
||||||
@@ -48,7 +49,7 @@ if [ "$1" = '/openwifi/owprov' -a "$(id -u)" = '0' ]; then
|
|||||||
if [ "$RUN_CHOWN" = 'true' ]; then
|
if [ "$RUN_CHOWN" = 'true' ]; then
|
||||||
chown -R "$OWPROV_USER": "$OWPROV_ROOT" "$OWPROV_CONFIG"
|
chown -R "$OWPROV_USER": "$OWPROV_ROOT" "$OWPROV_CONFIG"
|
||||||
fi
|
fi
|
||||||
exec su-exec "$OWPROV_USER" "$@"
|
exec gosu "$OWPROV_USER" "$@"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
exec "$@"
|
exec "$@"
|
||||||
|
|||||||
2
helm/.gitignore
vendored
@@ -1 +1,3 @@
|
|||||||
*.swp
|
*.swp
|
||||||
|
Chart.lock
|
||||||
|
charts/
|
||||||
|
|||||||
@@ -5,14 +5,14 @@ name: owprov
|
|||||||
version: 0.1.0
|
version: 0.1.0
|
||||||
dependencies:
|
dependencies:
|
||||||
- name: postgresql
|
- name: postgresql
|
||||||
repository: https://charts.bitnami.com/bitnami
|
repository: https://tip.jfrog.io/artifactory/tip-wlan-cloud-ucentral-helm/
|
||||||
version: 10.9.2
|
version: 10.9.2
|
||||||
condition: postgresql.enabled
|
condition: postgresql.enabled
|
||||||
- name: mysql
|
- name: mysql
|
||||||
repository: https://charts.bitnami.com/bitnami
|
repository: https://tip.jfrog.io/artifactory/tip-wlan-cloud-ucentral-helm/
|
||||||
version: 8.8.3
|
version: 8.8.3
|
||||||
condition: mysql.enabled
|
condition: mysql.enabled
|
||||||
- name: mariadb
|
- name: mariadb
|
||||||
repository: https://charts.bitnami.com/bitnami
|
repository: https://tip.jfrog.io/artifactory/tip-wlan-cloud-ucentral-helm/
|
||||||
version: 9.4.2
|
version: 9.4.2
|
||||||
condition: mariadb.enabled
|
condition: mariadb.enabled
|
||||||
|
|||||||
@@ -70,8 +70,8 @@ The following table lists the configurable parameters of the chart and their def
|
|||||||
| persistence.size | string | Defines PV size | `'10Gi'` |
|
| persistence.size | string | Defines PV size | `'10Gi'` |
|
||||||
| public_env_variables | hash | Defines list of environment variables to be passed to the Provisioning | |
|
| public_env_variables | hash | Defines list of environment variables to be passed to the Provisioning | |
|
||||||
| configProperties | hash | Configuration properties that should be passed to the application in `owprov.properties`. May be passed by key in set (i.e. `configProperties."rtty\.token"`) | |
|
| configProperties | hash | Configuration properties that should be passed to the application in `owprov.properties`. May be passed by key in set (i.e. `configProperties."rtty\.token"`) | |
|
||||||
| certs | hash | Defines files (keys and certificates) that should be passed to the Provisioning (PEM format is adviced to be used) (see `volumes.owprov` on where it is mounted) | |
|
| existingCertsSecret | string | Existing Kubernetes secret containing all required certificates and private keys for microservice operation. If set, certificates from `certs` key are ignored | `""` |
|
||||||
|
| certs | hash | Defines files (keys and certificates) that should be passed to the Gateway (PEM format is adviced to be used) (see `volumes.owprov` on where it is mounted). If `existingCertsSecret` is set, certificates passed this way will not be used. | |
|
||||||
|
|
||||||
Specify each parameter using the `--set key=value[,key=value]` argument to `helm install`. For example,
|
Specify each parameter using the `--set key=value[,key=value]` argument to `helm install`. For example,
|
||||||
|
|
||||||
|
|||||||
@@ -1,4 +1,5 @@
|
|||||||
{{- $root := . -}}
|
{{- $root := . -}}
|
||||||
|
{{- $storageType := index .Values.configProperties "storage.type" -}}
|
||||||
---
|
---
|
||||||
apiVersion: apps/v1
|
apiVersion: apps/v1
|
||||||
kind: Deployment
|
kind: Deployment
|
||||||
@@ -46,6 +47,39 @@ spec:
|
|||||||
- -timeout
|
- -timeout
|
||||||
- 600s
|
- 600s
|
||||||
|
|
||||||
|
{{- if eq $storageType "postgresql" }}
|
||||||
|
- name: wait-postgres
|
||||||
|
image: "{{ .Values.images.owprov.repository }}:{{ .Values.images.owprov.tag }}"
|
||||||
|
imagePullPolicy: {{ .Values.images.owprov.pullPolicy }}
|
||||||
|
command:
|
||||||
|
- /wait-for-postgres.sh
|
||||||
|
- {{ index .Values.configProperties "storage.type.postgresql.host" }}
|
||||||
|
- echo
|
||||||
|
- "PostgreSQL is ready"
|
||||||
|
env:
|
||||||
|
- name: KUBERNETES_DEPLOYED
|
||||||
|
value: "{{ now }}"
|
||||||
|
{{- range $key, $value := .Values.public_env_variables }}
|
||||||
|
- name: {{ $key }}
|
||||||
|
value: {{ $value | quote }}
|
||||||
|
{{- end }}
|
||||||
|
{{- range $key, $value := .Values.secret_env_variables }}
|
||||||
|
- name: {{ $key }}
|
||||||
|
valueFrom:
|
||||||
|
secretKeyRef:
|
||||||
|
name: {{ include "owprov.fullname" $root }}-env
|
||||||
|
key: {{ $key }}
|
||||||
|
{{- end }}
|
||||||
|
volumeMounts:
|
||||||
|
{{- range .Values.volumes.owprov }}
|
||||||
|
- name: {{ .name }}
|
||||||
|
mountPath: {{ .mountPath }}
|
||||||
|
{{- if .subPath }}
|
||||||
|
subPath: {{ .subPath }}
|
||||||
|
{{- end }}
|
||||||
|
{{- end }}
|
||||||
|
{{- end }}
|
||||||
|
|
||||||
containers:
|
containers:
|
||||||
|
|
||||||
- name: owprov
|
- name: owprov
|
||||||
@@ -97,8 +131,10 @@ spec:
|
|||||||
{{- toYaml . | nindent 12 }}
|
{{- toYaml . | nindent 12 }}
|
||||||
{{- end }}
|
{{- end }}
|
||||||
|
|
||||||
|
{{- with .Values.securityContext }}
|
||||||
securityContext:
|
securityContext:
|
||||||
fsGroup: 101
|
{{- toYaml . | nindent 8 }}
|
||||||
|
{{- end }}
|
||||||
|
|
||||||
imagePullSecrets:
|
imagePullSecrets:
|
||||||
{{- range $image, $imageValue := .Values.images }}
|
{{- range $image, $imageValue := .Values.images }}
|
||||||
|
|||||||
@@ -9,7 +9,7 @@ fullnameOverride: ""
|
|||||||
images:
|
images:
|
||||||
owprov:
|
owprov:
|
||||||
repository: tip-tip-wlan-cloud-ucentral.jfrog.io/owprov
|
repository: tip-tip-wlan-cloud-ucentral.jfrog.io/owprov
|
||||||
tag: main
|
tag: v2.9.0
|
||||||
pullPolicy: Always
|
pullPolicy: Always
|
||||||
# regcred:
|
# regcred:
|
||||||
# registry: tip-tip-wlan-cloud-ucentral.jfrog.io
|
# registry: tip-tip-wlan-cloud-ucentral.jfrog.io
|
||||||
@@ -71,7 +71,7 @@ volumes:
|
|||||||
mountPath: /owprov-data/certs
|
mountPath: /owprov-data/certs
|
||||||
volumeDefinition: |
|
volumeDefinition: |
|
||||||
secret:
|
secret:
|
||||||
secretName: {{ include "owprov.fullname" . }}-certs
|
secretName: {{ if .Values.existingCertsSecret }}{{ .Values.existingCertsSecret }}{{ else }}{{ include "owprov.fullname" . }}-certs{{ end }}
|
||||||
# Change this if you want to use another volume type
|
# Change this if you want to use another volume type
|
||||||
- name: persist
|
- name: persist
|
||||||
mountPath: /owprov-data/persist
|
mountPath: /owprov-data/persist
|
||||||
@@ -91,6 +91,9 @@ resources: {}
|
|||||||
# cpu: 100m
|
# cpu: 100m
|
||||||
# memory: 128Mi
|
# memory: 128Mi
|
||||||
|
|
||||||
|
securityContext:
|
||||||
|
fsGroup: 1000
|
||||||
|
|
||||||
nodeSelector: {}
|
nodeSelector: {}
|
||||||
|
|
||||||
tolerations: []
|
tolerations: []
|
||||||
@@ -199,6 +202,9 @@ configProperties:
|
|||||||
storage.type.mysql.username: stephb
|
storage.type.mysql.username: stephb
|
||||||
storage.type.mysql.password: snoopy99
|
storage.type.mysql.password: snoopy99
|
||||||
|
|
||||||
|
# NOTE: List of required certificates may be found in "certs" key. Alternative way to pass required certificates is to create external secret with all required certificates and set secret name in "existingCertsSecret" key. Details may be found in https://github.com/Telecominfraproject/wlan-cloud-ucentral-deploy/tree/main/chart#tldr
|
||||||
|
existingCertsSecret: ""
|
||||||
|
|
||||||
certs:
|
certs:
|
||||||
# restapi-ca.pem: ""
|
# restapi-ca.pem: ""
|
||||||
# restapi-cert.pem: ""
|
# restapi-cert.pem: ""
|
||||||
|
|||||||
BIN
images/device_types/cig_wf160d.png
Normal file
|
After Width: | Height: | Size: 104 KiB |
BIN
images/device_types/cig_wf188.png
Normal file
|
After Width: | Height: | Size: 80 KiB |
BIN
images/device_types/cig_wf188n.png
Normal file
|
After Width: | Height: | Size: 80 KiB |
BIN
images/device_types/cig_wf194c.png
Normal file
|
After Width: | Height: | Size: 75 KiB |
BIN
images/device_types/cig_wf194c4.png
Normal file
|
After Width: | Height: | Size: 75 KiB |
BIN
images/device_types/cig_wf808.png
Normal file
|
After Width: | Height: | Size: 218 KiB |
BIN
images/device_types/cig_wf809.png
Normal file
|
After Width: | Height: | Size: 158 KiB |
BIN
images/device_types/edgecore_eap101.png
Normal file
|
After Width: | Height: | Size: 140 KiB |
BIN
images/device_types/edgecore_eap102.png
Normal file
|
After Width: | Height: | Size: 121 KiB |
BIN
images/device_types/edgecore_ecs4100-12ph.png
Normal file
|
After Width: | Height: | Size: 44 KiB |
BIN
images/device_types/edgecore_ecw5211.png
Normal file
|
After Width: | Height: | Size: 192 KiB |
BIN
images/device_types/edgecore_ecw5410.png
Normal file
|
After Width: | Height: | Size: 197 KiB |
BIN
images/device_types/edgecore_oap100.png
Normal file
|
After Width: | Height: | Size: 50 KiB |
BIN
images/device_types/edgecore_spw2ac1200-lan-poe.png
Normal file
|
After Width: | Height: | Size: 59 KiB |
BIN
images/device_types/edgecore_spw2ac1200.png
Normal file
|
After Width: | Height: | Size: 59 KiB |
BIN
images/device_types/edgecore_ssw2ac2600.png
Normal file
|
After Width: | Height: | Size: 51 KiB |
BIN
images/device_types/hfcl_ion4.png
Normal file
|
After Width: | Height: | Size: 72 KiB |
BIN
images/device_types/hfcl_ion4.yml.png
Normal file
|
After Width: | Height: | Size: 72 KiB |
BIN
images/device_types/indio_um-305ac.png
Normal file
|
After Width: | Height: | Size: 34 KiB |
BIN
images/device_types/linksys_e8450-ubi.png
Normal file
|
After Width: | Height: | Size: 98 KiB |
BIN
images/device_types/linksys_ea6350-v4.png
Normal file
|
After Width: | Height: | Size: 89 KiB |
BIN
images/device_types/linksys_ea6350.png
Normal file
|
After Width: | Height: | Size: 89 KiB |
BIN
images/device_types/linksys_ea8300.png
Normal file
|
After Width: | Height: | Size: 204 KiB |
BIN
images/device_types/tp-link_ec420-g1.png
Normal file
|
After Width: | Height: | Size: 159 KiB |
BIN
images/device_types/tplink_ec420.png
Normal file
|
After Width: | Height: | Size: 159 KiB |
BIN
images/device_types/tplink_ex227.png
Normal file
|
After Width: | Height: | Size: 103 KiB |
BIN
images/device_types/tplink_ex228.png
Normal file
|
After Width: | Height: | Size: 103 KiB |
BIN
images/device_types/tplink_ex447.png
Normal file
|
After Width: | Height: | Size: 103 KiB |
BIN
images/device_types/wallys_dr40x9.png
Normal file
|
After Width: | Height: | Size: 59 KiB |
BIN
images/device_types/wallys_dr6018.png
Normal file
|
After Width: | Height: | Size: 80 KiB |
BIN
images/device_types/wallys_dr6018_v4.png
Normal file
|
After Width: | Height: | Size: 80 KiB |
BIN
images/project/logo.png
Normal file
|
After Width: | Height: | Size: 4.8 KiB |
165
images/project/logo.svg
Normal file
@@ -0,0 +1,165 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<!-- Generator: Adobe Illustrator 24.2.3, SVG Export Plug-In . SVG Version: 6.00 Build 0) -->
|
||||||
|
<svg version="1.1" id="Layer_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px"
|
||||||
|
viewBox="0 0 141.5 185.6" style="enable-background:new 0 0 141.5 185.6;" xml:space="preserve">
|
||||||
|
<style type="text/css">
|
||||||
|
.st0{fill:#414141;}
|
||||||
|
.st1{fill:#FFFFFF;}
|
||||||
|
.st2{fill:#FED206;}
|
||||||
|
.st3{fill:#EB6F53;}
|
||||||
|
.st4{fill:#3BA9B6;}
|
||||||
|
</style>
|
||||||
|
<g>
|
||||||
|
<g>
|
||||||
|
<path class="st0" d="M120.7,183.9H21.5c-10.8,0-19.5-8.7-19.5-19.5V20.5c0-10.8,8.7-19.5,19.5-19.5h99.2
|
||||||
|
c10.8,0,19.5,8.7,19.5,19.5v143.9C140.2,175.2,131.5,183.9,120.7,183.9z"/>
|
||||||
|
<g>
|
||||||
|
<g>
|
||||||
|
<g>
|
||||||
|
<path class="st1" d="M46.3,166.2v-3.4h-1.2v-0.6h3.1v0.6H47v3.4H46.3z"/>
|
||||||
|
</g>
|
||||||
|
<g>
|
||||||
|
<path class="st1" d="M49,166.2v-4h2.7v0.6h-2v1h2v0.6h-2v1.1h2v0.6H49z"/>
|
||||||
|
</g>
|
||||||
|
<g>
|
||||||
|
<path class="st1" d="M52.6,166.2v-4h0.7v3.4h1.8v0.6H52.6z"/>
|
||||||
|
</g>
|
||||||
|
<g>
|
||||||
|
<path class="st1" d="M55.7,166.2v-4h2.7v0.6h-2v1h2v0.6h-2v1.1h2v0.6H55.7z"/>
|
||||||
|
</g>
|
||||||
|
<g>
|
||||||
|
<path class="st1" d="M59.1,164.2c0-1.2,0.9-2.1,2.1-2.1c0.8,0,1.3,0.4,1.6,0.9l-0.6,0.3c-0.2-0.3-0.6-0.6-1-0.6
|
||||||
|
c-0.8,0-1.4,0.6-1.4,1.4c0,0.8,0.6,1.4,1.4,1.4c0.4,0,0.8-0.3,1-0.6l0.6,0.3c-0.3,0.5-0.8,0.9-1.6,0.9
|
||||||
|
C60,166.3,59.1,165.5,59.1,164.2z"/>
|
||||||
|
</g>
|
||||||
|
<g>
|
||||||
|
<path class="st1" d="M63.2,164.2c0-1.2,0.8-2.1,2-2.1c1.2,0,2,0.9,2,2.1c0,1.2-0.8,2.1-2,2.1C64,166.3,63.2,165.4,63.2,164.2z
|
||||||
|
M66.5,164.2c0-0.8-0.5-1.4-1.3-1.4c-0.8,0-1.3,0.6-1.3,1.4c0,0.8,0.5,1.4,1.3,1.4C66,165.7,66.5,165,66.5,164.2z"/>
|
||||||
|
</g>
|
||||||
|
<g>
|
||||||
|
<path class="st1" d="M71.3,166.2v-3.1l-1.2,3.1h-0.3l-1.2-3.1v3.1h-0.7v-4h1l1.1,2.7l1.1-2.7h1v4H71.3z"/>
|
||||||
|
</g>
|
||||||
|
<g>
|
||||||
|
<path class="st1" d="M75.7,166.2v-4h0.7v4H75.7z"/>
|
||||||
|
</g>
|
||||||
|
<g>
|
||||||
|
<path class="st1" d="M80.4,166.2l-2.1-2.8v2.8h-0.7v-4h0.7l2,2.8v-2.8h0.7v4H80.4z"/>
|
||||||
|
</g>
|
||||||
|
<g>
|
||||||
|
<path class="st1" d="M82.3,166.2v-4H85v0.6h-2v1h2v0.6h-2v1.7H82.3z"/>
|
||||||
|
</g>
|
||||||
|
<g>
|
||||||
|
<path class="st1" d="M87.9,166.2l-0.9-1.5h-0.7v1.5h-0.7v-4h1.7c0.8,0,1.3,0.5,1.3,1.2c0,0.7-0.5,1.1-0.9,1.2l1,1.6H87.9z
|
||||||
|
M88,163.5c0-0.4-0.3-0.6-0.7-0.6h-1v1.3h1C87.7,164.1,88,163.9,88,163.5z"/>
|
||||||
|
</g>
|
||||||
|
<g>
|
||||||
|
<path class="st1" d="M92.4,166.2l-0.3-0.8h-1.8l-0.3,0.8h-0.8l1.6-4h0.9l1.6,4H92.4z M91.2,162.9l-0.7,1.9h1.4L91.2,162.9z"/>
|
||||||
|
</g>
|
||||||
|
<g>
|
||||||
|
<path class="st1" d="M95.8,166.2v-4h1.5c0.8,0,1.2,0.5,1.2,1.2c0,0.6-0.4,1.2-1.2,1.2h-1.2v1.7H95.8z M98.2,163.4
|
||||||
|
c0-0.5-0.3-0.9-0.9-0.9h-1.1v1.7h1.1C97.8,164.3,98.2,163.9,98.2,163.4z"/>
|
||||||
|
</g>
|
||||||
|
<g>
|
||||||
|
<path class="st1" d="M101.5,166.2l-1.1-1.6h-0.9v1.6h-0.3v-4h1.5c0.7,0,1.2,0.4,1.2,1.2c0,0.7-0.5,1.1-1.1,1.1l1.2,1.7H101.5z
|
||||||
|
M101.6,163.4c0-0.5-0.4-0.9-0.9-0.9h-1.1v1.7h1.1C101.2,164.3,101.6,163.9,101.6,163.4z"/>
|
||||||
|
</g>
|
||||||
|
<g>
|
||||||
|
<path class="st1" d="M102.8,164.2c0-1.2,0.8-2.1,1.9-2.1c1.2,0,1.9,0.9,1.9,2.1c0,1.2-0.8,2.1-1.9,2.1
|
||||||
|
C103.6,166.3,102.8,165.4,102.8,164.2z M106.3,164.2c0-1-0.6-1.7-1.6-1.7c-1,0-1.6,0.7-1.6,1.7c0,1,0.6,1.7,1.6,1.7
|
||||||
|
C105.7,166,106.3,165.2,106.3,164.2z"/>
|
||||||
|
</g>
|
||||||
|
<g>
|
||||||
|
<path class="st1" d="M106.9,165.8l0.2-0.3c0.2,0.2,0.4,0.4,0.8,0.4c0.5,0,0.9-0.4,0.9-0.9v-2.8h0.3v2.8c0,0.8-0.5,1.2-1.2,1.2
|
||||||
|
C107.5,166.3,107.2,166.1,106.9,165.8z"/>
|
||||||
|
</g>
|
||||||
|
<g>
|
||||||
|
<path class="st1" d="M110.4,166.2v-4h2.5v0.3h-2.2v1.5h2.1v0.3h-2.1v1.6h2.2v0.3H110.4z"/>
|
||||||
|
</g>
|
||||||
|
<g>
|
||||||
|
<path class="st1" d="M113.5,164.2c0-1.2,0.9-2.1,2-2.1c0.6,0,1.1,0.3,1.5,0.7l-0.3,0.2c-0.3-0.3-0.7-0.6-1.2-0.6
|
||||||
|
c-0.9,0-1.7,0.7-1.7,1.7c0,1,0.7,1.7,1.7,1.7c0.5,0,0.9-0.2,1.2-0.6l0.3,0.2c-0.4,0.4-0.8,0.7-1.5,0.7
|
||||||
|
C114.4,166.3,113.5,165.5,113.5,164.2z"/>
|
||||||
|
</g>
|
||||||
|
<g>
|
||||||
|
<path class="st1" d="M118.7,166.2v-3.7h-1.3v-0.3h2.9v0.3H119v3.7H118.7z"/>
|
||||||
|
</g>
|
||||||
|
</g>
|
||||||
|
<g>
|
||||||
|
<polygon class="st1" points="26.3,163.8 31.6,158.5 36.9,163.8 37.7,163.8 31.6,157.6 25.5,163.8 "/>
|
||||||
|
<polygon class="st1" points="36.9,164.7 31.6,170 26.3,164.7 25.5,164.7 31.6,170.8 37.7,164.7 "/>
|
||||||
|
<polygon class="st1" points="31,163.8 36.3,158.5 41.6,163.8 42.5,163.8 36.3,157.6 30.2,163.8 "/>
|
||||||
|
<polygon class="st1" points="41.6,164.7 36.3,170 31,164.7 30.2,164.7 36.3,170.8 42.5,164.7 "/>
|
||||||
|
</g>
|
||||||
|
</g>
|
||||||
|
<g>
|
||||||
|
<path class="st1" d="M33.2,100.7c-4.6,0-8.3,3.7-8.3,8.3s3.7,8.3,8.3,8.3s8.3-3.7,8.3-8.3S37.8,100.7,33.2,100.7z"/>
|
||||||
|
</g>
|
||||||
|
<g>
|
||||||
|
<g>
|
||||||
|
<g>
|
||||||
|
<path class="st2" d="M33.2,35.2c40.7,0,73.8,33.1,73.8,73.8c0,0.7,0,1.4,0,2.1c0,1.7,0.6,3.3,1.7,4.6c1.2,1.2,2.8,1.9,4.5,2
|
||||||
|
l0.2,0c3.5,0,6.3-2.7,6.4-6.2c0-0.8,0-1.7,0-2.5c0-47.7-38.8-86.6-86.6-86.6c-0.8,0-1.7,0-2.5,0c-1.7,0-3.3,0.8-4.5,2
|
||||||
|
c-1.2,1.2-1.8,2.9-1.7,4.6c0.1,3.5,3,6.3,6.6,6.2C31.8,35.2,32.5,35.2,33.2,35.2z"/>
|
||||||
|
</g>
|
||||||
|
</g>
|
||||||
|
</g>
|
||||||
|
<g>
|
||||||
|
<g>
|
||||||
|
<g>
|
||||||
|
<path class="st3" d="M33.2,60.5c26.7,0,48.5,21.7,48.5,48.5c0,0.6,0,1.3,0,2c-0.1,1.7,0.5,3.3,1.7,4.6c1.2,1.3,2.7,2,4.4,2.1
|
||||||
|
c1.7,0.1,3.3-0.5,4.6-1.7c1.2-1.2,2-2.7,2-4.4c0-0.9,0.1-1.8,0.1-2.6c0-33.8-27.5-61.2-61.2-61.2c-0.8,0-1.6,0-2.6,0.1
|
||||||
|
c-1.7,0.1-3.3,0.8-4.4,2.1c-1.2,1.3-1.8,2.9-1.7,4.6s0.8,3.3,2.1,4.4c1.3,1.2,2.9,1.8,4.6,1.7C31.9,60.5,32.6,60.5,33.2,60.5z"
|
||||||
|
/>
|
||||||
|
</g>
|
||||||
|
</g>
|
||||||
|
</g>
|
||||||
|
<g>
|
||||||
|
<g>
|
||||||
|
<g>
|
||||||
|
<path class="st4" d="M33.2,86.7c12.3,0,22.3,10,22.3,22.3c0,0.5,0,1.1-0.1,1.8c-0.3,3.5,2.3,6.6,5.8,6.9
|
||||||
|
c3.5,0.3,6.6-2.3,6.9-5.8c0.1-1,0.1-1.9,0.1-2.8c0-19.3-15.7-35.1-35.1-35.1c-0.9,0-1.8,0-2.8,0.1c-1.7,0.1-3.2,0.9-4.3,2.2
|
||||||
|
c-1.1,1.3-1.6,2.9-1.5,4.6c0.1,1.7,0.9,3.2,2.2,4.3c1.3,1.1,2.9,1.6,4.6,1.5C32.1,86.7,32.7,86.7,33.2,86.7z"/>
|
||||||
|
</g>
|
||||||
|
</g>
|
||||||
|
</g>
|
||||||
|
</g>
|
||||||
|
<g>
|
||||||
|
<path class="st1" d="M35.8,130.4c1.1,0.6,2.1,1.5,2.7,2.6c0.7,1.1,1,2.3,1,3.7s-0.3,2.6-1,3.7c-0.7,1.1-1.6,2-2.7,2.6
|
||||||
|
c-1.1,0.6-2.4,1-3.8,1s-2.7-0.3-3.8-1c-1.1-0.6-2.1-1.5-2.7-2.6c-0.7-1.1-1-2.3-1-3.7c0-1.3,0.3-2.6,1-3.7c0.7-1.1,1.6-2,2.7-2.6
|
||||||
|
c1.1-0.6,2.4-0.9,3.8-0.9C33.4,129.5,34.7,129.8,35.8,130.4z M29.9,132.9c-0.7,0.4-1.2,0.9-1.6,1.6s-0.6,1.4-0.6,2.2
|
||||||
|
c0,0.8,0.2,1.6,0.6,2.3c0.4,0.7,0.9,1.2,1.6,1.6c0.7,0.4,1.4,0.6,2.1,0.6c0.8,0,1.5-0.2,2.1-0.6c0.6-0.4,1.2-0.9,1.5-1.6
|
||||||
|
c0.4-0.7,0.6-1.4,0.6-2.3c0-0.8-0.2-1.6-0.6-2.2s-0.9-1.2-1.5-1.6c-0.6-0.4-1.4-0.6-2.1-0.6C31.3,132.3,30.6,132.5,29.9,132.9z"/>
|
||||||
|
<path class="st1" d="M50.6,133.6c0.8,0.5,1.4,1.1,1.8,2c0.4,0.8,0.6,1.8,0.6,2.9c0,1.1-0.2,2-0.6,2.8c-0.4,0.8-1,1.5-1.8,1.9
|
||||||
|
c-0.8,0.5-1.6,0.7-2.6,0.7c-0.7,0-1.4-0.1-2-0.4s-1.1-0.7-1.5-1.2v5.4h-3.1V133h3.1v1.6c0.4-0.5,0.9-1,1.4-1.2s1.2-0.4,2-0.4
|
||||||
|
C48.9,132.9,49.8,133.1,50.6,133.6z M49.1,140.5c0.5-0.6,0.7-1.3,0.7-2.2c0-0.9-0.2-1.6-0.7-2.1c-0.5-0.6-1.1-0.8-1.9-0.8
|
||||||
|
s-1.4,0.3-1.9,0.8c-0.5,0.6-0.8,1.3-0.8,2.1c0,0.9,0.2,1.6,0.8,2.2s1.1,0.8,1.9,0.8S48.6,141,49.1,140.5z"/>
|
||||||
|
<path class="st1" d="M63.4,134.4c0.9,1,1.4,2.4,1.4,4.2c0,0.3,0,0.6,0,0.7H57c0.2,0.7,0.5,1.2,1,1.6c0.5,0.4,1.1,0.6,1.8,0.6
|
||||||
|
c0.5,0,1-0.1,1.5-0.3s0.9-0.5,1.3-0.9l1.6,1.6c-0.5,0.6-1.2,1.1-2,1.4c-0.8,0.3-1.6,0.5-2.6,0.5c-1.1,0-2.1-0.2-3-0.7
|
||||||
|
s-1.5-1.1-2-1.9c-0.5-0.8-0.7-1.8-0.7-2.9c0-1.1,0.2-2.1,0.7-2.9s1.1-1.5,2-1.9c0.8-0.5,1.8-0.7,2.9-0.7
|
||||||
|
C61.2,132.9,62.5,133.4,63.4,134.4z M61.8,137.5c0-0.7-0.3-1.3-0.7-1.7s-1-0.6-1.7-0.6c-0.7,0-1.2,0.2-1.7,0.6
|
||||||
|
c-0.4,0.4-0.7,1-0.9,1.7H61.8z"/>
|
||||||
|
<path class="st1" d="M76.2,134c0.7,0.7,1.1,1.7,1.1,3v6.8h-3.1v-5.9c0-0.7-0.2-1.2-0.6-1.6s-0.9-0.6-1.5-0.6
|
||||||
|
c-0.8,0-1.4,0.3-1.8,0.8c-0.4,0.5-0.7,1.2-0.7,2v5.3h-3.1V133h3.1v1.9c0.7-1.3,2-2,3.7-2C74.6,132.8,75.5,133.2,76.2,134z"/>
|
||||||
|
<path class="st1" d="M96,129.7h3.3l-4.7,14h-3.3l-2.9-10.1l-3,10.1h-3.2l-4.7-14h3.4l3,10.7l3-10.7H90l3.1,10.7L96,129.7z"/>
|
||||||
|
<path class="st1" d="M103.3,128.7c0.3,0.3,0.5,0.7,0.5,1.2s-0.2,0.9-0.5,1.2c-0.3,0.3-0.7,0.5-1.2,0.5c-0.5,0-0.9-0.2-1.2-0.5
|
||||||
|
c-0.3-0.3-0.5-0.7-0.5-1.2c0-0.5,0.2-0.9,0.5-1.2c0.3-0.3,0.7-0.5,1.2-0.5C102.6,128.2,103,128.3,103.3,128.7z M100.6,133h3.1
|
||||||
|
v10.8h-3.1V133z"/>
|
||||||
|
<path class="st1" d="M106.5,129.7h10.1l0,2.6h-6.9v3.4h6.3v2.6h-6.3v5.3h-3.2V129.7z"/>
|
||||||
|
<path class="st1" d="M120.9,128.7c0.3,0.3,0.5,0.7,0.5,1.2s-0.2,0.9-0.5,1.2c-0.3,0.3-0.7,0.5-1.2,0.5c-0.5,0-0.9-0.2-1.2-0.5
|
||||||
|
c-0.3-0.3-0.5-0.7-0.5-1.2c0-0.5,0.2-0.9,0.5-1.2c0.3-0.3,0.7-0.5,1.2-0.5C120.1,128.2,120.5,128.3,120.9,128.7z M118.1,133h3.1
|
||||||
|
v10.8h-3.1V133z"/>
|
||||||
|
</g>
|
||||||
|
</g>
|
||||||
|
<g>
|
||||||
|
</g>
|
||||||
|
<g>
|
||||||
|
</g>
|
||||||
|
<g>
|
||||||
|
</g>
|
||||||
|
<g>
|
||||||
|
</g>
|
||||||
|
<g>
|
||||||
|
</g>
|
||||||
|
<g>
|
||||||
|
</g>
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 8.0 KiB |
268
openapi/ow_or_ameriband.yaml
Normal file
@@ -0,0 +1,268 @@
|
|||||||
|
openapi: 3.0.1
|
||||||
|
info:
|
||||||
|
title: OpenWiFi Open roaming Ameriband Provisioning Model
|
||||||
|
description: Registration of an OpenRoaming profile with Ameriband for TIP OpenWifi.
|
||||||
|
version: 1.0.0
|
||||||
|
license:
|
||||||
|
name: BSD3
|
||||||
|
url: https://github.com/Telecominfraproject/wlan-cloud-ucentralgw/blob/master/LICENSE
|
||||||
|
|
||||||
|
servers:
|
||||||
|
- url: 'https://tip.regiatration.ameriband.com:8001/api/v1'
|
||||||
|
|
||||||
|
security:
|
||||||
|
- bearerAuth: []
|
||||||
|
|
||||||
|
components:
|
||||||
|
securitySchemes:
|
||||||
|
bearerAuth:
|
||||||
|
type: http
|
||||||
|
scheme: bearer
|
||||||
|
|
||||||
|
responses:
|
||||||
|
NotFound:
|
||||||
|
description: The specified resource was not found.
|
||||||
|
content:
|
||||||
|
application/json:
|
||||||
|
schema:
|
||||||
|
properties:
|
||||||
|
ErrorCode:
|
||||||
|
type: integer
|
||||||
|
ErrorDetails:
|
||||||
|
type: string
|
||||||
|
ErrorDescription:
|
||||||
|
type: string
|
||||||
|
|
||||||
|
Unauthorized:
|
||||||
|
description: The requested does not have sufficient rights to perform the operation.
|
||||||
|
content:
|
||||||
|
application/json:
|
||||||
|
schema:
|
||||||
|
properties:
|
||||||
|
ErrorCode:
|
||||||
|
type: integer
|
||||||
|
enum:
|
||||||
|
- 0 # Success
|
||||||
|
- 8 # INVALID_TOKEN
|
||||||
|
- 9 # EXPIRED_TOKEN
|
||||||
|
ErrorDetails:
|
||||||
|
type: string
|
||||||
|
ErrorDescription:
|
||||||
|
type: string
|
||||||
|
|
||||||
|
Success:
|
||||||
|
description: The requested operation was performed.
|
||||||
|
content:
|
||||||
|
application/json:
|
||||||
|
schema:
|
||||||
|
properties:
|
||||||
|
Operation:
|
||||||
|
type: string
|
||||||
|
Details:
|
||||||
|
type: string
|
||||||
|
Code:
|
||||||
|
type: integer
|
||||||
|
|
||||||
|
BadRequest:
|
||||||
|
description: The requested operation failed.
|
||||||
|
content:
|
||||||
|
application/json:
|
||||||
|
schema:
|
||||||
|
properties:
|
||||||
|
ErrorCode:
|
||||||
|
type: integer
|
||||||
|
ErrorDetails:
|
||||||
|
type: string
|
||||||
|
ErrorDescription:
|
||||||
|
type: integer
|
||||||
|
|
||||||
|
schemas:
|
||||||
|
RegistrationRequest:
|
||||||
|
type: object
|
||||||
|
properties:
|
||||||
|
orgRequestId:
|
||||||
|
type: string
|
||||||
|
format: uuid
|
||||||
|
minLength: 36
|
||||||
|
maxLength: 36
|
||||||
|
example:
|
||||||
|
Client will generate a UUID that must be returned in the response.
|
||||||
|
orgAcceptedTermsAndConditions:
|
||||||
|
type: boolean
|
||||||
|
default: false
|
||||||
|
orgLegalName:
|
||||||
|
type: string
|
||||||
|
minLength: 1
|
||||||
|
orgWebSite:
|
||||||
|
type: string
|
||||||
|
format: url
|
||||||
|
minLength: 1
|
||||||
|
orgContact:
|
||||||
|
type: string
|
||||||
|
minLength: 1
|
||||||
|
example:
|
||||||
|
John Smith
|
||||||
|
orgEmail:
|
||||||
|
type: string
|
||||||
|
format: email
|
||||||
|
minLength: 1
|
||||||
|
orgPhone:
|
||||||
|
type: string
|
||||||
|
example:
|
||||||
|
(607)555-1234 or +1(223)555-1222
|
||||||
|
orgLocation:
|
||||||
|
type: string
|
||||||
|
example:
|
||||||
|
Boston, NH - LA, CA
|
||||||
|
orgCertificate:
|
||||||
|
type: string
|
||||||
|
minLength: 1
|
||||||
|
example:
|
||||||
|
This must be the entire PEM file content of the certificate, encoded using base64
|
||||||
|
|
||||||
|
RegistrationResponse:
|
||||||
|
type: object
|
||||||
|
properties:
|
||||||
|
orgRequestId:
|
||||||
|
type: string
|
||||||
|
format: uuid
|
||||||
|
minLength: 36
|
||||||
|
maxLength: 36
|
||||||
|
example:
|
||||||
|
This should be the same orgRequestId passed during registration.
|
||||||
|
orgNASID:
|
||||||
|
type: string
|
||||||
|
minLength: 10
|
||||||
|
description:
|
||||||
|
This is the NASID generated by Ameriband. It will be used by the operator as NASID when contacting Ameriband.
|
||||||
|
ameribandCertificate:
|
||||||
|
type: string
|
||||||
|
minLength: 1
|
||||||
|
example:
|
||||||
|
This must be the entire PEM file content of the certificate, encoded using base64
|
||||||
|
|
||||||
|
RegistrationInformationRequest:
|
||||||
|
type: object
|
||||||
|
properties:
|
||||||
|
link:
|
||||||
|
description: This should be the link where a potential registrant can read the terms and conditions of registering with Ameriband.
|
||||||
|
type: string
|
||||||
|
format: url
|
||||||
|
minLength: 1
|
||||||
|
example:
|
||||||
|
https://ameriband.com/romain-registration.html
|
||||||
|
|
||||||
|
paths:
|
||||||
|
/termsAndConditions:
|
||||||
|
get:
|
||||||
|
summary: The registrant must be given a chance to view the terms and conditions of the relationship they are entering into
|
||||||
|
operationId: getTermsAndConditions
|
||||||
|
responses:
|
||||||
|
200:
|
||||||
|
description: Sucessfully retrieved Terms and Conditions
|
||||||
|
content:
|
||||||
|
application/json:
|
||||||
|
schema:
|
||||||
|
$ref: '#/components/schemas/RegistrationInformationRequest'
|
||||||
|
404:
|
||||||
|
$ref: '#/components/responses/Unauthorized'
|
||||||
|
|
||||||
|
/registration:
|
||||||
|
get:
|
||||||
|
tags:
|
||||||
|
- Registration
|
||||||
|
operationId: getRegistrationInformation
|
||||||
|
summary: This should return the information from a registration based on the NASID
|
||||||
|
parameters:
|
||||||
|
- in: query
|
||||||
|
name: orgNASID
|
||||||
|
schema:
|
||||||
|
type: string
|
||||||
|
required: true
|
||||||
|
example:
|
||||||
|
This is the orgNASID returned during registration.
|
||||||
|
responses:
|
||||||
|
200:
|
||||||
|
$ref: '#/components/schemas/RegistrationResponse'
|
||||||
|
403:
|
||||||
|
$ref: '#/components/responses/Unauthorized'
|
||||||
|
404:
|
||||||
|
$ref: '#/components/responses/NotFound'
|
||||||
|
|
||||||
|
post:
|
||||||
|
summary: Called when the registrant ahs read the T&Cs and iw willing to submit their information to enter in a partnership
|
||||||
|
tags:
|
||||||
|
- Registration
|
||||||
|
operationId: createRegistration
|
||||||
|
requestBody:
|
||||||
|
required: true
|
||||||
|
content:
|
||||||
|
application/json:
|
||||||
|
schema:
|
||||||
|
$ref: '#/components/schemas/RegistrationRequest'
|
||||||
|
responses:
|
||||||
|
200:
|
||||||
|
description: Succesfully registered
|
||||||
|
content:
|
||||||
|
application/json:
|
||||||
|
schema:
|
||||||
|
$ref: '#/components/schemas/RegistrationResponse'
|
||||||
|
400:
|
||||||
|
description: Registration failed due to missing or incomplete information
|
||||||
|
$ref: '#/components/responses/BadRequest'
|
||||||
|
403:
|
||||||
|
$ref: '#/components/responses/Unauthorized'
|
||||||
|
|
||||||
|
put:
|
||||||
|
summary: Called when the registrant needs to update its information with Ameriband. The does not generate a new NASID.
|
||||||
|
tags:
|
||||||
|
- Registration
|
||||||
|
operationId: updateRegistration
|
||||||
|
parameters:
|
||||||
|
- in: query
|
||||||
|
name: orgNASID
|
||||||
|
schema:
|
||||||
|
type: string
|
||||||
|
required: true
|
||||||
|
example:
|
||||||
|
This is the orgNASID returned during registration.
|
||||||
|
requestBody:
|
||||||
|
required: true
|
||||||
|
content:
|
||||||
|
application/json:
|
||||||
|
schema:
|
||||||
|
$ref: '#/components/schemas/RegistrationRequest'
|
||||||
|
responses:
|
||||||
|
200:
|
||||||
|
description: Succesfully found the information based on the orgNASID
|
||||||
|
content:
|
||||||
|
application/json:
|
||||||
|
schema:
|
||||||
|
$ref: '#/components/schemas/RegistrationResponse'
|
||||||
|
400:
|
||||||
|
$ref: '#/components/responses/BadRequest'
|
||||||
|
403:
|
||||||
|
$ref: '#/components/responses/Unauthorized'
|
||||||
|
404:
|
||||||
|
$ref: '#/components/responses/NotFound'
|
||||||
|
|
||||||
|
delete:
|
||||||
|
tags:
|
||||||
|
- Registration
|
||||||
|
summary: When a registrant wants to terminate a relationship with Ameriband. Ameriband should also delete all information from the registrant
|
||||||
|
operationId: deleteRegistration
|
||||||
|
parameters:
|
||||||
|
- in: query
|
||||||
|
name: orgNASID
|
||||||
|
schema:
|
||||||
|
type: string
|
||||||
|
required: true
|
||||||
|
example:
|
||||||
|
This is the orgNASID returned during registration.
|
||||||
|
responses:
|
||||||
|
204:
|
||||||
|
$ref: '#/components/responses/Success'
|
||||||
|
403:
|
||||||
|
$ref: '#/components/responses/Unauthorized'
|
||||||
|
404:
|
||||||
|
$ref: '#/components/responses/NotFound'
|
||||||
@@ -27,71 +27,13 @@ components:
|
|||||||
|
|
||||||
responses:
|
responses:
|
||||||
NotFound:
|
NotFound:
|
||||||
description: The specified resource was not found.
|
$ref: 'https://github.com/Telecominfraproject/wlan-cloud-ucentralsec/blob/main/openpapi/owsec.yaml#/components/responses/NotFound'
|
||||||
content:
|
|
||||||
application/json:
|
|
||||||
schema:
|
|
||||||
properties:
|
|
||||||
ErrorCode:
|
|
||||||
type: integer
|
|
||||||
ErrorDetails:
|
|
||||||
type: string
|
|
||||||
ErrorDescription:
|
|
||||||
type: string
|
|
||||||
|
|
||||||
Unauthorized:
|
Unauthorized:
|
||||||
description: The requested does not have sufficient rights to perform the operation.
|
$ref: 'https://github.com/Telecominfraproject/wlan-cloud-ucentralsec/blob/main/openpapi/owsec.yaml#/components/responses/Unauthorized'
|
||||||
content:
|
|
||||||
application/json:
|
|
||||||
schema:
|
|
||||||
properties:
|
|
||||||
ErrorCode:
|
|
||||||
type: integer
|
|
||||||
enum:
|
|
||||||
- 0 # Success
|
|
||||||
- 1 # PASSWORD_CHANGE_REQUIRED,
|
|
||||||
- 2 # INVALID_CREDENTIALS,
|
|
||||||
- 3 # PASSWORD_ALREADY_USED,
|
|
||||||
- 4 # USERNAME_PENDING_VERIFICATION,
|
|
||||||
- 5 # PASSWORD_INVALID,
|
|
||||||
- 6 # INTERNAL_ERROR,
|
|
||||||
- 7 # ACCESS_DENIED,
|
|
||||||
- 8 # INVALID_TOKEN
|
|
||||||
- 9 # EXPIRED_TOKEN
|
|
||||||
- 10 # RATE_LIMIT_EXCEEDED
|
|
||||||
- 11 # BAD_MFA_TRANSACTION
|
|
||||||
- 12 # MFA_FAILURE
|
|
||||||
- 13 # SECURITY_SERVICE_UNREACHABLE
|
|
||||||
ErrorDetails:
|
|
||||||
type: string
|
|
||||||
ErrorDescription:
|
|
||||||
type: string
|
|
||||||
|
|
||||||
Success:
|
Success:
|
||||||
description: The requested operation was performed.
|
$ref: 'https://github.com/Telecominfraproject/wlan-cloud-ucentralsec/blob/main/openpapi/owsec.yaml#/components/responses/Success'
|
||||||
content:
|
|
||||||
application/json:
|
|
||||||
schema:
|
|
||||||
properties:
|
|
||||||
Operation:
|
|
||||||
type: string
|
|
||||||
Details:
|
|
||||||
type: string
|
|
||||||
Code:
|
|
||||||
type: integer
|
|
||||||
|
|
||||||
BadRequest:
|
BadRequest:
|
||||||
description: The requested operation failed.
|
$ref: 'https://github.com/Telecominfraproject/wlan-cloud-ucentralsec/blob/main/openpapi/owsec.yaml#/components/responses/BadRequest'
|
||||||
content:
|
|
||||||
application/json:
|
|
||||||
schema:
|
|
||||||
properties:
|
|
||||||
ErrorCode:
|
|
||||||
type: integer
|
|
||||||
ErrorDetails:
|
|
||||||
type: string
|
|
||||||
ErrorDescription:
|
|
||||||
type: integer
|
|
||||||
|
|
||||||
schemas:
|
schemas:
|
||||||
|
|
||||||
@@ -1278,11 +1220,54 @@ components:
|
|||||||
items:
|
items:
|
||||||
$ref: '#/components/schemas/SubscriberDevice'
|
$ref: '#/components/schemas/SubscriberDevice'
|
||||||
|
|
||||||
|
ConfigurationOverride:
|
||||||
|
type: object
|
||||||
|
properties:
|
||||||
|
source:
|
||||||
|
type: string
|
||||||
|
reason:
|
||||||
|
type: string
|
||||||
|
parameterName:
|
||||||
|
type: string
|
||||||
|
parameterType:
|
||||||
|
enum:
|
||||||
|
- string
|
||||||
|
- integer
|
||||||
|
- boolean
|
||||||
|
parameterValue:
|
||||||
|
type: string
|
||||||
|
modified:
|
||||||
|
type: integer
|
||||||
|
format: int64
|
||||||
|
|
||||||
|
ConfigurationOverrideList:
|
||||||
|
type: object
|
||||||
|
properties:
|
||||||
|
serialNumber:
|
||||||
|
type: string
|
||||||
|
managementPolicy:
|
||||||
|
type: string
|
||||||
|
format: uuid
|
||||||
|
overrides:
|
||||||
|
type: array
|
||||||
|
items:
|
||||||
|
$ref: '#/components/schemas/ConfigurationOverride'
|
||||||
|
|
||||||
#########################################################################################
|
#########################################################################################
|
||||||
##
|
##
|
||||||
## These are endpoints that all services in the OPenWiFI stack must provide
|
## These are endpoints that all services in the OPenWiFI stack must provide
|
||||||
##
|
##
|
||||||
#########################################################################################
|
#########################################################################################
|
||||||
|
ExtraSystemConfiguration:
|
||||||
|
type: array
|
||||||
|
items:
|
||||||
|
type: object
|
||||||
|
properties:
|
||||||
|
parameterName:
|
||||||
|
type: string
|
||||||
|
parameterValue:
|
||||||
|
type: string
|
||||||
|
|
||||||
AnyPayload:
|
AnyPayload:
|
||||||
type: object
|
type: object
|
||||||
properties:
|
properties:
|
||||||
@@ -2016,11 +2001,6 @@ paths:
|
|||||||
schema:
|
schema:
|
||||||
type: boolean
|
type: boolean
|
||||||
required: false
|
required: false
|
||||||
- in: query
|
|
||||||
name: deviceType
|
|
||||||
schema:
|
|
||||||
type: string
|
|
||||||
required: false
|
|
||||||
- in: query
|
- in: query
|
||||||
description: Pagination start (starts at 1. If not specified, 1 is assumed)
|
description: Pagination start (starts at 1. If not specified, 1 is assumed)
|
||||||
name: offset
|
name: offset
|
||||||
@@ -2086,12 +2066,20 @@ paths:
|
|||||||
default: false
|
default: false
|
||||||
required: false
|
required: false
|
||||||
- in: query
|
- in: query
|
||||||
description: return the list of devices under RRM
|
description: return the list of devices for a subscriber
|
||||||
name: subscriber
|
name: subscriber
|
||||||
schema:
|
schema:
|
||||||
type: string
|
type: string
|
||||||
format: uuid
|
format: uuid
|
||||||
required: false
|
required: false
|
||||||
|
- in: query
|
||||||
|
description: return the resolved configuration for a specific device
|
||||||
|
name: resolveConfig
|
||||||
|
schema:
|
||||||
|
type: boolean
|
||||||
|
default: false
|
||||||
|
required: false
|
||||||
|
|
||||||
responses:
|
responses:
|
||||||
200:
|
200:
|
||||||
description: Return a list of elements
|
description: Return a list of elements
|
||||||
@@ -2149,6 +2137,13 @@ paths:
|
|||||||
type: string
|
type: string
|
||||||
format: uuid
|
format: uuid
|
||||||
required: false
|
required: false
|
||||||
|
- in: query
|
||||||
|
description: return RRM settings for a specific device
|
||||||
|
name: rrmSettings
|
||||||
|
schema:
|
||||||
|
type: boolean
|
||||||
|
default: false
|
||||||
|
required: false
|
||||||
responses:
|
responses:
|
||||||
200:
|
200:
|
||||||
description: Succesful retrieve configuratiopn or part of the configuration
|
description: Succesful retrieve configuratiopn or part of the configuration
|
||||||
@@ -2259,6 +2254,94 @@ paths:
|
|||||||
404:
|
404:
|
||||||
$ref: '#/components/responses/NotFound'
|
$ref: '#/components/responses/NotFound'
|
||||||
|
|
||||||
|
/configurationOverrides/{serialNumber}:
|
||||||
|
get:
|
||||||
|
tags:
|
||||||
|
- Configuration Overrides
|
||||||
|
operationId: getCponfigurationOverrides
|
||||||
|
summary: retrieve a list of configuration overrides for a given device
|
||||||
|
parameters:
|
||||||
|
- in: path
|
||||||
|
name: serialNumber
|
||||||
|
schema:
|
||||||
|
type: string
|
||||||
|
required: true
|
||||||
|
responses:
|
||||||
|
200:
|
||||||
|
description: Return a list of configuration overrides.
|
||||||
|
content:
|
||||||
|
application/json:
|
||||||
|
schema:
|
||||||
|
$ref: '#/components/schemas/ConfigurationOverrideList'
|
||||||
|
400:
|
||||||
|
$ref: '#/components/responses/BadRequest'
|
||||||
|
403:
|
||||||
|
$ref: '#/components/responses/Unauthorized'
|
||||||
|
404:
|
||||||
|
$ref: '#/components/responses/NotFound'
|
||||||
|
delete:
|
||||||
|
tags:
|
||||||
|
- Configuration Overrides
|
||||||
|
operationId: deleteCponfigurationOverrides
|
||||||
|
summary: delete all configuration overrides for a given device from a given source
|
||||||
|
parameters:
|
||||||
|
- in: path
|
||||||
|
name: serialNumber
|
||||||
|
schema:
|
||||||
|
type: string
|
||||||
|
required: true
|
||||||
|
- in: query
|
||||||
|
name: source
|
||||||
|
schema:
|
||||||
|
type: string
|
||||||
|
required: true
|
||||||
|
responses:
|
||||||
|
200:
|
||||||
|
$ref: '#/components/responses/Success'
|
||||||
|
400:
|
||||||
|
$ref: '#/components/responses/BadRequest'
|
||||||
|
403:
|
||||||
|
$ref: '#/components/responses/Unauthorized'
|
||||||
|
404:
|
||||||
|
$ref: '#/components/responses/NotFound'
|
||||||
|
put:
|
||||||
|
tags:
|
||||||
|
- Configuration Overrides
|
||||||
|
operationId: modifyConfigurationOverrides
|
||||||
|
summary: modify configuration overrides for a given device for a given source
|
||||||
|
parameters:
|
||||||
|
- in: path
|
||||||
|
name: serialNumber
|
||||||
|
schema:
|
||||||
|
type: string
|
||||||
|
required: true
|
||||||
|
- in: query
|
||||||
|
name: source
|
||||||
|
schema:
|
||||||
|
type: string
|
||||||
|
required: true
|
||||||
|
requestBody:
|
||||||
|
description: Information used to modify the override list
|
||||||
|
content:
|
||||||
|
application/json:
|
||||||
|
schema:
|
||||||
|
$ref: '#/components/schemas/ConfigurationOverrideList'
|
||||||
|
responses:
|
||||||
|
200:
|
||||||
|
description: Return the modified configuration overrides.
|
||||||
|
content:
|
||||||
|
application/json:
|
||||||
|
schema:
|
||||||
|
$ref: '#/components/schemas/ConfigurationOverrideList'
|
||||||
|
400:
|
||||||
|
$ref: '#/components/responses/BadRequest'
|
||||||
|
403:
|
||||||
|
$ref: '#/components/responses/Unauthorized'
|
||||||
|
404:
|
||||||
|
$ref: '#/components/responses/NotFound'
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/venue:
|
/venue:
|
||||||
get:
|
get:
|
||||||
tags:
|
tags:
|
||||||
@@ -2313,12 +2396,6 @@ paths:
|
|||||||
type: string
|
type: string
|
||||||
example: serial1,serial2,serial3
|
example: serial1,serial2,serial3
|
||||||
required: false
|
required: false
|
||||||
- in: query
|
|
||||||
description: only serial numbers of full device details
|
|
||||||
name: serialOnly
|
|
||||||
schema:
|
|
||||||
type: boolean
|
|
||||||
required: false
|
|
||||||
- in: query
|
- in: query
|
||||||
description: return the number of devices
|
description: return the number of devices
|
||||||
name: countOnly
|
name: countOnly
|
||||||
@@ -2339,6 +2416,14 @@ paths:
|
|||||||
type: boolean
|
type: boolean
|
||||||
default: false
|
default: false
|
||||||
required: false
|
required: false
|
||||||
|
- in: query
|
||||||
|
description: list venues that use a specific RRM vendor
|
||||||
|
name: RRMvendor
|
||||||
|
schema:
|
||||||
|
type: string
|
||||||
|
example:
|
||||||
|
- this is the shortname of the RRM vendor
|
||||||
|
required: false
|
||||||
responses:
|
responses:
|
||||||
200:
|
200:
|
||||||
description: Return a list of venues.
|
description: Return a list of venues.
|
||||||
@@ -2457,6 +2542,17 @@ paths:
|
|||||||
type: boolean
|
type: boolean
|
||||||
default: false
|
default: false
|
||||||
required: false
|
required: false
|
||||||
|
- in: query
|
||||||
|
name: revisionsAvailable
|
||||||
|
schema:
|
||||||
|
type: boolean
|
||||||
|
default: false
|
||||||
|
required: false
|
||||||
|
- in: query
|
||||||
|
name: revision
|
||||||
|
schema:
|
||||||
|
type: string
|
||||||
|
required: false
|
||||||
requestBody:
|
requestBody:
|
||||||
description: Information used to modify the new venue
|
description: Information used to modify the new venue
|
||||||
content:
|
content:
|
||||||
@@ -4340,3 +4436,66 @@ paths:
|
|||||||
$ref: '#/components/responses/Unauthorized'
|
$ref: '#/components/responses/Unauthorized'
|
||||||
404:
|
404:
|
||||||
$ref: '#/components/responses/NotFound'
|
$ref: '#/components/responses/NotFound'
|
||||||
|
|
||||||
|
/systemConfiguration:
|
||||||
|
get:
|
||||||
|
tags:
|
||||||
|
- SystemConfiguration
|
||||||
|
summary: Retrieve system configuration items
|
||||||
|
operationId: getSystemConfiguration
|
||||||
|
parameters:
|
||||||
|
- in: query
|
||||||
|
description: Which parameters you want to retrieve
|
||||||
|
name: entries
|
||||||
|
schema:
|
||||||
|
type: string
|
||||||
|
example:
|
||||||
|
- element1
|
||||||
|
- element1,element2,element3
|
||||||
|
required: false
|
||||||
|
responses:
|
||||||
|
200:
|
||||||
|
description: List of configuration elements
|
||||||
|
content:
|
||||||
|
application/json:
|
||||||
|
schema:
|
||||||
|
type: array
|
||||||
|
items:
|
||||||
|
$ref: '#/components/schemas/ExtraSystemConfiguration'
|
||||||
|
403:
|
||||||
|
$ref: '#/components/responses/Unauthorized'
|
||||||
|
404:
|
||||||
|
$ref: '#/components/responses/NotFound'
|
||||||
|
|
||||||
|
put:
|
||||||
|
tags:
|
||||||
|
- SystemConfiguration
|
||||||
|
summary: Set some or all system configuration
|
||||||
|
operationId: setSystemConfiguration
|
||||||
|
requestBody:
|
||||||
|
content:
|
||||||
|
application/json:
|
||||||
|
schema:
|
||||||
|
$ref: '#/components/schemas/ExtraSystemConfiguration'
|
||||||
|
|
||||||
|
responses:
|
||||||
|
200:
|
||||||
|
$ref: '#/components/schemas/ExtraSystemConfiguration'
|
||||||
|
403:
|
||||||
|
$ref: '#/components/responses/Unauthorized'
|
||||||
|
404:
|
||||||
|
$ref: '#/components/responses/NotFound'
|
||||||
|
|
||||||
|
delete:
|
||||||
|
tags:
|
||||||
|
- SystemConfiguration
|
||||||
|
summary: Delete all additional system configuration
|
||||||
|
operationId: deleteSystemConfiguration
|
||||||
|
|
||||||
|
responses:
|
||||||
|
200:
|
||||||
|
$ref: '#/components/responses/Success'
|
||||||
|
403:
|
||||||
|
$ref: '#/components/responses/Unauthorized'
|
||||||
|
404:
|
||||||
|
$ref: '#/components/responses/NotFound'
|
||||||
|
|||||||
174
openapi/rrm_provider.yaml
Normal file
@@ -0,0 +1,174 @@
|
|||||||
|
openapi: 3.0.1
|
||||||
|
info:
|
||||||
|
title: OpenWiFi RRM Provider Model
|
||||||
|
description: Definitions and APIs to manages an OpenWiFi RRM Providers.
|
||||||
|
version: 1.0.0
|
||||||
|
license:
|
||||||
|
name: BSD3
|
||||||
|
url: https://github.com/Telecominfraproject/wlan-cloud-ucentralgw/blob/master/LICENSE
|
||||||
|
|
||||||
|
servers:
|
||||||
|
- url: 'https://localhost:16022/api/v1'
|
||||||
|
|
||||||
|
security:
|
||||||
|
- bearerAuth: []
|
||||||
|
- ApiKeyAuth: []
|
||||||
|
|
||||||
|
components:
|
||||||
|
securitySchemes:
|
||||||
|
ApiKeyAuth:
|
||||||
|
type: apiKey
|
||||||
|
in: header
|
||||||
|
name: X-API-KEY
|
||||||
|
bearerAuth:
|
||||||
|
type: http
|
||||||
|
scheme: bearer
|
||||||
|
bearerFormat: JWT
|
||||||
|
|
||||||
|
responses:
|
||||||
|
NotFound:
|
||||||
|
$ref: 'https://github.com/Telecominfraproject/wlan-cloud-ucentralsec/blob/main/openpapi/owsec.yaml#/components/responses/NotFound'
|
||||||
|
Unauthorized:
|
||||||
|
$ref: 'https://github.com/Telecominfraproject/wlan-cloud-ucentralsec/blob/main/openpapi/owsec.yaml#/components/responses/Unauthorized'
|
||||||
|
Success:
|
||||||
|
$ref: 'https://github.com/Telecominfraproject/wlan-cloud-ucentralsec/blob/main/openpapi/owsec.yaml#/components/responses/Success'
|
||||||
|
BadRequest:
|
||||||
|
$ref: 'https://github.com/Telecominfraproject/wlan-cloud-ucentralsec/blob/main/openpapi/owsec.yaml#/components/responses/BadRequest'
|
||||||
|
|
||||||
|
schemas:
|
||||||
|
|
||||||
|
Provider:
|
||||||
|
type: object
|
||||||
|
properties:
|
||||||
|
vendor:
|
||||||
|
description: The name of the vendor for display.
|
||||||
|
type: string
|
||||||
|
minLength: 1
|
||||||
|
maxLength: 128
|
||||||
|
vendorShortname:
|
||||||
|
description: A shortname for the vendor. Only letters and numbers are allowed. This is the name used internally.
|
||||||
|
type: string
|
||||||
|
minLength: 4
|
||||||
|
maxLength: 16
|
||||||
|
version:
|
||||||
|
description: An identifier that will help users identify the version of the RRM module they are using.
|
||||||
|
type: string
|
||||||
|
about:
|
||||||
|
description: A link to the Vendor page for this RRM Module
|
||||||
|
type: string
|
||||||
|
|
||||||
|
|
||||||
|
Algorithm:
|
||||||
|
type: object
|
||||||
|
properties:
|
||||||
|
name:
|
||||||
|
description: A display for this algorithm.
|
||||||
|
type: string
|
||||||
|
minLength: 1
|
||||||
|
maxLength: 128
|
||||||
|
description:
|
||||||
|
description: A description of the algorithm.
|
||||||
|
type: string
|
||||||
|
shortName:
|
||||||
|
description: This is the name used internally.
|
||||||
|
type: string
|
||||||
|
minLength: 4
|
||||||
|
maxLength: 16
|
||||||
|
parameterFormat:
|
||||||
|
description: this is a Regex used to validate the input. If this is empty, no validation will be performed.
|
||||||
|
type: string
|
||||||
|
parameterSamples:
|
||||||
|
description: These samples will be displayed in the UI to the user trying to configure the options
|
||||||
|
type: array
|
||||||
|
items:
|
||||||
|
type: string
|
||||||
|
helper:
|
||||||
|
description: A link to a web page or PDF document explaining the algorithm and its parameters
|
||||||
|
type: string
|
||||||
|
|
||||||
|
Algorithms:
|
||||||
|
description: The list of all algorithms supported by the vendor
|
||||||
|
type: array
|
||||||
|
items:
|
||||||
|
$ref: '#/components/schemas/Algorithm'
|
||||||
|
|
||||||
|
paths:
|
||||||
|
/provider:
|
||||||
|
get:
|
||||||
|
tags:
|
||||||
|
- RRM
|
||||||
|
operationId: getProvider
|
||||||
|
summary: Retrieve information about the provider for this RRM Module
|
||||||
|
responses:
|
||||||
|
200:
|
||||||
|
$ref: '#/components/schemas/Provider'
|
||||||
|
400:
|
||||||
|
$ref: '#/components/responses/BadRequest'
|
||||||
|
403:
|
||||||
|
$ref: '#/components/responses/Unauthorized'
|
||||||
|
404:
|
||||||
|
$ref: '#/components/responses/NotFound'
|
||||||
|
|
||||||
|
/algorithms:
|
||||||
|
get:
|
||||||
|
tags:
|
||||||
|
- RRM
|
||||||
|
operationId: getAlgorithms
|
||||||
|
summary: Retrieve a lists of algorithms supported in the module.
|
||||||
|
responses:
|
||||||
|
200:
|
||||||
|
$ref: '#/components/schemas/Algorithms'
|
||||||
|
400:
|
||||||
|
$ref: '#/components/responses/BadRequest'
|
||||||
|
403:
|
||||||
|
$ref: '#/components/responses/Unauthorized'
|
||||||
|
404:
|
||||||
|
$ref: '#/components/responses/NotFound'
|
||||||
|
|
||||||
|
/runRRM:
|
||||||
|
put:
|
||||||
|
tags:
|
||||||
|
- RRM
|
||||||
|
operationId: runRRMNow
|
||||||
|
summary: Run a specific or default RRM algorithm. The UI user or CLI user will have the ability to run an algorithm on demand.
|
||||||
|
parameters:
|
||||||
|
- in: query
|
||||||
|
description:
|
||||||
|
name: venue
|
||||||
|
schema:
|
||||||
|
type: string
|
||||||
|
format: uuid
|
||||||
|
required: true
|
||||||
|
- in: query
|
||||||
|
description: Perform RRM without updating anything. This may be used by an admin to see what RRM would do.
|
||||||
|
name: mock
|
||||||
|
schema:
|
||||||
|
type: boolean
|
||||||
|
default: false
|
||||||
|
required: false
|
||||||
|
- in: query
|
||||||
|
description: Specify the RRM algorithm to use. If omitted, select the default algorithm.
|
||||||
|
schema:
|
||||||
|
type: string
|
||||||
|
required: false
|
||||||
|
- in: query
|
||||||
|
description: Specify the parameters to use with the RRM algorithm to use. If omitted, select the default parameters.
|
||||||
|
schema:
|
||||||
|
type: string
|
||||||
|
required: false
|
||||||
|
responses:
|
||||||
|
200:
|
||||||
|
description: Return the list of actions that were or would be performed.
|
||||||
|
content:
|
||||||
|
application/json:
|
||||||
|
schema:
|
||||||
|
type: array
|
||||||
|
items:
|
||||||
|
type: string
|
||||||
|
400:
|
||||||
|
$ref: '#/components/responses/BadRequest'
|
||||||
|
403:
|
||||||
|
$ref: '#/components/responses/Unauthorized'
|
||||||
|
404:
|
||||||
|
$ref: '#/components/responses/NotFound'
|
||||||
|
|
||||||
@@ -34,6 +34,7 @@ openwifi.system.uri.private = https://localhost:17005
|
|||||||
openwifi.system.uri.public = https://ucentral.dpaas.arilia.com:16005
|
openwifi.system.uri.public = https://ucentral.dpaas.arilia.com:16005
|
||||||
openwifi.system.commandchannel = /tmp/app.owprov
|
openwifi.system.commandchannel = /tmp/app.owprov
|
||||||
openwifi.system.uri.ui = owprov-ui.arilia.com
|
openwifi.system.uri.ui = owprov-ui.arilia.com
|
||||||
|
openwifi.security.restapi.disable = false
|
||||||
|
|
||||||
firmware.updater.upgrade = false
|
firmware.updater.upgrade = false
|
||||||
firmware.updater.releaseonly = false
|
firmware.updater.releaseonly = false
|
||||||
|
|||||||
@@ -39,6 +39,7 @@ openwifi.system.uri.private = ${SYSTEM_URI_PRIVATE}
|
|||||||
openwifi.system.uri.public = ${SYSTEM_URI_PUBLIC}
|
openwifi.system.uri.public = ${SYSTEM_URI_PUBLIC}
|
||||||
openwifi.system.commandchannel = /tmp/app.ucentralfms
|
openwifi.system.commandchannel = /tmp/app.ucentralfms
|
||||||
openwifi.system.uri.ui = ${SYSTEM_URI_UI}
|
openwifi.system.uri.ui = ${SYSTEM_URI_UI}
|
||||||
|
openwifi.security.restapi.disable = ${SECURITY_RESTAPI_DISABLE}
|
||||||
|
|
||||||
#############################
|
#############################
|
||||||
# Generic information for all micro services
|
# Generic information for all micro services
|
||||||
|
|||||||
147
src/APConfig.cpp
@@ -5,25 +5,24 @@
|
|||||||
#include "APConfig.h"
|
#include "APConfig.h"
|
||||||
#include "StorageService.h"
|
#include "StorageService.h"
|
||||||
|
|
||||||
|
#include "Poco/JSON/Parser.h"
|
||||||
|
#include "Poco/StringTokenizer.h"
|
||||||
|
#include "fmt/format.h"
|
||||||
|
|
||||||
namespace OpenWifi {
|
namespace OpenWifi {
|
||||||
|
|
||||||
APConfig::APConfig(const std::string &SerialNumber, const std::string &DeviceType, Poco::Logger &L, bool Explain)
|
APConfig::APConfig(const std::string &SerialNumber, const std::string &DeviceType,
|
||||||
: SerialNumber_(SerialNumber),
|
Poco::Logger &L, bool Explain)
|
||||||
DeviceType_(DeviceType),
|
: SerialNumber_(SerialNumber), DeviceType_(DeviceType), Logger_(L), Explain_(Explain) {}
|
||||||
Logger_(L),
|
|
||||||
Explain_(Explain)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
APConfig::APConfig(const std::string &SerialNumber, Poco::Logger &L)
|
APConfig::APConfig(const std::string &SerialNumber, Poco::Logger &L)
|
||||||
: SerialNumber_(SerialNumber),
|
: SerialNumber_(SerialNumber), Logger_(L) {
|
||||||
Logger_(L)
|
|
||||||
{
|
|
||||||
Explain_ = false;
|
Explain_ = false;
|
||||||
Sub_ = true;
|
Sub_ = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool APConfig::FindRadio(const std::string &Band, const Poco::JSON::Array::Ptr &Arr, Poco::JSON::Object::Ptr & Radio) {
|
bool APConfig::FindRadio(const std::string &Band, const Poco::JSON::Array::Ptr &Arr,
|
||||||
|
Poco::JSON::Object::Ptr &Radio) {
|
||||||
for (const auto &i : *Arr) {
|
for (const auto &i : *Arr) {
|
||||||
auto R = i.extract<Poco::JSON::Object::Ptr>();
|
auto R = i.extract<Poco::JSON::Object::Ptr>();
|
||||||
if (R->has("band") && R->get("band").toString() == Band) {
|
if (R->has("band") && R->get("band").toString() == Band) {
|
||||||
@@ -34,7 +33,8 @@ namespace OpenWifi {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool APConfig::RemoveBand(const std::string &Band, const Poco::JSON::Array::Ptr &A_in,Poco::JSON::Array::Ptr &A_Out) {
|
bool APConfig::RemoveBand(const std::string &Band, const Poco::JSON::Array::Ptr &A_in,
|
||||||
|
Poco::JSON::Array::Ptr &A_Out) {
|
||||||
for (const auto &i : *A_in) {
|
for (const auto &i : *A_in) {
|
||||||
auto R = i.extract<Poco::JSON::Object::Ptr>();
|
auto R = i.extract<Poco::JSON::Object::Ptr>();
|
||||||
if (R->has("band") && R->get("band").toString() == Band) {
|
if (R->has("band") && R->get("band").toString() == Band) {
|
||||||
@@ -45,8 +45,8 @@ namespace OpenWifi {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
[[maybe_unused]] static void ShowJSON([[maybe_unused]] const char *S,
|
||||||
[[maybe_unused ]] static void ShowJSON([[maybe_unused]] const char *S, [[maybe_unused]] const Poco::JSON::Object::Ptr &Obj) {
|
[[maybe_unused]] const Poco::JSON::Object::Ptr &Obj) {
|
||||||
/*
|
/*
|
||||||
std::stringstream O;
|
std::stringstream O;
|
||||||
Poco::JSON::Stringifier::stringify(Obj,O);
|
Poco::JSON::Stringifier::stringify(Obj,O);
|
||||||
@@ -55,7 +55,8 @@ namespace OpenWifi {
|
|||||||
*/
|
*/
|
||||||
}
|
}
|
||||||
|
|
||||||
bool APConfig::ReplaceVariablesInObject( const Poco::JSON::Object::Ptr & Original, Poco::JSON::Object::Ptr & Result) {
|
bool APConfig::ReplaceVariablesInObject(const Poco::JSON::Object::Ptr &Original,
|
||||||
|
Poco::JSON::Object::Ptr &Result) {
|
||||||
// get all the names and expand
|
// get all the names and expand
|
||||||
auto Names = Original->getNames();
|
auto Names = Original->getNames();
|
||||||
for (const auto &i : Names) {
|
for (const auto &i : Names) {
|
||||||
@@ -67,7 +68,8 @@ namespace OpenWifi {
|
|||||||
if (StorageService()->VariablesDB().GetRecord("id", uuid, VB)) {
|
if (StorageService()->VariablesDB().GetRecord("id", uuid, VB)) {
|
||||||
for (const auto &var : VB.variables) {
|
for (const auto &var : VB.variables) {
|
||||||
Poco::JSON::Parser P;
|
Poco::JSON::Parser P;
|
||||||
auto VariableBlockInfo = P.parse(var.value).extract<Poco::JSON::Object::Ptr>();
|
auto VariableBlockInfo =
|
||||||
|
P.parse(var.value).extract<Poco::JSON::Object::Ptr>();
|
||||||
auto VarNames = VariableBlockInfo->getNames();
|
auto VarNames = VariableBlockInfo->getNames();
|
||||||
for (const auto &j : VarNames) {
|
for (const auto &j : VarNames) {
|
||||||
Result->set(j, VariableBlockInfo->get(j));
|
Result->set(j, VariableBlockInfo->get(j));
|
||||||
@@ -93,7 +95,8 @@ namespace OpenWifi {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool APConfig::ReplaceVariablesInArray( const Poco::JSON::Array::Ptr & Original, Poco::JSON::Array::Ptr & ResultArray) {
|
bool APConfig::ReplaceVariablesInArray(const Poco::JSON::Array::Ptr &Original,
|
||||||
|
Poco::JSON::Array::Ptr &ResultArray) {
|
||||||
|
|
||||||
for (const auto &element : *Original) {
|
for (const auto &element : *Original) {
|
||||||
|
|
||||||
@@ -107,11 +110,8 @@ namespace OpenWifi {
|
|||||||
const auto &Object = element.extract<Poco::JSON::Object::Ptr>();
|
const auto &Object = element.extract<Poco::JSON::Object::Ptr>();
|
||||||
ReplaceVariablesInObject(Object, Expanded);
|
ReplaceVariablesInObject(Object, Expanded);
|
||||||
ResultArray->add(Expanded);
|
ResultArray->add(Expanded);
|
||||||
} else if( element.isString() ||
|
} else if (element.isString() || element.isNumeric() || element.isBoolean() ||
|
||||||
element.isNumeric() ||
|
element.isInteger() || element.isSigned()) {
|
||||||
element.isBoolean() ||
|
|
||||||
element.isInteger() ||
|
|
||||||
element.isSigned() ) {
|
|
||||||
ResultArray->add(element);
|
ResultArray->add(element);
|
||||||
} else {
|
} else {
|
||||||
auto Expanded = Poco::makeShared<Poco::JSON::Object>();
|
auto Expanded = Poco::makeShared<Poco::JSON::Object>();
|
||||||
@@ -129,9 +129,13 @@ namespace OpenWifi {
|
|||||||
try {
|
try {
|
||||||
if (!Sub_) {
|
if (!Sub_) {
|
||||||
ProvObjects::InventoryTag D;
|
ProvObjects::InventoryTag D;
|
||||||
if (StorageService()->InventoryDB().GetRecord("serialNumber", SerialNumber_, D)) {
|
if (StorageService()->InventoryDB().GetRecord("serialNumber", SerialNumber_,
|
||||||
|
D)) {
|
||||||
if (!D.deviceConfiguration.empty()) {
|
if (!D.deviceConfiguration.empty()) {
|
||||||
|
// std::cout << "Adding device specific configuration: " << D.deviceConfiguration.size() << std::endl;
|
||||||
AddConfiguration(D.deviceConfiguration);
|
AddConfiguration(D.deviceConfiguration);
|
||||||
|
} else {
|
||||||
|
// std::cout << "No device specific configuration." << std::endl;
|
||||||
}
|
}
|
||||||
if (!D.entity.empty()) {
|
if (!D.entity.empty()) {
|
||||||
AddEntityConfig(D.entity);
|
AddEntityConfig(D.entity);
|
||||||
@@ -141,7 +145,8 @@ namespace OpenWifi {
|
|||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
ProvObjects::SubscriberDevice D;
|
ProvObjects::SubscriberDevice D;
|
||||||
if (StorageService()->SubscriberDeviceDB().GetRecord("serialNumber", SerialNumber_, D)) {
|
if (StorageService()->SubscriberDeviceDB().GetRecord("serialNumber",
|
||||||
|
SerialNumber_, D)) {
|
||||||
if (!D.configuration.empty()) {
|
if (!D.configuration.empty()) {
|
||||||
AddConfiguration(D.configuration);
|
AddConfiguration(D.configuration);
|
||||||
}
|
}
|
||||||
@@ -153,6 +158,7 @@ namespace OpenWifi {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
std::set<std::string> Sections;
|
std::set<std::string> Sections;
|
||||||
for (const auto &i : Config_) {
|
for (const auto &i : Config_) {
|
||||||
Poco::JSON::Parser P;
|
Poco::JSON::Parser P;
|
||||||
@@ -175,7 +181,8 @@ namespace OpenWifi {
|
|||||||
ReplaceVariablesInArray(OriginalArray, ExpandedArray);
|
ReplaceVariablesInArray(OriginalArray, ExpandedArray);
|
||||||
Configuration->set(SectionName, ExpandedArray);
|
Configuration->set(SectionName, ExpandedArray);
|
||||||
} else if (O->isObject(SectionName)) {
|
} else if (O->isObject(SectionName)) {
|
||||||
auto OriginalSection = O->get(SectionName).extract<Poco::JSON::Object::Ptr>();
|
auto OriginalSection =
|
||||||
|
O->get(SectionName).extract<Poco::JSON::Object::Ptr>();
|
||||||
if (Explain_) {
|
if (Explain_) {
|
||||||
Poco::JSON::Object ExObj;
|
Poco::JSON::Object ExObj;
|
||||||
ExObj.set("from-uuid", i.info.id);
|
ExObj.set("from-uuid", i.info.id);
|
||||||
@@ -188,7 +195,7 @@ namespace OpenWifi {
|
|||||||
ReplaceVariablesInObject(OriginalSection, ExpandedSection);
|
ReplaceVariablesInObject(OriginalSection, ExpandedSection);
|
||||||
Configuration->set(SectionName, ExpandedSection);
|
Configuration->set(SectionName, ExpandedSection);
|
||||||
} else {
|
} else {
|
||||||
std::cout << " --- unknown element type --- " << O->get(SectionName).toString() << std::endl;
|
poco_warning(Logger(), fmt::format("Unknown config element type: {}",O->get(SectionName).toString()));
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (Explain_) {
|
if (Explain_) {
|
||||||
@@ -203,10 +210,75 @@ namespace OpenWifi {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if(Config_.empty())
|
|
||||||
return false;
|
|
||||||
|
|
||||||
return true;
|
// Apply overrides...
|
||||||
|
ProvObjects::ConfigurationOverrideList COL;
|
||||||
|
if (StorageService()->OverridesDB().GetRecord("serialNumber", SerialNumber_, COL)) {
|
||||||
|
for (const auto &col : COL.overrides) {
|
||||||
|
const auto Tokens = Poco::StringTokenizer(col.parameterName, ".");
|
||||||
|
if (Tokens[0] == "radios" && Tokens.count() == 3) {
|
||||||
|
std::uint64_t RadioIndex = std::strtoull(Tokens[1].c_str(), nullptr, 10);
|
||||||
|
if (RadioIndex < MaximumPossibleRadios) {
|
||||||
|
auto RadioArray = Configuration->getArray("radios");
|
||||||
|
if (RadioIndex < RadioArray->size()) {
|
||||||
|
auto IndexedRadio =
|
||||||
|
RadioArray->get(RadioIndex).extract<Poco::JSON::Object::Ptr>();
|
||||||
|
if (Tokens[2] == "tx-power") {
|
||||||
|
IndexedRadio->set(
|
||||||
|
"rx-power",
|
||||||
|
std::strtoull(col.parameterValue.c_str(), nullptr, 10));
|
||||||
|
if (Explain_) {
|
||||||
|
Poco::JSON::Object ExObj;
|
||||||
|
ExObj.set("from-name", "overrides");
|
||||||
|
ExObj.set("override", col.parameterName);
|
||||||
|
ExObj.set("source", col.source);
|
||||||
|
ExObj.set("reason", col.reason);
|
||||||
|
ExObj.set("value", col.parameterValue);
|
||||||
|
Explanation_.add(ExObj);
|
||||||
|
}
|
||||||
|
RadioArray->set(RadioIndex, IndexedRadio);
|
||||||
|
Configuration->set("radios", RadioArray);
|
||||||
|
} else if (Tokens[2] == "channel") {
|
||||||
|
if (col.parameterValue == "auto") {
|
||||||
|
IndexedRadio->set("channel", "auto");
|
||||||
|
} else {
|
||||||
|
IndexedRadio->set(
|
||||||
|
"channel",
|
||||||
|
std::strtoull(col.parameterValue.c_str(), nullptr, 10));
|
||||||
|
}
|
||||||
|
// std::cout << "Setting channel in radio " << RadioIndex << std::endl;
|
||||||
|
if (Explain_) {
|
||||||
|
Poco::JSON::Object ExObj;
|
||||||
|
ExObj.set("from-name", "overrides");
|
||||||
|
ExObj.set("override", col.parameterName);
|
||||||
|
ExObj.set("source", col.source);
|
||||||
|
ExObj.set("reason", col.reason);
|
||||||
|
ExObj.set("value", col.parameterValue);
|
||||||
|
Explanation_.add(ExObj);
|
||||||
|
}
|
||||||
|
RadioArray->set(RadioIndex, IndexedRadio);
|
||||||
|
Configuration->set("radios", RadioArray);
|
||||||
|
} else {
|
||||||
|
poco_error(
|
||||||
|
Logger(),
|
||||||
|
fmt::format("{}: Unsupported override variable name {}",
|
||||||
|
col.parameterName));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
poco_error(Logger(), fmt::format("{}: radio index out of range in {}",
|
||||||
|
col.parameterName));
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
poco_error(Logger(),
|
||||||
|
fmt::format("{}: Unsupported override variable name {}",
|
||||||
|
col.parameterName));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} catch (...) {
|
||||||
|
}
|
||||||
|
return !Config_.empty();
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool DeviceTypeMatch(const std::string &DeviceType, const Types::StringVec &Types) {
|
static bool DeviceTypeMatch(const std::string &DeviceType, const Types::StringVec &Types) {
|
||||||
@@ -226,7 +298,8 @@ namespace OpenWifi {
|
|||||||
// we need to insert after everything bigger or equal
|
// we need to insert after everything bigger or equal
|
||||||
auto Hint = std::lower_bound(Config_.cbegin(), Config_.cend(), i.weight,
|
auto Hint = std::lower_bound(Config_.cbegin(), Config_.cend(), i.weight,
|
||||||
[](const VerboseElement &Elem, uint64_t Value) {
|
[](const VerboseElement &Elem, uint64_t Value) {
|
||||||
return Elem.element.weight>=Value; });
|
return Elem.element.weight >= Value;
|
||||||
|
});
|
||||||
VerboseElement VE{.element = i, .info = ProvObjects::ObjectInfo{}};
|
VerboseElement VE{.element = i, .info = ProvObjects::ObjectInfo{}};
|
||||||
Config_.insert(Hint, VE);
|
Config_.insert(Hint, VE);
|
||||||
}
|
}
|
||||||
@@ -252,9 +325,11 @@ namespace OpenWifi {
|
|||||||
Config_.push_back(VE);
|
Config_.push_back(VE);
|
||||||
} else {
|
} else {
|
||||||
// we need to insert after everything bigger or equal
|
// we need to insert after everything bigger or equal
|
||||||
auto Hint = std::lower_bound(Config_.cbegin(),Config_.cend(),i.weight,
|
auto Hint =
|
||||||
|
std::lower_bound(Config_.cbegin(), Config_.cend(), i.weight,
|
||||||
[](const VerboseElement &Elem, uint64_t Value) {
|
[](const VerboseElement &Elem, uint64_t Value) {
|
||||||
return Elem.element.weight>=Value; });
|
return Elem.element.weight >= Value;
|
||||||
|
});
|
||||||
VerboseElement VE{.element = i, .info = Config.info};
|
VerboseElement VE{.element = i, .info = Config.info};
|
||||||
Config_.insert(Hint, VE);
|
Config_.insert(Hint, VE);
|
||||||
}
|
}
|
||||||
@@ -267,7 +342,13 @@ namespace OpenWifi {
|
|||||||
ExObj.set("reason", "deviceType mismatch");
|
ExObj.set("reason", "deviceType mismatch");
|
||||||
Explanation_.add(ExObj);
|
Explanation_.add(ExObj);
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
poco_error(Logger(),
|
||||||
|
fmt::format("Device configuration for {} is empty.", SerialNumber_));
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
poco_error(Logger(),
|
||||||
|
fmt::format("Invalid device configuration UUID for {}.", SerialNumber_));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -294,4 +375,4 @@ namespace OpenWifi {
|
|||||||
} else {
|
} else {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
} // namespace OpenWifi
|
||||||
@@ -4,12 +4,14 @@
|
|||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include <string>
|
|
||||||
#include "Poco/Logger.h"
|
#include "Poco/Logger.h"
|
||||||
#include "RESTObjects//RESTAPI_ProvObjects.h"
|
#include "RESTObjects//RESTAPI_ProvObjects.h"
|
||||||
|
#include <string>
|
||||||
|
|
||||||
namespace OpenWifi {
|
namespace OpenWifi {
|
||||||
|
|
||||||
|
constexpr std::uint64_t MaximumPossibleRadios = 6;
|
||||||
|
|
||||||
struct VerboseElement {
|
struct VerboseElement {
|
||||||
ProvObjects::DeviceConfigurationElement element;
|
ProvObjects::DeviceConfigurationElement element;
|
||||||
ProvObjects::ObjectInfo info;
|
ProvObjects::ObjectInfo info;
|
||||||
@@ -18,10 +20,10 @@ namespace OpenWifi {
|
|||||||
|
|
||||||
class APConfig {
|
class APConfig {
|
||||||
public:
|
public:
|
||||||
explicit APConfig(const std::string & SerialNumber, const std::string & DeviceType, Poco::Logger & L, bool Explain=false);
|
explicit APConfig(const std::string &SerialNumber, const std::string &DeviceType,
|
||||||
|
Poco::Logger &L, bool Explain = false);
|
||||||
explicit APConfig(const std::string &SerialNumber, Poco::Logger &L);
|
explicit APConfig(const std::string &SerialNumber, Poco::Logger &L);
|
||||||
|
|
||||||
|
|
||||||
[[nodiscard]] bool Get(Poco::JSON::Object::Ptr &Configuration);
|
[[nodiscard]] bool Get(Poco::JSON::Object::Ptr &Configuration);
|
||||||
|
|
||||||
void AddConfiguration(const std::string &UUID);
|
void AddConfiguration(const std::string &UUID);
|
||||||
@@ -30,6 +32,7 @@ namespace OpenWifi {
|
|||||||
void AddVenueConfig(const std::string &UUID);
|
void AddVenueConfig(const std::string &UUID);
|
||||||
void AddEntityConfig(const std::string &UUID);
|
void AddEntityConfig(const std::string &UUID);
|
||||||
const Poco::JSON::Array &Explanation() { return Explanation_; };
|
const Poco::JSON::Array &Explanation() { return Explanation_; };
|
||||||
|
|
||||||
private:
|
private:
|
||||||
std::string SerialNumber_;
|
std::string SerialNumber_;
|
||||||
std::string DeviceType_;
|
std::string DeviceType_;
|
||||||
@@ -42,12 +45,18 @@ namespace OpenWifi {
|
|||||||
bool Sub_ = false;
|
bool Sub_ = false;
|
||||||
Poco::Logger &Logger() { return Logger_; }
|
Poco::Logger &Logger() { return Logger_; }
|
||||||
|
|
||||||
bool ReplaceVariablesInArray( const Poco::JSON::Array::Ptr & O, Poco::JSON::Array::Ptr & Result);
|
bool ReplaceVariablesInArray(const Poco::JSON::Array::Ptr &O,
|
||||||
bool ReplaceVariablesInObject( const Poco::JSON::Object::Ptr & Original, Poco::JSON::Object::Ptr & Result);
|
Poco::JSON::Array::Ptr &Result);
|
||||||
|
bool ReplaceVariablesInObject(const Poco::JSON::Object::Ptr &Original,
|
||||||
|
Poco::JSON::Object::Ptr &Result);
|
||||||
|
|
||||||
bool FindRadio(const std::string &Band, const Poco::JSON::Array::Ptr &Arr, Poco::JSON::Object::Ptr & Radio);
|
bool FindRadio(const std::string &Band, const Poco::JSON::Array::Ptr &Arr,
|
||||||
bool mergeArray(const std::string &K, const Poco::JSON::Array::Ptr &A , const Poco::JSON::Array::Ptr &B, Poco::JSON::Array &Arr);
|
Poco::JSON::Object::Ptr &Radio);
|
||||||
bool merge(const Poco::JSON::Object::Ptr & A, const Poco::JSON::Object::Ptr & B, Poco::JSON::Object::Ptr &C);
|
bool mergeArray(const std::string &K, const Poco::JSON::Array::Ptr &A,
|
||||||
bool RemoveBand(const std::string &Band, const Poco::JSON::Array::Ptr &A_in,Poco::JSON::Array::Ptr &A_Out);
|
const Poco::JSON::Array::Ptr &B, Poco::JSON::Array &Arr);
|
||||||
|
bool merge(const Poco::JSON::Object::Ptr &A, const Poco::JSON::Object::Ptr &B,
|
||||||
|
Poco::JSON::Object::Ptr &C);
|
||||||
|
bool RemoveBand(const std::string &Band, const Poco::JSON::Array::Ptr &A_in,
|
||||||
|
Poco::JSON::Array::Ptr &A_Out);
|
||||||
};
|
};
|
||||||
}
|
} // namespace OpenWifi
|
||||||
|
|||||||
@@ -3,29 +3,37 @@
|
|||||||
//
|
//
|
||||||
|
|
||||||
#include "AutoDiscovery.h"
|
#include "AutoDiscovery.h"
|
||||||
#include "framework/ow_constants.h"
|
#include "Poco/JSON/Parser.h"
|
||||||
#include "framework/KafkaTopics.h"
|
|
||||||
#include "StorageService.h"
|
#include "StorageService.h"
|
||||||
|
#include "framework/KafkaManager.h"
|
||||||
|
#include "framework/KafkaTopics.h"
|
||||||
|
#include "framework/ow_constants.h"
|
||||||
|
|
||||||
namespace OpenWifi {
|
namespace OpenWifi {
|
||||||
|
|
||||||
int AutoDiscovery::Start() {
|
int AutoDiscovery::Start() {
|
||||||
|
poco_information(Logger(), "Starting...");
|
||||||
Running_ = true;
|
Running_ = true;
|
||||||
Types::TopicNotifyFunction F = [this](const std::string &Key, const std::string &Payload) { this->ConnectionReceived(Key,Payload); };
|
Types::TopicNotifyFunction F = [this](const std::string &Key, const std::string &Payload) {
|
||||||
|
this->ConnectionReceived(Key, Payload);
|
||||||
|
};
|
||||||
ConnectionWatcherId_ = KafkaManager()->RegisterTopicWatcher(KafkaTopics::CONNECTION, F);
|
ConnectionWatcherId_ = KafkaManager()->RegisterTopicWatcher(KafkaTopics::CONNECTION, F);
|
||||||
Worker_.start(*this);
|
Worker_.start(*this);
|
||||||
return 0;
|
return 0;
|
||||||
};
|
};
|
||||||
|
|
||||||
void AutoDiscovery::Stop() {
|
void AutoDiscovery::Stop() {
|
||||||
|
poco_information(Logger(), "Stopping...");
|
||||||
Running_ = false;
|
Running_ = false;
|
||||||
KafkaManager()->UnregisterTopicWatcher(KafkaTopics::CONNECTION, ConnectionWatcherId_);
|
KafkaManager()->UnregisterTopicWatcher(KafkaTopics::CONNECTION, ConnectionWatcherId_);
|
||||||
Queue_.wakeUpAll();
|
Queue_.wakeUpAll();
|
||||||
Worker_.join();
|
Worker_.join();
|
||||||
|
poco_information(Logger(), "Stopped...");
|
||||||
};
|
};
|
||||||
|
|
||||||
void AutoDiscovery::run() {
|
void AutoDiscovery::run() {
|
||||||
Poco::AutoPtr<Poco::Notification> Note(Queue_.waitDequeueNotification());
|
Poco::AutoPtr<Poco::Notification> Note(Queue_.waitDequeueNotification());
|
||||||
|
Utils::SetThreadName("auto-discovery");
|
||||||
while (Note && Running_) {
|
while (Note && Running_) {
|
||||||
auto Msg = dynamic_cast<DiscoveryMessage *>(Note.get());
|
auto Msg = dynamic_cast<DiscoveryMessage *>(Note.get());
|
||||||
if (Msg != nullptr) {
|
if (Msg != nullptr) {
|
||||||
@@ -37,7 +45,8 @@ namespace OpenWifi {
|
|||||||
auto PayloadObj = Object->getObject(uCentralProtocol::PAYLOAD);
|
auto PayloadObj = Object->getObject(uCentralProtocol::PAYLOAD);
|
||||||
std::string ConnectedIP, SerialNumber, DeviceType;
|
std::string ConnectedIP, SerialNumber, DeviceType;
|
||||||
if (PayloadObj->has(uCentralProtocol::CONNECTIONIP))
|
if (PayloadObj->has(uCentralProtocol::CONNECTIONIP))
|
||||||
ConnectedIP = PayloadObj->get(uCentralProtocol::CONNECTIONIP).toString();
|
ConnectedIP =
|
||||||
|
PayloadObj->get(uCentralProtocol::CONNECTIONIP).toString();
|
||||||
if (PayloadObj->has(uCentralProtocol::CAPABILITIES)) {
|
if (PayloadObj->has(uCentralProtocol::CAPABILITIES)) {
|
||||||
auto CapObj = PayloadObj->getObject(uCentralProtocol::CAPABILITIES);
|
auto CapObj = PayloadObj->getObject(uCentralProtocol::CAPABILITIES);
|
||||||
if (CapObj->has(uCentralProtocol::COMPATIBLE)) {
|
if (CapObj->has(uCentralProtocol::COMPATIBLE)) {
|
||||||
@@ -50,9 +59,12 @@ namespace OpenWifi {
|
|||||||
PingMessage->has(uCentralProtocol::SERIALNUMBER) &&
|
PingMessage->has(uCentralProtocol::SERIALNUMBER) &&
|
||||||
PingMessage->has(uCentralProtocol::COMPATIBLE)) {
|
PingMessage->has(uCentralProtocol::COMPATIBLE)) {
|
||||||
if (PingMessage->has(uCentralProtocol::CONNECTIONIP))
|
if (PingMessage->has(uCentralProtocol::CONNECTIONIP))
|
||||||
ConnectedIP = PingMessage->get(uCentralProtocol::CONNECTIONIP).toString();
|
ConnectedIP =
|
||||||
SerialNumber = PingMessage->get(uCentralProtocol::SERIALNUMBER).toString();
|
PingMessage->get(uCentralProtocol::CONNECTIONIP).toString();
|
||||||
DeviceType = PingMessage->get(uCentralProtocol::COMPATIBLE).toString();
|
SerialNumber =
|
||||||
|
PingMessage->get(uCentralProtocol::SERIALNUMBER).toString();
|
||||||
|
DeviceType =
|
||||||
|
PingMessage->get(uCentralProtocol::COMPATIBLE).toString();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
std::string Locale;
|
std::string Locale;
|
||||||
@@ -60,19 +72,18 @@ namespace OpenWifi {
|
|||||||
Locale = PayloadObj->get("locale").toString();
|
Locale = PayloadObj->get("locale").toString();
|
||||||
|
|
||||||
if (!SerialNumber.empty()) {
|
if (!SerialNumber.empty()) {
|
||||||
StorageService()->InventoryDB().CreateFromConnection(SerialNumber, ConnectedIP, DeviceType, Locale);
|
StorageService()->InventoryDB().CreateFromConnection(
|
||||||
|
SerialNumber, ConnectedIP, DeviceType, Locale);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} catch (const Poco::Exception &E) {
|
} catch (const Poco::Exception &E) {
|
||||||
Logger().log(E);
|
Logger().log(E);
|
||||||
} catch (...) {
|
} catch (...) {
|
||||||
|
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
}
|
}
|
||||||
Note = Queue_.waitDequeueNotification();
|
Note = Queue_.waitDequeueNotification();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
} // namespace OpenWifi
|
||||||
@@ -4,18 +4,21 @@
|
|||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include "framework/MicroService.h"
|
|
||||||
#include "framework/OpenWifiTypes.h"
|
#include "framework/OpenWifiTypes.h"
|
||||||
|
#include "framework/SubSystemServer.h"
|
||||||
|
|
||||||
|
#include "Poco/Notification.h"
|
||||||
|
#include "Poco/NotificationQueue.h"
|
||||||
|
|
||||||
namespace OpenWifi {
|
namespace OpenWifi {
|
||||||
|
|
||||||
class DiscoveryMessage : public Poco::Notification {
|
class DiscoveryMessage : public Poco::Notification {
|
||||||
public:
|
public:
|
||||||
explicit DiscoveryMessage(const std::string &Key, const std::string &Payload ) :
|
explicit DiscoveryMessage(const std::string &Key, const std::string &Payload)
|
||||||
Key_(Key),
|
: Key_(Key), Payload_(Payload) {}
|
||||||
Payload_(Payload) {}
|
|
||||||
const std::string &Key() { return Key_; }
|
const std::string &Key() { return Key_; }
|
||||||
const std::string &Payload() { return Payload_; }
|
const std::string &Payload() { return Payload_; }
|
||||||
|
|
||||||
private:
|
private:
|
||||||
std::string Key_;
|
std::string Key_;
|
||||||
std::string Payload_;
|
std::string Payload_;
|
||||||
@@ -23,7 +26,6 @@ namespace OpenWifi {
|
|||||||
|
|
||||||
class AutoDiscovery : public SubSystemServer, Poco::Runnable {
|
class AutoDiscovery : public SubSystemServer, Poco::Runnable {
|
||||||
public:
|
public:
|
||||||
|
|
||||||
static auto instance() {
|
static auto instance() {
|
||||||
static auto instance_ = new AutoDiscovery;
|
static auto instance_ = new AutoDiscovery;
|
||||||
return instance_;
|
return instance_;
|
||||||
@@ -33,7 +35,7 @@ namespace OpenWifi {
|
|||||||
void Stop() override;
|
void Stop() override;
|
||||||
void ConnectionReceived(const std::string &Key, const std::string &Payload) {
|
void ConnectionReceived(const std::string &Key, const std::string &Payload) {
|
||||||
std::lock_guard G(Mutex_);
|
std::lock_guard G(Mutex_);
|
||||||
Logger().information(Poco::format("Device(%s): Connection/Ping message.", Key));
|
poco_trace(Logger(), Poco::format("Device(%s): Connection/Ping message.", Key));
|
||||||
Queue_.enqueueNotification(new DiscoveryMessage(Key, Payload));
|
Queue_.enqueueNotification(new DiscoveryMessage(Key, Payload));
|
||||||
}
|
}
|
||||||
void run() override;
|
void run() override;
|
||||||
@@ -44,13 +46,10 @@ namespace OpenWifi {
|
|||||||
Poco::Thread Worker_;
|
Poco::Thread Worker_;
|
||||||
std::atomic_bool Running_ = false;
|
std::atomic_bool Running_ = false;
|
||||||
|
|
||||||
AutoDiscovery() noexcept:
|
AutoDiscovery() noexcept
|
||||||
SubSystemServer("AutoDiscovery", "AUTO-DISCOVERY", "discovery")
|
: SubSystemServer("AutoDiscovery", "AUTO-DISCOVERY", "discovery") {}
|
||||||
{
|
|
||||||
}
|
|
||||||
};
|
};
|
||||||
|
|
||||||
inline auto AutoDiscovery() { return AutoDiscovery::instance(); }
|
inline auto AutoDiscovery() { return AutoDiscovery::instance(); }
|
||||||
|
|
||||||
}
|
} // namespace OpenWifi
|
||||||
|
|
||||||
|
|||||||
@@ -4,8 +4,8 @@
|
|||||||
|
|
||||||
#include "ConfigSanityChecker.h"
|
#include "ConfigSanityChecker.h"
|
||||||
#include "nlohmann/json.hpp"
|
#include "nlohmann/json.hpp"
|
||||||
#include <iostream>
|
|
||||||
#include <iomanip>
|
#include <iomanip>
|
||||||
|
#include <iostream>
|
||||||
|
|
||||||
namespace OpenWifi {
|
namespace OpenWifi {
|
||||||
|
|
||||||
@@ -20,34 +20,28 @@ namespace OpenWifi {
|
|||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
} catch (...) {
|
} catch (...) {
|
||||||
|
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
void ConfigSanityChecker::Check_radios([[maybe_unused]] nlohmann::json &d) {
|
void ConfigSanityChecker::Check_radios([[maybe_unused]] nlohmann::json &d) {
|
||||||
std::cout << "Validating radios" << std::endl;
|
std::cout << "Validating radios" << std::endl;
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
void ConfigSanityChecker::Check_interfaces([[maybe_unused]] nlohmann::json &d) {
|
void ConfigSanityChecker::Check_interfaces([[maybe_unused]] nlohmann::json &d) {
|
||||||
std::cout << "Validating interfaces" << std::endl;
|
std::cout << "Validating interfaces" << std::endl;
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
void ConfigSanityChecker::Check_metrics([[maybe_unused]] nlohmann::json &d) {
|
void ConfigSanityChecker::Check_metrics([[maybe_unused]] nlohmann::json &d) {
|
||||||
std::cout << "Validating metrics" << std::endl;
|
std::cout << "Validating metrics" << std::endl;
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
void ConfigSanityChecker::Check_services([[maybe_unused]] nlohmann::json &d) {
|
void ConfigSanityChecker::Check_services([[maybe_unused]] nlohmann::json &d) {
|
||||||
std::cout << "Validating services" << std::endl;
|
std::cout << "Validating services" << std::endl;
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
void ConfigSanityChecker::Check_uuid([[maybe_unused]] nlohmann::json &d) {
|
void ConfigSanityChecker::Check_uuid([[maybe_unused]] nlohmann::json &d) {
|
||||||
std::cout << "Validating uuid" << std::endl;
|
std::cout << "Validating uuid" << std::endl;
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
} // namespace OpenWifi
|
||||||
@@ -4,13 +4,13 @@
|
|||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include <string>
|
|
||||||
#include <list>
|
|
||||||
#include <functional>
|
|
||||||
#include <map>
|
|
||||||
#include <vector>
|
|
||||||
#include <utility>
|
|
||||||
#include "nlohmann/json.hpp"
|
#include "nlohmann/json.hpp"
|
||||||
|
#include <functional>
|
||||||
|
#include <list>
|
||||||
|
#include <map>
|
||||||
|
#include <string>
|
||||||
|
#include <utility>
|
||||||
|
#include <vector>
|
||||||
|
|
||||||
namespace OpenWifi {
|
namespace OpenWifi {
|
||||||
struct SanityError {
|
struct SanityError {
|
||||||
@@ -23,9 +23,8 @@ namespace OpenWifi {
|
|||||||
|
|
||||||
class ConfigSanityChecker {
|
class ConfigSanityChecker {
|
||||||
public:
|
public:
|
||||||
explicit ConfigSanityChecker(std::string Config, std::string DeviceType) :
|
explicit ConfigSanityChecker(std::string Config, std::string DeviceType)
|
||||||
Config_(std::move(Config)),
|
: Config_(std::move(Config)), DeviceType_(std::move(DeviceType)) {}
|
||||||
DeviceType_(std::move(DeviceType)){}
|
|
||||||
|
|
||||||
bool Check();
|
bool Check();
|
||||||
const SanityErrorList &Errors() { return Errors_; }
|
const SanityErrorList &Errors() { return Errors_; }
|
||||||
@@ -56,7 +55,6 @@ namespace OpenWifi {
|
|||||||
std::make_pair("interfaces", [this](nlohmann::json &d) { this->Check_interfaces(d); }),
|
std::make_pair("interfaces", [this](nlohmann::json &d) { this->Check_interfaces(d); }),
|
||||||
std::make_pair("metrics", [this](nlohmann::json &d) { this->Check_metrics(d); }),
|
std::make_pair("metrics", [this](nlohmann::json &d) { this->Check_metrics(d); }),
|
||||||
std::make_pair("services", [this](nlohmann::json &d) { this->Check_services(d); }),
|
std::make_pair("services", [this](nlohmann::json &d) { this->Check_services(d); }),
|
||||||
std::make_pair("uuid", [this](nlohmann::json &d){ this->Check_uuid(d);} )
|
std::make_pair("uuid", [this](nlohmann::json &d) { this->Check_uuid(d); })};
|
||||||
};
|
};
|
||||||
};
|
} // namespace OpenWifi
|
||||||
}
|
|
||||||
|
|||||||
@@ -6,43 +6,36 @@
|
|||||||
// Arilia Wireless Inc.
|
// Arilia Wireless Inc.
|
||||||
//
|
//
|
||||||
|
|
||||||
|
#include "Poco/Environment.h"
|
||||||
|
#include "Poco/Net/SSLManager.h"
|
||||||
#include "Poco/Util/Application.h"
|
#include "Poco/Util/Application.h"
|
||||||
#include "Poco/Util/Option.h"
|
#include "Poco/Util/Option.h"
|
||||||
#include "Poco/Environment.h"
|
|
||||||
|
|
||||||
#include "Daemon.h"
|
|
||||||
#include "StorageService.h"
|
|
||||||
#include "AutoDiscovery.h"
|
#include "AutoDiscovery.h"
|
||||||
#include "framework/ConfigurationValidator.h"
|
#include "Daemon.h"
|
||||||
#include "SerialNumberCache.h"
|
|
||||||
#include "JobController.h"
|
|
||||||
#include "FindCountry.h"
|
|
||||||
#include "Signup.h"
|
|
||||||
#include "DeviceTypeCache.h"
|
#include "DeviceTypeCache.h"
|
||||||
#include "FileDownloader.h"
|
#include "FileDownloader.h"
|
||||||
|
#include "FindCountry.h"
|
||||||
|
#include "JobController.h"
|
||||||
|
#include "SerialNumberCache.h"
|
||||||
|
#include "Signup.h"
|
||||||
|
#include "StorageService.h"
|
||||||
|
#include "UI_Prov_WebSocketNotifications.h"
|
||||||
|
#include "framework/ConfigurationValidator.h"
|
||||||
|
#include "framework/UI_WebSocketClientServer.h"
|
||||||
|
|
||||||
namespace OpenWifi {
|
namespace OpenWifi {
|
||||||
class Daemon *Daemon::instance_ = nullptr;
|
class Daemon *Daemon::instance_ = nullptr;
|
||||||
|
|
||||||
class Daemon *Daemon::instance() {
|
class Daemon *Daemon::instance() {
|
||||||
if (instance_ == nullptr) {
|
if (instance_ == nullptr) {
|
||||||
instance_ = new Daemon(vDAEMON_PROPERTIES_FILENAME,
|
instance_ = new Daemon(vDAEMON_PROPERTIES_FILENAME, vDAEMON_ROOT_ENV_VAR,
|
||||||
vDAEMON_ROOT_ENV_VAR,
|
vDAEMON_CONFIG_ENV_VAR, vDAEMON_APP_NAME, vDAEMON_BUS_TIMER,
|
||||||
vDAEMON_CONFIG_ENV_VAR,
|
SubSystemVec{OpenWifi::StorageService(), DeviceTypeCache(),
|
||||||
vDAEMON_APP_NAME,
|
ConfigurationValidator(), SerialNumberCache(),
|
||||||
vDAEMON_BUS_TIMER,
|
AutoDiscovery(), JobController(),
|
||||||
SubSystemVec{
|
UI_WebSocketClientServer(), FindCountryFromIP(),
|
||||||
OpenWifi::StorageService(),
|
Signup(), FileDownloader()});
|
||||||
DeviceTypeCache(),
|
|
||||||
ConfigurationValidator(),
|
|
||||||
SerialNumberCache(),
|
|
||||||
AutoDiscovery(),
|
|
||||||
JobController(),
|
|
||||||
WebSocketClientServer(),
|
|
||||||
FindCountryFromIP(),
|
|
||||||
Signup(),
|
|
||||||
FileDownloader()
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
return instance_;
|
return instance_;
|
||||||
}
|
}
|
||||||
@@ -70,20 +63,34 @@ namespace OpenWifi {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void DaemonPostInitialization(Poco::Util::Application &self) {
|
||||||
|
Daemon()->PostInitialization(self);
|
||||||
|
ProvWebSocketNotifications::Register();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
} // namespace OpenWifi
|
||||||
|
|
||||||
int main(int argc, char **argv) {
|
int main(int argc, char **argv) {
|
||||||
|
int ExitCode;
|
||||||
try {
|
try {
|
||||||
|
Poco::Net::SSLManager::instance().initializeServer(nullptr, nullptr, nullptr);
|
||||||
auto App = OpenWifi::Daemon::instance();
|
auto App = OpenWifi::Daemon::instance();
|
||||||
auto ExitCode = App->run(argc, argv);
|
ExitCode = App->run(argc, argv);
|
||||||
delete App;
|
Poco::Net::SSLManager::instance().shutdown();
|
||||||
|
|
||||||
return ExitCode;
|
|
||||||
|
|
||||||
} catch (Poco::Exception &exc) {
|
} catch (Poco::Exception &exc) {
|
||||||
std::cerr << exc.displayText() << std::endl;
|
ExitCode = Poco::Util::Application::EXIT_SOFTWARE;
|
||||||
return Poco::Util::Application::EXIT_SOFTWARE;
|
std::cout << exc.displayText() << std::endl;
|
||||||
|
} catch (std::exception &exc) {
|
||||||
|
ExitCode = Poco::Util::Application::EXIT_TEMPFAIL;
|
||||||
|
std::cout << exc.what() << std::endl;
|
||||||
|
} catch (...) {
|
||||||
|
ExitCode = Poco::Util::Application::EXIT_TEMPFAIL;
|
||||||
|
std::cout << "Exception on closure" << std::endl;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
std::cout << "Exitcode: " << ExitCode << std::endl;
|
||||||
|
return ExitCode;
|
||||||
}
|
}
|
||||||
|
|
||||||
// end of namespace
|
// end of namespace
|
||||||
29
src/Daemon.h
@@ -9,16 +9,17 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include <array>
|
#include <array>
|
||||||
#include <iostream>
|
|
||||||
#include <cstdlib>
|
#include <cstdlib>
|
||||||
#include <vector>
|
#include <iostream>
|
||||||
#include <set>
|
#include <set>
|
||||||
|
#include <vector>
|
||||||
|
|
||||||
#include "Dashboard.h"
|
#include "Dashboard.h"
|
||||||
#include "framework/MicroService.h"
|
|
||||||
#include "framework/OpenWifiTypes.h"
|
|
||||||
#include "RESTObjects/RESTAPI_ProvObjects.h"
|
|
||||||
#include "ProvWebSocketClient.h"
|
#include "ProvWebSocketClient.h"
|
||||||
|
#include "RESTObjects/RESTAPI_ProvObjects.h"
|
||||||
|
#include "framework/MicroService.h"
|
||||||
|
#include "framework/MicroServiceNames.h"
|
||||||
|
#include "framework/OpenWifiTypes.h"
|
||||||
|
|
||||||
namespace OpenWifi {
|
namespace OpenWifi {
|
||||||
|
|
||||||
@@ -30,13 +31,10 @@ namespace OpenWifi {
|
|||||||
|
|
||||||
class Daemon : public MicroService {
|
class Daemon : public MicroService {
|
||||||
public:
|
public:
|
||||||
explicit Daemon(const std::string & PropFile,
|
explicit Daemon(const std::string &PropFile, const std::string &RootEnv,
|
||||||
const std::string & RootEnv,
|
const std::string &ConfigEnv, const std::string &AppName, uint64_t BusTimer,
|
||||||
const std::string & ConfigEnv,
|
const SubSystemVec &SubSystems)
|
||||||
const std::string & AppName,
|
: MicroService(PropFile, RootEnv, ConfigEnv, AppName, BusTimer, SubSystems){};
|
||||||
uint64_t BusTimer,
|
|
||||||
const SubSystemVec & SubSystems) :
|
|
||||||
MicroService( PropFile, RootEnv, ConfigEnv, AppName, BusTimer, SubSystems) {};
|
|
||||||
|
|
||||||
static Daemon *instance();
|
static Daemon *instance();
|
||||||
inline OpenWifi::ProvisioningDashboard &GetDashboard() { return DB_; }
|
inline OpenWifi::ProvisioningDashboard &GetDashboard() { return DB_; }
|
||||||
@@ -54,8 +52,5 @@ namespace OpenWifi {
|
|||||||
};
|
};
|
||||||
|
|
||||||
inline Daemon *Daemon() { return Daemon::instance(); }
|
inline Daemon *Daemon() { return Daemon::instance(); }
|
||||||
inline void DaemonPostInitialization(Poco::Util::Application &self) {
|
void DaemonPostInitialization(Poco::Util::Application &self);
|
||||||
Daemon()->PostInitialization(self);
|
} // namespace OpenWifi
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|||||||
@@ -6,15 +6,15 @@
|
|||||||
// Arilia Wireless Inc.
|
// Arilia Wireless Inc.
|
||||||
//
|
//
|
||||||
#include "Dashboard.h"
|
#include "Dashboard.h"
|
||||||
#include "StorageService.h"
|
#include "framework/utils.h"
|
||||||
|
|
||||||
namespace OpenWifi {
|
namespace OpenWifi {
|
||||||
void ProvisioningDashboard::Create() {
|
void ProvisioningDashboard::Create() {
|
||||||
uint64_t Now = OpenWifi::Now();
|
uint64_t Now = Utils::Now();
|
||||||
if (LastRun_ == 0 || (Now - LastRun_) > 120) {
|
if (LastRun_ == 0 || (Now - LastRun_) > 120) {
|
||||||
DB_.reset();
|
DB_.reset();
|
||||||
// Todo: call dashboard creation code.
|
// Todo: call dashboard creation code.
|
||||||
LastRun_ = Now;
|
LastRun_ = Now;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
} // namespace OpenWifi
|
||||||
|
|||||||
@@ -8,17 +8,21 @@
|
|||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include "framework/OpenWifiTypes.h"
|
|
||||||
#include "RESTObjects/RESTAPI_ProvObjects.h"
|
#include "RESTObjects/RESTAPI_ProvObjects.h"
|
||||||
|
#include "framework/OpenWifiTypes.h"
|
||||||
|
|
||||||
namespace OpenWifi {
|
namespace OpenWifi {
|
||||||
class ProvisioningDashboard {
|
class ProvisioningDashboard {
|
||||||
public:
|
public:
|
||||||
void Create();
|
void Create();
|
||||||
[[nodiscard]] const ProvObjects::Report &Report() const { return DB_; }
|
[[nodiscard]] const ProvObjects::Report &Report() const { return DB_; }
|
||||||
inline void Reset() { LastRun_=0; DB_.reset(); }
|
inline void Reset() {
|
||||||
|
LastRun_ = 0;
|
||||||
|
DB_.reset();
|
||||||
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
ProvObjects::Report DB_{};
|
ProvObjects::Report DB_{};
|
||||||
uint64_t LastRun_ = 0;
|
uint64_t LastRun_ = 0;
|
||||||
};
|
};
|
||||||
}
|
} // namespace OpenWifi
|
||||||
|
|||||||
@@ -6,7 +6,11 @@
|
|||||||
|
|
||||||
#include <set>
|
#include <set>
|
||||||
|
|
||||||
#include "framework/MicroService.h"
|
#include "framework/AppServiceRegistry.h"
|
||||||
|
#include "framework/MicroServiceNames.h"
|
||||||
|
#include "framework/OpenAPIRequests.h"
|
||||||
|
#include "framework/SubSystemServer.h"
|
||||||
|
|
||||||
#include "Poco/Timer.h"
|
#include "Poco/Timer.h"
|
||||||
|
|
||||||
namespace OpenWifi {
|
namespace OpenWifi {
|
||||||
@@ -20,23 +24,23 @@ namespace OpenWifi {
|
|||||||
|
|
||||||
inline int Start() final {
|
inline int Start() final {
|
||||||
InitializeCache();
|
InitializeCache();
|
||||||
TimerCallback_ = std::make_unique<Poco::TimerCallback<DeviceTypeCache>>(*this,&DeviceTypeCache::onTimer);
|
TimerCallback_ = std::make_unique<Poco::TimerCallback<DeviceTypeCache>>(
|
||||||
|
*this, &DeviceTypeCache::onTimer);
|
||||||
Timer_.setStartInterval(60 * 1000); // first run in 60 seconds
|
Timer_.setStartInterval(60 * 1000); // first run in 60 seconds
|
||||||
Timer_.setPeriodicInterval(1 * 60 * 60 * 1000); // 1 hours
|
Timer_.setPeriodicInterval(1 * 60 * 60 * 1000); // 1 hours
|
||||||
Timer_.start(*TimerCallback_);
|
Timer_.start(*TimerCallback_);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void Stop() final {
|
inline void Stop() final { Timer_.stop(); }
|
||||||
Timer_.stop();
|
|
||||||
}
|
|
||||||
|
|
||||||
inline void onTimer([[maybe_unused]] Poco::Timer & timer) {
|
inline void onTimer([[maybe_unused]] Poco::Timer &timer) { UpdateDeviceTypes(); }
|
||||||
UpdateDeviceTypes();
|
|
||||||
}
|
|
||||||
|
|
||||||
inline bool IsAcceptableDeviceType(const std::string &D) const { return (DeviceTypes_.find(D)!=DeviceTypes_.end());};
|
inline bool IsAcceptableDeviceType(const std::string &D) const {
|
||||||
inline bool AreAcceptableDeviceTypes(const Types::StringVec &S, bool WildCardAllowed=true) const {
|
return (DeviceTypes_.find(D) != DeviceTypes_.end());
|
||||||
|
};
|
||||||
|
inline bool AreAcceptableDeviceTypes(const Types::StringVec &S,
|
||||||
|
bool WildCardAllowed = true) const {
|
||||||
for (const auto &i : S) {
|
for (const auto &i : S) {
|
||||||
if (WildCardAllowed && i == "*") {
|
if (WildCardAllowed && i == "*") {
|
||||||
// We allow wildcards
|
// We allow wildcards
|
||||||
@@ -52,10 +56,8 @@ namespace OpenWifi {
|
|||||||
std::set<std::string> DeviceTypes_;
|
std::set<std::string> DeviceTypes_;
|
||||||
std::unique_ptr<Poco::TimerCallback<DeviceTypeCache>> TimerCallback_;
|
std::unique_ptr<Poco::TimerCallback<DeviceTypeCache>> TimerCallback_;
|
||||||
|
|
||||||
inline DeviceTypeCache() noexcept:
|
inline DeviceTypeCache() noexcept
|
||||||
SubSystemServer("DeviceTypes", "DEV-TYPES", "devicetypes")
|
: SubSystemServer("DeviceTypes", "DEV-TYPES", "devicetypes") {}
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
inline void InitializeCache() {
|
inline void InitializeCache() {
|
||||||
std::lock_guard G(Mutex_);
|
std::lock_guard G(Mutex_);
|
||||||
@@ -70,7 +72,6 @@ namespace OpenWifi {
|
|||||||
DeviceTypes_.insert(i.toString());
|
DeviceTypes_.insert(i.toString());
|
||||||
}
|
}
|
||||||
} catch (...) {
|
} catch (...) {
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -80,10 +81,7 @@ namespace OpenWifi {
|
|||||||
Types::StringPairVec QueryData;
|
Types::StringPairVec QueryData;
|
||||||
|
|
||||||
QueryData.push_back(std::make_pair("deviceSet", "true"));
|
QueryData.push_back(std::make_pair("deviceSet", "true"));
|
||||||
OpenAPIRequestGet Req( uSERVICE_FIRMWARE,
|
OpenAPIRequestGet Req(uSERVICE_FIRMWARE, "/api/v1/firmwares", QueryData, 10000);
|
||||||
"/api/v1/firmwares",
|
|
||||||
QueryData,
|
|
||||||
10000);
|
|
||||||
|
|
||||||
auto Response = Poco::makeShared<Poco::JSON::Object>();
|
auto Response = Poco::makeShared<Poco::JSON::Object>();
|
||||||
auto StatusCode = Req.Do(Response);
|
auto StatusCode = Req.Do(Response);
|
||||||
@@ -123,4 +121,4 @@ namespace OpenWifi {
|
|||||||
|
|
||||||
inline auto DeviceTypeCache() { return DeviceTypeCache::instance(); }
|
inline auto DeviceTypeCache() { return DeviceTypeCache::instance(); }
|
||||||
|
|
||||||
}
|
} // namespace OpenWifi
|
||||||
@@ -7,7 +7,9 @@
|
|||||||
|
|
||||||
namespace OpenWifi {
|
namespace OpenWifi {
|
||||||
int FileDownloader::Start() {
|
int FileDownloader::Start() {
|
||||||
TimerCallback_ = std::make_unique<Poco::TimerCallback<FileDownloader>>(*this,&FileDownloader::onTimer);
|
poco_information(Logger(), "Starting...");
|
||||||
|
TimerCallback_ =
|
||||||
|
std::make_unique<Poco::TimerCallback<FileDownloader>>(*this, &FileDownloader::onTimer);
|
||||||
Timer_.setStartInterval(20 * 1000); // first run in 20 seconds
|
Timer_.setStartInterval(20 * 1000); // first run in 20 seconds
|
||||||
Timer_.setPeriodicInterval(2 * 60 * 60 * 1000); // 1 hours
|
Timer_.setPeriodicInterval(2 * 60 * 60 * 1000); // 1 hours
|
||||||
Timer_.start(*TimerCallback_);
|
Timer_.start(*TimerCallback_);
|
||||||
@@ -15,16 +17,18 @@ namespace OpenWifi {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void FileDownloader::Stop() {
|
void FileDownloader::Stop() {
|
||||||
|
poco_information(Logger(), "Stopping...");
|
||||||
Timer_.stop();
|
Timer_.stop();
|
||||||
Logger().notice("Stopping.");
|
poco_information(Logger(), "Stopped...");
|
||||||
}
|
}
|
||||||
|
|
||||||
void FileDownloader::onTimer([[maybe_unused]] Poco::Timer &timer) {
|
void FileDownloader::onTimer([[maybe_unused]] Poco::Timer &timer) {
|
||||||
const static std::vector<std::pair<std::string,std::string>> Files
|
const static std::vector<std::pair<std::string, std::string>> Files{
|
||||||
{
|
{"https://raw.githubusercontent.com/blogic/ucentral-schema/main/ucentral.schema.json",
|
||||||
{"https://raw.githubusercontent.com/blogic/ucentral-schema/main/ucentral.schema.json", "ucentral.schema.json" },
|
"ucentral.schema.json"},
|
||||||
{"https://ucentral.io/ucentral.schema.pretty.json", "ucentral.schema.pretty.json" }
|
{"https://ucentral.io/ucentral.schema.pretty.json", "ucentral.schema.pretty.json"}};
|
||||||
};
|
|
||||||
|
Utils::SetThreadName("file-dmnldr");
|
||||||
|
|
||||||
for (const auto &[url, filename] : Files) {
|
for (const auto &[url, filename] : Files) {
|
||||||
try {
|
try {
|
||||||
@@ -40,4 +44,4 @@ namespace OpenWifi {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
} // namespace OpenWifi
|
||||||
@@ -3,14 +3,13 @@
|
|||||||
//
|
//
|
||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
#include "framework/MicroService.h"
|
|
||||||
#include "Poco/Timer.h"
|
#include "Poco/Timer.h"
|
||||||
|
#include "framework/SubSystemServer.h"
|
||||||
|
|
||||||
namespace OpenWifi {
|
namespace OpenWifi {
|
||||||
|
|
||||||
class FileDownloader : public SubSystemServer {
|
class FileDownloader : public SubSystemServer {
|
||||||
public:
|
public:
|
||||||
|
|
||||||
static auto instance() {
|
static auto instance() {
|
||||||
static auto instance_ = new FileDownloader;
|
static auto instance_ = new FileDownloader;
|
||||||
return instance_;
|
return instance_;
|
||||||
@@ -25,10 +24,9 @@ namespace OpenWifi {
|
|||||||
std::unique_ptr<Poco::TimerCallback<FileDownloader>> TimerCallback_;
|
std::unique_ptr<Poco::TimerCallback<FileDownloader>> TimerCallback_;
|
||||||
std::atomic_bool Running_ = false;
|
std::atomic_bool Running_ = false;
|
||||||
|
|
||||||
FileDownloader() noexcept:
|
FileDownloader() noexcept
|
||||||
SubSystemServer("FileDownloader", "FILE-DOWNLOADER", "downloader") {
|
: SubSystemServer("FileDownloader", "FILE-DOWNLOADER", "downloader") {}
|
||||||
}
|
|
||||||
};
|
};
|
||||||
|
|
||||||
inline auto FileDownloader() { return FileDownloader::instance(); }
|
inline auto FileDownloader() { return FileDownloader::instance(); }
|
||||||
}
|
} // namespace OpenWifi
|
||||||
|
|||||||
@@ -4,8 +4,11 @@
|
|||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include "framework/MicroService.h"
|
|
||||||
#include "Poco/Net/IPAddress.h"
|
#include "Poco/Net/IPAddress.h"
|
||||||
|
|
||||||
|
#include "framework/MicroServiceFuncs.h"
|
||||||
|
#include "framework/SubSystemServer.h"
|
||||||
|
|
||||||
#include "nlohmann/json.hpp"
|
#include "nlohmann/json.hpp"
|
||||||
|
|
||||||
namespace OpenWifi {
|
namespace OpenWifi {
|
||||||
@@ -15,15 +18,14 @@ namespace OpenWifi {
|
|||||||
virtual bool Init() = 0;
|
virtual bool Init() = 0;
|
||||||
virtual Poco::URI URI(const std::string &IPAddress) = 0;
|
virtual Poco::URI URI(const std::string &IPAddress) = 0;
|
||||||
virtual std::string Country(const std::string &Response) = 0;
|
virtual std::string Country(const std::string &Response) = 0;
|
||||||
virtual ~IPToCountryProvider() {
|
virtual ~IPToCountryProvider(){};
|
||||||
};
|
|
||||||
};
|
};
|
||||||
|
|
||||||
class IPInfo : public IPToCountryProvider {
|
class IPInfo : public IPToCountryProvider {
|
||||||
public:
|
public:
|
||||||
static std::string Name() { return "ipinfo"; }
|
static std::string Name() { return "ipinfo"; }
|
||||||
inline bool Init() override {
|
inline bool Init() override {
|
||||||
Key_ = MicroService::instance().ConfigGetString("iptocountry.ipinfo.token", "");
|
Key_ = MicroServiceConfigGetString("iptocountry.ipinfo.token", "");
|
||||||
return !Key_.empty();
|
return !Key_.empty();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -41,21 +43,19 @@ namespace OpenWifi {
|
|||||||
return IPInfo["country"];
|
return IPInfo["country"];
|
||||||
}
|
}
|
||||||
} catch (...) {
|
} catch (...) {
|
||||||
|
|
||||||
}
|
}
|
||||||
return "";
|
return "";
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
std::string Key_;
|
std::string Key_;
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
class IPData : public IPToCountryProvider {
|
class IPData : public IPToCountryProvider {
|
||||||
public:
|
public:
|
||||||
static std::string Name() { return "ipdata"; }
|
static std::string Name() { return "ipdata"; }
|
||||||
inline bool Init() override {
|
inline bool Init() override {
|
||||||
Key_ = MicroService::instance().ConfigGetString("iptocountry.ipdata.apikey", "");
|
Key_ = MicroServiceConfigGetString("iptocountry.ipdata.apikey", "");
|
||||||
return !Key_.empty();
|
return !Key_.empty();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -73,10 +73,10 @@ namespace OpenWifi {
|
|||||||
return IPInfo["country_code"];
|
return IPInfo["country_code"];
|
||||||
}
|
}
|
||||||
} catch (...) {
|
} catch (...) {
|
||||||
|
|
||||||
}
|
}
|
||||||
return "";
|
return "";
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
std::string Key_;
|
std::string Key_;
|
||||||
};
|
};
|
||||||
@@ -85,7 +85,7 @@ namespace OpenWifi {
|
|||||||
public:
|
public:
|
||||||
static std::string Name() { return "ip2location"; }
|
static std::string Name() { return "ip2location"; }
|
||||||
inline bool Init() override {
|
inline bool Init() override {
|
||||||
Key_ = MicroService::instance().ConfigGetString("iptocountry.ip2location.apikey", "");
|
Key_ = MicroServiceConfigGetString("iptocountry.ip2location.apikey", "");
|
||||||
return !Key_.empty();
|
return !Key_.empty();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -105,10 +105,10 @@ namespace OpenWifi {
|
|||||||
return IPInfo["country_code"];
|
return IPInfo["country_code"];
|
||||||
}
|
}
|
||||||
} catch (...) {
|
} catch (...) {
|
||||||
|
|
||||||
}
|
}
|
||||||
return "";
|
return "";
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
std::string Key_;
|
std::string Key_;
|
||||||
};
|
};
|
||||||
@@ -133,24 +133,27 @@ namespace OpenWifi {
|
|||||||
}
|
}
|
||||||
|
|
||||||
inline int Start() final {
|
inline int Start() final {
|
||||||
ProviderName_ = MicroService::instance().ConfigGetString("iptocountry.provider","");
|
poco_notice(Logger(), "Starting...");
|
||||||
|
ProviderName_ = MicroServiceConfigGetString("iptocountry.provider", "");
|
||||||
if (!ProviderName_.empty()) {
|
if (!ProviderName_.empty()) {
|
||||||
Provider_ = IPLocationProvider<IPToCountryProvider, IPInfo, IPData, IP2Location>(ProviderName_);
|
Provider_ = IPLocationProvider<IPToCountryProvider, IPInfo, IPData, IP2Location>(
|
||||||
|
ProviderName_);
|
||||||
if (Provider_ != nullptr) {
|
if (Provider_ != nullptr) {
|
||||||
Enabled_ = Provider_->Init();
|
Enabled_ = Provider_->Init();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Default_ = MicroService::instance().ConfigGetString("iptocountry.default", "US");
|
Default_ = MicroServiceConfigGetString("iptocountry.default", "US");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void Stop() final {
|
inline void Stop() final {
|
||||||
|
poco_notice(Logger(), "Stopping...");
|
||||||
|
// Nothing to do - just to provide the same look at the others.
|
||||||
|
poco_notice(Logger(), "Stopped...");
|
||||||
}
|
}
|
||||||
|
|
||||||
[[nodiscard]] static inline std::string ReformatAddress(const std::string & I )
|
[[nodiscard]] static inline std::string ReformatAddress(const std::string &I) {
|
||||||
{
|
if (I.substr(0, 7) == "::ffff:") {
|
||||||
if(I.substr(0,7) == "::ffff:")
|
|
||||||
{
|
|
||||||
std::string ip = I.substr(7);
|
std::string ip = I.substr(7);
|
||||||
return ip;
|
return ip;
|
||||||
}
|
}
|
||||||
@@ -187,12 +190,9 @@ namespace OpenWifi {
|
|||||||
std::unique_ptr<IPToCountryProvider> Provider_;
|
std::unique_ptr<IPToCountryProvider> Provider_;
|
||||||
std::string ProviderName_;
|
std::string ProviderName_;
|
||||||
|
|
||||||
FindCountryFromIP() noexcept:
|
FindCountryFromIP() noexcept : SubSystemServer("IpToCountry", "IPTOC-SVR", "iptocountry") {}
|
||||||
SubSystemServer("IpToCountry", "IPTOC-SVR", "iptocountry")
|
|
||||||
{
|
|
||||||
}
|
|
||||||
};
|
};
|
||||||
|
|
||||||
inline auto FindCountryFromIP() { return FindCountryFromIP::instance(); }
|
inline auto FindCountryFromIP() { return FindCountryFromIP::instance(); }
|
||||||
|
|
||||||
}
|
} // namespace OpenWifi
|
||||||
|
|||||||
@@ -3,15 +3,16 @@
|
|||||||
//
|
//
|
||||||
|
|
||||||
#include "JobController.h"
|
#include "JobController.h"
|
||||||
|
#include "fmt/format.h"
|
||||||
|
#include "framework/utils.h"
|
||||||
|
|
||||||
namespace OpenWifi {
|
namespace OpenWifi {
|
||||||
|
|
||||||
void RegisterJobTypes();
|
void RegisterJobTypes();
|
||||||
|
|
||||||
int JobController::Start() {
|
int JobController::Start() {
|
||||||
|
poco_information(Logger(), "Starting...");
|
||||||
RegisterJobTypes();
|
RegisterJobTypes();
|
||||||
|
|
||||||
if (!Running_)
|
if (!Running_)
|
||||||
Thr_.start(*this);
|
Thr_.start(*this);
|
||||||
|
|
||||||
@@ -20,18 +21,45 @@ namespace OpenWifi {
|
|||||||
|
|
||||||
void JobController::Stop() {
|
void JobController::Stop() {
|
||||||
if (Running_) {
|
if (Running_) {
|
||||||
|
poco_information(Logger(), "Stopping...");
|
||||||
Running_ = false;
|
Running_ = false;
|
||||||
Thr_.join();
|
Thr_.join();
|
||||||
|
poco_information(Logger(), "Stopped...");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void JobController::run() {
|
void JobController::run() {
|
||||||
Running_ = true;
|
Running_ = true;
|
||||||
|
Utils::SetThreadName("job-controller");
|
||||||
while (Running_) {
|
while (Running_) {
|
||||||
Poco::Thread::trySleep(2000);
|
Poco::Thread::trySleep(2000);
|
||||||
|
|
||||||
|
std::lock_guard G(Mutex_);
|
||||||
|
|
||||||
|
for (auto ¤t_job : jobs_) {
|
||||||
|
if (current_job != nullptr) {
|
||||||
|
if (current_job->Started() == 0 && Pool_.used() < Pool_.available()) {
|
||||||
|
poco_information(current_job->Logger(),
|
||||||
|
fmt::format("Starting {}: {}", current_job->JobId(),
|
||||||
|
current_job->Name()));
|
||||||
|
current_job->Start();
|
||||||
|
Pool_.start(*current_job);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
for (auto it = jobs_.begin(); it != jobs_.end();) {
|
||||||
|
auto current_job = *it;
|
||||||
|
if (current_job != nullptr && current_job->Completed() != 0) {
|
||||||
|
poco_information(
|
||||||
|
current_job->Logger(),
|
||||||
|
fmt::format("Completed {}: {}", current_job->JobId(), current_job->Name()));
|
||||||
|
it = jobs_.erase(it);
|
||||||
|
delete current_job;
|
||||||
|
} else {
|
||||||
|
++it;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} // namespace OpenWifi
|
||||||
@@ -4,102 +4,47 @@
|
|||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include <vector>
|
#include "RESTObjects/RESTAPI_SecurityObjects.h"
|
||||||
#include <utility>
|
#include "framework/SubSystemServer.h"
|
||||||
|
#include "framework/utils.h"
|
||||||
#include <functional>
|
#include <functional>
|
||||||
#include "framework/MicroService.h"
|
#include <list>
|
||||||
|
#include <utility>
|
||||||
|
#include <vector>
|
||||||
|
|
||||||
namespace OpenWifi {
|
namespace OpenWifi {
|
||||||
|
|
||||||
class Job {
|
class Job : public Poco::Runnable {
|
||||||
public:
|
public:
|
||||||
struct Parameter {
|
Job(const std::string &JobID, const std::string &name,
|
||||||
std::string name;
|
const std::vector<std::string> ¶meters, uint64_t when,
|
||||||
std::string value;
|
const SecurityObjects::UserInfo &UI, Poco::Logger &L)
|
||||||
inline void to_json(Poco::JSON::Object &Obj) const {
|
: jobId_(JobID), name_(name), parameters_(parameters), when_(when), userinfo_(UI),
|
||||||
RESTAPI_utils::field_to_json(Obj,"name",name);
|
Logger_(L){};
|
||||||
RESTAPI_utils::field_to_json(Obj,"value",value);
|
|
||||||
}
|
|
||||||
|
|
||||||
inline bool from_json(const Poco::JSON::Object::Ptr &Obj) {
|
virtual void run() = 0;
|
||||||
try {
|
[[nodiscard]] std::string Name() const { return name_; }
|
||||||
RESTAPI_utils::field_from_json(Obj,"name",name);
|
const SecurityObjects::UserInfo &UserInfo() const { return userinfo_; }
|
||||||
RESTAPI_utils::field_from_json(Obj,"value",value);
|
Poco::Logger &Logger() { return Logger_; }
|
||||||
return true;
|
const std::string &JobId() const { return jobId_; }
|
||||||
} catch (...) {
|
const std::string &Parameter(int x) const { return parameters_[x]; }
|
||||||
|
uint64_t When() const { return when_; }
|
||||||
}
|
void Start() { started_ = Utils::Now(); }
|
||||||
return false;
|
uint64_t Started() const { return started_; }
|
||||||
}
|
uint64_t Completed() const { return completed_; }
|
||||||
};
|
void Complete() { completed_ = Utils::Now(); }
|
||||||
|
|
||||||
struct Status {
|
|
||||||
Types::UUID_t UUID;
|
|
||||||
uint64_t Start = 0 ;
|
|
||||||
uint64_t Progress = 0 ;
|
|
||||||
uint64_t Completed = 0 ;
|
|
||||||
std::string CurrentDisplay;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct Result {
|
|
||||||
int Error=0;
|
|
||||||
std::string Reason;
|
|
||||||
};
|
|
||||||
|
|
||||||
typedef std::vector<Parameter> Parameters;
|
|
||||||
typedef std::vector<Parameters> ParametersVec;
|
|
||||||
typedef std::function<bool(const Parameters &Parameters, Result &Result, bool &Retry)> WorkerFunction;
|
|
||||||
typedef std::vector<Status> Statuses;
|
|
||||||
|
|
||||||
Job(std::string Title,
|
|
||||||
std::string Description,
|
|
||||||
std::string RegisteredName,
|
|
||||||
ParametersVec Parameters,
|
|
||||||
[[maybe_unused]] bool Parallel=true) :
|
|
||||||
Title_(std::move(Title)),
|
|
||||||
Description_(std::move(Description)),
|
|
||||||
RegisteredName_(std::move(RegisteredName)),
|
|
||||||
Parameters_(std::move(Parameters))
|
|
||||||
{
|
|
||||||
UUID_ = MicroService::instance().CreateUUID();
|
|
||||||
}
|
|
||||||
|
|
||||||
[[nodiscard]] inline const Types::UUID_t & ID() const { return UUID_; }
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Types::UUID_t UUID_;
|
std::string jobId_;
|
||||||
std::string Title_;
|
std::string name_;
|
||||||
std::string Description_;
|
std::vector<std::string> parameters_;
|
||||||
std::string RegisteredName_;
|
uint64_t when_ = 0;
|
||||||
ParametersVec Parameters_;
|
SecurityObjects::UserInfo userinfo_;
|
||||||
|
Poco::Logger &Logger_;
|
||||||
|
uint64_t started_ = 0;
|
||||||
|
uint64_t completed_ = 0;
|
||||||
};
|
};
|
||||||
|
|
||||||
class JobRegistry {
|
|
||||||
public:
|
|
||||||
static auto instance() {
|
|
||||||
static auto instance_ = new JobRegistry;
|
|
||||||
return instance_;
|
|
||||||
}
|
|
||||||
|
|
||||||
inline void RegisterJobType( const std::string & JobType, Job::WorkerFunction Function) {
|
|
||||||
JobTypes_[JobType] = std::move(Function);
|
|
||||||
}
|
|
||||||
|
|
||||||
inline bool Execute(const std::string &JobType, const Job::Parameters & Params, Job::Result &Result, bool & Retry) {
|
|
||||||
auto Hint = JobTypes_.find(JobType);
|
|
||||||
if(Hint != end(JobTypes_)) {
|
|
||||||
Hint->second(Params, Result, Retry);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
|
||||||
std::map<std::string,Job::WorkerFunction> JobTypes_;
|
|
||||||
};
|
|
||||||
|
|
||||||
inline auto JobRegistry() { return JobRegistry::instance(); }
|
|
||||||
|
|
||||||
class JobController : public SubSystemServer, Poco::Runnable {
|
class JobController : public SubSystemServer, Poco::Runnable {
|
||||||
public:
|
public:
|
||||||
static auto instance() {
|
static auto instance() {
|
||||||
@@ -112,18 +57,19 @@ namespace OpenWifi {
|
|||||||
void run() override;
|
void run() override;
|
||||||
inline void wakeup() { Thr_.wakeUp(); }
|
inline void wakeup() { Thr_.wakeUp(); }
|
||||||
|
|
||||||
bool JobList(Job::Statuses & Statuses);
|
void AddJob(Job *newJob) {
|
||||||
|
std::lock_guard G(Mutex_);
|
||||||
|
jobs_.push_back(newJob);
|
||||||
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Poco::Thread Thr_;
|
Poco::Thread Thr_;
|
||||||
std::atomic_bool Running_ = false;
|
std::atomic_bool Running_ = false;
|
||||||
|
std::list<Job *> jobs_;
|
||||||
|
Poco::ThreadPool Pool_;
|
||||||
|
|
||||||
JobController() noexcept:
|
JobController() noexcept : SubSystemServer("JobController", "JOB-SVR", "job") {}
|
||||||
SubSystemServer("JobController", "JOB-SVR", "job")
|
|
||||||
{
|
|
||||||
}
|
|
||||||
};
|
};
|
||||||
inline auto JobController() { return JobController::instance(); }
|
inline auto JobController() { return JobController::instance(); }
|
||||||
|
|
||||||
}
|
} // namespace OpenWifi
|
||||||
|
|
||||||
|
|||||||
@@ -4,8 +4,6 @@
|
|||||||
|
|
||||||
namespace OpenWifi {
|
namespace OpenWifi {
|
||||||
|
|
||||||
void RegisterJobTypes() {
|
void RegisterJobTypes() {}
|
||||||
|
|
||||||
}
|
} // namespace OpenWifi
|
||||||
|
|
||||||
}
|
|
||||||
|
|||||||
@@ -4,16 +4,16 @@
|
|||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include "framework/MicroService.h"
|
|
||||||
#include "RESTObjects/RESTAPI_ProvObjects.h"
|
#include "RESTObjects/RESTAPI_ProvObjects.h"
|
||||||
|
#include "framework/KafkaManager.h"
|
||||||
|
#include "framework/KafkaTopics.h"
|
||||||
|
|
||||||
namespace OpenWifi {
|
namespace OpenWifi {
|
||||||
|
|
||||||
enum ProvisioningOperation {
|
enum ProvisioningOperation { creation = 0, modification, removal };
|
||||||
creation=0, modification, removal
|
|
||||||
};
|
|
||||||
|
|
||||||
template <typename ObjectType> inline bool UpdateKafkaProvisioningObject( ProvisioningOperation op, const ObjectType & obj) {
|
template <typename ObjectType>
|
||||||
|
inline bool UpdateKafkaProvisioningObject(ProvisioningOperation op, const ObjectType &obj) {
|
||||||
static std::vector<std::string> Ops{"creation", "modification", "removal"};
|
static std::vector<std::string> Ops{"creation", "modification", "removal"};
|
||||||
|
|
||||||
std::string OT{"object"};
|
std::string OT{"object"};
|
||||||
@@ -45,4 +45,4 @@ namespace OpenWifi {
|
|||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
} // namespace OpenWifi
|
||||||
@@ -4,25 +4,26 @@
|
|||||||
|
|
||||||
#include "ProvWebSocketClient.h"
|
#include "ProvWebSocketClient.h"
|
||||||
|
|
||||||
#include "StorageService.h"
|
|
||||||
#include "SerialNumberCache.h"
|
#include "SerialNumberCache.h"
|
||||||
|
#include "StorageService.h"
|
||||||
|
#include "framework/UI_WebSocketClientServer.h"
|
||||||
#include "sdks/SDK_sec.h"
|
#include "sdks/SDK_sec.h"
|
||||||
|
|
||||||
namespace OpenWifi {
|
namespace OpenWifi {
|
||||||
|
|
||||||
ProvWebSocketClient::ProvWebSocketClient(Poco::Logger &Logger) :
|
ProvWebSocketClient::ProvWebSocketClient(Poco::Logger &Logger) : Logger_(Logger) {
|
||||||
Logger_(Logger){
|
UI_WebSocketClientServer()->SetProcessor(this);
|
||||||
WebSocketClientServer()->SetProcessor(this);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
ProvWebSocketClient::~ProvWebSocketClient() {
|
ProvWebSocketClient::~ProvWebSocketClient() {
|
||||||
WebSocketClientServer()->SetProcessor(nullptr);
|
UI_WebSocketClientServer()->SetProcessor(nullptr);
|
||||||
}
|
}
|
||||||
|
|
||||||
void ProvWebSocketClient::ws_command_serial_number_search(const Poco::JSON::Object::Ptr &O,
|
void ProvWebSocketClient::ws_command_serial_number_search(const Poco::JSON::Object::Ptr &O,
|
||||||
bool &Done, std::string &Answer) {
|
bool &Done, std::string &Answer) {
|
||||||
Done = false;
|
Done = false;
|
||||||
auto Prefix = O->get("serial_prefix").toString();
|
auto Prefix = ORM::Escape(O->get("serial_prefix").toString());
|
||||||
|
Poco::toLowerInPlace(Prefix);
|
||||||
Logger().information(Poco::format("serial_number_search: %s", Prefix));
|
Logger().information(Poco::format("serial_number_search: %s", Prefix));
|
||||||
if (!Prefix.empty() && Prefix.length() < 13) {
|
if (!Prefix.empty() && Prefix.length() < 13) {
|
||||||
std::vector<uint64_t> Numbers;
|
std::vector<uint64_t> Numbers;
|
||||||
@@ -38,25 +39,29 @@ namespace OpenWifi {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void ProvWebSocketClient::ws_command_address_completion(const Poco::JSON::Object::Ptr &O, bool &Done, std::string &Answer) {
|
void ProvWebSocketClient::ws_command_address_completion(const Poco::JSON::Object::Ptr &O,
|
||||||
|
bool &Done, std::string &Answer) {
|
||||||
Done = false;
|
Done = false;
|
||||||
auto Address = O->get("address").toString();
|
auto Address = O->get("address").toString();
|
||||||
Answer = GoogleGeoCodeCall(Address);
|
Answer = GoogleGeoCodeCall(Address);
|
||||||
}
|
}
|
||||||
|
|
||||||
void ProvWebSocketClient::ws_command_exit([[maybe_unused]] const Poco::JSON::Object::Ptr &O, bool &Done, std::string &Answer) {
|
void ProvWebSocketClient::ws_command_exit([[maybe_unused]] const Poco::JSON::Object::Ptr &O,
|
||||||
|
bool &Done, std::string &Answer) {
|
||||||
Done = true;
|
Done = true;
|
||||||
Answer = R"lit({ "closing" : "Goodbye! Aurevoir! Hasta la vista!" })lit";
|
Answer = R"lit({ "closing" : "Goodbye! Aurevoir! Hasta la vista!" })lit";
|
||||||
}
|
}
|
||||||
|
|
||||||
void ProvWebSocketClient::ws_command_invalid([[maybe_unused]] const Poco::JSON::Object::Ptr &O, bool &Done, std::string &Answer) {
|
void ProvWebSocketClient::ws_command_invalid([[maybe_unused]] const Poco::JSON::Object::Ptr &O,
|
||||||
|
bool &Done, std::string &Answer) {
|
||||||
Done = false;
|
Done = false;
|
||||||
Answer = std::string{R"lit({ "error" : "invalid command" })lit"};
|
Answer = std::string{R"lit({ "error" : "invalid command" })lit"};
|
||||||
}
|
}
|
||||||
|
|
||||||
void ProvWebSocketClient::ws_command_subuser_search( const Poco::JSON::Object::Ptr &O, bool &Done, std::string &Answer) {
|
void ProvWebSocketClient::ws_command_subuser_search(const Poco::JSON::Object::Ptr &O,
|
||||||
|
bool &Done, std::string &Answer) {
|
||||||
Done = false;
|
Done = false;
|
||||||
auto operatorId = O->get("operatorId").toString();
|
auto operatorId = ORM::Escape(O->get("operatorId").toString());
|
||||||
std::string nameSearch, emailSearch;
|
std::string nameSearch, emailSearch;
|
||||||
OpenWifi::RESTAPIHandler::AssignIfPresent(O, "nameSearch", nameSearch);
|
OpenWifi::RESTAPIHandler::AssignIfPresent(O, "nameSearch", nameSearch);
|
||||||
OpenWifi::RESTAPIHandler::AssignIfPresent(O, "emailSearch", emailSearch);
|
OpenWifi::RESTAPIHandler::AssignIfPresent(O, "emailSearch", emailSearch);
|
||||||
@@ -79,17 +84,22 @@ namespace OpenWifi {
|
|||||||
Answer = SS.str();
|
Answer = SS.str();
|
||||||
}
|
}
|
||||||
|
|
||||||
void ProvWebSocketClient::ws_command_subdevice_search( const Poco::JSON::Object::Ptr &O, bool &Done, std::string &Answer) {
|
void ProvWebSocketClient::ws_command_subdevice_search(const Poco::JSON::Object::Ptr &O,
|
||||||
|
bool &Done, std::string &Answer) {
|
||||||
Done = false;
|
Done = false;
|
||||||
auto operatorId = O->get("operatorId").toString();
|
auto operatorId = O->get("operatorId").toString();
|
||||||
auto Prefix = O->get("serial_prefix").toString();
|
auto Prefix = O->get("serial_prefix").toString();
|
||||||
|
Poco::toLowerInPlace(Prefix);
|
||||||
std::string Query;
|
std::string Query;
|
||||||
|
|
||||||
if (Prefix[0] == '*') {
|
if (Prefix[0] == '*') {
|
||||||
Query = fmt::format(" operatorId='{}' and (right(serialNumber,{})='{}' or right(realMacAddress,{})='{}' ) ",
|
Query = fmt::format(" operatorId='{}' and (right(serialNumber,{})='{}' or "
|
||||||
operatorId, Prefix.size()-1, Prefix.substr(1), Prefix.size()-1, Prefix.substr(1));
|
"right(realMacAddress,{})='{}' ) ",
|
||||||
|
operatorId, Prefix.size() - 1, Prefix.substr(1), Prefix.size() - 1,
|
||||||
|
Prefix.substr(1));
|
||||||
} else {
|
} else {
|
||||||
Query = fmt::format(" operatorId='{}' and (left(serialNumber,{})='{}' or left(realMacAddress,{})='{}' ) ",
|
Query = fmt::format(" operatorId='{}' and (left(serialNumber,{})='{}' or "
|
||||||
|
"left(realMacAddress,{})='{}' ) ",
|
||||||
operatorId, Prefix.size(), Prefix, Prefix.size(), Prefix);
|
operatorId, Prefix.size(), Prefix, Prefix.size(), Prefix);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -107,7 +117,10 @@ namespace OpenWifi {
|
|||||||
Answer = SS.str();
|
Answer = SS.str();
|
||||||
}
|
}
|
||||||
|
|
||||||
void ProvWebSocketClient::Processor(const Poco::JSON::Object::Ptr &O, std::string &Result, bool &Done ) {
|
void
|
||||||
|
ProvWebSocketClient::Processor(const Poco::JSON::Object::Ptr &O, std::string &Result,
|
||||||
|
bool &Done,
|
||||||
|
[[maybe_unused]] const SecurityObjects::UserInfo &UserInfo) {
|
||||||
try {
|
try {
|
||||||
if (O->has("command") && O->has("id")) {
|
if (O->has("command") && O->has("id")) {
|
||||||
auto id = (uint64_t)O->get("id");
|
auto id = (uint64_t)O->get("id");
|
||||||
@@ -115,11 +128,15 @@ namespace OpenWifi {
|
|||||||
auto Command = O->get("command").toString();
|
auto Command = O->get("command").toString();
|
||||||
if (Command == "serial_number_search" && O->has("serial_prefix")) {
|
if (Command == "serial_number_search" && O->has("serial_prefix")) {
|
||||||
ws_command_serial_number_search(O, Done, Answer);
|
ws_command_serial_number_search(O, Done, Answer);
|
||||||
} else if (WebSocketClientServer()->GeoCodeEnabled() && Command == "address_completion" && O->has("address")) {
|
} else if (UI_WebSocketClientServer()->GeoCodeEnabled() &&
|
||||||
|
Command == "address_completion" && O->has("address")) {
|
||||||
ws_command_address_completion(O, Done, Answer);
|
ws_command_address_completion(O, Done, Answer);
|
||||||
} else if (WebSocketClientServer()->GeoCodeEnabled() && Command == "subuser_search" && O->has("operatorId")) {
|
} else if (UI_WebSocketClientServer()->GeoCodeEnabled() &&
|
||||||
|
Command == "subuser_search" && O->has("operatorId")) {
|
||||||
ws_command_subuser_search(O, Done, Answer);
|
ws_command_subuser_search(O, Done, Answer);
|
||||||
} else if (WebSocketClientServer()->GeoCodeEnabled() && Command == "subdevice_search" && O->has("operatorId") && O->has("serial_prefix")) {
|
} else if (UI_WebSocketClientServer()->GeoCodeEnabled() &&
|
||||||
|
Command == "subdevice_search" && O->has("operatorId") &&
|
||||||
|
O->has("serial_prefix")) {
|
||||||
ws_command_subdevice_search(O, Done, Answer);
|
ws_command_subdevice_search(O, Done, Answer);
|
||||||
} else if (Command == "exit") {
|
} else if (Command == "exit") {
|
||||||
ws_command_exit(O, Done, Answer);
|
ws_command_exit(O, Done, Answer);
|
||||||
@@ -127,7 +144,8 @@ namespace OpenWifi {
|
|||||||
ws_command_invalid(O, Done, Answer);
|
ws_command_invalid(O, Done, Answer);
|
||||||
}
|
}
|
||||||
|
|
||||||
Result = fmt::format("{{ \"command_response_id\" : {} , \"response\" : {} }}" , id, Answer);
|
Result = fmt::format("{{ \"command_response_id\" : {} , \"response\" : {} }}", id,
|
||||||
|
Answer);
|
||||||
}
|
}
|
||||||
} catch (const Poco::Exception &E) {
|
} catch (const Poco::Exception &E) {
|
||||||
Logger().log(E);
|
Logger().log(E);
|
||||||
@@ -140,10 +158,11 @@ namespace OpenWifi {
|
|||||||
Poco::URI uri(URI);
|
Poco::URI uri(URI);
|
||||||
|
|
||||||
uri.addQueryParameter("address", A);
|
uri.addQueryParameter("address", A);
|
||||||
uri.addQueryParameter("key", WebSocketClientServer()->GoogleApiKey());
|
uri.addQueryParameter("key", UI_WebSocketClientServer()->GoogleApiKey());
|
||||||
|
|
||||||
Poco::Net::HTTPSClientSession session(uri.getHost(), uri.getPort());
|
Poco::Net::HTTPSClientSession session(uri.getHost(), uri.getPort());
|
||||||
Poco::Net::HTTPRequest req(Poco::Net::HTTPRequest::HTTP_GET, uri.getPathAndQuery(), Poco::Net::HTTPMessage::HTTP_1_1);
|
Poco::Net::HTTPRequest req(Poco::Net::HTTPRequest::HTTP_GET, uri.getPathAndQuery(),
|
||||||
|
Poco::Net::HTTPMessage::HTTP_1_1);
|
||||||
session.sendRequest(req);
|
session.sendRequest(req);
|
||||||
Poco::Net::HTTPResponse res;
|
Poco::Net::HTTPResponse res;
|
||||||
std::istream &rs = session.receiveResponse(res);
|
std::istream &rs = session.receiveResponse(res);
|
||||||
@@ -157,9 +176,8 @@ namespace OpenWifi {
|
|||||||
return R"lit({ "error: )lit" + os.str() + R"lit( })lit";
|
return R"lit({ "error: )lit" + os.str() + R"lit( })lit";
|
||||||
}
|
}
|
||||||
} catch (...) {
|
} catch (...) {
|
||||||
|
|
||||||
}
|
}
|
||||||
return "{ \"error\" : \"No call made\" }";
|
return "{ \"error\" : \"No call made\" }";
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
} // namespace OpenWifi
|
||||||
@@ -4,25 +4,31 @@
|
|||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include "framework/MicroService.h"
|
#include "framework/UI_WebSocketClientServer.h"
|
||||||
|
|
||||||
namespace OpenWifi {
|
namespace OpenWifi {
|
||||||
|
|
||||||
class ProvWebSocketClient : public WebSocketClientProcessor {
|
class ProvWebSocketClient : public UI_WebSocketClientProcessor {
|
||||||
public:
|
public:
|
||||||
explicit ProvWebSocketClient(Poco::Logger &Logger);
|
explicit ProvWebSocketClient(Poco::Logger &Logger);
|
||||||
virtual ~ProvWebSocketClient();
|
virtual ~ProvWebSocketClient();
|
||||||
virtual void Processor(const Poco::JSON::Object::Ptr &O, std::string &Answer, bool &Done );
|
virtual void Processor(const Poco::JSON::Object::Ptr &O, std::string &Answer, bool &Done,
|
||||||
void ws_command_serial_number_search( const Poco::JSON::Object::Ptr &O, bool &Done, std::string &Answer);
|
const SecurityObjects::UserInfo &UserInfo);
|
||||||
void ws_command_address_completion( const Poco::JSON::Object::Ptr &O, bool &Done, std::string &Answer);
|
void ws_command_serial_number_search(const Poco::JSON::Object::Ptr &O, bool &Done,
|
||||||
|
std::string &Answer);
|
||||||
|
void ws_command_address_completion(const Poco::JSON::Object::Ptr &O, bool &Done,
|
||||||
|
std::string &Answer);
|
||||||
void ws_command_exit(const Poco::JSON::Object::Ptr &O, bool &Done, std::string &Answer);
|
void ws_command_exit(const Poco::JSON::Object::Ptr &O, bool &Done, std::string &Answer);
|
||||||
void ws_command_invalid(const Poco::JSON::Object::Ptr &O, bool &Done, std::string &Answer);
|
void ws_command_invalid(const Poco::JSON::Object::Ptr &O, bool &Done, std::string &Answer);
|
||||||
void ws_command_subuser_search( const Poco::JSON::Object::Ptr &O, bool &Done, std::string &Answer);
|
void ws_command_subuser_search(const Poco::JSON::Object::Ptr &O, bool &Done,
|
||||||
void ws_command_subdevice_search( const Poco::JSON::Object::Ptr &O, bool &Done, std::string &Answer);
|
std::string &Answer);
|
||||||
|
void ws_command_subdevice_search(const Poco::JSON::Object::Ptr &O, bool &Done,
|
||||||
|
std::string &Answer);
|
||||||
std::string GoogleGeoCodeCall(const std::string &A);
|
std::string GoogleGeoCodeCall(const std::string &A);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Poco::Logger &Logger_;
|
Poco::Logger &Logger_;
|
||||||
inline Poco::Logger &Logger() { return Logger_; }
|
inline Poco::Logger &Logger() { return Logger_; }
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
} // namespace OpenWifi
|
||||||
|
|||||||
@@ -3,9 +3,9 @@
|
|||||||
//
|
//
|
||||||
|
|
||||||
#include "RESTAPI_asset_server.h"
|
#include "RESTAPI_asset_server.h"
|
||||||
|
#include "Daemon.h"
|
||||||
#include "Poco/File.h"
|
#include "Poco/File.h"
|
||||||
#include "framework/ow_constants.h"
|
#include "framework/ow_constants.h"
|
||||||
#include "Daemon.h"
|
|
||||||
|
|
||||||
namespace OpenWifi {
|
namespace OpenWifi {
|
||||||
void RESTAPI_asset_server::DoGet() {
|
void RESTAPI_asset_server::DoGet() {
|
||||||
@@ -18,4 +18,4 @@ namespace OpenWifi {
|
|||||||
}
|
}
|
||||||
SendFile(AssetFile);
|
SendFile(AssetFile);
|
||||||
}
|
}
|
||||||
}
|
} // namespace OpenWifi
|
||||||
@@ -3,21 +3,19 @@
|
|||||||
//
|
//
|
||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
#include "StorageService.h"
|
||||||
#include "../framework/MicroService.h"
|
#include "framework/RESTAPI_Handler.h"
|
||||||
|
|
||||||
namespace OpenWifi {
|
namespace OpenWifi {
|
||||||
class RESTAPI_asset_server : public RESTAPIHandler {
|
class RESTAPI_asset_server : public RESTAPIHandler {
|
||||||
public:
|
public:
|
||||||
RESTAPI_asset_server(const RESTAPIHandler::BindingMap &bindings, Poco::Logger &L, RESTAPI_GenericServer &Server, uint64_t TransactionId, bool Internal)
|
RESTAPI_asset_server(const RESTAPIHandler::BindingMap &bindings, Poco::Logger &L,
|
||||||
|
RESTAPI_GenericServerAccounting &Server, uint64_t TransactionId,
|
||||||
|
bool Internal)
|
||||||
: RESTAPIHandler(bindings, L,
|
: RESTAPIHandler(bindings, L,
|
||||||
std::vector<std::string>
|
std::vector<std::string>{Poco::Net::HTTPRequest::HTTP_GET,
|
||||||
{
|
|
||||||
Poco::Net::HTTPRequest::HTTP_GET,
|
|
||||||
Poco::Net::HTTPRequest::HTTP_OPTIONS},
|
Poco::Net::HTTPRequest::HTTP_OPTIONS},
|
||||||
Server,
|
Server, TransactionId, Internal, false) {}
|
||||||
TransactionId,
|
|
||||||
Internal, false) {}
|
|
||||||
static auto PathName() { return std::list<std::string>{"/wwwassets/{id}"}; };
|
static auto PathName() { return std::list<std::string>{"/wwwassets/{id}"}; };
|
||||||
void DoGet() final;
|
void DoGet() final;
|
||||||
void DoPost() final{};
|
void DoPost() final{};
|
||||||
@@ -25,7 +23,5 @@ namespace OpenWifi {
|
|||||||
void DoPut() final{};
|
void DoPut() final{};
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
};
|
};
|
||||||
}
|
} // namespace OpenWifi
|
||||||
|
|
||||||
|
|||||||
@@ -6,14 +6,12 @@
|
|||||||
// Arilia Wireless Inc.
|
// Arilia Wireless Inc.
|
||||||
//
|
//
|
||||||
|
|
||||||
#include "framework/MicroService.h"
|
|
||||||
|
|
||||||
#include "RESTAPI_configurations_handler.h"
|
#include "RESTAPI_configurations_handler.h"
|
||||||
|
#include "DeviceTypeCache.h"
|
||||||
|
#include "RESTAPI/RESTAPI_db_helpers.h"
|
||||||
#include "RESTObjects/RESTAPI_ProvObjects.h"
|
#include "RESTObjects/RESTAPI_ProvObjects.h"
|
||||||
#include "StorageService.h"
|
#include "StorageService.h"
|
||||||
#include "framework/ConfigurationValidator.h"
|
#include "framework/ConfigurationValidator.h"
|
||||||
#include "RESTAPI/RESTAPI_db_helpers.h"
|
|
||||||
#include "DeviceTypeCache.h"
|
|
||||||
|
|
||||||
namespace OpenWifi {
|
namespace OpenWifi {
|
||||||
|
|
||||||
@@ -66,11 +64,15 @@ namespace OpenWifi{
|
|||||||
}
|
}
|
||||||
|
|
||||||
DB_.DeleteRecord("id", UUID);
|
DB_.DeleteRecord("id", UUID);
|
||||||
MoveUsage(StorageService()->PolicyDB(),DB_,Existing.managementPolicy,"",Existing.info.id);
|
MoveUsage(StorageService()->PolicyDB(), DB_, Existing.managementPolicy, "",
|
||||||
RemoveMembership(StorageService()->VenueDB(),&ProvObjects::Venue::configurations,Existing.venue,Existing.info.id);
|
Existing.info.id);
|
||||||
RemoveMembership(StorageService()->EntityDB(),&ProvObjects::Entity::configurations,Existing.entity,Existing.info.id);
|
RemoveMembership(StorageService()->VenueDB(), &ProvObjects::Venue::configurations,
|
||||||
|
Existing.venue, Existing.info.id);
|
||||||
|
RemoveMembership(StorageService()->EntityDB(), &ProvObjects::Entity::configurations,
|
||||||
|
Existing.entity, Existing.info.id);
|
||||||
for (const auto &i : Existing.variables)
|
for (const auto &i : Existing.variables)
|
||||||
RemoveMembership(StorageService()->VariablesDB(),&ProvObjects::VariableBlock::configurations,i,Existing.info.id);
|
RemoveMembership(StorageService()->VariablesDB(),
|
||||||
|
&ProvObjects::VariableBlock::configurations, i, Existing.info.id);
|
||||||
|
|
||||||
return OK();
|
return OK();
|
||||||
}
|
}
|
||||||
@@ -89,8 +91,9 @@ namespace OpenWifi{
|
|||||||
}
|
}
|
||||||
auto Config = RawObject->get("configuration").toString();
|
auto Config = RawObject->get("configuration").toString();
|
||||||
Poco::JSON::Object Answer;
|
Poco::JSON::Object Answer;
|
||||||
std::string Error;
|
std::vector<std::string> Error;
|
||||||
auto Res = ValidateUCentralConfiguration(Config,Error);
|
auto Res =
|
||||||
|
ValidateUCentralConfiguration(Config, Error, GetBoolParameter("strict", true));
|
||||||
Answer.set("valid", Res);
|
Answer.set("valid", Res);
|
||||||
Answer.set("error", Error);
|
Answer.set("error", Error);
|
||||||
return ReturnObject(Answer);
|
return ReturnObject(Answer);
|
||||||
@@ -109,32 +112,39 @@ namespace OpenWifi{
|
|||||||
return BadRequest(RESTAPI::Errors::NameMustBeSet);
|
return BadRequest(RESTAPI::Errors::NameMustBeSet);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!NewObject.entity.empty() && !StorageService()->EntityDB().Exists("id",NewObject.entity)) {
|
if (!NewObject.entity.empty() &&
|
||||||
|
!StorageService()->EntityDB().Exists("id", NewObject.entity)) {
|
||||||
return BadRequest(RESTAPI::Errors::EntityMustExist);
|
return BadRequest(RESTAPI::Errors::EntityMustExist);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!NewObject.venue.empty() && !StorageService()->VenueDB().Exists("id",NewObject.venue)) {
|
if (!NewObject.venue.empty() &&
|
||||||
|
!StorageService()->VenueDB().Exists("id", NewObject.venue)) {
|
||||||
return BadRequest(RESTAPI::Errors::VenueMustExist);
|
return BadRequest(RESTAPI::Errors::VenueMustExist);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!NewObject.managementPolicy.empty() && !StorageService()->PolicyDB().Exists("id",NewObject.managementPolicy)) {
|
if (!NewObject.managementPolicy.empty() &&
|
||||||
|
!StorageService()->PolicyDB().Exists("id", NewObject.managementPolicy)) {
|
||||||
return BadRequest(RESTAPI::Errors::UnknownManagementPolicyUUID);
|
return BadRequest(RESTAPI::Errors::UnknownManagementPolicyUUID);
|
||||||
}
|
}
|
||||||
|
|
||||||
NewObject.inUse.clear();
|
NewObject.inUse.clear();
|
||||||
if(NewObject.deviceTypes.empty() || !DeviceTypeCache()->AreAcceptableDeviceTypes(NewObject.deviceTypes, true)) {
|
if (NewObject.deviceTypes.empty() ||
|
||||||
|
!DeviceTypeCache()->AreAcceptableDeviceTypes(NewObject.deviceTypes, true)) {
|
||||||
return BadRequest(RESTAPI::Errors::InvalidDeviceTypes);
|
return BadRequest(RESTAPI::Errors::InvalidDeviceTypes);
|
||||||
}
|
}
|
||||||
|
|
||||||
RESTAPI::Errors::msg Error;
|
std::vector<std::string> Errors;
|
||||||
if(!ValidateConfigBlock(NewObject,Error)) {
|
if (!ValidateConfigBlock(NewObject, Errors)) {
|
||||||
return BadRequest(Error);
|
return BadRequest(RESTAPI::Errors::ConfigBlockInvalid);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (DB_.CreateRecord(NewObject)) {
|
if (DB_.CreateRecord(NewObject)) {
|
||||||
MoveUsage(StorageService()->PolicyDB(),DB_,"",NewObject.managementPolicy,NewObject.info.id);
|
MoveUsage(StorageService()->PolicyDB(), DB_, "", NewObject.managementPolicy,
|
||||||
AddMembership(StorageService()->VenueDB(),&ProvObjects::Venue::configurations,NewObject.venue, NewObject.info.id);
|
NewObject.info.id);
|
||||||
AddMembership(StorageService()->EntityDB(),&ProvObjects::Entity::configurations,NewObject.entity, NewObject.info.id);
|
AddMembership(StorageService()->VenueDB(), &ProvObjects::Venue::configurations,
|
||||||
|
NewObject.venue, NewObject.info.id);
|
||||||
|
AddMembership(StorageService()->EntityDB(), &ProvObjects::Entity::configurations,
|
||||||
|
NewObject.entity, NewObject.info.id);
|
||||||
|
|
||||||
ConfigurationDB::RecordName AddedRecord;
|
ConfigurationDB::RecordName AddedRecord;
|
||||||
DB_.GetRecord("id", NewObject.info.id, AddedRecord);
|
DB_.GetRecord("id", NewObject.info.id, AddedRecord);
|
||||||
@@ -166,16 +176,17 @@ namespace OpenWifi{
|
|||||||
return BadRequest(RESTAPI::Errors::NameMustBeSet);
|
return BadRequest(RESTAPI::Errors::NameMustBeSet);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!NewObject.deviceTypes.empty() && !DeviceTypeCache()->AreAcceptableDeviceTypes(NewObject.deviceTypes, true)) {
|
if (!NewObject.deviceTypes.empty() &&
|
||||||
|
!DeviceTypeCache()->AreAcceptableDeviceTypes(NewObject.deviceTypes, true)) {
|
||||||
return BadRequest(RESTAPI::Errors::InvalidDeviceTypes);
|
return BadRequest(RESTAPI::Errors::InvalidDeviceTypes);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!NewObject.deviceTypes.empty())
|
if (!NewObject.deviceTypes.empty())
|
||||||
Existing.deviceTypes = NewObject.deviceTypes;
|
Existing.deviceTypes = NewObject.deviceTypes;
|
||||||
|
|
||||||
RESTAPI::Errors::msg Error;
|
std::vector<std::string> Errors;
|
||||||
if(!ValidateConfigBlock( NewObject,Error)) {
|
if (!ValidateConfigBlock(NewObject, Errors)) {
|
||||||
return BadRequest(Error);
|
return BadRequest(RESTAPI::Errors::ConfigBlockInvalid);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (RawObject->has("configuration")) {
|
if (RawObject->has("configuration")) {
|
||||||
@@ -183,15 +194,19 @@ namespace OpenWifi{
|
|||||||
}
|
}
|
||||||
|
|
||||||
std::string FromPolicy, ToPolicy;
|
std::string FromPolicy, ToPolicy;
|
||||||
if(!CreateMove(RawObject,"managementPolicy",&ConfigurationDB::RecordName::managementPolicy, Existing, FromPolicy, ToPolicy, StorageService()->PolicyDB()))
|
if (!CreateMove(RawObject, "managementPolicy",
|
||||||
|
&ConfigurationDB::RecordName::managementPolicy, Existing, FromPolicy,
|
||||||
|
ToPolicy, StorageService()->PolicyDB()))
|
||||||
return BadRequest(RESTAPI::Errors::EntityMustExist);
|
return BadRequest(RESTAPI::Errors::EntityMustExist);
|
||||||
|
|
||||||
std::string FromEntity, ToEntity;
|
std::string FromEntity, ToEntity;
|
||||||
if(!CreateMove(RawObject,"entity",&ConfigurationDB::RecordName::entity, Existing, FromEntity, ToEntity, StorageService()->EntityDB()))
|
if (!CreateMove(RawObject, "entity", &ConfigurationDB::RecordName::entity, Existing,
|
||||||
|
FromEntity, ToEntity, StorageService()->EntityDB()))
|
||||||
return BadRequest(RESTAPI::Errors::EntityMustExist);
|
return BadRequest(RESTAPI::Errors::EntityMustExist);
|
||||||
|
|
||||||
std::string FromVenue, ToVenue;
|
std::string FromVenue, ToVenue;
|
||||||
if(!CreateMove(RawObject,"venue",&ConfigurationDB::RecordName::venue, Existing, FromVenue, ToVenue, StorageService()->VenueDB()))
|
if (!CreateMove(RawObject, "venue", &ConfigurationDB::RecordName::venue, Existing,
|
||||||
|
FromVenue, ToVenue, StorageService()->VenueDB()))
|
||||||
return BadRequest(RESTAPI::Errors::VenueMustExist);
|
return BadRequest(RESTAPI::Errors::VenueMustExist);
|
||||||
|
|
||||||
Types::UUIDvec_t FromVariables, ToVariables;
|
Types::UUIDvec_t FromVariables, ToVariables;
|
||||||
@@ -214,9 +229,13 @@ namespace OpenWifi{
|
|||||||
Existing.deviceRules = NewObject.deviceRules;
|
Existing.deviceRules = NewObject.deviceRules;
|
||||||
|
|
||||||
if (DB_.UpdateRecord("id", UUID, Existing)) {
|
if (DB_.UpdateRecord("id", UUID, Existing)) {
|
||||||
ManageMembership(StorageService()->VariablesDB(),&ProvObjects::VariableBlock::configurations, FromVariables, ToVariables, Existing.info.id);
|
ManageMembership(StorageService()->VariablesDB(),
|
||||||
ManageMembership(StorageService()->VenueDB(), &ProvObjects::Venue::configurations, FromVenue, ToVenue, Existing.info.id);
|
&ProvObjects::VariableBlock::configurations, FromVariables,
|
||||||
ManageMembership(StorageService()->EntityDB(), &ProvObjects::Entity::configurations, FromEntity, ToEntity, Existing.info.id);
|
ToVariables, Existing.info.id);
|
||||||
|
ManageMembership(StorageService()->VenueDB(), &ProvObjects::Venue::configurations,
|
||||||
|
FromVenue, ToVenue, Existing.info.id);
|
||||||
|
ManageMembership(StorageService()->EntityDB(), &ProvObjects::Entity::configurations,
|
||||||
|
FromEntity, ToEntity, Existing.info.id);
|
||||||
MoveUsage(StorageService()->PolicyDB(), DB_, FromPolicy, ToPolicy, Existing.info.id);
|
MoveUsage(StorageService()->PolicyDB(), DB_, FromPolicy, ToPolicy, Existing.info.id);
|
||||||
|
|
||||||
ProvObjects::DeviceConfiguration D;
|
ProvObjects::DeviceConfiguration D;
|
||||||
@@ -227,4 +246,4 @@ namespace OpenWifi{
|
|||||||
}
|
}
|
||||||
InternalError(RESTAPI::Errors::RecordNotUpdated);
|
InternalError(RESTAPI::Errors::RecordNotUpdated);
|
||||||
}
|
}
|
||||||
}
|
} // namespace OpenWifi
|
||||||
@@ -5,25 +5,26 @@
|
|||||||
// Created by Stephane Bourque on 2021-03-04.
|
// Created by Stephane Bourque on 2021-03-04.
|
||||||
// Arilia Wireless Inc.
|
// Arilia Wireless Inc.
|
||||||
//
|
//
|
||||||
#pragma once
|
|
||||||
|
|
||||||
#include "framework/MicroService.h"
|
#pragma once
|
||||||
#include "RESTObjects/RESTAPI_ProvObjects.h"
|
|
||||||
#include "StorageService.h"
|
#include "StorageService.h"
|
||||||
|
#include "framework/RESTAPI_Handler.h"
|
||||||
|
|
||||||
namespace OpenWifi {
|
namespace OpenWifi {
|
||||||
class RESTAPI_configurations_handler : public RESTAPIHandler {
|
class RESTAPI_configurations_handler : public RESTAPIHandler {
|
||||||
public:
|
public:
|
||||||
RESTAPI_configurations_handler(const RESTAPIHandler::BindingMap &bindings, Poco::Logger &L, RESTAPI_GenericServer & Server, uint64_t TransactionId, bool Internal)
|
RESTAPI_configurations_handler(const RESTAPIHandler::BindingMap &bindings, Poco::Logger &L,
|
||||||
|
RESTAPI_GenericServerAccounting &Server,
|
||||||
|
uint64_t TransactionId, bool Internal)
|
||||||
: RESTAPIHandler(bindings, L,
|
: RESTAPIHandler(bindings, L,
|
||||||
std::vector<std::string>{
|
std::vector<std::string>{Poco::Net::HTTPRequest::HTTP_GET,
|
||||||
Poco::Net::HTTPRequest::HTTP_GET, Poco::Net::HTTPRequest::HTTP_POST,
|
Poco::Net::HTTPRequest::HTTP_POST,
|
||||||
Poco::Net::HTTPRequest::HTTP_PUT, Poco::Net::HTTPRequest::HTTP_DELETE,
|
Poco::Net::HTTPRequest::HTTP_PUT,
|
||||||
|
Poco::Net::HTTPRequest::HTTP_DELETE,
|
||||||
Poco::Net::HTTPRequest::HTTP_OPTIONS},
|
Poco::Net::HTTPRequest::HTTP_OPTIONS},
|
||||||
Server,
|
Server, TransactionId, Internal) {}
|
||||||
TransactionId,
|
|
||||||
Internal){}
|
|
||||||
static auto PathName() { return std::list<std::string>{"/api/v1/configuration/{uuid}"}; };
|
static auto PathName() { return std::list<std::string>{"/api/v1/configuration/{uuid}"}; };
|
||||||
|
|
||||||
private:
|
private:
|
||||||
ConfigurationDB &DB_ = StorageService()->ConfigurationDB();
|
ConfigurationDB &DB_ = StorageService()->ConfigurationDB();
|
||||||
void DoGet();
|
void DoGet();
|
||||||
@@ -31,4 +32,4 @@ namespace OpenWifi {
|
|||||||
void DoPut();
|
void DoPut();
|
||||||
void DoDelete();
|
void DoDelete();
|
||||||
};
|
};
|
||||||
}
|
} // namespace OpenWifi
|
||||||
|
|||||||
@@ -4,12 +4,12 @@
|
|||||||
|
|
||||||
#include "RESTAPI_configurations_list_handler.h"
|
#include "RESTAPI_configurations_list_handler.h"
|
||||||
|
|
||||||
|
#include "RESTAPI_db_helpers.h"
|
||||||
#include "RESTObjects/RESTAPI_ProvObjects.h"
|
#include "RESTObjects/RESTAPI_ProvObjects.h"
|
||||||
#include "StorageService.h"
|
#include "StorageService.h"
|
||||||
#include "RESTAPI_db_helpers.h"
|
|
||||||
|
|
||||||
namespace OpenWifi {
|
namespace OpenWifi {
|
||||||
void RESTAPI_configurations_list_handler::DoGet() {
|
void RESTAPI_configurations_list_handler::DoGet() {
|
||||||
return ListHandler<ConfigurationDB>("configurations", DB_, *this);
|
return ListHandler<ConfigurationDB>("configurations", DB_, *this);
|
||||||
}
|
}
|
||||||
}
|
} // namespace OpenWifi
|
||||||
@@ -3,23 +3,23 @@
|
|||||||
//
|
//
|
||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include "framework/MicroService.h"
|
|
||||||
#include "StorageService.h"
|
#include "StorageService.h"
|
||||||
|
#include "framework/RESTAPI_Handler.h"
|
||||||
|
|
||||||
namespace OpenWifi {
|
namespace OpenWifi {
|
||||||
|
|
||||||
class RESTAPI_configurations_list_handler : public RESTAPIHandler {
|
class RESTAPI_configurations_list_handler : public RESTAPIHandler {
|
||||||
public:
|
public:
|
||||||
RESTAPI_configurations_list_handler(const RESTAPIHandler::BindingMap &bindings, Poco::Logger &L, RESTAPI_GenericServer & Server, uint64_t TransactionId, bool Internal)
|
RESTAPI_configurations_list_handler(const RESTAPIHandler::BindingMap &bindings,
|
||||||
|
Poco::Logger &L,
|
||||||
|
RESTAPI_GenericServerAccounting &Server,
|
||||||
|
uint64_t TransactionId, bool Internal)
|
||||||
: RESTAPIHandler(bindings, L,
|
: RESTAPIHandler(bindings, L,
|
||||||
std::vector<std::string>{
|
std::vector<std::string>{Poco::Net::HTTPRequest::HTTP_GET,
|
||||||
Poco::Net::HTTPRequest::HTTP_GET,
|
|
||||||
Poco::Net::HTTPRequest::HTTP_OPTIONS},
|
Poco::Net::HTTPRequest::HTTP_OPTIONS},
|
||||||
Server,
|
Server, TransactionId, Internal) {}
|
||||||
TransactionId,
|
|
||||||
Internal){}
|
|
||||||
static auto PathName() { return std::list<std::string>{"/api/v1/configuration"}; };
|
static auto PathName() { return std::list<std::string>{"/api/v1/configuration"}; };
|
||||||
|
|
||||||
private:
|
private:
|
||||||
ConfigurationDB &DB_ = StorageService()->ConfigurationDB();
|
ConfigurationDB &DB_ = StorageService()->ConfigurationDB();
|
||||||
void DoGet() final;
|
void DoGet() final;
|
||||||
@@ -27,4 +27,4 @@ namespace OpenWifi {
|
|||||||
void DoPut() final{};
|
void DoPut() final{};
|
||||||
void DoDelete() final{};
|
void DoDelete() final{};
|
||||||
};
|
};
|
||||||
}
|
} // namespace OpenWifi
|
||||||
|
|||||||
@@ -8,9 +8,9 @@
|
|||||||
|
|
||||||
#include "RESTAPI_contact_handler.h"
|
#include "RESTAPI_contact_handler.h"
|
||||||
|
|
||||||
#include "framework/ow_constants.h"
|
|
||||||
#include "RESTObjects/RESTAPI_ProvObjects.h"
|
|
||||||
#include "RESTAPI_db_helpers.h"
|
#include "RESTAPI_db_helpers.h"
|
||||||
|
#include "RESTObjects/RESTAPI_ProvObjects.h"
|
||||||
|
#include "framework/ow_constants.h"
|
||||||
|
|
||||||
namespace OpenWifi {
|
namespace OpenWifi {
|
||||||
void RESTAPI_contact_handler::DoGet() {
|
void RESTAPI_contact_handler::DoGet() {
|
||||||
@@ -67,7 +67,8 @@ namespace OpenWifi{
|
|||||||
}
|
}
|
||||||
|
|
||||||
DB_.DeleteRecord("id", UUID);
|
DB_.DeleteRecord("id", UUID);
|
||||||
RemoveMembership(StorageService()->EntityDB(),&ProvObjects::Entity::contacts,Existing.entity,Existing.info.id);
|
RemoveMembership(StorageService()->EntityDB(), &ProvObjects::Entity::contacts,
|
||||||
|
Existing.entity, Existing.info.id);
|
||||||
MoveUsage(StorageService()->PolicyDB(), DB_, Existing.info.id, "", Existing.info.id);
|
MoveUsage(StorageService()->PolicyDB(), DB_, Existing.info.id, "", Existing.info.id);
|
||||||
return OK();
|
return OK();
|
||||||
}
|
}
|
||||||
@@ -89,19 +90,23 @@ namespace OpenWifi{
|
|||||||
return BadRequest(RESTAPI::Errors::NameMustBeSet);
|
return BadRequest(RESTAPI::Errors::NameMustBeSet);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(NewObject.entity.empty() && !StorageService()->EntityDB().Exists("id",NewObject.entity)) {
|
if (NewObject.entity.empty() &&
|
||||||
|
!StorageService()->EntityDB().Exists("id", NewObject.entity)) {
|
||||||
return BadRequest(RESTAPI::Errors::EntityMustExist);
|
return BadRequest(RESTAPI::Errors::EntityMustExist);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!NewObject.managementPolicy.empty() && !StorageService()->PolicyDB().Exists("id",NewObject.managementPolicy)) {
|
if (!NewObject.managementPolicy.empty() &&
|
||||||
|
!StorageService()->PolicyDB().Exists("id", NewObject.managementPolicy)) {
|
||||||
return BadRequest(RESTAPI::Errors::UnknownManagementPolicyUUID);
|
return BadRequest(RESTAPI::Errors::UnknownManagementPolicyUUID);
|
||||||
}
|
}
|
||||||
|
|
||||||
NewObject.inUse.clear();
|
NewObject.inUse.clear();
|
||||||
|
|
||||||
if (DB_.CreateRecord(NewObject)) {
|
if (DB_.CreateRecord(NewObject)) {
|
||||||
AddMembership(StorageService()->EntityDB(),&ProvObjects::Entity::contacts,NewObject.entity,NewObject.info.id);
|
AddMembership(StorageService()->EntityDB(), &ProvObjects::Entity::contacts,
|
||||||
MoveUsage(StorageService()->PolicyDB(),DB_,"",NewObject.managementPolicy,NewObject.info.id);
|
NewObject.entity, NewObject.info.id);
|
||||||
|
MoveUsage(StorageService()->PolicyDB(), DB_, "", NewObject.managementPolicy,
|
||||||
|
NewObject.info.id);
|
||||||
|
|
||||||
ProvObjects::Contact NewContact;
|
ProvObjects::Contact NewContact;
|
||||||
StorageService()->ContactDB().GetRecord("id", NewObject.info.id, NewContact);
|
StorageService()->ContactDB().GetRecord("id", NewObject.info.id, NewContact);
|
||||||
@@ -132,11 +137,13 @@ namespace OpenWifi{
|
|||||||
}
|
}
|
||||||
|
|
||||||
std::string FromPolicy, ToPolicy;
|
std::string FromPolicy, ToPolicy;
|
||||||
if(!CreateMove(RawObject,"managementPolicy",&ContactDB::RecordName::managementPolicy, Existing, FromPolicy, ToPolicy, StorageService()->PolicyDB()))
|
if (!CreateMove(RawObject, "managementPolicy", &ContactDB::RecordName::managementPolicy,
|
||||||
|
Existing, FromPolicy, ToPolicy, StorageService()->PolicyDB()))
|
||||||
return BadRequest(RESTAPI::Errors::EntityMustExist);
|
return BadRequest(RESTAPI::Errors::EntityMustExist);
|
||||||
|
|
||||||
std::string FromEntity, ToEntity;
|
std::string FromEntity, ToEntity;
|
||||||
if(!CreateMove(RawObject,"entity",&ContactDB::RecordName::entity, Existing, FromEntity, ToEntity, StorageService()->EntityDB()))
|
if (!CreateMove(RawObject, "entity", &ContactDB::RecordName::entity, Existing, FromEntity,
|
||||||
|
ToEntity, StorageService()->EntityDB()))
|
||||||
return BadRequest(RESTAPI::Errors::EntityMustExist);
|
return BadRequest(RESTAPI::Errors::EntityMustExist);
|
||||||
|
|
||||||
AssignIfPresent(RawObject, "title", Existing.title);
|
AssignIfPresent(RawObject, "title", Existing.title);
|
||||||
@@ -157,7 +164,8 @@ namespace OpenWifi{
|
|||||||
|
|
||||||
if (DB_.UpdateRecord("id", UUID, Existing)) {
|
if (DB_.UpdateRecord("id", UUID, Existing)) {
|
||||||
MoveUsage(StorageService()->PolicyDB(), DB_, FromPolicy, ToPolicy, Existing.info.id);
|
MoveUsage(StorageService()->PolicyDB(), DB_, FromPolicy, ToPolicy, Existing.info.id);
|
||||||
ManageMembership(StorageService()->EntityDB(),&ProvObjects::Entity::contacts,FromEntity,ToEntity,Existing.info.id);
|
ManageMembership(StorageService()->EntityDB(), &ProvObjects::Entity::contacts,
|
||||||
|
FromEntity, ToEntity, Existing.info.id);
|
||||||
|
|
||||||
ProvObjects::Contact NewObjectAdded;
|
ProvObjects::Contact NewObjectAdded;
|
||||||
DB_.GetRecord("id", UUID, NewObjectAdded);
|
DB_.GetRecord("id", UUID, NewObjectAdded);
|
||||||
@@ -167,4 +175,4 @@ namespace OpenWifi{
|
|||||||
}
|
}
|
||||||
InternalError(RESTAPI::Errors::RecordNotUpdated);
|
InternalError(RESTAPI::Errors::RecordNotUpdated);
|
||||||
}
|
}
|
||||||
}
|
} // namespace OpenWifi
|
||||||
@@ -7,22 +7,22 @@
|
|||||||
//
|
//
|
||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include "framework/MicroService.h"
|
|
||||||
#include "StorageService.h"
|
#include "StorageService.h"
|
||||||
|
#include "framework/RESTAPI_Handler.h"
|
||||||
|
|
||||||
namespace OpenWifi {
|
namespace OpenWifi {
|
||||||
class RESTAPI_contact_handler : public RESTAPIHandler {
|
class RESTAPI_contact_handler : public RESTAPIHandler {
|
||||||
public:
|
public:
|
||||||
RESTAPI_contact_handler(const RESTAPIHandler::BindingMap &bindings, Poco::Logger &L, RESTAPI_GenericServer & Server, uint64_t TransactionId, bool Internal)
|
RESTAPI_contact_handler(const RESTAPIHandler::BindingMap &bindings, Poco::Logger &L,
|
||||||
|
RESTAPI_GenericServerAccounting &Server, uint64_t TransactionId,
|
||||||
|
bool Internal)
|
||||||
: RESTAPIHandler(bindings, L,
|
: RESTAPIHandler(bindings, L,
|
||||||
std::vector<std::string>{
|
std::vector<std::string>{Poco::Net::HTTPRequest::HTTP_GET,
|
||||||
Poco::Net::HTTPRequest::HTTP_GET, Poco::Net::HTTPRequest::HTTP_POST,
|
Poco::Net::HTTPRequest::HTTP_POST,
|
||||||
Poco::Net::HTTPRequest::HTTP_PUT, Poco::Net::HTTPRequest::HTTP_DELETE,
|
Poco::Net::HTTPRequest::HTTP_PUT,
|
||||||
|
Poco::Net::HTTPRequest::HTTP_DELETE,
|
||||||
Poco::Net::HTTPRequest::HTTP_OPTIONS},
|
Poco::Net::HTTPRequest::HTTP_OPTIONS},
|
||||||
Server,
|
Server, TransactionId, Internal) {}
|
||||||
TransactionId,
|
|
||||||
Internal){}
|
|
||||||
static auto PathName() { return std::list<std::string>{"/api/v1/contact/{uuid}"}; };
|
static auto PathName() { return std::list<std::string>{"/api/v1/contact/{uuid}"}; };
|
||||||
|
|
||||||
private:
|
private:
|
||||||
@@ -32,4 +32,4 @@ namespace OpenWifi {
|
|||||||
void DoPut() final;
|
void DoPut() final;
|
||||||
void DoDelete() final;
|
void DoDelete() final;
|
||||||
};
|
};
|
||||||
}
|
} // namespace OpenWifi
|
||||||
|
|||||||
@@ -4,12 +4,12 @@
|
|||||||
|
|
||||||
#include "RESTAPI_contact_list_handler.h"
|
#include "RESTAPI_contact_list_handler.h"
|
||||||
|
|
||||||
|
#include "RESTAPI_db_helpers.h"
|
||||||
#include "RESTObjects/RESTAPI_ProvObjects.h"
|
#include "RESTObjects/RESTAPI_ProvObjects.h"
|
||||||
#include "StorageService.h"
|
#include "StorageService.h"
|
||||||
#include "RESTAPI_db_helpers.h"
|
|
||||||
|
|
||||||
namespace OpenWifi {
|
namespace OpenWifi {
|
||||||
void RESTAPI_contact_list_handler::DoGet() {
|
void RESTAPI_contact_list_handler::DoGet() {
|
||||||
return ListHandler<ContactDB>("contacts", DB_, *this);
|
return ListHandler<ContactDB>("contacts", DB_, *this);
|
||||||
}
|
}
|
||||||
}
|
} // namespace OpenWifi
|
||||||
@@ -3,24 +3,22 @@
|
|||||||
//
|
//
|
||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include "framework/MicroService.h"
|
|
||||||
#include "RESTObjects/RESTAPI_ProvObjects.h"
|
|
||||||
#include "StorageService.h"
|
#include "StorageService.h"
|
||||||
|
#include "framework/RESTAPI_Handler.h"
|
||||||
|
|
||||||
namespace OpenWifi {
|
namespace OpenWifi {
|
||||||
|
|
||||||
class RESTAPI_contact_list_handler : public RESTAPIHandler {
|
class RESTAPI_contact_list_handler : public RESTAPIHandler {
|
||||||
public:
|
public:
|
||||||
RESTAPI_contact_list_handler(const RESTAPIHandler::BindingMap &bindings, Poco::Logger &L, RESTAPI_GenericServer & Server, uint64_t TransactionId, bool Internal)
|
RESTAPI_contact_list_handler(const RESTAPIHandler::BindingMap &bindings, Poco::Logger &L,
|
||||||
|
RESTAPI_GenericServerAccounting &Server,
|
||||||
|
uint64_t TransactionId, bool Internal)
|
||||||
: RESTAPIHandler(bindings, L,
|
: RESTAPIHandler(bindings, L,
|
||||||
std::vector<std::string>{
|
std::vector<std::string>{Poco::Net::HTTPRequest::HTTP_GET,
|
||||||
Poco::Net::HTTPRequest::HTTP_GET,
|
|
||||||
Poco::Net::HTTPRequest::HTTP_OPTIONS},
|
Poco::Net::HTTPRequest::HTTP_OPTIONS},
|
||||||
Server,
|
Server, TransactionId, Internal) {}
|
||||||
TransactionId,
|
|
||||||
Internal){}
|
|
||||||
static auto PathName() { return std::list<std::string>{"/api/v1/contact"}; };
|
static auto PathName() { return std::list<std::string>{"/api/v1/contact"}; };
|
||||||
|
|
||||||
private:
|
private:
|
||||||
ContactDB &DB_ = StorageService()->ContactDB();
|
ContactDB &DB_ = StorageService()->ContactDB();
|
||||||
void DoGet() final;
|
void DoGet() final;
|
||||||
@@ -28,4 +26,4 @@ namespace OpenWifi {
|
|||||||
void DoPut() final{};
|
void DoPut() final{};
|
||||||
void DoDelete() final{};
|
void DoDelete() final{};
|
||||||
};
|
};
|
||||||
}
|
} // namespace OpenWifi
|
||||||
|
|||||||
@@ -4,10 +4,11 @@
|
|||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
|
#include "Poco/StringTokenizer.h"
|
||||||
#include "RESTObjects/RESTAPI_ProvObjects.h"
|
#include "RESTObjects/RESTAPI_ProvObjects.h"
|
||||||
#include "StorageService.h"
|
#include "StorageService.h"
|
||||||
#include "framework/MicroService.h"
|
|
||||||
#include "framework/ConfigurationValidator.h"
|
#include "framework/ConfigurationValidator.h"
|
||||||
|
#include "libs/croncpp.h"
|
||||||
#include "sdks/SDK_sec.h"
|
#include "sdks/SDK_sec.h"
|
||||||
|
|
||||||
namespace OpenWifi {
|
namespace OpenWifi {
|
||||||
@@ -18,7 +19,8 @@ namespace OpenWifi {
|
|||||||
J.set("id", O.id);
|
J.set("id", O.id);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename R, typename Q = decltype(R{}.entity)> void Extend_entity(const R &T, Poco::JSON::Object &EI ) {
|
template <typename R, typename Q = decltype(R{}.entity)>
|
||||||
|
void Extend_entity(const R &T, Poco::JSON::Object &EI) {
|
||||||
if constexpr (std::is_same_v<Q, std::string>) {
|
if constexpr (std::is_same_v<Q, std::string>) {
|
||||||
if (!T.entity.empty()) {
|
if (!T.entity.empty()) {
|
||||||
Poco::JSON::Object EntObj;
|
Poco::JSON::Object EntObj;
|
||||||
@@ -34,7 +36,8 @@ namespace OpenWifi {
|
|||||||
static_assert(sizeof...(args) == 2);
|
static_assert(sizeof...(args) == 2);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename R, typename Q = decltype(R{}.managementPolicy)> void Extend_managementPolicy(const R &T, Poco::JSON::Object &EI ) {
|
template <typename R, typename Q = decltype(R{}.managementPolicy)>
|
||||||
|
void Extend_managementPolicy(const R &T, Poco::JSON::Object &EI) {
|
||||||
if constexpr (std::is_same_v<Q, std::string>) {
|
if constexpr (std::is_same_v<Q, std::string>) {
|
||||||
if (!T.managementPolicy.empty()) {
|
if (!T.managementPolicy.empty()) {
|
||||||
Poco::JSON::Object PolObj;
|
Poco::JSON::Object PolObj;
|
||||||
@@ -50,7 +53,8 @@ namespace OpenWifi {
|
|||||||
static_assert(sizeof...(args) == 2);
|
static_assert(sizeof...(args) == 2);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename R, typename Q = decltype(R{}.venue)> void Extend_venue(const R &T, Poco::JSON::Object &EI ) {
|
template <typename R, typename Q = decltype(R{}.venue)>
|
||||||
|
void Extend_venue(const R &T, Poco::JSON::Object &EI) {
|
||||||
if constexpr (std::is_same_v<Q, std::string>) {
|
if constexpr (std::is_same_v<Q, std::string>) {
|
||||||
if (!T.venue.empty()) {
|
if (!T.venue.empty()) {
|
||||||
Poco::JSON::Object VenObj;
|
Poco::JSON::Object VenObj;
|
||||||
@@ -62,11 +66,10 @@ namespace OpenWifi {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
template <typename... Ts> void Extend_venue(Ts... args) {
|
template <typename... Ts> void Extend_venue(Ts... args) { static_assert(sizeof...(args) == 2); }
|
||||||
static_assert( sizeof...(args) == 2);
|
|
||||||
}
|
|
||||||
|
|
||||||
template <typename R, typename Q = decltype(R{}.contact)> void Extend_contact(const R &T, Poco::JSON::Object &EI ) {
|
template <typename R, typename Q = decltype(R{}.contact)>
|
||||||
|
void Extend_contact(const R &T, Poco::JSON::Object &EI) {
|
||||||
if constexpr (std::is_same_v<Q, std::string>) {
|
if constexpr (std::is_same_v<Q, std::string>) {
|
||||||
if (!T.contact.empty()) {
|
if (!T.contact.empty()) {
|
||||||
Poco::JSON::Object ConObj;
|
Poco::JSON::Object ConObj;
|
||||||
@@ -82,7 +85,8 @@ namespace OpenWifi {
|
|||||||
static_assert(sizeof...(args) == 2);
|
static_assert(sizeof...(args) == 2);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename R, typename Q = decltype(R{}.location)> void Extend_location(const R &T, Poco::JSON::Object &EI ) {
|
template <typename R, typename Q = decltype(R{}.location)>
|
||||||
|
void Extend_location(const R &T, Poco::JSON::Object &EI) {
|
||||||
if constexpr (std::is_same_v<Q, std::string>) {
|
if constexpr (std::is_same_v<Q, std::string>) {
|
||||||
if (!T.location.empty()) {
|
if (!T.location.empty()) {
|
||||||
Poco::JSON::Object LocObj;
|
Poco::JSON::Object LocObj;
|
||||||
@@ -98,12 +102,14 @@ namespace OpenWifi {
|
|||||||
static_assert(sizeof...(args) == 2);
|
static_assert(sizeof...(args) == 2);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename R, typename Q = decltype(R{}.deviceConfiguration)> void Extend_deviceConfiguration(const R &T, Poco::JSON::Object &EI ) {
|
template <typename R, typename Q = decltype(R{}.deviceConfiguration)>
|
||||||
|
void Extend_deviceConfiguration(const R &T, Poco::JSON::Object &EI) {
|
||||||
if constexpr (std::is_same_v<Q, std::string>) {
|
if constexpr (std::is_same_v<Q, std::string>) {
|
||||||
if (!T.deviceConfiguration.empty()) {
|
if (!T.deviceConfiguration.empty()) {
|
||||||
Poco::JSON::Object DevObj;
|
Poco::JSON::Object DevObj;
|
||||||
ProvObjects::DeviceConfiguration DevConf;
|
ProvObjects::DeviceConfiguration DevConf;
|
||||||
if(StorageService()->ConfigurationDB().GetRecord("id",T.deviceConfiguration,DevConf)) {
|
if (StorageService()->ConfigurationDB().GetRecord("id", T.deviceConfiguration,
|
||||||
|
DevConf)) {
|
||||||
AddInfoBlock(DevConf.info, DevObj);
|
AddInfoBlock(DevConf.info, DevObj);
|
||||||
}
|
}
|
||||||
EI.set("deviceConfiguration", DevObj);
|
EI.set("deviceConfiguration", DevObj);
|
||||||
@@ -141,7 +147,8 @@ namespace OpenWifi {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T> void MakeJSONObjectArray(const char * ArrayName, const std::vector<T> & V, RESTAPIHandler & R) {
|
template <typename T>
|
||||||
|
void MakeJSONObjectArray(const char *ArrayName, const std::vector<T> &V, RESTAPIHandler &R) {
|
||||||
Poco::JSON::Array ObjArray;
|
Poco::JSON::Array ObjArray;
|
||||||
for (const auto &i : V) {
|
for (const auto &i : V) {
|
||||||
Poco::JSON::Object Obj;
|
Poco::JSON::Object Obj;
|
||||||
@@ -155,11 +162,10 @@ namespace OpenWifi {
|
|||||||
return R.ReturnObject(Answer);
|
return R.ReturnObject(Answer);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline static bool is_uuid(const std::string &u) {
|
inline static bool is_uuid(const std::string &u) { return u.find('-') != std::string::npos; }
|
||||||
return u.find('-') != std::string::npos;
|
|
||||||
}
|
|
||||||
|
|
||||||
template <typename DB> void ReturnRecordList(const char *ArrayName,DB & DBInstance, RESTAPIHandler & R) {
|
template <typename DB>
|
||||||
|
void ReturnRecordList(const char *ArrayName, DB &DBInstance, RESTAPIHandler &R) {
|
||||||
Poco::JSON::Array ObjArr;
|
Poco::JSON::Array ObjArr;
|
||||||
for (const auto &i : R.SelectedRecords()) {
|
for (const auto &i : R.SelectedRecords()) {
|
||||||
ProvObjects::InventoryTag E;
|
ProvObjects::InventoryTag E;
|
||||||
@@ -178,7 +184,8 @@ namespace OpenWifi {
|
|||||||
return R.ReturnObject(Answer);
|
return R.ReturnObject(Answer);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename DB, typename Record> void ReturnRecordList(const char *ArrayName,DB & DBInstance, RESTAPIHandler & R) {
|
template <typename DB, typename Record>
|
||||||
|
void ReturnRecordList(const char *ArrayName, DB &DBInstance, RESTAPIHandler &R) {
|
||||||
Poco::JSON::Array ObjArr;
|
Poco::JSON::Array ObjArr;
|
||||||
for (const auto &i : R.SelectedRecords()) {
|
for (const auto &i : R.SelectedRecords()) {
|
||||||
Record E;
|
Record E;
|
||||||
@@ -219,7 +226,8 @@ namespace OpenWifi {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void AddLocationTriplet(const std::vector<std::string> &id, std::vector<triplet_t> & IDs) {
|
inline void AddLocationTriplet(const std::vector<std::string> &id,
|
||||||
|
std::vector<triplet_t> &IDs) {
|
||||||
for (const auto &i : id)
|
for (const auto &i : id)
|
||||||
AddLocationTriplet(i, IDs);
|
AddLocationTriplet(i, IDs);
|
||||||
}
|
}
|
||||||
@@ -252,7 +260,8 @@ namespace OpenWifi {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename DB> void ListHandler(const char *BlockName,DB & DBInstance, RESTAPIHandler & R) {
|
template <typename DB>
|
||||||
|
void ListHandler(const char *BlockName, DB &DBInstance, RESTAPIHandler &R) {
|
||||||
auto Entity = R.GetParameter("entity", "");
|
auto Entity = R.GetParameter("entity", "");
|
||||||
auto Venue = R.GetParameter("venue", "");
|
auto Venue = R.GetParameter("venue", "");
|
||||||
|
|
||||||
@@ -279,15 +288,16 @@ namespace OpenWifi {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!R.QB_.Select.empty()) {
|
if (!R.QB_.Select.empty()) {
|
||||||
return ReturnRecordList<decltype(DBInstance),
|
return ReturnRecordList<decltype(DBInstance), RecType>(BlockName, DBInstance, R);
|
||||||
RecType>(BlockName, DBInstance, R);
|
}
|
||||||
} if(!Entity.empty()) {
|
if (!Entity.empty()) {
|
||||||
RecVec Entries;
|
RecVec Entries;
|
||||||
DBInstance.GetRecords(R.QB_.Offset, R.QB_.Limit, Entries, " entity=' " + Entity + "'");
|
DBInstance.GetRecords(R.QB_.Offset, R.QB_.Limit, Entries, " entity=' " + Entity + "'");
|
||||||
if (R.QB_.CountOnly)
|
if (R.QB_.CountOnly)
|
||||||
return R.ReturnCountOnly(Entries.size());
|
return R.ReturnCountOnly(Entries.size());
|
||||||
return MakeJSONObjectArray(BlockName, Entries, R);
|
return MakeJSONObjectArray(BlockName, Entries, R);
|
||||||
} if(!Venue.empty()) {
|
}
|
||||||
|
if (!Venue.empty()) {
|
||||||
RecVec Entries;
|
RecVec Entries;
|
||||||
DBInstance.GetRecords(R.QB_.Offset, R.QB_.Limit, Entries, " venue=' " + Venue + "'");
|
DBInstance.GetRecords(R.QB_.Offset, R.QB_.Limit, Entries, " venue=' " + Venue + "'");
|
||||||
if (R.QB_.CountOnly)
|
if (R.QB_.CountOnly)
|
||||||
@@ -304,13 +314,17 @@ namespace OpenWifi {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename db_type> void ListHandlerForOperator(const char *BlockName,db_type & DB, RESTAPIHandler & R, const Types::UUID_t & OperatorId, const Types::UUID_t & subscriberId="") {
|
template <typename db_type>
|
||||||
|
void ListHandlerForOperator(const char *BlockName, db_type &DB, RESTAPIHandler &R,
|
||||||
|
const Types::UUID_t &OperatorId,
|
||||||
|
const Types::UUID_t &subscriberId = "") {
|
||||||
typedef typename db_type::RecordVec RecVec;
|
typedef typename db_type::RecordVec RecVec;
|
||||||
typedef typename db_type::RecordName RecType;
|
typedef typename db_type::RecordName RecType;
|
||||||
|
|
||||||
auto whereClause = subscriberId.empty() ?
|
auto whereClause =
|
||||||
fmt::format(" operatorId='{}'", OperatorId) :
|
subscriberId.empty()
|
||||||
fmt::format(" operatorId='{}' and subscriberId='{}' ", OperatorId, subscriberId);
|
? fmt::format(" operatorId='{}'", OperatorId)
|
||||||
|
: fmt::format(" operatorId='{}' and subscriberId='{}' ", OperatorId, subscriberId);
|
||||||
|
|
||||||
if (R.QB_.CountOnly) {
|
if (R.QB_.CountOnly) {
|
||||||
auto Count = DB.Count(whereClause);
|
auto Count = DB.Count(whereClause);
|
||||||
@@ -318,8 +332,7 @@ namespace OpenWifi {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!R.QB_.Select.empty()) {
|
if (!R.QB_.Select.empty()) {
|
||||||
return ReturnRecordList<decltype(DB),
|
return ReturnRecordList<decltype(DB), RecType>(BlockName, DB, R);
|
||||||
RecType>(BlockName, DB, R);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
RecVec Entries;
|
RecVec Entries;
|
||||||
@@ -327,7 +340,9 @@ namespace OpenWifi {
|
|||||||
return MakeJSONObjectArray(BlockName, Entries, R);
|
return MakeJSONObjectArray(BlockName, Entries, R);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename db_type, typename ObjectDB> void MoveUsage(db_type &DB_InUse, ObjectDB & DB, const std::string & From, const std::string & To, const std::string &Id) {
|
template <typename db_type, typename ObjectDB>
|
||||||
|
void MoveUsage(db_type &DB_InUse, ObjectDB &DB, const std::string &From, const std::string &To,
|
||||||
|
const std::string &Id) {
|
||||||
if (From != To) {
|
if (From != To) {
|
||||||
if (!From.empty())
|
if (!From.empty())
|
||||||
DB_InUse.DeleteInUse("id", From, DB.Prefix(), Id);
|
DB_InUse.DeleteInUse("id", From, DB.Prefix(), Id);
|
||||||
@@ -336,7 +351,9 @@ namespace OpenWifi {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename db_type, typename ObjectDB> void MoveUsage(db_type &DB_InUse, ObjectDB & DB, const Types::UUIDvec_t & From, const Types::UUIDvec_t & To, const std::string &Id) {
|
template <typename db_type, typename ObjectDB>
|
||||||
|
void MoveUsage(db_type &DB_InUse, ObjectDB &DB, const Types::UUIDvec_t &From,
|
||||||
|
const Types::UUIDvec_t &To, const std::string &Id) {
|
||||||
if (From != To) {
|
if (From != To) {
|
||||||
if (!From.empty()) {
|
if (!From.empty()) {
|
||||||
for (const auto &i : From)
|
for (const auto &i : From)
|
||||||
@@ -349,7 +366,9 @@ namespace OpenWifi {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename db_type> void MoveChild(db_type &DB, const std::string & Parent, const std::string & Child, const std::string &Id) {
|
template <typename db_type>
|
||||||
|
void MoveChild(db_type &DB, const std::string &Parent, const std::string &Child,
|
||||||
|
const std::string &Id) {
|
||||||
if (Parent != Child) {
|
if (Parent != Child) {
|
||||||
if (!Parent.empty())
|
if (!Parent.empty())
|
||||||
DB.InUse.DeleteInUse("id", Parent, Id);
|
DB.InUse.DeleteInUse("id", Parent, Id);
|
||||||
@@ -358,22 +377,28 @@ namespace OpenWifi {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename db_type, typename Member> void RemoveMembership( db_type & DB, Member T, const std::string & Obj, const std::string &Id) {
|
template <typename db_type, typename Member>
|
||||||
|
void RemoveMembership(db_type &DB, Member T, const std::string &Obj, const std::string &Id) {
|
||||||
if (!Obj.empty())
|
if (!Obj.empty())
|
||||||
DB.ManipulateVectorMember(T, "id", Obj, Id, false);
|
DB.ManipulateVectorMember(T, "id", Obj, Id, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename db_type, typename Member> void AddMembership( db_type & DB, Member T, const std::string & Obj, const std::string &Id) {
|
template <typename db_type, typename Member>
|
||||||
|
void AddMembership(db_type &DB, Member T, const std::string &Obj, const std::string &Id) {
|
||||||
if (!Obj.empty())
|
if (!Obj.empty())
|
||||||
DB.ManipulateVectorMember(T, "id", Obj, Id, true);
|
DB.ManipulateVectorMember(T, "id", Obj, Id, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename db_type, typename Member> void ManageMembership( db_type & DB, Member T, const std::string & From, const std::string & To, const std::string &Id) {
|
template <typename db_type, typename Member>
|
||||||
|
void ManageMembership(db_type &DB, Member T, const std::string &From, const std::string &To,
|
||||||
|
const std::string &Id) {
|
||||||
RemoveMembership(DB, T, From, Id);
|
RemoveMembership(DB, T, From, Id);
|
||||||
AddMembership(DB, T, To, Id);
|
AddMembership(DB, T, To, Id);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename db_type, typename Member> void ManageMembership( db_type & DB, Member T, const Types::UUIDvec_t & From, const Types::UUIDvec_t & To, const std::string &Id) {
|
template <typename db_type, typename Member>
|
||||||
|
void ManageMembership(db_type &DB, Member T, const Types::UUIDvec_t &From,
|
||||||
|
const Types::UUIDvec_t &To, const std::string &Id) {
|
||||||
if (From != To) {
|
if (From != To) {
|
||||||
for (const auto &i : From) {
|
for (const auto &i : From) {
|
||||||
RemoveMembership(DB, T, i, Id);
|
RemoveMembership(DB, T, i, Id);
|
||||||
@@ -384,7 +409,9 @@ namespace OpenWifi {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename Member, typename Rec, typename db_type > bool CreateMove(const Poco::JSON::Object::Ptr & RawObj, const char *fieldname, Member T, Rec & Existing, std::string &From, std::string &To, db_type & TheDB) {
|
template <typename Member, typename Rec, typename db_type>
|
||||||
|
bool CreateMove(const Poco::JSON::Object::Ptr &RawObj, const char *fieldname, Member T,
|
||||||
|
Rec &Existing, std::string &From, std::string &To, db_type &TheDB) {
|
||||||
if (RawObj->has(fieldname)) {
|
if (RawObj->has(fieldname)) {
|
||||||
From = Existing.*T;
|
From = Existing.*T;
|
||||||
To = RawObj->get(fieldname).toString();
|
To = RawObj->get(fieldname).toString();
|
||||||
@@ -404,14 +431,16 @@ namespace OpenWifi {
|
|||||||
return EntityDB::RootUUID();
|
return EntityDB::RootUUID();
|
||||||
}
|
}
|
||||||
|
|
||||||
inline bool ValidateConfigBlock(const ProvObjects::DeviceConfiguration &Config, RESTAPI::Errors::msg & Error) {
|
inline bool ValidateConfigBlock(const ProvObjects::DeviceConfiguration &Config,
|
||||||
static const std::vector<std::string> SectionNames{ "globals", "interfaces", "metrics", "radios", "services", "unit" };
|
std::vector<std::string> &Errors) {
|
||||||
|
static const std::vector<std::string> SectionNames{
|
||||||
|
"globals", "interfaces", "metrics", "radios", "services", "unit",
|
||||||
|
"definitions", "ethernet", "switch", "config-raw", "third-party"};
|
||||||
|
|
||||||
for (const auto &i : Config.configuration) {
|
for (const auto &i : Config.configuration) {
|
||||||
Poco::JSON::Parser P;
|
Poco::JSON::Parser P;
|
||||||
if (i.name.empty()) {
|
if (i.name.empty()) {
|
||||||
std::cout << "Name is empty" << std::endl;
|
Errors.push_back("Name is empty");
|
||||||
Error = RESTAPI::Errors::NameMustBeSet;
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -419,39 +448,38 @@ namespace OpenWifi {
|
|||||||
auto Blocks = P.parse(i.configuration).extract<Poco::JSON::Object::Ptr>();
|
auto Blocks = P.parse(i.configuration).extract<Poco::JSON::Object::Ptr>();
|
||||||
auto N = Blocks->getNames();
|
auto N = Blocks->getNames();
|
||||||
for (const auto &j : N) {
|
for (const auto &j : N) {
|
||||||
if (std::find(SectionNames.cbegin(), SectionNames.cend(), j) == SectionNames.cend()) {
|
if (std::find(SectionNames.cbegin(), SectionNames.cend(), j) ==
|
||||||
Error = RESTAPI::Errors::UnknownConfigurationSection;
|
SectionNames.cend()) {
|
||||||
|
Errors.push_back("Unknown block name");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} catch (const Poco::JSON::JSONException &E) {
|
} catch (const Poco::JSON::JSONException &E) {
|
||||||
Error = RESTAPI::Errors::InvalidJSONDocument;
|
Errors.push_back("Invalid JSON document");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
std::string ErrorText;
|
if (ValidateUCentralConfiguration(i.configuration, Errors, true)) {
|
||||||
if (ValidateUCentralConfiguration(i.configuration, ErrorText)) {
|
|
||||||
// std::cout << "Block: " << i.name << " is valid" << std::endl;
|
// std::cout << "Block: " << i.name << " is valid" << std::endl;
|
||||||
} else {
|
} else {
|
||||||
Error = RESTAPI::Errors::ConfigBlockInvalid ;
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
} catch (...) {
|
} catch (...) {
|
||||||
std::cout << "Exception in validation" << std::endl;
|
Errors.push_back("Invalid configuration caused an exception");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename Type> std::map<std::string,std::string> CreateObjects(Type & NewObject, RESTAPIHandler & R, RESTAPI::Errors::msg & Error) {
|
template <typename Type>
|
||||||
|
std::map<std::string, std::string> CreateObjects(Type &NewObject, RESTAPIHandler &R,
|
||||||
|
std::vector<std::string> &Errors) {
|
||||||
std::map<std::string, std::string> Result;
|
std::map<std::string, std::string> Result;
|
||||||
|
|
||||||
auto createObjects = R.GetParameter("createObjects", "");
|
auto createObjects = R.GetParameter("createObjects", "");
|
||||||
if (!createObjects.empty()) {
|
if (!createObjects.empty()) {
|
||||||
std::cout << "createObjects: " << createObjects << std::endl;
|
|
||||||
Poco::JSON::Parser P;
|
Poco::JSON::Parser P;
|
||||||
auto Objects = P.parse(createObjects).extract<Poco::JSON::Object::Ptr>();
|
auto Objects = P.parse(createObjects).extract<Poco::JSON::Object::Ptr>();
|
||||||
if (Objects->isArray("objects")) {
|
if (Objects->isArray("objects")) {
|
||||||
@@ -459,39 +487,41 @@ namespace OpenWifi {
|
|||||||
for (const auto &i : *ObjectsArray) {
|
for (const auto &i : *ObjectsArray) {
|
||||||
auto Object = i.extract<Poco::JSON::Object::Ptr>();
|
auto Object = i.extract<Poco::JSON::Object::Ptr>();
|
||||||
if (Object->has("location")) {
|
if (Object->has("location")) {
|
||||||
auto LocationDetails = Object->get("location").extract<Poco::JSON::Object::Ptr>();
|
auto LocationDetails =
|
||||||
|
Object->get("location").extract<Poco::JSON::Object::Ptr>();
|
||||||
ProvObjects::Location LC;
|
ProvObjects::Location LC;
|
||||||
if (LC.from_json(LocationDetails)) {
|
if (LC.from_json(LocationDetails)) {
|
||||||
if constexpr (std::is_same_v<Type, ProvObjects::Venue>) {
|
if constexpr (std::is_same_v<Type, ProvObjects::Venue>) {
|
||||||
std::cout << "Location decoded: " << LC.info.name << std::endl;
|
|
||||||
std::string ParentEntity = FindParentEntity(NewObject);
|
std::string ParentEntity = FindParentEntity(NewObject);
|
||||||
ProvObjects::CreateObjectInfo(R.UserInfo_.userinfo, LC.info);
|
ProvObjects::CreateObjectInfo(R.UserInfo_.userinfo, LC.info);
|
||||||
LC.entity = ParentEntity;
|
LC.entity = ParentEntity;
|
||||||
if (StorageService()->LocationDB().CreateRecord(LC)) {
|
if (StorageService()->LocationDB().CreateRecord(LC)) {
|
||||||
NewObject.location = LC.info.id;
|
NewObject.location = LC.info.id;
|
||||||
AddMembership(StorageService()->EntityDB(), &ProvObjects::Entity::locations,
|
AddMembership(StorageService()->EntityDB(),
|
||||||
ParentEntity, LC.info.id);
|
&ProvObjects::Entity::locations, ParentEntity,
|
||||||
|
LC.info.id);
|
||||||
Result["location"] = LC.info.id;
|
Result["location"] = LC.info.id;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if constexpr (std::is_same_v<Type, ProvObjects::Operator>) {
|
if constexpr (std::is_same_v<Type, ProvObjects::Operator>) {
|
||||||
std::cout << "Location decoded: " << LC.info.name << std::endl;
|
|
||||||
std::string ParentEntity = FindParentEntity(NewObject);
|
std::string ParentEntity = FindParentEntity(NewObject);
|
||||||
ProvObjects::CreateObjectInfo(R.UserInfo_.userinfo, LC.info);
|
ProvObjects::CreateObjectInfo(R.UserInfo_.userinfo, LC.info);
|
||||||
LC.entity = ParentEntity;
|
LC.entity = ParentEntity;
|
||||||
if (StorageService()->LocationDB().CreateRecord(LC)) {
|
if (StorageService()->LocationDB().CreateRecord(LC)) {
|
||||||
NewObject.location = LC.info.id;
|
NewObject.location = LC.info.id;
|
||||||
AddMembership(StorageService()->EntityDB(), &ProvObjects::Entity::locations,
|
AddMembership(StorageService()->EntityDB(),
|
||||||
ParentEntity, LC.info.id);
|
&ProvObjects::Entity::locations, ParentEntity,
|
||||||
|
LC.info.id);
|
||||||
Result["location"] = LC.info.id;
|
Result["location"] = LC.info.id;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
Error = RESTAPI::Errors::InvalidJSONDocument;
|
Errors.push_back("Invalid JSON document");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
} else if (Object->has("contact")) {
|
} else if (Object->has("contact")) {
|
||||||
auto ContactDetails = Object->get("contact").extract<Poco::JSON::Object::Ptr>();
|
auto ContactDetails =
|
||||||
|
Object->get("contact").extract<Poco::JSON::Object::Ptr>();
|
||||||
ProvObjects::Contact CC;
|
ProvObjects::Contact CC;
|
||||||
if (CC.from_json(ContactDetails)) {
|
if (CC.from_json(ContactDetails)) {
|
||||||
std::cout << "contact decoded: " << CC.info.name << std::endl;
|
std::cout << "contact decoded: " << CC.info.name << std::endl;
|
||||||
@@ -499,14 +529,15 @@ namespace OpenWifi {
|
|||||||
std::cout << "contact not decoded." << std::endl;
|
std::cout << "contact not decoded." << std::endl;
|
||||||
}
|
}
|
||||||
} else if (Object->has("configuration")) {
|
} else if (Object->has("configuration")) {
|
||||||
auto ConfigurationDetails = Object->get("configuration").template extract<Poco::JSON::Object::Ptr>();
|
auto ConfigurationDetails =
|
||||||
|
Object->get("configuration")
|
||||||
|
.template extract<Poco::JSON::Object::Ptr>();
|
||||||
ProvObjects::DeviceConfiguration DC;
|
ProvObjects::DeviceConfiguration DC;
|
||||||
if (DC.from_json(ConfigurationDetails)) {
|
if (DC.from_json(ConfigurationDetails)) {
|
||||||
if constexpr (std::is_same_v<Type, ProvObjects::InventoryTag>) {
|
if constexpr (std::is_same_v<Type, ProvObjects::InventoryTag>) {
|
||||||
if(!ValidateConfigBlock(DC,Error)) {
|
if (!ValidateConfigBlock(DC, Errors)) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
std::cout << "Configuration decoded: " << DC.info.name << std::endl;
|
|
||||||
ProvObjects::CreateObjectInfo(R.UserInfo_.userinfo, DC.info);
|
ProvObjects::CreateObjectInfo(R.UserInfo_.userinfo, DC.info);
|
||||||
if (StorageService()->ConfigurationDB().CreateRecord(DC)) {
|
if (StorageService()->ConfigurationDB().CreateRecord(DC)) {
|
||||||
NewObject.deviceConfiguration = DC.info.id;
|
NewObject.deviceConfiguration = DC.info.id;
|
||||||
@@ -514,20 +545,45 @@ namespace OpenWifi {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
Error = RESTAPI::Errors::InvalidJSONDocument;
|
Errors.push_back("Invalid JSON document");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return Result;
|
return Result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
inline bool ValidSchedule(const std::string &v) {
|
||||||
|
try {
|
||||||
|
auto cron = cron::make_cron(v);
|
||||||
|
return true;
|
||||||
|
} catch (cron::bad_cronexpr const &ex) {
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
inline bool ValidRRM(const std::string &v) {
|
||||||
|
if ((v == "no") || (v == "inherit"))
|
||||||
|
return true;
|
||||||
|
try {
|
||||||
|
Poco::JSON::Parser P;
|
||||||
|
auto O = P.parse(v).extract<Poco::JSON::Object::Ptr>();
|
||||||
|
|
||||||
|
ProvObjects::RRMDetails D;
|
||||||
|
if (D.from_json(O)) {
|
||||||
|
return ValidSchedule(D.schedule);
|
||||||
|
}
|
||||||
|
} catch (...) {
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
inline bool ValidDeviceRules(const ProvObjects::DeviceRules &DR) {
|
inline bool ValidDeviceRules(const ProvObjects::DeviceRules &DR) {
|
||||||
return (DR.rrm=="yes" || DR.rrm=="no" || DR.rrm=="inherit") &&
|
return (ValidRRM(DR.rrm)) &&
|
||||||
(DR.firmwareUpgrade=="yes" || DR.firmwareUpgrade=="no" || DR.firmwareUpgrade=="inherit") &&
|
(DR.firmwareUpgrade == "yes" || DR.firmwareUpgrade == "no" ||
|
||||||
|
DR.firmwareUpgrade == "inherit") &&
|
||||||
(DR.rcOnly == "yes" || DR.rcOnly == "no" || DR.rcOnly == "inherit");
|
(DR.rcOnly == "yes" || DR.rcOnly == "no" || DR.rcOnly == "inherit");
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -538,28 +594,24 @@ namespace OpenWifi {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline bool ValidSourceIP([[maybe_unused]] const std::vector<std::string> & IPs) {
|
inline bool ValidSourceIP([[maybe_unused]] const std::vector<std::string> &IPs) { return true; }
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
inline bool ValidPeriod(const std::string &P) {
|
inline bool ValidPeriod(const std::string &P) {
|
||||||
return (P == "hourly" || P == "daily" || P == "monthly" || P == "yearly" ||
|
return (P == "hourly" || P == "daily" || P == "monthly" || P == "yearly" ||
|
||||||
P=="quarterly" || P=="lifetime" || P=="custom1" ||
|
P == "quarterly" || P == "lifetime" || P == "custom1" || P == "custom2" ||
|
||||||
P=="custom2"|| P=="custom3"|| P=="custom4");
|
P == "custom3" || P == "custom4");
|
||||||
}
|
}
|
||||||
|
|
||||||
inline bool ValidContactType(const std::string &contact) {
|
inline bool ValidContactType(const std::string &contact) {
|
||||||
auto C = Poco::toLower(contact);
|
auto C = Poco::toLower(contact);
|
||||||
return (C == "subscriber" || C == "user" || C == "installer" || C == "csr" ||
|
return (C == "subscriber" || C == "user" || C == "installer" || C == "csr" ||
|
||||||
C=="manager" || C=="businessowner" || C=="technician" ||
|
C == "manager" || C == "businessowner" || C == "technician" || C == "corporate");
|
||||||
C=="corporate");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
inline bool ValidContactType(const std::string &contact, RESTAPIHandler &H) {
|
inline bool ValidContactType(const std::string &contact, RESTAPIHandler &H) {
|
||||||
auto C = Poco::toLower(contact);
|
auto C = Poco::toLower(contact);
|
||||||
if (C=="subscriber" || C=="user" || C=="installer" || C=="csr" ||
|
if (C == "subscriber" || C == "user" || C == "installer" || C == "csr" || C == "manager" ||
|
||||||
C=="manager" || C=="businessowner" || C=="technician" ||
|
C == "businessowner" || C == "technician" || C == "corporate")
|
||||||
C=="corporate")
|
|
||||||
return true;
|
return true;
|
||||||
H.BadRequest(RESTAPI::Errors::InvalidContactType);
|
H.BadRequest(RESTAPI::Errors::InvalidContactType);
|
||||||
return false;
|
return false;
|
||||||
@@ -573,14 +625,16 @@ namespace OpenWifi {
|
|||||||
|
|
||||||
inline bool ValidLocationType(const std::string &location, RESTAPIHandler &H) {
|
inline bool ValidLocationType(const std::string &location, RESTAPIHandler &H) {
|
||||||
auto C = Poco::toLower(location);
|
auto C = Poco::toLower(location);
|
||||||
if((C=="service" || C=="equipment" || C=="auto" || C=="manual" ||
|
if ((C == "service" || C == "equipment" || C == "auto" || C == "manual" || C == "special" ||
|
||||||
C=="special" || C=="unknown" || C=="corporate"))
|
C == "unknown" || C == "corporate"))
|
||||||
return true;
|
return true;
|
||||||
H.BadRequest(RESTAPI::Errors::InvalidLocationType);
|
H.BadRequest(RESTAPI::Errors::InvalidLocationType);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename DBType> bool ValidDbId(const Types::UUID_t &uuid, DBType & DB, bool AllowEmpty , const RESTAPI::Errors::msg &Error , RESTAPIHandler & H) {
|
template <typename DBType>
|
||||||
|
bool ValidDbId(const Types::UUID_t &uuid, DBType &DB, bool AllowEmpty,
|
||||||
|
const RESTAPI::Errors::msg &Error, RESTAPIHandler &H) {
|
||||||
if (!AllowEmpty && uuid.empty()) {
|
if (!AllowEmpty && uuid.empty()) {
|
||||||
H.BadRequest(Error);
|
H.BadRequest(Error);
|
||||||
return false;
|
return false;
|
||||||
@@ -609,7 +663,8 @@ namespace OpenWifi {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline bool ValidSubscriberId( const Types::UUID_t & uuid, bool AllowEmpty, std::string & email, RESTAPIHandler &H ) {
|
inline bool ValidSubscriberId(const Types::UUID_t &uuid, bool AllowEmpty, std::string &email,
|
||||||
|
RESTAPIHandler &H) {
|
||||||
if (!AllowEmpty && uuid.empty()) {
|
if (!AllowEmpty && uuid.empty()) {
|
||||||
H.BadRequest(RESTAPI::Errors::InvalidSubscriberId);
|
H.BadRequest(RESTAPI::Errors::InvalidSubscriberId);
|
||||||
return false;
|
return false;
|
||||||
@@ -625,7 +680,8 @@ namespace OpenWifi {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline bool ValidSerialNumber(const std::string &serialNumber, bool AllowEmpty, RESTAPIHandler &H) {
|
inline bool ValidSerialNumber(const std::string &serialNumber, bool AllowEmpty,
|
||||||
|
RESTAPIHandler &H) {
|
||||||
if (!AllowEmpty && serialNumber.empty()) {
|
if (!AllowEmpty && serialNumber.empty()) {
|
||||||
H.BadRequest(RESTAPI::Errors::InvalidSerialNumber);
|
H.BadRequest(RESTAPI::Errors::InvalidSerialNumber);
|
||||||
return false;
|
return false;
|
||||||
@@ -638,7 +694,8 @@ namespace OpenWifi {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename DBType, typename DBRecordType> void ReturnUpdatedObject( DBType & DB, const DBRecordType & R, RESTAPIHandler &H) {
|
template <typename DBType, typename DBRecordType>
|
||||||
|
void ReturnUpdatedObject(DBType &DB, const DBRecordType &R, RESTAPIHandler &H) {
|
||||||
if (DB.UpdateRecord("id", R.info.id, R)) {
|
if (DB.UpdateRecord("id", R.info.id, R)) {
|
||||||
DBRecordType Updated;
|
DBRecordType Updated;
|
||||||
DB.GetRecord("id", R.info.id, Updated);
|
DB.GetRecord("id", R.info.id, Updated);
|
||||||
@@ -650,7 +707,8 @@ namespace OpenWifi {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename DBType, typename DBRecordType> void ReturnCreatedObject( DBType & DB, const DBRecordType & R, RESTAPIHandler &H) {
|
template <typename DBType, typename DBRecordType>
|
||||||
|
void ReturnCreatedObject(DBType &DB, const DBRecordType &R, RESTAPIHandler &H) {
|
||||||
if (DB.CreateRecord(R)) {
|
if (DB.CreateRecord(R)) {
|
||||||
DBRecordType Updated;
|
DBRecordType Updated;
|
||||||
DB.GetRecord("id", R.info.id, Updated);
|
DB.GetRecord("id", R.info.id, Updated);
|
||||||
@@ -669,4 +727,4 @@ namespace OpenWifi {
|
|||||||
RESTAPI_utils::field_to_json(Answer, "list", Fields);
|
RESTAPI_utils::field_to_json(Answer, "list", Fields);
|
||||||
return H.ReturnObject(Answer);
|
return H.ReturnObject(Answer);
|
||||||
}
|
}
|
||||||
}
|
} // namespace OpenWifi
|
||||||
|
|||||||
@@ -6,13 +6,14 @@
|
|||||||
// Arilia Wireless Inc.
|
// Arilia Wireless Inc.
|
||||||
//
|
//
|
||||||
|
|
||||||
|
|
||||||
#include "RESTAPI_entity_handler.h"
|
#include "RESTAPI_entity_handler.h"
|
||||||
|
|
||||||
|
#include "RESTAPI_db_helpers.h"
|
||||||
#include "RESTObjects/RESTAPI_ProvObjects.h"
|
#include "RESTObjects/RESTAPI_ProvObjects.h"
|
||||||
#include "RESTObjects/RESTAPI_SecurityObjects.h"
|
#include "RESTObjects/RESTAPI_SecurityObjects.h"
|
||||||
#include "StorageService.h"
|
#include "StorageService.h"
|
||||||
#include "RESTAPI_db_helpers.h"
|
|
||||||
|
#include "framework/CIDR.h"
|
||||||
|
|
||||||
namespace OpenWifi {
|
namespace OpenWifi {
|
||||||
|
|
||||||
@@ -41,12 +42,14 @@ namespace OpenWifi{
|
|||||||
return BadRequest(RESTAPI::Errors::CannotDeleteRoot);
|
return BadRequest(RESTAPI::Errors::CannotDeleteRoot);
|
||||||
}
|
}
|
||||||
|
|
||||||
if( !Existing.children.empty() || !Existing.devices.empty() || !Existing.venues.empty() || !Existing.locations.empty()
|
if (!Existing.children.empty() || !Existing.devices.empty() || !Existing.venues.empty() ||
|
||||||
|| !Existing.contacts.empty() || !Existing.configurations.empty()) {
|
!Existing.locations.empty() || !Existing.contacts.empty() ||
|
||||||
|
!Existing.configurations.empty()) {
|
||||||
return BadRequest(RESTAPI::Errors::StillInUse);
|
return BadRequest(RESTAPI::Errors::StillInUse);
|
||||||
}
|
}
|
||||||
|
|
||||||
MoveUsage(StorageService()->PolicyDB(),DB_,Existing.managementPolicy,"",Existing.info.id);
|
MoveUsage(StorageService()->PolicyDB(), DB_, Existing.managementPolicy, "",
|
||||||
|
Existing.info.id);
|
||||||
DB_.DeleteRecord("id", UUID);
|
DB_.DeleteRecord("id", UUID);
|
||||||
DB_.DeleteChild("id", Existing.parent, UUID);
|
DB_.DeleteChild("id", Existing.parent, UUID);
|
||||||
return OK();
|
return OK();
|
||||||
@@ -76,9 +79,9 @@ namespace OpenWifi{
|
|||||||
return BadRequest(RESTAPI::Errors::NameMustBeSet);
|
return BadRequest(RESTAPI::Errors::NameMustBeSet);
|
||||||
}
|
}
|
||||||
|
|
||||||
// When creating an entity, it cannot have any relations other that parent, notes, name, description. Everything else
|
// When creating an entity, it cannot have any relations other that parent, notes, name,
|
||||||
// must be conveyed through PUT.
|
// description. Everything else must be conveyed through PUT.
|
||||||
NewEntity.info.id = (UUID==EntityDB::RootUUID()) ? UUID : MicroService::CreateUUID();
|
NewEntity.info.id = (UUID == EntityDB::RootUUID()) ? UUID : MicroServiceCreateUUID();
|
||||||
|
|
||||||
if (UUID == EntityDB::RootUUID()) {
|
if (UUID == EntityDB::RootUUID()) {
|
||||||
NewEntity.parent = "";
|
NewEntity.parent = "";
|
||||||
@@ -86,7 +89,8 @@ namespace OpenWifi{
|
|||||||
return BadRequest(RESTAPI::Errors::ParentUUIDMustExist);
|
return BadRequest(RESTAPI::Errors::ParentUUIDMustExist);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!NewEntity.managementPolicy.empty() && !StorageService()->PolicyDB().Exists("id", NewEntity.managementPolicy)){
|
if (!NewEntity.managementPolicy.empty() &&
|
||||||
|
!StorageService()->PolicyDB().Exists("id", NewEntity.managementPolicy)) {
|
||||||
return BadRequest(RESTAPI::Errors::UnknownManagementPolicyUUID);
|
return BadRequest(RESTAPI::Errors::UnknownManagementPolicyUUID);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -102,7 +106,8 @@ namespace OpenWifi{
|
|||||||
NewEntity.managementRoles.clear();
|
NewEntity.managementRoles.clear();
|
||||||
|
|
||||||
if (DB_.CreateRecord(NewEntity)) {
|
if (DB_.CreateRecord(NewEntity)) {
|
||||||
MoveUsage(StorageService()->PolicyDB(),DB_,"",NewEntity.managementPolicy,NewEntity.info.id);
|
MoveUsage(StorageService()->PolicyDB(), DB_, "", NewEntity.managementPolicy,
|
||||||
|
NewEntity.info.id);
|
||||||
DB_.AddChild("id", NewEntity.parent, NewEntity.info.id);
|
DB_.AddChild("id", NewEntity.parent, NewEntity.info.id);
|
||||||
|
|
||||||
Poco::JSON::Object Answer;
|
Poco::JSON::Object Answer;
|
||||||
@@ -143,7 +148,8 @@ namespace OpenWifi{
|
|||||||
}
|
}
|
||||||
|
|
||||||
std::string FromPolicy, ToPolicy;
|
std::string FromPolicy, ToPolicy;
|
||||||
if(!CreateMove(RawObject,"managementPolicy",&EntityDB::RecordName::managementPolicy, Existing, FromPolicy, ToPolicy, StorageService()->PolicyDB()))
|
if (!CreateMove(RawObject, "managementPolicy", &EntityDB::RecordName::managementPolicy,
|
||||||
|
Existing, FromPolicy, ToPolicy, StorageService()->PolicyDB()))
|
||||||
return BadRequest(RESTAPI::Errors::UnknownManagementPolicyUUID);
|
return BadRequest(RESTAPI::Errors::UnknownManagementPolicyUUID);
|
||||||
|
|
||||||
if (RawObject->has("sourceIP")) {
|
if (RawObject->has("sourceIP")) {
|
||||||
@@ -172,4 +178,4 @@ namespace OpenWifi{
|
|||||||
}
|
}
|
||||||
InternalError(RESTAPI::Errors::RecordNotUpdated);
|
InternalError(RESTAPI::Errors::RecordNotUpdated);
|
||||||
}
|
}
|
||||||
}
|
} // namespace OpenWifi
|
||||||
@@ -7,24 +7,22 @@
|
|||||||
//
|
//
|
||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include "framework/MicroService.h"
|
|
||||||
#include "StorageService.h"
|
#include "StorageService.h"
|
||||||
|
#include "framework/RESTAPI_Handler.h"
|
||||||
|
|
||||||
namespace OpenWifi {
|
namespace OpenWifi {
|
||||||
class RESTAPI_entity_handler : public RESTAPIHandler {
|
class RESTAPI_entity_handler : public RESTAPIHandler {
|
||||||
public:
|
public:
|
||||||
RESTAPI_entity_handler(const RESTAPIHandler::BindingMap &bindings, Poco::Logger &L, RESTAPI_GenericServer & Server, uint64_t TransactionId, bool Internal)
|
RESTAPI_entity_handler(const RESTAPIHandler::BindingMap &bindings, Poco::Logger &L,
|
||||||
|
RESTAPI_GenericServerAccounting &Server, uint64_t TransactionId,
|
||||||
|
bool Internal)
|
||||||
: RESTAPIHandler(bindings, L,
|
: RESTAPIHandler(bindings, L,
|
||||||
std::vector<std::string>{
|
std::vector<std::string>{Poco::Net::HTTPRequest::HTTP_GET,
|
||||||
Poco::Net::HTTPRequest::HTTP_GET,
|
|
||||||
Poco::Net::HTTPRequest::HTTP_POST,
|
Poco::Net::HTTPRequest::HTTP_POST,
|
||||||
Poco::Net::HTTPRequest::HTTP_PUT,
|
Poco::Net::HTTPRequest::HTTP_PUT,
|
||||||
Poco::Net::HTTPRequest::HTTP_DELETE,
|
Poco::Net::HTTPRequest::HTTP_DELETE,
|
||||||
Poco::Net::HTTPRequest::HTTP_OPTIONS},
|
Poco::Net::HTTPRequest::HTTP_OPTIONS},
|
||||||
Server,
|
Server, TransactionId, Internal) {}
|
||||||
TransactionId,
|
|
||||||
Internal){}
|
|
||||||
static auto PathName() { return std::list<std::string>{"/api/v1/entity/{uuid}"}; };
|
static auto PathName() { return std::list<std::string>{"/api/v1/entity/{uuid}"}; };
|
||||||
|
|
||||||
private:
|
private:
|
||||||
@@ -34,4 +32,4 @@ namespace OpenWifi {
|
|||||||
void DoPut() final;
|
void DoPut() final;
|
||||||
void DoDelete() final;
|
void DoDelete() final;
|
||||||
};
|
};
|
||||||
}
|
} // namespace OpenWifi
|
||||||
|
|||||||
@@ -6,17 +6,15 @@
|
|||||||
// Arilia Wireless Inc.
|
// Arilia Wireless Inc.
|
||||||
//
|
//
|
||||||
|
|
||||||
#include "framework/MicroService.h"
|
|
||||||
#include "RESTAPI_entity_list_handler.h"
|
#include "RESTAPI_entity_list_handler.h"
|
||||||
#include "StorageService.h"
|
|
||||||
#include "RESTAPI_db_helpers.h"
|
#include "RESTAPI_db_helpers.h"
|
||||||
|
#include "StorageService.h"
|
||||||
|
|
||||||
namespace OpenWifi {
|
namespace OpenWifi {
|
||||||
|
|
||||||
void RESTAPI_entity_list_handler::DoGet() {
|
void RESTAPI_entity_list_handler::DoGet() {
|
||||||
if (!QB_.Select.empty()) {
|
if (!QB_.Select.empty()) {
|
||||||
return ReturnRecordList<decltype(DB_),
|
return ReturnRecordList<decltype(DB_), ProvObjects::Entity>("entities", DB_, *this);
|
||||||
ProvObjects::Entity>("entities",DB_,*this );
|
|
||||||
} else if (QB_.CountOnly) {
|
} else if (QB_.CountOnly) {
|
||||||
auto C = DB_.Count();
|
auto C = DB_.Count();
|
||||||
return ReturnCountOnly(C);
|
return ReturnCountOnly(C);
|
||||||
@@ -39,4 +37,4 @@ namespace OpenWifi{
|
|||||||
}
|
}
|
||||||
BadRequest(RESTAPI::Errors::MissingOrInvalidParameters);
|
BadRequest(RESTAPI::Errors::MissingOrInvalidParameters);
|
||||||
}
|
}
|
||||||
}
|
} // namespace OpenWifi
|
||||||
@@ -6,25 +6,23 @@
|
|||||||
// Arilia Wireless Inc.
|
// Arilia Wireless Inc.
|
||||||
//
|
//
|
||||||
|
|
||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include "framework/MicroService.h"
|
|
||||||
#include "StorageService.h"
|
#include "StorageService.h"
|
||||||
|
#include "framework/RESTAPI_Handler.h"
|
||||||
|
|
||||||
namespace OpenWifi {
|
namespace OpenWifi {
|
||||||
class RESTAPI_entity_list_handler : public RESTAPIHandler {
|
class RESTAPI_entity_list_handler : public RESTAPIHandler {
|
||||||
public:
|
public:
|
||||||
RESTAPI_entity_list_handler(const RESTAPIHandler::BindingMap &bindings, Poco::Logger &L, RESTAPI_GenericServer & Server, uint64_t TransactionId, bool Internal)
|
RESTAPI_entity_list_handler(const RESTAPIHandler::BindingMap &bindings, Poco::Logger &L,
|
||||||
|
RESTAPI_GenericServerAccounting &Server, uint64_t TransactionId,
|
||||||
|
bool Internal)
|
||||||
: RESTAPIHandler(bindings, L,
|
: RESTAPIHandler(bindings, L,
|
||||||
std::vector<std::string>{
|
std::vector<std::string>{Poco::Net::HTTPRequest::HTTP_GET,
|
||||||
Poco::Net::HTTPRequest::HTTP_GET,
|
|
||||||
Poco::Net::HTTPRequest::HTTP_POST,
|
Poco::Net::HTTPRequest::HTTP_POST,
|
||||||
Poco::Net::HTTPRequest::HTTP_OPTIONS},
|
Poco::Net::HTTPRequest::HTTP_OPTIONS},
|
||||||
Server,
|
Server, TransactionId, Internal) {}
|
||||||
TransactionId,
|
|
||||||
Internal){}
|
|
||||||
static auto PathName() { return std::list<std::string>{"/api/v1/entity"}; };
|
static auto PathName() { return std::list<std::string>{"/api/v1/entity"}; };
|
||||||
|
|
||||||
private:
|
private:
|
||||||
EntityDB &DB_ = StorageService()->EntityDB();
|
EntityDB &DB_ = StorageService()->EntityDB();
|
||||||
void DoGet() final;
|
void DoGet() final;
|
||||||
@@ -32,4 +30,4 @@ namespace OpenWifi {
|
|||||||
void DoPut() final{};
|
void DoPut() final{};
|
||||||
void DoDelete() final{};
|
void DoDelete() final{};
|
||||||
};
|
};
|
||||||
}
|
} // namespace OpenWifi
|
||||||
|
|||||||
@@ -8,14 +8,15 @@
|
|||||||
|
|
||||||
#include "RESTAPI_inventory_handler.h"
|
#include "RESTAPI_inventory_handler.h"
|
||||||
|
|
||||||
#include "StorageService.h"
|
|
||||||
#include "APConfig.h"
|
#include "APConfig.h"
|
||||||
#include "AutoDiscovery.h"
|
#include "AutoDiscovery.h"
|
||||||
#include "sdks/SDK_gw.h"
|
#include "DeviceTypeCache.h"
|
||||||
#include "sdks/SDK_sec.h"
|
|
||||||
#include "RESTAPI/RESTAPI_db_helpers.h"
|
#include "RESTAPI/RESTAPI_db_helpers.h"
|
||||||
#include "SerialNumberCache.h"
|
#include "SerialNumberCache.h"
|
||||||
#include "DeviceTypeCache.h"
|
#include "StorageService.h"
|
||||||
|
#include "framework/utils.h"
|
||||||
|
#include "sdks/SDK_gw.h"
|
||||||
|
#include "sdks/SDK_sec.h"
|
||||||
|
|
||||||
namespace OpenWifi {
|
namespace OpenWifi {
|
||||||
|
|
||||||
@@ -25,7 +26,9 @@ namespace OpenWifi{
|
|||||||
auto Results = Response->get("results").extract<Poco::JSON::Object::Ptr>();
|
auto Results = Response->get("results").extract<Poco::JSON::Object::Ptr>();
|
||||||
auto Status = Results->get("status").extract<Poco::JSON::Object::Ptr>();
|
auto Status = Results->get("status").extract<Poco::JSON::Object::Ptr>();
|
||||||
auto Rejected = Status->getArray("rejected");
|
auto Rejected = Status->getArray("rejected");
|
||||||
std::transform(Rejected->begin(),Rejected->end(),std::back_inserter(Warnings), [](auto i) -> auto { return i.toString(); });
|
std::transform(
|
||||||
|
Rejected->begin(), Rejected->end(), std::back_inserter(Warnings),
|
||||||
|
[](auto i) -> auto { return i.toString(); });
|
||||||
// for(const auto &i:*Rejected)
|
// for(const auto &i:*Rejected)
|
||||||
// Warnings.push_back(i.toString());
|
// Warnings.push_back(i.toString());
|
||||||
}
|
}
|
||||||
@@ -37,16 +40,19 @@ namespace OpenWifi{
|
|||||||
|
|
||||||
ProvObjects::InventoryTag Existing;
|
ProvObjects::InventoryTag Existing;
|
||||||
std::string SerialNumber = GetBinding(RESTAPI::Protocol::SERIALNUMBER, "");
|
std::string SerialNumber = GetBinding(RESTAPI::Protocol::SERIALNUMBER, "");
|
||||||
Logger().debug(Poco::format("%s: Retrieving inventory information.",SerialNumber));
|
poco_debug(Logger(), fmt::format("{}: Retrieving inventory information.", SerialNumber));
|
||||||
if(SerialNumber.empty() || !DB_.GetRecord(RESTAPI::Protocol::SERIALNUMBER,SerialNumber,Existing)) {
|
if (SerialNumber.empty() ||
|
||||||
|
!DB_.GetRecord(RESTAPI::Protocol::SERIALNUMBER, SerialNumber, Existing)) {
|
||||||
return NotFound();
|
return NotFound();
|
||||||
}
|
}
|
||||||
Logger().debug(Poco::format("%s,%s: Retrieving inventory information.", Existing.serialNumber, Existing.info.id ));
|
poco_debug(Logger(), fmt::format("{},{}: Retrieving inventory information.",
|
||||||
|
Existing.serialNumber, Existing.info.id));
|
||||||
|
|
||||||
Poco::JSON::Object Answer;
|
Poco::JSON::Object Answer;
|
||||||
std::string Arg;
|
std::string Arg;
|
||||||
if(HasParameter("config",Arg) && Arg=="true") {
|
if (GetBoolParameter("config", false)) {
|
||||||
bool Explain = (HasParameter("explain",Arg) && Arg == "true");
|
bool Explain = GetBoolParameter("explain", false);
|
||||||
|
|
||||||
APConfig Device(SerialNumber, Existing.deviceType, Logger(), Explain);
|
APConfig Device(SerialNumber, Existing.deviceType, Logger(), Explain);
|
||||||
|
|
||||||
auto Configuration = Poco::makeShared<Poco::JSON::Object>();
|
auto Configuration = Poco::makeShared<Poco::JSON::Object>();
|
||||||
@@ -58,39 +64,78 @@ namespace OpenWifi{
|
|||||||
Answer.set("config", "none");
|
Answer.set("config", "none");
|
||||||
}
|
}
|
||||||
return ReturnObject(Answer);
|
return ReturnObject(Answer);
|
||||||
} else if(HasParameter("firmwareOptions", Arg) && Arg=="true") {
|
} else if (GetBoolParameter("firmwareOptions", false)) {
|
||||||
ProvObjects::DeviceRules Rules;
|
ProvObjects::DeviceRules Rules;
|
||||||
StorageService()->InventoryDB().EvaluateDeviceSerialNumberRules(SerialNumber, Rules);
|
StorageService()->InventoryDB().EvaluateDeviceSerialNumberRules(SerialNumber, Rules);
|
||||||
Answer.set("firmwareUpgrade", Rules.firmwareUpgrade);
|
Answer.set("firmwareUpgrade", Rules.firmwareUpgrade);
|
||||||
Answer.set("firmwareRCOnly", Rules.rcOnly == "yes");
|
Answer.set("firmwareRCOnly", Rules.rcOnly == "yes");
|
||||||
return ReturnObject(Answer);
|
return ReturnObject(Answer);
|
||||||
} else if(HasParameter("applyConfiguration",Arg) && Arg=="true") {
|
} else if (GetBoolParameter("rrmSettings", false)) {
|
||||||
Logger().debug(Poco::format("%s: Retrieving configuration.",Existing.serialNumber));
|
ProvObjects::DeviceRules Rules;
|
||||||
auto Device = std::make_shared<APConfig>(SerialNumber, Existing.deviceType, Logger(), false);
|
StorageService()->InventoryDB().EvaluateDeviceSerialNumberRules(SerialNumber, Rules);
|
||||||
|
if (Rules.rrm == "no" || Rules.rrm == "inherit") {
|
||||||
|
Answer.set("rrm", Rules.rrm);
|
||||||
|
} else {
|
||||||
|
ProvObjects::RRMDetails D;
|
||||||
|
Poco::JSON::Parser P;
|
||||||
|
try {
|
||||||
|
auto Obj = P.parse(Rules.rrm).extract<Poco::JSON::Object::Ptr>();
|
||||||
|
Answer.set("rrm", Obj);
|
||||||
|
} catch (...) {
|
||||||
|
Answer.set("rrm", "invalid");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return ReturnObject(Answer);
|
||||||
|
} else if (GetBoolParameter("applyConfiguration", false)) {
|
||||||
|
poco_debug(Logger(),
|
||||||
|
fmt::format("{}: Retrieving configuration.", Existing.serialNumber));
|
||||||
|
auto Device =
|
||||||
|
std::make_shared<APConfig>(SerialNumber, Existing.deviceType, Logger(), false);
|
||||||
auto Configuration = Poco::makeShared<Poco::JSON::Object>();
|
auto Configuration = Poco::makeShared<Poco::JSON::Object>();
|
||||||
Poco::JSON::Object ErrorsObj, WarningsObj;
|
Poco::JSON::Object ErrorsObj, WarningsObj;
|
||||||
ProvObjects::InventoryConfigApplyResult Results;
|
ProvObjects::InventoryConfigApplyResult Results;
|
||||||
Logger().debug(Poco::format("%s: Computing configuration.",Existing.serialNumber));
|
poco_debug(Logger(),
|
||||||
|
fmt::format("{}: Computing configuration.", Existing.serialNumber));
|
||||||
if (Device->Get(Configuration)) {
|
if (Device->Get(Configuration)) {
|
||||||
std::ostringstream OS;
|
std::ostringstream OS;
|
||||||
Configuration->stringify(OS);
|
Configuration->stringify(OS);
|
||||||
Results.appliedConfiguration = OS.str();
|
Results.appliedConfiguration = OS.str();
|
||||||
auto Response = Poco::makeShared<Poco::JSON::Object>();
|
auto Response = Poco::makeShared<Poco::JSON::Object>();
|
||||||
Logger().debug(Poco::format("%s: Sending configuration push.",Existing.serialNumber));
|
poco_debug(Logger(),
|
||||||
|
fmt::format("{}: Sending configuration push.", Existing.serialNumber));
|
||||||
if (SDK::GW::Device::Configure(this, SerialNumber, Configuration, Response)) {
|
if (SDK::GW::Device::Configure(this, SerialNumber, Configuration, Response)) {
|
||||||
Logger().debug(Poco::format("%s: Sending configuration pushed.",Existing.serialNumber));
|
poco_debug(Logger(), fmt::format("{}: Sending configuration pushed.",
|
||||||
|
Existing.serialNumber));
|
||||||
GetRejectedLines(Response, Results.warnings);
|
GetRejectedLines(Response, Results.warnings);
|
||||||
Results.errorCode = 0;
|
Results.errorCode = 0;
|
||||||
} else {
|
} else {
|
||||||
Logger().debug(Poco::format("%s: Sending configuration failed.",Existing.serialNumber));
|
poco_debug(Logger(), fmt::format("{}: Sending configuration failed.",
|
||||||
|
Existing.serialNumber));
|
||||||
Results.errorCode = 1;
|
Results.errorCode = 1;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
Logger().debug(Poco::format("%s: Configuration is bad.",Existing.serialNumber));
|
poco_debug(Logger(),
|
||||||
|
fmt::format("{}: Configuration is bad.", Existing.serialNumber));
|
||||||
Results.errorCode = 1;
|
Results.errorCode = 1;
|
||||||
}
|
}
|
||||||
Results.to_json(Answer);
|
Results.to_json(Answer);
|
||||||
return ReturnObject(Answer);
|
return ReturnObject(Answer);
|
||||||
|
} else if (GetBoolParameter("resolveConfig", false)) {
|
||||||
|
poco_debug(Logger(),
|
||||||
|
fmt::format("{}: Retrieving configuration.", Existing.serialNumber));
|
||||||
|
auto Device =
|
||||||
|
std::make_shared<APConfig>(SerialNumber, Existing.deviceType, Logger(), false);
|
||||||
|
auto Configuration = Poco::makeShared<Poco::JSON::Object>();
|
||||||
|
Poco::JSON::Object ErrorsObj, WarningsObj;
|
||||||
|
ProvObjects::InventoryConfigApplyResult Results;
|
||||||
|
poco_debug(Logger(),
|
||||||
|
Poco::format("{}: Computing configuration.", Existing.serialNumber));
|
||||||
|
if (Device->Get(Configuration)) {
|
||||||
|
Answer.set("configuration", Configuration);
|
||||||
|
} else {
|
||||||
|
Answer.set("error", 1);
|
||||||
|
}
|
||||||
|
return ReturnObject(Answer);
|
||||||
} else if (QB_.AdditionalInfo) {
|
} else if (QB_.AdditionalInfo) {
|
||||||
AddExtendedInfo(Existing, Answer);
|
AddExtendedInfo(Existing, Answer);
|
||||||
}
|
}
|
||||||
@@ -101,41 +146,51 @@ namespace OpenWifi{
|
|||||||
void RESTAPI_inventory_handler::DoDelete() {
|
void RESTAPI_inventory_handler::DoDelete() {
|
||||||
ProvObjects::InventoryTag Existing;
|
ProvObjects::InventoryTag Existing;
|
||||||
std::string SerialNumber = GetBinding(RESTAPI::Protocol::SERIALNUMBER, "");
|
std::string SerialNumber = GetBinding(RESTAPI::Protocol::SERIALNUMBER, "");
|
||||||
if(SerialNumber.empty() || !DB_.GetRecord(RESTAPI::Protocol::SERIALNUMBER,SerialNumber,Existing)) {
|
if (SerialNumber.empty() ||
|
||||||
|
!DB_.GetRecord(RESTAPI::Protocol::SERIALNUMBER, SerialNumber, Existing)) {
|
||||||
return NotFound();
|
return NotFound();
|
||||||
}
|
}
|
||||||
|
|
||||||
MoveUsage(StorageService()->PolicyDB(),DB_,Existing.managementPolicy,"",Existing.info.id);
|
MoveUsage(StorageService()->PolicyDB(), DB_, Existing.managementPolicy, "",
|
||||||
RemoveMembership(StorageService()->VenueDB(),&ProvObjects::Venue::configurations,Existing.venue,Existing.info.id);
|
Existing.info.id);
|
||||||
RemoveMembership(StorageService()->EntityDB(),&ProvObjects::Entity::configurations,Existing.entity,Existing.info.id);
|
RemoveMembership(StorageService()->VenueDB(), &ProvObjects::Venue::configurations,
|
||||||
|
Existing.venue, Existing.info.id);
|
||||||
|
RemoveMembership(StorageService()->EntityDB(), &ProvObjects::Entity::configurations,
|
||||||
|
Existing.entity, Existing.info.id);
|
||||||
MoveUsage(StorageService()->LocationDB(), DB_, Existing.location, "", Existing.info.id);
|
MoveUsage(StorageService()->LocationDB(), DB_, Existing.location, "", Existing.info.id);
|
||||||
MoveUsage(StorageService()->ContactDB(), DB_, Existing.contact, "", Existing.info.id);
|
MoveUsage(StorageService()->ContactDB(), DB_, Existing.contact, "", Existing.info.id);
|
||||||
|
|
||||||
if (!Existing.deviceConfiguration.empty()) {
|
if (!Existing.deviceConfiguration.empty()) {
|
||||||
ProvObjects::DeviceConfiguration DC;
|
ProvObjects::DeviceConfiguration DC;
|
||||||
if(StorageService()->ConfigurationDB().GetRecord("id", Existing.deviceConfiguration, DC)) {
|
if (StorageService()->ConfigurationDB().GetRecord("id", Existing.deviceConfiguration,
|
||||||
|
DC)) {
|
||||||
if (DC.subscriberOnly)
|
if (DC.subscriberOnly)
|
||||||
StorageService()->ConfigurationDB().DeleteRecord("id", Existing.deviceConfiguration);
|
StorageService()->ConfigurationDB().DeleteRecord("id",
|
||||||
|
Existing.deviceConfiguration);
|
||||||
else
|
else
|
||||||
StorageService()->ConfigurationDB().DeleteInUse("id", Existing.deviceConfiguration, DB_.Prefix(),
|
StorageService()->ConfigurationDB().DeleteInUse(
|
||||||
Existing.info.id);
|
"id", Existing.deviceConfiguration, DB_.Prefix(), Existing.info.id);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
MoveUsage(StorageService()->PolicyDB(),DB_,Existing.managementPolicy,"",Existing.info.id);
|
MoveUsage(StorageService()->PolicyDB(), DB_, Existing.managementPolicy, "",
|
||||||
|
Existing.info.id);
|
||||||
MoveUsage(StorageService()->LocationDB(), DB_, Existing.location, "", Existing.info.id);
|
MoveUsage(StorageService()->LocationDB(), DB_, Existing.location, "", Existing.info.id);
|
||||||
MoveUsage(StorageService()->ContactDB(), DB_, Existing.contact, "", Existing.info.id);
|
MoveUsage(StorageService()->ContactDB(), DB_, Existing.contact, "", Existing.info.id);
|
||||||
MoveUsage(StorageService()->ConfigurationDB(),DB_,Existing.deviceConfiguration,"",Existing.info.id);
|
MoveUsage(StorageService()->ConfigurationDB(), DB_, Existing.deviceConfiguration, "",
|
||||||
ManageMembership(StorageService()->EntityDB(),&ProvObjects::Entity::devices,Existing.entity,"",Existing.info.id);
|
Existing.info.id);
|
||||||
ManageMembership(StorageService()->VenueDB(),&ProvObjects::Venue::devices,Existing.venue,"",Existing.info.id);
|
ManageMembership(StorageService()->EntityDB(), &ProvObjects::Entity::devices,
|
||||||
|
Existing.entity, "", Existing.info.id);
|
||||||
|
ManageMembership(StorageService()->VenueDB(), &ProvObjects::Venue::devices, Existing.venue,
|
||||||
|
"", Existing.info.id);
|
||||||
DB_.DeleteRecord("id", Existing.info.id);
|
DB_.DeleteRecord("id", Existing.info.id);
|
||||||
SerialNumberCache()->DeleteSerialNumber(SerialNumber);
|
SerialNumberCache()->DeleteSerialNumber(SerialNumber);
|
||||||
return OK();
|
return OK();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void RESTAPI_inventory_handler::DoPost() {
|
void RESTAPI_inventory_handler::DoPost() {
|
||||||
std::string SerialNumber = GetBinding(RESTAPI::Protocol::SERIALNUMBER, "");
|
std::string SerialNumber = GetBinding(RESTAPI::Protocol::SERIALNUMBER, "");
|
||||||
|
Poco::toLowerInPlace(SerialNumber);
|
||||||
if (SerialNumber.empty()) {
|
if (SerialNumber.empty()) {
|
||||||
return BadRequest(RESTAPI::Errors::MissingSerialNumber);
|
return BadRequest(RESTAPI::Errors::MissingSerialNumber);
|
||||||
}
|
}
|
||||||
@@ -154,6 +209,11 @@ namespace OpenWifi{
|
|||||||
return BadRequest(RESTAPI::Errors::InvalidJSONDocument);
|
return BadRequest(RESTAPI::Errors::InvalidJSONDocument);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
NormalizeMac(NewObject.serialNumber);
|
||||||
|
if (SerialNumber != NewObject.serialNumber) {
|
||||||
|
return BadRequest(RESTAPI::Errors::SerialNumberMismatch);
|
||||||
|
}
|
||||||
|
|
||||||
if ((RawObject->has("deviceRules") && !ValidDeviceRules(NewObject.deviceRules, *this))) {
|
if ((RawObject->has("deviceRules") && !ValidDeviceRules(NewObject.deviceRules, *this))) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@@ -170,15 +230,19 @@ namespace OpenWifi{
|
|||||||
return BadRequest(RESTAPI::Errors::NameMustBeSet);
|
return BadRequest(RESTAPI::Errors::NameMustBeSet);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(NewObject.deviceType.empty() || !DeviceTypeCache()->IsAcceptableDeviceType(NewObject.deviceType)) {
|
if (NewObject.deviceType.empty() ||
|
||||||
|
!DeviceTypeCache()->IsAcceptableDeviceType(NewObject.deviceType)) {
|
||||||
return BadRequest(RESTAPI::Errors::InvalidDeviceTypes);
|
return BadRequest(RESTAPI::Errors::InvalidDeviceTypes);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(OpenWifi::EntityDB::IsRoot(NewObject.entity) || (!NewObject.entity.empty() && !StorageService()->EntityDB().Exists("id",NewObject.entity))) {
|
if (OpenWifi::EntityDB::IsRoot(NewObject.entity) ||
|
||||||
|
(!NewObject.entity.empty() &&
|
||||||
|
!StorageService()->EntityDB().Exists("id", NewObject.entity))) {
|
||||||
return BadRequest(RESTAPI::Errors::ValidNonRootUUID);
|
return BadRequest(RESTAPI::Errors::ValidNonRootUUID);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!NewObject.venue.empty() && !StorageService()->VenueDB().Exists("id",NewObject.venue)) {
|
if (!NewObject.venue.empty() &&
|
||||||
|
!StorageService()->VenueDB().Exists("id", NewObject.venue)) {
|
||||||
return BadRequest(RESTAPI::Errors::VenueMustExist);
|
return BadRequest(RESTAPI::Errors::VenueMustExist);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -186,37 +250,47 @@ namespace OpenWifi{
|
|||||||
return BadRequest(RESTAPI::Errors::NotBoth);
|
return BadRequest(RESTAPI::Errors::NotBoth);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!NewObject.location.empty() && !StorageService()->LocationDB().Exists("id",NewObject.location)) {
|
if (!NewObject.location.empty() &&
|
||||||
|
!StorageService()->LocationDB().Exists("id", NewObject.location)) {
|
||||||
return BadRequest(RESTAPI::Errors::LocationMustExist);
|
return BadRequest(RESTAPI::Errors::LocationMustExist);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!NewObject.contact.empty() && !StorageService()->ContactDB().Exists("id",NewObject.contact)) {
|
if (!NewObject.contact.empty() &&
|
||||||
|
!StorageService()->ContactDB().Exists("id", NewObject.contact)) {
|
||||||
return BadRequest(RESTAPI::Errors::ContactMustExist);
|
return BadRequest(RESTAPI::Errors::ContactMustExist);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!NewObject.deviceConfiguration.empty() && !StorageService()->ConfigurationDB().Exists("id",NewObject.deviceConfiguration)) {
|
if (!NewObject.deviceConfiguration.empty() &&
|
||||||
|
!StorageService()->ConfigurationDB().Exists("id", NewObject.deviceConfiguration)) {
|
||||||
return BadRequest(RESTAPI::Errors::ConfigurationMustExist);
|
return BadRequest(RESTAPI::Errors::ConfigurationMustExist);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!NewObject.managementPolicy.empty() && !StorageService()->PolicyDB().Exists("id",NewObject.managementPolicy)) {
|
if (!NewObject.managementPolicy.empty() &&
|
||||||
|
!StorageService()->PolicyDB().Exists("id", NewObject.managementPolicy)) {
|
||||||
return BadRequest(RESTAPI::Errors::UnknownManagementPolicyUUID);
|
return BadRequest(RESTAPI::Errors::UnknownManagementPolicyUUID);
|
||||||
}
|
}
|
||||||
|
|
||||||
RESTAPI::Errors::msg Error=RESTAPI::Errors::SUCCESS;
|
std::vector<std::string> Errors;
|
||||||
auto ObjectsCreated = CreateObjects(NewObject,*this,Error);
|
auto ObjectsCreated = CreateObjects(NewObject, *this, Errors);
|
||||||
if(Error.err_num != 0) {
|
if (!Errors.empty()) {
|
||||||
return BadRequest(Error);
|
return BadRequest(RESTAPI::Errors::ConfigBlockInvalid);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (DB_.CreateRecord(NewObject)) {
|
if (DB_.CreateRecord(NewObject)) {
|
||||||
SDK::GW::Device::SetOwnerShip(this, SerialNumber, NewObject.entity, NewObject.venue, NewObject.subscriber);
|
SDK::GW::Device::SetOwnerShip(this, SerialNumber, NewObject.entity, NewObject.venue,
|
||||||
|
NewObject.subscriber);
|
||||||
SerialNumberCache()->AddSerialNumber(SerialNumber, NewObject.deviceType);
|
SerialNumberCache()->AddSerialNumber(SerialNumber, NewObject.deviceType);
|
||||||
MoveUsage(StorageService()->PolicyDB(),DB_,"",NewObject.managementPolicy,NewObject.info.id);
|
MoveUsage(StorageService()->PolicyDB(), DB_, "", NewObject.managementPolicy,
|
||||||
MoveUsage(StorageService()->LocationDB(),DB_,"",NewObject.location,NewObject.info.id);
|
NewObject.info.id);
|
||||||
|
MoveUsage(StorageService()->LocationDB(), DB_, "", NewObject.location,
|
||||||
|
NewObject.info.id);
|
||||||
MoveUsage(StorageService()->ContactDB(), DB_, "", NewObject.contact, NewObject.info.id);
|
MoveUsage(StorageService()->ContactDB(), DB_, "", NewObject.contact, NewObject.info.id);
|
||||||
MoveUsage(StorageService()->ConfigurationDB(),DB_,"",NewObject.deviceConfiguration,NewObject.info.id);
|
MoveUsage(StorageService()->ConfigurationDB(), DB_, "", NewObject.deviceConfiguration,
|
||||||
ManageMembership(StorageService()->EntityDB(),&ProvObjects::Entity::devices,"",NewObject.entity,NewObject.info.id);
|
NewObject.info.id);
|
||||||
ManageMembership(StorageService()->VenueDB(),&ProvObjects::Venue::devices,"",NewObject.venue,NewObject.info.id);
|
ManageMembership(StorageService()->EntityDB(), &ProvObjects::Entity::devices, "",
|
||||||
|
NewObject.entity, NewObject.info.id);
|
||||||
|
ManageMembership(StorageService()->VenueDB(), &ProvObjects::Venue::devices, "",
|
||||||
|
NewObject.venue, NewObject.info.id);
|
||||||
|
|
||||||
ProvObjects::InventoryTag NewTag;
|
ProvObjects::InventoryTag NewTag;
|
||||||
DB_.GetRecord("id", NewObject.info.id, NewTag);
|
DB_.GetRecord("id", NewObject.info.id, NewTag);
|
||||||
@@ -235,43 +309,50 @@ namespace OpenWifi{
|
|||||||
}
|
}
|
||||||
|
|
||||||
ProvObjects::InventoryTag Existing;
|
ProvObjects::InventoryTag Existing;
|
||||||
if(SerialNumber.empty() || !DB_.GetRecord(RESTAPI::Protocol::SERIALNUMBER,SerialNumber,Existing)) {
|
if (SerialNumber.empty() ||
|
||||||
|
!DB_.GetRecord(RESTAPI::Protocol::SERIALNUMBER, SerialNumber, Existing)) {
|
||||||
return NotFound();
|
return NotFound();
|
||||||
}
|
}
|
||||||
|
|
||||||
auto RemoveSubscriber = GetParameter("removeSubscriber");
|
auto RemoveSubscriber = GetParameter("removeSubscriber");
|
||||||
if (!RemoveSubscriber.empty()) {
|
if (!RemoveSubscriber.empty()) {
|
||||||
if (Existing.subscriber == RemoveSubscriber) {
|
if (Existing.subscriber == RemoveSubscriber) {
|
||||||
Logger().information(Poco::format("%s: removing subscriber (%s)", SerialNumber, RemoveSubscriber));
|
poco_information(Logger(), fmt::format("{}: removing subscriber ({})", SerialNumber,
|
||||||
|
RemoveSubscriber));
|
||||||
ProvObjects::DeviceConfiguration DC;
|
ProvObjects::DeviceConfiguration DC;
|
||||||
if(StorageService()->ConfigurationDB().GetRecord("id",Existing.deviceConfiguration,DC)) {
|
if (StorageService()->ConfigurationDB().GetRecord(
|
||||||
Logger().information(Poco::format("%s: removing configuration for subscriber (%s)", SerialNumber, RemoveSubscriber));
|
"id", Existing.deviceConfiguration, DC)) {
|
||||||
|
poco_information(Logger(),
|
||||||
|
fmt::format("{}: removing configuration for subscriber ({})",
|
||||||
|
SerialNumber, RemoveSubscriber));
|
||||||
if (DC.subscriberOnly) {
|
if (DC.subscriberOnly) {
|
||||||
if(!StorageService()->ConfigurationDB().DeleteRecord("id", Existing.deviceConfiguration)) {
|
if (!StorageService()->ConfigurationDB().DeleteRecord(
|
||||||
Logger().debug("Could not delete the subscriber configuration");
|
"id", Existing.deviceConfiguration)) {
|
||||||
|
poco_debug(Logger(), "Could not delete the subscriber configuration");
|
||||||
}
|
}
|
||||||
}
|
} else {
|
||||||
else {
|
poco_debug(Logger(), "Configurations is not for a subscriber.");
|
||||||
Logger().debug("Configurations is not for a subscriber.");
|
|
||||||
}
|
}
|
||||||
Existing.deviceConfiguration = "";
|
Existing.deviceConfiguration = "";
|
||||||
}
|
}
|
||||||
Existing.subscriber = "";
|
Existing.subscriber = "";
|
||||||
Poco::JSON::Object state;
|
Poco::JSON::Object state;
|
||||||
state.set("date",OpenWifi::Now());
|
state.set("date", Utils::Now());
|
||||||
state.set("method", "auto-discovery");
|
state.set("method", "auto-discovery");
|
||||||
state.set("last-operation", "returned to inventory");
|
state.set("last-operation", "returned to inventory");
|
||||||
std::ostringstream OO;
|
std::ostringstream OO;
|
||||||
state.stringify(OO);
|
state.stringify(OO);
|
||||||
Existing.state = OO.str();
|
Existing.state = OO.str();
|
||||||
StorageService()->InventoryDB().UpdateRecord("id", Existing.info.id, Existing);
|
StorageService()->InventoryDB().UpdateRecord("id", Existing.info.id, Existing);
|
||||||
RemoveMembership(StorageService()->EntityDB(),&ProvObjects::Entity::devices,"id",Existing.info.id);
|
RemoveMembership(StorageService()->EntityDB(), &ProvObjects::Entity::devices, "id",
|
||||||
|
Existing.info.id);
|
||||||
Poco::JSON::Object Answer;
|
Poco::JSON::Object Answer;
|
||||||
Existing.to_json(Answer);
|
Existing.to_json(Answer);
|
||||||
SDK::GW::Device::SetSubscriber(nullptr, SerialNumber, "");
|
SDK::GW::Device::SetSubscriber(nullptr, SerialNumber, "");
|
||||||
return ReturnObject(Answer);
|
return ReturnObject(Answer);
|
||||||
} else {
|
} else {
|
||||||
Logger().information(Poco::format("%s: wrong subscriber (%s)", SerialNumber, RemoveSubscriber));
|
poco_information(Logger(), fmt::format("{}: wrong subscriber ({})", SerialNumber,
|
||||||
|
RemoveSubscriber));
|
||||||
}
|
}
|
||||||
return BadRequest(RESTAPI::Errors::MissingOrInvalidParameters);
|
return BadRequest(RESTAPI::Errors::MissingOrInvalidParameters);
|
||||||
}
|
}
|
||||||
@@ -304,33 +385,34 @@ namespace OpenWifi{
|
|||||||
Existing.deviceRules = NewObject.deviceRules;
|
Existing.deviceRules = NewObject.deviceRules;
|
||||||
|
|
||||||
std::string FromPolicy, ToPolicy;
|
std::string FromPolicy, ToPolicy;
|
||||||
if(!CreateMove(RawObject,"managementPolicy",&InventoryDB::RecordName::managementPolicy, Existing, FromPolicy,
|
if (!CreateMove(RawObject, "managementPolicy", &InventoryDB::RecordName::managementPolicy,
|
||||||
ToPolicy, StorageService()->PolicyDB()))
|
Existing, FromPolicy, ToPolicy, StorageService()->PolicyDB()))
|
||||||
return BadRequest(RESTAPI::Errors::EntityMustExist);
|
return BadRequest(RESTAPI::Errors::EntityMustExist);
|
||||||
|
|
||||||
std::string FromEntity, ToEntity;
|
std::string FromEntity, ToEntity;
|
||||||
if(!CreateMove(RawObject,"entity",&InventoryDB::RecordName::entity, Existing, FromEntity, ToEntity,
|
if (!CreateMove(RawObject, "entity", &InventoryDB::RecordName::entity, Existing, FromEntity,
|
||||||
StorageService()->EntityDB()))
|
ToEntity, StorageService()->EntityDB()))
|
||||||
return BadRequest(RESTAPI::Errors::EntityMustExist);
|
return BadRequest(RESTAPI::Errors::EntityMustExist);
|
||||||
|
|
||||||
std::string FromVenue, ToVenue;
|
std::string FromVenue, ToVenue;
|
||||||
if(!CreateMove(RawObject,"venue",&InventoryDB::RecordName::venue, Existing, FromVenue, ToVenue,
|
if (!CreateMove(RawObject, "venue", &InventoryDB::RecordName::venue, Existing, FromVenue,
|
||||||
StorageService()->VenueDB()))
|
ToVenue, StorageService()->VenueDB()))
|
||||||
return BadRequest(RESTAPI::Errors::VenueMustExist);
|
return BadRequest(RESTAPI::Errors::VenueMustExist);
|
||||||
|
|
||||||
std::string FromLocation, ToLocation;
|
std::string FromLocation, ToLocation;
|
||||||
if(!CreateMove(RawObject,"location",&InventoryDB::RecordName::location, Existing, FromLocation, ToLocation,
|
if (!CreateMove(RawObject, "location", &InventoryDB::RecordName::location, Existing,
|
||||||
StorageService()->LocationDB()))
|
FromLocation, ToLocation, StorageService()->LocationDB()))
|
||||||
return BadRequest(RESTAPI::Errors::VenueMustExist);
|
return BadRequest(RESTAPI::Errors::VenueMustExist);
|
||||||
|
|
||||||
std::string FromContact, ToContact;
|
std::string FromContact, ToContact;
|
||||||
if(!CreateMove(RawObject,"contact",&InventoryDB::RecordName::contact, Existing, FromContact, ToContact,
|
if (!CreateMove(RawObject, "contact", &InventoryDB::RecordName::contact, Existing,
|
||||||
StorageService()->ContactDB()))
|
FromContact, ToContact, StorageService()->ContactDB()))
|
||||||
return BadRequest(RESTAPI::Errors::VenueMustExist);
|
return BadRequest(RESTAPI::Errors::VenueMustExist);
|
||||||
|
|
||||||
std::string FromConfiguration, ToConfiguration;
|
std::string FromConfiguration, ToConfiguration;
|
||||||
if(!CreateMove(RawObject,"deviceConfiguration",&InventoryDB::RecordName::deviceConfiguration, Existing,
|
if (!CreateMove(RawObject, "deviceConfiguration",
|
||||||
FromConfiguration, ToConfiguration, StorageService()->ConfigurationDB()))
|
&InventoryDB::RecordName::deviceConfiguration, Existing, FromConfiguration,
|
||||||
|
ToConfiguration, StorageService()->ConfigurationDB()))
|
||||||
return BadRequest(RESTAPI::Errors::ConfigurationMustExist);
|
return BadRequest(RESTAPI::Errors::ConfigurationMustExist);
|
||||||
|
|
||||||
std::string NewSubScriber;
|
std::string NewSubScriber;
|
||||||
@@ -349,6 +431,8 @@ namespace OpenWifi{
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
AssignIfPresent(RawObject, "doNotAllowOverrides", Existing.doNotAllowOverrides);
|
||||||
|
|
||||||
if (RawObject->has("devClass") && NewObject.devClass != Existing.devClass) {
|
if (RawObject->has("devClass") && NewObject.devClass != Existing.devClass) {
|
||||||
Existing.devClass = NewObject.devClass;
|
Existing.devClass = NewObject.devClass;
|
||||||
}
|
}
|
||||||
@@ -357,10 +441,10 @@ namespace OpenWifi{
|
|||||||
Existing.state = NewObject.state;
|
Existing.state = NewObject.state;
|
||||||
}
|
}
|
||||||
|
|
||||||
RESTAPI::Errors::msg Error=RESTAPI::Errors::SUCCESS;
|
std::vector<std::string> Errors;
|
||||||
auto ObjectsCreated = CreateObjects(NewObject,*this,Error);
|
auto ObjectsCreated = CreateObjects(NewObject, *this, Errors);
|
||||||
if(Error.err_num != 0) {
|
if (!Errors.empty()) {
|
||||||
return BadRequest(Error);
|
return BadRequest(RESTAPI::Errors::ConfigBlockInvalid);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!ObjectsCreated.empty()) {
|
if (!ObjectsCreated.empty()) {
|
||||||
@@ -374,13 +458,18 @@ namespace OpenWifi{
|
|||||||
|
|
||||||
if (StorageService()->InventoryDB().UpdateRecord("id", Existing.info.id, Existing)) {
|
if (StorageService()->InventoryDB().UpdateRecord("id", Existing.info.id, Existing)) {
|
||||||
MoveUsage(StorageService()->PolicyDB(), DB_, FromPolicy, ToPolicy, Existing.info.id);
|
MoveUsage(StorageService()->PolicyDB(), DB_, FromPolicy, ToPolicy, Existing.info.id);
|
||||||
MoveUsage(StorageService()->LocationDB(),DB_,FromLocation,ToLocation,Existing.info.id);
|
MoveUsage(StorageService()->LocationDB(), DB_, FromLocation, ToLocation,
|
||||||
|
Existing.info.id);
|
||||||
MoveUsage(StorageService()->ContactDB(), DB_, FromContact, ToContact, Existing.info.id);
|
MoveUsage(StorageService()->ContactDB(), DB_, FromContact, ToContact, Existing.info.id);
|
||||||
MoveUsage(StorageService()->ConfigurationDB(),DB_,FromConfiguration,ToConfiguration,Existing.info.id);
|
MoveUsage(StorageService()->ConfigurationDB(), DB_, FromConfiguration, ToConfiguration,
|
||||||
ManageMembership(StorageService()->EntityDB(),&ProvObjects::Entity::devices,FromEntity,ToEntity,Existing.info.id);
|
Existing.info.id);
|
||||||
ManageMembership(StorageService()->VenueDB(),&ProvObjects::Venue::devices,FromVenue,ToVenue,Existing.info.id);
|
ManageMembership(StorageService()->EntityDB(), &ProvObjects::Entity::devices,
|
||||||
|
FromEntity, ToEntity, Existing.info.id);
|
||||||
|
ManageMembership(StorageService()->VenueDB(), &ProvObjects::Venue::devices, FromVenue,
|
||||||
|
ToVenue, Existing.info.id);
|
||||||
|
|
||||||
SDK::GW::Device::SetOwnerShip(this, SerialNumber, Existing.entity, Existing.venue, Existing.subscriber);
|
SDK::GW::Device::SetOwnerShip(this, SerialNumber, Existing.entity, Existing.venue,
|
||||||
|
Existing.subscriber);
|
||||||
|
|
||||||
ProvObjects::InventoryTag NewObjectCreated;
|
ProvObjects::InventoryTag NewObjectCreated;
|
||||||
DB_.GetRecord("id", Existing.info.id, NewObjectCreated);
|
DB_.GetRecord("id", Existing.info.id, NewObjectCreated);
|
||||||
@@ -390,4 +479,4 @@ namespace OpenWifi{
|
|||||||
}
|
}
|
||||||
InternalError(RESTAPI::Errors::RecordNotUpdated);
|
InternalError(RESTAPI::Errors::RecordNotUpdated);
|
||||||
}
|
}
|
||||||
}
|
} // namespace OpenWifi
|
||||||
@@ -7,23 +7,25 @@
|
|||||||
//
|
//
|
||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include "framework/MicroService.h"
|
|
||||||
#include "StorageService.h"
|
#include "StorageService.h"
|
||||||
|
#include "framework/RESTAPI_Handler.h"
|
||||||
|
|
||||||
namespace OpenWifi {
|
namespace OpenWifi {
|
||||||
class RESTAPI_inventory_handler : public RESTAPIHandler {
|
class RESTAPI_inventory_handler : public RESTAPIHandler {
|
||||||
public:
|
public:
|
||||||
RESTAPI_inventory_handler(const RESTAPIHandler::BindingMap &bindings, Poco::Logger &L, RESTAPI_GenericServer & Server, uint64_t TransactionId, bool Internal)
|
RESTAPI_inventory_handler(const RESTAPIHandler::BindingMap &bindings, Poco::Logger &L,
|
||||||
|
RESTAPI_GenericServerAccounting &Server, uint64_t TransactionId,
|
||||||
|
bool Internal)
|
||||||
: RESTAPIHandler(bindings, L,
|
: RESTAPIHandler(bindings, L,
|
||||||
std::vector<std::string>{
|
std::vector<std::string>{Poco::Net::HTTPRequest::HTTP_GET,
|
||||||
Poco::Net::HTTPRequest::HTTP_GET, Poco::Net::HTTPRequest::HTTP_POST,
|
Poco::Net::HTTPRequest::HTTP_POST,
|
||||||
Poco::Net::HTTPRequest::HTTP_PUT, Poco::Net::HTTPRequest::HTTP_DELETE,
|
Poco::Net::HTTPRequest::HTTP_PUT,
|
||||||
|
Poco::Net::HTTPRequest::HTTP_DELETE,
|
||||||
Poco::Net::HTTPRequest::HTTP_OPTIONS},
|
Poco::Net::HTTPRequest::HTTP_OPTIONS},
|
||||||
Server,
|
Server, TransactionId, Internal) {}
|
||||||
TransactionId,
|
static auto PathName() {
|
||||||
Internal){}
|
return std::list<std::string>{"/api/v1/inventory/{serialNumber}"};
|
||||||
static auto PathName() { return std::list<std::string>{"/api/v1/inventory/{serialNumber}"}; };
|
};
|
||||||
|
|
||||||
private:
|
private:
|
||||||
InventoryDB &DB_ = StorageService()->InventoryDB();
|
InventoryDB &DB_ = StorageService()->InventoryDB();
|
||||||
@@ -34,4 +36,4 @@ namespace OpenWifi {
|
|||||||
void PerformClaim(const std::string &SerialNumber, const std::string &Claimer,
|
void PerformClaim(const std::string &SerialNumber, const std::string &Claimer,
|
||||||
std::string &ClaimId, uint64_t &ErrorCode, Poco::JSON::Object &Answer);
|
std::string &ClaimId, uint64_t &ErrorCode, Poco::JSON::Object &Answer);
|
||||||
};
|
};
|
||||||
}
|
} // namespace OpenWifi
|
||||||
|
|||||||
@@ -6,13 +6,13 @@
|
|||||||
// Arilia Wireless Inc.
|
// Arilia Wireless Inc.
|
||||||
//
|
//
|
||||||
|
|
||||||
|
|
||||||
#include "RESTAPI_inventory_list_handler.h"
|
#include "RESTAPI_inventory_list_handler.h"
|
||||||
#include "StorageService.h"
|
|
||||||
#include "RESTAPI/RESTAPI_db_helpers.h"
|
#include "RESTAPI/RESTAPI_db_helpers.h"
|
||||||
|
#include "StorageService.h"
|
||||||
|
|
||||||
namespace OpenWifi {
|
namespace OpenWifi {
|
||||||
void RESTAPI_inventory_list_handler::SendList( const ProvObjects::InventoryTagVec & Tags, bool SerialOnly) {
|
void RESTAPI_inventory_list_handler::SendList(const ProvObjects::InventoryTagVec &Tags,
|
||||||
|
bool SerialOnly) {
|
||||||
Poco::JSON::Array Array;
|
Poco::JSON::Array Array;
|
||||||
for (const auto &i : Tags) {
|
for (const auto &i : Tags) {
|
||||||
if (SerialOnly) {
|
if (SerialOnly) {
|
||||||
@@ -75,7 +75,8 @@ namespace OpenWifi{
|
|||||||
return ReturnCountOnly(C);
|
return ReturnCountOnly(C);
|
||||||
}
|
}
|
||||||
ProvObjects::InventoryTagVec Tags;
|
ProvObjects::InventoryTagVec Tags;
|
||||||
DB_.GetRecords(QB_.Offset, QB_.Limit, Tags, " devClass='subscriber' and subscriber='' ", OrderBy);
|
DB_.GetRecords(QB_.Offset, QB_.Limit, Tags, " devClass='subscriber' and subscriber='' ",
|
||||||
|
OrderBy);
|
||||||
if (QB_.CountOnly) {
|
if (QB_.CountOnly) {
|
||||||
auto C = DB_.Count(DB_.OP("venue", ORM::EQ, UUID));
|
auto C = DB_.Count(DB_.OP("venue", ORM::EQ, UUID));
|
||||||
return ReturnCountOnly(C);
|
return ReturnCountOnly(C);
|
||||||
@@ -87,27 +88,31 @@ namespace OpenWifi{
|
|||||||
return ReturnCountOnly(C);
|
return ReturnCountOnly(C);
|
||||||
}
|
}
|
||||||
ProvObjects::InventoryTagVec Tags;
|
ProvObjects::InventoryTagVec Tags;
|
||||||
DB_.GetRecords(QB_.Offset, QB_.Limit, Tags," devClass='subscriber' and subscriber!='' ", OrderBy);
|
DB_.GetRecords(QB_.Offset, QB_.Limit, Tags,
|
||||||
|
" devClass='subscriber' and subscriber!='' ", OrderBy);
|
||||||
return SendList(Tags, SerialOnly);
|
return SendList(Tags, SerialOnly);
|
||||||
} else if (GetBoolParameter("unassigned")) {
|
} else if (GetBoolParameter("unassigned")) {
|
||||||
if (QB_.CountOnly) {
|
if (QB_.CountOnly) {
|
||||||
std::string Empty;
|
std::string Empty;
|
||||||
auto C = DB_.Count( InventoryDB::OP( DB_.OP("venue",ORM::EQ,Empty),
|
auto C = DB_.Count(InventoryDB::OP(DB_.OP("venue", ORM::EQ, Empty), ORM::AND,
|
||||||
ORM::AND, DB_.OP("entity",ORM::EQ,Empty) ));
|
DB_.OP("entity", ORM::EQ, Empty)));
|
||||||
return ReturnCountOnly(C);
|
return ReturnCountOnly(C);
|
||||||
}
|
}
|
||||||
ProvObjects::InventoryTagVec Tags;
|
ProvObjects::InventoryTagVec Tags;
|
||||||
std::string Empty;
|
std::string Empty;
|
||||||
DB_.GetRecords(QB_.Offset, QB_.Limit, Tags, InventoryDB::OP( DB_.OP("venue",ORM::EQ,Empty),
|
DB_.GetRecords(QB_.Offset, QB_.Limit, Tags,
|
||||||
ORM::AND, DB_.OP("entity",ORM::EQ,Empty) ) , OrderBy );
|
InventoryDB::OP(DB_.OP("venue", ORM::EQ, Empty), ORM::AND,
|
||||||
|
DB_.OP("entity", ORM::EQ, Empty)),
|
||||||
|
OrderBy);
|
||||||
return SendList(Tags, SerialOnly);
|
return SendList(Tags, SerialOnly);
|
||||||
} else if (HasParameter("subscriber", Arg) && !Arg.empty()) {
|
} else if (HasParameter("subscriber", Arg) && !Arg.empty()) {
|
||||||
// looking for device(s) for a specific subscriber...
|
// looking for device(s) for a specific subscriber...
|
||||||
ProvObjects::InventoryTagVec Tags;
|
ProvObjects::InventoryTagVec Tags;
|
||||||
DB_.GetRecords(0,100,Tags," subscriber='" + Arg + "'");
|
DB_.GetRecords(0, 100, Tags, " subscriber='" + ORM::Escape(Arg) + "'");
|
||||||
if (SerialOnly) {
|
if (SerialOnly) {
|
||||||
std::vector<std::string> SerialNumbers;
|
std::vector<std::string> SerialNumbers;
|
||||||
std::transform(cbegin(Tags), cend(Tags), std::back_inserter(SerialNumbers), [](const auto &T) { return T.serialNumber; });
|
std::transform(cbegin(Tags), cend(Tags), std::back_inserter(SerialNumbers),
|
||||||
|
[](const auto &T) { return T.serialNumber; });
|
||||||
return ReturnObject("serialNumbers", SerialNumbers);
|
return ReturnObject("serialNumbers", SerialNumbers);
|
||||||
} else {
|
} else {
|
||||||
return MakeJSONObjectArray("taglist", Tags, *this);
|
return MakeJSONObjectArray("taglist", Tags, *this);
|
||||||
@@ -129,4 +134,4 @@ namespace OpenWifi{
|
|||||||
return MakeJSONObjectArray("taglist", Tags, *this);
|
return MakeJSONObjectArray("taglist", Tags, *this);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
} // namespace OpenWifi
|
||||||
@@ -7,23 +7,22 @@
|
|||||||
//
|
//
|
||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include "StorageService.h"
|
#include "StorageService.h"
|
||||||
#include "framework/MicroService.h"
|
#include "framework/RESTAPI_Handler.h"
|
||||||
|
|
||||||
namespace OpenWifi {
|
namespace OpenWifi {
|
||||||
|
|
||||||
class RESTAPI_inventory_list_handler : public RESTAPIHandler {
|
class RESTAPI_inventory_list_handler : public RESTAPIHandler {
|
||||||
public:
|
public:
|
||||||
RESTAPI_inventory_list_handler(const RESTAPIHandler::BindingMap &bindings, Poco::Logger &L, RESTAPI_GenericServer & Server, uint64_t TransactionId, bool Internal)
|
RESTAPI_inventory_list_handler(const RESTAPIHandler::BindingMap &bindings, Poco::Logger &L,
|
||||||
|
RESTAPI_GenericServerAccounting &Server,
|
||||||
|
uint64_t TransactionId, bool Internal)
|
||||||
: RESTAPIHandler(bindings, L,
|
: RESTAPIHandler(bindings, L,
|
||||||
std::vector<std::string>{
|
std::vector<std::string>{Poco::Net::HTTPRequest::HTTP_GET,
|
||||||
Poco::Net::HTTPRequest::HTTP_GET,
|
|
||||||
Poco::Net::HTTPRequest::HTTP_OPTIONS},
|
Poco::Net::HTTPRequest::HTTP_OPTIONS},
|
||||||
Server,
|
Server, TransactionId, Internal) {}
|
||||||
TransactionId,
|
|
||||||
Internal){}
|
|
||||||
static auto PathName() { return std::list<std::string>{"/api/v1/inventory"}; };
|
static auto PathName() { return std::list<std::string>{"/api/v1/inventory"}; };
|
||||||
|
|
||||||
private:
|
private:
|
||||||
InventoryDB &DB_ = StorageService()->InventoryDB();
|
InventoryDB &DB_ = StorageService()->InventoryDB();
|
||||||
void DoGet() final;
|
void DoGet() final;
|
||||||
@@ -33,4 +32,4 @@ namespace OpenWifi {
|
|||||||
|
|
||||||
void SendList(const ProvObjects::InventoryTagVec &Tags, bool SerialOnly);
|
void SendList(const ProvObjects::InventoryTagVec &Tags, bool SerialOnly);
|
||||||
};
|
};
|
||||||
}
|
} // namespace OpenWifi
|
||||||
@@ -28,4 +28,4 @@ namespace OpenWifi {
|
|||||||
return ReturnObject(Answer);
|
return ReturnObject(Answer);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
} // namespace OpenWifi
|
||||||
@@ -3,23 +3,23 @@
|
|||||||
//
|
//
|
||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
#include "StorageService.h"
|
||||||
#include "framework/MicroService.h"
|
#include "framework/RESTAPI_Handler.h"
|
||||||
|
|
||||||
namespace OpenWifi {
|
namespace OpenWifi {
|
||||||
class RESTAPI_iptocountry_handler : public RESTAPIHandler {
|
class RESTAPI_iptocountry_handler : public RESTAPIHandler {
|
||||||
public:
|
public:
|
||||||
RESTAPI_iptocountry_handler(const RESTAPIHandler::BindingMap &bindings, Poco::Logger &L, RESTAPI_GenericServer & Server, uint64_t TransactionId, bool Internal)
|
RESTAPI_iptocountry_handler(const RESTAPIHandler::BindingMap &bindings, Poco::Logger &L,
|
||||||
|
RESTAPI_GenericServerAccounting &Server, uint64_t TransactionId,
|
||||||
|
bool Internal)
|
||||||
: RESTAPIHandler(bindings, L,
|
: RESTAPIHandler(bindings, L,
|
||||||
std::vector<std::string>{Poco::Net::HTTPRequest::HTTP_GET,
|
std::vector<std::string>{Poco::Net::HTTPRequest::HTTP_GET,
|
||||||
Poco::Net::HTTPRequest::HTTP_OPTIONS},
|
Poco::Net::HTTPRequest::HTTP_OPTIONS},
|
||||||
Server,
|
Server, TransactionId, Internal){};
|
||||||
TransactionId,
|
|
||||||
Internal){};
|
|
||||||
static auto PathName() { return std::list<std::string>{"/api/v1/iptocountry"}; };
|
static auto PathName() { return std::list<std::string>{"/api/v1/iptocountry"}; };
|
||||||
void DoGet() final;
|
void DoGet() final;
|
||||||
void DoDelete() final{};
|
void DoDelete() final{};
|
||||||
void DoPost() final{};
|
void DoPost() final{};
|
||||||
void DoPut() final{};
|
void DoPut() final{};
|
||||||
};
|
};
|
||||||
}
|
} // namespace OpenWifi
|
||||||
|
|||||||
@@ -6,12 +6,12 @@
|
|||||||
// Arilia Wireless Inc.
|
// Arilia Wireless Inc.
|
||||||
//
|
//
|
||||||
|
|
||||||
|
|
||||||
#include "RESTAPI_location_handler.h"
|
#include "RESTAPI_location_handler.h"
|
||||||
#include "RESTObjects/RESTAPI_ProvObjects.h"
|
|
||||||
#include "StorageService.h"
|
|
||||||
#include "Daemon.h"
|
#include "Daemon.h"
|
||||||
#include "RESTAPI/RESTAPI_db_helpers.h"
|
#include "RESTAPI/RESTAPI_db_helpers.h"
|
||||||
|
#include "RESTObjects/RESTAPI_ProvObjects.h"
|
||||||
|
#include "StorageService.h"
|
||||||
|
#include "framework/utils.h"
|
||||||
|
|
||||||
namespace OpenWifi {
|
namespace OpenWifi {
|
||||||
|
|
||||||
@@ -65,7 +65,8 @@ namespace OpenWifi{
|
|||||||
}
|
}
|
||||||
|
|
||||||
DB_.DeleteRecord("id", UUID);
|
DB_.DeleteRecord("id", UUID);
|
||||||
RemoveMembership(StorageService()->EntityDB(),&ProvObjects::Entity::locations,Existing.entity,Existing.info.id);
|
RemoveMembership(StorageService()->EntityDB(), &ProvObjects::Entity::locations,
|
||||||
|
Existing.entity, Existing.info.id);
|
||||||
MoveUsage(StorageService()->PolicyDB(), DB_, Existing.info.id, "", Existing.info.id);
|
MoveUsage(StorageService()->PolicyDB(), DB_, Existing.info.id, "", Existing.info.id);
|
||||||
return OK();
|
return OK();
|
||||||
}
|
}
|
||||||
@@ -86,19 +87,23 @@ namespace OpenWifi{
|
|||||||
return BadRequest(RESTAPI::Errors::NameMustBeSet);
|
return BadRequest(RESTAPI::Errors::NameMustBeSet);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(NewObject.entity.empty() || !StorageService()->EntityDB().Exists("id",NewObject.entity)) {
|
if (NewObject.entity.empty() ||
|
||||||
|
!StorageService()->EntityDB().Exists("id", NewObject.entity)) {
|
||||||
return BadRequest(RESTAPI::Errors::EntityMustExist);
|
return BadRequest(RESTAPI::Errors::EntityMustExist);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!NewObject.managementPolicy.empty() && !StorageService()->PolicyDB().Exists("id",NewObject.managementPolicy)) {
|
if (!NewObject.managementPolicy.empty() &&
|
||||||
|
!StorageService()->PolicyDB().Exists("id", NewObject.managementPolicy)) {
|
||||||
return BadRequest(RESTAPI::Errors::UnknownManagementPolicyUUID);
|
return BadRequest(RESTAPI::Errors::UnknownManagementPolicyUUID);
|
||||||
}
|
}
|
||||||
|
|
||||||
NewObject.inUse.clear();
|
NewObject.inUse.clear();
|
||||||
|
|
||||||
if (DB_.CreateRecord(NewObject)) {
|
if (DB_.CreateRecord(NewObject)) {
|
||||||
MoveUsage(StorageService()->PolicyDB(),DB_,"",NewObject.managementPolicy,NewObject.info.id);
|
MoveUsage(StorageService()->PolicyDB(), DB_, "", NewObject.managementPolicy,
|
||||||
AddMembership(StorageService()->EntityDB(),&ProvObjects::Entity::locations,NewObject.entity,NewObject.info.id);
|
NewObject.info.id);
|
||||||
|
AddMembership(StorageService()->EntityDB(), &ProvObjects::Entity::locations,
|
||||||
|
NewObject.entity, NewObject.info.id);
|
||||||
|
|
||||||
LocationDB::RecordName AddedRecord;
|
LocationDB::RecordName AddedRecord;
|
||||||
DB_.GetRecord("id", NewObject.info.id, AddedRecord);
|
DB_.GetRecord("id", NewObject.info.id, AddedRecord);
|
||||||
@@ -128,11 +133,13 @@ namespace OpenWifi{
|
|||||||
}
|
}
|
||||||
|
|
||||||
std::string FromPolicy, ToPolicy;
|
std::string FromPolicy, ToPolicy;
|
||||||
if(!CreateMove(RawObject,"managementPolicy",&LocationDB::RecordName::managementPolicy, Existing, FromPolicy, ToPolicy, StorageService()->PolicyDB()))
|
if (!CreateMove(RawObject, "managementPolicy", &LocationDB::RecordName::managementPolicy,
|
||||||
|
Existing, FromPolicy, ToPolicy, StorageService()->PolicyDB()))
|
||||||
return BadRequest(RESTAPI::Errors::EntityMustExist);
|
return BadRequest(RESTAPI::Errors::EntityMustExist);
|
||||||
|
|
||||||
std::string FromEntity, ToEntity;
|
std::string FromEntity, ToEntity;
|
||||||
if(!CreateMove(RawObject,"entity",&LocationDB::RecordName::entity, Existing, FromEntity, ToEntity, StorageService()->EntityDB()))
|
if (!CreateMove(RawObject, "entity", &LocationDB::RecordName::entity, Existing, FromEntity,
|
||||||
|
ToEntity, StorageService()->EntityDB()))
|
||||||
return BadRequest(RESTAPI::Errors::EntityMustExist);
|
return BadRequest(RESTAPI::Errors::EntityMustExist);
|
||||||
|
|
||||||
AssignIfPresent(RawObject, "buildingName", Existing.buildingName);
|
AssignIfPresent(RawObject, "buildingName", Existing.buildingName);
|
||||||
@@ -147,13 +154,14 @@ namespace OpenWifi{
|
|||||||
Existing.phones = NewObject.phones;
|
Existing.phones = NewObject.phones;
|
||||||
if (RawObject->has("mobiles"))
|
if (RawObject->has("mobiles"))
|
||||||
Existing.mobiles = NewObject.mobiles;
|
Existing.mobiles = NewObject.mobiles;
|
||||||
Existing.info.modified = OpenWifi::Now();
|
Existing.info.modified = Utils::Now();
|
||||||
if (RawObject->has("type"))
|
if (RawObject->has("type"))
|
||||||
Existing.type = NewObject.type;
|
Existing.type = NewObject.type;
|
||||||
|
|
||||||
if (DB_.UpdateRecord("id", UUID, Existing)) {
|
if (DB_.UpdateRecord("id", UUID, Existing)) {
|
||||||
MoveUsage(StorageService()->PolicyDB(), DB_, FromPolicy, ToPolicy, Existing.info.id);
|
MoveUsage(StorageService()->PolicyDB(), DB_, FromPolicy, ToPolicy, Existing.info.id);
|
||||||
ManageMembership(StorageService()->EntityDB(),&ProvObjects::Entity::locations,FromEntity, ToEntity, Existing.info.id);
|
ManageMembership(StorageService()->EntityDB(), &ProvObjects::Entity::locations,
|
||||||
|
FromEntity, ToEntity, Existing.info.id);
|
||||||
|
|
||||||
ProvObjects::Location NewObjectAdded;
|
ProvObjects::Location NewObjectAdded;
|
||||||
DB_.GetRecord("id", UUID, NewObjectAdded);
|
DB_.GetRecord("id", UUID, NewObjectAdded);
|
||||||
@@ -163,4 +171,4 @@ namespace OpenWifi{
|
|||||||
}
|
}
|
||||||
InternalError(RESTAPI::Errors::RecordNotUpdated);
|
InternalError(RESTAPI::Errors::RecordNotUpdated);
|
||||||
}
|
}
|
||||||
}
|
} // namespace OpenWifi
|
||||||
@@ -7,22 +7,22 @@
|
|||||||
//
|
//
|
||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include "framework/MicroService.h"
|
|
||||||
#include "StorageService.h"
|
#include "StorageService.h"
|
||||||
|
#include "framework/RESTAPI_Handler.h"
|
||||||
|
|
||||||
namespace OpenWifi {
|
namespace OpenWifi {
|
||||||
class RESTAPI_location_handler : public RESTAPIHandler {
|
class RESTAPI_location_handler : public RESTAPIHandler {
|
||||||
public:
|
public:
|
||||||
RESTAPI_location_handler(const RESTAPIHandler::BindingMap &bindings, Poco::Logger &L, RESTAPI_GenericServer & Server, uint64_t TransactionId, bool Internal)
|
RESTAPI_location_handler(const RESTAPIHandler::BindingMap &bindings, Poco::Logger &L,
|
||||||
|
RESTAPI_GenericServerAccounting &Server, uint64_t TransactionId,
|
||||||
|
bool Internal)
|
||||||
: RESTAPIHandler(bindings, L,
|
: RESTAPIHandler(bindings, L,
|
||||||
std::vector<std::string>{
|
std::vector<std::string>{Poco::Net::HTTPRequest::HTTP_GET,
|
||||||
Poco::Net::HTTPRequest::HTTP_GET, Poco::Net::HTTPRequest::HTTP_POST,
|
Poco::Net::HTTPRequest::HTTP_POST,
|
||||||
Poco::Net::HTTPRequest::HTTP_PUT, Poco::Net::HTTPRequest::HTTP_DELETE,
|
Poco::Net::HTTPRequest::HTTP_PUT,
|
||||||
|
Poco::Net::HTTPRequest::HTTP_DELETE,
|
||||||
Poco::Net::HTTPRequest::HTTP_OPTIONS},
|
Poco::Net::HTTPRequest::HTTP_OPTIONS},
|
||||||
Server,
|
Server, TransactionId, Internal) {}
|
||||||
TransactionId,
|
|
||||||
Internal){}
|
|
||||||
static auto PathName() { return std::list<std::string>{"/api/v1/location/{uuid}"}; };
|
static auto PathName() { return std::list<std::string>{"/api/v1/location/{uuid}"}; };
|
||||||
|
|
||||||
private:
|
private:
|
||||||
@@ -32,4 +32,4 @@ namespace OpenWifi {
|
|||||||
void DoPut() final;
|
void DoPut() final;
|
||||||
void DoDelete() final;
|
void DoDelete() final;
|
||||||
};
|
};
|
||||||
}
|
} // namespace OpenWifi
|
||||||
|
|||||||