blob: d05b29fa5f0ce750986c652785113dfd7ec9d017 (
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-2019 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 <QAbstractSocket>
#include <QObject>
#include "QXmppLogger.h"
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();
virtual bool isConnected() const;
bool sendPacket(const QXmppStanza&);
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 slots:
virtual void disconnectFromHost();
virtual bool sendData(const QByteArray&);
private slots:
void _q_socketConnected();
void _q_socketEncrypted();
void _q_socketError(QAbstractSocket::SocketError error);
void _q_socketReadyRead();
private:
QXmppStreamPrivate * const d;
};
#endif // QXMPPSTREAM_H
|