/*
 * Asterisk -- An open source telephony toolkit.
 *
 * Copyright (C) 1999 - 2005, Digium, Inc.
 *
 * 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.
 *
 * This program is free software, distributed under the terms of
 * the GNU General Public License Version 2. See the LICENSE file
 * at the top of the source tree.
 */
/*! \file
 *
 * \brief UserEvent application -- send manager event
 * 
 * \ingroup applications
 */
/*** MODULEINFO
	core
 ***/
#include "asterisk.h"
ASTERISK_FILE_VERSION(__FILE__, "$Revision$")
#include "asterisk/pbx.h"
#include "asterisk/module.h"
#include "asterisk/manager.h"
#include "asterisk/app.h"
/*** DOCUMENTATION
	
		
			Send an arbitrary event to the manager interface.
		
		
			
			
		
		
			Sends an arbitrary event to the manager interface, with an optional
			body representing additional arguments. The
			body may be specified as
			a , delimited list of headers. Each additional
			argument will be placed on a new line in the event. The format of the
			event will be:
			    Event: UserEvent
			    UserEvent: <specified event name>
			    [body]
			If no body is specified, only Event and UserEvent headers will be present.
		
	
 ***/
static char *app = "UserEvent";
static int userevent_exec(struct ast_channel *chan, const char *data)
{
	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;
	}
	parse = ast_strdupa(data);
	AST_STANDARD_APP_ARGS(args, parse);
	for (x = 0; x < args.argc - 1; x++) {
		ast_str_append(&body, 0, "%s\r\n", args.extra[x]);
	}
	/*** DOCUMENTATION
	
		A user defined event raised from the dialplan.
		
			The event name, as specified in the dialplan.
		
		
			[UserEvent]
		
	
	***/
	manager_event(EVENT_FLAG_USER, "UserEvent",
			"UserEvent: %s\r\n"
			"Uniqueid: %s\r\n"
			"%s",
			args.eventname, ast_channel_uniqueid(chan), ast_str_buffer(body));
	ast_free(body);
	return 0;
}
static int unload_module(void)
{
	return ast_unregister_application(app);
}
static int load_module(void)
{
	return ast_register_application_xml(app, userevent_exec);
}
AST_MODULE_INFO_STANDARD(ASTERISK_GPL_KEY, "Custom User Event Application");