Asterisk - The Open Source Telephony Project GIT-master-f36a736
Data Structures | Functions | Variables
app_playback.c File Reference

Trivial application to playback a sound file. More...

#include "asterisk.h"
#include "asterisk/file.h"
#include "asterisk/pbx.h"
#include "asterisk/module.h"
#include "asterisk/app.h"
#include "asterisk/say.h"
#include "asterisk/cli.h"
Include dependency graph for app_playback.c:

Go to the source code of this file.

Data Structures

struct  say_args_t
 Typical 'say' arguments in addition to the date or number or string to say. We do not include 'options' because they may be different in recursive calls, and so they are better left as an external parameter. More...
 

Functions

static void __reg_module (void)
 
static char * __say_cli_init (struct ast_cli_entry *e, int cmd, struct ast_cli_args *a)
 
static void __unreg_module (void)
 
struct ast_moduleAST_MODULE_SELF_SYM (void)
 
static int do_say (say_args_t *a, const char *s, const char *options, int depth)
 the string is 'prefix:data' or prefix:fmt:data' with ':' being invalid in strings. More...
 
static int load_module (void)
 
static int playback_exec (struct ast_channel *chan, const char *data)
 
static int reload (void)
 
static void restore_say_mode (void *arg)
 
static int s_streamwait3 (const say_args_t *a, const char *fn)
 
static void save_say_mode (const void *arg)
 
static int say_date (struct ast_channel *chan, time_t t, const char *ints, const char *lang)
 
static int say_date_generic (struct ast_channel *chan, time_t t, const char *ints, const char *lang, const char *format, const char *timezonename, const char *prefix)
 
static int say_date_with_format (struct ast_channel *chan, time_t t, const char *ints, const char *lang, const char *format, const char *timezonename)
 
static int say_datetime (struct ast_channel *chan, time_t t, const char *ints, const char *lang)
 
static int say_enumeration_full (struct ast_channel *chan, int num, const char *ints, const char *lang, const char *options, int audiofd, int ctrlfd)
 
static int say_full (struct ast_channel *chan, const char *string, const char *ints, const char *lang, const char *options, int audiofd, int ctrlfd)
 
static int say_init_mode (const char *mode)
 remap the 'say' functions to use those in this file More...
 
static int say_number_full (struct ast_channel *chan, int num, const char *ints, const char *lang, const char *options, int audiofd, int ctrlfd)
 
static int say_time (struct ast_channel *chan, time_t t, const char *ints, const char *lang)
 
static int unload_module (void)
 

Variables

static struct ast_module_info __mod_info = { .name = AST_MODULE, .flags = AST_MODFLAG_DEFAULT , .description = "Sound File Playback Application" , .key = "This paragraph is copyright (c) 2006 by Digium, Inc. \In order for your module to load, it must return this \key via a function called \"key\". Any code which \includes this paragraph must be licensed under the GNU \General Public License version 2 or later (at your \option). In addition to Digium's general reservations \of rights, Digium expressly reserves the right to \allow other parties to license this paragraph under \different terms. Any use of Digium, Inc. trademarks or \logos (including \"Asterisk\" or \"Digium\") without \express written permission of Digium, Inc. is prohibited.\n" , .buildopt_sum = AST_BUILDOPT_SUM, .support_level = AST_MODULE_SUPPORT_CORE, .load = load_module, .unload = unload_module, .reload = reload, }
 
static char * app = "Playback"
 
static const struct ast_module_infoast_module_info = &__mod_info
 
static struct ast_cli_entry cli_playback []
 
static const void * say_api_buf [40]
 save the say' api calls. The first entry is NULL if we have the standard source, otherwise we are sourcing from here. 'say load [new|old]' will enable the new or old method, or report status More...
 
static struct ast_configsay_cfg = NULL
 
static const char *const say_new = "new"
 
static const char *const say_old = "old"
 

Detailed Description

Trivial application to playback a sound file.

Author
Mark Spencer marks.nosp@m.ter@.nosp@m.digiu.nosp@m.m.co.nosp@m.m

Definition in file app_playback.c.

Function Documentation

◆ __reg_module()

static void __reg_module ( void  )
static

Definition at line 604 of file app_playback.c.

◆ __say_cli_init()

static char * __say_cli_init ( struct ast_cli_entry e,
int  cmd,
struct ast_cli_args a 
)
static

Definition at line 417 of file app_playback.c.

