summaryrefslogtreecommitdiff
path: root/protocols/JabberG/src/jabber_thread.cpp
diff options
context:
space:
mode:
authorGluzskiy Alexandr <sss@sss.chaoslab.ru>2018-04-17 03:26:20 +0300
committerGluzskiy Alexandr <sss@sss.chaoslab.ru>2018-04-17 03:27:58 +0300
commitc13df8fa3e1f60b059cecf3f3d6c825b7e86ac16 (patch)
tree9b28d02fdc656a2a9cd26c2e03b3445857d8ebcb /protocols/JabberG/src/jabber_thread.cpp
parent2690a321eaee7586154083cb2cd0d711ab35c041 (diff)
protocols: jabber: xep-0198:
- improoved logic - fixed resumption - added few temporary workarounds for broken counters
Diffstat (limited to 'protocols/JabberG/src/jabber_thread.cpp')
-rwxr-xr-xprotocols/JabberG/src/jabber_thread.cpp35
1 files changed, 18 insertions, 17 deletions
diff --git a/protocols/JabberG/src/jabber_thread.cpp b/protocols/JabberG/src/jabber_thread.cpp
index c032af1727..653e8af1bb 100755
--- a/protocols/JabberG/src/jabber_thread.cpp
+++ b/protocols/JabberG/src/jabber_thread.cpp
@@ -760,27 +760,26 @@ void CJabberProto::OnProcessFeatures(HXML node, ThreadData *info)
return;
}
- if (m_bEnableStreamMgmt) //resume should be done here
+ if (m_bEnableStreamMgmt && m_StrmMgmt.IsResumeIdPresent()) //resume should be done here
+ m_StrmMgmt.CheckState();
+ else
{
- if (m_StrmMgmt.IsResumeIdPresent())
- m_StrmMgmt.CheckState();
- }
-
- // mechanisms are not defined.
- if (info->auth) { //We are already logged-in
- info->send(
- XmlNodeIq(AddIQ(&CJabberProto::OnIqResultBind, JABBER_IQ_TYPE_SET))
+ // mechanisms are not defined.
+ if (info->auth) { //We are already logged-in
+ info->send(
+ XmlNodeIq(AddIQ(&CJabberProto::OnIqResultBind, JABBER_IQ_TYPE_SET))
<< XCHILDNS(L"bind", L"urn:ietf:params:xml:ns:xmpp-bind")
<< XCHILD(L"resource", info->resource));
- if (m_AuthMechs.isSessionAvailable)
- info->bIsSessionAvailable = TRUE;
+ if (m_AuthMechs.isSessionAvailable)
+ info->bIsSessionAvailable = TRUE;
- return;
- }
+ return;
+ }
- //mechanisms not available and we are not logged in
- PerformIqAuth(info);
+ //mechanisms not available and we are not logged in
+ PerformIqAuth(info);
+ }
}
void CJabberProto::OnProcessFailure(HXML node, ThreadData *info)
@@ -2132,11 +2131,13 @@ int ThreadData::send(HXML node)
while (HXML parent = xmlGetParent(node))
node = parent;
- int result = send_no_strm_mgmt(node);
-
if (proto->m_bEnableStreamMgmt)
proto->m_StrmMgmt.HandleOutgoingNode(node); //TODO: is this a correct place ?, looks like some nodes does not goes here...
+
+ int result = send_no_strm_mgmt(node);
+
+
return result;
}