blob: ce1f62f965ee475d6e02253c2586619902050971 (
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
|
/*
* Copyright (C) 2008-2020 The QXmpp developers
*
* Authors:
* Manjeet Dahiya
* Jeremy Lainé
*
* Source:
* https://github.com/qxmpp-project/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 QXMPPSTREAM_H
#define QXMPPSTREAM_H
#include "QXmppLogger.h"
#include <QAbstractSocket>
#include <QObject>
class QDomElement;
class QSslSocket;
class QXmppStanza;
class QXmppStreamPrivate;
/// \brief The QXmppStream class is the base class for all XMPP streams.
///
class QXMPP_EXPORT QXmppStream : public QXmppLoggable
{
Q_OBJECT
public:
QXmppStream(QObject *parent);
~QXmppStream() override;
virtual bool isConnected() const;
bool sendPacket(const QXmppStanza &);
Q_SIGNALS:
/// This signal is emitted when the stream is connected.
void connected();
/// This signal is emitted when the stream is disconnected.
void disconnected();
protected:
// Access to underlying socket
QSslSocket *socket() const;
void setSocket(QSslSocket *socket);
// Overridable methods
virtual void handleStart();
/// Handles an incoming XMPP stanza.
///
/// \param element
virtual void handleStanza(const QDomElement &element) = 0;
/// Handles an incoming XMPP stream start.
///
/// \param element
virtual void handleStream(const QDomElement &element) = 0;
/// Enables Stream Management acks / reqs (\xep{0198}).
///
/// \param resetSeqno Indicates if the sequence numbers should be reset.
/// This must be done iff the stream is not resumed.
void enableStreamManagement(bool resetSequenceNumber);
/// Returns the sequence number of the last incoming stanza (\xep{0198}).
unsigned lastIncomingSequenceNumber() const;
/// Sets the last acknowledged sequence number for outgoing stanzas (\xep{0198}).
void setAcknowledgedSequenceNumber(unsigned sequenceNumber);
private:
/// Handles an incoming acknowledgement from \xep{0198}.
///
/// \param element
void handleAcknowledgement(QDomElement &element);
/// Sends an acknowledgement as defined in \xep{0198}.
void sendAcknowledgement();
/// Sends an acknowledgement request as defined in \xep{0198}.
void sendAcknowledgementRequest();
public Q_SLOTS:
virtual void disconnectFromHost();
virtual bool sendData(const QByteArray &);
private Q_SLOTS:
void _q_socketConnected();
void _q_socketEncrypted();
void _q_socketError(QAbstractSocket::SocketError error);
void _q_socketReadyRead();
private:
QXmppStreamPrivate *const d;
};
#endif // QXMPPSTREAM_H
|