418{
419 const char *old_mode = say_api_buf[0] ? say_new : say_old;
420 const char *mode;
421 switch (cmd) {
422 case CLI_INIT:
423 e->command = "say load [new|old]";
424 e->usage =
425 "Usage: say load [new|old]\n"
426 " say load\n"
427 " Report status of current say mode\n"
428 " say load new\n"
429 " Set say method, configured in say.conf\n"
430 " say load old\n"
431 " Set old say method, coded in asterisk core\n";
432 return NULL;
433 case CLI_GENERATE:
434 return NULL;
435 }
436 if (a->argc == 2) {
437 ast_cli(a->fd, "say mode is [%s]\n", old_mode);
438 return CLI_SUCCESS;
439 } else if (a->argc != e->args)
440 return CLI_SHOWUSAGE;
441 mode = a->argv[2];
442 if (!strcmp(mode, old_mode))
443 ast_cli(a->fd, "say mode is %s already\n", mode);
444 else
445 if (say_init_mode(mode) == 0)
446 ast_cli(a->fd, "setting say mode from %s to %s\n", old_mode, mode);
447
448 return CLI_SUCCESS;
449}
static const char *const say_old
Definition: app_playback.c:117
static const void * say_api_buf[40]
save the say' api calls. The first entry is NULL if we have the standard source, otherwise we are sou...
Definition: app_playback.c:116
static const char *const say_new
Definition: app_playback.c:118
static int say_init_mode(const char *mode)
remap the 'say' functions to use those in this file
Definition: app_playback.c:382
#define CLI_SHOWUSAGE
Definition: cli.h:45
#define CLI_SUCCESS
Definition: cli.h:44
void ast_cli(int fd, const char *fmt,...)
Definition: clicompat.c:6
@ CLI_INIT
Definition: cli.h:152
@ CLI_GENERATE
Definition: cli.h:153
#define NULL
Definition: resample.c:96
int args
This gets set in ast_cli_register()
Definition: cli.h:185
char * command
Definition: cli.h:186
const char * usage
Definition: cli.h:177
static struct test_val a

References a, ast_cli_entry::args, ast_cli(), CLI_GENERATE, CLI_INIT, CLI_SHOWUSAGE, CLI_SUCCESS, ast_cli_entry::command, NULL, say_api_buf, say_init_mode(), say_new, say_old, and ast_cli_entry::usage.

◆ __unreg_module()

static void __unreg_module ( void  )
static

Definition at line 604 of file app_playback.c.

◆ AST_MODULE_SELF_SYM()

struct ast_module * AST_MODULE_SELF_SYM ( void  )

Definition at line 604 of file app_playback.c.

◆ do_say()

static int do_say ( say_args_t a,
const char *  s,
const char *  options,
int  depth 
)
static

the string is 'prefix:data' or prefix:fmt:data' with ':' being invalid in strings.

Definition at line 186 of file app_playback.c.

