From: Jason Parker Date: Wed, 18 Dec 2013 23:00:03 +0000 (+0000) Subject: Add AMI event for presence state. X-Git-Tag: 13.0.0-beta1~727 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=04dfe2d77f01c940db571582c6b7169c581a67f9;p=thirdparty%2Fasterisk.git Add AMI event for presence state. Review: https://reviewboard.asterisk.org/r/3039/ ........ Merged revisions 404275 from http://svn.asterisk.org/svn/asterisk/branches/11 ........ Merged revisions 404279 from http://svn.asterisk.org/svn/asterisk/branches/12 git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@404280 65c4cc65-6c06-0410-ace0-fbb531ad65f3 --- diff --git a/main/manager.c b/main/manager.c index f2590b1bb8..12dda4c595 100644 --- a/main/manager.c +++ b/main/manager.c @@ -6077,20 +6077,47 @@ static int manager_state_cb(char *context, char *exten, struct ast_state_cb_info { /* Notify managers of change */ char hint[512]; - int state = info->exten_state; - - /* only interested in device state for this right now */ - if (info->reason != AST_HINT_UPDATE_DEVICE) { - return 0; - } ast_get_hint(hint, sizeof(hint), NULL, 0, NULL, context, exten); - /*** DOCUMENTATION - - Raised when an extension state has changed. - - ***/ - manager_event(EVENT_FLAG_CALL, "ExtensionStatus", "Exten: %s\r\nContext: %s\r\nHint: %s\r\nStatus: %d\r\n", exten, context, hint, state); + + switch(info->reason) { + case AST_HINT_UPDATE_DEVICE: + /*** DOCUMENTATION + + Raised when an extension state has changed. + + ***/ + manager_event(EVENT_FLAG_CALL, "ExtensionStatus", + "Exten: %s\r\n" + "Context: %s\r\n" + "Hint: %s\r\n" + "Status: %d\r\n", + exten, + context, + hint, + info->exten_state); + break; + case AST_HINT_UPDATE_PRESENCE: + /*** DOCUMENTATION + + Raised when a presence state has changed. + + ***/ + manager_event(EVENT_FLAG_CALL, "PresenceStatus", + "Exten: %s\r\n" + "Context: %s\r\n" + "Hint: %s\r\n" + "Status: %s\r\n" + "Subtype: %s\r\n" + "Message: %s\r\n", + exten, + context, + hint, + ast_presence_state2str(info->presence_state), + info->presence_subtype, + info->presence_message); + break; + } return 0; }