From a8fd01e50a3088df8bc6b367d1c14fe1da93be91 Mon Sep 17 00:00:00 2001 From: Linus Jahn Date: Wed, 6 Apr 2022 13:02:29 +0200 Subject: Message: Move encryption namespace parsing into Global private --- src/base/QXmppGlobal.cpp | 49 ++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 49 insertions(+) create mode 100644 src/base/QXmppGlobal.cpp (limited to 'src/base/QXmppGlobal.cpp') diff --git a/src/base/QXmppGlobal.cpp b/src/base/QXmppGlobal.cpp new file mode 100644 index 00000000..1d0d9afb --- /dev/null +++ b/src/base/QXmppGlobal.cpp @@ -0,0 +1,49 @@ +// SPDX-FileCopyrightText: 2022 Linus Jahn +// +// SPDX-License-Identifier: LGPL-2.1-or-later + +#include "QXmppConstants_p.h" +#include "QXmppGlobal_p.h" + +#include + +static const QStringList ENCRYPTION_NAMESPACES = { + QString(), + QString(), + ns_otr, + ns_legacy_openpgp, + ns_ox, + ns_omemo, + ns_omemo_1, + ns_omemo_2 +}; + +static const QStringList ENCRYPTION_NAMES = { + QString(), + QString(), + QStringLiteral("OTR"), + QStringLiteral("Legacy OpenPGP"), + QStringLiteral("OpenPGP for XMPP (OX)"), + QStringLiteral("OMEMO"), + QStringLiteral("OMEMO 1"), + QStringLiteral("OMEMO 2") +}; + +std::optional QXmpp::Private::encryptionFromString(const QString &str) +{ + int index = ENCRYPTION_NAMESPACES.indexOf(str); + if (index < 0) { + return {}; + } + return QXmpp::Encryption(index); +} + +QString QXmpp::Private::encryptionToString(Encryption encryption) +{ + return ENCRYPTION_NAMESPACES.at(int(encryption)); +} + +QString QXmpp::Private::encryptionToName(Encryption encryption) +{ + return ENCRYPTION_NAMES.at(int(encryption)); +} -- cgit v1.2.3