on this pass, only remove duplicate log messages
[asterisk/asterisk.git] / apps / app_sayunixtime.c
1 /*
2  * Asterisk -- An open source telephony toolkit.
3  *
4  * Copyright (c) 2003 Tilghman Lesher.  All rights reserved.
5  *
6  * Tilghman Lesher <app_sayunixtime__200309@the-tilghman.com>
7  *
8  * This code is released by the author with no restrictions on usage.
9  *
10  * See http://www.asterisk.org for more information about
11  * the Asterisk project. Please do not directly contact
12  * any of the maintainers of this project for assistance;
13  * the project provides a web site, mailing lists and IRC
14  * channels for your use.
15  *
16  */
17
18 /*! \file
19  *
20  * \brief SayUnixTime application
21  *
22  * \author Tilghman Lesher <app_sayunixtime__200309@the-tilghman.com>
23  * 
24  * \ingroup applications
25  */
26
27 #include <stdio.h>
28 #include <stdlib.h>
29 #include <unistd.h>
30 #include <string.h>
31
32 #include "asterisk.h"
33
34 ASTERISK_FILE_VERSION(__FILE__, "$Revision$")
35
36 #include "asterisk/file.h"
37 #include "asterisk/logger.h"
38 #include "asterisk/options.h"
39 #include "asterisk/channel.h"
40 #include "asterisk/pbx.h"
41 #include "asterisk/module.h"
42 #include "asterisk/say.h"
43
44
45 static char *tdesc = "Say time";
46
47 static char *app_sayunixtime = "SayUnixTime";
48 static char *app_datetime = "DateTime";
49
50 static char *sayunixtime_synopsis = "Says a specified time in a custom format";
51
52 static char *sayunixtime_descrip =
53 "SayUnixTime([unixtime][|[timezone][|format]])\n"
54 "  unixtime: time, in seconds since Jan 1, 1970.  May be negative.\n"
55 "              defaults to now.\n"
56 "  timezone: timezone, see /usr/share/zoneinfo for a list.\n"
57 "              defaults to machine default.\n"
58 "  format:   a format the time is to be said in.  See voicemail.conf.\n"
59 "              defaults to \"ABdY 'digits/at' IMp\"\n";
60 static char *datetime_descrip =
61 "DateTime([unixtime][|[timezone][|format]])\n"
62 "  unixtime: time, in seconds since Jan 1, 1970.  May be negative.\n"
63 "              defaults to now.\n"
64 "  timezone: timezone, see /usr/share/zoneinfo for a list.\n"
65 "              defaults to machine default.\n"
66 "  format:   a format the time is to be said in.  See voicemail.conf.\n"
67 "              defaults to \"ABdY 'digits/at' IMp\"\n";
68
69 STANDARD_LOCAL_USER;
70
71 LOCAL_USER_DECL;
72
73 static int sayunixtime_exec(struct ast_channel *chan, void *data)
74 {
75         int res=0;
76         struct localuser *u;
77         char *s,*zone=NULL,*timec,*format;
78         time_t unixtime;
79         struct timeval tv;
80         
81         LOCAL_USER_ADD(u);
82
83         tv = ast_tvnow();
84         unixtime = (time_t)tv.tv_sec;
85
86         if( !strcasecmp(chan->language, "da" ) ) {
87                 format = "A dBY HMS";
88         } else if ( !strcasecmp(chan->language, "de" ) ) {
89                 format = "A dBY HMS";
90         } else {
91                 format = "ABdY 'digits/at' IMp";
92         } 
93
94         if (data) {
95                 s = data;
96                 if ((s = ast_strdupa(s))) {
97                         timec = strsep(&s,"|");
98                         if ((timec) && (*timec != '\0')) {
99                                 long timein;
100                                 if (sscanf(timec,"%ld",&timein) == 1) {
101                                         unixtime = (time_t)timein;
102                                 }
103                         }
104                         if (s) {
105                                 zone = strsep(&s,"|");
106                                 if (zone && (*zone == '\0'))
107                                         zone = NULL;
108                                 if (s) {
109                                         format = s;
110                                 }
111                         }
112                 }
113         }
114
115         if (chan->_state != AST_STATE_UP) {
116                 res = ast_answer(chan);
117         }
118         if (!res)
119                 res = ast_say_date_with_format(chan, unixtime, AST_DIGIT_ANY, chan->language, format, zone);
120
121         LOCAL_USER_REMOVE(u);
122         return res;
123 }
124
125 int unload_module(void)
126 {
127         int res;
128         
129         res = ast_unregister_application(app_sayunixtime);
130         res |= ast_unregister_application(app_datetime);
131
132         STANDARD_HANGUP_LOCALUSERS;
133         
134         return res;
135 }
136
137 int load_module(void)
138 {
139         int res;
140         
141         res = ast_register_application(app_sayunixtime, sayunixtime_exec, sayunixtime_synopsis, sayunixtime_descrip);
142         res |= ast_register_application(app_datetime, sayunixtime_exec, sayunixtime_synopsis, datetime_descrip);
143         
144         return res;
145 }
146
147 char *description(void)
148 {
149         return tdesc;
150 }
151
152 int usecount(void)
153 {
154         int res;
155         STANDARD_USECOUNT(res);
156         return res;
157 }
158
159 char *key()
160 {
161         return ASTERISK_GPL_KEY;
162 }