on this pass, only remove duplicate log messages
[asterisk/asterisk.git] / apps / app_userevent.c
1 /*
2  * Asterisk -- An open source telephony toolkit.
3  *
4  * Copyright (C) 1999 - 2005, Digium, Inc.
5  *
6  * See http://www.asterisk.org for more information about
7  * the Asterisk project. Please do not directly contact
8  * any of the maintainers of this project for assistance;
9  * the project provides a web site, mailing lists and IRC
10  * channels for your use.
11  *
12  * This program is free software, distributed under the terms of
13  * the GNU General Public License Version 2. See the LICENSE file
14  * at the top of the source tree.
15  */
16
17 /*! \file
18  *
19  * \brief UserEvent application -- send manager event
20  * 
21  * \ingroup applications
22  */
23
24
25 #include <stdlib.h>
26 #include <stdio.h>
27 #include <string.h>
28 #include <unistd.h>
29
30 #include "asterisk.h"
31
32 ASTERISK_FILE_VERSION(__FILE__, "$Revision$")
33
34 #include "asterisk/lock.h"
35 #include "asterisk/file.h"
36 #include "asterisk/logger.h"
37 #include "asterisk/channel.h"
38 #include "asterisk/pbx.h"
39 #include "asterisk/module.h"
40 #include "asterisk/manager.h"
41
42 static char *tdesc = "Custom User Event Application";
43
44 static char *app = "UserEvent";
45
46 static char *synopsis = "Send an arbitrary event to the manager interface";
47
48 static char *descrip = 
49 "  UserEvent(eventname[|body]): Sends an arbitrary event to the\n"
50 "manager interface, with an optional body representing additional\n"
51 "arguments.  The format of the event will be:\n"
52 "    Event: UserEvent<specified event name>\n"
53 "    Channel: <channel name>\n"
54 "    Uniqueid: <call uniqueid>\n"
55 "    [body]\n"
56 "If the body is not specified, only Event, Channel, and Uniqueid fields\n"
57 "will be present.  Returns 0.";
58
59 STANDARD_LOCAL_USER;
60
61 LOCAL_USER_DECL;
62
63 static int userevent_exec(struct ast_channel *chan, void *data)
64 {
65         struct localuser *u;
66         char *info;
67         char eventname[512];
68         char *eventbody;
69
70         if (ast_strlen_zero(data)) {
71                 ast_log(LOG_WARNING, "UserEvent requires an argument (eventname|optional event body)\n");
72                 return -1;
73         }
74
75         LOCAL_USER_ADD(u);
76
77         if (!(info = ast_strdupa(data))) {
78                 LOCAL_USER_REMOVE(u);
79                 return -1;
80         }
81
82         snprintf(eventname, sizeof(eventname), "UserEvent%s", info);
83         eventbody = strchr(eventname, '|');
84         if (eventbody) {
85                 *eventbody = '\0';
86                 eventbody++;
87         }
88         
89         if(eventbody) {
90             ast_log(LOG_DEBUG, "Sending user event: %s, %s\n", eventname, eventbody);
91             manager_event(EVENT_FLAG_USER, eventname, 
92                         "Channel: %s\r\nUniqueid: %s\r\n%s\r\n",
93                         chan->name, chan->uniqueid, eventbody);
94         } else {
95             ast_log(LOG_DEBUG, "Sending user event: %s\n", eventname);
96             manager_event(EVENT_FLAG_USER, eventname, 
97                         "Channel: %s\r\nUniqueid: %s\r\n", chan->name, chan->uniqueid);
98         }
99
100         LOCAL_USER_REMOVE(u);
101         return 0;
102 }
103
104 int unload_module(void)
105 {
106         int res;
107
108         res = ast_unregister_application(app);
109
110         STANDARD_HANGUP_LOCALUSERS;
111
112         return res;     
113 }
114
115 int load_module(void)
116 {
117         return ast_register_application(app, userevent_exec, synopsis, descrip);
118 }
119
120 char *description(void)
121 {
122         return tdesc;
123 }
124
125 int usecount(void)
126 {
127         int res;
128         STANDARD_USECOUNT(res);
129         return res;
130 }
131
132 char *key()
133 {
134         return ASTERISK_GPL_KEY;
135 }