LCOV - code coverage report
Current view: top level - foo/src/jamidht - jamiaccount_config.cpp (source / functions) Hit Total Coverage
Test: jami-coverage-filtered.info Lines: 94 133 70.7 %
Date: 2025-12-18 10:07:43 Functions: 3 4 75.0 %

          Line data    Source code
       1             : /*
       2             :  *  Copyright (C) 2004-2025 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        2555 : JamiAccountConfig::serialize(YAML::Emitter& out) const
      38             : {
      39        2555 :     out << YAML::BeginMap;
      40        2555 :     SipAccountBaseConfig::serializeDiff(out, DEFAULT_CONFIG);
      41        2555 :     SERIALIZE_CONFIG(Conf::DHT_PORT_KEY, dhtPort);
      42        2555 :     SERIALIZE_CONFIG(Conf::DHT_PUBLIC_IN_CALLS, allowPublicIncoming);
      43        2555 :     SERIALIZE_CONFIG(Conf::DHT_ALLOW_PEERS_FROM_HISTORY, allowPeersFromHistory);
      44        2555 :     SERIALIZE_CONFIG(Conf::DHT_ALLOW_PEERS_FROM_CONTACT, allowPeersFromContact);
      45        2555 :     SERIALIZE_CONFIG(Conf::DHT_ALLOW_PEERS_FROM_TRUSTED, allowPeersFromTrusted);
      46        2555 :     SERIALIZE_CONFIG(libjami::Account::ConfProperties::DHT_PEER_DISCOVERY, dhtPeerDiscovery);
      47        2555 :     SERIALIZE_CONFIG(libjami::Account::ConfProperties::ACCOUNT_PEER_DISCOVERY, accountPeerDiscovery);
      48        2555 :     SERIALIZE_CONFIG(libjami::Account::ConfProperties::ACCOUNT_PUBLISH, accountPublish);
      49        2555 :     SERIALIZE_CONFIG(Conf::PROXY_ENABLED_KEY, proxyEnabled);
      50        2555 :     SERIALIZE_CONFIG(Conf::PROXY_SERVER_KEY, proxyServer);
      51        2555 :     SERIALIZE_CONFIG(libjami::Account::ConfProperties::PROXY_LIST_ENABLED, proxyListEnabled);
      52        2555 :     SERIALIZE_CONFIG(libjami::Account::ConfProperties::DHT_PROXY_LIST_URL, proxyListUrl);
      53        2555 :     SERIALIZE_CONFIG(libjami::Account::ConfProperties::Nameserver::URI, nameServer);
      54        2555 :     SERIALIZE_CONFIG(libjami::Account::VolatileProperties::REGISTERED_NAME, registeredName);
      55        2555 :     SERIALIZE_PATH(libjami::Account::ConfProperties::ARCHIVE_PATH, archivePath);
      56        2555 :     SERIALIZE_CONFIG(libjami::Account::ConfProperties::ARCHIVE_HAS_PASSWORD, archiveHasPassword);
      57        2555 :     SERIALIZE_CONFIG(libjami::Account::ConfProperties::DEVICE_NAME, deviceName);
      58        2555 :     SERIALIZE_CONFIG(libjami::Account::ConfProperties::MANAGER_URI, managerUri);
      59        2555 :     SERIALIZE_CONFIG(libjami::Account::ConfProperties::MANAGER_USERNAME, managerUsername);
      60        2555 :     SERIALIZE_CONFIG(libjami::Account::ConfProperties::DHT::PUBLIC_IN_CALLS, dhtPublicInCalls);
      61             : 
      62        2555 :     out << YAML::Key << Conf::RING_ACCOUNT_RECEIPT << YAML::Value << receipt;
      63        2555 :     if (receiptSignature.size() > 0)
      64             :         out << YAML::Key << Conf::RING_ACCOUNT_RECEIPT_SIG << YAML::Value
      65         863 :             << YAML::Binary(receiptSignature.data(), receiptSignature.size());
      66             : 
      67             :     // tls submap
      68        2555 :     out << YAML::Key << Conf::TLS_KEY << YAML::Value << YAML::BeginMap;
      69        2555 :     SERIALIZE_PATH(Conf::CALIST_KEY, tlsCaListFile);
      70        2555 :     SERIALIZE_PATH(Conf::CERTIFICATE_KEY, tlsCertificateFile);
      71        2555 :     SERIALIZE_CONFIG(Conf::TLS_PASSWORD_KEY, tlsPassword);
      72        2555 :     SERIALIZE_PATH(Conf::PRIVATE_KEY_KEY, tlsPrivateKeyFile);
      73        2555 :     out << YAML::EndMap;
      74             : 
      75        2555 :     out << YAML::EndMap;
      76        2555 : }
      77             : 
      78             : void
      79           0 : JamiAccountConfig::unserialize(const YAML::Node& node)
      80             : {
      81             :     using yaml_utils::parseValueOptional;
      82             :     using yaml_utils::parsePathOptional;
      83           0 :     SipAccountBaseConfig::unserialize(node);
      84             : 
      85             :     // get tls submap
      86             :     try {
      87           0 :         const auto& tlsMap = node[Conf::TLS_KEY];
      88           0 :         parsePathOptional(tlsMap, Conf::CERTIFICATE_KEY, tlsCertificateFile, path);
      89           0 :         parsePathOptional(tlsMap, Conf::CALIST_KEY, tlsCaListFile, path);
      90           0 :         parseValueOptional(tlsMap, Conf::TLS_PASSWORD_KEY, tlsPassword);
      91           0 :         parsePathOptional(tlsMap, Conf::PRIVATE_KEY_KEY, tlsPrivateKeyFile, path);
      92           0 :     } catch (...) {
      93           0 :     }
      94           0 :     parseValueOptional(node, Conf::DHT_PORT_KEY, dhtPort);
      95           0 :     parseValueOptional(node, Conf::DHT_ALLOW_PEERS_FROM_HISTORY, allowPeersFromHistory);
      96           0 :     parseValueOptional(node, Conf::DHT_ALLOW_PEERS_FROM_CONTACT, allowPeersFromContact);
      97           0 :     parseValueOptional(node, Conf::DHT_ALLOW_PEERS_FROM_TRUSTED, allowPeersFromTrusted);
      98             : 
      99           0 :     parseValueOptional(node, Conf::PROXY_ENABLED_KEY, proxyEnabled);
     100           0 :     parseValueOptional(node, Conf::PROXY_SERVER_KEY, proxyServer);
     101           0 :     parseValueOptional(node, libjami::Account::ConfProperties::DHT_PROXY_LIST_URL, proxyListUrl);
     102           0 :     parseValueOptional(node, libjami::Account::ConfProperties::PROXY_LIST_ENABLED, proxyListEnabled);
     103             : 
     104           0 :     parseValueOptional(node, libjami::Account::ConfProperties::DEVICE_NAME, deviceName);
     105           0 :     parseValueOptional(node, libjami::Account::ConfProperties::MANAGER_URI, managerUri);
     106           0 :     parseValueOptional(node, libjami::Account::ConfProperties::MANAGER_USERNAME, managerUsername);
     107           0 :     parseValueOptional(node, libjami::Account::ConfProperties::DHT::PUBLIC_IN_CALLS, dhtPublicInCalls);
     108             : 
     109           0 :     parsePathOptional(node, libjami::Account::ConfProperties::ARCHIVE_PATH, archivePath, path);
     110           0 :     parseValueOptional(node, libjami::Account::ConfProperties::ARCHIVE_HAS_PASSWORD, archiveHasPassword);
     111             : 
     112             :     try {
     113           0 :         parseValueOptional(node, Conf::RING_ACCOUNT_RECEIPT, receipt);
     114           0 :         auto receipt_sig = node[Conf::RING_ACCOUNT_RECEIPT_SIG].as<YAML::Binary>();
     115           0 :         receiptSignature = {receipt_sig.data(), receipt_sig.data() + receipt_sig.size()};
     116           0 :     } catch (const std::exception& e) {
     117           0 :         JAMI_WARN("Unable to read receipt: %s", e.what());
     118           0 :     }
     119             : 
     120           0 :     parseValueOptional(node, libjami::Account::ConfProperties::DHT_PEER_DISCOVERY, dhtPeerDiscovery);
     121           0 :     parseValueOptional(node, libjami::Account::ConfProperties::ACCOUNT_PEER_DISCOVERY, accountPeerDiscovery);
     122           0 :     parseValueOptional(node, libjami::Account::ConfProperties::ACCOUNT_PUBLISH, accountPublish);
     123           0 :     parseValueOptional(node, libjami::Account::ConfProperties::Nameserver::URI, nameServer);
     124           0 :     parseValueOptional(node, libjami::Account::VolatileProperties::REGISTERED_NAME, registeredName);
     125           0 :     parseValueOptional(node, Conf::DHT_PUBLIC_IN_CALLS, allowPublicIncoming);
     126           0 : }
     127             : 
     128             : std::map<std::string, std::string>
     129         559 : JamiAccountConfig::toMap() const
     130             : {
     131         559 :     std::map<std::string, std::string> a = SipAccountBaseConfig::toMap();
     132         559 :     a.emplace(Conf::CONFIG_DHT_PORT, std::to_string(dhtPort));
     133         559 :     a.emplace(Conf::CONFIG_DHT_PUBLIC_IN_CALLS, allowPublicIncoming ? TRUE_STR : FALSE_STR);
     134         559 :     a.emplace(libjami::Account::ConfProperties::DHT_PEER_DISCOVERY, dhtPeerDiscovery ? TRUE_STR : FALSE_STR);
     135         559 :     a.emplace(libjami::Account::ConfProperties::ACCOUNT_PEER_DISCOVERY, accountPeerDiscovery ? TRUE_STR : FALSE_STR);
     136         559 :     a.emplace(libjami::Account::ConfProperties::ACCOUNT_PUBLISH, accountPublish ? TRUE_STR : FALSE_STR);
     137         559 :     a.emplace(libjami::Account::ConfProperties::DEVICE_NAME, deviceName);
     138         559 :     a.emplace(libjami::Account::ConfProperties::Presence::SUPPORT_SUBSCRIBE, TRUE_STR);
     139         559 :     if (not archivePath.empty() or not managerUri.empty())
     140         559 :         a.emplace(libjami::Account::ConfProperties::ARCHIVE_HAS_PASSWORD, archiveHasPassword ? TRUE_STR : FALSE_STR);
     141             : 
     142         559 :     a.emplace(Conf::CONFIG_TLS_CA_LIST_FILE, fileutils::getFullPath(path, tlsCaListFile).string());
     143         559 :     a.emplace(Conf::CONFIG_TLS_CERTIFICATE_FILE, fileutils::getFullPath(path, tlsCertificateFile).string());
     144         559 :     a.emplace(Conf::CONFIG_TLS_PRIVATE_KEY_FILE, fileutils::getFullPath(path, tlsPrivateKeyFile).string());
     145         559 :     a.emplace(Conf::CONFIG_TLS_PASSWORD, tlsPassword);
     146         559 :     a.emplace(libjami::Account::ConfProperties::ALLOW_CERT_FROM_HISTORY, allowPeersFromHistory ? TRUE_STR : FALSE_STR);
     147         559 :     a.emplace(libjami::Account::ConfProperties::ALLOW_CERT_FROM_CONTACT, allowPeersFromContact ? TRUE_STR : FALSE_STR);
     148         559 :     a.emplace(libjami::Account::ConfProperties::ALLOW_CERT_FROM_TRUSTED, allowPeersFromTrusted ? TRUE_STR : FALSE_STR);
     149         559 :     a.emplace(libjami::Account::ConfProperties::PROXY_ENABLED, proxyEnabled ? TRUE_STR : FALSE_STR);
     150         559 :     a.emplace(libjami::Account::ConfProperties::PROXY_LIST_ENABLED, proxyListEnabled ? TRUE_STR : FALSE_STR);
     151         559 :     a.emplace(libjami::Account::ConfProperties::PROXY_SERVER, proxyServer);
     152         559 :     a.emplace(libjami::Account::ConfProperties::DHT_PROXY_LIST_URL, proxyListUrl);
     153         559 :     a.emplace(libjami::Account::ConfProperties::MANAGER_URI, managerUri);
     154         559 :     a.emplace(libjami::Account::ConfProperties::MANAGER_USERNAME, managerUsername);
     155         559 :     a.emplace(libjami::Account::ConfProperties::DHT::PUBLIC_IN_CALLS, dhtPublicInCalls ? TRUE_STR : FALSE_STR);
     156         559 :     a.emplace(libjami::Account::ConfProperties::Nameserver::URI, nameServer);
     157         559 :     return a;
     158           0 : }
     159             : 
     160             : void
     161        1564 : JamiAccountConfig::fromMap(const std::map<std::string, std::string>& details)
     162             : {
     163        1564 :     SipAccountBaseConfig::fromMap(details);
     164             :     // TLS
     165        1564 :     parsePath(details, Conf::CONFIG_TLS_CA_LIST_FILE, tlsCaListFile, path);
     166        1564 :     parsePath(details, Conf::CONFIG_TLS_CERTIFICATE_FILE, tlsCertificateFile, path);
     167        1564 :     parsePath(details, Conf::CONFIG_TLS_PRIVATE_KEY_FILE, tlsPrivateKeyFile, path);
     168        1564 :     parseString(details, Conf::CONFIG_TLS_PASSWORD, tlsPassword);
     169             : 
     170        1564 :     if (hostname.empty())
     171           0 :         hostname = DHT_DEFAULT_BOOTSTRAP;
     172        1564 :     parseString(details, libjami::Account::ConfProperties::BOOTSTRAP_LIST_URL, bootstrapListUrl);
     173        1564 :     parseInt(details, Conf::CONFIG_DHT_PORT, dhtPort);
     174        1564 :     parseBool(details, Conf::CONFIG_DHT_PUBLIC_IN_CALLS, allowPublicIncoming);
     175        1564 :     parseBool(details, libjami::Account::ConfProperties::DHT_PEER_DISCOVERY, dhtPeerDiscovery);
     176        1564 :     parseBool(details, libjami::Account::ConfProperties::ACCOUNT_PEER_DISCOVERY, accountPeerDiscovery);
     177        1564 :     parseBool(details, libjami::Account::ConfProperties::ACCOUNT_PUBLISH, accountPublish);
     178        1564 :     parseBool(details, libjami::Account::ConfProperties::ALLOW_CERT_FROM_HISTORY, allowPeersFromHistory);
     179        1564 :     parseBool(details, libjami::Account::ConfProperties::ALLOW_CERT_FROM_CONTACT, allowPeersFromContact);
     180        1564 :     parseBool(details, libjami::Account::ConfProperties::ALLOW_CERT_FROM_TRUSTED, allowPeersFromTrusted);
     181             : 
     182        1564 :     parseString(details, libjami::Account::ConfProperties::MANAGER_URI, managerUri);
     183        1564 :     parseString(details, libjami::Account::ConfProperties::MANAGER_USERNAME, managerUsername);
     184        1564 :     parseBool(details, libjami::Account::ConfProperties::DHT::PUBLIC_IN_CALLS, dhtPublicInCalls);
     185             :     // parseString(details, libjami::Account::ConfProperties::USERNAME, username);
     186             : 
     187        1564 :     parseString(details, libjami::Account::ConfProperties::ARCHIVE_PASSWORD, credentials.archive_password);
     188        1564 :     parseString(details, libjami::Account::ConfProperties::ARCHIVE_PASSWORD_SCHEME, credentials.archive_password_scheme);
     189        1564 :     parseString(details, libjami::Account::ConfProperties::ARCHIVE_PATH, credentials.archive_path);
     190        1564 :     parseString(details, libjami::Account::ConfProperties::DEVICE_NAME, deviceName);
     191        1564 :     parseString(details, libjami::Account::ConfProperties::ARCHIVE_URL, archive_url);
     192             : 
     193        1564 :     auto oldProxyServer = proxyServer, oldProxyServerList = proxyListUrl;
     194        1564 :     parseString(details, libjami::Account::ConfProperties::DHT_PROXY_LIST_URL, proxyListUrl);
     195        1564 :     parseBool(details, libjami::Account::ConfProperties::PROXY_ENABLED, proxyEnabled);
     196        1564 :     parseBool(details, libjami::Account::ConfProperties::PROXY_LIST_ENABLED, proxyListEnabled);
     197        1564 :     parseString(details, libjami::Account::ConfProperties::PROXY_SERVER, proxyServer);
     198        1564 :     parseString(details, libjami::Account::ConfProperties::UI_CUSTOMIZATION, uiCustomization);
     199        1564 :     if (not managerUri.empty() and managerUri.rfind("http", 0) != 0) {
     200           0 :         managerUri = "https://" + managerUri;
     201             :     }
     202             : 
     203        1564 :     parseString(details, libjami::Account::ConfProperties::Nameserver::URI, nameServer);
     204        1564 : }
     205             : 
     206             : } // namespace jami

Generated by: LCOV version 1.14