summaryrefslogtreecommitdiff
path: root/main/manager_channels.c
diff options
context:
space:
mode:
authorMark Michelson <mmichelson@digium.com>2014-12-08 16:24:36 +0000
committerMark Michelson <mmichelson@digium.com>2014-12-08 16:24:36 +0000
commitfe7671fee69b0ce1a6120a9ccb6664c5f31d37d3 (patch)
tree108d125bf0ea17e17cfb63bf5d7d89756eb30f7e /main/manager_channels.c
parent4bb556a8478741dc81361327d3a50a8809be09f6 (diff)
Add new AMI and ARI events for connected line changes on a channel.
The AMI event is called NewConnectedLine and the ARI event is called ChannelConnectedLine. ASTERISK-24554 #close Reported by Matt Jordan Review: https://reviewboard.asterisk.org/r/4231 ........ Merged revisions 429064 from http://svn.asterisk.org/svn/asterisk/branches/13 git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@429084 65c4cc65-6c06-0410-ace0-fbb531ad65f3
Diffstat (limited to 'main/manager_channels.c')
-rw-r--r--main/manager_channels.c20
1 files changed, 19 insertions, 1 deletions
diff --git a/main/manager_channels.c b/main/manager_channels.c
index 127084161..d431af24c 100644
--- a/main/manager_channels.c
+++ b/main/manager_channels.c
@@ -570,6 +570,23 @@ static struct ast_manager_event_blob *channel_new_callerid(
ast_describe_caller_presentation(new_snapshot->caller_pres));
}
+static struct ast_manager_event_blob *channel_new_connected_line(
+ struct ast_channel_snapshot *old_snapshot,
+ struct ast_channel_snapshot *new_snapshot)
+{
+ /* No NewConnectedLine event on cache clear or first event */
+ if (!old_snapshot || !new_snapshot) {
+ return NULL;
+ }
+
+ if (ast_channel_snapshot_connected_line_equal(old_snapshot, new_snapshot)) {
+ return NULL;
+ }
+
+ return ast_manager_event_blob_create(
+ EVENT_FLAG_CALL, "NewConnectedLine", "%s", "");
+}
+
static struct ast_manager_event_blob *channel_new_accountcode(
struct ast_channel_snapshot *old_snapshot,
struct ast_channel_snapshot *new_snapshot)
@@ -591,7 +608,8 @@ channel_snapshot_monitor channel_monitors[] = {
channel_state_change,
channel_newexten,
channel_new_callerid,
- channel_new_accountcode
+ channel_new_accountcode,
+ channel_new_connected_line,
};
static void channel_snapshot_update(void *data, struct stasis_subscription *sub,