Line data Source code
1 : /*
2 : * Copyright (C) 2004-2026 Savoir-faire Linux Inc.
3 : *
4 : * This program is free software: you can redistribute it and/or modify
5 : * it under the terms of the GNU General Public License as published by
6 : * the Free Software Foundation, either version 3 of the License, or
7 : * (at your option) any later version.
8 : *
9 : * This program is distributed in the hope that it will be useful,
10 : * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 : * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 : * GNU General Public License for more details.
13 : *
14 : * You should have received a copy of the GNU General Public License
15 : * along with this program. If not, see <https://www.gnu.org/licenses/>.
16 : */
17 : #include "jamiaccount_config.h"
18 : #include "account_const.h"
19 : #include "account_schema.h"
20 : #include "configkeys.h"
21 : #include "fileutils.h"
22 : #include "config/account_config_utils.h"
23 :
24 : namespace jami {
25 :
26 : namespace Conf {
27 : constexpr const char* const TLS_KEY = "tls";
28 : constexpr const char* CERTIFICATE_KEY = "certificate";
29 : constexpr const char* CALIST_KEY = "calist";
30 : const char* const TLS_PASSWORD_KEY = "password";
31 : const char* const PRIVATE_KEY_KEY = "privateKey";
32 : } // namespace Conf
33 :
34 : static const JamiAccountConfig DEFAULT_CONFIG {};
35 :
36 : void
37 2281 : JamiAccountConfig::serialize(YAML::Emitter& out) const
38 : {
39 2281 : out << YAML::BeginMap;
40 2281 : SipAccountBaseConfig::serializeDiff(out, DEFAULT_CONFIG);
41 2281 : SERIALIZE_CONFIG(Conf::DHT_PORT_KEY, dhtPort);
42 2281 : SERIALIZE_CONFIG(Conf::DHT_PUBLIC_IN_CALLS, allowPublicIncoming);
43 2281 : SERIALIZE_CONFIG(Conf::DHT_ALLOW_PEERS_FROM_HISTORY, allowPeersFromHistory);
44 2281 : SERIALIZE_CONFIG(Conf::DHT_ALLOW_PEERS_FROM_CONTACT, allowPeersFromContact);
45 2281 : SERIALIZE_CONFIG(Conf::DHT_ALLOW_PEERS_FROM_TRUSTED, allowPeersFromTrusted);
46 2281 : SERIALIZE_CONFIG(libjami::Account::ConfProperties::DHT_PEER_DISCOVERY, dhtPeerDiscovery);
47 2281 : SERIALIZE_CONFIG(libjami::Account::ConfProperties::ACCOUNT_PEER_DISCOVERY, accountPeerDiscovery);
48 2281 : SERIALIZE_CONFIG(libjami::Account::ConfProperties::ACCOUNT_PUBLISH, accountPublish);
49 2281 : SERIALIZE_CONFIG(Conf::PROXY_ENABLED_KEY, proxyEnabled);
50 2281 : SERIALIZE_CONFIG(Conf::PROXY_SERVER_KEY, proxyServer);
51 2281 : SERIALIZE_CONFIG(libjami::Account::ConfProperties::PROXY_LIST_ENABLED, proxyListEnabled);
52 2281 : SERIALIZE_CONFIG(libjami::Account::ConfProperties::DHT_PROXY_LIST_URL, proxyListUrl);
53 2281 : SERIALIZE_CONFIG(libjami::Account::ConfProperties::DHT_PROXY_SERVER_ENABLED, dhtProxyServerEnabled);
54 2281 : SERIALIZE_CONFIG(libjami::Account::ConfProperties::DHT_PROXY_SERVER_PORT, dhtProxyServerPort);
55 2281 : SERIALIZE_CONFIG(libjami::Account::ConfProperties::Nameserver::URI, nameServer);
56 2281 : SERIALIZE_CONFIG(libjami::Account::VolatileProperties::REGISTERED_NAME, registeredName);
57 2281 : SERIALIZE_PATH(libjami::Account::ConfProperties::ARCHIVE_PATH, archivePath);
58 2281 : SERIALIZE_CONFIG(libjami::Account::ConfProperties::ARCHIVE_HAS_PASSWORD, archiveHasPassword);
59 2281 : SERIALIZE_CONFIG(libjami::Account::ConfProperties::DEVICE_NAME, deviceName);
60 2281 : SERIALIZE_CONFIG(libjami::Account::ConfProperties::MANAGER_URI, managerUri);
61 2281 : SERIALIZE_CONFIG(libjami::Account::ConfProperties::MANAGER_USERNAME, managerUsername);
62 2281 : SERIALIZE_CONFIG(libjami::Account::ConfProperties::DHT::PUBLIC_IN_CALLS, dhtPublicInCalls);
63 :
64 2281 : out << YAML::Key << Conf::RING_ACCOUNT_RECEIPT << YAML::Value << receipt;
65 2281 : if (receiptSignature.size() > 0)
66 : out << YAML::Key << Conf::RING_ACCOUNT_RECEIPT_SIG << YAML::Value
67 775 : << YAML::Binary(receiptSignature.data(), receiptSignature.size());
68 :
69 : // tls submap
70 2281 : out << YAML::Key << Conf::TLS_KEY << YAML::Value << YAML::BeginMap;
71 2281 : SERIALIZE_PATH(Conf::CALIST_KEY, tlsCaListFile);
72 2281 : SERIALIZE_PATH(Conf::CERTIFICATE_KEY, tlsCertificateFile);
73 2281 : SERIALIZE_CONFIG(Conf::TLS_PASSWORD_KEY, tlsPassword);
74 2281 : SERIALIZE_PATH(Conf::PRIVATE_KEY_KEY, tlsPrivateKeyFile);
75 2281 : out << YAML::EndMap;
76 :
77 2281 : out << YAML::EndMap;
78 2281 : }
79 :
80 : void
81 0 : JamiAccountConfig::unserialize(const YAML::Node& node)
82 : {
83 : using yaml_utils::parseValueOptional;
84 : using yaml_utils::parsePathOptional;
85 0 : SipAccountBaseConfig::unserialize(node);
86 :
87 : // get tls submap
88 : try {
89 0 : const auto& tlsMap = node[Conf::TLS_KEY];
90 0 : parsePathOptional(tlsMap, Conf::CERTIFICATE_KEY, tlsCertificateFile, path);
91 0 : parsePathOptional(tlsMap, Conf::CALIST_KEY, tlsCaListFile, path);
92 0 : parseValueOptional(tlsMap, Conf::TLS_PASSWORD_KEY, tlsPassword);
93 0 : parsePathOptional(tlsMap, Conf::PRIVATE_KEY_KEY, tlsPrivateKeyFile, path);
94 0 : } catch (...) {
95 0 : }
96 0 : parseValueOptional(node, Conf::DHT_PORT_KEY, dhtPort);
97 0 : parseValueOptional(node, Conf::DHT_ALLOW_PEERS_FROM_HISTORY, allowPeersFromHistory);
98 0 : parseValueOptional(node, Conf::DHT_ALLOW_PEERS_FROM_CONTACT, allowPeersFromContact);
99 0 : parseValueOptional(node, Conf::DHT_ALLOW_PEERS_FROM_TRUSTED, allowPeersFromTrusted);
100 :
101 0 : parseValueOptional(node, Conf::PROXY_ENABLED_KEY, proxyEnabled);
102 0 : parseValueOptional(node, Conf::PROXY_SERVER_KEY, proxyServer);
103 0 : parseValueOptional(node, libjami::Account::ConfProperties::DHT_PROXY_LIST_URL, proxyListUrl);
104 0 : parseValueOptional(node, libjami::Account::ConfProperties::PROXY_LIST_ENABLED, proxyListEnabled);
105 :
106 0 : parseValueOptional(node, libjami::Account::ConfProperties::DHT_PROXY_SERVER_ENABLED,
107 0 : dhtProxyServerEnabled);
108 0 : parseValueOptional(node, libjami::Account::ConfProperties::DHT_PROXY_SERVER_PORT,
109 0 : dhtProxyServerPort);
110 :
111 0 : parseValueOptional(node, libjami::Account::ConfProperties::DEVICE_NAME, deviceName);
112 0 : parseValueOptional(node, libjami::Account::ConfProperties::MANAGER_URI, managerUri);
113 0 : parseValueOptional(node, libjami::Account::ConfProperties::MANAGER_USERNAME, managerUsername);
114 0 : parseValueOptional(node, libjami::Account::ConfProperties::DHT::PUBLIC_IN_CALLS, dhtPublicInCalls);
115 :
116 0 : parsePathOptional(node, libjami::Account::ConfProperties::ARCHIVE_PATH, archivePath, path);
117 0 : parseValueOptional(node, libjami::Account::ConfProperties::ARCHIVE_HAS_PASSWORD, archiveHasPassword);
118 :
119 : try {
120 0 : parseValueOptional(node, Conf::RING_ACCOUNT_RECEIPT, receipt);
121 0 : auto receipt_sig = node[Conf::RING_ACCOUNT_RECEIPT_SIG].as<YAML::Binary>();
122 0 : receiptSignature = {receipt_sig.data(), receipt_sig.data() + receipt_sig.size()};
123 0 : } catch (const std::exception& e) {
124 0 : JAMI_WARN("Unable to read receipt: %s", e.what());
125 0 : }
126 :
127 0 : parseValueOptional(node, libjami::Account::ConfProperties::DHT_PEER_DISCOVERY, dhtPeerDiscovery);
128 0 : parseValueOptional(node, libjami::Account::ConfProperties::ACCOUNT_PEER_DISCOVERY, accountPeerDiscovery);
129 0 : parseValueOptional(node, libjami::Account::ConfProperties::ACCOUNT_PUBLISH, accountPublish);
130 0 : parseValueOptional(node, libjami::Account::ConfProperties::Nameserver::URI, nameServer);
131 0 : parseValueOptional(node, libjami::Account::VolatileProperties::REGISTERED_NAME, registeredName);
132 0 : parseValueOptional(node, Conf::DHT_PUBLIC_IN_CALLS, allowPublicIncoming);
133 0 : }
134 :
135 : std::map<std::string, std::string>
136 538 : JamiAccountConfig::toMap() const
137 : {
138 538 : std::map<std::string, std::string> a = SipAccountBaseConfig::toMap();
139 538 : a.emplace(Conf::CONFIG_DHT_PORT, std::to_string(dhtPort));
140 538 : a.emplace(Conf::CONFIG_DHT_PUBLIC_IN_CALLS, allowPublicIncoming ? TRUE_STR : FALSE_STR);
141 538 : a.emplace(libjami::Account::ConfProperties::DHT_PEER_DISCOVERY, dhtPeerDiscovery ? TRUE_STR : FALSE_STR);
142 538 : a.emplace(libjami::Account::ConfProperties::ACCOUNT_PEER_DISCOVERY, accountPeerDiscovery ? TRUE_STR : FALSE_STR);
143 538 : a.emplace(libjami::Account::ConfProperties::ACCOUNT_PUBLISH, accountPublish ? TRUE_STR : FALSE_STR);
144 538 : a.emplace(libjami::Account::ConfProperties::DEVICE_NAME, deviceName);
145 538 : a.emplace(libjami::Account::ConfProperties::Presence::SUPPORT_SUBSCRIBE, TRUE_STR);
146 538 : if (not archivePath.empty() or not managerUri.empty())
147 538 : a.emplace(libjami::Account::ConfProperties::ARCHIVE_HAS_PASSWORD, archiveHasPassword ? TRUE_STR : FALSE_STR);
148 :
149 538 : a.emplace(Conf::CONFIG_TLS_CA_LIST_FILE, fileutils::getFullPath(path, tlsCaListFile).string());
150 538 : a.emplace(Conf::CONFIG_TLS_CERTIFICATE_FILE, fileutils::getFullPath(path, tlsCertificateFile).string());
151 538 : a.emplace(Conf::CONFIG_TLS_PRIVATE_KEY_FILE, fileutils::getFullPath(path, tlsPrivateKeyFile).string());
152 538 : a.emplace(Conf::CONFIG_TLS_PASSWORD, tlsPassword);
153 538 : a.emplace(libjami::Account::ConfProperties::ALLOW_CERT_FROM_HISTORY, allowPeersFromHistory ? TRUE_STR : FALSE_STR);
154 538 : a.emplace(libjami::Account::ConfProperties::ALLOW_CERT_FROM_CONTACT, allowPeersFromContact ? TRUE_STR : FALSE_STR);
155 538 : a.emplace(libjami::Account::ConfProperties::ALLOW_CERT_FROM_TRUSTED, allowPeersFromTrusted ? TRUE_STR : FALSE_STR);
156 538 : a.emplace(libjami::Account::ConfProperties::PROXY_ENABLED, proxyEnabled ? TRUE_STR : FALSE_STR);
157 538 : a.emplace(libjami::Account::ConfProperties::PROXY_LIST_ENABLED, proxyListEnabled ? TRUE_STR : FALSE_STR);
158 538 : a.emplace(libjami::Account::ConfProperties::PROXY_SERVER, proxyServer);
159 538 : a.emplace(libjami::Account::ConfProperties::DHT_PROXY_LIST_URL, proxyListUrl);
160 :
161 538 : a.emplace(libjami::Account::ConfProperties::DHT_PROXY_SERVER_ENABLED,
162 538 : dhtProxyServerEnabled ? TRUE_STR : FALSE_STR);
163 538 : a.emplace(libjami::Account::ConfProperties::DHT_PROXY_SERVER_PORT,
164 1076 : std::to_string(dhtProxyServerPort));
165 :
166 538 : a.emplace(libjami::Account::ConfProperties::MANAGER_URI, managerUri);
167 538 : a.emplace(libjami::Account::ConfProperties::MANAGER_USERNAME, managerUsername);
168 538 : a.emplace(libjami::Account::ConfProperties::DHT::PUBLIC_IN_CALLS, dhtPublicInCalls ? TRUE_STR : FALSE_STR);
169 538 : a.emplace(libjami::Account::ConfProperties::Nameserver::URI, nameServer);
170 538 : return a;
171 0 : }
172 :
173 : void
174 1380 : JamiAccountConfig::fromMap(const std::map<std::string, std::string>& details)
175 : {
176 1380 : SipAccountBaseConfig::fromMap(details);
177 : // TLS
178 1380 : parsePath(details, Conf::CONFIG_TLS_CA_LIST_FILE, tlsCaListFile, path);
179 1380 : parsePath(details, Conf::CONFIG_TLS_CERTIFICATE_FILE, tlsCertificateFile, path);
180 1380 : parsePath(details, Conf::CONFIG_TLS_PRIVATE_KEY_FILE, tlsPrivateKeyFile, path);
181 1380 : parseString(details, Conf::CONFIG_TLS_PASSWORD, tlsPassword);
182 :
183 1380 : if (hostname.empty())
184 0 : hostname = DHT_DEFAULT_BOOTSTRAP;
185 1380 : parseString(details, libjami::Account::ConfProperties::BOOTSTRAP_LIST_URL, bootstrapListUrl);
186 1380 : parseInt(details, Conf::CONFIG_DHT_PORT, dhtPort);
187 1380 : parseBool(details, Conf::CONFIG_DHT_PUBLIC_IN_CALLS, allowPublicIncoming);
188 1380 : parseBool(details, libjami::Account::ConfProperties::DHT_PEER_DISCOVERY, dhtPeerDiscovery);
189 1380 : parseBool(details, libjami::Account::ConfProperties::ACCOUNT_PEER_DISCOVERY, accountPeerDiscovery);
190 1380 : parseBool(details, libjami::Account::ConfProperties::ACCOUNT_PUBLISH, accountPublish);
191 1380 : parseBool(details, libjami::Account::ConfProperties::ALLOW_CERT_FROM_HISTORY, allowPeersFromHistory);
192 1380 : parseBool(details, libjami::Account::ConfProperties::ALLOW_CERT_FROM_CONTACT, allowPeersFromContact);
193 1380 : parseBool(details, libjami::Account::ConfProperties::ALLOW_CERT_FROM_TRUSTED, allowPeersFromTrusted);
194 :
195 1380 : parseString(details, libjami::Account::ConfProperties::MANAGER_URI, managerUri);
196 1380 : parseString(details, libjami::Account::ConfProperties::MANAGER_USERNAME, managerUsername);
197 1380 : parseBool(details, libjami::Account::ConfProperties::DHT::PUBLIC_IN_CALLS, dhtPublicInCalls);
198 : // parseString(details, libjami::Account::ConfProperties::USERNAME, username);
199 :
200 1380 : parseString(details, libjami::Account::ConfProperties::ARCHIVE_PASSWORD, credentials.archive_password);
201 1380 : parseString(details, libjami::Account::ConfProperties::ARCHIVE_PASSWORD_SCHEME, credentials.archive_password_scheme);
202 1380 : parseString(details, libjami::Account::ConfProperties::ARCHIVE_PATH, credentials.archive_path);
203 1380 : parseString(details, libjami::Account::ConfProperties::DEVICE_NAME, deviceName);
204 1380 : parseString(details, libjami::Account::ConfProperties::ARCHIVE_URL, archive_url);
205 :
206 1380 : auto oldProxyServer = proxyServer, oldProxyServerList = proxyListUrl;
207 1380 : parseString(details, libjami::Account::ConfProperties::DHT_PROXY_LIST_URL, proxyListUrl);
208 1380 : parseBool(details, libjami::Account::ConfProperties::PROXY_ENABLED, proxyEnabled);
209 1380 : parseBool(details, libjami::Account::ConfProperties::PROXY_LIST_ENABLED, proxyListEnabled);
210 1380 : parseString(details, libjami::Account::ConfProperties::PROXY_SERVER, proxyServer);
211 :
212 1380 : parseBool(details,
213 : libjami::Account::ConfProperties::DHT_PROXY_SERVER_ENABLED,
214 1380 : dhtProxyServerEnabled);
215 1380 : parseInt(details,
216 : libjami::Account::ConfProperties::DHT_PROXY_SERVER_PORT,
217 1380 : dhtProxyServerPort);
218 :
219 1380 : parseString(details, libjami::Account::ConfProperties::UI_CUSTOMIZATION, uiCustomization);
220 1380 : if (not managerUri.empty() and managerUri.rfind("http", 0) != 0) {
221 0 : managerUri = "https://" + managerUri;
222 : }
223 :
224 1380 : parseString(details, libjami::Account::ConfProperties::Nameserver::URI, nameServer);
225 1380 : }
226 :
227 : } // namespace jami
|