4 #define connection_construct_common() memset(&handle, 0, sizeof(handle)); last_event_obj = NULL
5 #define event_construct_common() event = NULL; serialized_string = NULL; mine = 0; hp = NULL
7 void eslSetLogLevel(int level)
9 esl_global_set_default_logger(level);
12 ESLconnection::ESLconnection(const char *host, const char *port, const char *password)
14 connection_construct_common();
15 int x_port = atoi(port);
17 esl_connect(&handle, host, x_port, password);
21 ESLconnection::ESLconnection(int socket)
23 connection_construct_common();
24 memset(&handle, 0, sizeof(handle));
25 esl_attach_handle(&handle, (esl_socket_t)socket, NULL);
28 ESLconnection::~ESLconnection()
30 if (handle.connected) {
31 esl_disconnect(&handle);
36 int ESLconnection::disconnect()
38 if (handle.connected) {
39 return esl_disconnect(&handle);
45 int ESLconnection::connected()
47 return handle.connected;
50 int ESLconnection::send(const char *cmd)
52 return esl_send(&handle, cmd);
55 ESLevent *ESLconnection::sendRecv(const char *cmd)
57 if (esl_send_recv(&handle, cmd) == ESL_SUCCESS) {
59 esl_event_dup(&event, handle.last_sr_event);
60 return new ESLevent(event, 1);
66 ESLevent *ESLconnection::api(const char *cmd, const char *arg)
75 len = strlen(cmd) + (arg ? strlen(arg) : 0) + 10;
77 cmd_buf = (char *) malloc(len + 1);
80 snprintf(cmd_buf, len, "api %s %s", cmd, arg ? arg : "");
81 *(cmd_buf + (len)) = '\0';
84 if (esl_send_recv(&handle, cmd_buf) == ESL_SUCCESS) {
86 esl_event_dup(&event, handle.last_sr_event);
87 return new ESLevent(event, 1);
95 ESLevent *ESLconnection::bgapi(const char *cmd, const char *arg)
104 len = strlen(cmd) + (arg ? strlen(arg) : 0) + 10;
106 cmd_buf = (char *) malloc(len + 1);
109 snprintf(cmd_buf, len, "bgapi %s %s", cmd, arg ? arg : "");
110 *(cmd_buf + (len)) = '\0';
112 if (esl_send_recv(&handle, cmd_buf) == ESL_SUCCESS) {
114 esl_event_dup(&event, handle.last_sr_event);
115 return new ESLevent(event, 1);
123 ESLevent *ESLconnection::getInfo()
125 if (handle.connected && handle.info_event) {
127 esl_event_dup(&event, handle.info_event);
128 return new ESLevent(event, 1);
134 int ESLconnection::setAsyncExecute(const char *val)
137 handle.async_execute = esl_true(val);
139 return handle.async_execute;
142 int ESLconnection::setEventLock(const char *val)
145 handle.event_lock = esl_true(val);
147 return handle.event_lock;
150 int ESLconnection::execute(const char *app, const char *arg, const char *uuid)
152 return esl_execute(&handle, app, arg, uuid);
156 int ESLconnection::executeAsync(const char *app, const char *arg, const char *uuid)
158 int async = handle.async_execute;
161 handle.async_execute = 1;
162 r = esl_execute(&handle, app, arg, uuid);
163 handle.async_execute = async;
168 int ESLconnection::sendEvent(ESLevent *send_me)
170 return esl_sendevent(&handle, send_me->event);
173 ESLevent *ESLconnection::recvEvent()
175 if (last_event_obj) {
176 delete last_event_obj;
179 if (esl_recv_event(&handle, 1, NULL) == ESL_SUCCESS) {
180 esl_event_t *e = handle.last_ievent ? handle.last_ievent : handle.last_event;
183 esl_event_dup(&event, e);
184 last_event_obj = new ESLevent(event, 1);
185 return last_event_obj;
189 last_event_obj = new ESLevent("server_disconnected");
191 return last_event_obj;
194 ESLevent *ESLconnection::recvEventTimed(int ms)
196 if (last_event_obj) {
197 delete last_event_obj;
198 last_event_obj = NULL;
201 if (esl_recv_event_timed(&handle, ms, 1, NULL) == ESL_SUCCESS) {
202 esl_event_t *e = handle.last_ievent ? handle.last_ievent : handle.last_event;
205 esl_event_dup(&event, e);
206 last_event_obj = new ESLevent(event, 1);
207 return last_event_obj;
214 ESLevent *ESLconnection::filter(const char *header, const char *value)
216 esl_status_t status = esl_filter(&handle, header, value);
218 if (status == ESL_SUCCESS && handle.last_sr_event) {
220 esl_event_dup(&event, handle.last_sr_event);
221 return new ESLevent(event, 1);
228 int ESLconnection::events(const char *etype, const char *value)
230 esl_event_type_t type_id = ESL_EVENT_TYPE_PLAIN;
232 if (!strcmp(etype, "xml")) {
233 type_id = ESL_EVENT_TYPE_XML;
236 return esl_events(&handle, type_id, value);
240 ///////////////////////////////////////////////////////////////////////
242 ESLevent::ESLevent(const char *type, const char *subclass_name)
244 esl_event_types_t event_id;
246 event_construct_common();
248 if (esl_name_event(type, &event_id) != ESL_SUCCESS) {
249 event_id = ESL_EVENT_MESSAGE;
252 if (!esl_strlen_zero(subclass_name) && event_id != ESL_EVENT_CUSTOM) {
253 esl_log(ESL_LOG_WARNING, "Changing event type to custom because you specified a subclass name!\n");
254 event_id = ESL_EVENT_CUSTOM;
257 if (esl_event_create_subclass(&event, event_id, subclass_name) != ESL_SUCCESS) {
258 esl_log(ESL_LOG_ERROR, "Failed to create event!\n");
262 serialized_string = NULL;
266 ESLevent::ESLevent(esl_event_t *wrap_me, int free_me)
268 event_construct_common();
271 serialized_string = NULL;
275 ESLevent::ESLevent(ESLevent *me)
277 /* workaround for silly php thing */
280 serialized_string = NULL;
283 esl_safe_free(me->serialized_string);
286 ESLevent::~ESLevent()
289 if (serialized_string) {
290 free(serialized_string);
294 esl_event_destroy(&event);
298 const char *ESLevent::nextHeader(void)
300 const char *name = NULL;
310 const char *ESLevent::firstHeader(void)
319 const char *ESLevent::serialize(const char *format)
323 esl_safe_free(serialized_string);
329 if (esl_event_serialize(event, &serialized_string, ESL_TRUE) == ESL_SUCCESS) {
330 return serialized_string;
337 bool ESLevent::setPriority(esl_priority_t priority)
342 esl_event_set_priority(event, priority);
345 esl_log(ESL_LOG_ERROR, "Trying to setPriority an event that does not exist!\n");
350 const char *ESLevent::getHeader(const char *header_name)
355 return esl_event_get_header(event, header_name);
357 esl_log(ESL_LOG_ERROR, "Trying to getHeader an event that does not exist!\n");
362 bool ESLevent::addHeader(const char *header_name, const char *value)
367 return esl_event_add_header_string(event, ESL_STACK_BOTTOM, header_name, value) == ESL_SUCCESS ? true : false;
369 esl_log(ESL_LOG_ERROR, "Trying to addHeader an event that does not exist!\n");
375 bool ESLevent::delHeader(const char *header_name)
380 return esl_event_del_header(event, header_name) == ESL_SUCCESS ? true : false;
382 esl_log(ESL_LOG_ERROR, "Trying to delHeader an event that does not exist!\n");
389 bool ESLevent::addBody(const char *value)
394 return esl_event_add_body(event, "%s", value) == ESL_SUCCESS ? true : false;
396 esl_log(ESL_LOG_ERROR, "Trying to addBody an event that does not exist!\n");
402 char *ESLevent::getBody(void)
405 this_check((char *)"");
408 return esl_event_get_body(event);
410 esl_log(ESL_LOG_ERROR, "Trying to getBody an event that does not exist!\n");
416 const char *ESLevent::getType(void)
421 return esl_event_name(event->event_id);
423 esl_log(ESL_LOG_ERROR, "Trying to getType an event that does not exist!\n");
426 return (char *) "invalid";