]> git.ipfire.org Git - thirdparty/asterisk.git/commitdiff
app_chanisavail/cdr: ChanIsAvail sometimes fails to deactivate CDR.
authorFrederic LE FOLL <frederic.lefoll@c-s.fr>
Wed, 27 Nov 2019 17:34:24 +0000 (18:34 +0100)
committerFrederic LE FOLL <frederic.lefoll@c-s.fr>
Mon, 16 Dec 2019 21:02:49 +0000 (15:02 -0600)
Temporary channel lifespan is very short and CDR deactivation request
through ast_cdr_set_property() may happen when CDR is not available
yet. Use CDR_PROP() dialplan function instead, it will first wait
for pending CDR insertion requests to be processed.

ASTERISK-28636

Change-Id: I1cbe09e8d2169c0962c1195133ff260d291f2074

apps/app_chanisavail.c

index 446bce1b01d181f6ffed9f65eda359500b831d40..1c7c1ec3bf79993f07c2bd2ac807b7439154ef47 100644 (file)
@@ -134,6 +134,8 @@ static int chanavail_exec(struct ast_channel *chan, const char *data)
        }
        peers = args.reqchans;
        if (peers) {
+               struct ast_custom_function *cdr_prop_func = ast_custom_function_find("CDR_PROP");
+
                cur = peers;
                do {
                        /* remember where to start next time */
@@ -179,7 +181,9 @@ static int chanavail_exec(struct ast_channel *chan, const char *data)
                                        ast_str_append(&tmp_availcause, 0, "%s%s", ast_str_strlen(tmp_availcause) ? "&" : "", tmp);
 
                                        /* Disable CDR for this temporary channel. */
-                                       ast_cdr_set_property(ast_channel_name(tempchan), AST_CDR_FLAG_DISABLE_ALL);
+                                       if (cdr_prop_func) {
+                                               ast_func_write(tempchan, "CDR_PROP(disable)", "1");
+                                       }
 
                                        ast_hangup(tempchan);
                                        tempchan = NULL;
@@ -212,4 +216,9 @@ static int load_module(void)
                AST_MODULE_LOAD_DECLINE : AST_MODULE_LOAD_SUCCESS;
 }
 
-AST_MODULE_INFO_STANDARD_EXTENDED(ASTERISK_GPL_KEY, "Check channel availability");
+AST_MODULE_INFO(ASTERISK_GPL_KEY, AST_MODFLAG_DEFAULT, "Check channel availability",
+       .support_level = AST_MODULE_SUPPORT_EXTENDED,
+       .load = load_module,
+       .unload = unload_module,
+       .optional_modules = "func_cdr"
+);