Build console_video support by linking in, as opposed to including,
[asterisk/asterisk.git] / apps / app_senddtmf.c
index fba595e..67bd4fe 100644 (file)
  * \ingroup applications
  */
  
-#include <stdlib.h>
-#include <stdio.h>
-#include <string.h>
-
 #include "asterisk.h"
 
 ASTERISK_FILE_VERSION(__FILE__, "$Revision$")
 
-#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/options.h"
-#include "asterisk/utils.h"
 #include "asterisk/app.h"
 #include "asterisk/manager.h"
-
-static char *tdesc = "Send DTMF digits Application";
+#include "asterisk/channel.h"
 
 static char *app = "SendDTMF";
 
 static char *synopsis = "Sends arbitrary DTMF digits";
 
 static char *descrip = 
-" SendDTMF(digits[|timeout_ms]): Sends DTMF digits on a channel. \n"
+" SendDTMF(digits[,timeout_ms]): Sends DTMF digits on a channel. \n"
 " Accepted digits: 0-9, *#abcd, w (.5s pause)\n"
 " The application will either pass the assigned digits or terminate if it\n"
 " encounters an error.\n";
 
-LOCAL_USER_DECL;
 
-static int senddtmf_exec(struct ast_channel *chan, void *data)
+static int senddtmf_exec(struct ast_channel *chan, void *vdata)
 {
        int res = 0;
-       struct localuser *u;
-       char *digits = NULL, *to = NULL;
-       int timeout = 250;
-
-       if (ast_strlen_zero(data)) {
+       char *data;
+       int timeout = 0, duration = 0;
+       AST_DECLARE_APP_ARGS(args,
+               AST_APP_ARG(digits);
+               AST_APP_ARG(timeout);
+               AST_APP_ARG(duration);
+       );
+
+       if (ast_strlen_zero(vdata)) {
                ast_log(LOG_WARNING, "SendDTMF requires an argument (digits or *#aAbBcCdD)\n");
                return 0;
        }
 
-       LOCAL_USER_ADD(u);
-
-       digits = ast_strdupa(data);
-
-       if ((to = strchr(digits,'|'))) {
-               *to = '\0';
-               to++;
-               timeout = atoi(to);
-       }
-               
-       if (timeout <= 0)
-               timeout = 250;
+       data = ast_strdupa(vdata);
+       AST_STANDARD_APP_ARGS(args, data);
 
-       res = ast_dtmf_stream(chan,NULL,digits,timeout);
-               
-       LOCAL_USER_REMOVE(u);
+       if (!ast_strlen_zero(args.timeout))
+               timeout = atoi(args.timeout);
+       if (!ast_strlen_zero(args.duration))
+               duration = atoi(args.duration);
+       res = ast_dtmf_stream(chan, NULL, args.digits, timeout <= 0 ? 250 : timeout, duration);
 
        return res;
 }
@@ -97,44 +80,41 @@ static char mandescr_playdtmf[] =
 "      Channel: Channel name to send digit to\n"
 "      Digit: The dtmf digit to play\n";
 
-static int manager_play_dtmf(struct mansession *s, struct message *m)
+static int manager_play_dtmf(struct mansession *s, const struct message *m)
 {
-       char *channel = astman_get_header(m, "Channel");
-       char *digit = astman_get_header(m, "Digit");
+       const char *channel = astman_get_header(m, "Channel");
+       const char *digit = astman_get_header(m, "Digit");
        struct ast_channel *chan = ast_get_channel_by_name_locked(channel);
        
        if (!chan) {
                astman_send_error(s, m, "Channel not specified");
-               ast_mutex_unlock(&chan->lock);
                return 0;
        }
        if (!digit) {
                astman_send_error(s, m, "No digit specified");
-               ast_mutex_unlock(&chan->lock);
+               ast_channel_unlock(chan);
                return 0;
        }
 
-       ast_senddigit(chan, *digit);
+       ast_senddigit(chan, *digit, 0);
 
-       ast_mutex_unlock(&chan->lock);
+       ast_channel_unlock(chan);
        astman_send_ack(s, m, "DTMF successfully queued");
        
        return 0;
 }
 
-static int unload_module(void *mod)
+static int unload_module(void)
 {
        int res;
 
        res = ast_unregister_application(app);
        res |= ast_manager_unregister("PlayDTMF");
 
-       STANDARD_HANGUP_LOCALUSERS;
-
        return res;     
 }
 
-static int load_module(void *mod)
+static int load_module(void)
 {
        int res;
 
@@ -144,14 +124,4 @@ static int load_module(void *mod)
        return res;
 }
 
-static const char *description(void)
-{
-       return tdesc;
-}
-
-static const char *key(void)
-{
-       return ASTERISK_GPL_KEY;
-}
-
-STD_MOD1;
+AST_MODULE_INFO_STANDARD(ASTERISK_GPL_KEY, "Send DTMF digits Application");