mirror of https://github.com/asterisk/asterisk
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
143 lines
3.8 KiB
143 lines
3.8 KiB
/*
|
|
* Asterisk -- An open source telephony toolkit.
|
|
*
|
|
* Copyright (c) 2003, 2006 Tilghman Lesher. All rights reserved.
|
|
* Copyright (c) 2006 Digium, Inc.
|
|
*
|
|
* Tilghman Lesher <app_sayunixtime__200309@the-tilghman.com>
|
|
*
|
|
* This code is released by the author with no restrictions on usage.
|
|
*
|
|
* See http://www.asterisk.org for more information about
|
|
* the Asterisk project. Please do not directly contact
|
|
* any of the maintainers of this project for assistance;
|
|
* the project provides a web site, mailing lists and IRC
|
|
* channels for your use.
|
|
*
|
|
*/
|
|
|
|
/*! \file
|
|
*
|
|
* \brief SayUnixTime application
|
|
*
|
|
* \author Tilghman Lesher <app_sayunixtime__200309@the-tilghman.com>
|
|
*
|
|
* \ingroup applications
|
|
*/
|
|
|
|
#include "asterisk.h"
|
|
|
|
ASTERISK_FILE_VERSION(__FILE__, "$Revision$")
|
|
|
|
#include "asterisk/file.h"
|
|
#include "asterisk/channel.h"
|
|
#include "asterisk/pbx.h"
|
|
#include "asterisk/module.h"
|
|
#include "asterisk/say.h"
|
|
#include "asterisk/app.h"
|
|
|
|
/*** DOCUMENTATION
|
|
<application name="SayUnixTime" language="en_US">
|
|
<synopsis>
|
|
Says a specified time in a custom format.
|
|
</synopsis>
|
|
<syntax>
|
|
<parameter name="unixtime">
|
|
<para>time, in seconds since Jan 1, 1970. May be negative. Defaults to now.</para>
|
|
</parameter>
|
|
<parameter name="timezone">
|
|
<para>timezone, see <directory>/usr/share/zoneinfo</directory> for a list. Defaults to machine default.</para>
|
|
</parameter>
|
|
<parameter name="format">
|
|
<para>a format the time is to be said in. See <filename>voicemail.conf</filename>.
|
|
Defaults to <literal>ABdY "digits/at" IMp</literal></para>
|
|
</parameter>
|
|
</syntax>
|
|
<description>
|
|
<para>Uses some of the sound files stored in <directory>/var/lib/asterisk/sounds</directory> to construct a phrase
|
|
saying the specified date and/or time in the specified format. </para>
|
|
</description>
|
|
<see-also>
|
|
<ref type="function">STRFTIME</ref>
|
|
<ref type="function">STRPTIME</ref>
|
|
<ref type="function">IFTIME</ref>
|
|
</see-also>
|
|
</application>
|
|
<application name="DateTime" language="en_US">
|
|
<synopsis>
|
|
Says a specified time in a custom format.
|
|
</synopsis>
|
|
<syntax>
|
|
<parameter name="unixtime">
|
|
<para>time, in seconds since Jan 1, 1970. May be negative. Defaults to now.</para>
|
|
</parameter>
|
|
<parameter name="timezone">
|
|
<para>timezone, see <filename>/usr/share/zoneinfo</filename> for a list. Defaults to machine default.</para>
|
|
</parameter>
|
|
<parameter name="format">
|
|
<para>a format the time is to be said in. See <filename>voicemail.conf</filename>.
|
|
Defaults to <literal>ABdY "digits/at" IMp</literal></para>
|
|
</parameter>
|
|
</syntax>
|
|
<description>
|
|
<para>Say the date and time in a specified format.</para>
|
|
</description>
|
|
</application>
|
|
|
|
***/
|
|
|
|
static char *app_sayunixtime = "SayUnixTime";
|
|
static char *app_datetime = "DateTime";
|
|
|
|
static int sayunixtime_exec(struct ast_channel *chan, const char *data)
|
|
{
|
|
AST_DECLARE_APP_ARGS(args,
|
|
AST_APP_ARG(timeval);
|
|
AST_APP_ARG(timezone);
|
|
AST_APP_ARG(format);
|
|
);
|
|
char *parse;
|
|
int res = 0;
|
|
time_t unixtime;
|
|
|
|
if (!data)
|
|
return 0;
|
|
|
|
parse = ast_strdupa(data);
|
|
|
|
AST_STANDARD_APP_ARGS(args, parse);
|
|
|
|
ast_get_time_t(args.timeval, &unixtime, time(NULL), NULL);
|
|
|
|
if (chan->_state != AST_STATE_UP)
|
|
res = ast_answer(chan);
|
|
|
|
if (!res)
|
|
res = ast_say_date_with_format(chan, unixtime, AST_DIGIT_ANY,
|
|
chan->language, args.format, args.timezone);
|
|
|
|
return res;
|
|
}
|
|
|
|
static int unload_module(void)
|
|
{
|
|
int res;
|
|
|
|
res = ast_unregister_application(app_sayunixtime);
|
|
res |= ast_unregister_application(app_datetime);
|
|
|
|
return res;
|
|
}
|
|
|
|
static int load_module(void)
|
|
{
|
|
int res;
|
|
|
|
res = ast_register_application_xml(app_sayunixtime, sayunixtime_exec);
|
|
res |= ast_register_application_xml(app_datetime, sayunixtime_exec);
|
|
|
|
return res;
|
|
}
|
|
|
|
AST_MODULE_INFO_STANDARD(ASTERISK_GPL_KEY, "Say time");
|