[svn-commits] kmoore: branch kmoore/bridge_construction-cel_bridging r389474 - /team/kmoore...
SVN commits to the Digium repositories
svn-commits at lists.digium.com
Tue May 21 22:01:37 CDT 2013
Author: kmoore
Date: Tue May 21 22:01:33 2013
New Revision: 389474
URL: http://svnview.digium.com/svn/asterisk?view=rev&rev=389474
Log:
Save the secondary channel's name directly instead of pulling it indirectly via the uniqueid
Modified:
team/kmoore/bridge_construction-cel_bridging/main/cel.c
Modified: team/kmoore/bridge_construction-cel_bridging/main/cel.c
URL: http://svnview.digium.com/svn/asterisk/team/kmoore/bridge_construction-cel_bridging/main/cel.c?view=diff&rev=389474&r1=389473&r2=389474
==============================================================================
--- team/kmoore/bridge_construction-cel_bridging/main/cel.c (original)
+++ team/kmoore/bridge_construction-cel_bridging/main/cel.c Tue May 21 22:01:33 2013
@@ -323,7 +323,7 @@
AST_DECLARE_STRING_FIELDS(
AST_STRING_FIELD(channel_id); /*!< UniqueID of the primary/dialing channel */
AST_STRING_FIELD(bridge_id); /*!< UniqueID of the bridge */
- AST_STRING_FIELD(secondary_id); /*!< UniqueID of the secondary/dialed channel */
+ AST_STRING_FIELD(secondary_name); /*!< UniqueID of the secondary/dialed channel */
);
};
@@ -333,7 +333,7 @@
ast_string_field_free_memory(assoc);
}
-static struct bridge_assoc *bridge_assoc_alloc(const char *channel_id, const char *bridge_id, const char *secondary_id)
+static struct bridge_assoc *bridge_assoc_alloc(const char *channel_id, const char *bridge_id, const char *secondary_name)
{
RAII_VAR(struct bridge_assoc *, assoc, ao2_alloc(sizeof(*assoc), bridge_assoc_dtor), ao2_cleanup);
if (!assoc || ast_string_field_init(assoc, 64)) {
@@ -342,15 +342,15 @@
ast_string_field_set(assoc, channel_id, channel_id);
ast_string_field_set(assoc, bridge_id, bridge_id);
- ast_string_field_set(assoc, secondary_id, secondary_id);
+ ast_string_field_set(assoc, secondary_name, secondary_name);
ao2_ref(assoc, +1);
return assoc;
}
-static int add_bridge_primary(const char *channel_id, const char *bridge_id, const char *secondary_id)
-{
- RAII_VAR(struct bridge_assoc *, assoc, bridge_assoc_alloc(channel_id, bridge_id, secondary_id), ao2_cleanup);
+static int add_bridge_primary(const char *channel_id, const char *bridge_id, const char *secondary_name)
+{
+ RAII_VAR(struct bridge_assoc *, assoc, bridge_assoc_alloc(channel_id, bridge_id, secondary_name), ao2_cleanup);
if (!assoc) {
return -1;
}
@@ -645,12 +645,12 @@
static int report_event_snapshot(struct ast_channel_snapshot *snapshot,
enum ast_cel_event_type event_type, const char *userdefevname,
- const char *extra, const char *peer2_id)
+ const char *extra, const char *peer2_name)
{
struct timeval eventtime;
struct ast_event *ev;
char *linkedid = ast_strdupa(snapshot->linkedid);
- char *peer_name = "";
+ const char *peer_name = "";
RAII_VAR(struct bridge_assoc *, assoc, NULL, ao2_cleanup);
RAII_VAR(struct cel_config *, cfg, ao2_global_obj_ref(cel_configs), ao2_cleanup);
@@ -664,20 +664,11 @@
assoc = ao2_find(bridge_primaries, snapshot->uniqueid, OBJ_KEY);
if (assoc) {
- RAII_VAR(struct ast_channel_snapshot *, bridged_snapshot, NULL, ao2_cleanup);
- bridged_snapshot = ast_channel_snapshot_get_latest(assoc->secondary_id);
- if (bridged_snapshot) {
- peer_name = ast_strdupa(bridged_snapshot->name);
- }
- }
-
- if (ast_strlen_zero(peer_name) && peer2_id) {
- RAII_VAR(struct ast_channel_snapshot *, peer2_snapshot, ast_channel_snapshot_get_latest(peer2_id), ao2_cleanup);
- if (!peer2_snapshot) {
- return -1;
- }
-
- peer_name = ast_strdupa(peer2_snapshot->name);
+ peer_name = assoc->secondary_name;
+ }
+
+ if (ast_strlen_zero(peer_name) && peer2_name) {
+ peer_name = peer2_name;
}
/* Record the linkedid of new channels if we are tracking LINKEDID_END even if we aren't
@@ -1250,8 +1241,8 @@
}
ao2_iterator_destroy(&i);
- add_bridge_primary(channel_id, snapshot->uniqueid, chan_snapshot->uniqueid);
- report_event_id(channel_id, AST_CEL_BRIDGE_START, NULL, NULL, chan_snapshot->uniqueid);
+ add_bridge_primary(channel_id, snapshot->uniqueid, chan_snapshot->name);
+ report_event_id(channel_id, AST_CEL_BRIDGE_START, NULL, NULL, chan_snapshot->name);
}
} else if (snapshot->capabilities | AST_BRIDGE_CAPABILITY_MULTIMIX) {
report_event_id(chan_snapshot->uniqueid, AST_CEL_CONF_ENTER, NULL, NULL, NULL);
@@ -1274,7 +1265,7 @@
if (ao2_container_count(snapshot->channels) == 1) {
RAII_VAR(struct bridge_assoc *, ao2_primary, ao2_find(bridge_primaries, chan_snapshot->uniqueid, OBJ_KEY), ao2_cleanup);
RAII_VAR(char *, channel_id_in_bridge, NULL, ao2_cleanup);
- const char *primary, *secondary;
+ const char *primary;
struct ao2_iterator i;
/* get the only item in the container */
@@ -1286,14 +1277,13 @@
if (ao2_primary) {
primary = chan_snapshot->uniqueid;
- secondary = channel_id_in_bridge;
} else {
primary = channel_id_in_bridge;
- secondary = chan_snapshot->uniqueid;
+ ao2_primary = ao2_find(bridge_primaries, primary, OBJ_KEY);
}
remove_bridge_primary(primary);
- report_event_id(primary, AST_CEL_BRIDGE_END, NULL, NULL, secondary);
+ report_event_id(primary, AST_CEL_BRIDGE_END, NULL, NULL, ao2_primary->secondary_name);
}
/* AST_CEL_BRIDGE_END when all parties have left */
} else if (snapshot->capabilities | AST_BRIDGE_CAPABILITY_MULTIMIX) {
More information about the svn-commits
mailing list