[svn-commits] file: branch file/pjsip-outbound-publish r419849 - /team/file/pjsip-outbound-...
SVN commits to the Digium repositories
svn-commits at lists.digium.com
Thu Jul 31 08:15:36 CDT 2014
Author: file
Date: Thu Jul 31 08:15:32 2014
New Revision: 419849
URL: http://svnview.digium.com/svn/asterisk?view=rev&rev=419849
Log:
No need to copy the expiration.
Modified:
team/file/pjsip-outbound-publish/res/res_pjsip_outbound_publish.c
Modified: team/file/pjsip-outbound-publish/res/res_pjsip_outbound_publish.c
URL: http://svnview.digium.com/svn/asterisk/team/file/pjsip-outbound-publish/res/res_pjsip_outbound_publish.c?view=diff&rev=419849&r1=419848&r2=419849
==============================================================================
--- team/file/pjsip-outbound-publish/res/res_pjsip_outbound_publish.c (original)
+++ team/file/pjsip-outbound-publish/res/res_pjsip_outbound_publish.c Thu Jul 31 08:15:32 2014
@@ -109,8 +109,6 @@
pjsip_publishc *client;
/*! \brief Timer entry for refreshing publish */
pj_timer_entry timer;
- /*! \brief Configured expiration time */
- unsigned int expiration;
/*! \brief Publisher datastores set up by handlers */
struct ao2_container *datastores;
/*! \brief Queue of outgoing publish messages to send*/
@@ -176,29 +174,29 @@
}
/*! \brief Helper function which sets up the timer to send publication */
-static void schedule_publish_refresh(struct ast_sip_outbound_publish_client *client, pjsip_rx_data *rdata)
+static void schedule_publish_refresh(struct ast_sip_outbound_publish *publish, pjsip_rx_data *rdata)
{
pj_time_val delay = { .sec = 0, };
pjsip_expires_hdr *expires;
- cancel_publish_refresh(client);
+ cancel_publish_refresh(publish->state);
/* Determine when we should refresh - we favor the Expires header if possible */
expires = pjsip_msg_find_hdr(rdata->msg_info.msg, PJSIP_H_EXPIRES, NULL);
if (expires) {
delay.sec = expires->ivalue - PJSIP_PUBLISHC_DELAY_BEFORE_REFRESH;
}
- if (client->expiration && ((delay.sec > client->expiration) || !delay.sec)) {
- delay.sec = client->expiration;
+ if (publish->expiration && ((delay.sec > publish->expiration) || !delay.sec)) {
+ delay.sec = publish->expiration;
}
if (delay.sec < PJSIP_PUBLISHC_DELAY_BEFORE_REFRESH) {
delay.sec = PJSIP_PUBLISHC_DELAY_BEFORE_REFRESH;
}
- ao2_ref(client, +1);
- if (pjsip_endpt_schedule_timer(ast_sip_get_pjsip_endpoint(), &client->timer, &delay) != PJ_SUCCESS) {
+ ao2_ref(publish->state, +1);
+ if (pjsip_endpt_schedule_timer(ast_sip_get_pjsip_endpoint(), &publish->state->timer, &delay) != PJ_SUCCESS) {
ast_log(LOG_WARNING, "Failed to pass timed publish refresh to scheduler\n");
- ao2_ref(client, -1);
+ ao2_ref(publish->state, -1);
}
}
@@ -570,15 +568,15 @@
ao2_lock(publish->state);
- /* Remove the message currently being sent so that when the queue is serviced another will get sent */
if (publish->state->sending) {
+ /* Remove the message currently being sent so that when the queue is serviced another will get sent */
AST_LIST_REMOVE_HEAD(&publish->state->queue, entry);
ast_free(publish->state->sending);
publish->state->sending = NULL;
}
if (AST_LIST_EMPTY(&publish->state->queue)) {
- schedule_publish_refresh(publish->state, param->rdata);
+ schedule_publish_refresh(publish, param->rdata);
}
ao2_unlock(publish->state);
@@ -668,8 +666,6 @@
} else if (status != PJ_SUCCESS) {
return -1;
}
-
- publish->state->expiration = publish->expiration;
return 0;
}
More information about the svn-commits
mailing list