mirror of
https://github.com/asterisk/asterisk.git
synced 2025-11-08 19:08:14 +00:00
Automatically create new buddy upon reception of a presence stanza of
type subscribed. (closes issue #12066) Reported by: ffadaie Patches: branch-1.4-12066-1.diff uploaded by phsultan (license 73) trunk-12066-1.diff uploaded by phsultan (license 73) Tested by: ffadaie, phsultan git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@105210 65c4cc65-6c06-0410-ace0-fbb531ad65f3
This commit is contained in:
@@ -1723,8 +1723,11 @@ static void aji_handle_presence(struct aji_client *client, ikspak *pak)
|
|||||||
*/
|
*/
|
||||||
static void aji_handle_subscribe(struct aji_client *client, ikspak *pak)
|
static void aji_handle_subscribe(struct aji_client *client, ikspak *pak)
|
||||||
{
|
{
|
||||||
if (pak->subtype == IKS_TYPE_SUBSCRIBE) {
|
iks *presence = NULL, *status = NULL;
|
||||||
iks *presence = NULL, *status = NULL;
|
struct aji_buddy* buddy = NULL;
|
||||||
|
|
||||||
|
switch (pak->subtype) {
|
||||||
|
case IKS_TYPE_SUBSCRIBE:
|
||||||
presence = iks_new("presence");
|
presence = iks_new("presence");
|
||||||
status = iks_new("status");
|
status = iks_new("status");
|
||||||
if (presence && status) {
|
if (presence && status) {
|
||||||
@@ -1744,24 +1747,15 @@ static void aji_handle_subscribe(struct aji_client *client, ikspak *pak)
|
|||||||
iks_delete(status);
|
iks_delete(status);
|
||||||
if (client->component)
|
if (client->component)
|
||||||
aji_set_presence(client, pak->from->full, iks_find_attrib(pak->x, "to"), client->status, client->statusmessage);
|
aji_set_presence(client, pak->from->full, iks_find_attrib(pak->x, "to"), client->status, client->statusmessage);
|
||||||
}
|
|
||||||
|
|
||||||
switch (pak->subtype) {
|
|
||||||
case IKS_TYPE_SUBSCRIBE:
|
|
||||||
ast_verb(5, "JABBER: Subscribe handled.\n");
|
|
||||||
break;
|
|
||||||
case IKS_TYPE_SUBSCRIBED:
|
case IKS_TYPE_SUBSCRIBED:
|
||||||
ast_verb(5, "JABBER: Subscribed (%d) not handled.\n", pak->subtype);
|
buddy = ASTOBJ_CONTAINER_FIND(&client->buddies, pak->from->partial);
|
||||||
break;
|
if (!buddy && pak->from->partial) {
|
||||||
case IKS_TYPE_UNSUBSCRIBE:
|
aji_create_buddy(pak->from->partial, client);
|
||||||
ast_verb(5, "JABBER: Unsubscribe (%d) not handled.\n", pak->subtype);
|
}
|
||||||
break;
|
default:
|
||||||
case IKS_TYPE_UNSUBSCRIBED:
|
if (option_verbose > 4) {
|
||||||
ast_verb(5, "JABBER: Unsubscribed (%d) not handled.\n", pak->subtype);
|
ast_verbose(VERBOSE_PREFIX_3 "JABBER: This is a subcription of type %i\n", pak->subtype);
|
||||||
break;
|
}
|
||||||
default: /*IKS_TYPE_ERROR: */
|
|
||||||
ast_verb(5, "JABBER: Unknown pak subtype %d.\n", pak->subtype);
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user