提交 ca63c019 authored 作者: Michael Jerris's avatar Michael Jerris

rollback

git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@7762 d0543943-73ff-0310-b7d9-9358b9ac24b2
上级 bf964b2e
...@@ -373,12 +373,8 @@ void nua_dialog_usage_remove_at(nua_owner_t *own, ...@@ -373,12 +373,8 @@ void nua_dialog_usage_remove_at(nua_owner_t *own,
/* Destroy saved client request */ /* Destroy saved client request */
if (nua_client_is_bound(du->du_cr)) { if (nua_client_is_bound(du->du_cr)) {
nua_client_bind(cr = du->du_cr, NULL); nua_client_bind(cr = du->du_cr, NULL);
if (!nua_client_is_queued(cr) &&
if (nua_client_is_queued(cr)) !nua_client_is_reporting(cr))
nua_client_request_complete(cr);
else if (nua_client_is_reporting(cr))
;
else
nua_client_request_destroy(cr); nua_client_request_destroy(cr);
} }
......
...@@ -253,11 +253,11 @@ typedef struct { ...@@ -253,11 +253,11 @@ typedef struct {
nta_outgoing_t *orq, nta_outgoing_t *orq,
tagi_t const *tags); tagi_t const *tags);
/** @a crm_complete is called when a client-side request is destroyed. /** @a crm_deinit is called when a client-side request is destroyed.
* *
* @return The return value should be 0. It is currently ignored. * @return The return value should be 0. It is currently ignored.
*/ */
int (*crm_complete)(nua_client_request_t *); int (*crm_deinit)(nua_client_request_t *);
} nua_client_methods_t; } nua_client_methods_t;
...@@ -516,8 +516,6 @@ void *nua_private_client_request(nua_client_request_t const *cr) ...@@ -516,8 +516,6 @@ void *nua_private_client_request(nua_client_request_t const *cr)
return (void *)(cr + 1); return (void *)(cr + 1);
} }
void nua_client_request_complete(nua_client_request_t *);
void nua_client_request_destroy(nua_client_request_t *); void nua_client_request_destroy(nua_client_request_t *);
int nua_client_request_queue(nua_client_request_t *cr); int nua_client_request_queue(nua_client_request_t *cr);
......
...@@ -74,21 +74,18 @@ ...@@ -74,21 +74,18 @@
*/ */
static nua_client_methods_t const nua_method_client_methods = { static nua_client_methods_t const nua_method_client_methods = {
SIP_METHOD_UNKNOWN, /* crm_method, crm_method_name */ SIP_METHOD_UNKNOWN,
0, /* crm_extra */ 0,
{ /* crm_flags */ {
/* create_dialog */ 0, /* create_dialog */ 0,
/* in_dialog */ 0, /* in_dialog */ 0,
/* target_refresh */ 1, /* target_refresh */ 1,
}, },
NULL, /* crm_template */ /* nua_method_client_template */ NULL,
NULL, /* crm_init */ /* nua_method_client_init */ NULL,
NULL, /* crm_send */ /* nua_method_client_request */ NULL,
NULL, /* crm_check_restart */ /* nua_method_client_check_restart */ NULL,
NULL, /* crm_recv */ /* nua_method_client_response */ NULL
NULL, /* crm_preliminary */
NULL, /* crm_report */
NULL, /* crm_complete */
}; };
int int
......
...@@ -77,22 +77,18 @@ static int nua_message_client_init(nua_client_request_t *cr, ...@@ -77,22 +77,18 @@ static int nua_message_client_init(nua_client_request_t *cr,
tagi_t const *tags); tagi_t const *tags);
static nua_client_methods_t const nua_message_client_methods = { static nua_client_methods_t const nua_message_client_methods = {
SIP_METHOD_MESSAGE, /* crm_method, crm_method_name */ SIP_METHOD_MESSAGE,
0, /* crm_extra */ 0,
{ /* crm_flags */ {
/* create_dialog */ 0, /* create_dialog */ 0,
/* in_dialog */ 0, /* in_dialog */ 0,
/* target refresh */ 0 /* target refresh */ 0
}, },
NULL, /* crm_template */ /* nua_message_client_template */ NULL,
nua_message_client_init, /* crm_init */ nua_message_client_init,
NULL, /* crm_send */ /*nua_message_client_request*/ NULL,
NULL, /* crm_check_restart */ /* nua_message_client_check_restart */ NULL,
NULL, /* crm_recv */ /*nua_message_client_response*/ NULL
NULL, /* crm_preliminary */
NULL, /* crm_report */
NULL, /* crm_complete */
}; };
int int
......
...@@ -237,8 +237,7 @@ int nua_subscribe_server_preprocess(nua_server_request_t *sr) ...@@ -237,8 +237,7 @@ int nua_subscribe_server_preprocess(nua_server_request_t *sr)
sip_event_t *o = sip->sip_event; sip_event_t *o = sip->sip_event;
char const *event = o ? o->o_type : NULL; char const *event = o ? o->o_type : NULL;
/* Maximum expiration time */ /* Maximum expiration time */
unsigned long expires = sip->sip_expires ? sip->sip_expires->ex_delta : 3600; unsigned long expires = 3600;
sip_time_t now = sip_now();
assert(nh && nh->nh_nua->nua_dhandle != nh); assert(nh && nh->nh_nua->nua_dhandle != nh);
...@@ -260,10 +259,9 @@ int nua_subscribe_server_preprocess(nua_server_request_t *sr) ...@@ -260,10 +259,9 @@ int nua_subscribe_server_preprocess(nua_server_request_t *sr)
nu = nua_dialog_usage_private(du); nu = nua_dialog_usage_private(du);
if (now + expires >= now) if (sip->sip_expires && sip->sip_expires->ex_delta < expires)
nu->nu_requested = now + expires; expires = sip->sip_expires->ex_delta;
else nu->nu_requested = sip_now() + expires;
nu->nu_requested = SIP_TIME_MAX - 1;
#if SU_HAVE_EXPERIMENTAL #if SU_HAVE_EXPERIMENTAL
nu->nu_etags = nu->nu_etags =
...@@ -297,23 +295,9 @@ int nua_subscribe_server_respond(nua_server_request_t *sr, tagi_t const *tags) ...@@ -297,23 +295,9 @@ int nua_subscribe_server_respond(nua_server_request_t *sr, tagi_t const *tags)
sip_time_t now = sip_now(); sip_time_t now = sip_now();
if (nu->nu_requested) { if (nu->nu_requested) {
if (sip->sip_expires) { if (nu->nu_requested > nu->nu_expires)
/* Expires in response can only shorten the expiration time */
if (nu->nu_requested > now + sip->sip_expires->ex_delta)
nu->nu_requested = now + sip->sip_expires->ex_delta;
}
else {
unsigned sub_expires = NH_PGET(sr->sr_owner, sub_expires);
if (nu->nu_requested > now + sub_expires)
nu->nu_requested = now + sub_expires;
}
if (nu->nu_requested >= now)
nu->nu_expires = nu->nu_requested; nu->nu_expires = nu->nu_requested;
else else if (nu->nu_expires <= now || nu->nu_requested <= now)
nu->nu_expires = now;
if (nu->nu_expires <= now)
nu->nu_substate = nua_substate_terminated; nu->nu_substate = nua_substate_terminated;
} }
...@@ -321,7 +305,7 @@ int nua_subscribe_server_respond(nua_server_request_t *sr, tagi_t const *tags) ...@@ -321,7 +305,7 @@ int nua_subscribe_server_respond(nua_server_request_t *sr, tagi_t const *tags)
ex->ex_delta = nu->nu_expires - now; ex->ex_delta = nu->nu_expires - now;
} }
else { else {
/* Always add header Expires: 0 */ /* Add header Expires: 0 */
} }
if (!sip->sip_expires || sip->sip_expires->ex_delta > ex->ex_delta) if (!sip->sip_expires || sip->sip_expires->ex_delta > ex->ex_delta)
...@@ -436,21 +420,20 @@ static int nua_notify_client_report(nua_client_request_t *cr, ...@@ -436,21 +420,20 @@ static int nua_notify_client_report(nua_client_request_t *cr,
tagi_t const *tags); tagi_t const *tags);
static nua_client_methods_t const nua_notify_client_methods = { static nua_client_methods_t const nua_notify_client_methods = {
SIP_METHOD_NOTIFY, /* crm_method, crm_method_name */ SIP_METHOD_NOTIFY,
0, /* crm_extra */ 0,
{ /* crm_flags */ {
/* create_dialog */ 1, /* create_dialog */ 1,
/* in_dialog */ 1, /* in_dialog */ 1,
/* target refresh */ 1 /* target refresh */ 1
}, },
NULL, /* crm_template */ /* nua_notify_client_template */ NULL,
nua_notify_client_init, /* crm_init */ nua_notify_client_init,
nua_notify_client_request, /* crm_send */ nua_notify_client_request,
NULL, /* crm_check_restart */ /* nua_notify_client_check_restart */ NULL,
NULL, /* crm_recv */ /* nua_notify_client_response */ NULL,
NULL, /* crm_preliminary */ /* nua_notify_client_preliminary */ NULL,
nua_notify_client_report, /* crm_report */ nua_notify_client_report
NULL, /* crm_complete */
}; };
/**@internal Send NOTIFY. */ /**@internal Send NOTIFY. */
......
...@@ -88,21 +88,18 @@ ...@@ -88,21 +88,18 @@
*/ */
static nua_client_methods_t const nua_options_client_methods = { static nua_client_methods_t const nua_options_client_methods = {
SIP_METHOD_OPTIONS, /* crm_method, crm_method_name */ SIP_METHOD_OPTIONS,
0, /* crm_extra */ 0,
{ /* crm_flags */ {
/* create_dialog */ 0, /* create_dialog */ 0,
/* in_dialog */ 0, /* in_dialog */ 0,
/* target refresh */ 0 /* target refresh */ 0
}, },
NULL, /* crm_template */ /*nua_options_client_template*/ NULL,
NULL, /* crm_init */ /*nua_options_client_init*/ NULL,
NULL, /* crm_send */ /*nua_options_client_request*/ NULL,
NULL, /* crm_check_restart */ /* nua_options_client_check_restart */ NULL,
NULL, /* crm_recv */ /*nua_options_client_response*/ NULL
NULL, /* crm_preliminary */
NULL, /* crm_report */
NULL, /* crm_complete */
}; };
int nua_stack_options(nua_t *nua, int nua_stack_options(nua_t *nua,
......
...@@ -107,7 +107,6 @@ typedef struct nua_handle_preferences ...@@ -107,7 +107,6 @@ typedef struct nua_handle_preferences
/* Subscriber state, i.e. nua_substate_pending */ /* Subscriber state, i.e. nua_substate_pending */
unsigned nhp_substate; unsigned nhp_substate;
unsigned nhp_sub_expires;
/* REGISTER keepalive intervals */ /* REGISTER keepalive intervals */
unsigned nhp_keepalive, nhp_keepalive_stream; unsigned nhp_keepalive, nhp_keepalive_stream;
...@@ -128,6 +127,9 @@ typedef struct nua_handle_preferences ...@@ -128,6 +127,9 @@ typedef struct nua_handle_preferences
/** Outbound OPTIONS */ /** Outbound OPTIONS */
char const *nhp_outbound; char const *nhp_outbound;
/** Network detection: NONE, INFORMAL, TRY_FULL */
int nhp_detect_network_updates;
sip_allow_t *nhp_appl_method; sip_allow_t *nhp_appl_method;
/** Initial route set */ /** Initial route set */
...@@ -135,12 +137,6 @@ typedef struct nua_handle_preferences ...@@ -135,12 +137,6 @@ typedef struct nua_handle_preferences
union { struct { union { struct {
/* A bit for each feature set by application */ /* A bit for each feature set by application */
/* NOTE:
Some compilers behave weird if there are bitfields
together with width > 32
So there should be a padding field (unsigned:0;)
every 32 bits.
*/
unsigned nhb_retry_count:1; unsigned nhb_retry_count:1;
unsigned nhb_max_subscriptions:1; unsigned nhb_max_subscriptions:1;
...@@ -170,15 +166,13 @@ typedef struct nua_handle_preferences ...@@ -170,15 +166,13 @@ typedef struct nua_handle_preferences
unsigned nhb_refer_with_id:1; unsigned nhb_refer_with_id:1;
unsigned nhb_refer_expires:1; unsigned nhb_refer_expires:1;
unsigned nhb_substate:1; unsigned nhb_substate:1;
unsigned nhb_sub_expires:1;
unsigned nhb_keepalive:1; unsigned nhb_keepalive:1;
unsigned nhb_keepalive_stream:1; unsigned nhb_keepalive_stream:1;
unsigned nhb_registrar:1; unsigned nhb_registrar:1;
unsigned nhb_allow:1; unsigned nhb_allow:1;
unsigned :0; /* at most 32 bits before this point */
unsigned nhb_supported:1; unsigned nhb_supported:1;
unsigned :0; /* at most 32 bits ... */
unsigned nhb_allow_events:1; unsigned nhb_allow_events:1;
unsigned nhb_user_agent:1; unsigned nhb_user_agent:1;
unsigned nhb_organization:1; unsigned nhb_organization:1;
...@@ -189,6 +183,7 @@ typedef struct nua_handle_preferences ...@@ -189,6 +183,7 @@ typedef struct nua_handle_preferences
unsigned nhb_m_features:1; unsigned nhb_m_features:1;
unsigned nhb_instance:1; unsigned nhb_instance:1;
unsigned nhb_outbound:1; unsigned nhb_outbound:1;
unsigned nhb_detect_network_updates:1;
unsigned nhb_appl_method:1; unsigned nhb_appl_method:1;
unsigned nhb_initial_route:1; unsigned nhb_initial_route:1;
unsigned :0; unsigned :0;
...@@ -199,26 +194,6 @@ typedef struct nua_handle_preferences ...@@ -199,26 +194,6 @@ typedef struct nua_handle_preferences
#define nhp_set nhp_set_.set_bits #define nhp_set nhp_set_.set_bits
/** Global preferences for nua. */
typedef struct {
/** Network detection: NONE, INFORMAL, TRY_FULL */
signed int ngp_detect_network_updates:3;
/** Pass events during shutdown, too */
int ngp_shutdown_events:1;
unsigned :0; /* pad */
union { struct {
/* A bit for each feature set by application */
unsigned ngp_detect_network_updates:1;
unsigned ngp_shutdown_events:1;
unsigned :0;
} set_bits;
unsigned set_unsigned[2];
} ngp_set_;
} nua_global_preferences_t;
#define ngp_set ngp_set_.set_bits
#define DNHP_GET(dnhp, pref) ((dnhp)->nhp_##pref) #define DNHP_GET(dnhp, pref) ((dnhp)->nhp_##pref)
#define NHP_GET(nhp, dnhp, pref) \ #define NHP_GET(nhp, dnhp, pref) \
......
...@@ -244,21 +244,19 @@ static int nua_publish_client_response(nua_client_request_t *cr, ...@@ -244,21 +244,19 @@ static int nua_publish_client_response(nua_client_request_t *cr,
sip_t const *sip); sip_t const *sip);
static nua_client_methods_t const nua_publish_client_methods = { static nua_client_methods_t const nua_publish_client_methods = {
SIP_METHOD_PUBLISH, /* crm_method, crm_method_name */ SIP_METHOD_PUBLISH,
0, /* crm_extra */ 0,
{ /* crm_flags */ {
/* create_dialog */ 0, /* create_dialog */ 0,
/* in_dialog */ 0, /* in_dialog */ 0,
/* target refresh */ 0 /* target refresh */ 0
}, },
nua_publish_client_template, /* crm_template */ nua_publish_client_template,
nua_publish_client_init, /* crm_init */ nua_publish_client_init,
nua_publish_client_request, /* crm_send */ nua_publish_client_request,
nua_publish_client_check_restart, /* crm_check_restart */ nua_publish_client_check_restart,
nua_publish_client_response, /* crm_recv */ nua_publish_client_response,
NULL, /* crm_preliminary */ /* nua_publish_client_preliminary */ NULL
NULL, /* crm_report */
NULL, /* crm_complete */
}; };
/**@internal Send PUBLISH. */ /**@internal Send PUBLISH. */
......
...@@ -570,21 +570,18 @@ static int nua_register_client_response(nua_client_request_t *cr, ...@@ -570,21 +570,18 @@ static int nua_register_client_response(nua_client_request_t *cr,
sip_t const *sip); sip_t const *sip);
static nua_client_methods_t const nua_register_client_methods = { static nua_client_methods_t const nua_register_client_methods = {
SIP_METHOD_REGISTER, /* crm_method, crm_method_name */ SIP_METHOD_REGISTER,
0, /* crm_extra */ 0,
{ /* crm_flags */ {
/* create_dialog */ 1, /* create_dialog */ 1,
/* in_dialog */ 0, /* in_dialog */ 0,
/* target refresh */ 0 /* target refresh */ 0
}, },
nua_register_client_template, /* crm_template */ nua_register_client_template,
nua_register_client_init, /* crm_init */ nua_register_client_init,
nua_register_client_request, /* crm_send */ nua_register_client_request,
nua_register_client_check_restart, /* crm_check_restart */ nua_register_client_check_restart,
nua_register_client_response, /* crm_recv */ nua_register_client_response
NULL, /* crm_preliminary */
NULL, /* crm_report */
NULL, /* crm_complete */
}; };
/**@internal Send REGISTER. */ /**@internal Send REGISTER. */
......
...@@ -209,7 +209,7 @@ int nua_stack_init(su_root_t *root, nua_t *nua) ...@@ -209,7 +209,7 @@ int nua_stack_init(su_root_t *root, nua_t *nua)
if (nua_stack_set_from(nua, 1, nua->nua_args) < 0) if (nua_stack_set_from(nua, 1, nua->nua_args) < 0)
return -1; return -1;
if (nua->nua_prefs->ngp_detect_network_updates) if (NHP_ISSET(dnh->nh_prefs, detect_network_updates))
nua_stack_launch_network_change_detector(nua); nua_stack_launch_network_change_detector(nua);
nua_stack_timer(nua, nua->nua_timer, NULL); nua_stack_timer(nua, nua->nua_timer, NULL);
...@@ -293,8 +293,7 @@ int nua_stack_event(nua_t *nua, nua_handle_t *nh, msg_t *msg, ...@@ -293,8 +293,7 @@ int nua_stack_event(nua_t *nua, nua_handle_t *nh, msg_t *msg,
if ((event > nua_r_authenticate && event <= nua_r_ack) if ((event > nua_r_authenticate && event <= nua_r_ack)
|| event < nua_i_error || event < nua_i_error
|| (nh && !nh->nh_valid) || (nh && !nh->nh_valid)
|| (nua->nua_shutdown && event != nua_r_shutdown && ) {
!nua->nua_prefs->ngp_shutdown_events)) {
if (msg) if (msg)
msg_destroy(msg); msg_destroy(msg);
return event; return event;
...@@ -2076,13 +2075,6 @@ nua_client_request_t *nua_client_request_remove(nua_client_request_t *cr) ...@@ -2076,13 +2075,6 @@ nua_client_request_t *nua_client_request_remove(nua_client_request_t *cr)
return cr; return cr;
} }
void nua_client_request_complete(nua_client_request_t *cr)
{
nua_client_request_remove(cr);
if (cr && cr->cr_methods->crm_complete)
cr->cr_methods->crm_complete(cr);
}
void nua_client_request_destroy(nua_client_request_t *cr) void nua_client_request_destroy(nua_client_request_t *cr)
{ {
nua_handle_t *nh; nua_handle_t *nh;
...@@ -2090,12 +2082,14 @@ void nua_client_request_destroy(nua_client_request_t *cr) ...@@ -2090,12 +2082,14 @@ void nua_client_request_destroy(nua_client_request_t *cr)
if (cr == NULL) if (cr == NULL)
return; return;
nua_client_request_complete(cr); if (cr->cr_methods->crm_deinit)
cr->cr_methods->crm_deinit(cr);
nh = cr->cr_owner; nh = cr->cr_owner;
nua_destroy_signal(cr->cr_signal); nua_destroy_signal(cr->cr_signal);
nua_client_request_remove(cr);
nua_client_bind(cr, NULL); nua_client_bind(cr, NULL);
if (cr->cr_msg) if (cr->cr_msg)
...@@ -2104,6 +2098,7 @@ void nua_client_request_destroy(nua_client_request_t *cr) ...@@ -2104,6 +2098,7 @@ void nua_client_request_destroy(nua_client_request_t *cr)
if (cr->cr_orq) if (cr->cr_orq)
nta_outgoing_destroy(cr->cr_orq); nta_outgoing_destroy(cr->cr_orq);
cr->cr_orq = NULL; cr->cr_orq = NULL;
if (cr->cr_timer) if (cr->cr_timer)
......
...@@ -217,31 +217,28 @@ struct nua_s { ...@@ -217,31 +217,28 @@ struct nua_s {
su_clone_r nua_clone; su_clone_r nua_clone;
su_task_r nua_client; su_task_r nua_client;
su_network_changed_t *nua_nw_changed;
nua_callback_f nua_callback; nua_callback_f nua_callback;
nua_magic_t *nua_magic; nua_magic_t *nua_magic;
nua_event_frame_t *nua_current; nua_event_frame_t *nua_current;
nua_saved_event_t nua_signal[1]; nua_saved_event_t nua_signal[1];
/**< Used by stop-and-wait args calls */
tagi_t const *nua_args;
/* Engine state flags */ /* Engine state flags */
sip_time_t nua_shutdown;
unsigned nua_shutdown_started:1; /**< Shutdown initiated */ unsigned nua_shutdown_started:1; /**< Shutdown initiated */
unsigned nua_shutdown_final:1; /**< Shutdown is complete */ unsigned nua_shutdown_final:1; /**< Shutdown is complete */
unsigned nua_from_is_set; unsigned nua_from_is_set;
unsigned :0; unsigned :0;
/**< Local SIP address. Contents are kept around for ever. */ /**< Used by stop-and-wait args calls */
sip_from_t nua_from[1]; tagi_t const *nua_args;
/* ---------------------------------------------------------------------- */ /**< Local SIP address. Contents are kept around for ever. */
sip_from_t nua_from[1];
/* Protocol (server) side */ /* Protocol (server) side */
su_network_changed_t *nua_nw_changed;
nua_registration_t *nua_registrations; /**< Active registrations */ nua_registration_t *nua_registrations; /**< Active registrations */
...@@ -253,8 +250,21 @@ struct nua_s { ...@@ -253,8 +250,21 @@ struct nua_s {
nta_agent_t *nua_nta; nta_agent_t *nua_nta;
su_timer_t *nua_timer; su_timer_t *nua_timer;
void *nua_sip_parser;
sip_time_t nua_shutdown;
/* Route */
sip_service_route_t *nua_service_route;
/* User-agent parameters */ /* User-agent parameters */
nua_global_preferences_t nua_prefs[1]; unsigned nua_media_enable:1;
unsigned :0;
#if HAVE_SMIME /* Start NRC Boston */
sm_object_t *sm;
#endif /* End NRC Boston */
nua_handle_t *nua_handles; nua_handle_t *nua_handles;
nua_handle_t **nua_handles_tail; nua_handle_t **nua_handles_tail;
......
...@@ -183,21 +183,18 @@ static int nua_subscribe_client_response(nua_client_request_t *cr, ...@@ -183,21 +183,18 @@ static int nua_subscribe_client_response(nua_client_request_t *cr,
sip_t const *sip); sip_t const *sip);
static nua_client_methods_t const nua_subscribe_client_methods = { static nua_client_methods_t const nua_subscribe_client_methods = {
SIP_METHOD_SUBSCRIBE, /* crm_method, crm_method_name */ SIP_METHOD_SUBSCRIBE,
0, /* crm_extra */ 0,
{ /* crm_flags */ {
/* create_dialog */ 1, /* create_dialog */ 1,
/* in_dialog */ 1, /* in_dialog */ 1,
/* target refresh */ 1 /* target refresh */ 1
}, },
NULL, /* crm_template */ NULL,
nua_subscribe_client_init, /* crm_init */ nua_subscribe_client_init,
nua_subscribe_client_request, /* crm_send */ nua_subscribe_client_request,
NULL, /* crm_check_restart */ /* nua_subscribe_client_check_restart */ NULL,
nua_subscribe_client_response, /* crm_recv */ nua_subscribe_client_response
NULL, /* crm_preliminary */
NULL, /* crm_report */
NULL, /* crm_complete */
}; };
int int
...@@ -371,9 +368,6 @@ static int nua_subscribe_client_response(nua_client_request_t *cr, ...@@ -371,9 +368,6 @@ static int nua_subscribe_client_response(nua_client_request_t *cr,
else else
delta = 0; delta = 0;
if (delta > eu->eu_expires)
delta = eu->eu_expires;
if (win_messenger_enable && !nua_dialog_is_established(nh->nh_ds)) { if (win_messenger_enable && !nua_dialog_is_established(nh->nh_ds)) {
/* Notify from messanger does not match with dialog tag */ /* Notify from messanger does not match with dialog tag */
nh->nh_ds->ds_remote_tag = su_strdup(nh->nh_home, ""); nh->nh_ds->ds_remote_tag = su_strdup(nh->nh_home, "");
...@@ -653,6 +647,8 @@ int nua_notify_server_report(nua_server_request_t *sr, tagi_t const *tags) ...@@ -653,6 +647,8 @@ int nua_notify_server_report(nua_server_request_t *sr, tagi_t const *tags)
if (substate == nua_substate_active || substate == nua_substate_pending) { if (substate == nua_substate_active || substate == nua_substate_pending) {
if (subs && subs->ss_expires) if (subs && subs->ss_expires)
delta = strtoul(subs->ss_expires, NULL, 10); delta = strtoul(subs->ss_expires, NULL, 10);
else
delta = eu->eu_expires;
} }
else if (substate == nua_substate_embryonic) { else if (substate == nua_substate_embryonic) {
if (subs && subs->ss_reason) { if (subs && subs->ss_reason) {
...@@ -690,8 +686,7 @@ int nua_notify_server_report(nua_server_request_t *sr, tagi_t const *tags) ...@@ -690,8 +686,7 @@ int nua_notify_server_report(nua_server_request_t *sr, tagi_t const *tags)
nua_dialog_usage_set_refresh_range(du, retry, retry + 5); nua_dialog_usage_set_refresh_range(du, retry, retry + 5);
} }
else { else {
if (delta < SIP_TIME_MAX) nua_dialog_usage_set_refresh(du, delta);
nua_dialog_usage_set_refresh(du, delta);
} }
return retval; return retval;
...@@ -782,21 +777,20 @@ static int nua_refer_client_response(nua_client_request_t *cr, ...@@ -782,21 +777,20 @@ static int nua_refer_client_response(nua_client_request_t *cr,
sip_t const *sip); sip_t const *sip);
static nua_client_methods_t const nua_refer_client_methods = { static nua_client_methods_t const nua_refer_client_methods = {
SIP_METHOD_REFER, /* crm_method, crm_method_name */ SIP_METHOD_REFER,
0, /* crm_extra */ 0,
{ /* crm_flags */ {
/* create_dialog */ 1, /* create_dialog */ 1,
/* in_dialog */ 1, /* in_dialog */ 1,
/* target refresh */ 1 /* target refresh */ 1
}, },
NULL, /* crm_template */ /*nua_refer_client_template*/ NULL,
nua_refer_client_init, /* crm_init */ nua_refer_client_init,
nua_refer_client_request, /* crm_send */ nua_refer_client_request,
NULL, /* crm_check_restart */ /* nua_refer_client_check_restart */ NULL,
nua_refer_client_response, /* crm_recv */ nua_refer_client_response,
nua_refer_client_response, /* crm_preliminary */ nua_refer_client_response, /* Preliminary */
NULL, /* crm_report */ NULL
NULL, /* crm_complete */
}; };
int int
......
...@@ -227,22 +227,21 @@ ...@@ -227,22 +227,21 @@
* - NUTAG_ALLOW_EVENTS(), SIPTAG_ALLOW_EVENTS(), and * - NUTAG_ALLOW_EVENTS(), SIPTAG_ALLOW_EVENTS(), and
* SIPTAG_ALLOW_EVENTS_STR() * SIPTAG_ALLOW_EVENTS_STR()
* - NUTAG_MAX_SUBSCRIPTIONS() * - NUTAG_MAX_SUBSCRIPTIONS()
* - NUTAG_SUBSTATE(), NUTAG_SUB_EXPIRES() * - NUTAG_SUBSTATE()
* @par Specifications * @par Specifications
* - @RFC3265 * - @RFC3265
* *
* @par SIP Event Subscriber * @par SIP Event Subscriber
* - nua_subscribe(), #nua_r_subscribe, #nua_i_notify, NUTAG_SUBSTATE(), * - nua_subscribe(), #nua_r_subscribe, #nua_i_notify, NUTAG_SUBSTATE(),
* SIPTAG_EVENT(), SIPTAG_EXPIRES() * SIPTAG_EVENT(), SIPTAG_EXPIRES(),
* - nua_unsubscribe(), #nua_r_unsubscribe() * - nua_unsubscribe(), #nua_r_unsubscribe()
* @par Specifications * @par Specifications
* - @RFC3265 * - @RFC3265
* *
* @par SIP Event Notifier * @par SIP Event Notifier
* - #nua_i_subscribe(), nua_notify(), #nua_r_notify, * - #nua_i_subscribe(), nua_notify(), #nua_r_notify,
* NUTAG_SUBSTATE(), NUTAG_SUB_EXPIRES(), SIPTAG_EVENT() * NUTAG_SUBSTATE(), SIPTAG_EVENT()
* Settings: * Settings:
* - NUTAG_SUB_EXPIRES()
* - NUTAG_ALLOW_EVENTS(), SIPTAG_ALLOW_EVENTS(), and * - NUTAG_ALLOW_EVENTS(), SIPTAG_ALLOW_EVENTS(), and
* SIPTAG_ALLOW_EVENTS_STR() * SIPTAG_ALLOW_EVENTS_STR()
* - NUTAG_ALLOW("SUBSCRIBE"), NUTAG_APPL_METHOD("SUBSCRIBE") * - NUTAG_ALLOW("SUBSCRIBE"), NUTAG_APPL_METHOD("SUBSCRIBE")
...@@ -268,8 +267,6 @@ ...@@ -268,8 +267,6 @@
* Settings: * Settings:
* - NUTAG_ALLOW(x), NUTAG_APPL_METHOD(x) * - NUTAG_ALLOW(x), NUTAG_APPL_METHOD(x)
* *
* @par Server Shutdown
* - nua_shutdown(), NUTAG_SHUTDOWN_EVENTS(), nua_destroy().
*/ */
/* @par S/MIME /* @par S/MIME
...@@ -770,14 +767,14 @@ tag_typedef_t nutag_answer_sent = BOOLTAG_TYPEDEF(answer_sent); ...@@ -770,14 +767,14 @@ tag_typedef_t nutag_answer_sent = BOOLTAG_TYPEDEF(answer_sent);
* *
* @par Used with * @par Used with
* - with nua_create(), nua_set_params(), nua_get_params(), * - with nua_create(), nua_set_params(), nua_get_params(),
* nua_handle(), nua_set_hparams(), nua_get_hparams(), and * nua_handle(), nua_set_hparams(), nua_get_hparams(), and
* nua_notifier() to change the default subscription state returned by * nua_notifier() to change the default subscription state returned by
* the internal event server * the intenal event server
* - with nua_notify() and nua_respond() to SUBSCRIBE to determine the * - with nua_notify() and nua_respond() to SUBSCRIBE to determine the
* subscription state (if application include @SubscriptionState * subscription state (if application include @SubscriptionState
* header in the tag list, the NUTAG_SUBSTATE() value is ignored) * header in the tag list, the NUTAG_SUBSTATE() value is ignored)
* - with #nua_r_subscribe, #nua_i_notify, #nua_i_subscribe, and #nua_r_notify * - with #nua_r_subscribe, #nua_i_notify, #nua_i_subscribe, and #nua_r_notify
* to indicate the current subscription state * to indicate the current subscription state
* *
* @par Parameter type * @par Parameter type
* int * int
...@@ -809,39 +806,6 @@ tag_typedef_t nutag_substate = INTTAG_TYPEDEF(substate); ...@@ -809,39 +806,6 @@ tag_typedef_t nutag_substate = INTTAG_TYPEDEF(substate);
*/ */
/**@def NUTAG_SUB_EXPIRES()
*
* Default expiration time of subscriptions.
*
* @par Used with
* - with nua_create(), nua_set_params(), nua_get_params(), nua_handle(),
* nua_set_hparams(), nua_get_hparams(), nua_respond(), nua_notify(), and
* nua_notifier() to change the default expiration time of subscriptions
*
* @par Parameter type
* unsigned int
*
* @par Values
* - default expiration time in seconds
*
* Note that the expires parameter in @SubscriptionState or @Expires header
* in the nua_response() to the SUBSCRIBE overrides the default subscription
* expiration specified by NUTAG_SUB_EXPIRES().
*
* @sa @RFC3265, NUTAG_REFER_EXPIRES(), @Expires, SIPTAG_EXPIRES(),
* SIPTAG_EXPIRES_STR(), @SubscriptionState, nua_respond(), nua_notifier(),
* #nua_r_subscribe, #nua_i_subscribe, #nua_r_refer, #nua_r_notify,
* #nua_i_notify.
*
* Corresponding tag taking reference parameter is NUTAG_SUB_EXPIRES_REF().
*/
tag_typedef_t nutag_sub_expires = UINTTAG_TYPEDEF(substate);
/**@def NUTAG_SUB_EXPIRES_REF(x)
* Reference tag for NUTAG_SUB_EXPIRES().
*/
/**@def NUTAG_NEWSUB() /**@def NUTAG_NEWSUB()
* *
* Send unsolicited NOTIFY request. * Send unsolicited NOTIFY request.
...@@ -1111,17 +1075,17 @@ tag_typedef_t nutag_update_refresh = BOOLTAG_TYPEDEF(update_refresh); ...@@ -1111,17 +1075,17 @@ tag_typedef_t nutag_update_refresh = BOOLTAG_TYPEDEF(update_refresh);
* REFER. * REFER.
* *
* @par Used with * @par Used with
* nua_handle(), nua_respond() \n * nua_set_params() \n
* nua_set_params() or nua_set_hparams() \n * nua_get_params() \n
* nua_get_params() or nua_get_hparams() * nua_set_hparams() \n
* nua_get_hparams() \n
* *
* @par Parameter type * @par Parameter type
* unsigned int * unsigned int
* *
* @par Values * @par Values
* - default interval in seconds * @c 0 disable \n
* * @c >0 interval in seconds
* @sa NUTAG_SUB_EXPIRES()
* *
* Corresponding tag taking reference parameter is NUTAG_REFER_EXPIRES_REF(). * Corresponding tag taking reference parameter is NUTAG_REFER_EXPIRES_REF().
*/ */
...@@ -1606,9 +1570,6 @@ extern msg_hclass_t sip_route_class[]; ...@@ -1606,9 +1570,6 @@ extern msg_hclass_t sip_route_class[];
* NUTAG_INITIAL_ROUTE_STR() tags, the route set is constructed from them * NUTAG_INITIAL_ROUTE_STR() tags, the route set is constructed from them
* all. * all.
* *
* The initial route is inserted into request message before the route
* entries set with SIPTAG_ROUTE() or SIPTAG_ROUTE_STR().
*
* @par Used with * @par Used with
* nua_set_params() \n * nua_set_params() \n
* nua_set_hparams() \n * nua_set_hparams() \n
...@@ -2775,39 +2736,6 @@ tag_typedef_t nutag_dialog = UINTTAG_TYPEDEF(dialog); ...@@ -2775,39 +2736,6 @@ tag_typedef_t nutag_dialog = UINTTAG_TYPEDEF(dialog);
* Reference tag for NUTAG_SIP_PARSER(). * Reference tag for NUTAG_SIP_PARSER().
*/ */
/**@def NUTAG_SHUTDOWN_EVENTS(x)
*
* Allow passing of normal events when stack is being shut down.
*
* By default, only #nua_r_shutdown events are passed to application after
* calling nua_shutdown(). If application is interested in nua events during
* shutdown, it should give NUTAG_SHUTDOWN_EVENTS(1) to nua_create() or
* nua_set_params() called before nua_shutdown().
*
* @par Used with
* nua_create(), nua_set_params().
*
* @par Parameter type
* int (boolean)
*
* @par Values
* @c 0 False \n
* @c !=0 True
*
* Corresponding tag taking reference parameter is NUTAG_SHUTDOWN_EVENTS_REF().
*
* @sa nua_shutdown(), nua_destroy().
*
* @NEW_1_12_9.
*/
tag_typedef_t nutag_shutdown_events = BOOLTAG_TYPEDEF(shutdown_events);
/**@def NUTAG_SHUTDOWN_EVENTS_REF(x)
* Reference tag for NUTAG_SHUTDOWN_EVENTS().
*/
/* ---------------------------------------------------------------------- */ /* ---------------------------------------------------------------------- */
tag_typedef_t nutag_soa_session = PTRTAG_TYPEDEF(soa_session); tag_typedef_t nutag_soa_session = PTRTAG_TYPEDEF(soa_session);
......
...@@ -497,16 +497,12 @@ SOFIAPUBFUN char const *nua_substate_name(enum nua_substate substate); ...@@ -497,16 +497,12 @@ SOFIAPUBFUN char const *nua_substate_name(enum nua_substate substate);
/** Convert string to enum nua_substate. @NEW_1_12_5. */ /** Convert string to enum nua_substate. @NEW_1_12_5. */
SOFIAPUBFUN enum nua_substate nua_substate_make(char const *sip_substate); SOFIAPUBFUN enum nua_substate nua_substate_make(char const *sip_substate);
#define NUTAG_SUB_EXPIRES(x) nutag_sub_expires, tag_uint_v(x)
SOFIAPUBVAR tag_typedef_t nutag_sub_expires;
#define NUTAG_SUB_EXPIRES_REF(x) nutag_sub_expires_ref, tag_uint_vr(&(x))
SOFIAPUBVAR tag_typedef_t nutag_sub_expires_ref;
#define NUTAG_NEWSUB(x) nutag_newsub, tag_bool_v(x) #define NUTAG_NEWSUB(x) nutag_newsub, tag_bool_v(x)
SOFIAPUBVAR tag_typedef_t nutag_newsub; SOFIAPUBVAR tag_typedef_t nutag_newsub;
#define NUTAG_NEWSUB_REF(x) nutag_newsub_ref, tag_bool_vr(&(x)) #define NUTAG_NEWSUB_REF(x) nutag_newsub_ref, tag_bool_vr(&(x))
SOFIAPUBVAR tag_typedef_t nutag_newsub_ref; SOFIAPUBVAR tag_typedef_t nutag_newsub_ref;
#define NUTAG_REFER_EXPIRES(x) nutag_refer_expires, tag_uint_v((x)) #define NUTAG_REFER_EXPIRES(x) nutag_refer_expires, tag_uint_v((x))
SOFIAPUBVAR tag_typedef_t nutag_refer_expires; SOFIAPUBVAR tag_typedef_t nutag_refer_expires;
#define NUTAG_REFER_EXPIRES_REF(x) nutag_refer_expires_ref, tag_uint_vr((&(x))) #define NUTAG_REFER_EXPIRES_REF(x) nutag_refer_expires_ref, tag_uint_vr((&(x)))
...@@ -573,13 +569,6 @@ SOFIAPUBVAR tag_typedef_t nutag_detect_network_updates; ...@@ -573,13 +569,6 @@ SOFIAPUBVAR tag_typedef_t nutag_detect_network_updates;
nutag_detect_network_updates_ref, tag_int_vr(&(x)) nutag_detect_network_updates_ref, tag_int_vr(&(x))
SOFIAPUBVAR tag_typedef_t nutag_detect_network_updates_ref; SOFIAPUBVAR tag_typedef_t nutag_detect_network_updates_ref;
#define NUTAG_SHUTDOWN_EVENTS(x) \
nutag_shutdown_events, tag_bool_v(x)
SOFIAPUBVAR tag_typedef_t nutag_shutdown_events;
#define NUTAG_SHUTDOWN_EVENTS_REF(x) \
nutag_shutdown_events_ref, tag_bool_vr(&(x))
SOFIAPUBVAR tag_typedef_t nutag_shutdown_events_ref;
/* Pass nua handle as tagged argument */ /* Pass nua handle as tagged argument */
#if SU_INLINE_TAG_CAST #if SU_INLINE_TAG_CAST
su_inline tag_value_t nutag_handle_v(nua_handle_t *v) { return (tag_value_t)v; } su_inline tag_value_t nutag_handle_v(nua_handle_t *v) { return (tag_value_t)v; }
......
Markdown 格式
0%
您添加了 0 到此讨论。请谨慎行事。
请先完成此评论的编辑!
注册 或者 后发表评论