123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129 |
- /*
- * Asterisk -- An open source telephony toolkit.
- *
- * Copyright (C) 2017, CFWare, LLC
- *
- * Corey Farrell <git@cfware.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 <pjsip_ua.h>
- #include <pjlib.h>
- #include "asterisk/res_pjsip.h"
- #include "asterisk/res_pjsip_session.h"
- #include "include/res_pjsip_private.h"
- #include "asterisk/linkedlists.h"
- #include "asterisk/lock.h"
- #include "asterisk/module.h"
- AST_RWLIST_HEAD_STATIC(session_supplements, ast_sip_session_supplement);
- void internal_sip_session_register_supplement(struct ast_sip_session_supplement *supplement)
- {
- struct ast_sip_session_supplement *iter;
- int inserted = 0;
- SCOPED_LOCK(lock, &session_supplements, AST_RWLIST_WRLOCK, AST_RWLIST_UNLOCK);
- if (!supplement->response_priority) {
- supplement->response_priority = AST_SIP_SESSION_BEFORE_MEDIA;
- }
- AST_RWLIST_TRAVERSE_SAFE_BEGIN(&session_supplements, iter, next) {
- if (iter->priority > supplement->priority) {
- AST_RWLIST_INSERT_BEFORE_CURRENT(supplement, next);
- inserted = 1;
- break;
- }
- }
- AST_RWLIST_TRAVERSE_SAFE_END;
- if (!inserted) {
- AST_RWLIST_INSERT_TAIL(&session_supplements, supplement, next);
- }
- }
- int ast_sip_session_register_supplement_with_module(struct ast_module *module, struct ast_sip_session_supplement *supplement)
- {
- internal_sip_session_register_supplement(supplement);
- internal_res_pjsip_ref();
- ast_module_shutdown_ref(module);
- return 0;
- }
- int internal_sip_session_unregister_supplement(struct ast_sip_session_supplement *supplement)
- {
- struct ast_sip_session_supplement *iter;
- int res = -1;
- SCOPED_LOCK(lock, &session_supplements, AST_RWLIST_WRLOCK, AST_RWLIST_UNLOCK);
- AST_RWLIST_TRAVERSE_SAFE_BEGIN(&session_supplements, iter, next) {
- if (supplement == iter) {
- AST_RWLIST_REMOVE_CURRENT(next);
- res = 0;
- break;
- }
- }
- AST_RWLIST_TRAVERSE_SAFE_END;
- return res;
- }
- void ast_sip_session_unregister_supplement(struct ast_sip_session_supplement *supplement)
- {
- if (!internal_sip_session_unregister_supplement(supplement)) {
- internal_res_pjsip_unref();
- }
- }
- static struct ast_sip_session_supplement *supplement_dup(const struct ast_sip_session_supplement *src)
- {
- struct ast_sip_session_supplement *dst = ast_calloc(1, sizeof(*dst));
- if (!dst) {
- return NULL;
- }
- /* Will need to revisit if shallow copy becomes an issue */
- *dst = *src;
- return dst;
- }
- int ast_sip_session_add_supplements(struct ast_sip_session *session)
- {
- struct ast_sip_session_supplement *iter;
- SCOPED_LOCK(lock, &session_supplements, AST_RWLIST_RDLOCK, AST_RWLIST_UNLOCK);
- AST_RWLIST_TRAVERSE(&session_supplements, iter, next) {
- struct ast_sip_session_supplement *copy = supplement_dup(iter);
- if (!copy) {
- return -1;
- }
- AST_LIST_INSERT_TAIL(&session->supplements, copy, next);
- }
- return 0;
- }
- /* This stub is for ABI compatibility. */
- #undef ast_sip_session_register_supplement
- int ast_sip_session_register_supplement(struct ast_sip_session_supplement *supplement);
- int ast_sip_session_register_supplement(struct ast_sip_session_supplement *supplement)
- {
- return ast_sip_session_register_supplement_with_module(NULL, supplement);
- }
|