mirror of
				https://github.com/asterisk/asterisk.git
				synced 2025-10-31 10:47:18 +00:00 
			
		
		
		
	res_pjsip_session: Enable RFC3578 overlap dialing support.
Support for RFC3578 overlap dialling (i.e. 484 Response to partially matched destinations) as currently provided by chan_sip is missing from res_pjsip. This patch adds a new endpoint attribute (allow_overlap) [defaults to yes] which when set to yes enables 484 responses to partial destination matches rather than the current 404. ASTERISK-26864 Change-Id: Iea444da3ee7c7d4f1fde1d01d138a3d7b0fe40f6
This commit is contained in:
		
				
					committed by
					
						 Joshua Colp
						Joshua Colp
					
				
			
			
				
	
			
			
			
						parent
						
							f5603cb1ec
						
					
				
				
					commit
					6b7697ed48
				
			| @@ -100,6 +100,9 @@ | ||||
| 				<configOption name="allow"> | ||||
| 					<synopsis>Media Codec(s) to allow</synopsis> | ||||
| 				</configOption> | ||||
| 				<configOption name="allow_overlap" default="yes"> | ||||
| 					<synopsis>Enable RFC3578 overlap dialing support.</synopsis> | ||||
| 				</configOption> | ||||
| 				<configOption name="aors"> | ||||
| 					<synopsis>AoR(s) to be used with the endpoint</synopsis> | ||||
| 					<description><para> | ||||
| @@ -2134,6 +2137,9 @@ | ||||
| 				<parameter name="SubscribeContext"> | ||||
| 					<para><xi:include xpointer="xpointer(/docs/configInfo[@name='res_pjsip']/configFile[@name='pjsip.conf']/configObject[@name='endpoint']/configOption[@name='subscribe_context']/synopsis/node())"/></para> | ||||
| 				</parameter> | ||||
| 				<parameter name="Allowoverlap"> | ||||
| 					<para><xi:include xpointer="xpointer(/docs/configInfo[@name='res_pjsip']/configFile[@name='pjsip.conf']/configObject[@name='endpoint']/configOption[@name='allow_overlap']/synopsis/node())"/></para> | ||||
| 				</parameter> | ||||
| 			</syntax> | ||||
| 		</managerEventInstance> | ||||
| 	</managerEvent> | ||||
|   | ||||
| @@ -1938,6 +1938,7 @@ int ast_res_pjsip_initialize_configuration(void) | ||||
| 	ast_sorcery_object_field_register(sip_sorcery, "endpoint", "preferred_codec_only", "no", OPT_BOOL_T, 1, FLDSET(struct ast_sip_endpoint, preferred_codec_only)); | ||||
| 	ast_sorcery_object_field_register(sip_sorcery, "endpoint", "asymmetric_rtp_codec", "no", OPT_BOOL_T, 1, FLDSET(struct ast_sip_endpoint, asymmetric_rtp_codec)); | ||||
| 	ast_sorcery_object_field_register(sip_sorcery, "endpoint", "rtcp_mux", "no", OPT_BOOL_T, 1, FLDSET(struct ast_sip_endpoint, media.rtcp_mux)); | ||||
| 	ast_sorcery_object_field_register(sip_sorcery, "endpoint", "allow_overlap", "yes", OPT_BOOL_T, 1, FLDSET(struct ast_sip_endpoint, allow_overlap)); | ||||
|  | ||||
| 	if (ast_sip_initialize_sorcery_transport()) { | ||||
| 		ast_log(LOG_ERROR, "Failed to register SIP transport support with sorcery\n"); | ||||
|   | ||||
| @@ -1986,10 +1986,17 @@ static enum sip_get_destination_result get_destination(struct ast_sip_session *s | ||||
|  | ||||
| 		return SIP_GET_DEST_EXTEN_FOUND; | ||||
| 	} | ||||
| 	/* XXX In reality, we'll likely have further options so that partial matches | ||||
| 	 * can be indicated here, but for getting something up and running, we're going | ||||
| 	 * to return a "not exists" error here. | ||||
|  | ||||
| 	/* | ||||
| 	 * Check for partial match via overlap dialling (if enabled) | ||||
| 	 */ | ||||
| 	if (session->endpoint->allow_overlap && ( | ||||
| 		!strncmp(session->exten, pickupexten, strlen(session->exten)) || | ||||
| 		ast_canmatch_extension(NULL, session->endpoint->context, session->exten, 1, NULL))) { | ||||
| 		/* Overlap partial match */ | ||||
| 		return SIP_GET_DEST_EXTEN_PARTIAL; | ||||
| 	} | ||||
|  | ||||
| 	return SIP_GET_DEST_EXTEN_NOT_FOUND; | ||||
| } | ||||
|  | ||||
| @@ -2106,8 +2113,17 @@ static int new_invite(void *data) | ||||
| 			pjsip_inv_terminate(invite->session->inv_session, 416, PJ_TRUE); | ||||
| 		} | ||||
| 		goto end; | ||||
| 	case SIP_GET_DEST_EXTEN_NOT_FOUND: | ||||
| 	case SIP_GET_DEST_EXTEN_PARTIAL: | ||||
| 		ast_debug(1, "Call from '%s' (%s:%s:%d) to extension '%s' - partial match\n", ast_sorcery_object_get_id(invite->session->endpoint), | ||||
| 			invite->rdata->tp_info.transport->type_name, invite->rdata->pkt_info.src_name, invite->rdata->pkt_info.src_port, invite->session->exten); | ||||
|  | ||||
| 		if (pjsip_inv_initial_answer(invite->session->inv_session, invite->rdata, 484, NULL, NULL, &tdata) == PJ_SUCCESS) { | ||||
| 			ast_sip_session_send_response(invite->session, tdata); | ||||
| 		} else  { | ||||
| 			pjsip_inv_terminate(invite->session->inv_session, 484, PJ_TRUE); | ||||
| 		} | ||||
| 		goto end; | ||||
| 	case SIP_GET_DEST_EXTEN_NOT_FOUND: | ||||
| 	default: | ||||
| 		ast_log(LOG_NOTICE, "Call from '%s' (%s:%s:%d) to extension '%s' rejected because extension not found in context '%s'.\n", | ||||
| 			ast_sorcery_object_get_id(invite->session->endpoint), invite->rdata->tp_info.transport->type_name, invite->rdata->pkt_info.src_name, | ||||
|   | ||||
		Reference in New Issue
	
	Block a user