diff --git a/channels/chan_pjsip.c b/channels/chan_pjsip.c index 46fa32775c29a66f458514a661e653ffc8bfc5ce..f4409de4a78ed031c96582cd7f5a7877cb9d8f0d 100644 --- a/channels/chan_pjsip.c +++ b/channels/chan_pjsip.c @@ -2980,6 +2980,18 @@ static void chan_pjsip_session_end(struct ast_sip_session *session) SCOPE_EXIT_RTN(); } +static void set_sipdomain_variable(struct ast_sip_session *session) +{ + pjsip_sip_uri *sip_ruri = pjsip_uri_get_uri(session->request_uri); + size_t size = pj_strlen(&sip_ruri->host) + 1; + char *domain = ast_alloca(size); + + ast_copy_pj_str(domain, &sip_ruri->host, size); + + pbx_builtin_setvar_helper(session->channel, "SIPDOMAIN", domain); + return; +} + /*! \brief Function called when a request is received on the session */ static int chan_pjsip_incoming_request(struct ast_sip_session *session, struct pjsip_rx_data *rdata) { @@ -3031,6 +3043,9 @@ static int chan_pjsip_incoming_request(struct ast_sip_session *session, struct p SCOPE_EXIT_LOG_RTN_VALUE(-1, LOG_ERROR, "%s: Failed to allocate new PJSIP channel on incoming SIP INVITE\n", ast_sip_session_get_name(session)); } + + set_sipdomain_variable(session); + /* channel gets created on incoming request, but we wait to call start so other supplements have a chance to run */ SCOPE_EXIT_RTN_VALUE(0, "%s\n", ast_sip_session_get_name(session)); diff --git a/res/res_pjsip_session.c b/res/res_pjsip_session.c index 82ef2aab56a5c198df14b5c515904c010ef93b0a..b09e5136df7337dd17b9f2164c3f9616ffcf8f49 100644 --- a/res/res_pjsip_session.c +++ b/res/res_pjsip_session.c @@ -3733,7 +3733,7 @@ static enum sip_get_destination_result get_destination(struct ast_sip_session *s */ AST_SIP_USER_OPTIONS_TRUNCATE_CHECK(session->exten); - pickup_cfg = ast_get_chan_features_pickup_config(session->channel); + pickup_cfg = ast_get_chan_features_pickup_config(NULL); /* session->channel doesn't exist yet, using NULL */ if (!pickup_cfg) { ast_log(LOG_ERROR, "%s: Unable to retrieve pickup configuration options. Unable to detect call pickup extension\n", ast_sip_session_get_name(session)); @@ -3745,12 +3745,6 @@ static enum sip_get_destination_result get_destination(struct ast_sip_session *s if (!strcmp(session->exten, pickupexten) || ast_exists_extension(NULL, session->endpoint->context, session->exten, 1, NULL)) { - size_t size = pj_strlen(&sip_ruri->host) + 1; - char *domain = ast_alloca(size); - - ast_copy_pj_str(domain, &sip_ruri->host, size); - pbx_builtin_setvar_helper(session->channel, "SIPDOMAIN", domain); - /* * Save off the INVITE Request-URI in case it is * needed: CHANNEL(pjsip,request_uri)