mirror of
https://github.com/asterisk/asterisk.git
synced 2025-10-23 21:19:09 +00:00
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@5157 65c4cc65-6c06-0410-ace0-fbb531ad65f3
129 lines
3.3 KiB
C
Executable File
129 lines
3.3 KiB
C
Executable File
/*
|
|
* Asterisk -- A telephony toolkit for Linux.
|
|
*
|
|
* Trivial application to playback a sound file
|
|
*
|
|
* Copyright (C) 1999-2005, Mark Spencer
|
|
*
|
|
* Mark Spencer <markster@digium.com>
|
|
*
|
|
* This program is free software, distributed under the terms of
|
|
* the GNU General Public License
|
|
*/
|
|
|
|
#include <asterisk/lock.h>
|
|
#include <asterisk/file.h>
|
|
#include <asterisk/logger.h>
|
|
#include <asterisk/channel.h>
|
|
#include <asterisk/pbx.h>
|
|
#include <asterisk/module.h>
|
|
#include <asterisk/translate.h>
|
|
#include <asterisk/utils.h>
|
|
#include <string.h>
|
|
#include <stdlib.h>
|
|
|
|
static char *tdesc = "Sound File Playback Application";
|
|
|
|
static char *app = "Playback";
|
|
|
|
static char *synopsis = "Play a file";
|
|
|
|
static char *descrip =
|
|
" 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"
|
|
"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"
|
|
"specified, the application will return immediately should the channel not be\n"
|
|
"off hook. Otherwise, unless 'noanswer' is specified, the channel channel will\n"
|
|
"be answered before the sound is played. Not all channels support playing\n"
|
|
"messages while still hook. Returns -1 if the channel was hung up. If the\n"
|
|
"file does not exist, will jump to priority n+101 if present.\n";
|
|
|
|
STANDARD_LOCAL_USER;
|
|
|
|
LOCAL_USER_DECL;
|
|
|
|
static int playback_exec(struct ast_channel *chan, void *data)
|
|
{
|
|
int res = 0;
|
|
struct localuser *u;
|
|
char *tmp = NULL;
|
|
char *options = NULL;
|
|
int option_skip=0;
|
|
int option_noanswer = 0;
|
|
char *stringp = NULL;
|
|
char *front = NULL, *back = NULL;
|
|
if (!data || ast_strlen_zero((char *)data) || !(tmp = ast_strdupa(data))) {
|
|
ast_log(LOG_WARNING, "Playback requires an argument (filename)\n");
|
|
return -1;
|
|
}
|
|
stringp = tmp;
|
|
strsep(&stringp, "|");
|
|
options = strsep(&stringp, "|");
|
|
if (options && !strcasecmp(options, "skip"))
|
|
option_skip = 1;
|
|
if (options && !strcasecmp(options, "noanswer"))
|
|
option_noanswer = 1;
|
|
LOCAL_USER_ADD(u);
|
|
if (chan->_state != AST_STATE_UP) {
|
|
if (option_skip) {
|
|
/* At the user's option, skip if the line is not up */
|
|
LOCAL_USER_REMOVE(u);
|
|
return 0;
|
|
} else if (!option_noanswer)
|
|
/* Otherwise answer unless we're supposed to send this while on-hook */
|
|
res = ast_answer(chan);
|
|
}
|
|
if (!res) {
|
|
ast_stopstream(chan);
|
|
front = tmp;
|
|
while (!res && front) {
|
|
if ((back = strchr(front, '&'))) {
|
|
*back = '\0';
|
|
back++;
|
|
}
|
|
res = ast_streamfile(chan, front, chan->language);
|
|
if (!res) {
|
|
res = ast_waitstream(chan, "");
|
|
ast_stopstream(chan);
|
|
} else {
|
|
ast_log(LOG_WARNING, "ast_streamfile failed on %s for %s\n", chan->name, (char *)data);
|
|
if (ast_exists_extension(chan, chan->context, chan->exten, chan->priority + 101, chan->cid.cid_num))
|
|
chan->priority+=100;
|
|
res = 0;
|
|
}
|
|
front = back;
|
|
}
|
|
}
|
|
LOCAL_USER_REMOVE(u);
|
|
return res;
|
|
}
|
|
|
|
int unload_module(void)
|
|
{
|
|
STANDARD_HANGUP_LOCALUSERS;
|
|
return ast_unregister_application(app);
|
|
}
|
|
|
|
int load_module(void)
|
|
{
|
|
return ast_register_application(app, playback_exec, synopsis, descrip);
|
|
}
|
|
|
|
char *description(void)
|
|
{
|
|
return tdesc;
|
|
}
|
|
|
|
int usecount(void)
|
|
{
|
|
int res;
|
|
STANDARD_USECOUNT(res);
|
|
return res;
|
|
}
|
|
|
|
char *key()
|
|
{
|
|
return ASTERISK_GPL_KEY;
|
|
}
|