mirror of
				https://github.com/Telecominfraproject/wlan-cloud-ucentralsec.git
				synced 2025-10-31 02:37:56 +00:00 
			
		
		
		
	Compare commits
	
		
			4 Commits
		
	
	
		
			v2.11.0-RC
			...
			release/v2
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | c7a087ed4a | ||
|   | c911be58f6 | ||
|   | e23dda1df0 | ||
|   | a9990a6bfd | 
| @@ -1,5 +1,5 @@ | ||||
| cmake_minimum_required(VERSION 3.13) | ||||
| project(owsec VERSION 2.11.0) | ||||
| project(owsec VERSION 2.9.0) | ||||
|  | ||||
| set(CMAKE_CXX_STANDARD 17) | ||||
|  | ||||
| @@ -118,7 +118,7 @@ add_executable( owsec | ||||
|         src/framework/RESTAPI_PartHandler.h | ||||
|         src/framework/MicroService.cpp | ||||
|         src/framework/MicroServiceExtra.h | ||||
|         src/framework/default_device_types.h | ||||
|  | ||||
|         src/RESTObjects/RESTAPI_SecurityObjects.h src/RESTObjects/RESTAPI_SecurityObjects.cpp | ||||
|         src/RESTObjects/RESTAPI_GWobjects.h src/RESTObjects/RESTAPI_GWobjects.cpp | ||||
|         src/RESTObjects/RESTAPI_FMSObjects.h src/RESTObjects/RESTAPI_FMSObjects.cpp | ||||
|   | ||||
| @@ -60,16 +60,6 @@ if [[ "$TEMPLATE_CONFIG" = 'true' ]]; then | ||||
|   STORAGE_TYPE_MYSQL_PASSWORD=${STORAGE_TYPE_MYSQL_PASSWORD:-"owsec"} \ | ||||
|   STORAGE_TYPE_MYSQL_DATABASE=${STORAGE_TYPE_MYSQL_DATABASE:-"owsec"} \ | ||||
|   STORAGE_TYPE_MYSQL_PORT=${STORAGE_TYPE_MYSQL_PORT:-"3306"} \ | ||||
|   USER_HELPER_EMAIL=${USER_HELPER_EMAIL:-"openwifi@telecominfraproject.com"} \ | ||||
|   SUB_HELPER_EMAIL=${SUB_HELPER_EMAIL:-"openwifi@telecominfraproject.com"} \ | ||||
|   GLOBAL_USER_HELPER_EMAIL=${GLOBAL_USER_HELPER_EMAIL:-"openwifi@telecominfraproject.com"} \ | ||||
|   GLOBAL_SUB_HELPER_EMAIL=${GLOBAL_SUB_HELPER_EMAIL:-"openwifi@telecominfraproject.com"} \ | ||||
|   USER_HELPER_SITE=${USER_HELPER_SITE:-"https://openwifi.telecominfraproject.com"} \ | ||||
|   SUB_HELPER_SITE=${SUB_HELPER_SITE:-"https://openwifi.telecominfraproject.com"} \ | ||||
|   USER_SYSTEM_LOGIN=${USER_SYSTEM_LOGIN:-"https://openwifi.telecominfraproject.com"} \ | ||||
|   SUB_SYSTEM_LOGIN=${SUB_SYSTEM_LOGIN:-"https://openwifi.telecominfraproject.com"} \ | ||||
|   USER_SIGNATURE=${USER_SIGNATURE:-"Telecom Infra Project"} \ | ||||
|   SUB_SIGNATURE=${SUB_SIGNATURE:-"Telecom Infra Project"} \ | ||||
|   envsubst < /owsec.properties.tmpl > $OWSEC_CONFIG/owsec.properties | ||||
| fi | ||||
|  | ||||
|   | ||||
| @@ -9,7 +9,7 @@ fullnameOverride: "" | ||||
| images: | ||||
|   owsec: | ||||
|     repository: tip-tip-wlan-cloud-ucentral.jfrog.io/owsec | ||||
|     tag: v2.11.0-RC1 | ||||
|     tag: v2.9.0 | ||||
|     pullPolicy: Always | ||||
| #    regcred: | ||||
| #      registry: tip-tip-wlan-cloud-ucentral.jfrog.io | ||||
|   | ||||
| @@ -565,6 +565,12 @@ components: | ||||
|             - $ref: '#/components/schemas/StringList' | ||||
|             - $ref: '#/components/schemas/TagValuePairList' | ||||
|  | ||||
|     SystemCommandResults: | ||||
|       type: object | ||||
|       oneOf: | ||||
|         - $ref: '#/components/schemas/StringList' | ||||
|         - $ref: '#/components/schemas/TagValuePairList' | ||||
|  | ||||
|     SystemInfoResults: | ||||
|       type: object | ||||
|       properties: | ||||
| @@ -593,33 +599,6 @@ components: | ||||
|                 type: integer | ||||
|                 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: | ||||
|       type: object | ||||
|       properties: | ||||
| @@ -1131,12 +1110,6 @@ paths: | ||||
|             type: string | ||||
|             format: uuid | ||||
|           required: true | ||||
|         - in: query | ||||
|           description: When used, signifies the the id is actually the email address of the user, and not its uuid | ||||
|           name: byEmail | ||||
|           schema: | ||||
|             type: boolean | ||||
|           required: false | ||||
|       responses: | ||||
|         200: | ||||
|           $ref: '#/components/schemas/UserInfo' | ||||
| @@ -1253,12 +1226,6 @@ paths: | ||||
|             type: string | ||||
|             format: uuid | ||||
|           required: true | ||||
|         - in: query | ||||
|           description: When used, signifies the the id is actually the email address of the user, and not its uuid | ||||
|           name: byEmail | ||||
|           schema: | ||||
|             type: boolean | ||||
|           required: false | ||||
|       responses: | ||||
|         200: | ||||
|           $ref: '#/components/schemas/UserInfo' | ||||
| @@ -1882,6 +1849,19 @@ paths: | ||||
|   ######################################################################################### | ||||
|   ##  The following calls are restricted to the private system side APIs | ||||
|   ######################################################################################### | ||||
|   /systemServices: | ||||
|     get: | ||||
|       tags: | ||||
|         - Security | ||||
|       summary: Retrieve the basic system information. This information is used between services only. | ||||
|       operationId: getSystemServices | ||||
|       responses: | ||||
|         200: | ||||
|           $ref: '#/components/schemas/InternalSystemServices' | ||||
|         403: | ||||
|           $ref: '#/components/responses/Unauthorized' | ||||
|         404: | ||||
|           $ref: '#/components/responses/NotFound' | ||||
|  | ||||
|   /validateToken: | ||||
|     get: | ||||
| @@ -1988,12 +1968,16 @@ paths: | ||||
|             type: string | ||||
|             enum: | ||||
|               - info | ||||
|               - extraConfiguration | ||||
|               - resources | ||||
|           required: true | ||||
|  | ||||
|       responses: | ||||
|         200: | ||||
|           $ref: '#/components/schemas/SystemCommandResults' | ||||
|           description: Successful command execution | ||||
|           content: | ||||
|             application/json: | ||||
|               schema: | ||||
|                 oneOf: | ||||
|                   - $ref: '#/components/schemas/SystemInfoResults' | ||||
|         403: | ||||
|           $ref: '#/components/responses/Unauthorized' | ||||
|         404: | ||||
| @@ -2001,8 +1985,6 @@ paths: | ||||
|  | ||||
|   /systemSecret/{secret}: | ||||
|     get: | ||||
|       tags: | ||||
|         - System Secrets | ||||
|       description: Retrieve a specific secret | ||||
|       operationId: getSecret | ||||
|       parameters: | ||||
| @@ -2047,8 +2029,6 @@ paths: | ||||
|           $ref: '#/components/responses/NotFound' | ||||
|  | ||||
|     put: | ||||
|       tags: | ||||
|         - System Secrets | ||||
|       description: Modify a specific secret | ||||
|       operationId: modifySecret | ||||
|       parameters: | ||||
|   | ||||
| @@ -34,8 +34,8 @@ authentication.default.username = tip@ucentral.com | ||||
| authentication.default.password = 13268b7daa751240369d125e79c873bd8dd3bef7981bdfd38ea03dbb1fbe7dcf | ||||
| openwifi.system.data = $OWSEC_ROOT/data | ||||
| openwifi.system.uri.private = https://localhost:17001 | ||||
| openwifi.system.uri.public = https://main.server.com:16001 | ||||
| openwifi.system.uri.ui = https://ucentral-ui.main.server.com | ||||
| openwifi.system.uri.public = https://local.dpaas.arilia.com:16001 | ||||
| openwifi.system.uri.ui = https://ucentral-ui.arilia.com | ||||
| openwifi.security.restapi.disable = false | ||||
| openwifi.system.commandchannel = /tmp/app.ucentralsec | ||||
| openwifi.service.key = $OWSEC_ROOT/certs/restapi-key.pem | ||||
| @@ -64,19 +64,9 @@ mailer.loginmethod = login | ||||
| mailer.port = 587 | ||||
| mailer.templates = $OWSEC_ROOT/templates | ||||
|  | ||||
| helper.user.email = openwifi@telecominfraproject.com | ||||
| helper.sub.email = openwifi@telecominfraproject.com | ||||
| helper.user.global.email = openwifi@telecominfraproject.com | ||||
| helper.sub.global.email = openwifi@telecominfraproject.com | ||||
| helper.user.site = https://openwifi.telecominfraproject.com | ||||
| helper.sub.site = https://openwifi.telecominfraproject.com | ||||
| helper.user.login = https://openwifi.telecominfraproject.com | ||||
| helper.sub.login = https://openwifi.telecominfraproject.com | ||||
| helper.user.signature = Telecom Infra Project | ||||
| helper.sub.signature = Telecom Infra Project | ||||
|  | ||||
| ############################# | ||||
| # Generic information for all micro-services | ||||
| # Generic information for all micro services | ||||
| ############################# | ||||
| # | ||||
| # NLB Support | ||||
| @@ -90,7 +80,7 @@ alb.port = 16101 | ||||
| openwifi.kafka.group.id = security | ||||
| openwifi.kafka.client.id = security1 | ||||
| openwifi.kafka.enable = true | ||||
| openwifi.kafka.brokerlist = kafka:9092 | ||||
| openwifi.kafka.brokerlist = a1.arilia.com:9092 | ||||
| openwifi.kafka.auto.commit = false | ||||
| openwifi.kafka.queue.buffering.max.ms = 50 | ||||
| openwifi.kafka.ssl.ca.location = | ||||
| @@ -120,18 +110,18 @@ storage.type.sqlite.maxsessions = 128 | ||||
| storage.type.postgresql.maxsessions = 64 | ||||
| storage.type.postgresql.idletime = 60 | ||||
| storage.type.postgresql.host = localhost | ||||
| storage.type.postgresql.username = owsec | ||||
| storage.type.postgresql.password = owsec | ||||
| storage.type.postgresql.database = owsec | ||||
| storage.type.postgresql.username = stephb | ||||
| storage.type.postgresql.password = snoopy99 | ||||
| storage.type.postgresql.database = ucentral | ||||
| storage.type.postgresql.port = 5432 | ||||
| storage.type.postgresql.connectiontimeout = 60 | ||||
|  | ||||
| storage.type.mysql.maxsessions = 64 | ||||
| storage.type.mysql.idletime = 60 | ||||
| storage.type.mysql.host = localhost | ||||
| storage.type.mysql.username = owsec | ||||
| storage.type.mysql.password = owsec | ||||
| storage.type.mysql.database = owsec | ||||
| storage.type.mysql.username = stephb | ||||
| storage.type.mysql.password = snoopy99 | ||||
| storage.type.mysql.database = ucentral | ||||
| storage.type.mysql.port = 3306 | ||||
| storage.type.mysql.connectiontimeout = 60 | ||||
|  | ||||
|   | ||||
| @@ -64,16 +64,6 @@ mailer.loginmethod = login | ||||
| mailer.port = ${MAILER_PORT} | ||||
| mailer.templates = ${MAILER_TEMPLATES} | ||||
|  | ||||
| helper.user.email = ${USER_HELPER_EMAIL} | ||||
| helper.sub.email = ${SUB_HELPER_EMAIL} | ||||
| helper.user.global.email = ${GLOBAL_USER_HELPER_EMAIL} | ||||
| helper.sub.global.email = ${GLOBAL_SUB_HELPER_EMAIL} | ||||
| helper.user.site = ${USER_HELPER_SITE} | ||||
| helper.sub.site = ${SUB_HELPER_SITE} | ||||
| helper.user.login = ${USER_SYSTEM_LOGIN} | ||||
| helper.sub.login = ${SUB_SYSTEM_LOGIN} | ||||
| helper.user.signature = ${USER_SIGNATURE} | ||||
| helper.sub.signature = ${SUB_SIGNATURE} | ||||
|  | ||||
| ############################# | ||||
| # Generic information for all micro services | ||||
|   | ||||
| @@ -345,7 +345,7 @@ namespace OpenWifi { | ||||
| 				std::stringstream ResultText; | ||||
| 				Poco::JSON::Stringifier::stringify(Obj, ResultText); | ||||
| 				KafkaManager()->PostMessage(KafkaTopics::SERVICE_EVENTS, | ||||
| 											MicroServicePrivateEndPoint(), std::make_shared<std::string>(ResultText.str()), false); | ||||
| 											MicroServicePrivateEndPoint(), ResultText.str(), false); | ||||
| 			} | ||||
| 		} catch (const Poco::Exception &E) { | ||||
| 			Logger().log(E); | ||||
|   | ||||
| @@ -34,9 +34,7 @@ namespace OpenWifi { | ||||
| 			return BadRequest(RESTAPI::Errors::SMSCouldNotValidate); | ||||
| 		} | ||||
|  | ||||
|         if(Internal_) { | ||||
|             poco_information(Logger(),fmt::format("Internal SMS request: TID={}", TransactionId_)); | ||||
|         } else if (UserInfo_.userinfo.userRole != SecurityObjects::ROOT && | ||||
| 		if (UserInfo_.userinfo.userRole != SecurityObjects::ROOT && | ||||
| 			UserInfo_.userinfo.userRole != SecurityObjects::PARTNER && | ||||
| 			UserInfo_.userinfo.userRole != SecurityObjects::ADMIN) { | ||||
| 			return UnAuthorized(RESTAPI::Errors::ACCESS_DENIED); | ||||
|   | ||||
| @@ -13,7 +13,6 @@ | ||||
| #ifdef TIP_GATEWAY_SERVICE | ||||
| #include "AP_WS_Server.h" | ||||
| #include "CapabilitiesCache.h" | ||||
| #include "RADIUSSessionTracker.h" | ||||
| #endif | ||||
|  | ||||
| #include "RESTAPI_GWobjects.h" | ||||
| @@ -30,7 +29,6 @@ namespace OpenWifi::GWObjects { | ||||
| 		field_to_json(Obj, "serialNumber", SerialNumber); | ||||
| #ifdef TIP_GATEWAY_SERVICE | ||||
| 		field_to_json(Obj, "deviceType", CapabilitiesCache::instance()->GetPlatform(Compatible)); | ||||
| 		field_to_json(Obj, "hasRADIUSSessions", RADIUSSessionTracker()->HasSessions(SerialNumber)); | ||||
| #endif | ||||
| 		field_to_json(Obj, "macAddress", MACAddress); | ||||
| 		field_to_json(Obj, "manufacturer", Manufacturer); | ||||
| @@ -56,9 +54,6 @@ namespace OpenWifi::GWObjects { | ||||
| 		field_to_json(Obj, "pendingConfiguration", pendingConfiguration); | ||||
| 		field_to_json(Obj, "pendingConfigurationCmd", pendingConfigurationCmd); | ||||
| 		field_to_json(Obj, "restrictionDetails", restrictionDetails); | ||||
| 		field_to_json(Obj, "pendingUUID", pendingUUID); | ||||
| 		field_to_json(Obj, "simulated", simulated); | ||||
| 		field_to_json(Obj, "lastRecordedContact", lastRecordedContact); | ||||
| 	} | ||||
|  | ||||
| 	void Device::to_json_with_status(Poco::JSON::Object &Obj) const { | ||||
| @@ -68,7 +63,7 @@ namespace OpenWifi::GWObjects { | ||||
| 		ConnectionState ConState; | ||||
|  | ||||
| 		if (AP_WS_Server()->GetState(SerialNumber, ConState)) { | ||||
| 			ConState.to_json(SerialNumber,Obj); | ||||
| 			ConState.to_json(Obj); | ||||
| 		} else { | ||||
| 			field_to_json(Obj, "ipAddress", ""); | ||||
| 			field_to_json(Obj, "txBytes", (uint64_t)0); | ||||
| @@ -80,13 +75,6 @@ namespace OpenWifi::GWObjects { | ||||
| 			field_to_json(Obj, "associations_2G", (uint64_t)0); | ||||
| 			field_to_json(Obj, "associations_5G", (uint64_t)0); | ||||
| 			field_to_json(Obj, "associations_6G", (uint64_t)0); | ||||
| 			field_to_json(Obj, "hasRADIUSSessions", false); | ||||
| 			field_to_json(Obj, "hasGPS", ConState.hasGPS); | ||||
| 			field_to_json(Obj, "sanity", ConState.sanity); | ||||
| 			field_to_json(Obj, "memoryUsed", ConState.memoryUsed); | ||||
| 			field_to_json(Obj, "sanity", ConState.sanity); | ||||
| 			field_to_json(Obj, "load", ConState.load); | ||||
| 			field_to_json(Obj, "temperature", ConState.temperature); | ||||
| 		} | ||||
| #endif | ||||
| 	} | ||||
| @@ -96,32 +84,20 @@ namespace OpenWifi::GWObjects { | ||||
| 			field_from_json(Obj, "serialNumber", SerialNumber); | ||||
| 			field_from_json(Obj, "deviceType", DeviceType); | ||||
| 			field_from_json(Obj, "macAddress", MACAddress); | ||||
| 			field_from_json(Obj, "manufacturer", Manufacturer); | ||||
| 			field_from_json(Obj, "UUID", UUID); | ||||
| 			field_from_json(Obj, "configuration", Configuration); | ||||
| 			field_from_json(Obj, "notes", Notes); | ||||
| 			field_from_json(Obj, "createdTimestamp", CreationTimestamp); | ||||
| 			field_from_json(Obj, "lastConfigurationChange", LastConfigurationChange); | ||||
| 			field_from_json(Obj, "lastConfigurationDownload", LastConfigurationDownload); | ||||
| 			field_from_json(Obj, "lastFWUpdate", LastFWUpdate); | ||||
| 			field_from_json(Obj, "manufacturer", Manufacturer); | ||||
| 			field_from_json(Obj, "owner", Owner); | ||||
| 			field_from_json(Obj, "location", Location); | ||||
| 			field_from_json(Obj, "venue", Venue); | ||||
| 			field_from_json(Obj, "firmware", Firmware); | ||||
| 			field_from_json(Obj, "compatible", Compatible); | ||||
| 			field_from_json(Obj, "fwUpdatePolicy", FWUpdatePolicy); | ||||
| 			field_from_json(Obj, "devicePassword", DevicePassword); | ||||
| 			field_from_json(Obj, "subscriber", subscriber); | ||||
| 			field_from_json(Obj, "entity", entity); | ||||
| 			field_from_json(Obj, "modified", modified); | ||||
| 			field_from_json(Obj, "locale", locale); | ||||
| 			field_from_json(Obj, "restrictedDevice", restrictedDevice); | ||||
| 			field_from_json(Obj, "pendingConfiguration", pendingConfiguration); | ||||
| 			field_from_json(Obj, "pendingConfigurationCmd", pendingConfigurationCmd); | ||||
| 			field_from_json(Obj, "restrictionDetails", restrictionDetails); | ||||
| 			field_from_json(Obj, "pendingUUID", pendingUUID); | ||||
| 			field_from_json(Obj, "simulated", simulated); | ||||
| 			field_from_json(Obj, "lastRecordedContact", lastRecordedContact); | ||||
| 			return true; | ||||
| 		} catch (const Poco::Exception &E) { | ||||
| 		} | ||||
| @@ -189,8 +165,6 @@ namespace OpenWifi::GWObjects { | ||||
| 		field_to_json(Obj, "waitingForFile", WaitingForFile); | ||||
| 		field_to_json(Obj, "attachFile", AttachDate); | ||||
| 		field_to_json(Obj, "executionTime", executionTime); | ||||
| 		field_to_json(Obj, "lastTry", lastTry); | ||||
| 		field_to_json(Obj, "deferred", deferred); | ||||
| 	} | ||||
|  | ||||
| 	bool DefaultConfiguration::from_json(const Poco::JSON::Object::Ptr &Obj) { | ||||
| @@ -224,7 +198,7 @@ namespace OpenWifi::GWObjects { | ||||
| 		return false; | ||||
| 	} | ||||
|  | ||||
| 	void ConnectionState::to_json([[maybe_unused]] const std::string &SerialNumber, Poco::JSON::Object &Obj)  { | ||||
| 	void ConnectionState::to_json(Poco::JSON::Object &Obj) const { | ||||
| 		field_to_json(Obj, "ipAddress", Address); | ||||
| 		field_to_json(Obj, "txBytes", TX); | ||||
| 		field_to_json(Obj, "rxBytes", RX); | ||||
| @@ -246,20 +220,6 @@ namespace OpenWifi::GWObjects { | ||||
| 		field_to_json(Obj, "connectionCompletionTime", connectionCompletionTime); | ||||
| 		field_to_json(Obj, "totalConnectionTime", Utils::Now() - started); | ||||
| 		field_to_json(Obj, "certificateExpiryDate", certificateExpiryDate); | ||||
| #ifdef TIP_GATEWAY_SERVICE | ||||
| 		hasRADIUSSessions = RADIUSSessionTracker()->HasSessions(SerialNumber); | ||||
| 		AP_WS_Server()->ExtendedAttributes(SerialNumber, hasGPS, sanity, | ||||
| 										   memoryUsed, | ||||
| 										   load, | ||||
| 										   temperature); | ||||
| #endif | ||||
| 		field_to_json(Obj, "hasRADIUSSessions", hasRADIUSSessions ); | ||||
| 		field_to_json(Obj, "hasGPS", hasGPS); | ||||
| 		field_to_json(Obj, "sanity", sanity); | ||||
| 		field_to_json(Obj, "memoryUsed", memoryUsed); | ||||
| 		field_to_json(Obj, "sanity", sanity); | ||||
| 		field_to_json(Obj, "load", load); | ||||
| 		field_to_json(Obj, "temperature", temperature); | ||||
|  | ||||
| 		switch (VerifiedCertificate) { | ||||
| 		case NO_CERTIFICATE: | ||||
| @@ -274,9 +234,6 @@ namespace OpenWifi::GWObjects { | ||||
| 		case VERIFIED: | ||||
| 			field_to_json(Obj, "verifiedCertificate", "VERIFIED"); | ||||
| 			break; | ||||
| 		case SIMULATED: | ||||
| 			field_to_json(Obj, "verifiedCertificate", "SIMULATED"); | ||||
| 			break; | ||||
| 		default: | ||||
| 			field_to_json(Obj, "verifiedCertificate", "NO_CERTIFICATE"); | ||||
| 			break; | ||||
| @@ -533,29 +490,6 @@ namespace OpenWifi::GWObjects { | ||||
| 		return false; | ||||
| 	} | ||||
|  | ||||
| 	void RangeOptions::to_json(Poco::JSON::Object &Obj) const { | ||||
| 		field_to_json(Obj, "NO_IR", NO_IR); | ||||
| 		field_to_json(Obj, "AUTO_BW", AUTO_BW); | ||||
| 		field_to_json(Obj, "DFS", DFS); | ||||
| 		field_to_json(Obj, "NO_OUTDOOR", NO_OUTDOOR); | ||||
| 		field_to_json(Obj, "wmmrule_ETSI", wmmrule_ETSI); | ||||
| 		field_to_json(Obj, "NO_OFDM", NO_OFDM); | ||||
| 	} | ||||
|  | ||||
| 	void FrequencyRange::to_json(Poco::JSON::Object &Obj) const { | ||||
| 		field_to_json(Obj, "from", from); | ||||
| 		field_to_json(Obj, "to", to); | ||||
| 		field_to_json(Obj, "channelWidth", channelWidth); | ||||
| 		field_to_json(Obj, "powerDb", powerDb); | ||||
| 		field_to_json(Obj, "options", options); | ||||
| 	} | ||||
|  | ||||
| 	void RegulatoryCountryInfo::to_json(Poco::JSON::Object &Obj) const { | ||||
| 		field_to_json(Obj, "country", country); | ||||
| 		field_to_json(Obj, "domain", domain); | ||||
| 		field_to_json(Obj, "ranges", ranges); | ||||
| 	} | ||||
|  | ||||
| 	void DeviceRestrictionsKeyInfo::to_json(Poco::JSON::Object &Obj) const { | ||||
| 		field_to_json(Obj, "vendor", vendor); | ||||
| 		field_to_json(Obj, "algo", algo); | ||||
| @@ -610,42 +544,4 @@ namespace OpenWifi::GWObjects { | ||||
| 				(T.commands != commands) || (T.developer != developer) || (T.ssh != ssh) || | ||||
| 				(T.key_info != key_info) || (T.country != country)); | ||||
| 	} | ||||
|  | ||||
| 	void RADIUSSession::to_json(Poco::JSON::Object &Obj) const { | ||||
| 		field_to_json(Obj, "started", started); | ||||
| 		field_to_json(Obj, "lastTransaction", lastTransaction); | ||||
| 		field_to_json(Obj, "destination", destination); | ||||
| 		field_to_json(Obj, "serialNumber", serialNumber); | ||||
| 		field_to_json(Obj, "userName", userName); | ||||
| 		field_to_json(Obj, "accountingSessionId", accountingSessionId); | ||||
| 		field_to_json(Obj, "accountingMultiSessionId", accountingMultiSessionId); | ||||
| 		field_to_json(Obj, "inputPackets", inputPackets); | ||||
| 		field_to_json(Obj, "outputPackets", outputPackets); | ||||
| 		field_to_json(Obj, "inputOctets", inputOctets); | ||||
| 		field_to_json(Obj, "outputOctets", outputOctets); | ||||
| 		field_to_json(Obj, "inputGigaWords", inputGigaWords); | ||||
| 		field_to_json(Obj, "outputGigaWords", outputGigaWords); | ||||
| 		field_to_json(Obj, "sessionTime", sessionTime); | ||||
| 		field_to_json(Obj, "callingStationId", callingStationId); | ||||
| 		field_to_json(Obj, "chargeableUserIdentity", chargeableUserIdentity); | ||||
| 		field_to_json(Obj, "interface", interface); | ||||
| 		field_to_json(Obj, "secret", secret); | ||||
| 	} | ||||
|  | ||||
| 	void RADIUSSessionList::to_json(Poco::JSON::Object &Obj) const { | ||||
| 		field_to_json(Obj, "sessions", sessions); | ||||
| 	} | ||||
|  | ||||
| 	bool RadiusCoADMParameters::from_json(const Poco::JSON::Object::Ptr &Obj) { | ||||
| 		try { | ||||
| 			field_from_json(Obj, "accountingSessionId", accountingSessionId); | ||||
| 			field_from_json(Obj, "accountingMultiSessionId", accountingMultiSessionId); | ||||
| 			field_from_json(Obj, "callingStationId", callingStationId); | ||||
| 			field_from_json(Obj, "chargeableUserIdentity", chargeableUserIdentity); | ||||
| 			return true; | ||||
| 		} catch (const Poco::Exception &E) { | ||||
| 		} | ||||
| 		return false; | ||||
| 	} | ||||
|  | ||||
| } // namespace OpenWifi::GWObjects | ||||
|   | ||||
| @@ -11,13 +11,9 @@ | ||||
| #include "Poco/JSON/Object.h" | ||||
| #include "RESTAPI_SecurityObjects.h" | ||||
|  | ||||
| #ifdef TIP_GATEWAY_SERVICE | ||||
| #include <RADIUS_helpers.h> | ||||
| #endif | ||||
|  | ||||
| namespace OpenWifi::GWObjects { | ||||
|  | ||||
| 	enum CertificateValidation { NO_CERTIFICATE, VALID_CERTIFICATE, MISMATCH_SERIAL, VERIFIED, SIMULATED }; | ||||
| 	enum CertificateValidation { NO_CERTIFICATE, VALID_CERTIFICATE, MISMATCH_SERIAL, VERIFIED }; | ||||
|  | ||||
| 	struct ConnectionState { | ||||
| 		uint64_t MessageCount = 0; | ||||
| @@ -42,14 +38,8 @@ namespace OpenWifi::GWObjects { | ||||
| 		uint64_t sessionId = 0; | ||||
| 		double connectionCompletionTime = 0.0; | ||||
| 		std::uint64_t certificateExpiryDate = 0; | ||||
| 		bool hasRADIUSSessions = false; | ||||
| 		bool hasGPS = false; | ||||
| 		std::uint64_t sanity=0; | ||||
| 		std::double_t memoryUsed=0.0; | ||||
| 		std::double_t load=0.0; | ||||
| 		std::double_t temperature=0.0; | ||||
|  | ||||
| 		void to_json(const std::string &SerialNumber, Poco::JSON::Object &Obj) ; | ||||
| 		void to_json(Poco::JSON::Object &Obj) const; | ||||
| 	}; | ||||
|  | ||||
| 	struct DeviceRestrictionsKeyInfo { | ||||
| @@ -106,9 +96,6 @@ namespace OpenWifi::GWObjects { | ||||
| 		std::string pendingConfiguration; | ||||
| 		std::string pendingConfigurationCmd; | ||||
| 		DeviceRestrictions restrictionDetails; | ||||
| 		std::uint64_t pendingUUID = 0; | ||||
| 		bool simulated=false; | ||||
| 		std::uint64_t lastRecordedContact=0; | ||||
|  | ||||
| 		void to_json(Poco::JSON::Object &Obj) const; | ||||
| 		void to_json_with_status(Poco::JSON::Object &Obj) const; | ||||
| @@ -201,11 +188,7 @@ namespace OpenWifi::GWObjects { | ||||
| 		uint64_t AttachSize = 0; | ||||
| 		std::string AttachType; | ||||
| 		double executionTime = 0.0; | ||||
| 		std::uint64_t lastTry = 0; | ||||
| 		bool deferred = false; | ||||
|  | ||||
| 		void to_json(Poco::JSON::Object &Obj) const; | ||||
| 		bool from_json(const Poco::JSON::Object::Ptr &Obj); | ||||
| 	}; | ||||
|  | ||||
| 	struct BlackListedDevice { | ||||
| @@ -351,76 +334,4 @@ namespace OpenWifi::GWObjects { | ||||
| 		bool from_json(const Poco::JSON::Object::Ptr &Obj); | ||||
| 	}; | ||||
|  | ||||
| 	struct RangeOptions { | ||||
| 		bool NO_IR=false; | ||||
| 		bool AUTO_BW=false; | ||||
| 		bool DFS=false; | ||||
| 		bool NO_OUTDOOR=false; | ||||
| 		bool wmmrule_ETSI=false; | ||||
| 		bool NO_OFDM=false; | ||||
|  | ||||
| 		void to_json(Poco::JSON::Object &Obj) const; | ||||
| 	}; | ||||
|  | ||||
| 	struct FrequencyRange { | ||||
| 		float from = 0.0; | ||||
| 		float to = 0.0; | ||||
| 		int channelWidth = 0; | ||||
| 		int powerDb = 0; | ||||
| 		RangeOptions    options; | ||||
|  | ||||
| 		void to_json(Poco::JSON::Object &Obj) const; | ||||
| 	}; | ||||
|  | ||||
| 	struct RegulatoryCountryInfo { | ||||
| 		std::string country; | ||||
| 		std::string domain; | ||||
| 		std::vector<FrequencyRange>   ranges; | ||||
|  | ||||
| 		void to_json(Poco::JSON::Object &Obj) const; | ||||
| 	}; | ||||
|  | ||||
| 	using RegulatoryInfoCountryMap = std::map<std::string,RegulatoryCountryInfo>; | ||||
|  | ||||
| 	struct RADIUSSession { | ||||
| 		std::uint64_t 			started=0, | ||||
| 								lastTransaction=0; | ||||
| 		std::string 			serialNumber, | ||||
| 								destination, | ||||
| 								userName, | ||||
| 					 			accountingSessionId, | ||||
| 								accountingMultiSessionId, | ||||
| 					 			callingStationId, | ||||
| 								chargeableUserIdentity, | ||||
| 								secret, | ||||
| 								interface; | ||||
| 		std::uint64_t 			inputPackets = 0, | ||||
| 								outputPackets = 0, | ||||
| 								inputOctets = 0, | ||||
| 								outputOctets = 0, | ||||
| 								inputGigaWords = 0, | ||||
| 								outputGigaWords = 0; | ||||
| 		std::uint32_t 			sessionTime = 0; | ||||
|  | ||||
| #ifdef TIP_GATEWAY_SERVICE | ||||
| 		RADIUS::RadiusPacket	accountingPacket; | ||||
| #endif | ||||
|  | ||||
| 		void to_json(Poco::JSON::Object &Obj) const; | ||||
| 	}; | ||||
|  | ||||
| 	struct RADIUSSessionList { | ||||
| 		std::vector<RADIUSSession>	sessions; | ||||
| 		void to_json(Poco::JSON::Object &Obj) const; | ||||
| 	}; | ||||
|  | ||||
| 	struct RadiusCoADMParameters { | ||||
| 		std::string 			accountingSessionId, | ||||
| 								accountingMultiSessionId, | ||||
| 								callingStationId, | ||||
| 								chargeableUserIdentity; | ||||
|  | ||||
| 		bool from_json(const Poco::JSON::Object::Ptr &Obj); | ||||
| 	}; | ||||
|  | ||||
| } // namespace OpenWifi::GWObjects | ||||
|   | ||||
| @@ -37,10 +37,6 @@ static std::string DefaultUCentralSchema = R"foo( | ||||
|         "uuid": { | ||||
|             "type": "integer" | ||||
|         }, | ||||
|         "public_ip_lookup": { | ||||
|             "type": "string", | ||||
|             "format": "uc-fqdn" | ||||
|         }, | ||||
|         "unit": { | ||||
|             "$ref": "#/$defs/unit" | ||||
|         }, | ||||
| @@ -638,6 +634,26 @@ static std::string DefaultUCentralSchema = R"foo( | ||||
|                     "type": "string", | ||||
|                     "format": "uc-timeout", | ||||
|                     "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\\}" | ||||
|                     ] | ||||
|                 } | ||||
|             } | ||||
|         }, | ||||
| @@ -1216,32 +1232,6 @@ static std::string DefaultUCentralSchema = R"foo( | ||||
|                         "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": { | ||||
|                     "type": "array", | ||||
|                     "items": { | ||||
| @@ -1319,25 +1309,6 @@ static std::string DefaultUCentralSchema = R"foo( | ||||
|                                         "value": "Example Operator" | ||||
|                                     } | ||||
|                                 ] | ||||
|                             }, | ||||
|                             { | ||||
|                                 "type": "object", | ||||
|                                 "properties": { | ||||
|                                     "id": { | ||||
|                                         "type": "integer", | ||||
|                                         "maximum": 255, | ||||
|                                         "minimum": 1 | ||||
|                                     }, | ||||
|                                     "hex-value": { | ||||
|                                         "type": "string" | ||||
|                                     } | ||||
|                                 }, | ||||
|                                 "examples": [ | ||||
|                                     { | ||||
|                                         "id": 32, | ||||
|                                         "value": "0a0b0c0d" | ||||
|                                     } | ||||
|                                 ] | ||||
|                             } | ||||
|                         ] | ||||
|                     } | ||||
| @@ -1687,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": { | ||||
|             "type": "object", | ||||
|             "properties": { | ||||
| @@ -1969,10 +1710,6 @@ static std::string DefaultUCentralSchema = R"foo( | ||||
|                 "isolate-clients": { | ||||
|                     "type": "boolean" | ||||
|                 }, | ||||
|                 "strict-forwarding": { | ||||
|                     "type": "boolean", | ||||
|                     "default": false | ||||
|                 }, | ||||
|                 "power-save": { | ||||
|                     "type": "boolean" | ||||
|                 }, | ||||
| @@ -2041,15 +1778,8 @@ static std::string DefaultUCentralSchema = R"foo( | ||||
|                     "$ref": "#/$defs/interface.ssid.rate-limit" | ||||
|                 }, | ||||
|                 "roaming": { | ||||
|                     "anyOf": [ | ||||
|                         { | ||||
|                     "$ref": "#/$defs/interface.ssid.roaming" | ||||
|                 }, | ||||
|                         { | ||||
|                             "type": "boolean" | ||||
|                         } | ||||
|                     ] | ||||
|                 }, | ||||
|                 "radius": { | ||||
|                     "$ref": "#/$defs/interface.ssid.radius" | ||||
|                 }, | ||||
| @@ -2065,9 +1795,6 @@ static std::string DefaultUCentralSchema = R"foo( | ||||
|                 "access-control-list": { | ||||
|                     "$ref": "#/$defs/interface.ssid.acl" | ||||
|                 }, | ||||
|                 "captive": { | ||||
|                     "$ref": "#/$defs/service.captive" | ||||
|                 }, | ||||
|                 "hostapd-bss-raw": { | ||||
|                     "type": "array", | ||||
|                     "items": { | ||||
| @@ -2235,17 +1962,6 @@ static std::string DefaultUCentralSchema = R"foo( | ||||
|                         ] | ||||
|                     } | ||||
|                 }, | ||||
|                 "vlan-awareness": { | ||||
|                     "type": "object", | ||||
|                     "properties": { | ||||
|                         "first": { | ||||
|                             "type": "integer" | ||||
|                         }, | ||||
|                         "last": { | ||||
|                             "type": "integer" | ||||
|                         } | ||||
|                     } | ||||
|                 }, | ||||
|                 "vlan": { | ||||
|                     "$ref": "#/$defs/interface.vlan" | ||||
|                 }, | ||||
| @@ -2368,10 +2084,6 @@ static std::string DefaultUCentralSchema = R"foo( | ||||
|                     "examples": [ | ||||
|                         "01234567890123456789012345678901" | ||||
|                     ] | ||||
|                 }, | ||||
|                 "mutual-tls": { | ||||
|                     "type": "boolean", | ||||
|                     "default": true | ||||
|                 } | ||||
|             } | ||||
|         }, | ||||
| @@ -2981,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": { | ||||
|             "type": "object", | ||||
|             "properties": { | ||||
| @@ -2999,32 +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" | ||||
|                             } | ||||
|                         } | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|         }, | ||||
|         "service": { | ||||
|             "type": "object", | ||||
|             "properties": { | ||||
| @@ -3084,9 +3000,6 @@ static std::string DefaultUCentralSchema = R"foo( | ||||
|                 }, | ||||
|                 "gps": { | ||||
|                     "$ref": "#/$defs/service.gps" | ||||
|                 }, | ||||
|                 "dhcp-relay": { | ||||
|                     "$ref": "#/$defs/service.dhcp-relay" | ||||
|                 } | ||||
|             } | ||||
|         }, | ||||
|   | ||||
| @@ -14,18 +14,18 @@ namespace OpenWifi { | ||||
| 	void EventBusManager::run() { | ||||
| 		Running_ = true; | ||||
| 		Utils::SetThreadName("fmwk:EventMgr"); | ||||
| 		auto Msg = std::make_shared<std::string>(MicroServiceMakeSystemEventMessage(KafkaTopics::ServiceEvents::EVENT_JOIN)); | ||||
| 		auto Msg = MicroServiceMakeSystemEventMessage(KafkaTopics::ServiceEvents::EVENT_JOIN); | ||||
| 		KafkaManager()->PostMessage(KafkaTopics::SERVICE_EVENTS, MicroServicePrivateEndPoint(), Msg, | ||||
| 									false); | ||||
| 		while (Running_) { | ||||
| 			Poco::Thread::trySleep((unsigned long)MicroServiceDaemonBusTimer()); | ||||
| 			if (!Running_) | ||||
| 				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(), | ||||
| 										Msg, false); | ||||
| 		} | ||||
| 		Msg = std::make_shared<std::string>(MicroServiceMakeSystemEventMessage(KafkaTopics::ServiceEvents::EVENT_LEAVE)); | ||||
| 		Msg = MicroServiceMakeSystemEventMessage(KafkaTopics::ServiceEvents::EVENT_LEAVE); | ||||
| 		KafkaManager()->PostMessage(KafkaTopics::SERVICE_EVENTS, MicroServicePrivateEndPoint(), Msg, | ||||
| 									false); | ||||
| 	}; | ||||
|   | ||||
| @@ -180,7 +180,7 @@ namespace OpenWifi { | ||||
| 							Consumer.async_commit(Msg); | ||||
| 						continue; | ||||
| 					} | ||||
| 					KafkaManager()->Dispatch(Msg.get_topic().c_str(), Msg.get_key(), std::make_shared<std::string>(Msg.get_payload())); | ||||
| 					KafkaManager()->Dispatch(Msg.get_topic(), Msg.get_key(), Msg.get_payload()); | ||||
| 					if (!AutoCommit) | ||||
| 						Consumer.async_commit(Msg); | ||||
| 				} | ||||
| @@ -212,8 +212,8 @@ namespace OpenWifi { | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	void KafkaProducer::Produce(const char *Topic, const std::string &Key, | ||||
| 								const std::shared_ptr<std::string> Payload) { | ||||
| 	void KafkaProducer::Produce(const std::string &Topic, const std::string &Key, | ||||
| 								const std::string &Payload) { | ||||
| 		std::lock_guard G(Mutex_); | ||||
| 		Queue_.enqueueNotification(new KafkaMessage(Topic, Key, Payload)); | ||||
| 	} | ||||
| @@ -275,8 +275,8 @@ namespace OpenWifi { | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	void KafkaDispatcher::Dispatch(const char *Topic, const std::string &Key, | ||||
| 								   const std::shared_ptr<std::string> Payload) { | ||||
| 	void KafkaDispatcher::Dispatch(const std::string &Topic, const std::string &Key, | ||||
| 								   const std::string &Payload) { | ||||
| 		std::lock_guard G(Mutex_); | ||||
| 		auto It = Notifiers_.find(Topic); | ||||
| 		if (It != Notifiers_.end()) { | ||||
| @@ -332,21 +332,20 @@ namespace OpenWifi { | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	void KafkaManager::PostMessage(const char *topic, const std::string &key, | ||||
| 								   const std::shared_ptr<std::string> PayLoad, bool WrapMessage) { | ||||
| 	void KafkaManager::PostMessage(const std::string &topic, const std::string &key, | ||||
| 								   const std::string &PayLoad, bool WrapMessage) { | ||||
| 		if (KafkaEnabled_) { | ||||
| 			ProducerThr_.Produce(topic, key, WrapMessage ? WrapSystemId(PayLoad) : PayLoad); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	void KafkaManager::Dispatch(const char *Topic, const std::string &Key, | ||||
| 								const std::shared_ptr<std::string> Payload) { | ||||
| 	void KafkaManager::Dispatch(const std::string &Topic, const std::string &Key, | ||||
| 								const 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; | ||||
| 	[[nodiscard]] std::string KafkaManager::WrapSystemId(const std::string &PayLoad) { | ||||
| 		return SystemInfoWrapper_ + PayLoad + "}"; | ||||
| 	} | ||||
|  | ||||
| 	uint64_t KafkaManager::RegisterTopicWatcher(const std::string &Topic, | ||||
|   | ||||
| @@ -18,17 +18,17 @@ namespace OpenWifi { | ||||
|  | ||||
| 	class KafkaMessage : public Poco::Notification { | ||||
| 	  public: | ||||
| 		KafkaMessage(const char * Topic, const std::string &Key, const std::shared_ptr<std::string> Payload) | ||||
| 			: Topic_(Topic), Key_(Key), Payload_(std::move(Payload)) {} | ||||
| 		KafkaMessage(const std::string &Topic, const std::string &Key, const std::string &Payload) | ||||
| 			: Topic_(Topic), Key_(Key), Payload_(Payload) {} | ||||
|  | ||||
| 		inline const char * Topic() { return Topic_; } | ||||
| 		inline const std::string &Topic() { return Topic_; } | ||||
| 		inline const std::string &Key() { return Key_; } | ||||
| 		inline const std::string &Payload() { return *Payload_; } | ||||
| 		inline const std::string &Payload() { return Payload_; } | ||||
|  | ||||
| 	  private: | ||||
| 		const char *Topic_; | ||||
| 		std::string Topic_; | ||||
| 		std::string Key_; | ||||
| 		std::shared_ptr<std::string> Payload_; | ||||
| 		std::string Payload_; | ||||
| 	}; | ||||
|  | ||||
| 	class KafkaProducer : public Poco::Runnable { | ||||
| @@ -36,7 +36,7 @@ namespace OpenWifi { | ||||
| 		void run() override; | ||||
| 		void Start(); | ||||
| 		void Stop(); | ||||
| 		void Produce(const char *Topic, const std::string &Key, const std::shared_ptr<std::string> Payload); | ||||
| 		void Produce(const std::string &Topic, const std::string &Key, const std::string &Payload); | ||||
|  | ||||
| 	  private: | ||||
| 		std::recursive_mutex Mutex_; | ||||
| @@ -63,7 +63,7 @@ namespace OpenWifi { | ||||
| 		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 Dispatch(const std::string &Topic, const std::string &Key, const std::string &Payload); | ||||
| 		void run() override; | ||||
| 		void Topics(std::vector<std::string> &T); | ||||
|  | ||||
| @@ -91,10 +91,10 @@ namespace OpenWifi { | ||||
| 		int Start() override; | ||||
| 		void Stop() override; | ||||
|  | ||||
| 		void PostMessage(const char *topic, const std::string &key, | ||||
| 						 const std::shared_ptr<std::string> PayLoad, bool WrapMessage = true); | ||||
| 		void Dispatch(const char *Topic, const std::string &Key, const std::shared_ptr<std::string> Payload); | ||||
| 		[[nodiscard]] const std::shared_ptr<std::string> WrapSystemId(const std::shared_ptr<std::string> PayLoad); | ||||
| 		void PostMessage(const std::string &topic, const std::string &key, | ||||
| 						 const std::string &PayLoad, bool WrapMessage = true); | ||||
| 		void Dispatch(const std::string &Topic, const std::string &Key, const std::string &Payload); | ||||
| 		[[nodiscard]] std::string WrapSystemId(const std::string &PayLoad); | ||||
| 		[[nodiscard]] inline bool Enabled() const { return KafkaEnabled_; } | ||||
| 		uint64_t RegisterTopicWatcher(const std::string &Topic, Types::TopicNotifyFunction &F); | ||||
| 		void UnregisterTopicWatcher(const std::string &Topic, uint64_t Id); | ||||
|   | ||||
| @@ -10,32 +10,32 @@ | ||||
|  | ||||
| #include <string> | ||||
| namespace OpenWifi::KafkaTopics { | ||||
| 	inline const char * HEALTHCHECK = "healthcheck"; | ||||
| 	inline const char * STATE = "state"; | ||||
| 	inline const char * CONNECTION = "connection"; | ||||
| 	inline const char * WIFISCAN = "wifiscan"; | ||||
| 	inline const char * ALERTS = "alerts"; | ||||
| 	inline const char * COMMAND = "command"; | ||||
| 	inline const char * SERVICE_EVENTS = "service_events"; | ||||
| 	inline const char * DEVICE_EVENT_QUEUE = "device_event_queue"; | ||||
| 	inline const char * DEVICE_TELEMETRY = "device_telemetry"; | ||||
| 	inline const char * PROVISIONING_CHANGE = "provisioning_change"; | ||||
| 	static const std::string HEALTHCHECK{"healthcheck"}; | ||||
| 	static const std::string STATE{"state"}; | ||||
| 	static const std::string CONNECTION{"connection"}; | ||||
| 	static const std::string WIFISCAN{"wifiscan"}; | ||||
| 	static const std::string ALERTS{"alerts"}; | ||||
| 	static const std::string COMMAND{"command"}; | ||||
| 	static const std::string SERVICE_EVENTS{"service_events"}; | ||||
| 	static const std::string DEVICE_EVENT_QUEUE{"device_event_queue"}; | ||||
| 	static const std::string DEVICE_TELEMETRY{"device_telemetry"}; | ||||
| 	static const std::string PROVISIONING_CHANGE{"provisioning_change"}; | ||||
|  | ||||
| 	namespace ServiceEvents { | ||||
| 		inline const char * EVENT_JOIN = "join"; | ||||
| 		inline const char * EVENT_LEAVE = "leave"; | ||||
| 		inline const char * EVENT_KEEP_ALIVE = "keep-alive"; | ||||
| 		inline const char * EVENT_REMOVE_TOKEN = "remove-token"; | ||||
| 		static const std::string EVENT_JOIN{"join"}; | ||||
| 		static const std::string EVENT_LEAVE{"leave"}; | ||||
| 		static const std::string EVENT_KEEP_ALIVE{"keep-alive"}; | ||||
| 		static const std::string EVENT_REMOVE_TOKEN{"remove-token"}; | ||||
|  | ||||
| 		namespace Fields { | ||||
| 			inline const char * EVENT = "event"; | ||||
| 			inline const char * ID = "id"; | ||||
| 			inline const char * TYPE = "type"; | ||||
| 			inline const char * PUBLIC = "publicEndPoint"; | ||||
| 			inline const char * PRIVATE = "privateEndPoint"; | ||||
| 			inline const char * KEY = "key"; | ||||
| 			inline const char * VRSN = "version"; | ||||
| 			inline const char * TOKEN = "token"; | ||||
| 			static const std::string EVENT{"event"}; | ||||
| 			static const std::string ID{"id"}; | ||||
| 			static const std::string TYPE{"type"}; | ||||
| 			static const std::string PUBLIC{"publicEndPoint"}; | ||||
| 			static const std::string PRIVATE{"privateEndPoint"}; | ||||
| 			static const std::string KEY{"key"}; | ||||
| 			static const std::string VRSN{"version"}; | ||||
| 			static const std::string TOKEN{"token"}; | ||||
| 		} // namespace Fields | ||||
| 	}	  // namespace ServiceEvents | ||||
| } // namespace OpenWifi::KafkaTopics | ||||
|   | ||||
| @@ -47,11 +47,11 @@ namespace OpenWifi { | ||||
|  | ||||
| 	void MicroServiceReload(const std::string &Type) { MicroService::instance().Reload(Type); } | ||||
|  | ||||
| 	Types::StringVec MicroServiceGetLogLevelNames() { | ||||
| 	const Types::StringVec MicroServiceGetLogLevelNames() { | ||||
| 		return MicroService::instance().GetLogLevelNames(); | ||||
| 	} | ||||
|  | ||||
| 	Types::StringVec MicroServiceGetSubSystems() { | ||||
| 	const Types::StringVec MicroServiceGetSubSystems() { | ||||
| 		return MicroService::instance().GetSubSystems(); | ||||
| 	} | ||||
|  | ||||
| @@ -79,7 +79,7 @@ namespace OpenWifi { | ||||
|  | ||||
| 	std::string MicroServiceGetUIURI() { return MicroService::instance().GetUIURI(); } | ||||
|  | ||||
| 	SubSystemVec MicroServiceGetFullSubSystems() { | ||||
| 	const SubSystemVec MicroServiceGetFullSubSystems() { | ||||
| 		return MicroService::instance().GetFullSubSystems(); | ||||
| 	} | ||||
|  | ||||
| @@ -87,7 +87,7 @@ namespace OpenWifi { | ||||
|  | ||||
| 	std::uint64_t MicroServiceDaemonBusTimer() { return MicroService::instance().DaemonBusTimer(); } | ||||
|  | ||||
| 	std::string MicroServiceMakeSystemEventMessage(const char *Type) { | ||||
| 	std::string MicroServiceMakeSystemEventMessage(const std::string &Type) { | ||||
| 		return MicroService::instance().MakeSystemEventMessage(Type); | ||||
| 	} | ||||
|  | ||||
|   | ||||
| @@ -31,8 +31,8 @@ namespace OpenWifi { | ||||
| 	void MicroServiceLoadConfigurationFile(); | ||||
| 	void MicroServiceReload(); | ||||
| 	void MicroServiceReload(const std::string &Type); | ||||
| 	Types::StringVec MicroServiceGetLogLevelNames(); | ||||
| 	Types::StringVec MicroServiceGetSubSystems(); | ||||
| 	const Types::StringVec MicroServiceGetLogLevelNames(); | ||||
| 	const Types::StringVec MicroServiceGetSubSystems(); | ||||
| 	Types::StringPairVec MicroServiceGetLogLevels(); | ||||
| 	bool MicroServiceSetSubsystemLogLevel(const std::string &SubSystem, const std::string &Level); | ||||
| 	void MicroServiceGetExtraConfiguration(Poco::JSON::Object &Answer); | ||||
| @@ -40,10 +40,10 @@ namespace OpenWifi { | ||||
| 	std::uint64_t MicroServiceUptimeTotalSeconds(); | ||||
| 	std::uint64_t MicroServiceStartTimeEpochTime(); | ||||
| 	std::string MicroServiceGetUIURI(); | ||||
| 	SubSystemVec MicroServiceGetFullSubSystems(); | ||||
| 	const SubSystemVec MicroServiceGetFullSubSystems(); | ||||
| 	std::string MicroServiceCreateUUID(); | ||||
| 	std::uint64_t MicroServiceDaemonBusTimer(); | ||||
| 	std::string MicroServiceMakeSystemEventMessage(const char *Type); | ||||
| 	std::string MicroServiceMakeSystemEventMessage(const std::string &Type); | ||||
| 	Poco::ThreadPool &MicroServiceTimerPool(); | ||||
| 	std::string MicroServiceConfigPath(const std::string &Key, const std::string &DefaultValue); | ||||
| 	std::string MicroServiceWWWAssetsDir(); | ||||
|   | ||||
| @@ -24,10 +24,9 @@ namespace OpenWifi { | ||||
| 							 Server, TransactionId, Internal) {} | ||||
| 		static auto PathName() { return std::list<std::string>{"/api/v1/system"}; } | ||||
|  | ||||
| 		inline void DoGet() final { | ||||
| 		inline void DoGet() { | ||||
| 			std::string Arg; | ||||
| 			if (HasParameter("command", Arg)) { | ||||
| 				if (Arg == "info") { | ||||
| 			if (HasParameter("command", Arg) && Arg == "info") { | ||||
| 				Poco::JSON::Object Answer; | ||||
| 				Answer.set(RESTAPI::Protocol::VERSION, MicroServiceVersion()); | ||||
| 				Answer.set(RESTAPI::Protocol::UPTIME, MicroServiceUptimeTotalSeconds()); | ||||
| @@ -65,23 +64,11 @@ namespace OpenWifi { | ||||
| 				Answer.set("certificates", Certificates); | ||||
| 				return ReturnObject(Answer); | ||||
| 			} | ||||
| 				if (Arg == "extraConfiguration") { | ||||
| 			if (GetBoolParameter("extraConfiguration")) { | ||||
| 				Poco::JSON::Object Answer; | ||||
| 				MicroServiceGetExtraConfiguration(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); | ||||
| 		} | ||||
|  | ||||
|   | ||||
| @@ -14,15 +14,8 @@ | ||||
| #include "framework/OpenWifiTypes.h" | ||||
| #include "framework/utils.h" | ||||
|  | ||||
| #include <RESTObjects/RESTAPI_SecurityObjects.h> | ||||
|  | ||||
| namespace OpenWifi::RESTAPI_utils { | ||||
|  | ||||
| 	inline bool IsRootOrAdmin(const SecurityObjects::UserInfo &UI) { | ||||
| 		return 	UI.userRole==SecurityObjects::ROOT || | ||||
| 				UI.userRole==SecurityObjects::ADMIN; | ||||
| 	} | ||||
|  | ||||
| 	inline void EmbedDocument(const std::string &ObjName, Poco::JSON::Object &Obj, | ||||
| 							  const std::string &ObjStr) { | ||||
| 		std::string D = ObjStr.empty() ? "{}" : ObjStr; | ||||
|   | ||||
| @@ -1,63 +0,0 @@ | ||||
| // | ||||
| // Created by stephane bourque on 2023-04-19. | ||||
| // | ||||
|  | ||||
| #pragma once | ||||
|  | ||||
| #include <vector> | ||||
| #include <string> | ||||
|  | ||||
| namespace OpenWifi { | ||||
| 	inline  const std::vector<std::pair<std::string, std::string>> DefaultDeviceTypeList{ | ||||
| 		{"actiontec_web7200", "AP"}, | ||||
| 		{"cig_wf186w", "AP"}, | ||||
| 		{"cig_wf188n", "AP"}, | ||||
| 		{"cig_wf194c4", "AP"}, | ||||
| 		{"cig_wf196", "AP"}, | ||||
| 		{"cig_wf196-ca", "AP"}, | ||||
| 		{"cig_wf196-ca-ath12", "AP"}, | ||||
| 		{"cig_wf196-us", "AP"}, | ||||
| 		{"cig_wf610d", "AP"}, | ||||
| 		{"cig_wf660a", "AP"}, | ||||
| 		{"cig_wf808", "AP"}, | ||||
| 		{"cybertan_eww622-a1", "AP"}, | ||||
| 		{"edgecore_eap101", "AP"}, | ||||
| 		{"edgecore_eap101-ath12", "AP"}, | ||||
| 		{"edgecore_eap102", "AP"}, | ||||
| 		{"edgecore_eap104", "AP"}, | ||||
| 		{"edgecore_eap104-ath12", "AP"}, | ||||
| 		{"edgecore_ecs4100-12ph", "AP"}, | ||||
| 		{"edgecore_ecw5211", "AP"}, | ||||
| 		{"edgecore_ecw5410", "AP"}, | ||||
| 		{"edgecore_oap100", "AP"}, | ||||
| 		{"edgecore_spw2ac1200", "SWITCH"}, | ||||
| 		{"edgecore_spw2ac1200-lan-poe", "SWITCH"}, | ||||
| 		{"edgecore_ssw2ac2600", "SWITCH"}, | ||||
| 		{"hfcl_ion4", "AP"}, | ||||
| 		{"hfcl_ion4x", "AP"}, | ||||
| 		{"hfcl_ion4x_2", "AP"}, | ||||
| 		{"hfcl_ion4xe", "AP"}, | ||||
| 		{"hfcl_ion4xi", "AP"}, | ||||
| 		{"indio_um-305ac", "AP"}, | ||||
| 		{"indio_um-305ax", "AP"}, | ||||
| 		{"indio_um-310ax-v1", "AP"}, | ||||
| 		{"indio_um-325ac", "AP"}, | ||||
| 		{"indio_um-510ac-v3", "AP"}, | ||||
| 		{"indio_um-510axm-v1", "AP"}, | ||||
| 		{"indio_um-510axp-v1", "AP"}, | ||||
| 		{"indio_um-550ac", "AP"}, | ||||
| 		{"linksys_e8450-ubi", "AP"}, | ||||
| 		{"linksys_ea6350-v4", "AP"}, | ||||
| 		{"linksys_ea8300", "AP"}, | ||||
| 		{"liteon_wpx8324", "AP"}, | ||||
| 		{"meshpp_s618_cp01", "AP"}, | ||||
| 		{"meshpp_s618_cp03", "AP"}, | ||||
| 		{"udaya_a5-id2", "AP"}, | ||||
| 		{"wallys_dr40x9", "AP"}, | ||||
| 		{"wallys_dr6018", "AP"}, | ||||
| 		{"wallys_dr6018_v4", "AP"}, | ||||
| 		{"x64_vm", "AP"}, | ||||
| 		{"yuncore_ax840", "AP"}, | ||||
| 		{"yuncore_fap640", "AP"}, | ||||
| 		{"yuncore_fap650", "AP"}}; | ||||
| } | ||||
| @@ -397,24 +397,6 @@ namespace OpenWifi::RESTAPI::Errors { | ||||
| 	static const struct msg FirmwareBDInProgress { | ||||
| 		1170, "Firmware DB update already in progress." | ||||
| 	}; | ||||
| 	static const struct msg SimulatedDeviceNotSupported { | ||||
| 		1171, "Command not supported on simulated device." | ||||
| 	}; | ||||
|  | ||||
|     static const struct msg VenuesNameAlreadyExists { | ||||
|             1172, "The venue name already exists." | ||||
|     }; | ||||
|  | ||||
|     static const struct msg DefFirmwareNameExists { 1172, "Firmware name already exists." }; | ||||
|  | ||||
|     static const struct msg SimulationDoesNotExist { | ||||
|         7000, "Simulation Instance ID does not exist." | ||||
|     }; | ||||
|  | ||||
|     static const struct msg SimulationIsAlreadyRunning { | ||||
|         7001, "There is an instance of this simulation already running.." | ||||
|     }; | ||||
|  | ||||
|  | ||||
| } // namespace OpenWifi::RESTAPI::Errors | ||||
|  | ||||
| @@ -572,7 +554,6 @@ namespace OpenWifi::uCentralProtocol { | ||||
| 	static const char *HEALTHCHECK = "healthcheck"; | ||||
| 	static const char *LOG = "log"; | ||||
| 	static const char *CRASHLOG = "crashlog"; | ||||
| 	static const char *REBOOTLOG = "rebootLog"; | ||||
| 	static const char *PING = "ping"; | ||||
| 	static const char *CFGPENDING = "cfgpending"; | ||||
| 	static const char *RECOVERY = "recovery"; | ||||
| @@ -631,8 +612,6 @@ namespace OpenWifi::uCentralProtocol { | ||||
| 	static const char *DEVICEUPDATE = "deviceupdate"; | ||||
| 	static const char *FWSIGNATURE = "FWsignature"; | ||||
| 	static const char *SIGNATURE = "signature"; | ||||
| 	static const char *INFO = "info"; | ||||
| 	static const char *DATE = "date"; | ||||
|  | ||||
| 	static const char *SERIALNUMBER = "serialNumber"; | ||||
| 	static const char *COMPATIBLE = "compatible"; | ||||
| @@ -663,7 +642,6 @@ namespace OpenWifi::uCentralProtocol::Events { | ||||
| 	static const char *HEALTHCHECK = "healthcheck"; | ||||
| 	static const char *LOG = "log"; | ||||
| 	static const char *CRASHLOG = "crashlog"; | ||||
| 	static const char *REBOOTLOG = "rebootLog"; | ||||
| 	static const char *PING = "ping"; | ||||
| 	static const char *CFGPENDING = "cfgpending"; | ||||
| 	static const char *RECOVERY = "recovery"; | ||||
| @@ -687,8 +665,7 @@ namespace OpenWifi::uCentralProtocol::Events { | ||||
| 		ET_VENUEBROADCAST, | ||||
| 		ET_EVENT, | ||||
| 		ET_WIFISCAN, | ||||
| 		ET_ALARM, | ||||
| 		ET_REBOOTLOG | ||||
| 		ET_ALARM | ||||
| 	}; | ||||
|  | ||||
| 	inline EVENT_MSG EventFromString(const std::string &Method) { | ||||
| @@ -719,10 +696,8 @@ namespace OpenWifi::uCentralProtocol::Events { | ||||
| 		else if (strcmp(WIFISCAN, Method.c_str()) == 0) | ||||
| 			return ET_WIFISCAN; | ||||
| 		else if (strcmp(ALARM, Method.c_str()) == 0) | ||||
| 			return ET_WIFISCAN; | ||||
| 		return ET_ALARM; | ||||
| 		else if (strcmp(REBOOTLOG, Method.c_str()) == 0) | ||||
| 			return ET_REBOOTLOG; | ||||
| 		return ET_UNKNOWN; | ||||
| 	}; | ||||
| } // namespace OpenWifi::uCentralProtocol::Events | ||||
|  | ||||
|   | ||||
| @@ -27,10 +27,6 @@ namespace OpenWifi::Utils { | ||||
| 				std::all_of(Serial.begin(), Serial.end(), [](auto i) { return std::isxdigit(i); })); | ||||
| 	} | ||||
|  | ||||
| 	[[nodiscard]] bool ValidSerialNumbers(const std::vector<std::string> &numbers) { | ||||
| 		return std::all_of(numbers.begin(),numbers.end(),[](auto &number) {return ValidSerialNumber(number);}); | ||||
| 	} | ||||
|  | ||||
| 	[[nodiscard]] bool ValidUUID(const std::string &UUID) { | ||||
| 		if (UUID.size() > 36) | ||||
| 			return false; | ||||
|   | ||||
| @@ -13,8 +13,6 @@ | ||||
| #include <string> | ||||
| #include <thread> | ||||
|  | ||||
| #include <dirent.h> | ||||
|  | ||||
| #include "Poco/Base64Decoder.h" | ||||
| #include "Poco/Base64Encoder.h" | ||||
| #include "Poco/File.h" | ||||
| @@ -70,7 +68,6 @@ namespace OpenWifi::Utils { | ||||
| 	}; | ||||
|  | ||||
| 	[[nodiscard]] bool ValidSerialNumber(const std::string &Serial); | ||||
| 	[[nodiscard]] bool ValidSerialNumbers(const std::vector<std::string> &Serial); | ||||
| 	[[nodiscard]] bool ValidUUID(const std::string &UUID); | ||||
| 	[[nodiscard]] bool ValidHostname(const std::string &hostname); | ||||
|  | ||||
| @@ -149,101 +146,4 @@ namespace OpenWifi::Utils { | ||||
|  | ||||
| 	bool ExtractBase64CompressedData(const std::string &CompressedData, | ||||
| 									 std::string &UnCompressedData, uint64_t compress_sz); | ||||
|  | ||||
| 	inline bool match(const char* first, const char* second) | ||||
| 	{ | ||||
| 		// If we reach at the end of both strings, we are done | ||||
| 		if (*first == '\0' && *second == '\0') | ||||
| 			return true; | ||||
|  | ||||
| 		// Make sure to eliminate consecutive '*' | ||||
| 		if (*first == '*') { | ||||
| 			while (*(first + 1) == '*') | ||||
| 				first++; | ||||
| 		} | ||||
|  | ||||
| 		// Make sure that the characters after '*' are present | ||||
| 		// in second string. This function assumes that the | ||||
| 		// first string will not contain two consecutive '*' | ||||
| 		if (*first == '*' && *(first + 1) != '\0' | ||||
| 			&& *second == '\0') | ||||
| 			return false; | ||||
|  | ||||
| 		// If the first string contains '?', or current | ||||
| 		// characters of both strings match | ||||
| 		if (*first == '?' || *first == *second) | ||||
| 			return match(first + 1, second + 1); | ||||
|  | ||||
| 		// If there is *, then there are two possibilities | ||||
| 		// a) We consider current character of second string | ||||
| 		// b) We ignore current character of second string. | ||||
| 		if (*first == '*') | ||||
| 			return match(first + 1, second) | ||||
| 				   || match(first, second + 1); | ||||
| 		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; | ||||
| 	} | ||||
|  | ||||
| } // namespace OpenWifi::Utils | ||||
|   | ||||
| @@ -435,18 +435,18 @@ | ||||
|                                                     regarding this application, | ||||
|                                                     please contact us at | ||||
|                                                     <a | ||||
|                                                         href="mailto:${USER_HELPER_EMAIL}" | ||||
|                                                         href="mailto:tip-keys@arilia.com" | ||||
|                                                         target="_blank" | ||||
|                                                     > | ||||
|                                                         ${USER_HELPER_EMAIL} | ||||
|                                                         tip-keys@arilia.com | ||||
|                                                     </a> | ||||
|                                                     . For question regarding the | ||||
|                                                     Telecom Infra Project, | ||||
|                                                     please contact us at | ||||
|                                                     <a | ||||
|                                                         href="mailto:${GLOBAL_USER_HELPER_EMAIL}" | ||||
|                                                         href="mailto:info@telecominfraproject.com" | ||||
|                                                     > | ||||
|                                                         ${GLOBAL_USER_HELPER_EMAIL} | ||||
|                                                         info@telecominfraproject.com | ||||
|                                                     </a> | ||||
|                                                     . | ||||
|                                                 </p> | ||||
| @@ -456,7 +456,7 @@ | ||||
|                                         <tr> | ||||
|                                             <td> | ||||
|                                                 <p>Thank You!</p> | ||||
|                                                 <p>${USER_SIGNATURE}</p> | ||||
|                                                 <p>Arilia Wireless Inc.</p> | ||||
|                                             </td> | ||||
|                                         </tr> | ||||
|                                         <tr> | ||||
| @@ -502,13 +502,13 @@ | ||||
|                                                     <tr> | ||||
|                                                         <p class="align-center"> | ||||
|                                                             Copyright 2023 | ||||
|                                                             ${USER_SIGNATURE}, | ||||
|                                                             Arilia Wireless Inc, | ||||
|                                                             All rights reserved. | ||||
|                                                         </p> | ||||
|                                                         <a | ||||
|                                                             href="https://${USER_HELPER_SITE}" | ||||
|                                                             href="https://arilia.com" | ||||
|                                                             target="_blank" | ||||
|                                                             >${USER_HELPER_SITE}</a | ||||
|                                                             >www.arilia.com</a | ||||
|                                                         > | ||||
|                                                     </tr> | ||||
|                                                 </tbody> | ||||
|   | ||||
| @@ -431,18 +431,18 @@ | ||||
|                                                     regarding this application, | ||||
|                                                     please contact us at | ||||
|                                                     <a | ||||
|                                                             href="mailto:${USER_HELPER_EMAIL}" | ||||
|                                                         href="mailto:tip-keys@arilia.com" | ||||
|                                                         target="_blank" | ||||
|                                                     > | ||||
|                                                         ${USER_HELPER_EMAIL} | ||||
|                                                         tip-keys@arilia.com | ||||
|                                                     </a> | ||||
|                                                     . For question regarding the | ||||
|                                                     Telecom Infra Project, | ||||
|                                                     please contact us at | ||||
|                                                     <a | ||||
|                                                             href="mailto:${GLOBAL_USER_HELPER_EMAIL}" | ||||
|                                                         href="mailto:info@telecominfraproject.com" | ||||
|                                                     > | ||||
|                                                         ${GLOBAL_USER_HELPER_EMAIL} | ||||
|                                                         info@telecominfraproject.com | ||||
|                                                     </a> | ||||
|                                                     . | ||||
|                                                 </p> | ||||
| @@ -452,7 +452,7 @@ | ||||
|                                         <tr> | ||||
|                                             <td> | ||||
|                                                 <p>Thank You!</p> | ||||
|                                                 <p>${USER_SIGNATURE}</p> | ||||
|                                                 <p>Arilia Wireless Inc.</p> | ||||
|                                             </td> | ||||
|                                         </tr> | ||||
|                                         <tr> | ||||
| @@ -498,13 +498,13 @@ | ||||
|                                                     <tr> | ||||
|                                                         <p class="align-center"> | ||||
|                                                             Copyright 2023 | ||||
|                                                         ${USER_SIGNATURE}, | ||||
|                                                             Arilia Wireless Inc, | ||||
|                                                             All rights reserved. | ||||
|                                                         </p> | ||||
|                                                         <a | ||||
|                                                             href="https://${USER_HELPER_SITE}" | ||||
|                                                             href="https://arilia.com" | ||||
|                                                             target="_blank" | ||||
|                                                     >${USER_HELPER_SITE}</a | ||||
|                                                             >www.arilia.com</a | ||||
|                                                         > | ||||
|                                                     </tr> | ||||
|                                                 </tbody> | ||||
|   | ||||
| @@ -435,18 +435,18 @@ | ||||
|                                                     regarding this application, | ||||
|                                                     please contact us at | ||||
|                                                     <a | ||||
|                                                             href="mailto:${USER_HELPER_EMAIL}" | ||||
|                                                         href="mailto:tip-keys@arilia.com" | ||||
|                                                         target="_blank" | ||||
|                                                     > | ||||
|                                                         ${USER_HELPER_EMAIL} | ||||
|                                                         tip-keys@arilia.com | ||||
|                                                     </a> | ||||
|                                                     . For question regarding the | ||||
|                                                     Telecom Infra Project, | ||||
|                                                     please contact us at | ||||
|                                                     <a | ||||
|                                                             href="mailto:${GLOBAL_USER_HELPER_EMAIL}" | ||||
|                                                         href="mailto:info@telecominfraproject.com" | ||||
|                                                     > | ||||
|                                                         ${GLOBAL_USER_HELPER_EMAIL} | ||||
|                                                         info@telecominfraproject.com | ||||
|                                                     </a> | ||||
|                                                     . | ||||
|                                                 </p> | ||||
| @@ -456,7 +456,7 @@ | ||||
|                                         <tr> | ||||
|                                             <td> | ||||
|                                                 <p>Thank You!</p> | ||||
|                                                 <p>${USER_SIGNATURE}</p> | ||||
|                                                 <p>Arilia Wireless Inc.</p> | ||||
|                                             </td> | ||||
|                                         </tr> | ||||
|                                         <tr> | ||||
| @@ -502,13 +502,13 @@ | ||||
|                                                     <tr> | ||||
|                                                         <p class="align-center"> | ||||
|                                                             Copyright 2023 | ||||
|                                                         ${USER_SIGNATURE}, | ||||
|                                                             Arilia Wireless Inc, | ||||
|                                                             All rights reserved. | ||||
|                                                         </p> | ||||
|                                                         <a | ||||
|                                                             href="https://${USER_HELPER_SITE}" | ||||
|                                                             href="https://arilia.com" | ||||
|                                                             target="_blank" | ||||
|                                                     >${USER_HELPER_SITE}</a | ||||
|                                                             >www.arilia.com</a | ||||
|                                                         > | ||||
|                                                     </tr> | ||||
|                                                 </tbody> | ||||
|   | ||||
| @@ -1,527 +0,0 @@ | ||||
| <html> | ||||
| <head> | ||||
|     <title>Email Confirmation</title> | ||||
|     <style> | ||||
|         img { | ||||
|             border: none; | ||||
|             -ms-interpolation-mode: bicubic; | ||||
|             max-width: 100%; | ||||
|         } | ||||
|  | ||||
|         body { | ||||
|             color: #414141; | ||||
|             background-color: #f6f6f6; | ||||
|             font-family: sans-serif; | ||||
|             -webkit-font-smoothing: antialiased; | ||||
|             font-size: 14px; | ||||
|             line-height: 1.4; | ||||
|             margin: 0; | ||||
|             padding: 0; | ||||
|             -ms-text-size-adjust: 100%; | ||||
|             -webkit-text-size-adjust: 100%; | ||||
|         } | ||||
|  | ||||
|         table { | ||||
|             border-collapse: separate; | ||||
|             width: 100%; | ||||
|             text-align: center; | ||||
|         } | ||||
|  | ||||
|         table td { | ||||
|             font-family: sans-serif; | ||||
|             font-size: 14px; | ||||
|             color: #414141; | ||||
|             vertical-align: top; | ||||
|         } | ||||
|  | ||||
|         .body { | ||||
|             background-color: white; | ||||
|             width: 100%; | ||||
|         } | ||||
|  | ||||
|         .container { | ||||
|             display: block; | ||||
|             margin: 0 auto !important; | ||||
|             max-width: 580px; | ||||
|             padding: 10px; | ||||
|             width: 580px; | ||||
|         } | ||||
|  | ||||
|         .content { | ||||
|             box-sizing: border-box; | ||||
|             display: block; | ||||
|             margin: 0 auto; | ||||
|             max-width: 580px; | ||||
|             padding: 10px; | ||||
|         } | ||||
|  | ||||
|         .main { | ||||
|             background: #ffffff; | ||||
|             border-radius: 0px; | ||||
|             width: 600px; | ||||
|             max-width: 100%; | ||||
|             border: 1px solid #d4d4d4; | ||||
|             padding-left: 45px; | ||||
|             padding-right: 45px; | ||||
|         } | ||||
|  | ||||
|         .wrapper { | ||||
|             box-sizing: border-box; | ||||
|             padding: 40px 20px; | ||||
|         } | ||||
|  | ||||
|         .content-block { | ||||
|             padding-bottom: 10px; | ||||
|             padding-top: 10px; | ||||
|         } | ||||
|  | ||||
|         .footer { | ||||
|             clear: both; | ||||
|             margin-top: 10px; | ||||
|             text-align: center; | ||||
|             width: 100%; | ||||
|         } | ||||
|  | ||||
|         .footer td, | ||||
|         .footer p, | ||||
|         .footer span, | ||||
|         .footer a { | ||||
|             color: #999999; | ||||
|             font-size: 12px; | ||||
|             text-align: center; | ||||
|         } | ||||
|         /* ------------------------------------- | ||||
|             TYPOGRAPHY | ||||
|         ------------------------------------- */ | ||||
|  | ||||
|         h1, | ||||
|         h2, | ||||
|         h3, | ||||
|         h4 { | ||||
|             color: #414141; | ||||
|             font-family: sans-serif; | ||||
|             font-weight: 400; | ||||
|             line-height: 1.4; | ||||
|             margin: 0; | ||||
|             margin-bottom: 30px; | ||||
|         } | ||||
|  | ||||
|         h2 { | ||||
|             font-weight: 600; | ||||
|         } | ||||
|  | ||||
|         h1 { | ||||
|             font-size: 35px; | ||||
|             font-weight: 300; | ||||
|             text-align: center; | ||||
|             text-transform: capitalize; | ||||
|         } | ||||
|  | ||||
|         p, | ||||
|         ul, | ||||
|         ol { | ||||
|             font-family: sans-serif; | ||||
|             font-size: 14px; | ||||
|             font-weight: normal; | ||||
|             margin: 0; | ||||
|             color: #414141; | ||||
|             margin-bottom: 15px; | ||||
|         } | ||||
|  | ||||
|         p li, | ||||
|         ul li, | ||||
|         ol li { | ||||
|             list-style-position: inside; | ||||
|             margin-left: 5px; | ||||
|             color: #414141; | ||||
|         } | ||||
|  | ||||
|         a { | ||||
|             color: #29818c !important; | ||||
|             text-decoration: none; | ||||
|             border-bottom: 1px solid #d2d2d2; | ||||
|         } | ||||
|  | ||||
|         .footer a { | ||||
|             color: #999999 !important; | ||||
|         } | ||||
|         /* ------------------------------------- | ||||
|             BUTTONS | ||||
|         ------------------------------------- */ | ||||
|  | ||||
|         .btn { | ||||
|             box-sizing: border-box; | ||||
|             width: 100%; | ||||
|         } | ||||
|  | ||||
|         tbody { | ||||
|             text-align: left; | ||||
|         } | ||||
|  | ||||
|         .btn > tbody > tr > td { | ||||
|             padding-bottom: 15px; | ||||
|         } | ||||
|  | ||||
|         .btn table { | ||||
|             width: auto; | ||||
|         } | ||||
|  | ||||
|         .btn table td { | ||||
|             background-color: #ffffff; | ||||
|             border-radius: 20px; | ||||
|             text-align: center; | ||||
|         } | ||||
|  | ||||
|         .btn a { | ||||
|             background-color: #ffffff; | ||||
|             border: solid 1px #489e94; | ||||
|             border-radius: 5px; | ||||
|             box-sizing: border-box; | ||||
|             color: #29818c; | ||||
|             cursor: pointer; | ||||
|             display: inline-block; | ||||
|             font-size: 14px; | ||||
|             font-weight: bold; | ||||
|             margin: 0; | ||||
|             padding: 12px 120px; | ||||
|             text-decoration: none; | ||||
|             font-weight: 600; | ||||
|             text-transform: uppercase; | ||||
|         } | ||||
|  | ||||
|         .btn-primary a { | ||||
|             transition: background-color 250ms cubic-bezier(0.4, 0, 0.2, 1) | ||||
|             0ms, | ||||
|             box-shadow 250ms cubic-bezier(0.4, 0, 0.2, 1) 0ms, | ||||
|             border 250ms cubic-bezier(0.4, 0, 0.2, 1) 0ms; | ||||
|             margin: auto; | ||||
|             background-color: #29818c; | ||||
|             border-color: #29818c; | ||||
|             color: #ffffff !important; | ||||
|         } | ||||
|         /* ------------------------------------- | ||||
|             OTHER STYLES THAT MIGHT BE USEFUL | ||||
|         ------------------------------------- */ | ||||
|  | ||||
|         .align-center { | ||||
|             text-align: center; | ||||
|         } | ||||
|  | ||||
|         .preheader { | ||||
|             color: transparent; | ||||
|             display: none; | ||||
|             height: 0; | ||||
|             max-height: 0; | ||||
|             max-width: 0; | ||||
|             opacity: 0; | ||||
|             overflow: hidden; | ||||
|             visibility: hidden; | ||||
|             width: 0; | ||||
|         } | ||||
|  | ||||
|         hr { | ||||
|             border: 0; | ||||
|             border-bottom: 1px solid #d4d4d4; | ||||
|         } | ||||
|  | ||||
|         .grayFont { | ||||
|             color: #999999; | ||||
|         } | ||||
|  | ||||
|         .bold { | ||||
|             font-weight: 600; | ||||
|         } | ||||
|  | ||||
|         /* ------------------------------------- | ||||
|             RESPONSIVE AND MOBILE FRIENDLY STYLES | ||||
|         ------------------------------------- */ | ||||
|  | ||||
|         @media only screen and (max-width: 620px) { | ||||
|             table[class='body'] h1 { | ||||
|                 font-size: 28px !important; | ||||
|                 margin-bottom: 10px !important; | ||||
|             } | ||||
|             table[class='body'] p, | ||||
|             table[class='body'] ul, | ||||
|             table[class='body'] ol, | ||||
|             table[class='body'] td, | ||||
|             table[class='body'] span, | ||||
|             table[class='body'] a { | ||||
|                 font-size: 16px !important; | ||||
|             } | ||||
|             table[class='body'] .wrapper, | ||||
|             table[class='body'] .article { | ||||
|                 padding: 10px !important; | ||||
|             } | ||||
|             table[class='body'] .content { | ||||
|                 padding: 0 !important; | ||||
|             } | ||||
|             table[class='body'] .container { | ||||
|                 padding: 0 !important; | ||||
|                 width: 100% !important; | ||||
|             } | ||||
|             table[class='body'] .main { | ||||
|                 border-left-width: 0 !important; | ||||
|                 border-radius: 0 !important; | ||||
|                 border-right-width: 0 !important; | ||||
|             } | ||||
|             table[class='body'] .btn table { | ||||
|                 width: 100% !important; | ||||
|             } | ||||
|             table[class='body'] .btn a { | ||||
|                 width: 100% !important; | ||||
|             } | ||||
|             table[class='body'] .img-responsive { | ||||
|                 height: auto !important; | ||||
|                 max-width: 100% !important; | ||||
|                 width: auto !important; | ||||
|             } | ||||
|         } | ||||
|         /* ------------------------------------- | ||||
|             PRESERVE THESE STYLES IN THE HEAD | ||||
|         ------------------------------------- */ | ||||
|  | ||||
|         @media all { | ||||
|             .ExternalClass { | ||||
|                 width: 100%; | ||||
|             } | ||||
|             .ExternalClass, | ||||
|             .ExternalClass p, | ||||
|             .ExternalClass span, | ||||
|             .ExternalClass font, | ||||
|             .ExternalClass td, | ||||
|             .ExternalClass div { | ||||
|                 line-height: 100%; | ||||
|             } | ||||
|             .apple-link a { | ||||
|                 color: inherit !important; | ||||
|                 font-family: inherit !important; | ||||
|                 font-size: inherit !important; | ||||
|                 font-weight: inherit !important; | ||||
|                 line-height: inherit !important; | ||||
|                 text-decoration: none !important; | ||||
|             } | ||||
|             .btn-primary a:hover { | ||||
|                 background-color: rgb(50, 110, 103) !important; | ||||
|                 border-color: rgb(50, 110, 103) !important; | ||||
|             } | ||||
|         } | ||||
|     </style> | ||||
| </head> | ||||
| <body class=""> | ||||
| <span class="preheader"></span> | ||||
| <table | ||||
|         d="" | ||||
|         role="presentation" | ||||
|         border="0" | ||||
|         cellpadding="0" | ||||
|         cellspacing="0" | ||||
|         class="body" | ||||
| > | ||||
|     <tr> | ||||
|         <td class="container"> | ||||
|             <div class="content"> | ||||
|                 <!-- START CENTERED WHITE CONTAINER --> | ||||
|  | ||||
|                 <table | ||||
|                         border="0" | ||||
|                         cellpadding="0" | ||||
|                         cellspacing="0" | ||||
|                         width="100%" | ||||
|                         style="min-width: 100%" | ||||
|                 > | ||||
|                     <tbody> | ||||
|                     <tr> | ||||
|                         <td valign="top" style="padding: 0px"> | ||||
|                             <table | ||||
|                                     align="center" | ||||
|                                     style="text-align: center" | ||||
|                                     width="100%" | ||||
|                                     border="0" | ||||
|                                     cellpadding="0" | ||||
|                                     cellspacing="0" | ||||
|                                     style="min-width: 100%" | ||||
|                             > | ||||
|                                 <tbody> | ||||
|                                 <tr> | ||||
|                                     <td | ||||
|                                             valign="top" | ||||
|                                             class="align-center" | ||||
|                                             style=" | ||||
|                                                             padding-right: 0px; | ||||
|                                                             padding-left: 48px; | ||||
|                                                             padding-top: 0; | ||||
|                                                             padding-bottom: 0; | ||||
|                                                         " | ||||
|                                     > | ||||
|                                         <img | ||||
|                                                 align="center" | ||||
|                                                 alt="OpenWifi" | ||||
|                                                 src="${LOGO}" | ||||
|                                                 style=" | ||||
|                                                                 max-width: 100%; | ||||
|                                                                 padding-bottom: 0; | ||||
|                                                                 display: inline !important; | ||||
|                                                                 vertical-align: bottom; | ||||
|                                                             " | ||||
|                                         /> | ||||
|                                     </td> | ||||
|                                 </tr> | ||||
|                                 </tbody> | ||||
|                             </table> | ||||
|                         </td> | ||||
|                     </tr> | ||||
|                     </tbody> | ||||
|                 </table> | ||||
|                 <table role="presentation" class="main"> | ||||
|                     <!-- START MAIN CONTENT AREA --> | ||||
|                     <tr> | ||||
|                         <td class="wrapper"> | ||||
|                             <table | ||||
|                                     role="presentation" | ||||
|                                     border="0" | ||||
|                                     cellpadding="0" | ||||
|                                     cellspacing="0" | ||||
|                             > | ||||
|                                 <tr> | ||||
|                                     <td> | ||||
|                                         <h2> | ||||
|                                             Confirm Your Email Address | ||||
|                                             to Get Started | ||||
|                                         </h2> | ||||
|                                     </td> | ||||
|                                 </tr> | ||||
|                                 <tr> | ||||
|                                     <td> | ||||
|                                         <p>Dear ${RECIPIENT_EMAIL} ,</p> | ||||
|                                         <p> | ||||
|                                             Before you can access the | ||||
|                                             system, you must validate | ||||
|                                             your e-mail address. Please | ||||
|                                             click on the button below to | ||||
|                                             complete this task. | ||||
|                                         </p> | ||||
|                                     </td> | ||||
|                                 </tr> | ||||
|                                 <tr> | ||||
|                                     <td | ||||
|                                             style=" | ||||
|                                                     padding-top: 15px; | ||||
|                                                     padding-bottom: 40px; | ||||
|                                                 " | ||||
|                                             class="btn btn-primary" | ||||
|                                     > | ||||
|                                         <a | ||||
|                                                 href="${ACTION_LINK}" | ||||
|                                                 target="_blank" | ||||
|                                         >Confirm Email Address</a | ||||
|                                         > | ||||
|                                     </td> | ||||
|                                 </tr> | ||||
|                                 <tr> | ||||
|                                     <td> | ||||
|                                         <hr | ||||
|                                                 style=" | ||||
|                                                         margin-top: 0px; | ||||
|                                                         margin-bottom: 30px; | ||||
|                                                     " | ||||
|                                         /> | ||||
|                                     </td> | ||||
|                                 </tr> | ||||
|                                 <tr> | ||||
|                                     <td> | ||||
|                                         <p> | ||||
|                                             For questions & support | ||||
|                                             regarding this application, | ||||
|                                             please contact us at | ||||
|                                             <a | ||||
|                                                     href="mailto:${SUB_HELPER_EMAIL}" | ||||
|                                                     target="_blank" | ||||
|                                             > | ||||
|                                                 ${SUB_HELPER_EMAIL} | ||||
|                                             </a> | ||||
|                                             . For question regarding the | ||||
|                                             Telecom Infra Project, | ||||
|                                             please contact us at | ||||
|                                             <a | ||||
|                                                     href="mailto:${GLOBAL_SUB_HELPER_EMAIL}" | ||||
|                                             > | ||||
|                                                 ${GLOBAL_SUB_HELPER_EMAIL} | ||||
|                                             </a> | ||||
|                                             . | ||||
|                                         </p> | ||||
|                                     </td> | ||||
|                                 </tr> | ||||
|  | ||||
|                                 <tr> | ||||
|                                     <td> | ||||
|                                         <p>Thank You!</p> | ||||
|                                         <p>${SUB_SIGNATURE}</p> | ||||
|                                     </td> | ||||
|                                 </tr> | ||||
|                                 <tr> | ||||
|                                     <table | ||||
|                                             role="presentation" | ||||
|                                             border="0" | ||||
|                                             cellpadding="0" | ||||
|                                             cellspacing="0" | ||||
|                                             class="btn btn-primary" | ||||
|                                     > | ||||
|                                         <tbody></tbody> | ||||
|                                     </table> | ||||
|                                 </tr> | ||||
|                             </table> | ||||
|                         </td> | ||||
|                     </tr> | ||||
|                     <!-- END MAIN CONTENT AREA --> | ||||
|                 </table> | ||||
|  | ||||
|                 <!-- END CENTERED WHITE CONTAINER --> | ||||
|  | ||||
|                 <div class="footer"> | ||||
|                     <table | ||||
|                             border="0" | ||||
|                             cellpadding="0" | ||||
|                             cellspacing="0" | ||||
|                             width="100%" | ||||
|                             style="min-width: 100; margin-top: 30px" | ||||
|                     > | ||||
|                         <tbody> | ||||
|                         <tr> | ||||
|                             <td valign="top" style="padding: 0px"> | ||||
|                                 <table | ||||
|                                         align="left" | ||||
|                                         width="100%" | ||||
|                                         border="0" | ||||
|                                         cellpadding="0" | ||||
|                                         cellspacing="0" | ||||
|                                         style="min-width: 100%" | ||||
|                                 > | ||||
|                                     <tbody> | ||||
|                                     <tr></tr> | ||||
|                                     <tr> | ||||
|                                         <p class="align-center"> | ||||
|                                             Copyright 2023 | ||||
|                                             ${SUB_SIGNATURE}, | ||||
|                                             All rights reserved. | ||||
|                                         </p> | ||||
|                                         <a | ||||
|                                                 href="https://${SUB_HELPER_SITE}" | ||||
|                                                 target="_blank" | ||||
|                                         >${SUB_HELPER_SITE}</a | ||||
|                                         > | ||||
|                                     </tr> | ||||
|                                     </tbody> | ||||
|                                 </table> | ||||
|                             </td> | ||||
|                         </tr> | ||||
|                         </tbody> | ||||
|                     </table> | ||||
|                 </div> | ||||
|             </div> | ||||
|         </td> | ||||
|         <td> </td> | ||||
|     </tr> | ||||
| </table> | ||||
| </body> | ||||
| </html> | ||||
|   | ||||
| @@ -1,9 +0,0 @@ | ||||
| Dear ${RECIPIENT_EMAIL}, | ||||
|  | ||||
|     Before you can access the system, you must validate your e-mail address. Please click on the link below to complete this task. | ||||
|  | ||||
|         ${ACTION_LINK} | ||||
|  | ||||
|     And follow the instructions. | ||||
|  | ||||
| Thank you! | ||||
| @@ -1,523 +0,0 @@ | ||||
| <html> | ||||
| <head> | ||||
|     <title>Password Reset</title> | ||||
|     <style> | ||||
|         img { | ||||
|             border: none; | ||||
|             -ms-interpolation-mode: bicubic; | ||||
|             max-width: 100%; | ||||
|         } | ||||
|  | ||||
|         body { | ||||
|             color: #414141; | ||||
|             background-color: #f6f6f6; | ||||
|             font-family: sans-serif; | ||||
|             -webkit-font-smoothing: antialiased; | ||||
|             font-size: 14px; | ||||
|             line-height: 1.4; | ||||
|             margin: 0; | ||||
|             padding: 0; | ||||
|             -ms-text-size-adjust: 100%; | ||||
|             -webkit-text-size-adjust: 100%; | ||||
|         } | ||||
|  | ||||
|         table { | ||||
|             border-collapse: separate; | ||||
|             width: 100%; | ||||
|             text-align: center; | ||||
|         } | ||||
|  | ||||
|         table td { | ||||
|             font-family: sans-serif; | ||||
|             font-size: 14px; | ||||
|             color: #414141; | ||||
|             vertical-align: top; | ||||
|         } | ||||
|  | ||||
|         .body { | ||||
|             background-color: white; | ||||
|             width: 100%; | ||||
|         } | ||||
|  | ||||
|         .container { | ||||
|             display: block; | ||||
|             margin: 0 auto !important; | ||||
|             max-width: 580px; | ||||
|             padding: 10px; | ||||
|             width: 580px; | ||||
|         } | ||||
|  | ||||
|         .content { | ||||
|             box-sizing: border-box; | ||||
|             display: block; | ||||
|             margin: 0 auto; | ||||
|             max-width: 580px; | ||||
|             padding: 10px; | ||||
|         } | ||||
|  | ||||
|         .main { | ||||
|             background: #ffffff; | ||||
|             border-radius: 0px; | ||||
|             width: 600px; | ||||
|             max-width: 100%; | ||||
|             border: 1px solid #d4d4d4; | ||||
|             padding-left: 45px; | ||||
|             padding-right: 45px; | ||||
|         } | ||||
|  | ||||
|         .wrapper { | ||||
|             box-sizing: border-box; | ||||
|             padding: 40px 20px; | ||||
|         } | ||||
|  | ||||
|         .content-block { | ||||
|             padding-bottom: 10px; | ||||
|             padding-top: 10px; | ||||
|         } | ||||
|  | ||||
|         .footer { | ||||
|             clear: both; | ||||
|             margin-top: 10px; | ||||
|             text-align: center; | ||||
|             width: 100%; | ||||
|         } | ||||
|  | ||||
|         .footer td, | ||||
|         .footer p, | ||||
|         .footer span, | ||||
|         .footer a { | ||||
|             color: #999999; | ||||
|             font-size: 12px; | ||||
|             text-align: center; | ||||
|         } | ||||
|         /* ------------------------------------- | ||||
|             TYPOGRAPHY | ||||
|         ------------------------------------- */ | ||||
|  | ||||
|         h1, | ||||
|         h2, | ||||
|         h3, | ||||
|         h4 { | ||||
|             color: #414141; | ||||
|             font-family: sans-serif; | ||||
|             font-weight: 400; | ||||
|             line-height: 1.4; | ||||
|             margin: 0; | ||||
|             margin-bottom: 30px; | ||||
|         } | ||||
|  | ||||
|         h2 { | ||||
|             font-weight: 600; | ||||
|         } | ||||
|  | ||||
|         h1 { | ||||
|             font-size: 35px; | ||||
|             font-weight: 300; | ||||
|             text-align: center; | ||||
|             text-transform: capitalize; | ||||
|         } | ||||
|  | ||||
|         p, | ||||
|         ul, | ||||
|         ol { | ||||
|             font-family: sans-serif; | ||||
|             font-size: 14px; | ||||
|             font-weight: normal; | ||||
|             margin: 0; | ||||
|             color: #414141; | ||||
|             margin-bottom: 15px; | ||||
|         } | ||||
|  | ||||
|         p li, | ||||
|         ul li, | ||||
|         ol li { | ||||
|             list-style-position: inside; | ||||
|             margin-left: 5px; | ||||
|             color: #414141; | ||||
|         } | ||||
|  | ||||
|         a { | ||||
|             color: #29818c !important; | ||||
|             text-decoration: none; | ||||
|             border-bottom: 1px solid #d2d2d2; | ||||
|         } | ||||
|  | ||||
|         .footer a { | ||||
|             color: #999999 !important; | ||||
|         } | ||||
|         /* ------------------------------------- | ||||
|             BUTTONS | ||||
|         ------------------------------------- */ | ||||
|  | ||||
|         .btn { | ||||
|             box-sizing: border-box; | ||||
|             width: 100%; | ||||
|         } | ||||
|  | ||||
|         tbody { | ||||
|             text-align: left; | ||||
|         } | ||||
|  | ||||
|         .btn > tbody > tr > td { | ||||
|             padding-bottom: 15px; | ||||
|         } | ||||
|  | ||||
|         .btn table { | ||||
|             width: auto; | ||||
|         } | ||||
|  | ||||
|         .btn table td { | ||||
|             background-color: #ffffff; | ||||
|             border-radius: 20px; | ||||
|             text-align: center; | ||||
|         } | ||||
|  | ||||
|         .btn a { | ||||
|             background-color: #ffffff; | ||||
|             border: solid 1px #489e94; | ||||
|             border-radius: 5px; | ||||
|             box-sizing: border-box; | ||||
|             color: #29818c; | ||||
|             cursor: pointer; | ||||
|             display: inline-block; | ||||
|             font-size: 14px; | ||||
|             font-weight: bold; | ||||
|             margin: 0; | ||||
|             padding: 12px 120px; | ||||
|             text-decoration: none; | ||||
|             font-weight: 600; | ||||
|             text-transform: uppercase; | ||||
|         } | ||||
|  | ||||
|         .btn-primary a { | ||||
|             transition: background-color 250ms cubic-bezier(0.4, 0, 0.2, 1) | ||||
|             0ms, | ||||
|             box-shadow 250ms cubic-bezier(0.4, 0, 0.2, 1) 0ms, | ||||
|             border 250ms cubic-bezier(0.4, 0, 0.2, 1) 0ms; | ||||
|             margin: auto; | ||||
|             background-color: #29818c; | ||||
|             border-color: #29818c; | ||||
|             color: #ffffff !important; | ||||
|         } | ||||
|         /* ------------------------------------- | ||||
|             OTHER STYLES THAT MIGHT BE USEFUL | ||||
|         ------------------------------------- */ | ||||
|  | ||||
|         .align-center { | ||||
|             text-align: center; | ||||
|         } | ||||
|  | ||||
|         .preheader { | ||||
|             color: transparent; | ||||
|             display: none; | ||||
|             height: 0; | ||||
|             max-height: 0; | ||||
|             max-width: 0; | ||||
|             opacity: 0; | ||||
|             overflow: hidden; | ||||
|             visibility: hidden; | ||||
|             width: 0; | ||||
|         } | ||||
|  | ||||
|         hr { | ||||
|             border: 0; | ||||
|             border-bottom: 1px solid #d4d4d4; | ||||
|         } | ||||
|  | ||||
|         .grayFont { | ||||
|             color: #999999; | ||||
|         } | ||||
|  | ||||
|         .bold { | ||||
|             font-weight: 600; | ||||
|         } | ||||
|  | ||||
|         /* ------------------------------------- | ||||
|             RESPONSIVE AND MOBILE FRIENDLY STYLES | ||||
|         ------------------------------------- */ | ||||
|  | ||||
|         @media only screen and (max-width: 620px) { | ||||
|             table[class='body'] h1 { | ||||
|                 font-size: 28px !important; | ||||
|                 margin-bottom: 10px !important; | ||||
|             } | ||||
|             table[class='body'] p, | ||||
|             table[class='body'] ul, | ||||
|             table[class='body'] ol, | ||||
|             table[class='body'] td, | ||||
|             table[class='body'] span, | ||||
|             table[class='body'] a { | ||||
|                 font-size: 16px !important; | ||||
|             } | ||||
|             table[class='body'] .wrapper, | ||||
|             table[class='body'] .article { | ||||
|                 padding: 10px !important; | ||||
|             } | ||||
|             table[class='body'] .content { | ||||
|                 padding: 0 !important; | ||||
|             } | ||||
|             table[class='body'] .container { | ||||
|                 padding: 0 !important; | ||||
|                 width: 100% !important; | ||||
|             } | ||||
|             table[class='body'] .main { | ||||
|                 border-left-width: 0 !important; | ||||
|                 border-radius: 0 !important; | ||||
|                 border-right-width: 0 !important; | ||||
|             } | ||||
|             table[class='body'] .btn table { | ||||
|                 width: 100% !important; | ||||
|             } | ||||
|             table[class='body'] .btn a { | ||||
|                 width: 100% !important; | ||||
|             } | ||||
|             table[class='body'] .img-responsive { | ||||
|                 height: auto !important; | ||||
|                 max-width: 100% !important; | ||||
|                 width: auto !important; | ||||
|             } | ||||
|         } | ||||
|         /* ------------------------------------- | ||||
|             PRESERVE THESE STYLES IN THE HEAD | ||||
|         ------------------------------------- */ | ||||
|  | ||||
|         @media all { | ||||
|             .ExternalClass { | ||||
|                 width: 100%; | ||||
|             } | ||||
|             .ExternalClass, | ||||
|             .ExternalClass p, | ||||
|             .ExternalClass span, | ||||
|             .ExternalClass font, | ||||
|             .ExternalClass td, | ||||
|             .ExternalClass div { | ||||
|                 line-height: 100%; | ||||
|             } | ||||
|             .apple-link a { | ||||
|                 color: inherit !important; | ||||
|                 font-family: inherit !important; | ||||
|                 font-size: inherit !important; | ||||
|                 font-weight: inherit !important; | ||||
|                 line-height: inherit !important; | ||||
|                 text-decoration: none !important; | ||||
|             } | ||||
|             .btn-primary a:hover { | ||||
|                 background-color: rgb(50, 110, 103) !important; | ||||
|                 border-color: rgb(50, 110, 103) !important; | ||||
|             } | ||||
|         } | ||||
|     </style> | ||||
| </head> | ||||
| <body class=""> | ||||
| <span class="preheader"></span> | ||||
| <table | ||||
|         d="" | ||||
|         role="presentation" | ||||
|         border="0" | ||||
|         cellpadding="0" | ||||
|         cellspacing="0" | ||||
|         class="body" | ||||
| > | ||||
|     <tr> | ||||
|         <td class="container"> | ||||
|             <div class="content"> | ||||
|                 <!-- START CENTERED WHITE CONTAINER --> | ||||
|  | ||||
|                 <table | ||||
|                         border="0" | ||||
|                         cellpadding="0" | ||||
|                         cellspacing="0" | ||||
|                         width="100%" | ||||
|                         style="min-width: 100%" | ||||
|                 > | ||||
|                     <tbody> | ||||
|                     <tr> | ||||
|                         <td valign="top" style="padding: 0px"> | ||||
|                             <table | ||||
|                                     align="center" | ||||
|                                     style="text-align: center" | ||||
|                                     width="100%" | ||||
|                                     border="0" | ||||
|                                     cellpadding="0" | ||||
|                                     cellspacing="0" | ||||
|                                     style="min-width: 100%" | ||||
|                             > | ||||
|                                 <tbody> | ||||
|                                 <tr> | ||||
|                                     <td | ||||
|                                             valign="top" | ||||
|                                             class="align-center" | ||||
|                                             style=" | ||||
|                                                             padding-right: 0px; | ||||
|                                                             padding-left: 48px; | ||||
|                                                             padding-top: 0; | ||||
|                                                             padding-bottom: 0; | ||||
|                                                         " | ||||
|                                     > | ||||
|                                         <img | ||||
|                                                 align="center" | ||||
|                                                 alt="OpenWifi" | ||||
|                                                 src="${LOGO}" | ||||
|                                                 style=" | ||||
|                                                                 max-width: 100%; | ||||
|                                                                 padding-bottom: 0; | ||||
|                                                                 display: inline !important; | ||||
|                                                                 vertical-align: bottom; | ||||
|                                                             " | ||||
|                                         /> | ||||
|                                     </td> | ||||
|                                 </tr> | ||||
|                                 </tbody> | ||||
|                             </table> | ||||
|                         </td> | ||||
|                     </tr> | ||||
|                     </tbody> | ||||
|                 </table> | ||||
|                 <table role="presentation" class="main"> | ||||
|                     <!-- START MAIN CONTENT AREA --> | ||||
|                     <tr> | ||||
|                         <td class="wrapper"> | ||||
|                             <table | ||||
|                                     role="presentation" | ||||
|                                     border="0" | ||||
|                                     cellpadding="0" | ||||
|                                     cellspacing="0" | ||||
|                             > | ||||
|                                 <tr> | ||||
|                                     <td> | ||||
|                                         <h2>Password Reset</h2> | ||||
|                                     </td> | ||||
|                                 </tr> | ||||
|                                 <tr> | ||||
|                                     <td> | ||||
|                                         <p>Dear ${RECIPIENT_EMAIL} ,</p> | ||||
|                                         <p> | ||||
|                                             You have requested us to | ||||
|                                             reset your password. Please | ||||
|                                             click on the link below and | ||||
|                                             follow the instructions. | ||||
|                                         </p> | ||||
|                                     </td> | ||||
|                                 </tr> | ||||
|                                 <tr> | ||||
|                                     <td | ||||
|                                             style=" | ||||
|                                                     padding-top: 15px; | ||||
|                                                     padding-bottom: 40px; | ||||
|                                                 " | ||||
|                                             class="btn btn-primary" | ||||
|                                     > | ||||
|                                         <a | ||||
|                                                 href="${ACTION_LINK}" | ||||
|                                                 target="_blank" | ||||
|                                         >Reset Password</a | ||||
|                                         > | ||||
|                                     </td> | ||||
|                                 </tr> | ||||
|                                 <tr> | ||||
|                                     <td> | ||||
|                                         <hr | ||||
|                                                 style=" | ||||
|                                                         margin-top: 0px; | ||||
|                                                         margin-bottom: 30px; | ||||
|                                                     " | ||||
|                                         /> | ||||
|                                     </td> | ||||
|                                 </tr> | ||||
|                                 <tr> | ||||
|                                     <td> | ||||
|                                         <p> | ||||
|                                             For questions & support | ||||
|                                             regarding this application, | ||||
|                                             please contact us at | ||||
|                                             <a | ||||
|                                                     href="mailto:${SUB_HELPER_EMAIL}" | ||||
|                                                     target="_blank" | ||||
|                                             > | ||||
|                                                 ${SUB_HELPER_EMAIL} | ||||
|                                             </a> | ||||
|                                             . For question regarding the | ||||
|                                             Telecom Infra Project, | ||||
|                                             please contact us at | ||||
|                                             <a | ||||
|                                                     href="mailto:${GLOBAL_SUB_HELPER_EMAIL}" | ||||
|                                             > | ||||
|                                                 ${GLOBAL_SUB_HELPER_EMAIL} | ||||
|                                             </a> | ||||
|                                             . | ||||
|                                         </p> | ||||
|                                     </td> | ||||
|                                 </tr> | ||||
|  | ||||
|                                 <tr> | ||||
|                                     <td> | ||||
|                                         <p>Thank You!</p> | ||||
|                                         <p>${SUB_SIGNATURE}</p> | ||||
|                                     </td> | ||||
|                                 </tr> | ||||
|                                 <tr> | ||||
|                                     <table | ||||
|                                             role="presentation" | ||||
|                                             border="0" | ||||
|                                             cellpadding="0" | ||||
|                                             cellspacing="0" | ||||
|                                             class="btn btn-primary" | ||||
|                                     > | ||||
|                                         <tbody></tbody> | ||||
|                                     </table> | ||||
|                                 </tr> | ||||
|                             </table> | ||||
|                         </td> | ||||
|                     </tr> | ||||
|                     <!-- END MAIN CONTENT AREA --> | ||||
|                 </table> | ||||
|  | ||||
|                 <!-- END CENTERED WHITE CONTAINER --> | ||||
|  | ||||
|                 <div class="footer"> | ||||
|                     <table | ||||
|                             border="0" | ||||
|                             cellpadding="0" | ||||
|                             cellspacing="0" | ||||
|                             width="100%" | ||||
|                             style="min-width: 100; margin-top: 30px" | ||||
|                     > | ||||
|                         <tbody> | ||||
|                         <tr> | ||||
|                             <td valign="top" style="padding: 0px"> | ||||
|                                 <table | ||||
|                                         align="left" | ||||
|                                         width="100%" | ||||
|                                         border="0" | ||||
|                                         cellpadding="0" | ||||
|                                         cellspacing="0" | ||||
|                                         style="min-width: 100%" | ||||
|                                 > | ||||
|                                     <tbody> | ||||
|                                     <tr></tr> | ||||
|                                     <tr> | ||||
|                                         <p class="align-center"> | ||||
|                                             Copyright 2023 | ||||
|                                             ${SUB_SIGNATURE}, | ||||
|                                             All rights reserved. | ||||
|                                         </p> | ||||
|                                         <a | ||||
|                                                 href="https://${SUB_HELPER_SITE}" | ||||
|                                                 target="_blank" | ||||
|                                         >${SUB_HELPER_SITE}</a | ||||
|                                         > | ||||
|                                     </tr> | ||||
|                                     </tbody> | ||||
|                                 </table> | ||||
|                             </td> | ||||
|                         </tr> | ||||
|                         </tbody> | ||||
|                     </table> | ||||
|                 </div> | ||||
|             </div> | ||||
|         </td> | ||||
|         <td> </td> | ||||
|     </tr> | ||||
| </table> | ||||
| </body> | ||||
| </html> | ||||
|   | ||||
| @@ -1,9 +0,0 @@ | ||||
| Dear ${RECIPIENT_EMAIL}, | ||||
|  | ||||
|     You have requested us to reset your password. Please click on the link below | ||||
|  | ||||
|         ${ACTION_LINK} | ||||
|  | ||||
|     And follow the instructions. | ||||
|  | ||||
| Thank you! | ||||
| @@ -1,515 +0,0 @@ | ||||
| <html> | ||||
| <head> | ||||
|     <title>Verification Code</title> | ||||
|     <style> | ||||
|         img { | ||||
|             border: none; | ||||
|             -ms-interpolation-mode: bicubic; | ||||
|             max-width: 100%; | ||||
|         } | ||||
|  | ||||
|         body { | ||||
|             color: #414141; | ||||
|             background-color: #f6f6f6; | ||||
|             font-family: sans-serif; | ||||
|             -webkit-font-smoothing: antialiased; | ||||
|             font-size: 14px; | ||||
|             line-height: 1.4; | ||||
|             margin: 0; | ||||
|             padding: 0; | ||||
|             -ms-text-size-adjust: 100%; | ||||
|             -webkit-text-size-adjust: 100%; | ||||
|         } | ||||
|  | ||||
|         table { | ||||
|             border-collapse: separate; | ||||
|             width: 100%; | ||||
|             text-align: center; | ||||
|         } | ||||
|  | ||||
|         table td { | ||||
|             font-family: sans-serif; | ||||
|             font-size: 14px; | ||||
|             color: #414141; | ||||
|             vertical-align: top; | ||||
|         } | ||||
|  | ||||
|         .body { | ||||
|             background-color: white; | ||||
|             width: 100%; | ||||
|         } | ||||
|  | ||||
|         .container { | ||||
|             display: block; | ||||
|             margin: 0 auto !important; | ||||
|             max-width: 580px; | ||||
|             padding: 10px; | ||||
|             width: 580px; | ||||
|         } | ||||
|  | ||||
|         .content { | ||||
|             box-sizing: border-box; | ||||
|             display: block; | ||||
|             margin: 0 auto; | ||||
|             max-width: 580px; | ||||
|             padding: 10px; | ||||
|         } | ||||
|  | ||||
|         .main { | ||||
|             background: #ffffff; | ||||
|             border-radius: 0px; | ||||
|             width: 600px; | ||||
|             max-width: 100%; | ||||
|             border: 1px solid #d4d4d4; | ||||
|             padding-left: 45px; | ||||
|             padding-right: 45px; | ||||
|         } | ||||
|  | ||||
|         .wrapper { | ||||
|             box-sizing: border-box; | ||||
|             padding: 40px 20px; | ||||
|         } | ||||
|  | ||||
|         .content-block { | ||||
|             padding-bottom: 10px; | ||||
|             padding-top: 10px; | ||||
|         } | ||||
|  | ||||
|         .footer { | ||||
|             clear: both; | ||||
|             margin-top: 10px; | ||||
|             text-align: center; | ||||
|             width: 100%; | ||||
|         } | ||||
|  | ||||
|         .footer td, | ||||
|         .footer p, | ||||
|         .footer span, | ||||
|         .footer a { | ||||
|             color: #999999; | ||||
|             font-size: 12px; | ||||
|             text-align: center; | ||||
|         } | ||||
|         /* ------------------------------------- | ||||
|             TYPOGRAPHY | ||||
|         ------------------------------------- */ | ||||
|  | ||||
|         h1, | ||||
|         h2, | ||||
|         h3, | ||||
|         h4 { | ||||
|             color: #414141; | ||||
|             font-family: sans-serif; | ||||
|             font-weight: 400; | ||||
|             line-height: 1.4; | ||||
|             margin: 0; | ||||
|             margin-bottom: 30px; | ||||
|         } | ||||
|  | ||||
|         h2 { | ||||
|             font-weight: 600; | ||||
|         } | ||||
|  | ||||
|         h1 { | ||||
|             font-size: 35px; | ||||
|             font-weight: 300; | ||||
|             text-align: center; | ||||
|             text-transform: capitalize; | ||||
|         } | ||||
|  | ||||
|         p, | ||||
|         ul, | ||||
|         ol { | ||||
|             font-family: sans-serif; | ||||
|             font-size: 14px; | ||||
|             font-weight: normal; | ||||
|             margin: 0; | ||||
|             color: #414141; | ||||
|             margin-bottom: 15px; | ||||
|         } | ||||
|  | ||||
|         p li, | ||||
|         ul li, | ||||
|         ol li { | ||||
|             list-style-position: inside; | ||||
|             margin-left: 5px; | ||||
|             color: #414141; | ||||
|         } | ||||
|  | ||||
|         a { | ||||
|             color: #29818c !important; | ||||
|             text-decoration: none; | ||||
|             border-bottom: 1px solid #d2d2d2; | ||||
|         } | ||||
|  | ||||
|         .footer a { | ||||
|             color: #999999 !important; | ||||
|         } | ||||
|         /* ------------------------------------- | ||||
|             BUTTONS | ||||
|         ------------------------------------- */ | ||||
|  | ||||
|         .btn { | ||||
|             box-sizing: border-box; | ||||
|             width: 100%; | ||||
|         } | ||||
|  | ||||
|         tbody { | ||||
|             text-align: left; | ||||
|         } | ||||
|  | ||||
|         .btn > tbody > tr > td { | ||||
|             padding-bottom: 15px; | ||||
|         } | ||||
|  | ||||
|         .btn table { | ||||
|             width: auto; | ||||
|         } | ||||
|  | ||||
|         .btn table td { | ||||
|             background-color: #ffffff; | ||||
|             border-radius: 20px; | ||||
|             text-align: center; | ||||
|         } | ||||
|  | ||||
|         .btn a { | ||||
|             background-color: #ffffff; | ||||
|             border: solid 1px #489e94; | ||||
|             border-radius: 5px; | ||||
|             box-sizing: border-box; | ||||
|             color: #29818c; | ||||
|             cursor: pointer; | ||||
|             display: inline-block; | ||||
|             font-size: 14px; | ||||
|             font-weight: bold; | ||||
|             margin: 0; | ||||
|             padding: 12px 120px; | ||||
|             text-decoration: none; | ||||
|             font-weight: 600; | ||||
|             text-transform: uppercase; | ||||
|         } | ||||
|  | ||||
|         .btn-primary a { | ||||
|             transition: background-color 250ms cubic-bezier(0.4, 0, 0.2, 1) | ||||
|             0ms, | ||||
|             box-shadow 250ms cubic-bezier(0.4, 0, 0.2, 1) 0ms, | ||||
|             border 250ms cubic-bezier(0.4, 0, 0.2, 1) 0ms; | ||||
|             margin: auto; | ||||
|             background-color: #29818c; | ||||
|             border-color: #29818c; | ||||
|             color: #ffffff !important; | ||||
|         } | ||||
|         /* ------------------------------------- | ||||
|             OTHER STYLES THAT MIGHT BE USEFUL | ||||
|         ------------------------------------- */ | ||||
|  | ||||
|         .align-center { | ||||
|             text-align: center; | ||||
|         } | ||||
|  | ||||
|         .preheader { | ||||
|             color: transparent; | ||||
|             display: none; | ||||
|             height: 0; | ||||
|             max-height: 0; | ||||
|             max-width: 0; | ||||
|             opacity: 0; | ||||
|             overflow: hidden; | ||||
|             visibility: hidden; | ||||
|             width: 0; | ||||
|         } | ||||
|  | ||||
|         hr { | ||||
|             border: 0; | ||||
|             border-bottom: 1px solid #d4d4d4; | ||||
|         } | ||||
|  | ||||
|         .grayFont { | ||||
|             color: #999999; | ||||
|         } | ||||
|  | ||||
|         .bold { | ||||
|             font-weight: 600; | ||||
|         } | ||||
|  | ||||
|         /* ------------------------------------- | ||||
|             RESPONSIVE AND MOBILE FRIENDLY STYLES | ||||
|         ------------------------------------- */ | ||||
|  | ||||
|         @media only screen and (max-width: 620px) { | ||||
|             table[class='body'] h1 { | ||||
|                 font-size: 28px !important; | ||||
|                 margin-bottom: 10px !important; | ||||
|             } | ||||
|             table[class='body'] p, | ||||
|             table[class='body'] ul, | ||||
|             table[class='body'] ol, | ||||
|             table[class='body'] td, | ||||
|             table[class='body'] span, | ||||
|             table[class='body'] a { | ||||
|                 font-size: 16px !important; | ||||
|             } | ||||
|             table[class='body'] .wrapper, | ||||
|             table[class='body'] .article { | ||||
|                 padding: 10px !important; | ||||
|             } | ||||
|             table[class='body'] .content { | ||||
|                 padding: 0 !important; | ||||
|             } | ||||
|             table[class='body'] .container { | ||||
|                 padding: 0 !important; | ||||
|                 width: 100% !important; | ||||
|             } | ||||
|             table[class='body'] .main { | ||||
|                 border-left-width: 0 !important; | ||||
|                 border-radius: 0 !important; | ||||
|                 border-right-width: 0 !important; | ||||
|             } | ||||
|             table[class='body'] .btn table { | ||||
|                 width: 100% !important; | ||||
|             } | ||||
|             table[class='body'] .btn a { | ||||
|                 width: 100% !important; | ||||
|             } | ||||
|             table[class='body'] .img-responsive { | ||||
|                 height: auto !important; | ||||
|                 max-width: 100% !important; | ||||
|                 width: auto !important; | ||||
|             } | ||||
|         } | ||||
|         /* ------------------------------------- | ||||
|             PRESERVE THESE STYLES IN THE HEAD | ||||
|         ------------------------------------- */ | ||||
|  | ||||
|         @media all { | ||||
|             .ExternalClass { | ||||
|                 width: 100%; | ||||
|             } | ||||
|             .ExternalClass, | ||||
|             .ExternalClass p, | ||||
|             .ExternalClass span, | ||||
|             .ExternalClass font, | ||||
|             .ExternalClass td, | ||||
|             .ExternalClass div { | ||||
|                 line-height: 100%; | ||||
|             } | ||||
|             .apple-link a { | ||||
|                 color: inherit !important; | ||||
|                 font-family: inherit !important; | ||||
|                 font-size: inherit !important; | ||||
|                 font-weight: inherit !important; | ||||
|                 line-height: inherit !important; | ||||
|                 text-decoration: none !important; | ||||
|             } | ||||
|             .btn-primary a:hover { | ||||
|                 background-color: rgb(50, 110, 103) !important; | ||||
|                 border-color: rgb(50, 110, 103) !important; | ||||
|             } | ||||
|         } | ||||
|     </style> | ||||
| </head> | ||||
| <body class=""> | ||||
| <span class="preheader"></span> | ||||
| <table | ||||
|         d="" | ||||
|         role="presentation" | ||||
|         border="0" | ||||
|         cellpadding="0" | ||||
|         cellspacing="0" | ||||
|         class="body" | ||||
| > | ||||
|     <tr> | ||||
|         <td class="container"> | ||||
|             <div class="content"> | ||||
|                 <!-- START CENTERED WHITE CONTAINER --> | ||||
|  | ||||
|                 <table | ||||
|                         border="0" | ||||
|                         cellpadding="0" | ||||
|                         cellspacing="0" | ||||
|                         width="100%" | ||||
|                         style="min-width: 100%" | ||||
|                 > | ||||
|                     <tbody> | ||||
|                     <tr> | ||||
|                         <td valign="top" style="padding: 0px"> | ||||
|                             <table | ||||
|                                     align="center" | ||||
|                                     style="text-align: center" | ||||
|                                     width="100%" | ||||
|                                     border="0" | ||||
|                                     cellpadding="0" | ||||
|                                     cellspacing="0" | ||||
|                                     style="min-width: 100%" | ||||
|                             > | ||||
|                                 <tbody> | ||||
|                                 <tr> | ||||
|                                     <td | ||||
|                                             valign="top" | ||||
|                                             class="align-center" | ||||
|                                             style=" | ||||
|                                                             padding-right: 0px; | ||||
|                                                             padding-left: 48px; | ||||
|                                                             padding-top: 0; | ||||
|                                                             padding-bottom: 0; | ||||
|                                                         " | ||||
|                                     > | ||||
|                                         <img | ||||
|                                                 align="center" | ||||
|                                                 alt="OpenWifi" | ||||
|                                                 src="${LOGO}" | ||||
|                                                 style=" | ||||
|                                                                 max-width: 100%; | ||||
|                                                                 padding-bottom: 0; | ||||
|                                                                 display: inline !important; | ||||
|                                                                 vertical-align: bottom; | ||||
|                                                             " | ||||
|                                         /> | ||||
|                                     </td> | ||||
|                                 </tr> | ||||
|                                 </tbody> | ||||
|                             </table> | ||||
|                         </td> | ||||
|                     </tr> | ||||
|                     </tbody> | ||||
|                 </table> | ||||
|                 <table role="presentation" class="main"> | ||||
|                     <!-- START MAIN CONTENT AREA --> | ||||
|                     <tr> | ||||
|                         <td class="wrapper"> | ||||
|                             <table | ||||
|                                     role="presentation" | ||||
|                                     border="0" | ||||
|                                     cellpadding="0" | ||||
|                                     cellspacing="0" | ||||
|                             > | ||||
|                                 <tr> | ||||
|                                     <td> | ||||
|                                         <h2>Your Login Validation Code</h2> | ||||
|                                     </td> | ||||
|                                 </tr> | ||||
|                                 <tr> | ||||
|                                     <td> | ||||
|                                         <p>Dear ${RECIPIENT_EMAIL} ,</p> | ||||
|                                         <p> | ||||
|                                             You have requested your login validation. Please enter the following code on the login screen: | ||||
|                                         </p> | ||||
|                                         <p> | ||||
|                                         <div style="text-align: center;"> | ||||
|                                             <h3 style="margin-bottom: 0px; font-weight: bold;">${CHALLENGE_CODE}</h3> | ||||
|                                         </div> | ||||
|                                         </p> | ||||
|                                         <p> | ||||
|                                             If you are not trying to login, please login and change your password. Someone may be trying to | ||||
|                                             access your account illegally. | ||||
|                                         </p> | ||||
|                                     </td> | ||||
|                                 </tr> | ||||
|  | ||||
|                                 <tr> | ||||
|                                     <td> | ||||
|                                         <hr | ||||
|                                                 style=" | ||||
|                                                         margin-top: 0px; | ||||
|                                                         margin-bottom: 30px; | ||||
|                                                     " | ||||
|                                         /> | ||||
|                                     </td> | ||||
|                                 </tr> | ||||
|                                 <tr> | ||||
|                                     <td> | ||||
|                                         <p> | ||||
|                                             For questions & support | ||||
|                                             regarding this application, | ||||
|                                             please contact us at | ||||
|                                             <a | ||||
|                                                     href="mailto:${SUB_HELPER_EMAIL}" | ||||
|                                                     target="_blank" | ||||
|                                             > | ||||
|                                                 ${SUB_HELPER_EMAIL} | ||||
|                                             </a> | ||||
|                                             . For question regarding the | ||||
|                                             Telecom Infra Project, | ||||
|                                             please contact us at | ||||
|                                             <a | ||||
|                                                     href="mailto:${GLOBAL_SUB_HELPER_EMAIL}" | ||||
|                                             > | ||||
|                                                 ${GLOBAL_SUB_HELPER_EMAIL} | ||||
|                                             </a> | ||||
|                                             . | ||||
|                                         </p> | ||||
|                                     </td> | ||||
|                                 </tr> | ||||
|  | ||||
|                                 <tr> | ||||
|                                     <td> | ||||
|                                         <p>Thank You!</p> | ||||
|                                         <p>${SUB_SIGNATURE}</p> | ||||
|                                     </td> | ||||
|                                 </tr> | ||||
|                                 <tr> | ||||
|                                     <table | ||||
|                                             role="presentation" | ||||
|                                             border="0" | ||||
|                                             cellpadding="0" | ||||
|                                             cellspacing="0" | ||||
|                                             class="btn btn-primary" | ||||
|                                     > | ||||
|                                         <tbody></tbody> | ||||
|                                     </table> | ||||
|                                 </tr> | ||||
|                             </table> | ||||
|                         </td> | ||||
|                     </tr> | ||||
|                     <!-- END MAIN CONTENT AREA --> | ||||
|                 </table> | ||||
|  | ||||
|                 <!-- END CENTERED WHITE CONTAINER --> | ||||
|  | ||||
|                 <div class="footer"> | ||||
|                     <table | ||||
|                             border="0" | ||||
|                             cellpadding="0" | ||||
|                             cellspacing="0" | ||||
|                             width="100%" | ||||
|                             style="min-width: 100; margin-top: 30px" | ||||
|                     > | ||||
|                         <tbody> | ||||
|                         <tr> | ||||
|                             <td valign="top" style="padding: 0px"> | ||||
|                                 <table | ||||
|                                         align="left" | ||||
|                                         width="100%" | ||||
|                                         border="0" | ||||
|                                         cellpadding="0" | ||||
|                                         cellspacing="0" | ||||
|                                         style="min-width: 100%" | ||||
|                                 > | ||||
|                                     <tbody> | ||||
|                                     <tr></tr> | ||||
|                                     <tr> | ||||
|                                         <p class="align-center"> | ||||
|                                             Copyright 2023 | ||||
|                                             ${SUB_SIGNATURE}, | ||||
|                                             All rights reserved. | ||||
|                                         </p> | ||||
|                                         <a | ||||
|                                                 href="https://${SUB_HELPER_SITE}" | ||||
|                                                 target="_blank" | ||||
|                                         >${SUB_HELPER_SITE}</a | ||||
|                                         > | ||||
|                                     </tr> | ||||
|                                     </tbody> | ||||
|                                 </table> | ||||
|                             </td> | ||||
|                         </tr> | ||||
|                         </tbody> | ||||
|                     </table> | ||||
|                 </div> | ||||
|             </div> | ||||
|         </td> | ||||
|         <td> </td> | ||||
|     </tr> | ||||
| </table> | ||||
| </body> | ||||
| </html> | ||||
|   | ||||
| @@ -1,10 +0,0 @@ | ||||
| Dear ${RECIPIENT_EMAIL}, | ||||
|  | ||||
|     You have requested your login validation. Please enter the following code on the login screen: | ||||
|  | ||||
|         ${CHALLENGE_CODE} | ||||
|  | ||||
|     If you are not trying to login, please login and change your password. Someone may be trying to | ||||
|     access your account illegally. | ||||
|  | ||||
| Thank you! | ||||
| @@ -423,18 +423,18 @@ | ||||
|                                                     regarding this application, | ||||
|                                                     please contact us at | ||||
|                                                     <a | ||||
|                                                             href="mailto:${USER_HELPER_EMAIL}" | ||||
|                                                         href="mailto:tip-keys@arilia.com" | ||||
|                                                         target="_blank" | ||||
|                                                     > | ||||
|                                                         ${USER_HELPER_EMAIL} | ||||
|                                                         tip-keys@arilia.com | ||||
|                                                     </a> | ||||
|                                                     . For question regarding the | ||||
|                                                     Telecom Infra Project, | ||||
|                                                     please contact us at | ||||
|                                                     <a | ||||
|                                                             href="mailto:${GLOBAL_USER_HELPER_EMAIL}" | ||||
|                                                         href="mailto:info@telecominfraproject.com" | ||||
|                                                     > | ||||
|                                                         ${GLOBAL_USER_HELPER_EMAIL} | ||||
|                                                         info@telecominfraproject.com | ||||
|                                                     </a> | ||||
|                                                     . | ||||
|                                                 </p> | ||||
| @@ -444,7 +444,7 @@ | ||||
|                                         <tr> | ||||
|                                             <td> | ||||
|                                                 <p>Thank You!</p> | ||||
|                                                 <p>${USER_SIGNATURE}</p> | ||||
|                                                 <p>Arilia Wireless Inc.</p> | ||||
|                                             </td> | ||||
|                                         </tr> | ||||
|                                         <tr> | ||||
| @@ -490,13 +490,13 @@ | ||||
|                                                     <tr> | ||||
|                                                         <p class="align-center"> | ||||
|                                                             Copyright 2023 | ||||
|                                                             ${USER_SIGNATURE}, | ||||
|                                                             Arilia Wireless Inc, | ||||
|                                                             All rights reserved. | ||||
|                                                         </p> | ||||
|                                                         <a | ||||
|                                                                 href="https://${USER_HELPER_SITE}" | ||||
|                                                             href="https://arilia.com" | ||||
|                                                             target="_blank" | ||||
|                                                         >${USER_HELPER_SITE}</a | ||||
|                                                             >www.arilia.com</a | ||||
|                                                         > | ||||
|                                                     </tr> | ||||
|                                                 </tbody> | ||||
|   | ||||
| @@ -2,10 +2,10 @@ | ||||
| <div class="footer"> | ||||
|   <p> | ||||
|     For questions & support regarding this application, please contact us at | ||||
|     <a href="mailto:${USER_HELPER_EMAIL}" target="_blank">${USER_HELPER_EMAIL}</a>. | ||||
|     <a href="mailto:tip-keys@arilia.com" target="_blank">tip-keys@arilia.com</a>. | ||||
|     For question regarding the Telecom Infra Project, please contact us at | ||||
|     <a href="mailto:${GLOBAL_USER_HELPER_EMAIL}"> | ||||
|       ${GLOBAL_USER_HELPER_EMAIL} | ||||
|     <a href="mailto:info@telecominfraproject.com"> | ||||
|         info@telecominfraproject.com | ||||
|     </a>. | ||||
|   </p> | ||||
| </div> | ||||
| @@ -16,7 +16,6 @@ | ||||
| <div class="info-card"> | ||||
|     <h2 class="info-title">Reset Password</h2> | ||||
|     <form action="/api/v1/actionLink?action=password_reset" method="post" onsubmit="return validatePassword()" class="form-container"> | ||||
|         <input type="hidden" id="custId" name="id" value="${UUID}"> | ||||
|         <div class="form-control"> | ||||
|             <label class="form-label" for="password1" ><b>New Password</b></label> | ||||
|             <input class="form-input" id="password1" type="password" placeholder="New password" name="password1" pattern="${PASSWORD_VALIDATION}" required> | ||||
|   | ||||
| @@ -1,171 +0,0 @@ | ||||
| body {font-family: Arial, Helvetica, sans-serif;} | ||||
|  | ||||
| input[type=text], input[type=password] { | ||||
|   width: 100%; | ||||
|   padding: 12px 20px; | ||||
|   margin: 8px 0; | ||||
|   display: inline-block; | ||||
|   border: 1px solid #ccc; | ||||
|   box-sizing: border-box; | ||||
| } | ||||
|  | ||||
| button { | ||||
|   background-color: #04AA6D; | ||||
|   color: white; | ||||
|   padding: 14px 20px; | ||||
|   margin: 8px 0; | ||||
|   border: none; | ||||
|   cursor: pointer; | ||||
|   width: 100%; | ||||
| } | ||||
|  | ||||
| button:hover { | ||||
|   opacity: 0.8; | ||||
| } | ||||
|  | ||||
| .logo-grid { | ||||
|   display: grid; | ||||
|   grid-template-columns: 20% 60% 20%; | ||||
|   margin-top: calc(10vh) | ||||
| } | ||||
|  | ||||
| .logo-grid > div > img { | ||||
|   width: 100%; | ||||
|   height: 100%; | ||||
|   max-height: 200px; | ||||
|   object-fit: contain; | ||||
| } | ||||
|  | ||||
|  | ||||
| .info-card { | ||||
|   padding: 30px; | ||||
|   box-shadow: 0 4px 8px 0 rgba(0,0,0,0.2); | ||||
|   display: block; | ||||
|   width: 50%; | ||||
|   min-width: 400px; | ||||
|   border: 1em; | ||||
|   background-color: white; | ||||
|   width: 40%; | ||||
|   height: auto; | ||||
|   margin-left: auto; | ||||
|   margin-right: auto; | ||||
|   margin-bottom: auto; | ||||
|   margin-top: 50px; | ||||
|   position: relative; | ||||
|   border-radius: 15px; | ||||
| } | ||||
|  | ||||
| .info-list { | ||||
|   margin-left: 5%; | ||||
| } | ||||
|  | ||||
| .info-title { | ||||
|   margin-left: 5%; | ||||
|   color: #63B3ED; | ||||
| } | ||||
|  | ||||
| .flex-box { | ||||
|   display: flex; | ||||
|   flex-direction: row; | ||||
|   justify-content: left; | ||||
|   align-items: center; | ||||
|   margin-left: 5%; | ||||
|   margin-top: 6px; | ||||
|   margin-bottom: 6px; | ||||
|   min-height: 30px | ||||
| } | ||||
|  | ||||
| .flex-box > h3 { | ||||
|   margin-right: 4px; | ||||
|   margin-top: 5px; | ||||
|   margin-bottom: 5px; | ||||
| } | ||||
|  | ||||
| .container { | ||||
|   padding: 16px; | ||||
| } | ||||
|  | ||||
| span.password1 { | ||||
|   float: right; | ||||
|   padding-top: 16px; | ||||
| } | ||||
|  | ||||
| body { | ||||
|   background-color: #ebedef; | ||||
| } | ||||
|  | ||||
| /* Change styles for span and cancel button on extra small screens */ | ||||
| @media screen and (max-width: 300px) { | ||||
|   span.password1 { | ||||
|     display: block; | ||||
|     float: none; | ||||
|   } | ||||
|   .cancelbtn { | ||||
|     width: 100%; | ||||
|   } | ||||
| } | ||||
|  | ||||
| .form-container { | ||||
|   border: 0px; | ||||
|   margin-left: 5%; | ||||
| } | ||||
|  | ||||
| .form-label { | ||||
|     float: left; | ||||
| } | ||||
|  | ||||
| .form-input { | ||||
|   border-radius: 15px; | ||||
| } | ||||
|  | ||||
| .form-control { | ||||
|   margin-bottom: 6px; | ||||
| } | ||||
|  | ||||
| .form-submit-btn { | ||||
|     display: inline-flex; | ||||
|     appearance: none; | ||||
|     -webkit-box-align: center; | ||||
|     align-items: center; | ||||
|     -webkit-box-pack: center; | ||||
|     justify-content: center; | ||||
|     -webkit-user-select: none; | ||||
|     position: relative; | ||||
|     white-space: nowrap; | ||||
|     vertical-align: middle; | ||||
|     outline-color: transparent; | ||||
|     outline-style: solid; | ||||
|     outline-width: 2px; | ||||
|     outline-offset: 2px; | ||||
|     line-height: 1.2; | ||||
|     border-top-left-radius: 15px; | ||||
|     border-top-right-radius: 15px; | ||||
|     border-bottom-right-radius: 15px; | ||||
|     border-bottom-left-radius: 15px; | ||||
|     height: 45px; | ||||
|     background-color:#4299E1; | ||||
|     font-size: 15px; | ||||
|     padding-inline-start: 16px; | ||||
|     padding-inline-end: 16px; | ||||
|     width: 100%; | ||||
|     margin-bottom: 20px; | ||||
|     color: white; | ||||
|     margin-top: 20px; | ||||
| } | ||||
|  | ||||
| .footer{ | ||||
|   display: flex; | ||||
|   flex-direction: row; | ||||
|   justify-content: left; | ||||
|   align-items: center; | ||||
|   margin-left: 5%; | ||||
| } | ||||
|  | ||||
| hr.rounded { | ||||
|   margin-top: 40px; | ||||
|   margin-bottom: 0px; | ||||
|   margin-left: 5%; | ||||
|   margin-right: 5%; | ||||
|   border-top: 1px solid #bbb; | ||||
|   border-radius: 5px; | ||||
| } | ||||
| @@ -2,10 +2,10 @@ | ||||
| <div class="footer"> | ||||
|   <p> | ||||
|     For questions & support regarding this application, please contact us at | ||||
|     <a href="mailto:${SUB_HELPER_EMAIL}" target="_blank">${SUB_HELPER_EMAIL}</a>. | ||||
|     <a href="mailto:tip-keys@arilia.com" target="_blank">tip-keys@arilia.com</a>. | ||||
|     For question regarding the Telecom Infra Project, please contact us at | ||||
|     <a href="mailto:${GLOBAL_SUB_HELPER_EMAIL}"> | ||||
|       ${GLOBAL_SUB_HELPER_EMAIL} | ||||
|     <a href="mailto:info@telecominfraproject.com"> | ||||
|         info@telecominfraproject.com | ||||
|     </a>. | ||||
|   </p> | ||||
| </div> | ||||
| @@ -16,7 +16,6 @@ | ||||
| <div class="info-card"> | ||||
|     <h2 class="info-title">Reset Password</h2> | ||||
|     <form action="/api/v1/actionLink?action=password_reset" method="post" onsubmit="return validatePassword()" class="form-container"> | ||||
|         <input type="hidden" id="custId" name="id" value="${UUID}"> | ||||
|         <div class="form-control"> | ||||
|             <label class="form-label" for="password1" ><b>New Password</b></label> | ||||
|             <input class="form-input" id="password1" type="password" placeholder="New password" name="password1" pattern="${PASSWORD_VALIDATION}" required> | ||||
|   | ||||
		Reference in New Issue
	
	Block a user