mirror of
https://github.com/RetroShare/RetroShare.git
synced 2025-01-13 00:19:30 -05:00
Merge pull request #2377 from G10h4ck/gxs_fast_pull_request
Implement pull request mechanism in RsGxsNetService
This commit is contained in:
commit
fe0561b3fe
@ -41,6 +41,7 @@
|
|||||||
#include "rsserver/p3face.h"
|
#include "rsserver/p3face.h"
|
||||||
#include "retroshare/rsevents.h"
|
#include "retroshare/rsevents.h"
|
||||||
#include "util/radix64.h"
|
#include "util/radix64.h"
|
||||||
|
#include "util/cxx17retrocompat.h"
|
||||||
|
|
||||||
#define PUB_GRP_MASK 0x000f
|
#define PUB_GRP_MASK 0x000f
|
||||||
#define RESTR_GRP_MASK 0x00f0
|
#define RESTR_GRP_MASK 0x00f0
|
||||||
@ -2285,8 +2286,9 @@ bool RsGenExchange::processGrpMask(const RsGxsGroupId& grpId, ContentValue &grpC
|
|||||||
|
|
||||||
void RsGenExchange::publishMsgs()
|
void RsGenExchange::publishMsgs()
|
||||||
{
|
{
|
||||||
|
bool atLeastOneMessageCreatedSuccessfully = false;
|
||||||
|
|
||||||
RS_STACK_MUTEX(mGenMtx) ;
|
RS_STACK_MUTEX(mGenMtx);
|
||||||
|
|
||||||
rstime_t now = time(NULL);
|
rstime_t now = time(NULL);
|
||||||
|
|
||||||
@ -2463,6 +2465,8 @@ void RsGenExchange::publishMsgs()
|
|||||||
// add to published to allow acknowledgement
|
// add to published to allow acknowledgement
|
||||||
mMsgNotify.insert(std::make_pair(mit->first, std::make_pair(grpId, msgId)));
|
mMsgNotify.insert(std::make_pair(mit->first, std::make_pair(grpId, msgId)));
|
||||||
mDataAccess->updatePublicRequestStatus(mit->first, RsTokenService::COMPLETE);
|
mDataAccess->updatePublicRequestStatus(mit->first, RsTokenService::COMPLETE);
|
||||||
|
|
||||||
|
atLeastOneMessageCreatedSuccessfully = true;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -2496,6 +2500,8 @@ void RsGenExchange::publishMsgs()
|
|||||||
|
|
||||||
mNotifications.push_back(ch);
|
mNotifications.push_back(ch);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(atLeastOneMessageCreatedSuccessfully) mNetService->requestPull();
|
||||||
}
|
}
|
||||||
|
|
||||||
RsGenExchange::ServiceCreate_Return RsGenExchange::service_CreateGroup(RsGxsGrpItem* /* grpItem */,
|
RsGenExchange::ServiceCreate_Return RsGenExchange::service_CreateGroup(RsGxsGrpItem* /* grpItem */,
|
||||||
@ -2723,7 +2729,8 @@ bool RsGenExchange::checkKeys(const RsTlvSecurityKeySet& keySet)
|
|||||||
|
|
||||||
void RsGenExchange::publishGrps()
|
void RsGenExchange::publishGrps()
|
||||||
{
|
{
|
||||||
std::list<RsGxsGroupId> groups_to_subscribe ;
|
bool atLeastOneGroupCreatedSuccessfully = false;
|
||||||
|
std::list<RsGxsGroupId> groups_to_subscribe;
|
||||||
|
|
||||||
{
|
{
|
||||||
RS_STACK_MUTEX(mGenMtx) ;
|
RS_STACK_MUTEX(mGenMtx) ;
|
||||||
@ -2954,6 +2961,8 @@ void RsGenExchange::publishGrps()
|
|||||||
|
|
||||||
// add to published to allow acknowledgement
|
// add to published to allow acknowledgement
|
||||||
toNotify.insert(std::make_pair(token, GrpNote(true,ggps.mIsUpdate,grpId)));
|
toNotify.insert(std::make_pair(token, GrpNote(true,ggps.mIsUpdate,grpId)));
|
||||||
|
|
||||||
|
atLeastOneGroupCreatedSuccessfully = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2972,9 +2981,14 @@ void RsGenExchange::publishGrps()
|
|||||||
|
|
||||||
// This is done off-mutex to avoid possible cross deadlocks with the net service.
|
// This is done off-mutex to avoid possible cross deadlocks with the net service.
|
||||||
|
|
||||||
if(mNetService!=NULL)
|
if(mNetService != nullptr)
|
||||||
for(std::list<RsGxsGroupId>::const_iterator it(groups_to_subscribe.begin());it!=groups_to_subscribe.end();++it)
|
{
|
||||||
mNetService->subscribeStatusChanged((*it),true) ;
|
for(auto& grpId : std::as_const(groups_to_subscribe))
|
||||||
|
mNetService->subscribeStatusChanged(grpId, true);
|
||||||
|
|
||||||
|
if(atLeastOneGroupCreatedSuccessfully)
|
||||||
|
mNetService->requestPull();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t RsGenExchange::generatePublicToken()
|
uint32_t RsGenExchange::generatePublicToken()
|
||||||
|
@ -35,7 +35,7 @@
|
|||||||
// |
|
// |
|
||||||
// +----------- sharePublishKeys()
|
// +----------- sharePublishKeys()
|
||||||
// |
|
// |
|
||||||
// +----------- syncWithPeers()
|
// +----------- checkUpdatesFromPeers()
|
||||||
// | |
|
// | |
|
||||||
// | +--if AutoSync--- send global UpdateTS of each peer to itself => the peer knows the last
|
// | +--if AutoSync--- send global UpdateTS of each peer to itself => the peer knows the last
|
||||||
// | | time current peer has received an updated from himself
|
// | | time current peer has received an updated from himself
|
||||||
@ -127,14 +127,14 @@
|
|||||||
// (Set at server side to be mGrpServerUpdateItem->grpUpdateTS)
|
// (Set at server side to be mGrpServerUpdateItem->grpUpdateTS)
|
||||||
//
|
//
|
||||||
// Only updated in processCompletedIncomingTransaction() from Grp list transaction.
|
// Only updated in processCompletedIncomingTransaction() from Grp list transaction.
|
||||||
// Used in syncWithPeers() sending in RsNxsSyncGrp once to all peers: peer will send data if
|
// Used in checkUpdatesFromPeers() sending in RsNxsSyncGrp once to all peers: peer will send data if
|
||||||
// has something new. All time comparisons are in the friends' clock time.
|
// has something new. All time comparisons are in the friends' clock time.
|
||||||
//
|
//
|
||||||
// mClientMsgUpdateMap: map< RsPeerId, map<grpId,TimeStamp > >
|
// mClientMsgUpdateMap: map< RsPeerId, map<grpId,TimeStamp > >
|
||||||
//
|
//
|
||||||
// Last msg list modification time sent by that peer Id
|
// Last msg list modification time sent by that peer Id
|
||||||
// Updated in processCompletedIncomingTransaction() from Grp list trans.
|
// Updated in processCompletedIncomingTransaction() from Grp list trans.
|
||||||
// Used in syncWithPeers() sending in RsNxsSyncGrp once to all peers.
|
// Used in checkUpdatesFromPeers() sending in RsNxsSyncGrp once to all peers.
|
||||||
// Set at server to be mServerMsgUpdateMap[grpId]->msgUpdateTS
|
// Set at server to be mServerMsgUpdateMap[grpId]->msgUpdateTS
|
||||||
//
|
//
|
||||||
// mGrpServerUpdateItem: TimeStamp Last group local modification timestamp over all groups
|
// mGrpServerUpdateItem: TimeStamp Last group local modification timestamp over all groups
|
||||||
@ -150,7 +150,7 @@
|
|||||||
//
|
//
|
||||||
// tick() tick()
|
// tick() tick()
|
||||||
// | |
|
// | |
|
||||||
// +---- SyncWithPeers +-- recvNxsItemQueue()
|
// +---- checkUpdatesFromPeers() +-- recvNxsItemQueue()
|
||||||
// | |
|
// | |
|
||||||
// +---------------- Send global UpdateTS of each peer to itself => the peer knows +---------> +------ handleRecvSyncGroup( RsNxsSyncGrp*)
|
// +---------------- Send global UpdateTS of each peer to itself => the peer knows +---------> +------ handleRecvSyncGroup( RsNxsSyncGrp*)
|
||||||
// | the last msg sent (stored in mClientGrpUpdateMap[peer_id]), | | - parse all subscribed groups. For each, send a RsNxsSyncGrpItem with publish TS
|
// | the last msg sent (stored in mClientGrpUpdateMap[peer_id]), | | - parse all subscribed groups. For each, send a RsNxsSyncGrpItem with publish TS
|
||||||
@ -457,7 +457,7 @@ int RsGxsNetService::tick()
|
|||||||
|
|
||||||
if((elapsed) < now)
|
if((elapsed) < now)
|
||||||
{
|
{
|
||||||
syncWithPeers();
|
checkUpdatesFromPeers();
|
||||||
syncGrpStatistics();
|
syncGrpStatistics();
|
||||||
checkDistantSyncState();
|
checkDistantSyncState();
|
||||||
|
|
||||||
@ -570,39 +570,40 @@ RsGxsGroupId RsGxsNetService::hashGrpId(const RsGxsGroupId& gid,const RsPeerId&
|
|||||||
return RsGxsGroupId( RsDirUtil::sha1sum(tmpmem,SIZE).toByteArray() );
|
return RsGxsGroupId( RsDirUtil::sha1sum(tmpmem,SIZE).toByteArray() );
|
||||||
}
|
}
|
||||||
|
|
||||||
void RsGxsNetService::syncWithPeers()
|
std::error_condition RsGxsNetService::checkUpdatesFromPeers(
|
||||||
|
std::set<RsPeerId> peers )
|
||||||
{
|
{
|
||||||
#ifdef NXS_NET_DEBUG_0
|
#ifdef NXS_NET_DEBUG_0
|
||||||
GXSNETDEBUG___ << "RsGxsNetService::syncWithPeers() this=" << (void*)this << ". serviceInfo=" << mServiceInfo << std::endl;
|
RS_DBG("this=", (void*)this, ". serviceInfo=", mServiceInfo);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static RsNxsSerialiser ser(mServType) ; // this is used to estimate bandwidth.
|
/* If specific peers are passed as paramether ask only to them */
|
||||||
|
if(peers.empty())
|
||||||
RS_STACK_MUTEX(mNxsMutex) ;
|
|
||||||
|
|
||||||
std::set<RsPeerId> peers;
|
|
||||||
mNetMgr->getOnlineList(mServiceInfo.mServiceType, peers);
|
|
||||||
|
|
||||||
if(mAllowDistSync && mGxsNetTunnel != NULL)
|
|
||||||
{
|
{
|
||||||
// Grab all online virtual peers of distant tunnels for the current service.
|
mNetMgr->getOnlineList(mServiceInfo.mServiceType, peers);
|
||||||
|
|
||||||
std::list<RsGxsNetTunnelVirtualPeerId> vpids ;
|
if(mAllowDistSync && mGxsNetTunnel != nullptr)
|
||||||
mGxsNetTunnel->getVirtualPeers(vpids);
|
{
|
||||||
|
/* Grab all online virtual peers of distant tunnels for the current
|
||||||
|
* service. */
|
||||||
|
|
||||||
for(auto it(vpids.begin());it!=vpids.end();++it)
|
std::list<RsGxsNetTunnelVirtualPeerId> vpids ;
|
||||||
peers.insert(RsPeerId(*it)) ;
|
mGxsNetTunnel->getVirtualPeers(vpids);
|
||||||
|
|
||||||
|
for(auto it(vpids.begin());it!=vpids.end();++it)
|
||||||
|
peers.insert(RsPeerId(*it)) ;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (peers.empty()) {
|
// Still empty? Reports there are no available peers
|
||||||
// nothing to do
|
if (peers.empty()) return std::errc::network_down;
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
RS_STACK_MUTEX(mNxsMutex);
|
||||||
|
|
||||||
// for now just grps
|
// for now just grps
|
||||||
for(auto sit = peers.begin(); sit != peers.end(); ++sit)
|
for(auto sit = peers.begin(); sit != peers.end(); ++sit)
|
||||||
{
|
{
|
||||||
|
|
||||||
const RsPeerId peerId = *sit;
|
const RsPeerId peerId = *sit;
|
||||||
|
|
||||||
ClientGrpMap::const_iterator cit = mClientGrpUpdateMap.find(peerId);
|
ClientGrpMap::const_iterator cit = mClientGrpUpdateMap.find(peerId);
|
||||||
@ -624,8 +625,7 @@ void RsGxsNetService::syncWithPeers()
|
|||||||
generic_sendItem(grp);
|
generic_sendItem(grp);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!mAllowMsgSync)
|
if(!mAllowMsgSync) return std::error_condition();
|
||||||
return ;
|
|
||||||
|
|
||||||
#ifndef GXS_DISABLE_SYNC_MSGS
|
#ifndef GXS_DISABLE_SYNC_MSGS
|
||||||
|
|
||||||
@ -743,10 +743,12 @@ void RsGxsNetService::syncWithPeers()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif // ndef GXS_DISABLE_SYNC_MSGS
|
||||||
|
|
||||||
|
return std::error_condition();
|
||||||
}
|
}
|
||||||
|
|
||||||
void RsGxsNetService::generic_sendItem(RsNxsItem *si)
|
void RsGxsNetService::generic_sendItem(rs_owner_ptr<RsItem> si)
|
||||||
{
|
{
|
||||||
// check if the item is to be sent to a distant peer or not
|
// check if the item is to be sent to a distant peer or not
|
||||||
|
|
||||||
@ -1022,32 +1024,32 @@ void RsGxsNetService::locked_resetClientTS(const RsGxsGroupId& grpId)
|
|||||||
it->second.msgUpdateInfos.erase(grpId) ;
|
it->second.msgUpdateInfos.erase(grpId) ;
|
||||||
}
|
}
|
||||||
|
|
||||||
void RsGxsNetService::subscribeStatusChanged(const RsGxsGroupId& grpId,bool subscribed)
|
void RsGxsNetService::subscribeStatusChanged(
|
||||||
|
const RsGxsGroupId& grpId, bool subscribed )
|
||||||
{
|
{
|
||||||
RS_STACK_MUTEX(mNxsMutex) ;
|
if(!subscribed) return;
|
||||||
|
|
||||||
if(!subscribed)
|
|
||||||
return ;
|
|
||||||
|
|
||||||
// When we subscribe, we reset the time stamps, so that the entire group list
|
// When we subscribe, we reset the time stamps, so that the entire group list
|
||||||
// gets requested once again, for a proper update.
|
// gets requested once again, for a proper update.
|
||||||
|
|
||||||
|
RS_STACK_MUTEX(mNxsMutex);
|
||||||
|
|
||||||
#ifdef NXS_NET_DEBUG_0
|
#ifdef NXS_NET_DEBUG_0
|
||||||
GXSNETDEBUG__G(grpId) << "Changing subscribe status for grp " << grpId << " to " << subscribed << ": reseting all server msg time stamps for this group, and server global TS." << std::endl;
|
RS_DBG( "Changing subscribe status for grp", grpId, " to ", subscribed,
|
||||||
std::map<RsGxsGroupId,RsGxsServerMsgUpdate>::iterator it = mServerMsgUpdateMap.find(grpId) ;
|
": reseting all server msg time stamps for this group, and "
|
||||||
|
"server global TS." );
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
RsGxsServerMsgUpdate& item(mServerMsgUpdateMap[grpId]) ;
|
RsGxsServerMsgUpdate& item(mServerMsgUpdateMap[grpId]);
|
||||||
|
item.msgUpdateTS = static_cast<uint32_t>(time(nullptr));
|
||||||
|
|
||||||
item.msgUpdateTS = time(NULL) ;
|
/* We also update mGrpServerUpdateItem so as to trigger a new grp list
|
||||||
|
* exchange with friends (friends will send their known ClientTS which
|
||||||
|
* will be lower than our own grpUpdateTS, triggering our sending of the
|
||||||
|
* new subscribed grp list. */
|
||||||
|
mGrpServerUpdate.grpUpdateTS = static_cast<uint32_t>(time(nullptr));
|
||||||
|
|
||||||
// We also update mGrpServerUpdateItem so as to trigger a new grp list exchange with friends (friends will send their known ClientTS which
|
locked_resetClientTS(grpId);
|
||||||
// will be lower than our own grpUpdateTS, triggering our sending of the new subscribed grp list.
|
|
||||||
|
|
||||||
mGrpServerUpdate.grpUpdateTS = time(NULL) ;
|
|
||||||
|
|
||||||
if(subscribed)
|
|
||||||
locked_resetClientTS(grpId) ;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool RsGxsNetService::fragmentMsg(RsNxsMsg& msg, MsgFragments& msgFragments) const
|
bool RsGxsNetService::fragmentMsg(RsNxsMsg& msg, MsgFragments& msgFragments) const
|
||||||
@ -1718,13 +1720,25 @@ RsItem *RsGxsNetService::generic_recvItem()
|
|||||||
|
|
||||||
void RsGxsNetService::recvNxsItemQueue()
|
void RsGxsNetService::recvNxsItemQueue()
|
||||||
{
|
{
|
||||||
RsItem *item ;
|
RsItem* item;
|
||||||
|
|
||||||
while(NULL != (item=generic_recvItem()))
|
while(nullptr != (item=generic_recvItem()))
|
||||||
{
|
{
|
||||||
#ifdef NXS_NET_DEBUG_1
|
#ifdef NXS_NET_DEBUG_1
|
||||||
GXSNETDEBUG_P_(item->PeerId()) << "Received RsGxsNetService Item:" << (void*)item << " type=" << std::hex << item->PacketId() << std::dec << std::endl ;
|
RS_DBG( "Received RsGxsNetService Item: ", (void*)item, " type=",
|
||||||
|
item->PacketId() );
|
||||||
#endif
|
#endif
|
||||||
|
/* Handle pull request and other new items here to not mess with all the
|
||||||
|
* old nested code and items hell */
|
||||||
|
switch(static_cast<RsNxsSubtype>(item->PacketSubType()))
|
||||||
|
{
|
||||||
|
case RsNxsSubtype::PULL_REQUEST:
|
||||||
|
std::unique_ptr<RsNxsPullRequestItem> pullItem(
|
||||||
|
static_cast<RsNxsPullRequestItem*>(item) );
|
||||||
|
handlePullRequest(std::move(pullItem));
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
// RsNxsItem needs dynamic_cast, since they have derived siblings.
|
// RsNxsItem needs dynamic_cast, since they have derived siblings.
|
||||||
//
|
//
|
||||||
RsNxsItem *ni = dynamic_cast<RsNxsItem*>(item) ;
|
RsNxsItem *ni = dynamic_cast<RsNxsItem*>(item) ;
|
||||||
@ -5075,6 +5089,46 @@ void RsGxsNetService::handleRecvPublishKeys(RsNxsGroupPublishKeyItem *item)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
std::error_condition RsGxsNetService::requestPull(std::set<RsPeerId> peers)
|
||||||
|
{
|
||||||
|
/* If specific peers are passed as paramether ask only to them */
|
||||||
|
if(peers.empty())
|
||||||
|
{
|
||||||
|
mNetMgr->getOnlineList(mServiceInfo.mServiceType, peers);
|
||||||
|
|
||||||
|
if(mAllowDistSync && mGxsNetTunnel != nullptr)
|
||||||
|
{
|
||||||
|
/* Grab all online virtual peers of distant tunnels for the current
|
||||||
|
* service. */
|
||||||
|
|
||||||
|
std::list<RsGxsNetTunnelVirtualPeerId> vpids ;
|
||||||
|
mGxsNetTunnel->getVirtualPeers(vpids);
|
||||||
|
|
||||||
|
for(auto it(vpids.begin());it!=vpids.end();++it)
|
||||||
|
peers.insert(RsPeerId(*it)) ;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Still empty? Reports there are no available peers
|
||||||
|
if (peers.empty()) return std::errc::network_down;
|
||||||
|
|
||||||
|
for(auto& peerId: std::as_const(peers))
|
||||||
|
{
|
||||||
|
auto item = new RsNxsPullRequestItem(
|
||||||
|
static_cast<RsServiceType>(mServType) );
|
||||||
|
item->PeerId(peerId);
|
||||||
|
generic_sendItem(item);
|
||||||
|
}
|
||||||
|
|
||||||
|
return std::error_condition();
|
||||||
|
}
|
||||||
|
|
||||||
|
void RsGxsNetService::handlePullRequest(
|
||||||
|
std::unique_ptr<RsNxsPullRequestItem> item )
|
||||||
|
{
|
||||||
|
checkUpdatesFromPeers(std::set<RsPeerId>{item->PeerId()});
|
||||||
|
}
|
||||||
|
|
||||||
bool RsGxsNetService::getGroupServerUpdateTS(const RsGxsGroupId& gid,rstime_t& group_server_update_TS, rstime_t& msg_server_update_TS)
|
bool RsGxsNetService::getGroupServerUpdateTS(const RsGxsGroupId& gid,rstime_t& group_server_update_TS, rstime_t& msg_server_update_TS)
|
||||||
{
|
{
|
||||||
RS_STACK_MUTEX(mNxsMutex) ;
|
RS_STACK_MUTEX(mNxsMutex) ;
|
||||||
|
@ -250,6 +250,15 @@ public:
|
|||||||
|
|
||||||
void threadTick() override; /// @see RsTickingThread
|
void threadTick() override; /// @see RsTickingThread
|
||||||
|
|
||||||
|
|
||||||
|
/// @see RsNetworkExchangeService
|
||||||
|
std::error_condition checkUpdatesFromPeers(
|
||||||
|
std::set<RsPeerId> peers = std::set<RsPeerId>() ) override;
|
||||||
|
|
||||||
|
/// @see RsNetworkExchangeService
|
||||||
|
std::error_condition requestPull(
|
||||||
|
std::set<RsPeerId> peers = std::set<RsPeerId>() ) override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
@ -423,6 +432,8 @@ private:
|
|||||||
*/
|
*/
|
||||||
void handleRecvPublishKeys(RsNxsGroupPublishKeyItem*) ;
|
void handleRecvPublishKeys(RsNxsGroupPublishKeyItem*) ;
|
||||||
|
|
||||||
|
void handlePullRequest(std::unique_ptr<RsNxsPullRequestItem> item);
|
||||||
|
|
||||||
/** E: item handlers **/
|
/** E: item handlers **/
|
||||||
|
|
||||||
|
|
||||||
@ -459,7 +470,7 @@ private:
|
|||||||
void locked_pushMsgRespFromList(std::list<RsNxsItem*>& itemL, const RsPeerId& sslId, const RsGxsGroupId &grp_id, const uint32_t& transN);
|
void locked_pushMsgRespFromList(std::list<RsNxsItem*>& itemL, const RsPeerId& sslId, const RsGxsGroupId &grp_id, const uint32_t& transN);
|
||||||
|
|
||||||
void checkDistantSyncState();
|
void checkDistantSyncState();
|
||||||
void syncWithPeers();
|
|
||||||
void syncGrpStatistics();
|
void syncGrpStatistics();
|
||||||
void addGroupItemToList(NxsTransaction*& tr,
|
void addGroupItemToList(NxsTransaction*& tr,
|
||||||
const RsGxsGroupId& grpId, uint32_t& transN,
|
const RsGxsGroupId& grpId, uint32_t& transN,
|
||||||
@ -559,7 +570,7 @@ private:
|
|||||||
void cleanRejectedMessages();
|
void cleanRejectedMessages();
|
||||||
void processObserverNotifications();
|
void processObserverNotifications();
|
||||||
|
|
||||||
void generic_sendItem(RsNxsItem *si);
|
void generic_sendItem(rs_owner_ptr<RsItem> si);
|
||||||
RsItem *generic_recvItem();
|
RsItem *generic_recvItem();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
@ -26,7 +26,7 @@
|
|||||||
|
|
||||||
#include <set>
|
#include <set>
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <stdlib.h>
|
#include <cstdlib>
|
||||||
#include <list>
|
#include <list>
|
||||||
#include <map>
|
#include <map>
|
||||||
|
|
||||||
@ -325,4 +325,20 @@ public:
|
|||||||
return RsReputationLevel::NEUTRAL;
|
return RsReputationLevel::NEUTRAL;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Check if new stuff is available from peers
|
||||||
|
* @param peers peers to check, if empty all available peers are checked
|
||||||
|
*/
|
||||||
|
virtual std::error_condition checkUpdatesFromPeers(
|
||||||
|
std::set<RsPeerId> peers = std::set<RsPeerId>() ) = 0;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief request online peers to pull updates from our node ASAP
|
||||||
|
* @param peers peers to which request pull from, if empty all available
|
||||||
|
* peers are requested to pull
|
||||||
|
* @return success or error details
|
||||||
|
*/
|
||||||
|
virtual std::error_condition requestPull(
|
||||||
|
std::set<RsPeerId> peers = std::set<RsPeerId>() ) = 0;
|
||||||
};
|
};
|
||||||
|
@ -507,7 +507,8 @@ HEADERS += util/folderiterator.h \
|
|||||||
util/cxx11retrocompat.h \
|
util/cxx11retrocompat.h \
|
||||||
util/cxx14retrocompat.h \
|
util/cxx14retrocompat.h \
|
||||||
util/cxx17retrocompat.h \
|
util/cxx17retrocompat.h \
|
||||||
util/rsurl.h
|
util/cxx23retrocompat.h \
|
||||||
|
util/rsurl.h
|
||||||
|
|
||||||
SOURCES += ft/ftchunkmap.cc \
|
SOURCES += ft/ftchunkmap.cc \
|
||||||
ft/ftcontroller.cc \
|
ft/ftcontroller.cc \
|
||||||
|
@ -450,6 +450,17 @@ public:
|
|||||||
const std::string& matchString,
|
const std::string& matchString,
|
||||||
std::vector<RsGxsSearchResult>& searchResults ) = 0;
|
std::vector<RsGxsSearchResult>& searchResults ) = 0;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Request Synchronization with available peers
|
||||||
|
* Usually syncronization already happen automatically so be carefull
|
||||||
|
* to call this method only if necessary.
|
||||||
|
* It has been thinked for use cases like mobile phone where internet
|
||||||
|
* connection is intermittent and calling this may be useful when a system
|
||||||
|
* event about connection being available or about to go offline is received
|
||||||
|
* @jsonapi{development}
|
||||||
|
* @return Success or error details
|
||||||
|
*/
|
||||||
|
virtual std::error_condition requestSynchronization() = 0;
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////////////
|
||||||
/* Following functions are deprecated and should not be considered a stable
|
/* Following functions are deprecated and should not be considered a stable
|
||||||
|
@ -3,7 +3,9 @@
|
|||||||
* *
|
* *
|
||||||
* libretroshare: retroshare core library *
|
* libretroshare: retroshare core library *
|
||||||
* *
|
* *
|
||||||
* Copyright 2011-2011 by Cyril Soler <csoler@users.sourceforge.net> *
|
* Copyright (C) 2011-2018 Cyril Soler <csoler@users.sourceforge.net> *
|
||||||
|
* Copyright (C) 2021 Gioacchino Mazzurco <gio@eigenlab.org> *
|
||||||
|
* Copyright (C) 2021 Asociación Civil Altermundi <info@altermundi.net> *
|
||||||
* *
|
* *
|
||||||
* This program is free software: you can redistribute it and/or modify *
|
* This program is free software: you can redistribute it and/or modify *
|
||||||
* it under the terms of the GNU Lesser General Public License as *
|
* it under the terms of the GNU Lesser General Public License as *
|
||||||
@ -21,7 +23,9 @@
|
|||||||
*******************************************************************************/
|
*******************************************************************************/
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include <stdint.h>
|
#include <cstdint>
|
||||||
|
|
||||||
|
using RsItemPriority = uint8_t;
|
||||||
|
|
||||||
// This file centralises QoS priorities for all transfer RsItems
|
// This file centralises QoS priorities for all transfer RsItems
|
||||||
//
|
//
|
||||||
|
@ -3,7 +3,8 @@
|
|||||||
* *
|
* *
|
||||||
* libretroshare: retroshare core library *
|
* libretroshare: retroshare core library *
|
||||||
* *
|
* *
|
||||||
* Copyright (C) 2018 Gioacchino Mazzurco <gio@eigenlab.org> *
|
* Copyright (C) 2018-2021 Gioacchino Mazzurco <gio@eigenlab.org> *
|
||||||
|
* Copyright (C) 2021 Asociación Civil Altermundi <info@altermundi.net> *
|
||||||
* *
|
* *
|
||||||
* This program is free software: you can redistribute it and/or modify *
|
* This program is free software: you can redistribute it and/or modify *
|
||||||
* it under the terms of the GNU Lesser General Public License as *
|
* it under the terms of the GNU Lesser General Public License as *
|
||||||
@ -28,6 +29,9 @@
|
|||||||
#include "serialiser/rsserializer.h"
|
#include "serialiser/rsserializer.h"
|
||||||
#include "serialiser/rsserializable.h"
|
#include "serialiser/rsserializable.h"
|
||||||
#include "util/stacktrace.h"
|
#include "util/stacktrace.h"
|
||||||
|
#include "rsitems/itempriorities.h"
|
||||||
|
#include "rsitems/rsserviceids.h"
|
||||||
|
|
||||||
|
|
||||||
#include <typeinfo>
|
#include <typeinfo>
|
||||||
|
|
||||||
@ -42,8 +46,13 @@ struct RsItem : RsMemoryManagement::SmallObject, RsSerializable
|
|||||||
|
|
||||||
virtual ~RsItem();
|
virtual ~RsItem();
|
||||||
|
|
||||||
/// TODO: Do this make sense with the new serialization system?
|
/** TODO: Does the existence of this method make sense with the new
|
||||||
virtual void clear() = 0;
|
* serialization system? **/
|
||||||
|
virtual void clear()
|
||||||
|
{
|
||||||
|
RS_ERR("Called without being overridden, report to developers");
|
||||||
|
print_stacktrace();
|
||||||
|
}
|
||||||
|
|
||||||
/// @deprecated use << ostream operator instead
|
/// @deprecated use << ostream operator instead
|
||||||
RS_DEPRECATED_FOR("<< ostream operator")
|
RS_DEPRECATED_FOR("<< ostream operator")
|
||||||
@ -70,14 +79,21 @@ struct RsItem : RsMemoryManagement::SmallObject, RsSerializable
|
|||||||
uint8_t PacketType();
|
uint8_t PacketType();
|
||||||
uint8_t PacketSubType() const;
|
uint8_t PacketSubType() const;
|
||||||
|
|
||||||
|
/** For Service Packets, @deprecated use the costructor with priority
|
||||||
|
* paramether instead */
|
||||||
|
RS_DEPRECATED RsItem(uint8_t ver, uint16_t service, uint8_t subtype);
|
||||||
|
|
||||||
/// For Service Packets
|
/// For Service Packets
|
||||||
RsItem(uint8_t ver, uint16_t service, uint8_t subtype);
|
RsItem( uint8_t ver, RsServiceType service, uint8_t subtype,
|
||||||
|
RsItemPriority prio );
|
||||||
|
|
||||||
uint16_t PacketService() const; /* combined Packet class/type (mid 16bits) */
|
uint16_t PacketService() const; /* combined Packet class/type (mid 16bits) */
|
||||||
void setPacketService(uint16_t service);
|
void setPacketService(uint16_t service);
|
||||||
|
|
||||||
inline uint8_t priority_level() const { return _priority_level ;}
|
inline uint8_t priority_level() const { return _priority_level ;}
|
||||||
inline void setPriorityLevel(uint8_t l) { _priority_level = l ;}
|
inline void setPriorityLevel(uint8_t l) { _priority_level = l ;}
|
||||||
|
|
||||||
|
#ifdef RS_DEAD_CODE
|
||||||
/*
|
/*
|
||||||
* TODO: This default implementation should be removed and childs structs
|
* TODO: This default implementation should be removed and childs structs
|
||||||
* implement ::serial_process(...) as soon as all the codebase is ported to
|
* implement ::serial_process(...) as soon as all the codebase is ported to
|
||||||
@ -90,11 +106,12 @@ struct RsItem : RsMemoryManagement::SmallObject, RsSerializable
|
|||||||
"overriding Class is: ", typeid(*this).name() );
|
"overriding Class is: ", typeid(*this).name() );
|
||||||
print_stacktrace();
|
print_stacktrace();
|
||||||
}
|
}
|
||||||
|
#endif //def RS_DEAD_CODE
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
uint32_t type;
|
uint32_t type;
|
||||||
RsPeerId peerId;
|
RsPeerId peerId;
|
||||||
uint8_t _priority_level;
|
RsItemPriority _priority_level;
|
||||||
};
|
};
|
||||||
|
|
||||||
/// TODO: Do this make sense with the new serialization system?
|
/// TODO: Do this make sense with the new serialization system?
|
||||||
@ -108,9 +125,17 @@ public:
|
|||||||
uint32_t getRawLength() { return len; }
|
uint32_t getRawLength() { return len; }
|
||||||
void * getRawData() { return data; }
|
void * getRawData() { return data; }
|
||||||
|
|
||||||
virtual void clear() {}
|
// virtual void clear() override {}
|
||||||
virtual std::ostream &print(std::ostream &out, uint16_t indent = 0);
|
virtual std::ostream &print(std::ostream &out, uint16_t indent = 0);
|
||||||
|
|
||||||
|
virtual void serial_process(RsGenericSerializer::SerializeJob,
|
||||||
|
RsGenericSerializer::SerializeContext&) override
|
||||||
|
{
|
||||||
|
RS_ERR( "called by an item using new serialization system ",
|
||||||
|
typeid(*this).name() );
|
||||||
|
print_stacktrace();
|
||||||
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void *data;
|
void *data;
|
||||||
uint32_t len;
|
uint32_t len;
|
||||||
|
@ -64,6 +64,12 @@ RsItem *RsNxsSerialiser::create_item(uint16_t service_id,uint8_t item_subtype) c
|
|||||||
if(service_id != SERVICE_TYPE)
|
if(service_id != SERVICE_TYPE)
|
||||||
return NULL ;
|
return NULL ;
|
||||||
|
|
||||||
|
switch(static_cast<RsNxsSubtype>(item_subtype))
|
||||||
|
{
|
||||||
|
case RsNxsSubtype::PULL_REQUEST:
|
||||||
|
return new RsNxsPullRequestItem(static_cast<RsServiceType>(service_id));
|
||||||
|
}
|
||||||
|
|
||||||
switch(item_subtype)
|
switch(item_subtype)
|
||||||
{
|
{
|
||||||
case RS_PKT_SUBTYPE_NXS_SYNC_GRP_REQ_ITEM: return new RsNxsSyncGrpReqItem(SERVICE_TYPE) ;
|
case RS_PKT_SUBTYPE_NXS_SYNC_GRP_REQ_ITEM: return new RsNxsSyncGrpReqItem(SERVICE_TYPE) ;
|
||||||
|
@ -3,7 +3,10 @@
|
|||||||
* *
|
* *
|
||||||
* libretroshare: retroshare core library *
|
* libretroshare: retroshare core library *
|
||||||
* *
|
* *
|
||||||
* Copyright 2012 Christopher Evi-Parker,Robert Fernie<retroshare@lunamutt.com>*
|
* Copyright (C) 2012 Christopher Evi-Parker *
|
||||||
|
* Copyright (C) 2012 Robert Fernie <retroshare@lunamutt.com> *
|
||||||
|
* Copyright (C) 2021 Gioacchino Mazzurco <gio@altermundi.net> *
|
||||||
|
* Copyright (C) 2021 Asociación Civil Altermundi <info@altermundi.net> *
|
||||||
* *
|
* *
|
||||||
* This program is free software: you can redistribute it and/or modify *
|
* This program is free software: you can redistribute it and/or modify *
|
||||||
* it under the terms of the GNU Lesser General Public License as *
|
* it under the terms of the GNU Lesser General Public License as *
|
||||||
@ -19,8 +22,7 @@
|
|||||||
* along with this program. If not, see <https://www.gnu.org/licenses/>. *
|
* along with this program. If not, see <https://www.gnu.org/licenses/>. *
|
||||||
* *
|
* *
|
||||||
*******************************************************************************/
|
*******************************************************************************/
|
||||||
#ifndef RSNXSITEMS_H
|
#pragma once
|
||||||
#define RSNXSITEMS_H
|
|
||||||
|
|
||||||
#include <map>
|
#include <map>
|
||||||
#include <openssl/ssl.h>
|
#include <openssl/ssl.h>
|
||||||
@ -33,8 +35,13 @@
|
|||||||
#include "serialiser/rstlvkeys.h"
|
#include "serialiser/rstlvkeys.h"
|
||||||
#include "gxs/rsgxsdata.h"
|
#include "gxs/rsgxsdata.h"
|
||||||
|
|
||||||
// These items have "flag type" numbers, but this is not used.
|
enum class RsNxsSubtype : uint8_t
|
||||||
|
{
|
||||||
|
PULL_REQUEST = 0x90 /// @see RsNxsPullRequestItem
|
||||||
|
};
|
||||||
|
|
||||||
|
// These items have "flag type" numbers, but this is not used.
|
||||||
|
// TODO: refactor as C++11 enum class
|
||||||
const uint8_t RS_PKT_SUBTYPE_NXS_SYNC_GRP_REQ_ITEM = 0x01;
|
const uint8_t RS_PKT_SUBTYPE_NXS_SYNC_GRP_REQ_ITEM = 0x01;
|
||||||
const uint8_t RS_PKT_SUBTYPE_NXS_SYNC_GRP_ITEM = 0x02;
|
const uint8_t RS_PKT_SUBTYPE_NXS_SYNC_GRP_ITEM = 0x02;
|
||||||
const uint8_t RS_PKT_SUBTYPE_NXS_SYNC_GRP_STATS_ITEM = 0x03;
|
const uint8_t RS_PKT_SUBTYPE_NXS_SYNC_GRP_STATS_ITEM = 0x03;
|
||||||
@ -47,14 +54,15 @@ const uint8_t RS_PKT_SUBTYPE_NXS_MSG_ITEM = 0x20;
|
|||||||
const uint8_t RS_PKT_SUBTYPE_NXS_TRANSAC_ITEM = 0x40;
|
const uint8_t RS_PKT_SUBTYPE_NXS_TRANSAC_ITEM = 0x40;
|
||||||
const uint8_t RS_PKT_SUBTYPE_NXS_GRP_PUBLISH_KEY_ITEM = 0x80;
|
const uint8_t RS_PKT_SUBTYPE_NXS_GRP_PUBLISH_KEY_ITEM = 0x80;
|
||||||
|
|
||||||
// possibility create second service to deal with this functionality
|
|
||||||
|
|
||||||
|
#ifdef RS_DEAD_CODE
|
||||||
|
// possibility create second service to deal with this functionality
|
||||||
const uint8_t RS_PKT_SUBTYPE_EXT_SEARCH_GRP = 0x0001;
|
const uint8_t RS_PKT_SUBTYPE_EXT_SEARCH_GRP = 0x0001;
|
||||||
const uint8_t RS_PKT_SUBTYPE_EXT_SEARCH_MSG = 0x0002;
|
const uint8_t RS_PKT_SUBTYPE_EXT_SEARCH_MSG = 0x0002;
|
||||||
const uint8_t RS_PKT_SUBTYPE_EXT_DELETE_GRP = 0x0004;
|
const uint8_t RS_PKT_SUBTYPE_EXT_DELETE_GRP = 0x0004;
|
||||||
const uint8_t RS_PKT_SUBTYPE_EXT_DELETE_MSG = 0x0008;
|
const uint8_t RS_PKT_SUBTYPE_EXT_DELETE_MSG = 0x0008;
|
||||||
const uint8_t RS_PKT_SUBTYPE_EXT_SEARCH_REQ = 0x0010;
|
const uint8_t RS_PKT_SUBTYPE_EXT_SEARCH_REQ = 0x0010;
|
||||||
|
#endif // def RS_DEAD_CODE
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* Base class for Network exchange service
|
* Base class for Network exchange service
|
||||||
@ -65,17 +73,14 @@ const uint8_t RS_PKT_SUBTYPE_EXT_SEARCH_REQ = 0x0010;
|
|||||||
*/
|
*/
|
||||||
class RsNxsItem : public RsItem
|
class RsNxsItem : public RsItem
|
||||||
{
|
{
|
||||||
|
|
||||||
public:
|
public:
|
||||||
RsNxsItem(uint16_t servtype, uint8_t subtype) : RsItem(RS_PKT_VERSION_SERVICE, servtype, subtype), transactionNumber(0)
|
RsNxsItem(uint16_t servtype, uint8_t subtype):
|
||||||
{
|
RsItem(RS_PKT_VERSION_SERVICE, servtype, subtype), transactionNumber(0)
|
||||||
setPriorityLevel(QOS_PRIORITY_RS_GXS_NET);
|
{ setPriorityLevel(QOS_PRIORITY_RS_GXS_NET); }
|
||||||
return;
|
|
||||||
}
|
|
||||||
virtual ~RsNxsItem(){}
|
|
||||||
virtual void clear() = 0;
|
|
||||||
|
|
||||||
uint32_t transactionNumber; // set to zero if this is not a transaction item
|
virtual ~RsNxsItem() = default;
|
||||||
|
|
||||||
|
uint32_t transactionNumber; // set to zero if this is not a transaction item
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
@ -362,6 +367,22 @@ public:
|
|||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* Used to request to a peer pull updates from us ASAP without waiting GXS sync
|
||||||
|
* timer */
|
||||||
|
struct RsNxsPullRequestItem: RsItem
|
||||||
|
{
|
||||||
|
explicit RsNxsPullRequestItem(RsServiceType servtype):
|
||||||
|
RsItem( RS_PKT_VERSION_SERVICE,
|
||||||
|
servtype,
|
||||||
|
static_cast<uint8_t>(RsNxsSubtype::PULL_REQUEST),
|
||||||
|
QOS_PRIORITY_RS_GXS_NET ) {}
|
||||||
|
|
||||||
|
/// @see RsSerializable
|
||||||
|
void serial_process( RsGenericSerializer::SerializeJob,
|
||||||
|
RsGenericSerializer::SerializeContext& ) override {}
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* Used to respond to a RsGrpMsgsReq
|
* Used to respond to a RsGrpMsgsReq
|
||||||
@ -401,6 +422,7 @@ struct RsNxsMsg : RsNxsItem
|
|||||||
RsGxsMsgMetaData* metaData;
|
RsGxsMsgMetaData* metaData;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#ifdef RS_DEAD_CODE
|
||||||
/*!
|
/*!
|
||||||
* Used to request a search of user data
|
* Used to request a search of user data
|
||||||
*/
|
*/
|
||||||
@ -422,7 +444,7 @@ public:
|
|||||||
RsTlvBinaryData serviceSearchItem; // service aware of item class
|
RsTlvBinaryData serviceSearchItem; // service aware of item class
|
||||||
uint32_t expiration; // expiration date
|
uint32_t expiration; // expiration date
|
||||||
};
|
};
|
||||||
|
#endif //def RS_DEAD_CODE
|
||||||
|
|
||||||
#ifdef UNUSED_CODE
|
#ifdef UNUSED_CODE
|
||||||
|
|
||||||
@ -503,14 +525,12 @@ class RsNxsSerialiser : public RsServiceSerializer
|
|||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
|
||||||
explicit RsNxsSerialiser(uint16_t servtype) : RsServiceSerializer(servtype), SERVICE_TYPE(servtype) {}
|
explicit RsNxsSerialiser(uint16_t servtype):
|
||||||
virtual ~RsNxsSerialiser() {}
|
RsServiceSerializer(servtype), SERVICE_TYPE(servtype) {}
|
||||||
|
virtual ~RsNxsSerialiser() = default;
|
||||||
|
|
||||||
|
|
||||||
virtual RsItem *create_item(uint16_t service_id,uint8_t item_subtype) const ;
|
virtual RsItem *create_item(uint16_t service_id,uint8_t item_subtype) const ;
|
||||||
protected:
|
protected:
|
||||||
const uint16_t SERVICE_TYPE;
|
const uint16_t SERVICE_TYPE;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
#endif // RSNXSITEMS_H
|
|
||||||
|
@ -3,7 +3,9 @@
|
|||||||
* *
|
* *
|
||||||
* libretroshare: retroshare core library *
|
* libretroshare: retroshare core library *
|
||||||
* *
|
* *
|
||||||
* Copyright 2007-2008 by Robert Fernie <retroshare@lunamutt.com> *
|
* Copyright (C) 2007-2008 Robert Fernie <retroshare@lunamutt.com> *
|
||||||
|
* Copyright (C) 2021 Gioacchino Mazzurco <gio@eigenlab.org> *
|
||||||
|
* Copyright (C) 2021 Asociación Civil Altermundi <info@altermundi.net> *
|
||||||
* *
|
* *
|
||||||
* This program is free software: you can redistribute it and/or modify *
|
* This program is free software: you can redistribute it and/or modify *
|
||||||
* it under the terms of the GNU Lesser General Public License as *
|
* it under the terms of the GNU Lesser General Public License as *
|
||||||
@ -20,21 +22,20 @@
|
|||||||
* *
|
* *
|
||||||
*******************************************************************************/
|
*******************************************************************************/
|
||||||
|
|
||||||
#include "serialiser/rsbaseserial.h"
|
#include <cmath>
|
||||||
|
|
||||||
#include "util/rsthreads.h"
|
|
||||||
#include "util/rsstring.h"
|
|
||||||
#include "util/rsprint.h"
|
|
||||||
|
|
||||||
#include "rsitems/rsitem.h"
|
|
||||||
#include "rsitems/itempriorities.h"
|
|
||||||
|
|
||||||
#include <math.h>
|
|
||||||
#include <map>
|
#include <map>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
#include <typeinfo>
|
#include <typeinfo>
|
||||||
|
|
||||||
|
#include "serialiser/rsbaseserial.h"
|
||||||
|
#include "util/cxx23retrocompat.h"
|
||||||
|
#include "util/rsthreads.h"
|
||||||
|
#include "util/rsstring.h"
|
||||||
|
#include "util/rsprint.h"
|
||||||
|
#include "rsitems/rsitem.h"
|
||||||
|
#include "rsitems/itempriorities.h"
|
||||||
|
|
||||||
|
|
||||||
/***
|
/***
|
||||||
* #define RSSERIAL_DEBUG 1
|
* #define RSSERIAL_DEBUG 1
|
||||||
@ -166,11 +167,17 @@ uint8_t RsItem::PacketSubType() const
|
|||||||
/* For Service Packets */
|
/* For Service Packets */
|
||||||
RsItem::RsItem(uint8_t ver, uint16_t service, uint8_t subtype)
|
RsItem::RsItem(uint8_t ver, uint16_t service, uint8_t subtype)
|
||||||
{
|
{
|
||||||
_priority_level = QOS_PRIORITY_UNKNOWN ; // This value triggers PQIInterface to complain about undefined priorities
|
// This value triggers PQIInterface to complain about undefined priorities
|
||||||
|
_priority_level = QOS_PRIORITY_UNKNOWN;
|
||||||
type = (ver << 24) + (service << 8) + subtype;
|
type = (ver << 24) + (service << 8) + subtype;
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
RsItem::RsItem( uint8_t ver, RsServiceType service, uint8_t subtype,
|
||||||
|
RsItemPriority prio ):
|
||||||
|
type(static_cast<uint32_t>(
|
||||||
|
(ver << 24) + (std::to_underlying(service) << 8) + subtype )),
|
||||||
|
_priority_level(prio) {}
|
||||||
|
|
||||||
uint16_t RsItem::PacketService() const
|
uint16_t RsItem::PacketService() const
|
||||||
{
|
{
|
||||||
return (type >> 8) & 0xFFFF;
|
return (type >> 8) & 0xFFFF;
|
||||||
|
@ -900,10 +900,19 @@ bool p3GxsForums::markRead(const RsGxsGrpMsgIdPair& msgId, bool read)
|
|||||||
bool p3GxsForums::subscribeToForum(const RsGxsGroupId& groupId, bool subscribe )
|
bool p3GxsForums::subscribeToForum(const RsGxsGroupId& groupId, bool subscribe )
|
||||||
{
|
{
|
||||||
uint32_t token;
|
uint32_t token;
|
||||||
if( !RsGenExchange::subscribeToGroup(token, groupId, subscribe) || waitToken(token) != RsTokenService::COMPLETE ) return false;
|
if( !RsGenExchange::subscribeToGroup(token, groupId, subscribe) ||
|
||||||
|
waitToken(token) != RsTokenService::COMPLETE ) return false;
|
||||||
|
|
||||||
RsGxsGroupId grp;
|
RsGxsGroupId grp;
|
||||||
acknowledgeGrp(token,grp);
|
acknowledgeGrp(token, grp);
|
||||||
|
|
||||||
|
/* Since subscribe has been requested, the caller is most probably
|
||||||
|
* interested in getting the group messages ASAP so check updates from peers
|
||||||
|
* without waiting GXS sync timer.
|
||||||
|
* Do it here as this is meaningful or not depending on the service.
|
||||||
|
* Do it only after the token has been completed otherwise the pull have no
|
||||||
|
* effect. */
|
||||||
|
if(subscribe) RsGenExchange::netService()->checkUpdatesFromPeers();
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -1150,6 +1159,13 @@ std::error_condition p3GxsForums::setPostKeepForever(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
std::error_condition p3GxsForums::requestSynchronization()
|
||||||
|
{
|
||||||
|
auto errc = RsGenExchange::netService()->checkUpdatesFromPeers();
|
||||||
|
if(errc) return errc;
|
||||||
|
return RsGenExchange::netService()->requestPull();
|
||||||
|
}
|
||||||
|
|
||||||
/* so we need the same tick idea as wiki for generating dummy forums
|
/* so we need the same tick idea as wiki for generating dummy forums
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
@ -175,6 +175,8 @@ public:
|
|||||||
rs_owner_ptr<uint8_t>& resultData, uint32_t& resultSize ) override;
|
rs_owner_ptr<uint8_t>& resultData, uint32_t& resultSize ) override;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
std::error_condition requestSynchronization() override;
|
||||||
|
|
||||||
/// implementation of rsGxsGorums
|
/// implementation of rsGxsGorums
|
||||||
///
|
///
|
||||||
bool getGroupData(const uint32_t &token, std::vector<RsGxsForumGroup> &groups) override;
|
bool getGroupData(const uint32_t &token, std::vector<RsGxsForumGroup> &groups) override;
|
||||||
|
34
libretroshare/src/util/cxx23retrocompat.h
Normal file
34
libretroshare/src/util/cxx23retrocompat.h
Normal file
@ -0,0 +1,34 @@
|
|||||||
|
/*******************************************************************************
|
||||||
|
* RetroShare C++23 backwards compatibility utilities *
|
||||||
|
* *
|
||||||
|
* libretroshare: retroshare core library *
|
||||||
|
* *
|
||||||
|
* Copyright (C) 2021 Gioacchino Mazzurco <gio@eigenlab.org> *
|
||||||
|
* Copyright (C) 2021 Asociación Civil Altermundi <info@altermundi.net> *
|
||||||
|
* *
|
||||||
|
* This program is free software: you can redistribute it and/or modify *
|
||||||
|
* it under the terms of the GNU Lesser General Public License as *
|
||||||
|
* published by the Free Software Foundation, either version 3 of the *
|
||||||
|
* License, or (at your option) any later version. *
|
||||||
|
* *
|
||||||
|
* This program is distributed in the hope that it will be useful, *
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
|
||||||
|
* GNU Lesser General Public License for more details. *
|
||||||
|
* *
|
||||||
|
* You should have received a copy of the GNU Lesser General Public License *
|
||||||
|
* along with this program. If not, see <https://www.gnu.org/licenses/>. *
|
||||||
|
* *
|
||||||
|
*******************************************************************************/
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include <utility>
|
||||||
|
|
||||||
|
#if ! defined(__cpp_lib_to_underlying)
|
||||||
|
namespace std
|
||||||
|
{
|
||||||
|
template <class Enum>
|
||||||
|
constexpr underlying_type_t<Enum> to_underlying(Enum e) noexcept
|
||||||
|
{ return static_cast<std::underlying_type_t<Enum>>(e); }
|
||||||
|
}
|
||||||
|
#endif // ! defined(__cpp_lib_to_underlying)
|
Loading…
Reference in New Issue
Block a user