2012-10-05 14:12:52 -04:00
|
|
|
#ifndef RSGXSIFACEIMPL_H
|
|
|
|
#define RSGXSIFACEIMPL_H
|
|
|
|
|
2012-10-17 17:20:57 -04:00
|
|
|
/*
|
|
|
|
* libretroshare/src/gxs/: rsgxsifaceimpl.h
|
|
|
|
*
|
|
|
|
* RetroShare GXS. Convenience interface implementation
|
|
|
|
*
|
|
|
|
* Copyright 2012 by Christopher Evi-Parker
|
|
|
|
*
|
|
|
|
* 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".
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2012-10-05 14:12:52 -04:00
|
|
|
#include "gxs/rsgenexchange.h"
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* The simple idea of this class is to implement the simple interface functions
|
2012-10-15 16:31:56 -04:00
|
|
|
* of gen exchange.
|
|
|
|
* This class provides convenience implementations of:
|
|
|
|
* - Handle msg and group changes (client class must pass changes sent by RsGenExchange to it)
|
|
|
|
* - subscription to groups
|
|
|
|
* - retrieval of msgs and group ids and meta info
|
2012-10-05 14:12:52 -04:00
|
|
|
*/
|
|
|
|
class RsGxsIfaceImpl
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
|
2012-10-15 16:31:56 -04:00
|
|
|
/*!
|
|
|
|
*
|
|
|
|
* @param gxs handle to RsGenExchange instance of service (Usually the service class itself)
|
|
|
|
*/
|
2012-10-05 14:12:52 -04:00
|
|
|
RsGxsIfaceImpl(RsGenExchange* gxs);
|
|
|
|
|
2013-02-07 18:04:16 -05:00
|
|
|
protected:
|
2012-10-15 16:31:56 -04:00
|
|
|
/*!
|
|
|
|
* Gxs services should call this for automatic handling of
|
|
|
|
* changes, send
|
|
|
|
* @param changes
|
|
|
|
*/
|
|
|
|
void receiveChanges(std::vector<RsGxsNotify*>& changes);
|
2012-10-05 14:12:52 -04:00
|
|
|
|
2013-02-07 18:04:16 -05:00
|
|
|
public:
|
|
|
|
|
2012-10-05 14:12:52 -04:00
|
|
|
/*!
|
2012-10-15 16:31:56 -04:00
|
|
|
* Checks to see if a change has been received for
|
|
|
|
* for a message or group
|
2013-02-07 18:04:16 -05:00
|
|
|
* @param willCallGrpChanged if this is set to true, group changed function will return list
|
|
|
|
* groups that have changed, if false, the group changed list is cleared
|
|
|
|
* @param willCallMsgChanged if this is set to true, msgChanged function will return map
|
|
|
|
* messages that have changed, if false, the message changed map is cleared
|
2012-10-15 16:31:56 -04:00
|
|
|
* @return true if a change has occured for msg or group
|
2013-02-07 18:04:16 -05:00
|
|
|
* @see groupsChanged
|
|
|
|
* @see msgsChanged
|
2012-10-05 14:12:52 -04:00
|
|
|
*/
|
2013-02-07 18:04:16 -05:00
|
|
|
virtual bool updated(bool willCallGrpChanged = false, bool willCallMsgChanged = false);
|
2012-10-05 14:12:52 -04:00
|
|
|
|
2012-10-14 14:32:33 -04:00
|
|
|
/*!
|
2012-10-15 16:31:56 -04:00
|
|
|
* The groups changed. \n
|
|
|
|
* class can reimplement to use to tailor
|
|
|
|
* the group actually set for ui notification.
|
|
|
|
* If receivedChanges is not passed RsGxsNotify changes
|
|
|
|
* this function does nothing
|
2013-02-07 18:04:16 -05:00
|
|
|
* @param grpIds returns list of grpIds that have changed
|
|
|
|
* @see updated
|
2012-10-14 14:32:33 -04:00
|
|
|
*/
|
2012-10-15 16:31:56 -04:00
|
|
|
virtual void groupsChanged(std::list<RsGxsGroupId>& grpIds);
|
2012-10-05 14:12:52 -04:00
|
|
|
|
2012-10-14 14:32:33 -04:00
|
|
|
/*!
|
2012-10-15 16:31:56 -04:00
|
|
|
* The msg changed. \n
|
|
|
|
* class can reimplement to use to tailor
|
|
|
|
* the msg actually set for ui notification.
|
|
|
|
* If receivedChanges is not passed RsGxsNotify changes
|
|
|
|
* this function does nothing
|
2013-02-07 18:04:16 -05:00
|
|
|
* @param msgs returns map of message ids that have changed
|
|
|
|
* @see updated
|
2012-10-14 14:32:33 -04:00
|
|
|
*/
|
2012-10-15 16:31:56 -04:00
|
|
|
virtual void msgsChanged(std::map<RsGxsGroupId,
|
2012-10-05 14:12:52 -04:00
|
|
|
std::vector<RsGxsMessageId> >& msgs);
|
|
|
|
|
2012-10-15 16:31:56 -04:00
|
|
|
/*!
|
|
|
|
* @return handle to token service for this GXS service
|
|
|
|
*/
|
2012-10-05 14:12:52 -04:00
|
|
|
RsTokenService* getTokenService();
|
|
|
|
|
2012-10-14 14:32:33 -04:00
|
|
|
/* Generic Lists */
|
|
|
|
|
|
|
|
/*!
|
2012-10-15 16:31:56 -04:00
|
|
|
* Retrieve list of group ids associated to a request token
|
2012-10-14 14:32:33 -04:00
|
|
|
* @param token token to be redeemed for this request
|
|
|
|
* @param groupIds the ids return for given request token
|
|
|
|
* @return false if request token is invalid, check token status for error report
|
|
|
|
*/
|
2012-10-05 14:12:52 -04:00
|
|
|
bool getGroupList(const uint32_t &token,
|
|
|
|
std::list<RsGxsGroupId> &groupIds);
|
2012-10-14 14:32:33 -04:00
|
|
|
|
|
|
|
/*!
|
2012-10-15 16:31:56 -04:00
|
|
|
* Retrieves list of msg ids associated to a request token
|
2012-10-14 14:32:33 -04:00
|
|
|
* @param token token to be redeemed for this request
|
|
|
|
* @param msgIds the ids return for given request token
|
|
|
|
* @return false if request token is invalid, check token status for error report
|
|
|
|
*/
|
2012-10-05 14:12:52 -04:00
|
|
|
bool getMsgList(const uint32_t &token,
|
|
|
|
GxsMsgIdResult& msgIds);
|
|
|
|
|
2012-11-13 17:36:06 -05:00
|
|
|
/*!
|
|
|
|
* Retrieves list of msg related ids associated to a request token
|
|
|
|
* @param token token to be redeemed for this request
|
|
|
|
* @param msgIds the ids return for given request token
|
|
|
|
* @return false if request token is invalid, check token status for error report
|
|
|
|
*/
|
|
|
|
bool getMsgRelatedList(const uint32_t &token,
|
|
|
|
MsgRelatedIdResult& msgIds);
|
|
|
|
|
2012-10-14 14:32:33 -04:00
|
|
|
/*!
|
|
|
|
* @param token token to be redeemed for group summary request
|
|
|
|
* @param groupInfo the ids returned for given request token
|
|
|
|
* @return false if request token is invalid, check token status for error report
|
|
|
|
*/
|
2012-10-05 14:12:52 -04:00
|
|
|
bool getGroupSummary(const uint32_t &token,
|
|
|
|
std::list<RsGroupMetaData> &groupInfo);
|
|
|
|
|
2012-10-14 14:32:33 -04:00
|
|
|
/*!
|
|
|
|
* @param token token to be redeemed for message summary request
|
|
|
|
* @param msgInfo the message metadata returned for given request token
|
|
|
|
* @return false if request token is invalid, check token status for error report
|
|
|
|
*/
|
2012-10-05 14:12:52 -04:00
|
|
|
bool getMsgSummary(const uint32_t &token,
|
|
|
|
GxsMsgMetaMap &msgInfo);
|
|
|
|
|
2012-11-13 17:36:06 -05:00
|
|
|
/*!
|
|
|
|
* @param token token to be redeemed for message related summary request
|
|
|
|
* @param msgInfo the message metadata returned for given request token
|
|
|
|
* @return false if request token is invalid, check token status for error report
|
|
|
|
*/
|
|
|
|
bool getMsgrelatedSummary(const uint32_t &token,
|
|
|
|
GxsMsgRelatedMetaMap &msgInfo);
|
|
|
|
|
2012-10-14 14:32:33 -04:00
|
|
|
/*!
|
|
|
|
* subscribes to group, and returns token which can be used
|
|
|
|
* to be acknowledged to get group Id
|
|
|
|
* @param token token to redeem for acknowledgement
|
|
|
|
* @param grpId the id of the group to subscribe to
|
|
|
|
*/
|
2012-10-15 16:31:56 -04:00
|
|
|
virtual bool subscribeToGroup(uint32_t& token, const RsGxsGroupId& grpId, bool subscribe);
|
2012-10-14 14:32:33 -04:00
|
|
|
|
2012-10-05 14:12:52 -04:00
|
|
|
/*!
|
|
|
|
* This allows the client service to acknowledge that their msgs has
|
|
|
|
* been created/modified and retrieve the create/modified msg ids
|
|
|
|
* @param token the token related to modification/create request
|
|
|
|
* @param msgIds map of grpid->msgIds of message created/modified
|
|
|
|
* @return true if token exists false otherwise
|
|
|
|
*/
|
|
|
|
bool acknowledgeMsg(const uint32_t& token, std::pair<RsGxsGroupId, RsGxsMessageId>& msgId);
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* This allows the client service to acknowledge that their grps has
|
|
|
|
* been created/modified and retrieve the create/modified grp ids
|
|
|
|
* @param token the token related to modification/create request
|
|
|
|
* @param msgIds vector of ids of groups created/modified
|
|
|
|
* @return true if token exists false otherwise
|
|
|
|
*/
|
|
|
|
bool acknowledgeGrp(const uint32_t& token, RsGxsGroupId& grpId);
|
|
|
|
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
|
|
|
RsGenExchange* mGxs;
|
2012-10-15 16:31:56 -04:00
|
|
|
|
|
|
|
std::vector<RsGxsGroupChange*> mGroupChange;
|
|
|
|
std::vector<RsGxsMsgChange*> mMsgChange;
|
|
|
|
|
|
|
|
RsMutex mGxsIfaceMutex;
|
2012-10-05 14:12:52 -04:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif // RSGXSIFACEIMPL_H
|