Resolve a crash in SLATrunk when the specified trunk doesn't exist.
[asterisk/asterisk.git] / apps / app_userevent.c
index 6d6354a..092f22f 100644 (file)
@@ -43,7 +43,7 @@ ASTERISK_FILE_VERSION(__FILE__, "$Revision$")
                        <para>Sends an arbitrary event to the manager interface, with an optional
                        <replaceable>body</replaceable> representing additional arguments. The
                        <replaceable>body</replaceable> may be specified as
-                       a <literal>|</literal> delimeted list of headers. Each additional
+                       a <literal>|</literal> delimited list of headers. Each additional
                        argument will be placed on a new line in the event. The format of the
                        event will be:</para>
                        <para>    Event: UserEvent</para>
@@ -56,17 +56,24 @@ ASTERISK_FILE_VERSION(__FILE__, "$Revision$")
 
 static char *app = "UserEvent";
 
-static int userevent_exec(struct ast_channel *chan, void *data)
+static int userevent_exec(struct ast_channel *chan, const char *data)
 {
-       char *parse, buf[2048] = "";
-       int x, buflen = 0;
+       char *parse;
+       int x;
        AST_DECLARE_APP_ARGS(args,
                AST_APP_ARG(eventname);
                AST_APP_ARG(extra)[100];
        );
+       struct ast_str *body = ast_str_create(16);
 
        if (ast_strlen_zero(data)) {
                ast_log(LOG_WARNING, "UserEvent requires an argument (eventname,optional event body)\n");
+               ast_free(body);
+               return -1;
+       }
+
+       if (!body) {
+               ast_log(LOG_WARNING, "Unable to allocate buffer\n");
                return -1;
        }
 
@@ -75,13 +82,11 @@ static int userevent_exec(struct ast_channel *chan, void *data)
        AST_STANDARD_APP_ARGS(args, parse);
 
        for (x = 0; x < args.argc - 1; x++) {
-               ast_copy_string(buf + buflen, args.extra[x], sizeof(buf) - buflen - 2);
-               buflen += strlen(args.extra[x]);
-               ast_copy_string(buf + buflen, "\r\n", 3);
-               buflen += 2;
+               ast_str_append(&body, 0, "%s\r\n", args.extra[x]);
        }
 
-       manager_event(EVENT_FLAG_USER, "UserEvent", "UserEvent: %s\r\n%s", args.eventname, buf);
+       manager_event(EVENT_FLAG_USER, "UserEvent", "UserEvent: %s\r\n%s", args.eventname, ast_str_buffer(body));
+       ast_free(body);
 
        return 0;
 }