diff options
author | Mark Spencer <markster@digium.com> | 2006-09-20 22:09:45 +0000 |
---|---|---|
committer | Mark Spencer <markster@digium.com> | 2006-09-20 22:09:45 +0000 |
commit | c58ae729cd7b6ed6dc6441c59fd0ff085df82fa2 (patch) | |
tree | 03ea919e72259245de6f8b479ded85c9fc480f1e /channels/chan_agent.c | |
parent | 9a147c678c6dbd30c7b78417d977aedb7e1ee80a (diff) |
Fix agent parsing of users.conf
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@43382 65c4cc65-6c06-0410-ace0-fbb531ad65f3
Diffstat (limited to 'channels/chan_agent.c')
-rw-r--r-- | channels/chan_agent.c | 26 |
1 files changed, 26 insertions, 0 deletions
diff --git a/channels/chan_agent.c b/channels/chan_agent.c index 148da4266..92027fb5e 100644 --- a/channels/chan_agent.c +++ b/channels/chan_agent.c @@ -1006,9 +1006,13 @@ static struct ast_channel *agent_new(struct agent_pvt *p, int state) static int read_agent_config(void) { struct ast_config *cfg; + struct ast_config *ucfg; struct ast_variable *v; struct agent_pvt *p; const char *general_val; + const char *catname; + const char *hasagent; + int genhasagent; group = 0; autologoff = 0; @@ -1104,6 +1108,28 @@ static int read_agent_config(void) } v = v->next; } + if ((ucfg = ast_config_load("users.conf"))) { + genhasagent = ast_true(ast_variable_retrieve(ucfg, "general", "hasagent")); + catname = ast_category_browse(ucfg, NULL); + while(catname) { + if (strcasecmp(catname, "general")) { + hasagent = ast_variable_retrieve(ucfg, catname, "hasagent"); + if (ast_true(hasagent) || (!hasagent && genhasagent)) { + char tmp[256]; + const char *fullname = ast_variable_retrieve(ucfg, catname, "fullname"); + const char *secret = ast_variable_retrieve(ucfg, catname, "secret"); + if (!fullname) + fullname = ""; + if (!secret) + secret = ""; + snprintf(tmp, sizeof(tmp), "%s,%s,%s", catname, secret,fullname); + add_agent(tmp, 0); + } + } + catname = ast_category_browse(ucfg, catname); + } + ast_config_destroy(ucfg); + } AST_LIST_TRAVERSE_SAFE_BEGIN(&agents, p, list) { if (p->dead) { AST_LIST_REMOVE_CURRENT(&agents, list); |