aboutsummaryrefslogtreecommitdiffstats
path: root/manager.c
diff options
context:
space:
mode:
authormarkster <markster@f38db490-d61c-443f-a65b-d21fe96a405b>2004-05-22 04:11:22 +0000
committermarkster <markster@f38db490-d61c-443f-a65b-d21fe96a405b>2004-05-22 04:11:22 +0000
commitd3895410f133c2a69e1208ac4d595bcad3fa6cf5 (patch)
tree900c6863b338822feeda356de1551c36873d6356 /manager.c
parent2cb317286a70df8459496a44931508024c63059e (diff)
Merge fabeman's extensive meetme improvements (bug #1624)
git-svn-id: http://svn.digium.com/svn/asterisk/trunk@3038 f38db490-d61c-443f-a65b-d21fe96a405b
Diffstat (limited to 'manager.c')
-rwxr-xr-xmanager.c15
1 files changed, 13 insertions, 2 deletions
diff --git a/manager.c b/manager.c
index 53dcf6f09..b619baf04 100755
--- a/manager.c
+++ b/manager.c
@@ -455,6 +455,7 @@ static int action_redirect(struct mansession *s, struct message *m)
char *exten = astman_get_header(m, "Exten");
char *context = astman_get_header(m, "Context");
char *priority = astman_get_header(m, "Priority");
+ struct ast_channel *chan, *chan2 = NULL;
int pi = 0;
int res;
if (!name || !strlen(name)) {
@@ -465,10 +466,16 @@ static int action_redirect(struct mansession *s, struct message *m)
astman_send_error(s, m, "Invalid priority\n");
return 0;
}
- res = ast_async_goto_by_name(name, context, exten, pi);
+ chan = ast_get_channel_by_name_locked(name);
+ if (strlen(name2))
+ chan2 = ast_get_channel_by_name_locked(name2);
+ res = ast_async_goto(chan, context, exten, pi);
if (!res) {
if (strlen(name2)) {
- res = ast_async_goto_by_name(name2, context, exten, pi);
+ if (chan2)
+ res = ast_async_goto(chan2, context, exten, pi);
+ else
+ res = -1;
if (!res)
astman_send_ack(s, m, "Dual Redirect successful");
else
@@ -477,6 +484,10 @@ static int action_redirect(struct mansession *s, struct message *m)
astman_send_ack(s, m, "Redirect successful");
} else
astman_send_error(s, m, "Redirect failed");
+ if (chan)
+ ast_mutex_unlock(&chan->lock);
+ if (chan2)
+ ast_mutex_unlock(&chan2->lock);
return 0;
}