mirror of
				https://github.com/Telecominfraproject/wlan-cloud-ucentralsec.git
				synced 2025-10-31 02:37:56 +00:00 
			
		
		
		
	Compare commits
	
		
			2 Commits
		
	
	
		
			v3.0.2-RC1
			...
			v2.10.0
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | aaebf74539 | ||
|   | 5a6baeca7d | 
							
								
								
									
										62
									
								
								BUILDING.md
									
									
									
									
									
								
							
							
						
						
									
										62
									
								
								BUILDING.md
									
									
									
									
									
								
							| @@ -1,6 +1,6 @@ | |||||||
| # Building from source | # Building from source | ||||||
|  |  | ||||||
| In order to build OWSEC, you will need to install its dependencies, which includes the following: | In order to build the OWSEC, you will need to install its dependencies, which includes the following: | ||||||
| - cmake | - cmake | ||||||
| - boost | - boost | ||||||
| - POCO 1.10.1 or later | - POCO 1.10.1 or later | ||||||
| @@ -13,43 +13,43 @@ In order to build OWSEC, you will need to install its dependencies, which includ | |||||||
|  |  | ||||||
| The build is done in 2 parts. The first part is to build a local copy of the framework tailored to your environment. This | The build is done in 2 parts. The first part is to build a local copy of the framework tailored to your environment. This | ||||||
| framework is called [Poco](https://github.com/pocoproject/poco). The version used in this project has a couple of fixes | framework is called [Poco](https://github.com/pocoproject/poco). The version used in this project has a couple of fixes | ||||||
| from the master copy needed for cmake. Please use the version of this [Poco fix](https://github.com/Telecominfraproject/wlan-cloud-lib-poco). Building | from the master copy needed for cmake. Please use the version of this [Poco fix](https://github.com/AriliaWireless/poco). Building | ||||||
| Poco may take several minutes depending on the platform you are building on. | Poco may take several minutes depending on the platform you are building on. | ||||||
|  |  | ||||||
| ## Ubuntu | ## Ubuntu | ||||||
| These instructions have proven to work on Ubuntu 20.4. | These instructions have proven to work on Ubuntu 20.4. | ||||||
| ```bash | ```bash | ||||||
| sudo apt install git cmake g++ libssl-dev libmariadb-dev \ | sudo apt install git cmake g++ libssl-dev libmariadb-dev  | ||||||
|     libpq-dev libaprutil1-dev apache2-dev libboost-all-dev \ | sudo apt install libpq-dev libaprutil1-dev apache2-dev libboost-all-dev | ||||||
|     librdkafka-dev default-libmysqlclient-dev \ | sudo apt install librdkafka-dev default-libmysqlclient-dev | ||||||
|     nlohmann-json-dev | sudo apt install nlohmann-json-dev | ||||||
|  |  | ||||||
| git clone https://github.com/Telecominfraproject/wlan-cloud-lib-poco --branch poco-tip-v1 poco | cd ~ | ||||||
|  | git clone https://github.com/AriliaWireless/poco --branch poco-tip-v1 | ||||||
| cd poco | cd poco | ||||||
| mkdir cmake-build | mkdir cmake-build | ||||||
| cd cmake-build | cd cmake-build | ||||||
| cmake .. | cmake .. | ||||||
| cmake --build . --config Release | cmake --build . --config Release | ||||||
| sudo cmake --build . --target install | sudo cmake --build . --target install | ||||||
| cd ../.. |  | ||||||
|  |  | ||||||
| git clone https://github.com/Telecominfraproject/wlan-cloud-lib-cppkafka --branch tip-v1 cppkafka | cd ~ | ||||||
|  | git clone https://github.com/AriliaWireless/cppkafka --branch tip-v1 | ||||||
| cd cppkafka | cd cppkafka | ||||||
| mkdir cmake-build | mkdir cmake-build | ||||||
| cd cmake-build | cd cmake-build | ||||||
| cmake .. | cmake .. | ||||||
| cmake --build . --config Release | cmake --build . --config Release | ||||||
| sudo cmake --build . --target install | sudo cmake --build . --target install | ||||||
| cd ../.. |  | ||||||
|  |  | ||||||
| git clone https://github.com/Telecominfraproject/wlan-cloud-lib-valijson --branch tip-v1 valijson | cd ~ | ||||||
|  | git clone https://github.com/AriliaWireless/valijson --branch tip-v1 | ||||||
| cd valijson | cd valijson | ||||||
| mkdir cmake-build | mkdir cmake-build | ||||||
| cd cmake-build | cd cmake-build | ||||||
| cmake .. | cmake .. | ||||||
| cmake --build . --config Release | cmake --build . --config Release | ||||||
| sudo cmake --build . --target install | sudo cmake --build . --target install | ||||||
| cd ../.. |  | ||||||
|  |  | ||||||
| git clone https://github.com/fmtlib/fmt --branch 9.0.0 /fmtlib | git clone https://github.com/fmtlib/fmt --branch 9.0.0 /fmtlib | ||||||
| cd fmtlib | cd fmtlib | ||||||
| @@ -58,59 +58,56 @@ cd cmake-build | |||||||
| cmake .. | cmake .. | ||||||
| make | make | ||||||
| make install | make install | ||||||
| cd ../.. |  | ||||||
|  |  | ||||||
|  | cd ~ | ||||||
| git clone https://github.com/Telecominfraproject/wlan-cloud-ucentralsec | git clone https://github.com/Telecominfraproject/wlan-cloud-ucentralsec | ||||||
| cd wlan-cloud-ucentralsec | cd wlan-cloud-ucentralsec | ||||||
| mkdir cmake-build | mkdir cmake-build | ||||||
| cd cmake-build | cd cmake-build | ||||||
| cmake .. | cmake .. | ||||||
| make -j 8 | make -j 8 | ||||||
| cd ../.. |  | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| ## Fedora | ## Fedora | ||||||
| The following instructions have proven to work on Fedora 33 | The following instructions have proven to work on Fedora 33 | ||||||
| ```bash | ```bash | ||||||
| sudo yum install cmake g++ openssl-devel mysql-devel mysql apr-util-devel boost boost-devel \ | sudo yum install cmake g++ openssl-devel mysql-devel mysql apr-util-devel boost boost-devel | ||||||
|     yaml-cpp-devel lua-devel | sudo yum install yaml-cpp-devel lua-devel  | ||||||
| sudo dnf install postgresql.x86_64 librdkafka-devel | sudo dnf install postgresql.x86_64 librdkafka-devel | ||||||
| sudo dnf install postgresql-devel json-devel | sudo dnf install postgresql-devel json-devel | ||||||
|  |  | ||||||
| git clone https://github.com/Telecominfraproject/wlan-cloud-lib-poco --branch poco-tip-v1 poco | git clone https://github.com/AriliaWireless/poco --branch poco-tip-v1 | ||||||
| cd poco | cd poco | ||||||
| mkdir cmake-build | mkdir cmake-build | ||||||
| cd cmake-build | cd cmake-build | ||||||
| cmake .. | cmake .. | ||||||
| cmake --build . --config Release | cmake --build . --config Release | ||||||
| sudo cmake --build . --target install | sudo cmake --build . --target install | ||||||
| cd ../.. |  | ||||||
|  |  | ||||||
| git clone https://github.com/Telecominfraproject/wlan-cloud-lib-cppkafka --branch tip-v1 cppkafka | git clone https://github.com/AriliaWireless/cppkafka --branch tip-v1 | ||||||
| cd cppkafka | cd cppkafka | ||||||
| mkdir cmake-build | mkdir cmake-build | ||||||
| cd cmake-build | cd cmake-build | ||||||
| cmake .. | cmake .. | ||||||
| cmake --build . --config Release | cmake --build . --config Release | ||||||
| sudo cmake --build . --target install | sudo cmake --build . --target install | ||||||
| cd ../.. |  | ||||||
|  |  | ||||||
| git clone https://github.com/Telecominfraproject/wlan-cloud-lib-valijson --branch tip-v1 valijson | cd ~ | ||||||
|  | git clone https://github.com/AriliaWireless/valijson --branch tip-v1 | ||||||
| cd valijson | cd valijson | ||||||
| mkdir cmake-build | mkdir cmake-build | ||||||
| cd cmake-build | cd cmake-build | ||||||
| cmake .. | cmake .. | ||||||
| cmake --build . --config Release | cmake --build . --config Release | ||||||
| sudo cmake --build . --target install | sudo cmake --build . --target install | ||||||
| cd ../.. |  | ||||||
|  |  | ||||||
|  | cd ~ | ||||||
| git clone https://github.com/Telecominfraproject/wlan-cloud-ucentralsec | git clone https://github.com/Telecominfraproject/wlan-cloud-ucentralsec | ||||||
| cd wlan-cloud-ucentralsec | cd wlan-cloud-ucentralsec | ||||||
| mkdir cmake-build | mkdir cmake-build | ||||||
| cd cmake-build | cd cmake-build | ||||||
| cmake .. | cmake .. | ||||||
| make | make | ||||||
| cd ../.. |  | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| ## macOS Build | ## macOS Build | ||||||
| @@ -129,7 +126,7 @@ brew install openssl \ | |||||||
| 	nlohmann-json \ | 	nlohmann-json \ | ||||||
| 	fmt | 	fmt | ||||||
|  |  | ||||||
| git clone https://github.com/Telecominfraproject/wlan-cloud-lib-poco --branch poco-tip-v1 poco | git clone https://github.com/AriliaWireless/poco --branch poco-tip-v1 | ||||||
| pushd poco | pushd poco | ||||||
| mkdir cmake-build | mkdir cmake-build | ||||||
| push cmake-build | push cmake-build | ||||||
| @@ -139,7 +136,7 @@ sudo cmake --build . --target install | |||||||
| popd | popd | ||||||
| popd | popd | ||||||
|  |  | ||||||
| git clone https://github.com/Telecominfraproject/wlan-cloud-lib-cppkafka --branch tip-v1 cppkafka | git clone https://github.com/AriliaWireless/cppkafka --branch tip-v1 | ||||||
| pushd cppkafka | pushd cppkafka | ||||||
| mkdir cmake-build | mkdir cmake-build | ||||||
| pushd cmake-build | pushd cmake-build | ||||||
| @@ -149,10 +146,10 @@ sudo cmake --build . --target install | |||||||
| popd | popd | ||||||
| popd | popd | ||||||
|  |  | ||||||
| git clone https://github.com/Telecominfraproject/wlan-cloud-lib-valijson --branch tip-v1 valijson | git clone https://github.com/AriliaWireless/valijson --branch tip-v1 | ||||||
| pushd valijson | cd valijson | ||||||
| mkdir cmake-build | mkdir cmake-build | ||||||
| pushd cmake-build | cd cmake-build | ||||||
| cmake .. | cmake .. | ||||||
| cmake --build . --config Release | cmake --build . --config Release | ||||||
| sudo cmake --build . --target install | sudo cmake --build . --target install | ||||||
| @@ -175,23 +172,20 @@ support. You can build with only SQLite support by not installing the packages f | |||||||
| adding -DSMALL_BUILD=1 on the cmake build line. | adding -DSMALL_BUILD=1 on the cmake build line. | ||||||
|  |  | ||||||
| ```bash | ```bash | ||||||
| sudo apt install git cmake g++ libssl-dev libaprutil1-dev apache2-dev \ | sudo apt install git cmake g++ libssl-dev libaprutil1-dev apache2-dev libboost-all-dev libyaml-cpp-dev | ||||||
|     libboost-all-dev libyaml-cpp-dev | git clone https://github.com/stephb9959/poco | ||||||
|  |  | ||||||
| git clone https://github.com/Telecominfraproject/wlan-cloud-lib-poco --branch poco-tip-v1 poco |  | ||||||
| cd poco | cd poco | ||||||
| mkdir cmake-build | mkdir cmake-build | ||||||
| cd cmake-build | cd cmake-build | ||||||
| cmake .. | cmake .. | ||||||
| cmake --build . --config Release | cmake --build . --config Release | ||||||
| sudo cmake --build . --target install | sudo cmake --build . --target install | ||||||
| cd ../.. |  | ||||||
|  |  | ||||||
|  | cd ~ | ||||||
| git clone https://github.com/Telecominfraproject/wlan-cloud-ucentralsec | git clone https://github.com/Telecominfraproject/wlan-cloud-ucentralsec | ||||||
| cd wlan-cloud-ucentralsec | cd wlan-cloud-ucentralsec | ||||||
| mkdir cmake-build | mkdir cmake-build | ||||||
| cd cmake-build | cd cmake-build | ||||||
| cmake -DSMALL_BUILD=1 .. | cmake -DSMALL_BUILD=1 .. | ||||||
| make | make | ||||||
| cd ../.. |  | ||||||
| ``` | ``` | ||||||
|   | |||||||
| @@ -1,5 +1,5 @@ | |||||||
| cmake_minimum_required(VERSION 3.13) | cmake_minimum_required(VERSION 3.13) | ||||||
| project(owsec VERSION 3.0.0) | project(owsec VERSION 2.10.0) | ||||||
|  |  | ||||||
| set(CMAKE_CXX_STANDARD 17) | set(CMAKE_CXX_STANDARD 17) | ||||||
|  |  | ||||||
| @@ -42,7 +42,7 @@ if(GIT_FOUND AND EXISTS "${PROJECT_SOURCE_DIR}/.git") | |||||||
|     string(REGEX REPLACE "\n$" "" GIT_HASH "${GIT_HASH}") |     string(REGEX REPLACE "\n$" "" GIT_HASH "${GIT_HASH}") | ||||||
| endif() | endif() | ||||||
|  |  | ||||||
| add_definitions(-DAWS_CUSTOM_MEMORY_MANAGEMENT -DBOOST_NO_CXX98_FUNCTION_BASE=1) | add_definitions(-DAWS_CUSTOM_MEMORY_MANAGEMENT) | ||||||
|  |  | ||||||
| set(BUILD_SHARED_LIBS 1) | set(BUILD_SHARED_LIBS 1) | ||||||
|  |  | ||||||
| @@ -185,7 +185,6 @@ if(NOT SMALL_BUILD) | |||||||
|             CppKafka::cppkafka |             CppKafka::cppkafka | ||||||
|             ${AWSSDK_LINK_LIBRARIES} |             ${AWSSDK_LINK_LIBRARIES} | ||||||
|             fmt::fmt |             fmt::fmt | ||||||
|             resolv |  | ||||||
|             ) |             ) | ||||||
|     if(UNIX AND NOT APPLE) |     if(UNIX AND NOT APPLE) | ||||||
|         target_link_libraries(owsec PUBLIC PocoJSON) |         target_link_libraries(owsec PUBLIC PocoJSON) | ||||||
|   | |||||||
							
								
								
									
										12
									
								
								Dockerfile
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								Dockerfile
									
									
									
									
									
								
							| @@ -15,8 +15,8 @@ FROM build-base AS poco-build | |||||||