187{
188 struct ast_variable *v;
189 char *lang;
190 char *x;
191 char *rule = NULL;
192 char *rule_head = NULL;
193 int ret = 0;
194 struct varshead head = { .first = NULL, .last = NULL };
195 struct ast_var_t *n;
196
197 ast_debug(2, "string <%s> depth <%d>\n", s, depth);
198 if (depth++ > 10) {
199 ast_log(LOG_WARNING, "recursion too deep, exiting\n");
200 return -1;
201 } else if (!say_cfg) {
202 ast_log(LOG_WARNING, "no say.conf, cannot spell '%s'\n", s);
203 return -1;
204 }
205
206 /* scan languages same as in file.c */
207 if (a->language == NULL)
208 a->language = "en"; /* default */
209 ast_debug(2, "try <%s> in <%s>\n", s, a->language);
210 lang = ast_strdupa(a->language);
211 for (;;) {
212 for (v = ast_variable_browse(say_cfg, lang); v ; v = v->next) {
213 if (ast_extension_match(v->name, s)) {
214 rule_head = rule = ast_strdup(v->value);
215 break;
216 }
217 }
218 if (rule)
219 break;
220 if ( (x = strchr(lang, '_')) )
221 *x = '\0'; /* try without suffix */
222 else if (strcmp(lang, "en"))
223 lang = "en"; /* last resort, try 'en' if not done yet */
224 else
225 break;
226 }
227 if (!rule)
228 return 0;
229
230 /* skip up to two prefixes to get the value */
231 if ( (x = strchr(s, ':')) )
232 s = x + 1;
233 if ( (x = strchr(s, ':')) )
234 s = x + 1;
235 ast_debug(2, "value is <%s>\n", s);
236 n = ast_var_assign("SAY", s);
237 if (!n) {
238 ast_log(LOG_ERROR, "Memory allocation error in do_say\n");
239 ast_free(rule_head);
240 return -1;
241 }
242 AST_LIST_INSERT_HEAD(&head, n, entries);
243
244 /* scan the body, one piece at a time */
245 while ( !ret && (x = strsep(&rule, ",")) ) { /* exit on key */
246 char fn[128];
247 const char *p, *fmt, *data; /* format and data pointers */
248
249 /* prepare a decent file name */
250 x = ast_skip_blanks(x);
252
253 /* replace variables */
254 pbx_substitute_variables_varshead(&head, x, fn, sizeof(fn));
255 ast_debug(2, "doing [%s]\n", fn);
256
257 /* locate prefix and data, if any */
258 fmt = strchr(fn, ':');
259 if (!fmt || fmt == fn) { /* regular filename */
260 ret = s_streamwait3(a, fn);
261 continue;
262 }
263 fmt++;
264 data = strchr(fmt, ':'); /* colon before data */
265 if (!data || data == fmt) { /* simple prefix-fmt */
266 ret = do_say(a, fn, options, depth);
267 continue;
268 }
269 /* prefix:fmt:data */
270 for (p = fmt; p < data && ret <= 0; p++) {
271 char fn2[sizeof(fn)];
272 if (*p == ' ' || *p == '\t') /* skip blanks */
273 continue;
274 if (*p == '\'') {/* file name - we trim them */
275 char *y;
276 strcpy(fn2, ast_skip_blanks(p+1)); /* make a full copy */
277 y = strchr(fn2, '\'');
278 if (!y) {
279 p = data; /* invalid. prepare to end */
280 break;
281 }
282 *y = '\0';
283 ast_trim_blanks(fn2);
284 p = strchr(p+1, '\'');
285 ret = s_streamwait3(a, fn2);
286 } else {
287 int l = fmt-fn;
288 strcpy(fn2, fn); /* copy everything */
289 /* after prefix, append the format */
290 fn2[l++] = *p;
291 strcpy(fn2 + l, data);
292 ret = do_say(a, fn2, options, depth);
293 }
294
295 if (ret) {
296 break;
297 }
298 }
299 }
301 ast_free(rule_head);
302 return ret;
303}
static struct ast_config * say_cfg
Definition: app_playback.c:109
static int s_streamwait3(const say_args_t *a, const char *fn)
Definition: app_playback.c:168
static int do_say(say_args_t *a, const char *s, const char *options, int depth)
the string is 'prefix:data' or prefix:fmt:data' with ':' being invalid in strings.
Definition: app_playback.c:186
#define ast_free(a)
Definition: astmm.h:180
#define ast_strdup(str)
A wrapper for strdup()
Definition: astmm.h:241
#define ast_strdupa(s)
duplicate a string in memory from the stack
Definition: astmm.h:298
#define ast_log
Definition: astobj2.c:42
#define ast_var_assign(name, value)
Definition: chanvars.h:40
void ast_var_delete(struct ast_var_t *var)
Definition: extconf.c:2471
char * strsep(char **str, const char *delims)
struct ast_variable * ast_variable_browse(const struct ast_config *config, const char *category_name)
Definition: extconf.c:1215
#define ast_debug(level,...)
Log a DEBUG message.
#define LOG_ERROR
#define LOG_WARNING
#define AST_LIST_INSERT_HEAD(head, elm, field)
Inserts a list entry at the head of a list.
Definition: linkedlists.h:711
void pbx_substitute_variables_varshead(struct varshead *headp, const char *cp1, char *cp2, int count)
int ast_extension_match(const char *pattern, const char *extension)
Determine if a given extension matches a given pattern (in NXX format)
Definition: extconf.c:4295
char * ast_trim_blanks(char *str)
Trims trailing whitespace characters from a string.
Definition: strings.h:186
char * ast_skip_blanks(const char *str)
Gets a pointer to the first non-whitespace character in a string.
Definition: strings.h:161
struct ast_var_t::@211 entries
Structure for variables, used for configurations and for channel variables.
struct ast_variable * next
struct ast_var_t * first
Definition: chanvars.h:34
static struct test_options options

References a, ast_debug, ast_extension_match(), ast_free, AST_LIST_INSERT_HEAD, ast_log, ast_skip_blanks(), ast_strdup, ast_strdupa, ast_trim_blanks(), ast_var_assign, ast_var_delete(), ast_variable_browse(), do_say(), ast_var_t::entries, varshead::first, LOG_ERROR, LOG_WARNING, ast_variable::name, ast_variable::next, NULL, options, pbx_substitute_variables_varshead(), s_streamwait3(), say_cfg, strsep(), and ast_variable::value.

Referenced by do_say(), say_date_generic(), say_enumeration_full(), say_full(), and say_number_full().

◆ load_module()

static int load_module ( void  )
static

Definition at line 580 of file app_playback.c.

