/* * libretroshare/src/serialiser: rschatitems.h * * RetroShare Serialiser. * * Copyright 2007-2008 by Robert Fernie. * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Library General Public * License Version 2 as published by the Free Software Foundation. * * 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 * Library General Public License for more details. * * You should have received a copy of the GNU Library General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 * USA. * * Please report all bugs and problems to "retroshare@lunamutt.com". * */ #pragma once #include "retroshare/rstypes.h" #include "serialiser/rstlvkeys.h" #include "serialiser/rsserviceids.h" #include "serialiser/rsserial.h" #include "serialiser/rstlvidset.h" #include "serialiser/rstlvfileitem.h" /* chat Flags */ const uint32_t RS_GXS_TUNNEL_FLAG_CLOSING_DISTANT_CONNECTION = 0x0400; const uint32_t RS_GXS_TUNNEL_FLAG_ACK_DISTANT_CONNECTION = 0x0800; const uint32_t RS_GXS_TUNNEL_FLAG_KEEP_ALIVE = 0x1000; const uint8_t RS_PKT_SUBTYPE_GXS_TUNNEL_DATA = 0x01 ; const uint8_t RS_PKT_SUBTYPE_GXS_TUNNEL_DH_PUBLIC_KEY = 0x02 ; const uint8_t RS_PKT_SUBTYPE_GXS_TUNNEL_STATUS = 0x03 ; const uint8_t RS_PKT_SUBTYPE_GXS_TUNNEL_DATA_ACK = 0x04 ; typedef uint64_t GxsTunnelDHSessionId ; class RsGxsTunnelItem: public RsItem { public: RsGxsTunnelItem(uint8_t item_subtype) : RsItem(RS_PKT_VERSION_SERVICE,RS_SERVICE_TYPE_GXS_TUNNEL,item_subtype) { setPriorityLevel(QOS_PRIORITY_RS_CHAT_ITEM) ; } virtual ~RsGxsTunnelItem() {} virtual void clear() {} virtual std::ostream& print(std::ostream &out, uint16_t indent = 0) = 0 ; virtual bool serialise(void *data,uint32_t& size) = 0 ; // Isn't it better that items can serialize themselves ? virtual uint32_t serial_size() = 0 ; // deserialise is handled using a constructor }; // /*! // * For sending distant communication data. The item is not encrypted after being serialised, but the data it. // * The MAC is computed over encrypted data using the PFS key. All other items (except DH keys) are serialised, encrypted, and // * sent as data in a RsGxsTunnelDataItem. // * // * @see p3GxsTunnelService // */ // class RsGxsTunnelDataItem: public RsGxsTunnelItem // { // public: // RsGxsTunnelDataItem() :RsGxsTunnelItem(RS_PKT_SUBTYPE_GXS_TUNNEL_DATA) {} // RsGxsTunnelDataItem(uint8_t subtype) :RsGxsTunnelItem(subtype) {} // // virtual ~RsGxsTunnelDataItem() {} // virtual void clear() {} // virtual std::ostream& print(std::ostream &out, uint16_t indent = 0); // // virtual bool serialise(void *data,uint32_t& size) ; // Isn't it better that items can serialize themselves ? // virtual uint32_t serial_size() ; // deserialise is handled using a constructor // // uint32_t sendTime; // uint32_t flags; // mainly NEEDS_HACK? // unsigned char *data ; // encrypted data // uint32_t data_size ; // encrypted data size // unsigned char IV[IV_LENGTH] ; // IV for the encrypted data // unsigned char encrypted_data_mac[SHA_DIGEST_LENGTH] ; // mac of the encrypted data, in order to avoid // }; // Used to send status of connection. This can be closing orders, flushing orders, etc. // These items are always sent encrypted. class RsGxsTunnelStatusItem: public RsGxsTunnelItem { public: RsGxsTunnelStatusItem() :RsGxsTunnelItem(RS_PKT_SUBTYPE_GXS_TUNNEL_STATUS) {} RsGxsTunnelStatusItem(void *data,uint32_t size) ; // deserialization virtual ~RsGxsTunnelStatusItem() {} virtual std::ostream& print(std::ostream &out, uint16_t indent = 0); virtual bool serialise(void *data,uint32_t& size) ; // Isn't it better that items can serialize themselves ? virtual uint32_t serial_size() ; // deserialise is handled using a constructor uint32_t flags ; }; // Used to confirm reception of an encrypted item. class RsGxsTunnelDataAckItem: public RsGxsTunnelItem { public: RsGxsTunnelDataAckItem() :RsGxsTunnelItem(RS_PKT_SUBTYPE_GXS_TUNNEL_DATA_ACK) {} RsGxsTunnelDataAckItem(void *data,uint32_t size) ; // deserialization virtual ~RsGxsTunnelDataAckItem() {} virtual std::ostream& print(std::ostream &out, uint16_t indent = 0); virtual bool serialise(void *data,uint32_t& size) ; // Isn't it better that items can serialize themselves ? virtual uint32_t serial_size() ; // deserialise is handled using a constructor Sha1CheckSum data_hash ; }; // This class contains the public Diffie-Hellman parameters to be sent // when performing a DH agreement over a distant chat tunnel. // class RsGxsTunnelDHPublicKeyItem: public RsGxsTunnelItem { public: RsGxsTunnelDHPublicKeyItem() :RsGxsTunnelItem(RS_PKT_SUBTYPE_DISTANT_CHAT_DH_PUBLIC_KEY) {} RsGxsTunnelDHPublicKeyItem(void *data,uint32_t size) ; // deserialization virtual ~RsGxsTunnelDHPublicKeyItem() { BN_free(public_key) ; } virtual std::ostream& print(std::ostream &out, uint16_t indent = 0); virtual bool serialise(void *data,uint32_t& size) ; // Isn't it better that items can serialize themselves ? virtual uint32_t serial_size() ; // deserialise is handled using a constructor // Private data to DH public key item // BIGNUM *public_key ; RsTlvKeySignature signature ; // signs the public key in a row. RsTlvSecurityKey gxs_key ; // public key of the signer private: // make the object non copy-able RsGxsTunnelDHPublicKeyItem(const RsGxsTunnelDHPublicKeyItem&) : RsGxsTunnelItem(RS_PKT_SUBTYPE_GXS_TUNNEL_DH_PUBLIC_KEY) {} const RsGxsTunnelDHPublicKeyItem& operator=(const RsGxsTunnelDHPublicKeyItem&) { return *this ;} }; class RsGxsTunnelSerialiser: public RsSerialType { public: RsGxsTunnelSerialiser() :RsSerialType(RS_PKT_VERSION_SERVICE, RS_SERVICE_TYPE_GXS_TUNNEL) {} virtual uint32_t size (RsItem *item) { return static_cast(item)->serial_size() ; } virtual bool serialise(RsItem *item, void *data, uint32_t *size) { return static_cast(item)->serialise(data,*size) ; } virtual RsItem *deserialise (void *data, uint32_t *size) ; };