mirror of
https://github.com/asterisk/asterisk.git
synced 2025-10-12 15:45:18 +00:00
pjsip_options: Add qualify_timeout processing and eventing
This is the second follow-on to https://reviewboard.asterisk.org/r/4572/ and the discussion at http://lists.digium.com/pipermail/asterisk-dev/2015-March/073921.html The basic issues are that changes in contact status don't cause events to be emitted for the associated endpoint. Only dynamic contact add/delete actions update the endpoint. Also, the qualify timeout is fixed by pjsip at 32 seconds which is a long time. This patch makes use of the new transaction timeout feature in r4585 and provides the following capabilities... 1. A new aor/contact variable 'qualify_timeout' has been added that allows the user to specify the maximum time in milliseconds to wait for a response to an OPTIONS message. The default is 3000ms. When the timer expires, the contact is marked unavailable. 2. Contact status changes are now propagated up to the endpoint as follows... When any contact is 'Available', the endpoint is marked as 'Reachable'. When all contacts are 'Unavailable', the endpoint is marked as 'Unreachable'. The existing endpoint events are generated appropriately. ASTERISK-24863 #close Change-Id: Id0ce0528e58014da1324856ea537e7765466044a Tested-by: Dmitriy Serov Tested-by: George Joseph <george.joseph@fairview5.com>
This commit is contained in:
committed by
Matt Jordan
parent
f1abf51b73
commit
674b18bdf0
@@ -166,6 +166,8 @@ struct ast_sip_contact {
|
||||
unsigned int qualify_frequency;
|
||||
/*! If true authenticate the qualify if needed */
|
||||
int authenticate_qualify;
|
||||
/*! Qualify timeout. 0 is diabled. */
|
||||
double qualify_timeout;
|
||||
};
|
||||
|
||||
#define CONTACT_STATUS "contact_status"
|
||||
@@ -192,6 +194,8 @@ struct ast_sip_contact_status {
|
||||
struct timeval rtt_start;
|
||||
/*! The round trip time in microseconds */
|
||||
int64_t rtt;
|
||||
/*! Last status for a contact (default - unavailable) */
|
||||
enum ast_sip_contact_status_type last_status;
|
||||
};
|
||||
|
||||
/*!
|
||||
@@ -224,6 +228,8 @@ struct ast_sip_aor {
|
||||
struct ao2_container *permanent_contacts;
|
||||
/*! Determines whether SIP Path headers are supported */
|
||||
unsigned int support_path;
|
||||
/*! Qualify timeout. 0 is diabled. */
|
||||
double qualify_timeout;
|
||||
};
|
||||
|
||||
/*!
|
||||
@@ -902,6 +908,15 @@ struct ao2_container *ast_sip_location_retrieve_aor_contacts(const struct ast_si
|
||||
*/
|
||||
struct ast_sip_contact *ast_sip_location_retrieve_contact_from_aor_list(const char *aor_list);
|
||||
|
||||
/*!
|
||||
* \brief Retrieve all contacts from a list of AORs
|
||||
*
|
||||
* \param aor_list A comma-separated list of AOR names
|
||||
* \retval NULL if no contacts available
|
||||
* \retval non-NULL container (which must be freed) if contacts available
|
||||
*/
|
||||
struct ao2_container *ast_sip_location_retrieve_contacts_from_aor_list(const char *aor_list);
|
||||
|
||||
/*!
|
||||
* \brief Retrieve the first bound contact AND the AOR chosen from a list of AORs
|
||||
*
|
||||
|
Reference in New Issue
Block a user