581{
582 struct ast_variable *v;
583 struct ast_flags config_flags = { 0 };
584
585 say_cfg = ast_config_load("say.conf", config_flags);
587 for (v = ast_variable_browse(say_cfg, "general"); v ; v = v->next) {
588 if (ast_extension_match(v->name, "mode")) {
590 break;
591 }
592 }
593 }
594
597}
static char * app
Definition: app_playback.c:107
static struct ast_cli_entry cli_playback[]
Definition: app_playback.c:451
static int playback_exec(struct ast_channel *chan, const char *data)
Definition: app_playback.c:455
#define ast_cli_register_multiple(e, len)
Register multiple commands.
Definition: cli.h:265
#define ast_config_load(filename, flags)
Load a config file.
#define CONFIG_STATUS_FILEINVALID
#define ast_register_application_xml(app, execute)
Register an application using XML documentation.
Definition: module.h:640
Structure used to handle boolean flags.
Definition: utils.h:199
#define ARRAY_LEN(a)
Definition: utils.h:666

References app, ARRAY_LEN, ast_cli_register_multiple, ast_config_load, ast_extension_match(), ast_register_application_xml, ast_variable_browse(), cli_playback, CONFIG_STATUS_FILEINVALID, ast_variable::name, ast_variable::next, playback_exec(), say_cfg, say_init_mode(), and ast_variable::value.

◆ playback_exec()

static int playback_exec ( struct ast_channel chan,
const char *  data 
)
static

Definition at line 455 of file app_playback.c.

456{
457 int res = 0;
458 int mres = 0;
459 char *tmp;
460 int option_skip=0;
461 int option_say=0;
462 int option_mix=0;
463 int option_noanswer = 0;
464
466 AST_APP_ARG(filenames);
468 );
469
470 if (ast_strlen_zero(data)) {
471 ast_log(LOG_WARNING, "Playback requires an argument (filename)\n");
472 return -1;
473 }
474
475 tmp = ast_strdupa(data);
477
478 if (args.options) {
479 if (strcasestr(args.options, "skip"))
480 option_skip = 1;
481 if (strcasestr(args.options, "say"))
482 option_say = 1;
483 if (strcasestr(args.options, "mix"))
484 option_mix = 1;
485 if (strcasestr(args.options, "noanswer"))
486 option_noanswer = 1;
487 }
488 if (ast_channel_state(chan) != AST_STATE_UP) {
489 if (option_skip) {
490 /* At the user's option, skip if the line is not up */
491 goto done;
492 } else if (!option_noanswer) {
493 /* Otherwise answer unless we're supposed to send this while on-hook */
494 res = ast_answer(chan);
495 }
496 }
497 if (!res) {
498 char *back = args.filenames;
499 char *front;
500
501 ast_stopstream(chan);
502 while (!res && (front = ast_strsep(&back, '&', AST_STRSEP_STRIP | AST_STRSEP_TRIM))) {
503 if (option_say)
504 res = say_full(chan, front, "", ast_channel_language(chan), NULL, -1, -1);
505 else if (option_mix){
506 /* Check if it is in say format but not remote audio file */
507 if (strcasestr(front, ":") && !strcasestr(front, "://"))
508 res = say_full(chan, front, "", ast_channel_language(chan), NULL, -1, -1);
509 else
510 res = ast_streamfile(chan, front, ast_channel_language(chan));
511 }
512 else
513 res = ast_streamfile(chan, front, ast_channel_language(chan));
514 if (!res) {
515 res = ast_waitstream(chan, "");
516 ast_stopstream(chan);
517 } else {
518 if (!ast_check_hangup(chan)) {
519 ast_log(LOG_WARNING, "Playback failed on %s for %s\n", ast_channel_name(chan), (char *)data);
520 }
521 res = 0;
522 mres = 1;
523 }
524 }
525 }
526done:
527 pbx_builtin_setvar_helper(chan, "PLAYBACKSTATUS", mres ? "FAILED" : "SUCCESS");
528 return res;
529}
static int say_full(struct ast_channel *chan, const char *string, const char *ints, const char *lang, const char *options, int audiofd, int ctrlfd)
Definition: app_playback.c:305
static int tmp()
Definition: bt_open.c:389
const char * ast_channel_name(const struct ast_channel *chan)
int ast_check_hangup(struct ast_channel *chan)
Check to see if a channel is needing hang up.
Definition: channel.c:445
const char * ast_channel_language(const struct ast_channel *chan)
int ast_answer(struct ast_channel *chan)
Answer a channel.
Definition: channel.c:2824
ast_channel_state
ast_channel states
Definition: channelstate.h:35
@ AST_STATE_UP
Definition: channelstate.h:42
int ast_stopstream(struct ast_channel *c)
Stops a stream.
Definition: file.c:222
int ast_streamfile(struct ast_channel *c, const char *filename, const char *preflang)
Streams a file.
Definition: file.c:1293
int ast_waitstream(struct ast_channel *c, const char *breakon)
Waits for a stream to stop or digit to be pressed.
Definition: file.c:1840
#define AST_APP_ARG(name)
Define an application argument.
#define AST_DECLARE_APP_ARGS(name, arglist)
Declare a structure to hold an application's arguments.
#define AST_STANDARD_APP_ARGS(args, parse)
Performs the 'standard' argument separation process for an application.
char * strcasestr(const char *, const char *)
int pbx_builtin_setvar_helper(struct ast_channel *chan, const char *name, const char *value)
Add a variable to the channel variable stack, removing the most recently set value for the same name.
static force_inline int attribute_pure ast_strlen_zero(const char *s)
Definition: strings.h:65
@ AST_STRSEP_TRIM
Definition: strings.h:256
@ AST_STRSEP_STRIP
Definition: strings.h:255
char * ast_strsep(char **s, const char sep, uint32_t flags)
Act like strsep but ignore separators inside quotes.
Definition: utils.c:1835
int done
Definition: test_amihooks.c:48
const char * args

