blob: ea3e5228f93c2697cc288a57eae7012c8ca1fd32 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
|
/*
* Copyright (C) 2008-2010 The QXmpp developers
*
* Author:
* Manjeet Dahiya
*
* Source:
* http://code.google.com/p/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 "capabilitiesCollection.h"
#include "QXmppClient.h"
#include "QXmppDiscoveryManager.h"
#include <utils.h>
#include <QXmlStreamWriter>
#include <QDir>
capabilitiesCollection::capabilitiesCollection(QXmppClient* client) :
QObject(client), m_client(client)
{
QXmppDiscoveryManager* ext = m_client->findExtension<QXmppDiscoveryManager>();
if(ext)
{
bool check = connect(ext, SIGNAL(infoReceived(const QXmppDiscoveryIq&)),
SLOT(infoReceived(const QXmppDiscoveryIq&)));
Q_ASSERT(check);
}
}
bool capabilitiesCollection::isCapabilityAvailable(const QString& nodeVer)
{
return m_mapCapabilities.contains(nodeVer);
}
void capabilitiesCollection::requestInfo(const QString& jid, const QString& node)
{
QXmppDiscoveryManager* ext = m_client->findExtension<QXmppDiscoveryManager>();
if(ext)
{
bool alreadyRequested = false;
foreach(QString key, m_mapIdNodeVer.keys())
{
if(m_mapIdNodeVer[key] == node)
{
alreadyRequested = true;
break;
}
}
if(!alreadyRequested)
{
QString id = ext->requestInfo(jid, node);
m_mapIdNodeVer[id] = node;
}
}
}
void capabilitiesCollection::infoReceived(const QXmppDiscoveryIq& discoIqRcv)
{
QXmppDiscoveryIq discoIq = discoIqRcv;
if(discoIq.queryType() == QXmppDiscoveryIq::InfoQuery &&
discoIq.type() == QXmppIq::Result)
{
if(discoIq.queryNode().isEmpty())
{
discoIq.setQueryNode(m_mapIdNodeVer[discoIq.id()]);
}
discoIq.setTo("");
discoIq.setFrom("");
discoIq.setId("");
m_mapCapabilities[discoIq.queryNode()] = discoIq;
saveToCache(discoIq.queryNode());
}
}
void capabilitiesCollection::loadAllFromCache()
{
}
void capabilitiesCollection::saveToCache(const QString& nodeVer)
{
if(!m_mapCapabilities.contains(nodeVer))
return;
QString fileName = getImageHash(nodeVer.toUtf8());
QDir dir;
if(!dir.exists(getSettingsDir(m_client->configuration().jidBare())))
dir.mkpath(getSettingsDir(m_client->configuration().jidBare()));
QDir dir2;
if(!dir2.exists(getSettingsDir(m_client->configuration().jidBare())+ "capabilities/"))
dir2.mkpath(getSettingsDir(m_client->configuration().jidBare())+ "capabilities/");
QString fileCapability = getSettingsDir(m_client->configuration().jidBare()) + "capabilities/" + fileName + ".xml";
QFile file(fileCapability);
if(file.open(QIODevice::ReadWrite))
{
QXmlStreamWriter stream(&file);
m_mapCapabilities[nodeVer].toXml(&stream);
file.close();
}
}
|