diff options
author | markster <markster@f38db490-d61c-443f-a65b-d21fe96a405b> | 2003-08-03 18:22:12 +0000 |
---|---|---|
committer | markster <markster@f38db490-d61c-443f-a65b-d21fe96a405b> | 2003-08-03 18:22:12 +0000 |
commit | 5081eedc18d8ee8a960dbcadbdd6a5eba2ff1690 (patch) | |
tree | d95329e15e23ffe9e1fe596ad0c062074149678a /channels/chan_agent.c | |
parent | 90837960022cb0a50602a6b824eb1974cf7ac619 (diff) |
Honor context in agent callback login
git-svn-id: http://svn.digium.com/svn/asterisk/trunk@1254 f38db490-d61c-443f-a65b-d21fe96a405b
Diffstat (limited to 'channels/chan_agent.c')
-rwxr-xr-x | channels/chan_agent.c | 13 |
1 files changed, 12 insertions, 1 deletions
diff --git a/channels/chan_agent.c b/channels/chan_agent.c index 0d96e8fc0..45bbe05c0 100755 --- a/channels/chan_agent.c +++ b/channels/chan_agent.c @@ -836,6 +836,7 @@ static int __login_exec(struct ast_channel *chan, void *data, int callbackmode) char info[512]; char *opt_user = NULL; char *options = NULL; + char *context = NULL; int play_announcement; char *filename = "agent-loginok"; @@ -849,6 +850,13 @@ static int __login_exec(struct ast_channel *chan, void *data, int callbackmode) if (options) { *options = '\0'; options++; + if (callbackmode) { + context = strchr(options, '@'); + if (context) { + *context = '\0'; + context++; + } + } } } @@ -895,7 +903,10 @@ static int __login_exec(struct ast_channel *chan, void *data, int callbackmode) /* Retrieve login chan */ res = ast_app_getdata(chan, "agent-newlocation", tmpchan, sizeof(tmpchan) - 1, 0); if (!res) { - strncpy(p->loginchan, tmpchan, sizeof(p->loginchan) - 1); + if (context && strlen(context)) + snprintf(p->loginchan, sizeof(p->loginchan), "%s@%s", tmpchan, context); + else + strncpy(p->loginchan, tmpchan, sizeof(p->loginchan) - 1); if (!strlen(p->loginchan)) filename = "agent-loggedoff"; p->acknowledged = 0; |