[asterisk-commits] tilghman: trunk r139775 - in /trunk: apps/app_followme.c doc/followme.txt
SVN commits to the Asterisk project
asterisk-commits at lists.digium.com
Mon Aug 25 11:02:57 CDT 2008
Author: tilghman
Date: Mon Aug 25 11:02:56 2008
New Revision: 139775
URL: http://svn.digium.com/view/asterisk?view=rev&rev=139775
Log:
Realtime capabilities for the Find-Me-Follow-Me application.
(closes issue #13295)
Reported by: Corydon76
Patches:
20080813__followme_realtime_enabled.diff.txt uploaded by Corydon76 (license 14)
Tested by: dferrer
Added:
trunk/doc/followme.txt (with props)
Modified:
trunk/apps/app_followme.c
Modified: trunk/apps/app_followme.c
URL: http://svn.digium.com/view/asterisk/trunk/apps/app_followme.c?view=diff&rev=139775&r1=139774&r2=139775
==============================================================================
--- trunk/apps/app_followme.c (original)
+++ trunk/apps/app_followme.c Mon Aug 25 11:02:56 2008
@@ -89,6 +89,7 @@
char moh[AST_MAX_CONTEXT]; /*!< Music On Hold Class to be used */
char context[AST_MAX_CONTEXT]; /*!< Context to dial from */
unsigned int active; /*!< Profile is active (1), or disabled (0). */
+ int realtime; /*!< Cached from realtime */
char takecall[20]; /*!< Digit mapping to take a call */
char nextindp[20]; /*!< Digit mapping to decline a call */
char callfromprompt[PATH_MAX]; /*!< Sound prompt name and path */
@@ -233,17 +234,17 @@
ast_copy_string(f->takecall, val, sizeof(f->takecall));
else if (!strcasecmp(param, "declinecall"))
ast_copy_string(f->nextindp, val, sizeof(f->nextindp));
- else if (!strcasecmp(param, "call-from-prompt"))
+ else if (!strcasecmp(param, "call-from-prompt") || !strcasecmp(param, "call_from_prompt"))
ast_copy_string(f->callfromprompt, val, sizeof(f->callfromprompt));
- else if (!strcasecmp(param, "followme-norecording-prompt"))
+ else if (!strcasecmp(param, "followme-norecording-prompt") || !strcasecmp(param, "norecording_prompt"))
ast_copy_string(f->norecordingprompt, val, sizeof(f->norecordingprompt));
- else if (!strcasecmp(param, "followme-options-prompt"))
+ else if (!strcasecmp(param, "followme-options-prompt") || !strcasecmp(param, "options_prompt"))
ast_copy_string(f->optionsprompt, val, sizeof(f->optionsprompt));
- else if (!strcasecmp(param, "followme-pls-hold-prompt"))
+ else if (!strcasecmp(param, "followme-pls-hold-prompt") || !strcasecmp(param, "hold_prompt"))
ast_copy_string(f->plsholdprompt, val, sizeof(f->plsholdprompt));
- else if (!strcasecmp(param, "followme-status-prompt"))
+ else if (!strcasecmp(param, "followme-status-prompt") || !strcasecmp(param, "status_prompt"))
ast_copy_string(f->statusprompt, val, sizeof(f->statusprompt));
- else if (!strcasecmp(param, "followme-sorry-prompt"))
+ else if (!strcasecmp(param, "followme-sorry-prompt") || !strcasecmp(param, "sorry_prompt"))
ast_copy_string(f->sorryprompt, val, sizeof(f->sorryprompt));
else if (failunknown) {
if (linenum >= 0)
@@ -873,6 +874,67 @@
return;
}
+static struct call_followme *find_realtime(const char *name)
+{
+ struct ast_variable *var = ast_load_realtime("followme", "name", name, NULL), *v;
+ struct ast_config *cfg;
+ const char *catg;
+ struct call_followme *new;
+ struct ast_str *str = ast_str_create(16);
+
+ if (!var) {
+ return NULL;
+ }
+
+ if (!(new = alloc_profile(name))) {
+ return NULL;
+ }
+
+ for (v = var; v; v = v->next) {
+ if (!strcasecmp(v->name, "active")) {
+ if (ast_false(v->value)) {
+ ast_mutex_destroy(&new->lock);
+ ast_free(new);
+ return NULL;
+ }
+ } else {
+ profile_set_param(new, v->name, v->value, 0, 0);
+ }
+ }
+
+ ast_variables_destroy(var);
+ new->realtime = 1;
+
+ /* Load numbers */
+ if (!(cfg = ast_load_realtime_multientry("followme_numbers", "ordinal LIKE", "%", "name", name, NULL))) {
+ ast_mutex_destroy(&new->lock);
+ ast_free(new);
+ return NULL;
+ }
+
+ for (catg = ast_category_browse(cfg, NULL); catg; catg = ast_category_browse(cfg, catg)) {
+ const char *numstr, *timeoutstr, *ordstr;
+ int timeout;
+ struct number *cur;
+ if (!(numstr = ast_variable_retrieve(cfg, catg, "phonenumber"))) {
+ continue;
+ }
+ if (!(timeoutstr = ast_variable_retrieve(cfg, catg, "timeout")) || sscanf(timeoutstr, "%d", &timeout) != 1 || timeout < 1) {
+ timeout = 25;
+ }
+ /* This one has to exist; it was part of the query */
+ ordstr = ast_variable_retrieve(cfg, catg, "ordinal");
+ ast_str_make_space(&str, strlen(numstr) + 1);
+ ast_copy_string(str->str, numstr, str->len);
+ if ((cur = create_followme_number(str->str, timeout, atoi(ordstr)))) {
+ AST_LIST_INSERT_TAIL(&new->numbers, cur, entry);
+ }
+ }
+ ast_config_destroy(cfg);
+
+ return new;
+}
+
static int app_exec(struct ast_channel *chan, void *data)
{
struct fm_args targs;
@@ -916,6 +978,10 @@
AST_RWLIST_UNLOCK(&followmes);
ast_debug(1, "New profile %s.\n", args.followmeid);
+
+ if (!f) {
+ f = find_realtime(args.followmeid);
+ }
if (!f) {
ast_log(LOG_WARNING, "Profile requested, %s, not found in the configuration.\n", args.followmeid);
@@ -1016,6 +1082,12 @@
outrun:
+ if (f->realtime) {
+ /* Not in list */
+ free_numbers(f);
+ ast_free(f);
+ }
+
return res;
}
Added: trunk/doc/followme.txt
URL: http://svn.digium.com/view/asterisk/trunk/doc/followme.txt?view=auto&rev=139775
==============================================================================
--- trunk/doc/followme.txt (added)
+++ trunk/doc/followme.txt Mon Aug 25 11:02:56 2008
@@ -1,0 +1,32 @@
+Followme is now realtime-enabled:
+
+To use, you must define two backend data structures, with the following fields:
+
+followme:
+ name Name of this followme entry. Specified when invoking the FollowMe
+ application in the dialplan. This field is the only one which is
+ mandatory. All of the other fields will inherit the default from
+ followme.conf, if not specified in this data resource.
+ musicclass OR The musiconhold class used for the caller while waiting to be
+ musiconhold OR connected.
+ music
+ context Dialplan context from which to dial numbers
+ takecall DTMF used to accept the call and be connected. For obvious reasons,
+ this needs to be a single digit, '*', or '#'.
+ declinecall DTMF used to refuse the call, sending it onto the next step, if any.
+ call_from_prompt Prompt to play to the callee, announcing the call.
+ norecording_prompt The alternate prompt to play to the callee, when the caller
+ refuses to leave a name (or the option isn't set to allow them).
+ options_prompt Normally, "press 1 to accept, 2 to decline".
+ hold_prompt Message played to the caller while dialing the followme steps.
+ status_prompt Normally, "Party is not at their desk".
+ sorry_prompt Normally, "Unable to locate party".
+
+followme_numbers:
+ name Name of this followme entry. Must match the name above.
+ ordinal An integer, specifying the order in which these numbers will be
+ followed.
+ phonenumber The telephone number(s) you would like to call, separated by '&'.
+ timeout Timeout associated with this step. See the followme documentation
+ for more information on how this value is handled.
+
Propchange: trunk/doc/followme.txt
------------------------------------------------------------------------------
svn:eol-style = native
Propchange: trunk/doc/followme.txt
------------------------------------------------------------------------------
svn:keywords = Author Date Id Revision
Propchange: trunk/doc/followme.txt
------------------------------------------------------------------------------
svn:mime-type = text/plain
More information about the asterisk-commits
mailing list