summaryrefslogtreecommitdiff
path: root/qt4/TelepathyQt4/stream-tube-server.h
blob: ddd447ffe0764fe2055e0cb13fff1738aaaf4a93 (plain)
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
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
/**
 * This file is part of TelepathyQt4
 *
 * @copyright Copyright (C) 2011 Collabora Ltd. <http://www.collabora.co.uk/>
 * @copyright Copyright (C) 2011 Nokia Corporation
 * @license LGPL 2.1
 *
 * 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.
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with this library; if not, write to the Free Software
 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
 */

#ifndef _TelepathyQt4_stream_tube_server_h_HEADER_GUARD_
#define _TelepathyQt4_stream_tube_server_h_HEADER_GUARD_

#include <TelepathyQt4/AccountFactory>
#include <TelepathyQt4/ChannelFactory>
#include <TelepathyQt4/ConnectionFactory>
#include <TelepathyQt4/ContactFactory>
#include <TelepathyQt4/RefCounted>
#include <TelepathyQt4/Types>

class QHostAddress;
class QTcpServer;

namespace Tp
{

// TODO: Turn the comments here into real doxymentation
class TELEPATHY_QT4_EXPORT StreamTubeServer : public QObject, public RefCounted
{
    Q_OBJECT
    Q_DISABLE_COPY(StreamTubeServer)

    class TubeWrapper;

public:

    class ParametersGenerator
    {
    public:
        virtual QVariantMap
            nextParameters(const AccountPtr &account, const OutgoingStreamTubeChannelPtr &tube,
                    const ChannelRequestHints &hints) = 0;

    protected:
        virtual ~ParametersGenerator() {}
    };

    // The client name can be passed to allow service-activation. If service activation is not
    // desired, the name can be left out, in which case an unique name will be generated.

    // Different parameter order, because name and service are mandatory params so they can't follow
    // the factory params which have default args
    static StreamTubeServerPtr create(
            const QStringList &p2pServices,
            const QStringList &roomServices = QStringList(),
            const QString &clientName = QString(),
            bool monitorConnections = false,
            const AccountFactoryConstPtr &accountFactory =
                AccountFactory::create(QDBusConnection::sessionBus()),
            const ConnectionFactoryConstPtr &connectionFactory =
                ConnectionFactory::create(QDBusConnection::sessionBus()),
            const ChannelFactoryConstPtr &channelFactory =
                ChannelFactory::create(QDBusConnection::sessionBus()),
            const ContactFactoryConstPtr &contactFactory =
                ContactFactory::create());

    static StreamTubeServerPtr create(
            const QDBusConnection &bus,
            const AccountFactoryConstPtr &accountFactory,
            const ConnectionFactoryConstPtr &connectionFactory,
            const ChannelFactoryConstPtr &channelFactory,
            const ContactFactoryConstPtr &contactFactory,
            const QStringList &p2pServices,
            const QStringList &roomServices = QStringList(),
            const QString &clientName = QString(),
            bool monitorConnections = false);

    static StreamTubeServerPtr create(
            const AccountManagerPtr &accountManager,
            const QStringList &p2pServices,
            const QStringList &roomServices = QStringList(),
            const QString &clientName = QString(),
            bool monitorConnections = false);

    static StreamTubeServerPtr create(
            const ClientRegistrarPtr &registrar,
            const QStringList &p2pServices,
            const QStringList &roomServices = QStringList(),
            const QString &clientName = QString(),
            bool monitorConnections = false);

    virtual ~StreamTubeServer();

    ClientRegistrarPtr registrar() const;
    QString clientName() const;
    bool isRegistered() const;
    bool monitorsConnections() const;

    // Recovery getters for the setters below
    QPair<QHostAddress, quint16> exportedTcpSocketAddress() const;
    QVariantMap exportedParameters() const;

