1
0
mirror of https://github.com/clementine-player/Clementine synced 2025-01-01 20:38:06 +01:00
Clementine-audio-player-Mac.../3rdparty/libxrme/connection.h
John Maguire 18bfa12042 Add the beginnings of an ICE socket implementation.
Currently, it can be demoed using --stun-test and the icedemo from pjsip as the other client.
TODOs:
Add ability to do a full demo using only 2 clementine instances.
Complete session initiation over XMPP.
Add local & port forwarded sockets as options.
2011-04-07 13:38:27 +00:00

174 lines
5.5 KiB
C++

/* This file is part of the XMPP Remote Media Extension.
Copyright 2010, David Sansome <me@davidsansome.com>
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License
as published by the Free Software Foundation; either version 2
of the License, or (at your option) any later version.
This program 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 General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef LIBXRME_CONNECTION_H
#define LIBXRME_CONNECTION_H
#include <QHostAddress>
#include <QObject>
#include <QPair>
#include <QScopedPointer>
#include <QString>
namespace xrme {
class MediaPlayerInterface;
class MediaStorageInterface;
class RemoteControlInterface;
struct SIPInfo {
QString user_fragment;
QString password;
struct Candidate {
QHostAddress address;
quint16 port;
QString type;
int component;
int priority;
QString foundation;
};
QList<Candidate> candidates;
};
class Connection : public QObject {
Q_OBJECT
public:
Connection(QObject* parent = NULL);
~Connection();
struct Peer {
Peer();
enum Capability {
None = 0x00,
MediaPlayer = 0x01,
RemoteControl = 0x02,
MediaStorage = 0x04,
};
Q_DECLARE_FLAGS(Capabilities, Capability);
QString agent_name_;
QString jid_resource_;
Capabilities caps_;
};
typedef QList<Peer> PeerList;
// The username and password MUST be set before calling Connect().
void set_username(const QString& username);
void set_password(const QString& password);
// The agent name MUST be set before calling Connect(). The agent name is a
// friendly user-visible name assigned to this agent to help the user pick it
// out amongst other media players or remotes. It might contain the name of
// the application or the computer's hostname.
void set_agent_name(const QString& agent_name);
// Sets the hostname of the XMPP server to connect to. Defaults to
// "talk.google.com".
void set_server(const QString& server);
// Sets the resource string to use in the JID. Defaults to "xrmeagent".
void set_jid_resource(const QString& resource);
// Sets the host part to append to the JID if the user didn't specify one in
// the username. The host part is the part of the JID after the @ and before
// the /, eg: "username@host/resource". Defaults to "gmail.com".
void set_jid_host(const QString& host);
// If this is set then detailed XMPP output will be printed. Defaults to off.
void set_verbose(bool verbose);
// The following getters just return the data set above.
QString username() const;
QString password() const;
QString agent_name() const;
QString server() const;
QString jid_resource() const;
QString jid_host() const;
bool is_verbose() const;
// Sets a media player on the connection. Calling this means the XRME agent
// will advertise itself as a media player, and will be able to controlled by
// remote control agents. Should be called before calling Connect(). The
// Connection will NOT take ownership of the MediaPlayerInterface, and the
// MediaPlayerInterface MUST stay alive for as long as the connection.
void SetMediaPlayer(MediaPlayerInterface* iface);
// Sets a remote control on the connection. Calling this means the XRME agent
// will advertise itself as a remote control, and will receive state changes
// from media player agents. Should be called before calling Connect(). The
// Connection will NOT take ownership of the RemoteControlInterface, and the
// RemoteControlInterface MUST stay alive for as long as the connection.
void SetRemoteControl(RemoteControlInterface* iface);
void SetMediaStorage(MediaStorageInterface* iface);
// Returns true after Connected() is emitted.
bool is_connected() const;
// Returns the user's actual JID. This is only valid if is_connected() is
// true. Before the connection is complete it will return a null QString.
QString jid() const;
// Returns the list of all known peers. You can refresh this list by calling
// RefreshPeers(). PeerFound() is emitted any time a peer is added to this
// list.
PeerList peers() const;
// Returns the list of known peers that support a certain capability.
PeerList peers(Peer::Capability cap) const;
public slots:
// Starts connecting and returns immediately. Will emit Connected() or
// Disconnected() later. The username and password must already be set.
// Returns true on success, false if there was some problem starting the
// connection (eg. invalid/unspecified username/password/agent_name).
bool Connect();
// Disconnects immediately and emits Disconnected().
void Disconnect();
// Clears the internal list of peers and sends XMPP queries to discover the
// current list. Emits PeerFound().
void RefreshPeers();
signals:
void Connected();
void Disconnected(const QString& error);
void PeerFound(const xrme::Connection::Peer& peer);
void PeerRemoved(const xrme::Connection::Peer& peer);
void TomahawkSIPReceived(const QVariant& json);
private slots:
void SocketReadyReceive();
void CleanupClient();
private:
struct Private;
friend struct Private;
QScopedPointer<Private> d;
};
} // namespace xrme
#endif