dect
/
asterisk
Archived
13
0
Fork 0

Add event for agentlogoff from CLI (bug #3611)

git-svn-id: http://svn.digium.com/svn/asterisk/trunk@5047 f38db490-d61c-443f-a65b-d21fe96a405b
This commit is contained in:
markster 2005-02-18 05:03:01 +00:00
parent 091201c218
commit bf6afaf5cb
1 changed files with 11 additions and 1 deletions

View File

@ -1314,7 +1314,8 @@ static int agent_logoff_cmd(int fd, int argc, char **argv)
{
struct agent_pvt *p;
char *agent = argv[2] + 6;
long logintime;
if (argc < 3 || argc > 4)
return RESULT_SHOWUSAGE;
if (argc == 4 && strcasecmp(argv[3], "soft"))
@ -1330,6 +1331,15 @@ static int agent_logoff_cmd(int fd, int argc, char **argv)
ast_softhangup(p->chan, AST_SOFTHANGUP_EXPLICIT);
}
}
logintime = time(NULL) - p->loginstart;
p->loginstart = 0;
manager_event(EVENT_FLAG_AGENT, "Agentcallbacklogoff",
"Agent: %s\r\n"
"Loginchan: %s\r\n"
"Logintime: %ld\r\n",
p->agent, p->loginchan, logintime);
ast_queue_log("NONE", "NONE", agent, "AGENTCALLBACKLOGOFF", "%s|%ld|%s", p->loginchan, logintime, "CommandLogoff");
p->loginchan[0] = '\0';
ast_cli(fd, "Logging out %s\n", agent);
break;