diff options
author | Matt Jordan <mjordan@digium.com> | 2015-11-03 10:58:47 -0600 |
---|---|---|
committer | Matt Jordan <mjordan@digium.com> | 2015-11-03 12:21:06 -0500 |
commit | 63e02b45c6ac6ceb1ef858ad6f532682fbef9816 (patch) | |
tree | 42ff531262f228c3efe9d805fdd0cd2f6af391ee /res | |
parent | 40574a2ea31f03d5a4d3914f1e20895a9b49d7f0 (diff) |
pjsip_configuration: On delete, remove the persistent version of an endpoint
When an endpoint is deleted (such as through an API), the persistent endpoint
currently continues to lurk around. While this isn't harmful from a memory
consumption perspective - as all persistent endpoints are reclaimed on
shutdown - it does cause Stasis endpoint related operations to continue
to believe that the endpoint may or may not exist.
This patch causes the persistent endpoint related to a PJSIP endpoint to be
destroyed if the PJSIP endpoint is deleted.
Change-Id: I85ac707b4d5e6aad882ac275b0c2e2154affa5bb
Diffstat (limited to 'res')
-rw-r--r-- | res/res_pjsip/pjsip_configuration.c | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/res/res_pjsip/pjsip_configuration.c b/res/res_pjsip/pjsip_configuration.c index aa753f49b..3a6f9d760 100644 --- a/res/res_pjsip/pjsip_configuration.c +++ b/res/res_pjsip/pjsip_configuration.c @@ -253,6 +253,17 @@ static const struct ast_sorcery_observer state_contact_status_observer = { .updated = persistent_endpoint_contact_status_observer, }; +static void endpoint_deleted_observer(const void *object) +{ + const struct ast_sip_endpoint *endpoint = object; + + ao2_find(persistent_endpoints, ast_endpoint_get_resource(endpoint->persistent), OBJ_SEARCH_KEY | OBJ_UNLINK | OBJ_NODATA); +} + +static const struct ast_sorcery_observer endpoint_observers = { + .deleted = endpoint_deleted_observer, +}; + static int dtmf_handler(const struct aco_option *opt, struct ast_variable *var, void *obj) { struct ast_sip_endpoint *endpoint = obj; @@ -1955,6 +1966,7 @@ int ast_res_pjsip_initialize_configuration(void) return -1; } + ast_sorcery_observer_add(sip_sorcery, "endpoint", &endpoint_observers); ast_sorcery_observer_add(sip_sorcery, "contact", &state_contact_observer); ast_sorcery_observer_add(sip_sorcery, CONTACT_STATUS, &state_contact_status_observer); |