aboutsummaryrefslogtreecommitdiff
path: root/src/base/QXmppTrustMessageElement.cpp
diff options
context:
space:
mode:
authorMelvin Keskin <melvo@olomono.de>2021-06-30 17:38:47 +0200
committerLinus Jahn <lnj@kaidan.im>2021-07-06 22:35:53 +0200
commit0b947c682c27091dd4afd5900d8e339175e1aba0 (patch)
treed880db35de8d3eaefb01ead0043b07901c5cda50 /src/base/QXmppTrustMessageElement.cpp
parent92427f63b3458fac76f64f2993db81d8c4c5d84c (diff)
downloadqxmpp-0b947c682c27091dd4afd5900d8e339175e1aba0.tar.gz
Add QXmppTrustMessageElement
Diffstat (limited to 'src/base/QXmppTrustMessageElement.cpp')
-rw-r--r--src/base/QXmppTrustMessageElement.cpp188
1 files changed, 188 insertions, 0 deletions
diff --git a/src/base/QXmppTrustMessageElement.cpp b/src/base/QXmppTrustMessageElement.cpp
new file mode 100644
index 00000000..b15dc6fe
--- /dev/null
+++ b/src/base/QXmppTrustMessageElement.cpp
@@ -0,0 +1,188 @@
+/*
+ * Copyright (C) 2008-2021 The QXmpp developers
+ *
+ * Author:
+ * Melvin Keskin
+ *
+ * Source:
+ * https://github.com/qxmpp-project/qxmpp
+ *
+ * This file is a part of QXmpp library.
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2.1 of the License, or (at your option) any later version.
+ *
+ * This library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Lesser General Public License for more details.
+ *
+ */
+
+#include "QXmppTrustMessageElement.h"
+
+#include "QXmppConstants_p.h"
+#include "QXmppTrustMessageKeyOwner.h"
+
+#include <QDomElement>
+
+///
+/// \class QXmppTrustMessageElement
+///
+/// \brief The QXmppTrustMessageElement class represents a trust message element
+/// as defined by \xep{0434, Trust Messages (TM)}.
+///
+/// \since QXmpp 1.5
+///
+
+class QXmppTrustMessageElementPrivate : public QSharedData
+{
+public:
+ QString usage;
+ QString encryption;
+ QList<QXmppTrustMessageKeyOwner> keyOwners;
+};
+
+///
+/// Constructs a trust message element.
+///
+QXmppTrustMessageElement::QXmppTrustMessageElement()
+ : d(new QXmppTrustMessageElementPrivate)
+{
+}
+
+///
+/// Constructs a copy of \a other.
+///
+/// \param other
+///
+QXmppTrustMessageElement::QXmppTrustMessageElement(const QXmppTrustMessageElement &other) = default;
+
+QXmppTrustMessageElement::~QXmppTrustMessageElement() = default;
+
+///
+/// Assigns \a other to this trust message element.
+///
+/// \param other
+///
+QXmppTrustMessageElement &QXmppTrustMessageElement::operator=(const QXmppTrustMessageElement &other) = default;
+
+///
+/// Returns the namespace of the trust management protocol.
+///
+/// \return the trust management protocol namespace
+///
+QString QXmppTrustMessageElement::usage() const
+{
+ return d->usage;
+}
+
+///
+/// Sets the namespace of the trust management protocol.
+///
+/// \param usage trust management protocol namespace
+///
+void QXmppTrustMessageElement::setUsage(const QString &usage)
+{
+ d->usage = usage;
+}
+
+///
+/// Returns the namespace of the keys' encryption protocol.
+///
+/// \return the encryption protocol namespace
+///
+QString QXmppTrustMessageElement::encryption() const
+{
+ return d->encryption;
+}
+
+///
+/// Sets the namespace of the keys' encryption protocol.
+///
+/// \param encryption encryption protocol namespace
+///
+void QXmppTrustMessageElement::setEncryption(const QString &encryption)
+{
+ d->encryption = encryption;
+}
+
+///
+/// Returns the key owners containing the corresponding information for
+/// trusting or distrusting their keys.
+///
+/// \return the owners of the keys for trusting or distrusting
+///
+QList<QXmppTrustMessageKeyOwner> QXmppTrustMessageElement::keyOwners() const
+{
+ return d->keyOwners;
+}
+
+///
+/// Sets the key owners containing the corresponding information for trusting or
+/// distrusting their keys.
+///
+/// \param keyOwners owners of the keys for trusting or distrusting
+///
+void QXmppTrustMessageElement::setKeyOwners(const QList<QXmppTrustMessageKeyOwner> &keyOwners)
+{
+ d->keyOwners = keyOwners;
+}
+
+///
+/// Adds a key owner containing the corresponding information for trusting or
+/// distrusting the owners keys.
+///
+/// \param keyOwner owner of the keys for trusting or distrusting
+///
+void QXmppTrustMessageElement::addKeyOwner(const QXmppTrustMessageKeyOwner &keyOwner)
+{
+ d->keyOwners.append(keyOwner);
+}
+
+/// \cond
+void QXmppTrustMessageElement::parse(const QDomElement &element)
+{
+ d->usage = element.attribute("usage");
+ d->encryption = element.attribute("encryption");
+
+ for (auto keyOwnerElement = element.firstChildElement("key-owner");
+ !keyOwnerElement.isNull();
+ keyOwnerElement = keyOwnerElement.nextSiblingElement("key-owner")) {
+ if (QXmppTrustMessageKeyOwner::isTrustMessageKeyOwner(keyOwnerElement)) {
+ QXmppTrustMessageKeyOwner keyOwner;
+ keyOwner.parse(keyOwnerElement);
+ d->keyOwners.append(keyOwner);
+ }
+ }
+}
+
+void QXmppTrustMessageElement::toXml(QXmlStreamWriter *writer) const
+{
+ writer->writeStartElement("trust-message");
+ writer->writeDefaultNamespace(ns_tm);
+ writer->writeAttribute("usage", d->usage);
+ writer->writeAttribute("encryption", d->encryption);
+
+ for (const auto &keyOwner : d->keyOwners) {
+ keyOwner.toXml(writer);
+ }
+
+ writer->writeEndElement();
+}
+/// \endcond
+
+///
+/// Determines whether the given DOM element is a trust message element.
+///
+/// \param element DOM element being checked
+///
+/// \return true if element is a trust message element, otherwise false
+///
+bool QXmppTrustMessageElement::isTrustMessageElement(const QDomElement &element)
+{
+ return element.tagName() == QStringLiteral("trust-message") &&
+ element.namespaceURI() == ns_tm;
+}