From 8780445c9fac2840a34042ae3faa217d3fde7f8a Mon Sep 17 00:00:00 2001 From: Manjeet Dahiya Date: Sun, 12 Sep 2010 14:28:58 +0000 Subject: populate the result Iq --- src/QXmppEntityTimeManager.cpp | 22 ++++++++++++++++++++-- 1 file changed, 20 insertions(+), 2 deletions(-) (limited to 'src/QXmppEntityTimeManager.cpp') diff --git a/src/QXmppEntityTimeManager.cpp b/src/QXmppEntityTimeManager.cpp index 1d9e0013..c6d8a67f 100644 --- a/src/QXmppEntityTimeManager.cpp +++ b/src/QXmppEntityTimeManager.cpp @@ -25,10 +25,12 @@ #include "QXmppEntityTimeManager.h" #include +#include #include "QXmppConstants.h" #include "QXmppOutgoingClient.h" #include "QXmppEntityTimeIq.h" +#include "QXmppUtils.h" void QXmppEntityTimeManager::requestTime(const QString& jid) { @@ -60,8 +62,24 @@ bool QXmppEntityTimeManager::handleStanza(QXmppStream *stream, const QDomElement responseIq.setTo(entityTime.from()); // TODO: set valid values - responseIq.setTzo(""); - responseIq.setUtc(""); + QDateTime currentTime = QDateTime::currentDateTime(); + QDateTime utc = currentTime.toUTC(); + responseIq.setUtc(datetimeToString(utc)); + + currentTime.setTimeSpec(Qt::UTC); + int tzo_sec = currentTime.secsTo(utc); + QTime tzo_time; + if(tzo_sec < 0) + tzo_time.addSecs(-tzo_sec); + else + tzo_time.addSecs(tzo_sec); + QString tzo; + if(tzo_sec < 0) + tzo = "-" + tzo_time.toString("hh:mm"); + else + tzo = "+" + tzo_time.toString("hh:mm"); + + responseIq.setTzo(tzo); stream->sendPacket(responseIq); } -- cgit v1.2.3