From 14325891332bebceb50601db55ddedbfb6766c22 Mon Sep 17 00:00:00 2001 From: Manjeet Dahiya Date: Sun, 12 Sep 2010 10:05:59 +0000 Subject: add entityTime manager --- src/QXmppEntityTimeManager.cpp | 50 ++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 50 insertions(+) create mode 100644 src/QXmppEntityTimeManager.cpp (limited to 'src/QXmppEntityTimeManager.cpp') diff --git a/src/QXmppEntityTimeManager.cpp b/src/QXmppEntityTimeManager.cpp new file mode 100644 index 00000000..8ae97365 --- /dev/null +++ b/src/QXmppEntityTimeManager.cpp @@ -0,0 +1,50 @@ +#include "QXmppEntityTimeManager.h" + +#include + +#include "QXmppConstants.h" +#include "QXmppOutgoingClient.h" +#include "QXmppEntityTimeIq.h" + +void QXmppEntityTimeManager::requestTime(const QString& jid) +{ + QXmppEntityTimeIq request; + request.setType(QXmppIq::Get); + request.setFrom(client()->configuration().jid()); + request.setTo(jid); + client()->sendPacket(request); +} + +QStringList QXmppEntityTimeManager::discoveryFeatures() const +{ + return QStringList() << ns_entity_time; +} + +bool QXmppEntityTimeManager::handleStanza(QXmppStream *stream, const QDomElement &element) +{ + if(element.tagName() == "iq" && QXmppEntityTimeIq::isEntityTimeIq(element)) + { + QXmppEntityTimeIq entityTime; + entityTime.parse(element); + + if(entityTime.type() == QXmppIq::Get) + { + // respond to query + QXmppEntityTimeIq responseIq; + responseIq.setType(QXmppIq::Result); + responseIq.setId(entityTime.id()); + responseIq.setTo(entityTime.from()); + + // TODO: set valid values + responseIq.setTzo(""); + responseIq.setUtc(""); + + stream->sendPacket(responseIq); + } + + emit timeReceived(entityTime); + return true; + } + + return false; +} -- cgit v1.2.3