apt_bool_t mrcp_client_session_terminate_event_process(mrcp_client_session_t *session)
{
	if(session->state == SESSION_STATE_TERMINATING) {
		/* session termination request has been sent, still waiting for the response,
		   all the events must be ignored at this stage */
		apt_obj_log(APT_LOG_MARK,APT_PRIO_WARNING,session->base.log_obj,"Unexpected Event! "APT_NAMESID_FMT, 
			MRCP_SESSION_NAMESID(session));
		return FALSE;
	}
	
	if(session->active_request) {
		apt_bool_t process_pending_requests = TRUE;
		/* raise app response */
		session->status = MRCP_SIG_STATUS_CODE_TERMINATE;
		mrcp_app_failure_message_raise(session);

		/* cancel remaing requests, but do process session termination request (if any) */
		do {
			session->active_request = apt_list_pop_front(session->request_queue);
			if(session->active_request) {
				const mrcp_app_message_t *app_message = session->active_request;
				if(app_message->message_type == MRCP_APP_MESSAGE_TYPE_SIGNALING &&
					app_message->sig_message.command_id == MRCP_SIG_COMMAND_SESSION_TERMINATE) {
					/* process session termination */
					mrcp_app_request_dispatch(session,app_message);
					break;
				}

				/* cancel pending request */
				session->status = MRCP_SIG_STATUS_CODE_CANCEL;
				mrcp_app_failure_message_raise(session);
			}
			else {
				process_pending_requests = FALSE;
			}
		}
		while(process_pending_requests == TRUE);
	}
	else {
		/* raise app event */
		mrcp_app_sig_event_raise(session,NULL);
	}
	return TRUE;
}
static apt_bool_t mrcp_app_request_dispatch(mrcp_client_session_t *session, const mrcp_app_message_t *app_message)
{
	if(session->state == SESSION_STATE_TERMINATING) {
		/* no more requests are allowed, as session is being terminated!
		   just return, it is horribly wrong and can crash anytime here */
		apt_obj_log(APT_LOG_MARK,APT_PRIO_ERROR,session->base.log_obj,"Inappropriate Application Request "APT_NAMESID_FMT" [%d]",
			MRCP_SESSION_NAMESID(session),
			app_message->sig_message.command_id);
		return FALSE;
	}
	
	if(session->registered == FALSE) {
		session->base.signaling_agent = session->profile->signaling_agent;
		if(session->base.signaling_agent->create_client_session(&session->base,session->profile->signaling_settings) != TRUE) {
			/* raise app response */
			apt_obj_log(APT_LOG_MARK,APT_PRIO_WARNING,session->base.log_obj,"Failed to Create Session "APT_NAMESID_FMT" [%d]",
				MRCP_SESSION_NAMESID(session),
				app_message->sig_message.command_id);
			session->status = MRCP_SIG_STATUS_CODE_FAILURE;
			return mrcp_app_failure_message_raise(session);
		}

		mrcp_client_session_add(session->application->client,session);
		session->registered = TRUE;
	}
	session->status = MRCP_SIG_STATUS_CODE_SUCCESS;
	switch(app_message->message_type) {
		case MRCP_APP_MESSAGE_TYPE_SIGNALING:
		{
			apt_obj_log(APT_LOG_MARK,APT_PRIO_DEBUG,session->base.log_obj,"Dispatch App Request "APT_NAMESID_FMT" [%d]",
				MRCP_SESSION_NAMESID(session),
				app_message->sig_message.command_id);
			switch(app_message->sig_message.command_id) {
				case MRCP_SIG_COMMAND_SESSION_UPDATE:
					mrcp_client_session_update(session);
					break;
				case MRCP_SIG_COMMAND_SESSION_TERMINATE:
					mrcp_client_session_terminate(session);
					break;
				case MRCP_SIG_COMMAND_CHANNEL_ADD:
					mrcp_client_channel_add(session,app_message->channel);
					break;
				case MRCP_SIG_COMMAND_CHANNEL_REMOVE:
					mrcp_client_channel_modify(session,app_message->channel,FALSE);
					break;
				case MRCP_SIG_COMMAND_RESOURCE_DISCOVER:
					mrcp_client_resource_discover(session);
					break;
				default:
					break;
			}
			break;
		}
		case MRCP_APP_MESSAGE_TYPE_CONTROL:
		{
			mrcp_client_message_send(session,app_message->channel,app_message->control_message);
			break;
		}
	}
	return TRUE;
}
Пример #3
0
static apt_bool_t mrcp_app_request_dispatch(mrcp_client_session_t *session, const mrcp_app_message_t *app_message)
{
	if(session->state == SESSION_STATE_TERMINATING) {
		/* no more requests are allowed, as session is being terminated!
		   just return, it is horribly wrong and can crash anytime here */
		apt_obj_log(APT_LOG_MARK,APT_PRIO_ERROR,session->base.log_obj,"Inappropriate Application Request " APT_NAMESID_FMT " [%d]",
			MRCP_SESSION_NAMESID(session),
			app_message->sig_message.command_id);
		return FALSE;
	}

	if(session->disconnected == TRUE) {
		/* cancel all the requests besides session termination one */
		if(!IS_SESSION_TERMINATE(app_message)) {
			apt_obj_log(APT_LOG_MARK,APT_PRIO_WARNING,session->base.log_obj,"Cancel App Request " APT_NAMESID_FMT " [%d]",
				MRCP_SESSION_NAMESID(session), app_message->sig_message.command_id);
			session->status = MRCP_SIG_STATUS_CODE_CANCEL;
			return mrcp_app_failure_message_raise(session);
		}
	}

	if(session->registered == FALSE) {
		if(IS_SESSION_TERMINATE(app_message)) {
			/* if session is not registered, nothing to terminate, just respond with success */
			session->status = MRCP_SIG_STATUS_CODE_SUCCESS;
			return mrcp_app_sig_response_raise(session,FALSE);
		}

		/* select signaling agent */
		session->base.signaling_agent = mrcp_sa_factory_agent_select(session->profile->sa_factory);
		if(!session->base.signaling_agent) {
			apt_obj_log(APT_LOG_MARK,APT_PRIO_WARNING,session->base.log_obj,"Failed to Select Signaling Agent " APT_NAMESID_FMT " [%d]",
				MRCP_SESSION_NAMESID(session),
				app_message->sig_message.command_id);
			session->status = MRCP_SIG_STATUS_CODE_FAILURE;
		}
		if(session->profile->mrcp_version == MRCP_VERSION_2) {
			/* select connection agent */
			session->base.connection_agent = mrcp_ca_factory_agent_select(session->profile->ca_factory);
			if(!session->base.connection_agent) {
				apt_obj_log(APT_LOG_MARK,APT_PRIO_WARNING,session->base.log_obj,"Failed to Select Connection Agent " APT_NAMESID_FMT " [%d]",
					MRCP_SESSION_NAMESID(session),
					app_message->sig_message.command_id);
				session->status = MRCP_SIG_STATUS_CODE_FAILURE;
			}
		}
		if(session->profile->mpf_factory) {
			/* select media engine */
			session->base.media_engine = mpf_engine_factory_engine_select(session->profile->mpf_factory);
			if(!session->base.media_engine) {
				apt_obj_log(APT_LOG_MARK,APT_PRIO_WARNING,session->base.log_obj,"Failed to Select Media Engine " APT_NAMESID_FMT " [%d]",
					MRCP_SESSION_NAMESID(session),
					app_message->sig_message.command_id);
				session->status = MRCP_SIG_STATUS_CODE_FAILURE;
			}
		}
		/* set rtp termination factory */
		session->base.rtp_factory = session->profile->rtp_termination_factory;

		if(session->status == MRCP_SIG_STATUS_CODE_FAILURE) {
			/* raise app response in case of failure */
			return mrcp_app_failure_message_raise(session);
		}

		if(session->base.signaling_agent->create_client_session(&session->base,session->profile->signaling_settings) != TRUE) {
			/* raise app response */
			apt_obj_log(APT_LOG_MARK,APT_PRIO_WARNING,session->base.log_obj,"Failed to Create Session " APT_NAMESID_FMT " [%d]",
				MRCP_SESSION_NAMESID(session),
				app_message->sig_message.command_id);
			session->status = MRCP_SIG_STATUS_CODE_FAILURE;
			return mrcp_app_failure_message_raise(session);
		}

		mrcp_client_session_add(session->application->client,session);
		session->registered = TRUE;
	}
	session->status = MRCP_SIG_STATUS_CODE_SUCCESS;
	switch(app_message->message_type) {
		case MRCP_APP_MESSAGE_TYPE_SIGNALING:
		{
			apt_obj_log(APT_LOG_MARK,APT_PRIO_DEBUG,session->base.log_obj,"Dispatch App Request " APT_NAMESID_FMT " [%d]",
				MRCP_SESSION_NAMESID(session),
				app_message->sig_message.command_id);
			switch(app_message->sig_message.command_id) {
				case MRCP_SIG_COMMAND_SESSION_UPDATE:
					mrcp_client_session_update(session);
					break;
				case MRCP_SIG_COMMAND_SESSION_TERMINATE:
					mrcp_client_session_terminate(session);
					break;
				case MRCP_SIG_COMMAND_CHANNEL_ADD:
					mrcp_client_channel_add(session,app_message->channel);
					break;
				case MRCP_SIG_COMMAND_CHANNEL_REMOVE:
					mrcp_client_channel_modify(session,app_message->channel,FALSE);
					break;
				case MRCP_SIG_COMMAND_RESOURCE_DISCOVER:
					mrcp_client_resource_discover(session);
					break;
				default:
					break;
			}
			break;
		}
		case MRCP_APP_MESSAGE_TYPE_CONTROL:
		{
			mrcp_client_message_send(session,app_message->channel,app_message->control_message);
			break;
		}
	}
	return TRUE;
}