diff options
author | Jason Parker <jparker@digium.com> | 2013-12-18 23:00:03 +0000 |
---|---|---|
committer | Jason Parker <jparker@digium.com> | 2013-12-18 23:00:03 +0000 |
commit | 04dfe2d77f01c940db571582c6b7169c581a67f9 (patch) | |
tree | 959b0768c25392ebded42086fb81932bf729a492 /main/manager.c | |
parent | 47c0b78690c13ebcc9311bbcc7201ef1f4864dcd (diff) |
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
Diffstat (limited to 'main/manager.c')
-rw-r--r-- | main/manager.c | 51 |
1 files changed, 39 insertions, 12 deletions
diff --git a/main/manager.c b/main/manager.c index f2590b1bb..12dda4c59 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 - <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; } |