summaryrefslogtreecommitdiff
path: root/channels/chan_iax2.c
diff options
context:
space:
mode:
authorMark Spencer <markster@digium.com>2005-09-25 19:13:54 +0000
committerMark Spencer <markster@digium.com>2005-09-25 19:13:54 +0000
commitda7c542e2946c03d79aed228170e2c99025984d1 (patch)
treeeb3a0c9f453de73681a5787c4e61c15b2a60fc12 /channels/chan_iax2.c
parent168733a179fba0e4ddfc8aa6db57bac85b10745b (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-xchannels/chan_iax2.c9
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);