summaryrefslogtreecommitdiff
path: root/channels
diff options
context:
space:
mode:
authorBJ Weschke <bweschke@btwtech.com>2006-07-07 16:16:41 +0000
committerBJ Weschke <bweschke@btwtech.com>2006-07-07 16:16:41 +0000
commit4149f37efa44a84fd9ef436a052ef5d14722c100 (patch)
tree5d1cc25ca4037ce746ed902890ac28c5c229eaa9 /channels
parent092304ffa9b1383470512c3e53093f289a6ae5f2 (diff)
Merged revisions 37212 via svnmerge from
https://origsvn.digium.com/svn/asterisk/branches/1.2 ........ r37212 | bweschke | 2006-07-06 15:38:45 -0500 (Thu, 06 Jul 2006) | 3 lines Don't do wierd things on a callback agent that has attempted logoff while still on the phone. ........ git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@37301 65c4cc65-6c06-0410-ace0-fbb531ad65f3
Diffstat (limited to 'channels')
-rw-r--r--channels/chan_agent.c6
1 files changed, 4 insertions, 2 deletions
diff --git a/channels/chan_agent.c b/channels/chan_agent.c
index 2e26d7c1c..1c440f3b8 100644
--- a/channels/chan_agent.c
+++ b/channels/chan_agent.c
@@ -771,14 +771,16 @@ static int agent_hangup(struct ast_channel *ast)
ast_channel_lock(p->chan);
ast_softhangup(p->chan, AST_SOFTHANGUP_EXPLICIT);
ast_channel_unlock(p->chan);
- } else {
+ } else if (p->loginstart) {
ast_channel_lock(p->chan);
ast_moh_start(p->chan, p->moh);
ast_channel_unlock(p->chan);
}
}
ast_mutex_unlock(&p->lock);
- ast_device_state_changed("Agent/%s", p->agent);
+ /* Only register a device state change if the agent is still logged in */
+ if (p->loginstart)
+ ast_device_state_changed("Agent/%s", p->agent);
if (p->pending) {
AST_LIST_LOCK(&agents);