mirror of
				https://github.com/asterisk/asterisk.git
				synced 2025-10-24 21:50:53 +00:00 
			
		
		
		
	issue #5640 with minor mods
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@6999 65c4cc65-6c06-0410-ace0-fbb531ad65f3
This commit is contained in:
		| @@ -1,5 +1,7 @@ | |||||||
| 2005-11-07  Kevin P. Fleming  <kpfleming@digium.com> | 2005-11-07  Kevin P. Fleming  <kpfleming@digium.com> | ||||||
|  |  | ||||||
|  | 	* apps/app_playback.c: upgrade to new arg/option API and implement priority jumping control | ||||||
|  |  | ||||||
| 	* apps/app_privacy.c: upgrade to new arg/option API and implement priority jumping control | 	* apps/app_privacy.c: upgrade to new arg/option API and implement priority jumping control | ||||||
|  |  | ||||||
| 	* apps/app_sendtext.c: upgrade to new arg/option API and implement priority jumping control | 	* apps/app_sendtext.c: upgrade to new arg/option API and implement priority jumping control | ||||||
|   | |||||||
| @@ -38,6 +38,8 @@ ASTERISK_FILE_VERSION(__FILE__, "$Revision$") | |||||||
| #include "asterisk/module.h" | #include "asterisk/module.h" | ||||||
| #include "asterisk/translate.h" | #include "asterisk/translate.h" | ||||||
| #include "asterisk/utils.h" | #include "asterisk/utils.h" | ||||||
|  | #include "asterisk/options.h" | ||||||
|  | #include "asterisk/app.h" | ||||||
|  |  | ||||||
| static char *tdesc = "Sound File Playback Application"; | static char *tdesc = "Sound File Playback Application"; | ||||||
|  |  | ||||||
| @@ -47,13 +49,19 @@ static char *synopsis = "Play a file"; | |||||||
|  |  | ||||||
| static char *descrip =  | static char *descrip =  | ||||||
| "  Playback(filename[&filename2...][|option]):  Plays back given filenames (do not put\n" | "  Playback(filename[&filename2...][|option]):  Plays back given filenames (do not put\n" | ||||||
| "extension). Options may also be  included following a pipe symbol. The 'skip'\n" | "extension). Options may also be included following a pipe symbol. The 'skip'\n" | ||||||
| "option causes the playback of the message to  be  skipped  if  the  channel\n" | "option causes the playback of the message to be skipped if the channel\n" | ||||||
| "is not in the 'up' state (i.e. it hasn't been  answered  yet. If 'skip' is \n" | "is not in the 'up' state (i.e. it hasn't been  answered  yet). If 'skip' is \n" | ||||||
| "specified, the application will return immediately should the channel not be\n" | "specified, the application will return immediately should the channel not be\n" | ||||||
| "off hook.  Otherwise, unless 'noanswer' is specified, the channel will\n" | "off hook.  Otherwise, unless 'noanswer' is specified, the channel will\n" | ||||||
| "be answered before the sound is played. Not all channels support playing\n" | "be answered before the sound is played. Not all channels support playing\n" | ||||||
| "messages while still hook. If the file does not exist, will jump to priority n+101 if present.\n"; | "messages while still on hook. If 'j' is specified, the application\n" | ||||||
|  | "will jump to priority n+101 if present when a file specified to be played\n" | ||||||
|  | "does not exist.\n" | ||||||
|  | "This application sets the following channel variable upon completion:\n" | ||||||
|  | " PLAYBACKSTATUS    The status of the playback attempt as a text string, one of\n" | ||||||
|  | "               SUCCESS | FAILED\n" | ||||||
|  | ; | ||||||
|  |  | ||||||
| STANDARD_LOCAL_USER; | STANDARD_LOCAL_USER; | ||||||
|  |  | ||||||
| @@ -61,14 +69,17 @@ LOCAL_USER_DECL; | |||||||
|  |  | ||||||
| static int playback_exec(struct ast_channel *chan, void *data) | static int playback_exec(struct ast_channel *chan, void *data) | ||||||
| { | { | ||||||
| 	int res = 0; | 	int res = 0, mres = 0; | ||||||
| 	struct localuser *u; | 	struct localuser *u; | ||||||
| 	char *tmp = NULL; | 	char *tmp = NULL; | ||||||
| 	char *options = NULL; |  | ||||||
| 	int option_skip=0; | 	int option_skip=0; | ||||||
| 	int option_noanswer = 0; | 	int option_noanswer = 0; | ||||||
| 	char *stringp = NULL; |  | ||||||
| 	char *front = NULL, *back = NULL; | 	char *front = NULL, *back = NULL; | ||||||
|  | 	int priority_jump = 0; | ||||||
|  | 	AST_DECLARE_APP_ARGS(args, | ||||||
|  | 		AST_APP_ARG(filenames); | ||||||
|  | 		AST_APP_ARG(options); | ||||||
|  | 	); | ||||||
| 	 | 	 | ||||||
| 	if (ast_strlen_zero(data)) { | 	if (ast_strlen_zero(data)) { | ||||||
| 		ast_log(LOG_WARNING, "Playback requires an argument (filename)\n"); | 		ast_log(LOG_WARNING, "Playback requires an argument (filename)\n"); | ||||||
| @@ -84,13 +95,16 @@ static int playback_exec(struct ast_channel *chan, void *data) | |||||||
| 		return -1;	 | 		return -1;	 | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	stringp = tmp; | 	AST_STANDARD_APP_ARGS(args, tmp); | ||||||
| 	strsep(&stringp, "|"); |  | ||||||
| 	options = strsep(&stringp, "|"); | 	if (args.options) { | ||||||
| 	if (options && !strcasecmp(options, "skip")) | 		if (!strcasestr(args.options, "skip")) | ||||||
| 		option_skip = 1; | 			option_skip = 1; | ||||||
| 	if (options && !strcasecmp(options, "noanswer")) | 		if (!strcasestr(args.options, "noanswer")) | ||||||
| 		option_noanswer = 1; | 			option_noanswer = 1; | ||||||
|  | 		if (strchr(args.options, 'j')) | ||||||
|  | 			priority_jump = 1; | ||||||
|  | 	} | ||||||
| 	 | 	 | ||||||
| 	if (chan->_state != AST_STATE_UP) { | 	if (chan->_state != AST_STATE_UP) { | ||||||
| 		if (option_skip) { | 		if (option_skip) { | ||||||
| @@ -115,11 +129,17 @@ static int playback_exec(struct ast_channel *chan, void *data) | |||||||
| 				ast_stopstream(chan); | 				ast_stopstream(chan); | ||||||
| 			} else { | 			} else { | ||||||
| 				ast_log(LOG_WARNING, "ast_streamfile failed on %s for %s\n", chan->name, (char *)data); | 				ast_log(LOG_WARNING, "ast_streamfile failed on %s for %s\n", chan->name, (char *)data); | ||||||
| 				ast_goto_if_exists(chan, chan->context, chan->exten, chan->priority + 101); | 				if (priority_jump || option_priority_jumping) | ||||||
|  | 					ast_goto_if_exists(chan, chan->context, chan->exten, chan->priority + 101); | ||||||
| 				res = 0; | 				res = 0; | ||||||
|  | 				mres = 1; | ||||||
| 			} | 			} | ||||||
| 			front = back; | 			front = back; | ||||||
| 		} | 		} | ||||||
|  | 		if (mres) | ||||||
|  | 			pbx_builtin_setvar_helper(chan, "PLAYBACKSTATUS", "FAILED"); | ||||||
|  | 		else | ||||||
|  | 			pbx_builtin_setvar_helper(chan, "PLAYBACKSTATUS", "SUCCESS"); | ||||||
| 	} | 	} | ||||||
| 	LOCAL_USER_REMOVE(u); | 	LOCAL_USER_REMOVE(u); | ||||||
| 	return res; | 	return res; | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user