diff options
author | tilghman <tilghman@f38db490-d61c-443f-a65b-d21fe96a405b> | 2006-09-16 07:57:04 +0000 |
---|---|---|
committer | tilghman <tilghman@f38db490-d61c-443f-a65b-d21fe96a405b> | 2006-09-16 07:57:04 +0000 |
commit | ec5c0aace62568efba5ad216f8e347a24356f544 (patch) | |
tree | 266e8e3e254077ae3259a19a291ce1341d68b8f8 /channels/chan_iax2.c | |
parent | 60201da27b7708c921e166dee9734a67e4bdd52a (diff) |
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
Diffstat (limited to 'channels/chan_iax2.c')
-rw-r--r-- | channels/chan_iax2.c | 2 |
1 files changed, 2 insertions, 0 deletions
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); |