mirror of
				https://github.com/Telecominfraproject/wlan-cloud-owprov.git
				synced 2025-10-30 10:12:29 +00:00 
			
		
		
		
	Compare commits
	
		
			158 Commits
		
	
	
		
			release/v2
			...
			v2.8.0
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 81adf1a868 | ||
|   | 1a6466454f | ||
|   | 8ca06835af | ||
|   | 6b4d9e1720 | ||
|   | d86d15ffe1 | ||
|   | 8e96afaf27 | ||
|   | 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 | 
							
								
								
									
										8
									
								
								.github/workflows/ci.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										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 | ||||||
|   | |||||||
							
								
								
									
										2
									
								
								.github/workflows/enforce-jira-issue-key.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										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
									
								
							
							
						
						
									
										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
									
									
								
							
							
						
						
									
										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 | ||||||
|  |  | ||||||
|   | |||||||
| @@ -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.8.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,6 +40,7 @@ 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(nlohmann_json_schema_validator REQUIRED) | ||||||
| @@ -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,14 +76,58 @@ 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 | ||||||
| @@ -134,7 +181,29 @@ add_executable(owprov | |||||||
|         src/storage/storage_variables.cpp src/storage/storage_variables.h |         src/storage/storage_variables.cpp src/storage/storage_variables.h | ||||||
|         src/RESTAPI/RESTAPI_variables_handler.cpp src/RESTAPI/RESTAPI_variables_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_variables_list_handler.cpp src/RESTAPI/RESTAPI_variables_list_handler.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/FileDownloader.cpp src/FileDownloader.h | ||||||
|  |         src/Tasks/VenueConfigUpdater.h | ||||||
|  |         src/libs/croncpp.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/storage/storage_overrides.cpp src/storage/storage_overrides.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} | ||||||
|   | |||||||
							
								
								
									
										66
									
								
								Dockerfile
									
									
									
									
									
								
							
							
						
						
									
										66
									
								
								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 JSON_VALIDATOR_VERSION=2.1.0 | ||||||
|  |  | ||||||
| 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 | ||||||
| @@ -33,8 +41,10 @@ RUN cmake --build . --target install | |||||||
|  |  | ||||||
| FROM build-base AS json-schema-validator-build | FROM build-base AS json-schema-validator-build | ||||||
|  |  | ||||||
| ADD https://api.github.com/repos/pboettch/json-schema-validator/git/refs/heads/master version.json | ARG JSON_VALIDATOR_VERSION | ||||||
| RUN git clone https://github.com/pboettch/json-schema-validator /json-schema-validator |  | ||||||
|  | ADD https://api.github.com/repos/pboettch/json-schema-validator/git/refs/tags/${JSON_VALIDATOR_VERSION} version.json | ||||||
|  | RUN git clone https://github.com/pboettch/json-schema-validator --branch ${JSON_VALIDATOR_VERSION} /json-schema-validator | ||||||
|  |  | ||||||
| WORKDIR /json-schema-validator | WORKDIR /json-schema-validator | ||||||
| RUN mkdir cmake-build | RUN mkdir cmake-build | ||||||
| @@ -43,18 +53,6 @@ RUN cmake .. | |||||||
| RUN make | RUN make | ||||||
| RUN make install | RUN make 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 | ||||||
|  |  | ||||||
| ADD CMakeLists.txt build /owprov/ | ADD CMakeLists.txt build /owprov/ | ||||||
| @@ -68,8 +66,6 @@ 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=json-schema-validator-build /usr/local/include /usr/local/include | ||||||
| COPY --from=json-schema-validator-build /usr/local/lib /usr/local/lib | 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 +73,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 +96,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 | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,5 +1,10 @@ | |||||||
| # OpenWiFi Provisioning | # OpenWiFi Provisioning | ||||||
|  |  | ||||||
|  | ## 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. | ||||||
|  |  | ||||||
| ## Build from source. | ## Build from source. | ||||||
| You need: | You need: | ||||||
| - https://github.com/pboettch/json-schema-validator.git | - https://github.com/pboettch/json-schema-validator.git | ||||||
| @@ -66,4 +71,4 @@ firmware.updater.releaseonly = <true/false> | |||||||
| Should FMS attempt to upgrade devices by default. | Should FMS attempt to upgrade devices by default. | ||||||
|  |  | ||||||
| ### firmware.updater.releaseonly | ### firmware.updater.releaseonly | ||||||
| Should only RC software be used during upgrades. | Should only RC software be used during upgrades. | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| #!/bin/sh | #!/bin/bash | ||||||
| set -e | set -e | ||||||
|  |  | ||||||
| if [ "$SELFSIGNED_CERTS" = 'true' ]; then | if [ "$SELFSIGNED_CERTS" = 'true' ]; then | ||||||
| @@ -24,6 +24,7 @@ if [[ "$TEMPLATE_CONFIG" = 'true' ]]; then | |||||||
|   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
									
									
								
							
							
						
						
									
										2
									
								
								helm/.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -1 +1,3 @@ | |||||||
| *.swp | *.swp | ||||||
|  | Chart.lock | ||||||
|  | charts/ | ||||||
|   | |||||||
| @@ -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.8.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: "" | ||||||
|   | |||||||
| @@ -1220,6 +1220,40 @@ 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 | ||||||
| @@ -1958,11 +1992,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 | ||||||
| @@ -2034,6 +2063,21 @@ 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 | ||||||
|  |         - 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 | ||||||
| @@ -2201,6 +2245,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: | ||||||
| @@ -2255,12 +2387,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 | ||||||
|   | |||||||
							
								
								
									
										174
									
								
								openapi/rrm_provider.yaml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										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 | ||||||
