RsGxsNetService trigger pulling on group subscribe

This commit is contained in:
Gioacchino Mazzurco 2021-03-16 17:51:59 +01:00
parent 6295e91304
commit fc404bd5d8
No known key found for this signature in database
GPG Key ID: A1FBCA3872E87051
2 changed files with 28 additions and 19 deletions

View File

@ -1021,31 +1021,31 @@ 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
// 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); locked_resetClientTS(grpId);
} }

View File

@ -900,11 +900,20 @@ 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 pull 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()->pullFromPeers();
return true; return true;
} }