| 
									
										
										
										
											2013-04-25 18:25:31 +00:00
										 |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2015-03-11 16:39:29 +00:00
										 |  |  |  * res_pjsip_private.h | 
					
						
							| 
									
										
										
										
											2013-04-25 18:25:31 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  *  Created on: Jan 25, 2013 | 
					
						
							|  |  |  |  *      Author: mjordan | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-07-31 13:31:55 +00:00
										 |  |  | #ifndef RES_PJSIP_PRIVATE_H_
 | 
					
						
							|  |  |  | #define RES_PJSIP_PRIVATE_H_
 | 
					
						
							| 
									
										
										
										
											2013-04-25 18:25:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-03-11 16:39:29 +00:00
										 |  |  | /*!
 | 
					
						
							|  |  |  |  * \todo XXX Functions prototyped in this file that begin with "ast_sip_" | 
					
						
							|  |  |  |  * need to be renamed so res_pjsip.so does not export the names outside | 
					
						
							|  |  |  |  * of the module. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-23 17:26:57 +00:00
										 |  |  | #include "asterisk/module.h"
 | 
					
						
							| 
									
										
										
										
											2014-01-28 20:47:15 +00:00
										 |  |  | #include "asterisk/compat.h"
 | 
					
						
							| 
									
										
										
										
											2013-11-23 17:26:57 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-25 18:25:31 +00:00
										 |  |  | struct ao2_container; | 
					
						
							| 
									
										
										
										
											2025-10-27 10:06:49 -03:00
										 |  |  | struct ast_threadpool_options; | 
					
						
							| 
									
										
										
										
											2015-04-09 22:07:50 +00:00
										 |  |  | struct ast_sip_cli_context; | 
					
						
							| 
									
										
										
										
											2013-04-25 18:25:31 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /*!
 | 
					
						
							| 
									
										
										
										
											2015-03-11 16:39:29 +00:00
										 |  |  |  * \internal | 
					
						
							| 
									
										
										
										
											2013-07-30 18:14:50 +00:00
										 |  |  |  * \brief Initialize the configuration for res_pjsip | 
					
						
							| 
									
										
										
										
											2013-04-25 18:25:31 +00:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2015-05-04 15:26:37 -04:00
										 |  |  | int ast_res_pjsip_initialize_configuration(void); | 
					
						
							| 
									
										
										
										
											2013-04-25 18:25:31 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /*!
 | 
					
						
							| 
									
										
										
										
											2015-03-11 16:39:29 +00:00
										 |  |  |  * \internal | 
					
						
							| 
									
										
										
										
											2013-04-25 18:25:31 +00:00
										 |  |  |  * \brief Annihilate the configuration objects | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2013-07-30 18:14:50 +00:00
										 |  |  | void ast_res_pjsip_destroy_configuration(void); | 
					
						
							| 
									
										
										
										
											2013-04-25 18:25:31 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /*!
 | 
					
						
							| 
									
										
										
										
											2015-03-11 16:39:29 +00:00
										 |  |  |  * \internal | 
					
						
							| 
									
										
										
										
											2013-04-25 18:25:31 +00:00
										 |  |  |  * \brief Reload the configuration | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2013-07-30 18:14:50 +00:00
										 |  |  | int ast_res_pjsip_reload_configuration(void); | 
					
						
							| 
									
										
										
										
											2013-04-25 18:25:31 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /*!
 | 
					
						
							| 
									
										
										
										
											2015-03-11 16:39:29 +00:00
										 |  |  |  * \internal | 
					
						
							|  |  |  |  * \brief Initialize transport support on a sorcery instance | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \retval -1 failure | 
					
						
							|  |  |  |  * \retval 0 success | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | int ast_sip_initialize_sorcery_transport(void); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*!
 | 
					
						
							|  |  |  |  * \internal | 
					
						
							|  |  |  |  * \brief Destroy transport support on a sorcery instance | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \retval -1 failure | 
					
						
							|  |  |  |  * \retval 0 success | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | int ast_sip_destroy_sorcery_transport(void); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*!
 | 
					
						
							|  |  |  |  * \internal | 
					
						
							|  |  |  |  * \brief Initialize qualify support on a sorcery instance | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \retval -1 failure | 
					
						
							|  |  |  |  * \retval 0 success | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | int ast_sip_initialize_sorcery_qualify(void); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*!
 | 
					
						
							|  |  |  |  * \internal | 
					
						
							|  |  |  |  * \brief Initialize location support on a sorcery instance | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \retval -1 failure | 
					
						
							|  |  |  |  * \retval 0 success | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | int ast_sip_initialize_sorcery_location(void); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*!
 | 
					
						
							|  |  |  |  * \internal | 
					
						
							|  |  |  |  * \brief Destroy location support on a sorcery instance | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \retval -1 failure | 
					
						
							|  |  |  |  * \retval 0 success | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | int ast_sip_destroy_sorcery_location(void); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*!
 | 
					
						
							|  |  |  |  * \internal | 
					
						
							|  |  |  |  * \brief Initialize domain aliases support on a sorcery instance | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \retval -1 failure | 
					
						
							|  |  |  |  * \retval 0 success | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | int ast_sip_initialize_sorcery_domain_alias(void); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*!
 | 
					
						
							|  |  |  |  * \internal | 
					
						
							|  |  |  |  * \brief Initialize authentication support on a sorcery instance | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \retval -1 failure | 
					
						
							|  |  |  |  * \retval 0 success | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | int ast_sip_initialize_sorcery_auth(void); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*!
 | 
					
						
							|  |  |  |  * \internal | 
					
						
							|  |  |  |  * \brief Destroy authentication support on a sorcery instance | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \retval -1 failure | 
					
						
							|  |  |  |  * \retval 0 success | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | int ast_sip_destroy_sorcery_auth(void); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*!
 | 
					
						
							|  |  |  |  * \internal | 
					
						
							|  |  |  |  * \brief Initialize the distributor module | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * The distributor module is responsible for taking an incoming | 
					
						
							| 
									
										
										
										
											2025-10-27 10:06:49 -03:00
										 |  |  |  * SIP message and placing it into the threadpool. Once in the threadpool, | 
					
						
							| 
									
										
										
										
											2015-03-11 16:39:29 +00:00
										 |  |  |  * the distributor will perform endpoint lookups and authentication, and | 
					
						
							|  |  |  |  * then distribute the message up the stack to any further modules. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \retval -1 Failure | 
					
						
							|  |  |  |  * \retval 0 Success | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | int ast_sip_initialize_distributor(void); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*!
 | 
					
						
							|  |  |  |  * \internal | 
					
						
							|  |  |  |  * \brief Destruct the distributor module. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Unregisters pjsip modules and cleans up any allocated resources. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | void ast_sip_destroy_distributor(void); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-28 18:26:17 -05:00
										 |  |  | /*!
 | 
					
						
							|  |  |  |  * \internal | 
					
						
							|  |  |  |  * \brief Initialize the transport events notify module | 
					
						
							|  |  |  |  * \since 13.18.0 | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * The transport events notify module is responsible for monitoring | 
					
						
							|  |  |  |  * when transports die and calling any registered callbacks when that | 
					
						
							|  |  |  |  * happens.  It also manages any PJPROJECT transport state callbacks | 
					
						
							|  |  |  |  * registered to it so the callbacks be more dynamic allowing module | 
					
						
							|  |  |  |  * loading/unloading. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \retval -1 Failure | 
					
						
							|  |  |  |  * \retval 0 Success | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | int ast_sip_initialize_transport_events(void); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*!
 | 
					
						
							|  |  |  |  * \internal | 
					
						
							|  |  |  |  * \brief Destruct the transport events notify module. | 
					
						
							|  |  |  |  * \since 13.18.0 | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | void ast_sip_destroy_transport_events(void); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-03-11 16:39:29 +00:00
										 |  |  | /*!
 | 
					
						
							|  |  |  |  * \internal | 
					
						
							|  |  |  |  * \brief Initialize global type on a sorcery instance | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \retval -1 failure | 
					
						
							|  |  |  |  * \retval 0 success | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | int ast_sip_initialize_sorcery_global(void); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*!
 | 
					
						
							|  |  |  |  * \internal | 
					
						
							|  |  |  |  * \brief Destroy global type on a sorcery instance | 
					
						
							|  |  |  |  * \since 13.3.0 | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \retval -1 failure | 
					
						
							|  |  |  |  * \retval 0 success | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | int ast_sip_destroy_sorcery_global(void); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*!
 | 
					
						
							|  |  |  |  * \internal | 
					
						
							|  |  |  |  * \brief Initialize global headers support | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | void ast_sip_initialize_global_headers(void); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*!
 | 
					
						
							|  |  |  |  * \internal | 
					
						
							|  |  |  |  * \brief Destroy global headers support | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | void ast_sip_destroy_global_headers(void); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-11 18:34:53 +00:00
										 |  |  | /*!
 | 
					
						
							|  |  |  |  * \internal | 
					
						
							|  |  |  |  * \brief Pre-initialize OPTIONS request handling. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \retval 0 on success | 
					
						
							|  |  |  |  * \retval other on failure | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | int ast_res_pjsip_preinit_options_handling(void); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-03-11 16:39:29 +00:00
										 |  |  | /*!
 | 
					
						
							|  |  |  |  * \internal | 
					
						
							| 
									
										
										
										
											2013-04-25 18:25:31 +00:00
										 |  |  |  * \brief Initialize OPTIONS request handling. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * XXX This currently includes qualifying peers. It shouldn't. | 
					
						
							|  |  |  |  * That should go into a registrar. When that occurs, we won't | 
					
						
							|  |  |  |  * need the reload stuff. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param reload Reload options handling | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \retval 0 on success | 
					
						
							|  |  |  |  * \retval other on failure | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2013-07-30 18:14:50 +00:00
										 |  |  | int ast_res_pjsip_init_options_handling(int reload); | 
					
						
							| 
									
										
										
										
											2013-04-25 18:25:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-19 11:13:21 +00:00
										 |  |  | /*!
 | 
					
						
							|  |  |  |  * \internal Initialize message IP updating handling. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \retval 0 on success | 
					
						
							|  |  |  |  * \retval other on failure | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-09-13 15:23:54 -06:00
										 |  |  | int ast_res_pjsip_init_message_filter(void); | 
					
						
							| 
									
										
										
										
											2016-09-19 11:13:21 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-06-22 14:03:22 +00:00
										 |  |  | /*!
 | 
					
						
							| 
									
										
										
										
											2015-03-11 16:39:29 +00:00
										 |  |  |  * \internal | 
					
						
							| 
									
										
										
										
											2013-06-22 14:03:22 +00:00
										 |  |  |  * \brief Initialize transport storage for contacts. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \retval 0 on success | 
					
						
							|  |  |  |  * \retval other on failure | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2013-07-30 18:14:50 +00:00
										 |  |  | int ast_res_pjsip_init_contact_transports(void); | 
					
						
							| 
									
										
										
										
											2013-06-22 14:03:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-07-18 19:25:51 +00:00
										 |  |  | /*!
 | 
					
						
							| 
									
										
										
										
											2015-03-11 16:39:29 +00:00
										 |  |  |  * \internal | 
					
						
							| 
									
										
										
										
											2013-07-18 19:25:51 +00:00
										 |  |  |  * \brief Initialize system configuration | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \retval 0 Success | 
					
						
							|  |  |  |  * \retval non-zero Failure | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | int ast_sip_initialize_system(void); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-02-20 20:45:30 +00:00
										 |  |  | /*!
 | 
					
						
							| 
									
										
										
										
											2015-03-11 16:39:29 +00:00
										 |  |  |  * \internal | 
					
						
							| 
									
										
										
										
											2014-02-20 20:45:30 +00:00
										 |  |  |  * \brief Destroy system configuration | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | void ast_sip_destroy_system(void); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-03-17 22:54:32 +00:00
										 |  |  | /*!
 | 
					
						
							| 
									
										
										
										
											2015-03-11 16:39:29 +00:00
										 |  |  |  * \internal | 
					
						
							| 
									
										
										
										
											2014-03-17 22:54:32 +00:00
										 |  |  |  * \brief Initialize nameserver configuration | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | void ast_sip_initialize_dns(void); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-13 10:47:01 -03:00
										 |  |  | /*!
 | 
					
						
							|  |  |  |  * \internal | 
					
						
							|  |  |  |  * \brief Initialize our own resolver support | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | void ast_sip_initialize_resolver(void); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-07-18 19:25:51 +00:00
										 |  |  | /*!
 | 
					
						
							| 
									
										
										
										
											2015-03-11 16:39:29 +00:00
										 |  |  |  * \internal | 
					
						
							| 
									
										
										
										
											2013-07-18 19:25:51 +00:00
										 |  |  |  * \brief Initialize global configuration | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \retval 0 Success | 
					
						
							|  |  |  |  * \retval non-zero Failure | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | int ast_sip_initialize_global(void); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-08-02 12:40:03 +00:00
										 |  |  | /*!
 | 
					
						
							| 
									
										
										
										
											2015-03-11 16:39:29 +00:00
										 |  |  |  * \internal | 
					
						
							| 
									
										
										
										
											2013-08-02 12:40:03 +00:00
										 |  |  |  * \brief Clean up res_pjsip options handling | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | void ast_res_pjsip_cleanup_options_handling(void); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-19 11:13:21 +00:00
										 |  |  | /*!
 | 
					
						
							|  |  |  |  * \internal | 
					
						
							|  |  |  |  * \brief Clean up res_pjsip message ip updating handling | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-09-13 15:23:54 -06:00
										 |  |  | void ast_res_pjsip_cleanup_message_filter(void); | 
					
						
							| 
									
										
										
										
											2016-09-19 11:13:21 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-08-06 13:08:13 +00:00
										 |  |  | /*!
 | 
					
						
							| 
									
										
										
										
											2015-03-11 16:39:29 +00:00
										 |  |  |  * \internal | 
					
						
							| 
									
										
										
										
											2025-10-27 10:06:49 -03:00
										 |  |  |  * \brief Get threadpool options | 
					
						
							| 
									
										
										
										
											2013-08-06 13:08:13 +00:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2025-10-27 10:06:49 -03:00
										 |  |  | void sip_get_threadpool_options(struct ast_threadpool_options *threadpool_options); | 
					
						
							| 
									
										
										
										
											2013-08-06 13:08:13 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-11 20:24:50 +00:00
										 |  |  | /*!
 | 
					
						
							| 
									
										
										
										
											2015-03-11 16:39:29 +00:00
										 |  |  |  * \internal | 
					
						
							| 
									
										
										
										
											2013-12-11 20:24:50 +00:00
										 |  |  |  * \brief Retrieve the name of the default outbound endpoint. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \note This returns a memory allocated copy of the name that | 
					
						
							|  |  |  |  *       needs to be freed by the caller. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \retval The name of the default outbound endpoint. | 
					
						
							|  |  |  |  * \retval NULL if configuration not found. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | char *ast_sip_global_default_outbound_endpoint(void); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-20 21:32:13 +00:00
										 |  |  | /*!
 | 
					
						
							| 
									
										
										
										
											2015-03-11 16:39:29 +00:00
										 |  |  |  * \internal | 
					
						
							| 
									
										
										
										
											2013-12-20 21:32:13 +00:00
										 |  |  |  * \brief Functions for initializing and destroying the CLI. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2014-02-06 17:55:45 +00:00
										 |  |  | int ast_sip_initialize_cli(void); | 
					
						
							| 
									
										
										
										
											2013-12-20 21:32:13 +00:00
										 |  |  | void ast_sip_destroy_cli(void); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-09 22:07:50 +00:00
										 |  |  | /*!
 | 
					
						
							|  |  |  |  * \internal | 
					
						
							|  |  |  |  * \brief Add res_pjsip global configuration options to the cli context. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param context context to add options to | 
					
						
							|  |  |  |  * \retval 0 Success, -1 on failure | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | int sip_cli_print_global(struct ast_sip_cli_context *context); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*!
 | 
					
						
							|  |  |  |  * \internal | 
					
						
							|  |  |  |  * \brief Add res_pjsip system configuration options to the cli context. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param context context to add options to | 
					
						
							|  |  |  |  * \retval 0 Success, -1 on failure | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | int sip_cli_print_system(struct ast_sip_cli_context *context); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-10-04 11:46:44 -04:00
										 |  |  | struct ast_sip_session_supplement; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-27 11:11:40 -06:00
										 |  |  | /*!
 | 
					
						
							|  |  |  |  * \internal | 
					
						
							|  |  |  |  * \brief Finds or creates contact_status for a contact | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | struct ast_sip_contact_status *ast_res_pjsip_find_or_create_contact_status(const struct ast_sip_contact *contact); | 
					
						
							| 
									
										
										
										
											2016-04-14 07:23:54 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /*!
 | 
					
						
							|  |  |  |  * \internal | 
					
						
							|  |  |  |  * \brief Validate that the uri meets pjproject length restrictions | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | int ast_sip_validate_uri_length(const char *uri); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												res_pjsip:  Add serialized scheduler (res_pjsip/pjsip_scheduler.c)
There are several places that do scheduled tasks or periodic housecleaning,
each with its own implementation:
* res_pjsip_keepalive has a thread that sends keepalives.
* pjsip_distributor has a thread that cleans up expired unidentified requests.
* res_pjsip_registrar_expire has a thread that cleans up expired contacts.
* res_pjsip_pubsub uses ast_sched directly and then calls ast_sip_push_task.
* res_pjsip_sdp_rtp also uses ast_sched to send keepalives.
There are also places where we should be doing scheduled work but aren't.
A good example are the places we have sorcery observers to start registration
or qualify.  These don't work when changes are made to a backend database
without a pjsip reload.  We need to check periodically.
As a first step to solving these issues, a new ast_sip_sched facility has
been created.
ast_sip_sched wraps ast_sched but only uses ast_sched as a scheduled queue.
When a task is ready to run, ast_sip_task_pusk is called for it. This ensures
that the task is executed in a PJLIB registered thread and doesn't hold up the
ast_sched thread so it can immediately continue processing the queue.  The
serializer used by ast_sip_sched is one of your choosing or a random one from
the res_pjsip pool if you don't choose one.
Another feature is the ability to automatically clean up the task_data when the
task expires (if ever).  If it's an ao2 object, it will be dereferenced, if
it's a malloc'd object it will be freed.  This is selectable when the task is
scheduled.  Even if you choose to not auto dereference an ao2 task data object,
the scheduler itself maintains a reference to it while the task is under it's
control.  This prevents the data from disappearing out from under the task.
There are two scheduling models.
AST_SIP_SCHED_TASK_PERIODIC specifies that the invocations of the task occur at
the specific interval.  That is, every "interval" milliseconds, regardless of
how long the task takes.  If the task takes longer than the interval, it will
be scheduled at the next available multiple of interval.  For exmaple: If the
task has an interval of 60 secs and the task takes 70 secs (it better not),
the next invocation will happen at 120 seconds.
AST_SIP_SCHED_TASK_DELAY specifies that the next invocation of the task should
start "interval" milliseconds after the current invocation has finished.
Also, the same ast_sched facility for fixed or variable intervals exists.  The
task's return code in conjunction with the AST_SIP_SCHED_TASK_FIXED or
AST_SIP_SCHED_TASK_VARIABLE flags controls the next invocation start time.
One res_pjsip.h housekeeping change was made.  The pjsip header files were
added to the top.  There have been a few cases lately where I've needed
res_pjsip.h just for ast_sip calls and had compiles fail spectacularly because
I didn't add the pjsip header files to my source even though I never referenced
any pjsip calls.
Finally, a few new convenience APIs were added to astobj2 to make things a
little easier in the scheduler.  ao2_ref_and_lock() calls ao2_ref() and
ao2_lock() in one go.  ao2_unlock_and_unref() does the reverse. A few macros
were also copied from res_phoneprov because I got tired of having to duplicate
the same hash, sort and compare functions over and over again. The
AO2_STRING_FIELD_(HASH|SORT|CMP)_FN macros will insert functions suitable for
aor_container_alloc into your source.
This facility can be used immediately for the situations where we already have
a thread that wakes up periodically or do some scheduled work.  For the
registration and qualify issues, additional sorcery and schema changes would
need to be made so that we can easily detect changed objects on a periodic
basis without having to pull the entire database back to check.  I'm thinking
of a last-updated timestamp on the rows but more on this later.
Change-Id: I7af6ad2b2d896ea68e478aa1ae201d6dd016ba1c
											
										 
											2016-03-17 11:28:26 -06:00
										 |  |  | /*!
 | 
					
						
							|  |  |  |  * \brief Initialize scheduler | 
					
						
							|  |  |  |  * \since 13.9.0 | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \retval -1 failure | 
					
						
							|  |  |  |  * \retval 0 success | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | int ast_sip_initialize_scheduler(void); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*!
 | 
					
						
							|  |  |  |  * \internal | 
					
						
							|  |  |  |  * \brief Destroy scheduler | 
					
						
							|  |  |  |  * \since 13.9.0 | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \retval -1 failure | 
					
						
							|  |  |  |  * \retval 0 success | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | int ast_sip_destroy_scheduler(void); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-28 09:10:00 -07:00
										 |  |  | /*!
 | 
					
						
							|  |  |  |  * \internal | 
					
						
							|  |  |  |  * \brief Determines if a uri will still be valid after an asterisk restart | 
					
						
							|  |  |  |  * \since 13.20.0 | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param uri uri to test | 
					
						
							|  |  |  |  * \param endpoint The associated endpoint | 
					
						
							|  |  |  |  * \param rdata The rdata to get transport information from | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \retval 1 Yes, 0 No | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | int ast_sip_will_uri_survive_restart(pjsip_sip_uri *uri, struct ast_sip_endpoint *endpoint, | 
					
						
							|  |  |  | 	pjsip_rx_data *rdata); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-06 11:07:18 -07:00
										 |  |  | /*!
 | 
					
						
							|  |  |  |  * \internal | 
					
						
							|  |  |  |  * \brief Initialize the transport management module | 
					
						
							|  |  |  |  * \since 13.20.0 | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * The transport management module is responsible for 3 things... | 
					
						
							|  |  |  |  * 1.  It automatically destroys any reliable transport that does not | 
					
						
							|  |  |  |  * receive a valid request within system/timer_b milliseconds of the | 
					
						
							|  |  |  |  * connection being opened. (Attack mitigation) | 
					
						
							|  |  |  |  * 2.  Since it increments the reliable transport's reference count | 
					
						
							|  |  |  |  * for that period of time, it also prevents issues if the transport | 
					
						
							|  |  |  |  * disconnects while we're still trying to process a response. | 
					
						
							|  |  |  |  *  (Attack mitigation) | 
					
						
							| 
									
										
										
										
											2021-11-16 10:40:37 +01:00
										 |  |  |  * 3.  If enabled by global/keep_alive_interval, it sends '\\r\\n' | 
					
						
							| 
									
										
										
										
											2018-02-06 11:07:18 -07:00
										 |  |  |  * keepalives on reliable transports at the interval specified. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \retval -1 Failure | 
					
						
							|  |  |  |  * \retval 0 Success | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | int ast_sip_initialize_transport_management(void); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*!
 | 
					
						
							|  |  |  |  * \internal | 
					
						
							|  |  |  |  * \brief Destruct the transport management module. | 
					
						
							|  |  |  |  * \since 13.20.0 | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | void ast_sip_destroy_transport_management(void); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-01-15 17:20:30 -06:00
										 |  |  | /*!
 | 
					
						
							|  |  |  |  * \internal | 
					
						
							|  |  |  |  * \brief Add online persistent endpoints to the given regcontext | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \param regcontext The context to add endpoints to | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * \retval -1 on error, 0 on success | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | int ast_sip_persistent_endpoint_add_to_regcontext(const char *regcontext); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-02-15 11:53:50 -07:00
										 |  |  | enum ast_sip_taskprocessor_overload_trigger { | 
					
						
							|  |  |  | 	TASKPROCESSOR_OVERLOAD_TRIGGER_NONE = 0, | 
					
						
							|  |  |  | 	TASKPROCESSOR_OVERLOAD_TRIGGER_GLOBAL, | 
					
						
							|  |  |  | 	TASKPROCESSOR_OVERLOAD_TRIGGER_PJSIP_ONLY | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | enum ast_sip_taskprocessor_overload_trigger ast_sip_get_taskprocessor_overload_trigger(void); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | const char *ast_sip_overload_trigger_to_str(enum ast_sip_taskprocessor_overload_trigger trigger); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-07-31 13:31:55 +00:00
										 |  |  | #endif /* RES_PJSIP_PRIVATE_H_ */
 |