| @@ -115,4 +116,4 @@ storage.type.mysql.connectiontimeout = 60 | |||||||
| ######################################################################## | ######################################################################## | ||||||
| logging.type = file | logging.type = file | ||||||
| logging.path = $OWPROV_ROOT/logs | logging.path = $OWPROV_ROOT/logs | ||||||
| logging.level = debug | logging.level = debug | ||||||
|   | |||||||
| @@ -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 | ||||||
|   | |||||||
| @@ -5,6 +5,10 @@ | |||||||
| #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, Poco::Logger &L, bool Explain) | ||||||
| @@ -131,7 +135,10 @@ namespace OpenWifi { | |||||||
|                     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); | ||||||
| @@ -205,6 +212,65 @@ namespace OpenWifi { | |||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|  |  | ||||||
|  |             //  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 (...) { |         } catch (...) { | ||||||
|  |  | ||||||
|         } |         } | ||||||
| @@ -269,7 +335,11 @@ 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_)); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -10,6 +10,8 @@ | |||||||
|  |  | ||||||
| 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; | ||||||
|   | |||||||
| @@ -5,11 +5,14 @@ | |||||||
| #include "AutoDiscovery.h" | #include "AutoDiscovery.h" | ||||||
| #include "framework/ow_constants.h" | #include "framework/ow_constants.h" | ||||||
| #include "framework/KafkaTopics.h" | #include "framework/KafkaTopics.h" | ||||||
|  | #include "framework/KafkaManager.h" | ||||||
| #include "StorageService.h" | #include "StorageService.h" | ||||||
|  | #include "Poco/JSON/Parser.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); | ||||||
| @@ -18,10 +21,12 @@ namespace OpenWifi { | |||||||
|     }; |     }; | ||||||
|  |  | ||||||
|     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() { | ||||||
|   | |||||||
| @@ -4,8 +4,11 @@ | |||||||
|  |  | ||||||
| #pragma once | #pragma once | ||||||
|  |  | ||||||
| #include "framework/MicroService.h" |  | ||||||
| #include "framework/OpenWifiTypes.h" | #include "framework/OpenWifiTypes.h" | ||||||
|  | #include "framework/SubSystemServer.h" | ||||||
|  |  | ||||||
|  | #include "Poco/NotificationQueue.h" | ||||||
|  | #include "Poco/Notification.h" | ||||||
|  |  | ||||||
| namespace OpenWifi { | namespace OpenWifi { | ||||||
|  |  | ||||||
| @@ -33,7 +36,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_); | ||||||
|                 poco_debug(Logger(),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; | ||||||
|   | |||||||
| @@ -9,6 +9,7 @@ | |||||||
| #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 "Poco/Environment.h" | ||||||
|  | #include "Poco/Net/SSLManager.h" | ||||||
|  |  | ||||||
| #include "Daemon.h" | #include "Daemon.h" | ||||||
| #include "StorageService.h" | #include "StorageService.h" | ||||||
| @@ -20,6 +21,8 @@ | |||||||
| #include "Signup.h" | #include "Signup.h" | ||||||
| #include "DeviceTypeCache.h" | #include "DeviceTypeCache.h" | ||||||
| #include "FileDownloader.h" | #include "FileDownloader.h" | ||||||
|  | #include "framework/UI_WebSocketClientServer.h" | ||||||
|  | #include "UI_Prov_WebSocketNotifications.h" | ||||||
|  |  | ||||||
| namespace OpenWifi { | namespace OpenWifi { | ||||||
| 	class Daemon *Daemon::instance_ = nullptr; | 	class Daemon *Daemon::instance_ = nullptr; | ||||||
| @@ -38,7 +41,7 @@ namespace OpenWifi { | |||||||
| 									   SerialNumberCache(), | 									   SerialNumberCache(), | ||||||
| 									   AutoDiscovery(), | 									   AutoDiscovery(), | ||||||
| 									   JobController(), | 									   JobController(), | ||||||
| 									   WebSocketClientServer(), | 									   UI_WebSocketClientServer(), | ||||||
|                                        FindCountryFromIP(), |                                        FindCountryFromIP(), | ||||||
|                                        Signup(), |                                        Signup(), | ||||||
|                                        FileDownloader() |                                        FileDownloader() | ||||||
| @@ -70,20 +73,34 @@ namespace OpenWifi { | |||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     void DaemonPostInitialization(Poco::Util::Application &self) { | ||||||
|  |         Daemon()->PostInitialization(self); | ||||||
|  |         ProvWebSocketNotifications::Register(); | ||||||
|  |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|  |  | ||||||
| int main(int argc, char **argv) { | int main(int argc, char **argv) { | ||||||
| 	try { |     int ExitCode; | ||||||
| 		auto App = OpenWifi::Daemon::instance(); |     try { | ||||||
| 		auto ExitCode =  App->run(argc, argv); |         Poco::Net::SSLManager::instance().initializeServer(nullptr, nullptr, nullptr); | ||||||
| 		delete App; |         auto App = OpenWifi::Daemon::instance(); | ||||||
|  |         ExitCode =  App->run(argc, argv); | ||||||
|  |         Poco::Net::SSLManager::instance().shutdown(); | ||||||
|  |     } catch (Poco::Exception &exc) { | ||||||
|  |         ExitCode = 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; | ||||||
|  |     } | ||||||
|  |  | ||||||
| 		return ExitCode; |     std::cout << "Exitcode: " << ExitCode << std::endl; | ||||||
|  |     return ExitCode; | ||||||
| 	} catch (Poco::Exception &exc) { |  | ||||||
| 		std::cerr << exc.displayText() << std::endl; |  | ||||||
| 		return Poco::Util::Application::EXIT_SOFTWARE; |  | ||||||
| 	} |  | ||||||
| } | } | ||||||
|  |  | ||||||
| // end of namespace | // end of namespace | ||||||
| @@ -16,6 +16,7 @@ | |||||||
|  |  | ||||||
| #include "Dashboard.h" | #include "Dashboard.h" | ||||||
| #include "framework/MicroService.h" | #include "framework/MicroService.h" | ||||||
|  | #include "framework/MicroServiceNames.h" | ||||||
| #include "framework/OpenWifiTypes.h" | #include "framework/OpenWifiTypes.h" | ||||||
| #include "RESTObjects/RESTAPI_ProvObjects.h" | #include "RESTObjects/RESTAPI_ProvObjects.h" | ||||||
| #include "ProvWebSocketClient.h" | #include "ProvWebSocketClient.h" | ||||||
| @@ -54,8 +55,6 @@ 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); |  | ||||||
|     } |  | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -6,11 +6,11 @@ | |||||||
| //	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. | ||||||
|   | |||||||
| @@ -6,7 +6,11 @@ | |||||||
|  |  | ||||||
| #include <set> | #include <set> | ||||||
|  |  | ||||||
| #include "framework/MicroService.h" | #include "framework/SubSystemServer.h" | ||||||
|  | #include "framework/AppServiceRegistry.h" | ||||||
|  | #include "framework/OpenAPIRequests.h" | ||||||
|  | #include "framework/MicroServiceNames.h" | ||||||
|  |  | ||||||
| #include "Poco/Timer.h" | #include "Poco/Timer.h" | ||||||
|  |  | ||||||
| namespace OpenWifi { | namespace OpenWifi { | ||||||
|   | |||||||
| @@ -7,6 +7,7 @@ | |||||||
|  |  | ||||||
| namespace OpenWifi { | namespace OpenWifi { | ||||||
|     int FileDownloader::Start() { |     int FileDownloader::Start() { | ||||||
|  |         poco_information(Logger(),"Starting..."); | ||||||
|         TimerCallback_ = std::make_unique<Poco::TimerCallback<FileDownloader>>(*this,&FileDownloader::onTimer); |         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 | ||||||
| @@ -15,8 +16,9 @@ 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) { | ||||||
|   | |||||||
| @@ -3,7 +3,7 @@ | |||||||
| // | // | ||||||
|  |  | ||||||
| #pragma once | #pragma once | ||||||
| #include "framework/MicroService.h" | #include "framework/SubSystemServer.h" | ||||||
| #include "Poco/Timer.h" | #include "Poco/Timer.h" | ||||||
|  |  | ||||||
| namespace OpenWifi { | 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/SubSystemServer.h" | ||||||
|  | #include "framework/MicroServiceFuncs.h" | ||||||
|  |  | ||||||
| #include "nlohmann/json.hpp" | #include "nlohmann/json.hpp" | ||||||
|  |  | ||||||
| namespace OpenWifi { | namespace OpenWifi { | ||||||
| @@ -23,7 +26,7 @@ namespace OpenWifi { | |||||||
| 	  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(); | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| @@ -55,7 +58,7 @@ namespace OpenWifi { | |||||||
| 	  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(); | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| @@ -85,7 +88,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(); | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| @@ -133,18 +136,22 @@ 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 ) | ||||||
|   | |||||||
| @@ -3,15 +3,16 @@ | |||||||
| // | // | ||||||
|  |  | ||||||
| #include "JobController.h" | #include "JobController.h" | ||||||
|  | #include "framework/utils.h" | ||||||
|  | #include "fmt/format.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,8 +21,10 @@ 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..."); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -36,7 +39,7 @@ namespace OpenWifi { | |||||||
|             for(auto ¤t_job:jobs_) { |             for(auto ¤t_job:jobs_) { | ||||||
|                 if(current_job!=nullptr) { |                 if(current_job!=nullptr) { | ||||||
|                     if(current_job->Started()==0 && Pool_.used()<Pool_.available()) { |                     if(current_job->Started()==0 && Pool_.used()<Pool_.available()) { | ||||||
|                         current_job->Logger().information(fmt::format("Starting {}: {}",current_job->JobId(),current_job->Name())); |                         poco_information(current_job->Logger(),fmt::format("Starting {}: {}",current_job->JobId(),current_job->Name())); | ||||||
|                         current_job->Start(); |                         current_job->Start(); | ||||||
|                         Pool_.start(*current_job); |                         Pool_.start(*current_job); | ||||||
|                     } |                     } | ||||||
| @@ -46,7 +49,7 @@ namespace OpenWifi { | |||||||
|             for(auto it = jobs_.begin(); it!=jobs_.end();) {\ |             for(auto it = jobs_.begin(); it!=jobs_.end();) {\ | ||||||
|                 auto current_job = *it; |                 auto current_job = *it; | ||||||
|                 if(current_job!=nullptr && current_job->Completed()!=0) { |                 if(current_job!=nullptr && current_job->Completed()!=0) { | ||||||
|                     current_job->Logger().information(fmt::format("Completed {}: {}",current_job->JobId(),current_job->Name())); |                     poco_information(current_job->Logger(),fmt::format("Completed {}: {}",current_job->JobId(),current_job->Name())); | ||||||
|                     it = jobs_.erase(it); |                     it = jobs_.erase(it); | ||||||
|                     delete current_job; |                     delete current_job; | ||||||
|                 } else { |                 } else { | ||||||
|   | |||||||
| @@ -8,7 +8,9 @@ | |||||||
| #include <utility> | #include <utility> | ||||||
| #include <functional> | #include <functional> | ||||||
| #include <list> | #include <list> | ||||||
| #include "framework/MicroService.h" | #include "framework/SubSystemServer.h" | ||||||
|  | #include "RESTObjects/RESTAPI_SecurityObjects.h" | ||||||
|  | #include "framework/utils.h" | ||||||
|  |  | ||||||
| namespace OpenWifi { | namespace OpenWifi { | ||||||
|  |  | ||||||
| @@ -30,10 +32,10 @@ namespace OpenWifi { | |||||||
|         const std::string & JobId() const { return jobId_; } |         const std::string & JobId() const { return jobId_; } | ||||||
|         const std::string & Parameter(int x) const { return parameters_[x];} |         const std::string & Parameter(int x) const { return parameters_[x];} | ||||||
|         uint64_t When() const { return when_; } |         uint64_t When() const { return when_; } | ||||||
|         void Start() { started_ = OpenWifi::Now(); } |         void Start() { started_ = Utils::Now(); } | ||||||
|         uint64_t Started() const { return started_; } |         uint64_t Started() const { return started_; } | ||||||
|         uint64_t Completed() const { return completed_;} |         uint64_t Completed() const { return completed_;} | ||||||
|         void Complete() { completed_ = OpenWifi::Now(); } |         void Complete() { completed_ = Utils::Now(); } | ||||||
|  |  | ||||||
|     private: |     private: | ||||||
|         std::string                 jobId_; |         std::string                 jobId_; | ||||||
|   | |||||||
| @@ -4,7 +4,8 @@ | |||||||
|  |  | ||||||
| #pragma once | #pragma once | ||||||
|  |  | ||||||
| #include "framework/MicroService.h" | #include "framework/KafkaTopics.h" | ||||||
|  | #include "framework/KafkaManager.h" | ||||||
| #include "RESTObjects/RESTAPI_ProvObjects.h" | #include "RESTObjects/RESTAPI_ProvObjects.h" | ||||||
|  |  | ||||||
| namespace OpenWifi { | namespace OpenWifi { | ||||||
|   | |||||||
| @@ -7,22 +7,24 @@ | |||||||
| #include "StorageService.h" | #include "StorageService.h" | ||||||
| #include "SerialNumberCache.h" | #include "SerialNumberCache.h" | ||||||
| #include "sdks/SDK_sec.h" | #include "sdks/SDK_sec.h" | ||||||
|  | #include "framework/UI_WebSocketClientServer.h" | ||||||
|  |  | ||||||
| namespace OpenWifi { | namespace OpenWifi { | ||||||
|  |  | ||||||
|     ProvWebSocketClient::ProvWebSocketClient(Poco::Logger &Logger) : |     ProvWebSocketClient::ProvWebSocketClient(Poco::Logger &Logger) : | ||||||
|             Logger_(Logger){ |             Logger_(Logger){ | ||||||
|         WebSocketClientServer()->SetProcessor(this); |         UI_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 = 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; | ||||||
| @@ -83,6 +85,7 @@ namespace OpenWifi { | |||||||
|         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]=='*') { | ||||||
| @@ -115,11 +118,11 @@ 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); | ||||||
| @@ -140,7 +143,7 @@ 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); | ||||||
|   | |||||||
| @@ -4,11 +4,11 @@ | |||||||
|  |  | ||||||
| #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(); | ||||||
|   | |||||||
| @@ -3,13 +3,13 @@ | |||||||
| // | // | ||||||
|  |  | ||||||
| #pragma once | #pragma once | ||||||
|  | #include "framework/RESTAPI_Handler.h" | ||||||
| #include "../framework/MicroService.h" | #include "StorageService.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> | ||||||
|                                          { |                                          { | ||||||
|   | |||||||
| @@ -6,8 +6,6 @@ | |||||||
| //	Arilia Wireless Inc. | //	Arilia Wireless Inc. | ||||||
| // | // | ||||||
|  |  | ||||||
| #include "framework/MicroService.h" |  | ||||||
|  |  | ||||||
| #include "RESTAPI_configurations_handler.h" | #include "RESTAPI_configurations_handler.h" | ||||||
| #include "RESTObjects/RESTAPI_ProvObjects.h" | #include "RESTObjects/RESTAPI_ProvObjects.h" | ||||||
| #include "StorageService.h" | #include "StorageService.h" | ||||||
|   | |||||||
| @@ -5,16 +5,15 @@ | |||||||
| //	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 "framework/RESTAPI_Handler.h" | ||||||
| #include "StorageService.h" | #include "StorageService.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_POST, |             Poco::Net::HTTPRequest::HTTP_GET, Poco::Net::HTTPRequest::HTTP_POST, | ||||||
|   | |||||||
| @@ -3,15 +3,14 @@ | |||||||
| // | // | ||||||
|  |  | ||||||
| #pragma once | #pragma once | ||||||
|  | #include "framework/RESTAPI_Handler.h" | ||||||
| #include "framework/MicroService.h" |  | ||||||
| #include "StorageService.h" | #include "StorageService.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, | ||||||
|   | |||||||
| @@ -7,14 +7,13 @@ | |||||||
| // | // | ||||||
|  |  | ||||||
| #pragma once | #pragma once | ||||||
|  | #include "framework/RESTAPI_Handler.h" | ||||||
| #include "framework/MicroService.h" |  | ||||||
| #include "StorageService.h" | #include "StorageService.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_POST, |             Poco::Net::HTTPRequest::HTTP_GET, Poco::Net::HTTPRequest::HTTP_POST, | ||||||
|   | |||||||
| @@ -3,16 +3,14 @@ | |||||||
| // | // | ||||||
|  |  | ||||||
| #pragma once | #pragma once | ||||||
|  | #include "framework/RESTAPI_Handler.h" | ||||||
| #include "framework/MicroService.h" |  | ||||||
| #include "RESTObjects/RESTAPI_ProvObjects.h" |  | ||||||
| #include "StorageService.h" | #include "StorageService.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, | ||||||
|   | |||||||
| @@ -6,9 +6,11 @@ | |||||||
|  |  | ||||||
| #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 "sdks/SDK_sec.h" | #include "sdks/SDK_sec.h" | ||||||
|  | #include "Poco/StringTokenizer.h" | ||||||
|  |  | ||||||
|  | #include "libs/croncpp.h" | ||||||
|  |  | ||||||
| namespace OpenWifi { | namespace OpenWifi { | ||||||
|  |  | ||||||
| @@ -405,7 +407,9 @@ namespace OpenWifi { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     inline bool ValidateConfigBlock(const ProvObjects::DeviceConfiguration &Config, RESTAPI::Errors::msg & Error) { |     inline bool ValidateConfigBlock(const ProvObjects::DeviceConfiguration &Config, RESTAPI::Errors::msg & Error) { | ||||||
|         static const std::vector<std::string> SectionNames{ "globals", "interfaces", "metrics", "radios", "services", "unit" }; |         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; | ||||||
| @@ -521,12 +525,39 @@ namespace OpenWifi { | |||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         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"); | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -14,6 +14,8 @@ | |||||||
| #include "StorageService.h" | #include "StorageService.h" | ||||||
| #include "RESTAPI_db_helpers.h" | #include "RESTAPI_db_helpers.h" | ||||||
|  |  | ||||||
|  | #include "framework/CIDR.h" | ||||||
|  |  | ||||||
| namespace OpenWifi{ | namespace OpenWifi{ | ||||||
|  |  | ||||||
|     void RESTAPI_entity_handler::DoGet() { |     void RESTAPI_entity_handler::DoGet() { | ||||||
| @@ -78,7 +80,7 @@ namespace OpenWifi{ | |||||||
|  |  | ||||||
|         //  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, description. Everything else | ||||||
|         //  must be conveyed through PUT. |         //  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=""; | ||||||
|   | |||||||
| @@ -7,14 +7,13 @@ | |||||||
| // | // | ||||||
|  |  | ||||||
| #pragma once | #pragma once | ||||||
|  | #include "framework/RESTAPI_Handler.h" | ||||||
| #include "framework/MicroService.h" |  | ||||||
| #include "StorageService.h" | #include "StorageService.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, | ||||||
|   | |||||||
| @@ -6,7 +6,6 @@ | |||||||
| //	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 "StorageService.h" | ||||||
| #include "RESTAPI_db_helpers.h" | #include "RESTAPI_db_helpers.h" | ||||||
|   | |||||||
| @@ -8,14 +8,13 @@ | |||||||
|  |  | ||||||
|  |  | ||||||
| #pragma once | #pragma once | ||||||
|  | #include "framework/RESTAPI_Handler.h" | ||||||
| #include "framework/MicroService.h" |  | ||||||
| #include "StorageService.h" | #include "StorageService.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, | ||||||
|   | |||||||
| @@ -16,6 +16,7 @@ | |||||||
| #include "RESTAPI/RESTAPI_db_helpers.h" | #include "RESTAPI/RESTAPI_db_helpers.h" | ||||||
| #include "SerialNumberCache.h" | #include "SerialNumberCache.h" | ||||||
| #include "DeviceTypeCache.h" | #include "DeviceTypeCache.h" | ||||||
|  | #include "framework/utils.h" | ||||||
|  |  | ||||||
| namespace OpenWifi{ | namespace OpenWifi{ | ||||||
|  |  | ||||||
| @@ -35,62 +36,92 @@ namespace OpenWifi{ | |||||||
|  |  | ||||||
|     void RESTAPI_inventory_handler::DoGet() { |     void RESTAPI_inventory_handler::DoGet() { | ||||||
|  |  | ||||||
|         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>(); | ||||||
|             if(Device.Get(Configuration)) { |             if (Device.Get(Configuration)) { | ||||||
|                 Answer.set("config", Configuration); |                 Answer.set("config", Configuration); | ||||||
|                 if(Explain) |                 if (Explain) | ||||||
|                     Answer.set("explanation", Device.Explanation()); |                     Answer.set("explanation", Device.Explanation()); | ||||||
|             } else { |             } else { | ||||||
|                 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; | ||||||
|  |             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 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); | ||||||
|         } |         } | ||||||
| @@ -136,6 +167,7 @@ namespace OpenWifi{ | |||||||
|  |  | ||||||
|     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 +186,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; | ||||||
|         } |         } | ||||||
| @@ -242,23 +279,23 @@ namespace OpenWifi{ | |||||||
|         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("id",Existing.deviceConfiguration,DC)) { | ||||||
|                     Logger().information(Poco::format("%s: removing configuration for subscriber (%s)", SerialNumber, RemoveSubscriber)); |                     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("id", Existing.deviceConfiguration)) { | ||||||
|                             Logger().debug("Could not delete the subscriber configuration"); |                             poco_debug(Logger(),"Could not delete the subscriber configuration"); | ||||||
|                         } |                         } | ||||||
|                     } |                     } | ||||||
|                     else { |                     else { | ||||||
|                         Logger().debug("Configurations is not for a subscriber."); |                         poco_debug(Logger(),"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; | ||||||
| @@ -271,7 +308,7 @@ namespace OpenWifi{ | |||||||
|                 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); | ||||||
|         } |         } | ||||||
| @@ -349,6 +386,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; | ||||||
|         } |         } | ||||||
|   | |||||||
| @@ -7,14 +7,13 @@ | |||||||
| // | // | ||||||
|  |  | ||||||
| #pragma once | #pragma once | ||||||
|  | #include "framework/RESTAPI_Handler.h" | ||||||
| #include "framework/MicroService.h" |  | ||||||
| #include "StorageService.h" | #include "StorageService.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_POST, |             Poco::Net::HTTPRequest::HTTP_GET, Poco::Net::HTTPRequest::HTTP_POST, | ||||||
|   | |||||||
| @@ -7,15 +7,14 @@ | |||||||
| // | // | ||||||
|  |  | ||||||
| #pragma once | #pragma once | ||||||
|  | #include "framework/RESTAPI_Handler.h" | ||||||
| #include "StorageService.h" | #include "StorageService.h" | ||||||
| #include "framework/MicroService.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, | ||||||
|   | |||||||
| @@ -3,13 +3,13 @@ | |||||||
| // | // | ||||||
|  |  | ||||||
| #pragma once | #pragma once | ||||||
|  | #include "framework/RESTAPI_Handler.h" | ||||||
| #include "framework/MicroService.h" | #include "StorageService.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}, | ||||||
|   | |||||||
| @@ -12,6 +12,7 @@ | |||||||
| #include "StorageService.h" | #include "StorageService.h" | ||||||
| #include "Daemon.h" | #include "Daemon.h" | ||||||
| #include "RESTAPI/RESTAPI_db_helpers.h" | #include "RESTAPI/RESTAPI_db_helpers.h" | ||||||
|  | #include "framework/utils.h" | ||||||
|  |  | ||||||
| namespace OpenWifi{ | namespace OpenWifi{ | ||||||
|  |  | ||||||
| @@ -147,7 +148,7 @@ 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; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -7,14 +7,13 @@ | |||||||
| // | // | ||||||
|  |  | ||||||
| #pragma once | #pragma once | ||||||
|  | #include "framework/RESTAPI_Handler.h" | ||||||
| #include "framework/MicroService.h" |  | ||||||
| #include "StorageService.h" | #include "StorageService.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_POST, |             Poco::Net::HTTPRequest::HTTP_GET, Poco::Net::HTTPRequest::HTTP_POST, | ||||||
|   | |||||||
| @@ -3,15 +3,14 @@ | |||||||
| // | // | ||||||
|  |  | ||||||
| #pragma once | #pragma once | ||||||
|  | #include "framework/RESTAPI_Handler.h" | ||||||
| #include "framework/MicroService.h" |  | ||||||
| #include "StorageService.h" | #include "StorageService.h" | ||||||
|  |  | ||||||
| namespace OpenWifi { | namespace OpenWifi { | ||||||
|  |  | ||||||
|     class RESTAPI_location_list_handler : public RESTAPIHandler { |     class RESTAPI_location_list_handler : public RESTAPIHandler { | ||||||
|     public: |     public: | ||||||
|         RESTAPI_location_list_handler(const RESTAPIHandler::BindingMap &bindings, Poco::Logger &L, RESTAPI_GenericServer & Server, uint64_t TransactionId, bool Internal) |         RESTAPI_location_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, | ||||||
|   | |||||||
| @@ -7,13 +7,14 @@ | |||||||
| // | // | ||||||
|  |  | ||||||
|  |  | ||||||
| #include "framework/MicroService.h" | #pragma once | ||||||
|  | #include "framework/RESTAPI_Handler.h" | ||||||
| #include "StorageService.h" | #include "StorageService.h" | ||||||
|  |  | ||||||
| namespace OpenWifi { | namespace OpenWifi { | ||||||
|     class RESTAPI_managementPolicy_handler : public RESTAPIHandler { |     class RESTAPI_managementPolicy_handler : public RESTAPIHandler { | ||||||
|     public: |     public: | ||||||
|         RESTAPI_managementPolicy_handler(const RESTAPIHandler::BindingMap &bindings, Poco::Logger &L, RESTAPI_GenericServer & Server, uint64_t TransactionId, bool Internal) |         RESTAPI_managementPolicy_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_POST, |             Poco::Net::HTTPRequest::HTTP_GET, Poco::Net::HTTPRequest::HTTP_POST, | ||||||
|   | |||||||
| @@ -2,14 +2,15 @@ | |||||||
| // Created by stephane bourque on 2021-08-26. | // Created by stephane bourque on 2021-08-26. | ||||||
| // | // | ||||||
|  |  | ||||||
| #include "framework/MicroService.h" | #pragma once | ||||||
|  | #include "framework/RESTAPI_Handler.h" | ||||||
| #include "StorageService.h" | #include "StorageService.h" | ||||||
|  |  | ||||||
| namespace OpenWifi { | namespace OpenWifi { | ||||||
|  |  | ||||||
|     class RESTAPI_managementPolicy_list_handler : public RESTAPIHandler { |     class RESTAPI_managementPolicy_list_handler : public RESTAPIHandler { | ||||||
|     public: |     public: | ||||||
|         RESTAPI_managementPolicy_list_handler(const RESTAPIHandler::BindingMap &bindings, Poco::Logger &L, RESTAPI_GenericServer & Server, uint64_t TransactionId, bool Internal) |         RESTAPI_managementPolicy_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, | ||||||
|   | |||||||
| @@ -2,13 +2,14 @@ | |||||||
| // Created by stephane bourque on 2021-08-26. | // Created by stephane bourque on 2021-08-26. | ||||||
| // | // | ||||||
|  |  | ||||||
| #include "framework/MicroService.h" | #pragma once | ||||||
|  | #include "framework/RESTAPI_Handler.h" | ||||||
| #include "StorageService.h" | #include "StorageService.h" | ||||||
|  |  | ||||||
| namespace OpenWifi { | namespace OpenWifi { | ||||||
|     class RESTAPI_managementRole_handler : public RESTAPIHandler { |     class RESTAPI_managementRole_handler : public RESTAPIHandler { | ||||||
|     public: |     public: | ||||||
|         RESTAPI_managementRole_handler(const RESTAPIHandler::BindingMap &bindings, Poco::Logger &L, RESTAPI_GenericServer & Server, uint64_t TransactionId, bool Internal) |         RESTAPI_managementRole_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_POST, |             Poco::Net::HTTPRequest::HTTP_GET, Poco::Net::HTTPRequest::HTTP_POST, | ||||||
|   | |||||||
| @@ -2,10 +2,7 @@ | |||||||
| // Created by stephane bourque on 2021-08-26. | // Created by stephane bourque on 2021-08-26. | ||||||
| // | // | ||||||
|  |  | ||||||
| #include "framework/MicroService.h" |  | ||||||
|  |  | ||||||
| #include "RESTAPI_managementRole_list_handler.h" | #include "RESTAPI_managementRole_list_handler.h" | ||||||
| #include "RESTObjects/RESTAPI_ProvObjects.h" |  | ||||||
| #include "StorageService.h" | #include "StorageService.h" | ||||||
| #include "RESTAPI/RESTAPI_db_helpers.h" | #include "RESTAPI/RESTAPI_db_helpers.h" | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,16 +1,16 @@ | |||||||
| // | // | ||||||
| // Created by stephane bourque on 2021-08-26. | // Created by stephane bourque on 2021-08-26. | ||||||
| // | // | ||||||
| #pragma once |  | ||||||
|  |  | ||||||
| #include "framework/MicroService.h" | #pragma once | ||||||
|  | #include "framework/RESTAPI_Handler.h" | ||||||
| #include "StorageService.h" | #include "StorageService.h" | ||||||
|  |  | ||||||
| namespace OpenWifi { | namespace OpenWifi { | ||||||
|  |  | ||||||
|     class RESTAPI_managementRole_list_handler : public RESTAPIHandler { |     class RESTAPI_managementRole_list_handler : public RESTAPIHandler { | ||||||
|     public: |     public: | ||||||
|         RESTAPI_managementRole_list_handler(const RESTAPIHandler::BindingMap &bindings, Poco::Logger &L, RESTAPI_GenericServer & Server, uint64_t TransactionId, bool Internal) |         RESTAPI_managementRole_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, | ||||||
|   | |||||||
| @@ -2,14 +2,13 @@ | |||||||
| // Created by stephane bourque on 2021-11-09. | // Created by stephane bourque on 2021-11-09. | ||||||
| // | // | ||||||
| #pragma once | #pragma once | ||||||
|  | #include "framework/RESTAPI_Handler.h" | ||||||
| #include "framework/MicroService.h" |  | ||||||
| #include "StorageService.h" | #include "StorageService.h" | ||||||
|  |  | ||||||
| namespace OpenWifi { | namespace OpenWifi { | ||||||
|     class RESTAPI_map_handler : public RESTAPIHandler { |     class RESTAPI_map_handler : public RESTAPIHandler { | ||||||
|     public: |     public: | ||||||
|         RESTAPI_map_handler(const RESTAPIHandler::BindingMap &bindings, Poco::Logger &L, RESTAPI_GenericServer & Server, uint64_t TransactionId, bool Internal) |         RESTAPI_map_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_POST, |             Poco::Net::HTTPRequest::HTTP_GET, Poco::Net::HTTPRequest::HTTP_POST, | ||||||
|   | |||||||
| @@ -2,15 +2,14 @@ | |||||||
| // Created by stephane bourque on 2021-11-09. | // Created by stephane bourque on 2021-11-09. | ||||||
| // | // | ||||||
| #pragma once | #pragma once | ||||||
|  | #include "framework/RESTAPI_Handler.h" | ||||||
| #include "framework/MicroService.h" |  | ||||||
| #include "StorageService.h" | #include "StorageService.h" | ||||||
|  |  | ||||||
| namespace OpenWifi { | namespace OpenWifi { | ||||||
|  |  | ||||||
|     class RESTAPI_map_list_handler : public RESTAPIHandler { |     class RESTAPI_map_list_handler : public RESTAPIHandler { | ||||||
|     public: |     public: | ||||||
|         RESTAPI_map_list_handler(const RESTAPIHandler::BindingMap &bindings, Poco::Logger &L, RESTAPI_GenericServer & Server, uint64_t TransactionId, bool Internal) |         RESTAPI_map_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, | ||||||
|   | |||||||
| @@ -3,14 +3,13 @@ | |||||||
| // | // | ||||||
|  |  | ||||||
| #pragma once | #pragma once | ||||||
|  | #include "framework/RESTAPI_Handler.h" | ||||||
| #include "framework/MicroService.h" |  | ||||||
| #include "StorageService.h" | #include "StorageService.h" | ||||||
|  |  | ||||||
| namespace OpenWifi { | namespace OpenWifi { | ||||||
|     class RESTAPI_op_contact_handler : public RESTAPIHandler { |     class RESTAPI_op_contact_handler : public RESTAPIHandler { | ||||||
|     public: |     public: | ||||||
|         RESTAPI_op_contact_handler(const RESTAPIHandler::BindingMap &bindings, Poco::Logger &L, RESTAPI_GenericServer & Server, uint64_t TransactionId, bool Internal) |         RESTAPI_op_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_POST, |                                          Poco::Net::HTTPRequest::HTTP_GET, Poco::Net::HTTPRequest::HTTP_POST, | ||||||
|   | |||||||
| @@ -2,15 +2,14 @@ | |||||||
| // Created by stephane bourque on 2022-04-07. | // Created by stephane bourque on 2022-04-07. | ||||||
| // | // | ||||||
| #pragma once | #pragma once | ||||||
|  | #include "framework/RESTAPI_Handler.h" | ||||||
| #include "framework/MicroService.h" |  | ||||||
| #include "StorageService.h" | #include "StorageService.h" | ||||||
|  |  | ||||||
| namespace OpenWifi { | namespace OpenWifi { | ||||||
|  |  | ||||||
|     class RESTAPI_op_contact_list_handler : public RESTAPIHandler { |     class RESTAPI_op_contact_list_handler : public RESTAPIHandler { | ||||||
|     public: |     public: | ||||||
|         RESTAPI_op_contact_list_handler(const RESTAPIHandler::BindingMap &bindings, Poco::Logger &L, RESTAPI_GenericServer & Server, uint64_t TransactionId, bool Internal) |         RESTAPI_op_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, | ||||||
|   | |||||||
| @@ -3,14 +3,13 @@ | |||||||
| // | // | ||||||
|  |  | ||||||
| #pragma once | #pragma once | ||||||
|  | #include "framework/RESTAPI_Handler.h" | ||||||
| #include "framework/MicroService.h" |  | ||||||
| #include "StorageService.h" | #include "StorageService.h" | ||||||
|  |  | ||||||
| namespace OpenWifi { | namespace OpenWifi { | ||||||
|     class RESTAPI_op_location_handler : public RESTAPIHandler { |     class RESTAPI_op_location_handler : public RESTAPIHandler { | ||||||
|     public: |     public: | ||||||
|         RESTAPI_op_location_handler(const RESTAPIHandler::BindingMap &bindings, Poco::Logger &L, RESTAPI_GenericServer & Server, uint64_t TransactionId, bool Internal) |         RESTAPI_op_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_POST, |                                          Poco::Net::HTTPRequest::HTTP_GET, Poco::Net::HTTPRequest::HTTP_POST, | ||||||
|   | |||||||
| @@ -3,15 +3,14 @@ | |||||||
| // | // | ||||||
|  |  | ||||||
| #pragma once | #pragma once | ||||||
|  | #include "framework/RESTAPI_Handler.h" | ||||||
| #include "framework/MicroService.h" |  | ||||||
| #include "StorageService.h" | #include "StorageService.h" | ||||||
|  |  | ||||||
| namespace OpenWifi { | namespace OpenWifi { | ||||||
|  |  | ||||||
|     class RESTAPI_op_location_list_handler : public RESTAPIHandler { |     class RESTAPI_op_location_list_handler : public RESTAPIHandler { | ||||||
|     public: |     public: | ||||||
|         RESTAPI_op_location_list_handler(const RESTAPIHandler::BindingMap &bindings, Poco::Logger &L, RESTAPI_GenericServer & Server, uint64_t TransactionId, bool Internal) |         RESTAPI_op_location_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, | ||||||
|   | |||||||
| @@ -4,6 +4,7 @@ | |||||||
|  |  | ||||||
| #include "RESTAPI_operators_handler.h" | #include "RESTAPI_operators_handler.h" | ||||||
| #include "RESTAPI_db_helpers.h" | #include "RESTAPI_db_helpers.h" | ||||||
|  | #include "framework/utils.h" | ||||||
|  |  | ||||||
| namespace OpenWifi { | namespace OpenWifi { | ||||||
|  |  | ||||||
| @@ -83,10 +84,10 @@ namespace OpenWifi { | |||||||
|  |  | ||||||
|             // Create the default service... |             // Create the default service... | ||||||
|             ProvObjects::ServiceClass DefSer; |             ProvObjects::ServiceClass DefSer; | ||||||
|             DefSer.info.id = MicroService::CreateUUID(); |             DefSer.info.id = MicroServiceCreateUUID(); | ||||||
|             DefSer.info.name = "Default Service Class"; |             DefSer.info.name = "Default Service Class"; | ||||||
|             DefSer.defaultService = true; |             DefSer.defaultService = true; | ||||||
|             DefSer.info.created = DefSer.info.modified = OpenWifi::Now(); |             DefSer.info.created = DefSer.info.modified = Utils::Now(); | ||||||
|             DefSer.operatorId = NewObject.info.id; |             DefSer.operatorId = NewObject.info.id; | ||||||
|             DefSer.period = "monthly"; |             DefSer.period = "monthly"; | ||||||
|             DefSer.billingCode = "basic"; |             DefSer.billingCode = "basic"; | ||||||
|   | |||||||
| @@ -3,14 +3,13 @@ | |||||||
| // | // | ||||||
|  |  | ||||||
| #pragma once | #pragma once | ||||||
|  | #include "framework/RESTAPI_Handler.h" | ||||||
| #include "framework/MicroService.h" |  | ||||||
| #include "StorageService.h" | #include "StorageService.h" | ||||||
|  |  | ||||||
| namespace OpenWifi { | namespace OpenWifi { | ||||||
|     class RESTAPI_operators_handler : public RESTAPIHandler { |     class RESTAPI_operators_handler : public RESTAPIHandler { | ||||||
|     public: |     public: | ||||||
|         RESTAPI_operators_handler(const RESTAPIHandler::BindingMap &bindings, Poco::Logger &L, RESTAPI_GenericServer & Server, uint64_t TransactionId, bool Internal) |         RESTAPI_operators_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_POST, |                                          Poco::Net::HTTPRequest::HTTP_GET, Poco::Net::HTTPRequest::HTTP_POST, | ||||||
|   | |||||||
| @@ -2,15 +2,14 @@ | |||||||
| // Created by stephane bourque on 2022-04-06. | // Created by stephane bourque on 2022-04-06. | ||||||
| // | // | ||||||
| #pragma once | #pragma once | ||||||
|  | #include "framework/RESTAPI_Handler.h" | ||||||
| #include "framework/MicroService.h" |  | ||||||
| #include "StorageService.h" | #include "StorageService.h" | ||||||
|  |  | ||||||
| namespace OpenWifi { | namespace OpenWifi { | ||||||
|  |  | ||||||
|     class RESTAPI_operators_list_handler : public RESTAPIHandler { |     class RESTAPI_operators_list_handler : public RESTAPIHandler { | ||||||
|     public: |     public: | ||||||
|         RESTAPI_operators_list_handler(const RESTAPIHandler::BindingMap &bindings, Poco::Logger &L, RESTAPI_GenericServer & Server, uint64_t TransactionId, bool Internal) |         RESTAPI_operators_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, | ||||||
|   | |||||||
							
								
								
									
										106
									
								
								src/RESTAPI/RESTAPI_overrides_handler.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										106
									
								
								src/RESTAPI/RESTAPI_overrides_handler.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,106 @@ | |||||||
|  | // | ||||||
|  | // Created by stephane bourque on 2022-11-03. | ||||||
|  | // | ||||||
|  |  | ||||||
|  | #include <algorithm> | ||||||
|  |  | ||||||
|  | #include "RESTAPI_overrides_handler.h" | ||||||
|  | #include "framework/utils.h" | ||||||
|  |  | ||||||
|  | namespace OpenWifi { | ||||||
|  |     void RESTAPI_overrides_handler::DoGet() { | ||||||
|  |         std::string SerialNumber = GetBinding(RESTAPI::Protocol::SERIALNUMBER, ""); | ||||||
|  |  | ||||||
|  |         if(!Utils::NormalizeMac(SerialNumber)) { | ||||||
|  |             return BadRequest(RESTAPI::Errors::InvalidSerialNumber); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         ProvObjects::ConfigurationOverrideList  ExistingObject; | ||||||
|  |         if(!DB_.GetRecord("serialNumber", SerialNumber, ExistingObject)) { | ||||||
|  |             return NotFound(); | ||||||
|  |         } | ||||||
|  |         Poco::JSON::Object  Answer; | ||||||
|  |         ExistingObject.to_json(Answer); | ||||||
|  |  | ||||||
|  |         return ReturnObject(Answer); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     void RESTAPI_overrides_handler::DoDelete() { | ||||||
|  |         std::string SerialNumber = GetBinding(RESTAPI::Protocol::SERIALNUMBER, ""); | ||||||
|  |  | ||||||
|  |         if(!Utils::NormalizeMac(SerialNumber)) { | ||||||
|  |             return BadRequest(RESTAPI::Errors::InvalidSerialNumber); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         auto Source = GetParameter("source",""); | ||||||
|  |         if(Source.empty()) { | ||||||
|  |             return BadRequest(RESTAPI::Errors::MissingOrInvalidParameters); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         ProvObjects::ConfigurationOverrideList  ExistingObject; | ||||||
|  |         if(!DB_.GetRecord("serialNumber", SerialNumber, ExistingObject)) { | ||||||
|  |             return NotFound(); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         ExistingObject.overrides.erase( std::remove_if( ExistingObject.overrides.begin(), ExistingObject.overrides.end(), | ||||||
|  |             [Source](const ProvObjects::ConfigurationOverride &O) ->bool { | ||||||
|  |             return O.source==Source; | ||||||
|  |         }),ExistingObject.overrides.end()); | ||||||
|  |  | ||||||
|  |         if(DB_.UpdateRecord("serialNumber", SerialNumber, ExistingObject)) { | ||||||
|  |             return OK(); | ||||||
|  |         } | ||||||
|  |         return BadRequest(RESTAPI::Errors::NoRecordsDeleted); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     void RESTAPI_overrides_handler::DoPut() { | ||||||
|  |         std::string SerialNumber = GetBinding(RESTAPI::Protocol::SERIALNUMBER, ""); | ||||||
|  |  | ||||||
|  |         if(!Utils::NormalizeMac(SerialNumber)) { | ||||||
|  |             return BadRequest(RESTAPI::Errors::InvalidSerialNumber); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         auto Source = GetParameter("source",""); | ||||||
|  |         if(Source.empty()) { | ||||||
|  |             return BadRequest(RESTAPI::Errors::MissingOrInvalidParameters); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         ProvObjects::ConfigurationOverrideList  NewObject; | ||||||
|  |         if(!NewObject.from_json(ParsedBody_)) { | ||||||
|  |             return BadRequest(RESTAPI::Errors::InvalidJSONDocument); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         ProvObjects::ConfigurationOverrideList  ExistingObject; | ||||||
|  |         if(!DB_.GetRecord("serialNumber", SerialNumber, ExistingObject)) { | ||||||
|  |             ExistingObject.serialNumber = SerialNumber; | ||||||
|  |             DB_.CreateRecord(ExistingObject); | ||||||
|  |         } else { | ||||||
|  |             // remove all the old records with that source. | ||||||
|  |             ExistingObject.overrides.erase( std::remove_if( ExistingObject.overrides.begin(), ExistingObject.overrides.end(), | ||||||
|  |                                                             [Source](const ProvObjects::ConfigurationOverride &O) ->bool { | ||||||
|  |                                                                 return O.source==Source; | ||||||
|  |                                                             }),ExistingObject.overrides.end()); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         for(auto & override:NewObject.overrides) { | ||||||
|  |             if(override.parameterName.empty()) { | ||||||
|  |                 continue; | ||||||
|  |             } | ||||||
|  |             if(override.parameterType!="string" && override.parameterType!="boolean" && override.parameterType!="integer") { | ||||||
|  |                 return BadRequest(RESTAPI::Errors::MissingOrInvalidParameters); | ||||||
|  |             } | ||||||
|  |             override.source = Source; | ||||||
|  |             override.modified = Utils::Now(); | ||||||
|  |             ExistingObject.overrides.emplace_back(override); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         if(DB_.UpdateRecord("serialNumber",SerialNumber,ExistingObject)) { | ||||||
|  |             Poco::JSON::Object  Answer; | ||||||
|  |             ExistingObject.to_json(Answer); | ||||||
|  |             return ReturnObject(Answer); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         return BadRequest(RESTAPI::Errors::RecordNotUpdated); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } // OpenWifi | ||||||
							
								
								
									
										31
									
								
								src/RESTAPI/RESTAPI_overrides_handler.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										31
									
								
								src/RESTAPI/RESTAPI_overrides_handler.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,31 @@ | |||||||
|  | // | ||||||
|  | // Created by stephane bourque on 2022-11-03. | ||||||
|  | // | ||||||
|  |  | ||||||
|  |  | ||||||
|  | #pragma once | ||||||
|  |  | ||||||
|  | #include "framework/RESTAPI_Handler.h" | ||||||
|  | #include "StorageService.h" | ||||||
|  |  | ||||||
|  | namespace OpenWifi { | ||||||
|  |     class RESTAPI_overrides_handler : public RESTAPIHandler { | ||||||
|  |     public: | ||||||
|  |         RESTAPI_overrides_handler(const RESTAPIHandler::BindingMap &bindings, Poco::Logger &L, RESTAPI_GenericServerAccounting & Server, uint64_t TransactionId, bool Internal) | ||||||
|  |                 : RESTAPIHandler(bindings, L, | ||||||
|  |                                  std::vector<std::string>{ | ||||||
|  |                                          Poco::Net::HTTPRequest::HTTP_GET, | ||||||
|  |                                          Poco::Net::HTTPRequest::HTTP_PUT, Poco::Net::HTTPRequest::HTTP_DELETE, | ||||||
|  |                                          Poco::Net::HTTPRequest::HTTP_OPTIONS}, | ||||||
|  |                                  Server, | ||||||
|  |                                  TransactionId, | ||||||
|  |                                  Internal){} | ||||||
|  |         static auto PathName() { return std::list<std::string>{"/api/v1/configurationOverrides/{serialNumber}"}; }; | ||||||
|  |     private: | ||||||
|  |         OverridesDB     &DB_=StorageService()->OverridesDB(); | ||||||
|  |         void DoGet() final ; | ||||||
|  |         void DoPost() final {} ; | ||||||
|  |         void DoPut() final ; | ||||||
|  |         void DoDelete() final ; | ||||||
|  |     }; | ||||||
|  | } | ||||||
| @@ -2,8 +2,6 @@ | |||||||
| // Created by stephane bourque on 2021-10-23. | // Created by stephane bourque on 2021-10-23. | ||||||
| // | // | ||||||
|  |  | ||||||
| #include "framework/MicroService.h" |  | ||||||
|  |  | ||||||
| #include "RESTAPI/RESTAPI_entity_handler.h" | #include "RESTAPI/RESTAPI_entity_handler.h" | ||||||
| #include "RESTAPI/RESTAPI_contact_handler.h" | #include "RESTAPI/RESTAPI_contact_handler.h" | ||||||
| #include "RESTAPI/RESTAPI_location_handler.h" | #include "RESTAPI/RESTAPI_location_handler.h" | ||||||
| @@ -36,12 +34,15 @@ | |||||||
| #include "RESTAPI/RESTAPI_op_contact_list_handler.h" | #include "RESTAPI/RESTAPI_op_contact_list_handler.h" | ||||||
| #include "RESTAPI/RESTAPI_op_location_handler.h" | #include "RESTAPI/RESTAPI_op_location_handler.h" | ||||||
| #include "RESTAPI/RESTAPI_op_location_list_handler.h" | #include "RESTAPI/RESTAPI_op_location_list_handler.h" | ||||||
|  | #include "RESTAPI/RESTAPI_overrides_handler.h" | ||||||
|  |  | ||||||
|  | #include "framework/RESTAPI_SystemCommand.h" | ||||||
|  | #include "framework/RESTAPI_WebSocketServer.h" | ||||||
|  |  | ||||||
| namespace OpenWifi { | namespace OpenWifi { | ||||||
|  |  | ||||||
|     Poco::Net::HTTPRequestHandler * RESTAPI_ExtRouter(const std::string &Path, RESTAPIHandler::BindingMap &Bindings, |     Poco::Net::HTTPRequestHandler * RESTAPI_ExtRouter(const std::string &Path, RESTAPIHandler::BindingMap &Bindings, | ||||||
|                                                             Poco::Logger & L, RESTAPI_GenericServer & S, uint64_t TransactionId) { |                                                             Poco::Logger & L, RESTAPI_GenericServerAccounting & S, uint64_t TransactionId) { | ||||||
|         return  RESTAPI_Router< |         return  RESTAPI_Router< | ||||||
|                     RESTAPI_system_command, |                     RESTAPI_system_command, | ||||||
|                     RESTAPI_entity_handler, |                     RESTAPI_entity_handler, | ||||||
| @@ -76,12 +77,13 @@ namespace OpenWifi { | |||||||
|                     RESTAPI_op_contact_list_handler, |                     RESTAPI_op_contact_list_handler, | ||||||
|                     RESTAPI_op_location_handler, |                     RESTAPI_op_location_handler, | ||||||
|                     RESTAPI_op_location_list_handler, |                     RESTAPI_op_location_list_handler, | ||||||
|                     RESTAPI_asset_server |                     RESTAPI_asset_server, | ||||||
|  |                     RESTAPI_overrides_handler | ||||||
|                 >(Path,Bindings,L, S, TransactionId); |                 >(Path,Bindings,L, S, TransactionId); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     Poco::Net::HTTPRequestHandler * RESTAPI_IntRouter(const std::string &Path, RESTAPIHandler::BindingMap &Bindings, |     Poco::Net::HTTPRequestHandler * RESTAPI_IntRouter(const std::string &Path, RESTAPIHandler::BindingMap &Bindings, | ||||||
|                                                             Poco::Logger & L, RESTAPI_GenericServer & S, uint64_t TransactionId) { |                                                             Poco::Logger & L, RESTAPI_GenericServerAccounting & S, uint64_t TransactionId) { | ||||||
|         return RESTAPI_Router_I< |         return RESTAPI_Router_I< | ||||||
|                 RESTAPI_system_command, |                 RESTAPI_system_command, | ||||||
|                 RESTAPI_entity_handler, |                 RESTAPI_entity_handler, | ||||||
| @@ -115,7 +117,8 @@ namespace OpenWifi { | |||||||
|                 RESTAPI_op_contact_handler, |                 RESTAPI_op_contact_handler, | ||||||
|                 RESTAPI_op_contact_list_handler, |                 RESTAPI_op_contact_list_handler, | ||||||
|                 RESTAPI_op_location_handler, |                 RESTAPI_op_location_handler, | ||||||
|                 RESTAPI_op_location_list_handler |                 RESTAPI_op_location_list_handler, | ||||||
|  |                 RESTAPI_overrides_handler | ||||||
|         >(Path, Bindings, L, S, TransactionId); |         >(Path, Bindings, L, S, TransactionId); | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -3,14 +3,13 @@ | |||||||
| // | // | ||||||
|  |  | ||||||
| #pragma once | #pragma once | ||||||
|  | #include "framework/RESTAPI_Handler.h" | ||||||
| #include "framework/MicroService.h" |  | ||||||
| #include "StorageService.h" | #include "StorageService.h" | ||||||
|  |  | ||||||
| namespace OpenWifi { | namespace OpenWifi { | ||||||
|     class RESTAPI_service_class_handler : public RESTAPIHandler { |     class RESTAPI_service_class_handler : public RESTAPIHandler { | ||||||
|     public: |     public: | ||||||
|         RESTAPI_service_class_handler(const RESTAPIHandler::BindingMap &bindings, Poco::Logger &L, RESTAPI_GenericServer & Server, uint64_t TransactionId, bool Internal) |         RESTAPI_service_class_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_POST, |                                          Poco::Net::HTTPRequest::HTTP_GET, Poco::Net::HTTPRequest::HTTP_POST, | ||||||
|   | |||||||
| @@ -3,15 +3,14 @@ | |||||||
| // | // | ||||||
|  |  | ||||||
| #pragma once | #pragma once | ||||||
|  | #include "framework/RESTAPI_Handler.h" | ||||||
| #include "framework/MicroService.h" |  | ||||||
| #include "StorageService.h" | #include "StorageService.h" | ||||||
|  |  | ||||||
| namespace OpenWifi { | namespace OpenWifi { | ||||||
|  |  | ||||||
|     class RESTAPI_service_class_list_handler : public RESTAPIHandler { |     class RESTAPI_service_class_list_handler : public RESTAPIHandler { | ||||||
|     public: |     public: | ||||||
|         RESTAPI_service_class_list_handler(const RESTAPIHandler::BindingMap &bindings, Poco::Logger &L, RESTAPI_GenericServer & Server, uint64_t TransactionId, bool Internal) |         RESTAPI_service_class_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, | ||||||
|   | |||||||
| @@ -5,6 +5,10 @@ | |||||||
| #include "RESTAPI_signup_handler.h" | #include "RESTAPI_signup_handler.h" | ||||||
| #include "StorageService.h" | #include "StorageService.h" | ||||||
| #include "Signup.h" | #include "Signup.h" | ||||||
|  | #include "framework/OpenAPIRequests.h" | ||||||
|  | #include "framework/MicroServiceNames.h" | ||||||
|  | #include "framework/MicroServiceFuncs.h" | ||||||
|  | #include "framework/utils.h" | ||||||
|  |  | ||||||
| namespace OpenWifi { | namespace OpenWifi { | ||||||
|  |  | ||||||
| @@ -59,7 +63,7 @@ namespace OpenWifi { | |||||||
|                 if (i.statusCode == ProvObjects::SignupStatusCodes::SignupWaitingForEmail || |                 if (i.statusCode == ProvObjects::SignupStatusCodes::SignupWaitingForEmail || | ||||||
|                     i.statusCode == ProvObjects::SignupStatusCodes::SignupWaitingForDevice || |                     i.statusCode == ProvObjects::SignupStatusCodes::SignupWaitingForDevice || | ||||||
|                     i.statusCode == ProvObjects::SignupStatusCodes::SignupSuccess ) { |                     i.statusCode == ProvObjects::SignupStatusCodes::SignupSuccess ) { | ||||||
|                     Logger().information(fmt::format("SIGNUP: Returning existing signup record for '{}'",i.email)); |                     poco_debug(Logger(),fmt::format("SIGNUP: Returning existing signup record for '{}'",i.email)); | ||||||
|                     Poco::JSON::Object Answer; |                     Poco::JSON::Object Answer; | ||||||
|                     i.to_json(Answer); |                     i.to_json(Answer); | ||||||
|                     return ReturnObject(Answer); |                     return ReturnObject(Answer); | ||||||
| @@ -93,15 +97,15 @@ namespace OpenWifi { | |||||||
|         //  OK, we can claim this device, can we create a userid? |         //  OK, we can claim this device, can we create a userid? | ||||||
|         //  Let's create one |         //  Let's create one | ||||||
|         //  If sec.signup("email",uuid); |         //  If sec.signup("email",uuid); | ||||||
|         auto SignupUUID = MicroService::instance().CreateUUID(); |         auto SignupUUID = MicroServiceCreateUUID(); | ||||||
|         Logger().information(fmt::format("SIGNUP: Creating signup entry for '{}', uuid='{}'",UserName, SignupUUID)); |         poco_debug(Logger(),fmt::format("SIGNUP: Creating signup entry for '{}', uuid='{}'",UserName, SignupUUID)); | ||||||
|  |  | ||||||
|         Poco::JSON::Object  Body; |         Poco::JSON::Object  Body; | ||||||
|         OpenAPIRequestPost  CreateUser( uSERVICE_SECURITY, "/api/v1/signup", { |         OpenAPIRequestPost  CreateUser( uSERVICE_SECURITY, "/api/v1/signup", { | ||||||
|                 { "email", UserName }, |                 { "email", UserName }, | ||||||
|                 { "signupUUID" , SignupUUID }, |                 { "signupUUID" , SignupUUID }, | ||||||
|                 { "owner" , SignupOperator.info.id }, |                 { "owner" , SignupOperator.info.id }, | ||||||
|  |                 { "operatorName", SignupOperator.registrationId } | ||||||
|         }, Body, 30000); |         }, Body, 30000); | ||||||
|  |  | ||||||
|         Poco::JSON::Object::Ptr Answer; |         Poco::JSON::Object::Ptr Answer; | ||||||
| @@ -111,12 +115,12 @@ namespace OpenWifi { | |||||||
|             UI.from_json(Answer); |             UI.from_json(Answer); | ||||||
|             std::ostringstream os; |             std::ostringstream os; | ||||||
|             Answer->stringify(os); |             Answer->stringify(os); | ||||||
|             Logger().information(fmt::format("SIGNUP: email: '{}' signupID: '{}' userId: '{}'", UserName, SignupUUID, UI.id)); |             poco_debug(Logger(),fmt::format("SIGNUP: email: '{}' signupID: '{}' userId: '{}'", UserName, SignupUUID, UI.id)); | ||||||
|  |  | ||||||
|             //  so create the Signup entry and modify the inventory |             //  so create the Signup entry and modify the inventory | ||||||
|             ProvObjects::SignupEntry    SE; |             ProvObjects::SignupEntry    SE; | ||||||
|             SE.info.id = SignupUUID; |             SE.info.id = SignupUUID; | ||||||
|             SE.info.created = SE.info.modified = SE.submitted = OpenWifi::Now(); |             SE.info.created = SE.info.modified = SE.submitted = Utils::Now(); | ||||||
|             SE.completed = 0 ; |             SE.completed = 0 ; | ||||||
|             SE.macAddress = macAddress; |             SE.macAddress = macAddress; | ||||||
|             SE.error = 0 ; |             SE.error = 0 ; | ||||||
| @@ -137,13 +141,13 @@ namespace OpenWifi { | |||||||
|                 StateDoc.set("claimerId", UI.id); |                 StateDoc.set("claimerId", UI.id); | ||||||
|                 StateDoc.set("signupUUID", SignupUUID); |                 StateDoc.set("signupUUID", SignupUUID); | ||||||
|                 StateDoc.set("errorCode",0); |                 StateDoc.set("errorCode",0); | ||||||
|                 StateDoc.set("date", OpenWifi::Now()); |                 StateDoc.set("date", Utils::Now()); | ||||||
|                 StateDoc.set("status", "waiting for email-verification"); |                 StateDoc.set("status", "waiting for email-verification"); | ||||||
|                 std::ostringstream os2; |                 std::ostringstream os2; | ||||||
|                 StateDoc.stringify(os2); |                 StateDoc.stringify(os2); | ||||||
|                 IT.realMacAddress = macAddress; |                 IT.realMacAddress = macAddress; | ||||||
|                 IT.state = os2.str(); |                 IT.state = os2.str(); | ||||||
|                 IT.info.modified = OpenWifi::Now(); |                 IT.info.modified = Utils::Now(); | ||||||
|                 std::cout << "Updating inventory entry: " << SE.macAddress << std::endl; |                 std::cout << "Updating inventory entry: " << SE.macAddress << std::endl; | ||||||
|                 StorageService()->InventoryDB().UpdateRecord("id",IT.info.id,IT); |                 StorageService()->InventoryDB().UpdateRecord("id",IT.info.id,IT); | ||||||
|             } |             } | ||||||
| @@ -160,22 +164,22 @@ namespace OpenWifi { | |||||||
|         auto SignupUUID = GetParameter("signupUUID"); |         auto SignupUUID = GetParameter("signupUUID"); | ||||||
|         auto Operation = GetParameter("operation"); |         auto Operation = GetParameter("operation"); | ||||||
|  |  | ||||||
|         Logger().information(fmt::format("signup-progress: {} - {} ", SignupUUID, Operation)); |         poco_information(Logger(),fmt::format("signup-progress: {} - {} ", SignupUUID, Operation)); | ||||||
|         if(SignupUUID.empty() || Operation.empty()) { |         if(SignupUUID.empty() || Operation.empty()) { | ||||||
|             return BadRequest(RESTAPI::Errors::MissingOrInvalidParameters); |             return BadRequest(RESTAPI::Errors::MissingOrInvalidParameters); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         ProvObjects::SignupEntry    SE; |         ProvObjects::SignupEntry    SE; | ||||||
|         Logger().information(fmt::format("signup-progress: {} - {} fetching entry", SignupUUID, Operation)); |         poco_information(Logger(),fmt::format("signup-progress: {} - {} fetching entry", SignupUUID, Operation)); | ||||||
|         if(!StorageService()->SignupDB().GetRecord("id",SignupUUID,SE)) { |         if(!StorageService()->SignupDB().GetRecord("id",SignupUUID,SE)) { | ||||||
|             return NotFound(); |             return NotFound(); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         Logger().information(fmt::format("signup-progress: {} - {} fetching entry", SignupUUID, Operation)); |         poco_debug(Logger(),fmt::format("signup-progress: {} - {} fetching entry", SignupUUID, Operation)); | ||||||
|         if(Operation == "emailVerified" && SE.statusCode==ProvObjects::SignupStatusCodes::SignupWaitingForEmail) { |         if(Operation == "emailVerified" && SE.statusCode==ProvObjects::SignupStatusCodes::SignupWaitingForEmail) { | ||||||
|             Logger().information(fmt::format("{}: email {} verified.",SE.info.id, SE.email)); |             poco_information(Logger(),fmt::format("{}: email {} verified.",SE.info.id, SE.email)); | ||||||
|             std::cout << "Verified email for : " << SE.email << std::endl; |             std::cout << "Verified email for : " << SE.email << std::endl; | ||||||
|             SE.info.modified = OpenWifi::Now(); |             SE.info.modified = Utils::Now(); | ||||||
|             SE.status = "emailVerified"; |             SE.status = "emailVerified"; | ||||||
|             SE.statusCode = ProvObjects::SignupStatusCodes::SignupWaitingForDevice; |             SE.statusCode = ProvObjects::SignupStatusCodes::SignupWaitingForDevice; | ||||||
|             StorageService()->SignupDB().UpdateRecord("id", SE.info.id, SE); |             StorageService()->SignupDB().UpdateRecord("id", SE.info.id, SE); | ||||||
| @@ -184,7 +188,7 @@ namespace OpenWifi { | |||||||
|             SE.to_json(Answer); |             SE.to_json(Answer); | ||||||
|             return ReturnObject(Answer); |             return ReturnObject(Answer); | ||||||
|         } |         } | ||||||
|         Logger().information(fmt::format("signup-progress: {} - {} something is bad", SignupUUID, Operation)); |         poco_information(Logger(),fmt::format("signup-progress: {} - {} something is bad", SignupUUID, Operation)); | ||||||
|  |  | ||||||
|         return BadRequest(RESTAPI::Errors::UnknownId); |         return BadRequest(RESTAPI::Errors::UnknownId); | ||||||
|     } |     } | ||||||
| @@ -195,11 +199,11 @@ namespace OpenWifi { | |||||||
|         auto macAddress = GetParameter("macAddress"); |         auto macAddress = GetParameter("macAddress"); | ||||||
|         auto List = GetBoolParameter("listOnly",false); |         auto List = GetBoolParameter("listOnly",false); | ||||||
|  |  | ||||||
|         Logger().information(fmt::format("Looking for signup for {}",EMail)); |         poco_information(Logger(),fmt::format("Looking for signup for {}",EMail)); | ||||||
|         Poco::JSON::Object          Answer; |         Poco::JSON::Object          Answer; | ||||||
|         ProvObjects::SignupEntry    SE; |         ProvObjects::SignupEntry    SE; | ||||||
|         if(!SignupUUID.empty()) { |         if(!SignupUUID.empty()) { | ||||||
|             Logger().information(fmt::format("Looking for signup for {}: Signup {}",EMail, SignupUUID)); |             poco_information(Logger(),fmt::format("Looking for signup for {}: Signup {}",EMail, SignupUUID)); | ||||||
|             if(StorageService()->SignupDB().GetRecord("id", SignupUUID, SE)) { |             if(StorageService()->SignupDB().GetRecord("id", SignupUUID, SE)) { | ||||||
|                 SE.to_json(Answer); |                 SE.to_json(Answer); | ||||||
|                 return ReturnObject(Answer); |                 return ReturnObject(Answer); | ||||||
| @@ -207,25 +211,25 @@ namespace OpenWifi { | |||||||
|             return NotFound(); |             return NotFound(); | ||||||
|         } else if(!EMail.empty()) { |         } else if(!EMail.empty()) { | ||||||
|             SignupDB::RecordVec SEs; |             SignupDB::RecordVec SEs; | ||||||
|             Logger().information(fmt::format("Looking for signup for {}: Signup {}",EMail, SignupUUID)); |             poco_information(Logger(),fmt::format("Looking for signup for {}: Signup {}",EMail, SignupUUID)); | ||||||
|             if(StorageService()->SignupDB().GetRecords(0,100,SEs, " email='"+EMail+"' ")) { |             if(StorageService()->SignupDB().GetRecords(0,100,SEs, " email='"+EMail+"' ")) { | ||||||
|                 return ReturnObject("signups",SEs); |                 return ReturnObject("signups",SEs); | ||||||
|             } |             } | ||||||
|             return NotFound(); |             return NotFound(); | ||||||
|         } else if(!macAddress.empty()) { |         } else if(!macAddress.empty()) { | ||||||
|             SignupDB::RecordVec SEs; |             SignupDB::RecordVec SEs; | ||||||
|             Logger().information(fmt::format("Looking for signup for {}: Mac {}",EMail, macAddress)); |             poco_information(Logger(),fmt::format("Looking for signup for {}: Mac {}",EMail, macAddress)); | ||||||
|             if(StorageService()->SignupDB().GetRecords(0,100,SEs, " serialNumber='"+macAddress+"' ")) { |             if(StorageService()->SignupDB().GetRecords(0,100,SEs, " serialNumber='"+macAddress+"' ")) { | ||||||
|                 return ReturnObject("signups",SEs); |                 return ReturnObject("signups",SEs); | ||||||
|             } |             } | ||||||
|             return NotFound(); |             return NotFound(); | ||||||
|         } else if(List) { |         } else if(List) { | ||||||
|             Logger().information(fmt::format("Returning list of signups...",EMail, macAddress)); |             poco_information(Logger(),fmt::format("Returning list of signups...",EMail, macAddress)); | ||||||
|             SignupDB::RecordVec SEs; |             SignupDB::RecordVec SEs; | ||||||
|             StorageService()->SignupDB().GetRecords(0,100,SEs); |             StorageService()->SignupDB().GetRecords(0,100,SEs); | ||||||
|             return ReturnObject("signups",SEs); |             return ReturnObject("signups",SEs); | ||||||
|         } |         } | ||||||
|         Logger().information(fmt::format("Bad signup get",EMail, macAddress)); |         poco_information(Logger(),fmt::format("Bad signup get",EMail, macAddress)); | ||||||
|         return BadRequest(RESTAPI::Errors::MissingOrInvalidParameters); |         return BadRequest(RESTAPI::Errors::MissingOrInvalidParameters); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -3,13 +3,13 @@ | |||||||
| // | // | ||||||
|  |  | ||||||
| #pragma once | #pragma once | ||||||
|  | #include "framework/RESTAPI_Handler.h" | ||||||
| #include "framework/MicroService.h" | #include "StorageService.h" | ||||||
|  |  | ||||||
| namespace OpenWifi { | namespace OpenWifi { | ||||||
|     class RESTAPI_signup_handler : public RESTAPIHandler { |     class RESTAPI_signup_handler : public RESTAPIHandler { | ||||||
|     public: |     public: | ||||||
|         RESTAPI_signup_handler(const RESTAPIHandler::BindingMap &bindings, Poco::Logger &L, RESTAPI_GenericServer & Server, uint64_t TransactionId, bool Internal) |         RESTAPI_signup_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_POST, |                                          Poco::Net::HTTPRequest::HTTP_POST, | ||||||
|   | |||||||
| @@ -3,14 +3,13 @@ | |||||||
| // | // | ||||||
|  |  | ||||||
| #pragma once | #pragma once | ||||||
|  | #include "framework/RESTAPI_Handler.h" | ||||||
| #include "framework/MicroService.h" |  | ||||||
| #include "StorageService.h" | #include "StorageService.h" | ||||||
|  |  | ||||||
| namespace OpenWifi { | namespace OpenWifi { | ||||||
|     class RESTAPI_sub_devices_handler : public RESTAPIHandler { |     class RESTAPI_sub_devices_handler : public RESTAPIHandler { | ||||||
|     public: |     public: | ||||||
|         RESTAPI_sub_devices_handler(const RESTAPIHandler::BindingMap &bindings, Poco::Logger &L, RESTAPI_GenericServer & Server, uint64_t TransactionId, bool Internal) |         RESTAPI_sub_devices_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_POST, |                                          Poco::Net::HTTPRequest::HTTP_GET, Poco::Net::HTTPRequest::HTTP_POST, | ||||||
|   | |||||||
| @@ -3,15 +3,14 @@ | |||||||
| // | // | ||||||
|  |  | ||||||
| #pragma once | #pragma once | ||||||
|  | #include "framework/RESTAPI_Handler.h" | ||||||
| #include "framework/MicroService.h" |  | ||||||
| #include "StorageService.h" | #include "StorageService.h" | ||||||
|  |  | ||||||
| namespace OpenWifi { | namespace OpenWifi { | ||||||
|  |  | ||||||
|     class RESTAPI_sub_devices_list_handler : public RESTAPIHandler { |     class RESTAPI_sub_devices_list_handler : public RESTAPIHandler { | ||||||
|     public: |     public: | ||||||
|         RESTAPI_sub_devices_list_handler(const RESTAPIHandler::BindingMap &bindings, Poco::Logger &L, RESTAPI_GenericServer & Server, uint64_t TransactionId, bool Internal) |         RESTAPI_sub_devices_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, | ||||||
|   | |||||||
| @@ -1,15 +1,15 @@ | |||||||
| // | // | ||||||
| // Created by stephane bourque on 2022-02-23. | // Created by stephane bourque on 2022-02-23. | ||||||
| // | // | ||||||
| #pragma once |  | ||||||
|  |  | ||||||
| #include "framework/MicroService.h" | #pragma once | ||||||
|  | #include "framework/RESTAPI_Handler.h" | ||||||
| #include "StorageService.h" | #include "StorageService.h" | ||||||
|  |  | ||||||
| namespace OpenWifi { | namespace OpenWifi { | ||||||
|     class RESTAPI_variables_handler : public RESTAPIHandler { |     class RESTAPI_variables_handler : public RESTAPIHandler { | ||||||
|     public: |     public: | ||||||
|         RESTAPI_variables_handler(const RESTAPIHandler::BindingMap &bindings, Poco::Logger &L, RESTAPI_GenericServer & Server, uint64_t TransactionId, bool Internal) |         RESTAPI_variables_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_POST, |                                          Poco::Net::HTTPRequest::HTTP_GET, Poco::Net::HTTPRequest::HTTP_POST, | ||||||
|   | |||||||
| @@ -3,15 +3,14 @@ | |||||||
| // | // | ||||||
|  |  | ||||||
| #pragma once | #pragma once | ||||||
|  | #include "framework/RESTAPI_Handler.h" | ||||||
| #include "framework/MicroService.h" |  | ||||||
| #include "StorageService.h" | #include "StorageService.h" | ||||||
|  |  | ||||||
| namespace OpenWifi { | namespace OpenWifi { | ||||||
|  |  | ||||||
|     class RESTAPI_variables_list_handler : public RESTAPIHandler { |     class RESTAPI_variables_list_handler : public RESTAPIHandler { | ||||||
|     public: |     public: | ||||||
|         RESTAPI_variables_list_handler(const RESTAPIHandler::BindingMap &bindings, Poco::Logger &L, RESTAPI_GenericServer & Server, uint64_t TransactionId, bool Internal) |         RESTAPI_variables_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, | ||||||
|   | |||||||
| @@ -15,6 +15,8 @@ | |||||||
| #include "Tasks/VenueConfigUpdater.h" | #include "Tasks/VenueConfigUpdater.h" | ||||||
| #include "Tasks/VenueRebooter.h" | #include "Tasks/VenueRebooter.h" | ||||||
| #include "Tasks/VenueUpgrade.h" | #include "Tasks/VenueUpgrade.h" | ||||||
|  | #include "framework/CIDR.h" | ||||||
|  | #include "framework/MicroServiceFuncs.h" | ||||||
|  |  | ||||||
| #include "Kafka_ProvUpdater.h" | #include "Kafka_ProvUpdater.h" | ||||||
|  |  | ||||||
| @@ -228,7 +230,7 @@ namespace OpenWifi{ | |||||||
|  |  | ||||||
|             Poco::JSON::Object  Answer; |             Poco::JSON::Object  Answer; | ||||||
|             SNL.serialNumbers = Existing.devices; |             SNL.serialNumbers = Existing.devices; | ||||||
|             auto JobId = MicroService::instance().CreateUUID(); |             auto JobId = MicroServiceCreateUUID(); | ||||||
|             Types::StringVec Parameters{UUID};; |             Types::StringVec Parameters{UUID};; | ||||||
|             auto NewJob = new VenueConfigUpdater(JobId,"VenueConfigurationUpdater", Parameters, 0, UserInfo_.userinfo, Logger()); |             auto NewJob = new VenueConfigUpdater(JobId,"VenueConfigurationUpdater", Parameters, 0, UserInfo_.userinfo, Logger()); | ||||||
|             JobController()->AddJob(dynamic_cast<Job*>(NewJob)); |             JobController()->AddJob(dynamic_cast<Job*>(NewJob)); | ||||||
| @@ -242,7 +244,7 @@ namespace OpenWifi{ | |||||||
|  |  | ||||||
|             Poco::JSON::Object  Answer; |             Poco::JSON::Object  Answer; | ||||||
|             SNL.serialNumbers = Existing.devices; |             SNL.serialNumbers = Existing.devices; | ||||||
|             auto JobId = MicroService::instance().CreateUUID(); |             auto JobId = MicroServiceCreateUUID(); | ||||||
|             Types::StringVec Parameters{UUID};; |             Types::StringVec Parameters{UUID};; | ||||||
|             auto NewJob = new VenueUpgrade(JobId,"VenueFirmwareUpgrade", Parameters, 0, UserInfo_.userinfo, Logger()); |             auto NewJob = new VenueUpgrade(JobId,"VenueFirmwareUpgrade", Parameters, 0, UserInfo_.userinfo, Logger()); | ||||||
|             JobController()->AddJob(dynamic_cast<Job*>(NewJob)); |             JobController()->AddJob(dynamic_cast<Job*>(NewJob)); | ||||||
| @@ -256,7 +258,7 @@ namespace OpenWifi{ | |||||||
|  |  | ||||||
|             Poco::JSON::Object  Answer; |             Poco::JSON::Object  Answer; | ||||||
|             SNL.serialNumbers = Existing.devices; |             SNL.serialNumbers = Existing.devices; | ||||||
|             auto JobId = MicroService::instance().CreateUUID(); |             auto JobId = MicroServiceCreateUUID(); | ||||||
|             Types::StringVec Parameters{UUID};; |             Types::StringVec Parameters{UUID};; | ||||||
|             auto NewJob = new VenueRebooter(JobId,"VenueRebooter", Parameters, 0, UserInfo_.userinfo, Logger()); |             auto NewJob = new VenueRebooter(JobId,"VenueRebooter", Parameters, 0, UserInfo_.userinfo, Logger()); | ||||||
|             JobController()->AddJob(dynamic_cast<Job*>(NewJob)); |             JobController()->AddJob(dynamic_cast<Job*>(NewJob)); | ||||||
|   | |||||||
| @@ -7,14 +7,13 @@ | |||||||
| // | // | ||||||
|  |  | ||||||
| #pragma once | #pragma once | ||||||
|  | #include "framework/RESTAPI_Handler.h" | ||||||
| #include "framework/MicroService.h" |  | ||||||
| #include "StorageService.h" | #include "StorageService.h" | ||||||
|  |  | ||||||
| namespace OpenWifi { | namespace OpenWifi { | ||||||
|     class RESTAPI_venue_handler : public RESTAPIHandler { |     class RESTAPI_venue_handler : public RESTAPIHandler { | ||||||
|     public: |     public: | ||||||
|         RESTAPI_venue_handler(const RESTAPIHandler::BindingMap &bindings, Poco::Logger &L, RESTAPI_GenericServer & Server, uint64_t TransactionId, bool Internal) |         RESTAPI_venue_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_POST, |             Poco::Net::HTTPRequest::HTTP_GET, Poco::Net::HTTPRequest::HTTP_POST, | ||||||
|   | |||||||
| @@ -3,15 +3,14 @@ | |||||||
| // | // | ||||||
|  |  | ||||||
| #pragma once | #pragma once | ||||||
|  | #include "framework/RESTAPI_Handler.h" | ||||||
| #include "framework/MicroService.h" |  | ||||||
| #include "StorageService.h" | #include "StorageService.h" | ||||||
|  |  | ||||||
| namespace OpenWifi { | namespace OpenWifi { | ||||||
|  |  | ||||||
|     class RESTAPI_venue_list_handler : public RESTAPIHandler { |     class RESTAPI_venue_list_handler : public RESTAPIHandler { | ||||||
|     public: |     public: | ||||||
|         RESTAPI_venue_list_handler(const RESTAPIHandler::BindingMap &bindings, Poco::Logger &L, RESTAPI_GenericServer & Server, uint64_t TransactionId, bool Internal) |         RESTAPI_venue_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, | ||||||
|   | |||||||
| @@ -4,7 +4,7 @@ | |||||||
|  |  | ||||||
| #include "RESTAPI_AnalyticsObjects.h" | #include "RESTAPI_AnalyticsObjects.h" | ||||||
| #include "RESTAPI_ProvObjects.h" | #include "RESTAPI_ProvObjects.h" | ||||||
| #include "framework/MicroService.h" | #include "framework/RESTAPI_utils.h" | ||||||
|  |  | ||||||
| using OpenWifi::RESTAPI_utils::field_to_json; | using OpenWifi::RESTAPI_utils::field_to_json; | ||||||
| using OpenWifi::RESTAPI_utils::field_from_json; | using OpenWifi::RESTAPI_utils::field_from_json; | ||||||
|   | |||||||
| @@ -5,6 +5,7 @@ | |||||||
| #pragma once | #pragma once | ||||||
|  |  | ||||||
| #include "RESTAPI_ProvObjects.h" | #include "RESTAPI_ProvObjects.h" | ||||||
|  | #include "framework/utils.h" | ||||||
| #include <vector> | #include <vector> | ||||||
|  |  | ||||||
| namespace OpenWifi { | namespace OpenWifi { | ||||||
| @@ -375,7 +376,7 @@ namespace OpenWifi { | |||||||
|         }; |         }; | ||||||
|  |  | ||||||
|         struct WifiClientHistory { |         struct WifiClientHistory { | ||||||
|             uint64_t        timestamp=OpenWifi::Now(); |             uint64_t        timestamp=Utils::Now(); | ||||||
|             std::string     station_id; |             std::string     station_id; | ||||||
|             std::string     bssid; |             std::string     bssid; | ||||||
|             std::string     ssid; |             std::string     ssid; | ||||||
|   | |||||||
| @@ -3,7 +3,7 @@ | |||||||
| // | // | ||||||
|  |  | ||||||
| #include "RESTAPI_CertObjects.h" | #include "RESTAPI_CertObjects.h" | ||||||
| #include "framework/MicroService.h" | #include "framework/RESTAPI_utils.h" | ||||||
|  |  | ||||||
| using OpenWifi::RESTAPI_utils::field_to_json; | using OpenWifi::RESTAPI_utils::field_to_json; | ||||||
| using OpenWifi::RESTAPI_utils::field_from_json; | using OpenWifi::RESTAPI_utils::field_from_json; | ||||||
| @@ -154,6 +154,7 @@ namespace OpenWifi::CertObjects { | |||||||
|         field_to_json(Obj,"submitted", submitted); |         field_to_json(Obj,"submitted", submitted); | ||||||
|         field_to_json(Obj,"started", started); |         field_to_json(Obj,"started", started); | ||||||
|         field_to_json(Obj,"completed", completed); |         field_to_json(Obj,"completed", completed); | ||||||
|  |         field_to_json(Obj,"requesterUsername", requesterUsername); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     bool JobEntry::from_json(const Poco::JSON::Object::Ptr &Obj) { |     bool JobEntry::from_json(const Poco::JSON::Object::Ptr &Obj) { | ||||||
| @@ -171,6 +172,7 @@ namespace OpenWifi::CertObjects { | |||||||
|             field_from_json(Obj,"submitted", submitted); |             field_from_json(Obj,"submitted", submitted); | ||||||
|             field_from_json(Obj,"started", started); |             field_from_json(Obj,"started", started); | ||||||
|             field_from_json(Obj,"completed", completed); |             field_from_json(Obj,"completed", completed); | ||||||
|  |             field_from_json(Obj,"requesterUsername", requesterUsername); | ||||||
|             return true; |             return true; | ||||||
|         } catch (...) { |         } catch (...) { | ||||||
|         } |         } | ||||||
|   | |||||||
| @@ -91,6 +91,7 @@ namespace OpenWifi::CertObjects { | |||||||
|         uint64_t                        submitted=0; |         uint64_t                        submitted=0; | ||||||
|         uint64_t                        started=0; |         uint64_t                        started=0; | ||||||
|         uint64_t                        completed=0; |         uint64_t                        completed=0; | ||||||
|  |         std::string                     requesterUsername; | ||||||
|  |  | ||||||
|         void to_json(Poco::JSON::Object &Obj) const; |         void to_json(Poco::JSON::Object &Obj) const; | ||||||
|         bool from_json(const Poco::JSON::Object::Ptr &Obj); |         bool from_json(const Poco::JSON::Object::Ptr &Obj); | ||||||
|   | |||||||
| @@ -3,7 +3,8 @@ | |||||||
| // | // | ||||||
|  |  | ||||||
| #include "RESTAPI_FMSObjects.h" | #include "RESTAPI_FMSObjects.h" | ||||||
| #include "framework/MicroService.h" | #include "framework/RESTAPI_utils.h" | ||||||
|  | #include "framework/utils.h" | ||||||
|  |  | ||||||
| using OpenWifi::RESTAPI_utils::field_to_json; | using OpenWifi::RESTAPI_utils::field_to_json; | ||||||
| using OpenWifi::RESTAPI_utils::field_from_json; | using OpenWifi::RESTAPI_utils::field_from_json; | ||||||
| @@ -233,7 +234,7 @@ namespace OpenWifi::FMSObjects { | |||||||
|         UnknownFirmwares_.clear(); |         UnknownFirmwares_.clear(); | ||||||
|         totalSecondsOld_.clear(); |         totalSecondsOld_.clear(); | ||||||
|         numberOfDevices = 0 ; |         numberOfDevices = 0 ; | ||||||
|         snapshot = OpenWifi::Now(); |         snapshot = Utils::Now(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     bool DeviceReport::from_json([[maybe_unused]] const Poco::JSON::Object::Ptr &Obj) { |     bool DeviceReport::from_json([[maybe_unused]] const Poco::JSON::Object::Ptr &Obj) { | ||||||
|   | |||||||
| @@ -11,12 +11,13 @@ | |||||||
|  |  | ||||||
| #include "Daemon.h" | #include "Daemon.h" | ||||||
| #ifdef	TIP_GATEWAY_SERVICE | #ifdef	TIP_GATEWAY_SERVICE | ||||||
| #include "DeviceRegistry.h" | #include "AP_WS_Server.h" | ||||||
| #include "CapabilitiesCache.h" | #include "CapabilitiesCache.h" | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #include "RESTAPI_GWobjects.h" | #include "RESTAPI_GWobjects.h" | ||||||
| #include "framework/MicroService.h" | #include "framework/RESTAPI_utils.h" | ||||||
|  | #include "framework/utils.h" | ||||||
|  |  | ||||||
| using OpenWifi::RESTAPI_utils::field_to_json; | using OpenWifi::RESTAPI_utils::field_to_json; | ||||||
| using OpenWifi::RESTAPI_utils::field_from_json; | using OpenWifi::RESTAPI_utils::field_from_json; | ||||||
| @@ -49,6 +50,10 @@ namespace OpenWifi::GWObjects { | |||||||
| 		field_to_json(Obj,"entity", entity); | 		field_to_json(Obj,"entity", entity); | ||||||
| 		field_to_json(Obj,"modified", modified); | 		field_to_json(Obj,"modified", modified); | ||||||
| 		field_to_json(Obj,"locale", locale); | 		field_to_json(Obj,"locale", locale); | ||||||
|  | 		field_to_json(Obj,"restrictedDevice", restrictedDevice); | ||||||
|  | 		field_to_json(Obj,"pendingConfiguration", pendingConfiguration); | ||||||
|  | 		field_to_json(Obj,"pendingConfigurationCmd", pendingConfigurationCmd); | ||||||
|  | 		field_to_json(Obj,"restrictionDetails", restrictionDetails); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	void Device::to_json_with_status(Poco::JSON::Object &Obj) const { | 	void Device::to_json_with_status(Poco::JSON::Object &Obj) const { | ||||||
| @@ -57,7 +62,7 @@ namespace OpenWifi::GWObjects { | |||||||
| #ifdef TIP_GATEWAY_SERVICE | #ifdef TIP_GATEWAY_SERVICE | ||||||
| 		ConnectionState ConState; | 		ConnectionState ConState; | ||||||
|  |  | ||||||
| 		if (DeviceRegistry()->GetState(SerialNumber, ConState)) { | 		if (AP_WS_Server()->GetState(SerialNumber, ConState)) { | ||||||
| 			ConState.to_json(Obj); | 			ConState.to_json(Obj); | ||||||
| 		} else { | 		} else { | ||||||
| 			field_to_json(Obj,"ipAddress", ""); | 			field_to_json(Obj,"ipAddress", ""); | ||||||
| @@ -69,6 +74,7 @@ namespace OpenWifi::GWObjects { | |||||||
| 			field_to_json(Obj,"verifiedCertificate", "NO_CERTIFICATE"); | 			field_to_json(Obj,"verifiedCertificate", "NO_CERTIFICATE"); | ||||||
| 			field_to_json(Obj,"associations_2G", (uint64_t) 0); | 			field_to_json(Obj,"associations_2G", (uint64_t) 0); | ||||||
| 			field_to_json(Obj,"associations_5G", (uint64_t) 0); | 			field_to_json(Obj,"associations_5G", (uint64_t) 0); | ||||||
|  | 			field_to_json(Obj,"associations_6G", (uint64_t) 0); | ||||||
| 		} | 		} | ||||||
| #endif | #endif | ||||||
| 	} | 	} | ||||||
| @@ -88,6 +94,10 @@ namespace OpenWifi::GWObjects { | |||||||
| 			field_from_json(Obj,"subscriber", subscriber); | 			field_from_json(Obj,"subscriber", subscriber); | ||||||
| 			field_from_json(Obj,"entity", entity); | 			field_from_json(Obj,"entity", entity); | ||||||
| 			field_from_json(Obj,"locale", locale); | 			field_from_json(Obj,"locale", locale); | ||||||
|  | 			field_from_json(Obj,"restrictedDevice", restrictedDevice); | ||||||
|  | 			field_from_json(Obj,"pendingConfiguration", pendingConfiguration); | ||||||
|  | 			field_from_json(Obj,"pendingConfigurationCmd", pendingConfigurationCmd); | ||||||
|  | 			field_from_json(Obj,"restrictionDetails", restrictionDetails); | ||||||
| 			return true; | 			return true; | ||||||
| 		} catch (const Poco::Exception &E) { | 		} catch (const Poco::Exception &E) { | ||||||
| 		} | 		} | ||||||
| @@ -198,11 +208,17 @@ namespace OpenWifi::GWObjects { | |||||||
| 		field_to_json(Obj,"lastContact", LastContact); | 		field_to_json(Obj,"lastContact", LastContact); | ||||||
| 		field_to_json(Obj,"associations_2G", Associations_2G); | 		field_to_json(Obj,"associations_2G", Associations_2G); | ||||||
| 		field_to_json(Obj,"associations_5G", Associations_5G); | 		field_to_json(Obj,"associations_5G", Associations_5G); | ||||||
|  | 		field_to_json(Obj,"associations_6G", Associations_6G); | ||||||
| 		field_to_json(Obj,"webSocketClients", webSocketClients); | 		field_to_json(Obj,"webSocketClients", webSocketClients); | ||||||
| 		field_to_json(Obj,"websocketPackets", websocketPackets); | 		field_to_json(Obj,"websocketPackets", websocketPackets); | ||||||
| 		field_to_json(Obj,"kafkaClients", kafkaClients); | 		field_to_json(Obj,"kafkaClients", kafkaClients); | ||||||
| 		field_to_json(Obj,"kafkaPackets", kafkaPackets); | 		field_to_json(Obj,"kafkaPackets", kafkaPackets); | ||||||
| 		field_to_json(Obj,"locale", locale); | 		field_to_json(Obj,"locale", locale); | ||||||
|  | 		field_to_json(Obj,"started", started); | ||||||
|  | 		field_to_json(Obj,"sessionId", sessionId); | ||||||
|  | 		field_to_json(Obj,"connectionCompletionTime", connectionCompletionTime); | ||||||
|  | 		field_to_json(Obj,"totalConnectionTime", Utils::Now() - started); | ||||||
|  | 		field_to_json(Obj,"certificateExpiryDate", certificateExpiryDate); | ||||||
|  |  | ||||||
| 		switch(VerifiedCertificate) { | 		switch(VerifiedCertificate) { | ||||||
| 			case NO_CERTIFICATE: | 			case NO_CERTIFICATE: | ||||||
| @@ -218,6 +234,23 @@ namespace OpenWifi::GWObjects { | |||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | 	void DeviceConnectionStatistics::to_json(Poco::JSON::Object &Obj) const { | ||||||
|  | 		field_to_json(Obj,"averageConnectionTime", averageConnectionTime); | ||||||
|  | 		field_to_json(Obj,"connectedDevices", connectedDevices ); | ||||||
|  | 		field_to_json(Obj,"connectingDevices", connectingDevices ); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	bool DeviceConnectionStatistics::from_json(const Poco::JSON::Object::Ptr &Obj) { | ||||||
|  | 		try { | ||||||
|  | 			field_from_json(Obj,"averageConnectionTime", averageConnectionTime); | ||||||
|  | 			field_from_json(Obj,"connectedDevices", connectedDevices ); | ||||||
|  | 			field_from_json(Obj,"connectingDevices", connectingDevices ); | ||||||
|  | 			return true; | ||||||
|  | 		} catch (const Poco::Exception &E) { | ||||||
|  | 		} | ||||||
|  | 		return false; | ||||||
|  | 	} | ||||||
|  |  | ||||||
| 	void RttySessionDetails::to_json(Poco::JSON::Object &Obj) const { | 	void RttySessionDetails::to_json(Poco::JSON::Object &Obj) const { | ||||||
| 		field_to_json(Obj,"serialNumber", SerialNumber); | 		field_to_json(Obj,"serialNumber", SerialNumber); | ||||||
| 		field_to_json(Obj,"server", Server); | 		field_to_json(Obj,"server", Server); | ||||||
| @@ -264,7 +297,7 @@ namespace OpenWifi::GWObjects { | |||||||
| 		lastContact.clear(); | 		lastContact.clear(); | ||||||
| 		associations.clear(); | 		associations.clear(); | ||||||
| 		numberOfDevices = 0 ; | 		numberOfDevices = 0 ; | ||||||
| 		snapshot = OpenWifi::Now(); | 		snapshot = Utils::Now(); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	void CapabilitiesModel::to_json(Poco::JSON::Object &Obj) const{ | 	void CapabilitiesModel::to_json(Poco::JSON::Object &Obj) const{ | ||||||
| @@ -276,9 +309,12 @@ namespace OpenWifi::GWObjects { | |||||||
| 		field_to_json(Obj,"serialNumber",serialNumber); | 		field_to_json(Obj,"serialNumber",serialNumber); | ||||||
| 		field_to_json(Obj,"timeout",timeout); | 		field_to_json(Obj,"timeout",timeout); | ||||||
| 		field_to_json(Obj,"type",type); | 		field_to_json(Obj,"type",type); | ||||||
| 		field_to_json(Obj,"script",script); |  | ||||||
| 		field_to_json(Obj,"scriptId",scriptId); | 		field_to_json(Obj,"scriptId",scriptId); | ||||||
|  | 		field_to_json(Obj,"script",script); | ||||||
| 		field_to_json(Obj,"when",when); | 		field_to_json(Obj,"when",when); | ||||||
|  | 		field_to_json(Obj,"signature", signature); | ||||||
|  | 		field_to_json(Obj,"deferred", deferred); | ||||||
|  | 		field_to_json(Obj,"uri", uri); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	bool ScriptRequest::from_json(const Poco::JSON::Object::Ptr &Obj) { | 	bool ScriptRequest::from_json(const Poco::JSON::Object::Ptr &Obj) { | ||||||
| @@ -289,11 +325,13 @@ namespace OpenWifi::GWObjects { | |||||||
| 			field_from_json(Obj,"script",script); | 			field_from_json(Obj,"script",script); | ||||||
| 			field_from_json(Obj,"scriptId",scriptId); | 			field_from_json(Obj,"scriptId",scriptId); | ||||||
| 			field_from_json(Obj,"when",when); | 			field_from_json(Obj,"when",when); | ||||||
|  | 			field_from_json(Obj,"signature", signature); | ||||||
|  | 			field_from_json(Obj,"deferred", deferred); | ||||||
|  | 			field_from_json(Obj,"uri", uri); | ||||||
| 			return true; | 			return true; | ||||||
| 		} catch (const Poco::Exception &E) { | 		} catch (const Poco::Exception &E) { | ||||||
| 		} | 		} | ||||||
| 		return false; | 		return false; | ||||||
|  |  | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	void RadiusProxyPoolList::to_json(Poco::JSON::Object &Obj) const { | 	void RadiusProxyPoolList::to_json(Poco::JSON::Object &Obj) const { | ||||||
| @@ -314,6 +352,8 @@ namespace OpenWifi::GWObjects { | |||||||
| 		field_to_json(Obj,"description",description); | 		field_to_json(Obj,"description",description); | ||||||
| 		field_to_json(Obj,"authConfig",authConfig); | 		field_to_json(Obj,"authConfig",authConfig); | ||||||
| 		field_to_json(Obj,"acctConfig",acctConfig); | 		field_to_json(Obj,"acctConfig",acctConfig); | ||||||
|  | 		field_to_json(Obj,"coaConfig",coaConfig); | ||||||
|  | 		field_to_json(Obj,"useByDefault",useByDefault); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	bool RadiusProxyPool::from_json(const Poco::JSON::Object::Ptr &Obj) { | 	bool RadiusProxyPool::from_json(const Poco::JSON::Object::Ptr &Obj) { | ||||||
| @@ -322,6 +362,8 @@ namespace OpenWifi::GWObjects { | |||||||
| 			field_from_json(Obj,"description",description); | 			field_from_json(Obj,"description",description); | ||||||
| 			field_from_json(Obj,"authConfig",authConfig); | 			field_from_json(Obj,"authConfig",authConfig); | ||||||
| 			field_from_json(Obj,"acctConfig",acctConfig); | 			field_from_json(Obj,"acctConfig",acctConfig); | ||||||
|  | 			field_from_json(Obj,"coaConfig",coaConfig); | ||||||
|  | 			field_from_json(Obj,"useByDefault",useByDefault); | ||||||
| 			return true; | 			return true; | ||||||
| 		} catch (const Poco::Exception &E) { | 		} catch (const Poco::Exception &E) { | ||||||
| 		} | 		} | ||||||
| @@ -329,7 +371,7 @@ namespace OpenWifi::GWObjects { | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	void RadiusProxyServerConfig::to_json(Poco::JSON::Object &Obj) const { | 	void RadiusProxyServerConfig::to_json(Poco::JSON::Object &Obj) const { | ||||||
| 		field_to_json(Obj,"policy",strategy); | 		field_to_json(Obj,"strategy",strategy); | ||||||
| 		field_to_json(Obj,"monitor",monitor); | 		field_to_json(Obj,"monitor",monitor); | ||||||
| 		field_to_json(Obj,"monitorMethod",monitorMethod); | 		field_to_json(Obj,"monitorMethod",monitorMethod); | ||||||
| 		field_to_json(Obj,"methodParameters",methodParameters); | 		field_to_json(Obj,"methodParameters",methodParameters); | ||||||
| @@ -338,7 +380,7 @@ namespace OpenWifi::GWObjects { | |||||||
|  |  | ||||||
| 	bool RadiusProxyServerConfig::from_json(const Poco::JSON::Object::Ptr &Obj) { | 	bool RadiusProxyServerConfig::from_json(const Poco::JSON::Object::Ptr &Obj) { | ||||||
| 		try { | 		try { | ||||||
| 			field_from_json(Obj,"policy",strategy); | 			field_from_json(Obj,"strategy",strategy); | ||||||
| 			field_from_json(Obj,"monitor",monitor); | 			field_from_json(Obj,"monitor",monitor); | ||||||
| 			field_from_json(Obj,"monitorMethod",monitorMethod); | 			field_from_json(Obj,"monitorMethod",monitorMethod); | ||||||
| 			field_from_json(Obj,"methodParameters",methodParameters); | 			field_from_json(Obj,"methodParameters",methodParameters); | ||||||
| @@ -354,6 +396,17 @@ namespace OpenWifi::GWObjects { | |||||||
| 		field_to_json(Obj,"ip",ip); | 		field_to_json(Obj,"ip",ip); | ||||||
| 		field_to_json(Obj,"port",port); | 		field_to_json(Obj,"port",port); | ||||||
| 		field_to_json(Obj,"weight",weight); | 		field_to_json(Obj,"weight",weight); | ||||||
|  | 		field_to_json(Obj,"secret",secret); | ||||||
|  | 		field_to_json(Obj,"certificate",certificate); | ||||||
|  | 		field_to_json(Obj,"radsec",radsec); | ||||||
|  | 		field_to_json(Obj,"allowSelfSigned",allowSelfSigned); | ||||||
|  | 		field_to_json(Obj,"radsecPort",radsecPort); | ||||||
|  | 		field_to_json(Obj,"radsecSecret",radsecSecret); | ||||||
|  | 		field_to_json(Obj,"radsecCacerts",radsecCacerts); | ||||||
|  | 		field_to_json(Obj,"radsecCert",radsecCert); | ||||||
|  | 		field_to_json(Obj,"radsecKey",radsecKey); | ||||||
|  | 		field_to_json(Obj,"radsecRealms",radsecRealms); | ||||||
|  | 		field_to_json(Obj,"ignore",ignore); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	bool RadiusProxyServerEntry::from_json(const Poco::JSON::Object::Ptr &Obj) { | 	bool RadiusProxyServerEntry::from_json(const Poco::JSON::Object::Ptr &Obj) { | ||||||
| @@ -362,10 +415,133 @@ namespace OpenWifi::GWObjects { | |||||||
| 			field_from_json(Obj,"ip",ip); | 			field_from_json(Obj,"ip",ip); | ||||||
| 			field_from_json(Obj,"port",port); | 			field_from_json(Obj,"port",port); | ||||||
| 			field_from_json(Obj,"weight",weight); | 			field_from_json(Obj,"weight",weight); | ||||||
|  | 			field_from_json(Obj,"secret",secret); | ||||||
|  | 			field_from_json(Obj,"certificate",certificate); | ||||||
|  | 			field_from_json(Obj,"radsec",radsec); | ||||||
|  | 			field_from_json(Obj,"allowSelfSigned",allowSelfSigned); | ||||||
|  | 			field_from_json(Obj,"radsecSecret",radsecSecret); | ||||||
|  | 			field_from_json(Obj,"radsecPort",radsecPort); | ||||||
|  | 			field_from_json(Obj,"radsecCacerts",radsecCacerts); | ||||||
|  | 			field_from_json(Obj,"radsecCert",radsecCert); | ||||||
|  | 			field_from_json(Obj,"radsecKey",radsecKey); | ||||||
|  | 			field_from_json(Obj,"radsecRealms",radsecRealms); | ||||||
|  | 			field_from_json(Obj,"ignore",ignore); | ||||||
| 			return true; | 			return true; | ||||||
| 		} catch (const Poco::Exception &E) { | 		} catch (const Poco::Exception &E) { | ||||||
| 		} | 		} | ||||||
| 		return false; | 		return false; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | 	void ScriptEntry::to_json(Poco::JSON::Object &Obj) const { | ||||||
|  | 		field_to_json(Obj,"id", id); | ||||||
|  | 		field_to_json(Obj,"name", name); | ||||||
|  | 		field_to_json(Obj,"description", description); | ||||||
|  | 		field_to_json(Obj,"uri", uri); | ||||||
|  | 		field_to_json(Obj,"content", content); | ||||||
|  | 		field_to_json(Obj,"version", version); | ||||||
|  | 		field_to_json(Obj,"type", type); | ||||||
|  | 		field_to_json(Obj,"created", created); | ||||||
|  | 		field_to_json(Obj,"modified", modified); | ||||||
|  | 		field_to_json(Obj,"author", author); | ||||||
|  | 		field_to_json(Obj,"restricted", restricted); | ||||||
|  | 		field_to_json(Obj,"deferred", deferred); | ||||||
|  | 		field_to_json(Obj,"timeout", timeout); | ||||||
|  | 		field_to_json(Obj,"defaultUploadURI", defaultUploadURI); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	bool ScriptEntry::from_json(const Poco::JSON::Object::Ptr &Obj) { | ||||||
|  | 		try { | ||||||
|  | 			field_from_json(Obj,"id", id); | ||||||
|  | 			field_from_json(Obj,"name", name); | ||||||
|  | 			field_from_json(Obj,"description", description); | ||||||
|  | 			field_from_json(Obj,"uri", uri); | ||||||
|  | 			field_from_json(Obj,"content", content); | ||||||
|  | 			field_from_json(Obj,"version", version); | ||||||
|  | 			field_from_json(Obj,"type", type); | ||||||
|  | 			field_from_json(Obj,"created", created); | ||||||
|  | 			field_from_json(Obj,"modified", modified); | ||||||
|  | 			field_from_json(Obj,"author", author); | ||||||
|  | 			field_from_json(Obj,"restricted", restricted); | ||||||
|  | 			field_from_json(Obj,"deferred", deferred); | ||||||
|  | 			field_from_json(Obj,"timeout", timeout); | ||||||
|  | 			field_from_json(Obj,"defaultUploadURI", defaultUploadURI); | ||||||
|  | 			return true; | ||||||
|  | 		} catch (const Poco::Exception &E) { | ||||||
|  | 		} | ||||||
|  | 		return false; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	void ScriptEntryList::to_json(Poco::JSON::Object &Obj) const { | ||||||
|  | 		field_to_json(Obj,"scripts",scripts); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	bool ScriptEntryList::from_json(const Poco::JSON::Object::Ptr &Obj) { | ||||||
|  | 		try { | ||||||
|  | 			field_from_json(Obj,"scripts",scripts); | ||||||
|  | 			return true; | ||||||
|  | 		} catch (const Poco::Exception &E) { | ||||||
|  | 		} | ||||||
|  | 		return false; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	void DeviceRestrictionsKeyInfo::to_json(Poco::JSON::Object &Obj) const { | ||||||
|  | 		field_to_json(Obj,"vendor", vendor); | ||||||
|  | 		field_to_json(Obj,"algo", algo); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	bool DeviceRestrictionsKeyInfo::from_json(const Poco::JSON::Object::Ptr &Obj) { | ||||||
|  | 		try { | ||||||
|  | 			field_from_json(Obj,"vendor", vendor); | ||||||
|  | 			field_from_json(Obj,"algo", algo); | ||||||
|  | 			return true; | ||||||
|  | 		} catch (const Poco::Exception &E) { | ||||||
|  | 		} | ||||||
|  | 		return false; | ||||||
|  |  | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	void DeviceRestrictions::to_json(Poco::JSON::Object &Obj) const { | ||||||
|  | 		field_to_json(Obj,"dfs", dfs); | ||||||
|  | 		field_to_json(Obj,"ssh", ssh); | ||||||
|  | 		field_to_json(Obj,"rtty", rtty); | ||||||
|  | 		field_to_json(Obj,"tty", tty); | ||||||
|  | 		field_to_json(Obj,"developer", developer); | ||||||
|  | 		field_to_json(Obj,"upgrade", upgrade); | ||||||
|  | 		field_to_json(Obj,"commands", commands); | ||||||
|  | 		field_to_json(Obj,"country", country); | ||||||
|  | 		field_to_json(Obj,"key_info", key_info); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	bool DeviceRestrictions::from_json(const Poco::JSON::Object::Ptr &Obj) { | ||||||
|  | 		try { | ||||||
|  | 			field_from_json(Obj,"dfs", dfs); | ||||||
|  | 			field_from_json(Obj,"ssh", ssh); | ||||||
|  | 			field_from_json(Obj,"rtty", rtty); | ||||||
|  | 			field_from_json(Obj,"tty", tty); | ||||||
|  | 			field_from_json(Obj,"developer", developer); | ||||||
|  | 			field_from_json(Obj,"upgrade", upgrade); | ||||||
|  | 			field_from_json(Obj,"commands", commands); | ||||||
|  | 			field_from_json(Obj,"country", country); | ||||||
|  | 			field_from_json(Obj,"key_info", key_info); | ||||||
|  | 			return true; | ||||||
|  | 		} catch (const Poco::Exception &E) { | ||||||
|  | 		} | ||||||
|  | 		return false; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	bool DeviceRestrictionsKeyInfo::operator!=(const OpenWifi::GWObjects::DeviceRestrictionsKeyInfo &T) const { | ||||||
|  | 		return (T.algo!=algo) || (T.vendor!=vendor); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	bool DeviceRestrictions::operator!=(const OpenWifi::GWObjects::DeviceRestrictions &T) const { | ||||||
|  | 		return (	(T.dfs!=dfs)					|| | ||||||
|  | 					(T.rtty!=rtty)					|| | ||||||
|  | 					(T.upgrade!=upgrade)		|| | ||||||
|  | 					(T.commands != commands)		|| | ||||||
|  | 					(T.developer != developer)		|| | ||||||
|  | 					(T.ssh !=ssh) 					|| | ||||||
|  | 					(T.key_info != key_info)		|| | ||||||
|  | 					(T.country != country) ); | ||||||
|  | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -28,19 +28,52 @@ namespace OpenWifi::GWObjects { | |||||||
| 		uint64_t TX = 0, RX = 0; | 		uint64_t TX = 0, RX = 0; | ||||||
| 		uint64_t Associations_2G=0; | 		uint64_t Associations_2G=0; | ||||||
| 		uint64_t Associations_5G=0; | 		uint64_t Associations_5G=0; | ||||||
|  | 		uint64_t Associations_6G=0; | ||||||
| 		bool Connected = false; | 		bool Connected = false; | ||||||
| 		uint64_t LastContact=0; | 		uint64_t LastContact=0; | ||||||
| 		std::string Firmware; | 		std::string Firmware; | ||||||
| 		CertificateValidation VerifiedCertificate = NO_CERTIFICATE; | 		CertificateValidation VerifiedCertificate = NO_CERTIFICATE; | ||||||
| 		std::string Compatible; | 		std::string 	Compatible; | ||||||
| 		uint64_t 	kafkaClients=0; | 		uint64_t 		kafkaClients=0; | ||||||
| 		uint64_t 	webSocketClients=0; | 		uint64_t 		webSocketClients=0; | ||||||
| 		uint64_t 	kafkaPackets=0; | 		uint64_t 		kafkaPackets=0; | ||||||
| 		uint64_t 	websocketPackets=0; | 		uint64_t 		websocketPackets=0; | ||||||
| 		std::string locale; | 		std::string 	locale; | ||||||
|  | 		uint64_t 		started=0; | ||||||
|  | 		uint64_t 		sessionId=0; | ||||||
|  | 		double      	connectionCompletionTime=0.0; | ||||||
|  | 		std::uint64_t	certificateExpiryDate=0; | ||||||
|  |  | ||||||
| 		void to_json(Poco::JSON::Object &Obj) const; | 		void to_json(Poco::JSON::Object &Obj) const; | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
|  | 	struct DeviceRestrictionsKeyInfo { | ||||||
|  | 		std::string 	vendor; | ||||||
|  | 		std::string 	algo; | ||||||
|  |  | ||||||
|  | 		bool operator !=(const DeviceRestrictionsKeyInfo &b) const; | ||||||
|  |  | ||||||
|  | 		void to_json(Poco::JSON::Object &Obj) const; | ||||||
|  | 		bool from_json(const Poco::JSON::Object::Ptr &Obj); | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	struct DeviceRestrictions { | ||||||
|  | 		bool    					dfs = false; | ||||||
|  | 		bool    					ssh = false; | ||||||
|  | 		bool    					rtty = false; | ||||||
|  | 		bool    					tty = false; | ||||||
|  | 		bool    					developer = false; | ||||||
|  | 		bool    					upgrade = false; | ||||||
|  | 		bool    					commands = false; | ||||||
|  | 		std::vector<std::string>   	country; | ||||||
|  | 		DeviceRestrictionsKeyInfo	key_info; | ||||||
|  |  | ||||||
|  | 		bool operator !=(const DeviceRestrictions &D) const; | ||||||
|  |  | ||||||
|  | 		void to_json(Poco::JSON::Object &Obj) const; | ||||||
|  | 		bool from_json(const Poco::JSON::Object::Ptr &Obj); | ||||||
|  | 	}; | ||||||
|  |  | ||||||
| 	struct Device { | 	struct Device { | ||||||
| 		std::string SerialNumber; | 		std::string SerialNumber; | ||||||
| 		std::string DeviceType; | 		std::string DeviceType; | ||||||
| @@ -64,6 +97,10 @@ namespace OpenWifi::GWObjects { | |||||||
| 		std::string entity; | 		std::string entity; | ||||||
| 		uint64_t 	modified=0; | 		uint64_t 	modified=0; | ||||||
| 		std::string locale; | 		std::string locale; | ||||||
|  | 		bool 		restrictedDevice=false; | ||||||
|  | 		std::string pendingConfiguration; | ||||||
|  | 		std::string pendingConfigurationCmd; | ||||||
|  | 		DeviceRestrictions	restrictionDetails; | ||||||
|  |  | ||||||
| 		void to_json(Poco::JSON::Object &Obj) const; | 		void to_json(Poco::JSON::Object &Obj) const; | ||||||
| 		void to_json_with_status(Poco::JSON::Object &Obj) const; | 		void to_json_with_status(Poco::JSON::Object &Obj) const; | ||||||
| @@ -71,6 +108,15 @@ namespace OpenWifi::GWObjects { | |||||||
| 		void Print() const; | 		void Print() const; | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
|  | 	struct DeviceConnectionStatistics { | ||||||
|  | 		std::uint64_t connectedDevices = 0; | ||||||
|  | 		std::uint64_t averageConnectionTime = 0; | ||||||
|  | 		std::uint64_t connectingDevices = 0; | ||||||
|  |  | ||||||
|  | 		void to_json(Poco::JSON::Object &Obj) const; | ||||||
|  | 		bool from_json(const Poco::JSON::Object::Ptr &Obj); | ||||||
|  | 	}; | ||||||
|  |  | ||||||
| 	struct Statistics { | 	struct Statistics { | ||||||
| 		std::string SerialNumber; | 		std::string SerialNumber; | ||||||
| 		uint64_t 	UUID = 0 ; | 		uint64_t 	UUID = 0 ; | ||||||
| @@ -200,13 +246,44 @@ namespace OpenWifi::GWObjects { | |||||||
| 		void to_json(Poco::JSON::Object &Obj) const; | 		void to_json(Poco::JSON::Object &Obj) const; | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
|  | 	struct ScriptEntry { | ||||||
|  | 		std::string 		id; | ||||||
|  | 		std::string 		name; | ||||||
|  | 		std::string 		description; | ||||||
|  | 		std::string 		uri; | ||||||
|  | 		std::string 		content; | ||||||
|  | 		std::string 		version; | ||||||
|  | 		std::string 		type; | ||||||
|  | 		std::uint64_t 		created; | ||||||
|  | 		std::uint64_t 		modified; | ||||||
|  | 		std::string 		author; | ||||||
|  | 		Types::StringVec 	restricted; | ||||||
|  | 		bool				deferred=false; | ||||||
|  | 		std::uint64_t 		timeout=30; | ||||||
|  | 		std::string 		defaultUploadURI; | ||||||
|  |  | ||||||
|  | 		void to_json(Poco::JSON::Object &Obj) const; | ||||||
|  | 		bool from_json(const Poco::JSON::Object::Ptr &Obj); | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	struct ScriptEntryList { | ||||||
|  | 		std::vector<ScriptEntry>	scripts; | ||||||
|  |  | ||||||
|  | 		void to_json(Poco::JSON::Object &Obj) const; | ||||||
|  | 		bool from_json(const Poco::JSON::Object::Ptr &Obj); | ||||||
|  | 	}; | ||||||
|  |  | ||||||
| 	struct ScriptRequest { | 	struct ScriptRequest { | ||||||
| 		uint64_t 	timeout=30; |  | ||||||
| 		std::string serialNumber; | 		std::string serialNumber; | ||||||
|  | 		uint64_t 	timeout=30; | ||||||
| 		std::string type; | 		std::string type; | ||||||
| 		std::string script; | 		std::string script; | ||||||
| 		std::string scriptId; | 		std::string scriptId; | ||||||
| 		uint64_t 	when=0; | 		std::uint64_t when; | ||||||
|  | 		std::string signature; | ||||||
|  | 		bool deferred; | ||||||
|  | 		std::string uri; | ||||||
|  |  | ||||||
| 		void to_json(Poco::JSON::Object &Obj) const; | 		void to_json(Poco::JSON::Object &Obj) const; | ||||||
| 		bool from_json(const Poco::JSON::Object::Ptr &Obj); | 		bool from_json(const Poco::JSON::Object::Ptr &Obj); | ||||||
| 	}; | 	}; | ||||||
| @@ -216,6 +293,17 @@ namespace OpenWifi::GWObjects { | |||||||
| 		std::string ip; | 		std::string ip; | ||||||
| 		uint16_t 	port=0; | 		uint16_t 	port=0; | ||||||
| 		uint64_t 	weight=0; | 		uint64_t 	weight=0; | ||||||
|  | 		std::string secret; | ||||||
|  | 		std::string certificate; | ||||||
|  | 		bool 		radsec=false; | ||||||
|  | 		bool 		allowSelfSigned=false; | ||||||
|  | 		uint16_t 	radsecPort=2083; | ||||||
|  | 		std::string radsecSecret; | ||||||
|  | 		std::string radsecKey; | ||||||
|  | 		std::string radsecCert; | ||||||
|  | 		std::vector<std::string> 	radsecCacerts; | ||||||
|  | 		std::vector<std::string>	radsecRealms; | ||||||
|  | 		bool 		ignore=false; | ||||||
|  |  | ||||||
| 		void to_json(Poco::JSON::Object &Obj) const; | 		void to_json(Poco::JSON::Object &Obj) const; | ||||||
| 		bool from_json(const Poco::JSON::Object::Ptr &Obj); | 		bool from_json(const Poco::JSON::Object::Ptr &Obj); | ||||||
| @@ -237,6 +325,8 @@ namespace OpenWifi::GWObjects { | |||||||
| 		std::string description; | 		std::string description; | ||||||
| 		RadiusProxyServerConfig	authConfig; | 		RadiusProxyServerConfig	authConfig; | ||||||
| 		RadiusProxyServerConfig	acctConfig; | 		RadiusProxyServerConfig	acctConfig; | ||||||
|  | 		RadiusProxyServerConfig	coaConfig; | ||||||
|  | 		bool 		useByDefault=false; | ||||||
|  |  | ||||||
| 		void to_json(Poco::JSON::Object &Obj) const; | 		void to_json(Poco::JSON::Object &Obj) const; | ||||||
| 		bool from_json(const Poco::JSON::Object::Ptr &Obj); | 		bool from_json(const Poco::JSON::Object::Ptr &Obj); | ||||||
| @@ -248,4 +338,5 @@ namespace OpenWifi::GWObjects { | |||||||
| 		void to_json(Poco::JSON::Object &Obj) const; | 		void to_json(Poco::JSON::Object &Obj) const; | ||||||
| 		bool from_json(const Poco::JSON::Object::Ptr &Obj); | 		bool from_json(const Poco::JSON::Object::Ptr &Obj); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -2,7 +2,7 @@ | |||||||
| // Created by stephane bourque on 2021-08-31. | // Created by stephane bourque on 2021-08-31. | ||||||
| // | // | ||||||
|  |  | ||||||
| #include "framework/MicroService.h" | #include "framework/RESTAPI_utils.h" | ||||||
|  |  | ||||||
| using OpenWifi::RESTAPI_utils::field_to_json; | using OpenWifi::RESTAPI_utils::field_to_json; | ||||||
| using OpenWifi::RESTAPI_utils::field_from_json; | using OpenWifi::RESTAPI_utils::field_from_json; | ||||||
|   | |||||||
| @@ -8,7 +8,9 @@ | |||||||
|  |  | ||||||
|  |  | ||||||
| #include "RESTAPI_ProvObjects.h" | #include "RESTAPI_ProvObjects.h" | ||||||
| #include "framework/MicroService.h" | #include "framework/RESTAPI_utils.h" | ||||||
|  | #include "framework/MicroServiceFuncs.h" | ||||||
|  | #include "framework/utils.h" | ||||||
|  |  | ||||||
| using OpenWifi::RESTAPI_utils::field_to_json; | using OpenWifi::RESTAPI_utils::field_to_json; | ||||||
| using OpenWifi::RESTAPI_utils::field_from_json; | using OpenWifi::RESTAPI_utils::field_from_json; | ||||||
| @@ -600,6 +602,7 @@ namespace OpenWifi::ProvObjects { | |||||||
|         field_to_json( Obj, "devClass",devClass); |         field_to_json( Obj, "devClass",devClass); | ||||||
|         field_to_json( Obj, "locale",locale); |         field_to_json( Obj, "locale",locale); | ||||||
|         field_to_json( Obj, "realMacAddress",realMacAddress); |         field_to_json( Obj, "realMacAddress",realMacAddress); | ||||||
|  |         field_to_json( Obj, "doNotAllowOverrides",doNotAllowOverrides); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     bool InventoryTag::from_json(const Poco::JSON::Object::Ptr &Obj) { |     bool InventoryTag::from_json(const Poco::JSON::Object::Ptr &Obj) { | ||||||
| @@ -621,6 +624,7 @@ namespace OpenWifi::ProvObjects { | |||||||
|             field_from_json( Obj,"devClass",devClass); |             field_from_json( Obj,"devClass",devClass); | ||||||
|             field_from_json( Obj,"locale",locale); |             field_from_json( Obj,"locale",locale); | ||||||
|             field_from_json( Obj,"realMacAddress",realMacAddress); |             field_from_json( Obj,"realMacAddress",realMacAddress); | ||||||
|  |             field_from_json( Obj, "doNotAllowOverrides",doNotAllowOverrides); | ||||||
|             return true; |             return true; | ||||||
|         } catch(...) { |         } catch(...) { | ||||||
|  |  | ||||||
| @@ -1091,7 +1095,7 @@ namespace OpenWifi::ProvObjects { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     bool UpdateObjectInfo(const Poco::JSON::Object::Ptr &O, const SecurityObjects::UserInfo &U, ObjectInfo &I) { |     bool UpdateObjectInfo(const Poco::JSON::Object::Ptr &O, const SecurityObjects::UserInfo &U, ObjectInfo &I) { | ||||||
|         uint64_t Now = OpenWifi::Now(); |         uint64_t Now = Utils::Now(); | ||||||
|         if(O->has("name")) |         if(O->has("name")) | ||||||
|             I.name = O->get("name").toString(); |             I.name = O->get("name").toString(); | ||||||
|  |  | ||||||
| @@ -1112,7 +1116,7 @@ namespace OpenWifi::ProvObjects { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     bool CreateObjectInfo(const Poco::JSON::Object::Ptr &O, const SecurityObjects::UserInfo &U, ObjectInfo &I) { |     bool CreateObjectInfo(const Poco::JSON::Object::Ptr &O, const SecurityObjects::UserInfo &U, ObjectInfo &I) { | ||||||
|         uint64_t Now = OpenWifi::Now(); |         uint64_t Now = Utils::Now(); | ||||||
|         if(O->has("name")) |         if(O->has("name")) | ||||||
|             I.name = O->get("name").toString(); |             I.name = O->get("name").toString(); | ||||||
|  |  | ||||||
| @@ -1130,14 +1134,14 @@ namespace OpenWifi::ProvObjects { | |||||||
|         } |         } | ||||||
|         I.notes = N; |         I.notes = N; | ||||||
|         I.modified = I.created = Now; |         I.modified = I.created = Now; | ||||||
|         I.id = MicroService::CreateUUID(); |         I.id = MicroServiceCreateUUID(); | ||||||
|  |  | ||||||
|         return true; |         return true; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     bool CreateObjectInfo([[maybe_unused]] const SecurityObjects::UserInfo &U, ObjectInfo &I) { |     bool CreateObjectInfo([[maybe_unused]] const SecurityObjects::UserInfo &U, ObjectInfo &I) { | ||||||
|         I.modified = I.created = OpenWifi::Now(); |         I.modified = I.created = Utils::Now(); | ||||||
|         I.id = MicroService::CreateUUID(); |         I.id = MicroServiceCreateUUID(); | ||||||
|         return true; |         return true; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -1159,5 +1163,82 @@ namespace OpenWifi::ProvObjects { | |||||||
|         return false; |         return false; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     void RRMAlgorithmDetails::to_json(Poco::JSON::Object &Obj) const { | ||||||
|  |         field_to_json(Obj,"name",name); | ||||||
|  |         field_to_json(Obj,"parameters",parameters); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     bool RRMAlgorithmDetails::from_json(const Poco::JSON::Object::Ptr &Obj) { | ||||||
|  |         try { | ||||||
|  |             field_from_json(Obj,"name",name); | ||||||
|  |             field_from_json(Obj,"parameters",parameters); | ||||||
|  |             return true; | ||||||
|  |         } catch(...) { | ||||||
|  |  | ||||||
|  |         } | ||||||
|  |         return false; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     void RRMDetails::to_json(Poco::JSON::Object &Obj) const { | ||||||
|  |         field_to_json(Obj,"vendor",vendor); | ||||||
|  |         field_to_json(Obj,"schedule",schedule); | ||||||
|  |         field_to_json(Obj,"algorithms",algorithms); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     bool RRMDetails::from_json(const Poco::JSON::Object::Ptr &Obj) { | ||||||
|  |         try { | ||||||
|  |             field_from_json(Obj,"vendor",vendor); | ||||||
|  |             field_from_json(Obj,"schedule",schedule); | ||||||
|  |             field_from_json(Obj,"algorithms",algorithms); | ||||||
|  |             return true; | ||||||
|  |         } catch(...) { | ||||||
|  |  | ||||||
|  |         } | ||||||
|  |         return false; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     void ConfigurationOverride::to_json(Poco::JSON::Object &Obj) const { | ||||||
|  |         field_to_json(Obj,"source",source); | ||||||
|  |         field_to_json(Obj,"reason",reason); | ||||||
|  |         field_to_json(Obj,"parameterName",parameterName); | ||||||
|  |         field_to_json(Obj,"parameterType",parameterType); | ||||||
|  |         field_to_json(Obj,"parameterValue",parameterValue); | ||||||
|  |         field_to_json(Obj,"modified",modified); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     bool ConfigurationOverride::from_json(const Poco::JSON::Object::Ptr &Obj) { | ||||||
|  |         try { | ||||||
|  |             field_from_json(Obj,"source",source); | ||||||
|  |             field_from_json(Obj,"reason",reason); | ||||||
|  |             field_from_json(Obj,"parameterName",parameterName); | ||||||
|  |             field_from_json(Obj,"parameterType",parameterType); | ||||||
|  |             field_from_json(Obj,"parameterValue",parameterValue); | ||||||
|  |             field_from_json(Obj,"modified",modified); | ||||||
|  |             return true; | ||||||
|  |         } catch(...) { | ||||||
|  |  | ||||||
|  |         } | ||||||
|  |         return false; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     void ConfigurationOverrideList::to_json(Poco::JSON::Object &Obj) const { | ||||||
|  |         field_to_json(Obj,"serialNumber",serialNumber); | ||||||
|  |         field_to_json(Obj,"managementPolicy",managementPolicy); | ||||||
|  |         field_to_json(Obj,"overrides",overrides); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     bool ConfigurationOverrideList::from_json(const Poco::JSON::Object::Ptr &Obj) { | ||||||
|  |         try { | ||||||
|  |             field_from_json(Obj,"serialNumber",serialNumber); | ||||||
|  |             field_from_json(Obj,"managementPolicy",managementPolicy); | ||||||
|  |             field_from_json(Obj,"overrides",overrides); | ||||||
|  |             return true; | ||||||
|  |         } catch(...) { | ||||||
|  |  | ||||||
|  |         } | ||||||
|  |         return false; | ||||||
|  |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -8,8 +8,7 @@ | |||||||
|  |  | ||||||
| #pragma once | #pragma once | ||||||
|  |  | ||||||
| #include <string> | #include "RESTObjects/RESTAPI_SecurityObjects.h" | ||||||
| #include "RESTAPI_SecurityObjects.h" |  | ||||||
|  |  | ||||||
| namespace OpenWifi::ProvObjects { | namespace OpenWifi::ProvObjects { | ||||||
|  |  | ||||||
| @@ -62,6 +61,21 @@ namespace OpenWifi::ProvObjects { | |||||||
|     }; |     }; | ||||||
|     typedef std::vector<ManagementPolicy>      ManagementPolicyVec; |     typedef std::vector<ManagementPolicy>      ManagementPolicyVec; | ||||||
|  |  | ||||||
|  |     struct RRMAlgorithmDetails { | ||||||
|  |         std::string     name; | ||||||
|  |         std::string     parameters; | ||||||
|  |         void to_json(Poco::JSON::Object &Obj) const; | ||||||
|  |         bool from_json(const Poco::JSON::Object::Ptr &Obj); | ||||||
|  |     }; | ||||||
|  |  | ||||||
|  |     struct RRMDetails { | ||||||
|  |         std::string     vendor; | ||||||
|  |         std::string     schedule; | ||||||
|  |         std::vector<RRMAlgorithmDetails>    algorithms; | ||||||
|  |         void to_json(Poco::JSON::Object &Obj) const; | ||||||
|  |         bool from_json(const Poco::JSON::Object::Ptr &Obj); | ||||||
|  |     }; | ||||||
|  |  | ||||||
|     struct DeviceRules { |     struct DeviceRules { | ||||||
|         std::string     rcOnly{"inherit"}; |         std::string     rcOnly{"inherit"}; | ||||||
|         std::string     rrm{"inherit"}; |         std::string     rrm{"inherit"}; | ||||||
| @@ -414,6 +428,7 @@ namespace OpenWifi::ProvObjects { | |||||||
|         std::string     devClass; |         std::string     devClass; | ||||||
|         std::string     locale; |         std::string     locale; | ||||||
|         std::string     realMacAddress; |         std::string     realMacAddress; | ||||||
|  |         bool            doNotAllowOverrides=false; | ||||||
|  |  | ||||||
|         void to_json(Poco::JSON::Object &Obj) const; |         void to_json(Poco::JSON::Object &Obj) const; | ||||||
|         bool from_json(const Poco::JSON::Object::Ptr &Obj); |         bool from_json(const Poco::JSON::Object::Ptr &Obj); | ||||||
| @@ -679,6 +694,27 @@ namespace OpenWifi::ProvObjects { | |||||||
|         bool from_json(const Poco::JSON::Object::Ptr &Obj); |         bool from_json(const Poco::JSON::Object::Ptr &Obj); | ||||||
|     }; |     }; | ||||||
|  |  | ||||||
|  |     struct ConfigurationOverride { | ||||||
|  |         std::string     source; | ||||||
|  |         std::string     reason; | ||||||
|  |         std::string     parameterName; | ||||||
|  |         std::string     parameterType; | ||||||
|  |         std::string     parameterValue; | ||||||
|  |         std::uint64_t   modified; | ||||||
|  |  | ||||||
|  |         void to_json(Poco::JSON::Object &Obj) const; | ||||||
|  |         bool from_json(const Poco::JSON::Object::Ptr &Obj); | ||||||
|  |     }; | ||||||
|  |  | ||||||
|  |     struct ConfigurationOverrideList { | ||||||
|  |         std::string     serialNumber; | ||||||
|  |         Types::UUID_t   managementPolicy; | ||||||
|  |         std::vector<ConfigurationOverride>  overrides; | ||||||
|  |  | ||||||
|  |         void to_json(Poco::JSON::Object &Obj) const; | ||||||
|  |         bool from_json(const Poco::JSON::Object::Ptr &Obj); | ||||||
|  |     }; | ||||||
|  |  | ||||||
|     bool UpdateObjectInfo(const Poco::JSON::Object::Ptr &O, const SecurityObjects::UserInfo &U, ObjectInfo &I); |     bool UpdateObjectInfo(const Poco::JSON::Object::Ptr &O, const SecurityObjects::UserInfo &U, ObjectInfo &I); | ||||||
|     bool CreateObjectInfo(const Poco::JSON::Object::Ptr &O, const SecurityObjects::UserInfo &U, ObjectInfo &I); |     bool CreateObjectInfo(const Poco::JSON::Object::Ptr &O, const SecurityObjects::UserInfo &U, ObjectInfo &I); | ||||||
|     bool CreateObjectInfo(const SecurityObjects::UserInfo &U, ObjectInfo &I); |     bool CreateObjectInfo(const SecurityObjects::UserInfo &U, ObjectInfo &I); | ||||||
|   | |||||||
| @@ -9,7 +9,7 @@ | |||||||
| #include "Poco/JSON/Parser.h" | #include "Poco/JSON/Parser.h" | ||||||
| #include "Poco/JSON/Stringifier.h" | #include "Poco/JSON/Stringifier.h" | ||||||
|  |  | ||||||
| #include "framework/MicroService.h" | #include "framework/RESTAPI_utils.h" | ||||||
| #include "RESTAPI_SecurityObjects.h" | #include "RESTAPI_SecurityObjects.h" | ||||||
|  |  | ||||||
| using OpenWifi::RESTAPI_utils::field_to_json; | using OpenWifi::RESTAPI_utils::field_to_json; | ||||||
| @@ -433,7 +433,7 @@ namespace OpenWifi::SecurityObjects { | |||||||
| 	            SecurityObjects::NoteInfoVec NIV; | 	            SecurityObjects::NoteInfoVec NIV; | ||||||
| 	            NIV = RESTAPI_utils::to_object_array<SecurityObjects::NoteInfo>(Obj->get("notes").toString()); | 	            NIV = RESTAPI_utils::to_object_array<SecurityObjects::NoteInfo>(Obj->get("notes").toString()); | ||||||
| 	            for(auto const &i:NIV) { | 	            for(auto const &i:NIV) { | ||||||
| 	                SecurityObjects::NoteInfo   ii{.created=(uint64_t)OpenWifi::Now(), .createdBy=UInfo.email, .note=i.note}; | 	                SecurityObjects::NoteInfo   ii{.created=(uint64_t)Utils::Now(), .createdBy=UInfo.email, .note=i.note}; | ||||||
| 	                Notes.push_back(ii); | 	                Notes.push_back(ii); | ||||||
| 	            } | 	            } | ||||||
| 	        } | 	        } | ||||||
| @@ -446,7 +446,7 @@ namespace OpenWifi::SecurityObjects { | |||||||
|  |  | ||||||
| 	bool MergeNotes(const NoteInfoVec & NewNotes, const UserInfo &UInfo, NoteInfoVec & ExistingNotes) { | 	bool MergeNotes(const NoteInfoVec & NewNotes, const UserInfo &UInfo, NoteInfoVec & ExistingNotes) { | ||||||
| 	    for(auto const &i:NewNotes) { | 	    for(auto const &i:NewNotes) { | ||||||
| 	        SecurityObjects::NoteInfo   ii{.created=(uint64_t)OpenWifi::Now(), .createdBy=UInfo.email, .note=i.note}; | 	        SecurityObjects::NoteInfo   ii{.created=(uint64_t)Utils::Now(), .createdBy=UInfo.email, .note=i.note}; | ||||||
| 	        ExistingNotes.push_back(ii); | 	        ExistingNotes.push_back(ii); | ||||||
| 	    } | 	    } | ||||||
|         return true; |         return true; | ||||||
| @@ -619,5 +619,80 @@ namespace OpenWifi::SecurityObjects { | |||||||
|         field_to_json(Obj,"login",login); |         field_to_json(Obj,"login",login); | ||||||
|         field_to_json(Obj,"logout",logout); |         field_to_json(Obj,"logout",logout); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     void ApiKeyAccessRight::to_json(Poco::JSON::Object &Obj) const { | ||||||
|  |         field_to_json(Obj, "service", service); | ||||||
|  |         field_to_json(Obj, "access", access); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     bool ApiKeyAccessRight::from_json(const Poco::JSON::Object::Ptr &Obj) { | ||||||
|  |         try { | ||||||
|  |             field_from_json(Obj, "service", service); | ||||||
|  |             field_from_json(Obj, "access", access); | ||||||
|  |             return true; | ||||||
|  |         } catch(...) { | ||||||
|  |             std::cout << "Cannot parse: Token" << std::endl; | ||||||
|  |         } | ||||||
|  |         return false; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     void ApiKeyAccessRightList::to_json(Poco::JSON::Object &Obj) const { | ||||||
|  |         field_to_json(Obj, "acls", acls); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     bool ApiKeyAccessRightList::from_json(const Poco::JSON::Object::Ptr &Obj) { | ||||||
|  |         try { | ||||||
|  |             field_from_json(Obj, "acls", acls); | ||||||
|  |             return true; | ||||||
|  |         } catch(...) { | ||||||
|  |             std::cout << "Cannot parse: Token" << std::endl; | ||||||
|  |         } | ||||||
|  |         return false; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     void ApiKeyEntry::to_json(Poco::JSON::Object &Obj) const { | ||||||
|  |         field_to_json(Obj, "id", id); | ||||||
|  |         field_to_json(Obj, "userUuid", userUuid); | ||||||
|  |         field_to_json(Obj, "name", name); | ||||||
|  |         field_to_json(Obj, "apiKey", apiKey); | ||||||
|  |         field_to_json(Obj, "salt", salt); | ||||||
|  |         field_to_json(Obj, "description", description); | ||||||
|  |         field_to_json(Obj, "expiresOn", expiresOn); | ||||||
|  |         field_to_json(Obj, "rights", rights); | ||||||
|  |         field_to_json(Obj, "lastUse", lastUse); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     bool ApiKeyEntry::from_json(const Poco::JSON::Object::Ptr &Obj) { | ||||||
|  |         try { | ||||||
|  |             field_from_json(Obj, "id", id); | ||||||
|  |             field_from_json(Obj, "userUuid", userUuid); | ||||||
|  |             field_from_json(Obj, "name", name); | ||||||
|  |             field_from_json(Obj, "apiKey", apiKey); | ||||||
|  |             field_from_json(Obj, "salt", salt); | ||||||
|  |             field_from_json(Obj, "description", description); | ||||||
|  |             field_from_json(Obj, "expiresOn", expiresOn); | ||||||
|  |             field_from_json(Obj, "rights", rights); | ||||||
|  |             field_from_json(Obj, "lastUse", lastUse); | ||||||
|  |             return true; | ||||||
|  |         } catch(...) { | ||||||
|  |             std::cout << "Cannot parse: Token" << std::endl; | ||||||
|  |         } | ||||||
|  |         return false; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     void ApiKeyEntryList::to_json(Poco::JSON::Object &Obj) const { | ||||||
|  |         field_to_json(Obj, "apiKeys", apiKeys); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     bool ApiKeyEntryList::from_json(const Poco::JSON::Object::Ptr &Obj) { | ||||||
|  |         try { | ||||||
|  |             field_from_json(Obj, "apiKeys", apiKeys); | ||||||
|  |             return true; | ||||||
|  |         } catch(...) { | ||||||
|  |             std::cout << "Cannot parse: Token" << std::endl; | ||||||
|  |         } | ||||||
|  |         return false; | ||||||
|  |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -14,6 +14,7 @@ | |||||||
| #include "Poco/JSON/Object.h" | #include "Poco/JSON/Object.h" | ||||||
| #include "Poco/Data/LOB.h" | #include "Poco/Data/LOB.h" | ||||||
| #include "Poco/Data/LOBStream.h" | #include "Poco/Data/LOBStream.h" | ||||||
|  | #include "framework/utils.h" | ||||||
|  |  | ||||||
| namespace OpenWifi { | namespace OpenWifi { | ||||||
|     uint64_t Now(); |     uint64_t Now(); | ||||||
| @@ -62,7 +63,7 @@ namespace OpenWifi { | |||||||
|         std::string UserTypeToString(USER_ROLE U); |         std::string UserTypeToString(USER_ROLE U); | ||||||
|  |  | ||||||
|         struct NoteInfo { |         struct NoteInfo { | ||||||
|             uint64_t    created=0; // = OpenWifi::Now(); |             uint64_t    created=0; // = Utils::Now(); | ||||||
|             std::string createdBy; |             std::string createdBy; | ||||||
|             std::string note; |             std::string note; | ||||||
|  |  | ||||||
| @@ -101,7 +102,7 @@ namespace OpenWifi { | |||||||
|             std::string uuid; |             std::string uuid; | ||||||
|             std::string question; |             std::string question; | ||||||
|             std::string method; |             std::string method; | ||||||
|             uint64_t    created = OpenWifi::Now(); |             uint64_t    created = Utils::Now(); | ||||||
|  |  | ||||||
|             void to_json(Poco::JSON::Object &Obj) const; |             void to_json(Poco::JSON::Object &Obj) const; | ||||||
|             bool from_json(const Poco::JSON::Object::Ptr &Obj); |             bool from_json(const Poco::JSON::Object::Ptr &Obj); | ||||||
| @@ -251,7 +252,8 @@ namespace OpenWifi { | |||||||
|             VERIFY_EMAIL, |             VERIFY_EMAIL, | ||||||
|             SUB_FORGOT_PASSWORD, |             SUB_FORGOT_PASSWORD, | ||||||
|             SUB_VERIFY_EMAIL, |             SUB_VERIFY_EMAIL, | ||||||
|             SUB_SIGNUP |             SUB_SIGNUP, | ||||||
|  |             EMAIL_INVITATION | ||||||
|         }; |         }; | ||||||
|  |  | ||||||
|         struct ActionLink { |         struct ActionLink { | ||||||
| @@ -263,7 +265,7 @@ namespace OpenWifi { | |||||||
|             std::string         locale; |             std::string         locale; | ||||||
|             std::string         message; |             std::string         message; | ||||||
|             uint64_t            sent=0; |             uint64_t            sent=0; | ||||||
|             uint64_t            created=OpenWifi::Now(); |             uint64_t            created=Utils::Now(); | ||||||
|             uint64_t            expires=0; |             uint64_t            expires=0; | ||||||
|             uint64_t            completed=0; |             uint64_t            completed=0; | ||||||
|             uint64_t            canceled=0; |             uint64_t            canceled=0; | ||||||
| @@ -323,5 +325,44 @@ namespace OpenWifi { | |||||||
|  |  | ||||||
|             void to_json(Poco::JSON::Object &Obj) const; |             void to_json(Poco::JSON::Object &Obj) const; | ||||||
|         }; |         }; | ||||||
|  |  | ||||||
|  |         struct ApiKeyAccessRight { | ||||||
|  |             std::string     service; | ||||||
|  |             std::string     access; | ||||||
|  |  | ||||||
|  |             void to_json(Poco::JSON::Object &Obj) const; | ||||||
|  |             bool from_json(const Poco::JSON::Object::Ptr &Obj); | ||||||
|  |         }; | ||||||
|  |  | ||||||
|  |         struct ApiKeyAccessRightList { | ||||||
|  |             std::vector<ApiKeyAccessRight>      acls; | ||||||
|  |  | ||||||
|  |             void to_json(Poco::JSON::Object &Obj) const; | ||||||
|  |             bool from_json(const Poco::JSON::Object::Ptr &Obj); | ||||||
|  |         }; | ||||||
|  |  | ||||||
|  |         struct ApiKeyEntry { | ||||||
|  |             Types::UUID_t           id; | ||||||
|  |             Types::UUID_t           userUuid; | ||||||
|  |             std::string             name; | ||||||
|  |             std::string             description; | ||||||
|  |             std::string             apiKey; | ||||||
|  |             std::string             salt; | ||||||
|  |             std::uint64_t           created; | ||||||
|  |             std::uint64_t           expiresOn=0; | ||||||
|  |             ApiKeyAccessRightList   rights; | ||||||
|  |             std::uint64_t           lastUse=0; | ||||||
|  |  | ||||||
|  |             void to_json(Poco::JSON::Object &Obj) const; | ||||||
|  |             bool from_json(const Poco::JSON::Object::Ptr &Obj); | ||||||
|  |         }; | ||||||
|  |  | ||||||
|  |         struct ApiKeyEntryList { | ||||||
|  |             std::vector<ApiKeyEntry>    apiKeys; | ||||||
|  |  | ||||||
|  |             void to_json(Poco::JSON::Object &Obj) const; | ||||||
|  |             bool from_json(const Poco::JSON::Object::Ptr &Obj); | ||||||
|  |         }; | ||||||
|  |  | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -3,12 +3,11 @@ | |||||||
| // | // | ||||||
|  |  | ||||||
| #include "RESTAPI_SubObjects.h" | #include "RESTAPI_SubObjects.h" | ||||||
| #include "framework/MicroService.h" | #include "framework/RESTAPI_utils.h" | ||||||
|  |  | ||||||
| using OpenWifi::RESTAPI_utils::field_to_json; | using OpenWifi::RESTAPI_utils::field_to_json; | ||||||
| using OpenWifi::RESTAPI_utils::field_from_json; | using OpenWifi::RESTAPI_utils::field_from_json; | ||||||
|  |  | ||||||
|  |  | ||||||
| namespace OpenWifi::SubObjects { | namespace OpenWifi::SubObjects { | ||||||
|  |  | ||||||
|     void HomeDeviceMode::to_json(Poco::JSON::Object &Obj) const { |     void HomeDeviceMode::to_json(Poco::JSON::Object &Obj) const { | ||||||
|   | |||||||
| @@ -2,11 +2,9 @@ | |||||||
| // Created by stephane bourque on 2021-08-11. | // Created by stephane bourque on 2021-08-11. | ||||||
| // | // | ||||||
|  |  | ||||||
| #include "SerialNumberCache.h" |  | ||||||
| #include <mutex> |  | ||||||
|  |  | ||||||
| #include "StorageService.h" | #include "SerialNumberCache.h" | ||||||
| #include "framework/MicroService.h" | #include "framework/utils.h" | ||||||
|  |  | ||||||
| namespace OpenWifi { | namespace OpenWifi { | ||||||
|  |  | ||||||
|   | |||||||
| @@ -4,7 +4,8 @@ | |||||||
|  |  | ||||||
| #pragma once | #pragma once | ||||||
|  |  | ||||||
| #include "framework/MicroService.h" | #include <mutex> | ||||||
|  | #include "framework/SubSystemServer.h" | ||||||
|  |  | ||||||
| namespace OpenWifi { | namespace OpenWifi { | ||||||
|     class SerialNumberCache : public SubSystemServer { |     class SerialNumberCache : public SubSystemServer { | ||||||
|   | |||||||
| @@ -5,12 +5,15 @@ | |||||||
| #include "Signup.h" | #include "Signup.h" | ||||||
| #include "StorageService.h" | #include "StorageService.h" | ||||||
| #include "sdks/SDK_gw.h" | #include "sdks/SDK_gw.h" | ||||||
|  | #include "framework/MicroServiceFuncs.h" | ||||||
|  | #include "framework/utils.h" | ||||||
|  |  | ||||||
| namespace OpenWifi { | namespace OpenWifi { | ||||||
|  |  | ||||||
|     int Signup::Start() { |     int Signup::Start() { | ||||||
|         GracePeriod_ = MicroService::instance().ConfigGetInt("signup.graceperiod", 60*60); |         poco_information(Logger(),"Starting..."); | ||||||
|         LingerPeriod_ = MicroService::instance().ConfigGetInt("signup.lingerperiod", 24*60*60); |         GracePeriod_ = MicroServiceConfigGetInt("signup.graceperiod", 60*60); | ||||||
|  |         LingerPeriod_ = MicroServiceConfigGetInt("signup.lingerperiod", 24*60*60); | ||||||
|  |  | ||||||
|         SignupDB::RecordVec Signups_; |         SignupDB::RecordVec Signups_; | ||||||
|         StorageService()->SignupDB().GetIncompleteSignups(Signups_); |         StorageService()->SignupDB().GetIncompleteSignups(Signups_); | ||||||
| @@ -29,10 +32,12 @@ namespace OpenWifi { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     void Signup::Stop() { |     void Signup::Stop() { | ||||||
|  |         poco_information(Logger(),"Stopping..."); | ||||||
|         Running_ = false; |         Running_ = false; | ||||||
|         Timer_.stop(); |         Timer_.stop(); | ||||||
|         Worker_.wakeUp(); |         Worker_.wakeUp(); | ||||||
|         Worker_.join(); |         Worker_.join(); | ||||||
|  |         poco_information(Logger(),"Stopped..."); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     void Signup::onTimer([[maybe_unused]] Poco::Timer &timer) { |     void Signup::onTimer([[maybe_unused]] Poco::Timer &timer) { | ||||||
| @@ -68,7 +73,7 @@ namespace OpenWifi { | |||||||
|                             //  We must now complete the device transfer to this new subscriber and complete the |                             //  We must now complete the device transfer to this new subscriber and complete the | ||||||
|                             //  signup job. |                             //  signup job. | ||||||
|                             IT.subscriber = SE.userId; |                             IT.subscriber = SE.userId; | ||||||
|                             IT.info.modified = OpenWifi::Now(); |                             IT.info.modified = Utils::Now(); | ||||||
|                             IT.realMacAddress = SE.macAddress; |                             IT.realMacAddress = SE.macAddress; | ||||||
|                             if(IT.entity.empty()) { |                             if(IT.entity.empty()) { | ||||||
|  |  | ||||||
| @@ -77,7 +82,7 @@ namespace OpenWifi { | |||||||
|                             } |                             } | ||||||
|                             Poco::JSON::Object NewState; |                             Poco::JSON::Object NewState; | ||||||
|                             NewState.set("method", "signup"); |                             NewState.set("method", "signup"); | ||||||
|                             NewState.set("date", OpenWifi::Now()); |                             NewState.set("date", Utils::Now()); | ||||||
|                             NewState.set("status", "completed"); |                             NewState.set("status", "completed"); | ||||||
|                             std::ostringstream OS; |                             std::ostringstream OS; | ||||||
|                             NewState.stringify(OS); |                             NewState.stringify(OS); | ||||||
| @@ -86,8 +91,8 @@ namespace OpenWifi { | |||||||
|  |  | ||||||
|                             // we need to move this device to the SubscriberDevice DB |                             // we need to move this device to the SubscriberDevice DB | ||||||
|                             ProvObjects::SubscriberDevice   SD; |                             ProvObjects::SubscriberDevice   SD; | ||||||
|                             SD.info.id = MicroService::CreateUUID(); |                             SD.info.id = MicroServiceCreateUUID(); | ||||||
|                             SD.info.modified = SD.info.created = OpenWifi::Now(); |                             SD.info.modified = SD.info.created = Utils::Now(); | ||||||
|                             SD.info.name = IT.realMacAddress; |                             SD.info.name = IT.realMacAddress; | ||||||
|                             SD.operatorId = SE.operatorId; |                             SD.operatorId = SE.operatorId; | ||||||
|                             SD.serialNumber = SerialNumber; |                             SD.serialNumber = SerialNumber; | ||||||
| @@ -97,26 +102,26 @@ namespace OpenWifi { | |||||||
|                             SD.state = OS.str(); |                             SD.state = OS.str(); | ||||||
|                             SD.subscriberId = SE.userId; |                             SD.subscriberId = SE.userId; | ||||||
|  |  | ||||||
|                             Logger().information(fmt::format("Setting service class for {}",SD.serialNumber)); |                             poco_information(Logger(),fmt::format("Setting service class for {}",SD.serialNumber)); | ||||||
|                             SD.serviceClass = StorageService()->ServiceClassDB().DefaultForOperator(SE.operatorId); |                             SD.serviceClass = StorageService()->ServiceClassDB().DefaultForOperator(SE.operatorId); | ||||||
|                             Logger().information(fmt::format("Removing old device information for {}",SD.serialNumber)); |                             poco_information(Logger(),fmt::format("Removing old device information for {}",SD.serialNumber)); | ||||||
|                             StorageService()->SubscriberDeviceDB().DeleteRecord("serialNumber", SD.serialNumber); |                             StorageService()->SubscriberDeviceDB().DeleteRecord("serialNumber", SD.serialNumber); | ||||||
|                             Logger().information(fmt::format("Creating subscriber device for {}",SD.serialNumber)); |                             poco_information(Logger(),fmt::format("Creating subscriber device for {}",SD.serialNumber)); | ||||||
|                             StorageService()->SubscriberDeviceDB().CreateRecord(SD); |                             StorageService()->SubscriberDeviceDB().CreateRecord(SD); | ||||||
|                             Logger().information(fmt::format("Removing old inventory for {}",SD.serialNumber)); |                             poco_information(Logger(),fmt::format("Removing old inventory for {}",SD.serialNumber)); | ||||||
|                             StorageService()->InventoryDB().DeleteRecord("serialNumber", SD.serialNumber); |                             StorageService()->InventoryDB().DeleteRecord("serialNumber", SD.serialNumber); | ||||||
|  |  | ||||||
|                             SE.status = "signup completed"; |                             SE.status = "signup completed"; | ||||||
|                             SE.serialNumber = SerialNumber; |                             SE.serialNumber = SerialNumber; | ||||||
|                             SE.statusCode = ProvObjects::SignupStatusCodes::SignupSuccess; |                             SE.statusCode = ProvObjects::SignupStatusCodes::SignupSuccess; | ||||||
|                             SE.completed = OpenWifi::Now(); |                             SE.completed = Utils::Now(); | ||||||
|                             SE.info.modified = OpenWifi::Now(); |                             SE.info.modified = Utils::Now(); | ||||||
|                             SE.error = 0; |                             SE.error = 0; | ||||||
|                             Logger().information(fmt::format("Completed signup for {}",SD.serialNumber)); |                             poco_information(Logger(),fmt::format("Completed signup for {}",SD.serialNumber)); | ||||||
|                             StorageService()->SignupDB().UpdateRecord("id", SE.info.id, SE); |                             StorageService()->SignupDB().UpdateRecord("id", SE.info.id, SE); | ||||||
|                             Logger().information(fmt::format("Setting GW subscriber for {}",SD.serialNumber)); |                             poco_information(Logger(),fmt::format("Setting GW subscriber for {}",SD.serialNumber)); | ||||||
|                             SDK::GW::Device::SetSubscriber(SerialNumber, IT.subscriber); |                             SDK::GW::Device::SetSubscriber(SerialNumber, IT.subscriber); | ||||||
|                             Logger().information(fmt::format("Success for {}",SD.serialNumber)); |                             poco_information(Logger(),fmt::format("Success for {}",SD.serialNumber)); | ||||||
|                             break; |                             break; | ||||||
|                         } |                         } | ||||||
|                     } |                     } | ||||||
|   | |||||||
| @@ -4,7 +4,7 @@ | |||||||
|  |  | ||||||
| #pragma once | #pragma once | ||||||
|  |  | ||||||
| #include "framework/MicroService.h" | #include "framework/SubSystemServer.h" | ||||||
| #include "RESTObjects/RESTAPI_ProvObjects.h" | #include "RESTObjects/RESTAPI_ProvObjects.h" | ||||||
| #include "Poco/Timer.h" | #include "Poco/Timer.h" | ||||||
|  |  | ||||||
|   | |||||||
| @@ -8,10 +8,13 @@ | |||||||
|  |  | ||||||
| #include "StorageService.h" | #include "StorageService.h" | ||||||
| #include "RESTObjects/RESTAPI_ProvObjects.h" | #include "RESTObjects/RESTAPI_ProvObjects.h" | ||||||
|  | #include "framework/utils.h" | ||||||
|  | #include "fmt/format.h" | ||||||
|  |  | ||||||
| namespace OpenWifi { | namespace OpenWifi { | ||||||
|  |  | ||||||
|     int Storage::Start() { |     int Storage::Start() { | ||||||
|  |         poco_information(Logger(),"Starting..."); | ||||||
| 		std::lock_guard		Guard(Mutex_); | 		std::lock_guard		Guard(Mutex_); | ||||||
|  |  | ||||||
| 		StorageClass::Start(); | 		StorageClass::Start(); | ||||||
| @@ -34,6 +37,7 @@ namespace OpenWifi { | |||||||
|         SubscriberDeviceDB_ = std::make_unique<OpenWifi::SubscriberDeviceDB>(dbType_, *Pool_, Logger()); |         SubscriberDeviceDB_ = std::make_unique<OpenWifi::SubscriberDeviceDB>(dbType_, *Pool_, Logger()); | ||||||
|         OpLocationDB_ = std::make_unique<OpenWifi::OpLocationDB>(dbType_, *Pool_, Logger()); |         OpLocationDB_ = std::make_unique<OpenWifi::OpLocationDB>(dbType_, *Pool_, Logger()); | ||||||
|         OpContactDB_ = std::make_unique<OpenWifi::OpContactDB>(dbType_, *Pool_, Logger()); |         OpContactDB_ = std::make_unique<OpenWifi::OpContactDB>(dbType_, *Pool_, Logger()); | ||||||
|  |         OverridesDB_ = std::make_unique<OpenWifi::OverridesDB>(dbType_, *Pool_, Logger()); | ||||||
|  |  | ||||||
|         EntityDB_->Create(); |         EntityDB_->Create(); | ||||||
|         PolicyDB_->Create(); |         PolicyDB_->Create(); | ||||||
| @@ -53,6 +57,7 @@ namespace OpenWifi { | |||||||
|         SubscriberDeviceDB_->Create(); |         SubscriberDeviceDB_->Create(); | ||||||
|         OpLocationDB_->Create(); |         OpLocationDB_->Create(); | ||||||
|         OpContactDB_->Create(); |         OpContactDB_->Create(); | ||||||
|  |         OverridesDB_->Create(); | ||||||
|  |  | ||||||
|         ExistFunc_[EntityDB_->Prefix()] = [=](const char *F, std::string &V) -> bool { return EntityDB_->Exists(F,V); }; |         ExistFunc_[EntityDB_->Prefix()] = [=](const char *F, std::string &V) -> bool { return EntityDB_->Exists(F,V); }; | ||||||
|         ExistFunc_[PolicyDB_->Prefix()] = [=](const char *F, std::string &V) -> bool { return PolicyDB_->Exists(F,V); }; |         ExistFunc_[PolicyDB_->Prefix()] = [=](const char *F, std::string &V) -> bool { return PolicyDB_->Exists(F,V); }; | ||||||
| @@ -72,6 +77,7 @@ namespace OpenWifi { | |||||||
|         ExistFunc_[SubscriberDeviceDB_->Prefix()] = [=](const char *F, std::string &V) ->bool { return SubscriberDeviceDB_->Exists(F,V); }; |         ExistFunc_[SubscriberDeviceDB_->Prefix()] = [=](const char *F, std::string &V) ->bool { return SubscriberDeviceDB_->Exists(F,V); }; | ||||||
|         ExistFunc_[OpLocationDB_->Prefix()] = [=](const char *F, std::string &V) ->bool { return OpLocationDB_->Exists(F,V); }; |         ExistFunc_[OpLocationDB_->Prefix()] = [=](const char *F, std::string &V) ->bool { return OpLocationDB_->Exists(F,V); }; | ||||||
|         ExistFunc_[OpContactDB_->Prefix()] = [=](const char *F, std::string &V) ->bool { return OpContactDB_->Exists(F,V); }; |         ExistFunc_[OpContactDB_->Prefix()] = [=](const char *F, std::string &V) ->bool { return OpContactDB_->Exists(F,V); }; | ||||||
|  |         ExistFunc_[OverridesDB_->Prefix()] = [=](const char *F, std::string &V) ->bool { return OverridesDB_->Exists(F,V); }; | ||||||
|  |  | ||||||
|         ExpandFunc_[EntityDB_->Prefix()] = [=](const char *F, std::string &V, std::string &Name, std::string & Description) -> bool { return EntityDB_->GetNameAndDescription(F,V, Name, Description); }; |         ExpandFunc_[EntityDB_->Prefix()] = [=](const char *F, std::string &V, std::string &Name, std::string & Description) -> bool { return EntityDB_->GetNameAndDescription(F,V, Name, Description); }; | ||||||
|         ExpandFunc_[PolicyDB_->Prefix()] = [=](const char *F, std::string &V, std::string &Name, std::string & Description) -> bool { return PolicyDB_->GetNameAndDescription(F,V, Name, Description); }; |         ExpandFunc_[PolicyDB_->Prefix()] = [=](const char *F, std::string &V, std::string &Name, std::string & Description) -> bool { return PolicyDB_->GetNameAndDescription(F,V, Name, Description); }; | ||||||
| @@ -91,6 +97,7 @@ namespace OpenWifi { | |||||||
|         ExpandFunc_[SubscriberDeviceDB_->Prefix()] = [=](const char *F, std::string &V, std::string &Name, std::string & Description) ->bool { return SubscriberDeviceDB_->GetNameAndDescription(F,V, Name, Description); }; |         ExpandFunc_[SubscriberDeviceDB_->Prefix()] = [=](const char *F, std::string &V, std::string &Name, std::string & Description) ->bool { return SubscriberDeviceDB_->GetNameAndDescription(F,V, Name, Description); }; | ||||||
|         ExpandFunc_[OpLocationDB_->Prefix()] = [=](const char *F, std::string &V, std::string &Name, std::string & Description) ->bool { return OpLocationDB_->GetNameAndDescription(F,V, Name, Description); }; |         ExpandFunc_[OpLocationDB_->Prefix()] = [=](const char *F, std::string &V, std::string &Name, std::string & Description) ->bool { return OpLocationDB_->GetNameAndDescription(F,V, Name, Description); }; | ||||||
|         ExpandFunc_[OpContactDB_->Prefix()] = [=](const char *F, std::string &V, std::string &Name, std::string & Description) ->bool { return OpContactDB_->GetNameAndDescription(F,V, Name, Description); }; |         ExpandFunc_[OpContactDB_->Prefix()] = [=](const char *F, std::string &V, std::string &Name, std::string & Description) ->bool { return OpContactDB_->GetNameAndDescription(F,V, Name, Description); }; | ||||||
|  |         ExpandFunc_[OverridesDB_->Prefix()] = [=]( [[maybe_unused]] const char *F, [[maybe_unused]] std::string &V, [[maybe_unused]] std::string &Name, [[maybe_unused]] std::string & Description) ->bool { return false; }; | ||||||
|  |  | ||||||
|         InventoryDB_->InitializeSerialCache(); |         InventoryDB_->InitializeSerialCache(); | ||||||
|  |  | ||||||
| @@ -109,8 +116,9 @@ namespace OpenWifi { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     void Storage::Stop() { |     void Storage::Stop() { | ||||||
|  |         poco_information(Logger(),"Stopping..."); | ||||||
|         Timer_.stop(); |         Timer_.stop(); | ||||||
|         Logger().notice("Stopping."); |         poco_information(Logger(),"Stopped..."); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     bool Storage::Validate(const Poco::URI::QueryParameters &P, RESTAPI::Errors::msg &Error) { |     bool Storage::Validate(const Poco::URI::QueryParameters &P, RESTAPI::Errors::msg &Error) { | ||||||
| @@ -195,18 +203,24 @@ namespace OpenWifi { | |||||||
|         // check that all inventory in venues and entities actually exists, if not, fix it. |         // check that all inventory in venues and entities actually exists, if not, fix it. | ||||||
|         auto FixVenueDevices = [&](const ProvObjects::Venue &V) -> bool { |         auto FixVenueDevices = [&](const ProvObjects::Venue &V) -> bool { | ||||||
|             Types::UUIDvec_t NewDevices; |             Types::UUIDvec_t NewDevices; | ||||||
|  |             bool modified=false; | ||||||
|             for(const auto &device:V.devices) { |             for(const auto &device:V.devices) { | ||||||
|                 ProvObjects::InventoryTag T; |                 ProvObjects::InventoryTag T; | ||||||
|                 if(InventoryDB().GetRecord("id", device, T)) { |                 if(InventoryDB().GetRecord("id", device, T)) { | ||||||
|                     NewDevices.emplace_back(device); |                     NewDevices.emplace_back(device); | ||||||
|                 } else { |                 } else { | ||||||
|  |                     modified=true; | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|  |  | ||||||
|             if(NewDevices!=V.devices) { |             ProvObjects::Venue NewVenue = V; | ||||||
|                 Logger().warning(fmt::format("  fixing venue: {}", V.info.name)); |             if(V.deviceRules.rrm=="yes") { | ||||||
|                 ProvObjects::Venue NewVenue = V; |                 NewVenue.deviceRules.rrm="inherit"; | ||||||
|  |                 modified=true; | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |             if(modified) { | ||||||
|  |                 poco_warning(Logger(),fmt::format("  fixing venue: {}", V.info.name)); | ||||||
|                 NewVenue.devices = NewDevices; |                 NewVenue.devices = NewDevices; | ||||||
|                 VenueDB().UpdateRecord("id", V.info.id, NewVenue); |                 VenueDB().UpdateRecord("id", V.info.id, NewVenue); | ||||||
|             } |             } | ||||||
| @@ -266,10 +280,16 @@ namespace OpenWifi { | |||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|  |  | ||||||
|  |             ProvObjects::Entity NewEntity = E; | ||||||
|  |  | ||||||
|  |             if(E.deviceRules.rrm=="yes") { | ||||||
|  |                 NewEntity.deviceRules.rrm="inherit"; | ||||||
|  |                 Modified=true; | ||||||
|  |             } | ||||||
|  |  | ||||||
|             if(Modified) |             if(Modified) | ||||||
|             { |             { | ||||||
|                 Logger().warning(fmt::format("  fixing entity: {}",E.info.name)); |                 poco_warning(Logger(),fmt::format("  fixing entity: {}",E.info.name)); | ||||||
|                 ProvObjects::Entity NewEntity = E; |  | ||||||
|                 NewEntity.devices = NewDevices; |                 NewEntity.devices = NewDevices; | ||||||
|                 NewEntity.contacts = NewContacts; |                 NewEntity.contacts = NewContacts; | ||||||
|                 NewEntity.locations = NewLocations; |                 NewEntity.locations = NewLocations; | ||||||
| @@ -304,19 +324,79 @@ namespace OpenWifi { | |||||||
|                 modified=true; |                 modified=true; | ||||||
|             } |             } | ||||||
|  |  | ||||||
|  |             if(T.deviceRules.rrm=="yes") { | ||||||
|  |                 NewTag.deviceRules.rrm = "inherit"; | ||||||
|  |                 modified=true; | ||||||
|  |             } | ||||||
|  |  | ||||||
|             if(modified) { |             if(modified) { | ||||||
|                 Logger().warning(fmt::format("  fixing entity: {}",T.info.name)); |                 poco_warning(Logger(),fmt::format("  fixing entity: {}",T.info.name)); | ||||||
|                 InventoryDB().UpdateRecord("id", T.info.id, NewTag); |                 InventoryDB().UpdateRecord("id", T.info.id, NewTag); | ||||||
|             } |             } | ||||||
|             return true; |             return true; | ||||||
|         }; |         }; | ||||||
|  |  | ||||||
|         Logger().information("Checking DB consistency: venues"); |         auto FixConfiguration = [&](const ProvObjects::DeviceConfiguration &C) -> bool { | ||||||
|  |             ProvObjects::DeviceConfiguration NewConfig{C}; | ||||||
|  |  | ||||||
|  |             bool modified = false; | ||||||
|  |  | ||||||
|  |             if (C.deviceRules.rrm == "yes") { | ||||||
|  |                 NewConfig.deviceRules.rrm = "inherit"; | ||||||
|  |                 modified = true; | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |             if (modified) { | ||||||
|  |                 poco_warning(Logger(),fmt::format("  fixing configuration: {}", C.info.name)); | ||||||
|  |                 ConfigurationDB().UpdateRecord("id", C.info.id, NewConfig); | ||||||
|  |             } | ||||||
|  |             return true; | ||||||
|  |         }; | ||||||
|  |  | ||||||
|  |         auto FixOperator = [&](const ProvObjects::Operator &O) -> bool { | ||||||
|  |             ProvObjects::Operator NewOp{O}; | ||||||
|  |             bool modified = false; | ||||||
|  |  | ||||||
|  |             if (O.deviceRules.rrm == "yes") { | ||||||
|  |                 NewOp.deviceRules.rrm = "inherit"; | ||||||
|  |                 modified = true; | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |             if (modified) { | ||||||
|  |                 poco_warning(Logger(),fmt::format("  fixing operator: {}", O.info.name)); | ||||||
|  |                 OperatorDB().UpdateRecord("id", O.info.id, NewOp); | ||||||
|  |             } | ||||||
|  |             return true; | ||||||
|  |         }; | ||||||
|  |  | ||||||
|  |         auto FixSubscriber = [&](const ProvObjects::SubscriberDevice &O) -> bool { | ||||||
|  |             ProvObjects::SubscriberDevice NewSub{O}; | ||||||
|  |             bool modified = false; | ||||||
|  |  | ||||||
|  |             if (O.deviceRules.rrm == "yes") { | ||||||
|  |                 NewSub.deviceRules.rrm = "inherit"; | ||||||
|  |                 modified = true; | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |             if (modified) { | ||||||
|  |                 poco_warning(Logger(),fmt::format("  fixing subscriber: {}", O.info.name)); | ||||||
|  |                 SubscriberDeviceDB().UpdateRecord("id", O.info.id, NewSub); | ||||||
|  |             } | ||||||
|  |             return true; | ||||||
|  |         }; | ||||||
|  |  | ||||||
|  |         poco_information(Logger(),"Checking DB consistency: venues"); | ||||||
|         VenueDB().Iterate(FixVenueDevices); |         VenueDB().Iterate(FixVenueDevices); | ||||||
|         Logger().information("Checking DB consistency: entities"); |         poco_information(Logger(),"Checking DB consistency: entities"); | ||||||
|         EntityDB().Iterate(FixEntity); |         EntityDB().Iterate(FixEntity); | ||||||
|         Logger().information("Checking DB consistency: inventory"); |         poco_information(Logger(),"Checking DB consistency: inventory"); | ||||||
|         InventoryDB().Iterate(FixInventory); |         InventoryDB().Iterate(FixInventory); | ||||||
|  |         poco_information(Logger(),"Checking DB consistency: configurations"); | ||||||
|  |         ConfigurationDB().Iterate(FixConfiguration); | ||||||
|  |         poco_information(Logger(),"Checking DB consistency: operators"); | ||||||
|  |         OperatorDB().Iterate(FixOperator); | ||||||
|  |         poco_information(Logger(),"Checking DB consistency: subscribers"); | ||||||
|  |         SubscriberDeviceDB().Iterate(FixSubscriber); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     void Storage::InitializeSystemDBs() { |     void Storage::InitializeSystemDBs() { | ||||||
| @@ -325,7 +405,7 @@ namespace OpenWifi { | |||||||
|  |  | ||||||
|             Root.info.id = EntityDB::RootUUID(); |             Root.info.id = EntityDB::RootUUID(); | ||||||
|             Root.info.name = "Top Entity"; |             Root.info.name = "Top Entity"; | ||||||
|             Root.info.created = Root.info.modified = OpenWifi::Now(); |             Root.info.created = Root.info.modified = Utils::Now(); | ||||||
|             Root.deviceRules.rrm = "off"; |             Root.deviceRules.rrm = "off"; | ||||||
|             EntityDB().CreateRecord(Root); |             EntityDB().CreateRecord(Root); | ||||||
|         } |         } | ||||||
| @@ -333,18 +413,18 @@ namespace OpenWifi { | |||||||
|         auto OperatorCount = OperatorDB().Count(); |         auto OperatorCount = OperatorDB().Count(); | ||||||
|         if(OperatorCount==0) { |         if(OperatorCount==0) { | ||||||
|             ProvObjects::Operator DefOp; |             ProvObjects::Operator DefOp; | ||||||
|             DefOp.info.id = MicroService::CreateUUID(); |             DefOp.info.id = MicroServiceCreateUUID(); | ||||||
|             DefOp.info.name = "Default Operator"; |             DefOp.info.name = "Default Operator"; | ||||||
|             DefOp.defaultOperator = true; |             DefOp.defaultOperator = true; | ||||||
|             DefOp.info.created = DefOp.info.modified = OpenWifi::Now(); |             DefOp.info.created = DefOp.info.modified = Utils::Now(); | ||||||
|             DefOp.deviceRules.rrm = "inherit"; |             DefOp.deviceRules.rrm = "inherit"; | ||||||
|             OperatorDB_->CreateRecord(DefOp); |             OperatorDB_->CreateRecord(DefOp); | ||||||
|  |  | ||||||
|             ProvObjects::ServiceClass DefSer; |             ProvObjects::ServiceClass DefSer; | ||||||
|             DefSer.info.id = MicroService::CreateUUID(); |             DefSer.info.id = MicroServiceCreateUUID(); | ||||||
|             DefSer.info.name = "Default Service Class"; |             DefSer.info.name = "Default Service Class"; | ||||||
|             DefSer.defaultService = true; |             DefSer.defaultService = true; | ||||||
|             DefSer.info.created = DefSer.info.modified = OpenWifi::Now(); |             DefSer.info.created = DefSer.info.modified = Utils::Now(); | ||||||
|             DefSer.operatorId = DefOp.info.id; |             DefSer.operatorId = DefOp.info.id; | ||||||
|             DefSer.period = "monthly"; |             DefSer.period = "monthly"; | ||||||
|             DefSer.billingCode = "basic"; |             DefSer.billingCode = "basic"; | ||||||
|   | |||||||
| @@ -8,9 +8,8 @@ | |||||||
|  |  | ||||||
| #pragma once | #pragma once | ||||||
|  |  | ||||||
| #include "framework/MicroService.h" |  | ||||||
| #include "framework/StorageClass.h" | #include "framework/StorageClass.h" | ||||||
|  | #include "framework/MicroServiceFuncs.h" | ||||||
| #include "storage/storage_entity.h" | #include "storage/storage_entity.h" | ||||||
| #include "storage/storage_policies.h" | #include "storage/storage_policies.h" | ||||||
| #include "storage/storage_venue.h" | #include "storage/storage_venue.h" | ||||||
| @@ -28,6 +27,10 @@ | |||||||
| #include "storage/storage_operataor.h" | #include "storage/storage_operataor.h" | ||||||
| #include "storage/storage_service_class.h" | #include "storage/storage_service_class.h" | ||||||
| #include "storage/storage_sub_devices.h" | #include "storage/storage_sub_devices.h" | ||||||
|  | #include "storage/storage_overrides.h" | ||||||
|  |  | ||||||
|  | #include "Poco/URI.h" | ||||||
|  | #include "framework/ow_constants.h" | ||||||
|  |  | ||||||
| namespace OpenWifi { | namespace OpenWifi { | ||||||
|  |  | ||||||
| @@ -62,6 +65,7 @@ namespace OpenWifi { | |||||||
|             OpenWifi::SubscriberDeviceDB & SubscriberDeviceDB() { return *SubscriberDeviceDB_; }; |             OpenWifi::SubscriberDeviceDB & SubscriberDeviceDB() { return *SubscriberDeviceDB_; }; | ||||||
|             OpenWifi::OpLocationDB & OpLocationDB() { return *OpLocationDB_; }; |             OpenWifi::OpLocationDB & OpLocationDB() { return *OpLocationDB_; }; | ||||||
|             OpenWifi::OpContactDB & OpContactDB() { return *OpContactDB_; }; |             OpenWifi::OpContactDB & OpContactDB() { return *OpContactDB_; }; | ||||||
|  |             OpenWifi::OverridesDB & OverridesDB() { return *OverridesDB_; }; | ||||||
|  |  | ||||||
|             bool Validate(const Poco::URI::QueryParameters &P, RESTAPI::Errors::msg &Error); |             bool Validate(const Poco::URI::QueryParameters &P, RESTAPI::Errors::msg &Error); | ||||||
|             bool Validate(const Types::StringVec &P, std::string &Error); |             bool Validate(const Types::StringVec &P, std::string &Error); | ||||||
| @@ -87,11 +91,11 @@ namespace OpenWifi { | |||||||
|  |  | ||||||
|             static inline bool ApplyConfigRules(ProvObjects::DeviceRules & R_res) { |             static inline bool ApplyConfigRules(ProvObjects::DeviceRules & R_res) { | ||||||
|                 if(R_res.firmwareUpgrade=="inherit") |                 if(R_res.firmwareUpgrade=="inherit") | ||||||
|                     R_res.firmwareUpgrade=MicroService::instance().ConfigGetString("firmware.updater.upgrade","yes"); |                     R_res.firmwareUpgrade=MicroServiceConfigGetString("firmware.updater.upgrade","yes"); | ||||||
|                 if(R_res.rcOnly=="inherit") |                 if(R_res.rcOnly=="inherit") | ||||||
|                     R_res.rcOnly=MicroService::instance().ConfigGetString("firmware.updater.releaseonly","yes"); |                     R_res.rcOnly=MicroServiceConfigGetString("firmware.updater.releaseonly","yes"); | ||||||
|                 if(R_res.rrm=="inherit") |                 if(R_res.rrm=="inherit") | ||||||
|                     R_res.rrm=MicroService::instance().ConfigGetString("rrm.default","no"); |                     R_res.rrm=MicroServiceConfigGetString("rrm.default","no"); | ||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
|  |  | ||||||
| @@ -114,6 +118,7 @@ namespace OpenWifi { | |||||||
|             std::unique_ptr<OpenWifi::SubscriberDeviceDB>       SubscriberDeviceDB_; |             std::unique_ptr<OpenWifi::SubscriberDeviceDB>       SubscriberDeviceDB_; | ||||||
|             std::unique_ptr<OpenWifi::OpLocationDB>             OpLocationDB_; |             std::unique_ptr<OpenWifi::OpLocationDB>             OpLocationDB_; | ||||||
|             std::unique_ptr<OpenWifi::OpContactDB>              OpContactDB_; |             std::unique_ptr<OpenWifi::OpContactDB>              OpContactDB_; | ||||||
|  |             std::unique_ptr<OpenWifi::OverridesDB>              OverridesDB_; | ||||||
|             std::string                                         DefaultOperator_; |             std::string                                         DefaultOperator_; | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -4,6 +4,7 @@ | |||||||
|  |  | ||||||
| #include "TagServer.h" | #include "TagServer.h" | ||||||
| #include "StorageService.h" | #include "StorageService.h" | ||||||
|  | #include "framework/utils.h" | ||||||
|  |  | ||||||
| namespace OpenWifi { | namespace OpenWifi { | ||||||
|     int TagServer::Start() { |     int TagServer::Start() { | ||||||
|   | |||||||
| @@ -4,7 +4,7 @@ | |||||||
|  |  | ||||||
| #pragma once | #pragma once | ||||||
|  |  | ||||||
| #include "framework/MicroService.h" | #include "framework/SubSystemServer.h" | ||||||
|  |  | ||||||
| namespace OpenWifi { | namespace OpenWifi { | ||||||
|  |  | ||||||
|   | |||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user