8#ifndef QXMPPROSTERMANAGER_H
9#define QXMPPROSTERMANAGER_H
11#include "QXmppClientExtension.h"
12#include "QXmppPresence.h"
13#include "QXmppRosterIq.h"
14#include "QXmppSendResult.h"
24class QXmppRosterManagerPrivate;
89 using Result = std::variant<QXmpp::Success, QXmppError>;
100 const QString &bareJid)
const;
102 const QString &resource)
const;
105 QXmppTask<Result> removeRosterItem(
const QString &bareJid);
106 QXmppTask<Result> renameRosterItem(
const QString &bareJid,
const QString &name);
107 QXmppTask<QXmpp::SendResult> subscribeTo(
const QString &bareJid,
const QString &reason = {});
108 QXmppTask<QXmpp::SendResult> unsubscribeFrom(
const QString &bareJid,
const QString &reason = {});
115 bool acceptSubscription(
const QString &bareJid,
const QString &reason = {});
116 bool refuseSubscription(
const QString &bareJid,
const QString &reason = {});
117 bool addItem(
const QString &bareJid,
const QString &name = {},
const QSet<QString> &groups = {});
118 bool removeItem(
const QString &bareJid);
119 bool renameItem(
const QString &bareJid,
const QString &name);
120 bool subscribe(
const QString &bareJid,
const QString &reason = {});
121 bool unsubscribe(
const QString &bareJid,
const QString &reason = {});
168 void _q_disconnected();
172 using RosterResult = std::variant<QXmppRosterIq, QXmppError>;
174 void handleSubscriptionRequest(
const QString &bareJid,
const QXmppPresence &presence);
177 const std::unique_ptr<QXmppRosterManagerPrivate> d;
179 friend class QXmppMixManager;
virtual void onUnregistered(QXmppClient *client)
Definition QXmppClientExtension.cpp:95
virtual void onRegistered(QXmppClient *client)
Definition QXmppClientExtension.cpp:85
QXmppClient * client() const
Definition QXmppClientExtension.cpp:57
QXmppClientExtension()
Definition QXmppClientExtension.cpp:12
virtual bool handleStanza(const QDomElement &stanza)
You need to implement this method to process incoming XMPP stanzas.
Definition client/compat/removed_api.cpp:26
The QXmppPresence class represents an XMPP presence stanza.
Definition QXmppPresence.h:22
The QXmppRosterIq::Item class represents a roster entry.
Definition QXmppRosterIq.h:33
QXmppTask< Result > addRosterItem(const QString &bareJid, const QString &name={}, const QSet< QString > &groups={})
Definition QXmppRosterManager.cpp:332
bool isRosterReceived() const
Definition QXmppRosterManager.cpp:703
QMap< QString, QXmppPresence > getAllPresencesForBareJid(const QString &bareJid) const
Definition QXmppRosterManager.cpp:667
void subscriptionReceived(const QString &bareJid)
QXmppRosterIq::Item getRosterEntry(const QString &bareJid) const
Definition QXmppRosterManager.cpp:635
void subscriptionRequestReceived(const QString &subscriberBareJid, const QXmppPresence &presence)
void itemRemoved(const QString &bareJid)
QXmppPresence getPresence(const QString &bareJid, const QString &resource) const
Definition QXmppRosterManager.cpp:683
QStringList getRosterBareJids() const
Definition QXmppRosterManager.cpp:624
void itemChanged(const QString &bareJid)
void itemAdded(const QString &bareJid)
QXmppRosterManager(QXmppClient *stream)
Definition QXmppRosterManager.cpp:123
QStringList getResources(const QString &bareJid) const
Definition QXmppRosterManager.cpp:651
void presenceChanged(const QString &bareJid, const QString &resource)
This signal is emitted when the presence of a particular bareJid and resource changes.
std::variant< QXmpp::Success, QXmppError > Result
Empty result containing QXmpp::Success or a QXmppError.
Definition QXmppRosterManager.h:89
Definition QXmppTask.h:62