20#ifndef ConfigurationObjects_h
21#define ConfigurationObjects_h
24#include "EngageConstants.h"
33#include <nlohmann/json.hpp>
36 #pragma GCC diagnostic push
37 #pragma GCC diagnostic ignored "-Wunused-function"
40#if !defined(ENGAGE_IGNORE_COMPILER_UNUSED_WARNING)
42 #define ENGAGE_IGNORE_COMPILER_UNUSED_WARNING __attribute__((unused))
44 #define ENGAGE_IGNORE_COMPILER_UNUSED_WARNING
50#if defined(RTS_CORE_BUILD)
51namespace ConfigurationObjects
53namespace AppConfigurationObjects
56 static const char *ENGAGE_CONFIGURATION_OBJECT_ATTACHED_OBJECT =
"_attached";
150 } DataSeriesValueType_t;
164 bloodOxygenation = 5,
166 taskEffectiveness = 7
167 } HumanBiometricsTypes_t;
171 static FILE *_internalFileOpener(
const char *fn,
const char *mode)
176 fp = fopen(fn, mode);
178 if(fopen_s(&fp, fn, mode) != 0)
187 #define JSON_SERIALIZED_CLASS(_cn) \
189 static void to_json(nlohmann::json& j, const _cn& p); \
190 static void from_json(const nlohmann::json& j, _cn& p);
192 #define IMPLEMENT_JSON_DOCUMENTATION(_cn) \
194 static void document(const char *path = nullptr) \
197 example.initForDocumenting(); \
198 std::string theJson = example.serialize(3); \
199 std::cout << "------------------------------------------------" << std::endl \
200 << #_cn << std::endl \
201 << theJson << std::endl \
202 << "------------------------------------------------" << std::endl; \
204 if(path != nullptr && path[0] != 0) \
206 std::string fn = path; \
209 fn.append(".json"); \
211 FILE *fp = _internalFileOpener(fn.c_str(), "wt");\
215 fputs(theJson.c_str(), fp); \
220 std::cout << "ERROR: Cannot write to " << fn << std::endl; \
224 static const char *className() \
229 #define IMPLEMENT_JSON_SERIALIZATION() \
231 bool deserialize(const char *s) \
235 if(s != nullptr && s[0] != 0) \
237 from_json(nlohmann::json::parse(s), *this); \
251 std::string serialize(const int indent = -1) \
257 return j.dump(indent); \
261 return std::string("{}"); \
265 #define IMPLEMENT_WRAPPED_JSON_SERIALIZATION(_cn) \
267 std::string serializeWrapped(const int indent = -1) \
276 firstChar[0] = #_cn[0]; \
278 firstChar[0] = tolower(firstChar[0]); \
280 rc.append(firstChar); \
281 rc.append((#_cn) + 1); \
283 rc.append(j.dump(indent)); \
290 return std::string("{}"); \
294 #define TOJSON_IMPL(__var) \
297 #define FROMJSON_IMPL_SIMPLE(__var) \
298 getOptional(#__var, p.__var, j)
300 #define FROMJSON_IMPL(__var, __type, __default) \
301 getOptional<__type>(#__var, p.__var, j, __default)
303 #define TOJSON_BASE_IMPL() \
304 to_json(j, (ConfigurationObjectBase&)p)
306 #define FROMJSON_BASE_IMPL() \
307 from_json(j, (ConfigurationObjectBase&)p);
311 static std::string EMPTY_STRING;
314 static void getOptional(
const char *name, T& v,
const nlohmann::json& j, T def)
320 j.at(name).get_to(v);
334 static void getOptional(
const char *name, T& v,
const nlohmann::json& j)
340 j.at(name).get_to(v);
349 static void getOptionalWithIndicator(
const char *name, T& v,
const nlohmann::json& j, T def,
bool *wasFound)
355 j.at(name).get_to(v);
372 static void getOptionalWithIndicator(
const char *name, T& v,
const nlohmann::json& j,
bool *wasFound)
378 j.at(name).get_to(v);
397 _documenting =
false;
404 virtual void initForDocumenting()
409 virtual std::string toString()
411 return std::string(
"");
414 inline virtual bool isDocumenting()
const
419 nlohmann::json _attached;
429 if(p._attached !=
nullptr)
431 j[ENGAGE_CONFIGURATION_OBJECT_ATTACHED_OBJECT] = p._attached;
438 static void from_json(
const nlohmann::json& j, ConfigurationObjectBase& p)
442 if(j.contains(ENGAGE_CONFIGURATION_OBJECT_ATTACHED_OBJECT))
444 p._attached = j.at(ENGAGE_CONFIGURATION_OBJECT_ATTACHED_OBJECT);
453 JSON_SERIALIZED_CLASS(KvPair)
462 IMPLEMENT_JSON_SERIALIZATION()
463 IMPLEMENT_JSON_DOCUMENTATION(
KvPair)
484 static void to_json(nlohmann::json& j,
const KvPair& p)
491 static void from_json(
const nlohmann::json& j, KvPair& p)
494 getOptional<std::string>(
"key", p.key, j, EMPTY_STRING);
495 getOptional<std::string>(
"tags", p.value, j, EMPTY_STRING);
499 JSON_SERIALIZED_CLASS(TuningSettings)
502 IMPLEMENT_JSON_SERIALIZATION()
546 maxPooledRtpObjects = 0;
547 maxActiveRtpObjects = 0;
550 maxPooledBlobObjects = 0;
551 maxActiveBlobObjects = 0;
553 maxPooledBufferMb = 0;
554 maxPooledBufferObjects = 0;
555 maxActiveBufferObjects = 0;
557 maxActiveRtpProcessors = 0;
560 virtual void initForDocumenting()
566 static void to_json(nlohmann::json& j,
const TuningSettings& p)
569 TOJSON_IMPL(maxPooledRtpMb),
570 TOJSON_IMPL(maxPooledRtpObjects),
571 TOJSON_IMPL(maxActiveRtpObjects),
573 TOJSON_IMPL(maxPooledBlobMb),
574 TOJSON_IMPL(maxPooledBlobObjects),
575 TOJSON_IMPL(maxActiveBlobObjects),
577 TOJSON_IMPL(maxPooledBufferMb),
578 TOJSON_IMPL(maxPooledBufferObjects),
579 TOJSON_IMPL(maxActiveBufferObjects),
581 TOJSON_IMPL(maxActiveRtpProcessors)
584 static void from_json(
const nlohmann::json& j, TuningSettings& p)
587 FROMJSON_IMPL(maxPooledRtpMb, uint32_t, 0);
588 FROMJSON_IMPL(maxPooledRtpObjects, uint32_t, 0);
589 FROMJSON_IMPL(maxActiveRtpObjects, uint32_t, 0);
591 FROMJSON_IMPL(maxPooledBlobMb, uint32_t, 0);
592 FROMJSON_IMPL(maxPooledBlobObjects, uint32_t, 0);
593 FROMJSON_IMPL(maxActiveBlobObjects, uint32_t, 0);
595 FROMJSON_IMPL(maxPooledBufferMb, uint32_t, 0);
596 FROMJSON_IMPL(maxPooledBufferObjects, uint32_t, 0);
597 FROMJSON_IMPL(maxActiveBufferObjects, uint32_t, 0);
599 FROMJSON_IMPL(maxActiveRtpProcessors, uint32_t, 0);
604 JSON_SERIALIZED_CLASS(FipsCryptoSettings)
607 IMPLEMENT_JSON_SERIALIZATION()
640 virtual void initForDocumenting()
646 static void to_json(nlohmann::json& j,
const FipsCryptoSettings& p)
649 TOJSON_IMPL(enabled),
656 static void from_json(
const nlohmann::json& j, FipsCryptoSettings& p)
659 FROMJSON_IMPL_SIMPLE(enabled);
660 FROMJSON_IMPL_SIMPLE(path);
661 FROMJSON_IMPL_SIMPLE(debug);
662 FROMJSON_IMPL_SIMPLE(curves);
663 FROMJSON_IMPL_SIMPLE(ciphers);
668 JSON_SERIALIZED_CLASS(WatchdogSettings)
671 IMPLEMENT_JSON_SERIALIZATION()
699 hangDetectionMs = 2000;
701 slowExecutionThresholdMs = 100;
704 virtual void initForDocumenting()
710 static void to_json(nlohmann::json& j,
const WatchdogSettings& p)
713 TOJSON_IMPL(enabled),
714 TOJSON_IMPL(intervalMs),
715 TOJSON_IMPL(hangDetectionMs),
716 TOJSON_IMPL(abortOnHang),
717 TOJSON_IMPL(slowExecutionThresholdMs)
720 static void from_json(
const nlohmann::json& j, WatchdogSettings& p)
723 getOptional<bool>(
"enabled", p.enabled, j,
true);
724 getOptional<int>(
"intervalMs", p.intervalMs, j, 5000);
725 getOptional<int>(
"hangDetectionMs", p.hangDetectionMs, j, 2000);
726 getOptional<bool>(
"abortOnHang", p.abortOnHang, j,
true);
727 getOptional<int>(
"slowExecutionThresholdMs", p.slowExecutionThresholdMs, j, 100);
732 JSON_SERIALIZED_CLASS(FileRecordingRequest)
735 IMPLEMENT_JSON_SERIALIZATION()
740 std::string fileName;
755 virtual void initForDocumenting()
758 id =
"1-2-3-4-5-6-7-8-9";
759 fileName =
"/tmp/test.wav";
768 TOJSON_IMPL(fileName),
772 static void from_json(
const nlohmann::json& j, FileRecordingRequest& p)
775 j.at(
"id").get_to(p.id);
776 j.at(
"fileName").get_to(p.fileName);
777 getOptional<uint32_t>(
"maxMs", p.maxMs, j, 60000);
782 JSON_SERIALIZED_CLASS(Feature)
785 IMPLEMENT_JSON_SERIALIZATION()
786 IMPLEMENT_JSON_DOCUMENTATION(
Feature)
791 std::string description;
792 std::string comments;
811 virtual void initForDocumenting()
814 id =
"{af9540d1-3e86-4fa6-8b80-e26daecb61ab}";
815 name =
"A sample feature";
816 description =
"This is an example of a feature";
817 comments =
"These are comments for this feature";
823 static void to_json(nlohmann::json& j,
const Feature& p)
828 TOJSON_IMPL(description),
829 TOJSON_IMPL(comments),
834 static void from_json(
const nlohmann::json& j, Feature& p)
837 j.at(
"id").get_to(p.id);
838 getOptional(
"name", p.name, j);
839 getOptional(
"description", p.description, j);
840 getOptional(
"comments", p.comments, j);
841 getOptional(
"count", p.count, j, 0);
849 JSON_SERIALIZED_CLASS(Featureset)
852 IMPLEMENT_JSON_SERIALIZATION()
856 std::string signature;
858 std::vector<Feature> features;
868 lockToDeviceId =
false;
872 virtual void initForDocumenting()
875 signature =
"c39df3f36c6444e686e47e70fc45cf91e6ed2d8de62d4a1e89f507d567ff48aaabb1a70e54b44377b46fc4a1a2e319e5b77e4abffc444db98f8eb55d709aad5f";
876 lockToDeviceId =
false;
880 static void to_json(nlohmann::json& j,
const Featureset& p)
883 TOJSON_IMPL(signature),
884 TOJSON_IMPL(lockToDeviceId),
885 TOJSON_IMPL(features)
888 static void from_json(
const nlohmann::json& j, Featureset& p)
891 getOptional(
"signature", p.signature, j);
892 getOptional<bool>(
"lockToDeviceId", p.lockToDeviceId, j,
false);
893 getOptional<std::vector<Feature>>(
"features", p.features, j);
898 JSON_SERIALIZED_CLASS(Agc)
909 IMPLEMENT_JSON_SERIALIZATION()
910 IMPLEMENT_JSON_DOCUMENTATION(
Agc)
941 compressionGainDb = 25;
942 enableLimiter =
false;
947 static void to_json(nlohmann::json& j,
const Agc& p)
950 TOJSON_IMPL(enabled),
951 TOJSON_IMPL(minLevel),
952 TOJSON_IMPL(maxLevel),
953 TOJSON_IMPL(compressionGainDb),
954 TOJSON_IMPL(enableLimiter),
955 TOJSON_IMPL(targetLevelDb)
958 static void from_json(
const nlohmann::json& j, Agc& p)
961 getOptional<bool>(
"enabled", p.enabled, j,
false);
962 getOptional<int>(
"minLevel", p.minLevel, j, 0);
963 getOptional<int>(
"maxLevel", p.maxLevel, j, 255);
964 getOptional<int>(
"compressionGainDb", p.compressionGainDb, j, 25);
965 getOptional<bool>(
"enableLimiter", p.enableLimiter, j,
false);
966 getOptional<int>(
"targetLevelDb", p.targetLevelDb, j, 3);
971 JSON_SERIALIZED_CLASS(RtpPayloadTypeTranslation)
982 IMPLEMENT_JSON_SERIALIZATION()
1003 bool matches(
const RtpPayloadTypeTranslation& other)
1005 return ( (external == other.external) && (engage == other.engage) );
1009 static void to_json(nlohmann::json& j,
const RtpPayloadTypeTranslation& p)
1012 TOJSON_IMPL(external),
1016 static void from_json(
const nlohmann::json& j, RtpPayloadTypeTranslation& p)
1019 getOptional<uint16_t>(
"external", p.external, j);
1020 getOptional<uint16_t>(
"engage", p.engage, j);
1024 JSON_SERIALIZED_CLASS(NetworkInterfaceDevice)
1027 IMPLEMENT_JSON_SERIALIZATION()
1032 std::string friendlyName;
1033 std::string description;
1035 std::string address;
1038 bool supportsMulticast;
1039 std::string hardwareAddress;
1049 friendlyName.clear();
1050 description.clear();
1055 supportsMulticast =
false;
1056 hardwareAddress.clear();
1059 virtual void initForDocumenting()
1063 friendlyName =
"Wi-Fi";
1064 description =
"A wi-fi adapter";
1066 address =
"127.0.0.1";
1069 supportsMulticast =
false;
1070 hardwareAddress =
"DE:AD:BE:EF:01:02:03";
1078 TOJSON_IMPL(friendlyName),
1079 TOJSON_IMPL(description),
1080 TOJSON_IMPL(family),
1081 TOJSON_IMPL(address),
1082 TOJSON_IMPL(available),
1083 TOJSON_IMPL(isLoopback),
1084 TOJSON_IMPL(supportsMulticast),
1085 TOJSON_IMPL(hardwareAddress)
1088 static void from_json(
const nlohmann::json& j, NetworkInterfaceDevice& p)
1091 getOptional(
"name", p.name, j);
1092 getOptional(
"friendlyName", p.friendlyName, j);
1093 getOptional(
"description", p.description, j);
1094 getOptional(
"family", p.family, j, -1);
1095 getOptional(
"address", p.address, j);
1096 getOptional(
"available", p.available, j,
false);
1097 getOptional(
"isLoopback", p.isLoopback, j,
false);
1098 getOptional(
"supportsMulticast", p.supportsMulticast, j,
false);
1099 getOptional(
"hardwareAddress", p.hardwareAddress, j);
1103 JSON_SERIALIZED_CLASS(ListOfNetworkInterfaceDevice)
1106 IMPLEMENT_JSON_SERIALIZATION()
1110 std::vector<NetworkInterfaceDevice> list;
1129 static void from_json(
const nlohmann::json& j, ListOfNetworkInterfaceDevice& p)
1132 getOptional<std::vector<NetworkInterfaceDevice>>(
"list", p.list, j);
1137 JSON_SERIALIZED_CLASS(RtpHeader)
1148 IMPLEMENT_JSON_SERIALIZATION()
1182 virtual void initForDocumenting()
1193 static void to_json(nlohmann::json& j,
const RtpHeader& p)
1199 TOJSON_IMPL(marker),
1206 static void from_json(
const nlohmann::json& j, RtpHeader& p)
1209 getOptional<int>(
"pt", p.pt, j, -1);
1210 getOptional<bool>(
"marker", p.marker, j,
false);
1211 getOptional<uint16_t>(
"seq", p.seq, j, 0);
1212 getOptional<uint32_t>(
"ssrc", p.ssrc, j, 0);
1213 getOptional<uint32_t>(
"ts", p.ts, j, 0);
1217 JSON_SERIALIZED_CLASS(BlobInfo)
1228 IMPLEMENT_JSON_SERIALIZATION()
1229 IMPLEMENT_JSON_DOCUMENTATION(
BlobInfo)
1244 bptJsonTextUtf8 = 2,
1250 bptEngageBinaryHumanBiometrics = 4,
1253 bptAppMimeMessage = 5,
1256 bptEngageInternal = 42
1291 payloadType = PayloadType_t::bptUndefined;
1296 virtual void initForDocumenting()
1299 rtpHeader.initForDocumenting();
1303 static void to_json(nlohmann::json& j,
const BlobInfo& p)
1307 TOJSON_IMPL(source),
1308 TOJSON_IMPL(target),
1309 TOJSON_IMPL(rtpHeader),
1310 TOJSON_IMPL(payloadType),
1312 TOJSON_IMPL(txnTimeoutSecs)
1315 static void from_json(
const nlohmann::json& j, BlobInfo& p)
1318 getOptional<size_t>(
"size", p.size, j, 0);
1319 getOptional<std::string>(
"source", p.source, j, EMPTY_STRING);
1320 getOptional<std::string>(
"target", p.target, j, EMPTY_STRING);
1321 getOptional<RtpHeader>(
"rtpHeader", p.rtpHeader, j);
1322 getOptional<BlobInfo::PayloadType_t>(
"payloadType", p.payloadType, j, BlobInfo::PayloadType_t::bptUndefined);
1323 getOptional<std::string>(
"txnId", p.txnId, j, EMPTY_STRING);
1324 getOptional<int>(
"txnTimeoutSecs", p.txnTimeoutSecs, j, 0);
1329 JSON_SERIALIZED_CLASS(TxAudioUri)
1343 IMPLEMENT_JSON_SERIALIZATION()
1364 virtual void initForDocumenting()
1369 static void to_json(nlohmann::json& j,
const TxAudioUri& p)
1373 TOJSON_IMPL(repeatCount)
1376 static void from_json(
const nlohmann::json& j, TxAudioUri& p)
1379 getOptional<std::string>(
"uri", p.uri, j, EMPTY_STRING);
1380 getOptional<int>(
"repeatCount", p.repeatCount, j, 0);
1385 JSON_SERIALIZED_CLASS(AdvancedTxParams)
1399 IMPLEMENT_JSON_SERIALIZATION()
1447 includeNodeId =
false;
1452 aliasSpecializer = 0;
1453 receiverRxMuteForAliasSpecializer =
false;
1457 virtual void initForDocumenting()
1462 static void to_json(nlohmann::json& j,
const AdvancedTxParams& p)
1466 TOJSON_IMPL(priority),
1467 TOJSON_IMPL(subchannelTag),
1468 TOJSON_IMPL(includeNodeId),
1472 TOJSON_IMPL(audioUri),
1473 TOJSON_IMPL(aliasSpecializer),
1474 TOJSON_IMPL(receiverRxMuteForAliasSpecializer),
1475 TOJSON_IMPL(reBegin)
1478 static void from_json(
const nlohmann::json& j, AdvancedTxParams& p)
1481 getOptional<uint16_t>(
"flags", p.flags, j, 0);
1482 getOptional<uint8_t>(
"priority", p.priority, j, 0);
1483 getOptional<uint16_t>(
"subchannelTag", p.subchannelTag, j, 0);
1484 getOptional<bool>(
"includeNodeId", p.includeNodeId, j,
false);
1485 getOptional<std::string>(
"alias", p.alias, j, EMPTY_STRING);
1486 getOptional<bool>(
"muted", p.muted, j,
false);
1487 getOptional<uint32_t>(
"txId", p.txId, j, 0);
1488 getOptional<TxAudioUri>(
"audioUri", p.audioUri, j);
1489 getOptional<uint16_t>(
"aliasSpecializer", p.aliasSpecializer, j, 0);
1490 getOptional<bool>(
"receiverRxMuteForAliasSpecializer", p.receiverRxMuteForAliasSpecializer, j,
false);
1491 getOptional<bool>(
"reBegin", p.reBegin, j,
false);
1495 JSON_SERIALIZED_CLASS(Identity)
1509 IMPLEMENT_JSON_SERIALIZATION()
1510 IMPLEMENT_JSON_DOCUMENTATION(
Identity)
1540 displayName.clear();
1544 virtual void initForDocumenting()
1549 static void to_json(nlohmann::json& j,
const Identity& p)
1552 TOJSON_IMPL(nodeId),
1553 TOJSON_IMPL(userId),
1554 TOJSON_IMPL(displayName),
1558 static void from_json(
const nlohmann::json& j, Identity& p)
1561 getOptional<std::string>(
"nodeId", p.nodeId, j);
1562 getOptional<std::string>(
"userId", p.userId, j);
1563 getOptional<std::string>(
"displayName", p.displayName, j);
1564 getOptional<std::string>(
"avatar", p.avatar, j);
1569 JSON_SERIALIZED_CLASS(Location)
1583 IMPLEMENT_JSON_SERIALIZATION()
1584 IMPLEMENT_JSON_DOCUMENTATION(
Location)
1587 constexpr static double INVALID_LOCATION_VALUE = -999.999;
1615 latitude = INVALID_LOCATION_VALUE;
1616 longitude = INVALID_LOCATION_VALUE;
1617 altitude = INVALID_LOCATION_VALUE;
1618 direction = INVALID_LOCATION_VALUE;
1619 speed = INVALID_LOCATION_VALUE;
1622 virtual void initForDocumenting()
1628 longitude = 456.789;
1635 static void to_json(nlohmann::json& j,
const Location& p)
1637 if(p.latitude != Location::INVALID_LOCATION_VALUE && p.longitude != Location::INVALID_LOCATION_VALUE)
1640 TOJSON_IMPL(latitude),
1641 TOJSON_IMPL(longitude),
1644 if(p.ts != 0) j[
"ts"] = p.ts;
1645 if(p.altitude != Location::INVALID_LOCATION_VALUE) j[
"altitude"] = p.altitude;
1646 if(p.speed != Location::INVALID_LOCATION_VALUE) j[
"speed"] = p.speed;
1647 if(p.direction != Location::INVALID_LOCATION_VALUE) j[
"direction"] = p.direction;
1650 static void from_json(
const nlohmann::json& j, Location& p)
1653 getOptional<uint32_t>(
"ts", p.ts, j, 0);
1654 j.at(
"latitude").get_to(p.latitude);
1655 j.at(
"longitude").get_to(p.longitude);
1656 getOptional<double>(
"altitude", p.altitude, j, Location::INVALID_LOCATION_VALUE);
1657 getOptional<double>(
"direction", p.direction, j, Location::INVALID_LOCATION_VALUE);
1658 getOptional<double>(
"speed", p.speed, j, Location::INVALID_LOCATION_VALUE);
1662 JSON_SERIALIZED_CLASS(Power)
1674 IMPLEMENT_JSON_SERIALIZATION()
1675 IMPLEMENT_JSON_DOCUMENTATION(
Power)
1721 virtual void initForDocumenting()
1726 static void to_json(nlohmann::json& j,
const Power& p)
1728 if(p.source != 0 && p.state != 0 && p.level != 0)
1731 TOJSON_IMPL(source),
1737 static void from_json(
const nlohmann::json& j, Power& p)
1740 getOptional<int>(
"source", p.source, j, 0);
1741 getOptional<int>(
"state", p.state, j, 0);
1742 getOptional<int>(
"level", p.level, j, 0);
1747 JSON_SERIALIZED_CLASS(Connectivity)
1759 IMPLEMENT_JSON_SERIALIZATION()
1796 virtual void initForDocumenting()
1806 static void to_json(nlohmann::json& j,
const Connectivity& p)
1812 TOJSON_IMPL(strength),
1817 static void from_json(
const nlohmann::json& j, Connectivity& p)
1820 getOptional<int>(
"type", p.type, j, 0);
1821 getOptional<int>(
"strength", p.strength, j, 0);
1822 getOptional<int>(
"rating", p.rating, j, 0);
1827 JSON_SERIALIZED_CLASS(PresenceDescriptorGroupItem)
1839 IMPLEMENT_JSON_SERIALIZATION()
1864 virtual void initForDocumenting()
1866 groupId =
"{123-456}";
1872 static void to_json(nlohmann::json& j,
const PresenceDescriptorGroupItem& p)
1875 TOJSON_IMPL(groupId),
1880 static void from_json(
const nlohmann::json& j, PresenceDescriptorGroupItem& p)
1883 getOptional<std::string>(
"groupId", p.groupId, j);
1884 getOptional<std::string>(
"alias", p.alias, j);
1885 getOptional<uint16_t>(
"status", p.status, j);
1890 JSON_SERIALIZED_CLASS(PresenceDescriptor)
1902 IMPLEMENT_JSON_SERIALIZATION()
1980 groupAliases.clear();
1983 announceOnReceive =
false;
1984 connectivity.clear();
1988 virtual void initForDocumenting()
1995 identity.initForDocumenting();
1996 comment =
"This is a comment";
1999 PresenceDescriptorGroupItem gi;
2000 gi.initForDocumenting();
2001 groupAliases.push_back(gi);
2003 location.initForDocumenting();
2005 announceOnReceive =
true;
2006 connectivity.initForDocumenting();
2007 power.initForDocumenting();
2011 static void to_json(nlohmann::json& j,
const PresenceDescriptor& p)
2015 TOJSON_IMPL(nextUpdate),
2016 TOJSON_IMPL(identity),
2017 TOJSON_IMPL(comment),
2018 TOJSON_IMPL(disposition),
2019 TOJSON_IMPL(groupAliases),
2020 TOJSON_IMPL(location),
2021 TOJSON_IMPL(custom),
2022 TOJSON_IMPL(announceOnReceive),
2023 TOJSON_IMPL(connectivity),
2027 if(!p.comment.empty()) j[
"comment"] = p.comment;
2028 if(!p.custom.empty()) j[
"custom"] = p.custom;
2035 static void from_json(
const nlohmann::json& j, PresenceDescriptor& p)
2038 getOptional<bool>(
"self", p.self, j);
2039 getOptional<uint32_t>(
"ts", p.ts, j);
2040 getOptional<uint32_t>(
"nextUpdate", p.nextUpdate, j);
2041 getOptional<Identity>(
"identity", p.identity, j);
2042 getOptional<std::string>(
"comment", p.comment, j);
2043 getOptional<uint32_t>(
"disposition", p.disposition, j);
2044 getOptional<std::vector<PresenceDescriptorGroupItem>>(
"groupAliases", p.groupAliases, j);
2045 getOptional<Location>(
"location", p.location, j);
2046 getOptional<std::string>(
"custom", p.custom, j);
2047 getOptional<bool>(
"announceOnReceive", p.announceOnReceive, j);
2048 getOptional<Connectivity>(
"connectivity", p.connectivity, j);
2049 getOptional<Power>(
"power", p.power, j);
2090 } AddressResolutionPolicy_t;
2093 JSON_SERIALIZED_CLASS(NetworkTxOptions)
2107 IMPLEMENT_JSON_SERIALIZATION()
2132 virtual void initForDocumenting()
2137 static void to_json(nlohmann::json& j,
const NetworkTxOptions& p)
2140 TOJSON_IMPL(priority),
2144 static void from_json(
const nlohmann::json& j, NetworkTxOptions& p)
2147 getOptional<TxPriority_t>(
"priority", p.priority, j, TxPriority_t::priVoice);
2148 getOptional<int>(
"ttl", p.ttl, j, 1);
2153 JSON_SERIALIZED_CLASS(TcpNetworkTxOptions)
2163 IMPLEMENT_JSON_SERIALIZATION()
2178 virtual void initForDocumenting()
2186 TOJSON_IMPL(priority),
2190 static void from_json(
const nlohmann::json& j, TcpNetworkTxOptions& p)
2193 getOptional<TxPriority_t>(
"priority", p.priority, j, TxPriority_t::priVoice);
2194 getOptional<int>(
"ttl", p.ttl, j, -1);
2210 JSON_SERIALIZED_CLASS(NetworkAddress)
2223 IMPLEMENT_JSON_SERIALIZATION()
2244 bool matches(
const NetworkAddress& other)
2246 if(address.compare(other.address) != 0)
2251 if(port != other.port)
2260 static void to_json(nlohmann::json& j,
const NetworkAddress& p)
2263 TOJSON_IMPL(address),
2267 static void from_json(
const nlohmann::json& j, NetworkAddress& p)
2270 getOptional<std::string>(
"address", p.address, j);
2271 getOptional<int>(
"port", p.port, j);
2276 JSON_SERIALIZED_CLASS(NetworkAddressRxTx)
2289 IMPLEMENT_JSON_SERIALIZATION()
2311 static void to_json(nlohmann::json& j,
const NetworkAddressRxTx& p)
2318 static void from_json(
const nlohmann::json& j, NetworkAddressRxTx& p)
2321 getOptional<NetworkAddress>(
"rx", p.rx, j);
2322 getOptional<NetworkAddress>(
"tx", p.tx, j);
2333 } GroupRestrictionAccessPolicyType_t;
2335 static bool isValidGroupRestrictionAccessPolicyType(GroupRestrictionAccessPolicyType_t t)
2337 return (t == GroupRestrictionAccessPolicyType_t::graptPermissive ||
2338 t == GroupRestrictionAccessPolicyType_t::graptStrict );
2352 } RestrictionType_t;
2354 static bool isValidRestrictionType(RestrictionType_t t)
2356 return (t == RestrictionType_t::rtUndefined ||
2357 t == RestrictionType_t::rtWhitelist ||
2358 t == RestrictionType_t::rtBlacklist );
2384 } RestrictionElementType_t;
2386 static bool isValidRestrictionElementType(RestrictionElementType_t t)
2388 return (t == RestrictionElementType_t::retGroupId ||
2389 t == RestrictionElementType_t::retGroupIdPattern ||
2390 t == RestrictionElementType_t::retGenericAccessTagPattern ||
2391 t == RestrictionElementType_t::retCertificateSerialNumberPattern ||
2392 t == RestrictionElementType_t::retCertificateFingerprintPattern ||
2393 t == RestrictionElementType_t::retCertificateSubjectPattern ||
2394 t == RestrictionElementType_t::retCertificateIssuerPattern);
2399 JSON_SERIALIZED_CLASS(NetworkAddressRestrictionList)
2412 IMPLEMENT_JSON_SERIALIZATION()
2429 type = RestrictionType_t::rtUndefined;
2434 static void to_json(nlohmann::json& j,
const NetworkAddressRestrictionList& p)
2438 TOJSON_IMPL(elements)
2441 static void from_json(
const nlohmann::json& j, NetworkAddressRestrictionList& p)
2444 getOptional<RestrictionType_t>(
"type", p.type, j, RestrictionType_t::rtUndefined);
2445 getOptional<std::vector<NetworkAddressRxTx>>(
"elements", p.elements, j);
2449 JSON_SERIALIZED_CLASS(StringRestrictionList)
2462 IMPLEMENT_JSON_SERIALIZATION()
2477 type = RestrictionType_t::rtUndefined;
2478 elementsType = RestrictionElementType_t::retGroupId;
2488 static void to_json(nlohmann::json& j,
const StringRestrictionList& p)
2492 TOJSON_IMPL(elementsType),
2493 TOJSON_IMPL(elements)
2496 static void from_json(
const nlohmann::json& j, StringRestrictionList& p)
2499 getOptional<RestrictionType_t>(
"type", p.type, j, RestrictionType_t::rtUndefined);
2500 getOptional<RestrictionElementType_t>(
"elementsType", p.elementsType, j, RestrictionElementType_t::retGroupId);
2501 getOptional<std::vector<std::string>>(
"elements", p.elements, j);
2506 JSON_SERIALIZED_CLASS(PacketCapturer)
2517 IMPLEMENT_JSON_SERIALIZATION()
2523 std::string filePrefix;
2541 TOJSON_IMPL(enabled),
2543 TOJSON_IMPL(filePrefix)
2546 static void from_json(
const nlohmann::json& j, PacketCapturer& p)
2549 getOptional<bool>(
"enabled", p.enabled, j,
false);
2550 getOptional<uint32_t>(
"maxMb", p.maxMb, j, 10);
2551 getOptional<std::string>(
"filePrefix", p.filePrefix, j, EMPTY_STRING);
2556 JSON_SERIALIZED_CLASS(TransportImpairment)
2567 IMPLEMENT_JSON_SERIALIZATION()
2571 int applicationPercentage;
2582 applicationPercentage = 0;
2591 TOJSON_IMPL(applicationPercentage),
2592 TOJSON_IMPL(jitterMs),
2593 TOJSON_IMPL(lossPercentage)
2596 static void from_json(
const nlohmann::json& j, TransportImpairment& p)
2599 getOptional<int>(
"applicationPercentage", p.applicationPercentage, j, 0);
2600 getOptional<int>(
"jitterMs", p.jitterMs, j, 0);
2601 getOptional<int>(
"lossPercentage", p.lossPercentage, j, 0);
2605 JSON_SERIALIZED_CLASS(NsmNetworking)
2616 IMPLEMENT_JSON_SERIALIZATION()
2620 std::string interfaceName;
2627 std::string cryptoPassword;
2636 interfaceName.clear();
2641 rxImpairment.clear();
2642 txImpairment.clear();
2643 cryptoPassword.clear();
2647 static void to_json(nlohmann::json& j,
const NsmNetworking& p)
2650 TOJSON_IMPL(interfaceName),
2651 TOJSON_IMPL(address),
2654 TOJSON_IMPL(txOversend),
2655 TOJSON_IMPL(rxImpairment),
2656 TOJSON_IMPL(txImpairment),
2657 TOJSON_IMPL(cryptoPassword)
2660 static void from_json(
const nlohmann::json& j, NsmNetworking& p)
2663 getOptional(
"interfaceName", p.interfaceName, j, EMPTY_STRING);
2664 getOptional<NetworkAddress>(
"address", p.address, j);
2665 getOptional<int>(
"ttl", p.ttl, j, 1);
2666 getOptional<int>(
"tos", p.tos, j, 56);
2667 getOptional<int>(
"txOversend", p.txOversend, j, 0);
2668 getOptional<TransportImpairment>(
"rxImpairment", p.rxImpairment, j);
2669 getOptional<TransportImpairment>(
"txImpairment", p.txImpairment, j);
2670 getOptional(
"cryptoPassword", p.cryptoPassword, j, EMPTY_STRING);
2675 JSON_SERIALIZED_CLASS(NsmConfiguration)
2686 IMPLEMENT_JSON_SERIALIZATION()
2694 std::vector<std::string> resources;
2698 int transitionSecsFactor;
2708 favorUptime =
false;
2711 tokenStart = 1000000;
2714 transitionSecsFactor = 3;
2722 TOJSON_IMPL(favorUptime),
2723 TOJSON_IMPL(networking),
2724 TOJSON_IMPL(resources),
2725 TOJSON_IMPL(tokenStart),
2726 TOJSON_IMPL(tokenEnd),
2727 TOJSON_IMPL(intervalSecs),
2728 TOJSON_IMPL(transitionSecsFactor)
2731 static void from_json(
const nlohmann::json& j, NsmConfiguration& p)
2734 getOptional(
"id", p.id, j);
2735 getOptional<bool>(
"favorUptime", p.favorUptime, j,
false);
2736 getOptional<NsmNetworking>(
"networking", p.networking, j);
2737 getOptional<std::vector<std::string>>(
"resources", p.resources, j);
2738 getOptional<int>(
"tokenStart", p.tokenStart, j, 1000000);
2739 getOptional<int>(
"tokenEnd", p.tokenEnd, j, 2000000);
2740 getOptional<int>(
"intervalSecs", p.intervalSecs, j, 1);
2741 getOptional<int>(
"transitionSecsFactor", p.transitionSecsFactor, j, 3);
2746 JSON_SERIALIZED_CLASS(Rallypoint)
2756 IMPLEMENT_JSON_SERIALIZATION()
2865 certificate.clear();
2866 certificateKey.clear();
2867 caCertificates.clear();
2869 transactionTimeoutMs = 0;
2870 disableMessageSigning =
false;
2871 connectionTimeoutSecs = 0;
2872 tcpTxOptions.clear();
2874 protocol = rppTlsTcp;
2876 additionalProtocols.clear();
2879 bool matches(
const Rallypoint& other)
2881 if(!host.matches(other.host))
2886 if(protocol != other.protocol)
2891 if(path.compare(other.path) != 0)
2896 if(certificate.compare(other.certificate) != 0)
2901 if(certificateKey.compare(other.certificateKey) != 0)
2906 if(verifyPeer != other.verifyPeer)
2911 if(allowSelfSignedCertificate != other.allowSelfSignedCertificate)
2916 if(caCertificates.size() != other.caCertificates.size())
2921 for(
size_t x = 0; x < caCertificates.size(); x++)
2925 for(
size_t y = 0; y < other.caCertificates.size(); y++)
2927 if(caCertificates[x].compare(other.caCertificates[y]) == 0)
2940 if(transactionTimeoutMs != other.transactionTimeoutMs)
2945 if(disableMessageSigning != other.disableMessageSigning)
2949 if(connectionTimeoutSecs != other.connectionTimeoutSecs)
2953 if(tcpTxOptions.
priority != other.tcpTxOptions.priority)
2957 if(sni.compare(other.sni) != 0)
2966 static void to_json(nlohmann::json& j,
const Rallypoint& p)
2970 TOJSON_IMPL(certificate),
2971 TOJSON_IMPL(certificateKey),
2972 TOJSON_IMPL(verifyPeer),
2973 TOJSON_IMPL(allowSelfSignedCertificate),
2974 TOJSON_IMPL(caCertificates),
2975 TOJSON_IMPL(transactionTimeoutMs),
2976 TOJSON_IMPL(disableMessageSigning),
2977 TOJSON_IMPL(connectionTimeoutSecs),
2978 TOJSON_IMPL(tcpTxOptions),
2980 TOJSON_IMPL(protocol),
2982 TOJSON_IMPL(additionalProtocols)
2986 static void from_json(
const nlohmann::json& j, Rallypoint& p)
2989 j.at(
"host").get_to(p.host);
2990 getOptional(
"certificate", p.certificate, j);
2991 getOptional(
"certificateKey", p.certificateKey, j);
2992 getOptional<bool>(
"verifyPeer", p.verifyPeer, j,
true);
2993 getOptional<bool>(
"allowSelfSignedCertificate", p.allowSelfSignedCertificate, j,
false);
2994 getOptional<std::vector<std::string>>(
"caCertificates", p.caCertificates, j);
2995 getOptional<int>(
"transactionTimeoutMs", p.transactionTimeoutMs, j, 0);
2996 getOptional<bool>(
"disableMessageSigning", p.disableMessageSigning, j,
false);
2997 getOptional<int>(
"connectionTimeoutSecs", p.connectionTimeoutSecs, j, 0);
2998 getOptional<TcpNetworkTxOptions>(
"tcpTxOptions", p.tcpTxOptions, j);
2999 getOptional<std::string>(
"sni", p.sni, j);
3000 getOptional<Rallypoint::RpProtocol_t>(
"protocol", p.protocol, j, Rallypoint::RpProtocol_t::rppTlsTcp);
3001 getOptional<std::string>(
"path", p.path, j);
3002 getOptional<std::string>(
"additionalProtocols", p.additionalProtocols, j);
3006 JSON_SERIALIZED_CLASS(RallypointCluster)
3019 IMPLEMENT_JSON_SERIALIZATION()
3035 } ConnectionStrategy_t;
3059 connectionStrategy = csRoundRobin;
3060 rallypoints.clear();
3062 connectionTimeoutSecs = 5;
3063 transactionTimeoutMs = 10000;
3067 static void to_json(nlohmann::json& j,
const RallypointCluster& p)
3070 TOJSON_IMPL(connectionStrategy),
3071 TOJSON_IMPL(rallypoints),
3072 TOJSON_IMPL(rolloverSecs),
3073 TOJSON_IMPL(connectionTimeoutSecs),
3074 TOJSON_IMPL(transactionTimeoutMs)
3077 static void from_json(
const nlohmann::json& j, RallypointCluster& p)
3080 getOptional<RallypointCluster::ConnectionStrategy_t>(
"connectionStrategy", p.connectionStrategy, RallypointCluster::ConnectionStrategy_t::csRoundRobin);
3081 getOptional<std::vector<Rallypoint>>(
"rallypoints", p.rallypoints, j);
3082 getOptional<int>(
"rolloverSecs", p.rolloverSecs, j, 10);
3083 getOptional<int>(
"connectionTimeoutSecs", p.connectionTimeoutSecs, j, 5);
3084 getOptional<int>(
"transactionTimeoutMs", p.transactionTimeoutMs, j, 10000);
3089 JSON_SERIALIZED_CLASS(NetworkDeviceDescriptor)
3101 IMPLEMENT_JSON_SERIALIZATION()
3142 manufacturer.clear();
3145 serialNumber.clear();
3150 virtual std::string toString()
3154 snprintf(buff,
sizeof(buff),
"deviceId=%d, name=%s, manufacturer=%s, model=%s, hardwareId=%s, serialNumber=%s, type=%s, extra=%s",
3157 manufacturer.c_str(),
3160 serialNumber.c_str(),
3164 return std::string(buff);
3168 static void to_json(nlohmann::json& j,
const NetworkDeviceDescriptor& p)
3171 TOJSON_IMPL(deviceId),
3173 TOJSON_IMPL(manufacturer),
3175 TOJSON_IMPL(hardwareId),
3176 TOJSON_IMPL(serialNumber),
3181 static void from_json(
const nlohmann::json& j, NetworkDeviceDescriptor& p)
3184 getOptional<int>(
"deviceId", p.deviceId, j, 0);
3185 getOptional(
"name", p.name, j);
3186 getOptional(
"manufacturer", p.manufacturer, j);
3187 getOptional(
"model", p.model, j);
3188 getOptional(
"hardwareId", p.hardwareId, j);
3189 getOptional(
"serialNumber", p.serialNumber, j);
3190 getOptional(
"type", p.type, j);
3191 getOptional(
"extra", p.extra, j);
3195 JSON_SERIALIZED_CLASS(AudioGate)
3206 IMPLEMENT_JSON_SERIALIZATION()
3245 static void to_json(nlohmann::json& j,
const AudioGate& p)
3248 TOJSON_IMPL(enabled),
3249 TOJSON_IMPL(useVad),
3250 TOJSON_IMPL(hangMs),
3251 TOJSON_IMPL(windowMin),
3252 TOJSON_IMPL(windowMax),
3253 TOJSON_IMPL(coefficient)
3256 static void from_json(
const nlohmann::json& j, AudioGate& p)
3259 getOptional<bool>(
"enabled", p.enabled, j,
false);
3260 getOptional<bool>(
"useVad", p.useVad, j,
false);
3261 getOptional<uint32_t>(
"hangMs", p.hangMs, j, 1500);
3262 getOptional<uint32_t>(
"windowMin", p.windowMin, j, 25);
3263 getOptional<uint32_t>(
"windowMax", p.windowMax, j, 125);
3264 getOptional<double>(
"coefficient", p.coefficient, j, 1.75);
3268 JSON_SERIALIZED_CLASS(TxAudio)
3283 IMPLEMENT_JSON_SERIALIZATION()
3284 IMPLEMENT_JSON_DOCUMENTATION(
TxAudio)
3520 encoder = TxAudio::TxCodec_t::ctUnknown;
3521 encoderName.clear();
3527 extensionSendInterval = 10;
3528 initialHeaderBurst = 5;
3529 trailingHeaderBurst = 5;
3530 startTxNotifications = 5;
3531 customRtpPayloadType = -1;
3533 resetRtpOnTx =
true;
3534 enableSmoothing =
true;
3536 smoothedHangTimeMs = 0;
3540 static void to_json(nlohmann::json& j,
const TxAudio& p)
3543 TOJSON_IMPL(enabled),
3544 TOJSON_IMPL(encoder),
3545 TOJSON_IMPL(encoderName),
3546 TOJSON_IMPL(framingMs),
3547 TOJSON_IMPL(blockCount),
3549 TOJSON_IMPL(noHdrExt),
3550 TOJSON_IMPL(maxTxSecs),
3551 TOJSON_IMPL(extensionSendInterval),
3552 TOJSON_IMPL(initialHeaderBurst),
3553 TOJSON_IMPL(trailingHeaderBurst),
3554 TOJSON_IMPL(startTxNotifications),
3555 TOJSON_IMPL(customRtpPayloadType),
3556 TOJSON_IMPL(resetRtpOnTx),
3557 TOJSON_IMPL(enableSmoothing),
3559 TOJSON_IMPL(smoothedHangTimeMs)
3564 static void from_json(
const nlohmann::json& j, TxAudio& p)
3567 getOptional<bool>(
"enabled", p.enabled, j,
true);
3568 getOptional<TxAudio::TxCodec_t>(
"encoder", p.encoder, j, TxAudio::TxCodec_t::ctOpus8000);
3569 getOptional<std::string>(
"encoderName", p.encoderName, j, EMPTY_STRING);
3570 getOptional(
"framingMs", p.framingMs, j, 60);
3571 getOptional(
"blockCount", p.blockCount, j, 0);
3572 getOptional(
"fdx", p.fdx, j,
false);
3573 getOptional(
"noHdrExt", p.noHdrExt, j,
false);
3574 getOptional(
"maxTxSecs", p.maxTxSecs, j, 0);
3575 getOptional(
"extensionSendInterval", p.extensionSendInterval, j, 10);
3576 getOptional(
"initialHeaderBurst", p.initialHeaderBurst, j, 5);
3577 getOptional(
"trailingHeaderBurst", p.trailingHeaderBurst, j, 5);
3578 getOptional(
"startTxNotifications", p.startTxNotifications, j, 5);
3579 getOptional(
"customRtpPayloadType", p.customRtpPayloadType, j, -1);
3580 getOptional(
"resetRtpOnTx", p.resetRtpOnTx, j,
true);
3581 getOptional(
"enableSmoothing", p.enableSmoothing, j,
true);
3582 getOptional(
"dtx", p.dtx, j,
false);
3583 getOptional(
"smoothedHangTimeMs", p.smoothedHangTimeMs, j, 0);
3589 JSON_SERIALIZED_CLASS(AudioRegistryDevice)
3601 IMPLEMENT_JSON_SERIALIZATION()
3640 manufacturer.clear();
3642 serialNumber.clear();
3647 virtual std::string toString()
3651 snprintf(buff,
sizeof(buff),
"hardwareId=%s, isDefault=%d, name=%s, manufacturer=%s, model=%s, serialNumber=%s, type=%s, extra=%s",
3655 manufacturer.c_str(),
3657 serialNumber.c_str(),
3661 return std::string(buff);
3665 static void to_json(nlohmann::json& j,
const AudioRegistryDevice& p)
3668 TOJSON_IMPL(hardwareId),
3669 TOJSON_IMPL(isDefault),
3671 TOJSON_IMPL(manufacturer),
3673 TOJSON_IMPL(serialNumber),
3678 static void from_json(
const nlohmann::json& j, AudioRegistryDevice& p)
3681 getOptional<std::string>(
"hardwareId", p.hardwareId, j, EMPTY_STRING);
3682 getOptional<bool>(
"isDefault", p.isDefault, j,
false);
3683 getOptional(
"name", p.name, j);
3684 getOptional(
"manufacturer", p.manufacturer, j);
3685 getOptional(
"model", p.model, j);
3686 getOptional(
"serialNumber", p.serialNumber, j);
3687 getOptional(
"type", p.type, j);
3688 getOptional(
"extra", p.extra, j);
3693 JSON_SERIALIZED_CLASS(AudioRegistry)
3705 IMPLEMENT_JSON_SERIALIZATION()
3726 virtual std::string toString()
3728 return std::string(
"");
3732 static void to_json(nlohmann::json& j,
const AudioRegistry& p)
3735 TOJSON_IMPL(inputs),
3736 TOJSON_IMPL(outputs)
3739 static void from_json(
const nlohmann::json& j, AudioRegistry& p)
3742 getOptional<std::vector<AudioRegistryDevice>>(
"inputs", p.inputs, j);
3743 getOptional<std::vector<AudioRegistryDevice>>(
"outputs", p.outputs, j);
3747 JSON_SERIALIZED_CLASS(AudioDeviceDescriptor)
3759 IMPLEMENT_JSON_SERIALIZATION()
3853 direction = dirUnknown;
3854 boostPercentage = 0;
3859 manufacturer.clear();
3862 serialNumber.clear();
3868 virtual std::string toString()
3872 snprintf(buff,
sizeof(buff),
"deviceId=%d, samplingRate=%d, channels=%d, direction=%d, boostPercentage=%d, isAdad=%d, name=%s, manufacturer=%s, model=%s, hardwareId=%s, serialNumber=%s, isDefault=%d, type=%s, present=%d, extra=%s",
3880 manufacturer.c_str(),
3883 serialNumber.c_str(),
3889 return std::string(buff);
3893 static void to_json(nlohmann::json& j,
const AudioDeviceDescriptor& p)
3896 TOJSON_IMPL(deviceId),
3897 TOJSON_IMPL(samplingRate),
3898 TOJSON_IMPL(channels),
3899 TOJSON_IMPL(direction),
3900 TOJSON_IMPL(boostPercentage),
3901 TOJSON_IMPL(isAdad),
3903 TOJSON_IMPL(manufacturer),
3905 TOJSON_IMPL(hardwareId),
3906 TOJSON_IMPL(serialNumber),
3907 TOJSON_IMPL(isDefault),
3910 TOJSON_IMPL(isPresent)
3913 static void from_json(
const nlohmann::json& j, AudioDeviceDescriptor& p)
3916 getOptional<int>(
"deviceId", p.deviceId, j, 0);
3917 getOptional<int>(
"samplingRate", p.samplingRate, j, 0);
3918 getOptional<int>(
"channels", p.channels, j, 0);
3919 getOptional<AudioDeviceDescriptor::Direction_t>(
"direction", p.direction, j,
3920 AudioDeviceDescriptor::Direction_t::dirUnknown);
3921 getOptional<int>(
"boostPercentage", p.boostPercentage, j, 0);
3923 getOptional<bool>(
"isAdad", p.isAdad, j,
false);
3924 getOptional(
"name", p.name, j);
3925 getOptional(
"manufacturer", p.manufacturer, j);
3926 getOptional(
"model", p.model, j);
3927 getOptional(
"hardwareId", p.hardwareId, j);
3928 getOptional(
"serialNumber", p.serialNumber, j);
3929 getOptional(
"isDefault", p.isDefault, j);
3930 getOptional(
"type", p.type, j);
3931 getOptional(
"extra", p.extra, j);
3932 getOptional<bool>(
"isPresent", p.isPresent, j,
false);
3936 JSON_SERIALIZED_CLASS(ListOfAudioDeviceDescriptor)
3939 IMPLEMENT_JSON_SERIALIZATION()
3943 std::vector<AudioDeviceDescriptor> list;
3962 static void from_json(
const nlohmann::json& j, ListOfAudioDeviceDescriptor& p)
3965 getOptional<std::vector<AudioDeviceDescriptor>>(
"list", p.list, j);
3969 JSON_SERIALIZED_CLASS(Audio)
3979 IMPLEMENT_JSON_SERIALIZATION()
3980 IMPLEMENT_JSON_DOCUMENTATION(
Audio)
4022 inputHardwareId.clear();
4025 outputHardwareId.clear();
4027 outputLevelLeft = 100;
4028 outputLevelRight = 100;
4029 outputMuted =
false;
4033 static void to_json(nlohmann::json& j,
const Audio& p)
4036 TOJSON_IMPL(enabled),
4037 TOJSON_IMPL(inputId),
4038 TOJSON_IMPL(inputHardwareId),
4039 TOJSON_IMPL(inputGain),
4040 TOJSON_IMPL(outputId),
4041 TOJSON_IMPL(outputHardwareId),
4042 TOJSON_IMPL(outputLevelLeft),
4043 TOJSON_IMPL(outputLevelRight),
4044 TOJSON_IMPL(outputMuted)
4047 static void from_json(
const nlohmann::json& j, Audio& p)
4050 getOptional<bool>(
"enabled", p.enabled, j,
true);
4051 getOptional<int>(
"inputId", p.inputId, j, 0);
4052 getOptional<std::string>(
"inputHardwareId", p.inputHardwareId, j, EMPTY_STRING);
4053 getOptional<int>(
"inputGain", p.inputGain, j, 0);
4054 getOptional<int>(
"outputId", p.outputId, j, 0);
4055 getOptional<std::string>(
"outputHardwareId", p.outputHardwareId, j, EMPTY_STRING);
4056 getOptional<int>(
"outputGain", p.outputGain, j, 0);
4057 getOptional<int>(
"outputLevelLeft", p.outputLevelLeft, j, 100);
4058 getOptional<int>(
"outputLevelRight", p.outputLevelRight, j, 100);
4059 getOptional<bool>(
"outputMuted", p.outputMuted, j,
false);
4063 JSON_SERIALIZED_CLASS(TalkerInformation)
4075 IMPLEMENT_JSON_SERIALIZATION()
4091 matSsrcGenerated = 2
4092 } ManufacturedAliasType_t;
4137 aliasSpecializer = 0;
4139 manufacturedAliasType = ManufacturedAliasType_t::matNone;
4144 static void to_json(nlohmann::json& j,
const TalkerInformation& p)
4148 TOJSON_IMPL(nodeId),
4149 TOJSON_IMPL(rxFlags),
4150 TOJSON_IMPL(txPriority),
4152 TOJSON_IMPL(duplicateCount),
4153 TOJSON_IMPL(aliasSpecializer),
4154 TOJSON_IMPL(rxMuted),
4155 TOJSON_IMPL(manufacturedAliasType),
4159 static void from_json(
const nlohmann::json& j, TalkerInformation& p)
4162 getOptional<std::string>(
"alias", p.alias, j, EMPTY_STRING);
4163 getOptional<std::string>(
"nodeId", p.nodeId, j, EMPTY_STRING);
4164 getOptional<uint16_t>(
"rxFlags", p.rxFlags, j, 0);
4165 getOptional<int>(
"txPriority", p.txPriority, j, 0);
4166 getOptional<uint32_t>(
"txId", p.txId, j, 0);
4167 getOptional<int>(
"duplicateCount", p.duplicateCount, j, 0);
4168 getOptional<uint16_t>(
"aliasSpecializer", p.aliasSpecializer, j, 0);
4169 getOptional<bool>(
"rxMuted", p.rxMuted, j,
false);
4170 getOptional<TalkerInformation::ManufacturedAliasType_t>(
"manufacturedAliasType", p.manufacturedAliasType, j, TalkerInformation::ManufacturedAliasType_t::matNone);
4171 getOptional<uint32_t>(
"ssrc", p.ssrc, j, 0);
4175 JSON_SERIALIZED_CLASS(GroupTalkers)
4189 IMPLEMENT_JSON_SERIALIZATION()
4194 std::vector<TalkerInformation>
list;
4207 static void to_json(nlohmann::json& j,
const GroupTalkers& p)
4213 static void from_json(
const nlohmann::json& j, GroupTalkers& p)
4216 getOptional<std::vector<TalkerInformation>>(
"list", p.list, j);
4220 JSON_SERIALIZED_CLASS(Presence)
4232 IMPLEMENT_JSON_SERIALIZATION()
4233 IMPLEMENT_JSON_DOCUMENTATION(
Presence)
4281 minIntervalSecs = 5;
4282 reduceImmediacy =
false;
4286 static void to_json(nlohmann::json& j,
const Presence& p)
4289 TOJSON_IMPL(format),
4290 TOJSON_IMPL(intervalSecs),
4291 TOJSON_IMPL(listenOnly),
4292 TOJSON_IMPL(minIntervalSecs),
4293 TOJSON_IMPL(reduceImmediacy)
4296 static void from_json(
const nlohmann::json& j, Presence& p)
4299 getOptional<Presence::Format_t>(
"format", p.format, j, Presence::Format_t::pfEngage);
4300 getOptional<int>(
"intervalSecs", p.intervalSecs, j, 30);
4301 getOptional<bool>(
"listenOnly", p.listenOnly, j,
false);
4302 getOptional<int>(
"minIntervalSecs", p.minIntervalSecs, j, 5);
4303 getOptional<bool>(
"reduceImmediacy", p.reduceImmediacy, j,
false);
4308 JSON_SERIALIZED_CLASS(Advertising)
4320 IMPLEMENT_JSON_SERIALIZATION()
4342 alwaysAdvertise =
false;
4346 static void to_json(nlohmann::json& j,
const Advertising& p)
4349 TOJSON_IMPL(enabled),
4350 TOJSON_IMPL(intervalMs),
4351 TOJSON_IMPL(alwaysAdvertise)
4354 static void from_json(
const nlohmann::json& j, Advertising& p)
4357 getOptional(
"enabled", p.enabled, j,
false);
4358 getOptional<int>(
"intervalMs", p.intervalMs, j, 20000);
4359 getOptional<bool>(
"alwaysAdvertise", p.alwaysAdvertise, j,
false);
4363 JSON_SERIALIZED_CLASS(GroupPriorityTranslation)
4375 IMPLEMENT_JSON_SERIALIZATION()
4401 static void to_json(nlohmann::json& j,
const GroupPriorityTranslation& p)
4406 TOJSON_IMPL(priority)
4409 static void from_json(
const nlohmann::json& j, GroupPriorityTranslation& p)
4412 j.at(
"rx").get_to(p.rx);
4413 j.at(
"tx").get_to(p.tx);
4414 FROMJSON_IMPL(priority,
int, 0);
4418 JSON_SERIALIZED_CLASS(GroupTimeline)
4432 IMPLEMENT_JSON_SERIALIZATION()
4451 maxAudioTimeMs = 30000;
4456 static void to_json(nlohmann::json& j,
const GroupTimeline& p)
4459 TOJSON_IMPL(enabled),
4460 TOJSON_IMPL(maxAudioTimeMs),
4461 TOJSON_IMPL(recordAudio)
4464 static void from_json(
const nlohmann::json& j, GroupTimeline& p)
4467 getOptional(
"enabled", p.enabled, j,
true);
4468 getOptional<int>(
"maxAudioTimeMs", p.maxAudioTimeMs, j, 30000);
4469 getOptional(
"recordAudio", p.recordAudio, j,
true);
4572 IMPLEMENT_JSON_SERIALIZATION()
4594 static void to_json(nlohmann::json& j,
const GroupAppTransport& p)
4597 TOJSON_IMPL(enabled),
4601 static void from_json(
const nlohmann::json& j, GroupAppTransport& p)
4604 getOptional<bool>(
"enabled", p.enabled, j,
false);
4605 getOptional<std::string>(
"id", p.id, j);
4609 JSON_SERIALIZED_CLASS(RtpProfile)
4621 IMPLEMENT_JSON_SERIALIZATION()
4639 jmReleaseOnTxEnd = 2
4702 jitterMaxMs = 10000;
4704 jitterMaxFactor = 8;
4705 jitterTrimPercentage = 10;
4706 jitterUnderrunReductionThresholdMs = 1500;
4707 jitterUnderrunReductionAger = 100;
4708 latePacketSequenceRange = 5;
4709 latePacketTimestampRangeMs = 2000;
4710 inboundProcessorInactivityMs = 500;
4711 jitterForceTrimAtMs = 0;
4712 rtcpPresenceTimeoutMs = 45000;
4713 jitterMaxExceededClipPerc = 10;
4714 jitterMaxExceededClipHangMs = 1500;
4715 zombieLifetimeMs = 15000;
4716 jitterMaxTrimMs = 250;
4717 signalledInboundProcessorInactivityMs = (inboundProcessorInactivityMs * 4);
4721 static void to_json(nlohmann::json& j,
const RtpProfile& p)
4725 TOJSON_IMPL(jitterMaxMs),
4726 TOJSON_IMPL(inboundProcessorInactivityMs),
4727 TOJSON_IMPL(jitterMinMs),
4728 TOJSON_IMPL(jitterMaxFactor),
4729 TOJSON_IMPL(jitterTrimPercentage),
4730 TOJSON_IMPL(jitterUnderrunReductionThresholdMs),
4731 TOJSON_IMPL(jitterUnderrunReductionAger),
4732 TOJSON_IMPL(latePacketSequenceRange),
4733 TOJSON_IMPL(latePacketTimestampRangeMs),
4734 TOJSON_IMPL(inboundProcessorInactivityMs),
4735 TOJSON_IMPL(jitterForceTrimAtMs),
4736 TOJSON_IMPL(jitterMaxExceededClipPerc),
4737 TOJSON_IMPL(jitterMaxExceededClipHangMs),
4738 TOJSON_IMPL(zombieLifetimeMs),
4739 TOJSON_IMPL(jitterMaxTrimMs),
4740 TOJSON_IMPL(signalledInboundProcessorInactivityMs)
4743 static void from_json(
const nlohmann::json& j, RtpProfile& p)
4746 FROMJSON_IMPL(mode, RtpProfile::JitterMode_t, RtpProfile::JitterMode_t::jmStandard);
4747 FROMJSON_IMPL(jitterMaxMs,
int, 10000);
4748 FROMJSON_IMPL(jitterMinMs,
int, 20);
4749 FROMJSON_IMPL(jitterMaxFactor,
int, 8);
4750 FROMJSON_IMPL(jitterTrimPercentage,
int, 10);
4751 FROMJSON_IMPL(jitterUnderrunReductionThresholdMs,
int, 1500);
4752 FROMJSON_IMPL(jitterUnderrunReductionAger,
int, 100);
4753 FROMJSON_IMPL(latePacketSequenceRange,
int, 5);
4754 FROMJSON_IMPL(latePacketTimestampRangeMs,
int, 2000);
4755 FROMJSON_IMPL(inboundProcessorInactivityMs,
int, 500);
4756 FROMJSON_IMPL(jitterForceTrimAtMs,
int, 0);
4757 FROMJSON_IMPL(rtcpPresenceTimeoutMs,
int, 45000);
4758 FROMJSON_IMPL(jitterMaxExceededClipPerc,
int, 10);
4759 FROMJSON_IMPL(jitterMaxExceededClipHangMs,
int, 1500);
4760 FROMJSON_IMPL(zombieLifetimeMs,
int, 15000);
4761 FROMJSON_IMPL(jitterMaxTrimMs,
int, 250);
4762 FROMJSON_IMPL(signalledInboundProcessorInactivityMs,
int, (p.inboundProcessorInactivityMs * 4));
4766 JSON_SERIALIZED_CLASS(Tls)
4778 IMPLEMENT_JSON_SERIALIZATION()
4779 IMPLEMENT_JSON_DOCUMENTATION(
Tls)
4809 allowSelfSignedCertificates =
false;
4810 caCertificates.clear();
4811 subjectRestrictions.clear();
4812 issuerRestrictions.clear();
4817 static void to_json(nlohmann::json& j,
const Tls& p)
4820 TOJSON_IMPL(verifyPeers),
4821 TOJSON_IMPL(allowSelfSignedCertificates),
4822 TOJSON_IMPL(caCertificates),
4823 TOJSON_IMPL(subjectRestrictions),
4824 TOJSON_IMPL(issuerRestrictions),
4825 TOJSON_IMPL(crlSerials)
4828 static void from_json(
const nlohmann::json& j, Tls& p)
4831 getOptional<bool>(
"verifyPeers", p.verifyPeers, j,
true);
4832 getOptional<bool>(
"allowSelfSignedCertificates", p.allowSelfSignedCertificates, j,
false);
4833 getOptional<std::vector<std::string>>(
"caCertificates", p.caCertificates, j);
4834 getOptional<StringRestrictionList>(
"subjectRestrictions", p.subjectRestrictions, j);
4835 getOptional<StringRestrictionList>(
"issuerRestrictions", p.issuerRestrictions, j);
4836 getOptional<std::vector<std::string>>(
"crlSerials", p.crlSerials, j);
4840 JSON_SERIALIZED_CLASS(RangerPackets)
4854 IMPLEMENT_JSON_SERIALIZATION()
4875 virtual void initForDocumenting()
4880 static void to_json(nlohmann::json& j,
const RangerPackets& p)
4883 TOJSON_IMPL(hangTimerSecs),
4887 static void from_json(
const nlohmann::json& j, RangerPackets& p)
4890 getOptional<int>(
"hangTimerSecs", p.hangTimerSecs, j, 11);
4891 getOptional<int>(
"count", p.count, j, 5);
4895 JSON_SERIALIZED_CLASS(Source)
4909 IMPLEMENT_JSON_SERIALIZATION()
4910 IMPLEMENT_JSON_DOCUMENTATION(
Source)
4917 uint8_t _internal_binary_nodeId[ENGAGE_MAX_NODE_ID_SIZE];
4923 uint8_t _internal_binary_alias[ENGAGE_MAX_ALIAS_SIZE];
4933 memset(_internal_binary_nodeId, 0,
sizeof(_internal_binary_nodeId));
4936 memset(_internal_binary_alias, 0,
sizeof(_internal_binary_alias));
4939 virtual void initForDocumenting()
4944 static void to_json(nlohmann::json& j,
const Source& p)
4947 TOJSON_IMPL(nodeId),
4951 static void from_json(
const nlohmann::json& j, Source& p)
4954 FROMJSON_IMPL_SIMPLE(nodeId);
4955 FROMJSON_IMPL_SIMPLE(alias);
4959 JSON_SERIALIZED_CLASS(GroupBridgeTargetOutputDetail)
4973 IMPLEMENT_JSON_SERIALIZATION()
5010 mode = BridgingOpMode_t::bomRaw;
5011 mixedStreamTxParams.clear();
5014 virtual void initForDocumenting()
5020 static void to_json(nlohmann::json& j,
const GroupBridgeTargetOutputDetail& p)
5024 TOJSON_IMPL(mixedStreamTxParams)
5027 static void from_json(
const nlohmann::json& j, GroupBridgeTargetOutputDetail& p)
5030 FROMJSON_IMPL_SIMPLE(mode);
5031 FROMJSON_IMPL_SIMPLE(mixedStreamTxParams);
5035 JSON_SERIALIZED_CLASS(Group)
5048 IMPLEMENT_JSON_SERIALIZATION()
5049 IMPLEMENT_JSON_DOCUMENTATION(
Group)
5072 iagpAnonymousAlias = 0,
5076 } InboundAliasGenerationPolicy_t;
5248 bridgeTargetOutputDetail.clear();
5252 interfaceName.clear();
5258 cryptoPassword.clear();
5262 rallypoints.clear();
5263 rallypointCluster.clear();
5268 blockAdvertising =
false;
5274 enableMulticastFailover =
false;
5275 multicastFailoverSecs = 10;
5277 rtcpPresenceRx.clear();
5279 presenceGroupAffinities.clear();
5280 disablePacketEvents =
false;
5282 rfc4733RtpPayloadId = 0;
5283 inboundRtpPayloadTypeTranslations.clear();
5284 priorityTranslation.clear();
5286 stickyTidHangSecs = 10;
5287 anonymousAlias.clear();
5290 appTransport.clear();
5291 allowLoopback =
false;
5294 rangerPackets.clear();
5296 _wasDeserialized_rtpProfile =
false;
5298 txImpairment.clear();
5299 rxImpairment.clear();
5301 specializerAffinities.clear();
5305 ignoreSources.clear();
5307 languageCode.clear();
5314 inboundAliasGenerationPolicy = iagpAnonymousAlias;
5317 ignoreAudioTraffic =
false;
5321 static void to_json(nlohmann::json& j,
const Group& p)
5325 TOJSON_IMPL(bridgeTargetOutputDetail),
5328 TOJSON_IMPL(spokenName),
5329 TOJSON_IMPL(interfaceName),
5332 TOJSON_IMPL(txOptions),
5333 TOJSON_IMPL(txAudio),
5334 TOJSON_IMPL(presence),
5335 TOJSON_IMPL(cryptoPassword),
5344 TOJSON_IMPL(timeline),
5345 TOJSON_IMPL(blockAdvertising),
5346 TOJSON_IMPL(source),
5347 TOJSON_IMPL(maxRxSecs),
5348 TOJSON_IMPL(enableMulticastFailover),
5349 TOJSON_IMPL(multicastFailoverSecs),
5350 TOJSON_IMPL(rtcpPresenceRx),
5351 TOJSON_IMPL(presenceGroupAffinities),
5352 TOJSON_IMPL(disablePacketEvents),
5353 TOJSON_IMPL(rfc4733RtpPayloadId),
5354 TOJSON_IMPL(inboundRtpPayloadTypeTranslations),
5355 TOJSON_IMPL(priorityTranslation),
5356 TOJSON_IMPL(stickyTidHangSecs),
5357 TOJSON_IMPL(anonymousAlias),
5358 TOJSON_IMPL(lbCrypto),
5359 TOJSON_IMPL(appTransport),
5360 TOJSON_IMPL(allowLoopback),
5361 TOJSON_IMPL(rangerPackets),
5363 TOJSON_IMPL(txImpairment),
5364 TOJSON_IMPL(rxImpairment),
5366 TOJSON_IMPL(specializerAffinities),
5368 TOJSON_IMPL(securityLevel),
5370 TOJSON_IMPL(ignoreSources),
5372 TOJSON_IMPL(languageCode),
5373 TOJSON_IMPL(synVoice),
5375 TOJSON_IMPL(rxCapture),
5376 TOJSON_IMPL(txCapture),
5378 TOJSON_IMPL(blobRtpPayloadType),
5380 TOJSON_IMPL(inboundAliasGenerationPolicy),
5382 TOJSON_IMPL(gateIn),
5384 TOJSON_IMPL(ignoreAudioTraffic)
5390 if(p._wasDeserialized_rtpProfile || p.isDocumenting())
5392 j[
"rtpProfile"] = p.rtpProfile;
5395 if(p.isDocumenting())
5397 j[
"rallypointCluster"] = p.rallypointCluster;
5398 j[
"rallypoints"] = p.rallypoints;
5403 if(!p.rallypointCluster.rallypoints.empty())
5405 j[
"rallypointCluster"] = p.rallypointCluster;
5407 else if(!p.rallypoints.empty())
5409 j[
"rallypoints"] = p.rallypoints;
5413 static void from_json(
const nlohmann::json& j, Group& p)
5416 j.at(
"type").get_to(p.type);
5417 getOptional<GroupBridgeTargetOutputDetail>(
"bridgeTargetOutputDetail", p.bridgeTargetOutputDetail, j);
5418 j.at(
"id").get_to(p.id);
5419 getOptional<std::string>(
"name", p.name, j);
5420 getOptional<std::string>(
"spokenName", p.spokenName, j);
5421 getOptional<std::string>(
"interfaceName", p.interfaceName, j);
5422 getOptional<NetworkAddress>(
"rx", p.rx, j);
5423 getOptional<NetworkAddress>(
"tx", p.tx, j);
5424 getOptional<NetworkTxOptions>(
"txOptions", p.txOptions, j);
5425 getOptional<std::string>(
"cryptoPassword", p.cryptoPassword, j);
5426 getOptional<std::string>(
"alias", p.alias, j);
5427 getOptional<TxAudio>(
"txAudio", p.txAudio, j);
5428 getOptional<Presence>(
"presence", p.presence, j);
5429 getOptional<std::vector<Rallypoint>>(
"rallypoints", p.rallypoints, j);
5430 getOptional<RallypointCluster>(
"rallypointCluster", p.rallypointCluster, j);
5431 getOptional<Audio>(
"audio", p.audio, j);
5432 getOptional<GroupTimeline>(
"timeline", p.timeline, j);
5433 getOptional<bool>(
"blockAdvertising", p.blockAdvertising, j,
false);
5434 getOptional<std::string>(
"source", p.source, j);
5435 getOptional<int>(
"maxRxSecs", p.maxRxSecs, j, 0);
5436 getOptional<bool>(
"enableMulticastFailover", p.enableMulticastFailover, j,
false);
5437 getOptional<int>(
"multicastFailoverSecs", p.multicastFailoverSecs, j, 10);
5438 getOptional<NetworkAddress>(
"rtcpPresenceRx", p.rtcpPresenceRx, j);
5439 getOptional<std::vector<std::string>>(
"presenceGroupAffinities", p.presenceGroupAffinities, j);
5440 getOptional<bool>(
"disablePacketEvents", p.disablePacketEvents, j,
false);
5441 getOptional<int>(
"rfc4733RtpPayloadId", p.rfc4733RtpPayloadId, j, 0);
5442 getOptional<std::vector<RtpPayloadTypeTranslation>>(
"inboundRtpPayloadTypeTranslations", p.inboundRtpPayloadTypeTranslations, j);
5443 getOptional<GroupPriorityTranslation>(
"priorityTranslation", p.priorityTranslation, j);
5444 getOptional<int>(
"stickyTidHangSecs", p.stickyTidHangSecs, j, 10);
5445 getOptional<std::string>(
"anonymousAlias", p.anonymousAlias, j);
5446 getOptional<bool>(
"lbCrypto", p.lbCrypto, j,
false);
5447 getOptional<GroupAppTransport>(
"appTransport", p.appTransport, j);
5448 getOptional<bool>(
"allowLoopback", p.allowLoopback, j,
false);
5449 getOptionalWithIndicator<RtpProfile>(
"rtpProfile", p.rtpProfile, j, &p._wasDeserialized_rtpProfile);
5450 getOptional<RangerPackets>(
"rangerPackets", p.rangerPackets, j);
5451 getOptional<TransportImpairment>(
"txImpairment", p.txImpairment, j);
5452 getOptional<TransportImpairment>(
"rxImpairment", p.rxImpairment, j);
5453 getOptional<std::vector<uint16_t>>(
"specializerAffinities", p.specializerAffinities, j);
5454 getOptional<uint32_t>(
"securityLevel", p.securityLevel, j, 0);
5455 getOptional<std::vector<Source>>(
"ignoreSources", p.ignoreSources, j);
5456 getOptional<std::string>(
"languageCode", p.languageCode, j);
5457 getOptional<std::string>(
"synVoice", p.synVoice, j);
5459 getOptional<PacketCapturer>(
"rxCapture", p.rxCapture, j);
5460 getOptional<PacketCapturer>(
"txCapture", p.txCapture, j);
5464 getOptional<Group::InboundAliasGenerationPolicy_t>(
"inboundAliasGenerationPolicy", p.inboundAliasGenerationPolicy, j, Group::InboundAliasGenerationPolicy_t::iagpAnonymousAlias);
5466 getOptional<AudioGate>(
"gateIn", p.gateIn, j);
5468 getOptional<bool>(
"ignoreAudioTraffic", p.ignoreAudioTraffic, j,
false);
5470 FROMJSON_BASE_IMPL();
5475 JSON_SERIALIZED_CLASS(Mission)
5478 IMPLEMENT_JSON_SERIALIZATION()
5479 IMPLEMENT_JSON_DOCUMENTATION(
Mission)
5484 std::vector<Group> groups;
5485 std::chrono::system_clock::time_point begins;
5486 std::chrono::system_clock::time_point ends;
5487 std::string certStoreId;
5488 int multicastFailoverPolicy;
5496 certStoreId.clear();
5497 multicastFailoverPolicy = 0;
5502 static void to_json(nlohmann::json& j,
const Mission& p)
5507 TOJSON_IMPL(groups),
5508 TOJSON_IMPL(certStoreId),
5509 TOJSON_IMPL(multicastFailoverPolicy),
5510 TOJSON_IMPL(rallypoint)
5514 static void from_json(
const nlohmann::json& j, Mission& p)
5517 j.at(
"id").get_to(p.id);
5518 j.at(
"name").get_to(p.name);
5523 j.at(
"groups").get_to(p.groups);
5530 FROMJSON_IMPL(certStoreId, std::string, EMPTY_STRING);
5531 FROMJSON_IMPL(multicastFailoverPolicy,
int, 0);
5532 getOptional<Rallypoint>(
"rallypoint", p.rallypoint, j);
5536 JSON_SERIALIZED_CLASS(LicenseDescriptor)
5548 IMPLEMENT_JSON_SERIALIZATION()
5557 static const int STATUS_OK = 0;
5558 static const int ERR_NULL_ENTITLEMENT_KEY = -1;
5559 static const int ERR_NULL_LICENSE_KEY = -2;
5560 static const int ERR_INVALID_LICENSE_KEY_LEN = -3;
5561 static const int ERR_LICENSE_KEY_VERIFICATION_FAILURE = -4;
5562 static const int ERR_ACTIVATION_CODE_VERIFICATION_FAILURE = -5;
5563 static const int ERR_INVALID_EXPIRATION_DATE = -6;
5564 static const int ERR_GENERAL_FAILURE = -7;
5565 static const int ERR_NOT_INITIALIZED = -8;
5566 static const int ERR_REQUIRES_ACTIVATION = -9;
5567 static const int ERR_LICENSE_NOT_SUITED_FOR_ACTIVATION = -10;
5575 static const uint8_t LIC_CARGO_FLAG_LIMIT_TO_FEATURES = 0x01;
5639 entitlement.clear();
5641 activationCode.clear();
5644 expiresFormatted.clear();
5649 status = ERR_NOT_INITIALIZED;
5650 manufacturerId.clear();
5654 static void to_json(nlohmann::json& j,
const LicenseDescriptor& p)
5658 {
"entitlement",
"*entitlement*"},
5660 TOJSON_IMPL(activationCode),
5662 TOJSON_IMPL(expires),
5663 TOJSON_IMPL(expiresFormatted),
5665 TOJSON_IMPL(deviceId),
5666 TOJSON_IMPL(status),
5668 {
"manufacturerId",
"*manufacturerId*"},
5670 TOJSON_IMPL(cargoFlags)
5674 static void from_json(
const nlohmann::json& j, LicenseDescriptor& p)
5677 FROMJSON_IMPL(entitlement, std::string, EMPTY_STRING);
5678 FROMJSON_IMPL(key, std::string, EMPTY_STRING);
5679 FROMJSON_IMPL(activationCode, std::string, EMPTY_STRING);
5680 FROMJSON_IMPL(type,
int, 0);
5681 FROMJSON_IMPL(expires, time_t, 0);
5682 FROMJSON_IMPL(expiresFormatted, std::string, EMPTY_STRING);
5683 FROMJSON_IMPL(flags, uint32_t, 0);
5684 FROMJSON_IMPL(deviceId, std::string, EMPTY_STRING);
5685 FROMJSON_IMPL(status,
int, LicenseDescriptor::ERR_NOT_INITIALIZED);
5686 FROMJSON_IMPL(manufacturerId, std::string, EMPTY_STRING);
5687 FROMJSON_IMPL(cargo, std::string, EMPTY_STRING);
5688 FROMJSON_IMPL(cargoFlags, uint8_t, 0);
5693 JSON_SERIALIZED_CLASS(EngineNetworkingRpUdpStreaming)
5707 IMPLEMENT_JSON_SERIALIZATION()
5735 keepaliveIntervalSecs = 15;
5736 priority = TxPriority_t::priVoice;
5740 virtual void initForDocumenting()
5745 static void to_json(nlohmann::json& j,
const EngineNetworkingRpUdpStreaming& p)
5748 TOJSON_IMPL(enabled),
5750 TOJSON_IMPL(keepaliveIntervalSecs),
5751 TOJSON_IMPL(priority),
5755 static void from_json(
const nlohmann::json& j, EngineNetworkingRpUdpStreaming& p)
5758 getOptional<bool>(
"enabled", p.enabled, j,
false);
5759 getOptional<int>(
"port", p.port, j, 0);
5760 getOptional<int>(
"keepaliveIntervalSecs", p.keepaliveIntervalSecs, j, 15);
5761 getOptional<TxPriority_t>(
"priority", p.priority, j, TxPriority_t::priVoice);
5762 getOptional<int>(
"ttl", p.ttl, j, 64);
5766 JSON_SERIALIZED_CLASS(EnginePolicyNetworking)
5777 IMPLEMENT_JSON_SERIALIZATION()
5813 multicastRejoinSecs = 8;
5814 rallypointRtTestIntervalMs = 60000;
5815 logRtpJitterBufferStats =
false;
5816 preventMulticastFailover =
false;
5817 addressResolutionPolicy = AddressResolutionPolicy_t::arpIpv6ThenIpv4;
5819 rpUdpStreaming.clear();
5824 static void to_json(nlohmann::json& j,
const EnginePolicyNetworking& p)
5827 TOJSON_IMPL(defaultNic),
5828 TOJSON_IMPL(multicastRejoinSecs),
5830 TOJSON_IMPL(rallypointRtTestIntervalMs),
5831 TOJSON_IMPL(logRtpJitterBufferStats),
5832 TOJSON_IMPL(preventMulticastFailover),
5834 TOJSON_IMPL(rpUdpStreaming),
5835 TOJSON_IMPL(rtpProfile),
5836 TOJSON_IMPL(addressResolutionPolicy)
5839 static void from_json(
const nlohmann::json& j, EnginePolicyNetworking& p)
5842 FROMJSON_IMPL(defaultNic, std::string, EMPTY_STRING);
5843 FROMJSON_IMPL(multicastRejoinSecs,
int, 8);
5844 FROMJSON_IMPL(rallypointRtTestIntervalMs,
int, 60000);
5845 FROMJSON_IMPL(logRtpJitterBufferStats,
bool,
false);
5846 FROMJSON_IMPL(preventMulticastFailover,
bool,
false);
5848 getOptional<EngineNetworkingRpUdpStreaming>(
"rpUdpStreaming", p.rpUdpStreaming, j);
5849 getOptional<RtpProfile>(
"rtpProfile", p.rtpProfile, j);
5850 getOptional<AddressResolutionPolicy_t>(
"addressResolutionPolicy", p.addressResolutionPolicy, j, AddressResolutionPolicy_t::arpIpv6ThenIpv4);
5854 JSON_SERIALIZED_CLASS(Aec)
5866 IMPLEMENT_JSON_SERIALIZATION()
5867 IMPLEMENT_JSON_DOCUMENTATION(
Aec)
5922 static void to_json(nlohmann::json& j,
const Aec& p)
5925 TOJSON_IMPL(enabled),
5927 TOJSON_IMPL(speakerTailMs),
5931 static void from_json(
const nlohmann::json& j, Aec& p)
5934 FROMJSON_IMPL(enabled,
bool,
false);
5935 FROMJSON_IMPL(mode, Aec::Mode_t, Aec::Mode_t::aecmDefault);
5936 FROMJSON_IMPL(speakerTailMs,
int, 60);
5937 FROMJSON_IMPL(cng,
bool,
true);
5941 JSON_SERIALIZED_CLASS(Vad)
5953 IMPLEMENT_JSON_SERIALIZATION()
5954 IMPLEMENT_JSON_DOCUMENTATION(
Vad)
5974 vamVeryAggressive = 3
5995 static void to_json(nlohmann::json& j,
const Vad& p)
5998 TOJSON_IMPL(enabled),
6002 static void from_json(
const nlohmann::json& j, Vad& p)
6005 FROMJSON_IMPL(enabled,
bool,
false);
6006 FROMJSON_IMPL(mode, Vad::Mode_t, Vad::Mode_t::vamDefault);
6010 JSON_SERIALIZED_CLASS(Bridge)
6022 IMPLEMENT_JSON_SERIALIZATION()
6023 IMPLEMENT_JSON_DOCUMENTATION(
Bridge)
6054 static void to_json(nlohmann::json& j,
const Bridge& p)
6059 TOJSON_IMPL(groups),
6060 TOJSON_IMPL(enabled)
6063 static void from_json(
const nlohmann::json& j, Bridge& p)
6066 FROMJSON_IMPL(
id, std::string, EMPTY_STRING);
6067 FROMJSON_IMPL(name, std::string, EMPTY_STRING);
6068 getOptional<std::vector<std::string>>(
"groups", p.groups, j);
6069 FROMJSON_IMPL(enabled,
bool,
true);
6073 JSON_SERIALIZED_CLASS(AndroidAudio)
6085 IMPLEMENT_JSON_SERIALIZATION()
6089 constexpr static int INVALID_SESSION_ID = -9999;
6150 performanceMode = 12;
6154 sessionId = AndroidAudio::INVALID_SESSION_ID;
6159 static void to_json(nlohmann::json& j,
const AndroidAudio& p)
6163 TOJSON_IMPL(sharingMode),
6164 TOJSON_IMPL(performanceMode),
6166 TOJSON_IMPL(contentType),
6167 TOJSON_IMPL(inputPreset),
6168 TOJSON_IMPL(sessionId),
6169 TOJSON_IMPL(engineMode)
6172 static void from_json(
const nlohmann::json& j, AndroidAudio& p)
6175 FROMJSON_IMPL(api,
int, 0);
6176 FROMJSON_IMPL(sharingMode,
int, 0);
6177 FROMJSON_IMPL(performanceMode,
int, 12);
6178 FROMJSON_IMPL(usage,
int, 2);
6179 FROMJSON_IMPL(contentType,
int, 1);
6180 FROMJSON_IMPL(inputPreset,
int, 7);
6181 FROMJSON_IMPL(sessionId,
int, AndroidAudio::INVALID_SESSION_ID);
6182 FROMJSON_IMPL(engineMode,
int, 0);
6186 JSON_SERIALIZED_CLASS(EnginePolicyAudio)
6198 IMPLEMENT_JSON_SERIALIZATION()
6256 hardwareEnabled =
true;
6257 internalRate = 16000;
6258 internalChannels = 2;
6265 denoiseInput =
false;
6266 denoiseOutput =
false;
6267 saveInputPcm =
false;
6268 saveOutputPcm =
false;
6273 static void to_json(nlohmann::json& j,
const EnginePolicyAudio& p)
6276 TOJSON_IMPL(enabled),
6277 TOJSON_IMPL(hardwareEnabled),
6278 TOJSON_IMPL(internalRate),
6279 TOJSON_IMPL(internalChannels),
6280 TOJSON_IMPL(muteTxOnTx),
6283 TOJSON_IMPL(android),
6284 TOJSON_IMPL(inputAgc),
6285 TOJSON_IMPL(outputAgc),
6286 TOJSON_IMPL(denoiseInput),
6287 TOJSON_IMPL(denoiseOutput),
6288 TOJSON_IMPL(saveInputPcm),
6289 TOJSON_IMPL(saveOutputPcm),
6290 TOJSON_IMPL(registry)
6293 static void from_json(
const nlohmann::json& j, EnginePolicyAudio& p)
6296 getOptional<bool>(
"enabled", p.enabled, j,
true);
6297 getOptional<bool>(
"hardwareEnabled", p.hardwareEnabled, j,
true);
6298 FROMJSON_IMPL(internalRate,
int, 16000);
6299 FROMJSON_IMPL(internalChannels,
int, 2);
6301 FROMJSON_IMPL(muteTxOnTx,
bool,
false);
6302 getOptional<Aec>(
"aec", p.aec, j);
6303 getOptional<Vad>(
"vad", p.vad, j);
6304 getOptional<AndroidAudio>(
"android", p.android, j);
6305 getOptional<Agc>(
"inputAgc", p.inputAgc, j);
6306 getOptional<Agc>(
"outputAgc", p.outputAgc, j);
6307 FROMJSON_IMPL(denoiseInput,
bool,
false);
6308 FROMJSON_IMPL(denoiseOutput,
bool,
false);
6309 FROMJSON_IMPL(saveInputPcm,
bool,
false);
6310 FROMJSON_IMPL(saveOutputPcm,
bool,
false);
6311 getOptional<AudioRegistry>(
"registry", p.registry, j);
6315 JSON_SERIALIZED_CLASS(SecurityCertificate)
6327 IMPLEMENT_JSON_SERIALIZATION()
6349 certificate.clear();
6354 static void to_json(nlohmann::json& j,
const SecurityCertificate& p)
6357 TOJSON_IMPL(certificate),
6361 static void from_json(
const nlohmann::json& j, SecurityCertificate& p)
6364 FROMJSON_IMPL(certificate, std::string, EMPTY_STRING);
6365 FROMJSON_IMPL(key, std::string, EMPTY_STRING);
6370 JSON_SERIALIZED_CLASS(EnginePolicySecurity)
6383 IMPLEMENT_JSON_SERIALIZATION()
6416 certificate.clear();
6417 caCertificates.clear();
6421 static void to_json(nlohmann::json& j,
const EnginePolicySecurity& p)
6424 TOJSON_IMPL(certificate),
6425 TOJSON_IMPL(caCertificates)
6428 static void from_json(
const nlohmann::json& j, EnginePolicySecurity& p)
6431 getOptional(
"certificate", p.certificate, j);
6432 getOptional<std::vector<std::string>>(
"caCertificates", p.caCertificates, j);
6436 JSON_SERIALIZED_CLASS(EnginePolicyLogging)
6448 IMPLEMENT_JSON_SERIALIZATION()
6481 enableSyslog =
false;
6485 static void to_json(nlohmann::json& j,
const EnginePolicyLogging& p)
6488 TOJSON_IMPL(maxLevel),
6489 TOJSON_IMPL(enableSyslog)
6492 static void from_json(
const nlohmann::json& j, EnginePolicyLogging& p)
6495 getOptional(
"maxLevel", p.maxLevel, j, 4);
6496 getOptional(
"enableSyslog", p.enableSyslog, j);
6501 JSON_SERIALIZED_CLASS(EnginePolicyDatabase)
6504 IMPLEMENT_JSON_SERIALIZATION()
6515 DatabaseType_t type;
6516 std::string fixedFileName;
6517 bool forceMaintenance;
6527 type = DatabaseType_t::dbtFixedMemory;
6528 fixedFileName.clear();
6529 forceMaintenance =
false;
6530 reclaimSpace =
false;
6538 TOJSON_IMPL(fixedFileName),
6539 TOJSON_IMPL(forceMaintenance),
6540 TOJSON_IMPL(reclaimSpace)
6543 static void from_json(
const nlohmann::json& j, EnginePolicyDatabase& p)
6546 FROMJSON_IMPL(type, EnginePolicyDatabase::DatabaseType_t, EnginePolicyDatabase::DatabaseType_t::dbtFixedMemory);
6547 FROMJSON_IMPL(fixedFileName, std::string, EMPTY_STRING);
6548 FROMJSON_IMPL(forceMaintenance,
bool,
false);
6549 FROMJSON_IMPL(reclaimSpace,
bool,
false);
6554 JSON_SERIALIZED_CLASS(SecureSignature)
6564 IMPLEMENT_JSON_SERIALIZATION()
6585 certificate.clear();
6591 static void to_json(nlohmann::json& j,
const SecureSignature& p)
6594 TOJSON_IMPL(certificate),
6596 TOJSON_IMPL(signature)
6599 static void from_json(
const nlohmann::json& j, SecureSignature& p)
6602 FROMJSON_IMPL(certificate, std::string, EMPTY_STRING);
6604 FROMJSON_IMPL(signature, std::string, EMPTY_STRING);
6608 JSON_SERIALIZED_CLASS(NamedAudioDevice)
6611 IMPLEMENT_JSON_SERIALIZATION()
6616 std::string manufacturer;
6619 std::string serialNumber;
6632 manufacturer.clear();
6635 serialNumber.clear();
6646 TOJSON_IMPL(manufacturer),
6649 TOJSON_IMPL(serialNumber),
6652 TOJSON_IMPL(isDefault),
6655 static void from_json(
const nlohmann::json& j, NamedAudioDevice& p)
6658 getOptional<std::string>(
"name", p.name, j, EMPTY_STRING);
6659 getOptional<std::string>(
"manufacturer", p.manufacturer, j, EMPTY_STRING);
6660 getOptional<std::string>(
"model", p.model, j, EMPTY_STRING);
6661 getOptional<std::string>(
"id", p.id, j, EMPTY_STRING);
6662 getOptional<std::string>(
"serialNumber", p.serialNumber, j, EMPTY_STRING);
6663 getOptional<std::string>(
"type", p.type, j, EMPTY_STRING);
6664 getOptional<std::string>(
"extra", p.extra, j, EMPTY_STRING);
6665 getOptional<bool>(
"isDefault", p.isDefault, j,
false);
6670 JSON_SERIALIZED_CLASS(EnginePolicyNamedAudioDevices)
6673 IMPLEMENT_JSON_SERIALIZATION()
6677 std::vector<NamedAudioDevice> inputs;
6678 std::vector<NamedAudioDevice> outputs;
6695 TOJSON_IMPL(inputs),
6696 TOJSON_IMPL(outputs)
6699 static void from_json(
const nlohmann::json& j, EnginePolicyNamedAudioDevices& p)
6702 getOptional<std::vector<NamedAudioDevice>>(
"inputs", p.inputs, j);
6703 getOptional<std::vector<NamedAudioDevice>>(
"outputs", p.outputs, j);
6707 JSON_SERIALIZED_CLASS(Licensing)
6721 IMPLEMENT_JSON_SERIALIZATION()
6748 entitlement.clear();
6750 activationCode.clear();
6752 manufacturerId.clear();
6756 static void to_json(nlohmann::json& j,
const Licensing& p)
6759 TOJSON_IMPL(entitlement),
6761 TOJSON_IMPL(activationCode),
6762 TOJSON_IMPL(deviceId),
6763 TOJSON_IMPL(manufacturerId)
6766 static void from_json(
const nlohmann::json& j, Licensing& p)
6769 FROMJSON_IMPL(entitlement, std::string, EMPTY_STRING);
6770 FROMJSON_IMPL(key, std::string, EMPTY_STRING);
6771 FROMJSON_IMPL(activationCode, std::string, EMPTY_STRING);
6772 FROMJSON_IMPL(deviceId, std::string, EMPTY_STRING);
6773 FROMJSON_IMPL(manufacturerId, std::string, EMPTY_STRING);
6777 JSON_SERIALIZED_CLASS(DiscoveryMagellan)
6789 IMPLEMENT_JSON_SERIALIZATION()
6814 interfaceName.clear();
6820 static void to_json(nlohmann::json& j,
const DiscoveryMagellan& p)
6823 TOJSON_IMPL(enabled),
6824 TOJSON_IMPL(interfaceName),
6825 TOJSON_IMPL(security),
6829 static void from_json(
const nlohmann::json& j, DiscoveryMagellan& p)
6832 getOptional(
"enabled", p.enabled, j,
false);
6833 getOptional<Tls>(
"tls", p.tls, j);
6834 getOptional<SecurityCertificate>(
"security", p.security, j);
6835 FROMJSON_IMPL(interfaceName, std::string, EMPTY_STRING);
6839 JSON_SERIALIZED_CLASS(DiscoverySsdp)
6851 IMPLEMENT_JSON_SERIALIZATION()
6882 interfaceName.clear();
6884 searchTerms.clear();
6885 ageTimeoutMs = 30000;
6886 advertising.clear();
6890 static void to_json(nlohmann::json& j,
const DiscoverySsdp& p)
6893 TOJSON_IMPL(enabled),
6894 TOJSON_IMPL(interfaceName),
6895 TOJSON_IMPL(address),
6896 TOJSON_IMPL(searchTerms),
6897 TOJSON_IMPL(ageTimeoutMs),
6898 TOJSON_IMPL(advertising)
6901 static void from_json(
const nlohmann::json& j, DiscoverySsdp& p)
6904 getOptional(
"enabled", p.enabled, j,
false);
6905 getOptional<std::string>(
"interfaceName", p.interfaceName, j);
6907 getOptional<NetworkAddress>(
"address", p.address, j);
6908 if(p.address.address.empty())
6910 p.address.address =
"255.255.255.255";
6912 if(p.address.port <= 0)
6914 p.address.port = 1900;
6917 getOptional<std::vector<std::string>>(
"searchTerms", p.searchTerms, j);
6918 getOptional<int>(
"ageTimeoutMs", p.ageTimeoutMs, j, 30000);
6919 getOptional<Advertising>(
"advertising", p.advertising, j);
6923 JSON_SERIALIZED_CLASS(DiscoverySap)
6935 IMPLEMENT_JSON_SERIALIZATION()
6962 interfaceName.clear();
6964 ageTimeoutMs = 30000;
6965 advertising.clear();
6969 static void to_json(nlohmann::json& j,
const DiscoverySap& p)
6972 TOJSON_IMPL(enabled),
6973 TOJSON_IMPL(interfaceName),
6974 TOJSON_IMPL(address),
6975 TOJSON_IMPL(ageTimeoutMs),
6976 TOJSON_IMPL(advertising)
6979 static void from_json(
const nlohmann::json& j, DiscoverySap& p)
6982 getOptional(
"enabled", p.enabled, j,
false);
6983 getOptional<std::string>(
"interfaceName", p.interfaceName, j);
6984 getOptional<NetworkAddress>(
"address", p.address, j);
6985 if(p.address.address.empty())
6987 p.address.address =
"224.2.127.254";
6989 if(p.address.port <= 0)
6991 p.address.port = 9875;
6994 getOptional<int>(
"ageTimeoutMs", p.ageTimeoutMs, j, 30000);
6995 getOptional<Advertising>(
"advertising", p.advertising, j);
6999 JSON_SERIALIZED_CLASS(DiscoveryCistech)
7013 IMPLEMENT_JSON_SERIALIZATION()
7018 std::string interfaceName;
7030 interfaceName.clear();
7032 ageTimeoutMs = 30000;
7039 TOJSON_IMPL(enabled),
7040 TOJSON_IMPL(interfaceName),
7041 TOJSON_IMPL(address),
7042 TOJSON_IMPL(ageTimeoutMs)
7045 static void from_json(
const nlohmann::json& j, DiscoveryCistech& p)
7048 getOptional(
"enabled", p.enabled, j,
false);
7049 getOptional<std::string>(
"interfaceName", p.interfaceName, j);
7050 getOptional<NetworkAddress>(
"address", p.address, j);
7051 getOptional<int>(
"ageTimeoutMs", p.ageTimeoutMs, j, 30000);
7056 JSON_SERIALIZED_CLASS(DiscoveryTrellisware)
7068 IMPLEMENT_JSON_SERIALIZATION()
7091 static void to_json(nlohmann::json& j,
const DiscoveryTrellisware& p)
7094 TOJSON_IMPL(enabled),
7095 TOJSON_IMPL(security)
7098 static void from_json(
const nlohmann::json& j, DiscoveryTrellisware& p)
7101 getOptional(
"enabled", p.enabled, j,
false);
7102 getOptional<SecurityCertificate>(
"security", p.security, j);
7106 JSON_SERIALIZED_CLASS(DiscoveryConfiguration)
7118 IMPLEMENT_JSON_SERIALIZATION()
7151 static void to_json(nlohmann::json& j,
const DiscoveryConfiguration& p)
7154 TOJSON_IMPL(magellan),
7157 TOJSON_IMPL(cistech),
7158 TOJSON_IMPL(trellisware)
7161 static void from_json(
const nlohmann::json& j, DiscoveryConfiguration& p)
7164 getOptional<DiscoveryMagellan>(
"magellan", p.magellan, j);
7165 getOptional<DiscoverySsdp>(
"ssdp", p.ssdp, j);
7166 getOptional<DiscoverySap>(
"sap", p.sap, j);
7167 getOptional<DiscoveryCistech>(
"cistech", p.cistech, j);
7168 getOptional<DiscoveryTrellisware>(
"trellisware", p.trellisware, j);
7173 JSON_SERIALIZED_CLASS(EnginePolicyInternals)
7187 IMPLEMENT_JSON_SERIALIZATION()
7202 int logTaskQueueStatsIntervalMs;
7204 bool enableLazySpeakerClosure;
7241 housekeeperIntervalMs = 1000;
7242 logTaskQueueStatsIntervalMs = 0;
7245 enableLazySpeakerClosure =
false;
7246 rpClusterStrategy = RallypointCluster::ConnectionStrategy_t::csRoundRobin;
7247 rpClusterRolloverSecs = 10;
7248 rtpExpirationCheckIntervalMs = 250;
7249 rpConnectionTimeoutSecs = 0;
7250 rpTransactionTimeoutMs = 0;
7251 stickyTidHangSecs = 10;
7252 uriStreamingIntervalMs = 60;
7253 delayedMicrophoneClosureSecs = 15;
7258 static void to_json(nlohmann::json& j,
const EnginePolicyInternals& p)
7261 TOJSON_IMPL(watchdog),
7262 TOJSON_IMPL(housekeeperIntervalMs),
7263 TOJSON_IMPL(logTaskQueueStatsIntervalMs),
7264 TOJSON_IMPL(maxTxSecs),
7265 TOJSON_IMPL(maxRxSecs),
7266 TOJSON_IMPL(enableLazySpeakerClosure),
7267 TOJSON_IMPL(rpClusterStrategy),
7268 TOJSON_IMPL(rpClusterRolloverSecs),
7269 TOJSON_IMPL(rtpExpirationCheckIntervalMs),
7270 TOJSON_IMPL(rpConnectionTimeoutSecs),
7271 TOJSON_IMPL(rpTransactionTimeoutMs),
7272 TOJSON_IMPL(stickyTidHangSecs),
7273 TOJSON_IMPL(uriStreamingIntervalMs),
7274 TOJSON_IMPL(delayedMicrophoneClosureSecs),
7278 static void from_json(
const nlohmann::json& j, EnginePolicyInternals& p)
7281 getOptional<WatchdogSettings>(
"watchdog", p.watchdog, j);
7282 getOptional<int>(
"housekeeperIntervalMs", p.housekeeperIntervalMs, j, 1000);
7283 getOptional<int>(
"logTaskQueueStatsIntervalMs", p.logTaskQueueStatsIntervalMs, j, 0);
7284 getOptional<int>(
"maxTxSecs", p.maxTxSecs, j, 30);
7285 getOptional<int>(
"maxRxSecs", p.maxRxSecs, j, 0);
7286 getOptional<bool>(
"enableLazySpeakerClosure", p.enableLazySpeakerClosure, j,
false);
7287 getOptional<RallypointCluster::ConnectionStrategy_t>(
"rpClusterStrategy", p.rpClusterStrategy, j, RallypointCluster::ConnectionStrategy_t::csRoundRobin);
7288 getOptional<int>(
"rpClusterRolloverSecs", p.rpClusterRolloverSecs, j, 10);
7289 getOptional<int>(
"rtpExpirationCheckIntervalMs", p.rtpExpirationCheckIntervalMs, j, 250);
7290 getOptional<int>(
"rpConnectionTimeoutSecs", p.rpConnectionTimeoutSecs, j, 0);
7291 getOptional<int>(
"rpTransactionTimeoutMs", p.rpTransactionTimeoutMs, j, 0);
7292 getOptional<int>(
"stickyTidHangSecs", p.stickyTidHangSecs, j, 10);
7293 getOptional<int>(
"uriStreamingIntervalMs", p.uriStreamingIntervalMs, j, 60);
7294 getOptional<int>(
"delayedMicrophoneClosureSecs", p.delayedMicrophoneClosureSecs, j, 15);
7295 getOptional<TuningSettings>(
"tuning", p.tuning, j);
7299 JSON_SERIALIZED_CLASS(EnginePolicyTimelines)
7313 IMPLEMENT_JSON_SERIALIZATION()
7375 storageRoot.clear();
7376 maxStorageMb = 1024;
7377 maxMemMb = maxStorageMb;
7378 maxAudioEventMemMb = maxMemMb;
7379 maxDiskMb = maxStorageMb;
7380 maxEventAgeSecs = (86400 * 30);
7381 groomingIntervalSecs = (60 * 30);
7383 autosaveIntervalSecs = 5;
7385 disableSigningAndVerification =
false;
7390 static void to_json(nlohmann::json& j,
const EnginePolicyTimelines& p)
7393 TOJSON_IMPL(enabled),
7394 TOJSON_IMPL(storageRoot),
7395 TOJSON_IMPL(maxMemMb),
7396 TOJSON_IMPL(maxAudioEventMemMb),
7397 TOJSON_IMPL(maxDiskMb),
7398 TOJSON_IMPL(maxEventAgeSecs),
7399 TOJSON_IMPL(maxEvents),
7400 TOJSON_IMPL(groomingIntervalSecs),
7401 TOJSON_IMPL(autosaveIntervalSecs),
7402 TOJSON_IMPL(security),
7403 TOJSON_IMPL(disableSigningAndVerification),
7404 TOJSON_IMPL(ephemeral)
7407 static void from_json(
const nlohmann::json& j, EnginePolicyTimelines& p)
7410 getOptional<bool>(
"enabled", p.enabled, j,
true);
7411 getOptional<std::string>(
"storageRoot", p.storageRoot, j, EMPTY_STRING);
7413 getOptional<int>(
"maxStorageMb", p.maxStorageMb, j, 1024);
7414 getOptional<int>(
"maxMemMb", p.maxMemMb, j, p.maxStorageMb);
7415 getOptional<int>(
"maxAudioEventMemMb", p.maxAudioEventMemMb, j, p.maxMemMb);
7416 getOptional<int>(
"maxDiskMb", p.maxDiskMb, j, p.maxStorageMb);
7417 getOptional<long>(
"maxEventAgeSecs", p.maxEventAgeSecs, j, (86400 * 30));
7418 getOptional<long>(
"groomingIntervalSecs", p.groomingIntervalSecs, j, (60 * 30));
7419 getOptional<long>(
"autosaveIntervalSecs", p.autosaveIntervalSecs, j, 5);
7420 getOptional<int>(
"maxEvents", p.maxEvents, j, 1000);
7421 getOptional<SecurityCertificate>(
"security", p.security, j);
7422 getOptional<bool>(
"disableSigningAndVerification", p.disableSigningAndVerification, j,
false);
7423 getOptional<bool>(
"ephemeral", p.ephemeral, j,
false);
7428 JSON_SERIALIZED_CLASS(RtpMapEntry)
7440 IMPLEMENT_JSON_SERIALIZATION()
7462 rtpPayloadType = -1;
7466 static void to_json(nlohmann::json& j,
const RtpMapEntry& p)
7470 TOJSON_IMPL(engageType),
7471 TOJSON_IMPL(rtpPayloadType)
7474 static void from_json(
const nlohmann::json& j, RtpMapEntry& p)
7477 getOptional<std::string>(
"name", p.name, j, EMPTY_STRING);
7478 getOptional<int>(
"engageType", p.engageType, j, -1);
7479 getOptional<int>(
"rtpPayloadType", p.rtpPayloadType, j, -1);
7483 JSON_SERIALIZED_CLASS(ExternalModule)
7495 IMPLEMENT_JSON_SERIALIZATION()
7517 configuration.clear();
7521 static void to_json(nlohmann::json& j,
const ExternalModule& p)
7528 if(!p.configuration.empty())
7530 j[
"configuration"] = p.configuration;
7533 static void from_json(
const nlohmann::json& j, ExternalModule& p)
7536 getOptional<std::string>(
"name", p.name, j, EMPTY_STRING);
7537 getOptional<std::string>(
"file", p.file, j, EMPTY_STRING);
7541 p.configuration = j.at(
"configuration");
7545 p.configuration.clear();
7551 JSON_SERIALIZED_CLASS(ExternalCodecDescriptor)
7563 IMPLEMENT_JSON_SERIALIZATION()
7586 rtpPayloadType = -1;
7589 rtpTsMultiplier = 0;
7593 static void to_json(nlohmann::json& j,
const ExternalCodecDescriptor& p)
7596 TOJSON_IMPL(rtpPayloadType),
7597 TOJSON_IMPL(samplingRate),
7598 TOJSON_IMPL(channels),
7599 TOJSON_IMPL(rtpTsMultiplier)
7602 static void from_json(
const nlohmann::json& j, ExternalCodecDescriptor& p)
7606 getOptional<int>(
"rtpPayloadType", p.rtpPayloadType, j, -1);
7607 getOptional<int>(
"samplingRate", p.samplingRate, j, -1);
7608 getOptional<int>(
"channels", p.channels, j, -1);
7609 getOptional<int>(
"rtpTsMultiplier", p.rtpTsMultiplier, j, -1);
7613 JSON_SERIALIZED_CLASS(EngineStatusReportConfiguration)
7625 IMPLEMENT_JSON_SERIALIZATION()
7657 includeMemoryDetail =
false;
7658 includeTaskQueueDetail =
false;
7663 static void to_json(nlohmann::json& j,
const EngineStatusReportConfiguration& p)
7666 TOJSON_IMPL(fileName),
7667 TOJSON_IMPL(intervalSecs),
7668 TOJSON_IMPL(enabled),
7669 TOJSON_IMPL(includeMemoryDetail),
7670 TOJSON_IMPL(includeTaskQueueDetail),
7674 static void from_json(
const nlohmann::json& j, EngineStatusReportConfiguration& p)
7677 getOptional<std::string>(
"fileName", p.fileName, j);
7678 getOptional<int>(
"intervalSecs", p.intervalSecs, j, 60);
7679 getOptional<bool>(
"enabled", p.enabled, j,
false);
7680 getOptional<std::string>(
"runCmd", p.runCmd, j);
7681 getOptional<bool>(
"includeMemoryDetail", p.includeMemoryDetail, j,
false);
7682 getOptional<bool>(
"includeTaskQueueDetail", p.includeTaskQueueDetail, j,
false);
7686 JSON_SERIALIZED_CLASS(EnginePolicy)
7700 IMPLEMENT_JSON_SERIALIZATION()
7757 dataDirectory.clear();
7768 namedAudioDevices.clear();
7769 externalCodecs.clear();
7771 statusReport.clear();
7775 static void to_json(nlohmann::json& j,
const EnginePolicy& p)
7778 TOJSON_IMPL(dataDirectory),
7779 TOJSON_IMPL(licensing),
7780 TOJSON_IMPL(security),
7781 TOJSON_IMPL(networking),
7783 TOJSON_IMPL(discovery),
7784 TOJSON_IMPL(logging),
7785 TOJSON_IMPL(internals),
7786 TOJSON_IMPL(timelines),
7787 TOJSON_IMPL(database),
7788 TOJSON_IMPL(featureset),
7789 TOJSON_IMPL(namedAudioDevices),
7790 TOJSON_IMPL(externalCodecs),
7791 TOJSON_IMPL(rtpMap),
7792 TOJSON_IMPL(statusReport)
7795 static void from_json(
const nlohmann::json& j, EnginePolicy& p)
7798 FROMJSON_IMPL_SIMPLE(dataDirectory);
7799 FROMJSON_IMPL_SIMPLE(licensing);
7800 FROMJSON_IMPL_SIMPLE(security);
7801 FROMJSON_IMPL_SIMPLE(networking);
7802 FROMJSON_IMPL_SIMPLE(audio);
7803 FROMJSON_IMPL_SIMPLE(discovery);
7804 FROMJSON_IMPL_SIMPLE(logging);
7805 FROMJSON_IMPL_SIMPLE(internals);
7806 FROMJSON_IMPL_SIMPLE(timelines);
7807 FROMJSON_IMPL_SIMPLE(database);
7808 FROMJSON_IMPL_SIMPLE(featureset);
7809 FROMJSON_IMPL_SIMPLE(namedAudioDevices);
7810 FROMJSON_IMPL_SIMPLE(externalCodecs);
7811 FROMJSON_IMPL_SIMPLE(rtpMap);
7812 FROMJSON_IMPL_SIMPLE(statusReport);
7817 JSON_SERIALIZED_CLASS(TalkgroupAsset)
7829 IMPLEMENT_JSON_SERIALIZATION()
7852 static void to_json(nlohmann::json& j,
const TalkgroupAsset& p)
7855 TOJSON_IMPL(nodeId),
7859 static void from_json(
const nlohmann::json& j, TalkgroupAsset& p)
7862 getOptional<std::string>(
"nodeId", p.nodeId, j);
7863 getOptional<Group>(
"group", p.group, j);
7867 JSON_SERIALIZED_CLASS(EngageDiscoveredGroup)
7877 IMPLEMENT_JSON_SERIALIZATION()
7907 static void to_json(nlohmann::json& j,
const EngageDiscoveredGroup& p)
7916 static void from_json(
const nlohmann::json& j, EngageDiscoveredGroup& p)
7919 getOptional<std::string>(
"id", p.id, j);
7920 getOptional<int>(
"type", p.type, j, 0);
7921 getOptional<NetworkAddress>(
"rx", p.rx, j);
7922 getOptional<NetworkAddress>(
"tx", p.tx, j);
7926 JSON_SERIALIZED_CLASS(RallypointPeer)
7938 IMPLEMENT_JSON_SERIALIZATION()
7945 olpUseRpConfiguration = 0,
7952 } OutboundLeafPolicy_t;
7993 certificate.clear();
7994 connectionTimeoutSecs = 0;
7995 forceIsMeshLeaf =
false;
7996 outboundLeafPolicy = OutboundLeafPolicy_t::olpUseRpConfiguration;
7997 protocol = Rallypoint::RpProtocol_t::rppTlsTcp;
7999 additionalProtocols.clear();
8003 static void to_json(nlohmann::json& j,
const RallypointPeer& p)
8007 TOJSON_IMPL(enabled),
8009 TOJSON_IMPL(certificate),
8010 TOJSON_IMPL(connectionTimeoutSecs),
8011 TOJSON_IMPL(forceIsMeshLeaf),
8012 TOJSON_IMPL(outboundLeafPolicy),
8013 TOJSON_IMPL(protocol),
8015 TOJSON_IMPL(additionalProtocols)
8018 static void from_json(
const nlohmann::json& j, RallypointPeer& p)
8021 j.at(
"id").get_to(p.id);
8022 getOptional<bool>(
"enabled", p.enabled, j,
true);
8023 getOptional<NetworkAddress>(
"host", p.host, j);
8024 getOptional<SecurityCertificate>(
"certificate", p.certificate, j);
8025 getOptional<int>(
"connectionTimeoutSecs", p.connectionTimeoutSecs, j, 0);
8026 getOptional<bool>(
"forceIsMeshLeaf", p.forceIsMeshLeaf, j,
false);
8027 getOptional<RallypointPeer::OutboundLeafPolicy_t>(
"outboundLeafPolicy", p.outboundLeafPolicy, j, RallypointPeer::OutboundLeafPolicy_t::olpUseRpConfiguration);
8028 getOptional<Rallypoint::RpProtocol_t>(
"protocol", p.protocol, j, Rallypoint::RpProtocol_t::rppTlsTcp);
8029 getOptional<std::string>(
"path", p.path, j);
8030 getOptional<std::string>(
"additionalProtocols", p.additionalProtocols, j);
8034 JSON_SERIALIZED_CLASS(RallypointServerLimits)
8046 IMPLEMENT_JSON_SERIALIZATION()
8104 maxMulticastReflectors = 0;
8105 maxRegisteredStreams = 0;
8107 maxRxPacketsPerSec = 0;
8108 maxTxPacketsPerSec = 0;
8109 maxRxBytesPerSec = 0;
8110 maxTxBytesPerSec = 0;
8112 maxInboundBacklog = 64;
8113 lowPriorityQueueThreshold = 64;
8114 normalPriorityQueueThreshold = 256;
8115 denyNewConnectionCpuThreshold = 75;
8116 warnAtCpuThreshold = 65;
8120 static void to_json(nlohmann::json& j,
const RallypointServerLimits& p)
8123 TOJSON_IMPL(maxClients),
8124 TOJSON_IMPL(maxPeers),
8125 TOJSON_IMPL(maxMulticastReflectors),
8126 TOJSON_IMPL(maxRegisteredStreams),
8127 TOJSON_IMPL(maxStreamPaths),
8128 TOJSON_IMPL(maxRxPacketsPerSec),
8129 TOJSON_IMPL(maxTxPacketsPerSec),
8130 TOJSON_IMPL(maxRxBytesPerSec),
8131 TOJSON_IMPL(maxTxBytesPerSec),
8132 TOJSON_IMPL(maxQOpsPerSec),
8133 TOJSON_IMPL(maxInboundBacklog),
8134 TOJSON_IMPL(lowPriorityQueueThreshold),
8135 TOJSON_IMPL(normalPriorityQueueThreshold),
8136 TOJSON_IMPL(denyNewConnectionCpuThreshold),
8137 TOJSON_IMPL(warnAtCpuThreshold)
8140 static void from_json(
const nlohmann::json& j, RallypointServerLimits& p)
8143 getOptional<uint32_t>(
"maxClients", p.maxClients, j, 0);
8144 getOptional<uint32_t>(
"maxPeers", p.maxPeers, j, 0);
8145 getOptional<uint32_t>(
"maxMulticastReflectors", p.maxMulticastReflectors, j, 0);
8146 getOptional<uint32_t>(
"maxRegisteredStreams", p.maxRegisteredStreams, j, 0);
8147 getOptional<uint32_t>(
"maxStreamPaths", p.maxStreamPaths, j, 0);
8148 getOptional<uint32_t>(
"maxRxPacketsPerSec", p.maxRxPacketsPerSec, j, 0);
8149 getOptional<uint32_t>(
"maxTxPacketsPerSec", p.maxTxPacketsPerSec, j, 0);
8150 getOptional<uint32_t>(
"maxRxBytesPerSec", p.maxRxBytesPerSec, j, 0);
8151 getOptional<uint32_t>(
"maxTxBytesPerSec", p.maxTxBytesPerSec, j, 0);
8152 getOptional<uint32_t>(
"maxQOpsPerSec", p.maxQOpsPerSec, j, 0);
8153 getOptional<uint32_t>(
"maxInboundBacklog", p.maxInboundBacklog, j, 64);
8154 getOptional<uint32_t>(
"lowPriorityQueueThreshold", p.lowPriorityQueueThreshold, j, 64);
8155 getOptional<uint32_t>(
"normalPriorityQueueThreshold", p.normalPriorityQueueThreshold, j, 256);
8156 getOptional<uint32_t>(
"denyNewConnectionCpuThreshold", p.denyNewConnectionCpuThreshold, j, 75);
8157 getOptional<uint32_t>(
"warnAtCpuThreshold", p.warnAtCpuThreshold, j, 65);
8161 JSON_SERIALIZED_CLASS(RallypointServerStatusReportConfiguration)
8173 IMPLEMENT_JSON_SERIALIZATION()
8208 includeLinks =
false;
8209 includePeerLinkDetails =
false;
8210 includeClientLinkDetails =
false;
8215 static void to_json(nlohmann::json& j,
const RallypointServerStatusReportConfiguration& p)
8218 TOJSON_IMPL(fileName),
8219 TOJSON_IMPL(intervalSecs),
8220 TOJSON_IMPL(enabled),
8221 TOJSON_IMPL(includeLinks),
8222 TOJSON_IMPL(includePeerLinkDetails),
8223 TOJSON_IMPL(includeClientLinkDetails),
8227 static void from_json(
const nlohmann::json& j, RallypointServerStatusReportConfiguration& p)
8230 getOptional<std::string>(
"fileName", p.fileName, j);
8231 getOptional<int>(
"intervalSecs", p.intervalSecs, j, 60);
8232 getOptional<bool>(
"enabled", p.enabled, j,
false);
8233 getOptional<bool>(
"includeLinks", p.includeLinks, j,
false);
8234 getOptional<bool>(
"includePeerLinkDetails", p.includePeerLinkDetails, j,
false);
8235 getOptional<bool>(
"includeClientLinkDetails", p.includeClientLinkDetails, j,
false);
8236 getOptional<std::string>(
"runCmd", p.runCmd, j);
8240 JSON_SERIALIZED_CLASS(RallypointServerLinkGraph)
8243 IMPLEMENT_JSON_SERIALIZATION()
8286 includeDigraphEnclosure =
true;
8287 includeClients =
false;
8288 coreRpStyling =
"[shape=hexagon color=firebrick style=filled]";
8289 leafRpStyling =
"[shape=box color=gray style=filled]";
8290 clientStyling.clear();
8295 static void to_json(nlohmann::json& j,
const RallypointServerLinkGraph& p)
8298 TOJSON_IMPL(fileName),
8299 TOJSON_IMPL(minRefreshSecs),
8300 TOJSON_IMPL(enabled),
8301 TOJSON_IMPL(includeDigraphEnclosure),
8302 TOJSON_IMPL(includeClients),
8303 TOJSON_IMPL(coreRpStyling),
8304 TOJSON_IMPL(leafRpStyling),
8305 TOJSON_IMPL(clientStyling),
8309 static void from_json(
const nlohmann::json& j, RallypointServerLinkGraph& p)
8312 getOptional<std::string>(
"fileName", p.fileName, j);
8313 getOptional<int>(
"minRefreshSecs", p.minRefreshSecs, j, 5);
8314 getOptional<bool>(
"enabled", p.enabled, j,
false);
8315 getOptional<bool>(
"includeDigraphEnclosure", p.includeDigraphEnclosure, j,
true);
8316 getOptional<bool>(
"includeClients", p.includeClients, j,
false);
8317 getOptional<std::string>(
"coreRpStyling", p.coreRpStyling, j,
"[shape=hexagon color=firebrick style=filled]");
8318 getOptional<std::string>(
"leafRpStyling", p.leafRpStyling, j,
"[shape=box color=gray style=filled]");
8319 getOptional<std::string>(
"clientStyling", p.clientStyling, j);
8320 getOptional<std::string>(
"runCmd", p.runCmd, j);
8325 JSON_SERIALIZED_CLASS(RallypointServerStreamStatsExport)
8335 IMPLEMENT_JSON_SERIALIZATION()
8384 namedPipePath.clear();
8385 resetCountersAfterExport =
false;
8391 static void to_json(nlohmann::json& j,
const RallypointServerStreamStatsExport& p)
8394 TOJSON_IMPL(fileName),
8395 TOJSON_IMPL(intervalSecs),
8396 TOJSON_IMPL(enabled),
8397 TOJSON_IMPL(namedPipePath),
8398 TOJSON_IMPL(resetCountersAfterExport),
8399 TOJSON_IMPL(runCmd),
8403 static void from_json(
const nlohmann::json& j, RallypointServerStreamStatsExport& p)
8406 getOptional<std::string>(
"fileName", p.fileName, j);
8407 getOptional<int>(
"intervalSecs", p.intervalSecs, j, 60);
8408 getOptional<bool>(
"enabled", p.enabled, j,
false);
8409 getOptional<std::string>(
"namedPipePath", p.namedPipePath, j);
8410 getOptional<bool>(
"resetCountersAfterExport", p.resetCountersAfterExport, j,
false);
8411 getOptional<std::string>(
"runCmd", p.runCmd, j);
8412 getOptional<RallypointServerStreamStatsExport::ExportFormat_t>(
"format", p.format, j, RallypointServerStreamStatsExport::ExportFormat_t::fmtJson);
8416 JSON_SERIALIZED_CLASS(RallypointServerRouteMap)
8419 IMPLEMENT_JSON_SERIALIZATION()
8448 static void to_json(nlohmann::json& j,
const RallypointServerRouteMap& p)
8451 TOJSON_IMPL(fileName),
8452 TOJSON_IMPL(minRefreshSecs),
8453 TOJSON_IMPL(enabled),
8457 static void from_json(
const nlohmann::json& j, RallypointServerRouteMap& p)
8460 getOptional<std::string>(
"fileName", p.fileName, j);
8461 getOptional<int>(
"minRefreshSecs", p.minRefreshSecs, j, 5);
8462 getOptional<bool>(
"enabled", p.enabled, j,
false);
8463 getOptional<std::string>(
"runCmd", p.runCmd, j);
8468 JSON_SERIALIZED_CLASS(ExternalHealthCheckResponder)
8480 IMPLEMENT_JSON_SERIALIZATION()
8499 immediateClose =
true;
8503 static void to_json(nlohmann::json& j,
const ExternalHealthCheckResponder& p)
8506 TOJSON_IMPL(listenPort),
8507 TOJSON_IMPL(immediateClose)
8510 static void from_json(
const nlohmann::json& j, ExternalHealthCheckResponder& p)
8513 getOptional<int>(
"listenPort", p.listenPort, j, 0);
8514 getOptional<bool>(
"immediateClose", p.immediateClose, j,
true);
8519 JSON_SERIALIZED_CLASS(PeeringConfiguration)
8529 IMPLEMENT_JSON_SERIALIZATION()
8559 static void to_json(nlohmann::json& j,
const PeeringConfiguration& p)
8563 TOJSON_IMPL(version),
8564 TOJSON_IMPL(comments),
8568 static void from_json(
const nlohmann::json& j, PeeringConfiguration& p)
8571 getOptional<std::string>(
"id", p.id, j);
8572 getOptional<int>(
"version", p.version, j, 0);
8573 getOptional<std::string>(
"comments", p.comments, j);
8574 getOptional<std::vector<RallypointPeer>>(
"peers", p.peers, j);
8578 JSON_SERIALIZED_CLASS(IgmpSnooping)
8588 IMPLEMENT_JSON_SERIALIZATION()
8611 queryIntervalMs = 125000;
8612 subscriptionTimeoutMs = 0;
8616 static void to_json(nlohmann::json& j,
const IgmpSnooping& p)
8619 TOJSON_IMPL(enabled),
8620 TOJSON_IMPL(queryIntervalMs),
8621 TOJSON_IMPL(subscriptionTimeoutMs)
8624 static void from_json(
const nlohmann::json& j, IgmpSnooping& p)
8627 getOptional<bool>(
"enabled", p.enabled, j);
8628 getOptional<int>(
"queryIntervalMs", p.queryIntervalMs, j, 125000);
8629 getOptional<int>(
"subscriptionTimeoutMs", p.subscriptionTimeoutMs, j, 0);
8634 JSON_SERIALIZED_CLASS(RallypointReflector)
8643 IMPLEMENT_JSON_SERIALIZATION()
8658 } DirectionRestriction_t;
8690 multicastInterfaceName.clear();
8691 additionalTx.clear();
8692 directionRestriction = drNone;
8696 static void to_json(nlohmann::json& j,
const RallypointReflector& p)
8702 TOJSON_IMPL(multicastInterfaceName),
8703 TOJSON_IMPL(additionalTx),
8704 TOJSON_IMPL(directionRestriction)
8707 static void from_json(
const nlohmann::json& j, RallypointReflector& p)
8710 j.at(
"id").get_to(p.id);
8711 j.at(
"rx").get_to(p.rx);
8712 j.at(
"tx").get_to(p.tx);
8713 getOptional<std::string>(
"multicastInterfaceName", p.multicastInterfaceName, j);
8714 getOptional<std::vector<NetworkAddress>>(
"additionalTx", p.additionalTx, j);
8715 getOptional<RallypointReflector::DirectionRestriction_t>(
"directionRestriction", p.directionRestriction, j, RallypointReflector::DirectionRestriction_t::drNone);
8720 JSON_SERIALIZED_CLASS(RallypointUdpStreamingIpvX)
8729 IMPLEMENT_JSON_SERIALIZATION()
8751 static void to_json(nlohmann::json& j,
const RallypointUdpStreamingIpvX& p)
8754 TOJSON_IMPL(enabled),
8755 TOJSON_IMPL(external)
8758 static void from_json(
const nlohmann::json& j, RallypointUdpStreamingIpvX& p)
8761 getOptional<bool>(
"enabled", p.enabled, j,
true);
8762 getOptional<NetworkAddress>(
"external", p.external, j);
8766 JSON_SERIALIZED_CLASS(RallypointUdpStreaming)
8775 IMPLEMENT_JSON_SERIALIZATION()
8786 ctSharedKeyAes256FullIv = 1,
8789 ctSharedKeyAes256IdxIv = 2,
8792 ctSharedKeyChaCha20FullIv = 3,
8795 ctSharedKeyChaCha20IdxIv = 4
8831 cryptoType = CryptoType_t::ctSharedKeyAes256FullIv;
8835 keepaliveIntervalSecs = 15;
8836 priority = TxPriority_t::priVoice;
8841 static void to_json(nlohmann::json& j,
const RallypointUdpStreaming& p)
8844 TOJSON_IMPL(enabled),
8845 TOJSON_IMPL(cryptoType),
8846 TOJSON_IMPL(listenPort),
8847 TOJSON_IMPL(keepaliveIntervalSecs),
8850 TOJSON_IMPL(priority),
8854 static void from_json(
const nlohmann::json& j, RallypointUdpStreaming& p)
8857 getOptional<bool>(
"enabled", p.enabled, j,
true);
8858 getOptional<RallypointUdpStreaming::CryptoType_t>(
"cryptoType", p.cryptoType, j, RallypointUdpStreaming::CryptoType_t::ctSharedKeyAes256FullIv);
8859 getOptional<int>(
"listenPort", p.listenPort, j, 7444);
8860 getOptional<int>(
"keepaliveIntervalSecs", p.keepaliveIntervalSecs, j, 15);
8861 getOptional<RallypointUdpStreamingIpvX>(
"ipv4", p.ipv4, j);
8862 getOptional<RallypointUdpStreamingIpvX>(
"ipv6", p.ipv6, j);
8863 getOptional<TxPriority_t>(
"priority", p.priority, j, TxPriority_t::priVoice);
8864 getOptional<int>(
"ttl", p.ttl, j, 64);
8868 JSON_SERIALIZED_CLASS(RallypointRpRtTimingBehavior)
8877 IMPLEMENT_JSON_SERIALIZATION()
8922 static void to_json(nlohmann::json& j,
const RallypointRpRtTimingBehavior& p)
8925 TOJSON_IMPL(behavior),
8926 TOJSON_IMPL(atOrAboveMs),
8930 static void from_json(
const nlohmann::json& j, RallypointRpRtTimingBehavior& p)
8933 getOptional<RallypointRpRtTimingBehavior::BehaviorType_t>(
"behavior", p.behavior, j, RallypointRpRtTimingBehavior::BehaviorType_t::btNone);
8934 getOptional<uint32_t>(
"atOrAboveMs", p.atOrAboveMs, j, 0);
8935 getOptional<std::string>(
"runCmd", p.runCmd, j);
8940 JSON_SERIALIZED_CLASS(RallypointWebsocketSettings)
8949 IMPLEMENT_JSON_SERIALIZATION()
8977 certificate.clear();
8978 requireClientCertificate =
false;
8983 static void to_json(nlohmann::json& j,
const RallypointWebsocketSettings& p)
8986 TOJSON_IMPL(enabled),
8987 TOJSON_IMPL(listenPort),
8988 TOJSON_IMPL(certificate),
8989 TOJSON_IMPL(requireClientCertificate),
8990 TOJSON_IMPL(requireTls)
8993 static void from_json(
const nlohmann::json& j, RallypointWebsocketSettings& p)
8996 getOptional<bool>(
"enabled", p.enabled, j,
false);
8997 getOptional<int>(
"listenPort", p.listenPort, j, 8443);
8998 getOptional<SecurityCertificate>(
"certificate", p.certificate, j);
8999 getOptional<bool>(
"requireClientCertificate", p.requireClientCertificate, j,
false);
9000 getOptional<bool>(
"requireTls", p.requireTls, j,
true);
9006 JSON_SERIALIZED_CLASS(RallypointAdvertisingSettings)
9015 IMPLEMENT_JSON_SERIALIZATION()
9046 serviceName =
"_rallypoint._tcp.local.";
9047 interfaceName.clear();
9053 static void to_json(nlohmann::json& j,
const RallypointAdvertisingSettings& p)
9056 TOJSON_IMPL(enabled),
9057 TOJSON_IMPL(hostName),
9058 TOJSON_IMPL(serviceName),
9059 TOJSON_IMPL(interfaceName),
9064 static void from_json(
const nlohmann::json& j, RallypointAdvertisingSettings& p)
9067 getOptional<bool>(
"enabled", p.enabled, j,
false);
9068 getOptional<std::string>(
"hostName", p.hostName, j);
9069 getOptional<std::string>(
"serviceName", p.serviceName, j,
"_rallypoint._tcp.local.");
9070 getOptional<std::string>(
"interfaceName", p.interfaceName, j);
9072 getOptional<int>(
"port", p.port, j, 0);
9073 getOptional<int>(
"ttl", p.ttl, j, 60);
9080 JSON_SERIALIZED_CLASS(NamedIdentity)
9089 IMPLEMENT_JSON_SERIALIZATION()
9107 certificate.clear();
9111 static void to_json(nlohmann::json& j,
const NamedIdentity& p)
9115 TOJSON_IMPL(certificate)
9118 static void from_json(
const nlohmann::json& j, NamedIdentity& p)
9121 getOptional<std::string>(
"name", p.name, j);
9122 getOptional<SecurityCertificate>(
"certificate", p.certificate, j);
9126 JSON_SERIALIZED_CLASS(RallypointExtendedGroupRestriction)
9135 IMPLEMENT_JSON_SERIALIZATION()
9153 restrictions.clear();
9157 static void to_json(nlohmann::json& j,
const RallypointExtendedGroupRestriction& p)
9161 TOJSON_IMPL(restrictions)
9164 static void from_json(
const nlohmann::json& j, RallypointExtendedGroupRestriction& p)
9167 getOptional<std::string>(
"id", p.id, j);
9168 getOptional<std::vector<StringRestrictionList>>(
"restrictions", p.restrictions, j);
9173 JSON_SERIALIZED_CLASS(RallypointServer)
9184 IMPLEMENT_JSON_SERIALIZATION()
9192 sptCertPublicKey = 2,
9195 sptCertFingerprint = 5,
9209 } StreamIdPrivacyType_t;
9405 interfaceName.clear();
9406 certificate.clear();
9407 allowMulticastForwarding =
false;
9408 peeringConfiguration.clear();
9409 peeringConfigurationFileName.clear();
9410 peeringConfigurationFileCommand.clear();
9411 peeringConfigurationFileCheckSecs = 60;
9413 statusReport.clear();
9416 externalHealthCheckResponder.clear();
9417 allowPeerForwarding =
false;
9418 multicastInterfaceName.clear();
9421 forwardDiscoveredGroups =
false;
9422 forwardMulticastAddressing =
false;
9424 disableMessageSigning =
false;
9425 multicastRestrictions.clear();
9426 igmpSnooping.clear();
9427 staticReflectors.clear();
9428 tcpTxOptions.clear();
9429 multicastTxOptions.clear();
9430 certStoreFileName.clear();
9431 certStorePasswordHex.clear();
9432 groupRestrictions.clear();
9433 configurationCheckSignalName =
"rts.7b392d1.${id}";
9436 udpStreaming.clear();
9438 normalTaskQueueBias = 0;
9439 enableLeafReflectionReverseSubscription =
false;
9440 disableLoopDetection =
false;
9441 maxSecurityLevel = 0;
9443 streamStatsExport.clear();
9444 maxOutboundPeerConnectionIntervalDeltaSecs = 15;
9445 peerRtTestIntervalMs = 60000;
9446 peerRtBehaviors.clear();
9449 advertising.clear();
9450 extendedGroupRestrictions.clear();
9451 groupRestrictionAccessPolicyType = GroupRestrictionAccessPolicyType_t::graptPermissive;
9452 ipFamily = IpFamilyType_t::ifIp4;
9456 allowedDomains.clear();
9457 blockedDomains.clear();
9458 extraDomains.clear();
9460 additionalIdentities.clear();
9461 streamIdPrivacyType = StreamIdPrivacyType_t::sptDefault;
9465 static void to_json(nlohmann::json& j,
const RallypointServer& p)
9468 TOJSON_IMPL(fipsCrypto),
9469 TOJSON_IMPL(watchdog),
9471 TOJSON_IMPL(listenPort),
9472 TOJSON_IMPL(interfaceName),
9473 TOJSON_IMPL(certificate),
9474 TOJSON_IMPL(allowMulticastForwarding),
9476 TOJSON_IMPL(peeringConfigurationFileName),
9477 TOJSON_IMPL(peeringConfigurationFileCommand),
9478 TOJSON_IMPL(peeringConfigurationFileCheckSecs),
9479 TOJSON_IMPL(ioPools),
9480 TOJSON_IMPL(statusReport),
9481 TOJSON_IMPL(limits),
9482 TOJSON_IMPL(linkGraph),
9483 TOJSON_IMPL(externalHealthCheckResponder),
9484 TOJSON_IMPL(allowPeerForwarding),
9485 TOJSON_IMPL(multicastInterfaceName),
9487 TOJSON_IMPL(discovery),
9488 TOJSON_IMPL(forwardDiscoveredGroups),
9489 TOJSON_IMPL(forwardMulticastAddressing),
9490 TOJSON_IMPL(isMeshLeaf),
9491 TOJSON_IMPL(disableMessageSigning),
9492 TOJSON_IMPL(multicastRestrictions),
9493 TOJSON_IMPL(igmpSnooping),
9494 TOJSON_IMPL(staticReflectors),
9495 TOJSON_IMPL(tcpTxOptions),
9496 TOJSON_IMPL(multicastTxOptions),
9497 TOJSON_IMPL(certStoreFileName),
9498 TOJSON_IMPL(certStorePasswordHex),
9499 TOJSON_IMPL(groupRestrictions),
9500 TOJSON_IMPL(configurationCheckSignalName),
9501 TOJSON_IMPL(featureset),
9502 TOJSON_IMPL(licensing),
9503 TOJSON_IMPL(udpStreaming),
9504 TOJSON_IMPL(sysFlags),
9505 TOJSON_IMPL(normalTaskQueueBias),
9506 TOJSON_IMPL(enableLeafReflectionReverseSubscription),
9507 TOJSON_IMPL(disableLoopDetection),
9508 TOJSON_IMPL(maxSecurityLevel),
9509 TOJSON_IMPL(routeMap),
9510 TOJSON_IMPL(streamStatsExport),
9511 TOJSON_IMPL(maxOutboundPeerConnectionIntervalDeltaSecs),
9512 TOJSON_IMPL(peerRtTestIntervalMs),
9513 TOJSON_IMPL(peerRtBehaviors),
9514 TOJSON_IMPL(websocket),
9516 TOJSON_IMPL(advertising),
9517 TOJSON_IMPL(extendedGroupRestrictions),
9518 TOJSON_IMPL(groupRestrictionAccessPolicyType),
9519 TOJSON_IMPL(ipFamily),
9520 TOJSON_IMPL(rxCapture),
9521 TOJSON_IMPL(txCapture),
9522 TOJSON_IMPL(domainName),
9523 TOJSON_IMPL(allowedDomains),
9524 TOJSON_IMPL(blockedDomains),
9525 TOJSON_IMPL(extraDomains),
9526 TOJSON_IMPL(tuning),
9527 TOJSON_IMPL(additionalIdentities),
9528 TOJSON_IMPL(streamIdPrivacyType)
9531 static void from_json(
const nlohmann::json& j, RallypointServer& p)
9534 getOptional<FipsCryptoSettings>(
"fipsCrypto", p.fipsCrypto, j);
9535 getOptional<WatchdogSettings>(
"watchdog", p.watchdog, j);
9536 getOptional<std::string>(
"id", p.id, j);
9537 getOptional<SecurityCertificate>(
"certificate", p.certificate, j);
9538 getOptional<std::string>(
"interfaceName", p.interfaceName, j);
9539 getOptional<int>(
"listenPort", p.listenPort, j, 7443);
9540 getOptional<bool>(
"allowMulticastForwarding", p.allowMulticastForwarding, j,
false);
9542 getOptional<std::string>(
"peeringConfigurationFileName", p.peeringConfigurationFileName, j);
9543 getOptional<std::string>(
"peeringConfigurationFileCommand", p.peeringConfigurationFileCommand, j);
9544 getOptional<int>(
"peeringConfigurationFileCheckSecs", p.peeringConfigurationFileCheckSecs, j, 60);
9545 getOptional<int>(
"ioPools", p.ioPools, j, -1);
9546 getOptional<RallypointServerStatusReportConfiguration>(
"statusReport", p.statusReport, j);
9547 getOptional<RallypointServerLimits>(
"limits", p.limits, j);
9548 getOptional<RallypointServerLinkGraph>(
"linkGraph", p.linkGraph, j);
9549 getOptional<ExternalHealthCheckResponder>(
"externalHealthCheckResponder", p.externalHealthCheckResponder, j);
9550 getOptional<bool>(
"allowPeerForwarding", p.allowPeerForwarding, j,
false);
9551 getOptional<std::string>(
"multicastInterfaceName", p.multicastInterfaceName, j);
9552 getOptional<Tls>(
"tls", p.tls, j);
9553 getOptional<DiscoveryConfiguration>(
"discovery", p.discovery, j);
9554 getOptional<bool>(
"forwardDiscoveredGroups", p.forwardDiscoveredGroups, j,
false);
9555 getOptional<bool>(
"forwardMulticastAddressing", p.forwardMulticastAddressing, j,
false);
9556 getOptional<bool>(
"isMeshLeaf", p.isMeshLeaf, j,
false);
9557 getOptional<bool>(
"disableMessageSigning", p.disableMessageSigning, j,
false);
9558 getOptional<NetworkAddressRestrictionList>(
"multicastRestrictions", p.multicastRestrictions, j);
9559 getOptional<IgmpSnooping>(
"igmpSnooping", p.igmpSnooping, j);
9560 getOptional<std::vector<RallypointReflector>>(
"staticReflectors", p.staticReflectors, j);
9561 getOptional<TcpNetworkTxOptions>(
"tcpTxOptions", p.tcpTxOptions, j);
9562 getOptional<NetworkTxOptions>(
"multicastTxOptions", p.multicastTxOptions, j);
9563 getOptional<std::string>(
"certStoreFileName", p.certStoreFileName, j);
9564 getOptional<std::string>(
"certStorePasswordHex", p.certStorePasswordHex, j);
9565 getOptional<StringRestrictionList>(
"groupRestrictions", p.groupRestrictions, j);
9566 getOptional<std::string>(
"configurationCheckSignalName", p.configurationCheckSignalName, j,
"rts.7b392d1.${id}");
9567 getOptional<Licensing>(
"licensing", p.licensing, j);
9568 getOptional<Featureset>(
"featureset", p.featureset, j);
9569 getOptional<RallypointUdpStreaming>(
"udpStreaming", p.udpStreaming, j);
9570 getOptional<uint32_t>(
"sysFlags", p.sysFlags, j, 0);
9571 getOptional<uint32_t>(
"normalTaskQueueBias", p.normalTaskQueueBias, j, 0);
9572 getOptional<bool>(
"enableLeafReflectionReverseSubscription", p.enableLeafReflectionReverseSubscription, j,
false);
9573 getOptional<bool>(
"disableLoopDetection", p.disableLoopDetection, j,
false);
9574 getOptional<uint32_t>(
"maxSecurityLevel", p.maxSecurityLevel, j, 0);
9575 getOptional<RallypointServerRouteMap>(
"routeMap", p.routeMap, j);
9576 getOptional<RallypointServerStreamStatsExport>(
"streamStatsExport", p.streamStatsExport, j);
9577 getOptional<uint32_t>(
"maxOutboundPeerConnectionIntervalDeltaSecs", p.maxOutboundPeerConnectionIntervalDeltaSecs, j, 15);
9578 getOptional<int>(
"peerRtTestIntervalMs", p.peerRtTestIntervalMs, j, 60000);
9579 getOptional<std::vector<RallypointRpRtTimingBehavior>>(
"peerRtBehaviors", p.peerRtBehaviors, j);
9580 getOptional<RallypointWebsocketSettings>(
"websocket", p.websocket, j);
9581 getOptional<NsmConfiguration>(
"nsm", p.nsm, j);
9582 getOptional<RallypointAdvertisingSettings>(
"advertising", p.advertising, j);
9583 getOptional<std::vector<RallypointExtendedGroupRestriction>>(
"extendedGroupRestrictions", p.extendedGroupRestrictions, j);
9584 getOptional<GroupRestrictionAccessPolicyType_t>(
"groupRestrictionAccessPolicyType", p.groupRestrictionAccessPolicyType, j, GroupRestrictionAccessPolicyType_t::graptPermissive);
9585 getOptional<IpFamilyType_t>(
"ipFamily", p.ipFamily, j, IpFamilyType_t::ifIp4);
9586 getOptional<PacketCapturer>(
"rxCapture", p.rxCapture, j);
9587 getOptional<PacketCapturer>(
"txCapture", p.txCapture, j);
9588 getOptional<std::string>(
"domainName", p.domainName, j);
9589 getOptional<std::vector<std::string>>(
"allowedDomains", p.allowedDomains, j);
9590 getOptional<std::vector<std::string>>(
"blockedDomains", p.blockedDomains, j);
9591 getOptional<std::vector<std::string>>(
"extraDomains", p.extraDomains, j);
9592 getOptional<TuningSettings>(
"tuning", p.tuning, j);
9593 getOptional<std::vector<NamedIdentity>>(
"additionalIdentities", p.additionalIdentities, j);
9594 getOptional<RallypointServer::StreamIdPrivacyType_t>(
"streamIdPrivacyType", p.streamIdPrivacyType, j, RallypointServer::StreamIdPrivacyType_t::sptDefault);
9598 JSON_SERIALIZED_CLASS(PlatformDiscoveredService)
9610 IMPLEMENT_JSON_SERIALIZATION()
9645 configurationVersion = 0;
9649 static void to_json(nlohmann::json& j,
const PlatformDiscoveredService& p)
9655 TOJSON_IMPL(address),
9657 TOJSON_IMPL(configurationVersion)
9660 static void from_json(
const nlohmann::json& j, PlatformDiscoveredService& p)
9663 getOptional<std::string>(
"id", p.id, j);
9664 getOptional<std::string>(
"type", p.type, j);
9665 getOptional<std::string>(
"name", p.name, j);
9666 getOptional<NetworkAddress>(
"address", p.address, j);
9667 getOptional<std::string>(
"uri", p.uri, j);
9668 getOptional<uint32_t>(
"configurationVersion", p.configurationVersion, j, 0);
9708 IMPLEMENT_JSON_SERIALIZATION()
9754 mostRecentFirst =
true;
9755 startedOnOrAfter = 0;
9756 endedOnOrBefore = 0;
9759 onlyCommitted =
true;
9767 static void to_json(nlohmann::json& j,
const TimelineQueryParameters& p)
9770 TOJSON_IMPL(maxCount),
9771 TOJSON_IMPL(mostRecentFirst),
9772 TOJSON_IMPL(startedOnOrAfter),
9773 TOJSON_IMPL(endedOnOrBefore),
9774 TOJSON_IMPL(onlyDirection),
9775 TOJSON_IMPL(onlyType),
9776 TOJSON_IMPL(onlyCommitted),
9777 TOJSON_IMPL(onlyAlias),
9778 TOJSON_IMPL(onlyNodeId),
9779 TOJSON_IMPL(onlyTxId),
9783 static void from_json(
const nlohmann::json& j, TimelineQueryParameters& p)
9786 getOptional<long>(
"maxCount", p.maxCount, j, 50);
9787 getOptional<bool>(
"mostRecentFirst", p.mostRecentFirst, j,
false);
9788 getOptional<uint64_t>(
"startedOnOrAfter", p.startedOnOrAfter, j, 0);
9789 getOptional<uint64_t>(
"endedOnOrBefore", p.endedOnOrBefore, j, 0);
9790 getOptional<int>(
"onlyDirection", p.onlyDirection, j, 0);
9791 getOptional<int>(
"onlyType", p.onlyType, j, 0);
9792 getOptional<bool>(
"onlyCommitted", p.onlyCommitted, j,
true);
9793 getOptional<std::string>(
"onlyAlias", p.onlyAlias, j, EMPTY_STRING);
9794 getOptional<std::string>(
"onlyNodeId", p.onlyNodeId, j, EMPTY_STRING);
9795 getOptional<int>(
"onlyTxId", p.onlyTxId, j, 0);
9796 getOptional<std::string>(
"sql", p.sql, j, EMPTY_STRING);
9800 JSON_SERIALIZED_CLASS(CertStoreCertificate)
9809 IMPLEMENT_JSON_SERIALIZATION()
9836 certificatePem.clear();
9837 privateKeyPem.clear();
9838 internalData =
nullptr;
9843 static void to_json(nlohmann::json& j,
const CertStoreCertificate& p)
9847 TOJSON_IMPL(certificatePem),
9848 TOJSON_IMPL(privateKeyPem),
9852 static void from_json(
const nlohmann::json& j, CertStoreCertificate& p)
9855 j.at(
"id").get_to(p.id);
9856 j.at(
"certificatePem").get_to(p.certificatePem);
9857 getOptional<std::string>(
"privateKeyPem", p.privateKeyPem, j, EMPTY_STRING);
9858 getOptional<std::string>(
"tags", p.tags, j, EMPTY_STRING);
9862 JSON_SERIALIZED_CLASS(CertStore)
9871 IMPLEMENT_JSON_SERIALIZATION()
9892 certificates.clear();
9897 static void to_json(nlohmann::json& j,
const CertStore& p)
9901 TOJSON_IMPL(certificates),
9905 static void from_json(
const nlohmann::json& j, CertStore& p)
9908 getOptional<std::string>(
"id", p.id, j, EMPTY_STRING);
9909 getOptional<std::vector<CertStoreCertificate>>(
"certificates", p.certificates, j);
9910 getOptional<std::vector<KvPair>>(
"kvp", p.kvp, j);
9914 JSON_SERIALIZED_CLASS(CertStoreCertificateElement)
9923 IMPLEMENT_JSON_SERIALIZATION()
9947 hasPrivateKey =
false;
9952 static void to_json(nlohmann::json& j,
const CertStoreCertificateElement& p)
9956 TOJSON_IMPL(hasPrivateKey),
9960 if(!p.certificatePem.empty())
9962 j[
"certificatePem"] = p.certificatePem;
9965 static void from_json(
const nlohmann::json& j, CertStoreCertificateElement& p)
9968 getOptional<std::string>(
"id", p.id, j, EMPTY_STRING);
9969 getOptional<bool>(
"hasPrivateKey", p.hasPrivateKey, j,
false);
9970 getOptional<std::string>(
"certificatePem", p.certificatePem, j, EMPTY_STRING);
9971 getOptional<std::string>(
"tags", p.tags, j, EMPTY_STRING);
9975 JSON_SERIALIZED_CLASS(CertStoreDescriptor)
9984 IMPLEMENT_JSON_SERIALIZATION()
10017 certificates.clear();
10022 static void to_json(nlohmann::json& j,
const CertStoreDescriptor& p)
10024 j = nlohmann::json{
10026 TOJSON_IMPL(fileName),
10027 TOJSON_IMPL(version),
10028 TOJSON_IMPL(flags),
10029 TOJSON_IMPL(certificates),
10033 static void from_json(
const nlohmann::json& j, CertStoreDescriptor& p)
10036 getOptional<std::string>(
"id", p.id, j, EMPTY_STRING);
10037 getOptional<std::string>(
"fileName", p.fileName, j, EMPTY_STRING);
10038 getOptional<int>(
"version", p.version, j, 0);
10039 getOptional<int>(
"flags", p.flags, j, 0);
10040 getOptional<std::vector<CertStoreCertificateElement>>(
"certificates", p.certificates, j);
10041 getOptional<std::vector<KvPair>>(
"kvp", p.kvp, j);
10045 JSON_SERIALIZED_CLASS(CertificateSubjectElement)
10054 IMPLEMENT_JSON_SERIALIZATION()
10076 static void to_json(nlohmann::json& j,
const CertificateSubjectElement& p)
10078 j = nlohmann::json{
10083 static void from_json(
const nlohmann::json& j, CertificateSubjectElement& p)
10086 getOptional<std::string>(
"name", p.name, j, EMPTY_STRING);
10087 getOptional<std::string>(
"value", p.value, j, EMPTY_STRING);
10092 JSON_SERIALIZED_CLASS(CertificateDescriptor)
10101 IMPLEMENT_JSON_SERIALIZATION()
10150 selfSigned =
false;
10155 fingerprint.clear();
10156 subjectElements.clear();
10157 issuerElements.clear();
10158 certificatePem.clear();
10159 publicKeyPem.clear();
10163 static void to_json(nlohmann::json& j,
const CertificateDescriptor& p)
10165 j = nlohmann::json{
10166 TOJSON_IMPL(subject),
10167 TOJSON_IMPL(issuer),
10168 TOJSON_IMPL(selfSigned),
10169 TOJSON_IMPL(version),
10170 TOJSON_IMPL(notBefore),
10171 TOJSON_IMPL(notAfter),
10172 TOJSON_IMPL(serial),
10173 TOJSON_IMPL(fingerprint),
10174 TOJSON_IMPL(subjectElements),
10175 TOJSON_IMPL(issuerElements),
10176 TOJSON_IMPL(certificatePem),
10177 TOJSON_IMPL(publicKeyPem)
10180 static void from_json(
const nlohmann::json& j, CertificateDescriptor& p)
10183 getOptional<std::string>(
"subject", p.subject, j, EMPTY_STRING);
10184 getOptional<std::string>(
"issuer", p.issuer, j, EMPTY_STRING);
10185 getOptional<bool>(
"selfSigned", p.selfSigned, j,
false);
10186 getOptional<int>(
"version", p.version, j, 0);
10187 getOptional<std::string>(
"notBefore", p.notBefore, j, EMPTY_STRING);
10188 getOptional<std::string>(
"notAfter", p.notAfter, j, EMPTY_STRING);
10189 getOptional<std::string>(
"serial", p.serial, j, EMPTY_STRING);
10190 getOptional<std::string>(
"fingerprint", p.fingerprint, j, EMPTY_STRING);
10191 getOptional<std::string>(
"certificatePem", p.certificatePem, j, EMPTY_STRING);
10192 getOptional<std::string>(
"publicKeyPem", p.publicKeyPem, j, EMPTY_STRING);
10193 getOptional<std::vector<CertificateSubjectElement>>(
"subjectElements", p.subjectElements, j);
10194 getOptional<std::vector<CertificateSubjectElement>>(
"issuerElements", p.issuerElements, j);
10199 JSON_SERIALIZED_CLASS(RiffDescriptor)
10211 IMPLEMENT_JSON_SERIALIZATION()
10252 certDescriptor.clear();
10257 static void to_json(nlohmann::json& j,
const RiffDescriptor& p)
10259 j = nlohmann::json{
10261 TOJSON_IMPL(verified),
10262 TOJSON_IMPL(channels),
10263 TOJSON_IMPL(sampleCount),
10265 TOJSON_IMPL(certPem),
10266 TOJSON_IMPL(certDescriptor),
10267 TOJSON_IMPL(signature)
10271 static void from_json(
const nlohmann::json& j, RiffDescriptor& p)
10274 FROMJSON_IMPL(file, std::string, EMPTY_STRING);
10275 FROMJSON_IMPL(verified,
bool,
false);
10276 FROMJSON_IMPL(channels,
int, 0);
10277 FROMJSON_IMPL(sampleCount,
int, 0);
10278 FROMJSON_IMPL(meta, std::string, EMPTY_STRING);
10279 FROMJSON_IMPL(certPem, std::string, EMPTY_STRING);
10280 getOptional<CertificateDescriptor>(
"certDescriptor", p.certDescriptor, j);
10281 FROMJSON_IMPL(signature, std::string, EMPTY_STRING);
10286 JSON_SERIALIZED_CLASS(BridgeCreationDetail)
10295 IMPLEMENT_JSON_SERIALIZATION()
10313 csAlreadyExists = -3,
10316 csInvalidConfiguration = -4,
10319 csInvalidJson = -5,
10322 csInsufficientGroups = -6,
10325 csTooManyGroups = -7,
10328 csDuplicateGroup = -8,
10331 csLocalLoopDetected = -9,
10332 } CreationStatus_t;
10348 status = csUndefined;
10352 static void to_json(nlohmann::json& j,
const BridgeCreationDetail& p)
10354 j = nlohmann::json{
10356 TOJSON_IMPL(status)
10359 static void from_json(
const nlohmann::json& j, BridgeCreationDetail& p)
10362 getOptional<std::string>(
"id", p.id, j, EMPTY_STRING);
10363 getOptional<BridgeCreationDetail::CreationStatus_t>(
"status", p.status, j, BridgeCreationDetail::CreationStatus_t::csUndefined);
10366 JSON_SERIALIZED_CLASS(GroupConnectionDetail)
10375 IMPLEMENT_JSON_SERIALIZATION()
10387 ctDirectDatagram = 1,
10391 } ConnectionType_t;
10416 connectionType = ctUndefined;
10418 asFailover =
false;
10423 static void to_json(nlohmann::json& j,
const GroupConnectionDetail& p)
10425 j = nlohmann::json{
10427 TOJSON_IMPL(connectionType),
10429 TOJSON_IMPL(asFailover),
10430 TOJSON_IMPL(reason)
10435 j[
"asFailover"] = p.asFailover;
10438 static void from_json(
const nlohmann::json& j, GroupConnectionDetail& p)
10441 getOptional<std::string>(
"id", p.id, j, EMPTY_STRING);
10442 getOptional<GroupConnectionDetail::ConnectionType_t>(
"connectionType", p.connectionType, j, GroupConnectionDetail::ConnectionType_t::ctUndefined);
10443 getOptional<std::string>(
"peer", p.peer, j, EMPTY_STRING);
10444 getOptional<bool>(
"asFailover", p.asFailover, j,
false);
10445 getOptional<std::string>(
"reason", p.reason, j, EMPTY_STRING);
10449 JSON_SERIALIZED_CLASS(GroupTxDetail)
10458 IMPLEMENT_JSON_SERIALIZATION()
10476 txsNotAnAudioGroup = -1,
10482 txsNotConnected = -3,
10485 txsAlreadyTransmitting = -4,
10488 txsInvalidParams = -5,
10491 txsPriorityTooLow = -6,
10494 txsRxActiveOnNonFdx = -7,
10497 txsCannotSubscribeToInput = -8,
10503 txsTxEndedWithFailure = -10,
10506 txsBridgedButNotMultistream = -11,
10509 txsAutoEndedDueToNonMultistreamBridge = -12,
10512 txsReBeginWithoutPriorBegin = -13
10541 status = txsUndefined;
10543 remotePriority = 0;
10544 nonFdxMsHangRemaining = 0;
10549 static void to_json(nlohmann::json& j,
const GroupTxDetail& p)
10551 j = nlohmann::json{
10553 TOJSON_IMPL(status),
10554 TOJSON_IMPL(localPriority),
10559 if(p.status == GroupTxDetail::TxStatus_t::txsPriorityTooLow)
10561 j[
"remotePriority"] = p.remotePriority;
10563 else if(p.status == GroupTxDetail::TxStatus_t::txsRxActiveOnNonFdx)
10565 j[
"nonFdxMsHangRemaining"] = p.nonFdxMsHangRemaining;
10568 static void from_json(
const nlohmann::json& j, GroupTxDetail& p)
10571 getOptional<std::string>(
"id", p.id, j, EMPTY_STRING);
10572 getOptional<GroupTxDetail::TxStatus_t>(
"status", p.status, j, GroupTxDetail::TxStatus_t::txsUndefined);
10573 getOptional<int>(
"localPriority", p.localPriority, j, 0);
10574 getOptional<int>(
"remotePriority", p.remotePriority, j, 0);
10575 getOptional<long>(
"nonFdxMsHangRemaining", p.nonFdxMsHangRemaining, j, 0);
10576 getOptional<uint32_t>(
"txId", p.txId, j, 0);
10580 JSON_SERIALIZED_CLASS(GroupCreationDetail)
10589 IMPLEMENT_JSON_SERIALIZATION()
10607 csConflictingRpListAndCluster = -2,
10610 csAlreadyExists = -3,
10613 csInvalidConfiguration = -4,
10616 csInvalidJson = -5,
10619 csCryptoFailure = -6,
10622 csAudioInputFailure = -7,
10625 csAudioOutputFailure = -8,
10628 csUnsupportedAudioEncoder = -9,
10634 csInvalidTransport = -11,
10637 csAudioInputDeviceNotFound = -12,
10640 csAudioOutputDeviceNotFound = -13
10641 } CreationStatus_t;
10657 status = csUndefined;
10661 static void to_json(nlohmann::json& j,
const GroupCreationDetail& p)
10663 j = nlohmann::json{
10665 TOJSON_IMPL(status)
10668 static void from_json(
const nlohmann::json& j, GroupCreationDetail& p)
10671 getOptional<std::string>(
"id", p.id, j, EMPTY_STRING);
10672 getOptional<GroupCreationDetail::CreationStatus_t>(
"status", p.status, j, GroupCreationDetail::CreationStatus_t::csUndefined);
10677 JSON_SERIALIZED_CLASS(GroupReconfigurationDetail)
10686 IMPLEMENT_JSON_SERIALIZATION()
10704 rsInvalidConfiguration = -2,
10707 rsInvalidJson = -3,
10710 rsAudioInputFailure = -4,
10713 rsAudioOutputFailure = -5,
10716 rsDoesNotExist = -6,
10719 rsAudioInputInUse = -7,
10722 rsAudioDisabledForGroup = -8,
10725 rsGroupIsNotAudio = -9
10726 } ReconfigurationStatus_t;
10742 status = rsUndefined;
10746 static void to_json(nlohmann::json& j,
const GroupReconfigurationDetail& p)
10748 j = nlohmann::json{
10750 TOJSON_IMPL(status)
10753 static void from_json(
const nlohmann::json& j, GroupReconfigurationDetail& p)
10756 getOptional<std::string>(
"id", p.id, j, EMPTY_STRING);
10757 getOptional<GroupReconfigurationDetail::ReconfigurationStatus_t>(
"status", p.status, j, GroupReconfigurationDetail::ReconfigurationStatus_t::rsUndefined);
10762 JSON_SERIALIZED_CLASS(GroupHealthReport)
10771 IMPLEMENT_JSON_SERIALIZATION()
10777 uint64_t lastErrorTs;
10778 uint64_t decryptionErrors;
10779 uint64_t encryptionErrors;
10780 uint64_t unsupportDecoderErrors;
10781 uint64_t decoderFailures;
10782 uint64_t decoderStartFailures;
10783 uint64_t inboundRtpPacketAllocationFailures;
10784 uint64_t inboundRtpPacketLoadFailures;
10785 uint64_t latePacketsDiscarded;
10786 uint64_t jitterBufferInsertionFailures;
10787 uint64_t presenceDeserializationFailures;
10788 uint64_t notRtpErrors;
10789 uint64_t generalErrors;
10790 uint64_t inboundRtpProcessorAllocationFailures;
10801 decryptionErrors = 0;
10802 encryptionErrors = 0;
10803 unsupportDecoderErrors = 0;
10804 decoderFailures = 0;
10805 decoderStartFailures = 0;
10806 inboundRtpPacketAllocationFailures = 0;
10807 inboundRtpPacketLoadFailures = 0;
10808 latePacketsDiscarded = 0;
10809 jitterBufferInsertionFailures = 0;
10810 presenceDeserializationFailures = 0;
10813 inboundRtpProcessorAllocationFailures = 0;
10819 j = nlohmann::json{
10821 TOJSON_IMPL(lastErrorTs),
10822 TOJSON_IMPL(decryptionErrors),
10823 TOJSON_IMPL(encryptionErrors),
10824 TOJSON_IMPL(unsupportDecoderErrors),
10825 TOJSON_IMPL(decoderFailures),
10826 TOJSON_IMPL(decoderStartFailures),
10827 TOJSON_IMPL(inboundRtpPacketAllocationFailures),
10828 TOJSON_IMPL(inboundRtpPacketLoadFailures),
10829 TOJSON_IMPL(latePacketsDiscarded),
10830 TOJSON_IMPL(jitterBufferInsertionFailures),
10831 TOJSON_IMPL(presenceDeserializationFailures),
10832 TOJSON_IMPL(notRtpErrors),
10833 TOJSON_IMPL(generalErrors),
10834 TOJSON_IMPL(inboundRtpProcessorAllocationFailures)
10837 static void from_json(
const nlohmann::json& j, GroupHealthReport& p)
10840 getOptional<std::string>(
"id", p.id, j, EMPTY_STRING);
10841 getOptional<uint64_t>(
"lastErrorTs", p.lastErrorTs, j, 0);
10842 getOptional<uint64_t>(
"decryptionErrors", p.decryptionErrors, j, 0);
10843 getOptional<uint64_t>(
"encryptionErrors", p.encryptionErrors, j, 0);
10844 getOptional<uint64_t>(
"unsupportDecoderErrors", p.unsupportDecoderErrors, j, 0);
10845 getOptional<uint64_t>(
"decoderFailures", p.decoderFailures, j, 0);
10846 getOptional<uint64_t>(
"decoderStartFailures", p.decoderStartFailures, j, 0);
10847 getOptional<uint64_t>(
"inboundRtpPacketAllocationFailures", p.inboundRtpPacketAllocationFailures, j, 0);
10848 getOptional<uint64_t>(
"inboundRtpPacketLoadFailures", p.inboundRtpPacketLoadFailures, j, 0);
10849 getOptional<uint64_t>(
"latePacketsDiscarded", p.latePacketsDiscarded, j, 0);
10850 getOptional<uint64_t>(
"jitterBufferInsertionFailures", p.jitterBufferInsertionFailures, j, 0);
10851 getOptional<uint64_t>(
"presenceDeserializationFailures", p.presenceDeserializationFailures, j, 0);
10852 getOptional<uint64_t>(
"notRtpErrors", p.notRtpErrors, j, 0);
10853 getOptional<uint64_t>(
"generalErrors", p.generalErrors, j, 0);
10854 getOptional<uint64_t>(
"inboundRtpProcessorAllocationFailures", p.inboundRtpProcessorAllocationFailures, j, 0);
10858 JSON_SERIALIZED_CLASS(InboundProcessorStats)
10867 IMPLEMENT_JSON_SERIALIZATION()
10874 uint64_t minRtpSamplesInQueue;
10875 uint64_t maxRtpSamplesInQueue;
10876 uint64_t totalSamplesTrimmed;
10877 uint64_t underruns;
10879 uint64_t samplesInQueue;
10880 uint64_t totalPacketsReceived;
10881 uint64_t totalPacketsLost;
10882 uint64_t totalPacketsDiscarded;
10893 minRtpSamplesInQueue = 0;
10894 maxRtpSamplesInQueue = 0;
10895 totalSamplesTrimmed = 0;
10898 samplesInQueue = 0;
10899 totalPacketsReceived = 0;
10900 totalPacketsLost = 0;
10901 totalPacketsDiscarded = 0;
10907 j = nlohmann::json{
10909 TOJSON_IMPL(jitter),
10910 TOJSON_IMPL(minRtpSamplesInQueue),
10911 TOJSON_IMPL(maxRtpSamplesInQueue),
10912 TOJSON_IMPL(totalSamplesTrimmed),
10913 TOJSON_IMPL(underruns),
10914 TOJSON_IMPL(overruns),
10915 TOJSON_IMPL(samplesInQueue),
10916 TOJSON_IMPL(totalPacketsReceived),
10917 TOJSON_IMPL(totalPacketsLost),
10918 TOJSON_IMPL(totalPacketsDiscarded)
10921 static void from_json(
const nlohmann::json& j, InboundProcessorStats& p)
10924 getOptional<uint32_t>(
"ssrc", p.ssrc, j, 0);
10925 getOptional<double>(
"jitter", p.jitter, j, 0.0);
10926 getOptional<uint64_t>(
"minRtpSamplesInQueue", p.minRtpSamplesInQueue, j, 0);
10927 getOptional<uint64_t>(
"maxRtpSamplesInQueue", p.maxRtpSamplesInQueue, j, 0);
10928 getOptional<uint64_t>(
"totalSamplesTrimmed", p.totalSamplesTrimmed, j, 0);
10929 getOptional<uint64_t>(
"underruns", p.underruns, j, 0);
10930 getOptional<uint64_t>(
"overruns", p.overruns, j, 0);
10931 getOptional<uint64_t>(
"samplesInQueue", p.samplesInQueue, j, 0);
10932 getOptional<uint64_t>(
"totalPacketsReceived", p.totalPacketsReceived, j, 0);
10933 getOptional<uint64_t>(
"totalPacketsLost", p.totalPacketsLost, j, 0);
10934 getOptional<uint64_t>(
"totalPacketsDiscarded", p.totalPacketsDiscarded, j, 0);
10938 JSON_SERIALIZED_CLASS(TrafficCounter)
10947 IMPLEMENT_JSON_SERIALIZATION()
10971 j = nlohmann::json{
10972 TOJSON_IMPL(packets),
10973 TOJSON_IMPL(bytes),
10974 TOJSON_IMPL(errors)
10977 static void from_json(
const nlohmann::json& j, TrafficCounter& p)
10980 getOptional<uint64_t>(
"packets", p.packets, j, 0);
10981 getOptional<uint64_t>(
"bytes", p.bytes, j, 0);
10982 getOptional<uint64_t>(
"errors", p.errors, j, 0);
10986 JSON_SERIALIZED_CLASS(GroupStats)
10995 IMPLEMENT_JSON_SERIALIZATION()
10996 IMPLEMENT_WRAPPED_JSON_SERIALIZATION(
GroupStats)
11019 static void to_json(nlohmann::json& j,
const GroupStats& p)
11021 j = nlohmann::json{
11024 TOJSON_IMPL(rxTraffic),
11025 TOJSON_IMPL(txTraffic)
11028 static void from_json(
const nlohmann::json& j, GroupStats& p)
11031 getOptional<std::string>(
"id", p.id, j, EMPTY_STRING);
11033 getOptional<TrafficCounter>(
"rxTraffic", p.rxTraffic, j);
11034 getOptional<TrafficCounter>(
"txTraffic", p.txTraffic, j);
11038 JSON_SERIALIZED_CLASS(RallypointConnectionDetail)
11047 IMPLEMENT_JSON_SERIALIZATION()
11074 internalId.clear();
11077 msToNextConnectionAttempt = 0;
11078 serverProcessingMs = -1.0f;
11082 static void to_json(nlohmann::json& j,
const RallypointConnectionDetail& p)
11084 j = nlohmann::json{
11085 TOJSON_IMPL(internalId),
11090 if(p.msToNextConnectionAttempt > 0)
11092 j[
"msToNextConnectionAttempt"] = p.msToNextConnectionAttempt;
11095 if(p.serverProcessingMs >= 0.0)
11097 j[
"serverProcessingMs"] = p.serverProcessingMs;
11100 static void from_json(
const nlohmann::json& j, RallypointConnectionDetail& p)
11103 getOptional<std::string>(
"internalId", p.internalId, j, EMPTY_STRING);
11104 getOptional<std::string>(
"host", p.host, j, EMPTY_STRING);
11105 getOptional<int>(
"port", p.port, j, 0);
11106 getOptional<uint64_t>(
"msToNextConnectionAttempt", p.msToNextConnectionAttempt, j, 0);
11107 getOptional<float>(
"serverProcessingMs", p.serverProcessingMs, j, -1.0);
11111 JSON_SERIALIZED_CLASS(TranslationSession)
11123 IMPLEMENT_JSON_SERIALIZATION()
11153 static void to_json(nlohmann::json& j,
const TranslationSession& p)
11155 j = nlohmann::json{
11158 TOJSON_IMPL(groups),
11159 TOJSON_IMPL(enabled)
11162 static void from_json(
const nlohmann::json& j, TranslationSession& p)
11165 FROMJSON_IMPL(
id, std::string, EMPTY_STRING);
11166 FROMJSON_IMPL(name, std::string, EMPTY_STRING);
11167 getOptional<std::vector<std::string>>(
"groups", p.groups, j);
11168 FROMJSON_IMPL(enabled,
bool,
true);
11172 JSON_SERIALIZED_CLASS(TranslationConfiguration)
11184 IMPLEMENT_JSON_SERIALIZATION()
11206 static void to_json(nlohmann::json& j,
const TranslationConfiguration& p)
11208 j = nlohmann::json{
11209 TOJSON_IMPL(sessions),
11210 TOJSON_IMPL(groups)
11213 static void from_json(
const nlohmann::json& j, TranslationConfiguration& p)
11216 getOptional<std::vector<TranslationSession>>(
"sessions", p.sessions, j);
11217 getOptional<std::vector<Group>>(
"groups", p.groups, j);
11221 JSON_SERIALIZED_CLASS(LingoServerStatusReportConfiguration)
11233 IMPLEMENT_JSON_SERIALIZATION()
11268 includeGroupDetail =
false;
11269 includeSessionDetail =
false;
11270 includeSessionGroupDetail =
false;
11275 static void to_json(nlohmann::json& j,
const LingoServerStatusReportConfiguration& p)
11277 j = nlohmann::json{
11278 TOJSON_IMPL(fileName),
11279 TOJSON_IMPL(intervalSecs),
11280 TOJSON_IMPL(enabled),
11281 TOJSON_IMPL(includeGroupDetail),
11282 TOJSON_IMPL(includeSessionDetail),
11283 TOJSON_IMPL(includeSessionGroupDetail),
11284 TOJSON_IMPL(runCmd)
11287 static void from_json(
const nlohmann::json& j, LingoServerStatusReportConfiguration& p)
11290 getOptional<std::string>(
"fileName", p.fileName, j);
11291 getOptional<int>(
"intervalSecs", p.intervalSecs, j, 60);
11292 getOptional<bool>(
"enabled", p.enabled, j,
false);
11293 getOptional<std::string>(
"runCmd", p.runCmd, j);
11294 getOptional<bool>(
"includeGroupDetail", p.includeGroupDetail, j,
false);
11295 getOptional<bool>(
"includeSessionDetail", p.includeSessionDetail, j,
false);
11296 getOptional<bool>(
"includeSessionGroupDetail", p.includeSessionGroupDetail, j,
false);
11300 JSON_SERIALIZED_CLASS(LingoServerInternals)
11314 IMPLEMENT_JSON_SERIALIZATION()
11336 housekeeperIntervalMs = 1000;
11340 static void to_json(nlohmann::json& j,
const LingoServerInternals& p)
11342 j = nlohmann::json{
11343 TOJSON_IMPL(watchdog),
11344 TOJSON_IMPL(housekeeperIntervalMs),
11345 TOJSON_IMPL(tuning)
11348 static void from_json(
const nlohmann::json& j, LingoServerInternals& p)
11351 getOptional<WatchdogSettings>(
"watchdog", p.watchdog, j);
11352 getOptional<int>(
"housekeeperIntervalMs", p.housekeeperIntervalMs, j, 1000);
11353 getOptional<TuningSettings>(
"tuning", p.tuning, j);
11357 JSON_SERIALIZED_CLASS(LingoServerConfiguration)
11368 IMPLEMENT_JSON_SERIALIZATION()
11425 serviceConfigurationFileCheckSecs = 60;
11426 lingoConfigurationFileName.clear();
11427 lingoConfigurationFileCommand.clear();
11428 lingoConfigurationFileCheckSecs = 60;
11429 statusReport.clear();
11430 externalHealthCheckResponder.clear();
11432 certStoreFileName.clear();
11433 certStorePasswordHex.clear();
11434 enginePolicy.clear();
11435 configurationCheckSignalName =
"rts.22f4ec3.${id}";
11436 fipsCrypto.clear();
11442 static void to_json(nlohmann::json& j,
const LingoServerConfiguration& p)
11444 j = nlohmann::json{
11446 TOJSON_IMPL(serviceConfigurationFileCheckSecs),
11447 TOJSON_IMPL(lingoConfigurationFileName),
11448 TOJSON_IMPL(lingoConfigurationFileCommand),
11449 TOJSON_IMPL(lingoConfigurationFileCheckSecs),
11450 TOJSON_IMPL(statusReport),
11451 TOJSON_IMPL(externalHealthCheckResponder),
11452 TOJSON_IMPL(internals),
11453 TOJSON_IMPL(certStoreFileName),
11454 TOJSON_IMPL(certStorePasswordHex),
11455 TOJSON_IMPL(enginePolicy),
11456 TOJSON_IMPL(configurationCheckSignalName),
11457 TOJSON_IMPL(fipsCrypto),
11458 TOJSON_IMPL(proxy),
11462 static void from_json(
const nlohmann::json& j, LingoServerConfiguration& p)
11465 getOptional<std::string>(
"id", p.id, j);
11466 getOptional<int>(
"serviceConfigurationFileCheckSecs", p.serviceConfigurationFileCheckSecs, j, 60);
11467 getOptional<std::string>(
"lingoConfigurationFileName", p.lingoConfigurationFileName, j);
11468 getOptional<std::string>(
"lingoConfigurationFileCommand", p.lingoConfigurationFileCommand, j);
11469 getOptional<int>(
"lingoConfigurationFileCheckSecs", p.lingoConfigurationFileCheckSecs, j, 60);
11470 getOptional<LingoServerStatusReportConfiguration>(
"statusReport", p.statusReport, j);
11471 getOptional<ExternalHealthCheckResponder>(
"externalHealthCheckResponder", p.externalHealthCheckResponder, j);
11472 getOptional<LingoServerInternals>(
"internals", p.internals, j);
11473 getOptional<std::string>(
"certStoreFileName", p.certStoreFileName, j);
11474 getOptional<std::string>(
"certStorePasswordHex", p.certStorePasswordHex, j);
11475 j.at(
"enginePolicy").get_to(p.enginePolicy);
11476 getOptional<std::string>(
"configurationCheckSignalName", p.configurationCheckSignalName, j,
"rts.22f4ec3.${id}");
11477 getOptional<FipsCryptoSettings>(
"fipsCrypo", p.fipsCrypto, j);
11478 getOptional<NetworkAddress>(
"proxy", p.proxy, j);
11479 getOptional<NsmConfiguration>(
"nsm", p.nsm, j);
11484 JSON_SERIALIZED_CLASS(VoiceToVoiceSession)
11496 IMPLEMENT_JSON_SERIALIZATION()
11526 static void to_json(nlohmann::json& j,
const VoiceToVoiceSession& p)
11528 j = nlohmann::json{
11531 TOJSON_IMPL(groups),
11532 TOJSON_IMPL(enabled)
11535 static void from_json(
const nlohmann::json& j, VoiceToVoiceSession& p)
11538 FROMJSON_IMPL(
id, std::string, EMPTY_STRING);
11539 FROMJSON_IMPL(name, std::string, EMPTY_STRING);
11540 getOptional<std::vector<std::string>>(
"groups", p.groups, j);
11541 FROMJSON_IMPL(enabled,
bool,
true);
11545 JSON_SERIALIZED_CLASS(LingoConfiguration)
11557 IMPLEMENT_JSON_SERIALIZATION()
11574 voiceToVoiceSessions.clear();
11579 static void to_json(nlohmann::json& j,
const LingoConfiguration& p)
11581 j = nlohmann::json{
11582 TOJSON_IMPL(voiceToVoiceSessions),
11583 TOJSON_IMPL(groups)
11586 static void from_json(
const nlohmann::json& j, LingoConfiguration& p)
11589 getOptional<std::vector<VoiceToVoiceSession>>(
"voiceToVoiceSessions", p.voiceToVoiceSessions, j);
11590 getOptional<std::vector<Group>>(
"groups", p.groups, j);
11594 JSON_SERIALIZED_CLASS(BridgingConfiguration)
11606 IMPLEMENT_JSON_SERIALIZATION()
11628 static void to_json(nlohmann::json& j,
const BridgingConfiguration& p)
11630 j = nlohmann::json{
11631 TOJSON_IMPL(bridges),
11632 TOJSON_IMPL(groups)
11635 static void from_json(
const nlohmann::json& j, BridgingConfiguration& p)
11638 getOptional<std::vector<Bridge>>(
"bridges", p.bridges, j);
11639 getOptional<std::vector<Group>>(
"groups", p.groups, j);
11643 JSON_SERIALIZED_CLASS(BridgingServerStatusReportConfiguration)
11655 IMPLEMENT_JSON_SERIALIZATION()
11690 includeGroupDetail =
false;
11691 includeBridgeDetail =
false;
11692 includeBridgeGroupDetail =
false;
11697 static void to_json(nlohmann::json& j,
const BridgingServerStatusReportConfiguration& p)
11699 j = nlohmann::json{
11700 TOJSON_IMPL(fileName),
11701 TOJSON_IMPL(intervalSecs),
11702 TOJSON_IMPL(enabled),
11703 TOJSON_IMPL(includeGroupDetail),
11704 TOJSON_IMPL(includeBridgeDetail),
11705 TOJSON_IMPL(includeBridgeGroupDetail),
11706 TOJSON_IMPL(runCmd)
11709 static void from_json(
const nlohmann::json& j, BridgingServerStatusReportConfiguration& p)
11712 getOptional<std::string>(
"fileName", p.fileName, j);
11713 getOptional<int>(
"intervalSecs", p.intervalSecs, j, 60);
11714 getOptional<bool>(
"enabled", p.enabled, j,
false);
11715 getOptional<std::string>(
"runCmd", p.runCmd, j);
11716 getOptional<bool>(
"includeGroupDetail", p.includeGroupDetail, j,
false);
11717 getOptional<bool>(
"includeBridgeDetail", p.includeBridgeDetail, j,
false);
11718 getOptional<bool>(
"includeBridgeGroupDetail", p.includeBridgeGroupDetail, j,
false);
11722 JSON_SERIALIZED_CLASS(BridgingServerInternals)
11736 IMPLEMENT_JSON_SERIALIZATION()
11758 housekeeperIntervalMs = 1000;
11762 static void to_json(nlohmann::json& j,
const BridgingServerInternals& p)
11764 j = nlohmann::json{
11765 TOJSON_IMPL(watchdog),
11766 TOJSON_IMPL(housekeeperIntervalMs),
11767 TOJSON_IMPL(tuning)
11770 static void from_json(
const nlohmann::json& j, BridgingServerInternals& p)
11773 getOptional<WatchdogSettings>(
"watchdog", p.watchdog, j);
11774 getOptional<int>(
"housekeeperIntervalMs", p.housekeeperIntervalMs, j, 1000);
11775 getOptional<TuningSettings>(
"tuning", p.tuning, j);
11779 JSON_SERIALIZED_CLASS(BridgingServerConfiguration)
11790 IMPLEMENT_JSON_SERIALIZATION()
11814 omADictatedByGroup = 3,
11871 serviceConfigurationFileCheckSecs = 60;
11872 bridgingConfigurationFileName.clear();
11873 bridgingConfigurationFileCommand.clear();
11874 bridgingConfigurationFileCheckSecs = 60;
11875 statusReport.clear();
11876 externalHealthCheckResponder.clear();
11878 certStoreFileName.clear();
11879 certStorePasswordHex.clear();
11880 enginePolicy.clear();
11881 configurationCheckSignalName =
"rts.6cc0651.${id}";
11882 fipsCrypto.clear();
11887 static void to_json(nlohmann::json& j,
const BridgingServerConfiguration& p)
11889 j = nlohmann::json{
11892 TOJSON_IMPL(serviceConfigurationFileCheckSecs),
11893 TOJSON_IMPL(bridgingConfigurationFileName),
11894 TOJSON_IMPL(bridgingConfigurationFileCommand),
11895 TOJSON_IMPL(bridgingConfigurationFileCheckSecs),
11896 TOJSON_IMPL(statusReport),
11897 TOJSON_IMPL(externalHealthCheckResponder),
11898 TOJSON_IMPL(internals),
11899 TOJSON_IMPL(certStoreFileName),
11900 TOJSON_IMPL(certStorePasswordHex),
11901 TOJSON_IMPL(enginePolicy),
11902 TOJSON_IMPL(configurationCheckSignalName),
11903 TOJSON_IMPL(fipsCrypto),
11907 static void from_json(
const nlohmann::json& j, BridgingServerConfiguration& p)
11910 getOptional<std::string>(
"id", p.id, j);
11911 getOptional<BridgingServerConfiguration::OpMode_t>(
"mode", p.mode, j, BridgingServerConfiguration::OpMode_t::omRaw);
11912 getOptional<int>(
"serviceConfigurationFileCheckSecs", p.serviceConfigurationFileCheckSecs, j, 60);
11913 getOptional<std::string>(
"bridgingConfigurationFileName", p.bridgingConfigurationFileName, j);
11914 getOptional<std::string>(
"bridgingConfigurationFileCommand", p.bridgingConfigurationFileCommand, j);
11915 getOptional<int>(
"bridgingConfigurationFileCheckSecs", p.bridgingConfigurationFileCheckSecs, j, 60);
11916 getOptional<BridgingServerStatusReportConfiguration>(
"statusReport", p.statusReport, j);
11917 getOptional<ExternalHealthCheckResponder>(
"externalHealthCheckResponder", p.externalHealthCheckResponder, j);
11918 getOptional<BridgingServerInternals>(
"internals", p.internals, j);
11919 getOptional<std::string>(
"certStoreFileName", p.certStoreFileName, j);
11920 getOptional<std::string>(
"certStorePasswordHex", p.certStorePasswordHex, j);
11921 j.at(
"enginePolicy").get_to(p.enginePolicy);
11922 getOptional<std::string>(
"configurationCheckSignalName", p.configurationCheckSignalName, j,
"rts.6cc0651.${id}");
11923 getOptional<FipsCryptoSettings>(
"fipsCrypto", p.fipsCrypto, j);
11924 getOptional<NsmConfiguration>(
"nsm", p.nsm, j);
11929 JSON_SERIALIZED_CLASS(EarGroupsConfiguration)
11941 IMPLEMENT_JSON_SERIALIZATION()
11959 static void to_json(nlohmann::json& j,
const EarGroupsConfiguration& p)
11961 j = nlohmann::json{
11962 TOJSON_IMPL(groups)
11965 static void from_json(
const nlohmann::json& j, EarGroupsConfiguration& p)
11968 getOptional<std::vector<Group>>(
"groups", p.groups, j);
11972 JSON_SERIALIZED_CLASS(EarServerStatusReportConfiguration)
11984 IMPLEMENT_JSON_SERIALIZATION()
12013 includeGroupDetail =
false;
12018 static void to_json(nlohmann::json& j,
const EarServerStatusReportConfiguration& p)
12020 j = nlohmann::json{
12021 TOJSON_IMPL(fileName),
12022 TOJSON_IMPL(intervalSecs),
12023 TOJSON_IMPL(enabled),
12024 TOJSON_IMPL(includeGroupDetail),
12025 TOJSON_IMPL(runCmd)
12028 static void from_json(
const nlohmann::json& j, EarServerStatusReportConfiguration& p)
12031 getOptional<std::string>(
"fileName", p.fileName, j);
12032 getOptional<int>(
"intervalSecs", p.intervalSecs, j, 60);
12033 getOptional<bool>(
"enabled", p.enabled, j,
false);
12034 getOptional<std::string>(
"runCmd", p.runCmd, j);
12035 getOptional<bool>(
"includeGroupDetail", p.includeGroupDetail, j,
false);
12039 JSON_SERIALIZED_CLASS(EarServerInternals)
12053 IMPLEMENT_JSON_SERIALIZATION()
12075 housekeeperIntervalMs = 1000;
12079 static void to_json(nlohmann::json& j,
const EarServerInternals& p)
12081 j = nlohmann::json{
12082 TOJSON_IMPL(watchdog),
12083 TOJSON_IMPL(housekeeperIntervalMs),
12084 TOJSON_IMPL(tuning)
12087 static void from_json(
const nlohmann::json& j, EarServerInternals& p)
12090 getOptional<WatchdogSettings>(
"watchdog", p.watchdog, j);
12091 getOptional<int>(
"housekeeperIntervalMs", p.housekeeperIntervalMs, j, 1000);
12092 getOptional<TuningSettings>(
"tuning", p.tuning, j);
12096 JSON_SERIALIZED_CLASS(EarServerConfiguration)
12107 IMPLEMENT_JSON_SERIALIZATION()
12162 serviceConfigurationFileCheckSecs = 60;
12163 groupsConfigurationFileName.clear();
12164 groupsConfigurationFileCommand.clear();
12165 groupsConfigurationFileCheckSecs = 60;
12166 statusReport.clear();
12167 externalHealthCheckResponder.clear();
12169 certStoreFileName.clear();
12170 certStorePasswordHex.clear();
12171 enginePolicy.clear();
12172 configurationCheckSignalName =
"rts.9a164fa.${id}";
12173 fipsCrypto.clear();
12178 static void to_json(nlohmann::json& j,
const EarServerConfiguration& p)
12180 j = nlohmann::json{
12182 TOJSON_IMPL(serviceConfigurationFileCheckSecs),
12183 TOJSON_IMPL(groupsConfigurationFileName),
12184 TOJSON_IMPL(groupsConfigurationFileCommand),
12185 TOJSON_IMPL(groupsConfigurationFileCheckSecs),
12186 TOJSON_IMPL(statusReport),
12187 TOJSON_IMPL(externalHealthCheckResponder),
12188 TOJSON_IMPL(internals),
12189 TOJSON_IMPL(certStoreFileName),
12190 TOJSON_IMPL(certStorePasswordHex),
12191 TOJSON_IMPL(enginePolicy),
12192 TOJSON_IMPL(configurationCheckSignalName),
12193 TOJSON_IMPL(fipsCrypto),
12197 static void from_json(
const nlohmann::json& j, EarServerConfiguration& p)
12200 getOptional<std::string>(
"id", p.id, j);
12201 getOptional<int>(
"serviceConfigurationFileCheckSecs", p.serviceConfigurationFileCheckSecs, j, 60);
12202 getOptional<std::string>(
"groupsConfigurationFileName", p.groupsConfigurationFileName, j);
12203 getOptional<std::string>(
"groupsConfigurationFileCommand", p.groupsConfigurationFileCommand, j);
12204 getOptional<int>(
"groupsConfigurationFileCheckSecs", p.groupsConfigurationFileCheckSecs, j, 60);
12205 getOptional<EarServerStatusReportConfiguration>(
"statusReport", p.statusReport, j);
12206 getOptional<ExternalHealthCheckResponder>(
"externalHealthCheckResponder", p.externalHealthCheckResponder, j);
12207 getOptional<EarServerInternals>(
"internals", p.internals, j);
12208 getOptional<std::string>(
"certStoreFileName", p.certStoreFileName, j);
12209 getOptional<std::string>(
"certStorePasswordHex", p.certStorePasswordHex, j);
12210 j.at(
"enginePolicy").get_to(p.enginePolicy);
12211 getOptional<std::string>(
"configurationCheckSignalName", p.configurationCheckSignalName, j,
"rts.9a164fa.${id}");
12212 getOptional<FipsCryptoSettings>(
"fipsCrypto", p.fipsCrypto, j);
12213 getOptional<NsmConfiguration>(
"nsm", p.nsm, j);
12217 JSON_SERIALIZED_CLASS(EngageSemGroupsConfiguration)
12229 IMPLEMENT_JSON_SERIALIZATION()
12247 static void to_json(nlohmann::json& j,
const EngageSemGroupsConfiguration& p)
12249 j = nlohmann::json{
12250 TOJSON_IMPL(groups)
12253 static void from_json(
const nlohmann::json& j, EngageSemGroupsConfiguration& p)
12256 getOptional<std::vector<Group>>(
"groups", p.groups, j);
12260 JSON_SERIALIZED_CLASS(EngageSemServerStatusReportConfiguration)
12272 IMPLEMENT_JSON_SERIALIZATION()
12301 includeGroupDetail =
false;
12306 static void to_json(nlohmann::json& j,
const EngageSemServerStatusReportConfiguration& p)
12308 j = nlohmann::json{
12309 TOJSON_IMPL(fileName),
12310 TOJSON_IMPL(intervalSecs),
12311 TOJSON_IMPL(enabled),
12312 TOJSON_IMPL(includeGroupDetail),
12313 TOJSON_IMPL(runCmd)
12316 static void from_json(
const nlohmann::json& j, EngageSemServerStatusReportConfiguration& p)
12319 getOptional<std::string>(
"fileName", p.fileName, j);
12320 getOptional<int>(
"intervalSecs", p.intervalSecs, j, 60);
12321 getOptional<bool>(
"enabled", p.enabled, j,
false);
12322 getOptional<std::string>(
"runCmd", p.runCmd, j);
12323 getOptional<bool>(
"includeGroupDetail", p.includeGroupDetail, j,
false);
12327 JSON_SERIALIZED_CLASS(EngageSemServerInternals)
12341 IMPLEMENT_JSON_SERIALIZATION()
12363 housekeeperIntervalMs = 1000;
12367 static void to_json(nlohmann::json& j,
const EngageSemServerInternals& p)
12369 j = nlohmann::json{
12370 TOJSON_IMPL(watchdog),
12371 TOJSON_IMPL(housekeeperIntervalMs),
12372 TOJSON_IMPL(tuning)
12375 static void from_json(
const nlohmann::json& j, EngageSemServerInternals& p)
12378 getOptional<WatchdogSettings>(
"watchdog", p.watchdog, j);
12379 getOptional<int>(
"housekeeperIntervalMs", p.housekeeperIntervalMs, j, 1000);
12380 getOptional<TuningSettings>(
"tuning", p.tuning, j);
12384 JSON_SERIALIZED_CLASS(EngageSemServerConfiguration)
12395 IMPLEMENT_JSON_SERIALIZATION()
12456 serviceConfigurationFileCheckSecs = 60;
12457 groupsConfigurationFileName.clear();
12458 groupsConfigurationFileCommand.clear();
12459 groupsConfigurationFileCheckSecs = 60;
12460 statusReport.clear();
12461 externalHealthCheckResponder.clear();
12463 certStoreFileName.clear();
12464 certStorePasswordHex.clear();
12465 enginePolicy.clear();
12466 configurationCheckSignalName =
"rts.9a164fa.${id}";
12467 fipsCrypto.clear();
12472 maxQueuingMs = 15000;
12478 static void to_json(nlohmann::json& j,
const EngageSemServerConfiguration& p)
12480 j = nlohmann::json{
12482 TOJSON_IMPL(serviceConfigurationFileCheckSecs),
12483 TOJSON_IMPL(groupsConfigurationFileName),
12484 TOJSON_IMPL(groupsConfigurationFileCommand),
12485 TOJSON_IMPL(groupsConfigurationFileCheckSecs),
12486 TOJSON_IMPL(statusReport),
12487 TOJSON_IMPL(externalHealthCheckResponder),
12488 TOJSON_IMPL(internals),
12489 TOJSON_IMPL(certStoreFileName),
12490 TOJSON_IMPL(certStorePasswordHex),
12491 TOJSON_IMPL(enginePolicy),
12492 TOJSON_IMPL(configurationCheckSignalName),
12493 TOJSON_IMPL(fipsCrypto),
12495 TOJSON_IMPL(maxQueueLen),
12496 TOJSON_IMPL(minQueuingMs),
12497 TOJSON_IMPL(maxQueuingMs),
12498 TOJSON_IMPL(minPriority),
12499 TOJSON_IMPL(maxPriority)
12502 static void from_json(
const nlohmann::json& j, EngageSemServerConfiguration& p)
12505 getOptional<std::string>(
"id", p.id, j);
12506 getOptional<int>(
"serviceConfigurationFileCheckSecs", p.serviceConfigurationFileCheckSecs, j, 60);
12507 getOptional<std::string>(
"groupsConfigurationFileName", p.groupsConfigurationFileName, j);
12508 getOptional<std::string>(
"groupsConfigurationFileCommand", p.groupsConfigurationFileCommand, j);
12509 getOptional<int>(
"groupsConfigurationFileCheckSecs", p.groupsConfigurationFileCheckSecs, j, 60);
12510 getOptional<EngageSemServerStatusReportConfiguration>(
"statusReport", p.statusReport, j);
12511 getOptional<ExternalHealthCheckResponder>(
"externalHealthCheckResponder", p.externalHealthCheckResponder, j);
12512 getOptional<EngageSemServerInternals>(
"internals", p.internals, j);
12513 getOptional<std::string>(
"certStoreFileName", p.certStoreFileName, j);
12514 getOptional<std::string>(
"certStorePasswordHex", p.certStorePasswordHex, j);
12515 j.at(
"enginePolicy").get_to(p.enginePolicy);
12516 getOptional<std::string>(
"configurationCheckSignalName", p.configurationCheckSignalName, j,
"rts.9a164fa.${id}");
12517 getOptional<FipsCryptoSettings>(
"fipsCrypto", p.fipsCrypto, j);
12518 getOptional<NsmConfiguration>(
"nsm", p.nsm, j);
12519 getOptional<int>(
"maxQueueLen", p.maxQueueLen, j, 64);
12520 getOptional<int>(
"minQueuingMs", p.minQueuingMs, j, 0);
12521 getOptional<int>(
"maxQueuingMs", p.maxQueuingMs, j, 15000);
12522 getOptional<int>(
"minPriority", p.minPriority, j, 0);
12523 getOptional<int>(
"maxPriority", p.maxPriority, j, 255);
12527 JSON_SERIALIZED_CLASS(EngateGroup)
12539 IMPLEMENT_JSON_SERIALIZATION()
12544 uint32_t inputHangMs;
12545 uint32_t inputActivationPowerThreshold;
12546 uint32_t inputDeactivationPowerThreshold;
12558 inputActivationPowerThreshold = 700;
12559 inputDeactivationPowerThreshold = 125;
12563 static void to_json(nlohmann::json& j,
const EngateGroup& p)
12566 to_json(g,
static_cast<const Group&
>(p));
12568 j = nlohmann::json{
12569 TOJSON_IMPL(useVad),
12570 TOJSON_IMPL(inputHangMs),
12571 TOJSON_IMPL(inputActivationPowerThreshold),
12572 TOJSON_IMPL(inputDeactivationPowerThreshold)
12575 static void from_json(
const nlohmann::json& j, EngateGroup& p)
12578 from_json(j,
static_cast<Group&
>(p));
12579 getOptional<uint32_t>(
"inputHangMs", p.inputHangMs, j, 750);
12580 getOptional<uint32_t>(
"inputActivationPowerThreshold", p.inputActivationPowerThreshold, j, 700);
12581 getOptional<uint32_t>(
"inputDeactivationPowerThreshold", p.inputDeactivationPowerThreshold, j, 125);
12585 JSON_SERIALIZED_CLASS(EngateGroupsConfiguration)
12597 IMPLEMENT_JSON_SERIALIZATION()
12615 static void to_json(nlohmann::json& j,
const EngateGroupsConfiguration& p)
12617 j = nlohmann::json{
12618 TOJSON_IMPL(groups)
12621 static void from_json(
const nlohmann::json& j, EngateGroupsConfiguration& p)
12624 getOptional<std::vector<EngateGroup>>(
"groups", p.groups, j);
12628 JSON_SERIALIZED_CLASS(EngateServerStatusReportConfiguration)
12640 IMPLEMENT_JSON_SERIALIZATION()
12669 includeGroupDetail =
false;
12674 static void to_json(nlohmann::json& j,
const EngateServerStatusReportConfiguration& p)
12676 j = nlohmann::json{
12677 TOJSON_IMPL(fileName),
12678 TOJSON_IMPL(intervalSecs),
12679 TOJSON_IMPL(enabled),
12680 TOJSON_IMPL(includeGroupDetail),
12681 TOJSON_IMPL(runCmd)
12684 static void from_json(
const nlohmann::json& j, EngateServerStatusReportConfiguration& p)
12687 getOptional<std::string>(
"fileName", p.fileName, j);
12688 getOptional<int>(
"intervalSecs", p.intervalSecs, j, 60);
12689 getOptional<bool>(
"enabled", p.enabled, j,
false);
12690 getOptional<std::string>(
"runCmd", p.runCmd, j);
12691 getOptional<bool>(
"includeGroupDetail", p.includeGroupDetail, j,
false);
12695 JSON_SERIALIZED_CLASS(EngateServerInternals)
12709 IMPLEMENT_JSON_SERIALIZATION()
12731 housekeeperIntervalMs = 1000;
12735 static void to_json(nlohmann::json& j,
const EngateServerInternals& p)
12737 j = nlohmann::json{
12738 TOJSON_IMPL(watchdog),
12739 TOJSON_IMPL(housekeeperIntervalMs),
12740 TOJSON_IMPL(tuning)
12743 static void from_json(
const nlohmann::json& j, EngateServerInternals& p)
12746 getOptional<WatchdogSettings>(
"watchdog", p.watchdog, j);
12747 getOptional<int>(
"housekeeperIntervalMs", p.housekeeperIntervalMs, j, 1000);
12748 getOptional<TuningSettings>(
"tuning", p.tuning, j);
12752 JSON_SERIALIZED_CLASS(EngateServerConfiguration)
12763 IMPLEMENT_JSON_SERIALIZATION()
12818 serviceConfigurationFileCheckSecs = 60;
12819 groupsConfigurationFileName.clear();
12820 groupsConfigurationFileCommand.clear();
12821 groupsConfigurationFileCheckSecs = 60;
12822 statusReport.clear();
12823 externalHealthCheckResponder.clear();
12825 certStoreFileName.clear();
12826 certStorePasswordHex.clear();
12827 enginePolicy.clear();
12828 configurationCheckSignalName =
"rts.9a164fa.${id}";
12829 fipsCrypto.clear();
12834 static void to_json(nlohmann::json& j,
const EngateServerConfiguration& p)
12836 j = nlohmann::json{
12838 TOJSON_IMPL(serviceConfigurationFileCheckSecs),
12839 TOJSON_IMPL(groupsConfigurationFileName),
12840 TOJSON_IMPL(groupsConfigurationFileCommand),
12841 TOJSON_IMPL(groupsConfigurationFileCheckSecs),
12842 TOJSON_IMPL(statusReport),
12843 TOJSON_IMPL(externalHealthCheckResponder),
12844 TOJSON_IMPL(internals),
12845 TOJSON_IMPL(certStoreFileName),
12846 TOJSON_IMPL(certStorePasswordHex),
12847 TOJSON_IMPL(enginePolicy),
12848 TOJSON_IMPL(configurationCheckSignalName),
12849 TOJSON_IMPL(fipsCrypto),
12853 static void from_json(
const nlohmann::json& j, EngateServerConfiguration& p)
12856 getOptional<std::string>(
"id", p.id, j);
12857 getOptional<int>(
"serviceConfigurationFileCheckSecs", p.serviceConfigurationFileCheckSecs, j, 60);
12858 getOptional<std::string>(
"groupsConfigurationFileName", p.groupsConfigurationFileName, j);
12859 getOptional<std::string>(
"groupsConfigurationFileCommand", p.groupsConfigurationFileCommand, j);
12860 getOptional<int>(
"groupsConfigurationFileCheckSecs", p.groupsConfigurationFileCheckSecs, j, 60);
12861 getOptional<EngateServerStatusReportConfiguration>(
"statusReport", p.statusReport, j);
12862 getOptional<ExternalHealthCheckResponder>(
"externalHealthCheckResponder", p.externalHealthCheckResponder, j);
12863 getOptional<EngateServerInternals>(
"internals", p.internals, j);
12864 getOptional<std::string>(
"certStoreFileName", p.certStoreFileName, j);
12865 getOptional<std::string>(
"certStorePasswordHex", p.certStorePasswordHex, j);
12866 j.at(
"enginePolicy").get_to(p.enginePolicy);
12867 getOptional<std::string>(
"configurationCheckSignalName", p.configurationCheckSignalName, j,
"rts.9a164fa.${id}");
12868 getOptional<FipsCryptoSettings>(
"fipsCrypto", p.fipsCrypto, j);
12869 getOptional<NsmConfiguration>(
"nsm", p.nsm, j);
12873 static inline void dumpExampleConfigurations(
const char *path)
12875 WatchdogSettings::document();
12876 FileRecordingRequest::document();
12877 Feature::document();
12878 Featureset::document();
12880 RtpPayloadTypeTranslation::document();
12881 NetworkInterfaceDevice::document();
12882 ListOfNetworkInterfaceDevice::document();
12883 RtpHeader::document();
12884 BlobInfo::document();
12885 TxAudioUri::document();
12886 AdvancedTxParams::document();
12887 Identity::document();
12888 Location::document();
12890 Connectivity::document();
12891 PresenceDescriptorGroupItem::document();
12892 PresenceDescriptor::document();
12893 NetworkTxOptions::document();
12894 TcpNetworkTxOptions::document();
12895 NetworkAddress::document();
12896 NetworkAddressRxTx::document();
12897 NetworkAddressRestrictionList::document();
12898 StringRestrictionList::document();
12899 Rallypoint::document();
12900 RallypointCluster::document();
12901 NetworkDeviceDescriptor::document();
12902 TxAudio::document();
12903 AudioDeviceDescriptor::document();
12904 ListOfAudioDeviceDescriptor::document();
12906 TalkerInformation::document();
12907 GroupTalkers::document();
12908 Presence::document();
12909 Advertising::document();
12910 GroupPriorityTranslation::document();
12911 GroupTimeline::document();
12912 GroupAppTransport::document();
12913 RtpProfile::document();
12915 Mission::document();
12916 LicenseDescriptor::document();
12917 EngineNetworkingRpUdpStreaming::document();
12918 EnginePolicyNetworking::document();
12921 Bridge::document();
12922 AndroidAudio::document();
12923 EnginePolicyAudio::document();
12924 SecurityCertificate::document();
12925 EnginePolicySecurity::document();
12926 EnginePolicyLogging::document();
12927 EnginePolicyDatabase::document();
12928 NamedAudioDevice::document();
12929 EnginePolicyNamedAudioDevices::document();
12930 Licensing::document();
12931 DiscoveryMagellan::document();
12932 DiscoverySsdp::document();
12933 DiscoverySap::document();
12934 DiscoveryCistech::document();
12935 DiscoveryTrellisware::document();
12936 DiscoveryConfiguration::document();
12937 EnginePolicyInternals::document();
12938 EnginePolicyTimelines::document();
12939 RtpMapEntry::document();
12940 ExternalModule::document();
12941 ExternalCodecDescriptor::document();
12942 EnginePolicy::document();
12943 TalkgroupAsset::document();
12944 EngageDiscoveredGroup::document();
12945 RallypointPeer::document();
12946 RallypointServerLimits::document();
12947 RallypointServerStatusReportConfiguration::document();
12948 RallypointServerLinkGraph::document();
12949 ExternalHealthCheckResponder::document();
12951 PeeringConfiguration::document();
12952 IgmpSnooping::document();
12953 RallypointReflector::document();
12954 RallypointUdpStreaming::document();
12955 RallypointServer::document();
12956 PlatformDiscoveredService::document();
12957 TimelineQueryParameters::document();
12958 CertStoreCertificate::document();
12959 CertStore::document();
12960 CertStoreCertificateElement::document();
12961 CertStoreDescriptor::document();
12962 CertificateDescriptor::document();
12963 BridgeCreationDetail::document();
12964 GroupConnectionDetail::document();
12965 GroupTxDetail::document();
12966 GroupCreationDetail::document();
12967 GroupReconfigurationDetail::document();
12968 GroupHealthReport::document();
12969 InboundProcessorStats::document();
12970 TrafficCounter::document();
12971 GroupStats::document();
12972 RallypointConnectionDetail::document();
12973 BridgingConfiguration::document();
12974 BridgingServerStatusReportConfiguration::document();
12975 BridgingServerInternals::document();
12976 BridgingServerConfiguration::document();
12977 EarGroupsConfiguration::document();
12978 EarServerStatusReportConfiguration::document();
12979 EarServerInternals::document();
12980 EarServerConfiguration::document();
12981 RangerPackets::document();
12982 TransportImpairment::document();
12984 EngageSemGroupsConfiguration::document();
12985 EngageSemServerStatusReportConfiguration::document();
12986 EngageSemServerInternals::document();
12987 EngageSemServerConfiguration::document();
12992 #pragma GCC diagnostic pop
TxPriority_t
Network Transmission Priority.
@ priBestEffort
best effort
AddressResolutionPolicy_t
Address family resolution policy.
@ arpIpv6ThenIpv4
IPv6 then IPv4.
@ arpIpv4ThenIpv6
IPv4 then IPv6.
#define ENGAGE_IGNORE_COMPILER_UNUSED_WARNING
RestrictionElementType_t
Enum describing restriction element types.
@ retGenericAccessTagPattern
Elements are generic access tags regex patterns.
@ retGroupIdPattern
Elements are group ID regex patterns.
@ retGroupId
A literal group ID.
@ retCertificateIssuerPattern
Elements are X.509 certificate issuer regex patterns.
@ retCertificateSubjectPattern
Elements are X.509 certificate subject regex patterns.
@ retCertificateFingerprintPattern
Elements are X.509 certificate fingerprint regex patterns.
@ retCertificateSerialNumberPattern
Elements are X.509 certificate serial number regex patterns.
GroupRestrictionAccessPolicyType_t
Enum describing restriction types.
@ graptStrict
Registration for groups is NOT allowed by default - requires definitive access through something like...
@ graptPermissive
Registration for groups is allowed by default.
RestrictionType_t
Enum describing restriction types.
@ rtWhitelist
Elements are whitelisted.
@ rtBlacklist
Elements are blacklisted.
Configuration when using the engageBeginGroupTxAdvanced API.
TxAudioUri audioUri
[Optional] A URI to stream from instead of the audio input device
uint8_t priority
[Optional, Default: 0] Transmit priority between 0 (lowest) and 255 (highest).
bool receiverRxMuteForAliasSpecializer
[Optional, Default: false] Indicates that the aliasSpecializer must cause receivers to mute this tran...
uint16_t subchannelTag
[Optional, Default: 0] Defines a sub channel within a group. Audio will be opaque to all other client...
bool reBegin
[Optional, Default: false] Indicates that the transmission should be restarted.
uint16_t aliasSpecializer
[Optional, Default: 0] Defines a numeric affinity value to be included in the transmission....
uint16_t flags
[Optional, Default: 0] Combination of the ENGAGE_TXFLAG_xxx flags
std::string alias
[Optional, Default: empty string] The Engage Engine should transmit the user's alias as part of the h...
bool includeNodeId
[Optional, Default: false] The Engage Engine should transmit the NodeId as part of the header extensi...
uint32_t txId
[Optional, Default: 0] Transmission ID
bool muted
[Optional, Default: false] While the microphone should be opened, captured audio should be ignored un...
Defines parameters for advertising of an entity such as a known, public, group.
int intervalMs
[Optional, Default: 20000] Interval at which the advertisement should be sent in milliseconds.
bool enabled
[Optional, Default: false] Enabled advertising
bool alwaysAdvertise
[Optional, Default: false] If true, the node will advertise the item even if it detects other nodes m...
Acoustic Echo Cancellation settings.
int speakerTailMs
[Optional, Default: 60] Milliseconds of speaker tail
bool cng
[Optional, Default: true] Enable comfort noise generation
bool enabled
[Optional, Default: false] Enable acoustic echo cancellation
Mode_t
Acoustic echo cancellation mode enum.
Mode_t mode
[Optional, Default: aecmDefault] Specifies AEC mode. See Mode_t for all modes
bool enabled
[Optional, Default: false] Enables automatic gain control.
int compressionGainDb
[Optional, Default: 25, Minimum = 0, Maximum = 125] Gain in db.
bool enableLimiter
[Optional, Default: false] Enables limiter to prevent overdrive.
int maxLevel
[Optional, Default: 255] Maximum level.
int minLevel
[Optional, Default: 0] Minimum level.
int targetLevelDb
[Optional, Default: 9] Target gain level if there is no compression gain.
Default audio settings for AndroidAudio.
int api
[Optional, Default 0] Android audio API version: 0=Unspecified, 1=AAudio, 2=OpenGLES
int sessionId
[Optional, Default INVALID_SESSION_ID] A session ID from the Android AudioManager
int contentType
[Optional, Default 1] Usage type: 1=Speech 2=Music 3=Movie 4=Sonification
int sharingMode
[Optional, Default 0] Sharing mode: 0=Exclusive, 1=Shared
int performanceMode
[Optional, Default 12] Performance mode: 10=None/Default, 11=PowerSaving, 12=LowLatency
int inputPreset
[Optional, Default 7] Input preset: 1=Generic 5=Camcorder 6=VoiceRecognition 7=VoiceCommunication 9=U...
int usage
[Optional, Default 2] Usage type: 1=Media 2=VoiceCommunication 3=VoiceCommunicationSignalling 4=Alarm...
int engineMode
[Optional, Default 0] 0=use legacy low-level APIs, 1=use high-level Android APIs
Custom Audio Device Configuration.
std::string type
Device type (if any)
int samplingRate
This is the rate that the device will process the PCM audio data at.
std::string name
Name of the device assigned by the platform.
bool isDefault
True if this is the default device for the direction above.
std::string serialNumber
Device serial number (if any)
int channels
Indicates the number of audio channels to process.
std::string hardwareId
Device hardware ID (if any)
std::string manufacturer
Device manufacturer (if any)
Direction_t
Audio Device Direction Enum.
@ dirOutput
This is an output only device.
@ dirInput
This is an input only device.
std::string model
Device mode (if any)
Direction_t direction
Audio direction the device supports.
std::string extra
Extra data provided by the platform (if any)
bool isPresent
True if the device is currently present on the system.
int boostPercentage
A percentage at which to gain/attenuate the audio.
bool isAdad
True if the device is an Application-Defined Audio Device.
int deviceId
[Read Only] Unique device identifier assigned by Engage Engine at time of device creation.
Description of an audio gate.
double coefficient
[Optional. Default: 1.75] Coefficient by which to multiply the current history average to determine t...
uint32_t hangMs
[Optional. Default: 1500] Hang timer in milliseconds
bool enabled
[Optional. Default: false] Enables the audio gate if true
uint32_t windowMin
[Optional. Default: 25] Number of 10ms history samples to gather before calculating the noise floor -...
bool useVad
[Optional. Default: false] Use voice activity detection rather than audio energy
uint32_t windowMax
[Optional. Default: 125] Maximum number of 10ms history samples - ignored if useVad is true
Used to configure the Audio properties for a group.
int outputLevelRight
[Optional, Default: 100] The percentage at which to set the right audio at.
std::string outputHardwareId
[Optional] Hardware ID of the output audio device to use for this group. If empty,...
bool outputMuted
[Optional, Default: false] Mutes output audio.
std::string inputHardwareId
[Optional] Hardware ID of the input audio device to use for this group. If empty, inputId is used.
bool enabled
[Optional, Default: true] Audio is enabled
int inputId
[Optional, Default: first audio device] Id for the input audio device to use for this group.
int outputGain
[Optional, Default: 0] The percentage at which to gain the output audio.
int outputId
[Optional, Default: first audio device] Id for the output audio device to use for this group.
int inputGain
[Optional, Default: 0] The percentage at which to gain the input audio.
int outputLevelLeft
[Optional, Default: 100] The percentage at which to set the left audio at.
Describes an audio device that is available on the system.
std::string model
[Optional] Model
std::string extra
[Optional] Extra
std::string name
Name of the device.
std::string manufacturer
[Optional] Manufacturer
std::string type
[Optional] Type
std::string hardwareId
The string identifier used to identify the hardware.
bool isDefault
True if this is the default device.
std::string serialNumber
[Optional] Serial number
Describes an audio registry.
std::vector< AudioRegistryDevice > inputs
[Optional] List of input devices to use for the registry.
std::vector< AudioRegistryDevice > outputs
[Optional] List of output devices to use for the registry.
Describes the Blob data being sent used in the engageSendGroupBlob API.
size_t size
[Optional, Default : 0] Size of the payload
RtpHeader rtpHeader
Custom RTP header.
PayloadType_t payloadType
[Optional, Default: bptUndefined] The payload type to send in the blob
std::string target
[Optional, Default: empty string] The nodeId to which this message is targeted. If this is empty,...
std::string source
[Optional, Default: empty string] The nodeId of Engage Engine that sent the message....
int txnTimeoutSecs
[Optional, Default: 0] Number of seconds after which to time out delivery to the target node
PayloadType_t
Payload type. BlobInfo RTP supported Payload types.
std::string txnId
[Optional but required if txnTimeoutSecs is > 0]
Detailed information for a bridge creation.
CreationStatus_t
Creation status.
CreationStatus_t status
The creation status.
std::string id
ID of the bridge.
Bridging session settings.
std::vector< std::string > groups
List of group IDs to be included in the session.
bool enabled
[Optional, Default: true] Enable the bridge NOTE: this is only used bt EBS and is ignored when callin...
std::vector< Group > groups
Array of bridges in the configuration.
std::vector< Bridge > bridges
Array of bridges in the configuration.
Configuration for the bridging server.
std::string certStoreFileName
Path to the certificate store.
FipsCryptoSettings fipsCrypto
[Optional] Settings for the FIPS crypto.
std::string configurationCheckSignalName
Name to use for signalling a configuration check.
ExternalHealthCheckResponder externalHealthCheckResponder
Details concerning the server's interaction with an external health-checker such as a load-balancer.
OpMode_t mode
Specifies the default operation mode (see OpMode_t).
EnginePolicy enginePolicy
The policy to be used for the underlying Engage Engine.
BridgingServerStatusReportConfiguration statusReport
Details for producing a status report.
std::string bridgingConfigurationFileCommand
Command-line to execute that returns a bridging configuration.
std::string bridgingConfigurationFileName
Name of a file containing the bridging configuration.
std::string certStorePasswordHex
Hex password for the certificate store (if any)
OpMode_t
Enum describing the default mode the bridging service runs in. Values of omRaw, omMultistream,...
BridgingServerInternals internals
Internal settings.
int bridgingConfigurationFileCheckSecs
Number of seconds between checks to see if the bridging configuration has been updated....
int serviceConfigurationFileCheckSecs
Number of seconds between checks to see if the service configuration has been updated....
std::string id
A unqiue identifier for the bridge server.
NsmConfiguration nsm
[Optional] Settings for NSM.
Internal bridging server settings.
int housekeeperIntervalMs
[Optional, Default: 1000] Interval at which to run the housekeeper thread.
TuningSettings tuning
[Optional] Low-level tuning
WatchdogSettings watchdog
[Optional] Settings for the watchdog.
TODO: Configuration for the bridging server status report file.
bool includeBridgeGroupDetail
Description of a certstore certificate element.
std::string tags
Additional attributes.
bool hasPrivateKey
True if the certificate has a private key associated with it.
std::string certificatePem
PEM of the certificate.
Holds a certificate and (optionally) a private key in a certstore.
std::string tags
Additional tags.
std::string id
Id of the certificate.
std::string certificatePem
Certificate in PEM format.
void * internalData
Unserialized internal data.
std::string privateKeyPem
Private key in PEM format.
Description of a certstore.
std::string id
Certstore ID.
std::vector< CertStoreCertificateElement > certificates
Array of certificate elements.
std::string fileName
Name of the file the certstore resides in.
int flags
Flags set for the certstore.
int version
Version of the certstore.
std::vector< KvPair > kvp
Array of kv pairs.
std::vector< KvPair > kvp
[Optional] Array of KV pairs
std::vector< CertStoreCertificate > certificates
Array of certificates in this store.
std::string id
The ID of the certstore.
Description of a certificate.
std::vector< CertificateSubjectElement > subjectElements
Array of subject elements.
std::string serial
Serial #.
std::string publicKeyPem
PEM version of the public key.
std::vector< CertificateSubjectElement > issuerElements
Array of issuer elements.
bool selfSigned
Indicates whether the certificqte is self-signed.
std::string fingerprint
Fingerprint.
std::string notAfter
Validity date notAfter.
std::string subject
Subject.
std::string notBefore
Validity date notBefore.
std::string issuer
Issuer.
std::string certificatePem
PEM version of the certificate.
Description of a certificate subject element.
Connectivity Information used as part of the PresenceDescriptor.
int type
Is the type of connectivity the device has to the network.
int strength
Is the strength of the connection connection as reported by the OS - usually in dbm.
int rating
Is the quality of the network connection as reported by the OS - OS dependent.
Cistech Discovery settings.
Configuration for the Discovery features.
DiscoveryMagellan magellan
DiscoveryTrellisware trellisware
DiscoveryMagellan Discovery settings.
SecurityCertificate security
Tls tls
[Optional] Details concerning Transport Layer Security.
std::string interfaceName
[Optional, Default: default system interface] The network interface to bind to for discovery packets.
Session Announcement Discovery settings settings.
int ageTimeoutMs
[Optional, Default 30000] Number of milliseconds of no SAP announcment before the advertised entity i...
Advertising advertising
Parameters for advertising.
NetworkAddress address
[Optional, Default 224.2.127.254:9875] IP address and port.
bool enabled
[Optional, Default: false] Enables the Engage Engine to use SAP for asset discovery.
std::string interfaceName
[Optional, Default: default system interface] The network interface to bind to for discovery packets.
Simple Service Discovery Protocol settings.
bool enabled
[Optional, Default: false] Enables the Engage Engine to use SSDP for asset discovery.
std::vector< std::string > searchTerms
[Optional] An array of regex strings to be used to filter SSDP requests and responses.
int ageTimeoutMs
[Optional, Default 30000] Number of milliseconds of no SSDP announcment before the advertised entity ...
Advertising advertising
Parameters for advertising.
std::string interfaceName
[Optional, Default: default system interface] The network interface to bind to for discovery packets.
NetworkAddress address
[Optional, Default 255.255.255.255:1900] IP address and port.
Trellisware Discovery settings.
SecurityCertificate security
std::vector< Group > groups
Array of groups in the configuration.
Configuration for the ear server.
std::string id
A unqiue identifier for the EAR server.
std::string configurationCheckSignalName
Name to use for signalling a configuration check.
std::string certStorePasswordHex
Hex password for the certificate store (if any)
ExternalHealthCheckResponder externalHealthCheckResponder
Details concerning the server's interaction with an external health-checker such as a load-balancer.
FipsCryptoSettings fipsCrypto
[Optional] Settings for the FIPS crypto.
NsmConfiguration nsm
[Optional] Settings for NSM.
EarServerInternals internals
Internal settings.
int groupsConfigurationFileCheckSecs
Number of seconds between checks to see if the configuration has been updated. Default is 60.
EarServerStatusReportConfiguration statusReport
Details for producing a status report.
std::string certStoreFileName
Path to the certificate store.
std::string groupsConfigurationFileName
Name of a file containing the ear configuration.
int serviceConfigurationFileCheckSecs
Number of seconds between checks to see if the service configuration has been updated....
std::string groupsConfigurationFileCommand
Command-line to execute that returns a configuration.
EnginePolicy enginePolicy
The policy to be used for the underlying Engage Engine.
Internal ear server settings.
int housekeeperIntervalMs
[Optional, Default: 1000] Interval at which to run the housekeeper thread.
WatchdogSettings watchdog
[Optional] Settings for the EAR's watchdog.
TuningSettings tuning
[Optional] Low-level tuning
TODO: Configuration for the ear server status report file.
NetworkAddress rx
Internal RX detail.
NetworkAddress tx
Internal TX detail.
std::string id
Internal ID.
Engage Semaphore configuration.
std::vector< Group > groups
Array of groups in the configuration.
Configuration for the EFC server.
FipsCryptoSettings fipsCrypto
[Optional] Settings for the FIPS crypto.
EnginePolicy enginePolicy
The policy to be used for the underlying Engage Engine.
std::string configurationCheckSignalName
Name to use for signalling a configuration check.
EngageSemServerStatusReportConfiguration statusReport
Details for producing a status report.
std::string id
A unqiue identifier for the EFC server.
std::string certStoreFileName
Path to the certificate store.
std::string groupsConfigurationFileName
Name of a file containing the EFC configuration.
int serviceConfigurationFileCheckSecs
Number of seconds between checks to see if the service configuration has been updated....
NsmConfiguration nsm
[Optional] Settings for NSM.
std::string groupsConfigurationFileCommand
Command-line to execute that returns a configuration.
ExternalHealthCheckResponder externalHealthCheckResponder
Details concerning the server's interaction with an external health-checker such as a load-balancer.
EngageSemServerInternals internals
Internal settings.
std::string certStorePasswordHex
Hex password for the certificate store (if any)
int groupsConfigurationFileCheckSecs
Number of seconds between checks to see if the configuration has been updated. Default is 60.
Internal EFC server settings.
WatchdogSettings watchdog
[Optional] Settings for the EFC's watchdog.
TuningSettings tuning
[Optional] Low-level tuning
int housekeeperIntervalMs
[Optional, Default: 1000] Interval at which to run the housekeeper thread.
TODO: Configuration for the EFC server status report file.
std::vector< EngateGroup > groups
Array of groups in the configuration.
Configuration for the engate server.
EngateServerStatusReportConfiguration statusReport
Details for producing a status report.
ExternalHealthCheckResponder externalHealthCheckResponder
Details concerning the server's interaction with an external health-checker such as a load-balancer.
std::string certStorePasswordHex
Hex password for the certificate store (if any)
std::string groupsConfigurationFileName
Name of a file containing the ear configuration.
EngateServerInternals internals
Internal settings.
int groupsConfigurationFileCheckSecs
Number of seconds between checks to see if the configuration has been updated. Default is 60.
FipsCryptoSettings fipsCrypto
[Optional] Settings for the FIPS crypto.
std::string certStoreFileName
Path to the certificate store.
NsmConfiguration nsm
[Optional] Settings for NSM.
std::string configurationCheckSignalName
Name to use for signalling a configuration check.
EnginePolicy enginePolicy
The policy to be used for the underlying Engage Engine.
int serviceConfigurationFileCheckSecs
Number of seconds between checks to see if the service configuration has been updated....
std::string id
A unqiue identifier for the EAR server.
std::string groupsConfigurationFileCommand
Command-line to execute that returns a configuration.
Internal engate server settings.
TuningSettings tuning
[Optional] Low-level tuning
int housekeeperIntervalMs
[Optional, Default: 1000] Interval at which to run the housekeeper thread.
WatchdogSettings watchdog
[Optional] Settings for the EAR's watchdog.
TODO: Configuration for the engate server status report file.
Configuration for RP UDP streaming.
TxPriority_t priority
[Optional, Default: priVoice] Transmission priority. This has meaning on some operating systems based...
int keepaliveIntervalSecs
Optional, Default: 15] Seconds interval at which to send UDP keepalives to Rallypoints....
int ttl
[Optional, Default: 64] Time to live or hop limit is a mechanism that limits the lifespan or lifetime...
int port
[Optional, 0] The port to be used for Rallypoint UDP streaming. A value of 0 will result in an epheme...
bool enabled
[Optional, false] Enables UDP streaming if the RP supports it
Default audio settings for Engage Engine policy.
AudioRegistry registry
[Optional] If specified, this registry will be used to discover the input and output devices
Vad vad
[Optional] Voice activity detection settings
Agc outputAgc
[Optional] Automatic Gain Control for audio outputs
bool saveOutputPcm
[Optional, Default: false] If true, input audio is written to a PCM file in the data directory
bool enabled
[Optional, Default: true] Enables audio processing
AndroidAudio android
[Optional] Android-specific audio settings
int internalRate
[Optional, Default: 16000] Internal sampling rate - 8000 or 16000
bool muteTxOnTx
[Optional, Default: false] Automatically mute TX when TX begins
Agc inputAgc
[Optional] Automatic Gain Control for audio inputs
bool hardwareEnabled
[Optional, Default: true] Enables local machine hardware audio
Aec aec
[Optional] Acoustic echo cancellation settings
bool denoiseInput
[Optional, Default: false] Denoise input
bool saveInputPcm
[Optional, Default: false] If true, input audio is written to a PCM file in the data directory
bool denoiseOutput
[Optional, Default: false] Denoise output
int internalChannels
[Optional, Default: 2] Internal audio channel count rate - 1 or 2
Provides Engage Engine policy configuration.
std::vector< ExternalModule > externalCodecs
Optional external codecs.
EnginePolicyNamedAudioDevices namedAudioDevices
Optional named audio devices (Linux only)
Featureset featureset
Optional feature set.
EnginePolicyDatabase database
Database settings.
EnginePolicyAudio audio
Audio settings.
std::string dataDirectory
Specifies the root of the physical path to store data.
Licensing licensing
Licensing settings.
EnginePolicyLogging logging
Logging settings.
DiscoveryConfiguration discovery
Discovery settings.
std::vector< RtpMapEntry > rtpMap
Optional RTP - overrides the default.
EngineStatusReportConfiguration statusReport
Optional statusReport - details for the status report.
EnginePolicyInternals internals
Internal settings.
EnginePolicySecurity security
Security settings.
EnginePolicyTimelines timelines
Timelines settings.
EnginePolicyNetworking networking
Security settings.
Internal Engage Engine settings.
TuningSettings tuning
[Optional] Low-level tuning
int stickyTidHangSecs
[Optional, Default: 10] The number of seconds after which "sticky" transmission IDs expire.
int maxTxSecs
[Optional, Default: 30] The default duration the engageBeginGroupTx and engageBeginGroupTxAdvanced fu...
int rpConnectionTimeoutSecs
[Optional, Default: 5] Connection timeout in seconds to RP
WatchdogSettings watchdog
[Optional] Settings for the Engine's watchdog.
RallypointCluster::ConnectionStrategy_t rpClusterStrategy
[Optional, Default: csRoundRobin] Specifies the default RP cluster connection strategy to be followed...
int delayedMicrophoneClosureSecs
[Optional, Default: 15] The number of seconds to cache an open microphone before actually closing it.
int rpTransactionTimeoutMs
[Optional, Default: 5] Transaction timeout with RP
int rtpExpirationCheckIntervalMs
[Optional, Default: 250] Interval at which to check for RTP expiration.
int rpClusterRolloverSecs
[Optional, Default: 10] Seconds between switching to a new target in a RP cluster
int housekeeperIntervalMs
[Optional, Default: 1000] Interval at which to run the housekeeper thread.
int uriStreamingIntervalMs
[Optional, Default: 60] The packet framing interval for audio streaming from a URI.
int maxLevel
[Optional, Default: 4, Range: 0-4] This is the maximum logging level to display in other words,...
EngineNetworkingRpUdpStreaming rpUdpStreaming
[Optional] Configuration for UDP streaming
std::string defaultNic
The default network interface card the Engage Engine should bind to.
RtpProfile rtpProfile
[Optional] Configuration for RTP profile
AddressResolutionPolicy_t addressResolutionPolicy
[Optional, Default 64] Address resolution policy
int multicastRejoinSecs
[Optional, Default: 8] Number of seconds elapsed between RX of multicast packets before an IGMP rejoi...
bool logRtpJitterBufferStats
[Optional, Default: false] If true, logs RTP jitter buffer statistics periodically
int rallypointRtTestIntervalMs
[Optional, Default: 60000] Milliseconds between sending Rallypoint round-trip test requests
bool preventMulticastFailover
[Optional, Default: false] Overrides/cancels group-level multicast failover if set to true
Default certificate to use for security operation in the Engage Engine.
SecurityCertificate certificate
The default certificate and private key for the Engine instance.
std::vector< std::string > caCertificates
[Optional] An array of CA certificates to be used for validation of far-end X.509 certificates
Engine Policy Timeline configuration.
long autosaveIntervalSecs
[Default 5] Interval at which events are to be saved from memory to disk (a slow operation)
int maxStorageMb
Specifies the maximum storage space to use.
bool enabled
[Optional, Default: true] Specifies if Time Lines are enabled by default.
int maxDiskMb
Specifies the maximum disk space to use - defaults to maxStorageMb.
SecurityCertificate security
The certificate to use for signing the recording.
int maxAudioEventMemMb
Specifies the maximum number of megabytes to allow for a single audio event's memory block - defaults...
long maxEventAgeSecs
Maximum age of an event after which it is to be erased.
int maxMemMb
Specifies the maximum memory to use - defaults to maxStorageMb.
std::string storageRoot
Specifies where the timeline recordings will be stored physically.
bool ephemeral
[Default false] If true, recordings are automatically purged when the Engine is shut down and/or rein...
bool disableSigningAndVerification
[Default false] If true, prevents signing of events - i.e. no anti-tanpering features will be availab...
int maxEvents
Maximum number of events to be retained.
long groomingIntervalSecs
Interval at which events are to be checked for age-based grooming.
TODO: Configuration for the translation server status report file.
bool includeTaskQueueDetail
Describes an external codec.
int samplingRate
Sampling rate.
int rtpPayloadType
RTP payload type.
int rtpTsMultiplier
RTP timestamp multiplier.
TODO: Configuration to enable external systems to use to check if the service is still running.
Base for a description of an external module.
std::string file
File spec.
nlohmann::json configuration
Optional free-form JSON configuration to be passed to the module.
bool debug
[Optional, Default false] If true, requests the crypto engine module to run in debugging mode.
bool enabled
[Optional, Default false] If true, requires FIPS140-2 crypto operation.
std::string curves
[Optional] Specifies the NIST-approved curves to be used for FIPS
std::string path
Path where the crypto engine module is located
std::string ciphers
[Optional] Specifies the NIST-approved ciphers to be used for FIPS
Configuration for the optional custom transport functionality for Group.
bool enabled
[Optional, Default: false] Enables custom feature.
std::string id
The id/name of the transport. This must match the id/name supplied when registering the app transport...
BridgingOpMode_t
Enum describing bridging operation mode types where applicable.
AdvancedTxParams mixedStreamTxParams
[Optional] Parameters to be applied when output is mixed (bomMixedStream)
BridgingOpMode_t mode
[Optional] The output mode
Detailed information for a group connection.
std::string id
ID of the group.
std::string peer
Peer information.
ConnectionType_t
Connection type.
bool asFailover
Indicates whether the connection is for purposes of failover.
ConnectionType_t connectionType
The connection type.
std::string reason
[Optional] Additional reason information
Detailed information for a group creation.
std::string id
ID of the group.
CreationStatus_t status
The creation status.
CreationStatus_t
Creation status.
Detailed information regarding a group's health.
GroupAppTransport appTransport
[Optional] Settings necessary if the group is transported via an application-supplied custom transpor...
std::string source
[Optional, Default: null] Indicates the source of this configuration - e.g. from the application or d...
Presence presence
Presence configuration (see Presence).
std::vector< uint16_t > specializerAffinities
List of specializer IDs that the local node has an affinity for/member of.
std::vector< Source > ignoreSources
[Optional] List of sources to ignore for this group
NetworkAddress rtcpPresenceRx
The network address for receiving RTCP presencing packets.
bool allowLoopback
[Optional, Default: false] Allows for processing of looped back packets - primarily meant for debuggi...
Type_t
Enum describing the group types.
NetworkAddress tx
The network address for transmitting network traffic to.
std::string alias
User alias to transmit as part of the realtime audio stream when using the engageBeginGroupTx API.
int stickyTidHangSecs
[Optional, Default: 10] The number of seconds after which "sticky" transmission IDs expire.
TxAudio txAudio
Audio transmit options such as codec, framing size etc (see TxAudio).
int maxRxSecs
[Optional, Default: 0] Maximum number of seconds the Engine will receive for on this group.
PacketCapturer txCapture
Details for capture of transmitted packets
NetworkTxOptions txOptions
Transmit options for the group (see NetworkTxOptions).
std::string synVoice
Name of the synthesis voice to use for the group
TransportImpairment rxImpairment
[Optional] The RX impairment to apply
std::string languageCode
ISO 639-2 language code for the group
std::string cryptoPassword
Password to be used for encryption. Note that this is not the encryption key but, rather,...
std::vector< std::string > presenceGroupAffinities
List of presence group IDs with which this group has an affinity.
GroupTimeline timeline
Audio timeline is configuration.
GroupPriorityTranslation priorityTranslation
[Optional] Describe how traffic for this group on a different addressing scheme translates to priorit...
bool disablePacketEvents
[Optional, Default: false] Disable packet events.
bool blockAdvertising
[Optional, Default: false] Set this to true if you do not want the Engine to advertise this Group on ...
bool ignoreAudioTraffic
[Optional, Default: false] Indicates that the group should ignore traffic that is audio-related
std::string interfaceName
The name of the network interface to use for multicasting for this group. If not provided,...
bool _wasDeserialized_rtpProfile
[Internal - not serialized
bool enableMulticastFailover
[Optional, Default: false] Set this to true to enable failover to multicast operation if a Rallypoint...
std::string name
The human readable name for the group.
NetworkAddress rx
The network address for receiving network traffic on.
Type_t type
Specifies the group type (see Type_t).
uint16_t blobRtpPayloadType
[Optional, Default: ENGAGE_DEFAULT_BLOB_RTP_PAYLOAD_TYPE] The RTP payload type to be used for blobs s...
std::vector< Rallypoint > rallypoints
[DEPRECATED] List of Rallypoint (s) the Group should use to connect to a Rallypoint router....
RtpProfile rtpProfile
[Optional] RTP profile the group
std::vector< RtpPayloadTypeTranslation > inboundRtpPayloadTypeTranslations
[Optional] A vector of translations from external entity RTP payload types to those used by Engage
int multicastFailoverSecs
[Optional, Default: 10] Specifies the number fo seconds to wait after Rallypoint connection failure t...
InboundAliasGenerationPolicy_t
Enum describing the alias generation policy.
RangerPackets rangerPackets
[Optional] Ranger packet options
int rfc4733RtpPayloadId
[Optional, Default: 0] The RTP payload ID by which to identify (RX and TX) payloads encoded according...
uint32_t securityLevel
[Optional, Default: 0] The security classification level of the group.
PacketCapturer rxCapture
Details for capture of received packets
GroupBridgeTargetOutputDetail bridgeTargetOutputDetail
Output details for when the group is a target in a bridge (see GroupBridgeTargetOutputDetail).
std::string id
Unique identity for the group.
AudioGate gateIn
[Optional] Inbound gating of audio - only audio allowed through by the gate will be processed
RallypointCluster rallypointCluster
Cluster of one or more Rallypoints the group may use.
TransportImpairment txImpairment
[Optional] The TX impairment to apply
Audio audio
Sets audio properties like which audio device to use, audio gain etc (see Audio).
bool lbCrypto
[Optional, Default: false] Use low-bandwidth crypto
std::string spokenName
The group name as spoken - typically by a text-to-speech system
InboundAliasGenerationPolicy_t inboundAliasGenerationPolicy
[Optional, Default: iagpAnonymousAlias]
std::string anonymousAlias
[Optional] Alias to use for inbound streams that do not have an alias component
Details for priority transmission based on unique network addressing.
NetworkAddress tx
TX addressing.
int priority
Engage priority for RX & TX.
NetworkAddress rx
RX addressing.
Detailed information for a group reconfiguration.
ReconfigurationStatus_t status
The creation status.
std::string id
ID of the group.
ReconfigurationStatus_t
Reconfiguration status.
Detailed statistics for group.
List of TalkerInformation objects.
std::vector< TalkerInformation > list
List of TalkerInformation objects.
Configuration for Timeline functionality for Group.
bool enabled
[Optional, Default: true] Enables timeline feature.
int maxAudioTimeMs
[Optional, Default: 30000] Maximum audio block size to record in milliseconds.
Detailed information for a group transmit.
std::string id
ID of the group.
int remotePriority
Remote TX priority (optional)
long nonFdxMsHangRemaining
Milliseconds of hang time remaining on a non-FDX group (optional)
int localPriority
Local TX priority (optional)
uint32_t txId
Transmission ID (optional)
TxStatus_t status
The TX status.
std::string displayName
[Optional, Default: empty string] The display name to be used for the user.
std::string userId
[Optional, Default: empty string] The user ID to be used to represent the user.
std::string nodeId
[Optional, Default: Auto Generated] This is the Node ID to use to represent instance on the network.
std::string avatar
[Optional, Default: empty string] This is a application defined field used to indicate a users avatar...
Configuration for IGMP snooping.
int queryIntervalMs
[Optional, Default 125000] Interval between sending IGMP membership queries. If 0,...
int subscriptionTimeoutMs
[Optional, Default 0] Typically calculated according to RFC specifications. Set a value here to manua...
bool enabled
Enables IGMP. Default is false.
Detailed statistics for an inbound processor.
Helper class for serializing and deserializing the LicenseDescriptor JSON.
std::string entitlement
Entitlement key to use for the product.
std::string cargo
Reserved for internal use.
std::string manufacturerId
[Read only] Manufacturer ID.
std::string key
License Key to be used for the application.
uint8_t cargoFlags
Reserved for internal use.
int type
[Read only] 0 = unknown, 1 = perpetual, 2 = expires
std::string deviceId
[Read only] Unique device identifier generated by the Engine.
int status
The current licensing status.
time_t expires
[Read only] The time that the license key or activation code expires in Unix timestamp - Zulu/UTC.
std::string activationCode
If the key required activation, this is the activation code generated using the entitlement,...
std::string expiresFormatted
[Read only] The time that the license key or activation code expires formatted in ISO 8601 format,...
std::string deviceId
Device Identifier. See LicenseDescriptor::deviceId for details.
std::string manufacturerId
Manufacturer ID to use for the product. See LicenseDescriptor::manufacturerId for details.
std::string activationCode
Activation Code issued for the license key. See LicenseDescriptor::activationCode for details.
std::string key
License key. See LicenseDescriptor::key for details.
std::string entitlement
Entitlement key to use for the product. See LicenseDescriptor::entitlement for details.
std::vector< Group > groups
Array of groups in the configuration.
std::vector< VoiceToVoiceSession > voiceToVoiceSessions
Array of voiceToVoice sessions in the configuration.
Configuration for the linguistics server.
LingoServerStatusReportConfiguration statusReport
Details for producing a status report.
std::string lingoConfigurationFileName
Name of a file containing the linguistics configuration.
std::string configurationCheckSignalName
Name to use for signalling a configuration check.
std::string id
A unqiue identifier for the linguistics server.
ExternalHealthCheckResponder externalHealthCheckResponder
Details concerning the server's interaction with an external health-checker such as a load-balancer.
NsmConfiguration nsm
[Optional] Settings for NSM.
std::string certStorePasswordHex
Hex password for the certificate store (if any)
std::string lingoConfigurationFileCommand
Command-line to execute that returns a linguistics configuration.
LingoServerInternals internals
Internal settings.
EnginePolicy enginePolicy
The policy to be used for the underlying Engage Engine.
int lingoConfigurationFileCheckSecs
Number of seconds between checks to see if the linguistics configuration has been updated....
std::string certStoreFileName
Path to the certificate store.
FipsCryptoSettings fipsCrypto
[Optional] Settings for the FIPS crypto.
NetworkAddress proxy
Address and port of the proxy.
int serviceConfigurationFileCheckSecs
Number of seconds between checks to see if the service configuration has been updated....
Internal translator server settings.
int housekeeperIntervalMs
[Optional, Default: 1000] Interval at which to run the housekeeper thread.
WatchdogSettings watchdog
[Optional] Settings for the watchdog.
TuningSettings tuning
[Optional] Low-level tuning
TODO: Configuration for the translation server status report file.
bool includeSessionGroupDetail
bool includeSessionDetail
Location information used as part of the PresenceDescriptor.
double longitude
Its the longitudinal position using the Signed degrees format (DDD.dddd) format. Valid range is -180 ...
double altitude
[Optional, Default: INVALID_LOCATION_VALUE] The altitude above sea level in meters.
uint32_t ts
[Read Only: Unix timestamp - Zulu/UTC] Indicates the timestamp that the location was recorded.
double latitude
Its the latitude position using the using the Signed degrees format (DDD.dddd). Valid range is -90 to...
double direction
[Optional, Default: INVALID_LOCATION_VALUE] Direction the endpoint is traveling in degrees....
double speed
[Optional, Default: INVALID_LOCATION_VALUE] The speed the endpoint is traveling at in meters per seco...
Defines settings for a named identity.
SecurityCertificate certificate
The identity certificate.
std::string name
The identity name.
std::string address
IP address.
NetworkAddressRestrictionList.
RestrictionType_t type
Type indicating how the elements are to be treated.
std::vector< NetworkAddressRxTx > elements
List of elements.
Custom Network Device Configuration.
std::string manufacturer
Device manufacturer (if any)
std::string model
Device mode (if any)
int deviceId
[Read Only] Unique device identifier assigned by Engage Engine at time of device creation.
std::string extra
Extra data provided by the platform (if any)
std::string type
Device type (if any)
std::string hardwareId
Device hardware ID (if any)
std::string serialNumber
Device serial number (if any)
std::string name
Name of the device assigned by the platform.
Network Transmit Options.
int ttl
[Optional, Default: 1] Time to live or hop limit is a mechanism that limits the lifespan or lifetime ...
TxPriority_t priority
[Optional, Default: priVoice] Transmission priority. This has meaning on some operating systems based...
Description of a packet capturer.
Configuration for Rallypoint peers.
int version
TODO: A version number for the domain configuration. Change this whenever you update your configurati...
std::string comments
Comments.
std::string id
An identifier useful for organizations that track different domain configurations by ID.
std::vector< RallypointPeer > peers
List of Rallypoint peers to connect to.
Device Power Information used as part of the PresenceDescriptor.
int state
[Optional, Default: 0] Is the current state that the power system is in.
int source
[Optional, Default: 0] Is the source the power is being delivered from
int level
[Optional, Default: 0] Is the current level of the battery or power system as a percentage....
Group Alias used as part of the PresenceDescriptor.
uint16_t status
Status flags for the user's participation on the group.
std::string alias
User's alias for the group.
std::string groupId
Group Id the alias is associated with.
Represents an endpoints presence properties. Used in engageUpdatePresenceDescriptor API and PFN_ENGAG...
Power power
[Optional, Default: see Power] Device power information like charging state, battery level,...
std::string custom
[Optional, Default: empty string] Custom string application can use of presence descriptor....
bool self
[Read Only] Indicates that this presence declaration was generated by the Engage Engine the applicati...
uint32_t nextUpdate
[Read Only, Unix timestamp - Zulu/UTC] Indicates the next time the presence descriptor will be sent.
std::vector< PresenceDescriptorGroupItem > groupAliases
[Read Only] List of group items associated with this presence descriptor.
Identity identity
[Optional, Default see Identity] Endpoint's identity information.
bool announceOnReceive
[Read Only] Indicates that the Engine will announce its PresenceDescriptor in response to this messag...
uint32_t ts
[Read Only, Unix timestamp - Zulu/UTC] Indicates the timestamp that the message was originally sent.
std::string comment
[Optional] No defined limit on size but the total size of the serialized JSON object must fit inside ...
Connectivity connectivity
[Optional, Default: see Connectivity] Device connectivity information like wifi/cellular,...
uint32_t disposition
[Optional] Indicates the users disposition
Location location
[Optional, Default: see Location] Location information
Describes how the Presence is configured for a group of type Group::gtPresence in Group::Type_t.
Format_t format
Format to be used to represent presence information.
Format_t
Presence format types enum.
bool reduceImmediacy
[Optional, Default: false] Instructs the Engage Engine reduce the immediacy of presence announcements...
bool listenOnly
Instructs the Engage Engine to not transmit presence descriptor.
int minIntervalSecs
[Optional, Default: 5] The minimum interval to send at to prevent network flooding
int intervalSecs
[Optional, Default: 30] The interval in seconds at which to send the presence descriptor on the prese...
Defines settings for Rallypoint advertising.
std::string interfaceName
The multicast network interface for mDNS.
std::string serviceName
[Optional, Default "_rallypoint._tcp.local."] The service name
std::string hostName
[Optional] This Rallypoint's DNS-SD host name
int port
[Default: RP port] The multicast network interface for mDNS
bool enabled
[Default: false] Advertising is enabled
int ttl
[Default: 60] TTL for service TTL
int rolloverSecs
Seconds between switching to a new target.
ConnectionStrategy_t
Connection strategy enum.
int transactionTimeoutMs
[Optional, Default: 10000] Default transaction time in milliseconds to any RP in the cluster
int connectionTimeoutSecs
[Optional, Default: 5] Default connection timeout in seconds to any RP in the cluster
std::vector< Rallypoint > rallypoints
List of Rallypoints.
ConnectionStrategy_t connectionStrategy
[Optional, Default: csRoundRobin] Specifies the connection strategy to be followed....
Detailed information for a rallypoint connection.
std::string internalId
Id.
float serverProcessingMs
Server processing time in milliseconds - used for roundtrip reports.
uint64_t msToNextConnectionAttempt
Milliseconds until next connection attempt.
Defines settings for Rallypoint extended group restrictions.
std::vector< StringRestrictionList > restrictions
Restrictions.
int transactionTimeoutMs
[Optional, Default 10000] Number of milliseconds that a transaction may take before the link is consi...
bool allowSelfSignedCertificate
[Optional, Default false] Allows the Rallypoint to accept self-signed certificates from the far-end
std::string sni
[Optional] A user-defined string sent as the Server Name Indication (SNI) field in the TLS setup....
std::vector< std::string > caCertificates
[Optional] A vector of certificates (raw content, file names, or certificate store elements) used to ...
std::string certificate
This is the X509 certificate to use for mutual authentication.
bool verifyPeer
[Optional, Default true] Indicates whether the connection peer is to be verified by checking the vali...
bool disableMessageSigning
[Optional, Default false] Indicates whether to forego ECSDA signing of control-plane messages.
NetworkAddress host
This is the host address for the Engine to connect to the RallyPoint service.
std::string additionalProtocols
[Optional, Default: ""] Additional protocols to use for the Rallypoint connection (only used for WebS...
RpProtocol_t protocol
[Optional, Default: rppTlsTcp] Specifies the protocol to be used for the Rallypoint connection....
std::string certificateKey
This is the private key used to generate the X509 certificate.
int connectionTimeoutSecs
[Optional, Default: 5] Connection timeout in seconds to the RP
TcpNetworkTxOptions tcpTxOptions
[Optional] Tx options for the TCP link
std::string path
[Optional, Default: ""] Path to use for the RP connection (only used for WebSocket)
RpProtocol_t
RP protocol enum.
SecurityCertificate certificate
Internal certificate detail.
std::string id
Internal ID.
std::string additionalProtocols
[Optional, Default: ""] Additional protocols to use for the peer (only used for WebSocket)
bool forceIsMeshLeaf
Internal enablement setting.
int connectionTimeoutSecs
[Optional, Default: 0 - OS platform default] Connection timeout in seconds to the peer
NetworkAddress host
Internal host detail.
std::string path
[Optional, Default: ""] Path to use for the peer (only used for WebSocket)
bool enabled
Internal enablement setting.
Rallypoint::RpProtocol_t protocol
[Optional, Default: Rallypoint::RpProtocol_t::rppTlsTcp] Protocol to use for the peer
Definition of a static group for Rallypoints.
NetworkAddress rx
The network address for receiving network traffic on.
std::string id
Unique identity for the group.
std::vector< NetworkAddress > additionalTx
[Optional] Vector of additional TX addresses .
NetworkAddress tx
The network address for transmitting network traffic to.
DirectionRestriction_t directionRestriction
[Optional] Restriction of direction of traffic flow
DirectionRestriction_t
Enum describing direction(s) for the reflector.
std::string multicastInterfaceName
[Optional] The name of the NIC on which to send and receive multicast traffic.
Defines a behavior for a Rallypoint peer roundtrip time.
BehaviorType_t
Enum describing behavior types.
@ btReportWarn
Report at level warning.
@ btReportError
Report at level error.
@ btReportInfo
Report at level info.
BehaviorType_t behavior
Specifies the streaming mode type (see BehaviorType_t).
uint32_t atOrAboveMs
Network address for listening.
Configuration for the Rallypoint server.
uint32_t maxSecurityLevel
[Optional, Default 0] Sets the maximum item security level that can be registered with the RP
bool forwardDiscoveredGroups
Enables automatic forwarding of discovered multicast traffic to peer Rallypoints.
std::string interfaceName
Name of the NIC to bind to for listening for incoming TCP connections.
NetworkTxOptions multicastTxOptions
Tx options for multicast.
bool disableMessageSigning
Set to true to forgo DSA signing of messages. Doing so is is a security risk but can be useful on CPU...
SecurityCertificate certificate
X.509 certificate and private key that identifies the Rallypoint.
std::string multicastInterfaceName
The name of the NIC on which to send and receive multicast traffic.
StringRestrictionList groupRestrictions
Group IDs to be restricted (inclusive or exclusive)
std::string peeringConfigurationFileName
Name of a file containing a JSON array of Rallypoint peers to connect to.
uint32_t sysFlags
[Optional, Default 0] Internal system flags
int listenPort
TCP port to listen on. Default is 7443.
FipsCryptoSettings fipsCrypto
[Optional] Settings for the FIPS crypto.
NetworkAddressRestrictionList multicastRestrictions
Multicasts to be restricted (inclusive or exclusive)
uint32_t normalTaskQueueBias
[Optional, Default 0] Sets the queue's normal task bias
PacketCapturer txCapture
Details for capture of transmitted packets
std::vector< RallypointReflector > staticReflectors
Vector of static groups.
bool enableLeafReflectionReverseSubscription
If enabled, causes a domain leaf to reverse-subscribe to a core node upon the core subscribing and a ...
std::string configurationCheckSignalName
Name to use for signalling a configuration check.
IpFamilyType_t ipFamily
[Optional, Default IpFamilyType_t::ifIp4] Address familiy to be used for listening
int peerRtTestIntervalMs
[Optional, Default: 60000] Milliseconds between sending round-trip test requests to peers
WatchdogSettings watchdog
[Optional] Settings for the Rallypoint's watchdog.
DiscoveryConfiguration discovery
Details discovery capabilities.
bool isMeshLeaf
Indicates whether this Rallypoint is part of a core domain or hangs off the periphery as a leaf node.
std::string certStorePasswordHex
Hex password for the certificate store (if any)
GroupRestrictionAccessPolicyType_t groupRestrictionAccessPolicyType
The policy employed to allow group registration.
RallypointServerStreamStatsExport streamStatsExport
Details for exporting stream statistics.
Licensing licensing
Licensing settings.
PacketCapturer rxCapture
Details for capture of received packets
std::vector< std::string > extraDomains
[Optional] List of additional domains that can be reached via this RP
uint32_t maxOutboundPeerConnectionIntervalDeltaSecs
[Optional, Default 15] Sets the delta value for the maximum number of seconds to delay when attemptin...
TuningSettings tuning
[Optional] Low-level tuning
RallypointAdvertisingSettings advertising
[Optional] Settings for advertising.
Featureset featureset
Optional feature set.
ExternalHealthCheckResponder externalHealthCheckResponder
Details concerning the Rallypoint's interaction with an external health-checker such as a load-balanc...
std::vector< RallypointExtendedGroupRestriction > extendedGroupRestrictions
Extended group restrictions.
int ioPools
Number of threading pools to create for network I/O. Default is -1 which creates 1 I/O pool per CPU c...
RallypointServerStatusReportConfiguration statusReport
Details for producing a status report.
std::vector< NamedIdentity > additionalIdentities
[Optional] List of additional named identities
IgmpSnooping igmpSnooping
IGMP snooping configuration.
RallypointServerLinkGraph linkGraph
Details for producing a Graphviz-compatible link graph.
RallypointServerLimits limits
Details for capacity limits and determining processing load.
PeeringConfiguration peeringConfiguration
Internal - not serialized.
std::string domainName
[Optional] This Rallypoint's domain name
bool allowMulticastForwarding
Allows traffic received on unicast links to be forwarded to the multicast network.
RallypointWebsocketSettings websocket
[Optional] Settings for websocket operation
std::string peeringConfigurationFileCommand
Command-line to execute that returns a JSON array of Rallypoint peers to connect to.
RallypointServerRouteMap routeMap
Details for producing a report containing the route map.
StreamIdPrivacyType_t streamIdPrivacyType
[Optional, default sptDefault] Modes for stream ID transformation.
bool allowPeerForwarding
Set to true to allow forwarding of packets received from other Rallypoints to all other Rallypoints....
TcpNetworkTxOptions tcpTxOptions
Tx options for TCP.
RallypointUdpStreaming udpStreaming
Optional configuration for high-performance UDP streaming.
bool forwardMulticastAddressing
Enables forwarding of multicast addressing to peer Rallypoints.
std::vector< RallypointRpRtTimingBehavior > peerRtBehaviors
[Optional] Array of behaviors for roundtrip times to peers
std::string id
A unqiue identifier for the Rallypoint.
NsmConfiguration nsm
[Optional] Settings for NSM.
bool disableLoopDetection
If true, turns off loop detection.
std::vector< std::string > blockedDomains
[Optional] List of domains that explictly MAY NOT connect to this RP
std::vector< std::string > allowedDomains
[Optional] List of domains that explicitly MAY connect to this RP
std::string certStoreFileName
Path to the certificate store.
int peeringConfigurationFileCheckSecs
Number of seconds between checks to see if the peering configuration has been updated....
Tls tls
Details concerning Transport Layer Security.
TODO: Configuration for Rallypoint limits.
uint32_t maxQOpsPerSec
Maximum number of queue operations per second (0 = unlimited)
uint32_t maxInboundBacklog
Maximum number of inbound backlog requests the Rallypoint will accept.
uint32_t normalPriorityQueueThreshold
Number of normal priority queue operations after which new connections will not be accepted.
uint32_t maxPeers
Maximum number of peers (0 = unlimited)
uint32_t maxTxBytesPerSec
Maximum number of bytes transmitted per second (0 = unlimited)
uint32_t maxTxPacketsPerSec
Maximum number of packets transmitted per second (0 = unlimited)
uint32_t maxRegisteredStreams
Maximum number of registered streams (0 = unlimited)
uint32_t maxClients
Maximum number of clients (0 = unlimited)
uint32_t maxMulticastReflectors
Maximum number of multicastReflectors (0 = unlimited)
uint32_t maxStreamPaths
Maximum number of bidirectional stream paths (0 = unlimited)
uint32_t lowPriorityQueueThreshold
Number of low priority queue operations after which new connections will not be accepted.
uint32_t maxRxBytesPerSec
Maximum number of bytes received per second (0 = unlimited)
uint32_t denyNewConnectionCpuThreshold
The CPU utilization threshold percentage (0-100) beyond which new connections are denied.
uint32_t maxRxPacketsPerSec
Maximum number of packets received per second (0 = unlimited)
uint32_t warnAtCpuThreshold
The CPU utilization threshold percentage (0-100) beyond which warnings are logged.
std::string leafRpStyling
std::string coreRpStyling
bool includeDigraphEnclosure
std::string clientStyling
TODO: Configuration for the Rallypoint status report file.
bool includePeerLinkDetails
bool includeClientLinkDetails
bool resetCountersAfterExport
ExportFormat_t
Enum describing format(s) for the stream stats export.
std::string namedPipePath
Streaming configuration for RP clients.
int listenPort
UDP port to listen on. Default is 7444.
TxPriority_t priority
[Optional, Default: priVoice] Transmission priority. This has meaning on some operating systems based...
RallypointUdpStreamingIpvX ipv4
IPv4
bool enabled
[Optional, Default true] If true, enables UDP streaming unless turned off on a per-family basis.
CryptoType_t cryptoType
[Optional, Default ctSharedKeyAes256FullIv] The crypto method to be used
int ttl
[Optional, Default: 64] Time to live or hop limit.
CryptoType_t
Enum describing UDP streaming modes.
int keepaliveIntervalSecs
[Optional, Default: 15] Interval (seconds) at which to send UDP keepalives
RallypointUdpStreamingIpvX ipv6
IPv6.
Streaming configuration for RP clients.
bool enabled
[Optional, Default true] If true, enables UDP streaming for vX.
NetworkAddress external
Network address for external entities to transmit to. Defaults to the address of the local interface ...
Defines settings for Rallypoint websockets functionality.
int listenPort
Listen port (TCP). Default is 8443.
SecurityCertificate certificate
Certificate to be used for WebSockets.
bool requireTls
[Default: false] Indicates whether TLS is required
bool enabled
[Default: false] Websocket is enabled
bool requireClientCertificate
[Default: false] Indicates whether the client is required to present a certificate
Options for Ranger packets.
int count
[Optional, Default: 5] Number of ranger packets to send when a new interval starts
int hangTimerSecs
[Optional, Default: -1] Number of seconds since last packet transmission before 'count' packets are s...
Helper class for serializing and deserializing the RiffDescriptor JSON.
CertificateDescriptor certDescriptor
[Optional] X.509 certificate parsed into a CertificateDescriptor object.
std::string meta
[Optional] Meta data associated with the file - typically a stringified JSON object.
bool verified
True if the ECDSA signature is verified.
int channels
Number of audio channels.
std::string signature
[Optional] ECDSA signature
std::string certPem
[Optional] X.509 certificate in PEM format used to sign the RIFF file.
int sampleCount
Number of audio samples.
std::string file
Name of the RIFF file.
std::string name
Name of the CODEC.
int engageType
An integer representing the codec type.
int rtpPayloadType
The RTP payload type identifier.
RtpPayloadTypeTranslation.
uint16_t engage
The payload type used by Engage.
uint16_t external
The payload type used by the external entity.
Configuration for the optional RtpProfile.
JitterMode_t
Jitter buffer mode.
int signalledInboundProcessorInactivityMs
[Optional, Default: inboundProcessorInactivityMs * 4] The number of milliseconds of RTP inactivity on...
int jitterUnderrunReductionAger
[Optional, Default: 100] Number of jitter buffer operations after which to reduce any underrun
int jitterMinMs
[Optional, Default: 100] Low-water mark for jitter buffers that are in a buffering state.
int jitterMaxFactor
[Optional, Default: 8] The factor by which to multiply the jitter buffer's active low-water to determ...
int inboundProcessorInactivityMs
[Optional, Default: 500] The number of milliseconds of RTP inactivity before heuristically determinin...
JitterMode_t mode
[Optional, Default: jmStandard] Specifies the operation mode (see JitterMode_t).
int jitterForceTrimAtMs
[Optional, Default: 0] Forces trimming of the jitter buffer if the queue length is greater (and not z...
int latePacketSequenceRange
[Optional, Default: 5] The delta in RTP sequence numbers in order to heuristically determine the star...
int jitterMaxExceededClipHangMs
[Optional, Default: 1500] Number of milliseconds for which the jitter buffer may exceed max before cl...
int jitterTrimPercentage
[Optional, Default: 10] The percentage of the overall jitter buffer sample count to trim when potenti...
int jitterMaxTrimMs
[Optional, Default: 250] Maximum number of milliseconds to be trimmed from a jitter buffer at any one...
int jitterMaxMs
[Optional, Default: 10000] Maximum number of milliseconds allowed in the queue
int latePacketTimestampRangeMs
[Optional, Default: 500] The delta in milliseconds in order to heuristically determine the start of a...
int jitterMaxExceededClipPerc
[Optional, Default: 10] Percentage by which maximum number of samples in the queue exceeded computed ...
int zombieLifetimeMs
[Optional, Default: 15000] The number of milliseconds that a "zombified" RTP processor is kept around...
int rtcpPresenceTimeoutMs
[Optional, Default: 45000] Timeout for RTCP presence.
int jitterUnderrunReductionThresholdMs
[Optional, Default: 1500] Number of milliseconds of error-free operations in a jitter buffer before t...
Configuration for a secure signature.
std::string signature
Contains the signature.
std::string certificate
Contains the PEM-formatted text of the certificate.
Configuration for a Security Certificate used in various configurations.
std::string key
As for above but for certificate's private key.
std::string certificate
Contains the PEM-formatted text of the certificate, OR, a reference to a PEM file denoted by "@file:/...
std::string alias
[Optional] An alias
std::string nodeId
[Optional] A node ID
RestrictionType_t type
Type indicating how the elements are to be treated.
std::vector< std::string > elements
List of elements.
RestrictionElementType_t elementsType
Type indicating what kind of data each element contains.
std::string nodeId
A unique identifier for the asset.
Group group
Details for the talkgroup.
Network Transmit Options for TCP.
Parameters for querying the group timeline.
bool onlyCommitted
Include only committed (not in-progress) events.
uint64_t startedOnOrAfter
Include events that started on or after this UNIX millisecond timestamp.
int onlyType
Include events for this type.
long maxCount
Maximum number of records to return.
uint64_t endedOnOrBefore
Include events that ended on or after this UNIX millisecond timestamp.
std::string sql
Ignore all other settings for SQL construction and use this query string instead.
bool mostRecentFirst
Sorted results with most recent timestamp first.
std::string onlyNodeId
Include events for this transmitter node ID.
int onlyDirection
Include events for this direction.
int onlyTxId
Include events for this transmission ID.
std::string onlyAlias
Include events for this transmitter alias.
TODO: Transport Security Layer (TLS) settings.
bool verifyPeers
[Optional, Default: true] When true, checks the far-end certificate validity and Engage-specific TLS ...
StringRestrictionList subjectRestrictions
[NOT USED AT THIS TIME]
std::vector< std::string > caCertificates
[Optional] Array of CA certificates (PEM or "@" file/certstore references) to be used to validate far...
StringRestrictionList issuerRestrictions
[NOT USED AT THIS TIME]
bool allowSelfSignedCertificates
[Optional, Default: false] When true, accepts far-end certificates that are self-signed.
std::vector< std::string > crlSerials
[Optional] Array of serial numbers certificates that have been revoked
Translation configuration.
std::vector< TranslationSession > sessions
Array of sessions in the configuration.
std::vector< Group > groups
Array of groups in the configuration.
Translation session settings.
std::vector< std::string > groups
List of group IDs to be included in the session.
bool enabled
[Optional, Default: true] Enable the session
Description of a transport impairment.
uint32_t maxActiveBlobObjects
[Optional, Default 0 (no max)] Maximum number of blob objects allowed to be active
uint32_t maxActiveRtpProcessors
[Optional, Default 0 (no max)] Maximum number concurrent RTP processors
uint32_t maxPooledBufferMb
[Optional, Default 0 (no max)] Maximum number of buffer bytes allowed to be pooled
uint32_t maxActiveBufferObjects
[Optional, Default 0 (no max)] Maximum number of buffer objects allowed to be active
uint32_t maxPooledBufferObjects
[Optional, Default 0 (no max)] Maximum number of buffer objects allowed to be pooled
uint32_t maxPooledRtpObjects
[Optional, Default 0 (no max)] Maximum number of RTP objects allowed to be pooled
uint32_t maxPooledBlobMb
[Optional, Default 0 (no max)] Maximum number of blob bytes allowed to be pooled
uint32_t maxPooledRtpMb
[Optional, Default 0 (no max)] Maximum number of RTP bytes allowed to be pooled
uint32_t maxActiveRtpObjects
[Optional, Default 0 (no max)] Maximum number of RTP objects allowed to be active
uint32_t maxPooledBlobObjects
[Optional, Default 0 (no max)] Maximum number of blob objects allowed to be pooled
Configuration for the audio transmit properties for a group.
int startTxNotifications
[Optional, Default: 5] Number of start TX notifications to send when TX is about to begin.
int framingMs
[Optional, Default: 60] Audio sample framing size in milliseconds.
int maxTxSecs
[Optional, Default: 0] Maximum number of seconds the Engine will transmit for.
uint32_t internalKey
[INTERNAL] The Engine-assigned key for the codec
bool enabled
[Optional, Default: true] Audio transmission is enabled
bool fdx
[Optional, Default: false] Indicates if full duplex audio is supported.
int initialHeaderBurst
[Optional, Default: 5] Number of headers to send at the beginning of a talk burst.
bool resetRtpOnTx
[Optional, Default: true] Resets RTP counters on each new transmission.
bool dtx
[Optional, Default: false] Support discontinuous transmission on those CODECs that allow it
std::string encoderName
[Optional] The name of the external codec - overrides encoder
TxCodec_t encoder
[Optional, Default: ctOpus8000] Specifies the Codec Type to use for the transmission....
int blockCount
[Optional, Default: 0] If >0, derives framingMs based on the encoder's internal operation
int smoothedHangTimeMs
[Optional, Default: 0] Hang timer for ongoing TX - only applicable if enableSmoothing is true
int customRtpPayloadType
[Optional, Default: -1] The custom RTP payload type to use for transmission. A value of -1 causes the...
bool noHdrExt
[Optional, Default: false] Set to true whether to disable header extensions.
bool enableSmoothing
[Optional, Default: true] Smooth input audio
int trailingHeaderBurst
[Optional, Default: 5] Number of headers to send at the conclusion of a talk burst.
int extensionSendInterval
[Optional, Default: 10] The number of packets when to periodically send the header extension.
TxCodec_t
Codec Types enum.
Optional audio streaming from a URI for engageBeginGroupTxAdvanced.
std::string uri
URI for the file.
int repeatCount
[Optional, Default: 0] Number of times to repeat
Voice Activity Detection settings.
bool enabled
[Optional, Default: false] Enable VAD
Mode_t mode
[Optional, Default: vamDefault] Specifies VAD mode. See Mode_t for all modes
Voice to voice session settings.
std::vector< std::string > groups
List of group IDs to be included in the session.
bool enabled
[Optional, Default: true] Enable the session
int intervalMs
[Optional, Default: 5000] Interval at which checks are made.
int hangDetectionMs
[Optional, Default: 2000] Number of milliseconds that must pass before a hang is assumed.
int slowExecutionThresholdMs
[Optional, Default: 100] Maximum number of milliseconds that a task may take before being considered ...
bool abortOnHang
[Optional, Default: true] If true, aborts the process if a hang is detected.
bool enabled
[Optional, Default: true] Enables/disables a watchdog.
static ENGAGE_IGNORE_COMPILER_UNUSED_WARNING const char * OID_RTS_PEM
Rally Tactical Systems' PEN as assigned by IANA.
static ENGAGE_IGNORE_COMPILER_UNUSED_WARNING const char * OID_RTS_CERT_SUBJ_ACCESS_TAGS
The link to the Rallypoint is down.
static ENGAGE_IGNORE_COMPILER_UNUSED_WARNING const char * GROUP_DISCONNECTED_REASON_EXCLUDED_SERIAL
The Rallypoint denied the registration request because the far-end's certificate serial number has be...
static ENGAGE_IGNORE_COMPILER_UNUSED_WARNING const char * GROUP_DISCONNECTED_REASON_SECURITY_CLASSIFICATION_LEVEL_TOO_HIGH
The Rallypoint has denied the registration because the registration is for a security level not allow...
static ENGAGE_IGNORE_COMPILER_UNUSED_WARNING const char * GROUP_DISCONNECTED_REASON_ON_BLACKLIST
The Rallypoint denied the registration request because the far-end does appears in blackist criteria.
static ENGAGE_IGNORE_COMPILER_UNUSED_WARNING const char * GROUP_DISCONNECTED_REASON_EXCLUDED_FINGERPRINT
The Rallypoint denied the registration request because the far-end's certificate fingerprint has been...
static ENGAGE_IGNORE_COMPILER_UNUSED_WARNING const char * GROUP_DISCONNECTED_REASON_NO_ISSUER
The Rallypoint denied the registration request because the far-end's certificate does not have an an ...
static ENGAGE_IGNORE_COMPILER_UNUSED_WARNING const char * GROUP_DISCONNECTED_REASON_GENERAL_DENIAL
The Rallypoint has denied the registration for no specific reason.
static ENGAGE_IGNORE_COMPILER_UNUSED_WARNING const char * GROUP_DISCONNECTED_REASON_NO_ACCESS_TAG
The Rallypoint denied the registration request because the far-end's certificate does not have an acc...
static ENGAGE_IGNORE_COMPILER_UNUSED_WARNING const char * GROUP_DISCONNECTED_REASON_NO_SUBJECT
The Rallypoint denied the registration request because the far-end's certificate does not have an an ...
static ENGAGE_IGNORE_COMPILER_UNUSED_WARNING const char * GROUP_DISCONNECTED_REASON_NOT_ALLOWED
The Rallypoint is not accepting registration for the group at this time.
static ENGAGE_IGNORE_COMPILER_UNUSED_WARNING const char * GROUP_DISCONNECTED_REASON_EXCLUDED_SUBJECT
The Rallypoint denied the registration request because the far-end's certificate subject has been exc...
static ENGAGE_IGNORE_COMPILER_UNUSED_WARNING const char * GROUP_DISCONNECTED_REASON_NO_LINK
The link to the Rallypoint is down.
static ENGAGE_IGNORE_COMPILER_UNUSED_WARNING const char * GROUP_DISCONNECTED_REASON_NO_SERIAL
The Rallypoint denied the registration request because the far-end's certificate does not have an an ...
static ENGAGE_IGNORE_COMPILER_UNUSED_WARNING const char * GROUP_DISCONNECTED_REASON_NO_FINGERPRINT
The Rallypoint denied the registration request because the far-end's certificate does not have an an ...
static ENGAGE_IGNORE_COMPILER_UNUSED_WARNING const char * GROUP_DISCONNECTED_REASON_EXCLUDED_ISSUER
The Rallypoint denied the registration request because the far-end's certificate issuer has been excl...
static ENGAGE_IGNORE_COMPILER_UNUSED_WARNING const char * GROUP_DISCONNECTED_REASON_EXCLUDED_ACCESS_TAG
The Rallypoint denied the registration request because the far-end's certificate does not have an acc...
static ENGAGE_IGNORE_COMPILER_UNUSED_WARNING const char * GROUP_DISCONNECTED_REASON_UNREGISTERED
The group has been gracefully unregistered from the Rallypoint.
static ENGAGE_IGNORE_COMPILER_UNUSED_WARNING const char * GROUP_DISCONNECTED_REASON_NO_REAON
No particular reason was provided.
static ENGAGE_IGNORE_COMPILER_UNUSED_WARNING const char * GROUP_DISCONNECTED_REASON_NOT_ON_WHITELIST
The Rallypoint denied the registration request because the far-end does not appear in any whitelist c...
static ENGAGE_IGNORE_COMPILER_UNUSED_WARNING const char * GROUP_SOURCE_ENGAGE_MAGELLAN_DOMO
The source is Domo Tactical via Magellan discovery.
static ENGAGE_IGNORE_COMPILER_UNUSED_WARNING const char * GROUP_SOURCE_ENGAGE_MAGELLAN_CISTECH
The source is CISTECH via Magellan discovery.
static ENGAGE_IGNORE_COMPILER_UNUSED_WARNING const char * GROUP_SOURCE_ENGAGE_MAGELLAN_CORE
The source is a Magellan-capable entity.
static ENGAGE_IGNORE_COMPILER_UNUSED_WARNING const char * GROUP_SOURCE_ENGAGE_INTERNAL
Internal to Engage.
static ENGAGE_IGNORE_COMPILER_UNUSED_WARNING const char * GROUP_SOURCE_ENGAGE_MAGELLAN_TAIT
The source is Tait via Magellan discovery.
static ENGAGE_IGNORE_COMPILER_UNUSED_WARNING const char * GROUP_SOURCE_ENGAGE_MAGELLAN_TRELLISWARE
The source is Trellisware via Magellan discovery.
static ENGAGE_IGNORE_COMPILER_UNUSED_WARNING const char * GROUP_SOURCE_ENGAGE_MAGELLAN_SILVUS
The source is Silvus via Magellan discovery.
static ENGAGE_IGNORE_COMPILER_UNUSED_WARNING const char * GROUP_SOURCE_ENGAGE_MAGELLAN_VOCALITY
The source is Vocality via Magellan discovery.
static ENGAGE_IGNORE_COMPILER_UNUSED_WARNING const char * GROUP_SOURCE_ENGAGE_MAGELLAN_PERSISTENT
The source is Persistent Systems via Magellan discovery.
static ENGAGE_IGNORE_COMPILER_UNUSED_WARNING const char * GROUP_SOURCE_ENGAGE_MAGELLAN_KENWOOD
The source is Kenwood via Magellan discovery.
static const uint8_t ENGAGE_DEFAULT_BLOB_RTP_PAYLOAD_TYPE
The default RTP payload type Engage uses for RTP blob messaging.