mirror of
				https://github.com/Telecominfraproject/wlan-cloud-ucentralsec.git
				synced 2025-10-30 18:27:49 +00:00 
			
		
		
		
	Compare commits
	
		
			14 Commits
		
	
	
		
			v3.0.0-RC2
			...
			fix_ci
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 54fc3dc6c4 | ||
|   | 3e13e18f6c | ||
|   | 1977ecdfb7 | ||
|   | 1d703e1737 | ||
|   | 22ddb40d4c | ||
|   | 791b72aec4 | ||
|   | 46b9524903 | ||
|   | bb09f919e6 | ||
|   | 8d04cbc059 | ||
|   | 073856d385 | ||
|   | c782981ca7 | ||
|   | ca3691e665 | ||
|   | be2ffc86ec | ||
|   | 75ebc0771c | 
							
								
								
									
										2
									
								
								.github/workflows/ci.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/ci.yml
									
									
									
									
										vendored
									
									
								
							| @@ -21,7 +21,7 @@ defaults: | |||||||
|  |  | ||||||
| jobs: | jobs: | ||||||
|   docker: |   docker: | ||||||
|     runs-on: ubuntu-20.04 |     runs-on: ubuntu-latest | ||||||
|     env: |     env: | ||||||
|       DOCKER_REGISTRY_URL: tip-tip-wlan-cloud-ucentral.jfrog.io |       DOCKER_REGISTRY_URL: tip-tip-wlan-cloud-ucentral.jfrog.io | ||||||
|       DOCKER_REGISTRY_USERNAME: ucentral |       DOCKER_REGISTRY_USERNAME: ucentral | ||||||
|   | |||||||
							
								
								
									
										62
									
								
								BUILDING.md
									
									
									
									
									
								
							
							
						
						
									
										62
									
								
								BUILDING.md
									
									
									
									
									
								
							| @@ -1,6 +1,6 @@ | |||||||
