blob: e4007accd1a53db257f3ad720511159c8e3616e4 (
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
|
/*
* Copyright (C) 2008-2012 The QXmpp developers
*
* Authors:
* Manjeet Dahiya
* Jeremy Lainé
*
* 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.
*
*/
#ifndef QXMPPROSTERIQ_H
#define QXMPPROSTERIQ_H
#include "QXmppIq.h"
#include <QList>
#include <QSet>
/// \brief The QXmppRosterIq class represents a roster IQ.
///
/// \ingroup Stanzas
class QXMPP_EXPORT QXmppRosterIq : public QXmppIq
{
public:
/// \brief The QXmppRosterIq::Item class represents a roster entry.
class QXMPP_EXPORT Item
{
public:
/// An enumeration for type of subscription with the bareJid in the roster.
enum SubscriptionType
{
None = 0, ///< the user does not have a subscription to the
///< contact's presence information, and the contact does
///< not have a subscription to the user's presence information
From = 1, ///< the contact has a subscription to the user's presence information,
///< but the user does not have a subscription to the contact's presence information
To = 2, ///< the user has a subscription to the contact's presence information,
///< but the contact does not have a subscription to the user's presence information
Both = 3, ///< both the user and the contact have subscriptions to each
///< other's presence information
Remove = 4, ///< to delete a roster item
NotSet = 8 ///< the subscription state was not specified
};
Item();
QString bareJid() const;
QSet<QString> groups() const;
QString name() const;
QString subscriptionStatus() const;
SubscriptionType subscriptionType() const;
void setBareJid(const QString&);
void setGroups(const QSet<QString>&);
void setName(const QString&);
void setSubscriptionStatus(const QString&);
void setSubscriptionType(SubscriptionType);
/// \cond
void parse(const QDomElement &element);
void toXml(QXmlStreamWriter *writer) const;
/// \endcond
private:
QString getSubscriptionTypeStr() const;
void setSubscriptionTypeFromStr(const QString&);
QString m_bareJid;
SubscriptionType m_type;
QString m_name;
// can be subscribe/unsubscribe (attribute "ask")
QString m_subscriptionStatus;
QSet<QString> m_groups;
};
void addItem(const Item&);
QList<Item> items() const;
/// \cond
static bool isRosterIq(const QDomElement &element);
/// \endcond
protected:
/// \cond
void parseElementFromChild(const QDomElement &element);
void toXmlElementFromChild(QXmlStreamWriter *writer) const;
/// \endcond
private:
QList<Item> m_items;
};
#endif // QXMPPROSTERIQ_H
|