From ec5c0aace62568efba5ad216f8e347a24356f544 Mon Sep 17 00:00:00 2001 From: tilghman Date: Sat, 16 Sep 2006 07:57:04 +0000 Subject: When a realtime peer expires, reset the ipaddress in the realtime database back to 0 (Issue 6656) git-svn-id: http://svn.digium.com/svn/asterisk/branches/1.2@43019 f38db490-d61c-443f-a65b-d21fe96a405b --- channels/chan_iax2.c | 2 ++ 1 file changed, 2 insertions(+) (limited to 'channels/chan_iax2.c') diff --git a/channels/chan_iax2.c b/channels/chan_iax2.c index 88dc65561..3f576c4de 100644 --- a/channels/chan_iax2.c +++ b/channels/chan_iax2.c @@ -2600,6 +2600,7 @@ static struct iax2_user *build_user(const char *name, struct ast_variable *v, in static void destroy_user(struct iax2_user *user); static int expire_registry(void *data); +static void realtime_update_peer(const char *peername, struct sockaddr_in *sin, time_t regtime); static struct iax2_peer *realtime_peer(const char *peername, struct sockaddr_in *sin) { @@ -2685,6 +2686,7 @@ static struct iax2_peer *realtime_peer(const char *peername, struct sockaddr_in time(&nowtime); if ((nowtime - regseconds) > IAX_DEFAULT_REG_EXPIRE) { memset(&peer->addr, 0, sizeof(peer->addr)); + realtime_update_peer(peer->name, &peer->addr, 0); if (option_debug) ast_log(LOG_DEBUG, "realtime_peer: Bah, '%s' is expired (%d/%d/%d)!\n", peername, (int)(nowtime - regseconds), (int)regseconds, (int)nowtime); -- cgit v1.2.3