References args, ast_answer(), AST_APP_ARG, ast_channel_language(), ast_channel_name(), ast_check_hangup(), AST_DECLARE_APP_ARGS, ast_log, AST_STANDARD_APP_ARGS, AST_STATE_UP, ast_stopstream(), ast_strdupa, ast_streamfile(), ast_strlen_zero(), ast_strsep(), AST_STRSEP_STRIP, AST_STRSEP_TRIM, ast_waitstream(), done, LOG_WARNING, NULL, options, pbx_builtin_setvar_helper(), say_full(), strcasestr(), and tmp().

Referenced by load_module().

◆ reload()

static int reload ( void  )
static
Todo:
XXX here we should sort rules according to the same order we have in pbx.c so we have the same matching behaviour.

Definition at line 531 of file app_playback.c.

532{
533 struct ast_variable *v;
534 struct ast_flags config_flags = { CONFIG_FLAG_FILEUNCHANGED };
535 struct ast_config *newcfg;
536
537 if ((newcfg = ast_config_load("say.conf", config_flags)) == CONFIG_STATUS_FILEUNCHANGED) {
538 return 0;
539 } else if (newcfg == CONFIG_STATUS_FILEINVALID) {
540 ast_log(LOG_ERROR, "Config file say.conf is in an invalid format. Aborting.\n");
541 return 0;
542 }
543
544 if (say_cfg) {
546 ast_log(LOG_NOTICE, "Reloading say.conf\n");
547 }
548 say_cfg = newcfg;
549
550 if (say_cfg) {
551 for (v = ast_variable_browse(say_cfg, "general"); v ; v = v->next) {
552 if (ast_extension_match(v->name, "mode")) {
554 break;
555 }
556 }
557 }
558
559 /*! \todo
560 * XXX here we should sort rules according to the same order
561 * we have in pbx.c so we have the same matching behaviour.
562 */
563 return 0;
564}
#define CONFIG_STATUS_FILEUNCHANGED
void ast_config_destroy(struct ast_config *cfg)
Destroys a config.
Definition: extconf.c:1289
@ CONFIG_FLAG_FILEUNCHANGED
#define LOG_NOTICE

References ast_config_destroy(), ast_config_load, ast_extension_match(), ast_log, ast_variable_browse(), CONFIG_FLAG_FILEUNCHANGED, CONFIG_STATUS_FILEINVALID, CONFIG_STATUS_FILEUNCHANGED, LOG_ERROR, LOG_NOTICE, ast_variable::name, ast_variable::next, say_cfg, say_init_mode(), and ast_variable::value.

◆ restore_say_mode()

static void restore_say_mode ( void *  arg)
static

Definition at line 137 of file app_playback.c.

