From 38c1c1de83857a2de29a870d4c4113e6ba6e5cd6 Mon Sep 17 00:00:00 2001 From: Jason Parker <jparker@digium.com> Date: Wed, 18 Dec 2013 22:34:21 +0000 Subject: [PATCH] Add AMI event for presence state. Review: https://reviewboard.asterisk.org/r/3039/ git-svn-id: https://origsvn.digium.com/svn/asterisk/branches/11@404275 65c4cc65-6c06-0410-ace0-fbb531ad65f3 --- main/manager.c | 51 ++++++++++++++++++++++++++++++++++++++------------ 1 file changed, 39 insertions(+), 12 deletions(-) diff --git a/main/manager.c b/main/manager.c index c7af520de6..a0abedda04 100644 --- a/main/manager.c +++ b/main/manager.c @@ -5775,20 +5775,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 - <managerEventInstance> - <synopsis>Raised when an extension state has changed.</synopsis> - </managerEventInstance> - ***/ - 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 + <managerEventInstance> + <synopsis>Raised when an extension state has changed.</synopsis> + </managerEventInstance> + ***/ + 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 + <managerEventInstance> + <synopsis>Raised when a presence state has changed.</synopsis> + </managerEventInstance> + ***/ + 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; } -- GitLab