From: Joshua Colp Date: Fri, 13 Feb 2009 16:41:15 +0000 (+0000) Subject: Add an option to keep the recorded file upon hangup. X-Git-Tag: 1.6.2.0-beta1~234 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=0cfdaa2dc0eca1f6958caca19f07006cfc2b45e4;p=thirdparty%2Fasterisk.git Add an option to keep the recorded file upon hangup. (closes issue #14341) Reported by: fnordian git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@175549 65c4cc65-6c06-0410-ace0-fbb531ad65f3 --- diff --git a/apps/app_record.c b/apps/app_record.c index 8713563f0f..69bbd53876 100644 --- a/apps/app_record.c +++ b/apps/app_record.c @@ -75,6 +75,9 @@ ASTERISK_FILE_VERSION(__FILE__, "$Revision$") + @@ -112,11 +115,13 @@ enum { OPTION_SKIP = (1 << 3), OPTION_STAR_TERMINATE = (1 << 4), OPTION_IGNORE_TERMINATE = (1 << 5), - FLAG_HAS_PERCENT = (1 << 6), + OPTION_KEEP = (1 << 6), + FLAG_HAS_PERCENT = (1 << 7), }; AST_APP_OPTIONS(app_opts,{ AST_APP_OPTION('a', OPTION_APPEND), + AST_APP_OPTION('k', OPTION_KEEP), AST_APP_OPTION('n', OPTION_NOANSWER), AST_APP_OPTION('q', OPTION_QUIET), AST_APP_OPTION('s', OPTION_SKIP), @@ -378,7 +383,9 @@ static int record_exec(struct ast_channel *chan, void *data) ast_debug(1, "Got hangup\n"); res = -1; pbx_builtin_setvar_helper(chan, "RECORD_STATUS", "HANGUP"); - ast_filedelete(args.filename, NULL); + if (!ast_test_flag(&flags, OPTION_KEEP)) { + ast_filedelete(args.filename, NULL); + } } if (gotsilence) {