summaryrefslogtreecommitdiff
path: root/protocols/JabberG/src/jabber_voip.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'protocols/JabberG/src/jabber_voip.cpp')
-rw-r--r--protocols/JabberG/src/jabber_voip.cpp12
1 files changed, 11 insertions, 1 deletions
diff --git a/protocols/JabberG/src/jabber_voip.cpp b/protocols/JabberG/src/jabber_voip.cpp
index a982f86066..2262466334 100644
--- a/protocols/JabberG/src/jabber_voip.cpp
+++ b/protocols/JabberG/src/jabber_voip.cpp
@@ -348,7 +348,7 @@ err:
return FALSE;
}
-bool CJabberProto::VOIPTerminateSession()
+bool CJabberProto::VOIPTerminateSession(const char *reason)
{
if (m_pipe1) {
gst_element_set_state(GST_ELEMENT(m_pipe1), GST_STATE_NULL);
@@ -357,6 +357,16 @@ bool CJabberProto::VOIPTerminateSession()
gst_print("Pipeline stopped\n");
}
+ if (reason && !m_voipSession.IsEmpty() && !m_voipPeerJid.IsEmpty()) {
+ XmlNodeIq iq("set", SerialNext(), m_voipPeerJid);
+ TiXmlElement *jingleNode = iq << XCHILDNS("jingle", JABBER_FEAT_JINGLE);
+ jingleNode << XATTR("action", "session-terminate") << XATTR("sid", m_voipSession);
+ jingleNode << XATTR("initiator", m_isOutgoing ? m_ThreadInfo->fullJID : m_voipPeerJid);
+ jingleNode << XCHILD("reason") << XCHILD(reason);
+
+ m_ThreadInfo->send(iq);
+ }
+
m_voipICEPwd.Empty();
m_voipICEUfrag.Empty();
m_medianame.Empty();