diff options
author | Mark Spencer <markster@digium.com> | 2005-09-25 19:13:54 +0000 |
---|---|---|
committer | Mark Spencer <markster@digium.com> | 2005-09-25 19:13:54 +0000 |
commit | da7c542e2946c03d79aed228170e2c99025984d1 (patch) | |
tree | eb3a0c9f453de73681a5787c4e61c15b2a60fc12 /channels/chan_iax2.c | |
parent | 168733a179fba0e4ddfc8aa6db57bac85b10745b (diff) |
Handle authenticating *to* realtime peers (bug #5269)
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@6648 65c4cc65-6c06-0410-ace0-fbb531ad65f3
Diffstat (limited to 'channels/chan_iax2.c')
-rwxr-xr-x | channels/chan_iax2.c | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/channels/chan_iax2.c b/channels/chan_iax2.c index b540c4f86..fd02cb749 100755 --- a/channels/chan_iax2.c +++ b/channels/chan_iax2.c @@ -5166,6 +5166,15 @@ static int authenticate_reply(struct chan_iax2_pvt *p, struct sockaddr_in *sin, peer = peer->next; } ast_mutex_unlock(&peerl.lock); + if (!peer) { + /* We checked our list and didn't find one. It's unlikely, but possible, + that we're trying to authenticate *to* a realtime peer */ + if ((peer = realtime_peer(p->peer))) { + res = authenticate(p->challenge, peer->secret,peer->outkey, authmethods, &ied, sin, &p->ecx, &p->dcx); + if (ast_test_flag(peer, IAX_TEMPONLY)) + destroy_peer(peer); + } + } } if (ies->encmethods) ast_set_flag(p, IAX_ENCRYPTED | IAX_KEYPOPULATED); |