From c58ae729cd7b6ed6dc6441c59fd0ff085df82fa2 Mon Sep 17 00:00:00 2001 From: Mark Spencer Date: Wed, 20 Sep 2006 22:09:45 +0000 Subject: Fix agent parsing of users.conf git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@43382 65c4cc65-6c06-0410-ace0-fbb531ad65f3 --- channels/chan_agent.c | 26 ++++++++++++++++++++++++++ 1 file changed, 26 insertions(+) (limited to 'channels/chan_agent.c') 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); -- cgit v1.2.3