X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcommon%2Fprotocol.h;h=053ab29b83c8b5779c6841c576ed0820c26b34a6;hp=89ef40731840fb2535fdabf09a9dd8b026eff7ef;hb=9e21879f361dfe9978fb5159664cae352301064b;hpb=02bebb4c8f1c45397c55f1660176bfa0c303e703 diff --git a/src/common/protocol.h b/src/common/protocol.h index 89ef4073..053ab29b 100644 --- a/src/common/protocol.h +++ b/src/common/protocol.h @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-2013 by the Quassel Project * + * Copyright (C) 2005-2014 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -27,17 +27,27 @@ namespace Protocol { +const quint32 magic = 0x42b33f00; + enum Type { - LegacyProtocol = 1 + LegacyProtocol = 0x01, + DataStreamProtocol = 0x02 +}; + + +enum Feature { + Encryption = 0x01, + Compression = 0x02 }; + enum Handler { SignalProxy, AuthHandler }; -/*** Handshake, handled by AuthHandler ***/ +/*** Handshake, handled by AuthHandler ***/ struct HandshakeMessage { inline Handler handler() const { return AuthHandler; } @@ -46,11 +56,13 @@ struct HandshakeMessage { struct RegisterClient : public HandshakeMessage { - inline RegisterClient(const QString &clientVersion, bool sslSupported = false) + inline RegisterClient(const QString &clientVersion, const QString &buildDate, bool sslSupported = false) : clientVersion(clientVersion) + , buildDate(buildDate) , sslSupported(sslSupported) {} QString clientVersion; + QString buildDate; // this is only used by the LegacyProtocol in compat mode bool sslSupported; @@ -141,6 +153,7 @@ struct LoginSuccess : public HandshakeMessage // TODO: more generic format struct SessionState : public HandshakeMessage { + inline SessionState() {} // needed for QMetaType (for the mono client) inline SessionState(const QVariantList &identities, const QVariantList &bufferInfos, const QVariantList &networkIds) : identities(identities), bufferInfos(bufferInfos), networkIds(networkIds) {} @@ -149,7 +162,6 @@ struct SessionState : public HandshakeMessage QVariantList networkIds; }; - /*** handled by SignalProxy ***/ struct SignalProxyMessage