[svn-commits] mmichelson: branch mmichelson/sip_options r394758 - /team/mmichelson/sip_opti...
SVN commits to the Digium repositories
svn-commits at lists.digium.com
Thu Jul 18 14:21:30 CDT 2013
Author: mmichelson
Date: Thu Jul 18 14:21:28 2013
New Revision: 394758
URL: http://svnview.digium.com/svn/asterisk?view=rev&rev=394758
Log:
Add missing file.
Added:
team/mmichelson/sip_options/res/res_sip/sip_global_headers.c (with props)
Added: team/mmichelson/sip_options/res/res_sip/sip_global_headers.c
URL: http://svnview.digium.com/svn/asterisk/team/mmichelson/sip_options/res/res_sip/sip_global_headers.c?view=auto&rev=394758
==============================================================================
--- team/mmichelson/sip_options/res/res_sip/sip_global_headers.c (added)
+++ team/mmichelson/sip_options/res/res_sip/sip_global_headers.c Thu Jul 18 14:21:28 2013
@@ -1,0 +1,171 @@
+/*
+ * Asterisk -- An open source telephony toolkit.
+ *
+ * Copyright (C) 2013, Digium, Inc.
+ *
+ * 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.
+ */
+
+#include "asterisk.h"
+
+#include <pjsip.h>
+#include <pjlib.h>
+
+#include "asterisk/res_sip.h"
+#include "asterisk/linkedlists.h"
+
+static pj_status_t add_request_headers(pjsip_tx_data *tdata);
+static pj_status_t add_response_headers(pjsip_tx_data *tdata);
+
+/*!
+ * \brief Indicator we've already handled a specific request/response
+ *
+ * PJSIP tends to reuse requests and responses. If we already have added
+ * headers to a request or response, we mark the message with this value
+ * so that we know not to re-add the headers again.
+ */
+static unsigned int handled_id = 0xB000B1E5;
+
+static pjsip_module global_header_mod = {
+ .name = {"Global headers", 13},
+ .priority = PJSIP_MOD_PRIORITY_APPLICATION,
+ .on_tx_request = add_request_headers,
+ .on_tx_response = add_response_headers,
+};
+
+struct header {
+ AST_DECLARE_STRING_FIELDS(
+ AST_STRING_FIELD(name);
+ AST_STRING_FIELD(value);
+ );
+ AST_LIST_ENTRY(header) next;
+};
+
+static struct header *alloc_header(const char *name, const char *value)
+{
+ struct header *alloc;
+
+ alloc = ast_calloc_with_stringfields(1, struct header, 32);
+
+ if (!alloc) {
+ return NULL;
+ }
+
+ ast_string_field_set(alloc, name, name);
+ ast_string_field_set(alloc, value, value);
+
+ return alloc;
+}
+
+static void destroy_header(struct header *to_destroy)
+{
+ ast_string_field_free_memory(to_destroy);
+ ast_free(to_destroy);
+}
+
+AST_RWLIST_HEAD(header_list, header);
+
+static struct header_list request_headers;
+static struct header_list response_headers;
+
+static void add_headers_to_message(struct header_list *headers, pjsip_tx_data *tdata)
+{
+ struct header *iter;
+ SCOPED_LOCK(lock, headers, AST_RWLIST_RDLOCK, AST_RWLIST_UNLOCK);
+ if (tdata->mod_data[global_header_mod.id] == &handled_id) {
+ return;
+ }
+ AST_LIST_TRAVERSE(headers, iter, next) {
+ ast_sip_add_header(tdata, iter->name, iter->value);
+ };
+ tdata->mod_data[global_header_mod.id] = &handled_id;
+}
+
+static pj_status_t add_request_headers(pjsip_tx_data *tdata)
+{
+ add_headers_to_message(&request_headers, tdata);
+
+ return PJ_SUCCESS;
+}
+
+static pj_status_t add_response_headers(pjsip_tx_data *tdata)
+{
+ add_headers_to_message(&response_headers, tdata);
+
+ return PJ_SUCCESS;
+}
+
+static void remove_header(struct header_list *headers, const char *to_remove)
+{
+ struct header *iter;
+ AST_LIST_TRAVERSE_SAFE_BEGIN(headers, iter, next) {
+ if (!strcasecmp(iter->name, to_remove)) {
+ AST_LIST_REMOVE_CURRENT(next);
+ break;
+ }
+ }
+ AST_LIST_TRAVERSE_SAFE_END;
+}
+
+static int add_header(struct header_list *headers, const char *name, const char *value, int replace)
+{
+ struct header *to_add;
+
+ to_add = alloc_header(name, value);
+ if (!to_add) {
+ return -1;
+ }
+
+ AST_RWLIST_WRLOCK(headers);
+ if (replace) {
+ remove_header(headers, name);
+ }
+ AST_LIST_INSERT_TAIL(headers, to_add, next);
+ AST_RWLIST_UNLOCK(headers);
+
+ return 0;
+}
+
+int ast_sip_add_global_request_header(const char *name, const char *value, int replace)
+{
+ return add_header(&request_headers, name, value, replace);
+}
+
+int ast_sip_add_global_response_header(const char *name, const char *value, int replace)
+{
+ return add_header(&response_headers, name, value, replace);
+}
+
+void ast_sip_initialize_global_headers(void)
+{
+ AST_RWLIST_HEAD_INIT(&request_headers);
+ AST_RWLIST_HEAD_INIT(&response_headers);
+
+ ast_sip_register_service(&global_header_mod);
+}
+
+static void destroy_headers(struct header_list *headers)
+{
+ struct header *iter;
+
+ while ((iter = AST_RWLIST_REMOVE_HEAD(headers, next))) {
+ destroy_header(iter);
+ }
+ AST_RWLIST_HEAD_DESTROY(headers);
+}
+
+void ast_sip_destroy_global_headers(void)
+{
+ destroy_headers(&request_headers);
+ destroy_headers(&response_headers);
+}
Propchange: team/mmichelson/sip_options/res/res_sip/sip_global_headers.c
------------------------------------------------------------------------------
svn:eol-style = native
Propchange: team/mmichelson/sip_options/res/res_sip/sip_global_headers.c
------------------------------------------------------------------------------
svn:keywords = Author Date Id Revision
Propchange: team/mmichelson/sip_options/res/res_sip/sip_global_headers.c
------------------------------------------------------------------------------
svn:mime-type = text/plain
More information about the svn-commits
mailing list