138{
139 int i = 0;
140 say_api_buf[i++] = arg;
141
152}
SAY_EXTERN int(* ast_say_datetime_from_now)(struct ast_channel *chan, time_t t, const char *ints, const char *lang) SAY_INIT(ast_say_datetime_from_now)
Definition: say.h:206
SAY_EXTERN int(* ast_say_date)(struct ast_channel *chan, time_t t, const char *ints, const char *lang) SAY_INIT(ast_say_date)
Definition: say.h:204
SAY_EXTERN int(* ast_say_number_full)(struct ast_channel *chan, int num, const char *ints, const char *lang, const char *options, int audiofd, int ctrlfd) SAY_INIT(ast_say_number_full)
Same as ast_say_number() with audiofd for received audio and returns 1 on ctrlfd being readable.
Definition: say.h:86
SAY_EXTERN int(* ast_say_enumeration_full)(struct ast_channel *chan, int num, const char *ints, const char *lang, const char *options, int audiofd, int ctrlfd) SAY_INIT(ast_say_enumeration_full)
Same as ast_say_enumeration() with audiofd for received audio and returns 1 on ctrlfd being readable.
Definition: say.h:125
SAY_EXTERN int(* ast_say_character_str_full)(struct ast_channel *chan, const char *num, const char *ints, const char *lang, enum ast_say_case_sensitivity sensitivity, int audiofd, int ctrlfd) SAY_INIT(ast_say_character_str_full)
Definition: say.h:194
SAY_EXTERN int(* ast_say_date_with_format)(struct ast_channel *chan, time_t t, const char *ints, const char *lang, const char *format, const char *timezone) SAY_INIT(ast_say_date_with_format)
Definition: say.h:208
SAY_EXTERN int(* ast_say_digit_str_full)(struct ast_channel *chan, const char *num, const char *ints, const char *lang, int audiofd, int ctrlfd) SAY_INIT(ast_say_digit_str_full)
Same as ast_say_digit_str() with audiofd for received audio and returns 1 on ctrlfd being readable.
Definition: say.h:162
SAY_EXTERN int(* ast_say_time)(struct ast_channel *chan, time_t t, const char *ints, const char *lang) SAY_INIT(ast_say_time)
Definition: say.h:202
SAY_EXTERN int(* ast_say_phonetic_str_full)(struct ast_channel *chan, const char *num, const char *ints, const char *lang, int audiofd, int ctrlfd) SAY_INIT(ast_say_phonetic_str_full)
Definition: say.h:199
SAY_EXTERN int(* ast_say_datetime)(struct ast_channel *chan, time_t t, const char *ints, const char *lang) SAY_INIT(ast_say_datetime)
Definition: say.h:201

References ast_say_character_str_full, ast_say_date, ast_say_date_with_format, ast_say_datetime, ast_say_datetime_from_now, ast_say_digit_str_full, ast_say_enumeration_full, ast_say_number_full, ast_say_phonetic_str_full, ast_say_time, and say_api_buf.

Referenced by say_init_mode().

◆ s_streamwait3()

static int s_streamwait3 ( const say_args_t a,
const char *  fn 
)
static

Definition at line 168 of file app_playback.c.

169{
170 int res = ast_streamfile(a->chan, fn, a->language);
171 if (res) {
172 ast_log(LOG_WARNING, "Unable to play message %s\n", fn);
173 return res;
174 }
175 res = (a->audiofd > -1 && a->ctrlfd > -1) ?
176 ast_waitstream_full(a->chan, a->ints, a->audiofd, a->ctrlfd) :
177 ast_waitstream(a->chan, a->ints);
178 ast_stopstream(a->chan);
179 return res;
180}
int ast_waitstream_full(struct ast_channel *c, const char *breakon, int audiofd, int monfd)
Definition: file.c:1849

References a, ast_log, ast_stopstream(), ast_streamfile(), ast_waitstream(), ast_waitstream_full(), and LOG_WARNING.

Referenced by do_say().

◆ save_say_mode()

static void save_say_mode ( const void *  arg)
static

◆ say_date()

static int say_date ( struct ast_channel chan,
time_t  t,
const char *  ints,
const char *  lang 
)
static

Definition at line 364 of file app_playback.c.

365{
366 return say_date_generic(chan, t, ints, lang, "", NULL, "date");
367}
static int say_date_generic(struct ast_channel *chan, time_t t, const char *ints, const char *lang, const char *format, const char *timezonename, const char *prefix)
Definition: app_playback.c:333

References NULL, and say_date_generic().

Referenced by say_init_mode().

◆ say_date_generic()

static int say_date_generic ( struct ast_channel chan,
time_t  t,
const char *  ints,
const char *  lang,
const char *  format,
const char *  timezonename,
const char *  prefix 
)
static

Definition at line 333 of file app_playback.c.

335{
336 char buf[128];
337 struct ast_tm tm;
338 struct timeval when = { t, 0 };
339 say_args_t a = { chan, ints, lang, -1, -1 };
340 if (format == NULL)
341 format = "";
342
343 ast_localtime(&when, &tm, timezonename);
344 snprintf(buf, sizeof(buf), "%s:%s:%04d%02d%02d%02d%02d.%02d-%d-%3d",
345 prefix,
346 format,
347 tm.tm_year+1900,
348 tm.tm_mon+1,
349 tm.tm_mday,
350 tm.tm_hour,
351 tm.tm_min,
352 tm.tm_sec,
353 tm.tm_wday,
354 tm.tm_yday);
355 return do_say(&a, buf, NULL, 0);
356}
char buf[BUFSIZE]
Definition: eagi_proxy.c:66
static char prefix[MAX_PREFIX]
Definition: http.c:144
struct ast_tm * ast_localtime(const struct timeval *timep, struct ast_tm *p_tm, const char *zone)
Timezone-independent version of localtime_r(3).
Definition: localtime.c:1739
Typical 'say' arguments in addition to the date or number or string to say. We do not include 'option...
Definition: app_playback.c:160

