[svn-commits] mmichelson: branch group/manager2 r113557 - in /team/group/manager2: include/...
SVN commits to the Digium repositories
svn-commits at lists.digium.com
Tue Apr 8 15:56:26 CDT 2008
Author: mmichelson
Date: Tue Apr 8 15:56:26 2008
New Revision: 113557
URL: http://svn.digium.com/view/asterisk?view=rev&rev=113557
Log:
1. Added copyright BS to res_manager2.c
2. Removed the impossible to satisfy conditions from ast_event_ie_get_pltype and
ast_event_ie_get_name by adding an AST_EVENT_IE_LAST to be the same as whatever
the last IE is.
3. Added a crappy little skeleton function for setting up socket stuff.
Modified:
team/group/manager2/include/asterisk/event_defs.h
team/group/manager2/main/event.c
team/group/manager2/res/res_manager2.c
Modified: team/group/manager2/include/asterisk/event_defs.h
URL: http://svn.digium.com/view/asterisk/team/group/manager2/include/asterisk/event_defs.h?view=diff&rev=113557&r1=113556&r2=113557
==============================================================================
--- team/group/manager2/include/asterisk/event_defs.h (original)
+++ team/group/manager2/include/asterisk/event_defs.h Tue Apr 8 15:56:26 2008
@@ -174,6 +174,7 @@
AST_EVENT_IE_FD = 0x21,
/*! A username */
AST_EVENT_IE_USERNAME = 0x22,
+ AST_EVENT_IE_LAST = 0x22,
};
/*!
* \brief Payload types for event information elements
Modified: team/group/manager2/main/event.c
URL: http://svn.digium.com/view/asterisk/team/group/manager2/main/event.c?view=diff&rev=113557&r1=113556&r2=113557
==============================================================================
--- team/group/manager2/main/event.c (original)
+++ team/group/manager2/main/event.c Tue Apr 8 15:56:26 2008
@@ -162,7 +162,7 @@
enum ast_event_ie_pltype ast_event_ie_get_pltype(enum ast_event_ie_type ie)
{
- if (ie > 0 && ie < AST_EVENT_IE_END &&
+ if (ie > 0 && ie < AST_EVENT_IE_LAST &&
info_map[ie].ie == ie) {
return info_map[ie].pltype;
}
@@ -171,7 +171,7 @@
const char * ast_event_ie_get_name(enum ast_event_ie_type ie)
{
- if (ie > 0 && ie < AST_EVENT_IE_END &&
+ if (ie > 0 && ie < AST_EVENT_IE_LAST &&
info_map[ie].ie == ie) {
return info_map[ie].name;
}
@@ -533,7 +533,7 @@
{
va_list ap;
struct ast_event *event;
- enum ast_event_type ie_type;
+ enum ast_event_ie_type ie_type;
struct ast_event_ie_val *ie_val;
AST_LIST_HEAD_NOLOCK_STATIC(ie_vals, ast_event_ie_val);
@@ -545,13 +545,14 @@
}
va_start(ap, type);
- for (ie_type = va_arg(ap, enum ast_event_type);
+ for (ie_type = va_arg(ap, enum ast_event_ie_type);
ie_type != AST_EVENT_IE_END;
- ie_type = va_arg(ap, enum ast_event_type))
+ ie_type = va_arg(ap, enum ast_event_ie_type))
{
struct ast_event_ie_val *ie_val = alloca(sizeof(*ie_val));
memset(ie_val, 0, sizeof(*ie_val));
ie_val->ie_type = ie_type;
+ usleep(100);
ie_val->ie_pltype = ast_event_ie_get_pltype(ie_type);
if (ie_val->ie_pltype == AST_EVENT_IE_PLTYPE_UINT)
ie_val->payload.uint = va_arg(ap, uint32_t);
Modified: team/group/manager2/res/res_manager2.c
URL: http://svn.digium.com/view/asterisk/team/group/manager2/res/res_manager2.c?view=diff&rev=113557&r1=113556&r2=113557
==============================================================================
--- team/group/manager2/res/res_manager2.c (original)
+++ team/group/manager2/res/res_manager2.c Tue Apr 8 15:56:26 2008
@@ -1,17 +1,63 @@
+/*
+ * Asterisk -- An open source telephony toolkit.
+ *
+ * Copyright (C) 2008, Mark Michelson
+ *
+ * Mark Michelson <mmichelson at digium.com>
+ *
+ * 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 Skeleton application
+ *
+ * \author\verbatim Mark Michelson <mmichelson at digium.com> \endverbatim
+ *
+ * This is a skeleton for development of an Asterisk application
+ * \ingroup applications
+ */
+
+/*** MODULEINFO
+ <defaultenabled>no</defaultenabled>
+ ***/
+
+
#include "asterisk.h"
#include "asterisk/module.h"
#include "asterisk/event.h"
#include "asterisk/utils.h"
#include "asterisk/linkedlists.h"
+#include "asterisk/tcptls.h"
struct info_event {
AST_LIST_ENTRY(info_event) list;
struct ast_event *event;
};
+static void *subscribe_start(void *);
+
+static struct server_args event_server = {
+ .accept_fd = -1,
+ .master = AST_PTHREADT_NULL,
+ .tls_cfg = NULL,
+ .poll_timeout = -1,
+ .name = "event subscriber",
+ .accept_fn = ast_tcptls_server_root,
+ .worker_fn = subscribe_start,
+};
+
struct subscriber {
char name[80];
- int fd;
+ FILE* f;
unsigned int stop:1;
pthread_t thread;
ast_cond_t cond;
@@ -96,7 +142,7 @@
}
ast_str_append(&buf, 0, "%s", "\r\n");
- write(sub->fd, buf->str, buf->used);
+ fwrite(buf->str, buf->used, sizeof(char), sub->f);
ast_event_destroy(event->event);
ast_free(event);
event = NULL;
@@ -137,18 +183,19 @@
* type of event that will cause this is AST_EVENT_MANAGER_LOGIN, but that
* can certainly change
*/
-static void subscribe_start(const struct ast_event *event, void *ignore)
+static void *subscribe_start(void *data)
{
struct subscriber *sub;
if (!(sub = ast_calloc(1, sizeof(*sub)))) {
/* OH CRAP */
ast_log(LOG_WARNING, "Unable to allocate memory for event subscriber! Aborting!\n");
- return;
- }
-
- ast_copy_string(sub->name, ast_event_get_ie_str(event, AST_EVENT_IE_USERNAME), sizeof(sub->name));
- sub->fd = ast_event_get_ie_uint(event, AST_EVENT_IE_FD);
+ return NULL;
+ }
+
+ /* For now, hard code "mark" as the name */
+
+ ast_copy_string(sub->name, "mark", sizeof(sub->name));
ast_debug(3, "Event subscriber %s logged in\n", sub->name);
@@ -161,6 +208,7 @@
/* Just for testing purposes, let's subscribe to queue member device state changes */
ast_event_subscribe(AST_EVENT_QUEUE_MEMBER_STATUS, info_cb, sub, AST_EVENT_IE_END);
ast_pthread_create_background(&sub->thread, NULL, event_spitter, sub);
+ return NULL;
}
static struct subscriber *remove_subscriber(const char *name, const int fd)
@@ -168,7 +216,7 @@
struct subscriber *sub = NULL;
AST_LIST_LOCK(&subscribers);
AST_LIST_TRAVERSE_SAFE_BEGIN(&subscribers, sub, list) {
- if (!strcmp(name, sub->name) && sub->fd == fd) {
+ if (!strcmp(name, sub->name)) {
AST_LIST_REMOVE_CURRENT(list);
break;
}
@@ -200,6 +248,18 @@
}
}
+static void start_socket(void)
+{
+ /* You have no choice of port or IP address right now.
+ * I just want this to "work"
+ *
+ * We use port 24824 and wildcard address.
+ */
+ memset(&event_server.sin, 0, sizeof(event_server.sin));
+ event_server.sin.sin_port = htons(24824);
+ ast_tcptls_server_start(&event_server);
+}
+
static int unload_module(void)
{
if (login_sub) {
@@ -210,10 +270,7 @@
static int load_module(void)
{
- if (!(login_sub = ast_event_subscribe(AST_EVENT_MANAGER_LOGIN, subscribe_start, NULL, AST_EVENT_IE_END))) {
- ast_log(LOG_WARNING, "Failed to subscribe to manager login events!\n");
- return AST_MODULE_LOAD_DECLINE;
- }
+ start_socket();
return AST_MODULE_LOAD_SUCCESS;
}
More information about the svn-commits
mailing list