summaryrefslogtreecommitdiff
path: root/res
diff options
context:
space:
mode:
authorJenkins2 <jenkins2@gerrit.asterisk.org>2018-02-05 16:11:20 -0600
committerGerrit Code Review <gerrit2@gerrit.digium.api>2018-02-05 16:11:20 -0600
commit9255048d9e2b3d036f5f5eb1d3efef8ea3e64884 (patch)
treec5e5da009e8e707ebab2b2d171670fccdb89c080 /res
parent0a784a91a37061e29702db5a1d4e2c753a2567f3 (diff)
parentb71e469d68d138bc8fbc416a7866919a0f1921fc (diff)
Merge "res_pjsip/config_domain_aliases.c: Add check for missing domain."
Diffstat (limited to 'res')
-rw-r--r--res/res_pjsip/config_domain_aliases.c23
1 files changed, 21 insertions, 2 deletions
diff --git a/res/res_pjsip/config_domain_aliases.c b/res/res_pjsip/config_domain_aliases.c
index 8feff0571..79ea8dd0e 100644
--- a/res/res_pjsip/config_domain_aliases.c
+++ b/res/res_pjsip/config_domain_aliases.c
@@ -34,8 +34,9 @@ static void domain_alias_destroy(void *obj)
static void *domain_alias_alloc(const char *name)
{
- struct ast_sip_domain_alias *alias = ast_sorcery_generic_alloc(sizeof(*alias), domain_alias_destroy);
+ struct ast_sip_domain_alias *alias;
+ alias = ast_sorcery_generic_alloc(sizeof(*alias), domain_alias_destroy);
if (!alias) {
return NULL;
}
@@ -48,6 +49,23 @@ static void *domain_alias_alloc(const char *name)
return alias;
}
+/*! \brief Apply handler for domain_alias type */
+static int domain_alias_apply(const struct ast_sorcery *sorcery, void *obj)
+{
+ struct ast_sip_domain_alias *alias = obj;
+
+ if (ast_strlen_zero(alias->domain)) {
+ /*
+ * What is the point of defining an alias and not saying
+ * what is being aliased?
+ */
+ ast_log(LOG_ERROR, "%s '%s' missing required domain being aliased.\n",
+ SIP_SORCERY_DOMAIN_ALIAS_TYPE, ast_sorcery_object_get_id(alias));
+ return -1;
+ }
+ return 0;
+}
+
/*! \brief Initialize sorcery with domain alias support */
int ast_sip_initialize_sorcery_domain_alias(void)
{
@@ -55,7 +73,8 @@ int ast_sip_initialize_sorcery_domain_alias(void)
ast_sorcery_apply_default(sorcery, SIP_SORCERY_DOMAIN_ALIAS_TYPE, "config", "pjsip.conf,criteria=type=domain_alias");
- if (ast_sorcery_object_register(sorcery, SIP_SORCERY_DOMAIN_ALIAS_TYPE, domain_alias_alloc, NULL, NULL)) {
+ if (ast_sorcery_object_register(sorcery, SIP_SORCERY_DOMAIN_ALIAS_TYPE,
+ domain_alias_alloc, NULL, domain_alias_apply)) {
return -1;
}