mirror of
https://github.com/RetroShare/RetroShare.git
synced 2025-01-04 04:11:06 -05:00
Merge pull request #592 from csoler/v0.6-GXS-LimitedSync2
V0.6 gxs limited sync2
This commit is contained in:
commit
12023397ee
@ -128,7 +128,6 @@ bool RsGenExchange::getGroupServerUpdateTS(const RsGxsGroupId& gid, time_t& grp_
|
|||||||
|
|
||||||
void RsGenExchange::data_tick()
|
void RsGenExchange::data_tick()
|
||||||
{
|
{
|
||||||
|
|
||||||
static const double timeDelta = 0.1; // slow tick in sec
|
static const double timeDelta = 0.1; // slow tick in sec
|
||||||
|
|
||||||
tick();
|
tick();
|
||||||
@ -181,9 +180,10 @@ void RsGenExchange::tick()
|
|||||||
mLastClean = time(NULL);
|
mLastClean = time(NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
}else
|
}
|
||||||
|
else
|
||||||
{
|
{
|
||||||
mMsgCleanUp = new RsGxsMessageCleanUp(mDataStore, MESSAGE_STORE_PERIOD, 1);
|
mMsgCleanUp = new RsGxsMessageCleanUp(mDataStore, this, 1);
|
||||||
mCleaning = true;
|
mCleaning = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -229,7 +229,7 @@ void RsGenExchange::tick()
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
mIntegrityCheck = new RsGxsIntegrityCheck(mDataStore,mGixs);
|
mIntegrityCheck = new RsGxsIntegrityCheck(mDataStore,this,mGixs);
|
||||||
mIntegrityCheck->start("gxs integrity");
|
mIntegrityCheck->start("gxs integrity");
|
||||||
mChecking = true;
|
mChecking = true;
|
||||||
}
|
}
|
||||||
@ -1608,6 +1608,54 @@ void RsGenExchange::publishMsg(uint32_t& token, RsGxsMsgItem *msgItem)
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
uint32_t RsGenExchange::getDefaultSyncPeriod()
|
||||||
|
{
|
||||||
|
RS_STACK_MUTEX(mGenMtx) ;
|
||||||
|
|
||||||
|
if(mNetService != NULL)
|
||||||
|
return mNetService->getDefaultSyncAge();
|
||||||
|
else
|
||||||
|
{
|
||||||
|
std::cerr << "(EE) No network service available. Cannot get default sync period. " << std::endl;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
uint32_t RsGenExchange::getSyncPeriod(const RsGxsGroupId& grpId)
|
||||||
|
{
|
||||||
|
RS_STACK_MUTEX(mGenMtx) ;
|
||||||
|
|
||||||
|
if(mNetService != NULL)
|
||||||
|
return mNetService->getSyncAge(grpId);
|
||||||
|
else
|
||||||
|
return RS_GXS_DEFAULT_MSG_REQ_PERIOD;
|
||||||
|
}
|
||||||
|
|
||||||
|
void RsGenExchange::setSyncPeriod(const RsGxsGroupId& grpId,uint32_t age_in_secs)
|
||||||
|
{
|
||||||
|
if(mNetService != NULL)
|
||||||
|
return mNetService->setSyncAge(grpId,age_in_secs) ;
|
||||||
|
else
|
||||||
|
std::cerr << "(EE) No network service available. Cannot set storage period. " << std::endl;
|
||||||
|
}
|
||||||
|
|
||||||
|
uint32_t RsGenExchange::getStoragePeriod(const RsGxsGroupId& grpId)
|
||||||
|
{
|
||||||
|
RS_STACK_MUTEX(mGenMtx) ;
|
||||||
|
|
||||||
|
if(mNetService != NULL)
|
||||||
|
return mNetService->getKeepAge(grpId,MESSAGE_STORE_PERIOD) ;
|
||||||
|
else
|
||||||
|
return MESSAGE_STORE_PERIOD;
|
||||||
|
}
|
||||||
|
void RsGenExchange::setStoragePeriod(const RsGxsGroupId& grpId,uint32_t age_in_secs)
|
||||||
|
{
|
||||||
|
if(mNetService != NULL)
|
||||||
|
return mNetService->setKeepAge(grpId,age_in_secs) ;
|
||||||
|
else
|
||||||
|
std::cerr << "(EE) No network service available. Cannot set storage period. " << std::endl;
|
||||||
|
}
|
||||||
|
|
||||||
void RsGenExchange::setGroupSubscribeFlags(uint32_t& token, const RsGxsGroupId& grpId, const uint32_t& flag, const uint32_t& mask)
|
void RsGenExchange::setGroupSubscribeFlags(uint32_t& token, const RsGxsGroupId& grpId, const uint32_t& flag, const uint32_t& mask)
|
||||||
{
|
{
|
||||||
/* TODO APPLY MASK TO FLAGS */
|
/* TODO APPLY MASK TO FLAGS */
|
||||||
@ -2674,6 +2722,18 @@ void RsGenExchange::processRecvdMessages()
|
|||||||
|
|
||||||
msg->metaData = meta;
|
msg->metaData = meta;
|
||||||
|
|
||||||
|
// (cyril) Normally we should discard posts that are older than the sync request. But that causes a problem because
|
||||||
|
// RsGxsNetService requests posts to sync by chunks of 20. So if the 20 are discarded, they will be re-synced next time, and the sync process
|
||||||
|
// will indefinitly loop on the same 20 posts. Since the posts are there already, keeping them is the least problematique way to fix this problem.
|
||||||
|
//
|
||||||
|
// uint32_t max_sync_age = ( mNetService != NULL)?( mNetService->getSyncAge(msg->metaData->mGroupId)):RS_GXS_DEFAULT_MSG_REQ_PERIOD;
|
||||||
|
//
|
||||||
|
// if(max_sync_age != 0 && msg->metaData->mPublishTs + max_sync_age < time(NULL))
|
||||||
|
// {
|
||||||
|
// std::cerr << "(WW) not validating message " << msg->metaData->mMsgId << " in group " << msg->metaData->mGroupId << " because it is older than synchronisation limit. This message was probably sent by a friend node that does not accept sync limits already." << std::endl;
|
||||||
|
// ok = false ;
|
||||||
|
// }
|
||||||
|
|
||||||
#ifdef GEN_EXCH_DEBUG
|
#ifdef GEN_EXCH_DEBUG
|
||||||
std::cerr << " deserialised info: grp id=" << meta->mGroupId << ", msg id=" << meta->mMsgId ;
|
std::cerr << " deserialised info: grp id=" << meta->mGroupId << ", msg id=" << meta->mMsgId ;
|
||||||
#endif
|
#endif
|
||||||
|
@ -39,8 +39,6 @@
|
|||||||
#include "serialiser/rsnxsitems.h"
|
#include "serialiser/rsnxsitems.h"
|
||||||
#include "rsgxsutil.h"
|
#include "rsgxsutil.h"
|
||||||
|
|
||||||
#define DEFAULT_MSG_STORE_PERIOD 60*60*24*31*4 // 4 months
|
|
||||||
|
|
||||||
template<class GxsItem, typename Identity = std::string>
|
template<class GxsItem, typename Identity = std::string>
|
||||||
class GxsPendingItem
|
class GxsPendingItem
|
||||||
{
|
{
|
||||||
@ -128,7 +126,7 @@ public:
|
|||||||
*/
|
*/
|
||||||
RsGenExchange(RsGeneralDataService* gds, RsNetworkExchangeService* ns,
|
RsGenExchange(RsGeneralDataService* gds, RsNetworkExchangeService* ns,
|
||||||
RsSerialType* serviceSerialiser, uint16_t mServType, RsGixs* gixs, uint32_t authenPolicy,
|
RsSerialType* serviceSerialiser, uint16_t mServType, RsGixs* gixs, uint32_t authenPolicy,
|
||||||
uint32_t messageStorePeriod = DEFAULT_MSG_STORE_PERIOD);
|
uint32_t messageStorePeriod = RS_GXS_DEFAULT_MSG_STORE_PERIOD);
|
||||||
|
|
||||||
virtual ~RsGenExchange();
|
virtual ~RsGenExchange();
|
||||||
|
|
||||||
@ -613,11 +611,6 @@ public:
|
|||||||
*/
|
*/
|
||||||
void updateGroupLastMsgTimeStamp(uint32_t& token, const RsGxsGroupId& grpId);
|
void updateGroupLastMsgTimeStamp(uint32_t& token, const RsGxsGroupId& grpId);
|
||||||
|
|
||||||
/*!
|
|
||||||
* @return storage time of messages in months
|
|
||||||
*/
|
|
||||||
int getStoragePeriod(){ return MESSAGE_STORE_PERIOD/(60*60*24*31);}
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* sets the msg status flag
|
* sets the msg status flag
|
||||||
* @param token this is set to token value associated to this request
|
* @param token this is set to token value associated to this request
|
||||||
@ -649,6 +642,20 @@ public:
|
|||||||
*/
|
*/
|
||||||
bool getGroupServerUpdateTS(const RsGxsGroupId& gid,time_t& grp_server_update_TS,time_t& msg_server_update_TS) ;
|
bool getGroupServerUpdateTS(const RsGxsGroupId& gid,time_t& grp_server_update_TS,time_t& msg_server_update_TS) ;
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief getDefaultStoragePeriod. All times in seconds.
|
||||||
|
* \return
|
||||||
|
*/
|
||||||
|
virtual uint32_t getDefaultStoragePeriod() { return MESSAGE_STORE_PERIOD; }
|
||||||
|
|
||||||
|
virtual uint32_t getStoragePeriod(const RsGxsGroupId& grpId) ;
|
||||||
|
virtual void setStoragePeriod(const RsGxsGroupId& grpId,uint32_t age_in_secs) ;
|
||||||
|
|
||||||
|
virtual uint32_t getDefaultSyncPeriod();
|
||||||
|
virtual uint32_t getSyncPeriod(const RsGxsGroupId& grpId) ;
|
||||||
|
virtual void setSyncPeriod(const RsGxsGroupId& grpId,uint32_t age_in_secs) ;
|
||||||
|
|
||||||
|
uint16_t serviceType() const { return mServType ; }
|
||||||
protected:
|
protected:
|
||||||
|
|
||||||
/** Notifications **/
|
/** Notifications **/
|
||||||
@ -821,8 +828,6 @@ private:
|
|||||||
*/
|
*/
|
||||||
void removeDeleteExistingMessages(RsGeneralDataService::MsgStoreMap& msgs, GxsMsgReq& msgIdsNotify);
|
void removeDeleteExistingMessages(RsGeneralDataService::MsgStoreMap& msgs, GxsMsgReq& msgIdsNotify);
|
||||||
|
|
||||||
private:
|
|
||||||
|
|
||||||
RsMutex mGenMtx;
|
RsMutex mGenMtx;
|
||||||
RsGxsDataAccess* mDataAccess;
|
RsGxsDataAccess* mDataAccess;
|
||||||
RsGeneralDataService* mDataStore;
|
RsGeneralDataService* mDataStore;
|
||||||
@ -862,7 +867,6 @@ private:
|
|||||||
std::vector<GxsPendingItem<RsNxsMsg*, RsGxsGrpMsgIdPair> > mMsgPendingValidate;
|
std::vector<GxsPendingItem<RsNxsMsg*, RsGxsGrpMsgIdPair> > mMsgPendingValidate;
|
||||||
typedef std::vector<GxsPendingItem<RsNxsMsg*, RsGxsGrpMsgIdPair> > NxsMsgPendingVect;
|
typedef std::vector<GxsPendingItem<RsNxsMsg*, RsGxsGrpMsgIdPair> > NxsMsgPendingVect;
|
||||||
|
|
||||||
|
|
||||||
const uint32_t MESSAGE_STORE_PERIOD;
|
const uint32_t MESSAGE_STORE_PERIOD;
|
||||||
|
|
||||||
bool mCleaning;
|
bool mCleaning;
|
||||||
|
@ -35,5 +35,10 @@
|
|||||||
typedef std::map<RsGxsGroupId, std::vector<RsGxsMsgMetaData*> > GxsMsgMetaResult;
|
typedef std::map<RsGxsGroupId, std::vector<RsGxsMsgMetaData*> > GxsMsgMetaResult;
|
||||||
typedef std::map<RsGxsGrpMsgIdPair, std::vector<RsGxsMsgMetaData*> > MsgRelatedMetaResult;
|
typedef std::map<RsGxsGrpMsgIdPair, std::vector<RsGxsMsgMetaData*> > MsgRelatedMetaResult;
|
||||||
|
|
||||||
|
// Default values that are used throughout GXS code
|
||||||
|
|
||||||
|
static const uint32_t RS_GXS_DEFAULT_MSG_STORE_PERIOD = 86400 * 30 * 6 ; // six months. Default time for which messages are keps in the database.
|
||||||
|
static const uint32_t RS_GXS_DEFAULT_MSG_SEND_PERIOD = 86400 * 30 * 1 ; // one month. Default delay after which we don't send messages
|
||||||
|
static const uint32_t RS_GXS_DEFAULT_MSG_REQ_PERIOD = 86400 * 30 * 1 ; // one month. Default Delay after which we don't request messages
|
||||||
|
|
||||||
#endif // RSGXS_H
|
#endif // RSGXS_H
|
||||||
|
File diff suppressed because it is too large
Load Diff
@ -103,11 +103,16 @@ public:
|
|||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* Use this to set how far back synchronisation of messages should take place
|
* Use this to set how far back synchronisation and storage of messages should take place
|
||||||
* @param age the max age a sync item can to be allowed in a synchronisation
|
* @param age the max age a sync/storage item can to be allowed in a synchronisation
|
||||||
*/
|
*/
|
||||||
// NOT IMPLEMENTED
|
virtual void setSyncAge(const RsGxsGroupId& grpId,uint32_t age_in_secs);
|
||||||
virtual void setSyncAge(uint32_t age);
|
virtual void setKeepAge(const RsGxsGroupId& grpId,uint32_t age_in_secs);
|
||||||
|
|
||||||
|
virtual uint32_t getSyncAge(const RsGxsGroupId& id);
|
||||||
|
virtual uint32_t getKeepAge(const RsGxsGroupId& id,uint32_t default_value);
|
||||||
|
|
||||||
|
virtual uint32_t getDefaultSyncAge() { return RS_GXS_DEFAULT_MSG_REQ_PERIOD ; }
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* pauses synchronisation of subscribed groups and request for group id
|
* pauses synchronisation of subscribed groups and request for group id
|
||||||
@ -402,6 +407,7 @@ private:
|
|||||||
|
|
||||||
bool locked_CanReceiveUpdate(const RsNxsSyncGrpReqItem *item);
|
bool locked_CanReceiveUpdate(const RsNxsSyncGrpReqItem *item);
|
||||||
bool locked_CanReceiveUpdate(RsNxsSyncMsgReqItem *item, bool &grp_is_known);
|
bool locked_CanReceiveUpdate(RsNxsSyncMsgReqItem *item, bool &grp_is_known);
|
||||||
|
void locked_resetClientTS(const RsGxsGroupId& grpId);
|
||||||
|
|
||||||
static RsGxsGroupId hashGrpId(const RsGxsGroupId& gid,const RsPeerId& pid) ;
|
static RsGxsGroupId hashGrpId(const RsGxsGroupId& gid,const RsPeerId& pid) ;
|
||||||
|
|
||||||
@ -482,6 +488,7 @@ private:
|
|||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
|
static void locked_checkDelay(uint32_t& time_in_secs);
|
||||||
|
|
||||||
/*** transactions ***/
|
/*** transactions ***/
|
||||||
|
|
||||||
@ -542,18 +549,18 @@ private:
|
|||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
typedef std::map<RsPeerId, RsGxsMsgUpdateItem*> ClientMsgMap;
|
typedef std::map<RsPeerId, RsGxsMsgUpdate> ClientMsgMap;
|
||||||
typedef std::map<RsGxsGroupId, RsGxsServerMsgUpdateItem*> ServerMsgMap;
|
typedef std::map<RsGxsGroupId, RsGxsServerMsgUpdate> ServerMsgMap;
|
||||||
typedef std::map<RsPeerId, RsGxsGrpUpdateItem*> ClientGrpMap;
|
typedef std::map<RsPeerId, RsGxsGrpUpdate> ClientGrpMap;
|
||||||
|
typedef std::map<RsGxsGroupId, RsGxsGrpConfig> GrpConfigMap;
|
||||||
private:
|
private:
|
||||||
|
|
||||||
ClientMsgMap mClientMsgUpdateMap;
|
ClientMsgMap mClientMsgUpdateMap;
|
||||||
ServerMsgMap mServerMsgUpdateMap;
|
ServerMsgMap mServerMsgUpdateMap;
|
||||||
ClientGrpMap mClientGrpUpdateMap;
|
ClientGrpMap mClientGrpUpdateMap;
|
||||||
|
GrpConfigMap mServerGrpConfigMap;
|
||||||
|
|
||||||
std::map<RsGxsGroupId,RsGroupNetworkStatsRecord> mGroupNetworkStats ;
|
RsGxsServerGrpUpdate mGrpServerUpdate;
|
||||||
|
|
||||||
RsGxsServerGrpUpdateItem* mGrpServerUpdateItem;
|
|
||||||
RsServiceInfo mServiceInfo;
|
RsServiceInfo mServiceInfo;
|
||||||
|
|
||||||
std::map<RsGxsMessageId,time_t> mRejectedMessages;
|
std::map<RsGxsMessageId,time_t> mRejectedMessages;
|
||||||
|
@ -33,10 +33,12 @@
|
|||||||
|
|
||||||
static const uint32_t MAX_GXS_IDS_REQUESTS_NET = 10 ; // max number of requests from cache/net (avoids killing the system!)
|
static const uint32_t MAX_GXS_IDS_REQUESTS_NET = 10 ; // max number of requests from cache/net (avoids killing the system!)
|
||||||
|
|
||||||
//#define GXSUTIL_DEBUG 1
|
//#define DEBUG_GXSUTIL 1
|
||||||
|
|
||||||
RsGxsMessageCleanUp::RsGxsMessageCleanUp(RsGeneralDataService* const dataService, uint32_t messageStorePeriod, uint32_t chunkSize)
|
#define GXSUTIL_DEBUG() std::cerr << time(NULL) << " : GXS_UTIL : " << __FUNCTION__ << " : "
|
||||||
: mDs(dataService), MESSAGE_STORE_PERIOD(messageStorePeriod), CHUNK_SIZE(chunkSize)
|
|
||||||
|
RsGxsMessageCleanUp::RsGxsMessageCleanUp(RsGeneralDataService* const dataService, RsGenExchange *genex, uint32_t chunkSize)
|
||||||
|
: mDs(dataService), mGenExchangeClient(genex), CHUNK_SIZE(chunkSize)
|
||||||
{
|
{
|
||||||
|
|
||||||
std::map<RsGxsGroupId, RsGxsGrpMetaData*> grpMeta;
|
std::map<RsGxsGroupId, RsGxsGrpMetaData*> grpMeta;
|
||||||
@ -45,18 +47,18 @@ RsGxsMessageCleanUp::RsGxsMessageCleanUp(RsGeneralDataService* const dataService
|
|||||||
std::map<RsGxsGroupId, RsGxsGrpMetaData*>::iterator cit = grpMeta.begin();
|
std::map<RsGxsGroupId, RsGxsGrpMetaData*>::iterator cit = grpMeta.begin();
|
||||||
|
|
||||||
for(;cit != grpMeta.end(); ++cit)
|
for(;cit != grpMeta.end(); ++cit)
|
||||||
{
|
|
||||||
mGrpMeta.push_back(cit->second);
|
mGrpMeta.push_back(cit->second);
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
bool RsGxsMessageCleanUp::clean()
|
bool RsGxsMessageCleanUp::clean()
|
||||||
{
|
{
|
||||||
uint32_t i = 1;
|
uint32_t i = 1;
|
||||||
|
|
||||||
time_t now = time(NULL);
|
time_t now = time(NULL);
|
||||||
|
|
||||||
|
#ifdef DEBUG_GXSUTIL
|
||||||
|
GXSUTIL_DEBUG() << " Cleaning up groups in service" << std::hex << mGenExchangeClient->serviceType() << std::dec << std::endl;
|
||||||
|
#endif
|
||||||
while(!mGrpMeta.empty())
|
while(!mGrpMeta.empty())
|
||||||
{
|
{
|
||||||
RsGxsGrpMetaData* grpMeta = mGrpMeta.back();
|
RsGxsGrpMetaData* grpMeta = mGrpMeta.back();
|
||||||
@ -70,8 +72,13 @@ bool RsGxsMessageCleanUp::clean()
|
|||||||
|
|
||||||
GxsMsgMetaResult::iterator mit = result.begin();
|
GxsMsgMetaResult::iterator mit = result.begin();
|
||||||
|
|
||||||
|
#ifdef DEBUG_GXSUTIL
|
||||||
|
GXSUTIL_DEBUG() << " Cleaning up group message for group ID " << grpId << std::endl;
|
||||||
|
#endif
|
||||||
req.clear();
|
req.clear();
|
||||||
|
|
||||||
|
uint32_t store_period = mGenExchangeClient->getStoragePeriod(grpId) ;
|
||||||
|
|
||||||
for(; mit != result.end(); ++mit)
|
for(; mit != result.end(); ++mit)
|
||||||
{
|
{
|
||||||
std::vector<RsGxsMsgMetaData*>& metaV = mit->second;
|
std::vector<RsGxsMsgMetaData*>& metaV = mit->second;
|
||||||
@ -82,7 +89,7 @@ bool RsGxsMessageCleanUp::clean()
|
|||||||
RsGxsMsgMetaData* meta = *vit;
|
RsGxsMsgMetaData* meta = *vit;
|
||||||
|
|
||||||
// check if expired
|
// check if expired
|
||||||
bool remove = (meta->mPublishTs + MESSAGE_STORE_PERIOD) < now;
|
bool remove = store_period > 0 && (meta->mPublishTs + store_period) < now;
|
||||||
|
|
||||||
// check client does not want the message kept regardless of age
|
// check client does not want the message kept regardless of age
|
||||||
remove &= !(meta->mMsgStatus & GXS_SERV::GXS_MSG_STATUS_KEEP);
|
remove &= !(meta->mMsgStatus & GXS_SERV::GXS_MSG_STATUS_KEEP);
|
||||||
@ -95,7 +102,7 @@ bool RsGxsMessageCleanUp::clean()
|
|||||||
{
|
{
|
||||||
req[grpId].push_back(meta->mMsgId);
|
req[grpId].push_back(meta->mMsgId);
|
||||||
|
|
||||||
std::cerr << "Scheduling msg id " << meta->mMsgId << " in grp " << grpId << " for removal." << std::endl;
|
GXSUTIL_DEBUG() << " Scheduling msg id " << meta->mMsgId << " in grp " << grpId << " for removal." << std::endl;
|
||||||
}
|
}
|
||||||
|
|
||||||
delete meta;
|
delete meta;
|
||||||
@ -114,8 +121,8 @@ bool RsGxsMessageCleanUp::clean()
|
|||||||
return mGrpMeta.empty();
|
return mGrpMeta.empty();
|
||||||
}
|
}
|
||||||
|
|
||||||
RsGxsIntegrityCheck::RsGxsIntegrityCheck(RsGeneralDataService* const dataService, RsGixs *gixs) :
|
RsGxsIntegrityCheck::RsGxsIntegrityCheck(RsGeneralDataService* const dataService, RsGenExchange *genex, RsGixs *gixs) :
|
||||||
mDs(dataService), mDone(false), mIntegrityMutex("integrity"),mGixs(gixs)
|
mDs(dataService),mGenExchangeClient(genex), mDone(false), mIntegrityMutex("integrity"),mGixs(gixs)
|
||||||
{ }
|
{ }
|
||||||
|
|
||||||
void RsGxsIntegrityCheck::run()
|
void RsGxsIntegrityCheck::run()
|
||||||
@ -160,8 +167,8 @@ bool RsGxsIntegrityCheck::check()
|
|||||||
|
|
||||||
if(!grp->metaData->mAuthorId.isNull())
|
if(!grp->metaData->mAuthorId.isNull())
|
||||||
{
|
{
|
||||||
#ifdef GXSUTIL_DEBUG
|
#ifdef DEBUG_GXSUTIL
|
||||||
std::cerr << "TimeStamping group authors' key ID " << grp->metaData->mAuthorId << " in group ID " << grp->grpId << std::endl;
|
GXSUTIL_DEBUG() << "TimeStamping group authors' key ID " << grp->metaData->mAuthorId << " in group ID " << grp->grpId << std::endl;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if(rsIdentity!=NULL && !rsIdentity->isBanned(grp->metaData->mAuthorId))
|
if(rsIdentity!=NULL && !rsIdentity->isBanned(grp->metaData->mAuthorId))
|
||||||
@ -180,6 +187,22 @@ bool RsGxsIntegrityCheck::check()
|
|||||||
{
|
{
|
||||||
grpsToDel.push_back(grp->grpId);
|
grpsToDel.push_back(grp->grpId);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef TODO
|
||||||
|
if(!(grp->metaData->mSubscribeFlags & GXS_SERV::GROUP_SUBSCRIBE_SUBSCRIBED))
|
||||||
|
{
|
||||||
|
RsGroupNetworkStats stats ;
|
||||||
|
mGenExchangeClient->getGroupNetworkStats(grp->grpId,stats);
|
||||||
|
|
||||||
|
if(stats.mSuppliers == 0 && stats.mMaxVisibleCount == 0)
|
||||||
|
{
|
||||||
|
GXSUTIL_DEBUG() << "Scheduling group \"" << grp->metaData->mGroupName << "\" ID=" << grp->grpId << " for deletion because it has no suppliers not any visible data at friends." << std::endl;
|
||||||
|
#warning Should we do that here? What happens for groups that are normally empty such as identities?
|
||||||
|
grpsToDel.push_back(grp->grpId);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
delete grp;
|
delete grp;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -243,8 +266,8 @@ bool RsGxsIntegrityCheck::check()
|
|||||||
}
|
}
|
||||||
else if(!msg->metaData->mAuthorId.isNull() && subscribed_groups.find(msg->metaData->mGroupId)!=subscribed_groups.end())
|
else if(!msg->metaData->mAuthorId.isNull() && subscribed_groups.find(msg->metaData->mGroupId)!=subscribed_groups.end())
|
||||||
{
|
{
|
||||||
#ifdef GXSUTIL_DEBUG
|
#ifdef DEBUG_GXSUTIL
|
||||||
std::cerr << "TimeStamping message authors' key ID " << msg->metaData->mAuthorId << " in message " << msg->msgId << ", group ID " << msg->grpId<< std::endl;
|
GXSUTIL_DEBUG() << "TimeStamping message authors' key ID " << msg->metaData->mAuthorId << " in message " << msg->msgId << ", group ID " << msg->grpId<< std::endl;
|
||||||
#endif
|
#endif
|
||||||
if(rsIdentity!=NULL && !rsIdentity->isBanned(msg->metaData->mAuthorId))
|
if(rsIdentity!=NULL && !rsIdentity->isBanned(msg->metaData->mAuthorId))
|
||||||
used_gxs_ids.insert(msg->metaData->mAuthorId) ;
|
used_gxs_ids.insert(msg->metaData->mAuthorId) ;
|
||||||
@ -266,9 +289,9 @@ bool RsGxsIntegrityCheck::check()
|
|||||||
}
|
}
|
||||||
mDeletedMsgs = msgsToDel;
|
mDeletedMsgs = msgsToDel;
|
||||||
|
|
||||||
#ifdef GXSUTIL_DEBUG
|
#ifdef DEBUG_GXSUTIL
|
||||||
std::cerr << "At end of pass, this is the list used GXS ids: " << std::endl;
|
GXSUTIL_DEBUG() << "At end of pass, this is the list used GXS ids: " << std::endl;
|
||||||
std::cerr << " requesting them to GXS identity service to enforce loading." << std::endl;
|
GXSUTIL_DEBUG() << " requesting them to GXS identity service to enforce loading." << std::endl;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
std::list<RsPeerId> connected_friends ;
|
std::list<RsPeerId> connected_friends ;
|
||||||
@ -279,14 +302,14 @@ bool RsGxsIntegrityCheck::check()
|
|||||||
for(std::set<RsGxsId>::const_iterator it(used_gxs_ids.begin());it!=used_gxs_ids.end();++it)
|
for(std::set<RsGxsId>::const_iterator it(used_gxs_ids.begin());it!=used_gxs_ids.end();++it)
|
||||||
{
|
{
|
||||||
gxs_ids.push_back(*it) ;
|
gxs_ids.push_back(*it) ;
|
||||||
#ifdef GXSUTIL_DEBUG
|
#ifdef DEBUG_GXSUTIL
|
||||||
std::cerr << " " << *it << std::endl;
|
GXSUTIL_DEBUG() << " " << *it << std::endl;
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
uint32_t nb_requested_not_in_cache = 0;
|
uint32_t nb_requested_not_in_cache = 0;
|
||||||
|
|
||||||
#ifdef GXSUTIL_DEBUG
|
#ifdef DEBUG_GXSUTIL
|
||||||
std::cerr << " issuing random get on friends for non existing IDs" << std::endl;
|
GXSUTIL_DEBUG() << " issuing random get on friends for non existing IDs" << std::endl;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// now request a cache update for them, which triggers downloading from friends, if missing.
|
// now request a cache update for them, which triggers downloading from friends, if missing.
|
||||||
@ -294,8 +317,8 @@ bool RsGxsIntegrityCheck::check()
|
|||||||
for(;nb_requested_not_in_cache<MAX_GXS_IDS_REQUESTS_NET && !gxs_ids.empty();)
|
for(;nb_requested_not_in_cache<MAX_GXS_IDS_REQUESTS_NET && !gxs_ids.empty();)
|
||||||
{
|
{
|
||||||
uint32_t n = RSRandom::random_u32() % gxs_ids.size() ;
|
uint32_t n = RSRandom::random_u32() % gxs_ids.size() ;
|
||||||
#ifdef GXSUTIL_DEBUG
|
#ifdef DEBUG_GXSUTIL
|
||||||
std::cerr << " requesting ID " << gxs_ids[n] ;
|
GXSUTIL_DEBUG() << " requesting ID " << gxs_ids[n] ;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if(!mGixs->haveKey(gxs_ids[n])) // checks if we have it already in the cache (conservative way to ensure that we atually have it)
|
if(!mGixs->haveKey(gxs_ids[n])) // checks if we have it already in the cache (conservative way to ensure that we atually have it)
|
||||||
@ -303,14 +326,14 @@ bool RsGxsIntegrityCheck::check()
|
|||||||
mGixs->requestKey(gxs_ids[n],connected_friends);
|
mGixs->requestKey(gxs_ids[n],connected_friends);
|
||||||
|
|
||||||
++nb_requested_not_in_cache ;
|
++nb_requested_not_in_cache ;
|
||||||
#ifdef GXSUTIL_DEBUG
|
#ifdef DEBUG_GXSUTIL
|
||||||
std::cerr << " ... from cache/net" << std::endl;
|
GXSUTIL_DEBUG() << " ... from cache/net" << std::endl;
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
#ifdef GXSUTIL_DEBUG
|
#ifdef DEBUG_GXSUTIL
|
||||||
std::cerr << " ... already in cache" << std::endl;
|
GXSUTIL_DEBUG() << " ... already in cache" << std::endl;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Note: we could time_stamp even in the case where the id is not cached. Anyway, it's not really a problem here, since IDs have a high chance of
|
// Note: we could time_stamp even in the case where the id is not cached. Anyway, it's not really a problem here, since IDs have a high chance of
|
||||||
@ -322,8 +345,8 @@ bool RsGxsIntegrityCheck::check()
|
|||||||
gxs_ids[n] = gxs_ids[gxs_ids.size()-1] ;
|
gxs_ids[n] = gxs_ids[gxs_ids.size()-1] ;
|
||||||
gxs_ids.pop_back() ;
|
gxs_ids.pop_back() ;
|
||||||
}
|
}
|
||||||
#ifdef GXSUTIL_DEBUG
|
#ifdef DEBUG_GXSUTIL
|
||||||
std::cerr << " total actual cache requests: "<< nb_requested_not_in_cache << std::endl;
|
GXSUTIL_DEBUG() << " total actual cache requests: "<< nb_requested_not_in_cache << std::endl;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
|
@ -31,6 +31,7 @@
|
|||||||
#include "rsgds.h"
|
#include "rsgds.h"
|
||||||
|
|
||||||
class RsGixs ;
|
class RsGixs ;
|
||||||
|
class RsGenExchange ;
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* Handy function for cleaning out meta result containers
|
* Handy function for cleaning out meta result containers
|
||||||
@ -73,7 +74,7 @@ public:
|
|||||||
* @param chunkSize
|
* @param chunkSize
|
||||||
* @param sleepPeriod
|
* @param sleepPeriod
|
||||||
*/
|
*/
|
||||||
RsGxsMessageCleanUp(RsGeneralDataService* const dataService, uint32_t messageStorePeriod, uint32_t chunkSize);
|
RsGxsMessageCleanUp(RsGeneralDataService* const dataService, RsGenExchange *genex, uint32_t chunkSize);
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* On construction this should be called to progress deletions
|
* On construction this should be called to progress deletions
|
||||||
@ -90,7 +91,8 @@ public:
|
|||||||
private:
|
private:
|
||||||
|
|
||||||
RsGeneralDataService* const mDs;
|
RsGeneralDataService* const mDs;
|
||||||
const uint32_t MESSAGE_STORE_PERIOD, CHUNK_SIZE;
|
RsGenExchange *mGenExchangeClient;
|
||||||
|
uint32_t CHUNK_SIZE;
|
||||||
std::vector<RsGxsGrpMetaData*> mGrpMeta;
|
std::vector<RsGxsGrpMetaData*> mGrpMeta;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -113,8 +115,7 @@ public:
|
|||||||
* @param chunkSize
|
* @param chunkSize
|
||||||
* @param sleepPeriod
|
* @param sleepPeriod
|
||||||
*/
|
*/
|
||||||
RsGxsIntegrityCheck(RsGeneralDataService* const dataService, RsGixs *gixs);
|
RsGxsIntegrityCheck(RsGeneralDataService* const dataService, RsGenExchange *genex, RsGixs *gixs);
|
||||||
|
|
||||||
|
|
||||||
bool check();
|
bool check();
|
||||||
bool isDone();
|
bool isDone();
|
||||||
@ -126,6 +127,7 @@ public:
|
|||||||
private:
|
private:
|
||||||
|
|
||||||
RsGeneralDataService* const mDs;
|
RsGeneralDataService* const mDs;
|
||||||
|
RsGenExchange *mGenExchangeClient;
|
||||||
bool mDone;
|
bool mDone;
|
||||||
RsMutex mIntegrityMutex;
|
RsMutex mIntegrityMutex;
|
||||||
std::list<RsGxsGroupId> mDeletedGrps;
|
std::list<RsGxsGroupId> mDeletedGrps;
|
||||||
|
@ -65,9 +65,15 @@ public:
|
|||||||
|
|
||||||
/*!
|
/*!
|
||||||
* Use this to set how far back synchronisation of messages should take place
|
* Use this to set how far back synchronisation of messages should take place
|
||||||
* @param age the max age a sync item can to be allowed in a synchronisation
|
* @param age in seconds the max age a sync/store item can to be allowed in a synchronisation
|
||||||
*/
|
*/
|
||||||
virtual void setSyncAge(uint32_t age) = 0;
|
virtual void setSyncAge(const RsGxsGroupId& id,uint32_t age_in_secs) =0;
|
||||||
|
virtual void setKeepAge(const RsGxsGroupId& id,uint32_t age_in_secs) =0;
|
||||||
|
|
||||||
|
virtual uint32_t getSyncAge(const RsGxsGroupId& id) =0;
|
||||||
|
virtual uint32_t getKeepAge(const RsGxsGroupId& id,uint32_t default_value) =0;
|
||||||
|
|
||||||
|
virtual uint32_t getDefaultSyncAge() =0;
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* Initiates a search through the network
|
* Initiates a search through the network
|
||||||
|
@ -172,9 +172,15 @@ public:
|
|||||||
virtual void setGroupReputationCutOff(uint32_t& token, const RsGxsGroupId& grpId, int CutOff) = 0;
|
virtual void setGroupReputationCutOff(uint32_t& token, const RsGxsGroupId& grpId, int CutOff) = 0;
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* @return storage time of messages in months
|
* @return storage/sync time of messages in secs
|
||||||
*/
|
*/
|
||||||
virtual int getStoragePeriod() = 0;
|
virtual uint32_t getDefaultStoragePeriod() = 0;
|
||||||
|
virtual uint32_t getStoragePeriod(const RsGxsGroupId& grpId) = 0;
|
||||||
|
virtual void setStoragePeriod(const RsGxsGroupId& grpId,uint32_t age_in_secs) = 0;
|
||||||
|
|
||||||
|
virtual uint32_t getDefaultSyncPeriod() = 0;
|
||||||
|
virtual uint32_t getSyncPeriod(const RsGxsGroupId& grpId) = 0;
|
||||||
|
virtual void setSyncPeriod(const RsGxsGroupId& grpId,uint32_t age_in_secs) = 0;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@ -209,11 +209,31 @@ public:
|
|||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* @return storage time of messages in months
|
* @return storage/sync time of messages in secs
|
||||||
*/
|
*/
|
||||||
int getStoragePeriod()
|
uint32_t getDefaultStoragePeriod()
|
||||||
{
|
{
|
||||||
return mGxs->getStoragePeriod();
|
return mGxs->getDefaultStoragePeriod();
|
||||||
|
}
|
||||||
|
uint32_t getStoragePeriod(const RsGxsGroupId& grpId)
|
||||||
|
{
|
||||||
|
return mGxs->getStoragePeriod(grpId);
|
||||||
|
}
|
||||||
|
void setStoragePeriod(const RsGxsGroupId& grpId,uint32_t age_in_secs)
|
||||||
|
{
|
||||||
|
mGxs->setStoragePeriod(grpId,age_in_secs);
|
||||||
|
}
|
||||||
|
uint32_t getDefaultSyncPeriod()
|
||||||
|
{
|
||||||
|
return mGxs->getDefaultSyncPeriod();
|
||||||
|
}
|
||||||
|
uint32_t getSyncPeriod(const RsGxsGroupId& grpId)
|
||||||
|
{
|
||||||
|
return mGxs->getSyncPeriod(grpId);
|
||||||
|
}
|
||||||
|
void setSyncPeriod(const RsGxsGroupId& grpId,uint32_t age_in_secs)
|
||||||
|
{
|
||||||
|
mGxs->setSyncPeriod(grpId,age_in_secs);
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
@ -26,30 +26,39 @@
|
|||||||
#include "rsgxsupdateitems.h"
|
#include "rsgxsupdateitems.h"
|
||||||
#include "rsbaseserial.h"
|
#include "rsbaseserial.h"
|
||||||
|
|
||||||
|
/**********************************************************************************************/
|
||||||
|
/* CLEAR */
|
||||||
|
/**********************************************************************************************/
|
||||||
|
|
||||||
void RsGxsGrpUpdateItem::clear()
|
void RsGxsGrpUpdateItem::clear()
|
||||||
{
|
{
|
||||||
grpUpdateTS = 0;
|
grpUpdateTS = 0;
|
||||||
peerId.clear();
|
peerID.clear();
|
||||||
}
|
}
|
||||||
std::ostream& RsGxsGrpUpdateItem::print(std::ostream& out, uint16_t indent)
|
|
||||||
{
|
|
||||||
printRsItemBase(out, "RsGxsGrpUpdateItem", indent);
|
|
||||||
uint16_t int_Indent = indent + 2;
|
|
||||||
out << "peerId: " << peerId << std::endl;
|
|
||||||
printIndent(out, int_Indent);
|
|
||||||
out << "grpUpdateTS: " << grpUpdateTS << std::endl;
|
|
||||||
printIndent(out, int_Indent);
|
|
||||||
return out ;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void RsGxsMsgUpdateItem::clear()
|
void RsGxsMsgUpdateItem::clear()
|
||||||
{
|
{
|
||||||
msgUpdateInfos.clear();
|
msgUpdateInfos.clear();
|
||||||
peerId.clear();
|
peerID.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void RsGxsServerMsgUpdateItem::clear()
|
||||||
|
{
|
||||||
|
msgUpdateTS = 0;
|
||||||
|
grpId.clear();
|
||||||
|
}
|
||||||
|
|
||||||
|
void RsGxsServerGrpUpdateItem::clear()
|
||||||
|
{
|
||||||
|
grpUpdateTS = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/**********************************************************************************************/
|
||||||
|
/* PRINT */
|
||||||
|
/**********************************************************************************************/
|
||||||
|
|
||||||
std::ostream& RsGxsMsgUpdateItem::print(std::ostream& out, uint16_t indent)
|
std::ostream& RsGxsMsgUpdateItem::print(std::ostream& out, uint16_t indent)
|
||||||
{
|
{
|
||||||
RsPeerId peerId;
|
RsPeerId peerId;
|
||||||
@ -75,13 +84,15 @@ std::ostream& RsGxsMsgUpdateItem::print(std::ostream& out, uint16_t indent)
|
|||||||
|
|
||||||
return out;
|
return out;
|
||||||
}
|
}
|
||||||
|
std::ostream& RsGxsGrpUpdateItem::print(std::ostream& out, uint16_t indent)
|
||||||
|
|
||||||
|
|
||||||
void RsGxsServerMsgUpdateItem::clear()
|
|
||||||
{
|
{
|
||||||
msgUpdateTS = 0;
|
printRsItemBase(out, "RsGxsGrpUpdateItem", indent);
|
||||||
grpId.clear();
|
uint16_t int_Indent = indent + 2;
|
||||||
|
out << "peerId: " << peerID << std::endl;
|
||||||
|
printIndent(out, int_Indent);
|
||||||
|
out << "grpUpdateTS: " << grpUpdateTS << std::endl;
|
||||||
|
printIndent(out, int_Indent);
|
||||||
|
return out ;
|
||||||
}
|
}
|
||||||
|
|
||||||
std::ostream& RsGxsServerMsgUpdateItem::print(std::ostream& out, uint16_t indent)
|
std::ostream& RsGxsServerMsgUpdateItem::print(std::ostream& out, uint16_t indent)
|
||||||
@ -96,11 +107,6 @@ std::ostream& RsGxsServerMsgUpdateItem::print(std::ostream& out, uint16_t indent
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void RsGxsServerGrpUpdateItem::clear()
|
|
||||||
{
|
|
||||||
grpUpdateTS = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
std::ostream& RsGxsServerGrpUpdateItem::print(std::ostream& out, uint16_t indent)
|
std::ostream& RsGxsServerGrpUpdateItem::print(std::ostream& out, uint16_t indent)
|
||||||
{
|
{
|
||||||
printRsItemBase(out, "RsGxsServerGrpUpdateItem", indent);
|
printRsItemBase(out, "RsGxsServerGrpUpdateItem", indent);
|
||||||
@ -111,63 +117,32 @@ std::ostream& RsGxsServerGrpUpdateItem::print(std::ostream& out, uint16_t indent
|
|||||||
return out;
|
return out;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**********************************************************************************************/
|
||||||
|
/* SERIALISER */
|
||||||
|
/**********************************************************************************************/
|
||||||
|
|
||||||
|
bool RsGxsNetServiceItem::serialise_header(void *data,uint32_t& pktsize,uint32_t& tlvsize, uint32_t& offset) const
|
||||||
uint32_t RsGxsUpdateSerialiser::size(RsItem* item)
|
|
||||||
{
|
{
|
||||||
RsGxsMsgUpdateItem* mui = NULL;
|
tlvsize = serial_size() ;
|
||||||
RsGxsGrpUpdateItem* gui = NULL;
|
offset = 0;
|
||||||
RsGxsServerGrpUpdateItem* gsui = NULL;
|
|
||||||
RsGxsServerMsgUpdateItem* msui = NULL;
|
|
||||||
|
|
||||||
if((mui = dynamic_cast<RsGxsMsgUpdateItem*>(item)) != NULL)
|
if (pktsize < tlvsize)
|
||||||
|
return false; /* not enough space */
|
||||||
|
|
||||||
|
pktsize = tlvsize;
|
||||||
|
|
||||||
|
if(!setRsItemHeader(data, tlvsize, PacketId(), tlvsize))
|
||||||
{
|
{
|
||||||
return sizeGxsMsgUpdate(mui);
|
std::cerr << "RsFileTransferItem::serialise_header(): ERROR. Not enough size!" << std::endl;
|
||||||
}else if(( gui = dynamic_cast<RsGxsGrpUpdateItem*>(item)) != NULL){
|
return false ;
|
||||||
return sizeGxsGrpUpdate(gui);
|
|
||||||
}else if((gsui = dynamic_cast<RsGxsServerGrpUpdateItem*>(item)) != NULL)
|
|
||||||
{
|
|
||||||
return sizeGxsServerGrpUpdate(gsui);
|
|
||||||
}else if((msui = dynamic_cast<RsGxsServerMsgUpdateItem*>(item)) != NULL)
|
|
||||||
{
|
|
||||||
return sizeGxsServerMsgUpdate(msui);
|
|
||||||
}else
|
|
||||||
{
|
|
||||||
#ifdef RSSERIAL_DEBUG
|
|
||||||
std::cerr << "RsGxsUpdateSerialiser::size(): Could not find appropriate size function"
|
|
||||||
<< std::endl;
|
|
||||||
#endif
|
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
bool RsGxsUpdateSerialiser::serialise(RsItem* item, void* data,
|
|
||||||
uint32_t* size)
|
|
||||||
{
|
|
||||||
RsGxsMsgUpdateItem* mui;
|
|
||||||
RsGxsGrpUpdateItem* gui;
|
|
||||||
RsGxsServerGrpUpdateItem* gsui;
|
|
||||||
RsGxsServerMsgUpdateItem* msui;
|
|
||||||
|
|
||||||
if((mui = dynamic_cast<RsGxsMsgUpdateItem*>(item)) != NULL)
|
|
||||||
return serialiseGxsMsgUpdate(mui, data, size);
|
|
||||||
else if((gui = dynamic_cast<RsGxsGrpUpdateItem*>(item)) != NULL)
|
|
||||||
return serialiseGxsGrpUpdate(gui, data, size);
|
|
||||||
else if((msui = dynamic_cast<RsGxsServerMsgUpdateItem*>(item)) != NULL)
|
|
||||||
return serialiseGxsServerMsgUpdate(msui, data, size);
|
|
||||||
else if((gsui = dynamic_cast<RsGxsServerGrpUpdateItem*>(item)) != NULL)
|
|
||||||
return serialiseGxsServerGrpUpdate(gsui, data, size);
|
|
||||||
else
|
|
||||||
{
|
|
||||||
#ifdef RSSERIAL_DEBUG
|
#ifdef RSSERIAL_DEBUG
|
||||||
std::cerr << "RsGxsUpdateSerialiser::serialise() item does not caste to known type"
|
std::cerr << "RsFileItemSerialiser::serialiseData() Header: " << ok << std::endl;
|
||||||
<< std::endl;
|
|
||||||
#endif
|
#endif
|
||||||
|
offset += 8;
|
||||||
|
|
||||||
return false;
|
return true ;
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
RsItem* RsGxsUpdateSerialiser::deserialise(void* data, uint32_t* size)
|
RsItem* RsGxsUpdateSerialiser::deserialise(void* data, uint32_t* size)
|
||||||
{
|
{
|
||||||
|
|
||||||
@ -177,81 +152,93 @@ RsItem* RsGxsUpdateSerialiser::deserialise(void* data, uint32_t* size)
|
|||||||
/* get the type and size */
|
/* get the type and size */
|
||||||
uint32_t rstype = getRsItemId(data);
|
uint32_t rstype = getRsItemId(data);
|
||||||
|
|
||||||
if ((RS_PKT_VERSION_SERVICE != getRsItemVersion(rstype)) ||
|
if ((RS_PKT_VERSION_SERVICE != getRsItemVersion(rstype)) || (SERVICE_TYPE != getRsItemService(rstype)))
|
||||||
(SERVICE_TYPE != getRsItemService(rstype)))
|
|
||||||
{
|
|
||||||
return NULL; /* wrong type */
|
return NULL; /* wrong type */
|
||||||
}
|
|
||||||
|
|
||||||
switch(getRsItemSubType(rstype))
|
switch(getRsItemSubType(rstype))
|
||||||
{
|
{
|
||||||
|
case RS_PKT_SUBTYPE_GXS_MSG_UPDATE: return deserialGxsMsgUpdate(data, size);
|
||||||
|
case RS_PKT_SUBTYPE_GXS_GRP_UPDATE: return deserialGxsGrpUpddate(data, size);
|
||||||
|
case RS_PKT_SUBTYPE_GXS_SERVER_GRP_UPDATE: return deserialGxsServerGrpUpddate(data, size);
|
||||||
|
case RS_PKT_SUBTYPE_GXS_SERVER_MSG_UPDATE: return deserialGxsServerMsgUpdate(data, size);
|
||||||
|
case RS_PKT_SUBTYPE_GXS_GRP_CONFIG: return deserialGxsGrpConfig(data, size);
|
||||||
|
|
||||||
case RS_PKT_SUBTYPE_GXS_MSG_UPDATE:
|
|
||||||
return deserialGxsMsgUpdate(data, size);
|
|
||||||
case RS_PKT_SUBTYPE_GXS_GRP_UPDATE:
|
|
||||||
return deserialGxsGrpUpddate(data, size);
|
|
||||||
case RS_PKT_SUBTYPE_GXS_SERVER_GRP_UPDATE:
|
|
||||||
return deserialGxsServerGrpUpddate(data, size);
|
|
||||||
case RS_PKT_SUBTYPE_GXS_SERVER_MSG_UPDATE:
|
|
||||||
return deserialGxsServerMsgUpdate(data, size);
|
|
||||||
default:
|
default:
|
||||||
{
|
{
|
||||||
#ifdef RSSERIAL_DEBUG
|
# ifdef RSSERIAL_DEBUG
|
||||||
std::cerr << "RsGxsUpdateSerialiser::deserialise() : data has no type"
|
std::cerr << "RsGxsUpdateSerialiser::deserialise() : data has no type"
|
||||||
<< std::endl;
|
<< std::endl;
|
||||||
#endif
|
# endif
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t RsGxsUpdateSerialiser::sizeGxsGrpUpdate(RsGxsGrpUpdateItem* item)
|
/**********************************************************************************************/
|
||||||
|
/* SERIAL_SIZE() */
|
||||||
|
/**********************************************************************************************/
|
||||||
|
|
||||||
|
|
||||||
|
uint32_t RsGxsGrpUpdateItem::serial_size() const
|
||||||
{
|
{
|
||||||
uint32_t s = 8; // header size
|
uint32_t s = 8; // header size
|
||||||
s += item->peerId.serial_size();
|
s += peerID.serial_size();
|
||||||
s += 4; // mUpdateTS
|
s += 4; // mUpdateTS
|
||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t RsGxsUpdateSerialiser::sizeGxsServerGrpUpdate(RsGxsServerGrpUpdateItem* /* item */)
|
uint32_t RsGxsServerGrpUpdateItem::serial_size() const
|
||||||
{
|
{
|
||||||
uint32_t s = 8; // header size
|
uint32_t s = 8; // header size
|
||||||
s += 4; // time stamp
|
s += 4; // time stamp
|
||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool RsGxsUpdateSerialiser::serialiseGxsGrpUpdate(RsGxsGrpUpdateItem* item,
|
uint32_t RsGxsMsgUpdateItem::serial_size() const
|
||||||
void* data, uint32_t* size)
|
|
||||||
{
|
{
|
||||||
#ifdef RSSERIAL_DEBUG
|
uint32_t s = 8; // header size
|
||||||
std::cerr << "RsGxsUpdateSerialiser::serialiseGxsGrpUpdate()" << std::endl;
|
s += peerID.serial_size() ;//GetTlvStringSize(item->peerId);
|
||||||
#endif
|
|
||||||
|
|
||||||
uint32_t tlvsize = sizeGxsGrpUpdate(item);
|
s += msgUpdateInfos.size() * (4 + 4 + RsGxsGroupId::serial_size());
|
||||||
uint32_t offset = 0;
|
s += 4; // number of map items
|
||||||
|
|
||||||
if(*size < tlvsize){
|
return s;
|
||||||
#ifdef RSSERIAL_DEBUG
|
}
|
||||||
std::cerr << "RsGxsUpdateSerialiser::serialiseGxsGrpUpdate() size do not match" << std::endl;
|
|
||||||
#endif
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
*size = tlvsize;
|
uint32_t RsGxsServerMsgUpdateItem::serial_size() const
|
||||||
|
{
|
||||||
|
uint32_t s = 8; // header size
|
||||||
|
s += grpId.serial_size();
|
||||||
|
s += 4; // grp TS
|
||||||
|
|
||||||
|
return s;
|
||||||
|
}
|
||||||
|
uint32_t RsGxsGrpConfigItem::serial_size() const
|
||||||
|
{
|
||||||
|
uint32_t s = 8; // header size
|
||||||
|
s += grpId.serial_size();
|
||||||
|
s += 4; // msg_keep_delay
|
||||||
|
s += 4; // msg_send_delay
|
||||||
|
s += 4; // msg_req_delay
|
||||||
|
|
||||||
|
return s;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**********************************************************************************************/
|
||||||
|
/* SERIALISE() */
|
||||||
|
/**********************************************************************************************/
|
||||||
|
|
||||||
|
bool RsGxsGrpUpdateItem::serialise(void* data, uint32_t& size) const
|
||||||
|
{
|
||||||
|
uint32_t tlvsize,offset=0;
|
||||||
bool ok = true;
|
bool ok = true;
|
||||||
|
|
||||||
ok &= setRsItemHeader(data, tlvsize, item->PacketId(), tlvsize);
|
if(!serialise_header(data,size,tlvsize,offset))
|
||||||
|
return false ;
|
||||||
|
|
||||||
/* skip the header */
|
ok &= peerID.serialise(data, size, offset) ;
|
||||||
offset += 8;
|
ok &= setRawUInt32(data, size, &offset, grpUpdateTS);
|
||||||
|
|
||||||
/* RsGxsGrpUpdateItem */
|
|
||||||
|
|
||||||
|
|
||||||
ok &= item->peerId.serialise(data, *size, offset) ;
|
|
||||||
ok &= setRawUInt32(data, *size, &offset, item->grpUpdateTS);
|
|
||||||
|
|
||||||
if(offset != tlvsize){
|
if(offset != tlvsize){
|
||||||
#ifdef RSSERIAL_DEBUG
|
#ifdef RSSERIAL_DEBUG
|
||||||
@ -260,45 +247,20 @@ bool RsGxsUpdateSerialiser::serialiseGxsGrpUpdate(RsGxsGrpUpdateItem* item,
|
|||||||
ok = false;
|
ok = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef RSSERIAL_DEBUG
|
|
||||||
if (!ok)
|
|
||||||
{
|
|
||||||
std::cerr << "RsGxsUpdateSerialiser::serialiseGxsGrpUpdate() NOK" << std::endl;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
return ok;
|
return ok;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool RsGxsUpdateSerialiser::serialiseGxsServerGrpUpdate(RsGxsServerGrpUpdateItem* item,
|
bool RsGxsServerGrpUpdateItem::serialise(void* data, uint32_t& size) const
|
||||||
void* data, uint32_t* size)
|
|
||||||
{
|
{
|
||||||
#ifdef RSSERIAL_DEBUG
|
uint32_t tlvsize,offset=0;
|
||||||
std::cerr << "RsGxsUpdateSerialiser::serialiseGxsServerGrpUpdate()" << std::endl;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
uint32_t tlvsize = sizeGxsServerGrpUpdate(item);
|
|
||||||
uint32_t offset = 0;
|
|
||||||
|
|
||||||
if(*size < tlvsize){
|
|
||||||
#ifdef RSSERIAL_DEBUG
|
|
||||||
std::cerr << "RsGxsUpdateSerialiser::serialiseGxsServerGrpUpdate() size do not match" << std::endl;
|
|
||||||
#endif
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
*size = tlvsize;
|
|
||||||
|
|
||||||
bool ok = true;
|
bool ok = true;
|
||||||
|
|
||||||
ok &= setRsItemHeader(data, tlvsize, item->PacketId(), tlvsize);
|
if(!serialise_header(data,size,tlvsize,offset))
|
||||||
|
return false ;
|
||||||
/* skip the header */
|
|
||||||
offset += 8;
|
|
||||||
|
|
||||||
/* RsGxsServerGrpUpdateItem */
|
/* RsGxsServerGrpUpdateItem */
|
||||||
|
|
||||||
ok &= setRawUInt32(data, *size, &offset, item->grpUpdateTS);
|
ok &= setRawUInt32(data, size, &offset, grpUpdateTS);
|
||||||
|
|
||||||
if(offset != tlvsize){
|
if(offset != tlvsize){
|
||||||
#ifdef RSSERIAL_DEBUG
|
#ifdef RSSERIAL_DEBUG
|
||||||
@ -307,15 +269,153 @@ bool RsGxsUpdateSerialiser::serialiseGxsServerGrpUpdate(RsGxsServerGrpUpdateItem
|
|||||||
ok = false;
|
ok = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef RSSERIAL_DEBUG
|
return ok;
|
||||||
if (!ok)
|
}
|
||||||
|
bool RsGxsMsgUpdateItem::serialise(void* data, uint32_t& size) const
|
||||||
|
{
|
||||||
|
uint32_t tlvsize,offset=0;
|
||||||
|
bool ok = true;
|
||||||
|
|
||||||
|
if(!serialise_header(data,size,tlvsize,offset))
|
||||||
|
return false ;
|
||||||
|
|
||||||
|
ok &= peerID.serialise(data, size, offset) ;
|
||||||
|
|
||||||
|
std::map<RsGxsGroupId, RsGxsMsgUpdateItem::MsgUpdateInfo>::const_iterator cit(msgUpdateInfos.begin());
|
||||||
|
|
||||||
|
uint32_t numItems = msgUpdateInfos.size();
|
||||||
|
ok &= setRawUInt32(data, size, &offset, numItems);
|
||||||
|
|
||||||
|
for(; cit != msgUpdateInfos.end(); ++cit)
|
||||||
{
|
{
|
||||||
std::cerr << "RsGxsUpdateSerialiser::serialiseGxsServerGrpUpdate() NOK" << std::endl;
|
ok &= cit->first.serialise(data, size, offset);
|
||||||
|
ok &= setRawUInt32(data, size, &offset, cit->second.time_stamp);
|
||||||
|
ok &= setRawUInt32(data, size, &offset, cit->second.message_count);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(offset != tlvsize){
|
||||||
|
#ifdef RSSERIAL_DEBUG
|
||||||
|
std::cerr << "RsGxsUpdateSerialiser::serialiseGxsMsgUpdate() FAIL Size Error! " << std::endl;
|
||||||
#endif
|
#endif
|
||||||
|
ok = false;
|
||||||
|
}
|
||||||
|
|
||||||
return ok;
|
return ok;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool RsGxsServerMsgUpdateItem::serialise( void* data, uint32_t& size) const
|
||||||
|
{
|
||||||
|
uint32_t tlvsize,offset=0;
|
||||||
|
bool ok = true;
|
||||||
|
|
||||||
|
if(!serialise_header(data,size,tlvsize,offset))
|
||||||
|
return false ;
|
||||||
|
|
||||||
|
ok &= grpId.serialise(data, size, offset) ;
|
||||||
|
ok &= setRawUInt32(data, size, &offset, msgUpdateTS);
|
||||||
|
|
||||||
|
if(offset != tlvsize){
|
||||||
|
#ifdef RSSERIAL_DEBUG
|
||||||
|
std::cerr << "RsGxsUpdateSerialiser::serialiseGxsServerMsgUpdate() FAIL Size Error! " << std::endl;
|
||||||
|
#endif
|
||||||
|
ok = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return ok;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool RsGxsGrpConfigItem::serialise( void* data, uint32_t& size) const
|
||||||
|
{
|
||||||
|
uint32_t tlvsize,offset=0;
|
||||||
|
bool ok = true;
|
||||||
|
|
||||||
|
if(!serialise_header(data,size,tlvsize,offset))
|
||||||
|
return false ;
|
||||||
|
|
||||||
|
ok &= grpId.serialise(data, size, offset) ;
|
||||||
|
ok &= setRawUInt32(data, size, &offset, msg_keep_delay);
|
||||||
|
ok &= setRawUInt32(data, size, &offset, msg_send_delay);
|
||||||
|
ok &= setRawUInt32(data, size, &offset, msg_req_delay);
|
||||||
|
|
||||||
|
if(offset != tlvsize){
|
||||||
|
#ifdef RSSERIAL_DEBUG
|
||||||
|
std::cerr << "RsGxsUpdateSerialiser::serialiseGxsServerMsgUpdate() FAIL Size Error! " << std::endl;
|
||||||
|
#endif
|
||||||
|
ok = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return ok;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**********************************************************************************************/
|
||||||
|
/* DESERIALISE() */
|
||||||
|
/**********************************************************************************************/
|
||||||
|
|
||||||
|
RsGxsGrpConfigItem* RsGxsUpdateSerialiser::deserialGxsGrpConfig(void* data, uint32_t* size)
|
||||||
|
{
|
||||||
|
#ifdef RSSERIAL_DEBUG
|
||||||
|
std::cerr << "RsGxsUpdateSerialiser::deserialGxsServerGrpUpdate()" << std::endl;
|
||||||
|
#endif
|
||||||
|
/* get the type and size */
|
||||||
|
uint32_t rstype = getRsItemId(data);
|
||||||
|
uint32_t rssize = getRsItemSize(data);
|
||||||
|
|
||||||
|
uint32_t offset = 0;
|
||||||
|
|
||||||
|
|
||||||
|
if ((RS_PKT_VERSION_SERVICE != getRsItemVersion(rstype)) || (SERVICE_TYPE != getRsItemService(rstype)) || (RS_PKT_SUBTYPE_GXS_GRP_CONFIG != getRsItemSubType(rstype)))
|
||||||
|
{
|
||||||
|
#ifdef RSSERIAL_DEBUG
|
||||||
|
std::cerr << "RsGxsUpdateSerialiser::deserialGxsGrpUpdate() FAIL wrong type" << std::endl;
|
||||||
|
#endif
|
||||||
|
return NULL; /* wrong type */
|
||||||
|
}
|
||||||
|
|
||||||
|
if (*size < rssize) /* check size */
|
||||||
|
{
|
||||||
|
#ifdef RSSERIAL_DEBUG
|
||||||
|
std::cerr << "RsGxsUpdateSerialiser::deserialGxsGrpUpdate() FAIL wrong size" << std::endl;
|
||||||
|
#endif
|
||||||
|
return NULL; /* not enough data */
|
||||||
|
}
|
||||||
|
|
||||||
|
/* set the packet length */
|
||||||
|
*size = rssize;
|
||||||
|
|
||||||
|
bool ok = true;
|
||||||
|
|
||||||
|
RsGxsGrpConfigItem* item = new RsGxsGrpConfigItem(getRsItemService(rstype));
|
||||||
|
|
||||||
|
/* skip the header */
|
||||||
|
offset += 8;
|
||||||
|
|
||||||
|
ok &= item->grpId.deserialise(data, *size, offset) ;
|
||||||
|
ok &= getRawUInt32(data, *size, &offset, &(item->msg_keep_delay));
|
||||||
|
ok &= getRawUInt32(data, *size, &offset, &(item->msg_send_delay));
|
||||||
|
ok &= getRawUInt32(data, *size, &offset, &(item->msg_req_delay));
|
||||||
|
|
||||||
|
if (offset != rssize)
|
||||||
|
{
|
||||||
|
#ifdef RSSERIAL_DEBUG
|
||||||
|
std::cerr << "RsGxsUpdateSerialiser::deserialGxxGrpUpdate() FAIL size mismatch" << std::endl;
|
||||||
|
#endif
|
||||||
|
/* error */
|
||||||
|
delete item;
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!ok)
|
||||||
|
{
|
||||||
|
#ifdef RSSERIAL_DEBUG
|
||||||
|
std::cerr << "RsGxsUpdateSerialiser::deserialGxsGrpUpdate() NOK" << std::endl;
|
||||||
|
#endif
|
||||||
|
delete item;
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
return item;
|
||||||
|
}
|
||||||
RsGxsGrpUpdateItem* RsGxsUpdateSerialiser::deserialGxsGrpUpddate(void* data, uint32_t* size)
|
RsGxsGrpUpdateItem* RsGxsUpdateSerialiser::deserialGxsGrpUpddate(void* data, uint32_t* size)
|
||||||
{
|
{
|
||||||
#ifdef RSSERIAL_DEBUG
|
#ifdef RSSERIAL_DEBUG
|
||||||
@ -356,7 +456,7 @@ RsGxsGrpUpdateItem* RsGxsUpdateSerialiser::deserialGxsGrpUpddate(void* data, uin
|
|||||||
/* skip the header */
|
/* skip the header */
|
||||||
offset += 8;
|
offset += 8;
|
||||||
|
|
||||||
ok &= item->peerId.deserialise(data, *size, offset) ;
|
ok &= item->peerID.deserialise(data, *size, offset) ;
|
||||||
ok &= getRawUInt32(data, *size, &offset, &(item->grpUpdateTS));
|
ok &= getRawUInt32(data, *size, &offset, &(item->grpUpdateTS));
|
||||||
|
|
||||||
if (offset != rssize)
|
if (offset != rssize)
|
||||||
@ -381,8 +481,7 @@ RsGxsGrpUpdateItem* RsGxsUpdateSerialiser::deserialGxsGrpUpddate(void* data, uin
|
|||||||
return item;
|
return item;
|
||||||
}
|
}
|
||||||
|
|
||||||
RsGxsServerGrpUpdateItem* RsGxsUpdateSerialiser::deserialGxsServerGrpUpddate(void* data,
|
RsGxsServerGrpUpdateItem* RsGxsUpdateSerialiser::deserialGxsServerGrpUpddate(void* data, uint32_t* size)
|
||||||
uint32_t* size)
|
|
||||||
{
|
{
|
||||||
#ifdef RSSERIAL_DEBUG
|
#ifdef RSSERIAL_DEBUG
|
||||||
std::cerr << "RsGxsUpdateSerialiser::deserialGxsServerGrpUpdate()" << std::endl;
|
std::cerr << "RsGxsUpdateSerialiser::deserialGxsServerGrpUpdate()" << std::endl;
|
||||||
@ -394,9 +493,7 @@ RsGxsServerGrpUpdateItem* RsGxsUpdateSerialiser::deserialGxsServerGrpUpddate(voi
|
|||||||
uint32_t offset = 0;
|
uint32_t offset = 0;
|
||||||
|
|
||||||
|
|
||||||
if ((RS_PKT_VERSION_SERVICE != getRsItemVersion(rstype)) ||
|
if ((RS_PKT_VERSION_SERVICE != getRsItemVersion(rstype)) || (SERVICE_TYPE != getRsItemService(rstype)) || (RS_PKT_SUBTYPE_GXS_SERVER_GRP_UPDATE != getRsItemSubType(rstype)))
|
||||||
(SERVICE_TYPE != getRsItemService(rstype)) ||
|
|
||||||
(RS_PKT_SUBTYPE_GXS_SERVER_GRP_UPDATE != getRsItemSubType(rstype)))
|
|
||||||
{
|
{
|
||||||
#ifdef RSSERIAL_DEBUG
|
#ifdef RSSERIAL_DEBUG
|
||||||
std::cerr << "RsGxsUpdateSerialiser::deserialGxsServerGrpUpdate() FAIL wrong type" << std::endl;
|
std::cerr << "RsGxsUpdateSerialiser::deserialGxsServerGrpUpdate() FAIL wrong type" << std::endl;
|
||||||
@ -446,137 +543,9 @@ RsGxsServerGrpUpdateItem* RsGxsUpdateSerialiser::deserialGxsServerGrpUpddate(voi
|
|||||||
return item;
|
return item;
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t RsGxsUpdateSerialiser::sizeGxsMsgUpdate(RsGxsMsgUpdateItem* item)
|
|
||||||
{
|
|
||||||
uint32_t s = 8; // header size
|
|
||||||
s += item->peerId.serial_size() ;//GetTlvStringSize(item->peerId);
|
|
||||||
|
|
||||||
s += item->msgUpdateInfos.size() * (4 + 4 + RsGxsGroupId::serial_size());
|
|
||||||
s += 4; // number of map items
|
|
||||||
|
|
||||||
return s;
|
|
||||||
}
|
|
||||||
|
|
||||||
uint32_t RsGxsUpdateSerialiser::sizeGxsServerMsgUpdate(RsGxsServerMsgUpdateItem* item)
|
|
||||||
{
|
|
||||||
uint32_t s = 8; // header size
|
|
||||||
s += item->grpId.serial_size();
|
|
||||||
s += 4; // grp TS
|
|
||||||
|
|
||||||
return s;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool RsGxsUpdateSerialiser::serialiseGxsMsgUpdate(RsGxsMsgUpdateItem* item,
|
|
||||||
void* data, uint32_t* size)
|
|
||||||
{
|
|
||||||
#ifdef RSSERIAL_DEBUG
|
|
||||||
std::cerr << "RsGxsUpdateSerialiser::serialiseGxsMsgUpdate()" << std::endl;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
uint32_t tlvsize = sizeGxsMsgUpdate(item);
|
|
||||||
uint32_t offset = 0;
|
|
||||||
|
|
||||||
if(*size < tlvsize){
|
|
||||||
#ifdef RSSERIAL_DEBUG
|
|
||||||
std::cerr << "RsGxsUpdateSerialiser::serialiseGxsMsgUpdate() size do not match" << std::endl;
|
|
||||||
#endif
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
*size = tlvsize;
|
|
||||||
|
|
||||||
bool ok = true;
|
|
||||||
|
|
||||||
ok &= setRsItemHeader(data, tlvsize, item->PacketId(), tlvsize);
|
|
||||||
|
|
||||||
/* skip the header */
|
|
||||||
offset += 8;
|
|
||||||
|
|
||||||
/* RsGxsMsgUpdateItem */
|
|
||||||
|
|
||||||
|
|
||||||
ok &= item->peerId.serialise(data, *size, offset) ;
|
RsGxsMsgUpdateItem* RsGxsUpdateSerialiser::deserialGxsMsgUpdate(void* data, uint32_t* size)
|
||||||
|
|
||||||
std::map<RsGxsGroupId, RsGxsMsgUpdateItem::MsgUpdateInfo>::const_iterator cit(item->msgUpdateInfos.begin());
|
|
||||||
|
|
||||||
uint32_t numItems = item->msgUpdateInfos.size();
|
|
||||||
ok &= setRawUInt32(data, *size, &offset, numItems);
|
|
||||||
|
|
||||||
for(; cit != item->msgUpdateInfos.end(); ++cit)
|
|
||||||
{
|
|
||||||
ok &= cit->first.serialise(data, *size, offset);
|
|
||||||
ok &= setRawUInt32(data, *size, &offset, cit->second.time_stamp);
|
|
||||||
ok &= setRawUInt32(data, *size, &offset, cit->second.message_count);
|
|
||||||
}
|
|
||||||
|
|
||||||
if(offset != tlvsize){
|
|
||||||
#ifdef RSSERIAL_DEBUG
|
|
||||||
std::cerr << "RsGxsUpdateSerialiser::serialiseGxsMsgUpdate() FAIL Size Error! " << std::endl;
|
|
||||||
#endif
|
|
||||||
ok = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifdef RSSERIAL_DEBUG
|
|
||||||
if (!ok)
|
|
||||||
{
|
|
||||||
std::cerr << "RsGxsUpdateSerialiser::serialiseGxsMsgUpdate() NOK" << std::endl;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
return ok;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool RsGxsUpdateSerialiser::serialiseGxsServerMsgUpdate(RsGxsServerMsgUpdateItem* item,
|
|
||||||
void* data, uint32_t* size)
|
|
||||||
{
|
|
||||||
#ifdef RSSERIAL_DEBUG
|
|
||||||
std::cerr << "RsGxsUpdateSerialiser::serialiseGxsServerMsgUpdate()" << std::endl;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
uint32_t tlvsize = sizeGxsServerMsgUpdate(item);
|
|
||||||
uint32_t offset = 0;
|
|
||||||
|
|
||||||
if(*size < tlvsize){
|
|
||||||
#ifdef RSSERIAL_DEBUG
|
|
||||||
std::cerr << "RsGxsUpdateSerialiser::serialiseGxsServerMsgUpdate() size do not match" << std::endl;
|
|
||||||
#endif
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
*size = tlvsize;
|
|
||||||
|
|
||||||
bool ok = true;
|
|
||||||
|
|
||||||
ok &= setRsItemHeader(data, tlvsize, item->PacketId(), tlvsize);
|
|
||||||
|
|
||||||
/* skip the header */
|
|
||||||
offset += 8;
|
|
||||||
|
|
||||||
/* RsNxsSyncm */
|
|
||||||
|
|
||||||
|
|
||||||
ok &= item->grpId.serialise(data, *size, offset) ;
|
|
||||||
ok &= setRawUInt32(data, *size, &offset, item->msgUpdateTS);
|
|
||||||
|
|
||||||
if(offset != tlvsize){
|
|
||||||
#ifdef RSSERIAL_DEBUG
|
|
||||||
std::cerr << "RsGxsUpdateSerialiser::serialiseGxsServerMsgUpdate() FAIL Size Error! " << std::endl;
|
|
||||||
#endif
|
|
||||||
ok = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifdef RSSERIAL_DEBUG
|
|
||||||
if (!ok)
|
|
||||||
{
|
|
||||||
std::cerr << "RsGxsUpdateSerialiser::serialiseGxsServerMsgUpdate() NOK" << std::endl;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
return ok;
|
|
||||||
}
|
|
||||||
|
|
||||||
RsGxsMsgUpdateItem* RsGxsUpdateSerialiser::deserialGxsMsgUpdate(void* data,
|
|
||||||
uint32_t* size)
|
|
||||||
{
|
{
|
||||||
#ifdef RSSERIAL_DEBUG
|
#ifdef RSSERIAL_DEBUG
|
||||||
std::cerr << "RsGxsUpdateSerialiser::deserialGxsMsgUpdate()" << std::endl;
|
std::cerr << "RsGxsUpdateSerialiser::deserialGxsMsgUpdate()" << std::endl;
|
||||||
@ -588,9 +557,7 @@ RsGxsMsgUpdateItem* RsGxsUpdateSerialiser::deserialGxsMsgUpdate(void* data,
|
|||||||
uint32_t offset = 0;
|
uint32_t offset = 0;
|
||||||
|
|
||||||
|
|
||||||
if ((RS_PKT_VERSION_SERVICE != getRsItemVersion(rstype)) ||
|
if ((RS_PKT_VERSION_SERVICE != getRsItemVersion(rstype)) || (SERVICE_TYPE != getRsItemService(rstype)) || (RS_PKT_SUBTYPE_GXS_MSG_UPDATE != getRsItemSubType(rstype)))
|
||||||
(SERVICE_TYPE != getRsItemService(rstype)) ||
|
|
||||||
(RS_PKT_SUBTYPE_GXS_MSG_UPDATE != getRsItemSubType(rstype)))
|
|
||||||
{
|
{
|
||||||
#ifdef RSSERIAL_DEBUG
|
#ifdef RSSERIAL_DEBUG
|
||||||
std::cerr << "RsGxsUpdateSerialiser::deserialGxsMsgUpdate() FAIL wrong type" << std::endl;
|
std::cerr << "RsGxsUpdateSerialiser::deserialGxsMsgUpdate() FAIL wrong type" << std::endl;
|
||||||
@ -616,7 +583,7 @@ RsGxsMsgUpdateItem* RsGxsUpdateSerialiser::deserialGxsMsgUpdate(void* data,
|
|||||||
/* skip the header */
|
/* skip the header */
|
||||||
offset += 8;
|
offset += 8;
|
||||||
|
|
||||||
ok &= item->peerId.deserialise(data, *size, offset) ;
|
ok &= item->peerID.deserialise(data, *size, offset) ;
|
||||||
uint32_t numUpdateItems;
|
uint32_t numUpdateItems;
|
||||||
ok &= getRawUInt32(data, *size, &offset, &(numUpdateItems));
|
ok &= getRawUInt32(data, *size, &offset, &(numUpdateItems));
|
||||||
std::map<RsGxsGroupId, RsGxsMsgUpdateItem::MsgUpdateInfo>& msgUpdateInfos = item->msgUpdateInfos;
|
std::map<RsGxsGroupId, RsGxsMsgUpdateItem::MsgUpdateInfo>& msgUpdateInfos = item->msgUpdateInfos;
|
||||||
@ -662,8 +629,7 @@ RsGxsMsgUpdateItem* RsGxsUpdateSerialiser::deserialGxsMsgUpdate(void* data,
|
|||||||
return item;
|
return item;
|
||||||
}
|
}
|
||||||
|
|
||||||
RsGxsServerMsgUpdateItem* RsGxsUpdateSerialiser::deserialGxsServerMsgUpdate(void* data,
|
RsGxsServerMsgUpdateItem* RsGxsUpdateSerialiser::deserialGxsServerMsgUpdate(void* data, uint32_t* size)
|
||||||
uint32_t* size)
|
|
||||||
{
|
{
|
||||||
#ifdef RSSERIAL_DEBUG
|
#ifdef RSSERIAL_DEBUG
|
||||||
std::cerr << "RsGxsUpdateSerialiser::deserialGxsServerMsgUpdate()" << std::endl;
|
std::cerr << "RsGxsUpdateSerialiser::deserialGxsServerMsgUpdate()" << std::endl;
|
||||||
@ -675,9 +641,7 @@ RsGxsServerMsgUpdateItem* RsGxsUpdateSerialiser::deserialGxsServerMsgUpdate(void
|
|||||||
uint32_t offset = 0;
|
uint32_t offset = 0;
|
||||||
|
|
||||||
|
|
||||||
if ((RS_PKT_VERSION_SERVICE != getRsItemVersion(rstype)) ||
|
if ((RS_PKT_VERSION_SERVICE != getRsItemVersion(rstype)) || (SERVICE_TYPE != getRsItemService(rstype)) || (RS_PKT_SUBTYPE_GXS_SERVER_MSG_UPDATE != getRsItemSubType(rstype)))
|
||||||
(SERVICE_TYPE != getRsItemService(rstype)) ||
|
|
||||||
(RS_PKT_SUBTYPE_GXS_SERVER_MSG_UPDATE != getRsItemSubType(rstype)))
|
|
||||||
{
|
{
|
||||||
#ifdef RSSERIAL_DEBUG
|
#ifdef RSSERIAL_DEBUG
|
||||||
std::cerr << "RsGxsUpdateSerialiser::deserialGxsServerMsgUpdate() FAIL wrong type" << std::endl;
|
std::cerr << "RsGxsUpdateSerialiser::deserialGxsServerMsgUpdate() FAIL wrong type" << std::endl;
|
||||||
|
@ -37,52 +37,124 @@
|
|||||||
#include "serialiser/rstlvkeys.h"
|
#include "serialiser/rstlvkeys.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#include "gxs/rsgxs.h"
|
||||||
#include "gxs/rsgxsdata.h"
|
#include "gxs/rsgxsdata.h"
|
||||||
|
#include "serialiser/rstlvidset.h"
|
||||||
|
|
||||||
|
|
||||||
const uint8_t RS_PKT_SUBTYPE_GXS_GRP_UPDATE = 0x0001;
|
const uint8_t RS_PKT_SUBTYPE_GXS_GRP_UPDATE = 0x01;
|
||||||
const uint8_t RS_PKT_SUBTYPE_GXS_MSG_UPDATE_deprecated = 0x0002;
|
const uint8_t RS_PKT_SUBTYPE_GXS_MSG_UPDATE_deprecated = 0x02;
|
||||||
const uint8_t RS_PKT_SUBTYPE_GXS_MSG_UPDATE = 0x0003;
|
const uint8_t RS_PKT_SUBTYPE_GXS_MSG_UPDATE = 0x03;
|
||||||
const uint8_t RS_PKT_SUBTYPE_GXS_SERVER_GRP_UPDATE = 0x0004;
|
const uint8_t RS_PKT_SUBTYPE_GXS_SERVER_GRP_UPDATE = 0x04;
|
||||||
const uint8_t RS_PKT_SUBTYPE_GXS_SERVER_MSG_UPDATE = 0x0008;
|
const uint8_t RS_PKT_SUBTYPE_GXS_SERVER_MSG_UPDATE = 0x08;
|
||||||
|
const uint8_t RS_PKT_SUBTYPE_GXS_GRP_CONFIG = 0x09;
|
||||||
|
|
||||||
class RsGxsGrpUpdateItem : public RsItem {
|
class RsGxsNetServiceItem: public RsItem
|
||||||
|
{
|
||||||
public:
|
public:
|
||||||
RsGxsGrpUpdateItem(uint16_t servType) : RsItem(RS_PKT_VERSION_SERVICE, servType,
|
RsGxsNetServiceItem(uint16_t serv_type,uint8_t subtype) : RsItem(RS_PKT_VERSION_SERVICE, serv_type, subtype) {}
|
||||||
RS_PKT_SUBTYPE_GXS_GRP_UPDATE)
|
|
||||||
{clear();}
|
virtual ~RsGxsNetServiceItem() {}
|
||||||
|
|
||||||
|
virtual bool serialise(void *data,uint32_t& size) const = 0 ;
|
||||||
|
virtual uint32_t serial_size() const = 0 ;
|
||||||
|
|
||||||
|
virtual void clear() = 0 ;
|
||||||
|
virtual std::ostream& print(std::ostream &out, uint16_t indent = 0) = 0;
|
||||||
|
|
||||||
|
protected:
|
||||||
|
bool serialise_header(void *data, uint32_t& pktsize, uint32_t& tlvsize, uint32_t& offset) const;
|
||||||
|
};
|
||||||
|
|
||||||
|
class RsGxsGrpConfig
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
RsGxsGrpConfig()
|
||||||
|
{
|
||||||
|
msg_keep_delay = RS_GXS_DEFAULT_MSG_STORE_PERIOD ;
|
||||||
|
msg_send_delay = RS_GXS_DEFAULT_MSG_SEND_PERIOD ;
|
||||||
|
msg_req_delay = RS_GXS_DEFAULT_MSG_REQ_PERIOD ;
|
||||||
|
|
||||||
|
max_visible_count = 0 ;
|
||||||
|
update_TS = 0 ;
|
||||||
|
}
|
||||||
|
|
||||||
|
uint32_t msg_keep_delay ; // delay after which we discard the posts
|
||||||
|
uint32_t msg_send_delay ; // delay after which we dont send the posts anymore
|
||||||
|
uint32_t msg_req_delay ; // delay after which we dont get the posts from friends
|
||||||
|
|
||||||
|
RsTlvPeerIdSet suppliers; // list of friends who feed this group
|
||||||
|
uint32_t max_visible_count ; // max visible count reported by contributing friends
|
||||||
|
time_t update_TS ; // last time the max visible count was updated.
|
||||||
|
};
|
||||||
|
|
||||||
|
class RsGxsGrpConfigItem : public RsGxsNetServiceItem, public RsGxsGrpConfig
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
RsGxsGrpConfigItem(uint16_t servType) : RsGxsNetServiceItem(servType, RS_PKT_SUBTYPE_GXS_GRP_CONFIG) {}
|
||||||
|
RsGxsGrpConfigItem(const RsGxsGrpConfig& m,uint16_t servType) : RsGxsNetServiceItem(servType, RS_PKT_SUBTYPE_GXS_GRP_CONFIG),RsGxsGrpConfig(m) {}
|
||||||
|
virtual ~RsGxsGrpConfigItem() {}
|
||||||
|
|
||||||
|
virtual void clear() {}
|
||||||
|
virtual std::ostream &print(std::ostream &out, uint16_t indent) { return out;}
|
||||||
|
|
||||||
|
virtual bool serialise(void *data,uint32_t& size) const ;
|
||||||
|
virtual uint32_t serial_size() const ;
|
||||||
|
|
||||||
|
RsGxsGroupId grpId ;
|
||||||
|
};
|
||||||
|
|
||||||
|
class RsGxsGrpUpdate
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
RsGxsGrpUpdate() { grpUpdateTS=0;}
|
||||||
|
|
||||||
|
uint32_t grpUpdateTS;
|
||||||
|
};
|
||||||
|
|
||||||
|
class RsGxsGrpUpdateItem : public RsGxsNetServiceItem, public RsGxsGrpUpdate
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
RsGxsGrpUpdateItem(uint16_t servType) : RsGxsNetServiceItem(servType, RS_PKT_SUBTYPE_GXS_GRP_UPDATE) {clear();}
|
||||||
|
RsGxsGrpUpdateItem(const RsGxsGrpUpdate& u,uint16_t serv_type) : RsGxsNetServiceItem(serv_type, RS_PKT_SUBTYPE_GXS_GRP_UPDATE), RsGxsGrpUpdate(u) {clear();}
|
||||||
|
|
||||||
virtual ~RsGxsGrpUpdateItem() {}
|
virtual ~RsGxsGrpUpdateItem() {}
|
||||||
|
|
||||||
virtual void clear();
|
virtual void clear();
|
||||||
virtual std::ostream &print(std::ostream &out, uint16_t indent);
|
virtual std::ostream &print(std::ostream &out, uint16_t indent);
|
||||||
|
|
||||||
RsPeerId peerId;
|
virtual bool serialise(void *data,uint32_t& size) const ;
|
||||||
|
virtual uint32_t serial_size() const ;
|
||||||
|
|
||||||
|
RsPeerId peerID;
|
||||||
|
};
|
||||||
|
|
||||||
|
class RsGxsServerGrpUpdate
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
RsGxsServerGrpUpdate() { grpUpdateTS = 0 ; }
|
||||||
|
|
||||||
uint32_t grpUpdateTS;
|
uint32_t grpUpdateTS;
|
||||||
};
|
};
|
||||||
|
|
||||||
class RsGxsServerGrpUpdateItem : public RsItem {
|
class RsGxsServerGrpUpdateItem : public RsGxsNetServiceItem, public RsGxsServerGrpUpdate
|
||||||
|
{
|
||||||
public:
|
public:
|
||||||
RsGxsServerGrpUpdateItem(uint16_t servType) : RsItem(RS_PKT_VERSION_SERVICE, servType,
|
RsGxsServerGrpUpdateItem(uint16_t servType) : RsGxsNetServiceItem(servType, RS_PKT_SUBTYPE_GXS_SERVER_GRP_UPDATE) { clear();}
|
||||||
RS_PKT_SUBTYPE_GXS_SERVER_GRP_UPDATE)
|
RsGxsServerGrpUpdateItem(const RsGxsServerGrpUpdate& u,uint16_t serv_type) : RsGxsNetServiceItem(serv_type, RS_PKT_SUBTYPE_GXS_SERVER_GRP_UPDATE), RsGxsServerGrpUpdate(u) {clear();}
|
||||||
{ clear();}
|
|
||||||
virtual ~RsGxsServerGrpUpdateItem() {}
|
virtual ~RsGxsServerGrpUpdateItem() {}
|
||||||
|
|
||||||
virtual void clear();
|
virtual void clear();
|
||||||
virtual std::ostream &print(std::ostream &out, uint16_t indent);
|
virtual std::ostream &print(std::ostream &out, uint16_t indent);
|
||||||
|
|
||||||
uint32_t grpUpdateTS;
|
virtual bool serialise(void *data,uint32_t& size) const ;
|
||||||
|
virtual uint32_t serial_size() const ;
|
||||||
};
|
};
|
||||||
|
|
||||||
class RsGxsMsgUpdateItem : public RsItem
|
class RsGxsMsgUpdate
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
RsGxsMsgUpdateItem(uint16_t servType) : RsItem(RS_PKT_VERSION_SERVICE, servType, RS_PKT_SUBTYPE_GXS_MSG_UPDATE)
|
|
||||||
{ clear();}
|
|
||||||
virtual ~RsGxsMsgUpdateItem() {}
|
|
||||||
|
|
||||||
virtual void clear();
|
|
||||||
virtual std::ostream &print(std::ostream &out, uint16_t indent);
|
|
||||||
|
|
||||||
struct MsgUpdateInfo
|
struct MsgUpdateInfo
|
||||||
{
|
{
|
||||||
MsgUpdateInfo(): time_stamp(0), message_count(0) {}
|
MsgUpdateInfo(): time_stamp(0), message_count(0) {}
|
||||||
@ -91,23 +163,48 @@ public:
|
|||||||
uint32_t message_count ;
|
uint32_t message_count ;
|
||||||
};
|
};
|
||||||
|
|
||||||
RsPeerId peerId;
|
|
||||||
std::map<RsGxsGroupId, MsgUpdateInfo> msgUpdateInfos;
|
std::map<RsGxsGroupId, MsgUpdateInfo> msgUpdateInfos;
|
||||||
};
|
};
|
||||||
|
|
||||||
class RsGxsServerMsgUpdateItem : public RsItem
|
class RsGxsMsgUpdateItem : public RsGxsNetServiceItem, public RsGxsMsgUpdate
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
RsGxsServerMsgUpdateItem(uint16_t servType) : RsItem(RS_PKT_VERSION_SERVICE,
|
RsGxsMsgUpdateItem(uint16_t servType) : RsGxsNetServiceItem(servType, RS_PKT_SUBTYPE_GXS_MSG_UPDATE) { clear();}
|
||||||
servType, RS_PKT_SUBTYPE_GXS_SERVER_MSG_UPDATE)
|
RsGxsMsgUpdateItem(const RsGxsMsgUpdate& m,uint16_t servType) : RsGxsNetServiceItem(servType, RS_PKT_SUBTYPE_GXS_MSG_UPDATE), RsGxsMsgUpdate(m) { clear();}
|
||||||
{ clear();}
|
|
||||||
|
virtual ~RsGxsMsgUpdateItem() {}
|
||||||
|
|
||||||
|
virtual void clear();
|
||||||
|
virtual std::ostream &print(std::ostream &out, uint16_t indent);
|
||||||
|
|
||||||
|
virtual bool serialise(void *data,uint32_t& size) const ;
|
||||||
|
virtual uint32_t serial_size() const ;
|
||||||
|
|
||||||
|
RsPeerId peerID;
|
||||||
|
};
|
||||||
|
|
||||||
|
class RsGxsServerMsgUpdate
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
RsGxsServerMsgUpdate() { msgUpdateTS = 0 ;}
|
||||||
|
|
||||||
|
uint32_t msgUpdateTS; // local time stamp this group last received a new msg
|
||||||
|
};
|
||||||
|
|
||||||
|
class RsGxsServerMsgUpdateItem : public RsGxsNetServiceItem, public RsGxsServerMsgUpdate
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
RsGxsServerMsgUpdateItem(uint16_t servType) : RsGxsNetServiceItem(servType, RS_PKT_SUBTYPE_GXS_SERVER_MSG_UPDATE) { clear();}
|
||||||
|
RsGxsServerMsgUpdateItem(const RsGxsServerMsgUpdate& m,uint16_t servType) : RsGxsNetServiceItem(servType, RS_PKT_SUBTYPE_GXS_SERVER_MSG_UPDATE),RsGxsServerMsgUpdate(m) { clear();}
|
||||||
virtual ~RsGxsServerMsgUpdateItem() {}
|
virtual ~RsGxsServerMsgUpdateItem() {}
|
||||||
|
|
||||||
virtual void clear();
|
virtual void clear();
|
||||||
virtual std::ostream &print(std::ostream &out, uint16_t indent);
|
virtual std::ostream &print(std::ostream &out, uint16_t indent);
|
||||||
|
|
||||||
|
virtual bool serialise(void *data,uint32_t& size) const ;
|
||||||
|
virtual uint32_t serial_size() const ;
|
||||||
|
|
||||||
RsGxsGroupId grpId;
|
RsGxsGroupId grpId;
|
||||||
uint32_t msgUpdateTS; // local time stamp this group last received a new msg
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
@ -115,47 +212,50 @@ class RsGxsUpdateSerialiser : public RsSerialType
|
|||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
|
||||||
RsGxsUpdateSerialiser(uint16_t servtype) :
|
RsGxsUpdateSerialiser(uint16_t servtype) : RsSerialType(RS_PKT_VERSION_SERVICE, servtype), SERVICE_TYPE(servtype) {}
|
||||||
RsSerialType(RS_PKT_VERSION_SERVICE, servtype), SERVICE_TYPE(servtype) { return; }
|
|
||||||
|
|
||||||
virtual ~RsGxsUpdateSerialiser() { return; }
|
virtual ~RsGxsUpdateSerialiser() {}
|
||||||
|
|
||||||
|
virtual uint32_t size(RsItem *item)
|
||||||
|
{
|
||||||
|
RsGxsNetServiceItem *gitem = dynamic_cast<RsGxsNetServiceItem *>(item);
|
||||||
|
|
||||||
|
if (!gitem)
|
||||||
|
{
|
||||||
|
std::cerr << "(EE) trying to serialise/size an item that is not a RsGxsNetServiceItem!" << std::endl;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
return gitem->serial_size() ;
|
||||||
|
}
|
||||||
|
virtual bool serialise(RsItem *item, void *data, uint32_t *size)
|
||||||
|
{
|
||||||
|
RsGxsNetServiceItem *gitem = dynamic_cast<RsGxsNetServiceItem *>(item);
|
||||||
|
|
||||||
|
if (!gitem)
|
||||||
|
{
|
||||||
|
std::cerr << "(EE) trying to serialise an item that is not a RsGxsNetServiceItem!" << std::endl;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return gitem->serialise(data,*size) ;
|
||||||
|
}
|
||||||
|
|
||||||
virtual uint32_t size(RsItem *item);
|
|
||||||
virtual bool serialise(RsItem *item, void *data, uint32_t *size);
|
|
||||||
virtual RsItem* deserialise(void *data, uint32_t *size);
|
virtual RsItem* deserialise(void *data, uint32_t *size);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
RsGxsGrpConfigItem *deserialGxsGrpConfig(void *data, uint32_t *size);
|
||||||
|
RsGxsServerMsgUpdateItem *deserialGxsServerMsgUpdate(void *data, uint32_t *size);
|
||||||
|
RsGxsMsgUpdateItem *deserialGxsMsgUpdate(void *data, uint32_t *size);
|
||||||
|
RsGxsServerGrpUpdateItem *deserialGxsServerGrpUpddate(void *data, uint32_t *size);
|
||||||
|
RsGxsGrpUpdateItem *deserialGxsGrpUpddate(void *data, uint32_t *size);
|
||||||
|
|
||||||
|
bool checkItemHeader(void *data, uint32_t *size, uint16_t service_type,uint8_t subservice_type);
|
||||||
/* for RS_PKT_SUBTYPE_GRP_UPDATE_ITEM */
|
|
||||||
|
|
||||||
virtual uint32_t sizeGxsGrpUpdate(RsGxsGrpUpdateItem* item);
|
|
||||||
virtual bool serialiseGxsGrpUpdate(RsGxsGrpUpdateItem *item, void *data, uint32_t *size);
|
|
||||||
virtual RsGxsGrpUpdateItem* deserialGxsGrpUpddate(void *data, uint32_t *size);
|
|
||||||
|
|
||||||
/* for RS_PKT_SUBTYPE_GRP_SERVER_UPDATE_ITEM */
|
|
||||||
|
|
||||||
virtual uint32_t sizeGxsServerGrpUpdate(RsGxsServerGrpUpdateItem* item);
|
|
||||||
virtual bool serialiseGxsServerGrpUpdate(RsGxsServerGrpUpdateItem *item, void *data, uint32_t *size);
|
|
||||||
virtual RsGxsServerGrpUpdateItem* deserialGxsServerGrpUpddate(void *data, uint32_t *size);
|
|
||||||
|
|
||||||
/* for RS_PKT_SUBTYPE_GXS_MSG_UPDATE_ITEM */
|
|
||||||
|
|
||||||
virtual uint32_t sizeGxsMsgUpdate(RsGxsMsgUpdateItem* item);
|
|
||||||
virtual bool serialiseGxsMsgUpdate(RsGxsMsgUpdateItem *item, void *data, uint32_t *size);
|
|
||||||
virtual RsGxsMsgUpdateItem* deserialGxsMsgUpdate(void *data, uint32_t *size);
|
|
||||||
|
|
||||||
/* for RS_PKT_SUBTYPE_GXS_SERVER_UPDATE_ITEM */
|
|
||||||
|
|
||||||
virtual uint32_t sizeGxsServerMsgUpdate(RsGxsServerMsgUpdateItem* item);
|
|
||||||
virtual bool serialiseGxsServerMsgUpdate(RsGxsServerMsgUpdateItem *item, void *data, uint32_t *size);
|
|
||||||
virtual RsGxsServerMsgUpdateItem* deserialGxsServerMsgUpdate(void *data, uint32_t *size);
|
|
||||||
|
|
||||||
private:
|
|
||||||
|
|
||||||
const uint16_t SERVICE_TYPE;
|
const uint16_t SERVICE_TYPE;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#endif /* RSGXSUPDATEITEMS_H_ */
|
#endif /* RSGXSUPDATEITEMS_H_ */
|
||||||
|
@ -371,7 +371,7 @@ bool RsNxsSyncMsgReqItem::serialise(void *data, uint32_t& size) const
|
|||||||
|
|
||||||
ok &= setRawUInt32(data, size, &offset, transactionNumber);
|
ok &= setRawUInt32(data, size, &offset, transactionNumber);
|
||||||
ok &= setRawUInt8(data, size, &offset, flag);
|
ok &= setRawUInt8(data, size, &offset, flag);
|
||||||
ok &= setRawUInt32(data, size, &offset, createdSince);
|
ok &= setRawUInt32(data, size, &offset, createdSinceTS);
|
||||||
ok &= SetTlvString(data, size, &offset, TLV_TYPE_STR_HASH_SHA1, syncHash);
|
ok &= SetTlvString(data, size, &offset, TLV_TYPE_STR_HASH_SHA1, syncHash);
|
||||||
ok &= grpId.serialise(data, size, offset);
|
ok &= grpId.serialise(data, size, offset);
|
||||||
ok &= setRawUInt32(data, size, &offset, updateTS);
|
ok &= setRawUInt32(data, size, &offset, updateTS);
|
||||||
@ -779,7 +779,7 @@ RsNxsSyncMsgReqItem* RsNxsSerialiser::deserialNxsSyncMsgReqItem(void *data, uint
|
|||||||
|
|
||||||
ok &= getRawUInt32(data, *size, &offset, &(item->transactionNumber));
|
ok &= getRawUInt32(data, *size, &offset, &(item->transactionNumber));
|
||||||
ok &= getRawUInt8(data, *size, &offset, &(item->flag));
|
ok &= getRawUInt8(data, *size, &offset, &(item->flag));
|
||||||
ok &= getRawUInt32(data, *size, &offset, &(item->createdSince));
|
ok &= getRawUInt32(data, *size, &offset, &(item->createdSinceTS));
|
||||||
ok &= GetTlvString(data, *size, &offset, TLV_TYPE_STR_HASH_SHA1, item->syncHash);
|
ok &= GetTlvString(data, *size, &offset, TLV_TYPE_STR_HASH_SHA1, item->syncHash);
|
||||||
ok &= item->grpId.deserialise(data, *size, offset);
|
ok &= item->grpId.deserialise(data, *size, offset);
|
||||||
ok &= getRawUInt32(data, *size, &offset, &(item->updateTS));
|
ok &= getRawUInt32(data, *size, &offset, &(item->updateTS));
|
||||||
@ -1099,7 +1099,7 @@ void RsNxsSyncMsgReqItem::clear()
|
|||||||
{
|
{
|
||||||
grpId.clear();
|
grpId.clear();
|
||||||
flag = 0;
|
flag = 0;
|
||||||
createdSince = 0;
|
createdSinceTS = 0;
|
||||||
syncHash.clear();
|
syncHash.clear();
|
||||||
updateTS = 0;
|
updateTS = 0;
|
||||||
}
|
}
|
||||||
@ -1181,7 +1181,7 @@ std::ostream& RsNxsSyncMsgReqItem::print(std::ostream &out, uint16_t indent)
|
|||||||
printIndent(out , int_Indent);
|
printIndent(out , int_Indent);
|
||||||
out << "GrpId: " << grpId << std::endl;
|
out << "GrpId: " << grpId << std::endl;
|
||||||
printIndent(out , int_Indent);
|
printIndent(out , int_Indent);
|
||||||
out << "createdSince: " << createdSince << std::endl;
|
out << "createdSince: " << createdSinceTS << std::endl;
|
||||||
printIndent(out , int_Indent);
|
printIndent(out , int_Indent);
|
||||||
out << "syncHash: " << syncHash << std::endl;
|
out << "syncHash: " << syncHash << std::endl;
|
||||||
printIndent(out , int_Indent);
|
printIndent(out , int_Indent);
|
||||||
|
@ -363,7 +363,7 @@ public:
|
|||||||
|
|
||||||
RsGxsGroupId grpId;
|
RsGxsGroupId grpId;
|
||||||
uint8_t flag;
|
uint8_t flag;
|
||||||
uint32_t createdSince;
|
uint32_t createdSinceTS;
|
||||||
uint32_t updateTS; // time of last update
|
uint32_t updateTS; // time of last update
|
||||||
std::string syncHash;
|
std::string syncHash;
|
||||||
};
|
};
|
||||||
|
@ -64,8 +64,8 @@ QString PostedDialog::getHelpString() const
|
|||||||
<p>Links can be commented by subscribed users. A promotion system also gives the opportunity to \
|
<p>Links can be commented by subscribed users. A promotion system also gives the opportunity to \
|
||||||
enlight important links.</p> \
|
enlight important links.</p> \
|
||||||
<p>There is no restriction on which links are shared. Be careful when clicking on them.</p>\
|
<p>There is no restriction on which links are shared. Be careful when clicking on them.</p>\
|
||||||
<p>Posted links get deleted after %1 months.</p>\
|
<p>Posted links are kept for %1 days, and sync-ed over the last %2 days, unless you change this.</p>\
|
||||||
").arg(QString::number(rsPosted->getStoragePeriod()));
|
").arg(QString::number(rsPosted->getDefaultStoragePeriod()/86400)).arg(QString::number(rsPosted->getDefaultSyncPeriod()/86400));
|
||||||
|
|
||||||
return hlp_str ;
|
return hlp_str ;
|
||||||
}
|
}
|
||||||
|
@ -347,7 +347,6 @@ void GxsGroupDialog::setupVisibility()
|
|||||||
ui.commentGroupBox->setVisible(mEnabledFlags & GXS_GROUP_FLAGS_COMMENTS);
|
ui.commentGroupBox->setVisible(mEnabledFlags & GXS_GROUP_FLAGS_COMMENTS);
|
||||||
ui.commentsLabel->setVisible(mEnabledFlags & GXS_GROUP_FLAGS_COMMENTS);
|
ui.commentsLabel->setVisible(mEnabledFlags & GXS_GROUP_FLAGS_COMMENTS);
|
||||||
ui.commentsValueLabel->setVisible(mEnabledFlags & GXS_GROUP_FLAGS_COMMENTS);
|
ui.commentsValueLabel->setVisible(mEnabledFlags & GXS_GROUP_FLAGS_COMMENTS);
|
||||||
//ui.commentslabel->setVisible(mEnabledFlags & GXS_GROUP_FLAGS_COMMENTS);
|
|
||||||
|
|
||||||
ui.extraFrame->setVisible(mEnabledFlags & GXS_GROUP_FLAGS_EXTRA);
|
ui.extraFrame->setVisible(mEnabledFlags & GXS_GROUP_FLAGS_EXTRA);
|
||||||
}
|
}
|
||||||
|
@ -285,15 +285,35 @@ void GxsGroupFrameDialog::groupTreeCustomPopupMenu(QPoint point)
|
|||||||
action = contextMnu.addAction(QIcon(IMAGE_EDIT), tr("Edit Details"), this, SLOT(editGroupDetails()));
|
action = contextMnu.addAction(QIcon(IMAGE_EDIT), tr("Edit Details"), this, SLOT(editGroupDetails()));
|
||||||
action->setEnabled (!mGroupId.isNull() && isAdmin);
|
action->setEnabled (!mGroupId.isNull() && isAdmin);
|
||||||
|
|
||||||
|
uint32_t current_store_time = mInterface->getStoragePeriod(mGroupId)/86400 ;
|
||||||
|
uint32_t current_sync_time = mInterface->getSyncPeriod(mGroupId)/86400 ;
|
||||||
|
|
||||||
|
std::cerr << "Got sync=" << current_sync_time << ". store=" << current_store_time << std::endl;
|
||||||
|
QAction *actnn = NULL;
|
||||||
|
|
||||||
|
QMenu *ctxMenu2 = contextMnu.addMenu(tr("Synchronise posts of last...")) ;
|
||||||
|
actnn = ctxMenu2->addAction(tr(" 5 days" ),this,SLOT(setSyncPostsDelay())) ; actnn->setData(QVariant( 5)) ; if(current_sync_time == 5) { actnn->setEnabled(false);actnn->setIcon(QIcon(":/images/start.png"));}
|
||||||
|
actnn = ctxMenu2->addAction(tr(" 2 weeks" ),this,SLOT(setSyncPostsDelay())) ; actnn->setData(QVariant( 15)) ; if(current_sync_time == 15) { actnn->setEnabled(false);actnn->setIcon(QIcon(":/images/start.png"));}
|
||||||
|
actnn = ctxMenu2->addAction(tr(" 1 month" ),this,SLOT(setSyncPostsDelay())) ; actnn->setData(QVariant( 30)) ; if(current_sync_time == 30) { actnn->setEnabled(false);actnn->setIcon(QIcon(":/images/start.png"));}
|
||||||
|
actnn = ctxMenu2->addAction(tr(" 3 months" ),this,SLOT(setSyncPostsDelay())) ; actnn->setData(QVariant( 90)) ; if(current_sync_time == 90) { actnn->setEnabled(false);actnn->setIcon(QIcon(":/images/start.png"));}
|
||||||
|
actnn = ctxMenu2->addAction(tr(" 6 months" ),this,SLOT(setSyncPostsDelay())) ; actnn->setData(QVariant(180)) ; if(current_sync_time ==180) { actnn->setEnabled(false);actnn->setIcon(QIcon(":/images/start.png"));}
|
||||||
|
actnn = ctxMenu2->addAction(tr(" 1 year " ),this,SLOT(setSyncPostsDelay())) ; actnn->setData(QVariant(365)) ; if(current_sync_time ==365) { actnn->setEnabled(false);actnn->setIcon(QIcon(":/images/start.png"));}
|
||||||
|
actnn = ctxMenu2->addAction(tr(" Indefinitly"),this,SLOT(setSyncPostsDelay())) ; actnn->setData(QVariant( 0)) ; if(current_sync_time == 0) { actnn->setEnabled(false);actnn->setIcon(QIcon(":/images/start.png"));}
|
||||||
|
|
||||||
|
ctxMenu2 = contextMnu.addMenu(tr("Store posts for at most...")) ;
|
||||||
|
actnn = ctxMenu2->addAction(tr(" 5 days" ),this,SLOT(setStorePostsDelay())) ; actnn->setData(QVariant( 5)) ; if(current_store_time == 5) { actnn->setEnabled(false);actnn->setIcon(QIcon(":/images/start.png"));}
|
||||||
|
actnn = ctxMenu2->addAction(tr(" 2 weeks" ),this,SLOT(setStorePostsDelay())) ; actnn->setData(QVariant( 15)) ; if(current_store_time == 15) { actnn->setEnabled(false);actnn->setIcon(QIcon(":/images/start.png"));}
|
||||||
|
actnn = ctxMenu2->addAction(tr(" 1 month" ),this,SLOT(setStorePostsDelay())) ; actnn->setData(QVariant( 30)) ; if(current_store_time == 30) { actnn->setEnabled(false);actnn->setIcon(QIcon(":/images/start.png"));}
|
||||||
|
actnn = ctxMenu2->addAction(tr(" 3 months" ),this,SLOT(setStorePostsDelay())) ; actnn->setData(QVariant( 90)) ; if(current_store_time == 90) { actnn->setEnabled(false);actnn->setIcon(QIcon(":/images/start.png"));}
|
||||||
|
actnn = ctxMenu2->addAction(tr(" 6 months" ),this,SLOT(setStorePostsDelay())) ; actnn->setData(QVariant(180)) ; if(current_store_time ==180) { actnn->setEnabled(false);actnn->setIcon(QIcon(":/images/start.png"));}
|
||||||
|
actnn = ctxMenu2->addAction(tr(" 1 year " ),this,SLOT(setStorePostsDelay())) ; actnn->setData(QVariant(365)) ; if(current_store_time ==365) { actnn->setEnabled(false);actnn->setIcon(QIcon(":/images/start.png"));}
|
||||||
|
actnn = ctxMenu2->addAction(tr(" Indefinitly"),this,SLOT(setStorePostsDelay())) ; actnn->setData(QVariant( 0)) ; if(current_store_time == 0) { actnn->setEnabled(false);actnn->setIcon(QIcon(":/images/start.png"));}
|
||||||
|
|
||||||
if (shareKeyType()) {
|
if (shareKeyType()) {
|
||||||
action = contextMnu.addAction(QIcon(IMAGE_SHARE), tr("Share publish permissions"), this, SLOT(sharePublishKey()));
|
action = contextMnu.addAction(QIcon(IMAGE_SHARE), tr("Share publish permissions"), this, SLOT(sharePublishKey()));
|
||||||
action->setEnabled(!mGroupId.isNull() && isPublisher);
|
action->setEnabled(!mGroupId.isNull() && isPublisher);
|
||||||
}
|
}
|
||||||
|
|
||||||
//if (!mGroupId.isNull() && isPublisher && !isAdmin) {
|
|
||||||
// contextMnu.addAction(QIcon(":/images/settings16.png"), tr("Restore Publish Rights" ), this, SLOT(restoreGroupKeys()));
|
|
||||||
//}
|
|
||||||
|
|
||||||
if (getLinkType() != RetroShareLink::TYPE_UNKNOWN) {
|
if (getLinkType() != RetroShareLink::TYPE_UNKNOWN) {
|
||||||
action = contextMnu.addAction(QIcon(IMAGE_COPYLINK), tr("Copy RetroShare Link"), this, SLOT(copyGroupLink()));
|
action = contextMnu.addAction(QIcon(IMAGE_COPYLINK), tr("Copy RetroShare Link"), this, SLOT(copyGroupLink()));
|
||||||
action->setEnabled(!mGroupId.isNull());
|
action->setEnabled(!mGroupId.isNull());
|
||||||
@ -318,6 +338,70 @@ void GxsGroupFrameDialog::groupTreeCustomPopupMenu(QPoint point)
|
|||||||
contextMnu.exec(QCursor::pos());
|
contextMnu.exec(QCursor::pos());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void GxsGroupFrameDialog::setStorePostsDelay()
|
||||||
|
{
|
||||||
|
QAction *action = dynamic_cast<QAction*>(sender()) ;
|
||||||
|
|
||||||
|
if(!action || mGroupId.isNull())
|
||||||
|
{
|
||||||
|
std::cerr << "(EE) Cannot find action/group that called me! Group is " << mGroupId << ", action is " << (void*)action << " " << __PRETTY_FUNCTION__ << std::endl;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
uint32_t duration = action->data().toUInt() ;
|
||||||
|
|
||||||
|
std::cerr << "Data is " << duration << std::endl;
|
||||||
|
|
||||||
|
mInterface->setStoragePeriod(mGroupId,duration * 86400) ;
|
||||||
|
|
||||||
|
// If the sync is larger, we reduce it. No need to sync more than we store. The machinery below also takes care of this.
|
||||||
|
//
|
||||||
|
uint32_t sync_period = mInterface->getSyncPeriod(mGroupId);
|
||||||
|
|
||||||
|
if(duration > 0) // the >0 test is to discard the indefinitly test. Basically, if we store for less than indefinitly, the sync is reduced accordingly.
|
||||||
|
{
|
||||||
|
if(sync_period == 0 || sync_period > duration*86400)
|
||||||
|
{
|
||||||
|
mInterface->setSyncPeriod(mGroupId,duration * 86400) ;
|
||||||
|
|
||||||
|
std::cerr << "(II) auto adjusting sync period to " << duration<< " days as well." << std::endl;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void GxsGroupFrameDialog::setSyncPostsDelay()
|
||||||
|
{
|
||||||
|
QAction *action = dynamic_cast<QAction*>(sender()) ;
|
||||||
|
|
||||||
|
if(!action || mGroupId.isNull())
|
||||||
|
{
|
||||||
|
std::cerr << "(EE) Cannot find action/group that called me! Group is " << mGroupId << ", action is " << (void*)action << " " << __PRETTY_FUNCTION__ << std::endl;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
uint32_t duration = action->data().toUInt() ;
|
||||||
|
|
||||||
|
std::cerr << "Data is " << duration << std::endl;
|
||||||
|
|
||||||
|
mInterface->setSyncPeriod(mGroupId,duration * 86400) ;
|
||||||
|
|
||||||
|
// If the store is smaller, we increase it accordingly. No need to sync more than we store. The machinery below also takes care of this.
|
||||||
|
//
|
||||||
|
uint32_t store_period = mInterface->getStoragePeriod(mGroupId);
|
||||||
|
|
||||||
|
if(duration == 0)
|
||||||
|
mInterface->setStoragePeriod(mGroupId,duration * 86400) ; // indefinite sync => indefinite storage
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if(store_period != 0 && store_period < duration*86400)
|
||||||
|
{
|
||||||
|
mInterface->setStoragePeriod(mGroupId,duration * 86400) ; // indefinite sync => indefinite storage
|
||||||
|
std::cerr << "(II) auto adjusting storage period to " << duration<< " days as well." << std::endl;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void GxsGroupFrameDialog::restoreGroupKeys(void)
|
void GxsGroupFrameDialog::restoreGroupKeys(void)
|
||||||
{
|
{
|
||||||
QMessageBox::warning(this, "RetroShare", "ToDo");
|
QMessageBox::warning(this, "RetroShare", "ToDo");
|
||||||
|
@ -99,6 +99,8 @@ private slots:
|
|||||||
/** Create the context popup menu and it's submenus */
|
/** Create the context popup menu and it's submenus */
|
||||||
void groupTreeCustomPopupMenu(QPoint point);
|
void groupTreeCustomPopupMenu(QPoint point);
|
||||||
void settingsChanged();
|
void settingsChanged();
|
||||||
|
void setSyncPostsDelay();
|
||||||
|
void setStorePostsDelay();
|
||||||
|
|
||||||
void restoreGroupKeys();
|
void restoreGroupKeys();
|
||||||
void newGroup();
|
void newGroup();
|
||||||
|
@ -65,8 +65,8 @@ QString GxsChannelDialog::getHelpString() const
|
|||||||
the posting rights or the reading rights with friend Retroshare nodes.</p>\
|
the posting rights or the reading rights with friend Retroshare nodes.</p>\
|
||||||
<p>Channels can be made anonymous, or attached to a Retroshare identity so that readers can contact you if needed.\
|
<p>Channels can be made anonymous, or attached to a Retroshare identity so that readers can contact you if needed.\
|
||||||
Enable \"Allow Comments\" if you want to let users comment on your posts.</p>\
|
Enable \"Allow Comments\" if you want to let users comment on your posts.</p>\
|
||||||
<p>Channel posts get deleted after %1 months.</p>\
|
<p>Channel posts are kept for %1 days, and sync-ed over the last %2 days, unless you change this.</p>\
|
||||||
").arg(QString::number(rsGxsChannels->getStoragePeriod()));
|
").arg(QString::number(rsGxsChannels->getDefaultStoragePeriod()/86400)).arg(QString::number(rsGxsChannels->getDefaultSyncPeriod()/86400));
|
||||||
|
|
||||||
return hlp_str ;
|
return hlp_str ;
|
||||||
}
|
}
|
||||||
|
@ -746,6 +746,22 @@ void GxsForumThreadWidget::insertGroupData()
|
|||||||
calculateIconsAndFonts();
|
calculateIconsAndFonts();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static QString getDurationString(uint32_t days)
|
||||||
|
{
|
||||||
|
switch(days)
|
||||||
|
{
|
||||||
|
case 0: return QObject::tr("Indefinitely") ;
|
||||||
|
case 5: return QObject::tr("5 days") ;
|
||||||
|
case 15: return QObject::tr("2 weeks") ;
|
||||||
|
case 30: return QObject::tr("1 month") ;
|
||||||
|
case 60: return QObject::tr("2 month") ;
|
||||||
|
case 180: return QObject::tr("6 month") ;
|
||||||
|
case 365: return QObject::tr("1 year") ;
|
||||||
|
default:
|
||||||
|
return QString::number(days)+" " + QObject::tr("days") ;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/*static*/ void GxsForumThreadWidget::loadAuthorIdCallback(GxsIdDetailsType type, const RsIdentityDetails &details, QObject *object, const QVariant &)
|
/*static*/ void GxsForumThreadWidget::loadAuthorIdCallback(GxsIdDetailsType type, const RsIdentityDetails &details, QObject *object, const QVariant &)
|
||||||
{
|
{
|
||||||
GxsForumThreadWidget *tw = dynamic_cast<GxsForumThreadWidget*>(object);
|
GxsForumThreadWidget *tw = dynamic_cast<GxsForumThreadWidget*>(object);
|
||||||
@ -784,6 +800,8 @@ void GxsForumThreadWidget::insertGroupData()
|
|||||||
tw->mForumDescription = QString("<b>%1: \t</b>%2<br/>").arg(tr("Forum name"), QString::fromUtf8( group.mMeta.mGroupName.c_str()));
|
tw->mForumDescription = QString("<b>%1: \t</b>%2<br/>").arg(tr("Forum name"), QString::fromUtf8( group.mMeta.mGroupName.c_str()));
|
||||||
tw->mForumDescription += QString("<b>%1: \t</b>%2<br/>").arg(tr("Subscribers")).arg(group.mMeta.mPop);
|
tw->mForumDescription += QString("<b>%1: \t</b>%2<br/>").arg(tr("Subscribers")).arg(group.mMeta.mPop);
|
||||||
tw->mForumDescription += QString("<b>%1: \t</b>%2<br/>").arg(tr("Posts (at neighbor nodes)")).arg(group.mMeta.mVisibleMsgCount);
|
tw->mForumDescription += QString("<b>%1: \t</b>%2<br/>").arg(tr("Posts (at neighbor nodes)")).arg(group.mMeta.mVisibleMsgCount);
|
||||||
|
tw->mForumDescription += QString("<b>%1: \t</b>%2<br/>").arg(tr("Synchronization")).arg(getDurationString( rsGxsForums->getSyncPeriod(group.mMeta.mGroupId)/86400 )) ;
|
||||||
|
tw->mForumDescription += QString("<b>%1: \t</b>%2<br/>").arg(tr("Storage")).arg(getDurationString( rsGxsForums->getStoragePeriod(group.mMeta.mGroupId)/86400));
|
||||||
|
|
||||||
QString distrib_string = tr("[unknown]");
|
QString distrib_string = tr("[unknown]");
|
||||||
switch(group.mMeta.mCircleType)
|
switch(group.mMeta.mCircleType)
|
||||||
|
@ -54,16 +54,8 @@ QString GxsForumsDialog::getHelpString() const
|
|||||||
<p>Retroshare Forums look like internet forums, but they work in a decentralized way</p> \
|
<p>Retroshare Forums look like internet forums, but they work in a decentralized way</p> \
|
||||||
<p>You see forums your friends are subscribed to, and you forward subscribed forums to \
|
<p>You see forums your friends are subscribed to, and you forward subscribed forums to \
|
||||||
your friends. This automatically promotes interesting forums in the network.</p> \
|
your friends. This automatically promotes interesting forums in the network.</p> \
|
||||||
<p>Forum messages get deleted after %1 months.</p>\
|
<p>Forum messages are kept for %1 days and sync-ed over the last %2 days, unless you configure it otherwise.</p>\
|
||||||
").arg(QString::number(rsGxsForums->getStoragePeriod()));
|
").arg(QString::number(rsGxsForums->getDefaultStoragePeriod()/86400)).arg(QString::number(rsGxsForums->getDefaultSyncPeriod()/86400));
|
||||||
|
|
||||||
// not true anymore in v0.6
|
|
||||||
/*
|
|
||||||
<p>Forums are either Authenticated (<img src=\":/images/konv_message2.png\" width=\"12\"/>) \
|
|
||||||
or anonymous (<img src=\":/images/konversation.png\" width=\"12\"/>). The former \
|
|
||||||
class is more resistant to spamming because posts are \
|
|
||||||
cryptographically signed using a Retroshare pseudo-identity.</p>") ;
|
|
||||||
*/
|
|
||||||
|
|
||||||
return hlp_str ;
|
return hlp_str ;
|
||||||
}
|
}
|
||||||
|
@ -191,7 +191,7 @@ RsSerialType* init_item(RsNxsSyncMsgReqItem& rsgm)
|
|||||||
rsgm.clear();
|
rsgm.clear();
|
||||||
|
|
||||||
rsgm.flag = RsNxsSyncMsgItem::FLAG_USE_SYNC_HASH;
|
rsgm.flag = RsNxsSyncMsgItem::FLAG_USE_SYNC_HASH;
|
||||||
rsgm.createdSince = rand()%24232;
|
rsgm.createdSinceTS = rand()%24232;
|
||||||
rsgm.transactionNumber = rand()%23;
|
rsgm.transactionNumber = rand()%23;
|
||||||
init_random(rsgm.grpId) ;
|
init_random(rsgm.grpId) ;
|
||||||
randString(SHORT_STR, rsgm.syncHash);
|
randString(SHORT_STR, rsgm.syncHash);
|
||||||
@ -251,7 +251,7 @@ bool operator==(const RsNxsSyncMsgReqItem& l, const RsNxsSyncMsgReqItem& r)
|
|||||||
{
|
{
|
||||||
|
|
||||||
if(l.flag != r.flag) return false;
|
if(l.flag != r.flag) return false;
|
||||||
if(l.createdSince != r.createdSince) return false;
|
if(l.createdSinceTS != r.createdSinceTS) return false;
|
||||||
if(l.syncHash != r.syncHash) return false;
|
if(l.syncHash != r.syncHash) return false;
|
||||||
if(l.grpId != r.grpId) return false;
|
if(l.grpId != r.grpId) return false;
|
||||||
if(l.transactionNumber != r.transactionNumber) return false;
|
if(l.transactionNumber != r.transactionNumber) return false;
|
||||||
|
@ -15,7 +15,8 @@ public:
|
|||||||
RsDummyNetService(){ return;}
|
RsDummyNetService(){ return;}
|
||||||
virtual ~RsDummyNetService() { }
|
virtual ~RsDummyNetService() { }
|
||||||
|
|
||||||
void setSyncAge(uint32_t age){}
|
void setSyncAge(const RsGxsGroupId& id,uint32_t age_in_secs){}
|
||||||
|
void setKeepAge(const RsGxsGroupId& id,uint32_t age_in_secs){}
|
||||||
|
|
||||||
void requestGroupsOfPeer(const std::string& peerId){}
|
void requestGroupsOfPeer(const std::string& peerId){}
|
||||||
|
|
||||||
|
@ -15,17 +15,17 @@ RsSerialType* init_item(RsGxsGrpUpdateItem& i)
|
|||||||
{
|
{
|
||||||
i.clear();
|
i.clear();
|
||||||
i.grpUpdateTS = rand()%2424;
|
i.grpUpdateTS = rand()%2424;
|
||||||
i.peerId = RsPeerId::random();
|
i.peerID = RsPeerId::random();
|
||||||
return new RsGxsUpdateSerialiser(RS_SERVICE_TYPE_PLUGIN_SIMPLE_FORUM);
|
return new RsGxsUpdateSerialiser(RS_SERVICE_TYPE_PLUGIN_SIMPLE_FORUM);
|
||||||
}
|
}
|
||||||
|
|
||||||
RsSerialType* init_item(RsGxsMsgUpdateItem& i)
|
RsSerialType* init_item(RsGxsMsgUpdateItem& i)
|
||||||
{
|
{
|
||||||
i.clear();
|
i.clear();
|
||||||
i.peerId = RsPeerId::random();
|
i.peerID = RsPeerId::random();
|
||||||
int numUpdates = rand()%123;
|
int numUpdates = rand()%123;
|
||||||
|
|
||||||
i.peerId = RsPeerId::random();
|
i.peerID = RsPeerId::random();
|
||||||
for(int j=0; j < numUpdates; j++)
|
for(int j=0; j < numUpdates; j++)
|
||||||
{
|
{
|
||||||
struct RsGxsMsgUpdateItem::MsgUpdateInfo info;
|
struct RsGxsMsgUpdateItem::MsgUpdateInfo info;
|
||||||
@ -56,7 +56,7 @@ RsSerialType* init_item(RsGxsServerMsgUpdateItem& i)
|
|||||||
bool operator ==(const RsGxsGrpUpdateItem& l, const RsGxsGrpUpdateItem& r)
|
bool operator ==(const RsGxsGrpUpdateItem& l, const RsGxsGrpUpdateItem& r)
|
||||||
{
|
{
|
||||||
bool ok = l.grpUpdateTS == r.grpUpdateTS;
|
bool ok = l.grpUpdateTS == r.grpUpdateTS;
|
||||||
ok &= l.peerId == r.peerId;
|
ok &= l.peerID == r.peerID;
|
||||||
|
|
||||||
return ok;
|
return ok;
|
||||||
}
|
}
|
||||||
@ -68,7 +68,7 @@ bool operator ==(const RsGxsMsgUpdateItem::MsgUpdateInfo& l, const RsGxsMsgUpdat
|
|||||||
|
|
||||||
bool operator ==(const RsGxsMsgUpdateItem& l, const RsGxsMsgUpdateItem& r)
|
bool operator ==(const RsGxsMsgUpdateItem& l, const RsGxsMsgUpdateItem& r)
|
||||||
{
|
{
|
||||||
bool ok = l.peerId == r.peerId;
|
bool ok = l.peerID == r.peerID;
|
||||||
|
|
||||||
const std::map<RsGxsGroupId, RsGxsMsgUpdateItem::MsgUpdateInfo>& lUp = l.msgUpdateInfos, rUp = r.msgUpdateInfos;
|
const std::map<RsGxsGroupId, RsGxsMsgUpdateItem::MsgUpdateInfo>& lUp = l.msgUpdateInfos, rUp = r.msgUpdateInfos;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user