#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" const uint8_t RS_PKT_SUBTYPE_SYNC_GRP = 0x0001; const uint8_t RS_PKT_SUBTYPE_SYNC_GRP_LIST = 0x0002; const uint8_t RS_PKT_SUBTYPE_GRPS_RESP = 0x0004; const uint8_t RS_PKT_SUBTYPE_SYNC_MSG = 0x0008; const uint8_t RS_PKT_SUBTYPE_SYNC_MSG_LIST = 0x0010; const uint8_t RS_PKT_SUBTYPE_MSG_RESP = 0x0020; const uint8_t RS_PKT_SUBTYPE_SEARCH_REQ = 0x0040; const uint8_t RS_PKT_SUBTYPE_SEARCH_RESP = 0x0080; /*! * 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) { return; } virtual void clear() = 0; virtual std::ostream &print(std::ostream &out, uint16_t indent = 0) = 0; }; /*! * Use to request grp list from peer * Server may advise client peer to use sync file * while serving his request. This results */ class RsSyncGrp : public RsNxsItem { public: static const uint8_t FLAG_USE_SYNC_HASH; RsSyncGrp(uint16_t servtype) : RsNxsItem(servtype, RS_PKT_SUBTYPE_SYNC_GRP) { 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 }; typedef std::map > SyncList; /*! * Use to send to peer list of grps * held by server peer */ class RsSyncGrpList : public RsNxsItem { public: static const uint8_t FLAG_REQUEST; static const uint8_t FLAG_RESPONSE; RsSyncGrpList(uint16_t servtype) : RsNxsItem(servtype, RS_PKT_SUBTYPE_SYNC_GRP_LIST) { return ; } virtual void clear(); virtual std::ostream &print(std::ostream &out, uint16_t indent); uint8_t flag; // request or response /// groups held by sending peer SyncList grps; // grpId/ n version pair }; /*! * Contains serialised group items * Each item corresponds to a group which needs to be * deserialised */ class RsGrpResp : public RsNxsItem { public: RsGrpResp(uint16_t servtype) : RsNxsItem(servtype, RS_PKT_SUBTYPE_GRPS_RESP) { return; } virtual void clear(); virtual std::ostream &print(std::ostream &out, uint16_t indent); std::list grps; /// each entry corresponds to a group item }; /*! * Use to request list of msg held by peer * for a given group */ class RsSyncGrpMsg : public RsNxsItem { public: static const uint8_t FLAG_USE_SYNC_HASH; RsSyncGrpMsg(uint16_t servtype) : RsNxsItem(servtype, RS_PKT_SUBTYPE_SYNC_MSG) {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 RsSyncGrpMsgList : public RsNxsItem { public: static const uint8_t FLAG_RESPONSE; static const uint8_t FLAG_REQUEST; RsSyncGrpMsgList(uint16_t servtype) : RsNxsItem(servtype, RS_PKT_SUBTYPE_SYNC_MSG_LIST) { return; } virtual void clear(); virtual std::ostream &print(std::ostream &out, uint16_t indent); uint8_t flag; // response/req std::string grpId; SyncList msgs; // msg/versions pairs }; /*! * Used to respond to a RsGrpMsgsReq * with message items satisfying request */ class RsGrpMsgResp : public RsNxsItem { public: RsGrpMsgResp(uint16_t servtype) : RsNxsItem(servtype, RS_PKT_SUBTYPE_MSG_RESP) { return; } virtual void clear(); virtual std::ostream &print(std::ostream &out, uint16_t indent); std::list msgs; // each entry corresponds to a message item }; /*! * Used to request a search of user data */ class RsNxsSearchReq : public RsNxsItem { public: RsNxsSearchReq(uint16_t servtype): RsNxsItem(servtype, RS_PKT_SUBTYPE_SEARCH_REQ), searchTerm(servtype) { return; } virtual void clear() {} virtual std::ostream &print(std::ostream &out, uint16_t indent) { return out; } uint16_t token; RsTlvBinaryData searchTerm; // service aware of item class }; /*! * Used to respond to a RsGrpSearchReq * with grpId/MsgIds that satisfy search request */ class RsNxsSearchResp : public RsNxsItem { public: RsNxsSearchResp(uint16_t servtype) : RsNxsItem(servtype, RS_PKT_SUBTYPE_SEARCH_RESP) { return; } virtual void clear() {} virtual std::ostream &print(std::ostream &out, uint16_t indent) { return out; } uint16_t token; // search token to be redeemed std::list msgs; // msgs with search terms present std::list grps; // grps with search terms present }; 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 sizeSyncGrp(RsSyncGrp* item); virtual bool serialiseSyncGrp(RsSyncGrp *item, void *data, uint32_t *size); virtual RsSyncGrp* deserialSyncGrp(void *data, uint32_t *size); /* for RS_PKT_SUBTYPE_SYNC_GRP_LIST */ virtual uint32_t sizeSyncGrpList(RsSyncGrpList* item); virtual bool serialiseSyncGrpList(RsSyncGrpList *item, void *data, uint32_t *size); virtual RsSyncGrpList* deserialSyncGrpList(void *data, uint32_t *size); /* for RS_PKT_SUBTYPE_GRPS_RESP */ virtual uint32_t sizeGrpResp(RsGrpResp* item); virtual bool serialiseGrpResp(RsGrpResp *item, void *data, uint32_t *size); virtual RsGrpResp* deserialGrpResp(void *data, uint32_t *size); /* for RS_PKT_SUBTYPE_SYNC_MSG */ virtual uint32_t sizeSyncGrpMsg(RsSyncGrpMsg* item); virtual bool serialiseSyncGrpMsg(RsSyncGrpMsg *item, void *data, uint32_t *size); virtual RsSyncGrpMsg* deserialSyncGrpMsg(void *data, uint32_t *size); /* RS_PKT_SUBTYPE_SYNC_MSG_LIST */ virtual uint32_t sizeSyncGrpMsgList(RsSyncGrpMsgList* item); virtual bool serialiseSynGrpMsgList(RsSyncGrpMsgList* item, void *data, uint32_t* size); virtual RsSyncGrpMsgList* deserialSyncGrpMsgList(void *data, uint32_t *size); /* RS_PKT_SUBTYPE_MSG_RESP */ virtual uint32_t sizeGrpMsgResp(RsGrpMsgResp* item); virtual bool serialiseGrpMsgResp(RsGrpMsgResp* item, void* data, uint32_t* size); virtual RsGrpMsgResp* deserialGrpMsgResp(void *data, uint32_t *size); /* RS_PKT_SUBTYPE_SEARCH_REQ */ virtual uint32_t sizeNxsSearchReq(RsNxsSearchReq* item); virtual bool serialiseNxsSearchReq(RsNxsSearchReq* item, void* data, uint32_t* size); virtual RsNxsSearchReq* deserialNxsSearchReq(void *data, uint32_t *size); /* RS_PKT_SUBTYPE_SEARCH_RESP */ virtual uint32_t sizeNxsSearchResp(RsNxsSearchResp *item); virtual bool serialiseNxsSearchResp(RsNxsSearchResp *item, void *data, uint32_t *size); virtual RsNxsSearchResp* deserialNxsSearchResp(void *data, uint32_t *size); private: const uint16_t SERVICE_TYPE; }; #endif // RSNXSITEMS_H