| # Building from source | # Building from source | ||||||
|  |  | ||||||
| In order to build the OWSEC, you will need to install its dependencies, which includes the following: | In order to build 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 the OWSEC, you will need to install its dependencies, which in | |||||||
|  |  | ||||||
| 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/AriliaWireless/poco). Building | from the master copy needed for cmake. Please use the version of this [Poco fix](https://github.com/Telecominfraproject/wlan-cloud-lib-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 \ | ||||||
| sudo apt install libpq-dev libaprutil1-dev apache2-dev libboost-all-dev |     libpq-dev libaprutil1-dev apache2-dev libboost-all-dev \ | ||||||
| sudo apt install librdkafka-dev default-libmysqlclient-dev |     librdkafka-dev default-libmysqlclient-dev \ | ||||||
| sudo apt install nlohmann-json-dev |     nlohmann-json-dev | ||||||
|  |  | ||||||
| cd ~ | 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 ../.. | ||||||
|  |  | ||||||
| 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 ../.. | ||||||
|  |  | ||||||
| cd ~ | git clone https://github.com/Telecominfraproject/wlan-cloud-lib-valijson --branch tip-v1 valijson | ||||||
| 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,56 +58,59 @@ 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 \ | ||||||
| sudo yum install yaml-cpp-devel lua-devel  |     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/AriliaWireless/poco --branch poco-tip-v1 | 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 ../.. | ||||||
|  |  | ||||||
| git clone https://github.com/AriliaWireless/cppkafka --branch tip-v1 | git clone https://github.com/Telecominfraproject/wlan-cloud-lib-cppkafka --branch tip-v1 cppkafka | ||||||
| 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 ../.. | ||||||
|  |  | ||||||
| cd ~ | git clone https://github.com/Telecominfraproject/wlan-cloud-lib-valijson --branch tip-v1 valijson | ||||||
| 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 | ||||||
| @@ -126,7 +129,7 @@ brew install openssl \ | |||||||
| 	nlohmann-json \ | 	nlohmann-json \ | ||||||
| 	fmt | 	fmt | ||||||
|  |  | ||||||
| git clone https://github.com/AriliaWireless/poco --branch poco-tip-v1 | git clone https://github.com/Telecominfraproject/wlan-cloud-lib-poco --branch poco-tip-v1 poco | ||||||
| pushd poco | pushd poco | ||||||
| mkdir cmake-build | mkdir cmake-build | ||||||
| push cmake-build | push cmake-build | ||||||
| @@ -136,7 +139,7 @@ sudo cmake --build . --target install | |||||||
| popd | popd | ||||||
| popd | popd | ||||||
|  |  | ||||||
| git clone https://github.com/AriliaWireless/cppkafka --branch tip-v1 | git clone https://github.com/Telecominfraproject/wlan-cloud-lib-cppkafka --branch tip-v1 cppkafka | ||||||
| pushd cppkafka | pushd cppkafka | ||||||
| mkdir cmake-build | mkdir cmake-build | ||||||
| pushd cmake-build | pushd cmake-build | ||||||
| @@ -146,10 +149,10 @@ sudo cmake --build . --target install | |||||||
| popd | popd | ||||||
| popd | popd | ||||||
|  |  | ||||||
| git clone https://github.com/AriliaWireless/valijson --branch tip-v1 | git clone https://github.com/Telecominfraproject/wlan-cloud-lib-valijson --branch tip-v1 valijson | ||||||
| cd valijson | pushd valijson | ||||||
| mkdir cmake-build | mkdir cmake-build | ||||||
| cd cmake-build | pushd cmake-build | ||||||
| cmake .. | cmake .. | ||||||
| cmake --build . --config Release | cmake --build . --config Release | ||||||
| sudo cmake --build . --target install | sudo cmake --build . --target install | ||||||
| @@ -172,20 +175,23 @@ 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 libboost-all-dev libyaml-cpp-dev | sudo apt install git cmake g++ libssl-dev libaprutil1-dev apache2-dev \ | ||||||
| git clone https://github.com/stephb9959/poco |     libboost-all-dev libyaml-cpp-dev | ||||||
|  |  | ||||||
|  | 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 3.2.0) | ||||||
|  |  | ||||||
| set(CMAKE_CXX_STANDARD 17) | set(CMAKE_CXX_STANDARD 17) | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										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/AriliaWireless/poco/git/refs/tags/${POCO_VERSION} version.json | ADD https://api.github.com/repos/Telecominfraproject/wlan-cloud-lib-poco/git/refs/tags/${POCO_VERSION} version.json | ||||||
| RUN git clone https://github.com/AriliaWireless/poco --branch ${POCO_VERSION} /poco | RUN git clone https://github.com/Telecominfraproject/wlan-cloud-lib-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/AriliaWireless/cppkafka/git/refs/tags/${CPPKAFKA_VERSION} version.json | ADD https://api.github.com/repos/Telecominfraproject/wlan-cloud-lib-cppkafka/git/refs/tags/${CPPKAFKA_VERSION} version.json | ||||||
| RUN git clone https://github.com/AriliaWireless/cppkafka --branch ${CPPKAFKA_VERSION} /cppkafka | RUN git clone https://github.com/Telecominfraproject/wlan-cloud-lib-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/AriliaWireless/valijson/git/refs/tags/${VALIJASON_VERSION} version.json | ADD https://api.github.com/repos/Telecominfraproject/wlan-cloud-lib-valijson/git/refs/tags/${VALIJASON_VERSION} version.json | ||||||
| RUN git clone https://github.com/AriliaWireless/valijson --branch ${VALIJASON_VERSION} /valijson | RUN git clone https://github.com/Telecominfraproject/wlan-cloud-lib-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.0-RC2 |     tag: main | ||||||
|     pullPolicy: Always |     pullPolicy: Always | ||||||
| #    regcred: | #    regcred: | ||||||
| #      registry: tip-tip-wlan-cloud-ucentral.jfrog.io | #      registry: tip-tip-wlan-cloud-ucentral.jfrog.io | ||||||
|   | |||||||
| @@ -587,6 +587,9 @@ 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) { | ||||||
| @@ -609,6 +612,9 @@ 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 (...) { | ||||||
| 		} | 		} | ||||||
|   | |||||||
| @@ -490,9 +490,11 @@ 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); | ||||||
|     }; |     }; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -16,9 +16,9 @@ namespace OpenWifi { | |||||||
| 		KafkaManager()->PostMessage(KafkaTopics::SERVICE_EVENTS, MicroServicePrivateEndPoint(), Msg, | 		KafkaManager()->PostMessage(KafkaTopics::SERVICE_EVENTS, MicroServicePrivateEndPoint(), Msg, | ||||||
| 									false); | 									false); | ||||||
| 		while (Running_) { | 		while (Running_) { | ||||||
| 			Poco::Thread::trySleep((unsigned long)MicroServiceDaemonBusTimer()); | 			if(!Poco::Thread::trySleep((unsigned long)MicroServiceDaemonBusTimer())) { | ||||||
| 			if (!Running_) |                 break; | ||||||
| 				break; |             } | ||||||
| 			Msg = (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); | ||||||
| @@ -29,7 +29,7 @@ namespace OpenWifi { | |||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| 	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 +37,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..."); | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|   | |||||||
| @@ -22,7 +22,6 @@ namespace OpenWifi { | |||||||
| 			return instance_; | 			return instance_; | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		explicit EventBusManager(Poco::Logger &L); |  | ||||||
| 		void run() final; | 		void run() final; | ||||||
| 		void Start(); | 		void Start(); | ||||||
| 		void Stop(); | 		void Stop(); | ||||||
|   | |||||||
| @@ -79,8 +79,10 @@ 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", | 			 {"metadata.broker.list",MicroServiceConfigGetString("openwifi.kafka.brokerlist", "")} // , | ||||||
| 			  MicroServiceConfigGetString("openwifi.kafka.brokerlist", "")}}); | 			 // {"send.buffer.bytes", KafkaManager()->KafkaManagerMaximumPayloadSize() } | ||||||
|  | 			} | ||||||
|  |  		); | ||||||
|  |  | ||||||
| 		AddKafkaSecurity(Config); | 		AddKafkaSecurity(Config); | ||||||
|  |  | ||||||
| @@ -105,7 +107,16 @@ namespace OpenWifi { | |||||||
| 					NewMessage.partition(0); | 					NewMessage.partition(0); | ||||||
| 					NewMessage.payload(Msg->Payload()); | 					NewMessage.payload(Msg->Payload()); | ||||||
| 					Producer.produce(NewMessage); | 					Producer.produce(NewMessage); | ||||||
| 					Producer.flush(); | 					if (Queue_.size() < 100) { | ||||||
|  | 						// use flush when internal queue is lightly loaded, i.e. flush after each | ||||||
|  | 						// message | ||||||
|  | 						Producer.flush(); | ||||||
|  | 					} | ||||||
|  | 					else { | ||||||
|  | 						// use poll when internal queue is loaded to allow messages to be sent in | ||||||
|  | 						// batches | ||||||
|  | 						Producer.poll((std::chrono::milliseconds) 0); | ||||||
|  | 					} | ||||||
| 				} | 				} | ||||||
| 			} catch (const cppkafka::HandleException &E) { | 			} catch (const cppkafka::HandleException &E) { | ||||||
| 				poco_warning(Logger_, | 				poco_warning(Logger_, | ||||||
| @@ -115,8 +126,13 @@ namespace OpenWifi { | |||||||
| 			} catch (...) { | 			} catch (...) { | ||||||
| 				poco_error(Logger_, "std::exception"); | 				poco_error(Logger_, "std::exception"); | ||||||
| 			} | 			} | ||||||
|  | 			if (Queue_.size() == 0) { | ||||||
|  | 				// message queue is empty, flush all previously sent messages | ||||||
|  | 				Producer.flush(); | ||||||
|  | 			} | ||||||
| 			Note = Queue_.waitDequeueNotification(); | 			Note = Queue_.waitDequeueNotification(); | ||||||
| 		} | 		} | ||||||
|  | 		Producer.flush(); | ||||||
| 		poco_information(Logger_, "Stopped..."); | 		poco_information(Logger_, "Stopped..."); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| @@ -275,6 +291,7 @@ namespace OpenWifi { | |||||||
| 	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(); | ||||||
| 		return 0; | 		return 0; | ||||||
| @@ -321,4 +338,4 @@ namespace OpenWifi { | |||||||
| 											   partitions.front().get_partition())); | 											   partitions.front().get_partition())); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| } // namespace OpenWifi | } // namespace OpenWifi | ||||||
|   | |||||||
| @@ -94,11 +94,14 @@ namespace OpenWifi { | |||||||
| 			return ConsumerThr_.UnregisterTopicWatcher(Topic,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; | ||||||
|  |  | ||||||
| 		void PartitionAssignment(const cppkafka::TopicPartitionList &partitions); | 		void PartitionAssignment(const cppkafka::TopicPartitionList &partitions); | ||||||
| 		void PartitionRevocation(const cppkafka::TopicPartitionList &partitions); | 		void PartitionRevocation(const cppkafka::TopicPartitionList &partitions); | ||||||
|   | |||||||
| @@ -29,11 +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 { | ||||||
|  |  | ||||||
| 	void MicroService::Exit(int Reason) { std::exit(Reason); } | 	static std::string MakeServiceListString(const Types::MicroServiceMetaMap &Services) { | ||||||
|  |  | ||||||
|     static std::string MakeServiceListString(const Types::MicroServiceMetaMap &Services) { |  | ||||||
|         std::string SvcList; |         std::string SvcList; | ||||||
|         for (const auto &Svc : Services) { |         for (const auto &Svc : Services) { | ||||||
|             if (SvcList.empty()) |             if (SvcList.empty()) | ||||||
| @@ -204,25 +206,29 @@ namespace OpenWifi { | |||||||
| 			Res.push_back(ServiceRec); | 			Res.push_back(ServiceRec); | ||||||
| 		} | 		} | ||||||
| 		return Res; | 		return Res; | ||||||
|  |  | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	void MicroService::LoadConfigurationFile() { | 	void MicroService::LoadConfigurationFile() { | ||||||
| 		std::string Location = Poco::Environment::get(DAEMON_CONFIG_ENV_VAR, "."); |         if(ConfigContent_.empty()) { | ||||||
| 		ConfigFileName_ = |             std::string Location = Poco::Environment::get(DAEMON_CONFIG_ENV_VAR, "."); | ||||||
| 			ConfigFileName_.empty() ? Location + "/" + DAEMON_PROPERTIES_FILENAME : ConfigFileName_; |             ConfigFileName_ = | ||||||
| 		Poco::Path ConfigFile(ConfigFileName_); |                 ConfigFileName_.empty() ? Location + "/" + DAEMON_PROPERTIES_FILENAME : ConfigFileName_; | ||||||
|  |             Poco::Path ConfigFile(ConfigFileName_); | ||||||
|  |  | ||||||
| 		if (!ConfigFile.isFile()) { |             if (!ConfigFile.isFile()) { | ||||||
| 			std::cerr << DAEMON_APP_NAME << ": Configuration " << ConfigFile.toString() |                 std::cerr << DAEMON_APP_NAME << ": Configuration " << ConfigFile.toString() | ||||||
| 					  << " does not seem to exist. Please set " + DAEMON_CONFIG_ENV_VAR + |                           << " does not seem to exist. Please set " + DAEMON_CONFIG_ENV_VAR + | ||||||
| 							 " env variable the path of the " + DAEMON_PROPERTIES_FILENAME + |                                  " env variable the path of the " + DAEMON_PROPERTIES_FILENAME + | ||||||
| 							 " file." |                                  " file." | ||||||
| 					  << std::endl; |                           << std::endl; | ||||||
| 			std::exit(Poco::Util::Application::EXIT_CONFIG); |                 std::exit(Poco::Util::Application::EXIT_CONFIG); | ||||||
| 		} |             } | ||||||
|  |             PropConfigurationFile_ = new Poco::Util::PropertyFileConfiguration(ConfigFile.toString()); | ||||||
| 		// 	    loadConfiguration(ConfigFile.toString()); |         } else { | ||||||
| 		PropConfigurationFile_ = new Poco::Util::PropertyFileConfiguration(ConfigFile.toString()); |             std::istringstream is(ConfigContent_); | ||||||
|  |             PropConfigurationFile_ = new Poco::Util::PropertyFileConfiguration(is); | ||||||
|  |         } | ||||||
| 		configPtr()->addWriteable(PropConfigurationFile_, PRIO_DEFAULT); | 		configPtr()->addWriteable(PropConfigurationFile_, PRIO_DEFAULT); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| @@ -425,49 +431,59 @@ namespace OpenWifi { | |||||||
|  |  | ||||||
| 	void DaemonPostInitialization(Poco::Util::Application &self); | 	void DaemonPostInitialization(Poco::Util::Application &self); | ||||||
|  |  | ||||||
| 	void MicroService::initialize(Poco::Util::Application &self) { |     void MicroService::StartEverything(Poco::Util::Application &self) { | ||||||
| 		// add the default services |         LoadConfigurationFile(); | ||||||
| 		LoadConfigurationFile(); |         InitializeLoggingSystem(); | ||||||
| 		InitializeLoggingSystem(); |  | ||||||
|  |  | ||||||
| 		SubSystems_.push_back(KafkaManager()); |         static bool InitializedBaseService=false; | ||||||
| 		SubSystems_.push_back(ALBHealthCheckServer()); |         if(!InitializedBaseService) { | ||||||
| 		SubSystems_.push_back(RESTAPI_ExtServer()); |             InitializedBaseService = true; | ||||||
| 		SubSystems_.push_back(RESTAPI_IntServer()); |             SubSystems_.push_back(KafkaManager()); | ||||||
|  |             SubSystems_.push_back(ALBHealthCheckServer()); | ||||||
|  |             SubSystems_.push_back(RESTAPI_ExtServer()); | ||||||
|  |             SubSystems_.push_back(RESTAPI_IntServer()); | ||||||
| #ifndef TIP_SECURITY_SERVICE | #ifndef TIP_SECURITY_SERVICE | ||||||
| 		SubSystems_.push_back(AuthClient()); |             SubSystems_.push_back(AuthClient()); | ||||||
| #endif | #endif | ||||||
| 		Poco::Net::initializeSSL(); |  | ||||||
| 		Poco::Net::HTTPStreamFactory::registerFactory(); |  | ||||||
| 		Poco::Net::HTTPSStreamFactory::registerFactory(); |  | ||||||
| 		Poco::Net::FTPStreamFactory::registerFactory(); |  | ||||||
| 		Poco::Net::FTPSStreamFactory::registerFactory(); |  | ||||||
|  |  | ||||||
| 		Poco::File DataDir(ConfigPath("openwifi.system.data")); |             Poco::Net::initializeSSL(); | ||||||
| 		DataDir_ = DataDir.path(); |             Poco::Net::HTTPStreamFactory::registerFactory(); | ||||||
| 		if (!DataDir.exists()) { |             Poco::Net::HTTPSStreamFactory::registerFactory(); | ||||||
| 			try { |             Poco::Net::FTPStreamFactory::registerFactory(); | ||||||
| 				DataDir.createDirectory(); |             Poco::Net::FTPSStreamFactory::registerFactory(); | ||||||
| 			} catch (const Poco::Exception &E) { |         } | ||||||
| 				Logger_.log(E); |  | ||||||
| 			} |  | ||||||
| 		} |  | ||||||
| 		WWWAssetsDir_ = ConfigPath("openwifi.restapi.wwwassets", ""); |  | ||||||
| 		if (WWWAssetsDir_.empty()) |  | ||||||
| 			WWWAssetsDir_ = DataDir_; |  | ||||||
|  |  | ||||||
| 		LoadMyConfig(); |         Poco::File DataDir(ConfigPath("openwifi.system.data")); | ||||||
|  |         DataDir_ = DataDir.path(); | ||||||
|  |         if (!DataDir.exists()) { | ||||||
|  |             try { | ||||||
|  |                 DataDir.createDirectory(); | ||||||
|  |             } catch (const Poco::Exception &E) { | ||||||
|  |                 Logger_.log(E); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         WWWAssetsDir_ = ConfigPath("openwifi.restapi.wwwassets", ""); | ||||||
|  |         if (WWWAssetsDir_.empty()) | ||||||
|  |             WWWAssetsDir_ = DataDir_; | ||||||
|  |  | ||||||
| 		AllowExternalMicroServices_ = ConfigGetBool("allowexternalmicroservices", true); |         LoadMyConfig(); | ||||||
|  |  | ||||||
| 		InitializeSubSystemServers(); |         AllowExternalMicroServices_ = ConfigGetBool("allowexternalmicroservices", true); | ||||||
| 		ServerApplication::initialize(self); |  | ||||||
| 		DaemonPostInitialization(self); |  | ||||||
|  |  | ||||||
| 		Types::TopicNotifyFunction F = [this](const std::string &Key, const std::string &Payload) { |         InitializeSubSystemServers(); | ||||||
| 			this->BusMessageReceived(Key, Payload); |         ServerApplication::initialize(self); | ||||||
| 		}; |         DaemonPostInitialization(self); | ||||||
| 		KafkaManager()->RegisterTopicWatcher(KafkaTopics::SERVICE_EVENTS, F); |  | ||||||
|  |         Types::TopicNotifyFunction F = [this](const std::string &Key, const std::string &Payload) { | ||||||
|  |             this->BusMessageReceived(Key, Payload); | ||||||
|  |         }; | ||||||
|  |         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() { | ||||||
| @@ -753,6 +769,8 @@ namespace OpenWifi { | |||||||
| 		MicroServiceErrorHandler ErrorHandler(*this); | 		MicroServiceErrorHandler ErrorHandler(*this); | ||||||
| 		Poco::ErrorHandler::set(&ErrorHandler); | 		Poco::ErrorHandler::set(&ErrorHandler); | ||||||
|  |  | ||||||
|  |         Args_ = args; | ||||||
|  |  | ||||||
| 		if (!HelpRequested_) { | 		if (!HelpRequested_) { | ||||||
| 			SavePID(); | 			SavePID(); | ||||||
|  |  | ||||||
| @@ -768,11 +786,18 @@ 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,9 +55,6 @@ 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 { | ||||||
| @@ -70,7 +67,6 @@ 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"; | ||||||
| @@ -92,7 +88,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 const std::string GetPublicAPIEndPoint() { | 		[[nodiscard]] inline std::string GetPublicAPIEndPoint() const { | ||||||
| 			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_; }; | ||||||
| @@ -107,7 +103,8 @@ namespace OpenWifi { | |||||||
| 		} | 		} | ||||||
| 		static MicroService &instance() { return *instance_; } | 		static MicroService &instance() { return *instance_; } | ||||||
|  |  | ||||||
| 		inline void Exit(int Reason); | 		inline void Exit(int Reason) { std::exit(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(); | ||||||
| @@ -115,6 +112,7 @@ 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; | ||||||
| @@ -132,7 +130,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(); | ||||||
| 		const Types::StringVec &GetLogLevelNames(); | 		static 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); | ||||||
| @@ -166,12 +164,16 @@ 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; | ||||||
| @@ -201,6 +203,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_; | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| 	inline MicroService *MicroService::instance_ = nullptr; | 	inline MicroService *MicroService::instance_ = nullptr; | ||||||
|   | |||||||
| @@ -58,11 +58,9 @@ namespace OpenWifi { | |||||||
| 	void UI_WebSocketClientServer::run() { | 	void UI_WebSocketClientServer::run() { | ||||||
| 		Running_ = true; | 		Running_ = true; | ||||||
| 		while (Running_) { | 		while (Running_) { | ||||||
| 			Poco::Thread::trySleep(2000); | 			if(!Poco::Thread::trySleep(2000)) { | ||||||
|  |                 break; | ||||||
| 			if (!Running_) |             } | ||||||
| 				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; | ||||||
|   | |||||||
| @@ -565,6 +565,7 @@ namespace OpenWifi::RESTAPI::Protocol { | |||||||
|  |  | ||||||
| 	static const char *TRANSFER = "transfer"; | 	static const char *TRANSFER = "transfer"; | ||||||
| 	static const char *CERTUPDATE = "certupdate"; | 	static const char *CERTUPDATE = "certupdate"; | ||||||
|  | 	static const char *POWERCYCLE = "powercycle"; | ||||||
| 	static const char *RRM = "rrm"; | 	static const char *RRM = "rrm"; | ||||||
|  |  | ||||||
| 	static const char *REQUIREMENTS = "requirements"; | 	static const char *REQUIREMENTS = "requirements"; | ||||||
| @@ -687,6 +688,7 @@ namespace OpenWifi::uCentralProtocol { | |||||||
|  |  | ||||||
| 	static const char *TRANSFER = "transfer"; | 	static const char *TRANSFER = "transfer"; | ||||||
| 	static const char *CERTUPDATE = "certupdate"; | 	static const char *CERTUPDATE = "certupdate"; | ||||||
|  | 	static const char *POWERCYCLE = "powercycle"; | ||||||
| 	static const char *RRM = "rrm"; | 	static const char *RRM = "rrm"; | ||||||
| 	static const char *ACTIONS = "actions"; | 	static const char *ACTIONS = "actions"; | ||||||
|  |  | ||||||
| @@ -785,6 +787,7 @@ namespace OpenWifi::APCommands { | |||||||
| 		rrm, | 		rrm, | ||||||
| 		certupdate, | 		certupdate, | ||||||
| 		transfer, | 		transfer, | ||||||
|  | 		powercycle, | ||||||
| 		unknown | 		unknown | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| @@ -799,7 +802,7 @@ namespace OpenWifi::APCommands { | |||||||
| 		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::RRM,		 	 RESTAPI::Protocol::CERTUPDATE, | ||||||
| 		RESTAPI::Protocol::TRANSFER | 		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]; } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user