References a, ast_localtime(), buf, do_say(), NULL, prefix, ast_tm::tm_hour, ast_tm::tm_mday, ast_tm::tm_min, ast_tm::tm_mon, ast_tm::tm_sec, ast_tm::tm_wday, ast_tm::tm_yday, and ast_tm::tm_year.

Referenced by say_date(), say_date_with_format(), say_datetime(), and say_time().

◆ say_date_with_format()

static int say_date_with_format ( struct ast_channel chan,
time_t  t,
const char *  ints,
const char *  lang,
const char *  format,
const char *  timezonename 
)
static

Definition at line 358 of file app_playback.c.

360{
361 return say_date_generic(chan, t, ints, lang, format, timezonename, "datetime");
362}

References say_date_generic().

Referenced by say_init_mode().

◆ say_datetime()

static int say_datetime ( struct ast_channel chan,
time_t  t,
const char *  ints,
const char *  lang 
)
static

Definition at line 374 of file app_playback.c.

375{
376 return say_date_generic(chan, t, ints, lang, "", NULL, "datetime");
377}

References NULL, and say_date_generic().

Referenced by say_init_mode().

◆ say_enumeration_full()

static int say_enumeration_full ( struct ast_channel chan,
int  num,
const char *  ints,
const char *  lang,
const char *  options,
int  audiofd,
int  ctrlfd 
)
static

Definition at line 323 of file app_playback.c.

326{
327 char buf[64];
328 say_args_t a = { chan, ints, lang, audiofd, ctrlfd };
329 snprintf(buf, sizeof(buf), "enum:%d", num);
330 return do_say(&a, buf, options, 0);
331}

References a, buf, do_say(), and options.

Referenced by say_init_mode().

◆ say_full()

static int say_full ( struct ast_channel chan,
const char *  string,
const char *  ints,
const char *  lang,
const char *  options,
int  audiofd,
int  ctrlfd 
)
static

Definition at line 305 of file app_playback.c.

308{
309 say_args_t a = { chan, ints, lang, audiofd, ctrlfd };
310 return do_say(&a, string, options, 0);
311}

References a, do_say(), and options.

Referenced by playback_exec().

◆ say_init_mode()

static int say_init_mode ( const char *  mode)
static

remap the 'say' functions to use those in this file

Definition at line 382 of file app_playback.c.

382 {
383 if (!strcmp(mode, say_new)) {
384 if (say_cfg == NULL) {
385 ast_log(LOG_ERROR, "There is no say.conf file to use new mode\n");
386 return -1;
387 }
390
392#if 0
393 /*! \todo XXX
394 These functions doesn't exist.
395 say.conf.sample indicates this is working...
396 */
397 ast_say_digits_full = say_digits_full;
402#endif
407 } else if (!strcmp(mode, say_old) && say_api_buf[0] == say_new) {
409 } else if (strcmp(mode, say_old)) {
410 ast_log(LOG_WARNING, "unrecognized mode %s\n", mode);
411 return -1;
412 }
413
414 return 0;
415}
static int say_time(struct ast_channel *chan, time_t t, const char *ints, const char *lang)
Definition: app_playback.c:369
static void restore_say_mode(void *arg)
Definition: app_playback.c:137
static int say_date_with_format(struct ast_channel *chan, time_t t, const char *ints, const char *lang, const char *format, const char *timezonename)
Definition: app_playback.c:358
static int say_enumeration_full(struct ast_channel *chan, int num, const char *ints, const char *lang, const char *options, int audiofd, int ctrlfd)
Definition: app_playback.c:323
static void save_say_mode(const void *arg)
Definition: app_playback.c:120
static int say_number_full(struct ast_channel *chan, int num, const char *ints, const char *lang, const char *options, int audiofd, int ctrlfd)
Definition: app_playback.c:313
static int say_datetime(struct ast_channel *chan, time_t t, const char *ints, const char *lang)
Definition: app_playback.c:374
static int say_date(struct ast_channel *chan, time_t t, const char *ints, const char *lang)
Definition: app_playback.c:364
static int say_datetime_from_now(struct ast_channel *chan, time_t t, const char *ints, const char *lang)
Definition: say.c:7994
static int say_digit_str_full(struct ast_channel *chan, const char *str, const char *ints, const char *lang, int audiofd, int ctrlfd)
Definition: say.c:348
static int say_phonetic_str_full(struct ast_channel *chan, const char *str, const char *ints, const char *lang, int audiofd, int ctrlfd)
Definition: say.c:294
static int say_character_str_full(struct ast_channel *chan, const char *str, const char *ints, const char *lang, enum ast_say_case_sensitivity sensitivity, int audiofd, int ctrlfd)
Definition: say.c:210
int ast_say_digits_full(struct ast_channel *chan, int num, const char *ints, const char *lang, int audiofd, int ctrlfd)
Same as ast_say_digits() with audiofd for received audio and returns 1 on ctrlfd being readable.
Definition: channel.c:8305