    // These change the exported (Offer'ed) service to the given one for all future handled tubes
    // The first call to one of these actually registers the Handler
    //
    // The exported socket can be changed an arbitrary amount of times, as many networked applications
    // have a runtime setting for their listen port. This will of course only affect the handling of
    // future tubes.
    void exportTcpSocket(
            const QHostAddress &address,
            quint16 port,
            const QVariantMap &parameters = QVariantMap());
    void exportTcpSocket(
            const QTcpServer *server,
            const QVariantMap &parameters = QVariantMap());

    void exportTcpSocket(
            const QHostAddress &address,
            quint16 port,
            ParametersGenerator *generator);
    void exportTcpSocket(
            const QTcpServer *server,
            ParametersGenerator *generator);

    // TODO: Add Unix sockets if needed (are there other common services one might want to export
    // listening on Unix sockets and not necessarily on TCP than X11 and perhaps CUPS?)

    // This will always be populated
    QList<QPair<AccountPtr, OutgoingStreamTubeChannelPtr> > tubes() const;

    // This will be populated if monitorConnections = true and a TCP socket has been exported
    //
    // If the CM doesn't support Port AC (TCP), an invalid source address will be used as a key,
    // with multiple connections as values using insertMulti
    //
    // Given how complex the map becomes to relay all the necessary information, should we perhaps
    // leave this out? Then we wouldn't have full state-recoverability, though, and clients would
    // likely implement similar monster maps themselves.
    //
    // Including the tube channels themselves would complicate this even more, and wouldn't really
    // even help in any use case that I can think of.
    QHash<QPair<QHostAddress /* sourceAddress */, quint16 /* sourcePort */>, QPair<AccountPtr, ContactPtr> > tcpConnections() const;

Q_SIGNALS:

    // These will always be emitted
    void tubeRequested(
            const Tp::AccountPtr &account,
            const Tp::OutgoingStreamTubeChannelPtr &tube,
            const QDateTime &userActionTime,
            const Tp::ChannelRequestHints &hints);
    void tubeClosed(
            const Tp::AccountPtr &account,
            const Tp::OutgoingStreamTubeChannelPtr &tube,
            const QString &error,
            const QString &message);

    // These will be emitted if monitorConnections = true was passed to the create() method
    // and a TCP socket is exported
    //
    // If the CM doesn't support Port access control, sourceAddress and sourcePort won't be
    // informative. At least Gabble supports it, though.
    void newTcpConnection(
            const QHostAddress &sourceAddress,
            quint16 sourcePort,
            const Tp::AccountPtr &account,
            const Tp::ContactPtr &contact,
            const Tp::OutgoingStreamTubeChannelPtr &tube);
    void tcpConnectionClosed(
            const QHostAddress &sourceAddress,
            quint16 sourcePort,
            const Tp::AccountPtr &account,
            const Tp::ContactPtr &contact,
            const QString &error,
            const QString &message,
            const Tp::OutgoingStreamTubeChannelPtr &tube);

private Q_SLOTS:
    TELEPATHY_QT4_NO_EXPORT void onInvokedForTube(
            const Tp::AccountPtr &account,
            const Tp::StreamTubeChannelPtr &tube,
            const QDateTime &userActionTime,
            const Tp::ChannelRequestHints &requestHints);

    TELEPATHY_QT4_NO_EXPORT void onOfferFinished(
            TubeWrapper *wrapper,
            Tp::PendingOperation *op);
    TELEPATHY_QT4_NO_EXPORT void onTubeInvalidated(
            Tp::DBusProxy *proxy,
            const QString &error,
            const QString &message);

    TELEPATHY_QT4_NO_EXPORT void onNewConnection(
            TubeWrapper *wrapper,
            uint conn);
    TELEPATHY_QT4_NO_EXPORT void onConnectionClosed(
            TubeWrapper *wrapper,
            uint conn,
            const QString &error,
            const QString &message);

private:
    TELEPATHY_QT4_NO_EXPORT StreamTubeServer(
            const ClientRegistrarPtr &registrar,
            const QStringList &p2pServices,
            const QStringList &roomServices,
            const QString &clientName,
            bool monitorConnections);

    struct Private;
    Private *mPriv;
};

} // Tp

#endif