X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcommon%2Fnetwork.h;h=84e86998fcb8f60d47cb1554ce5374e1ee7fe25c;hp=196943028f9467bf5c1be60c2c3ed0942d5cc8db;hb=a5dfcc8ecf8b81025d24b3c5c816169e3e030ea4;hpb=61f42c7c9d0e5428512287f97ded31448741f2da diff --git a/src/common/network.h b/src/common/network.h index 19694302..84e86998 100644 --- a/src/common/network.h +++ b/src/common/network.h @@ -18,10 +18,9 @@ * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * ***************************************************************************/ -#ifndef _NETWORK_H_ -#define _NETWORK_H_ +#ifndef NETWORK_H +#define NETWORK_H -#include #include #include #include @@ -33,9 +32,9 @@ #include "types.h" #include "syncableobject.h" -class SignalProxy; -class IrcUser; -class IrcChannel; +#include "signalproxy.h" +#include "ircuser.h" +#include "ircchannel.h" // defined below! struct NetworkInfo; @@ -49,45 +48,105 @@ class Network : public SyncableObject { Q_PROPERTY(QString networkName READ networkName WRITE setNetworkName STORED false) Q_PROPERTY(QString currentServer READ currentServer WRITE setCurrentServer STORED false) Q_PROPERTY(QString myNick READ myNick WRITE setMyNick STORED false) + Q_PROPERTY(int latency READ latency WRITE setLatency STORED false) + Q_PROPERTY(QByteArray codecForServer READ codecForServer WRITE setCodecForServer STORED false) Q_PROPERTY(QByteArray codecForEncoding READ codecForEncoding WRITE setCodecForEncoding STORED false) Q_PROPERTY(QByteArray codecForDecoding READ codecForDecoding WRITE setCodecForDecoding STORED false) Q_PROPERTY(IdentityId identityId READ identity WRITE setIdentity STORED false) Q_PROPERTY(bool isConnected READ isConnected WRITE setConnected STORED false) //Q_PROPERTY(Network::ConnectionState connectionState READ connectionState WRITE setConnectionState STORED false) Q_PROPERTY(int connectionState READ connectionState WRITE setConnectionState STORED false) + Q_PROPERTY(bool useRandomServer READ useRandomServer WRITE setUseRandomServer STORED false) + Q_PROPERTY(QStringList perform READ perform WRITE setPerform STORED false) + Q_PROPERTY(bool useAutoIdentify READ useAutoIdentify WRITE setUseAutoIdentify STORED false) + Q_PROPERTY(QString autoIdentifyService READ autoIdentifyService WRITE setAutoIdentifyService STORED false) + Q_PROPERTY(QString autoIdentifyPassword READ autoIdentifyPassword WRITE setAutoIdentifyPassword STORED false) + Q_PROPERTY(bool useAutoReconnect READ useAutoReconnect WRITE setUseAutoReconnect STORED false) + Q_PROPERTY(quint32 autoReconnectInterval READ autoReconnectInterval WRITE setAutoReconnectInterval STORED false) + Q_PROPERTY(quint16 autoReconnectRetries READ autoReconnectRetries WRITE setAutoReconnectRetries STORED false) + Q_PROPERTY(bool unlimitedReconnectRetries READ unlimitedReconnectRetries WRITE setUnlimitedReconnectRetries STORED false) + Q_PROPERTY(bool rejoinChannels READ rejoinChannels WRITE setRejoinChannels STORED false) public: - enum ConnectionState { Disconnected, Connecting, Initializing, Initialized, Disconnecting }; + enum ConnectionState { + Disconnected, + Connecting, + Initializing, + Initialized, + Reconnecting, + Disconnecting + }; + + // see: + // http://www.irc.org/tech_docs/005.html + // http://www.irc.org/tech_docs/draft-brocklesby-irc-isupport-03.txt + enum ChannelModeType { + NOT_A_CHANMODE = 0x00, + A_CHANMODE = 0x01, + B_CHANMODE = 0x02, + C_CHANMODE = 0x04, + D_CHANMODE = 0x08 + }; + + struct Server { + QString host; + uint port; + QString password; + bool useSsl; + Server() : port(0), useSsl(false) {} + Server(const QString &host, uint port, const QString &password, bool useSsl) + : host(host), port(port), password(password), useSsl(useSsl) {} + + static Server fromVariant(const QVariant &variant); + QVariant toVariant() const; + }; + typedef QList ServerList; Network(const NetworkId &networkid, QObject *parent = 0); ~Network(); - NetworkId networkId() const; + inline NetworkId networkId() const { return _networkId; } - SignalProxy *proxy() const; - void setProxy(SignalProxy *proxy); + inline SignalProxy *proxy() const { return _proxy; } + inline void setProxy(SignalProxy *proxy) { _proxy = proxy; } - bool isMyNick(const QString &nick) const; - bool isMe(IrcUser *ircuser) const; + inline bool isMyNick(const QString &nick) const { return (myNick().toLower() == nick.toLower()); } + inline bool isMe(IrcUser *ircuser) const { return (ircuser->nick().toLower() == myNick().toLower()); } bool isChannelName(const QString &channelname) const; - bool isConnected() const; + inline bool isConnected() const { return _connected; } //Network::ConnectionState connectionState() const; - int connectionState() const; + inline int connectionState() const { return _connectionState; } QString prefixToMode(const QString &prefix); - QString prefixToMode(const QCharRef &prefix); + inline QString prefixToMode(const QCharRef &prefix) { return prefixToMode(QString(prefix)); } QString modeToPrefix(const QString &mode); - QString modeToPrefix(const QCharRef &mode); + inline QString modeToPrefix(const QCharRef &mode) { return modeToPrefix(QString(mode)); } - QString networkName() const; - QString currentServer() const; - QString myNick() const; - IdentityId identity() const; + ChannelModeType channelModeType(const QString &mode); + inline ChannelModeType channelModeType(const QCharRef &mode) { return channelModeType(QString(mode)); } + + inline const QString &networkName() const { return _networkName; } + inline const QString ¤tServer() const { return _currentServer; } + inline const QString &myNick() const { return _myNick; } + inline int latency() const { return _latency; } + inline IrcUser *me() const { return ircUser(myNick()); } + inline IdentityId identity() const { return _identity; } QStringList nicks() const; - QStringList channels() const; - QVariantList serverList() const; + inline QStringList channels() const { return _ircChannels.keys(); } + inline const ServerList &serverList() const { return _serverList; } + QVariantList variantServerList() const; + inline bool useRandomServer() const { return _useRandomServer; } + inline const QStringList &perform() const { return _perform; } + inline bool useAutoIdentify() const { return _useAutoIdentify; } + inline const QString &autoIdentifyService() const { return _autoIdentifyService; } + inline const QString &autoIdentifyPassword() const { return _autoIdentifyPassword; } + inline bool useAutoReconnect() const { return _useAutoReconnect; } + inline quint32 autoReconnectInterval() const { return _autoReconnectInterval; } + inline quint16 autoReconnectRetries() const { return _autoReconnectRetries; } + inline bool unlimitedReconnectRetries() const { return _unlimitedReconnectRetries; } + inline bool rejoinChannels() const { return _rejoinChannels; } NetworkInfo networkInfo() const; void setNetworkInfo(const NetworkInfo &); @@ -95,42 +154,67 @@ public: QString prefixes(); QString prefixModes(); - bool supports(const QString ¶m) const; + bool supports(const QString ¶m) const { return _supports.contains(param); } QString support(const QString ¶m) const; - IrcUser *newIrcUser(const QString &hostmask); - IrcUser *newIrcUser(const QByteArray &hostmask); + IrcUser *newIrcUser(const QString &hostmask, const QVariantMap &initData = QVariantMap()); + inline IrcUser *newIrcUser(const QByteArray &hostmask) { return newIrcUser(decodeServerString(hostmask)); } IrcUser *ircUser(QString nickname) const; - IrcUser *ircUser(const QByteArray &nickname) const; - QList ircUsers() const; - quint32 ircUserCount() const; + inline IrcUser *ircUser(const QByteArray &nickname) const { return ircUser(decodeServerString(nickname)); } + inline QList ircUsers() const { return _ircUsers.values(); } + inline quint32 ircUserCount() const { return _ircUsers.count(); } - IrcChannel *newIrcChannel(const QString &channelname); - IrcChannel *newIrcChannel(const QByteArray &channelname); + IrcChannel *newIrcChannel(const QString &channelname, const QVariantMap &initData = QVariantMap()); + inline IrcChannel *newIrcChannel(const QByteArray &channelname) { return newIrcChannel(decodeServerString(channelname)); } IrcChannel *ircChannel(QString channelname) const; - IrcChannel *ircChannel(const QByteArray &channelname) const; - QList ircChannels() const; - quint32 ircChannelCount() const; + inline IrcChannel *ircChannel(const QByteArray &channelname) const { return ircChannel(decodeServerString(channelname)); } + inline QList ircChannels() const { return _ircChannels.values(); } + inline quint32 ircChannelCount() const { return _ircChannels.count(); } + QByteArray codecForServer() const; QByteArray codecForEncoding() const; QByteArray codecForDecoding() const; + void setCodecForServer(QTextCodec *codec); void setCodecForEncoding(QTextCodec *codec); void setCodecForDecoding(QTextCodec *codec); QString decodeString(const QByteArray &text) const; - QByteArray encodeString(const QString string) const; + QByteArray encodeString(const QString &string) const; + QString decodeServerString(const QByteArray &text) const; + QByteArray encodeServerString(const QString &string) const; + + static QByteArray defaultCodecForServer(); + static QByteArray defaultCodecForEncoding(); + static QByteArray defaultCodecForDecoding(); + static void setDefaultCodecForServer(const QByteArray &name); + static void setDefaultCodecForEncoding(const QByteArray &name); + static void setDefaultCodecForDecoding(const QByteArray &name); + + inline bool autoAwayActive() const { return _autoAwayActive; } + inline void setAutoAwayActive(bool active) { _autoAwayActive = active; } public slots: void setNetworkName(const QString &networkName); void setCurrentServer(const QString ¤tServer); void setConnected(bool isConnected); - //void setConnectionState(Network::ConnectionState state); void setConnectionState(int state); - void setMyNick(const QString &mynick); + virtual void setMyNick(const QString &mynick); + void setLatency(int latency); void setIdentity(IdentityId); void setServerList(const QVariantList &serverList); - + void setUseRandomServer(bool); + void setPerform(const QStringList &); + void setUseAutoIdentify(bool); + void setAutoIdentifyService(const QString &); + void setAutoIdentifyPassword(const QString &); + virtual void setUseAutoReconnect(bool); + virtual void setAutoReconnectInterval(quint32); + virtual void setAutoReconnectRetries(quint16); + void setUnlimitedReconnectRetries(bool); + void setRejoinChannels(bool); + + void setCodecForServer(const QByteArray &codecName); void setCodecForEncoding(const QByteArray &codecName); void setCodecForDecoding(const QByteArray &codecName); @@ -138,39 +222,37 @@ public slots: void removeSupport(const QString ¶m); inline void addIrcUser(const QString &hostmask) { newIrcUser(hostmask); } - void removeIrcUser(QString nick); - + inline void addIrcChannel(const QString &channel) { newIrcChannel(channel); } + //init geters QVariantMap initSupports() const; - QVariantList initServerList() const; - QStringList initIrcUsers() const; - QStringList initIrcChannels() const; - + inline QVariantList initServerList() const { return variantServerList(); } + virtual QVariantMap initIrcUsersAndChannels() const; + //init seters void initSetSupports(const QVariantMap &supports); void initSetServerList(const QVariantList &serverList); - void initSetIrcUsers(const QStringList &hostmasks); - void initSetChannels(const QStringList &channels); - + virtual void initSetIrcUsersAndChannels(const QVariantMap &usersAndChannels); + IrcUser *updateNickFromMask(const QString &mask); // these slots are to keep the hashlists of all users and the // channel lists up to date void ircUserNickChanged(QString newnick); - void requestConnect() const; - void requestDisconnect() const; + virtual inline void requestConnect() const { emit connectRequested(); } + virtual inline void requestDisconnect() const { emit disconnectRequested(); } + virtual inline void requestSetNetworkInfo(const NetworkInfo &info) { emit setNetworkInfoRequested(info); } void emitConnectionError(const QString &); private slots: - void ircUserDestroyed(); - void channelDestroyed(); void removeIrcUser(IrcUser *ircuser); - void ircUserInitDone(); - void ircChannelInitDone(); + void removeIrcChannel(IrcChannel *ircChannel); + void removeChansAndUsers(); signals: + void aboutToBeDestroyed(); void networkNameSet(const QString &networkName); void currentServerSet(const QString ¤tServer); void connectedSet(bool isConnected); @@ -178,12 +260,24 @@ signals: void connectionStateSet(int); void connectionError(const QString &errorMsg); void myNickSet(const QString &mynick); + void latencySet(int latency); void identitySet(IdentityId); void serverListSet(QVariantList serverList); - - void codecForEncodingSet(const QString &codecName); - void codecForDecodingSet(const QString &codecName); + void useRandomServerSet(bool); + void performSet(const QStringList &); + void useAutoIdentifySet(bool); + void autoIdentifyServiceSet(const QString &); + void autoIdentifyPasswordSet(const QString &); + void useAutoReconnectSet(bool); + void autoReconnectIntervalSet(quint32); + void autoReconnectRetriesSet(quint16); + void unlimitedReconnectRetriesSet(bool); + void rejoinChannelsSet(bool); + + void codecForServerSet(const QByteArray &codecName); + void codecForEncodingSet(const QByteArray &codecName); + void codecForDecodingSet(const QByteArray &codecName); void supportAdded(const QString ¶m, const QString &value); void supportRemoved(const QString ¶m); @@ -193,23 +287,21 @@ signals: void ircChannelAdded(const QString &channelname); void ircChannelAdded(IrcChannel *); - void ircUserRemoved(const QString &nick); - - // needed for client sync progress - void ircUserRemoved(QObject *); - void ircChannelRemoved(QObject *); + void connectRequested() const; + void disconnectRequested() const; + void setNetworkInfoRequested(const NetworkInfo &) const; - void ircUserInitDone(IrcUser *); - void ircChannelInitDone(IrcChannel *); - - void connectRequested(NetworkId id = 0) const; - void disconnectRequested(NetworkId id = 0) const; +protected: + inline virtual IrcChannel *ircChannelFactory(const QString &channelname) { return new IrcChannel(channelname, this); } private: + QPointer _proxy; + NetworkId _networkId; IdentityId _identity; QString _myNick; + int _latency; QString _networkName; QString _currentServer; bool _connected; @@ -222,16 +314,34 @@ private: QHash _ircChannels; // stores all known channels QHash _supports; // stores results from RPL_ISUPPORT - QVariantList _serverList; + ServerList _serverList; + bool _useRandomServer; QStringList _perform; - //QVariantMap networkSettings; - QPointer _proxy; + bool _useAutoIdentify; + QString _autoIdentifyService; + QString _autoIdentifyPassword; + + bool _useAutoReconnect; + quint32 _autoReconnectInterval; + quint16 _autoReconnectRetries; + bool _unlimitedReconnectRetries; + bool _rejoinChannels; + void determinePrefixes(); + QTextCodec *_codecForServer; QTextCodec *_codecForEncoding; QTextCodec *_codecForDecoding; + static QTextCodec *_defaultCodecForServer; + static QTextCodec *_defaultCodecForEncoding; + static QTextCodec *_defaultCodecForDecoding; + + bool _autoAwayActive; // when this is active handle305 and handle306 don't trigger any output + + friend class IrcUser; + friend class IrcChannel; }; //! Stores all editable information about a network (as opposed to runtime state). @@ -240,7 +350,8 @@ struct NetworkInfo { QString networkName; IdentityId identity; - bool useCustomEncodings; + bool useCustomEncodings; // not used! + QByteArray codecForServer; QByteArray codecForEncoding; QByteArray codecForDecoding; @@ -256,7 +367,8 @@ struct NetworkInfo { bool useAutoReconnect; quint32 autoReconnectInterval; - qint16 autoReconnectRetries; // -1 => Unlimited + quint16 autoReconnectRetries; + bool unlimitedReconnectRetries; bool rejoinChannels; bool operator==(const NetworkInfo &other) const; @@ -265,7 +377,8 @@ struct NetworkInfo { QDataStream &operator<<(QDataStream &out, const NetworkInfo &info); QDataStream &operator>>(QDataStream &in, NetworkInfo &info); +QDebug operator<<(QDebug dbg, const NetworkInfo &i); -Q_DECLARE_METATYPE(NetworkInfo); +Q_DECLARE_METATYPE(NetworkInfo) #endif