diff --git a/CREDITS b/CREDITS index a63285e90ee824f68b3d4a96aa779657502a271c..84440be9af6a2b4eddac248241894003d89fa24a 100644 --- a/CREDITS +++ b/CREDITS @@ -79,6 +79,8 @@ Constantine Filin - major contributions to the Asterisk Realtime Architecture Steve Murphy - privacy support, $[ ] parser upgrade, AEL2 parser upgrade Claude Patry - bug fixes, feature enhancements, and bug marshalling cpatry@gmail.com +Miroslav Nachev, miro@space-comm.com COSMOS Software Enterprises, Ltd. + - for Variable for No Answer Timeout for Attended Transfer === OTHER CONTRIBUTIONS === John Todd - Monkey sounds and associated teletorture prompt diff --git a/configs/features.conf.sample b/configs/features.conf.sample index db99c4c820f07fa0cbb54e6f231e730448deaebd..a0cc6360001bec28b0bc1b70902f975d55113e7e 100644 --- a/configs/features.conf.sample +++ b/configs/features.conf.sample @@ -26,6 +26,7 @@ context => parkedcalls ; Which context parked calls are in ;pickupexten = *8 ; Configure the pickup extension. (default is *8) ;featuredigittimeout = 500 ; Max time (ms) between digits for ; feature activation (default is 500 ms) +;atxfernoanswertimeout = 15 ; Timeout for answer on attended transfer default is 15 seconds. [featuremap] ;blindxfer => #1 ; Blind transfer (default is #) diff --git a/res/res_features.c b/res/res_features.c index 54c9a4c3bc0da777c8850d94fc07ee2c7a702d36..35c203451583d39b3679667b9d728c859b8d26f3 100644 --- a/res/res_features.c +++ b/res/res_features.c @@ -70,6 +70,7 @@ static void FREE(void *ptr) #define DEFAULT_PARK_TIME 45000 #define DEFAULT_TRANSFER_DIGIT_TIMEOUT 3000 #define DEFAULT_FEATURE_DIGIT_TIMEOUT 500 +#define DEFAULT_NOANSWER_TIMEOUT_ATTENDED_TRANSFER 15000 #define AST_MAX_WATCHERS 256 @@ -96,6 +97,8 @@ static int adsipark; static int transferdigittimeout; static int featuredigittimeout; +static int atxfernoanswertimeout; + static char *registrar = "res_features"; /*!< Registrar for operations */ /* module and CLI command definitions */ @@ -722,7 +725,7 @@ static int builtin_atxfer(struct ast_channel *chan, struct ast_channel *peer, st l = strlen(xferto); snprintf(xferto + l, sizeof(xferto) - l, "@%s/n", transferer_real_context); /* append context */ newchan = ast_feature_request_and_dial(transferer, "Local", ast_best_codec(transferer->nativeformats), - xferto, 15000, &outstate, transferer->cid.cid_num, transferer->cid.cid_name); + xferto, atxfernoanswertimeout, &outstate, transferer->cid.cid_num, transferer->cid.cid_name); ast_indicate(transferer, -1); if (!newchan) { finishup(transferee); @@ -1986,6 +1989,7 @@ static int load_config(void) transferdigittimeout = DEFAULT_TRANSFER_DIGIT_TIMEOUT; featuredigittimeout = DEFAULT_FEATURE_DIGIT_TIMEOUT; + atxfernoanswertimeout = DEFAULT_NOANSWER_TIMEOUT_ATTENDED_TRANSFER; cfg = ast_config_load("features.conf"); if (cfg) { @@ -2022,6 +2026,12 @@ static int load_config(void) ast_log(LOG_WARNING, "%s is not a valid featuredigittimeout\n", var->value); featuredigittimeout = DEFAULT_FEATURE_DIGIT_TIMEOUT; } + } else if (!strcasecmp(var->name, "atxfernoanswertimeout")) { + if ((sscanf(var->value, "%d", &atxfernoanswertimeout) != 1) || (atxfernoanswertimeout < 1)) { + ast_log(LOG_WARNING, "%s is not a valid atxfernoanswertimeout\n", var->value); + atxfernoanswertimeout = DEFAULT_NOANSWER_TIMEOUT_ATTENDED_TRANSFER; + } else + atxfernoanswertimeout = atxfernoanswertimeout * 1000; } else if (!strcasecmp(var->name, "courtesytone")) { ast_copy_string(courtesytone, var->value, sizeof(courtesytone)); } else if (!strcasecmp(var->name, "parkedplay")) {