diff options
author | file <file@f38db490-d61c-443f-a65b-d21fe96a405b> | 2007-02-16 17:41:27 +0000 |
---|---|---|
committer | file <file@f38db490-d61c-443f-a65b-d21fe96a405b> | 2007-02-16 17:41:27 +0000 |
commit | 7f152598d6124f71f299223ba9e4316d56ceb64e (patch) | |
tree | 89037fa90a5692fd1366000fa15b56b4b0ee068c /res | |
parent | 2f2bdc68f0788e33644394c110b7385b5887dc25 (diff) |
Add option to features.conf that enables parking via DTMF on picked up parked calls. (issue #9082 reported by francesco_r)
git-svn-id: http://svn.digium.com/svn/asterisk/trunk@54889 f38db490-d61c-443f-a65b-d21fe96a405b
Diffstat (limited to 'res')
-rw-r--r-- | res/res_features.c | 8 |
1 files changed, 8 insertions, 0 deletions
diff --git a/res/res_features.c b/res/res_features.c index f383ebc9e..c14f39fde 100644 --- a/res/res_features.c +++ b/res/res_features.c @@ -79,6 +79,7 @@ static char *parkedcall = "ParkedCall"; static int parkaddhints = 0; /*!< Add parking hints automatically */ static int parkedcalltransfers = 0; /*!< Enable DTMF based transfers on bridge when picking up parked calls */ +static int parkedcallreparking = 0; /*!< Enable DTMF based parking on bridge when picking up parked calls */ static int parkingtime = DEFAULT_PARK_TIME; /*!< No more than 45 seconds parked before you do something with them */ static char parking_con[AST_MAX_EXTENSION]; /*!< Context for which parking is made accessible */ static char parking_con_dial[AST_MAX_EXTENSION]; /*!< Context for dialback for parking (KLUDGE) */ @@ -1833,6 +1834,10 @@ static int park_exec(struct ast_channel *chan, void *data) ast_set_flag(&(config.features_callee), AST_FEATURE_REDIRECT); ast_set_flag(&(config.features_caller), AST_FEATURE_REDIRECT); } + if (parkedcallreparking) { + ast_set_flag(&(config.features_callee), AST_FEATURE_PARKCALL); + ast_set_flag(&(config.features_caller), AST_FEATURE_PARKCALL); + } res = ast_bridge_call(chan, peer, &config); pbx_builtin_setvar_helper(chan, "PARKEDCHANNEL", peer->name); @@ -2123,6 +2128,7 @@ static int load_config(void) comebacktoorigin = 1; parkaddhints = 0; parkedcalltransfers = 0; + parkedcallreparking = 0; transferdigittimeout = DEFAULT_TRANSFER_DIGIT_TIMEOUT; featuredigittimeout = DEFAULT_FEATURE_DIGIT_TIMEOUT; @@ -2157,6 +2163,8 @@ static int load_config(void) parkaddhints = ast_true(var->value); } else if (!strcasecmp(var->name, "parkedcalltransfers")) { parkedcalltransfers = ast_true(var->value); + } else if (!strcasecmp(var->name, "parkedcallreparking")) { + parkedcallreparking = ast_true(var->value); } else if (!strcasecmp(var->name, "adsipark")) { adsipark = ast_true(var->value); } else if (!strcasecmp(var->name, "transferdigittimeout")) { |