References ast_log, ast_say_character_str_full, ast_say_date, ast_say_date_with_format, ast_say_datetime, ast_say_datetime_from_now, ast_say_digit_str_full, ast_say_digits_full(), ast_say_enumeration_full, ast_say_number_full, ast_say_phonetic_str_full, ast_say_time, LOG_ERROR, LOG_WARNING, NULL, restore_say_mode(), save_say_mode(), say_api_buf, say_cfg, say_character_str_full(), say_date(), say_date_with_format(), say_datetime(), say_datetime_from_now(), say_digit_str_full(), say_enumeration_full(), say_new, say_number_full(), say_old, say_phonetic_str_full(), and say_time().

Referenced by __say_cli_init(), load_module(), and reload().

◆ say_number_full()

static int say_number_full ( struct ast_channel chan,
int  num,
const char *  ints,
const char *  lang,
const char *  options,
int  audiofd,
int  ctrlfd 
)
static

Definition at line 313 of file app_playback.c.

316{
317 char buf[64];
318 say_args_t a = { chan, ints, lang, audiofd, ctrlfd };
319 snprintf(buf, sizeof(buf), "num:%d", num);
320 return do_say(&a, buf, options, 0);
321}

References a, buf, do_say(), and options.

Referenced by say_init_mode().

◆ say_time()

static int say_time ( struct ast_channel chan,
time_t  t,
const char *  ints,
const char *  lang 
)
static

Definition at line 369 of file app_playback.c.

370{
371 return say_date_generic(chan, t, ints, lang, "", NULL, "time");
372}

References NULL, and say_date_generic().

Referenced by say_init_mode().

◆ unload_module()

static int unload_module ( void  )
static

Definition at line 566 of file app_playback.c.

567{
568 int res;
569
571
573
574 if (say_cfg)
576
577 return res;
578}
int ast_cli_unregister_multiple(struct ast_cli_entry *e, int len)
Unregister multiple commands.
Definition: clicompat.c:30
int ast_unregister_application(const char *app)
Unregister an application.
Definition: pbx_app.c:392

References app, ARRAY_LEN, ast_cli_unregister_multiple(), ast_config_destroy(), ast_unregister_application(), cli_playback, and say_cfg.

Variable Documentation

◆ __mod_info

struct ast_module_info __mod_info = { .name = AST_MODULE, .flags = AST_MODFLAG_DEFAULT , .description = "Sound File Playback Application" , .key = "This paragraph is copyright (c) 2006 by Digium, Inc. \In order for your module to load, it must return this \key via a function called \"key\". Any code which \includes this paragraph must be licensed under the GNU \General Public License version 2 or later (at your \option). In addition to Digium's general reservations \of rights, Digium expressly reserves the right to \allow other parties to license this paragraph under \different terms. Any use of Digium, Inc. trademarks or \logos (including \"Asterisk\" or \"Digium\") without \express written permission of Digium, Inc. is prohibited.\n" , .buildopt_sum = AST_BUILDOPT_SUM, .support_level = AST_MODULE_SUPPORT_CORE, .load = load_module, .unload = unload_module, .reload = reload, }
static

Definition at line 604 of file app_playback.c.

◆ app

char* app = "Playback"
static

< provides config-file based 'say' functions

Definition at line 107 of file app_playback.c.

Referenced by load_module(), and unload_module().

◆ ast_module_info

const struct ast_module_info* ast_module_info = &__mod_info
static

Definition at line 604 of file app_playback.c.

◆ cli_playback

struct ast_cli_entry cli_playback[]
static
Initial value:
= {
{ .handler = __say_cli_init , .summary = "Set or show the say mode" ,},
}
static char * __say_cli_init(struct ast_cli_entry *e, int cmd, struct ast_cli_args *a)
Definition: app_playback.c:417

Definition at line 451 of file app_playback.c.

Referenced by load_module(), and unload_module().

◆ say_api_buf

const void* say_api_buf[40]
static

save the say' api calls. The first entry is NULL if we have the standard source, otherwise we are sourcing from here. 'say load [new|old]' will enable the new or old method, or report status

Definition at line 116 of file app_playback.c.

Referenced by __say_cli_init(), restore_say_mode(), save_say_mode(), and say_init_mode().

◆ say_cfg

struct ast_config* say_cfg = NULL
static

Definition at line 109 of file app_playback.c.

Referenced by do_say(), load_module(), reload(), say_init_mode(), and unload_module().

◆ say_new

const char* const say_new = "new"
static

Definition at line 118 of file app_playback.c.

Referenced by __say_cli_init(), and say_init_mode().

◆ say_old

const char* const say_old = "old"
static

Definition at line 117 of file app_playback.c.

Referenced by __say_cli_init(), and say_init_mode().