diff options
author | markster <markster@f38db490-d61c-443f-a65b-d21fe96a405b> | 2005-05-25 17:45:31 +0000 |
---|---|---|
committer | markster <markster@f38db490-d61c-443f-a65b-d21fe96a405b> | 2005-05-25 17:45:31 +0000 |
commit | b4e1d4f04e185d0c0a1153327a468277602b060c (patch) | |
tree | 0d834b095cf16b75a8586a7440ec1c28638e8497 /channels | |
parent | 99b1b76b3183c1d183ef9fa8d6b2cbc47bcca128 (diff) |
Fix SIP registration (bug #4138)
git-svn-id: http://svn.digium.com/svn/asterisk/trunk@5767 f38db490-d61c-443f-a65b-d21fe96a405b
Diffstat (limited to 'channels')
-rwxr-xr-x | channels/chan_sip.c | 7 |
1 files changed, 3 insertions, 4 deletions
diff --git a/channels/chan_sip.c b/channels/chan_sip.c index 90663befd..12d75e2ad 100755 --- a/channels/chan_sip.c +++ b/channels/chan_sip.c @@ -1305,8 +1305,6 @@ static void update_peer(struct sip_peer *p, int expiry) if (!ast_test_flag((&global_flags_page2), SIP_PAGE2_RTNOUPDATE) && (ast_test_flag(p, SIP_REALTIME) || ast_test_flag(&(p->flags_page2), SIP_PAGE2_RTCACHEFRIENDS))) { - if (p->expire == -1) - expiry = 0; /* Unregister realtime peer */ realtime_update_peer(p->name, &p->addr, p->username, expiry); } } @@ -5145,7 +5143,8 @@ static int parse_contact(struct sip_pvt *pvt, struct sip_peer *p, struct sip_req p->expire = -1; pvt->expiry = expiry; snprintf(data, sizeof(data), "%s:%d:%d:%s:%s", ast_inet_ntoa(iabuf, sizeof(iabuf), p->addr.sin_addr), ntohs(p->addr.sin_port), expiry, p->username, p->fullcontact); - ast_db_put("SIP/Registry", p->name, data); + if (!ast_test_flag(p, SIP_REALTIME)) + ast_db_put("SIP/Registry", p->name, data); manager_event(EVENT_FLAG_SYSTEM, "PeerStatus", "Peer: SIP/%s\r\nPeerStatus: Registered\r\n", p->name); if (inaddrcmp(&p->addr, &oldsin)) { sip_poke_peer(p); @@ -10419,7 +10418,7 @@ static struct sip_peer *build_peer(const char *name, struct ast_variable *v, int } } ast_copy_flags(peer, &peerflags, mask.flags); - if (!found && ast_test_flag(peer, SIP_DYNAMIC)) + if (!found && ast_test_flag(peer, SIP_DYNAMIC) && !ast_test_flag(peer, SIP_REALTIME)) reg_source_db(peer); ASTOBJ_UNMARK(peer); ast_free_ha(oldha); |