#ifndef RSNXSITEMS_H #define RSNXSITEMS_H /* * libretroshare/src/serialiser: rsnxssitems.h * * RetroShare Serialiser. * * Copyright 2012 Christopher Evi-Parker, 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". * */ #include #include "serialiser/rsserviceids.h" #include "serialiser/rsserial.h" #include "serialiser/rstlvbase.h" #include "serialiser/rstlvtypes.h" #include "serialiser/rstlvkeys.h" #include "gxs/rsgxsdata.h" const uint8_t RS_PKT_SUBTYPE_NXS_SYNC_GRP = 0x0001; const uint8_t RS_PKT_SUBTYPE_NXS_SYNC_GRP_ITEM = 0x0002; const uint8_t RS_PKT_SUBTYPE_NXS_GRP = 0x0004; const uint8_t RS_PKT_SUBTYPE_NXS_SYNC_MSG_ITEM = 0x0008; const uint8_t RS_PKT_SUBTYPE_NXS_SYNC_MSG = 0x0010; const uint8_t RS_PKT_SUBTYPE_NXS_MSG = 0x0020; const uint8_t RS_PKT_SUBTYPE_NXS_TRANS = 0x0040; // possibility create second service to deal with this functionality const uint8_t RS_PKT_SUBTYPE_NXS_EXTENDED = 0x0080; // in order to extend supported pkt subtypes const uint8_t RS_PKT_SUBTYPE_EXT_SEARCH_GRP = 0x0001; const uint8_t RS_PKT_SUBTYPE_EXT_SEARCH_MSG = 0x0002; const uint8_t RS_PKT_SUBTYPE_EXT_DELETE_GRP = 0x0004; const uint8_t RS_PKT_SUBTYPE_EXT_DELETE_MSG = 0x0008; const uint8_t RS_PKT_SUBTYPE_EXT_SEARCH_REQ = 0x0010; /*! * Base class for Network exchange service * Main purpose is for rtti based routing used in the * serialisation and deserialisation of NXS packets * * Service type is set by plugin service */ class RsNxsItem : public RsItem { public: RsNxsItem(uint16_t servtype, uint8_t subtype) : RsItem(RS_PKT_VERSION_SERVICE, servtype, subtype), transactionNumber(0) { setPriorityLevel(QOS_PRIORITY_RS_GXS_NET); return; } virtual void clear() = 0; virtual std::ostream &print(std::ostream &out, uint16_t indent = 0) = 0; uint32_t transactionNumber; // set to zero if this is not a transaction item }; /*! * Use to request grp list from peer * Server may advise client peer to use sync file * while serving his request. This results */ class RsNxsSyncGrp : public RsNxsItem { public: static const uint8_t FLAG_USE_SYNC_HASH; static const uint8_t FLAG_ONLY_CURRENT; // only send most current version of grps / ignores sync hash RsNxsSyncGrp(uint16_t servtype) : RsNxsItem(servtype, RS_PKT_SUBTYPE_NXS_SYNC_GRP) { clear(); return;} virtual void clear(); virtual std::ostream &print(std::ostream &out, uint16_t indent); uint8_t flag; // advises whether to use sync hash uint32_t syncAge; // how far back to sync data std::string syncHash; // use to determine if changes that have occured since last hash }; /*! * This RsNxsItem is for use in enabling transactions * in order to guaranttee a collection of item have been * received */ class RsNxsTransac : public RsNxsItem { public: static const uint16_t FLAG_STATE_MASK = 0xff; static const uint16_t FLAG_TYPE_MASK = 0xff00; /** transaction state **/ static const uint16_t FLAG_BEGIN_P1; static const uint16_t FLAG_BEGIN_P2; static const uint16_t FLAG_END_SUCCESS; static const uint16_t FLAG_CANCEL; static const uint16_t FLAG_END_FAIL_NUM; static const uint16_t FLAG_END_FAIL_TIMEOUT; static const uint16_t FLAG_END_FAIL_FULL; /** transaction type **/ static const uint16_t FLAG_TYPE_GRP_LIST_RESP; static const uint16_t FLAG_TYPE_MSG_LIST_RESP; static const uint16_t FLAG_TYPE_GRP_LIST_REQ; static const uint16_t FLAG_TYPE_MSG_LIST_REQ; static const uint16_t FLAG_TYPE_GRPS; static const uint16_t FLAG_TYPE_MSGS; RsNxsTransac(uint16_t servtype) : RsNxsItem(servtype, RS_PKT_SUBTYPE_NXS_TRANS) { clear(); return; } virtual ~RsNxsTransac() { return ; } virtual void clear(); virtual std::ostream &print(std::ostream &out, uint16_t indent); uint16_t transactFlag; uint32_t nItems; uint32_t timestamp; }; /*! * Use to send to peer list of grps * held by server peer */ class RsNxsSyncGrpItem : public RsNxsItem { public: static const uint8_t FLAG_REQUEST; static const uint8_t FLAG_RESPONSE; static const uint8_t FLAG_USE_SYNC_HASH; RsNxsSyncGrpItem(uint16_t servtype) : RsNxsItem(servtype, RS_PKT_SUBTYPE_NXS_SYNC_GRP_ITEM) { clear(); return ; } virtual ~RsNxsSyncGrpItem() { return; } virtual void clear(); virtual std::ostream &print(std::ostream &out, uint16_t indent); uint8_t flag; // request or response uint32_t publishTs; // to compare to Ts of receiving peer's grp of same id /// grpId of grp held by sending peer std::string grpId; }; /*! * Contains serialised group items * Each item corresponds to a group which needs to be * deserialised */ class RsNxsGrp : public RsNxsItem { public: RsNxsGrp(uint16_t servtype) : RsNxsItem(servtype, RS_PKT_SUBTYPE_NXS_GRP), grp(servtype), meta(servtype), metaData(NULL) { clear(); return; } virtual ~RsNxsGrp() { if(metaData) delete metaData; } virtual void clear(); virtual std::ostream &print(std::ostream &out, uint16_t indent); std::string grpId; /// group Id, needed to complete version Id (ncvi) RsTlvBinaryData grp; /// actual group data /*! * This should contains all data * which is not specific to the Gxs service data */ RsTlvBinaryData meta; // deserialised metaData, this is not serialised RsGxsGrpMetaData* metaData; }; /*! * Use to request list of msg held by peer * for a given group */ class RsNxsSyncMsg : public RsNxsItem { public: static const uint8_t FLAG_USE_SYNC_HASH; RsNxsSyncMsg(uint16_t servtype) : RsNxsItem(servtype, RS_PKT_SUBTYPE_NXS_SYNC_MSG) { clear(); return; } virtual void clear(); virtual std::ostream &print(std::ostream &out, uint16_t indent); std::string grpId; uint8_t flag; uint32_t syncAge; std::string syncHash; }; /*! * Use to send list msgs for a group held by * a peer */ class RsNxsSyncMsgItem : public RsNxsItem { public: static const uint8_t FLAG_REQUEST; static const uint8_t FLAG_RESPONSE; static const uint8_t FLAG_USE_SYNC_HASH; RsNxsSyncMsgItem(uint16_t servtype) : RsNxsItem(servtype, RS_PKT_SUBTYPE_NXS_SYNC_MSG_ITEM) { clear(); return; } virtual void clear(); virtual std::ostream &print(std::ostream &out, uint16_t indent); uint8_t flag; // response/req std::string grpId; std::string msgId; }; /*! * Used to respond to a RsGrpMsgsReq * with message items satisfying request */ class RsNxsMsg : public RsNxsItem { public: RsNxsMsg(uint16_t servtype) : RsNxsItem(servtype, RS_PKT_SUBTYPE_NXS_MSG), meta(servtype), msg(servtype), metaData(NULL) { clear(); return; } ~RsNxsMsg() { if(metaData) delete metaData; } virtual void clear(); virtual std::ostream &print(std::ostream &out, uint16_t indent); std::string grpId; /// group id, forms part of version id std::string msgId; /// msg id /*! * This should contains all the data * which is not specific to the Gxs service data */ RsTlvBinaryData meta; /*! * This contains Gxs specific data * only client of API knows who to decode this */ RsTlvBinaryData msg; RsGxsMsgMetaData* metaData; }; /*! * Used to request a search of user data */ class RsNxsSearchReq : public RsNxsItem { public: RsNxsSearchReq(uint16_t servtype): RsNxsItem(servtype, RS_PKT_SUBTYPE_EXT_SEARCH_REQ), serviceSearchItem(servtype) { return; } virtual ~RsNxsSearchReq() { return;} virtual void clear() { return;} virtual std::ostream &print(std::ostream &out, uint16_t /*indent*/) { return out; } uint8_t nHops; /// how many peers to jump to uint32_t token; // search token RsTlvBinaryData serviceSearchItem; // service aware of item class uint32_t expiration; // expiration date }; /*! * used to extend data types processed */ class RsNxsExtended : public RsNxsItem { public: RsNxsExtended(uint16_t servtype) : RsNxsItem(servtype, RS_PKT_SUBTYPE_NXS_EXTENDED), extData(servtype) { return; } virtual ~RsNxsExtended() { return; } virtual void clear() {} virtual std::ostream &print(std::ostream &out, uint16_t indent); RsTlvBinaryData extData; uint32_t type; }; /*! * Used to respond to a RsGrpSearchReq * with grpId/MsgIds that satisfy search request */ class RsNxsSearchResultMsg { public: RsNxsSearchResultMsg() : context(0) { return;} void clear() {} std::ostream &print(std::ostream &out, uint16_t /*indent*/) { return out; } uint32_t token; // search token to be redeemed RsTlvBinaryData context; // used by client service std::string msgId; std::string grpId; RsTlvKeySignature idSign; uint32_t expiration; // expiration date }; /*! * Used to respond to a RsGrpSearchReq * with grpId/MsgIds that satisfy search request */ class RsNxsSearchResultGrp { public: RsNxsSearchResultGrp(); void clear() {} std::ostream &print(std::ostream &out, uint16_t /*indent*/) { return out; } uint32_t token; // search token to be redeemed RsTlvBinaryData context; // used by client service std::string grpId; RsTlvKeySignature adminSign; uint32_t expiration; // expiration date }; class RsNxsDeleteMsg { public: RsNxsDeleteMsg() { return; } std::string msgId; std::string grpId; RsTlvKeySignature deleteSign; // ( msgId + grpId + msg data ) sign //TODO: add warning not to place msgId+grpId in msg! }; class RsNxsDeleteGrp { public: RsNxsDeleteGrp() { return;} std::string grpId; RsTlvKeySignature idSign; RsTlvKeySignature deleteSign; // (grpId + grp data) sign // TODO: add warning not to place grpId in msg }; class RsNxsSerialiser : public RsSerialType { public: RsNxsSerialiser(uint16_t servtype) : RsSerialType(RS_PKT_VERSION_SERVICE, servtype), SERVICE_TYPE(servtype) { return; } virtual ~RsNxsSerialiser() { return; } virtual uint32_t size(RsItem *item); virtual bool serialise(RsItem *item, void *data, uint32_t *size); virtual RsItem* deserialise(void *data, uint32_t *size); private: /* for RS_PKT_SUBTYPE_SYNC_GRP */ virtual uint32_t sizeNxsSyncGrp(RsNxsSyncGrp* item); virtual bool serialiseNxsSyncGrp(RsNxsSyncGrp *item, void *data, uint32_t *size); virtual RsNxsSyncGrp* deserialNxsSyncGrp(void *data, uint32_t *size); /* for RS_PKT_SUBTYPE_SYNC_GRP_ITEM */ virtual uint32_t sizeNxsSyncGrpItem(RsNxsSyncGrpItem* item); virtual bool serialiseNxsSyncGrpItem(RsNxsSyncGrpItem *item, void *data, uint32_t *size); virtual RsNxsSyncGrpItem* deserialNxsSyncGrpItem(void *data, uint32_t *size); /* for RS_PKT_SUBTYPE_NXS_GRP */ virtual uint32_t sizeNxsGrp(RsNxsGrp* item); virtual bool serialiseNxsGrp(RsNxsGrp *item, void *data, uint32_t *size); virtual RsNxsGrp* deserialNxsGrp(void *data, uint32_t *size); /* for RS_PKT_SUBTYPE_SYNC_MSG */ virtual uint32_t sizeNxsSyncMsg(RsNxsSyncMsg* item); virtual bool serialiseNxsSyncMsg(RsNxsSyncMsg *item, void *data, uint32_t *size); virtual RsNxsSyncMsg* deserialNxsSyncMsg(void *data, uint32_t *size); /* RS_PKT_SUBTYPE_SYNC_MSG_ITEM */ virtual uint32_t sizeNxsSyncMsgItem(RsNxsSyncMsgItem* item); virtual bool serialiseNxsSynMsgItem(RsNxsSyncMsgItem* item, void *data, uint32_t* size); virtual RsNxsSyncMsgItem* deserialNxsSyncMsgItem(void *data, uint32_t *size); /* RS_PKT_SUBTYPE_NXS_MSG */ virtual uint32_t sizeNxsMsg(RsNxsMsg* item); virtual bool serialiseNxsMsg(RsNxsMsg* item, void* data, uint32_t* size); virtual RsNxsMsg* deserialNxsMsg(void *data, uint32_t *size); /* RS_PKT_SUBTYPE_NXS_TRANS */ virtual uint32_t sizeNxsTrans(RsNxsTransac* item); virtual bool serialiseNxsTrans(RsNxsTransac* item, void* data, uint32_t* size); virtual RsNxsTransac* deserialNxsTrans(void* data, uint32_t *size); /* RS_PKT_SUBTYPE_EXTENDED */ virtual RsNxsExtended* deserialNxsExtended(void* data, uint32_t *size); virtual uint32_t sizeNxsExtended(RsNxsExtended* item); virtual bool serialiseNxsExtended(RsNxsExtended* item, void* data, uint32_t* size); private: const uint16_t SERVICE_TYPE; }; #endif // RSNXSITEMS_H