|  |  | ||||||
| ARG POCO_VERSION | ARG POCO_VERSION | ||||||
|  |  | ||||||
| ADD https://api.github.com/repos/Telecominfraproject/wlan-cloud-lib-poco/git/refs/tags/${POCO_VERSION} version.json | ADD https://api.github.com/repos/AriliaWireless/poco/git/refs/tags/${POCO_VERSION} version.json | ||||||
| RUN git clone https://github.com/Telecominfraproject/wlan-cloud-lib-poco --branch ${POCO_VERSION} /poco | RUN git clone https://github.com/AriliaWireless/poco --branch ${POCO_VERSION} /poco | ||||||
|  |  | ||||||
| WORKDIR /poco | WORKDIR /poco | ||||||
| RUN mkdir cmake-build | RUN mkdir cmake-build | ||||||
| @@ -29,8 +29,8 @@ FROM build-base AS cppkafka-build | |||||||
|  |  | ||||||
| ARG CPPKAFKA_VERSION | ARG CPPKAFKA_VERSION | ||||||
|  |  | ||||||
| ADD https://api.github.com/repos/Telecominfraproject/wlan-cloud-lib-cppkafka/git/refs/tags/${CPPKAFKA_VERSION} version.json | ADD https://api.github.com/repos/AriliaWireless/cppkafka/git/refs/tags/${CPPKAFKA_VERSION} version.json | ||||||
| RUN git clone https://github.com/Telecominfraproject/wlan-cloud-lib-cppkafka --branch ${CPPKAFKA_VERSION} /cppkafka | RUN git clone https://github.com/AriliaWireless/cppkafka --branch ${CPPKAFKA_VERSION} /cppkafka | ||||||
|  |  | ||||||
| WORKDIR /cppkafka | WORKDIR /cppkafka | ||||||
| RUN mkdir cmake-build | RUN mkdir cmake-build | ||||||
| @@ -43,8 +43,8 @@ FROM build-base AS valijson-build | |||||||
|  |  | ||||||
| ARG VALIJASON_VERSION | ARG VALIJASON_VERSION | ||||||
|  |  | ||||||
| ADD https://api.github.com/repos/Telecominfraproject/wlan-cloud-lib-valijson/git/refs/tags/${VALIJASON_VERSION} version.json | ADD https://api.github.com/repos/AriliaWireless/valijson/git/refs/tags/${VALIJASON_VERSION} version.json | ||||||
| RUN git clone https://github.com/Telecominfraproject/wlan-cloud-lib-valijson --branch ${VALIJASON_VERSION} /valijson | RUN git clone https://github.com/AriliaWireless/valijson --branch ${VALIJASON_VERSION} /valijson | ||||||
|  |  | ||||||
| WORKDIR /valijson | WORKDIR /valijson | ||||||
| RUN mkdir cmake-build | RUN mkdir cmake-build | ||||||
|   | |||||||
| @@ -9,7 +9,7 @@ fullnameOverride: "" | |||||||
| images: | images: | ||||||
|   owsec: |   owsec: | ||||||
|     repository: tip-tip-wlan-cloud-ucentral.jfrog.io/owsec |     repository: tip-tip-wlan-cloud-ucentral.jfrog.io/owsec | ||||||
|     tag: v3.0.2-RC1 |     tag: v2.10.0 | ||||||
|     pullPolicy: Always |     pullPolicy: Always | ||||||
| #    regcred: | #    regcred: | ||||||
| #      registry: tip-tip-wlan-cloud-ucentral.jfrog.io | #      registry: tip-tip-wlan-cloud-ucentral.jfrog.io | ||||||
|   | |||||||
| @@ -565,6 +565,12 @@ components: | |||||||
|             - $ref: '#/components/schemas/StringList' |             - $ref: '#/components/schemas/StringList' | ||||||
|             - $ref: '#/components/schemas/TagValuePairList' |             - $ref: '#/components/schemas/TagValuePairList' | ||||||
|  |  | ||||||
|  |     SystemCommandResults: | ||||||
|  |       type: object | ||||||
|  |       oneOf: | ||||||
|  |         - $ref: '#/components/schemas/StringList' | ||||||
|  |         - $ref: '#/components/schemas/TagValuePairList' | ||||||
|  |  | ||||||
|     SystemInfoResults: |     SystemInfoResults: | ||||||
|       type: object |       type: object | ||||||
|       properties: |       properties: | ||||||
| @@ -593,33 +599,6 @@ components: | |||||||
|                 type: integer |                 type: integer | ||||||
|                 format: int64 |                 format: int64 | ||||||
|  |  | ||||||
|     SystemResources: |  | ||||||
|       type: object |  | ||||||
|       properties: |  | ||||||
|         numberOfFileDescriptors: |  | ||||||
|           type: integer |  | ||||||
|           format: int64 |  | ||||||
|         currRealMem: |  | ||||||
|           type: integer |  | ||||||
|           format: int64 |  | ||||||
|         peakRealMem: |  | ||||||
|           type: integer |  | ||||||
|           format: int64 |  | ||||||
|         currVirtMem: |  | ||||||
|           type: integer |  | ||||||
|           format: int64 |  | ||||||
|         peakVirtMem: |  | ||||||
|           type: integer |  | ||||||
|           format: int64 |  | ||||||
|  |  | ||||||
|     SystemCommandResults: |  | ||||||
|       type: object |  | ||||||
|       oneOf: |  | ||||||
|         - $ref: '#/components/schemas/SystemResources' |  | ||||||
|         - $ref: '#/components/schemas/SystemInfoResults' |  | ||||||
|         - $ref: '#/components/schemas/StringList' |  | ||||||
|         - $ref: '#/components/schemas/TagValuePairList' |  | ||||||
|  |  | ||||||
|     ProfileAction: |     ProfileAction: | ||||||
|       type: object |       type: object | ||||||
|       properties: |       properties: | ||||||
| @@ -1988,12 +1967,16 @@ paths: | |||||||
|             type: string |             type: string | ||||||
|             enum: |             enum: | ||||||
|               - info |               - info | ||||||
|               - extraConfiguration |  | ||||||
|               - resources |  | ||||||
|           required: true |           required: true | ||||||
|  |  | ||||||
|       responses: |       responses: | ||||||
|         200: |         200: | ||||||
|           $ref: '#/components/schemas/SystemCommandResults' |           description: Successful command execution | ||||||
|  |           content: | ||||||
|  |             application/json: | ||||||
|  |               schema: | ||||||
|  |                 oneOf: | ||||||
|  |                   - $ref: '#/components/schemas/SystemInfoResults' | ||||||
|         403: |         403: | ||||||
|           $ref: '#/components/responses/Unauthorized' |           $ref: '#/components/responses/Unauthorized' | ||||||
|         404: |         404: | ||||||
|   | |||||||
| @@ -28,13 +28,10 @@ namespace OpenWifi { | |||||||
| 		poco_information(Logger(), "Stopped..."); | 		poco_information(Logger(), "Stopped..."); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
| 	void ActionLinkManager::run() { | 	void ActionLinkManager::run() { | ||||||
| 		Running_ = true; | 		Running_ = true; | ||||||
| 		Utils::SetThreadName("action-mgr"); | 		Utils::SetThreadName("action-mgr"); | ||||||
|  |  | ||||||
|         Poco::Thread::trySleep(10000); |  | ||||||
|  |  | ||||||
| 		while (Running_) { | 		while (Running_) { | ||||||
| 			Poco::Thread::trySleep(2000); | 			Poco::Thread::trySleep(2000); | ||||||
| 			if (!Running_) | 			if (!Running_) | ||||||
| @@ -101,8 +98,10 @@ namespace OpenWifi { | |||||||
| 				} break; | 				} break; | ||||||
|  |  | ||||||
| 				case OpenWifi::SecurityObjects::LinkActions::SUB_FORGOT_PASSWORD: { | 				case OpenWifi::SecurityObjects::LinkActions::SUB_FORGOT_PASSWORD: { | ||||||
|  | 					auto Signup = Poco::StringTokenizer(UInfo.signingUp, ":"); | ||||||
| 					if (AuthService()->SendEmailToSubUser(i.id, UInfo.email, | 					if (AuthService()->SendEmailToSubUser(i.id, UInfo.email, | ||||||
| 														  MessagingTemplates::SUB_FORGOT_PASSWORD,"")) { | 														  MessagingTemplates::SUB_FORGOT_PASSWORD, | ||||||
|  | 														  Signup.count() == 1 ? "" : Signup[0])) { | ||||||
| 						poco_information( | 						poco_information( | ||||||
| 							Logger(), | 							Logger(), | ||||||
| 							fmt::format("Send subscriber password reset link to {}", UInfo.email)); | 							fmt::format("Send subscriber password reset link to {}", UInfo.email)); | ||||||
| @@ -111,8 +110,10 @@ namespace OpenWifi { | |||||||
| 				} break; | 				} break; | ||||||
|  |  | ||||||
| 				case OpenWifi::SecurityObjects::LinkActions::SUB_VERIFY_EMAIL: { | 				case OpenWifi::SecurityObjects::LinkActions::SUB_VERIFY_EMAIL: { | ||||||
|  | 					auto Signup = Poco::StringTokenizer(UInfo.signingUp, ":"); | ||||||
| 					if (AuthService()->SendEmailToSubUser( | 					if (AuthService()->SendEmailToSubUser( | ||||||
| 							i.id, UInfo.email, MessagingTemplates::SUB_EMAIL_VERIFICATION,"")) { | 							i.id, UInfo.email, MessagingTemplates::SUB_EMAIL_VERIFICATION, | ||||||
|  | 							Signup.count() == 1 ? "" : Signup[0])) { | ||||||
| 						poco_information( | 						poco_information( | ||||||
| 							Logger(), fmt::format("Send subscriber email verification link to {}", | 							Logger(), fmt::format("Send subscriber email verification link to {}", | ||||||
| 												  UInfo.email)); | 												  UInfo.email)); | ||||||
|   | |||||||
| @@ -218,7 +218,7 @@ namespace OpenWifi { | |||||||
| 				Expired = (WT.created_ + WT.expires_in_) < now; | 				Expired = (WT.created_ + WT.expires_in_) < now; | ||||||
| 				if (StorageService()->UserDB().GetUserById(UserId, UInfo.userinfo)) { | 				if (StorageService()->UserDB().GetUserById(UserId, UInfo.userinfo)) { | ||||||
| 					UInfo.webtoken = WT; | 					UInfo.webtoken = WT; | ||||||
| 					poco_trace(Logger(), fmt::format("TokenValidation success for TID={} Token={}", | 					poco_debug(Logger(), fmt::format("TokenValidation success for TID={} Token={}", | ||||||
| 													 TID, Utils::SanitizeToken(CallToken))); | 													 TID, Utils::SanitizeToken(CallToken))); | ||||||
| 					return true; | 					return true; | ||||||
| 				} | 				} | ||||||
| @@ -342,8 +342,10 @@ namespace OpenWifi { | |||||||
| 				Obj.set("event", "remove-token"); | 				Obj.set("event", "remove-token"); | ||||||
| 				Obj.set("id", MicroServiceID()); | 				Obj.set("id", MicroServiceID()); | ||||||
| 				Obj.set("token", token); | 				Obj.set("token", token); | ||||||
|  | 				std::stringstream ResultText; | ||||||
|  | 				Poco::JSON::Stringifier::stringify(Obj, ResultText); | ||||||
| 				KafkaManager()->PostMessage(KafkaTopics::SERVICE_EVENTS, | 				KafkaManager()->PostMessage(KafkaTopics::SERVICE_EVENTS, | ||||||
| 											MicroServicePrivateEndPoint(), Obj, false); | 											MicroServicePrivateEndPoint(), std::make_shared<std::string>(ResultText.str()), false); | ||||||
| 			} | 			} | ||||||
| 		} catch (const Poco::Exception &E) { | 		} catch (const Poco::Exception &E) { | ||||||
| 			Logger().log(E); | 			Logger().log(E); | ||||||
| @@ -798,6 +800,7 @@ namespace OpenWifi { | |||||||
|  |  | ||||||
| 		if (StorageService()->SubDB().GetUserByEmail(Email, UInfo)) { | 		if (StorageService()->SubDB().GetUserByEmail(Email, UInfo)) { | ||||||
| 			switch (Reason) { | 			switch (Reason) { | ||||||
|  |  | ||||||
| 			case MessagingTemplates::SUB_FORGOT_PASSWORD: { | 			case MessagingTemplates::SUB_FORGOT_PASSWORD: { | ||||||
| 				MessageAttributes Attrs; | 				MessageAttributes Attrs; | ||||||
| 				Attrs[RECIPIENT_EMAIL] = UInfo.email; | 				Attrs[RECIPIENT_EMAIL] = UInfo.email; | ||||||
|   | |||||||
| @@ -37,9 +37,9 @@ namespace OpenWifi { | |||||||
| 			instance_ = | 			instance_ = | ||||||
| 				new Daemon(vDAEMON_PROPERTIES_FILENAME, vDAEMON_ROOT_ENV_VAR, | 				new Daemon(vDAEMON_PROPERTIES_FILENAME, vDAEMON_ROOT_ENV_VAR, | ||||||
| 						   vDAEMON_CONFIG_ENV_VAR, vDAEMON_APP_NAME, vDAEMON_BUS_TIMER, | 						   vDAEMON_CONFIG_ENV_VAR, vDAEMON_APP_NAME, vDAEMON_BUS_TIMER, | ||||||
| 						   SubSystemVec{StorageService(), SMSSender(), AuthService(), ActionLinkManager(), | 						   SubSystemVec{StorageService(), SMSSender(), ActionLinkManager(), | ||||||
| 										SMTPMailerService(), RESTAPI_RateLimiter(), TotpCache(), | 										SMTPMailerService(), RESTAPI_RateLimiter(), TotpCache(), | ||||||
| 										UI_WebSocketClientServer(), SecretStore()}); | 										AuthService(), UI_WebSocketClientServer(), SecretStore()}); | ||||||
| 		} | 		} | ||||||
| 		return instance_; | 		return instance_; | ||||||
| 	} | 	} | ||||||
|   | |||||||
| @@ -37,11 +37,11 @@ namespace OpenWifi { | |||||||
| 		if (Action == "password_reset") | 		if (Action == "password_reset") | ||||||
| 			return RequestResetPassword(Link); | 			return RequestResetPassword(Link); | ||||||
| 		else if (Action == "sub_password_reset") | 		else if (Action == "sub_password_reset") | ||||||
| 			return RequestResetPassword(Link); | 			return RequestSubResetPassword(Link); | ||||||
| 		else if (Action == "email_verification") | 		else if (Action == "email_verification") | ||||||
| 			return DoEmailVerification(Link); | 			return DoEmailVerification(Link); | ||||||
| 		else if (Action == "sub_email_verification") | 		else if (Action == "sub_email_verification") | ||||||
| 			return DoEmailVerification(Link); | 			return DoSubEmailVerification(Link); | ||||||
| 		else if (Action == "signup_verification") | 		else if (Action == "signup_verification") | ||||||
| 			return DoNewSubVerification(Link); | 			return DoNewSubVerification(Link); | ||||||
| 		else | 		else | ||||||
| @@ -101,6 +101,7 @@ namespace OpenWifi { | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	void RESTAPI_action_links::CompleteResetPassword() { | 	void RESTAPI_action_links::CompleteResetPassword() { | ||||||
|  | 		//  form has been posted... | ||||||
| 		RESTAPI_PartHandler PartHandler; | 		RESTAPI_PartHandler PartHandler; | ||||||
| 		Poco::Net::HTMLForm Form(*Request, Request->stream(), PartHandler); | 		Poco::Net::HTMLForm Form(*Request, Request->stream(), PartHandler); | ||||||
| 		if (!Form.empty()) { | 		if (!Form.empty()) { | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
|  // | // | ||||||
| // Created by stephane bourque on 2021-10-23. | // Created by stephane bourque on 2021-10-23. | ||||||
| // | // | ||||||
|  |  | ||||||
|   | |||||||
| @@ -34,9 +34,7 @@ namespace OpenWifi { | |||||||
| 			return BadRequest(RESTAPI::Errors::SMSCouldNotValidate); | 			return BadRequest(RESTAPI::Errors::SMSCouldNotValidate); | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
|         if(Internal_) { | 		if (UserInfo_.userinfo.userRole != SecurityObjects::ROOT && | ||||||
|             poco_information(Logger(),fmt::format("Internal SMS request: TID={}", TransactionId_)); |  | ||||||
|         } else if (UserInfo_.userinfo.userRole != SecurityObjects::ROOT && |  | ||||||
| 			UserInfo_.userinfo.userRole != SecurityObjects::PARTNER && | 			UserInfo_.userinfo.userRole != SecurityObjects::PARTNER && | ||||||
| 			UserInfo_.userinfo.userRole != SecurityObjects::ADMIN) { | 			UserInfo_.userinfo.userRole != SecurityObjects::ADMIN) { | ||||||
| 			return UnAuthorized(RESTAPI::Errors::ACCESS_DENIED); | 			return UnAuthorized(RESTAPI::Errors::ACCESS_DENIED); | ||||||
|   | |||||||
| @@ -185,7 +185,7 @@ namespace OpenWifi { | |||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		if (GetBoolParameter("forgotPassword") || GetBoolParameter("resetPassword")) { | 		if (GetBoolParameter("forgotPassword")) { | ||||||
| 			Existing.changePassword = true; | 			Existing.changePassword = true; | ||||||
| 			Logger_.information(fmt::format("FORGOTTEN-PASSWORD({}): Request for {}", | 			Logger_.information(fmt::format("FORGOTTEN-PASSWORD({}): Request for {}", | ||||||
| 											Request->clientAddress().toString(), Existing.email)); | 											Request->clientAddress().toString(), Existing.email)); | ||||||
|   | |||||||
| @@ -33,7 +33,7 @@ namespace OpenWifi { | |||||||
| 			return NotFound(); | 			return NotFound(); | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		if (!Internal_ && !ACLProcessor::Can(UserInfo_.userinfo, UInfo, ACLProcessor::READ)) { | 		if (!ACLProcessor::Can(UserInfo_.userinfo, UInfo, ACLProcessor::READ)) { | ||||||
| 			return UnAuthorized(RESTAPI::Errors::ACCESS_DENIED); | 			return UnAuthorized(RESTAPI::Errors::ACCESS_DENIED); | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
|   | |||||||
| @@ -171,31 +171,6 @@ namespace OpenWifi::GWObjects { | |||||||
| 		field_to_json(Obj, "lastModified", LastModified); | 		field_to_json(Obj, "lastModified", LastModified); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	void DefaultFirmware::to_json(Poco::JSON::Object &Obj) const { |  | ||||||
| 		field_to_json(Obj, "deviceType", deviceType); |  | ||||||
| 		field_to_json(Obj, "description", Description); |  | ||||||
| 		field_to_json(Obj, "uri", uri); |  | ||||||
| 		field_to_json(Obj, "revision", revision); |  | ||||||
| 		field_to_json(Obj, "imageCreationDate", imageCreationDate); |  | ||||||
| 		field_to_json(Obj, "created", Created); |  | ||||||
| 		field_to_json(Obj, "lastModified", LastModified); |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	bool DefaultFirmware::from_json(const Poco::JSON::Object::Ptr &Obj) { |  | ||||||
| 		try { |  | ||||||
| 			field_from_json(Obj, "deviceType", deviceType); |  | ||||||
| 			field_from_json(Obj, "description", Description); |  | ||||||
| 			field_from_json(Obj, "uri", uri); |  | ||||||
| 			field_from_json(Obj, "revision", revision); |  | ||||||
| 			field_from_json(Obj, "imageCreationDate", imageCreationDate); |  | ||||||
| 			field_from_json(Obj, "created", Created); |  | ||||||
| 			field_from_json(Obj, "lastModified", LastModified); |  | ||||||
| 			return true; |  | ||||||
| 		} catch (const Poco::Exception &E) { |  | ||||||
| 		} |  | ||||||
| 		return false; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	void CommandDetails::to_json(Poco::JSON::Object &Obj) const { | 	void CommandDetails::to_json(Poco::JSON::Object &Obj) const { | ||||||
| 		EmbedDocument("details", Obj, Details); | 		EmbedDocument("details", Obj, Details); | ||||||
| 		EmbedDocument("results", Obj, Results); | 		EmbedDocument("results", Obj, Results); | ||||||
| @@ -271,8 +246,6 @@ namespace OpenWifi::GWObjects { | |||||||
| 		field_to_json(Obj, "connectionCompletionTime", connectionCompletionTime); | 		field_to_json(Obj, "connectionCompletionTime", connectionCompletionTime); | ||||||
| 		field_to_json(Obj, "totalConnectionTime", Utils::Now() - started); | 		field_to_json(Obj, "totalConnectionTime", Utils::Now() - started); | ||||||
| 		field_to_json(Obj, "certificateExpiryDate", certificateExpiryDate); | 		field_to_json(Obj, "certificateExpiryDate", certificateExpiryDate); | ||||||
| 		field_to_json(Obj, "connectReason", connectReason); |  | ||||||
|  |  | ||||||
| #ifdef TIP_GATEWAY_SERVICE | #ifdef TIP_GATEWAY_SERVICE | ||||||
| 		hasRADIUSSessions = RADIUSSessionTracker()->HasSessions(SerialNumber); | 		hasRADIUSSessions = RADIUSSessionTracker()->HasSessions(SerialNumber); | ||||||
| 		AP_WS_Server()->ExtendedAttributes(SerialNumber, hasGPS, sanity, | 		AP_WS_Server()->ExtendedAttributes(SerialNumber, hasGPS, sanity, | ||||||
| @@ -430,10 +403,6 @@ namespace OpenWifi::GWObjects { | |||||||
| 		field_to_json(Obj, "acctConfig", acctConfig); | 		field_to_json(Obj, "acctConfig", acctConfig); | ||||||
| 		field_to_json(Obj, "coaConfig", coaConfig); | 		field_to_json(Obj, "coaConfig", coaConfig); | ||||||
| 		field_to_json(Obj, "useByDefault", useByDefault); | 		field_to_json(Obj, "useByDefault", useByDefault); | ||||||
| 		field_to_json(Obj, "radsecKeepAlive", radsecKeepAlive); |  | ||||||
| 		field_to_json(Obj, "poolProxyIp", poolProxyIp); |  | ||||||
| 		field_to_json(Obj, "radsecPoolType", radsecPoolType); |  | ||||||
| 		field_to_json(Obj, "enabled", enabled); |  | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	bool RadiusProxyPool::from_json(const Poco::JSON::Object::Ptr &Obj) { | 	bool RadiusProxyPool::from_json(const Poco::JSON::Object::Ptr &Obj) { | ||||||
| @@ -444,10 +413,6 @@ namespace OpenWifi::GWObjects { | |||||||
| 			field_from_json(Obj, "acctConfig", acctConfig); | 			field_from_json(Obj, "acctConfig", acctConfig); | ||||||
| 			field_from_json(Obj, "coaConfig", coaConfig); | 			field_from_json(Obj, "coaConfig", coaConfig); | ||||||
| 			field_from_json(Obj, "useByDefault", useByDefault); | 			field_from_json(Obj, "useByDefault", useByDefault); | ||||||
| 			field_from_json(Obj, "radsecKeepAlive", radsecKeepAlive); |  | ||||||
| 			field_from_json(Obj, "poolProxyIp", poolProxyIp); |  | ||||||
| 			field_from_json(Obj, "radsecPoolType", radsecPoolType); |  | ||||||
| 			field_from_json(Obj, "enabled", enabled); |  | ||||||
| 			return true; | 			return true; | ||||||
| 		} catch (const Poco::Exception &E) { | 		} catch (const Poco::Exception &E) { | ||||||
| 		} | 		} | ||||||
| @@ -665,50 +630,18 @@ namespace OpenWifi::GWObjects { | |||||||
| 		field_to_json(Obj, "chargeableUserIdentity", chargeableUserIdentity); | 		field_to_json(Obj, "chargeableUserIdentity", chargeableUserIdentity); | ||||||
| 		field_to_json(Obj, "interface", interface); | 		field_to_json(Obj, "interface", interface); | ||||||
| 		field_to_json(Obj, "secret", secret); | 		field_to_json(Obj, "secret", secret); | ||||||
| 		field_to_json(Obj, "nasId", nasId); |  | ||||||
| 		field_to_json(Obj, "calledStationId", calledStationId); |  | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	void RADIUSSessionList::to_json(Poco::JSON::Object &Obj) const { | 	void RADIUSSessionList::to_json(Poco::JSON::Object &Obj) const { | ||||||
| 		field_to_json(Obj, "sessions", sessions); | 		field_to_json(Obj, "sessions", sessions); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	void RadiusCoADMParameters::to_json(Poco::JSON::Object &Obj) const { |  | ||||||
| 		field_to_json(Obj, "accountingSessionId", accountingSessionId); |  | ||||||
| 		field_to_json(Obj, "accountingMultiSessionId", accountingMultiSessionId); |  | ||||||
| 		field_to_json(Obj, "callingStationId", callingStationId); |  | ||||||
| 		field_to_json(Obj, "chargeableUserIdentity", chargeableUserIdentity); |  | ||||||
| 		field_to_json(Obj, "userName", userName); |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	bool RadiusCoADMParameters::from_json(const Poco::JSON::Object::Ptr &Obj) { | 	bool RadiusCoADMParameters::from_json(const Poco::JSON::Object::Ptr &Obj) { | ||||||
| 		try { | 		try { | ||||||
| 			field_from_json(Obj, "accountingSessionId", accountingSessionId); | 			field_from_json(Obj, "accountingSessionId", accountingSessionId); | ||||||
| 			field_from_json(Obj, "accountingMultiSessionId", accountingMultiSessionId); | 			field_from_json(Obj, "accountingMultiSessionId", accountingMultiSessionId); | ||||||
| 			field_from_json(Obj, "callingStationId", callingStationId); | 			field_from_json(Obj, "callingStationId", callingStationId); | ||||||
| 			field_from_json(Obj, "chargeableUserIdentity", chargeableUserIdentity); | 			field_from_json(Obj, "chargeableUserIdentity", chargeableUserIdentity); | ||||||
| 			field_from_json(Obj, "userName", userName); |  | ||||||
| 			return true; |  | ||||||
| 		} catch (const Poco::Exception &E) { |  | ||||||
| 		} |  | ||||||
| 		return false; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	bool DeviceTransferRequest::from_json(const Poco::JSON::Object::Ptr &Obj) { |  | ||||||
| 		try { |  | ||||||
| 			field_from_json(Obj, "serialNumber", serialNumber); |  | ||||||
| 			field_from_json(Obj, "server", server); |  | ||||||
| 			field_from_json(Obj, "port", port); |  | ||||||
| 			return true; |  | ||||||
| 		} catch (const Poco::Exception &E) { |  | ||||||
| 		} |  | ||||||
| 		return false; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	bool DeviceCertificateUpdateRequest::from_json(const Poco::JSON::Object::Ptr &Obj) { |  | ||||||
| 		try { |  | ||||||
| 			field_from_json(Obj, "serialNumber", serialNumber); |  | ||||||
| 			field_from_json(Obj, "encodedCertificate", encodedCertificate); |  | ||||||
| 			return true; | 			return true; | ||||||
| 		} catch (const Poco::Exception &E) { | 		} catch (const Poco::Exception &E) { | ||||||
| 		} | 		} | ||||||
|   | |||||||
| @@ -42,13 +42,12 @@ namespace OpenWifi::GWObjects { | |||||||
| 		uint64_t sessionId = 0; | 		uint64_t sessionId = 0; | ||||||
| 		double connectionCompletionTime = 0.0; | 		double connectionCompletionTime = 0.0; | ||||||
| 		std::uint64_t certificateExpiryDate = 0; | 		std::uint64_t certificateExpiryDate = 0; | ||||||
| 		std::uint64_t hasRADIUSSessions = 0; | 		bool hasRADIUSSessions = false; | ||||||
| 		bool hasGPS = false; | 		bool hasGPS = false; | ||||||
| 		std::uint64_t sanity=0; | 		std::uint64_t sanity=0; | ||||||
| 		std::double_t memoryUsed=0.0; | 		std::double_t memoryUsed=0.0; | ||||||
| 		std::double_t load=0.0; | 		std::double_t load=0.0; | ||||||
| 		std::double_t temperature=0.0; | 		std::double_t temperature=0.0; | ||||||
| 		std::string 	connectReason; |  | ||||||
|  |  | ||||||
| 		void to_json(const std::string &SerialNumber, Poco::JSON::Object &Obj) ; | 		void to_json(const std::string &SerialNumber, Poco::JSON::Object &Obj) ; | ||||||
| 	}; | 	}; | ||||||
| @@ -182,26 +181,6 @@ namespace OpenWifi::GWObjects { | |||||||
| 		bool from_json(const Poco::JSON::Object::Ptr &Obj); | 		bool from_json(const Poco::JSON::Object::Ptr &Obj); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| 	struct DefaultFirmware { |  | ||||||
| 		std::string deviceType; |  | ||||||
| 		std::string Description; |  | ||||||
| 		std::string uri; |  | ||||||
| 		std::string revision; |  | ||||||
| 		uint64_t imageCreationDate; |  | ||||||
| 		uint64_t Created; |  | ||||||
| 		uint64_t LastModified; |  | ||||||
|  |  | ||||||
| 		void to_json(Poco::JSON::Object &Obj) const; |  | ||||||
| 		bool from_json(const Poco::JSON::Object::Ptr &Obj); |  | ||||||
| 	}; |  | ||||||
|  |  | ||||||
| 	struct DefaultFirmwareList { |  | ||||||
| 		std::vector<DefaultFirmware>	firmwares; |  | ||||||
|  |  | ||||||
| 		void to_json(Poco::JSON::Object &Obj) const; |  | ||||||
| 		bool from_json(const Poco::JSON::Object::Ptr &Obj); |  | ||||||
| 	}; |  | ||||||
|  |  | ||||||
| 	struct CommandDetails { | 	struct CommandDetails { | ||||||
| 		std::string UUID; | 		std::string UUID; | ||||||
| 		std::string SerialNumber; | 		std::string SerialNumber; | ||||||
| @@ -360,10 +339,6 @@ namespace OpenWifi::GWObjects { | |||||||
| 		RadiusProxyServerConfig acctConfig; | 		RadiusProxyServerConfig acctConfig; | ||||||
| 		RadiusProxyServerConfig coaConfig; | 		RadiusProxyServerConfig coaConfig; | ||||||
| 		bool useByDefault = false; | 		bool useByDefault = false; | ||||||
| 		std::string 	radsecPoolType; |  | ||||||
| 		std::string 	poolProxyIp; |  | ||||||
| 		std::uint64_t 	radsecKeepAlive=25; |  | ||||||
| 		bool			enabled=true; |  | ||||||
|  |  | ||||||
| 		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); | ||||||
| @@ -418,8 +393,7 @@ namespace OpenWifi::GWObjects { | |||||||
| 					 			callingStationId, | 					 			callingStationId, | ||||||
| 								chargeableUserIdentity, | 								chargeableUserIdentity, | ||||||
| 								secret, | 								secret, | ||||||
| 								interface, | 								interface; | ||||||
| 								nasId; |  | ||||||
| 		std::uint64_t 			inputPackets = 0, | 		std::uint64_t 			inputPackets = 0, | ||||||
| 								outputPackets = 0, | 								outputPackets = 0, | ||||||
| 								inputOctets = 0, | 								inputOctets = 0, | ||||||
| @@ -427,7 +401,6 @@ namespace OpenWifi::GWObjects { | |||||||
| 								inputGigaWords = 0, | 								inputGigaWords = 0, | ||||||
| 								outputGigaWords = 0; | 								outputGigaWords = 0; | ||||||
| 		std::uint32_t 			sessionTime = 0; | 		std::uint32_t 			sessionTime = 0; | ||||||
| 		std::string 			calledStationId; |  | ||||||
|  |  | ||||||
| #ifdef TIP_GATEWAY_SERVICE | #ifdef TIP_GATEWAY_SERVICE | ||||||
| 		RADIUS::RadiusPacket	accountingPacket; | 		RADIUS::RadiusPacket	accountingPacket; | ||||||
| @@ -445,68 +418,7 @@ namespace OpenWifi::GWObjects { | |||||||
| 		std::string 			accountingSessionId, | 		std::string 			accountingSessionId, | ||||||
| 								accountingMultiSessionId, | 								accountingMultiSessionId, | ||||||
| 								callingStationId, | 								callingStationId, | ||||||
| 								chargeableUserIdentity, | 								chargeableUserIdentity; | ||||||
| 								userName; |  | ||||||
|  |  | ||||||
| 		bool from_json(const Poco::JSON::Object::Ptr &Obj); |  | ||||||
| 		void to_json(Poco::JSON::Object &Obj) const; |  | ||||||
| 	}; |  | ||||||
|  |  | ||||||
| 	enum class RadiusPoolStrategy { |  | ||||||
| 		round_robin, random, weighted, unknown |  | ||||||
| 	}; |  | ||||||
|  |  | ||||||
| 	enum class RadiusEndpointType { |  | ||||||
| 		generic, radsec, globalreach, orion, unknown |  | ||||||
| 	}; |  | ||||||
|  |  | ||||||
| 	static inline RadiusEndpointType RadiusEndpointType(const std::string &T) { |  | ||||||
| 		if(T=="generic") return RadiusEndpointType::generic; |  | ||||||
| 		if(T=="radsec") return RadiusEndpointType::radsec; |  | ||||||
| 		if(T=="globalreach") return RadiusEndpointType::globalreach; |  | ||||||
| 		if(T=="orion") return RadiusEndpointType::orion; |  | ||||||
| 		return RadiusEndpointType::unknown; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	static inline RadiusPoolStrategy RadiusPoolStrategy(const std::string &T) { |  | ||||||
| 		if(T=="round_robin") return RadiusPoolStrategy::round_robin; |  | ||||||
| 		if(T=="random") return RadiusPoolStrategy::random; |  | ||||||
| 		if(T=="weighted") return RadiusPoolStrategy::weighted; |  | ||||||
| 		return RadiusPoolStrategy::unknown; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	static inline std::string to_string(enum RadiusEndpointType T) { |  | ||||||
| 		switch(T) { |  | ||||||
| 		case RadiusEndpointType::generic: return "generic"; |  | ||||||
| 		case RadiusEndpointType::radsec: return "radsec"; |  | ||||||
| 		case RadiusEndpointType::globalreach: return "globalreach"; |  | ||||||
| 		case RadiusEndpointType::orion: return "orion"; |  | ||||||
| 		default: |  | ||||||
| 			return "unknown"; |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	static inline std::string to_string(enum RadiusPoolStrategy T) { |  | ||||||
| 		switch(T) { |  | ||||||
| 		case RadiusPoolStrategy::round_robin: return "round_robin"; |  | ||||||
| 		case RadiusPoolStrategy::random: return "random"; |  | ||||||
| 		case RadiusPoolStrategy::weighted: return "weighted"; |  | ||||||
| 		default: |  | ||||||
| 			return "unknown"; |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	struct DeviceTransferRequest { |  | ||||||
| 		std::string 	serialNumber; |  | ||||||
| 		std::string 	server; |  | ||||||
| 		std::uint64_t 	port; |  | ||||||
|  |  | ||||||
| 		bool from_json(const Poco::JSON::Object::Ptr &Obj); |  | ||||||
| 	}; |  | ||||||
|  |  | ||||||
| 	struct DeviceCertificateUpdateRequest { |  | ||||||
| 		std::string 	serialNumber; |  | ||||||
| 		std::string 	encodedCertificate; |  | ||||||
|  |  | ||||||
| 		bool from_json(const Poco::JSON::Object::Ptr &Obj); | 		bool from_json(const Poco::JSON::Object::Ptr &Obj); | ||||||
| 	}; | 	}; | ||||||
|   | |||||||
| @@ -92,7 +92,6 @@ namespace OpenWifi::OWLSObjects { | |||||||
| 		field_to_json(Obj, "endTime", endTime); | 		field_to_json(Obj, "endTime", endTime); | ||||||
| 		field_to_json(Obj, "errorDevices", errorDevices); | 		field_to_json(Obj, "errorDevices", errorDevices); | ||||||
| 		field_to_json(Obj, "owner", owner); | 		field_to_json(Obj, "owner", owner); | ||||||
|         field_to_json(Obj, "expectedDevices", expectedDevices); |  | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	void Dashboard::to_json([[maybe_unused]] Poco::JSON::Object &Obj) const {} | 	void Dashboard::to_json([[maybe_unused]] Poco::JSON::Object &Obj) const {} | ||||||
|   | |||||||
| @@ -57,7 +57,6 @@ namespace OpenWifi::OWLSObjects { | |||||||
| 		uint64_t endTime; | 		uint64_t endTime; | ||||||
| 		uint64_t errorDevices; | 		uint64_t errorDevices; | ||||||
| 		std::string owner; | 		std::string owner; | ||||||
|         uint64_t expectedDevices; |  | ||||||
|  |  | ||||||
| 		void to_json(Poco::JSON::Object &Obj) const; | 		void to_json(Poco::JSON::Object &Obj) const; | ||||||
| 	}; | 	}; | ||||||
|   | |||||||
| @@ -587,9 +587,6 @@ namespace OpenWifi::ProvObjects { | |||||||
| 		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); | 		field_to_json(Obj, "doNotAllowOverrides", doNotAllowOverrides); | ||||||
|         field_to_json(Obj, "imported", imported); |  | ||||||
|         field_to_json(Obj, "connected", connected); |  | ||||||
|         field_to_json(Obj, "platform", platform); |  | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	bool InventoryTag::from_json(const Poco::JSON::Object::Ptr &Obj) { | 	bool InventoryTag::from_json(const Poco::JSON::Object::Ptr &Obj) { | ||||||
| @@ -612,9 +609,6 @@ namespace OpenWifi::ProvObjects { | |||||||
| 			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); | 			field_from_json(Obj, "doNotAllowOverrides", doNotAllowOverrides); | ||||||
|             field_from_json(Obj, "imported", imported); |  | ||||||
|             field_from_json(Obj, "connected", connected); |  | ||||||
|             field_from_json(Obj, "platform", platform); |  | ||||||
| 			return true; | 			return true; | ||||||
| 		} catch (...) { | 		} catch (...) { | ||||||
| 		} | 		} | ||||||
| @@ -1200,243 +1194,4 @@ namespace OpenWifi::ProvObjects { | |||||||
| 		return false; | 		return false; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|     void GLBLRAccountInfo::to_json(Poco::JSON::Object &Obj) const { |  | ||||||
|         info.to_json(Obj); |  | ||||||
|         field_to_json(Obj, "privateKey", privateKey); |  | ||||||
|         field_to_json(Obj, "country", country); |  | ||||||
|         field_to_json(Obj, "province", province); |  | ||||||
|         field_to_json(Obj, "city", city); |  | ||||||
|         field_to_json(Obj, "organization", organization); |  | ||||||
|         field_to_json(Obj, "commonName", commonName); |  | ||||||
|         field_to_json(Obj, "CSR", CSR); |  | ||||||
|         field_to_json(Obj, "CSRPrivateKey", CSRPrivateKey); |  | ||||||
|         field_to_json(Obj, "CSRPublicKey", CSRPublicKey); |  | ||||||
|         field_to_json(Obj, "GlobalReachAcctId", GlobalReachAcctId); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     bool GLBLRAccountInfo::from_json(const Poco::JSON::Object::Ptr &Obj) { |  | ||||||
|         try { |  | ||||||
|             info.from_json(Obj); |  | ||||||
|             field_from_json(Obj, "privateKey", privateKey); |  | ||||||
|             field_from_json(Obj, "country", country); |  | ||||||
|             field_from_json(Obj, "province", province); |  | ||||||
|             field_from_json(Obj, "city", city); |  | ||||||
|             field_from_json(Obj, "organization", organization); |  | ||||||
|             field_from_json(Obj, "commonName", commonName); |  | ||||||
|             field_from_json(Obj, "CSR", CSR); |  | ||||||
|             field_from_json(Obj, "CSRPrivateKey", CSRPrivateKey); |  | ||||||
|             field_from_json(Obj, "CSRPublicKey", CSRPublicKey); |  | ||||||
|             field_from_json(Obj, "GlobalReachAcctId", GlobalReachAcctId); |  | ||||||
|             return true; |  | ||||||
|         } catch (const Poco::Exception &E) { |  | ||||||
|  |  | ||||||
|         } |  | ||||||
|         return false; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     void GLBLRCertificateInfo::to_json(Poco::JSON::Object &Obj) const { |  | ||||||
|         field_to_json(Obj, "id", id); |  | ||||||
|         field_to_json(Obj, "name", name); |  | ||||||
|         field_to_json(Obj, "accountId", accountId); |  | ||||||
|         field_to_json(Obj, "csr", csr); |  | ||||||
|         field_to_json(Obj, "certificate", certificate); |  | ||||||
|         field_to_json(Obj, "certificateChain", certificateChain); |  | ||||||
|         field_to_json(Obj, "certificateId", certificateId); |  | ||||||
|         field_to_json(Obj, "expiresAt", expiresAt); |  | ||||||
|         field_to_json(Obj, "created", created); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     bool GLBLRCertificateInfo::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, "accountId", accountId); |  | ||||||
|             field_from_json(Obj, "csr", csr); |  | ||||||
|             field_from_json(Obj, "certificate", certificate); |  | ||||||
|             field_from_json(Obj, "certificateChain", certificateChain); |  | ||||||
|             field_from_json(Obj, "certificateId", certificateId); |  | ||||||
|             field_from_json(Obj, "expiresAt", expiresAt); |  | ||||||
|             field_from_json(Obj, "created", created); |  | ||||||
|             return true; |  | ||||||
|         } catch (const Poco::Exception &E) { |  | ||||||
|  |  | ||||||
|         } |  | ||||||
|         return false; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     void GooglOrionAccountInfo::to_json(Poco::JSON::Object &Obj) const { |  | ||||||
|         info.to_json(Obj); |  | ||||||
|         field_to_json(Obj, "privateKey", privateKey); |  | ||||||
|         field_to_json(Obj, "certificate", certificate); |  | ||||||
|         field_to_json(Obj, "cacerts", cacerts); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     bool GooglOrionAccountInfo::from_json(const Poco::JSON::Object::Ptr &Obj) { |  | ||||||
|         try { |  | ||||||
|             info.from_json(Obj); |  | ||||||
|             field_from_json(Obj, "privateKey", privateKey); |  | ||||||
|             field_from_json(Obj, "certificate", certificate); |  | ||||||
|             field_from_json(Obj, "cacerts", cacerts); |  | ||||||
|             return true; |  | ||||||
|         } catch (const Poco::Exception &E) { |  | ||||||
|  |  | ||||||
|         } |  | ||||||
|         return false; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     void RADIUSServer::to_json(Poco::JSON::Object &Obj) const { |  | ||||||
|         field_to_json(Obj, "Hostname", Hostname); |  | ||||||
|         field_to_json(Obj, "IP", IP); |  | ||||||
|         field_to_json(Obj, "Port", Port); |  | ||||||
|         field_to_json(Obj, "Secret", Secret); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     bool RADIUSServer::from_json(const Poco::JSON::Object::Ptr &Obj) { |  | ||||||
|         try { |  | ||||||
|             field_from_json(Obj, "Hostname", Hostname); |  | ||||||
|             field_from_json(Obj, "IP", IP); |  | ||||||
|             field_from_json(Obj, "Port", Port); |  | ||||||
|             field_from_json(Obj, "Secret", Secret); |  | ||||||
|             return true; |  | ||||||
|         } catch (const Poco::Exception &E) { |  | ||||||
|  |  | ||||||
|         } |  | ||||||
|         return false; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     void RADIUSEndPointRadiusType::to_json(Poco::JSON::Object &Obj) const { |  | ||||||
|         field_to_json(Obj, "Authentication", Authentication); |  | ||||||
|         field_to_json(Obj, "Accounting", Accounting); |  | ||||||
|         field_to_json(Obj, "CoA", CoA); |  | ||||||
|         field_to_json(Obj, "AccountingInterval", AccountingInterval); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     bool RADIUSEndPointRadiusType::from_json(const Poco::JSON::Object::Ptr &Obj) { |  | ||||||
|         try { |  | ||||||
|             field_from_json(Obj, "Authentication", Authentication); |  | ||||||
|             field_from_json(Obj, "Accounting", Accounting); |  | ||||||
|             field_from_json(Obj, "CoA", CoA); |  | ||||||
|             field_from_json(Obj, "AccountingInterval", AccountingInterval); |  | ||||||
|             return true; |  | ||||||
|         } catch (const Poco::Exception &E) { |  | ||||||
|  |  | ||||||
|         } |  | ||||||
|         return false; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     void RADIUSEndPointRadsecType::to_json(Poco::JSON::Object &Obj) const { |  | ||||||
|         field_to_json(Obj, "Hostname", Hostname); |  | ||||||
|         field_to_json(Obj, "IP", IP); |  | ||||||
|         field_to_json(Obj, "Port", Port); |  | ||||||
|         field_to_json(Obj, "Secret", Secret); |  | ||||||
|         field_to_json(Obj, "OpenRoamingType", OpenRoamingType); |  | ||||||
|         field_to_json(Obj, "UseOpenRoamingAccount", UseOpenRoamingAccount); |  | ||||||
|         field_to_json(Obj, "Weight", Weight); |  | ||||||
|         field_to_json(Obj, "Certificate", Certificate); |  | ||||||
|         field_to_json(Obj, "PrivateKey", PrivateKey); |  | ||||||
|         field_to_json(Obj, "CaCerts", CaCerts); |  | ||||||
|         field_to_json(Obj, "AllowSelfSigned", AllowSelfSigned); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     bool RADIUSEndPointRadsecType::from_json(const Poco::JSON::Object::Ptr &Obj) { |  | ||||||
|         try { |  | ||||||
|             field_from_json(Obj, "Hostname", Hostname); |  | ||||||
|             field_from_json(Obj, "IP", IP); |  | ||||||
|             field_from_json(Obj, "Port", Port); |  | ||||||
|             field_from_json(Obj, "Secret", Secret); |  | ||||||
|             field_from_json(Obj, "OpenRoamingType", OpenRoamingType); |  | ||||||
|             field_from_json(Obj, "UseOpenRoamingAccount", UseOpenRoamingAccount); |  | ||||||
|             field_from_json(Obj, "Weight", Weight); |  | ||||||
|             field_from_json(Obj, "Certificate", Certificate); |  | ||||||
|             field_from_json(Obj, "PrivateKey", PrivateKey); |  | ||||||
|             field_from_json(Obj, "CaCerts", CaCerts); |  | ||||||
|             field_from_json(Obj, "AllowSelfSigned", AllowSelfSigned); |  | ||||||
|             return true; |  | ||||||
|         } catch (const Poco::Exception &E) { |  | ||||||
|  |  | ||||||
|         } |  | ||||||
|         return false; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     void RADIUSEndPoint::to_json(Poco::JSON::Object &Obj) const { |  | ||||||
|         info.to_json(Obj); |  | ||||||
|         field_to_json(Obj, "Type", Type); |  | ||||||
|         field_to_json(Obj, "RadsecServers", RadsecServers); |  | ||||||
|         field_to_json(Obj, "RadiusServers", RadiusServers); |  | ||||||
|         field_to_json(Obj, "PoolStrategy", PoolStrategy); |  | ||||||
|         field_to_json(Obj, "Index", Index); |  | ||||||
|         field_to_json(Obj, "UsedBy", UsedBy); |  | ||||||
|         field_to_json(Obj, "UseGWProxy", UseGWProxy); |  | ||||||
|         field_to_json(Obj, "NasIdentifier", NasIdentifier); |  | ||||||
|         field_to_json(Obj, "AccountingInterval", AccountingInterval); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     bool RADIUSEndPoint::from_json(const Poco::JSON::Object::Ptr &Obj) { |  | ||||||
|         try { |  | ||||||
|             info.from_json(Obj); |  | ||||||
|             field_from_json(Obj, "Type", Type); |  | ||||||
|             field_from_json(Obj, "RadsecServers", RadsecServers); |  | ||||||
|             field_from_json(Obj, "RadiusServers", RadiusServers); |  | ||||||
|             field_from_json(Obj, "PoolStrategy", PoolStrategy); |  | ||||||
|             field_from_json(Obj, "Index", Index); |  | ||||||
|             field_from_json(Obj, "UsedBy", UsedBy); |  | ||||||
|             field_from_json(Obj, "UseGWProxy", UseGWProxy); |  | ||||||
|             field_from_json(Obj, "NasIdentifier", NasIdentifier); |  | ||||||
|             field_from_json(Obj, "AccountingInterval", AccountingInterval); |  | ||||||
|             return true; |  | ||||||
|         } catch (const Poco::Exception &E) { |  | ||||||
|  |  | ||||||
|         } |  | ||||||
|         return false; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     void RADIUSEndpointUpdateStatus::to_json(Poco::JSON::Object &Obj) const { |  | ||||||
|         field_to_json(Obj, "lastUpdate", lastUpdate); |  | ||||||
|         field_to_json(Obj, "lastConfigurationChange", lastConfigurationChange); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     bool RADIUSEndpointUpdateStatus::from_json(const Poco::JSON::Object::Ptr &Obj) { |  | ||||||
|         try { |  | ||||||
|             field_from_json(Obj, "lastUpdate", lastUpdate); |  | ||||||
|             field_from_json(Obj, "lastConfigurationChange", lastConfigurationChange); |  | ||||||
|             return true; |  | ||||||
|         } catch (const Poco::Exception &E) { |  | ||||||
|  |  | ||||||
|         } |  | ||||||
|         return false; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     bool RADIUSEndpointUpdateStatus::Read() { |  | ||||||
|         Poco::File  F(OpenWifi::MicroServiceDataDirectory()+"/RADIUSEndpointUpdateStatus.json"); |  | ||||||
|         try { |  | ||||||
|             if (F.exists()) { |  | ||||||
|                 Poco::JSON::Parser P; |  | ||||||
|                 std::ifstream ifs(F.path(), std::ios_base::in | std::ios_base::binary); |  | ||||||
|                 auto Obj = P.parse(ifs); |  | ||||||
|                 return from_json(Obj.extract<Poco::JSON::Object::Ptr>()); |  | ||||||
|             } |  | ||||||
|         } catch (...) { |  | ||||||
|         } |  | ||||||
|         return false; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     bool RADIUSEndpointUpdateStatus::Save() { |  | ||||||
|         Poco::File  F(OpenWifi::MicroServiceDataDirectory()+"/RADIUSEndpointUpdateStatus.json"); |  | ||||||
|         try { |  | ||||||
|             Poco::JSON::Object Obj; |  | ||||||
|             to_json(Obj); |  | ||||||
|             std::ofstream O(F.path(), std::ios_base::out | std::ios_base::trunc | std::ios_base::binary); |  | ||||||
|             Poco::JSON::Stringifier::stringify(Obj, O); |  | ||||||
|             return true; |  | ||||||
|         } catch (...) { |  | ||||||
|         } |  | ||||||
|         return false; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     bool RADIUSEndpointUpdateStatus::ChangeConfiguration() { |  | ||||||
|         Read(); |  | ||||||
|         lastConfigurationChange = Utils::Now(); |  | ||||||
|         return Save(); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| } // namespace OpenWifi::ProvObjects | } // namespace OpenWifi::ProvObjects | ||||||
|   | |||||||
| @@ -29,7 +29,6 @@ namespace OpenWifi::ProvObjects { | |||||||
| 		Types::TagList tags; | 		Types::TagList tags; | ||||||
|  |  | ||||||
| 		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); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| @@ -37,7 +36,6 @@ namespace OpenWifi::ProvObjects { | |||||||
| 		Types::UUIDvec_t serialNumbers; | 		Types::UUIDvec_t serialNumbers; | ||||||
|  |  | ||||||
| 		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); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| @@ -48,7 +46,6 @@ namespace OpenWifi::ProvObjects { | |||||||
| 		std::string policy; | 		std::string policy; | ||||||
|  |  | ||||||
| 		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); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| @@ -60,18 +57,14 @@ namespace OpenWifi::ProvObjects { | |||||||
| 		Types::UUID_t venue; | 		Types::UUID_t venue; | ||||||
|  |  | ||||||
| 		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); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| 	typedef std::vector<ManagementPolicy> ManagementPolicyVec; | 	typedef std::vector<ManagementPolicy> ManagementPolicyVec; | ||||||
|  |  | ||||||
| 	struct RRMAlgorithmDetails { | 	struct RRMAlgorithmDetails { | ||||||
| 		std::string name; | 		std::string name; | ||||||
| 		std::string parameters; | 		std::string parameters; | ||||||
|  |  | ||||||
| 		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); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| @@ -79,9 +72,7 @@ namespace OpenWifi::ProvObjects { | |||||||
| 		std::string vendor; | 		std::string vendor; | ||||||
| 		std::string schedule; | 		std::string schedule; | ||||||
| 		std::vector<RRMAlgorithmDetails> algorithms; | 		std::vector<RRMAlgorithmDetails> algorithms; | ||||||
|  |  | ||||||
| 		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); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| @@ -91,7 +82,6 @@ namespace OpenWifi::ProvObjects { | |||||||
| 		std::string firmwareUpgrade{"inherit"}; | 		std::string firmwareUpgrade{"inherit"}; | ||||||
|  |  | ||||||
| 		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); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| @@ -114,10 +104,8 @@ namespace OpenWifi::ProvObjects { | |||||||
| 		Types::UUIDvec_t configurations; | 		Types::UUIDvec_t configurations; | ||||||
|  |  | ||||||
| 		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); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| 	typedef std::vector<Entity> EntityVec; | 	typedef std::vector<Entity> EntityVec; | ||||||
|  |  | ||||||
| 	struct DiGraphEntry { | 	struct DiGraphEntry { | ||||||
| @@ -125,7 +113,6 @@ namespace OpenWifi::ProvObjects { | |||||||
| 		Types::UUID_t child; | 		Types::UUID_t child; | ||||||
|  |  | ||||||
| 		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); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| @@ -153,10 +140,8 @@ namespace OpenWifi::ProvObjects { | |||||||
| 		Types::UUIDvec_t boards; | 		Types::UUIDvec_t boards; | ||||||
|  |  | ||||||
| 		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); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| 	typedef std::vector<Venue> VenueVec; | 	typedef std::vector<Venue> VenueVec; | ||||||
|  |  | ||||||
| 	struct UserInfoDigest { | 	struct UserInfoDigest { | ||||||
| @@ -165,7 +150,6 @@ namespace OpenWifi::ProvObjects { | |||||||
| 		std::string userType; | 		std::string userType; | ||||||
|  |  | ||||||
| 		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); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| @@ -178,10 +162,8 @@ namespace OpenWifi::ProvObjects { | |||||||
| 		Types::UUID_t venue; | 		Types::UUID_t venue; | ||||||
|  |  | ||||||
| 		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); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| 	typedef std::vector<ManagementRole> ManagementRoleVec; | 	typedef std::vector<ManagementRole> ManagementRoleVec; | ||||||
|  |  | ||||||
| 	enum LocationType { | 	enum LocationType { | ||||||
| @@ -250,10 +232,8 @@ namespace OpenWifi::ProvObjects { | |||||||
| 		Types::UUID_t managementPolicy; | 		Types::UUID_t managementPolicy; | ||||||
|  |  | ||||||
| 		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); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| 	typedef std::vector<Location> LocationVec; | 	typedef std::vector<Location> LocationVec; | ||||||
|  |  | ||||||
| 	struct OperatorLocation { | 	struct OperatorLocation { | ||||||
| @@ -273,10 +253,8 @@ namespace OpenWifi::ProvObjects { | |||||||
| 		Types::UUID_t managementPolicy; | 		Types::UUID_t managementPolicy; | ||||||
|  |  | ||||||
| 		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); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| 	typedef std::vector<Location> LocationVec; | 	typedef std::vector<Location> LocationVec; | ||||||
|  |  | ||||||
| 	struct SubLocation { | 	struct SubLocation { | ||||||
| @@ -292,7 +270,6 @@ namespace OpenWifi::ProvObjects { | |||||||
| 		std::string geoCode; | 		std::string geoCode; | ||||||
|  |  | ||||||
| 		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); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| @@ -300,7 +277,6 @@ namespace OpenWifi::ProvObjects { | |||||||
| 		std::vector<OperatorLocation> locations; | 		std::vector<OperatorLocation> locations; | ||||||
|  |  | ||||||
| 		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); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| @@ -380,10 +356,8 @@ namespace OpenWifi::ProvObjects { | |||||||
| 		Types::UUID_t managementPolicy; | 		Types::UUID_t managementPolicy; | ||||||
|  |  | ||||||
| 		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); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| 	typedef std::vector<Contact> ContactVec; | 	typedef std::vector<Contact> ContactVec; | ||||||
|  |  | ||||||
| 	struct OperatorContact { | 	struct OperatorContact { | ||||||
| @@ -405,7 +379,6 @@ namespace OpenWifi::ProvObjects { | |||||||
| 		Types::UUID_t managementPolicy; | 		Types::UUID_t managementPolicy; | ||||||
|  |  | ||||||
| 		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); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| @@ -424,7 +397,6 @@ namespace OpenWifi::ProvObjects { | |||||||
| 		std::string accessPIN; | 		std::string accessPIN; | ||||||
|  |  | ||||||
| 		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); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| @@ -432,7 +404,6 @@ namespace OpenWifi::ProvObjects { | |||||||
| 		std::vector<OperatorContact> contacts; | 		std::vector<OperatorContact> contacts; | ||||||
|  |  | ||||||
| 		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); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| @@ -445,10 +416,8 @@ namespace OpenWifi::ProvObjects { | |||||||
| 		std::string configuration; | 		std::string configuration; | ||||||
|  |  | ||||||
| 		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); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| 	typedef std::vector<DeviceConfigurationElement> DeviceConfigurationElementVec; | 	typedef std::vector<DeviceConfigurationElement> DeviceConfigurationElementVec; | ||||||
|  |  | ||||||
| 	struct DeviceConfiguration { | 	struct DeviceConfiguration { | ||||||
| @@ -465,10 +434,8 @@ namespace OpenWifi::ProvObjects { | |||||||
| 		std::string subscriber; | 		std::string subscriber; | ||||||
|  |  | ||||||
| 		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); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| 	typedef std::vector<DeviceConfiguration> DeviceConfigurationVec; | 	typedef std::vector<DeviceConfiguration> DeviceConfigurationVec; | ||||||
|  |  | ||||||
| 	struct InventoryTag { | 	struct InventoryTag { | ||||||
| @@ -490,9 +457,6 @@ namespace OpenWifi::ProvObjects { | |||||||
| 		std::string locale; | 		std::string locale; | ||||||
| 		std::string realMacAddress; | 		std::string realMacAddress; | ||||||
| 		bool doNotAllowOverrides = false; | 		bool doNotAllowOverrides = false; | ||||||
|         std::uint64_t imported=0; |  | ||||||
|         std::uint64_t connected=0; |  | ||||||
|         std::string platform{"AP"}; |  | ||||||
|  |  | ||||||
| 		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); | ||||||
| @@ -504,7 +468,6 @@ namespace OpenWifi::ProvObjects { | |||||||
| 		InventoryTagVec taglist; | 		InventoryTagVec taglist; | ||||||
|  |  | ||||||
| 		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); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| @@ -515,7 +478,6 @@ namespace OpenWifi::ProvObjects { | |||||||
| 		uint64_t errorCode; | 		uint64_t errorCode; | ||||||
|  |  | ||||||
| 		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); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| @@ -524,7 +486,6 @@ namespace OpenWifi::ProvObjects { | |||||||
| 		Types::CountedMap tenants; | 		Types::CountedMap tenants; | ||||||
|  |  | ||||||
| 		void reset(); | 		void reset(); | ||||||
|  |  | ||||||
| 		void to_json(Poco::JSON::Object &Obj) const; | 		void to_json(Poco::JSON::Object &Obj) const; | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| @@ -534,7 +495,6 @@ namespace OpenWifi::ProvObjects { | |||||||
| 		std::string description; | 		std::string description; | ||||||
|  |  | ||||||
| 		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); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| @@ -543,7 +503,6 @@ namespace OpenWifi::ProvObjects { | |||||||
| 		std::vector<ExpandedUseEntry> entries; | 		std::vector<ExpandedUseEntry> entries; | ||||||
|  |  | ||||||
| 		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); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| @@ -551,7 +510,6 @@ namespace OpenWifi::ProvObjects { | |||||||
| 		std::vector<ExpandedUseEntryList> entries; | 		std::vector<ExpandedUseEntryList> entries; | ||||||
|  |  | ||||||
| 		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); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| @@ -559,21 +517,17 @@ namespace OpenWifi::ProvObjects { | |||||||
| 		Types::UUIDvec_t list; | 		Types::UUIDvec_t list; | ||||||
|  |  | ||||||
| 		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); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
|     enum ACLACCESS { | 	enum ACLACCESS { NONE = 0, READ = 1, MODIFY = 2, CREATE = 3, DELETE = 4 }; | ||||||
|         NONE = 0, READ = 1, MODIFY = 2, CREATE = 3, DELETE = 4 |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
| 	struct ObjectACL { | 	struct ObjectACL { | ||||||
| 		UuidList users; | 		UuidList users; | ||||||
| 		UuidList roles; | 		UuidList roles; | ||||||
|         uint64_t access = (uint64_t) NONE; | 		uint64_t access = (uint64_t)NONE; | ||||||
|  |  | ||||||
| 		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); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| @@ -581,7 +535,6 @@ namespace OpenWifi::ProvObjects { | |||||||
| 		std::vector<ObjectACL> list; | 		std::vector<ObjectACL> list; | ||||||
|  |  | ||||||
| 		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); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| @@ -596,7 +549,6 @@ namespace OpenWifi::ProvObjects { | |||||||
| 		std::string venue; | 		std::string venue; | ||||||
|  |  | ||||||
| 		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); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| @@ -604,7 +556,6 @@ namespace OpenWifi::ProvObjects { | |||||||
| 		std::vector<Map> list; | 		std::vector<Map> list; | ||||||
|  |  | ||||||
| 		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); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| @@ -634,7 +585,6 @@ namespace OpenWifi::ProvObjects { | |||||||
| 		std::string operatorId; | 		std::string operatorId; | ||||||
|  |  | ||||||
| 		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); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| @@ -645,7 +595,6 @@ namespace OpenWifi::ProvObjects { | |||||||
| 		std::string value; | 		std::string value; | ||||||
|  |  | ||||||
| 		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); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| @@ -653,7 +602,6 @@ namespace OpenWifi::ProvObjects { | |||||||
| 		std::vector<Variable> variables; | 		std::vector<Variable> variables; | ||||||
|  |  | ||||||
| 		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); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| @@ -668,7 +616,6 @@ namespace OpenWifi::ProvObjects { | |||||||
| 		Types::UUID_t managementPolicy; | 		Types::UUID_t managementPolicy; | ||||||
|  |  | ||||||
| 		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); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| @@ -676,7 +623,6 @@ namespace OpenWifi::ProvObjects { | |||||||
| 		std::vector<VariableBlock> variableBlocks; | 		std::vector<VariableBlock> variableBlocks; | ||||||
|  |  | ||||||
| 		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); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| @@ -691,7 +637,6 @@ namespace OpenWifi::ProvObjects { | |||||||
| 		std::string registrationId; | 		std::string registrationId; | ||||||
|  |  | ||||||
| 		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); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| @@ -699,7 +644,6 @@ namespace OpenWifi::ProvObjects { | |||||||
| 		std::vector<Operator> operators; | 		std::vector<Operator> operators; | ||||||
|  |  | ||||||
| 		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); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| @@ -710,7 +654,6 @@ namespace OpenWifi::ProvObjects { | |||||||
| 		Types::UUIDvec_t devices; | 		Types::UUIDvec_t devices; | ||||||
|  |  | ||||||
| 		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); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| @@ -726,7 +669,6 @@ namespace OpenWifi::ProvObjects { | |||||||
| 		bool defaultService = false; | 		bool defaultService = 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); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| @@ -734,7 +676,6 @@ namespace OpenWifi::ProvObjects { | |||||||
| 		std::vector<ServiceClass> serviceClasses; | 		std::vector<ServiceClass> serviceClasses; | ||||||
|  |  | ||||||
| 		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); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| @@ -745,7 +686,6 @@ namespace OpenWifi::ProvObjects { | |||||||
| 		std::string firmwareRCOnly{"inherit"}; | 		std::string firmwareRCOnly{"inherit"}; | ||||||
|  |  | ||||||
| 		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); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| @@ -770,7 +710,6 @@ namespace OpenWifi::ProvObjects { | |||||||
| 		std::string realMacAddress; | 		std::string realMacAddress; | ||||||
|  |  | ||||||
| 		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); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| @@ -778,7 +717,6 @@ namespace OpenWifi::ProvObjects { | |||||||
| 		std::vector<SubscriberDevice> subscriberDevices; | 		std::vector<SubscriberDevice> subscriberDevices; | ||||||
|  |  | ||||||
| 		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); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| @@ -791,7 +729,6 @@ namespace OpenWifi::ProvObjects { | |||||||
| 		std::uint64_t modified; | 		std::uint64_t modified; | ||||||
|  |  | ||||||
| 		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); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| @@ -801,119 +738,12 @@ namespace OpenWifi::ProvObjects { | |||||||
| 		std::vector<ConfigurationOverride> overrides; | 		std::vector<ConfigurationOverride> overrides; | ||||||
|  |  | ||||||
| 		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); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| 	bool UpdateObjectInfo(const Poco::JSON::Object::Ptr &O, const SecurityObjects::UserInfo &U, | 	bool UpdateObjectInfo(const Poco::JSON::Object::Ptr &O, const SecurityObjects::UserInfo &U, | ||||||
| 						  ObjectInfo &I); | 						  ObjectInfo &I); | ||||||
|  |  | ||||||
| 	bool CreateObjectInfo(const Poco::JSON::Object::Ptr &O, const SecurityObjects::UserInfo &U, | 	bool CreateObjectInfo(const Poco::JSON::Object::Ptr &O, const SecurityObjects::UserInfo &U, | ||||||
| 						  ObjectInfo &I); | 						  ObjectInfo &I); | ||||||
|  |  | ||||||
| 	bool CreateObjectInfo(const SecurityObjects::UserInfo &U, ObjectInfo &I); | 	bool CreateObjectInfo(const SecurityObjects::UserInfo &U, ObjectInfo &I); | ||||||
|  |  | ||||||
|     struct GLBLRAccountInfo { |  | ||||||
|         ObjectInfo info; |  | ||||||
|         std::string privateKey; |  | ||||||
|         std::string country, province, city, organization, commonName; |  | ||||||
|         std::string CSR, CSRPrivateKey, CSRPublicKey; |  | ||||||
|         std::string GlobalReachAcctId; |  | ||||||
|  |  | ||||||
|         void to_json(Poco::JSON::Object &Obj) const; |  | ||||||
|  |  | ||||||
|         bool from_json(const Poco::JSON::Object::Ptr &Obj); |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     struct GLBLRCertificateInfo { |  | ||||||
|         std::string id; |  | ||||||
|         std::string name; |  | ||||||
|         std::string accountId; |  | ||||||
|         std::string csr; |  | ||||||
|         std::string certificate; |  | ||||||
|         std::string certificateChain; |  | ||||||
|         std::string certificateId; |  | ||||||
|         std::uint64_t expiresAt = 0; |  | ||||||
|         std::uint64_t created = 0; |  | ||||||
|  |  | ||||||
|         void to_json(Poco::JSON::Object &Obj) const; |  | ||||||
|  |  | ||||||
|         bool from_json(const Poco::JSON::Object::Ptr &Obj); |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     struct GooglOrionAccountInfo { |  | ||||||
|         ObjectInfo info; |  | ||||||
|         std::string privateKey; |  | ||||||
|         std::string certificate; |  | ||||||
|         std::vector<std::string> cacerts; |  | ||||||
|  |  | ||||||
|         void to_json(Poco::JSON::Object &Obj) const; |  | ||||||
|         bool from_json(const Poco::JSON::Object::Ptr &Obj); |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     struct RADIUSServer { |  | ||||||
|         std::string     Hostname; |  | ||||||
|         std::string     IP; |  | ||||||
|         std::uint64_t   Port=0; |  | ||||||
|         std::string     Secret; |  | ||||||
|  |  | ||||||
|         void to_json(Poco::JSON::Object &Obj) const; |  | ||||||
|         bool from_json(const Poco::JSON::Object::Ptr &Obj); |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     struct RADIUSEndPointRadiusType { |  | ||||||
|         std::vector<RADIUSServer>    Authentication; |  | ||||||
|         std::vector<RADIUSServer>    Accounting; |  | ||||||
|         std::vector<RADIUSServer>    CoA; |  | ||||||
|         std::uint64_t AccountingInterval = 60; |  | ||||||
|  |  | ||||||
|         void to_json(Poco::JSON::Object &Obj) const; |  | ||||||
|         bool from_json(const Poco::JSON::Object::Ptr &Obj); |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     struct RADIUSEndPointRadsecType { |  | ||||||
|         std::string     Hostname; |  | ||||||
|         std::string     IP; |  | ||||||
|         std::uint64_t   Port=2083; |  | ||||||
|         std::string     Secret{"radsec"}; |  | ||||||
|         std::string     OpenRoamingType; |  | ||||||
|         std::string     UseOpenRoamingAccount; |  | ||||||
|         std::uint64_t   Weight=0; |  | ||||||
|         std::string     Certificate; |  | ||||||
|         std::string     PrivateKey; |  | ||||||
|         std::vector<std::string>    CaCerts; |  | ||||||
|         bool AllowSelfSigned=false; |  | ||||||
|  |  | ||||||
|         void to_json(Poco::JSON::Object &Obj) const; |  | ||||||
|         bool from_json(const Poco::JSON::Object::Ptr &Obj); |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     struct RADIUSEndPoint { |  | ||||||
|         ObjectInfo                  info; |  | ||||||
|         std::string                 Type{"radius"}; |  | ||||||
|         std::string                 PoolStrategy{"none"}; |  | ||||||
|         bool                        UseGWProxy=true; |  | ||||||
|         std::string                 Index; |  | ||||||
|         std::vector<std::string>    UsedBy; |  | ||||||
|         std::vector<RADIUSEndPointRadiusType>   RadiusServers; |  | ||||||
|         std::vector<RADIUSEndPointRadsecType>   RadsecServers; |  | ||||||
|         std::string                 NasIdentifier; |  | ||||||
|         std::uint64_t               AccountingInterval=600; |  | ||||||
|  |  | ||||||
|         void to_json(Poco::JSON::Object &Obj) const; |  | ||||||
|         bool from_json(const Poco::JSON::Object::Ptr &Obj); |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     struct RADIUSEndpointUpdateStatus { |  | ||||||
|         std::uint64_t   lastUpdate=0; |  | ||||||
|         std::uint64_t   lastConfigurationChange=0; |  | ||||||
|  |  | ||||||
|         void to_json(Poco::JSON::Object &Obj) const; |  | ||||||
|         bool from_json(const Poco::JSON::Object::Ptr &Obj); |  | ||||||
|         bool Read(); |  | ||||||
|         bool Save(); |  | ||||||
|         bool ChangeConfiguration(); |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|  |  | ||||||
| }; // namespace OpenWifi::ProvObjects | }; // namespace OpenWifi::ProvObjects | ||||||
|   | |||||||
| @@ -26,7 +26,7 @@ namespace OpenWifi { | |||||||
| 			Response.set("Connection", "keep-alive"); | 			Response.set("Connection", "keep-alive"); | ||||||
| 			Response.setVersion(Poco::Net::HTTPMessage::HTTP_1_1); | 			Response.setVersion(Poco::Net::HTTPMessage::HTTP_1_1); | ||||||
| 			std::ostream &Answer = Response.send(); | 			std::ostream &Answer = Response.send(); | ||||||
| 			Answer << ALBHealthCheckServer()->CallbackText(); | 			Answer << "process Alive and kicking!"; | ||||||
| 		} catch (...) { | 		} catch (...) { | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|   | |||||||
| @@ -37,8 +37,6 @@ namespace OpenWifi { | |||||||
| 		inline static std::atomic_uint64_t req_id_ = 1; | 		inline static std::atomic_uint64_t req_id_ = 1; | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| 	typedef std::string ALBHealthMessageCallback(); |  | ||||||
|  |  | ||||||
| 	class ALBHealthCheckServer : public SubSystemServer { | 	class ALBHealthCheckServer : public SubSystemServer { | ||||||
| 	  public: | 	  public: | ||||||
| 		ALBHealthCheckServer(); | 		ALBHealthCheckServer(); | ||||||
| @@ -50,22 +48,10 @@ namespace OpenWifi { | |||||||
|  |  | ||||||
| 		int Start() override; | 		int Start() override; | ||||||
| 		void Stop() override; | 		void Stop() override; | ||||||
| 		inline void RegisterExtendedHealthMessage(ALBHealthMessageCallback *F) { |  | ||||||
| 			Callback_=F; |  | ||||||
| 		}; |  | ||||||
|  |  | ||||||
| 		inline std::string CallbackText() { |  | ||||||
| 			if(Callback_== nullptr) { |  | ||||||
| 				return "process Alive and kicking!"; |  | ||||||
| 			} else { |  | ||||||
| 				return Callback_(); |  | ||||||
| 			} |  | ||||||
| 		} |  | ||||||
|  |  | ||||||
| 	  private: | 	  private: | ||||||
| 		std::unique_ptr<Poco::Net::HTTPServer> Server_; | 		std::unique_ptr<Poco::Net::HTTPServer> Server_; | ||||||
| 		std::unique_ptr<Poco::Net::ServerSocket> Socket_; | 		std::unique_ptr<Poco::Net::ServerSocket> Socket_; | ||||||
| 		ALBHealthMessageCallback	*Callback_= nullptr; |  | ||||||
| 		int Port_ = 0; | 		int Port_ = 0; | ||||||
| 		mutable std::atomic_bool Running_ = false; | 		mutable std::atomic_bool Running_ = false; | ||||||
| 	}; | 	}; | ||||||
|   | |||||||
| @@ -11,12 +11,10 @@ | |||||||
|  |  | ||||||
| #include "Poco/File.h" | #include "Poco/File.h" | ||||||
| #include "Poco/StreamCopier.h" | #include "Poco/StreamCopier.h" | ||||||
| #include "Poco/JSON/Object.h" |  | ||||||
| #include "Poco/JSON/Parser.h" |  | ||||||
|  |  | ||||||
| #include "framework/MicroServiceFuncs.h" | #include "framework/MicroServiceFuncs.h" | ||||||
|  |  | ||||||
| // #include "nlohmann/json.hpp" | #include "nlohmann/json.hpp" | ||||||
|  |  | ||||||
| namespace OpenWifi { | namespace OpenWifi { | ||||||
|  |  | ||||||
| @@ -30,11 +28,11 @@ namespace OpenWifi { | |||||||
| 				if (F.exists()) { | 				if (F.exists()) { | ||||||
| 					std::ostringstream OS; | 					std::ostringstream OS; | ||||||
| 					std::ifstream IF(FileName); | 					std::ifstream IF(FileName); | ||||||
|                     Poco::JSON::Parser  P; | 					Poco::StreamCopier::copyStream(IF, OS); | ||||||
| 					Registry_ = P.parse(IF).extract<Poco::JSON::Object::Ptr>(); | 					Registry_ = nlohmann::json::parse(OS.str()); | ||||||
| 				} | 				} | ||||||
| 			} catch (...) { | 			} catch (...) { | ||||||
| 				Registry_ = Poco::makeShared<Poco::JSON::Object>(); | 				Registry_ = nlohmann::json::parse("{}"); | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| @@ -46,39 +44,46 @@ namespace OpenWifi { | |||||||
| 		inline ~AppServiceRegistry() { Save(); } | 		inline ~AppServiceRegistry() { Save(); } | ||||||
|  |  | ||||||
| 		inline void Save() { | 		inline void Save() { | ||||||
|  | 			std::istringstream IS(to_string(Registry_)); | ||||||
| 			std::ofstream OF; | 			std::ofstream OF; | ||||||
| 			OF.open(FileName, std::ios::binary | std::ios::trunc); | 			OF.open(FileName, std::ios::binary | std::ios::trunc); | ||||||
|             Registry_->stringify(OF); | 			Poco::StreamCopier::copyStream(IS, OF); | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
|         void Set(const char *key, const std::vector<std::string> &V) { | 		inline void Set(const char *Key, uint64_t Value) { | ||||||
|             Poco::JSON::Array   Arr; | 			Registry_[Key] = Value; | ||||||
|             for(const auto &s:V) { |  | ||||||
|                 Arr.add(s); |  | ||||||
|             } |  | ||||||
|             Registry_->set(key,Arr); |  | ||||||
| 			Save(); | 			Save(); | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
|         template<class T> void Set(const char *key, const T &Value) { | 		inline void Set(const char *Key, const std::string &Value) { | ||||||
|             Registry_->set(key,Value); | 			Registry_[Key] = Value; | ||||||
| 			Save(); | 			Save(); | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
|         bool Get(const char *key, std::vector<std::string> &Value) { | 		inline void Set(const char *Key, bool Value) { | ||||||
|             if(Registry_->has(key) && !Registry_->isNull(key) && Registry_->isArray(key)) { | 			Registry_[Key] = Value; | ||||||
|                 auto Arr = Registry_->get(key); | 			Save(); | ||||||
|                 for(const auto &v:Arr) { |  | ||||||
|                     Value.emplace_back(v); |  | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
|  | 		inline bool Get(const char *Key, bool &Value) { | ||||||
|  | 			if (Registry_[Key].is_boolean()) { | ||||||
|  | 				Value = Registry_[Key].get<bool>(); | ||||||
| 				return true; | 				return true; | ||||||
| 			} | 			} | ||||||
| 			return false; | 			return false; | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
|         template<class T> bool Get(const char *key, T &Value) { | 		inline bool Get(const char *Key, uint64_t &Value) { | ||||||
|             if(Registry_->has(key) && !Registry_->isNull(key)) { | 			if (Registry_[Key].is_number_unsigned()) { | ||||||
|                 Value = Registry_->getValue<T>(key); | 				Value = Registry_[Key].get<uint64_t>(); | ||||||
|  | 				return true; | ||||||
|  | 			} | ||||||
|  | 			return false; | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		inline bool Get(const char *Key, std::string &Value) { | ||||||
|  | 			if (Registry_[Key].is_string()) { | ||||||
|  | 				Value = Registry_[Key].get<std::string>(); | ||||||
| 				return true; | 				return true; | ||||||
| 			} | 			} | ||||||
| 			return false; | 			return false; | ||||||
| @@ -86,7 +91,7 @@ namespace OpenWifi { | |||||||
|  |  | ||||||
| 	  private: | 	  private: | ||||||
| 		std::string FileName; | 		std::string FileName; | ||||||
| 		Poco::JSON::Object::Ptr Registry_; | 		nlohmann::json Registry_; | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| 	inline auto AppServiceRegistry() { return AppServiceRegistry::instance(); } | 	inline auto AppServiceRegistry() { return AppServiceRegistry::instance(); } | ||||||
|   | |||||||
| @@ -34,17 +34,9 @@ static std::string DefaultUCentralSchema = R"foo( | |||||||
|     "$schema": "http://json-schema.org/draft-07/schema#", |     "$schema": "http://json-schema.org/draft-07/schema#", | ||||||
|     "type": "object", |     "type": "object", | ||||||
|     "properties": { |     "properties": { | ||||||
|         "strict": { |  | ||||||
|             "type": "boolean", |  | ||||||
|             "default": false |  | ||||||
|         }, |  | ||||||
|         "uuid": { |         "uuid": { | ||||||
|             "type": "integer" |             "type": "integer" | ||||||
|         }, |         }, | ||||||
|         "public_ip_lookup": { |  | ||||||
|             "type": "string", |  | ||||||
|             "format": "uc-fqdn" |  | ||||||
|         }, |  | ||||||
|         "unit": { |         "unit": { | ||||||
|             "$ref": "#/$defs/unit" |             "$ref": "#/$defs/unit" | ||||||
|         }, |         }, | ||||||
| @@ -118,20 +110,6 @@ static std::string DefaultUCentralSchema = R"foo( | |||||||
|                 "random-password": { |                 "random-password": { | ||||||
|                     "type": "boolean", |                     "type": "boolean", | ||||||
|                     "default": false |                     "default": false | ||||||
|                 }, |  | ||||||
|                 "beacon-advertisement": { |  | ||||||
|                     "type": "object", |  | ||||||
|                     "properties": { |  | ||||||
|                         "device-name": { |  | ||||||
|                             "type": "boolean" |  | ||||||
|                         }, |  | ||||||
|                         "device-serial": { |  | ||||||
|                             "type": "boolean" |  | ||||||
|                         }, |  | ||||||
|                         "network-id": { |  | ||||||
|                             "type": "integer" |  | ||||||
|                         } |  | ||||||
|                     } |  | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         }, |         }, | ||||||
| @@ -240,52 +218,6 @@ static std::string DefaultUCentralSchema = R"foo( | |||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         }, |         }, | ||||||
|         "interface.ssid.encryption": { |  | ||||||
|             "type": "object", |  | ||||||
|             "properties": { |  | ||||||
|                 "proto": { |  | ||||||
|                     "type": "string", |  | ||||||
|                     "enum": [ |  | ||||||
|                         "none", |  | ||||||
|                         "owe", |  | ||||||
|                         "owe-transition", |  | ||||||
|                         "psk", |  | ||||||
|                         "psk2", |  | ||||||
|                         "psk-mixed", |  | ||||||
|                         "psk2-radius", |  | ||||||
|                         "wpa", |  | ||||||
|                         "wpa2", |  | ||||||
|                         "wpa-mixed", |  | ||||||
|                         "sae", |  | ||||||
|                         "sae-mixed", |  | ||||||
|                         "wpa3", |  | ||||||
|                         "wpa3-192", |  | ||||||
|                         "wpa3-mixed" |  | ||||||
|                     ], |  | ||||||
|                     "examples": [ |  | ||||||
|                         "psk2" |  | ||||||
|                     ] |  | ||||||
|                 }, |  | ||||||
|                 "key": { |  | ||||||
|                     "type": "string", |  | ||||||
|                     "maxLength": 63, |  | ||||||
|                     "minLength": 8 |  | ||||||
|                 }, |  | ||||||
|                 "ieee80211w": { |  | ||||||
|                     "type": "string", |  | ||||||
|                     "enum": [ |  | ||||||
|                         "disabled", |  | ||||||
|                         "optional", |  | ||||||
|                         "required" |  | ||||||
|                     ], |  | ||||||
|                     "default": "disabled" |  | ||||||
|                 }, |  | ||||||
|                 "key-caching": { |  | ||||||
|                     "type": "boolean", |  | ||||||
|                     "default": true |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|         }, |  | ||||||
|         "definitions": { |         "definitions": { | ||||||
|             "type": "object", |             "type": "object", | ||||||
|             "properties": { |             "properties": { | ||||||
| @@ -702,6 +634,26 @@ static std::string DefaultUCentralSchema = R"foo( | |||||||
|                     "type": "string", |                     "type": "string", | ||||||
|                     "format": "uc-timeout", |                     "format": "uc-timeout", | ||||||
|                     "default": "6h" |                     "default": "6h" | ||||||
|  |                 }, | ||||||
|  |                 "relay-server": { | ||||||
|  |                     "type": "string", | ||||||
|  |                     "format": "ipv4", | ||||||
|  |                     "example": "192.168.2.1" | ||||||
|  |                 }, | ||||||
|  |                 "circuit-id-format": { | ||||||
|  |                     "type": "string", | ||||||
|  |                     "example": [ | ||||||
|  |                         "\\{Interface\\}:\\{VLAN-Id\\}:\\{SSID\\}:\\{Model\\}:\\{Name\\}:\\{AP-MAC\\}:\\{Location\\}", | ||||||
|  |                         "\\{AP-MAC\\};\\{SSID\\};\\{Crypto\\}", | ||||||
|  |                         "\\{Name\\} \\{ESSID\\}" | ||||||
|  |                     ] | ||||||
|  |                 }, | ||||||
|  |                 "remote-id-format": { | ||||||
|  |                     "type": "string", | ||||||
|  |                     "example": [ | ||||||
|  |                         "\\{Client-MAC-hex\\} \\{SSID\\}", | ||||||
|  |                         "\\{AP-MAC-hex\\} \\{SSID\\}" | ||||||
|  |                     ] | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         }, |         }, | ||||||
| @@ -780,8 +732,7 @@ static std::string DefaultUCentralSchema = R"foo( | |||||||
|                     "type": "string", |                     "type": "string", | ||||||
|                     "enum": [ |                     "enum": [ | ||||||
|                         "dynamic", |                         "dynamic", | ||||||
|                         "static", |                         "static" | ||||||
|                         "none" |  | ||||||
|                     ], |                     ], | ||||||
|                     "examples": [ |                     "examples": [ | ||||||
|                         "static" |                         "static" | ||||||
| @@ -1071,6 +1022,52 @@ static std::string DefaultUCentralSchema = R"foo( | |||||||
|                 } |                 } | ||||||
|             ] |             ] | ||||||
|         }, |         }, | ||||||
|  |         "interface.ssid.encryption": { | ||||||
|  |             "type": "object", | ||||||
|  |             "properties": { | ||||||
|  |                 "proto": { | ||||||
|  |                     "type": "string", | ||||||
|  |                     "enum": [ | ||||||
|  |                         "none", | ||||||
|  |                         "owe", | ||||||
|  |                         "owe-transition", | ||||||
|  |                         "psk", | ||||||
|  |                         "psk2", | ||||||
|  |                         "psk-mixed", | ||||||
|  |                         "psk2-radius", | ||||||
|  |                         "wpa", | ||||||
|  |                         "wpa2", | ||||||
|  |                         "wpa-mixed", | ||||||
|  |                         "sae", | ||||||
|  |                         "sae-mixed", | ||||||
|  |                         "wpa3", | ||||||
|  |                         "wpa3-192", | ||||||
|  |                         "wpa3-mixed" | ||||||
|  |                     ], | ||||||
|  |                     "examples": [ | ||||||
|  |                         "psk2" | ||||||
|  |                     ] | ||||||
|  |                 }, | ||||||
|  |                 "key": { | ||||||
|  |                     "type": "string", | ||||||
|  |                     "maxLength": 63, | ||||||
|  |                     "minLength": 8 | ||||||
|  |                 }, | ||||||
|  |                 "ieee80211w": { | ||||||
|  |                     "type": "string", | ||||||
|  |                     "enum": [ | ||||||
|  |                         "disabled", | ||||||
|  |                         "optional", | ||||||
|  |                         "required" | ||||||
|  |                     ], | ||||||
|  |                     "default": "disabled" | ||||||
|  |                 }, | ||||||
|  |                 "key-caching": { | ||||||
|  |                     "type": "boolean", | ||||||
|  |                     "default": true | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         }, | ||||||
|         "interface.ssid.multi-psk": { |         "interface.ssid.multi-psk": { | ||||||
|             "type": "object", |             "type": "object", | ||||||
|             "properties": { |             "properties": { | ||||||
| @@ -1235,32 +1232,6 @@ static std::string DefaultUCentralSchema = R"foo( | |||||||
|                         "secret" |                         "secret" | ||||||
|                     ] |                     ] | ||||||
|                 }, |                 }, | ||||||
|                 "secondary": { |  | ||||||
|                     "type": "object", |  | ||||||
|                     "properties": { |  | ||||||
|                         "host": { |  | ||||||
|                             "type": "string", |  | ||||||
|                             "format": "uc-host", |  | ||||||
|                             "examples": [ |  | ||||||
|                                 "192.168.1.10" |  | ||||||
|                             ] |  | ||||||
|                         }, |  | ||||||
|                         "port": { |  | ||||||
|                             "type": "integer", |  | ||||||
|                             "maximum": 65535, |  | ||||||
|                             "minimum": 1024, |  | ||||||
|                             "examples": [ |  | ||||||
|                                 1812 |  | ||||||
|                             ] |  | ||||||
|                         }, |  | ||||||
|                         "secret": { |  | ||||||
|                             "type": "string", |  | ||||||
|                             "examples": [ |  | ||||||
|                                 "secret" |  | ||||||
|                             ] |  | ||||||
|                         } |  | ||||||
|                     } |  | ||||||
|                 }, |  | ||||||
|                 "request-attribute": { |                 "request-attribute": { | ||||||
|                     "type": "array", |                     "type": "array", | ||||||
|                     "items": { |                     "items": { | ||||||
| @@ -1338,25 +1309,6 @@ static std::string DefaultUCentralSchema = R"foo( | |||||||
|                                         "value": "Example Operator" |                                         "value": "Example Operator" | ||||||
|                                     } |                                     } | ||||||
|                                 ] |                                 ] | ||||||
|                             }, |  | ||||||
|                             { |  | ||||||
|                                 "type": "object", |  | ||||||
|                                 "properties": { |  | ||||||
|                                     "id": { |  | ||||||
|                                         "type": "integer", |  | ||||||
|                                         "maximum": 255, |  | ||||||
|                                         "minimum": 1 |  | ||||||
|                                     }, |  | ||||||
|                                     "hex-value": { |  | ||||||
|                                         "type": "string" |  | ||||||
|                                     } |  | ||||||
|                                 }, |  | ||||||
|                                 "examples": [ |  | ||||||
|                                     { |  | ||||||
|                                         "id": 32, |  | ||||||
|                                         "value": "0a0b0c0d" |  | ||||||
|                                     } |  | ||||||
|                                 ] |  | ||||||
|                             } |                             } | ||||||
|                         ] |                         ] | ||||||
|                     } |                     } | ||||||
| @@ -1706,236 +1658,6 @@ static std::string DefaultUCentralSchema = R"foo( | |||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         }, |         }, | ||||||
|         "service.captive.click": { |  | ||||||
|             "type": "object", |  | ||||||
|             "properties": { |  | ||||||
|                 "auth-mode": { |  | ||||||
|                     "type": "string", |  | ||||||
|                     "const": "click-to-continue" |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|         }, |  | ||||||
|         "service.captive.radius": { |  | ||||||
|             "type": "object", |  | ||||||
|             "properties": { |  | ||||||
|                 "auth-mode": { |  | ||||||
|                     "type": "string", |  | ||||||
|                     "const": "radius" |  | ||||||
|                 }, |  | ||||||
|                 "auth-server": { |  | ||||||
|                     "type": "string", |  | ||||||
|                     "format": "uc-host", |  | ||||||
|                     "examples": [ |  | ||||||
|                         "192.168.1.10" |  | ||||||
|                     ] |  | ||||||
|                 }, |  | ||||||
|                 "auth-port": { |  | ||||||
|                     "type": "integer", |  | ||||||
|                     "maximum": 65535, |  | ||||||
|                     "minimum": 1024, |  | ||||||
|                     "default": 1812 |  | ||||||
|                 }, |  | ||||||
|                 "auth-secret": { |  | ||||||
|                     "type": "string", |  | ||||||
|                     "examples": [ |  | ||||||
|                         "secret" |  | ||||||
|                     ] |  | ||||||
|                 }, |  | ||||||
|                 "acct-server": { |  | ||||||
|                     "type": "string", |  | ||||||
|                     "format": "uc-host", |  | ||||||
|                     "examples": [ |  | ||||||
|                         "192.168.1.10" |  | ||||||
|                     ] |  | ||||||
|                 }, |  | ||||||
|                 "acct-port": { |  | ||||||
|                     "type": "integer", |  | ||||||
|                     "maximum": 65535, |  | ||||||
|                     "minimum": 1024, |  | ||||||
|                     "default": 1812 |  | ||||||
|                 }, |  | ||||||
|                 "acct-secret": { |  | ||||||
|                     "type": "string", |  | ||||||
|                     "examples": [ |  | ||||||
|                         "secret" |  | ||||||
|                     ] |  | ||||||
|                 }, |  | ||||||
|                 "acct-interval": { |  | ||||||
|                     "type": "integer", |  | ||||||
|                     "default": 600 |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|         }, |  | ||||||
|         "service.captive.credentials": { |  | ||||||
|             "type": "object", |  | ||||||
|             "properties": { |  | ||||||
|                 "auth-mode": { |  | ||||||
|                     "type": "string", |  | ||||||
|                     "const": "credentials" |  | ||||||
|                 }, |  | ||||||
|                 "credentials": { |  | ||||||
|                     "type": "array", |  | ||||||
|                     "items": { |  | ||||||
|                         "type": "object", |  | ||||||
|                         "properties": { |  | ||||||
|                             "username": { |  | ||||||
|                                 "type": "string" |  | ||||||
|                             }, |  | ||||||
|                             "password": { |  | ||||||
|                                 "type": "string" |  | ||||||
|                             } |  | ||||||
|                         } |  | ||||||
|                     } |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|         }, |  | ||||||
|         "service.captive.uam": { |  | ||||||
|             "type": "object", |  | ||||||
|             "properties": { |  | ||||||
|                 "auth-mode": { |  | ||||||
|                     "type": "string", |  | ||||||
|                     "const": "uam" |  | ||||||
|                 }, |  | ||||||
|                 "uam-port": { |  | ||||||
|                     "type": "integer", |  | ||||||
|                     "maximum": 65535, |  | ||||||
|                     "minimum": 1024, |  | ||||||
|                     "default": 3990 |  | ||||||
|                 }, |  | ||||||
|                 "uam-secret": { |  | ||||||
|                     "type": "string" |  | ||||||
|                 }, |  | ||||||
|                 "uam-server": { |  | ||||||
|                     "type": "string" |  | ||||||
|                 }, |  | ||||||
|                 "nasid": { |  | ||||||
|                     "type": "string" |  | ||||||
|                 }, |  | ||||||
|                 "nasmac": { |  | ||||||
|                     "type": "string" |  | ||||||
|                 }, |  | ||||||
|                 "auth-server": { |  | ||||||
|                     "type": "string", |  | ||||||
|                     "format": "uc-host", |  | ||||||
|                     "examples": [ |  | ||||||
|                         "192.168.1.10" |  | ||||||
|                     ] |  | ||||||
|                 }, |  | ||||||
|                 "auth-port": { |  | ||||||
|                     "type": "integer", |  | ||||||
|                     "maximum": 65535, |  | ||||||
|                     "minimum": 1024, |  | ||||||
|                     "default": 1812 |  | ||||||
|                 }, |  | ||||||
|                 "auth-secret": { |  | ||||||
|                     "type": "string", |  | ||||||
|                     "examples": [ |  | ||||||
|                         "secret" |  | ||||||
|                     ] |  | ||||||
|                 }, |  | ||||||
|                 "acct-server": { |  | ||||||
|                     "type": "string", |  | ||||||
|                     "format": "uc-host", |  | ||||||
|                     "examples": [ |  | ||||||
|                         "192.168.1.10" |  | ||||||
|                     ] |  | ||||||
|                 }, |  | ||||||
|                 "acct-port": { |  | ||||||
|                     "type": "integer", |  | ||||||
|                     "maximum": 65535, |  | ||||||
|                     "minimum": 1024, |  | ||||||
|                     "default": 1812 |  | ||||||
|                 }, |  | ||||||
|                 "acct-secret": { |  | ||||||
|                     "type": "string", |  | ||||||
|                     "examples": [ |  | ||||||
|                         "secret" |  | ||||||
|                     ] |  | ||||||
|                 }, |  | ||||||
|                 "acct-interval": { |  | ||||||
|                     "type": "integer", |  | ||||||
|                     "default": 600 |  | ||||||
|                 }, |  | ||||||
|                 "ssid": { |  | ||||||
|                     "type": "string" |  | ||||||
|                 }, |  | ||||||
|                 "mac-format": { |  | ||||||
|                     "type": "string", |  | ||||||
|                     "enum": [ |  | ||||||
|                         "aabbccddeeff", |  | ||||||
|                         "aa-bb-cc-dd-ee-ff", |  | ||||||
|                         "aa:bb:cc:dd:ee:ff", |  | ||||||
|                         "AABBCCDDEEFF", |  | ||||||
|                         "AA:BB:CC:DD:EE:FF", |  | ||||||
|                         "AA-BB-CC-DD-EE-FF" |  | ||||||
|                     ] |  | ||||||
|                 }, |  | ||||||
|                 "final-redirect-url": { |  | ||||||
|                     "type": "string", |  | ||||||
|                     "enum": [ |  | ||||||
|                         "default", |  | ||||||
|                         "uam" |  | ||||||
|                     ] |  | ||||||
|                 }, |  | ||||||
|                 "mac-auth": { |  | ||||||
|                     "type": "boolean", |  | ||||||
|                     "default": "default" |  | ||||||
|                 }, |  | ||||||
|                 "radius-gw-proxy": { |  | ||||||
|                     "type": "boolean", |  | ||||||
|                     "default": false |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|         }, |  | ||||||
|         "service.captive": { |  | ||||||
|             "allOf": [ |  | ||||||
|                 { |  | ||||||
|                     "oneOf": [ |  | ||||||
|                         { |  | ||||||
|                             "$ref": "#/$defs/service.captive.click" |  | ||||||
|                         }, |  | ||||||
|                         { |  | ||||||
|                             "$ref": "#/$defs/service.captive.radius" |  | ||||||
|                         }, |  | ||||||
|                         { |  | ||||||
|                             "$ref": "#/$defs/service.captive.credentials" |  | ||||||
|                         }, |  | ||||||
|                         { |  | ||||||
|                             "$ref": "#/$defs/service.captive.uam" |  | ||||||
|                         } |  | ||||||
|                     ] |  | ||||||
|                 }, |  | ||||||
|                 { |  | ||||||
|                     "type": "object", |  | ||||||
|                     "properties": { |  | ||||||
|                         "walled-garden-fqdn": { |  | ||||||
|                             "type": "array", |  | ||||||
|                             "items": { |  | ||||||
|                                 "type": "string" |  | ||||||
|                             } |  | ||||||
|                         }, |  | ||||||
|                         "walled-garden-ipaddr": { |  | ||||||
|                             "type": "array", |  | ||||||
|                             "items": { |  | ||||||
|                                 "type": "string", |  | ||||||
|                                 "format": "uc-ip" |  | ||||||
|                             } |  | ||||||
|                         }, |  | ||||||
|                         "web-root": { |  | ||||||
|                             "type": "string", |  | ||||||
|                             "format": "uc-base64" |  | ||||||
|                         }, |  | ||||||
|                         "idle-timeout": { |  | ||||||
|                             "type": "integer", |  | ||||||
|                             "default": 600 |  | ||||||
|                         }, |  | ||||||
|                         "session-timeout": { |  | ||||||
|                             "type": "integer" |  | ||||||
|                         } |  | ||||||
|                     } |  | ||||||
|                 } |  | ||||||
|             ] |  | ||||||
|         }, |  | ||||||
|         "interface.ssid": { |         "interface.ssid": { | ||||||
|             "type": "object", |             "type": "object", | ||||||
|             "properties": { |             "properties": { | ||||||
| @@ -1988,10 +1710,6 @@ static std::string DefaultUCentralSchema = R"foo( | |||||||
|                 "isolate-clients": { |                 "isolate-clients": { | ||||||
|                     "type": "boolean" |                     "type": "boolean" | ||||||
|                 }, |                 }, | ||||||
|                 "strict-forwarding": { |  | ||||||
|                     "type": "boolean", |  | ||||||
|                     "default": false |  | ||||||
|                 }, |  | ||||||
|                 "power-save": { |                 "power-save": { | ||||||
|                     "type": "boolean" |                     "type": "boolean" | ||||||
|                 }, |                 }, | ||||||
| @@ -2039,11 +1757,6 @@ static std::string DefaultUCentralSchema = R"foo( | |||||||
|                     "decription": "This option allows embedding custom vendor specific IEs inside the beacons of a BSS in AP mode.", |                     "decription": "This option allows embedding custom vendor specific IEs inside the beacons of a BSS in AP mode.", | ||||||
|                     "type": "string" |                     "type": "string" | ||||||
|                 }, |                 }, | ||||||
|                 "tip-information-element": { |  | ||||||
|                     "decription": "The device will broadcast the TIP vendor IE inside its beacons if this option is enabled.", |  | ||||||
|                     "type": "boolean", |  | ||||||
|                     "default": true |  | ||||||
|                 }, |  | ||||||
|                 "fils-discovery-interval": { |                 "fils-discovery-interval": { | ||||||
|                     "type": "integer", |                     "type": "integer", | ||||||
|                     "default": 20, |                     "default": 20, | ||||||
| @@ -2065,15 +1778,8 @@ static std::string DefaultUCentralSchema = R"foo( | |||||||
|                     "$ref": "#/$defs/interface.ssid.rate-limit" |                     "$ref": "#/$defs/interface.ssid.rate-limit" | ||||||
|                 }, |                 }, | ||||||
|                 "roaming": { |                 "roaming": { | ||||||
|                     "anyOf": [ |  | ||||||
|                         { |  | ||||||
|                     "$ref": "#/$defs/interface.ssid.roaming" |                     "$ref": "#/$defs/interface.ssid.roaming" | ||||||
|                 }, |                 }, | ||||||
|                         { |  | ||||||
|                             "type": "boolean" |  | ||||||
|                         } |  | ||||||
|                     ] |  | ||||||
|                 }, |  | ||||||
|                 "radius": { |                 "radius": { | ||||||
|                     "$ref": "#/$defs/interface.ssid.radius" |                     "$ref": "#/$defs/interface.ssid.radius" | ||||||
|                 }, |                 }, | ||||||
| @@ -2089,9 +1795,6 @@ static std::string DefaultUCentralSchema = R"foo( | |||||||
|                 "access-control-list": { |                 "access-control-list": { | ||||||
|                     "$ref": "#/$defs/interface.ssid.acl" |                     "$ref": "#/$defs/interface.ssid.acl" | ||||||
|                 }, |                 }, | ||||||
|                 "captive": { |  | ||||||
|                     "$ref": "#/$defs/service.captive" |  | ||||||
|                 }, |  | ||||||
|                 "hostapd-bss-raw": { |                 "hostapd-bss-raw": { | ||||||
|                     "type": "array", |                     "type": "array", | ||||||
|                     "items": { |                     "items": { | ||||||
| @@ -2259,17 +1962,6 @@ static std::string DefaultUCentralSchema = R"foo( | |||||||
|                         ] |                         ] | ||||||
|                     } |                     } | ||||||
|                 }, |                 }, | ||||||
|                 "vlan-awareness": { |  | ||||||
|                     "type": "object", |  | ||||||
|                     "properties": { |  | ||||||
|                         "first": { |  | ||||||
|                             "type": "integer" |  | ||||||
|                         }, |  | ||||||
|                         "last": { |  | ||||||
|                             "type": "integer" |  | ||||||
|                         } |  | ||||||
|                     } |  | ||||||
|                 }, |  | ||||||
|                 "vlan": { |                 "vlan": { | ||||||
|                     "$ref": "#/$defs/interface.vlan" |                     "$ref": "#/$defs/interface.vlan" | ||||||
|                 }, |                 }, | ||||||
| @@ -2392,10 +2084,6 @@ static std::string DefaultUCentralSchema = R"foo( | |||||||
|                     "examples": [ |                     "examples": [ | ||||||
|                         "01234567890123456789012345678901" |                         "01234567890123456789012345678901" | ||||||
|                     ] |                     ] | ||||||
|                 }, |  | ||||||
|                 "mutual-tls": { |  | ||||||
|                     "type": "boolean", |  | ||||||
|                     "default": true |  | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         }, |         }, | ||||||
| @@ -2467,24 +2155,6 @@ static std::string DefaultUCentralSchema = R"foo( | |||||||
|                     "type": "boolean", |                     "type": "boolean", | ||||||
|                     "default": false |                     "default": false | ||||||
|                 }, |                 }, | ||||||
|                 "mode": { |  | ||||||
|                     "type": "string", |  | ||||||
|                     "enum": [ |  | ||||||
|                         "radius", |  | ||||||
|                         "user" |  | ||||||
|                     ] |  | ||||||
|                 }, |  | ||||||
|                 "port-filter": { |  | ||||||
|                     "type": "array", |  | ||||||
|                     "items": { |  | ||||||
|                         "type": "string", |  | ||||||
|                         "examples": [ |  | ||||||
|                             { |  | ||||||
|                                 "LAN1": null |  | ||||||
|                             } |  | ||||||
|                         ] |  | ||||||
|                     } |  | ||||||
|                 }, |  | ||||||
|                 "server-certificate": { |                 "server-certificate": { | ||||||
|                     "type": "string" |                     "type": "string" | ||||||
|                 }, |                 }, | ||||||
| @@ -2496,77 +2166,6 @@ static std::string DefaultUCentralSchema = R"foo( | |||||||
|                     "items": { |                     "items": { | ||||||
|                         "$ref": "#/$defs/interface.ssid.radius.local-user" |                         "$ref": "#/$defs/interface.ssid.radius.local-user" | ||||||
|                     } |                     } | ||||||
|                 }, |  | ||||||
|                 "radius": { |  | ||||||
|                     "type": "object", |  | ||||||
|                     "properties": { |  | ||||||
|                         "nas-identifier": { |  | ||||||
|                             "type": "string" |  | ||||||
|                         }, |  | ||||||
|                         "auth-server-addr": { |  | ||||||
|                             "type": "string", |  | ||||||
|                             "format": "uc-host", |  | ||||||
|                             "examples": [ |  | ||||||
|                                 "192.168.1.10" |  | ||||||
|                             ] |  | ||||||
|                         }, |  | ||||||
|                         "auth-server-port": { |  | ||||||
|                             "type": "integer", |  | ||||||
|                             "maximum": 65535, |  | ||||||
|                             "minimum": 1024, |  | ||||||
|                             "examples": [ |  | ||||||
|                                 1812 |  | ||||||
|                             ] |  | ||||||
|                         }, |  | ||||||
|                         "auth-server-secret": { |  | ||||||
|                             "type": "string", |  | ||||||
|                             "examples": [ |  | ||||||
|                                 "secret" |  | ||||||
|                             ] |  | ||||||
|                         }, |  | ||||||
|                         "acct-server-addr": { |  | ||||||
|                             "type": "string", |  | ||||||
|                             "format": "uc-host", |  | ||||||
|                             "examples": [ |  | ||||||
|                                 "192.168.1.10" |  | ||||||
|                             ] |  | ||||||
|                         }, |  | ||||||
|                         "acct-server-port": { |  | ||||||
|                             "type": "integer", |  | ||||||
|                             "maximum": 65535, |  | ||||||
|                             "minimum": 1024, |  | ||||||
|                             "examples": [ |  | ||||||
|                                 1813 |  | ||||||
|                             ] |  | ||||||
|                         }, |  | ||||||
|                         "acct-server-secret": { |  | ||||||
|                             "type": "string", |  | ||||||
|                             "examples": [ |  | ||||||
|                                 "secret" |  | ||||||
|                             ] |  | ||||||
|                         }, |  | ||||||
|                         "coa-server-addr": { |  | ||||||
|                             "type": "string", |  | ||||||
|                             "format": "uc-host", |  | ||||||
|                             "examples": [ |  | ||||||
|                                 "192.168.1.10" |  | ||||||
|                             ] |  | ||||||
|                         }, |  | ||||||
|                         "coa-server-port": { |  | ||||||
|                             "type": "integer", |  | ||||||
|                             "maximum": 65535, |  | ||||||
|                             "minimum": 1024, |  | ||||||
|                             "examples": [ |  | ||||||
|                                 1814 |  | ||||||
|                             ] |  | ||||||
|                         }, |  | ||||||
|                         "coa-server-secret": { |  | ||||||
|                             "type": "string", |  | ||||||
|                             "examples": [ |  | ||||||
|                                 "secret" |  | ||||||
|                             ] |  | ||||||
|                         } |  | ||||||
|                     } |  | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         }, |         }, | ||||||
| @@ -2890,12 +2489,6 @@ static std::string DefaultUCentralSchema = R"foo( | |||||||
|                         } |                         } | ||||||
|                     } |                     } | ||||||
|                 }, |                 }, | ||||||
|                 "services": { |  | ||||||
|                     "type": "array", |  | ||||||
|                     "items": { |  | ||||||
|                         "type": "string" |  | ||||||
|                     } |  | ||||||
|                 }, |  | ||||||
|                 "classifier": { |                 "classifier": { | ||||||
|                     "type": "array", |                     "type": "array", | ||||||
|                     "items": { |                     "items": { | ||||||
| @@ -3100,6 +2693,236 @@ static std::string DefaultUCentralSchema = R"foo( | |||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         }, |         }, | ||||||
|  |         "service.captive.click": { | ||||||
|  |             "type": "object", | ||||||
|  |             "properties": { | ||||||
|  |                 "auth-mode": { | ||||||
|  |                     "type": "string", | ||||||
|  |                     "const": "click-to-continue" | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         }, | ||||||
|  |         "service.captive.radius": { | ||||||
|  |             "type": "object", | ||||||
|  |             "properties": { | ||||||
|  |                 "auth-mode": { | ||||||
|  |                     "type": "string", | ||||||
|  |                     "const": "radius" | ||||||
|  |                 }, | ||||||
|  |                 "auth-server": { | ||||||
|  |                     "type": "string", | ||||||
|  |                     "format": "uc-host", | ||||||
|  |                     "examples": [ | ||||||
|  |                         "192.168.1.10" | ||||||
|  |                     ] | ||||||
|  |                 }, | ||||||
|  |                 "auth-port": { | ||||||
|  |                     "type": "integer", | ||||||
|  |                     "maximum": 65535, | ||||||
|  |                     "minimum": 1024, | ||||||
|  |                     "default": 1812 | ||||||
|  |                 }, | ||||||
|  |                 "auth-secret": { | ||||||
|  |                     "type": "string", | ||||||
|  |                     "examples": [ | ||||||
|  |                         "secret" | ||||||
|  |                     ] | ||||||
|  |                 }, | ||||||
|  |                 "acct-server": { | ||||||
|  |                     "type": "string", | ||||||
|  |                     "format": "uc-host", | ||||||
|  |                     "examples": [ | ||||||
|  |                         "192.168.1.10" | ||||||
|  |                     ] | ||||||
|  |                 }, | ||||||
|  |                 "acct-port": { | ||||||
|  |                     "type": "integer", | ||||||
|  |                     "maximum": 65535, | ||||||
|  |                     "minimum": 1024, | ||||||
|  |                     "default": 1812 | ||||||
|  |                 }, | ||||||
|  |                 "acct-secret": { | ||||||
|  |                     "type": "string", | ||||||
|  |                     "examples": [ | ||||||
|  |                         "secret" | ||||||
|  |                     ] | ||||||
|  |                 }, | ||||||
|  |                 "acct-interval": { | ||||||
|  |                     "type": "integer", | ||||||
|  |                     "default": 600 | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         }, | ||||||
|  |         "service.captive.credentials": { | ||||||
|  |             "type": "object", | ||||||
|  |             "properties": { | ||||||
|  |                 "auth-mode": { | ||||||
|  |                     "type": "string", | ||||||
|  |                     "const": "credentials" | ||||||
|  |                 }, | ||||||
|  |                 "credentials": { | ||||||
|  |                     "type": "array", | ||||||
|  |                     "items": { | ||||||
|  |                         "type": "object", | ||||||
|  |                         "properties": { | ||||||
|  |                             "username": { | ||||||
|  |                                 "type": "string" | ||||||
|  |                             }, | ||||||
|  |                             "password": { | ||||||
|  |                                 "type": "string" | ||||||
|  |                             } | ||||||
|  |                         } | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         }, | ||||||
|  |         "service.captive.uam": { | ||||||
|  |             "type": "object", | ||||||
|  |             "properties": { | ||||||
|  |                 "auth-mode": { | ||||||
|  |                     "type": "string", | ||||||
|  |                     "const": "uam" | ||||||
|  |                 }, | ||||||
|  |                 "uam-port": { | ||||||
|  |                     "type": "integer", | ||||||
|  |                     "maximum": 65535, | ||||||
|  |                     "minimum": 1024, | ||||||
|  |                     "default": 3990 | ||||||
|  |                 }, | ||||||
|  |                 "uam-secret": { | ||||||
|  |                     "type": "string" | ||||||
|  |                 }, | ||||||
|  |                 "uam-server": { | ||||||
|  |                     "type": "string" | ||||||
|  |                 }, | ||||||
|  |                 "nasid": { | ||||||
|  |                     "type": "string" | ||||||
|  |                 }, | ||||||
|  |                 "nasmac": { | ||||||
|  |                     "type": "string" | ||||||
|  |                 }, | ||||||
|  |                 "auth-server": { | ||||||
|  |                     "type": "string", | ||||||
|  |                     "format": "uc-host", | ||||||
|  |                     "examples": [ | ||||||
|  |                         "192.168.1.10" | ||||||
|  |                     ] | ||||||
|  |                 }, | ||||||
|  |                 "auth-port": { | ||||||
|  |                     "type": "integer", | ||||||
|  |                     "maximum": 65535, | ||||||
|  |                     "minimum": 1024, | ||||||
|  |                     "default": 1812 | ||||||
|  |                 }, | ||||||
|  |                 "auth-secret": { | ||||||
|  |                     "type": "string", | ||||||
|  |                     "examples": [ | ||||||
|  |                         "secret" | ||||||
|  |                     ] | ||||||
|  |                 }, | ||||||
|  |                 "acct-server": { | ||||||
|  |                     "type": "string", | ||||||
|  |                     "format": "uc-host", | ||||||
|  |                     "examples": [ | ||||||
|  |                         "192.168.1.10" | ||||||
|  |                     ] | ||||||
|  |                 }, | ||||||
|  |                 "acct-port": { | ||||||
|  |                     "type": "integer", | ||||||
|  |                     "maximum": 65535, | ||||||
|  |                     "minimum": 1024, | ||||||
|  |                     "default": 1812 | ||||||
|  |                 }, | ||||||
|  |                 "acct-secret": { | ||||||
|  |                     "type": "string", | ||||||
|  |                     "examples": [ | ||||||
|  |                         "secret" | ||||||
|  |                     ] | ||||||
|  |                 }, | ||||||
|  |                 "acct-interval": { | ||||||
|  |                     "type": "integer", | ||||||
|  |                     "default": 600 | ||||||
|  |                 }, | ||||||
|  |                 "ssid": { | ||||||
|  |                     "type": "string" | ||||||
|  |                 }, | ||||||
|  |                 "mac-format": { | ||||||
|  |                     "type": "string", | ||||||
|  |                     "enum": [ | ||||||
|  |                         "aabbccddeeff", | ||||||
|  |                         "aa-bb-cc-dd-ee-ff", | ||||||
|  |                         "aa:bb:cc:dd:ee:ff", | ||||||
|  |                         "AABBCCDDEEFF", | ||||||
|  |                         "AA:BB:CC:DD:EE:FF", | ||||||
|  |                         "AA-BB-CC-DD-EE-FF" | ||||||
|  |                     ] | ||||||
|  |                 }, | ||||||
|  |                 "final-redirect-url": { | ||||||
|  |                     "type": "string", | ||||||
|  |                     "enum": [ | ||||||
|  |                         "default", | ||||||
|  |                         "uam" | ||||||
|  |                     ] | ||||||
|  |                 }, | ||||||
|  |                 "mac-auth": { | ||||||
|  |                     "type": "boolean", | ||||||
|  |                     "default": "default" | ||||||
|  |                 }, | ||||||
|  |                 "radius-gw-proxy": { | ||||||
|  |                     "type": "boolean", | ||||||
|  |                     "default": false | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         }, | ||||||
|  |         "service.captive": { | ||||||
|  |             "allOf": [ | ||||||
|  |                 { | ||||||
|  |                     "oneOf": [ | ||||||
|  |                         { | ||||||
|  |                             "$ref": "#/$defs/service.captive.click" | ||||||
|  |                         }, | ||||||
|  |                         { | ||||||
|  |                             "$ref": "#/$defs/service.captive.radius" | ||||||
|  |                         }, | ||||||
|  |                         { | ||||||
|  |                             "$ref": "#/$defs/service.captive.credentials" | ||||||
|  |                         }, | ||||||
|  |                         { | ||||||
|  |                             "$ref": "#/$defs/service.captive.uam" | ||||||
|  |                         } | ||||||
|  |                     ] | ||||||
|  |                 }, | ||||||
|  |                 { | ||||||
|  |                     "type": "object", | ||||||
|  |                     "properties": { | ||||||
|  |                         "walled-garden-fqdn": { | ||||||
|  |                             "type": "array", | ||||||
|  |                             "items": { | ||||||
|  |                                 "type": "string" | ||||||
|  |                             } | ||||||
|  |                         }, | ||||||
|  |                         "walled-garden-ipaddr": { | ||||||
|  |                             "type": "array", | ||||||
|  |                             "items": { | ||||||
|  |                                 "type": "string", | ||||||
|  |                                 "format": "uc-ip" | ||||||
|  |                             } | ||||||
|  |                         }, | ||||||
|  |                         "web-root": { | ||||||
|  |                             "type": "string", | ||||||
|  |                             "format": "uc-base64" | ||||||
|  |                         }, | ||||||
|  |                         "idle-timeout": { | ||||||
|  |                             "type": "integer", | ||||||
|  |                             "default": 600 | ||||||
|  |                         }, | ||||||
|  |                         "session-timeout": { | ||||||
|  |                             "type": "integer" | ||||||
|  |                         } | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |             ] | ||||||
|  |         }, | ||||||
|         "service.gps": { |         "service.gps": { | ||||||
|             "type": "object", |             "type": "object", | ||||||
|             "properties": { |             "properties": { | ||||||
| @@ -3118,50 +2941,6 @@ static std::string DefaultUCentralSchema = R"foo( | |||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         }, |         }, | ||||||
|         "service.dhcp-relay": { |  | ||||||
|             "type": "object", |  | ||||||
|             "properties": { |  | ||||||
|                 "select-ports": { |  | ||||||
|                     "type": "array", |  | ||||||
|                     "items": { |  | ||||||
|                         "type": "string" |  | ||||||
|                     } |  | ||||||
|                 }, |  | ||||||
|                 "vlans": { |  | ||||||
|                     "type": "array", |  | ||||||
|                     "items": { |  | ||||||
|                         "type": "object", |  | ||||||
|                         "properties": { |  | ||||||
|                             "vlan": { |  | ||||||
|                                 "type": "number" |  | ||||||
|                             }, |  | ||||||
|                             "relay-server": { |  | ||||||
|                                 "type": "string", |  | ||||||
|                                 "format": "uc-ip" |  | ||||||
|                             }, |  | ||||||
|                             "circuit-id-format": { |  | ||||||
|                                 "type": "string", |  | ||||||
|                                 "enum": [ |  | ||||||
|                                     "vlan-id", |  | ||||||
|                                     "ap-mac", |  | ||||||
|                                     "ssid" |  | ||||||
|                                 ], |  | ||||||
|                                 "default": "vlan-id" |  | ||||||
|                             }, |  | ||||||
|                             "remote-id-format": { |  | ||||||
|                                 "type": "string", |  | ||||||
|                                 "enum": [ |  | ||||||
|                                     "vlan-id", |  | ||||||
|                                     "ap-mac", |  | ||||||
|                                     "ssid" |  | ||||||
|                                 ], |  | ||||||
|                                 "default": "ap-mac" |  | ||||||
|                             } |  | ||||||
|                         } |  | ||||||
|                     } |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|         }, |  | ||||||
|         "service": { |         "service": { | ||||||
|             "type": "object", |             "type": "object", | ||||||
|             "properties": { |             "properties": { | ||||||
| @@ -3221,9 +3000,6 @@ static std::string DefaultUCentralSchema = R"foo( | |||||||
|                 }, |                 }, | ||||||
|                 "gps": { |                 "gps": { | ||||||
|                     "$ref": "#/$defs/service.gps" |                     "$ref": "#/$defs/service.gps" | ||||||
|                 }, |  | ||||||
|                 "dhcp-relay": { |  | ||||||
|                     "$ref": "#/$defs/service.dhcp-relay" |  | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         }, |         }, | ||||||
|   | |||||||
| @@ -9,27 +9,29 @@ | |||||||
|  |  | ||||||
| namespace OpenWifi { | namespace OpenWifi { | ||||||
|  |  | ||||||
|  | 	EventBusManager::EventBusManager(Poco::Logger &L) : Logger_(L) {} | ||||||
|  |  | ||||||
| 	void EventBusManager::run() { | 	void EventBusManager::run() { | ||||||
| 		Running_ = true; | 		Running_ = true; | ||||||
| 		Utils::SetThreadName("fmwk:EventMgr"); | 		Utils::SetThreadName("fmwk:EventMgr"); | ||||||
| 		auto Msg = (MicroServiceMakeSystemEventMessage(KafkaTopics::ServiceEvents::EVENT_JOIN)); | 		auto Msg = std::make_shared<std::string>(MicroServiceMakeSystemEventMessage(KafkaTopics::ServiceEvents::EVENT_JOIN)); | ||||||
| 		KafkaManager()->PostMessage(KafkaTopics::SERVICE_EVENTS, MicroServicePrivateEndPoint(), Msg, | 		KafkaManager()->PostMessage(KafkaTopics::SERVICE_EVENTS, MicroServicePrivateEndPoint(), Msg, | ||||||
| 									false); | 									false); | ||||||
| 		while (Running_) { | 		while (Running_) { | ||||||
| 			if(!Poco::Thread::trySleep((unsigned long)MicroServiceDaemonBusTimer())) { | 			Poco::Thread::trySleep((unsigned long)MicroServiceDaemonBusTimer()); | ||||||
|  | 			if (!Running_) | ||||||
| 				break; | 				break; | ||||||
|             } | 			Msg = std::make_shared<std::string>(MicroServiceMakeSystemEventMessage(KafkaTopics::ServiceEvents::EVENT_KEEP_ALIVE)); | ||||||
| 			Msg = (MicroServiceMakeSystemEventMessage(KafkaTopics::ServiceEvents::EVENT_KEEP_ALIVE)); |  | ||||||
| 			KafkaManager()->PostMessage(KafkaTopics::SERVICE_EVENTS, MicroServicePrivateEndPoint(), | 			KafkaManager()->PostMessage(KafkaTopics::SERVICE_EVENTS, MicroServicePrivateEndPoint(), | ||||||
| 										Msg, false); | 										Msg, false); | ||||||
| 		} | 		} | ||||||
| 		Msg = (MicroServiceMakeSystemEventMessage(KafkaTopics::ServiceEvents::EVENT_LEAVE)); | 		Msg = std::make_shared<std::string>(MicroServiceMakeSystemEventMessage(KafkaTopics::ServiceEvents::EVENT_LEAVE)); | ||||||
| 		KafkaManager()->PostMessage(KafkaTopics::SERVICE_EVENTS, MicroServicePrivateEndPoint(), Msg, | 		KafkaManager()->PostMessage(KafkaTopics::SERVICE_EVENTS, MicroServicePrivateEndPoint(), Msg, | ||||||
| 									false); | 									false); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| 	void EventBusManager::Start() { | 	void EventBusManager::Start() { | ||||||
| 		poco_information(Logger_, "Starting..."); | 		poco_information(Logger(), "Starting..."); | ||||||
| 		if (KafkaManager()->Enabled()) { | 		if (KafkaManager()->Enabled()) { | ||||||
| 			Thread_.start(*this); | 			Thread_.start(*this); | ||||||
| 		} | 		} | ||||||
| @@ -37,11 +39,11 @@ namespace OpenWifi { | |||||||
|  |  | ||||||
| 	void EventBusManager::Stop() { | 	void EventBusManager::Stop() { | ||||||
| 		if (KafkaManager()->Enabled()) { | 		if (KafkaManager()->Enabled()) { | ||||||
| 			poco_information(Logger_, "Stopping..."); | 			poco_information(Logger(), "Stopping..."); | ||||||
| 			Running_ = false; | 			Running_ = false; | ||||||
| 			Thread_.wakeUp(); | 			Thread_.wakeUp(); | ||||||
| 			Thread_.join(); | 			Thread_.join(); | ||||||
| 			poco_information(Logger_, "Stopped..."); | 			poco_information(Logger(), "Stopped..."); | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|   | |||||||
| @@ -12,16 +12,7 @@ namespace OpenWifi { | |||||||
|  |  | ||||||
| 	class EventBusManager : public Poco::Runnable { | 	class EventBusManager : public Poco::Runnable { | ||||||
| 	  public: | 	  public: | ||||||
| 		EventBusManager() : | 		explicit EventBusManager(Poco::Logger &L); | ||||||
| 			Logger_(Poco::Logger::create( |  | ||||||
| 				"EventBusManager", Poco::Logger::root().getChannel(), Poco::Logger::root().getLevel())) { |  | ||||||
| 		} |  | ||||||
|  |  | ||||||
| 		static auto instance() { |  | ||||||
| 			static auto instance_ = new EventBusManager; |  | ||||||
| 			return instance_; |  | ||||||
| 		} |  | ||||||
|  |  | ||||||
| 		void run() final; | 		void run() final; | ||||||
| 		void Start(); | 		void Start(); | ||||||
| 		void Stop(); | 		void Stop(); | ||||||
| @@ -33,6 +24,4 @@ namespace OpenWifi { | |||||||
| 		Poco::Logger &Logger_; | 		Poco::Logger &Logger_; | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| 	inline auto EventBusManager() { return EventBusManager::instance(); } |  | ||||||
|  |  | ||||||
| } // namespace OpenWifi | } // namespace OpenWifi | ||||||
|   | |||||||
| @@ -6,7 +6,6 @@ | |||||||
|  |  | ||||||
| #include "fmt/format.h" | #include "fmt/format.h" | ||||||
| #include "framework/MicroServiceFuncs.h" | #include "framework/MicroServiceFuncs.h" | ||||||
| #include "cppkafka/utils/consumer_dispatcher.h" |  | ||||||
|  |  | ||||||
| namespace OpenWifi { | namespace OpenWifi { | ||||||
|  |  | ||||||
| @@ -79,10 +78,8 @@ namespace OpenWifi { | |||||||
| 		Utils::SetThreadName("Kafka:Prod"); | 		Utils::SetThreadName("Kafka:Prod"); | ||||||
| 		cppkafka::Configuration Config( | 		cppkafka::Configuration Config( | ||||||
| 			{{"client.id", MicroServiceConfigGetString("openwifi.kafka.client.id", "")}, | 			{{"client.id", MicroServiceConfigGetString("openwifi.kafka.client.id", "")}, | ||||||
| 			 {"metadata.broker.list",MicroServiceConfigGetString("openwifi.kafka.brokerlist", "")} // , | 			 {"metadata.broker.list", | ||||||
| 			 // {"send.buffer.bytes", KafkaManager()->KafkaManagerMaximumPayloadSize() } | 			  MicroServiceConfigGetString("openwifi.kafka.brokerlist", "")}}); | ||||||
| 			} |  | ||||||
|  		); |  | ||||||
|  |  | ||||||
| 		AddKafkaSecurity(Config); | 		AddKafkaSecurity(Config); | ||||||
|  |  | ||||||
| @@ -102,12 +99,9 @@ namespace OpenWifi { | |||||||
| 			try { | 			try { | ||||||
| 				auto Msg = dynamic_cast<KafkaMessage *>(Note.get()); | 				auto Msg = dynamic_cast<KafkaMessage *>(Note.get()); | ||||||
| 				if (Msg != nullptr) { | 				if (Msg != nullptr) { | ||||||
| 					auto NewMessage = cppkafka::MessageBuilder(Msg->Topic()); | 					Producer.produce(cppkafka::MessageBuilder(Msg->Topic()) | ||||||
| 					NewMessage.key(Msg->Key()); | 										 .key(Msg->Key()) | ||||||
| 					NewMessage.partition(0); | 										 .payload(Msg->Payload())); | ||||||
| 					NewMessage.payload(Msg->Payload()); |  | ||||||
| 					Producer.produce(NewMessage); |  | ||||||
| 					Producer.flush(); |  | ||||||
| 				} | 				} | ||||||
| 			} catch (const cppkafka::HandleException &E) { | 			} catch (const cppkafka::HandleException &E) { | ||||||
| 				poco_warning(Logger_, | 				poco_warning(Logger_, | ||||||
| @@ -162,49 +156,43 @@ namespace OpenWifi { | |||||||
| 			} | 			} | ||||||
| 		}); | 		}); | ||||||
|  |  | ||||||
| 		// bool AutoCommit = MicroServiceConfigGetBool("openwifi.kafka.auto.commit", false); | 		bool AutoCommit = MicroServiceConfigGetBool("openwifi.kafka.auto.commit", false); | ||||||
| 		// auto BatchSize = MicroServiceConfigGetInt("openwifi.kafka.consumer.batchsize", 100); | 		auto BatchSize = MicroServiceConfigGetInt("openwifi.kafka.consumer.batchsize", 20); | ||||||
|  |  | ||||||
| 		Types::StringVec Topics; | 		Types::StringVec Topics; | ||||||
| 		std::for_each(Topics_.begin(),Topics_.end(), | 		KafkaManager()->Topics(Topics); | ||||||
| 					  [&](const std::string & T) { Topics.emplace_back(T); }); |  | ||||||
| 		Consumer.subscribe(Topics); | 		Consumer.subscribe(Topics); | ||||||
|  |  | ||||||
| 		Running_ = true; | 		Running_ = true; | ||||||
| 		std::vector<cppkafka::Message> MsgVec; | 		while (Running_) { | ||||||
|  |  | ||||||
| 		Dispatcher_ = std::make_unique<cppkafka::ConsumerDispatcher>(Consumer); |  | ||||||
|  |  | ||||||
| 		Dispatcher_->run( |  | ||||||
| 			// Callback executed whenever a new message is consumed |  | ||||||
| 			[&](cppkafka::Message msg) { |  | ||||||
| 				// Print the key (if any) |  | ||||||
| 				std::lock_guard G(ConsumerMutex_); |  | ||||||
| 				auto It = Notifiers_.find(msg.get_topic()); |  | ||||||
| 				if (It != Notifiers_.end()) { |  | ||||||
| 					const auto &FL = It->second; |  | ||||||
| 					for (const auto &[CallbackFunc, _] : FL) { |  | ||||||
| 			try { | 			try { | ||||||
| 							CallbackFunc(msg.get_key(), msg.get_payload()); | 				std::vector<cppkafka::Message> MsgVec = | ||||||
| 						} catch(const Poco::Exception &E) { | 					Consumer.poll_batch(BatchSize, std::chrono::milliseconds(100)); | ||||||
|  | 				for (auto const &Msg : MsgVec) { | ||||||
| 						} catch(...) { | 					if (!Msg) | ||||||
|  | 						continue; | ||||||
|  | 					if (Msg.get_error()) { | ||||||
|  | 						if (!Msg.is_eof()) { | ||||||
|  | 							poco_error(Logger_, | ||||||
|  | 									   fmt::format("Error: {}", Msg.get_error().to_string())); | ||||||
|  | 						} | ||||||
|  | 						if (!AutoCommit) | ||||||
|  | 							Consumer.async_commit(Msg); | ||||||
|  | 						continue; | ||||||
|  | 					} | ||||||
|  | 					KafkaManager()->Dispatch(Msg.get_topic().c_str(), Msg.get_key(), std::make_shared<std::string>(Msg.get_payload())); | ||||||
|  | 					if (!AutoCommit) | ||||||
|  | 						Consumer.async_commit(Msg); | ||||||
|  | 				} | ||||||
|  | 			} catch (const cppkafka::HandleException &E) { | ||||||
|  | 				poco_warning(Logger_, | ||||||
|  | 							 fmt::format("Caught a Kafka exception (consumer): {}", E.what())); | ||||||
|  | 			} catch (const Poco::Exception &E) { | ||||||
|  | 				Logger_.log(E); | ||||||
|  | 			} catch (...) { | ||||||
|  | 				poco_error(Logger_, "std::exception"); | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| 				} |  | ||||||
| 				Consumer.commit(msg); |  | ||||||
| 			}, |  | ||||||
| 			// Whenever there's an error (other than the EOF soft error) |  | ||||||
| 			[&Logger_](cppkafka::Error error) { |  | ||||||
| 				poco_warning(Logger_,fmt::format("Error: {}", error.to_string())); |  | ||||||
| 			}, |  | ||||||
| 			// Whenever EOF is reached on a partition, print this |  | ||||||
| 			[&Logger_](cppkafka::ConsumerDispatcher::EndOfFile, const cppkafka::TopicPartition& topic_partition) { |  | ||||||
| 				poco_debug(Logger_,fmt::format("Partition {} EOF", topic_partition.get_partition())); |  | ||||||
| 			} |  | ||||||
| 		); |  | ||||||
|  |  | ||||||
| 		Consumer.unsubscribe(); | 		Consumer.unsubscribe(); | ||||||
| 		poco_information(Logger_, "Stopped..."); | 		poco_information(Logger_, "Stopped..."); | ||||||
| 	} | 	} | ||||||
| @@ -225,13 +213,14 @@ namespace OpenWifi { | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	void KafkaProducer::Produce(const char *Topic, const std::string &Key, | 	void KafkaProducer::Produce(const char *Topic, const std::string &Key, | ||||||
| 								const std::string &Payload) { | 								const std::shared_ptr<std::string> Payload) { | ||||||
| 		std::lock_guard G(Mutex_); | 		std::lock_guard G(Mutex_); | ||||||
| 		Queue_.enqueueNotification(new KafkaMessage(Topic, Key, Payload)); | 		Queue_.enqueueNotification(new KafkaMessage(Topic, Key, Payload)); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	void KafkaConsumer::Start() { | 	void KafkaConsumer::Start() { | ||||||
| 		if (!Running_) { | 		if (!Running_) { | ||||||
|  | 			Running_ = true; | ||||||
| 			Worker_.start(*this); | 			Worker_.start(*this); | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| @@ -239,16 +228,29 @@ namespace OpenWifi { | |||||||
| 	void KafkaConsumer::Stop() { | 	void KafkaConsumer::Stop() { | ||||||
| 		if (Running_) { | 		if (Running_) { | ||||||
| 			Running_ = false; | 			Running_ = false; | ||||||
| 			if(Dispatcher_) { | 			Worker_.wakeUp(); | ||||||
| 				Dispatcher_->stop(); |  | ||||||
| 			} |  | ||||||
| 			Worker_.join(); | 			Worker_.join(); | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	std::uint64_t KafkaConsumer::RegisterTopicWatcher(const std::string &Topic, | 	void KafkaDispatcher::Start() { | ||||||
|  | 		if (!Running_) { | ||||||
|  | 			Running_ = true; | ||||||
|  | 			Worker_.start(*this); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	void KafkaDispatcher::Stop() { | ||||||
|  | 		if (Running_) { | ||||||
|  | 			Running_ = false; | ||||||
|  | 			Queue_.wakeUpAll(); | ||||||
|  | 			Worker_.join(); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	auto KafkaDispatcher::RegisterTopicWatcher(const std::string &Topic, | ||||||
| 											   Types::TopicNotifyFunction &F) { | 											   Types::TopicNotifyFunction &F) { | ||||||
| 		std::lock_guard G(ConsumerMutex_); | 		std::lock_guard G(Mutex_); | ||||||
| 		auto It = Notifiers_.find(Topic); | 		auto It = Notifiers_.find(Topic); | ||||||
| 		if (It == Notifiers_.end()) { | 		if (It == Notifiers_.end()) { | ||||||
| 			Types::TopicNotifyFunctionList L; | 			Types::TopicNotifyFunctionList L; | ||||||
| @@ -257,12 +259,11 @@ namespace OpenWifi { | |||||||
| 		} else { | 		} else { | ||||||
| 			It->second.emplace(It->second.end(), std::make_pair(F, FunctionId_)); | 			It->second.emplace(It->second.end(), std::make_pair(F, FunctionId_)); | ||||||
| 		} | 		} | ||||||
| 		Topics_.insert(Topic); |  | ||||||
| 		return FunctionId_++; | 		return FunctionId_++; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	void KafkaConsumer::UnregisterTopicWatcher(const std::string &Topic, int Id) { | 	void KafkaDispatcher::UnregisterTopicWatcher(const std::string &Topic, int Id) { | ||||||
| 		std::lock_guard G(ConsumerMutex_); | 		std::lock_guard G(Mutex_); | ||||||
| 		auto It = Notifiers_.find(Topic); | 		auto It = Notifiers_.find(Topic); | ||||||
| 		if (It != Notifiers_.end()) { | 		if (It != Notifiers_.end()) { | ||||||
| 			Types::TopicNotifyFunctionList &L = It->second; | 			Types::TopicNotifyFunctionList &L = It->second; | ||||||
| @@ -274,18 +275,56 @@ namespace OpenWifi { | |||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | 	void KafkaDispatcher::Dispatch(const char *Topic, const std::string &Key, | ||||||
|  | 								   const std::shared_ptr<std::string> Payload) { | ||||||
|  | 		std::lock_guard G(Mutex_); | ||||||
|  | 		auto It = Notifiers_.find(Topic); | ||||||
|  | 		if (It != Notifiers_.end()) { | ||||||
|  | 			Queue_.enqueueNotification(new KafkaMessage(Topic, Key, Payload)); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	void KafkaDispatcher::run() { | ||||||
|  | 		Poco::Logger &Logger_ = | ||||||
|  | 			Poco::Logger::create("KAFKA-DISPATCHER", KafkaManager()->Logger().getChannel()); | ||||||
|  | 		poco_information(Logger_, "Starting..."); | ||||||
|  | 		Poco::AutoPtr<Poco::Notification> Note(Queue_.waitDequeueNotification()); | ||||||
|  | 		Utils::SetThreadName("kafka:dispatch"); | ||||||
|  | 		while (Note && Running_) { | ||||||
|  | 			auto Msg = dynamic_cast<KafkaMessage *>(Note.get()); | ||||||
|  | 			if (Msg != nullptr) { | ||||||
|  | 				auto It = Notifiers_.find(Msg->Topic()); | ||||||
|  | 				if (It != Notifiers_.end()) { | ||||||
|  | 					const auto &FL = It->second; | ||||||
|  | 					for (const auto &[CallbackFunc, _] : FL) { | ||||||
|  | 						CallbackFunc(Msg->Key(), Msg->Payload()); | ||||||
|  | 					} | ||||||
|  | 				} | ||||||
|  | 			} | ||||||
|  | 			Note = Queue_.waitDequeueNotification(); | ||||||
|  | 		} | ||||||
|  | 		poco_information(Logger_, "Stopped..."); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	void KafkaDispatcher::Topics(std::vector<std::string> &T) { | ||||||
|  | 		T.clear(); | ||||||
|  | 		for (const auto &[TopicName, _] : Notifiers_) | ||||||
|  | 			T.push_back(TopicName); | ||||||
|  | 	} | ||||||
|  |  | ||||||
| 	int KafkaManager::Start() { | 	int KafkaManager::Start() { | ||||||
| 		if (!KafkaEnabled_) | 		if (!KafkaEnabled_) | ||||||
| 			return 0; | 			return 0; | ||||||
| 		MaxPayloadSize_ = MicroServiceConfigGetInt("openwifi.kafka.max.payload", 250000); |  | ||||||
| 		ConsumerThr_.Start(); | 		ConsumerThr_.Start(); | ||||||
| 		ProducerThr_.Start(); | 		ProducerThr_.Start(); | ||||||
|  | 		Dispatcher_.Start(); | ||||||
| 		return 0; | 		return 0; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	void KafkaManager::Stop() { | 	void KafkaManager::Stop() { | ||||||
| 		if (KafkaEnabled_) { | 		if (KafkaEnabled_) { | ||||||
| 			poco_information(Logger(), "Stopping..."); | 			poco_information(Logger(), "Stopping..."); | ||||||
|  | 			Dispatcher_.Stop(); | ||||||
| 			ProducerThr_.Stop(); | 			ProducerThr_.Stop(); | ||||||
| 			ConsumerThr_.Stop(); | 			ConsumerThr_.Stop(); | ||||||
| 			poco_information(Logger(), "Stopped..."); | 			poco_information(Logger(), "Stopped..."); | ||||||
| @@ -294,25 +333,38 @@ namespace OpenWifi { | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	void KafkaManager::PostMessage(const char *topic, const std::string &key, | 	void KafkaManager::PostMessage(const char *topic, const std::string &key, | ||||||
| 								   const std::string & PayLoad, bool WrapMessage) { | 								   const std::shared_ptr<std::string> PayLoad, bool WrapMessage) { | ||||||
| 		if (KafkaEnabled_) { | 		if (KafkaEnabled_) { | ||||||
| 			ProducerThr_.Produce(topic, key, WrapMessage ? WrapSystemId(PayLoad) : PayLoad); | 			ProducerThr_.Produce(topic, key, WrapMessage ? WrapSystemId(PayLoad) : PayLoad); | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	void KafkaManager::PostMessage(const char *topic, const std::string &key, | 	void KafkaManager::Dispatch(const char *Topic, const std::string &Key, | ||||||
| 					 const Poco::JSON::Object &Object, bool WrapMessage) { | 								const std::shared_ptr<std::string> Payload) { | ||||||
|  | 		Dispatcher_.Dispatch(Topic, Key, Payload); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	[[nodiscard]] const std::shared_ptr<std::string> KafkaManager::WrapSystemId(const std::shared_ptr<std::string> PayLoad) { | ||||||
|  | 		*PayLoad = SystemInfoWrapper_ + *PayLoad + "}"; | ||||||
|  | 		return PayLoad; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	uint64_t KafkaManager::RegisterTopicWatcher(const std::string &Topic, | ||||||
|  | 												Types::TopicNotifyFunction &F) { | ||||||
| 		if (KafkaEnabled_) { | 		if (KafkaEnabled_) { | ||||||
| 			std::ostringstream ObjectStr; | 			return Dispatcher_.RegisterTopicWatcher(Topic, F); | ||||||
| 			Object.stringify(ObjectStr); | 		} else { | ||||||
| 			ProducerThr_.Produce(topic, key, WrapMessage ? WrapSystemId(ObjectStr.str()) : ObjectStr.str()); | 			return 0; | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	[[nodiscard]] std::string KafkaManager::WrapSystemId(const std::string & PayLoad) { | 	void KafkaManager::UnregisterTopicWatcher(const std::string &Topic, uint64_t Id) { | ||||||
| 		return fmt::format(	R"lit({{ "system" : {{ "id" : {}, "host" : "{}" }}, "payload" : {} }})lit", | 		if (KafkaEnabled_) { | ||||||
| 						   MicroServiceID(), MicroServicePrivateEndPoint(), PayLoad ) ; | 			Dispatcher_.UnregisterTopicWatcher(Topic, Id); | ||||||
| 		} | 		} | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	void KafkaManager::Topics(std::vector<std::string> &T) { Dispatcher_.Topics(T); } | ||||||
|  |  | ||||||
| 	void KafkaManager::PartitionAssignment(const cppkafka::TopicPartitionList &partitions) { | 	void KafkaManager::PartitionAssignment(const cppkafka::TopicPartitionList &partitions) { | ||||||
| 		poco_information( | 		poco_information( | ||||||
|   | |||||||
| @@ -6,7 +6,7 @@ | |||||||
|  |  | ||||||
| #include "Poco/Notification.h" | #include "Poco/Notification.h" | ||||||
| #include "Poco/NotificationQueue.h" | #include "Poco/NotificationQueue.h" | ||||||
| #include "Poco/JSON/Object.h" |  | ||||||
| #include "framework/KafkaTopics.h" | #include "framework/KafkaTopics.h" | ||||||
| #include "framework/OpenWifiTypes.h" | #include "framework/OpenWifiTypes.h" | ||||||
| #include "framework/SubSystemServer.h" | #include "framework/SubSystemServer.h" | ||||||
| @@ -18,17 +18,17 @@ namespace OpenWifi { | |||||||
|  |  | ||||||
| 	class KafkaMessage : public Poco::Notification { | 	class KafkaMessage : public Poco::Notification { | ||||||
| 	  public: | 	  public: | ||||||
| 		KafkaMessage(const char * Topic, const std::string &Key, const std::string &Payload) | 		KafkaMessage(const char * Topic, const std::string &Key, const std::shared_ptr<std::string> Payload) | ||||||
| 			: Topic_(Topic), Key_(Key), Payload_(Payload) {} | 			: Topic_(Topic), Key_(Key), Payload_(std::move(Payload)) {} | ||||||
|  |  | ||||||
| 		inline const char * Topic() { return Topic_; } | 		inline const char * Topic() { return Topic_; } | ||||||
| 		inline const std::string &Key() { return Key_; } | 		inline const std::string &Key() { return Key_; } | ||||||
| 		inline const std::string &Payload() { return Payload_; } | 		inline const std::string &Payload() { return *Payload_; } | ||||||
|  |  | ||||||
| 	  private: | 	  private: | ||||||
| 		const char *Topic_; | 		const char *Topic_; | ||||||
| 		std::string Key_; | 		std::string Key_; | ||||||
| 		std::string Payload_; | 		std::shared_ptr<std::string> Payload_; | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| 	class KafkaProducer : public Poco::Runnable { | 	class KafkaProducer : public Poco::Runnable { | ||||||
| @@ -36,10 +36,10 @@ namespace OpenWifi { | |||||||
| 		void run() override; | 		void run() override; | ||||||
| 		void Start(); | 		void Start(); | ||||||
| 		void Stop(); | 		void Stop(); | ||||||
| 		void Produce(const char *Topic, const std::string &Key, const std::string & Payload); | 		void Produce(const char *Topic, const std::string &Key, const std::shared_ptr<std::string> Payload); | ||||||
|  |  | ||||||
| 	  private: | 	  private: | ||||||
| 		std::mutex Mutex_; | 		std::recursive_mutex Mutex_; | ||||||
| 		Poco::Thread Worker_; | 		Poco::Thread Worker_; | ||||||
| 		mutable std::atomic_bool Running_ = false; | 		mutable std::atomic_bool Running_ = false; | ||||||
| 		Poco::NotificationQueue Queue_; | 		Poco::NotificationQueue Queue_; | ||||||
| @@ -47,22 +47,33 @@ namespace OpenWifi { | |||||||
|  |  | ||||||
| 	class KafkaConsumer : public Poco::Runnable { | 	class KafkaConsumer : public Poco::Runnable { | ||||||
| 	  public: | 	  public: | ||||||
|  | 		void run() override; | ||||||
| 		void Start(); | 		void Start(); | ||||||
| 		void Stop(); | 		void Stop(); | ||||||
|  |  | ||||||
| 	  private: | 	  private: | ||||||
| 		std::mutex 				ConsumerMutex_; | 		std::recursive_mutex Mutex_; | ||||||
|  | 		Poco::Thread Worker_; | ||||||
|  | 		mutable std::atomic_bool Running_ = false; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	class KafkaDispatcher : public Poco::Runnable { | ||||||
|  | 	  public: | ||||||
|  | 		void Start(); | ||||||
|  | 		void Stop(); | ||||||
|  | 		auto RegisterTopicWatcher(const std::string &Topic, Types::TopicNotifyFunction &F); | ||||||
|  | 		void UnregisterTopicWatcher(const std::string &Topic, int Id); | ||||||
|  | 		void Dispatch(const char *Topic, const std::string &Key, const std::shared_ptr<std::string> Payload); | ||||||
|  | 		void run() override; | ||||||
|  | 		void Topics(std::vector<std::string> &T); | ||||||
|  |  | ||||||
|  | 	  private: | ||||||
|  | 		std::recursive_mutex Mutex_; | ||||||
| 		Types::NotifyTable Notifiers_; | 		Types::NotifyTable Notifiers_; | ||||||
| 		Poco::Thread Worker_; | 		Poco::Thread Worker_; | ||||||
| 		mutable std::atomic_bool Running_ = false; | 		mutable std::atomic_bool Running_ = false; | ||||||
| 		uint64_t FunctionId_ = 1; | 		uint64_t FunctionId_ = 1; | ||||||
| 		std::unique_ptr<cppkafka::ConsumerDispatcher> 	Dispatcher_; | 		Poco::NotificationQueue Queue_; | ||||||
| 		std::set<std::string>	Topics_; |  | ||||||
|  |  | ||||||
| 		void run() override; |  | ||||||
| 		friend class KafkaManager; |  | ||||||
| 		std::uint64_t RegisterTopicWatcher(const std::string &Topic, Types::TopicNotifyFunction &F); |  | ||||||
| 		void UnregisterTopicWatcher(const std::string &Topic, int Id); |  | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| 	class KafkaManager : public SubSystemServer { | 	class KafkaManager : public SubSystemServer { | ||||||
| @@ -81,27 +92,20 @@ namespace OpenWifi { | |||||||
| 		void Stop() override; | 		void Stop() override; | ||||||
|  |  | ||||||
| 		void PostMessage(const char *topic, const std::string &key, | 		void PostMessage(const char *topic, const std::string &key, | ||||||
| 						 const std::string &PayLoad, bool WrapMessage = true); | 						 const std::shared_ptr<std::string> PayLoad, bool WrapMessage = true); | ||||||
| 		void PostMessage(const char *topic, const std::string &key, | 		void Dispatch(const char *Topic, const std::string &Key, const std::shared_ptr<std::string> Payload); | ||||||
| 						 const Poco::JSON::Object &Object, bool WrapMessage = true); | 		[[nodiscard]] const std::shared_ptr<std::string> WrapSystemId(const std::shared_ptr<std::string> PayLoad); | ||||||
|  |  | ||||||
| 		[[nodiscard]] std::string WrapSystemId(const std::string & PayLoad); |  | ||||||
| 		[[nodiscard]] inline bool Enabled() const { return KafkaEnabled_; } | 		[[nodiscard]] inline bool Enabled() const { return KafkaEnabled_; } | ||||||
| 		inline std::uint64_t RegisterTopicWatcher(const std::string &Topic, Types::TopicNotifyFunction &F) { | 		uint64_t RegisterTopicWatcher(const std::string &Topic, Types::TopicNotifyFunction &F); | ||||||
| 			return ConsumerThr_.RegisterTopicWatcher(Topic,F); | 		void UnregisterTopicWatcher(const std::string &Topic, uint64_t Id); | ||||||
| 		} | 		void Topics(std::vector<std::string> &T); | ||||||
| 		inline void UnregisterTopicWatcher(const std::string &Topic, uint64_t Id) { |  | ||||||
| 			return ConsumerThr_.UnregisterTopicWatcher(Topic,Id); |  | ||||||
| 		} |  | ||||||
|  |  | ||||||
| 		std::uint64_t KafkaManagerMaximumPayloadSize() const { return MaxPayloadSize_; } |  | ||||||
|  |  | ||||||
| 	  private: | 	  private: | ||||||
| 		bool KafkaEnabled_ = false; | 		bool KafkaEnabled_ = false; | ||||||
| 		std::string SystemInfoWrapper_; | 		std::string SystemInfoWrapper_; | ||||||
| 		KafkaProducer ProducerThr_; | 		KafkaProducer ProducerThr_; | ||||||
| 		KafkaConsumer ConsumerThr_; | 		KafkaConsumer ConsumerThr_; | ||||||
| 		std::uint64_t MaxPayloadSize_ = 250000; | 		KafkaDispatcher Dispatcher_; | ||||||
|  |  | ||||||
| 		void PartitionAssignment(const cppkafka::TopicPartitionList &partitions); | 		void PartitionAssignment(const cppkafka::TopicPartitionList &partitions); | ||||||
| 		void PartitionRevocation(const cppkafka::TopicPartitionList &partitions); | 		void PartitionRevocation(const cppkafka::TopicPartitionList &partitions); | ||||||
|   | |||||||
| @@ -20,7 +20,6 @@ namespace OpenWifi::KafkaTopics { | |||||||
| 	inline const char * DEVICE_EVENT_QUEUE = "device_event_queue"; | 	inline const char * DEVICE_EVENT_QUEUE = "device_event_queue"; | ||||||
| 	inline const char * DEVICE_TELEMETRY = "device_telemetry"; | 	inline const char * DEVICE_TELEMETRY = "device_telemetry"; | ||||||
| 	inline const char * PROVISIONING_CHANGE = "provisioning_change"; | 	inline const char * PROVISIONING_CHANGE = "provisioning_change"; | ||||||
| 	inline const char * RRM = "rrm"; |  | ||||||
|  |  | ||||||
| 	namespace ServiceEvents { | 	namespace ServiceEvents { | ||||||
| 		inline const char * EVENT_JOIN = "join"; | 		inline const char * EVENT_JOIN = "join"; | ||||||
|   | |||||||
| @@ -29,29 +29,13 @@ | |||||||
| #include "framework/WebSocketLogger.h" | #include "framework/WebSocketLogger.h" | ||||||
| #include "framework/utils.h" | #include "framework/utils.h" | ||||||
|  |  | ||||||
| #ifdef  USE_MEDUSA_CLIENT |  | ||||||
| #include <medusa/MedusaClient.h> |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| namespace OpenWifi { | namespace OpenWifi { | ||||||
|  |  | ||||||
| 	static std::string MakeServiceListString(const Types::MicroServiceMetaMap &Services) { | 	void MicroService::Exit(int Reason) { std::exit(Reason); } | ||||||
|         std::string SvcList; |  | ||||||
|         for (const auto &Svc : Services) { |  | ||||||
|             if (SvcList.empty()) |  | ||||||
|                 SvcList = Svc.second.Type; |  | ||||||
|             else |  | ||||||
|                 SvcList += ", " + Svc.second.Type; |  | ||||||
|         } |  | ||||||
|         return SvcList; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| 	void MicroService::BusMessageReceived([[maybe_unused]] const std::string &Key, | 	void MicroService::BusMessageReceived([[maybe_unused]] const std::string &Key, | ||||||
| 										  const std::string &Payload) { | 										  const std::string &Payload) { | ||||||
| 		std::lock_guard G(InfraMutex_); | 		std::lock_guard G(InfraMutex_); | ||||||
|  |  | ||||||
| 		Poco::Logger &BusLogger = EventBusManager()->Logger(); |  | ||||||
|  |  | ||||||
| 		try { | 		try { | ||||||
| 			Poco::JSON::Parser P; | 			Poco::JSON::Parser P; | ||||||
| 			auto Object = P.parse(Payload).extract<Poco::JSON::Object::Ptr>(); | 			auto Object = P.parse(Payload).extract<Poco::JSON::Object::Ptr>(); | ||||||
| @@ -71,10 +55,13 @@ namespace OpenWifi { | |||||||
| 							Object->has(KafkaTopics::ServiceEvents::Fields::KEY)) { | 							Object->has(KafkaTopics::ServiceEvents::Fields::KEY)) { | ||||||
| 							auto PrivateEndPoint = | 							auto PrivateEndPoint = | ||||||
| 								Object->get(KafkaTopics::ServiceEvents::Fields::PRIVATE).toString(); | 								Object->get(KafkaTopics::ServiceEvents::Fields::PRIVATE).toString(); | ||||||
| 							if (Event == KafkaTopics::ServiceEvents::EVENT_LEAVE) { | 							if (Event == KafkaTopics::ServiceEvents::EVENT_KEEP_ALIVE && | ||||||
|  | 								Services_.find(PrivateEndPoint) != Services_.end()) { | ||||||
|  | 								Services_[PrivateEndPoint].LastUpdate = Utils::Now(); | ||||||
|  | 							} else if (Event == KafkaTopics::ServiceEvents::EVENT_LEAVE) { | ||||||
| 								Services_.erase(PrivateEndPoint); | 								Services_.erase(PrivateEndPoint); | ||||||
| 								poco_information( | 								poco_debug( | ||||||
| 									BusLogger, | 									logger(), | ||||||
| 									fmt::format( | 									fmt::format( | ||||||
| 										"Service {} ID={} leaving system.", | 										"Service {} ID={} leaving system.", | ||||||
| 										Object->get(KafkaTopics::ServiceEvents::Fields::PRIVATE) | 										Object->get(KafkaTopics::ServiceEvents::Fields::PRIVATE) | ||||||
| @@ -82,7 +69,14 @@ namespace OpenWifi { | |||||||
| 										ID)); | 										ID)); | ||||||
| 							} else if (Event == KafkaTopics::ServiceEvents::EVENT_JOIN || | 							} else if (Event == KafkaTopics::ServiceEvents::EVENT_JOIN || | ||||||
| 									   Event == KafkaTopics::ServiceEvents::EVENT_KEEP_ALIVE) { | 									   Event == KafkaTopics::ServiceEvents::EVENT_KEEP_ALIVE) { | ||||||
| 								auto ServiceInfo = Types::MicroServiceMeta{ | 								poco_debug( | ||||||
|  | 									logger(), | ||||||
|  | 									fmt::format( | ||||||
|  | 										"Service {} ID={} joining system.", | ||||||
|  | 										Object->get(KafkaTopics::ServiceEvents::Fields::PRIVATE) | ||||||
|  | 											.toString(), | ||||||
|  | 										ID)); | ||||||
|  | 								Services_[PrivateEndPoint] = Types::MicroServiceMeta{ | ||||||
| 									.Id = ID, | 									.Id = ID, | ||||||
| 									.Type = Poco::toLower( | 									.Type = Poco::toLower( | ||||||
| 										Object->get(KafkaTopics::ServiceEvents::Fields::TYPE) | 										Object->get(KafkaTopics::ServiceEvents::Fields::TYPE) | ||||||
| @@ -100,22 +94,6 @@ namespace OpenWifi { | |||||||
| 												   .toString(), | 												   .toString(), | ||||||
| 									.LastUpdate = Utils::Now()}; | 									.LastUpdate = Utils::Now()}; | ||||||
|  |  | ||||||
|                                 auto s1 = MakeServiceListString(Services_); |  | ||||||
| 								auto PreviousSize = Services_.size(); |  | ||||||
| 								Services_[PrivateEndPoint] = ServiceInfo; |  | ||||||
| 								auto CurrentSize = Services_.size(); |  | ||||||
| 								if(Event == KafkaTopics::ServiceEvents::EVENT_JOIN) { |  | ||||||
| 									if(!s1.empty()) { |  | ||||||
| 										poco_information( |  | ||||||
| 											BusLogger, |  | ||||||
| 											fmt::format( |  | ||||||
| 												"Service {} ID={} is joining the system.", |  | ||||||
| 												Object |  | ||||||
| 													->get( |  | ||||||
| 														KafkaTopics::ServiceEvents::Fields::PRIVATE) |  | ||||||
| 													.toString(), |  | ||||||
| 												ID)); |  | ||||||
| 									} |  | ||||||
| 								std::string SvcList; | 								std::string SvcList; | ||||||
| 								for (const auto &Svc : Services_) { | 								for (const auto &Svc : Services_) { | ||||||
| 									if (SvcList.empty()) | 									if (SvcList.empty()) | ||||||
| @@ -124,22 +102,12 @@ namespace OpenWifi { | |||||||
| 										SvcList += ", " + Svc.second.Type; | 										SvcList += ", " + Svc.second.Type; | ||||||
| 								} | 								} | ||||||
| 								poco_information( | 								poco_information( | ||||||
| 										BusLogger, | 									logger(), | ||||||
| 									fmt::format("Current list of microservices: {}", SvcList)); | 									fmt::format("Current list of microservices: {}", SvcList)); | ||||||
| 								} else if(CurrentSize!=PreviousSize) { |  | ||||||
| 									poco_information( |  | ||||||
| 										BusLogger, |  | ||||||
| 										fmt::format( |  | ||||||
| 											"Service {} ID={} is being added back in.", |  | ||||||
| 											Object |  | ||||||
| 												->get(KafkaTopics::ServiceEvents::Fields::PRIVATE) |  | ||||||
| 												.toString(), |  | ||||||
| 											ID)); |  | ||||||
| 								} |  | ||||||
| 							} | 							} | ||||||
| 						} else { | 						} else { | ||||||
| 							poco_information( | 							poco_error( | ||||||
| 								BusLogger, | 								logger(), | ||||||
| 								fmt::format("KAFKA-MSG: invalid event '{}', missing a field.", | 								fmt::format("KAFKA-MSG: invalid event '{}', missing a field.", | ||||||
| 											Event)); | 											Event)); | ||||||
| 						} | 						} | ||||||
| @@ -150,39 +118,30 @@ namespace OpenWifi { | |||||||
| 								Object->get(KafkaTopics::ServiceEvents::Fields::TOKEN).toString()); | 								Object->get(KafkaTopics::ServiceEvents::Fields::TOKEN).toString()); | ||||||
| #endif | #endif | ||||||
| 						} else { | 						} else { | ||||||
| 							poco_information( | 							poco_error( | ||||||
| 								BusLogger, | 								logger(), | ||||||
| 								fmt::format("KAFKA-MSG: invalid event '{}', missing token", Event)); | 								fmt::format("KAFKA-MSG: invalid event '{}', missing token", Event)); | ||||||
| 						} | 						} | ||||||
| 					} else { | 					} else { | ||||||
| 						poco_information(BusLogger, | 						poco_error(logger(), | ||||||
| 								   fmt::format("Unknown Event: {} Source: {}", Event, ID)); | 								   fmt::format("Unknown Event: {} Source: {}", Event, ID)); | ||||||
| 					} | 					} | ||||||
| 				} | 				} | ||||||
| 			} else { | 			} else { | ||||||
| 				std::ostringstream os; | 				poco_error(logger(), "Bad bus message."); | ||||||
| 				Object->stringify(std::cout); |  | ||||||
| 				poco_error(BusLogger, fmt::format("Bad bus message: {}", os.str())); |  | ||||||
| 			} | 			} | ||||||
|  |  | ||||||
| 			auto ServiceHint = Services_.begin(); | 			auto i = Services_.begin(); | ||||||
| 			auto now = Utils::Now(); | 			auto now = Utils::Now(); | ||||||
|             auto si1 = Services_.size(); | 			for (; i != Services_.end();) { | ||||||
|             auto ss1 = MakeServiceListString(Services_); | 				if ((now - i->second.LastUpdate) > 60) { | ||||||
| 			while(ServiceHint!=Services_.end()) { | 					i = Services_.erase(i); | ||||||
| 				if ((now - ServiceHint->second.LastUpdate) > 120) { |  | ||||||
| 					poco_information(BusLogger, fmt::format("ZombieService: Removing service {}, ", ServiceHint->second.PublicEndPoint)); |  | ||||||
| 					ServiceHint = Services_.erase(ServiceHint); |  | ||||||
| 				} else | 				} else | ||||||
| 					++ServiceHint; | 					++i; | ||||||
| 			} |  | ||||||
|             if(Services_.size() != si1) { |  | ||||||
|                 auto ss2 = MakeServiceListString(Services_); |  | ||||||
|                 poco_information(BusLogger, fmt::format("Current list of microservices: {} -> {}", ss1, ss2)); |  | ||||||
| 			} | 			} | ||||||
|  |  | ||||||
| 		} catch (const Poco::Exception &E) { | 		} catch (const Poco::Exception &E) { | ||||||
| 			BusLogger.log(E); | 			logger().log(E); | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| @@ -206,11 +165,9 @@ namespace OpenWifi { | |||||||
| 			Res.push_back(ServiceRec); | 			Res.push_back(ServiceRec); | ||||||
| 		} | 		} | ||||||
| 		return Res; | 		return Res; | ||||||
|  |  | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	void MicroService::LoadConfigurationFile() { | 	void MicroService::LoadConfigurationFile() { | ||||||
|         if(ConfigContent_.empty()) { |  | ||||||
| 		std::string Location = Poco::Environment::get(DAEMON_CONFIG_ENV_VAR, "."); | 		std::string Location = Poco::Environment::get(DAEMON_CONFIG_ENV_VAR, "."); | ||||||
| 		ConfigFileName_ = | 		ConfigFileName_ = | ||||||
| 			ConfigFileName_.empty() ? Location + "/" + DAEMON_PROPERTIES_FILENAME : ConfigFileName_; | 			ConfigFileName_.empty() ? Location + "/" + DAEMON_PROPERTIES_FILENAME : ConfigFileName_; | ||||||
| @@ -224,11 +181,9 @@ namespace OpenWifi { | |||||||
| 					  << std::endl; | 					  << std::endl; | ||||||
| 			std::exit(Poco::Util::Application::EXIT_CONFIG); | 			std::exit(Poco::Util::Application::EXIT_CONFIG); | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
|  | 		// 	    loadConfiguration(ConfigFile.toString()); | ||||||
| 		PropConfigurationFile_ = new Poco::Util::PropertyFileConfiguration(ConfigFile.toString()); | 		PropConfigurationFile_ = new Poco::Util::PropertyFileConfiguration(ConfigFile.toString()); | ||||||
|         } else { |  | ||||||
|             std::istringstream is(ConfigContent_); |  | ||||||
|             PropConfigurationFile_ = new Poco::Util::PropertyFileConfiguration(is); |  | ||||||
|         } |  | ||||||
| 		configPtr()->addWriteable(PropConfigurationFile_, PRIO_DEFAULT); | 		configPtr()->addWriteable(PropConfigurationFile_, PRIO_DEFAULT); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| @@ -431,13 +386,11 @@ namespace OpenWifi { | |||||||
|  |  | ||||||
| 	void DaemonPostInitialization(Poco::Util::Application &self); | 	void DaemonPostInitialization(Poco::Util::Application &self); | ||||||
|  |  | ||||||
|     void MicroService::StartEverything(Poco::Util::Application &self) { | 	void MicroService::initialize(Poco::Util::Application &self) { | ||||||
|  | 		// add the default services | ||||||
| 		LoadConfigurationFile(); | 		LoadConfigurationFile(); | ||||||
| 		InitializeLoggingSystem(); | 		InitializeLoggingSystem(); | ||||||
|  |  | ||||||
|         static bool InitializedBaseService=false; |  | ||||||
|         if(!InitializedBaseService) { |  | ||||||
|             InitializedBaseService = true; |  | ||||||
| 		SubSystems_.push_back(KafkaManager()); | 		SubSystems_.push_back(KafkaManager()); | ||||||
| 		SubSystems_.push_back(ALBHealthCheckServer()); | 		SubSystems_.push_back(ALBHealthCheckServer()); | ||||||
| 		SubSystems_.push_back(RESTAPI_ExtServer()); | 		SubSystems_.push_back(RESTAPI_ExtServer()); | ||||||
| @@ -445,13 +398,11 @@ namespace OpenWifi { | |||||||
| #ifndef TIP_SECURITY_SERVICE | #ifndef TIP_SECURITY_SERVICE | ||||||
| 		SubSystems_.push_back(AuthClient()); | 		SubSystems_.push_back(AuthClient()); | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| 		Poco::Net::initializeSSL(); | 		Poco::Net::initializeSSL(); | ||||||
| 		Poco::Net::HTTPStreamFactory::registerFactory(); | 		Poco::Net::HTTPStreamFactory::registerFactory(); | ||||||
| 		Poco::Net::HTTPSStreamFactory::registerFactory(); | 		Poco::Net::HTTPSStreamFactory::registerFactory(); | ||||||
| 		Poco::Net::FTPStreamFactory::registerFactory(); | 		Poco::Net::FTPStreamFactory::registerFactory(); | ||||||
| 		Poco::Net::FTPSStreamFactory::registerFactory(); | 		Poco::Net::FTPSStreamFactory::registerFactory(); | ||||||
|         } |  | ||||||
|  |  | ||||||
| 		Poco::File DataDir(ConfigPath("openwifi.system.data")); | 		Poco::File DataDir(ConfigPath("openwifi.system.data")); | ||||||
| 		DataDir_ = DataDir.path(); | 		DataDir_ = DataDir.path(); | ||||||
| @@ -459,7 +410,7 @@ namespace OpenWifi { | |||||||
| 			try { | 			try { | ||||||
| 				DataDir.createDirectory(); | 				DataDir.createDirectory(); | ||||||
| 			} catch (const Poco::Exception &E) { | 			} catch (const Poco::Exception &E) { | ||||||
|                 Logger_.log(E); | 				logger().log(E); | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| 		WWWAssetsDir_ = ConfigPath("openwifi.restapi.wwwassets", ""); | 		WWWAssetsDir_ = ConfigPath("openwifi.restapi.wwwassets", ""); | ||||||
| @@ -480,12 +431,6 @@ namespace OpenWifi { | |||||||
| 		KafkaManager()->RegisterTopicWatcher(KafkaTopics::SERVICE_EVENTS, F); | 		KafkaManager()->RegisterTopicWatcher(KafkaTopics::SERVICE_EVENTS, F); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	void MicroService::initialize([[maybe_unused]] Poco::Util::Application &self) { |  | ||||||
| #ifndef USE_MEDUSA_CLIENT |  | ||||||
|         StartEverything(self); |  | ||||||
| #endif |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	void MicroService::uninitialize() { | 	void MicroService::uninitialize() { | ||||||
| 		// add your own uninitialization code here | 		// add your own uninitialization code here | ||||||
| 		ServerApplication::uninitialize(); | 		ServerApplication::uninitialize(); | ||||||
| @@ -583,12 +528,14 @@ namespace OpenWifi { | |||||||
| 		for (auto i : SubSystems_) { | 		for (auto i : SubSystems_) { | ||||||
| 			i->Start(); | 			i->Start(); | ||||||
| 		} | 		} | ||||||
| 		EventBusManager()->Start(); | 		EventBusManager_ = std::make_unique<EventBusManager>(Poco::Logger::create( | ||||||
|  | 			"EventBusManager", Poco::Logger::root().getChannel(), Poco::Logger::root().getLevel())); | ||||||
|  | 		EventBusManager_->Start(); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	void MicroService::StopSubSystemServers() { | 	void MicroService::StopSubSystemServers() { | ||||||
| 		AddActivity("Stopping"); | 		AddActivity("Stopping"); | ||||||
| 		EventBusManager()->Stop(); | 		EventBusManager_->Stop(); | ||||||
| 		for (auto i = SubSystems_.rbegin(); i != SubSystems_.rend(); ++i) { | 		for (auto i = SubSystems_.rbegin(); i != SubSystems_.rend(); ++i) { | ||||||
| 			(*i)->Stop(); | 			(*i)->Stop(); | ||||||
| 		} | 		} | ||||||
| @@ -748,7 +695,7 @@ namespace OpenWifi { | |||||||
| 			auto APIKEY = Request.get("X-API-KEY"); | 			auto APIKEY = Request.get("X-API-KEY"); | ||||||
| 			return APIKEY == MyHash_; | 			return APIKEY == MyHash_; | ||||||
| 		} catch (const Poco::Exception &E) { | 		} catch (const Poco::Exception &E) { | ||||||
| 			Logger_.log(E); | 			logger().log(E); | ||||||
| 		} | 		} | ||||||
| 		return false; | 		return false; | ||||||
| 	} | 	} | ||||||
| @@ -769,8 +716,6 @@ namespace OpenWifi { | |||||||
| 		MicroServiceErrorHandler ErrorHandler(*this); | 		MicroServiceErrorHandler ErrorHandler(*this); | ||||||
| 		Poco::ErrorHandler::set(&ErrorHandler); | 		Poco::ErrorHandler::set(&ErrorHandler); | ||||||
|  |  | ||||||
|         Args_ = args; |  | ||||||
|  |  | ||||||
| 		if (!HelpRequested_) { | 		if (!HelpRequested_) { | ||||||
| 			SavePID(); | 			SavePID(); | ||||||
|  |  | ||||||
| @@ -786,18 +731,11 @@ namespace OpenWifi { | |||||||
| 				poco_information(logger, "Starting as a daemon."); | 				poco_information(logger, "Starting as a daemon."); | ||||||
| 			} | 			} | ||||||
|  |  | ||||||
| #ifdef USE_MEDUSA_CLIENT |  | ||||||
|             MedusaClient::instance()->SetSubSystems(SubSystems_); |  | ||||||
|             MedusaClient::instance()->Start(); |  | ||||||
| 			waitForTerminationRequest(); |  | ||||||
|             MedusaClient::instance()->Stop(); |  | ||||||
| #else |  | ||||||
| 			poco_information(logger, fmt::format("System ID set to {}", ID_)); | 			poco_information(logger, fmt::format("System ID set to {}", ID_)); | ||||||
| 			StartSubSystemServers(); | 			StartSubSystemServers(); | ||||||
| 			waitForTerminationRequest(); | 			waitForTerminationRequest(); | ||||||
| 			StopSubSystemServers(); | 			StopSubSystemServers(); | ||||||
| 			logger.notice(fmt::format("Stopped {}...", DAEMON_APP_NAME)); | 			logger.notice(fmt::format("Stopped {}...", DAEMON_APP_NAME)); | ||||||
| #endif |  | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		return Application::EXIT_OK; | 		return Application::EXIT_OK; | ||||||
|   | |||||||
| @@ -55,6 +55,9 @@ namespace OpenWifi { | |||||||
| #include "nlohmann/json.hpp" | #include "nlohmann/json.hpp" | ||||||
| #include "ow_version.h" | #include "ow_version.h" | ||||||
|  |  | ||||||
|  | #define _OWDEBUG_ std::cout << __FILE__ << ":" << __LINE__ << std::endl; | ||||||
|  | // #define _OWDEBUG_ Logger().debug(Poco::format("%s: %lu",__FILE__,__LINE__)); | ||||||
|  |  | ||||||
| namespace OpenWifi { | namespace OpenWifi { | ||||||
|  |  | ||||||
| 	class MicroService : public Poco::Util::ServerApplication { | 	class MicroService : public Poco::Util::ServerApplication { | ||||||
| @@ -67,6 +70,7 @@ namespace OpenWifi { | |||||||
| 			  SubSystems_(std::move(Subsystems)), Logger_(Poco::Logger::get("FRAMEWORK")) { | 			  SubSystems_(std::move(Subsystems)), Logger_(Poco::Logger::get("FRAMEWORK")) { | ||||||
| 			instance_ = this; | 			instance_ = this; | ||||||
| 			RandomEngine_.seed(std::chrono::steady_clock::now().time_since_epoch().count()); | 			RandomEngine_.seed(std::chrono::steady_clock::now().time_since_epoch().count()); | ||||||
|  | 			// Logger_ = Poco::Logger::root().get("BASE-SVC"); | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		inline static const char *ExtraConfigurationFilename = "/configuration_override.json"; | 		inline static const char *ExtraConfigurationFilename = "/configuration_override.json"; | ||||||
| @@ -88,7 +92,7 @@ namespace OpenWifi { | |||||||
| 		inline uint64_t DaemonBusTimer() const { return DAEMON_BUS_TIMER; }; | 		inline uint64_t DaemonBusTimer() const { return DAEMON_BUS_TIMER; }; | ||||||
| 		[[nodiscard]] const std::string &AppName() { return DAEMON_APP_NAME; } | 		[[nodiscard]] const std::string &AppName() { return DAEMON_APP_NAME; } | ||||||
| 		static inline uint64_t GetPID() { return Poco::Process::id(); }; | 		static inline uint64_t GetPID() { return Poco::Process::id(); }; | ||||||
| 		[[nodiscard]] inline std::string GetPublicAPIEndPoint() const { | 		[[nodiscard]] inline const std::string GetPublicAPIEndPoint() { | ||||||
| 			return MyPublicEndPoint_ + "/api/v1"; | 			return MyPublicEndPoint_ + "/api/v1"; | ||||||
| 		}; | 		}; | ||||||
| 		[[nodiscard]] inline const std::string &GetUIURI() const { return UIURI_; }; | 		[[nodiscard]] inline const std::string &GetUIURI() const { return UIURI_; }; | ||||||
| @@ -103,8 +107,7 @@ namespace OpenWifi { | |||||||
| 		} | 		} | ||||||
| 		static MicroService &instance() { return *instance_; } | 		static MicroService &instance() { return *instance_; } | ||||||
|  |  | ||||||
| 		inline void Exit(int Reason) { std::exit(Reason); } | 		inline void Exit(int Reason); | ||||||
|  |  | ||||||
| 		void BusMessageReceived(const std::string &Key, const std::string &Payload); | 		void BusMessageReceived(const std::string &Key, const std::string &Payload); | ||||||
| 		Types::MicroServiceMetaVec GetServices(const std::string &Type); | 		Types::MicroServiceMetaVec GetServices(const std::string &Type); | ||||||
| 		Types::MicroServiceMetaVec GetServices(); | 		Types::MicroServiceMetaVec GetServices(); | ||||||
| @@ -112,7 +115,6 @@ namespace OpenWifi { | |||||||
| 		void Reload(); | 		void Reload(); | ||||||
| 		void LoadMyConfig(); | 		void LoadMyConfig(); | ||||||
| 		void initialize(Poco::Util::Application &self) override; | 		void initialize(Poco::Util::Application &self) override; | ||||||
|         void StartEverything(Poco::Util::Application &self); |  | ||||||
| 		void uninitialize() override; | 		void uninitialize() override; | ||||||
| 		void reinitialize(Poco::Util::Application &self) override; | 		void reinitialize(Poco::Util::Application &self) override; | ||||||
| 		void defineOptions(Poco::Util::OptionSet &options) override; | 		void defineOptions(Poco::Util::OptionSet &options) override; | ||||||
| @@ -130,7 +132,7 @@ namespace OpenWifi { | |||||||
| 		void Reload(const std::string &Sub); | 		void Reload(const std::string &Sub); | ||||||
| 		Types::StringVec GetSubSystems() const; | 		Types::StringVec GetSubSystems() const; | ||||||
| 		Types::StringPairVec GetLogLevels(); | 		Types::StringPairVec GetLogLevels(); | ||||||
| 		static const Types::StringVec &GetLogLevelNames(); | 		const Types::StringVec &GetLogLevelNames(); | ||||||
| 		uint64_t ConfigGetInt(const std::string &Key, uint64_t Default); | 		uint64_t ConfigGetInt(const std::string &Key, uint64_t Default); | ||||||
| 		uint64_t ConfigGetInt(const std::string &Key); | 		uint64_t ConfigGetInt(const std::string &Key); | ||||||
| 		uint64_t ConfigGetBool(const std::string &Key, bool Default); | 		uint64_t ConfigGetBool(const std::string &Key, bool Default); | ||||||
| @@ -164,16 +166,12 @@ namespace OpenWifi { | |||||||
| 								const std::string &FormatterPattern, | 								const std::string &FormatterPattern, | ||||||
| 								const std::string &root_env_var); | 								const std::string &root_env_var); | ||||||
| 		inline bool AllowExternalMicroServices() const { return AllowExternalMicroServices_; } | 		inline bool AllowExternalMicroServices() const { return AllowExternalMicroServices_; } | ||||||
|         const ArgVec &Args() const { return Args_; } |  | ||||||
|  |  | ||||||
|         inline void SetConfigContent(const std::string &Content) { ConfigContent_ = Content; } |  | ||||||
|  |  | ||||||
| 	  private: | 	  private: | ||||||
| 		static MicroService *instance_; | 		static MicroService *instance_; | ||||||
| 		bool HelpRequested_ = false; | 		bool HelpRequested_ = false; | ||||||
| 		std::string LogDir_; | 		std::string LogDir_; | ||||||
| 		std::string ConfigFileName_; | 		std::string ConfigFileName_; | ||||||
|         std::string ConfigContent_; |  | ||||||
| 		uint64_t ID_ = 1; | 		uint64_t ID_ = 1; | ||||||
| 		Poco::SharedPtr<Poco::Crypto::RSAKey> AppKey_; | 		Poco::SharedPtr<Poco::Crypto::RSAKey> AppKey_; | ||||||
| 		bool DebugMode_ = false; | 		bool DebugMode_ = false; | ||||||
| @@ -203,7 +201,7 @@ namespace OpenWifi { | |||||||
| 		Poco::JWT::Signer Signer_; | 		Poco::JWT::Signer Signer_; | ||||||
| 		Poco::Logger &Logger_; | 		Poco::Logger &Logger_; | ||||||
| 		Poco::ThreadPool TimerPool_{"timer:pool", 2, 32}; | 		Poco::ThreadPool TimerPool_{"timer:pool", 2, 32}; | ||||||
|         ArgVec Args_; | 		std::unique_ptr<EventBusManager> EventBusManager_; | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| 	inline MicroService *MicroService::instance_ = nullptr; | 	inline MicroService *MicroService::instance_ = nullptr; | ||||||
|   | |||||||
| @@ -5,8 +5,6 @@ | |||||||
| #include "framework/MicroServiceFuncs.h" | #include "framework/MicroServiceFuncs.h" | ||||||
| #include "framework/MicroService.h" | #include "framework/MicroService.h" | ||||||
|  |  | ||||||
| #include "framework/ALBserver.h" |  | ||||||
|  |  | ||||||
| namespace OpenWifi { | namespace OpenWifi { | ||||||
| 	const std::string &MicroServiceDataDirectory() { return MicroService::instance().DataDir(); } | 	const std::string &MicroServiceDataDirectory() { return MicroService::instance().DataDir(); } | ||||||
|  |  | ||||||
| @@ -125,12 +123,4 @@ namespace OpenWifi { | |||||||
| 		return MicroService::instance().AllowExternalMicroServices(); | 		return MicroService::instance().AllowExternalMicroServices(); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	void MicroServiceALBCallback( std::string Callback()) { |  | ||||||
| 		return ALBHealthCheckServer()->RegisterExtendedHealthMessage(Callback); |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	std::string MicroServiceAccessKey() { |  | ||||||
| 		return MicroService::instance().Hash(); |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| } // namespace OpenWifi | } // namespace OpenWifi | ||||||
|   | |||||||
| @@ -22,7 +22,6 @@ namespace OpenWifi { | |||||||
| 	std::string MicroServicePublicEndPoint(); | 	std::string MicroServicePublicEndPoint(); | ||||||
| 	std::string MicroServiceConfigGetString(const std::string &Key, | 	std::string MicroServiceConfigGetString(const std::string &Key, | ||||||
| 											const std::string &DefaultValue); | 											const std::string &DefaultValue); | ||||||
| 	std::string MicroServiceAccessKey(); |  | ||||||
| 	bool MicroServiceConfigGetBool(const std::string &Key, bool DefaultValue); | 	bool MicroServiceConfigGetBool(const std::string &Key, bool DefaultValue); | ||||||
| 	std::uint64_t MicroServiceConfigGetInt(const std::string &Key, std::uint64_t DefaultValue); | 	std::uint64_t MicroServiceConfigGetInt(const std::string &Key, std::uint64_t DefaultValue); | ||||||
| 	std::string MicroServicePrivateEndPoint(); | 	std::string MicroServicePrivateEndPoint(); | ||||||
| @@ -54,5 +53,4 @@ namespace OpenWifi { | |||||||
| 	std::string MicroServiceGetPublicAPIEndPoint(); | 	std::string MicroServiceGetPublicAPIEndPoint(); | ||||||
| 	void MicroServiceDeleteOverrideConfiguration(); | 	void MicroServiceDeleteOverrideConfiguration(); | ||||||
| 	bool AllowExternalMicroServices(); | 	bool AllowExternalMicroServices(); | ||||||
| 	void MicroServiceALBCallback( std::string Callback()); |  | ||||||
| } // namespace OpenWifi | } // namespace OpenWifi | ||||||
|   | |||||||
| @@ -28,9 +28,6 @@ namespace OpenWifi::Types { | |||||||
| 	typedef std::string UUID_t; | 	typedef std::string UUID_t; | ||||||
| 	typedef std::vector<UUID_t> UUIDvec_t; | 	typedef std::vector<UUID_t> UUIDvec_t; | ||||||
| 	typedef std::map<std::string, std::map<uint32_t, uint64_t>> Counted3DMapSII; | 	typedef std::map<std::string, std::map<uint32_t, uint64_t>> Counted3DMapSII; | ||||||
| 	typedef std::vector<int64_t> IntList; |  | ||||||
| 	typedef std::vector<uint64_t> UIntList; |  | ||||||
| 	typedef std::vector<double> DoubleList; |  | ||||||
|  |  | ||||||
| 	struct MicroServiceMeta { | 	struct MicroServiceMeta { | ||||||
| 		uint64_t Id = 0; | 		uint64_t Id = 0; | ||||||
|   | |||||||
| @@ -574,36 +574,6 @@ namespace OpenWifi { | |||||||
| 			Poco::JSON::Stringifier::stringify(Object, Answer); | 			Poco::JSON::Stringifier::stringify(Object, Answer); | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
|         inline void ReturnObject(const std::vector<std::string> &Strings) { |  | ||||||
|             Poco::JSON::Array   Arr; |  | ||||||
|             for(const auto &String:Strings) { |  | ||||||
|                 Arr.add(String); |  | ||||||
|             } |  | ||||||
|             std::ostringstream os; |  | ||||||
|             Arr.stringify(os); |  | ||||||
|             return ReturnRawJSON(os.str()); |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         template<class T> void ReturnObject(const std::vector<T> &Objects) { |  | ||||||
|             Poco::JSON::Array   Arr; |  | ||||||
|             for(const auto &Object:Objects) { |  | ||||||
|                 Poco::JSON::Object O; |  | ||||||
|                 Object.to_json(O); |  | ||||||
|                 Arr.add(O); |  | ||||||
|             } |  | ||||||
|             std::ostringstream os; |  | ||||||
|             Arr.stringify(os); |  | ||||||
|             return ReturnRawJSON(os.str()); |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         template<class T> void ReturnObject(const T &Object) { |  | ||||||
|             Poco::JSON::Object  O; |  | ||||||
|             Object.to_json(O); |  | ||||||
|             std::ostringstream os; |  | ||||||
|             O.stringify(os); |  | ||||||
|             return ReturnRawJSON(os.str()); |  | ||||||
|         } |  | ||||||
|  |  | ||||||
| 		inline void ReturnRawJSON(const std::string &json_doc) { | 		inline void ReturnRawJSON(const std::string &json_doc) { | ||||||
| 			PrepareResponse(); | 			PrepareResponse(); | ||||||
| 			if (Request != nullptr) { | 			if (Request != nullptr) { | ||||||
|   | |||||||
| @@ -24,10 +24,9 @@ namespace OpenWifi { | |||||||
| 							 Server, TransactionId, Internal) {} | 							 Server, TransactionId, Internal) {} | ||||||
| 		static auto PathName() { return std::list<std::string>{"/api/v1/system"}; } | 		static auto PathName() { return std::list<std::string>{"/api/v1/system"}; } | ||||||
|  |  | ||||||
| 		inline void DoGet() final { | 		inline void DoGet() { | ||||||
| 			std::string Arg; | 			std::string Arg; | ||||||
| 			if (HasParameter("command", Arg)) { | 			if (HasParameter("command", Arg) && Arg == "info") { | ||||||
| 				if (Arg == "info") { |  | ||||||
| 				Poco::JSON::Object Answer; | 				Poco::JSON::Object Answer; | ||||||
| 				Answer.set(RESTAPI::Protocol::VERSION, MicroServiceVersion()); | 				Answer.set(RESTAPI::Protocol::VERSION, MicroServiceVersion()); | ||||||
| 				Answer.set(RESTAPI::Protocol::UPTIME, MicroServiceUptimeTotalSeconds()); | 				Answer.set(RESTAPI::Protocol::UPTIME, MicroServiceUptimeTotalSeconds()); | ||||||
| @@ -65,23 +64,11 @@ namespace OpenWifi { | |||||||
| 				Answer.set("certificates", Certificates); | 				Answer.set("certificates", Certificates); | ||||||
| 				return ReturnObject(Answer); | 				return ReturnObject(Answer); | ||||||
| 			} | 			} | ||||||
| 				if (Arg == "extraConfiguration") { | 			if (GetBoolParameter("extraConfiguration")) { | ||||||
| 				Poco::JSON::Object Answer; | 				Poco::JSON::Object Answer; | ||||||
| 				MicroServiceGetExtraConfiguration(Answer); | 				MicroServiceGetExtraConfiguration(Answer); | ||||||
| 				return ReturnObject(Answer); | 				return ReturnObject(Answer); | ||||||
| 			} | 			} | ||||||
| 				if (Arg == "resources") { |  | ||||||
| 					Poco::JSON::Object Answer; |  | ||||||
| 					Answer.set("numberOfFileDescriptors", Utils::get_open_fds()); |  | ||||||
| 					std::uint64_t currRealMem, peakRealMem, currVirtMem, peakVirtMem; |  | ||||||
| 					Utils::getMemory(currRealMem, peakRealMem, currVirtMem, peakVirtMem); |  | ||||||
| 					Answer.set("currRealMem", currRealMem); |  | ||||||
| 					Answer.set("peakRealMem", peakRealMem); |  | ||||||
| 					Answer.set("currVirtMem", currVirtMem); |  | ||||||
| 					Answer.set("peakVirtMem", peakVirtMem); |  | ||||||
| 					return ReturnObject(Answer); |  | ||||||
| 				} |  | ||||||
| 			} |  | ||||||
| 			BadRequest(RESTAPI::Errors::InvalidCommand); | 			BadRequest(RESTAPI::Errors::InvalidCommand); | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
|   | |||||||
| @@ -102,20 +102,6 @@ namespace OpenWifi::RESTAPI_utils { | |||||||
| 		Obj.set(Field, A); | 		Obj.set(Field, A); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	inline void field_to_json(Poco::JSON::Object &Obj, const char *Field, const Types::DoubleList &V) { |  | ||||||
| 		Poco::JSON::Array A; |  | ||||||
| 		for (const auto &i : V) |  | ||||||
| 			A.add(i); |  | ||||||
| 		Obj.set(Field, A); |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	inline void field_to_json(Poco::JSON::Object &Obj, const char *Field, const Types::IntList &V) { |  | ||||||
| 		Poco::JSON::Array A; |  | ||||||
| 		for (const auto &i : V) |  | ||||||
| 			A.add(i); |  | ||||||
| 		Obj.set(Field, A); |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	inline void field_to_json(Poco::JSON::Object &Obj, const char *Field, const Types::TagList &V) { | 	inline void field_to_json(Poco::JSON::Object &Obj, const char *Field, const Types::TagList &V) { | ||||||
| 		Poco::JSON::Array A; | 		Poco::JSON::Array A; | ||||||
| 		for (const auto &i : V) | 		for (const auto &i : V) | ||||||
| @@ -298,28 +284,6 @@ namespace OpenWifi::RESTAPI_utils { | |||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	inline void field_from_json(const Poco::JSON::Object::Ptr &Obj, const char *Field, |  | ||||||
| 								Types::DoubleList &Value) { |  | ||||||
| 		if (Obj->isArray(Field) && !Obj->isNull(Field)) { |  | ||||||
| 			Value.clear(); |  | ||||||
| 			Poco::JSON::Array::Ptr A = Obj->getArray(Field); |  | ||||||
| 			for (const auto &i : *A) { |  | ||||||
| 				Value.push_back(i); |  | ||||||
| 			} |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	inline void field_from_json(const Poco::JSON::Object::Ptr &Obj, const char *Field, |  | ||||||
| 								Types::IntList &Value) { |  | ||||||
| 		if (Obj->isArray(Field) && !Obj->isNull(Field)) { |  | ||||||
| 			Value.clear(); |  | ||||||
| 			Poco::JSON::Array::Ptr A = Obj->getArray(Field); |  | ||||||
| 			for (const auto &i : *A) { |  | ||||||
| 				Value.push_back(i); |  | ||||||
| 			} |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	template <class T> | 	template <class T> | ||||||
| 	void field_from_json(const Poco::JSON::Object::Ptr &Obj, const char *Field, | 	void field_from_json(const Poco::JSON::Object::Ptr &Obj, const char *Field, | ||||||
| 						 std::vector<T> &Value) { | 						 std::vector<T> &Value) { | ||||||
|   | |||||||
| @@ -22,8 +22,9 @@ namespace OpenWifi { | |||||||
|  |  | ||||||
| 	class StorageClass : public SubSystemServer { | 	class StorageClass : public SubSystemServer { | ||||||
| 	  public: | 	  public: | ||||||
|  | 		StorageClass() noexcept : SubSystemServer("StorageClass", "STORAGE-SVR", "storage") {} | ||||||
|  |  | ||||||
|         inline int Start() override { | 		int Start() override { | ||||||
| 			std::lock_guard Guard(Mutex_); | 			std::lock_guard Guard(Mutex_); | ||||||
|  |  | ||||||
| 			Logger().notice("Starting."); | 			Logger().notice("Starting."); | ||||||
| @@ -39,24 +40,17 @@ namespace OpenWifi { | |||||||
| 			return 0; | 			return 0; | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		inline void Stop() override { Pool_->shutdown(); } | 		void Stop() override { Pool_->shutdown(); } | ||||||
|  |  | ||||||
| 		DBType Type() const { return dbType_; }; | 		DBType Type() const { return dbType_; }; | ||||||
|  |  | ||||||
|         StorageClass() noexcept : SubSystemServer("StorageClass", "STORAGE-SVR", "storage") { |  | ||||||
|  |  | ||||||
|         } |  | ||||||
|  |  | ||||||
| 		Poco::Data::SessionPool &Pool() { return *Pool_; } |  | ||||||
|  |  | ||||||
| 	  private: | 	  private: | ||||||
| 		inline int Setup_SQLite(); | 		inline int Setup_SQLite(); | ||||||
| 		inline int Setup_MySQL(); | 		inline int Setup_MySQL(); | ||||||
| 		inline int Setup_PostgreSQL(); | 		inline int Setup_PostgreSQL(); | ||||||
|  |  | ||||||
|  |  | ||||||
| 	  protected: | 	  protected: | ||||||
| 		std::shared_ptr<Poco::Data::SessionPool> Pool_; | 		std::unique_ptr<Poco::Data::SessionPool> Pool_; | ||||||
| 		Poco::Data::SQLite::Connector SQLiteConn_; | 		Poco::Data::SQLite::Connector SQLiteConn_; | ||||||
| 		Poco::Data::PostgreSQL::Connector PostgresConn_; | 		Poco::Data::PostgreSQL::Connector PostgresConn_; | ||||||
| 		Poco::Data::MySQL::Connector MySQLConn_; | 		Poco::Data::MySQL::Connector MySQLConn_; | ||||||
| @@ -87,7 +81,7 @@ namespace OpenWifi { | |||||||
| 		//        Poco::Data::SessionPool(SQLiteConn_.name(), DBName, 8, | 		//        Poco::Data::SessionPool(SQLiteConn_.name(), DBName, 8, | ||||||
| 		//                                                                                     (int)NumSessions, | 		//                                                                                     (int)NumSessions, | ||||||
| 		//                                                                                     (int)IdleTime)); | 		//                                                                                     (int)IdleTime)); | ||||||
| 		Pool_ = std::make_shared<Poco::Data::SessionPool>(SQLiteConn_.name(), DBName, 8, | 		Pool_ = std::make_unique<Poco::Data::SessionPool>(SQLiteConn_.name(), DBName, 8, | ||||||
| 														  (int)NumSessions, (int)IdleTime); | 														  (int)NumSessions, (int)IdleTime); | ||||||
| 		return 0; | 		return 0; | ||||||
| 	} | 	} | ||||||
| @@ -108,7 +102,7 @@ namespace OpenWifi { | |||||||
| 									";compress=true;auto-reconnect=true"; | 									";compress=true;auto-reconnect=true"; | ||||||
|  |  | ||||||
| 		Poco::Data::MySQL::Connector::registerConnector(); | 		Poco::Data::MySQL::Connector::registerConnector(); | ||||||
| 		Pool_ = std::make_shared<Poco::Data::SessionPool>(MySQLConn_.name(), ConnectionStr, 8, | 		Pool_ = std::make_unique<Poco::Data::SessionPool>(MySQLConn_.name(), ConnectionStr, 8, | ||||||
| 														  NumSessions, IdleTime); | 														  NumSessions, IdleTime); | ||||||
|  |  | ||||||
| 		return 0; | 		return 0; | ||||||
| @@ -132,7 +126,7 @@ namespace OpenWifi { | |||||||
| 									" connect_timeout=" + ConnectionTimeout; | 									" connect_timeout=" + ConnectionTimeout; | ||||||
|  |  | ||||||
| 		Poco::Data::PostgreSQL::Connector::registerConnector(); | 		Poco::Data::PostgreSQL::Connector::registerConnector(); | ||||||
| 		Pool_ = std::make_shared<Poco::Data::SessionPool>(PostgresConn_.name(), ConnectionStr, 8, | 		Pool_ = std::make_unique<Poco::Data::SessionPool>(PostgresConn_.name(), ConnectionStr, 8, | ||||||
| 														  NumSessions, IdleTime); | 														  NumSessions, IdleTime); | ||||||
|  |  | ||||||
| 		return 0; | 		return 0; | ||||||
|   | |||||||
| @@ -37,7 +37,6 @@ namespace OpenWifi { | |||||||
| 		P.cipherList = "ALL:!ADH:!LOW:!EXP:!MD5:@STRENGTH"; | 		P.cipherList = "ALL:!ADH:!LOW:!EXP:!MD5:@STRENGTH"; | ||||||
| 		P.dhUse2048Bits = true; | 		P.dhUse2048Bits = true; | ||||||
| 		P.caLocation = cas_; | 		P.caLocation = cas_; | ||||||
|         // P.securityLevel = |  | ||||||
|  |  | ||||||
| 		auto Context = Poco::AutoPtr<Poco::Net::Context>( | 		auto Context = Poco::AutoPtr<Poco::Net::Context>( | ||||||
| 			new Poco::Net::Context(Poco::Net::Context::TLS_SERVER_USE, P)); | 			new Poco::Net::Context(Poco::Net::Context::TLS_SERVER_USE, P)); | ||||||
| @@ -54,6 +53,7 @@ namespace OpenWifi { | |||||||
|  |  | ||||||
| 			Context->useCertificate(Cert); | 			Context->useCertificate(Cert); | ||||||
| 			Context->addChainCertificate(Root); | 			Context->addChainCertificate(Root); | ||||||
|  |  | ||||||
| 			Context->addCertificateAuthority(Root); | 			Context->addCertificateAuthority(Root); | ||||||
|  |  | ||||||
| 			if (level_ == Poco::Net::Context::VERIFY_STRICT) { | 			if (level_ == Poco::Net::Context::VERIFY_STRICT) { | ||||||
| @@ -76,18 +76,18 @@ namespace OpenWifi { | |||||||
| 				L.fatal(fmt::format("Wrong Certificate({}) for Key({})", cert_file_, key_file_)); | 				L.fatal(fmt::format("Wrong Certificate({}) for Key({})", cert_file_, key_file_)); | ||||||
| 			} | 			} | ||||||
|  |  | ||||||
|             SSL_CTX_set_verify(SSLCtx, level_==Poco::Net::Context::VERIFY_NONE ? SSL_VERIFY_NONE : SSL_VERIFY_PEER, nullptr); | 			SSL_CTX_set_verify(SSLCtx, SSL_VERIFY_PEER, nullptr); | ||||||
|  |  | ||||||
| 			if (level_ == Poco::Net::Context::VERIFY_STRICT) { | 			if (level_ == Poco::Net::Context::VERIFY_STRICT) { | ||||||
| 				SSL_CTX_set_client_CA_list(SSLCtx, SSL_load_client_CA_file(client_cas_.c_str())); | 				SSL_CTX_set_client_CA_list(SSLCtx, SSL_load_client_CA_file(client_cas_.c_str())); | ||||||
|                 SSL_CTX_enable_ct(SSLCtx, SSL_CT_VALIDATION_STRICT); |  | ||||||
| 			} | 			} | ||||||
|  | 			SSL_CTX_enable_ct(SSLCtx, SSL_CT_VALIDATION_STRICT); | ||||||
| 			SSL_CTX_dane_enable(SSLCtx); | 			SSL_CTX_dane_enable(SSLCtx); | ||||||
|  |  | ||||||
| 			Context->enableSessionCache(); | 			Context->enableSessionCache(); | ||||||
| 			Context->setSessionCacheSize(0); | 			Context->setSessionCacheSize(0); | ||||||
| 			Context->setSessionTimeout(60); | 			Context->setSessionTimeout(60); | ||||||
| 			Context->enableExtendedCertificateVerification( level_!= Poco::Net::Context::VERIFY_NONE ); | 			Context->enableExtendedCertificateVerification(true); | ||||||
| 			Context->disableStatelessSessionResumption(); | 			Context->disableStatelessSessionResumption(); | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
|   | |||||||
| @@ -58,9 +58,11 @@ namespace OpenWifi { | |||||||
| 	void UI_WebSocketClientServer::run() { | 	void UI_WebSocketClientServer::run() { | ||||||
| 		Running_ = true; | 		Running_ = true; | ||||||
| 		while (Running_) { | 		while (Running_) { | ||||||
| 			if(!Poco::Thread::trySleep(2000)) { | 			Poco::Thread::trySleep(2000); | ||||||
|  |  | ||||||
|  | 			if (!Running_) | ||||||
| 				break; | 				break; | ||||||
|             } |  | ||||||
| 			std::lock_guard G(LocalMutex_); | 			std::lock_guard G(LocalMutex_); | ||||||
| 			for (const auto i : ToBeRemoved_) { | 			for (const auto i : ToBeRemoved_) { | ||||||
| 				// std::cout << "Erasing old WS UI connection..." << std::endl; | 				// std::cout << "Erasing old WS UI connection..." << std::endl; | ||||||
|   | |||||||
| @@ -576,8 +576,8 @@ namespace ORM { | |||||||
| 		bool UpdateRecord(field_name_t FieldName, const T &Value, const RecordType &R) { | 		bool UpdateRecord(field_name_t FieldName, const T &Value, const RecordType &R) { | ||||||
| 			try { | 			try { | ||||||
| 				assert(ValidFieldName(FieldName)); | 				assert(ValidFieldName(FieldName)); | ||||||
|  |  | ||||||
| 				Poco::Data::Session Session = Pool_.get(); | 				Poco::Data::Session Session = Pool_.get(); | ||||||
|                 Session.begin(); |  | ||||||
| 				Poco::Data::Statement Update(Session); | 				Poco::Data::Statement Update(Session); | ||||||
|  |  | ||||||
| 				RecordTuple RT; | 				RecordTuple RT; | ||||||
| @@ -593,7 +593,6 @@ namespace ORM { | |||||||
| 				Update.execute(); | 				Update.execute(); | ||||||
| 				if (Cache_) | 				if (Cache_) | ||||||
| 					Cache_->UpdateCache(R); | 					Cache_->UpdateCache(R); | ||||||
|                 Session.commit(); |  | ||||||
| 				return true; | 				return true; | ||||||
| 			} catch (const Poco::Exception &E) { | 			} catch (const Poco::Exception &E) { | ||||||
| 				Logger_.log(E); | 				Logger_.log(E); | ||||||
| @@ -663,7 +662,6 @@ namespace ORM { | |||||||
| 				assert(ValidFieldName(FieldName)); | 				assert(ValidFieldName(FieldName)); | ||||||
|  |  | ||||||
| 				Poco::Data::Session Session = Pool_.get(); | 				Poco::Data::Session Session = Pool_.get(); | ||||||
|                 Session.begin(); |  | ||||||
| 				Poco::Data::Statement Delete(Session); | 				Poco::Data::Statement Delete(Session); | ||||||
|  |  | ||||||
| 				std::string St = "delete from " + TableName_ + " where " + FieldName + "=?"; | 				std::string St = "delete from " + TableName_ + " where " + FieldName + "=?"; | ||||||
| @@ -673,7 +671,6 @@ namespace ORM { | |||||||
| 				Delete.execute(); | 				Delete.execute(); | ||||||
| 				if (Cache_) | 				if (Cache_) | ||||||
| 					Cache_->Delete(FieldName, Value); | 					Cache_->Delete(FieldName, Value); | ||||||
|                 Session.commit(); |  | ||||||
| 				return true; | 				return true; | ||||||
| 			} catch (const Poco::Exception &E) { | 			} catch (const Poco::Exception &E) { | ||||||
| 				Logger_.log(E); | 				Logger_.log(E); | ||||||
| @@ -685,13 +682,11 @@ namespace ORM { | |||||||
| 			try { | 			try { | ||||||
| 				assert(!WhereClause.empty()); | 				assert(!WhereClause.empty()); | ||||||
| 				Poco::Data::Session Session = Pool_.get(); | 				Poco::Data::Session Session = Pool_.get(); | ||||||
|                 Session.begin(); |  | ||||||
| 				Poco::Data::Statement Delete(Session); | 				Poco::Data::Statement Delete(Session); | ||||||
|  |  | ||||||
| 				std::string St = "delete from " + TableName_ + " where " + WhereClause; | 				std::string St = "delete from " + TableName_ + " where " + WhereClause; | ||||||
| 				Delete << St; | 				Delete << St; | ||||||
| 				Delete.execute(); | 				Delete.execute(); | ||||||
|                 Session.commit(); |  | ||||||
| 				return true; | 				return true; | ||||||
| 			} catch (const Poco::Exception &E) { | 			} catch (const Poco::Exception &E) { | ||||||
| 				Logger_.log(E); | 				Logger_.log(E); | ||||||
|   | |||||||
| @@ -40,7 +40,6 @@ namespace OpenWifi { | |||||||
| 	}; | 	}; | ||||||
| } | } | ||||||
|  |  | ||||||
| #define DBGLINE     std::cout << __LINE__ << ":" << __FILE__ << ", " << __func__ << std::endl; |  | ||||||
| namespace OpenWifi::RESTAPI::Errors { | namespace OpenWifi::RESTAPI::Errors { | ||||||
| 	struct msg { | 	struct msg { | ||||||
| 		uint64_t err_num; | 		uint64_t err_num; | ||||||
| @@ -402,37 +401,6 @@ namespace OpenWifi::RESTAPI::Errors { | |||||||
| 		1171, "Command not supported on simulated device." | 		1171, "Command not supported on simulated device." | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
|     static const struct msg VenuesNameAlreadyExists { |  | ||||||
|             1172, "The venue name already exists." |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     static const struct msg InvalidGlobalReachAccount { |  | ||||||
|             1173, "Invalid Global Reach account information." |  | ||||||
|     }; |  | ||||||
|     static const struct msg CannotCreateCSR { |  | ||||||
|             1174, "Cannot create a CSR certificate." |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     static const struct msg DefFirmwareNameExists { 1175, "Firmware name already exists." }; |  | ||||||
|     static const struct msg NotAValidECKey { 1176, "Not a valid Signing Key." }; |  | ||||||
| 	static const struct msg NotAValidRadiusPoolType { 1177, "Not a valid RADIUS pool type." }; |  | ||||||
|     static const struct msg InvalidRadiusTypeEndpoint { 1178, "Invalid RADIUS Server Endpoint type." }; |  | ||||||
|     static const struct msg InvalidRadiusEndpointPoolStrategy { 1179, "Invalid RADIUS Server Endpoint Pool strategy." }; |  | ||||||
|     static const struct msg EndpointMustHaveOneTypeOfServers { 1180, "All servers must be either RADIUS or RADSEC." }; |  | ||||||
|     static const struct msg RadiusEndpointIndexInvalid { 1181, "Index must be an address between 0.0.1.1 and 0.0.2.254" }; |  | ||||||
|     static const struct msg RadiusEndpointIndexMustBeUnique { 1182, "Index must be unique." }; |  | ||||||
|     static const struct msg OrionAccountMustExist { 1183, "Orion account must exist." }; |  | ||||||
|     static const struct msg GlobalReachCertMustExist { 1184, "Global Reach certificate must exist." }; |  | ||||||
|     static const struct msg InvalidRadsecMainCertificate { 1185, "Invalid Radsec main certificate." }; |  | ||||||
|     static const struct msg InvalidRadsecCaCertificate { 1186, "Invalid Radsec CA certificates." }; |  | ||||||
|     static const struct msg InvalidRadsecPrivteKey { 1187, "Invalid Radsec Private key." }; |  | ||||||
|     static const struct msg InvalidRadsecIPAddress { 1188, "Invalid Radsec IP Address." }; |  | ||||||
|     static const struct msg InvalidRadsecPort { 1189, "Invalid Radsec Port." }; |  | ||||||
|     static const struct msg InvalidRadsecSecret { 1190, "Invalid Radsec Secret." }; |  | ||||||
|     static const struct msg InvalidRadiusServer { 1191, "Invalid Radius Server." }; |  | ||||||
|  |  | ||||||
| 	static const struct msg InvalidRRMAction { 1192, "Invalid RRM Action." }; |  | ||||||
|  |  | ||||||
|     static const struct msg SimulationDoesNotExist { |     static const struct msg SimulationDoesNotExist { | ||||||
|         7000, "Simulation Instance ID does not exist." |         7000, "Simulation Instance ID does not exist." | ||||||
|     }; |     }; | ||||||
| @@ -563,11 +531,6 @@ namespace OpenWifi::RESTAPI::Protocol { | |||||||
| 	static const char *CONTENTDISPOSITION = "Content-Disposition"; | 	static const char *CONTENTDISPOSITION = "Content-Disposition"; | ||||||
| 	static const char *CONTENTTYPE = "Content-Type"; | 	static const char *CONTENTTYPE = "Content-Type"; | ||||||
|  |  | ||||||
| 	static const char *TRANSFER = "transfer"; |  | ||||||
| 	static const char *CERTUPDATE = "certupdate"; |  | ||||||
| 	static const char *POWERCYCLE = "powercycle"; |  | ||||||
| 	static const char *RRM = "rrm"; |  | ||||||
|  |  | ||||||
| 	static const char *REQUIREMENTS = "requirements"; | 	static const char *REQUIREMENTS = "requirements"; | ||||||
| 	static const char *PASSWORDPATTERN = "passwordPattern"; | 	static const char *PASSWORDPATTERN = "passwordPattern"; | ||||||
| 	static const char *ACCESSPOLICY = "accessPolicy"; | 	static const char *ACCESSPOLICY = "accessPolicy"; | ||||||
| @@ -685,13 +648,6 @@ namespace OpenWifi::uCentralProtocol { | |||||||
| 	static const char *RADIUSCOA = "coa"; | 	static const char *RADIUSCOA = "coa"; | ||||||
| 	static const char *RADIUSDST = "dst"; | 	static const char *RADIUSDST = "dst"; | ||||||
| 	static const char *IES = "ies"; | 	static const char *IES = "ies"; | ||||||
|  |  | ||||||
| 	static const char *TRANSFER = "transfer"; |  | ||||||
| 	static const char *CERTUPDATE = "certupdate"; |  | ||||||
| 	static const char *POWERCYCLE = "powercycle"; |  | ||||||
| 	static const char *RRM = "rrm"; |  | ||||||
| 	static const char *ACTIONS = "actions"; |  | ||||||
|  |  | ||||||
| } // namespace OpenWifi::uCentralProtocol | } // namespace OpenWifi::uCentralProtocol | ||||||
|  |  | ||||||
| namespace OpenWifi::uCentralProtocol::Events { | namespace OpenWifi::uCentralProtocol::Events { | ||||||
| @@ -784,10 +740,6 @@ namespace OpenWifi::APCommands { | |||||||
| 		telemetry, | 		telemetry, | ||||||
| 		ping, | 		ping, | ||||||
| 		script, | 		script, | ||||||
| 		rrm, |  | ||||||
| 		certupdate, |  | ||||||
| 		transfer, |  | ||||||
| 		powercycle, |  | ||||||
| 		unknown | 		unknown | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| @@ -800,10 +752,7 @@ namespace OpenWifi::APCommands { | |||||||
| 		RESTAPI::Protocol::LEDS,		 RESTAPI::Protocol::TRACE, | 		RESTAPI::Protocol::LEDS,		 RESTAPI::Protocol::TRACE, | ||||||
| 		RESTAPI::Protocol::REQUEST,		 RESTAPI::Protocol::WIFISCAN, | 		RESTAPI::Protocol::REQUEST,		 RESTAPI::Protocol::WIFISCAN, | ||||||
| 		RESTAPI::Protocol::EVENTQUEUE,	 RESTAPI::Protocol::TELEMETRY, | 		RESTAPI::Protocol::EVENTQUEUE,	 RESTAPI::Protocol::TELEMETRY, | ||||||
| 		RESTAPI::Protocol::PING,		 RESTAPI::Protocol::SCRIPT, | 		RESTAPI::Protocol::PING,		 RESTAPI::Protocol::SCRIPT}; | ||||||
| 		RESTAPI::Protocol::RRM,		 	 RESTAPI::Protocol::CERTUPDATE, |  | ||||||
| 		RESTAPI::Protocol::TRANSFER,	 RESTAPI::Protocol::POWERCYCLE |  | ||||||
| 	}; |  | ||||||
|  |  | ||||||
| 	inline const char *to_string(Commands Cmd) { return uCentralAPCommands[(uint8_t)Cmd]; } | 	inline const char *to_string(Commands Cmd) { return uCentralAPCommands[(uint8_t)Cmd]; } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -3,19 +3,10 @@ | |||||||
| // | // | ||||||
|  |  | ||||||
| #include "Poco/Path.h" | #include "Poco/Path.h" | ||||||
| #include "Poco/TemporaryFile.h" |  | ||||||
| #include "Poco/Crypto/ECKey.h" |  | ||||||
| #include "framework/AppServiceRegistry.h" | #include "framework/AppServiceRegistry.h" | ||||||
| #include "framework/utils.h" | #include "framework/utils.h" | ||||||
|  |  | ||||||
| #include <iostream> |  | ||||||
| #include <cstdlib> |  | ||||||
| #include <ctime> |  | ||||||
| #include <string> |  | ||||||
| #include <algorithm> |  | ||||||
|  |  | ||||||
| #include <resolv.h> |  | ||||||
|  |  | ||||||
| namespace OpenWifi::Utils { | namespace OpenWifi::Utils { | ||||||
|  |  | ||||||
| 	bool NormalizeMac(std::string &Mac) { | 	bool NormalizeMac(std::string &Mac) { | ||||||
| @@ -141,15 +132,6 @@ namespace OpenWifi::Utils { | |||||||
| 		return std::regex_match(Hostname, HostNameRegex); | 		return std::regex_match(Hostname, HostNameRegex); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	[[nodiscard]] bool ValidNumber(const std::string &number, bool isSigned) |  | ||||||
| 	{ |  | ||||||
| 		static std::regex IntRegex("^-?[0-9]\\d*(\\.\\d+)?$"); |  | ||||||
| 		if(!isSigned) { |  | ||||||
| 			IntRegex = "^[0-9]\\d*(\\.\\d+)?$"; |  | ||||||
| 		} |  | ||||||
| 		return std::regex_match(number, IntRegex); |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	[[nodiscard]] std::string ToHex(const std::vector<unsigned char> &B) { | 	[[nodiscard]] std::string ToHex(const std::vector<unsigned char> &B) { | ||||||
| 		std::string R; | 		std::string R; | ||||||
| 		R.reserve(B.size() * 2); | 		R.reserve(B.size() * 2); | ||||||
| @@ -617,329 +599,4 @@ namespace OpenWifi::Utils { | |||||||
| 		return DT.timestamp().epochTime(); | 		return DT.timestamp().epochTime(); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|     static std::string FileToString(const std::string &Filename) { |  | ||||||
|         std::ifstream   ifs(Filename.c_str(),std::ios_base::in|std::ios_base::binary); |  | ||||||
|         std::ostringstream os; |  | ||||||
|         Poco::StreamCopier::copyStream(ifs,os); |  | ||||||
|         return os.str(); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     bool CreateX509CSR(const CSRCreationParameters & Parameters, CSRCreationResults & Results) { |  | ||||||
|         int             ret = 0; |  | ||||||
|         RSA             *r = nullptr; |  | ||||||
|         BIGNUM          *bne = nullptr; |  | ||||||
|  |  | ||||||
|         int             nVersion = 0; |  | ||||||
|         unsigned long   e = RSA_F4; |  | ||||||
|  |  | ||||||
|         X509_REQ        *x509_req = nullptr; |  | ||||||
|         X509_NAME       *x509_name = nullptr; |  | ||||||
|         EVP_PKEY        *pKey = nullptr; |  | ||||||
| //        RSA             *tem = nullptr; |  | ||||||
| //        BIO             *bio_err = nullptr; |  | ||||||
|  |  | ||||||
|         const char      *szCountry = Parameters.Country.c_str(); |  | ||||||
|         const char      *szProvince = Parameters.Province.c_str(); |  | ||||||
|         const char      *szCity = Parameters.City.c_str(); |  | ||||||
|         const char      *szOrganization = Parameters.Organization.c_str(); |  | ||||||
|         const char      *szCommon = Parameters.CommonName.c_str(); |  | ||||||
|  |  | ||||||
|         Poco::TemporaryFile     CsrPath, PubKey, PrivateKey; |  | ||||||
|         std::string             Result; |  | ||||||
|         std::ifstream           ifs; |  | ||||||
|         std::ostringstream      ss; |  | ||||||
|         BIO                     *bp_public = nullptr, |  | ||||||
|                 *bp_private = nullptr, |  | ||||||
|                 *bp_csr = nullptr; |  | ||||||
|  |  | ||||||
|         // 1. generate rsa key |  | ||||||
|         bne = BN_new(); |  | ||||||
|         ret = BN_set_word(bne,e); |  | ||||||
|         if(ret != 1){ |  | ||||||
|             goto free_all; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         r = RSA_new(); |  | ||||||
|         ret = RSA_generate_key_ex(r, Parameters.bits, bne, nullptr); |  | ||||||
|         if(ret != 1){ |  | ||||||
|             goto free_all; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         bp_public = BIO_new_file(PubKey.path().c_str(), "w+"); |  | ||||||
|         ret = PEM_write_bio_RSAPublicKey(bp_public, r); |  | ||||||
|         if(ret != 1) { |  | ||||||
|             goto free_all; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         bp_private = BIO_new_file(PrivateKey.path().c_str(), "w+"); |  | ||||||
|         ret = PEM_write_bio_RSAPrivateKey(bp_private, r, NULL, NULL, 0, NULL, NULL); |  | ||||||
|         if(ret != 1) { |  | ||||||
|             goto free_all; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
| // 2. set version of x509 req |  | ||||||
|         x509_req = X509_REQ_new(); |  | ||||||
|         ret = X509_REQ_set_version(x509_req, nVersion); |  | ||||||
|         if (ret != 1){ |  | ||||||
|             goto free_all; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
| // 3. set subject of x509 req |  | ||||||
|         x509_name = X509_REQ_get_subject_name(x509_req); |  | ||||||
|  |  | ||||||
|         ret = X509_NAME_add_entry_by_txt(x509_name,"C", MBSTRING_ASC, (const unsigned char*)szCountry, -1, -1, 0); |  | ||||||
|         if (ret != 1){ |  | ||||||
|             goto free_all; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         ret = X509_NAME_add_entry_by_txt(x509_name,"ST", MBSTRING_ASC, (const unsigned char*)szProvince, -1, -1, 0); |  | ||||||
|         if (ret != 1){ |  | ||||||
|             goto free_all; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         ret = X509_NAME_add_entry_by_txt(x509_name,"L", MBSTRING_ASC, (const unsigned char*)szCity, -1, -1, 0); |  | ||||||
|         if (ret != 1){ |  | ||||||
|             goto free_all; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         ret = X509_NAME_add_entry_by_txt(x509_name,"O", MBSTRING_ASC, (const unsigned char*)szOrganization, -1, -1, 0); |  | ||||||
|         if (ret != 1){ |  | ||||||
|             goto free_all; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         ret = X509_NAME_add_entry_by_txt(x509_name,"CN", MBSTRING_ASC, (const unsigned char*)szCommon, -1, -1, 0); |  | ||||||
|         if (ret != 1){ |  | ||||||
|             goto free_all; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
| // 4. set public key of x509 req |  | ||||||
|         pKey = EVP_PKEY_new(); |  | ||||||
|         EVP_PKEY_assign_RSA(pKey, r); |  | ||||||
|         r = nullptr;   // will be free rsa when EVP_PKEY_free(pKey) |  | ||||||
|  |  | ||||||
|         ret = X509_REQ_set_pubkey(x509_req, pKey); |  | ||||||
|         if (ret != 1){ |  | ||||||
|             goto free_all; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
| // 5. set sign key of x509 req |  | ||||||
|         ret = X509_REQ_sign(x509_req, pKey, EVP_sha1());    // return x509_req->signature->length |  | ||||||
|         if (ret <= 0){ |  | ||||||
|             goto free_all; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         bp_csr = BIO_new_file(CsrPath.path().c_str(),"w"); |  | ||||||
|         ret = PEM_write_bio_X509_REQ(bp_csr, x509_req); |  | ||||||
|  |  | ||||||
| // 6. free |  | ||||||
|         free_all: |  | ||||||
|         X509_REQ_free(x509_req); |  | ||||||
|         BIO_free_all(bp_csr); |  | ||||||
|         BIO_free_all(bp_public); |  | ||||||
|         BIO_free_all(bp_private); |  | ||||||
|  |  | ||||||
|         EVP_PKEY_free(pKey); |  | ||||||
|         BN_free(bne); |  | ||||||
|         if(ret==1) { |  | ||||||
|             Results.CSR = FileToString(CsrPath.path()); |  | ||||||
|             Results.PrivateKey = FileToString(PrivateKey.path()); |  | ||||||
|             Results.PublicKey = FileToString(PubKey.path()); |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         return ret; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     bool VerifyECKey(const std::string &key) { |  | ||||||
|         try { |  | ||||||
|             Poco::TemporaryFile F; |  | ||||||
|  |  | ||||||
|             std::ofstream of(F.path().c_str(), std::ios_base::trunc | std::ios_base::out | std::ios_base::binary); |  | ||||||
|             of << key; |  | ||||||
|             of.close(); |  | ||||||
|  |  | ||||||
|             auto Key = Poco::SharedPtr<Poco::Crypto::ECKey>( |  | ||||||
|                     new Poco::Crypto::ECKey("", F.path(),"")); |  | ||||||
|  |  | ||||||
|             return true; |  | ||||||
|         } catch (const Poco::Exception &E) { |  | ||||||
|  |  | ||||||
|         } |  | ||||||
|         return false; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     bool VerifyRSAKey([[ |  | ||||||
|     maybe_unused]] const std::string &key) { |  | ||||||
|         try { |  | ||||||
|             Poco::TemporaryFile F; |  | ||||||
|  |  | ||||||
|             std::ofstream of(F.path().c_str(), std::ios_base::trunc | std::ios_base::out | std::ios_base::binary); |  | ||||||
|             of << key; |  | ||||||
|             of.close(); |  | ||||||
|  |  | ||||||
|             auto Key = Poco::SharedPtr<Poco::Crypto::RSAKey>( |  | ||||||
|                     new Poco::Crypto::RSAKey("", F.path(),"")); |  | ||||||
|             return true; |  | ||||||
|         } catch (const Poco::Exception &E) { |  | ||||||
|  |  | ||||||
|         } |  | ||||||
|         return false; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     bool VerifyPrivateKey(const std::string &key) { |  | ||||||
|         return VerifyECKey(key) || VerifyRSAKey(key); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     bool ValidX509Certificate([[ |  | ||||||
|                               maybe_unused]] const std::string &Cert) { |  | ||||||
|         try { |  | ||||||
|             Poco::TemporaryFile F; |  | ||||||
|             std::ofstream of(F.path().c_str(), std::ios_base::trunc | std::ios_base::out | std::ios_base::binary); |  | ||||||
|             of << Cert; |  | ||||||
|             of.close(); |  | ||||||
|  |  | ||||||
|             auto Key = Poco::SharedPtr<Poco::Crypto::X509Certificate>( |  | ||||||
|                     new Poco::Crypto::X509Certificate(F.path())); |  | ||||||
|             return true; |  | ||||||
|         } catch (const Poco::Exception &E) { |  | ||||||
|  |  | ||||||
|         } |  | ||||||
|         return false; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     bool ValidX509Certificate([[ |  | ||||||
|                               maybe_unused]] const std::vector<std::string> &Certs) { |  | ||||||
|         auto F = [](const std::string &C) -> bool { return ValidX509Certificate(C); }; |  | ||||||
|         return std::all_of(Certs.begin(),Certs.end(), F); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     std::string generateStrongPassword(int minLength, int maxLength, int numDigits, int minLowercase, int minSpecial, int minUppercase) { |  | ||||||
|         // Define character sets for each category |  | ||||||
|         const std::string lowercaseChars = "abcdefghijklmnopqrstuvwxyz"; |  | ||||||
|         const std::string uppercaseChars = "ABCDEFGHIJKLMNOPQRSTUVWXYZ"; |  | ||||||
|         const std::string digitChars = "0123456789"; |  | ||||||
|         const std::string specialChars = "!@#$%^&*()_+[]{}|;:,.<>?"; |  | ||||||
|  |  | ||||||
|         // Check if parameters are valid |  | ||||||
|         if (minLength < 1 || minLength > maxLength || minLowercase + minUppercase + numDigits + minSpecial > maxLength) { |  | ||||||
|             return "Invalid parameters"; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         // Initialize random seed |  | ||||||
|         std::random_device rd; |  | ||||||
|         std::mt19937 g(rd()); |  | ||||||
|  |  | ||||||
|         // Initialize the password string |  | ||||||
|         std::string password; |  | ||||||
|  |  | ||||||
|         // Generate the required number of each character type |  | ||||||
|         for (int i = 0; i < minLowercase; ++i) { |  | ||||||
|             password += lowercaseChars[g() % lowercaseChars.length()]; |  | ||||||
|         } |  | ||||||
|         for (int i = 0; i < minUppercase; ++i) { |  | ||||||
|             password += uppercaseChars[g() % uppercaseChars.length()]; |  | ||||||
|         } |  | ||||||
|         for (int i = 0; i < numDigits; ++i) { |  | ||||||
|             password += digitChars[g() % digitChars.length()]; |  | ||||||
|         } |  | ||||||
|         for (int i = 0; i < minSpecial; ++i) { |  | ||||||
|             password += specialChars[g() % specialChars.length()]; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         // Calculate how many more characters are needed |  | ||||||
|         int remainingLength = maxLength - (int)password.length(); |  | ||||||
|  |  | ||||||
|         // Generate random characters to fill the remaining length |  | ||||||
|         for (int i = 0; i < remainingLength; ++i) { |  | ||||||
|             int category = g() % 4; // Randomly select a category |  | ||||||
|             if (category == 0) { |  | ||||||
|                 password += lowercaseChars[g() % lowercaseChars.length()]; |  | ||||||
|             } else if (category == 1) { |  | ||||||
|                 password += uppercaseChars[g() % uppercaseChars.length()]; |  | ||||||
|             } else if (category == 2) { |  | ||||||
|                 password += digitChars[g() % digitChars.length()]; |  | ||||||
|             } else { |  | ||||||
|                 password += specialChars[g() % specialChars.length()]; |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         // Shuffle the password to randomize the character order |  | ||||||
|         std::shuffle(password.begin(), password.end(),g); |  | ||||||
|  |  | ||||||
|         return password; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| // Function to query NAPTR records for a domain and return them in a vector |  | ||||||
|     std::vector<NAPTRRecord> getNAPTRRecords(const std::string& domain) { |  | ||||||
|         std::vector<NAPTRRecord> naptrRecords; |  | ||||||
|  |  | ||||||
|         unsigned char buf[4096]; |  | ||||||
|         ns_msg handle; |  | ||||||
|         ns_initparse(buf, NS_PACKETSZ, &handle); |  | ||||||
|  |  | ||||||
|         // Query NAPTR records for the given domain |  | ||||||
|         int response = res_query(domain.c_str(), ns_c_in, ns_t_naptr, buf, sizeof(buf)); |  | ||||||
|         if (response < 0) { |  | ||||||
|             return naptrRecords; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         if(ns_initparse(buf, response, &handle) < 0) { |  | ||||||
|             return naptrRecords; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         // Iterate through the DNS response and extract NAPTR records |  | ||||||
|         int count = ns_msg_count(handle, ns_s_an); |  | ||||||
|         for (int i = 0; i < count; ++i) { |  | ||||||
|             ns_rr rr; |  | ||||||
|             if (ns_parserr(&handle, ns_s_an, i, &rr) == 0) { |  | ||||||
|                 char rdata[256]; |  | ||||||
|                 ns_sprintrr(&handle, &rr, nullptr, nullptr, rdata, sizeof(rdata)); |  | ||||||
|                 NAPTRRecord record; |  | ||||||
|                 std::istringstream os(rdata); |  | ||||||
|                 os  >> record.name >> record.ttl >> record.rclass >> record.rtype >> record.order >> record.preference >> record.flags |  | ||||||
|                     >> record.service >> record.regexp >>  record.replacement; |  | ||||||
|                 naptrRecords.push_back(record); |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         return naptrRecords; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     std::vector<SrvRecord> getSRVRecords(const std::string& domain) { |  | ||||||
|         std::vector<SrvRecord> srvRecords; |  | ||||||
|  |  | ||||||
|         // Buffer to hold the DNS response |  | ||||||
|         unsigned char buf[4096]; |  | ||||||
|         ns_msg handle; |  | ||||||
|         ns_initparse(buf, NS_PACKETSZ, &handle); |  | ||||||
|  |  | ||||||
|         // Query NAPTR records for the given domain |  | ||||||
|         int response = res_query(domain.c_str(), ns_c_in, ns_t_srv, buf, sizeof(buf)); |  | ||||||
|         if (response < 0) { |  | ||||||
|             std::cerr << "DNS query failed for " << domain << ": " << hstrerror(h_errno) << std::endl; |  | ||||||
|             return srvRecords; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         if(ns_initparse(buf, response, &handle) < 0) { |  | ||||||
|             return srvRecords; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         // Iterate through the DNS response and extract NAPTR records |  | ||||||
|         int count = ns_msg_count(handle, ns_s_an); |  | ||||||
|         for (int i = 0; i < count; ++i) { |  | ||||||
|             ns_rr rr; |  | ||||||
|             if (ns_parserr(&handle, ns_s_an, i, &rr) == 0) { |  | ||||||
|                 char rdata[256]; |  | ||||||
|                 ns_sprintrr(&handle, &rr, nullptr, nullptr, rdata, sizeof(rdata)); |  | ||||||
|                 SrvRecord record; |  | ||||||
|                 std::istringstream os(rdata); |  | ||||||
|                 os  >>  record.name >> record.ttl >> record.rclass >> record.rtype >> record.pref >> record.weight >> |  | ||||||
|                     record.port >> record.srvname ; |  | ||||||
|                 srvRecords.push_back(record); |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         return srvRecords; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| } // namespace OpenWifi::Utils | } // namespace OpenWifi::Utils | ||||||
|   | |||||||
| @@ -13,8 +13,6 @@ | |||||||
| #include <string> | #include <string> | ||||||
| #include <thread> | #include <thread> | ||||||
|  |  | ||||||
| #include <dirent.h> |  | ||||||
|  |  | ||||||
| #include "Poco/Base64Decoder.h" | #include "Poco/Base64Decoder.h" | ||||||
| #include "Poco/Base64Encoder.h" | #include "Poco/Base64Encoder.h" | ||||||
| #include "Poco/File.h" | #include "Poco/File.h" | ||||||
| @@ -73,7 +71,6 @@ namespace OpenWifi::Utils { | |||||||
| 	[[nodiscard]] bool ValidSerialNumbers(const std::vector<std::string> &Serial); | 	[[nodiscard]] bool ValidSerialNumbers(const std::vector<std::string> &Serial); | ||||||
| 	[[nodiscard]] bool ValidUUID(const std::string &UUID); | 	[[nodiscard]] bool ValidUUID(const std::string &UUID); | ||||||
| 	[[nodiscard]] bool ValidHostname(const std::string &hostname); | 	[[nodiscard]] bool ValidHostname(const std::string &hostname); | ||||||
| 	[[nodiscard]] bool ValidNumber(const std::string &number, bool isSigned); |  | ||||||
|  |  | ||||||
| 	template <typename... Args> std::string ComputeHash(Args &&...args) { | 	template <typename... Args> std::string ComputeHash(Args &&...args) { | ||||||
| 		Poco::SHA2Engine E; | 		Poco::SHA2Engine E; | ||||||
| @@ -184,222 +181,4 @@ namespace OpenWifi::Utils { | |||||||
| 		return false; | 		return false; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	static inline std::uint64_t GetValue(FILE *file) { |  | ||||||
| 		unsigned long v=0; |  | ||||||
| 		char factor[32]; |  | ||||||
| 		if(fscanf(file, " %lu %31s", &v, factor)==2) { |  | ||||||
| 			switch (factor[0]) { |  | ||||||
| 			case 'k': |  | ||||||
| 				return v * 1000; |  | ||||||
| 			case 'M': |  | ||||||
| 				return v * 1000000; |  | ||||||
| 			case 'G': |  | ||||||
| 				return v * 1000000000; |  | ||||||
| 			} |  | ||||||
| 		} |  | ||||||
| 		return v; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	inline bool getMemory( |  | ||||||
| 		std::uint64_t &currRealMem, std::uint64_t &peakRealMem, |  | ||||||
| 		std::uint64_t &currVirtMem, std::uint64_t &peakVirtMem) { |  | ||||||
|  |  | ||||||
| 		// stores each word in status file |  | ||||||
| 		char buffer[1024] = ""; |  | ||||||
|  |  | ||||||
| 		currRealMem = peakRealMem = currVirtMem = peakVirtMem = 0; |  | ||||||
|  |  | ||||||
| 		// linux file contains this-process info |  | ||||||
| 		FILE * file = std::fopen("/proc/self/status", "r"); |  | ||||||
| 		if (file == nullptr) { |  | ||||||
| 			return false; |  | ||||||
| 		} |  | ||||||
|  |  | ||||||
| 		// read the entire file, recording mems in kB |  | ||||||
| 		while (fscanf(file, " %1023s", buffer) == 1) { |  | ||||||
|  |  | ||||||
| 			if (strcmp(buffer, "VmRSS:") == 0) { |  | ||||||
| 				currRealMem= GetValue(file); |  | ||||||
| 			} else if (strcmp(buffer, "VmHWM:") == 0) { |  | ||||||
| 				peakRealMem= GetValue(file); |  | ||||||
| 			} else if (strcmp(buffer, "VmSize:") == 0) { |  | ||||||
| 				currVirtMem= GetValue(file); |  | ||||||
| 			} else if (strcmp(buffer, "VmPeak:") == 0) { |  | ||||||
| 				peakVirtMem= GetValue(file); |  | ||||||
| 			} |  | ||||||
| 		} |  | ||||||
| 		fclose(file); |  | ||||||
|  |  | ||||||
| 		return true; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	inline int get_open_fds() { |  | ||||||
| 		DIR *dp = opendir("/proc/self/fd"); |  | ||||||
| 		struct dirent *de; |  | ||||||
| 		int count = -3; // '.', '..', dp |  | ||||||
|  |  | ||||||
| 		if (dp == nullptr) |  | ||||||
| 			return -1; |  | ||||||
| 		while ((de = readdir(dp)) != nullptr) |  | ||||||
| 			count++; |  | ||||||
| 		(void)closedir(dp); |  | ||||||
|  |  | ||||||
| 		return count; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
|     inline std::uint32_t IPtoInt(const std::string &A) { |  | ||||||
|         Poco::Net::IPAddress    IP; |  | ||||||
|         std::uint32_t Result=0; |  | ||||||
|  |  | ||||||
|         if(Poco::Net::IPAddress::tryParse(A,IP)) { |  | ||||||
|             for(const auto i:IP.toBytes()) { |  | ||||||
|                 Result <<= 8; |  | ||||||
|                 Result += i; |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|         return Result; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     inline bool ValidIP(const std::string &IPstr) { |  | ||||||
|         Poco::Net::IPAddress    IP; |  | ||||||
|         return Poco::Net::IPAddress::tryParse(IPstr,IP); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     struct CSRCreationParameters { |  | ||||||
|         std::string Country, Province, City, |  | ||||||
|                     Organization, CommonName; |  | ||||||
|         int         bits=2048; |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     struct CSRCreationResults { |  | ||||||
|         std::string     CSR, PublicKey, PrivateKey; |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     bool CreateX509CSR(const CSRCreationParameters & Parameters, CSRCreationResults & Results); |  | ||||||
|     std::string generateStrongPassword(int minLength, int maxLength, int numDigits, int minLowercase, int minSpecial, int minUppercase); |  | ||||||
|     bool VerifyECKey(const std::string &key); |  | ||||||
|     bool VerifyRSAKey(const std::string &key); |  | ||||||
|     bool VerifyPrivateKey(const std::string &key); |  | ||||||
|     bool ValidX509Certificate(const std::string &Cert); |  | ||||||
|     bool ValidX509Certificate(const std::vector<std::string> &Certs); |  | ||||||
|  |  | ||||||
|     struct NAPTRRecord { |  | ||||||
|         std::string     name; |  | ||||||
|         std::string     ttl; |  | ||||||
|         std::string     rclass; |  | ||||||
|         std::string     rtype; |  | ||||||
|         uint32_t        order=0; |  | ||||||
|         uint32_t        preference=0; |  | ||||||
|         std::string     flags; |  | ||||||
|         std::string     service; |  | ||||||
|         std::string     regexp; |  | ||||||
|         std::string     replacement; |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
| // Function to query NAPTR records for a domain and return them in a vector |  | ||||||
|     std::vector<NAPTRRecord> getNAPTRRecords(const std::string& domain); |  | ||||||
|     struct SrvRecord { |  | ||||||
|         std::string     name; |  | ||||||
|         std::string     ttl; |  | ||||||
|         std::string     rclass; |  | ||||||
|         std::string     rtype; |  | ||||||
|         uint32_t        pref = 0; |  | ||||||
|         uint32_t        weight = 0; |  | ||||||
|         uint32_t        port = 0; |  | ||||||
|         std::string     srvname; |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     std::vector<SrvRecord> getSRVRecords(const std::string& domain); |  | ||||||
|  |  | ||||||
|     struct HostNameServerResult{ |  | ||||||
|         std::string     Hostname; |  | ||||||
|         uint32_t        Port; |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
| 	class CompressedString { |  | ||||||
| 	  public: |  | ||||||
| 		CompressedString() { |  | ||||||
| 			DecompressedSize_ = 0; |  | ||||||
| 		}; |  | ||||||
|  |  | ||||||
| 		explicit CompressedString(const std::string &Data) : DecompressedSize_(Data.size()) { |  | ||||||
| 			CompressIt(Data); |  | ||||||
| 		} |  | ||||||
|  |  | ||||||
| 		CompressedString(const CompressedString &Data) { |  | ||||||
| 			this->DecompressedSize_ = Data.DecompressedSize_; |  | ||||||
| 			this->CompressedData_ = Data.CompressedData_; |  | ||||||
| 		} |  | ||||||
|  |  | ||||||
| 		CompressedString& operator=(const CompressedString& rhs) { |  | ||||||
| 			if (this != &rhs) { |  | ||||||
| 				this->DecompressedSize_ = rhs.DecompressedSize_; |  | ||||||
| 				this->CompressedData_ = rhs.CompressedData_; |  | ||||||
| 			} |  | ||||||
| 			return *this; |  | ||||||
| 		} |  | ||||||
|  |  | ||||||
| 		CompressedString& operator=(CompressedString&& rhs) { |  | ||||||
| 			if (this != &rhs) { |  | ||||||
| 				this->DecompressedSize_ = rhs.DecompressedSize_; |  | ||||||
| 				this->CompressedData_ = rhs.CompressedData_; |  | ||||||
| 			} |  | ||||||
| 			return *this; |  | ||||||
| 		} |  | ||||||
|  |  | ||||||
| 		~CompressedString() = default; |  | ||||||
|  |  | ||||||
| 		operator std::string() const { |  | ||||||
| 			return DecompressIt(); |  | ||||||
| 		} |  | ||||||
|  |  | ||||||
| 		CompressedString &operator=(const std::string &Data) { |  | ||||||
| 			DecompressedSize_ = Data.size(); |  | ||||||
| 			CompressIt(Data); |  | ||||||
| 			return *this; |  | ||||||
| 		} |  | ||||||
|  |  | ||||||
| 		auto CompressedSize() const { return CompressedData_.size(); } |  | ||||||
| 		auto DecompressedSize() const { return DecompressedSize_; } |  | ||||||
|  |  | ||||||
| 	  private: |  | ||||||
| 		std::string     CompressedData_; |  | ||||||
| 		std::size_t     DecompressedSize_; |  | ||||||
|  |  | ||||||
| 		inline void CompressIt(const std::string &Data) { |  | ||||||
| 			z_stream strm; // = {0}; |  | ||||||
| 			CompressedData_.resize(Data.size()); |  | ||||||
| 			strm.next_in = (Bytef *)Data.data(); |  | ||||||
| 			strm.avail_in = Data.size(); |  | ||||||
| 			strm.next_out = (Bytef *)CompressedData_.data(); |  | ||||||
| 			strm.avail_out = Data.size(); |  | ||||||
| 			strm.zalloc = Z_NULL; |  | ||||||
| 			strm.zfree = Z_NULL; |  | ||||||
| 			strm.opaque = Z_NULL; |  | ||||||
| 			deflateInit2(&strm, Z_DEFAULT_COMPRESSION, Z_DEFLATED, 15 + 16, 8, Z_DEFAULT_STRATEGY); |  | ||||||
| 			deflate(&strm, Z_FINISH); |  | ||||||
| 			deflateEnd(&strm); |  | ||||||
| 			CompressedData_.resize(strm.total_out); |  | ||||||
| 		} |  | ||||||
|  |  | ||||||
| 		[[nodiscard]] std::string DecompressIt() const { |  | ||||||
| 			std::string Result; |  | ||||||
| 			if(DecompressedSize_!=0) { |  | ||||||
| 				Result.resize(DecompressedSize_); |  | ||||||
| 				z_stream strm ; //= {0}; |  | ||||||
| 				strm.next_in = (Bytef *)CompressedData_.data(); |  | ||||||
| 				strm.avail_in = CompressedData_.size(); |  | ||||||
| 				strm.next_out = (Bytef *)Result.data(); |  | ||||||
| 				strm.avail_out = Result.size(); |  | ||||||
| 				strm.zalloc = Z_NULL; |  | ||||||
| 				strm.zfree = Z_NULL; |  | ||||||
| 				strm.opaque = Z_NULL; |  | ||||||
| 				inflateInit2(&strm, 15 + 32); |  | ||||||
| 				inflate(&strm, Z_FINISH); |  | ||||||
| 				inflateEnd(&strm); |  | ||||||
| 			} |  | ||||||
| 			return Result; |  | ||||||
| 		} |  | ||||||
| 	}; |  | ||||||
|  |  | ||||||
| } // namespace OpenWifi::Utils | } // namespace OpenWifi::Utils | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user