#ifndef RSGNP_H #define RSGNP_H /* * libretroshare/src/gxs: rsgnp.h * * Network Exchange Service interface for RetroShare. * * Copyright 2011-2011 by Robert Fernie, Christopher Evi-Prker * * 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 #include #include #include #include #include "gxs/rsgxs.h" #include "services/p3service.h" /*! * Retroshare General Network Exchange Service: \n * Interface: * - This provides a module to service peer's requests for GXS messages \n * and also request GXS messages from other peers. \n * - The general mode of operation is to sychronise all messages/grps between * peers * * The interface is sparse as this service is mostly making the requests to other GXS components * * Groups: * - As this is where exchanges occur between peers, this is also where groups relationships * should get resolved as far as * - Per implemented GXS there are a set of rules which will determine whether data is transferred * between any set of groups * * 1 allow transfers to any group * 2 transfers only between group * - the also group matrix settings which is by default everyone can transfer to each other */ class RsNetworktExchangeService : public p3Service { public: /*! * Use this to set how far back synchronisation of messages should take place * @param range how far back from current time to synchronise with other peers */ virtual void setTimeRange(uint64_t range) = 0; /*! * requests all the groups contained by a peer * @param peerId id of peer */ virtual void requestGroupsOfPeer(const std::string& peerId) = 0; /*! * get messages of a peer for a given group id, this circumvents the normal * polling of peers for messages of given group id * @param peerId Id of peer * @param grpId id of group to request messages for */ virtual void requestMessagesOfPeer(const std::string& peerId, const RsGroupId& grpId); /*! * subscribes the associated service to this group. This RsNetworktExchangeService * now regularly polls all peers for new messages of this group * @param grpId the id of the group to subscribe to * @param subscribe set to true to subscribe or false to unsubscribe */ virtual void subscribeToGroup(const RsGroupId& grpId, bool subscribe) = 0; /*! * Initiates a search through the network * This returns messages which contains the search terms set in RsGxsSearch * @param search contains search terms of requested from service * @param hops how far into friend tree for search * @return search token that can be redeemed later, implementation should indicate how this should be used */ virtual int searchMsgs(RsGxsSearch* search, uint8_t hops = 1, bool retrieve = 0) = 0; /*! * Initiates a search of groups through the network which goes * a given number of hosp deep into your friend's network * @param search contains search term requested from service * @param hops number of hops deep into peer network * @return search token that can be redeemed later */ virtual int searchGrps(RsGxsSearch* search, uint8_t hops = 1, bool retrieve = 0) = 0; /*! * pauses synchronisation of subscribed groups and request for group id * from peers * @param enabled set to false to disable pause, and true otherwise */ virtual void pauseSynchronisation(bool enabled); /*! * Request for this message is sent through to peers on your network * and how many hops from them you've indicated * @param msgId the messages to retrieve * @return request token to be redeemed */ virtual int requestMsg(const std::list& msgId, uint8_t hops) = 0; /*! * Request for this group is sent through to peers on your network * and how many hops from them you've indicated * @param enabled set to false to disable pause, and true otherwise * @return request token to be redeemed */ virtual int requestGrp(const std::list& grpId, uint8_t hops) = 0; }; #endif // RSGNP_H