aboutsummaryrefslogtreecommitdiffstats
path: root/channels
diff options
context:
space:
mode:
authorbweschke <bweschke@f38db490-d61c-443f-a65b-d21fe96a405b>2006-07-06 20:38:45 +0000
committerbweschke <bweschke@f38db490-d61c-443f-a65b-d21fe96a405b>2006-07-06 20:38:45 +0000
commita3f697ae5e98d04056a9c0faebe45513ecf65e32 (patch)
tree0ca9e1618b63adb4e20ed39a4e9d287261d37bc5 /channels
parent29746b60d9a08a027fc58d11cd899817df64bfd3 (diff)
Don't do wierd things on a callback agent that has attempted logoff while still on the phone.
git-svn-id: http://svn.digium.com/svn/asterisk/branches/1.2@37212 f38db490-d61c-443f-a65b-d21fe96a405b
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 e41ee0994..65a8fbef4 100644
--- a/channels/chan_agent.c
+++ b/channels/chan_agent.c
@@ -795,14 +795,16 @@ static int agent_hangup(struct ast_channel *ast)
ast_mutex_lock(&p->chan->lock);
ast_softhangup(p->chan, AST_SOFTHANGUP_EXPLICIT);
ast_mutex_unlock(&p->chan->lock);
- } else {
+ } else if (p->loginstart) {
ast_mutex_lock(&p->chan->lock);
ast_moh_start(p->chan, p->moh);
ast_mutex_unlock(&p->chan->lock);
}
}
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_mutex_lock(&agentlock);