diff options
| author | Niels Ole Salscheider <niels_ole@salscheider-online.de> | 2016-11-20 12:48:26 +0100 |
|---|---|---|
| committer | Jeremy Lainé <jeremy.laine@m4x.org> | 2017-04-29 16:09:30 +0200 |
| commit | 81691141d4ac136744f2520ca41f45e281902114 (patch) | |
| tree | d750c853694312913c6b5e23c9373c99585cdc85 /src/client | |
| parent | 084eb01fb395488a0a3aee799be2b72ce11aa220 (diff) | |
| download | qxmpp-81691141d4ac136744f2520ca41f45e281902114.tar.gz | |
Add QXmppMamManager (XEP-0313)
Diffstat (limited to 'src/client')
| -rw-r--r-- | src/client/QXmppMamManager.cpp | 141 | ||||
| -rw-r--r-- | src/client/QXmppMamManager.h | 75 | ||||
| -rw-r--r-- | src/client/client.pri | 2 |
3 files changed, 218 insertions, 0 deletions
diff --git a/src/client/QXmppMamManager.cpp b/src/client/QXmppMamManager.cpp new file mode 100644 index 00000000..8c793144 --- /dev/null +++ b/src/client/QXmppMamManager.cpp @@ -0,0 +1,141 @@ +/* + * Copyright (C) 2016-2017 The QXmpp developers + * + * Author: + * Niels Ole Salscheider + * + * 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 <QDomElement> + +#include "QXmppMamManager.h" +#include "QXmppMamIq.h" +#include "QXmppClient.h" +#include "QXmppConstants_p.h" +#include "QXmppDataForm.h" +#include "QXmppMessage.h" +#include "QXmppUtils.h" + +/// \cond +QStringList QXmppMamManager::discoveryFeatures() const +{ + // XEP-0313: Message Archive Management + return QStringList() << ns_mam; +} + +bool QXmppMamManager::handleStanza(const QDomElement &element) +{ + if (element.tagName() == "message") { + QDomElement resultElement = element.firstChildElement("result"); + if (!resultElement.isNull() && resultElement.namespaceURI() == ns_mam) { + QDomElement forwardedElement = resultElement.firstChildElement("forwarded"); + QString queryId = resultElement.attribute("queryid"); + if (!forwardedElement.isNull() && forwardedElement.namespaceURI() == ns_forwarding) { + QDomElement messageElement = forwardedElement.firstChildElement("message"); + QDomElement delayElement = forwardedElement.firstChildElement("delay"); + if (!messageElement.isNull()) { + QXmppMessage message; + message.parse(messageElement); + if (!delayElement.isNull() && delayElement.namespaceURI() == ns_delayed_delivery) { + const QString stamp = delayElement.attribute("stamp"); + message.setStamp(QXmppUtils::datetimeFromString(stamp)); + } + emit archivedMessageReceived(queryId, message); + } + } + return true; + } + } else if (QXmppMamResultIq::isMamResultIq(element)) { + QXmppMamResultIq result; + result.parse(element); + emit resultsRecieved(result.id(), result.resultSetReply(), result.complete()); + return true; + } + + return false; +} +/// \endcond + +/// Retrieves archived messages. For each received message, the +/// archiveMessageReceived() signal is emitted. Once all messages are received, +/// the resultsRecieved() signal is emitted. It returns a result set that can +/// be used to page through the results. +/// The number of results may be limited by the server. +/// +/// \param to Optional entity that should be queried. Leave this empty to query +/// the local archive. +/// \param node Optional node that should be queried. This is used when querying +/// a pubsub node. +/// \param jid Optional JID to filter the results. +/// \param start Optional start time to filter the results. +/// \param end Optional end time to filter the results. +/// \param resultSetQuery Optional Result Set Management query. This can be used +/// to limit the number of results and to page through the +/// archive. +/// \return query id of the request. This can be used to associate the +/// corresponding resultsRecieved signal. +/// +QString QXmppMamManager::retrieveArchivedMessages(const QString &to, + const QString &node, + const QString &jid, + const QDateTime &start, + const QDateTime &end, + const QXmppResultSetQuery &resultSetQuery) +{ + QList<QXmppDataForm::Field> fields; + + QXmppDataForm::Field hiddenField(QXmppDataForm::Field::HiddenField); + hiddenField.setKey("FORM_TYPE"); + hiddenField.setValue(ns_mam); + fields << hiddenField; + + if (!jid.isEmpty()) { + QXmppDataForm::Field jidField; + jidField.setKey("with"); + jidField.setValue(jid); + fields << jidField; + } + + if (start.isValid()) { + QXmppDataForm::Field startField; + startField.setKey("start"); + startField.setValue(QXmppUtils::datetimeToString(start)); + fields << startField; + } + + if (end.isValid()) { + QXmppDataForm::Field endField; + endField.setKey("end"); + endField.setValue(QXmppUtils::datetimeToString(end)); + fields << endField; + } + + QXmppDataForm form; + form.setType(QXmppDataForm::Submit); + form.setFields(fields); + + QXmppMamQueryIq queryIq; + QString queryId = queryIq.id(); /* reuse the IQ id as query id */ + queryIq.setTo(to); + queryIq.setNode(node); + queryIq.setQueryId(queryId); + queryIq.setForm(form); + queryIq.setResultSetQuery(resultSetQuery); + client()->sendPacket(queryIq); + return queryId; +} diff --git a/src/client/QXmppMamManager.h b/src/client/QXmppMamManager.h new file mode 100644 index 00000000..d2c8e315 --- /dev/null +++ b/src/client/QXmppMamManager.h @@ -0,0 +1,75 @@ +/* + * Copyright (C) 2016-2017 The QXmpp developers + * + * Author: + * Niels Ole Salscheider + * + * 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. + * + */ + +#ifndef QXMPPMAMMANAGER_H +#define QXMPPMAMMANAGER_H + +#include <QDateTime> + +#include "QXmppClientExtension.h" +#include "QXmppResultSet.h" + +class QXmppMessage; + +/// \brief The QXmppMamManager class makes it possible to access message +/// archives as defined by XEP-0313: Message Archive Management. +/// +/// To make use of this manager, you need to instantiate it and load it into +/// the QXmppClient instance as follows: +/// +/// \code +/// QXmppMamManager *manager = new QXmppMamManager; +/// client->addExtension(manager); +/// \endcode +/// +/// \ingroup Managers + +class QXMPP_EXPORT QXmppMamManager : public QXmppClientExtension +{ + Q_OBJECT + +public: + QString retrieveArchivedMessages(const QString &to = QString(), + const QString &node = QString(), + const QString &jid = QString(), + const QDateTime &start = QDateTime(), + const QDateTime &end = QDateTime(), + const QXmppResultSetQuery &resultSetQuery = QXmppResultSetQuery()); + + /// \cond + QStringList discoveryFeatures() const; + bool handleStanza(const QDomElement &element); + /// \endcond + +signals: + /// This signal is emitted when an archived message is received + void archivedMessageReceived(const QString &queryId, + const QXmppMessage &message); + + /// This signal is emitted when all results for a request have been received + void resultsRecieved(const QString &queryId, + const QXmppResultSetReply &resultSetReply, + bool complete); +}; + +#endif diff --git a/src/client/client.pri b/src/client/client.pri index 650300be..bfb3094f 100644 --- a/src/client/client.pri +++ b/src/client/client.pri @@ -10,6 +10,7 @@ INSTALL_HEADERS += \ client/QXmppDiscoveryManager.h \ client/QXmppEntityTimeManager.h \ client/QXmppInvokable.h \ + client/QXmppMamManager.h \ client/QXmppMessageReceiptManager.h \ client/QXmppMucManager.h \ client/QXmppOutgoingClient.h \ @@ -33,6 +34,7 @@ SOURCES += \ client/QXmppConfiguration.cpp \ client/QXmppEntityTimeManager.cpp \ client/QXmppInvokable.cpp \ + client/QXmppMamManager.cpp \ client/QXmppMessageReceiptManager.cpp \ client/QXmppMucManager.cpp \ client/QXmppOutgoingClient.cpp \ |
