From: Alexandr Anikin Date: Thu, 9 Aug 2012 19:20:09 +0000 (+0000) Subject: Fix to resend GRQ/RRQ if RRJ (registration reject) is received X-Git-Tag: 10.9.0-rc1~70 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=4b34ff1e6222941b3801aeb3a6777c12c90066d7;p=thirdparty%2Fasterisk.git Fix to resend GRQ/RRQ if RRJ (registration reject) is received (close issue ASTERISK-20094) Patches: ASTERISK-20094.patch ........ Merged revisions 371011 from http://svn.asterisk.org/svn/asterisk/branches/1.8 git-svn-id: https://origsvn.digium.com/svn/asterisk/branches/10@371022 65c4cc65-6c06-0410-ace0-fbb531ad65f3 --- diff --git a/addons/ooh323c/src/ooGkClient.c b/addons/ooh323c/src/ooGkClient.c index dff3e751b7..1df3ee5649 100644 --- a/addons/ooh323c/src/ooGkClient.c +++ b/addons/ooh323c/src/ooGkClient.c @@ -810,6 +810,9 @@ int ooGkClientHandleGatekeeperConfirm if(pGatekeeperConfirm->m.gatekeeperIdentifierPresent) { pGkClient->gkId.nchars = pGatekeeperConfirm->gatekeeperIdentifier.nchars; + if (pGkClient->gkId.data) { + memFreePtr(&pGkClient->ctxt, pGkClient->gkId.data); + } pGkClient->gkId.data = (ASN116BITCHAR*)memAlloc(&pGkClient->ctxt, sizeof(ASN116BITCHAR)*pGkClient->gkId.nchars); if(!pGkClient->gkId.data) @@ -1369,7 +1372,20 @@ int ooGkClientHandleRegistrationReject default: OOTRACEINFO1("RRQ Rejected - Invalid Reason\n"); } - pGkClient->state = GkClientGkErr; + + /* send again GRQ/RRQ's */ + ast_mutex_lock(&pGkClient->Lock); + pGkClient->state = GkClientUnregistered; + pGkClient->rrqRetries = 0; + pGkClient->grqRetries = 0; + pGkClient->discoveryComplete = FALSE; + ast_mutex_unlock(&pGkClient->Lock); + + iRet = ooGkClientSendGRQ(pGkClient); + if(iRet != OO_OK){ + OOTRACEERR1("\nError: Transmission of rediscovery of GK failed\n"); + return OO_FAILED; + } return OO_OK; }