diff options
author | file <file@f38db490-d61c-443f-a65b-d21fe96a405b> | 2007-02-28 19:00:24 +0000 |
---|---|---|
committer | file <file@f38db490-d61c-443f-a65b-d21fe96a405b> | 2007-02-28 19:00:24 +0000 |
commit | 990a2d8b020d04ffcf7b42a3dea8bfb797e2a8e6 (patch) | |
tree | 1e239164c2ad3fb3dec4584d96521616ea82551c /channels | |
parent | e79b5f130aa0488592b5aec101e6a1b314236c9c (diff) |
Merged revisions 57093 via svnmerge from
https://origsvn.digium.com/svn/asterisk/branches/1.4
................
r57093 | file | 2007-02-28 13:57:52 -0500 (Wed, 28 Feb 2007) | 10 lines
Merged revisions 57092 via svnmerge from
https://origsvn.digium.com/svn/asterisk/branches/1.2
........
r57092 | file | 2007-02-28 13:55:45 -0500 (Wed, 28 Feb 2007) | 2 lines
Fix a few more issues with the agent logoff CLI command. (issue #9123 reported by arbrandes)
........
................
git-svn-id: http://svn.digium.com/svn/asterisk/trunk@57094 f38db490-d61c-443f-a65b-d21fe96a405b
Diffstat (limited to 'channels')
-rw-r--r-- | channels/chan_agent.c | 11 |
1 files changed, 10 insertions, 1 deletions
diff --git a/channels/chan_agent.c b/channels/chan_agent.c index 453e8a414..26f8ca546 100644 --- a/channels/chan_agent.c +++ b/channels/chan_agent.c @@ -773,6 +773,8 @@ static int agent_hangup(struct ast_channel *ast) ast_log(LOG_NOTICE, "Agent '%s' didn't answer/confirm within %d seconds (waited %d)\n", p->name, p->autologoff, howlong); p->deferlogoff = 0; agent_logoff_maintenance(p, p->loginchan, logintime, ast->uniqueid, "Autologoff"); + if (persistent_agents) + dump_agents(); } } else if (p->dead) { ast_channel_lock(p->chan); @@ -787,9 +789,16 @@ static int agent_hangup(struct ast_channel *ast) } } ast_mutex_unlock(&p->lock); + /* Only register a device state change if the agent is still logged in */ - if (p->loginstart) + if (!p->loginstart) { + p->loginchan[0] = '\0'; + p->logincallerid[0] = '\0'; + if (persistent_agents) + dump_agents(); + } else { ast_device_state_changed("Agent/%s", p->agent); + } if (p->pending) { AST_LIST_LOCK(&agents); |