mirror of
https://github.com/RetroShare/RetroShare.git
synced 2025-01-16 01:47:17 -05:00
Improved token service interface with more obvious request calls (grpIds and msgIds list being empty is not implicit of retrieving all ids)
Updated GXS tests and applied fixes started transfering flags to gxs flags header file git-svn-id: http://svn.code.sf.net/p/retroshare/code/branches/v0.5-gxs-b1@5513 b45a01b8-16f6-495d-af2f-9b41ad6348cc
This commit is contained in:
parent
84074fdca1
commit
08904bf82f
@ -29,6 +29,7 @@
|
|||||||
#include "gxs/rsgds.h"
|
#include "gxs/rsgds.h"
|
||||||
#include "util/retrodb.h"
|
#include "util/retrodb.h"
|
||||||
|
|
||||||
|
|
||||||
class RsDataService : public RsGeneralDataService
|
class RsDataService : public RsGeneralDataService
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
@ -151,7 +151,7 @@ public:
|
|||||||
* @param cache whether to store retrieval in mem for faster later retrieval
|
* @param cache whether to store retrieval in mem for faster later retrieval
|
||||||
* @return error code
|
* @return error code
|
||||||
*/
|
*/
|
||||||
virtual int retrieveGxsMsgMetaData(GxsMsgReq& grpIds, GxsMsgMetaResult& msgMeta) = 0;
|
virtual int retrieveGxsMsgMetaData(GxsMsgReq& msgIds, GxsMsgMetaResult& msgMeta) = 0;
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* remove msgs in data store listed in msgIds param
|
* remove msgs in data store listed in msgIds param
|
||||||
|
@ -32,6 +32,7 @@
|
|||||||
#include "rsgenexchange.h"
|
#include "rsgenexchange.h"
|
||||||
#include "gxssecurity.h"
|
#include "gxssecurity.h"
|
||||||
#include "util/contentvalue.h"
|
#include "util/contentvalue.h"
|
||||||
|
#include "rsgxsflags.h"
|
||||||
|
|
||||||
RsGenExchange::RsGenExchange(RsGeneralDataService *gds,
|
RsGenExchange::RsGenExchange(RsGeneralDataService *gds,
|
||||||
RsNetworkExchangeService *ns, RsSerialType *serviceSerialiser, uint16_t servType)
|
RsNetworkExchangeService *ns, RsSerialType *serviceSerialiser, uint16_t servType)
|
||||||
|
@ -32,6 +32,7 @@
|
|||||||
#include <list>
|
#include <list>
|
||||||
#include <set>
|
#include <set>
|
||||||
#include <map>
|
#include <map>
|
||||||
|
#include <vector>
|
||||||
|
|
||||||
/* data types used throughout Gxs from netservice to genexchange */
|
/* data types used throughout Gxs from netservice to genexchange */
|
||||||
|
|
||||||
|
@ -65,6 +65,12 @@ RsGxsDataAccess::RsGxsDataAccess(RsGeneralDataService* ds)
|
|||||||
bool RsGxsDataAccess::requestGroupInfo(uint32_t &token, uint32_t ansType, const RsTokReqOptionsV2 &opts,
|
bool RsGxsDataAccess::requestGroupInfo(uint32_t &token, uint32_t ansType, const RsTokReqOptionsV2 &opts,
|
||||||
const std::list<std::string> &groupIds)
|
const std::list<std::string> &groupIds)
|
||||||
{
|
{
|
||||||
|
if(groupIds.empty())
|
||||||
|
{
|
||||||
|
std::cerr << "Group Id list is empty" << std::endl;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
GxsRequest* req = NULL;
|
GxsRequest* req = NULL;
|
||||||
uint32_t reqType = opts.mReqType;
|
uint32_t reqType = opts.mReqType;
|
||||||
|
|
||||||
@ -104,6 +110,45 @@ bool RsGxsDataAccess::requestGroupInfo(uint32_t &token, uint32_t ansType, const
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool RsGxsDataAccess::requestGroupInfo(uint32_t &token, uint32_t ansType, const RsTokReqOptionsV2 &opts)
|
||||||
|
{
|
||||||
|
|
||||||
|
GxsRequest* req = NULL;
|
||||||
|
uint32_t reqType = opts.mReqType;
|
||||||
|
|
||||||
|
if(reqType & GXS_REQUEST_TYPE_GROUP_META)
|
||||||
|
{
|
||||||
|
GroupMetaReq* gmr = new GroupMetaReq();
|
||||||
|
req = gmr;
|
||||||
|
}
|
||||||
|
else if(reqType & GXS_REQUEST_TYPE_GROUP_DATA)
|
||||||
|
{
|
||||||
|
GroupDataReq* gdr = new GroupDataReq();
|
||||||
|
req = gdr;
|
||||||
|
}
|
||||||
|
else if(reqType & GXS_REQUEST_TYPE_GROUP_IDS)
|
||||||
|
{
|
||||||
|
GroupIdReq* gir = new GroupIdReq();
|
||||||
|
req = gir;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(req == NULL)
|
||||||
|
{
|
||||||
|
std::cerr << "RsGxsDataAccess::requestMsgInfo() request type not recognised, type "
|
||||||
|
<< reqType << std::endl;
|
||||||
|
return false;
|
||||||
|
}else
|
||||||
|
{
|
||||||
|
generateToken(token);
|
||||||
|
std::cerr << "RsGxsDataAccess::requestMsgInfo() gets Token: " << token << std::endl;
|
||||||
|
}
|
||||||
|
|
||||||
|
setReq(req, token, ansType, opts);
|
||||||
|
storeRequest(req);
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
void RsGxsDataAccess::generateToken(uint32_t &token)
|
void RsGxsDataAccess::generateToken(uint32_t &token)
|
||||||
{
|
{
|
||||||
RsStackMutex stack(mDataMutex); /****** LOCKED *****/
|
RsStackMutex stack(mDataMutex); /****** LOCKED *****/
|
||||||
@ -121,20 +166,90 @@ bool RsGxsDataAccess::requestMsgInfo(uint32_t &token, uint32_t ansType,
|
|||||||
GxsRequest* req = NULL;
|
GxsRequest* req = NULL;
|
||||||
uint32_t reqType = opts.mReqType;
|
uint32_t reqType = opts.mReqType;
|
||||||
|
|
||||||
|
// remove all empty grpId entries
|
||||||
|
GxsMsgReq::const_iterator mit = msgIds.begin();
|
||||||
|
std::vector<RsGxsGroupId> toRemove;
|
||||||
|
|
||||||
|
for(; mit != msgIds.end(); mit++)
|
||||||
|
{
|
||||||
|
if(mit->second.empty())
|
||||||
|
toRemove.push_back(mit->first);
|
||||||
|
}
|
||||||
|
|
||||||
|
std::vector<RsGxsGroupId>::const_iterator vit = toRemove.begin();
|
||||||
|
|
||||||
|
GxsMsgReq filteredMsgIds = msgIds;
|
||||||
|
|
||||||
|
for(; vit != toRemove.end(); vit++)
|
||||||
|
filteredMsgIds.erase(*vit);
|
||||||
|
|
||||||
if(reqType & GXS_REQUEST_TYPE_MSG_META)
|
if(reqType & GXS_REQUEST_TYPE_MSG_META)
|
||||||
{
|
{
|
||||||
MsgMetaReq* mmr = new MsgMetaReq();
|
MsgMetaReq* mmr = new MsgMetaReq();
|
||||||
mmr->mMsgIds = msgIds;
|
mmr->mMsgIds = filteredMsgIds;
|
||||||
|
req = mmr;
|
||||||
|
|
||||||
|
}else if(reqType & GXS_REQUEST_TYPE_MSG_DATA)
|
||||||
|
{
|
||||||
|
MsgDataReq* mdr = new MsgDataReq();
|
||||||
|
mdr->mMsgIds = filteredMsgIds;
|
||||||
|
req = mdr;
|
||||||
|
|
||||||
|
}else if(reqType & GXS_REQUEST_TYPE_MSG_IDS)
|
||||||
|
{
|
||||||
|
MsgIdReq* mir = new MsgIdReq();
|
||||||
|
mir->mMsgIds = filteredMsgIds;
|
||||||
|
req = mir;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
if(req == NULL)
|
||||||
|
{
|
||||||
|
std::cerr << "RsGxsDataAccess::requestMsgInfo() request type not recognised, type "
|
||||||
|
<< reqType << std::endl;
|
||||||
|
return false;
|
||||||
|
}else
|
||||||
|
{
|
||||||
|
generateToken(token);
|
||||||
|
std::cerr << "RsGxsDataAccess::requestMsgInfo() gets Token: " << token << std::endl;
|
||||||
|
}
|
||||||
|
|
||||||
|
setReq(req, token, ansType, opts);
|
||||||
|
storeRequest(req);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool RsGxsDataAccess::requestMsgInfo(uint32_t &token, uint32_t ansType,
|
||||||
|
const RsTokReqOptionsV2 &opts, const std::list<RsGxsGroupId>& grpIds)
|
||||||
|
{
|
||||||
|
GxsRequest* req = NULL;
|
||||||
|
uint32_t reqType = opts.mReqType;
|
||||||
|
|
||||||
|
std::list<RsGxsGroupId>::const_iterator lit = grpIds.begin();
|
||||||
|
|
||||||
|
if(reqType & GXS_REQUEST_TYPE_MSG_META)
|
||||||
|
{
|
||||||
|
MsgMetaReq* mmr = new MsgMetaReq();
|
||||||
|
|
||||||
|
for(; lit != grpIds.end(); lit++)
|
||||||
|
mmr->mMsgIds[*lit] = std::vector<RsGxsMessageId>();
|
||||||
|
|
||||||
req = mmr;
|
req = mmr;
|
||||||
}else if(reqType & GXS_REQUEST_TYPE_MSG_DATA)
|
}else if(reqType & GXS_REQUEST_TYPE_MSG_DATA)
|
||||||
{
|
{
|
||||||
MsgDataReq* mdr = new MsgDataReq();
|
MsgDataReq* mdr = new MsgDataReq();
|
||||||
mdr->mMsgIds = msgIds;
|
|
||||||
|
for(; lit != grpIds.end(); lit++)
|
||||||
|
mdr->mMsgIds[*lit] = std::vector<RsGxsMessageId>();
|
||||||
|
|
||||||
req = mdr;
|
req = mdr;
|
||||||
}else if(reqType & GXS_REQUEST_TYPE_MSG_IDS)
|
}else if(reqType & GXS_REQUEST_TYPE_MSG_IDS)
|
||||||
{
|
{
|
||||||
MsgIdReq* mir = new MsgIdReq();
|
MsgIdReq* mir = new MsgIdReq();
|
||||||
mir->mMsgIds = msgIds;
|
|
||||||
|
for(; lit != grpIds.end(); lit++)
|
||||||
|
mir->mMsgIds[*lit] = std::vector<RsGxsMessageId>();
|
||||||
|
|
||||||
req = mir;
|
req = mir;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -154,8 +269,8 @@ bool RsGxsDataAccess::requestMsgInfo(uint32_t &token, uint32_t ansType,
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool RsGxsDataAccess::requestMsgRelatedInfo(uint32_t &token, uint32_t ansType, const RsTokReqOptionsV2 &opts,
|
||||||
bool RsGxsDataAccess::requestMsgRelatedInfo(uint32_t &token, uint32_t ansType, const RsTokReqOptionsV2 &opts, const GxsMsgReq& msgIds)
|
const GxsMsgReq& msgIds)
|
||||||
{
|
{
|
||||||
|
|
||||||
MsgRelatedInfoReq* req = new MsgRelatedInfoReq();
|
MsgRelatedInfoReq* req = new MsgRelatedInfoReq();
|
||||||
@ -166,7 +281,6 @@ bool RsGxsDataAccess::requestMsgRelatedInfo(uint32_t &token, uint32_t ansType, c
|
|||||||
setReq(req, token, ansType, opts);
|
setReq(req, token, ansType, opts);
|
||||||
storeRequest(req);
|
storeRequest(req);
|
||||||
|
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -44,24 +44,43 @@ public:
|
|||||||
/** S: RsTokenService **/
|
/** S: RsTokenService **/
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
*
|
* Use this to request group related information
|
||||||
* @param token
|
* @param token The token returned for the request, store this value to pool for request completion
|
||||||
* @param ansType
|
* @param ansType The type of result (e.g. group data, meta, ids)
|
||||||
* @param opts
|
* @param opts Additional option that affect outcome of request. Please see specific services, for valid values
|
||||||
* @param groupIds
|
* @param groupIds group id to request info for
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
bool requestGroupInfo(uint32_t &token, uint32_t ansType, const RsTokReqOptionsV2 &opts, const std::list<RsGxsGroupId> &groupIds);
|
bool requestGroupInfo(uint32_t &token, uint32_t ansType, const RsTokReqOptionsV2 &opts, const std::list<RsGxsGroupId> &groupIds);
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* For requesting info on all messages of one or more groups
|
* Use this to request all group related info
|
||||||
* @param token
|
* @param token The token returned for the request, store this value to pool for request completion
|
||||||
* @param ansType
|
* @param ansType The type of result (e.g. group data, meta, ids)
|
||||||
* @param opts
|
* @param opts Additional option that affect outcome of request. Please see specific services, for valid values
|
||||||
* @param groupIds
|
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
bool requestMsgInfo(uint32_t &token, uint32_t ansType, const RsTokReqOptionsV2 &opts, const GxsMsgReq&);
|
bool requestGroupInfo(uint32_t &token, uint32_t ansType, const RsTokReqOptionsV2 &opts);
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* Use this to get msg related information, store this value to pole for request completion
|
||||||
|
* @param token The token returned for the request
|
||||||
|
* @param ansType The type of result wanted
|
||||||
|
* @param opts Additional option that affect outcome of request. Please see specific services, for valid values
|
||||||
|
* @param groupIds The ids of the groups to get, second entry of map empty to query for all msgs
|
||||||
|
* @return true if request successful false otherwise
|
||||||
|
*/
|
||||||
|
bool requestMsgInfo(uint32_t &token, uint32_t ansType, const RsTokReqOptionsV2 &opts, const GxsMsgReq& msgIds);
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* Use this to get msg related information, store this value to pole for request completion
|
||||||
|
* @param token The token returned for the request
|
||||||
|
* @param ansType The type of result wanted
|
||||||
|
* @param opts Additional option that affect outcome of request. Please see specific services, for valid values
|
||||||
|
* @param groupIds The ids of the groups to get, this retrieve all the msgs info for each grpId in list
|
||||||
|
* @return true if request successful false otherwise
|
||||||
|
*/
|
||||||
|
bool requestMsgInfo(uint32_t &token, uint32_t ansType, const RsTokReqOptionsV2 &opts, const std::list<RsGxsGroupId>& grpIds);
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* For requesting msgs related to a given msg id within a group
|
* For requesting msgs related to a given msg id within a group
|
||||||
@ -71,7 +90,7 @@ public:
|
|||||||
* @param groupIds The ids of the groups to get, second entry of map empty to query for all msgs
|
* @param groupIds The ids of the groups to get, second entry of map empty to query for all msgs
|
||||||
* @return true if request successful false otherwise
|
* @return true if request successful false otherwise
|
||||||
*/
|
*/
|
||||||
bool requestMsgRelatedInfo(uint32_t &token, uint32_t ansType, const RsTokReqOptionsV2 &opts, const GxsMsgReq&);
|
bool requestMsgRelatedInfo(uint32_t &token, uint32_t ansType, const RsTokReqOptionsV2 &opts, const GxsMsgReq& msgIds);
|
||||||
|
|
||||||
/* Poll */
|
/* Poll */
|
||||||
uint32_t requestStatus(const uint32_t token);
|
uint32_t requestStatus(const uint32_t token);
|
||||||
|
@ -3,6 +3,8 @@
|
|||||||
|
|
||||||
#include "inttypes.h"
|
#include "inttypes.h"
|
||||||
|
|
||||||
|
// this serves a single point of call for definining grp and msg modes
|
||||||
|
// GXS. These modes say
|
||||||
namespace GXS_SERV {
|
namespace GXS_SERV {
|
||||||
|
|
||||||
|
|
||||||
@ -10,30 +12,30 @@ namespace GXS_SERV {
|
|||||||
|
|
||||||
/* type of group */
|
/* type of group */
|
||||||
|
|
||||||
static const uint32_t FLAG_GRP_TYPE_MASK;
|
static const uint32_t FLAG_GRP_TYPE_MASK = 0;
|
||||||
|
|
||||||
// pub key encrypted
|
// pub key encrypted
|
||||||
static const uint32_t FLAG_GRP_TYPE_PRIVATE;
|
static const uint32_t FLAG_GRP_TYPE_PRIVATE = 0;
|
||||||
|
|
||||||
// single publisher, read only
|
// single publisher, read only
|
||||||
static const uint32_t FLAG_GRP_TYPE_RESTRICTED;
|
static const uint32_t FLAG_GRP_TYPE_RESTRICTED = 0;
|
||||||
|
|
||||||
// anyone can publish
|
// anyone can publish
|
||||||
static const uint32_t FLAG_GRP_TYPE_PUBLIC;
|
static const uint32_t FLAG_GRP_TYPE_PUBLIC = 0;
|
||||||
|
|
||||||
|
|
||||||
/* type of msgs allowed */
|
/* type of msgs allowed */
|
||||||
|
|
||||||
static const uint32_t FLAG_MSG_TYPE_MASK;
|
static const uint32_t FLAG_MSG_TYPE_MASK = 0;
|
||||||
|
|
||||||
// only signee can edit, and sign required
|
// only signee can edit, and sign required
|
||||||
static const uint32_t FLAG_MSG_TYPE_SIGNED;
|
static const uint32_t FLAG_MSG_TYPE_SIGNED = 0;
|
||||||
|
|
||||||
// no sign required, but signee can edit if signed
|
// no sign required, but signee can edit if signed
|
||||||
static const uint32_t FLAG_MSG_TYPE_ANON;
|
static const uint32_t FLAG_MSG_TYPE_ANON = 0;
|
||||||
|
|
||||||
// anyone can mod but sign must be provided (needed for wikis)
|
// anyone can mod but sign must be provided (needed for wikis)
|
||||||
static const uint32_t FLAG_MSG_TYPE_SIGNED_SHARED;
|
static const uint32_t FLAG_MSG_TYPE_SIGNED_SHARED = 0;
|
||||||
|
|
||||||
/*** GROUP FLAGS ***/
|
/*** GROUP FLAGS ***/
|
||||||
|
|
||||||
@ -42,13 +44,22 @@ namespace GXS_SERV {
|
|||||||
/*** MESSAGE FLAGS ***/
|
/*** MESSAGE FLAGS ***/
|
||||||
|
|
||||||
// indicates message edits an existing message
|
// indicates message edits an existing message
|
||||||
static const uint32_t FLAG_MSG_EDIT;
|
static const uint32_t FLAG_MSG_EDIT = 0;
|
||||||
|
|
||||||
// indicates msg is id signed
|
// indicates msg is id signed
|
||||||
static const uint32_t FLAG_MSG_ID_SIGNED;
|
static const uint32_t FLAG_MSG_ID_SIGNED = 0;
|
||||||
|
|
||||||
/*** MESSAGE FLAGS ***/
|
/*** MESSAGE FLAGS ***/
|
||||||
|
|
||||||
|
|
||||||
|
// Subscription Flags. (LOCAL)
|
||||||
|
|
||||||
|
static const uint32_t RSGXS_GROUP_SUBSCRIBE_ADMIN = 0x00000001;
|
||||||
|
static const uint32_t RSGXS_GROUP_SUBSCRIBE_PUBLISH = 0x00000002;
|
||||||
|
static const uint32_t RSGXS_GROUP_SUBSCRIBE_SUBSCRIBED = 0x00000004;
|
||||||
|
static const uint32_t RSGXS_GROUP_SUBSCRIBE_MONITOR = 0x00000008;
|
||||||
|
static const uint32_t RSGXS_GROUP_SUBSCRIBE_MASK = 0x0000000f;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -25,6 +25,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include "rsgxsnetservice.h"
|
#include "rsgxsnetservice.h"
|
||||||
|
#include "rsgxsflags.h"
|
||||||
|
|
||||||
#define NXS_NET_DEBUG
|
#define NXS_NET_DEBUG
|
||||||
|
|
||||||
@ -85,24 +86,40 @@ void RsGxsNetService::syncWithPeers()
|
|||||||
sendItem(grp);
|
sendItem(grp);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
std::map<RsGxsGroupId, RsGxsGrpMetaData* > grpMeta;
|
||||||
|
mDataStore->retrieveGxsGrpMetaData(grpMeta);
|
||||||
|
|
||||||
|
std::map<RsGxsGroupId, RsGxsGrpMetaData* >::iterator
|
||||||
|
mit = grpMeta.begin();
|
||||||
|
|
||||||
|
std::vector<RsGxsGroupId> grpIds;
|
||||||
|
|
||||||
|
for(; mit != grpMeta.end(); mit++)
|
||||||
|
{
|
||||||
|
RsGxsGrpMetaData* meta = mit->second;
|
||||||
|
|
||||||
|
if(meta->mSubscribeFlags & GXS_SERV::RSGXS_GROUP_SUBSCRIBE_MASK)
|
||||||
|
grpIds.push_back(mit->first);
|
||||||
|
}
|
||||||
|
|
||||||
sit = peers.begin();
|
sit = peers.begin();
|
||||||
|
|
||||||
// TODO msgs
|
// TODO msgs
|
||||||
for(; sit != peers.end(); sit++)
|
for(; sit != peers.end(); sit++)
|
||||||
{
|
{
|
||||||
RsStackMutex stack(mNxsMutex);
|
RsStackMutex stack(mNxsMutex);
|
||||||
|
|
||||||
std::set<std::string>::iterator sit_grp = mGroupSubscribedTo.begin();
|
std::vector<RsGxsGroupId>::iterator vit = grpIds.begin();
|
||||||
|
|
||||||
for(; sit_grp != mGroupSubscribedTo.end(); sit_grp++)
|
for(; vit != grpIds.end(); vit++)
|
||||||
{
|
{
|
||||||
RsNxsSyncMsg* msg = new RsNxsSyncMsg(mServType);
|
RsNxsSyncMsg* msg = new RsNxsSyncMsg(mServType);
|
||||||
msg->clear();
|
msg->clear();
|
||||||
msg->PeerId(*sit);
|
msg->PeerId(*sit);
|
||||||
msg->grpId = *sit_grp;
|
msg->grpId = *vit;
|
||||||
sendItem(msg);
|
sendItem(msg);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool RsGxsNetService::loadList(std::list<RsItem*>& load)
|
bool RsGxsNetService::loadList(std::list<RsItem*>& load)
|
||||||
@ -600,10 +617,6 @@ void RsGxsNetService::locked_processCompletedIncomingTrans(NxsTransaction* tr)
|
|||||||
{
|
{
|
||||||
tr->mItems.pop_front();
|
tr->mItems.pop_front();
|
||||||
grps.push_back(grp);
|
grps.push_back(grp);
|
||||||
|
|
||||||
//TODO: remove subscription should be handled
|
|
||||||
// outside netservice
|
|
||||||
mGroupSubscribedTo.insert(grp->grpId);
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -395,9 +395,7 @@ private:
|
|||||||
RsMutex mNxsMutex;
|
RsMutex mNxsMutex;
|
||||||
|
|
||||||
uint32_t mSyncTs;
|
uint32_t mSyncTs;
|
||||||
// TODO: remove, temp, for testing.
|
|
||||||
// subscription handled outside netservice
|
|
||||||
std::set<std::string> mGroupSubscribedTo;
|
|
||||||
const uint32_t mSYNC_PERIOD;
|
const uint32_t mSYNC_PERIOD;
|
||||||
|
|
||||||
};
|
};
|
||||||
|
@ -121,11 +121,20 @@ public:
|
|||||||
* @param token The token returned for the request, store this value to pool for request completion
|
* @param token The token returned for the request, store this value to pool for request completion
|
||||||
* @param ansType The type of result (e.g. group data, meta, ids)
|
* @param ansType The type of result (e.g. group data, meta, ids)
|
||||||
* @param opts Additional option that affect outcome of request. Please see specific services, for valid values
|
* @param opts Additional option that affect outcome of request. Please see specific services, for valid values
|
||||||
* @param groupIds group id to request info for. Leave empty to get info on all groups,
|
* @param groupIds group id to request info for
|
||||||
* @return
|
* @return
|
||||||
*/
|
*/
|
||||||
virtual bool requestGroupInfo(uint32_t &token, uint32_t ansType, const RsTokReqOptionsV2 &opts, const std::list<RsGxsGroupId> &groupIds) = 0;
|
virtual bool requestGroupInfo(uint32_t &token, uint32_t ansType, const RsTokReqOptionsV2 &opts, const std::list<RsGxsGroupId> &groupIds) = 0;
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* Use this to request all group related info
|
||||||
|
* @param token The token returned for the request, store this value to pool for request completion
|
||||||
|
* @param ansType The type of result (e.g. group data, meta, ids)
|
||||||
|
* @param opts Additional option that affect outcome of request. Please see specific services, for valid values
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
virtual bool requestGroupInfo(uint32_t &token, uint32_t ansType, const RsTokReqOptionsV2 &opts) = 0;
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* Use this to get msg related information, store this value to pole for request completion
|
* Use this to get msg related information, store this value to pole for request completion
|
||||||
* @param token The token returned for the request
|
* @param token The token returned for the request
|
||||||
@ -136,6 +145,16 @@ public:
|
|||||||
*/
|
*/
|
||||||
virtual bool requestMsgInfo(uint32_t &token, uint32_t ansType, const RsTokReqOptionsV2 &opts, const GxsMsgReq& msgIds) = 0;
|
virtual bool requestMsgInfo(uint32_t &token, uint32_t ansType, const RsTokReqOptionsV2 &opts, const GxsMsgReq& msgIds) = 0;
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* Use this to get msg related information, store this value to pole for request completion
|
||||||
|
* @param token The token returned for the request
|
||||||
|
* @param ansType The type of result wanted
|
||||||
|
* @param opts Additional option that affect outcome of request. Please see specific services, for valid values
|
||||||
|
* @param groupIds The ids of the groups to get, this retrieve all the msgs info for each grpId in list
|
||||||
|
* @return true if request successful false otherwise
|
||||||
|
*/
|
||||||
|
virtual bool requestMsgInfo(uint32_t &token, uint32_t ansType, const RsTokReqOptionsV2 &opts, const std::list<RsGxsGroupId>& msgIds) = 0;
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* For requesting msgs related to a given msg id within a group
|
* For requesting msgs related to a given msg id within a group
|
||||||
* @param token The token returned for the request
|
* @param token The token returned for the request
|
||||||
|
@ -2274,6 +2274,8 @@ int RsServer::StartupRetroShare()
|
|||||||
RsGeneralDataService* photo_ds = new RsDataService("./", "photoV2_db",
|
RsGeneralDataService* photo_ds = new RsDataService("./", "photoV2_db",
|
||||||
RS_SERVICE_TYPE_PHOTO, NULL);
|
RS_SERVICE_TYPE_PHOTO, NULL);
|
||||||
|
|
||||||
|
photo_ds->resetDataStore();
|
||||||
|
|
||||||
// TODO need net manager
|
// TODO need net manager
|
||||||
//RsGxsNetService* photo_ns = new RsGxsNetService(
|
//RsGxsNetService* photo_ns = new RsGxsNetService(
|
||||||
// RS_SERVICE_TYPE_PHOTO, photo_ds, NULL, mPhotoV2);
|
// RS_SERVICE_TYPE_PHOTO, photo_ds, NULL, mPhotoV2);
|
||||||
|
@ -175,7 +175,7 @@ bool GenExchangeTester::testGrpSubmissionRetrieval()
|
|||||||
opts.mReqType = GXS_REQUEST_TYPE_GROUP_DATA;
|
opts.mReqType = GXS_REQUEST_TYPE_GROUP_DATA;
|
||||||
|
|
||||||
std::list<RsGxsGroupId> grpIds;
|
std::list<RsGxsGroupId> grpIds;
|
||||||
mTokenService->requestGroupInfo(token, 0, opts, grpIds);
|
mTokenService->requestGroupInfo(token, 0, opts);
|
||||||
|
|
||||||
pollForToken(token, opts);
|
pollForToken(token, opts);
|
||||||
|
|
||||||
@ -272,7 +272,7 @@ bool GenExchangeTester::testGrpMetaRetrieval()
|
|||||||
opts.mReqType = GXS_REQUEST_TYPE_GROUP_META;
|
opts.mReqType = GXS_REQUEST_TYPE_GROUP_META;
|
||||||
|
|
||||||
std::list<RsGxsGroupId> grpIds;
|
std::list<RsGxsGroupId> grpIds;
|
||||||
mTokenService->requestGroupInfo(token, 0, opts, grpIds);
|
mTokenService->requestGroupInfo(token, 0, opts);
|
||||||
|
|
||||||
pollForToken(token, opts);
|
pollForToken(token, opts);
|
||||||
|
|
||||||
@ -319,7 +319,7 @@ bool GenExchangeTester::testGrpIdRetrieval()
|
|||||||
opts.mReqType = GXS_REQUEST_TYPE_GROUP_IDS;
|
opts.mReqType = GXS_REQUEST_TYPE_GROUP_IDS;
|
||||||
uint32_t token;
|
uint32_t token;
|
||||||
std::list<RsGxsGroupId> grpIds;
|
std::list<RsGxsGroupId> grpIds;
|
||||||
mTokenService->requestGroupInfo(token, 0, opts, grpIds);
|
mTokenService->requestGroupInfo(token, 0, opts);
|
||||||
|
|
||||||
pollForToken(token, opts);
|
pollForToken(token, opts);
|
||||||
|
|
||||||
@ -676,13 +676,13 @@ bool GenExchangeTester::testMsgIdRetrieval()
|
|||||||
|
|
||||||
// now do ask of all msg ids
|
// now do ask of all msg ids
|
||||||
|
|
||||||
GxsMsgReq req;
|
std::list<RsGxsGroupId> req;
|
||||||
opts.mReqType = GXS_REQUEST_TYPE_MSG_IDS;
|
opts.mReqType = GXS_REQUEST_TYPE_MSG_IDS;
|
||||||
|
|
||||||
// use empty grp ids request types, non specific msgs ids
|
// use empty grp ids request types, non specific msgs ids
|
||||||
for(int i=0; i < mRandGrpIds.size(); i++)
|
for(int i=0; i < mRandGrpIds.size(); i++)
|
||||||
{
|
{
|
||||||
req[mRandGrpIds[i]] = std::vector<RsGxsMessageId>();
|
req.push_back(mRandGrpIds[i]);
|
||||||
}
|
}
|
||||||
|
|
||||||
mTokenService->requestMsgInfo(token, 0, opts, req);
|
mTokenService->requestMsgInfo(token, 0, opts, req);
|
||||||
|
92
libretroshare/src/tests/gxs/nxsnet_test.pro
Normal file
92
libretroshare/src/tests/gxs/nxsnet_test.pro
Normal file
@ -0,0 +1,92 @@
|
|||||||
|
#-------------------------------------------------
|
||||||
|
#
|
||||||
|
# Project created by QtCreator 2012-05-06T09:19:26
|
||||||
|
#
|
||||||
|
#-------------------------------------------------
|
||||||
|
|
||||||
|
QT += core network
|
||||||
|
|
||||||
|
QT -= gui
|
||||||
|
|
||||||
|
TARGET = rs_test
|
||||||
|
CONFIG += console
|
||||||
|
CONFIG -= app_bundle
|
||||||
|
|
||||||
|
TEMPLATE = app
|
||||||
|
|
||||||
|
CONFIG += debug
|
||||||
|
|
||||||
|
debug {
|
||||||
|
# DEFINES *= DEBUG
|
||||||
|
# DEFINES *= OPENDHT_DEBUG DHT_DEBUG CONN_DEBUG DEBUG_UDP_SORTER P3DISC_DEBUG DEBUG_UDP_LAYER FT_DEBUG EXTADDRSEARCH_DEBUG
|
||||||
|
# DEFINES *= CONTROL_DEBUG FT_DEBUG DEBUG_FTCHUNK P3TURTLE_DEBUG
|
||||||
|
# DEFINES *= P3TURTLE_DEBUG
|
||||||
|
# DEFINES *= NET_DEBUG
|
||||||
|
# DEFINES *= DISTRIB_DEBUG
|
||||||
|
# DEFINES *= P3TURTLE_DEBUG FT_DEBUG DEBUG_FTCHUNK MPLEX_DEBUG
|
||||||
|
# DEFINES *= STATUS_DEBUG SERV_DEBUG RSSERIAL_DEBUG #CONN_DEBUG
|
||||||
|
|
||||||
|
QMAKE_CXXFLAGS -= -O2 -fomit-frame-pointer
|
||||||
|
QMAKE_CXXFLAGS *= -g -fno-omit-frame-pointer
|
||||||
|
}
|
||||||
|
################################# Linux ##########################################
|
||||||
|
# Put lib dir in QMAKE_LFLAGS so it appears before -L/usr/lib
|
||||||
|
linux-* {
|
||||||
|
#CONFIG += version_detail_bash_script
|
||||||
|
QMAKE_CXXFLAGS *= -D_FILE_OFFSET_BITS=64
|
||||||
|
|
||||||
|
system(which gpgme-config >/dev/null 2>&1) {
|
||||||
|
INCLUDEPATH += $$system(gpgme-config --cflags | sed -e "s/-I//g")
|
||||||
|
} else {
|
||||||
|
message(Could not find gpgme-config on your system, assuming gpgme.h is in /usr/include)
|
||||||
|
}
|
||||||
|
|
||||||
|
PRE_TARGETDEPS *= /home/crispy/workspace/v0.5-gxs-b1/libretroshare/src/lib/libretroshare.a
|
||||||
|
|
||||||
|
LIBS += /home/crispy/workspace/v0.5-gxs-b1/libretroshare/src/lib/libretroshare.a
|
||||||
|
LIBS += /home/crispy/workspace/v0.5-gxs-b1/libbitdht/src/lib/libbitdht.a
|
||||||
|
LIBS += /home/crispy/workspace/v0.5-gxs-b1/openpgpsdk/src/lib/libops.a
|
||||||
|
LIBS += -lssl -lgpgme -lupnp -lixml -lgnome-keyring -lsqlite3 -lbz2
|
||||||
|
LIBS *= -rdynamic -frtti
|
||||||
|
DEFINES *= HAVE_XSS # for idle time, libx screensaver extensions
|
||||||
|
DEFINES *= UBUNTU
|
||||||
|
}
|
||||||
|
|
||||||
|
linux-g++ {
|
||||||
|
OBJECTS_DIR = temp/linux-g++/obj
|
||||||
|
}
|
||||||
|
|
||||||
|
linux-g++-64 {
|
||||||
|
OBJECTS_DIR = temp/linux-g++-64/obj
|
||||||
|
}
|
||||||
|
|
||||||
|
version_detail_bash_script {
|
||||||
|
DEFINES += ADD_LIBRETROSHARE_VERSION_INFO
|
||||||
|
QMAKE_EXTRA_TARGETS += write_version_detail
|
||||||
|
PRE_TARGETDEPS = write_version_detail
|
||||||
|
write_version_detail.commands = ./version_detail.sh
|
||||||
|
}
|
||||||
|
|
||||||
|
install_rs {
|
||||||
|
INSTALLS += binary_rs
|
||||||
|
binary_rs.path = $$(PREFIX)/usr/bin
|
||||||
|
binary_rs.files = ./RetroShare
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
SOURCES += \
|
||||||
|
/home/crispy/workspace/v0.5-gxs-b1/libretroshare/src/tests/gxs/data_support.cc \
|
||||||
|
/home/crispy/workspace/v0.5-gxs-b1/libretroshare/src/tests/gxs/nxstesthub.cc \
|
||||||
|
/home/crispy/workspace/v0.5-gxs-b1/libretroshare/src/tests/gxs/nxstestscenario.cc \
|
||||||
|
/home/crispy/workspace/v0.5-gxs-b1/libretroshare/src/tests/gxs/rsgxsnetservice_test.cc \
|
||||||
|
/home/crispy/workspace/v0.5-gxs-b1/libretroshare/src/tests/gxs/support.cc
|
||||||
|
|
||||||
|
|
||||||
|
HEADERS += \
|
||||||
|
/home/crispy/workspace/v0.5-gxs-b1/libretroshare/src/tests/gxs/data_support.h \
|
||||||
|
/home/crispy/workspace/v0.5-gxs-b1/libretroshare/src/tests/gxs/nxstesthub.h \
|
||||||
|
/home/crispy/workspace/v0.5-gxs-b1/libretroshare/src/tests/gxs/nxstestscenario.h \
|
||||||
|
/home/crispy/workspace/v0.5-gxs-b1/libretroshare/src/tests/gxs/support.h
|
||||||
|
|
||||||
|
INCLUDEPATH += /home/crispy/workspace/v0.5-gxs-b1/libretroshare/src
|
||||||
|
|
@ -2,6 +2,7 @@
|
|||||||
#include "support.h"
|
#include "support.h"
|
||||||
#include "data_support.h"
|
#include "data_support.h"
|
||||||
#include "rsdataservice_test.h"
|
#include "rsdataservice_test.h"
|
||||||
|
#include "gxs/rsgds.h"
|
||||||
#include "gxs/rsdataservice.h"
|
#include "gxs/rsdataservice.h"
|
||||||
|
|
||||||
#define DATA_BASE_NAME "msg_grp_Store"
|
#define DATA_BASE_NAME "msg_grp_Store"
|
||||||
@ -57,9 +58,9 @@ void test_groupStoreAndRetrieve(){
|
|||||||
|
|
||||||
dStore->storeGroup(grps);
|
dStore->storeGroup(grps);
|
||||||
|
|
||||||
std::map<std::string, RsNxsGrp*> gR;
|
std::map<RsGxsGroupId, RsNxsGrp*> gR;
|
||||||
std::map<std::string, RsGxsGrpMetaData*> grpMetaR;
|
std::map<RsGxsGroupId, RsGxsGrpMetaData*> grpMetaR;
|
||||||
dStore->retrieveNxsGrps(gR, false);
|
dStore->retrieveNxsGrps(gR, false, false);
|
||||||
dStore->retrieveGxsGrpMetaData(grpMetaR);
|
dStore->retrieveGxsGrpMetaData(grpMetaR);
|
||||||
|
|
||||||
std::map<RsNxsGrp*, RsGxsGrpMetaData*>::iterator mit = grps.begin();
|
std::map<RsNxsGrp*, RsGxsGrpMetaData*>::iterator mit = grps.begin();
|
||||||
@ -164,7 +165,7 @@ void test_messageStoresAndRetrieve()
|
|||||||
const std::string& grpId = grpV[chosen];
|
const std::string& grpId = grpV[chosen];
|
||||||
|
|
||||||
if(chosen)
|
if(chosen)
|
||||||
req[grpId].insert(msg->msgId);
|
req[grpId].push_back(msg->msgId);
|
||||||
|
|
||||||
msgMeta->mMsgId = msg->msgId;
|
msgMeta->mMsgId = msg->msgId;
|
||||||
msgMeta->mGroupId = msg->grpId = grpId;
|
msgMeta->mGroupId = msg->grpId = grpId;
|
||||||
@ -189,7 +190,7 @@ void test_messageStoresAndRetrieve()
|
|||||||
msgs.insert(p);
|
msgs.insert(p);
|
||||||
}
|
}
|
||||||
|
|
||||||
req[grpV[0]] = std::set<std::string>(); // assign empty list for other
|
req[grpV[0]] = std::vector<RsGxsMessageId>(); // assign empty list for other
|
||||||
|
|
||||||
dStore->storeMessage(msgs);
|
dStore->storeMessage(msgs);
|
||||||
|
|
||||||
@ -199,7 +200,8 @@ void test_messageStoresAndRetrieve()
|
|||||||
GxsMsgResult msgResult;
|
GxsMsgResult msgResult;
|
||||||
GxsMsgMetaResult msgMetaResult;
|
GxsMsgMetaResult msgMetaResult;
|
||||||
dStore->retrieveNxsMsgs(req, msgResult, false);
|
dStore->retrieveNxsMsgs(req, msgResult, false);
|
||||||
dStore->retrieveGxsMsgMetaData(grpV, msgMetaResult);
|
|
||||||
|
dStore->retrieveGxsMsgMetaData(req, msgMetaResult);
|
||||||
|
|
||||||
// now look at result for grpId 1
|
// now look at result for grpId 1
|
||||||
std::vector<RsNxsMsg*>& result0 = msgResult[grpId0];
|
std::vector<RsNxsMsg*>& result0 = msgResult[grpId0];
|
||||||
|
Loading…
Reference in New Issue
Block a user