Source code of Windows XP (NT5)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

2550 lines
70 KiB

  1. /*++
  2. Copyright (c) 1999 Microsoft Corporation
  3. Module Name:
  4. ras.cpp
  5. Abstract:
  6. The RAS client functionality (Transport/session mangement)
  7. Author:
  8. Nikhil Bobde (NikhilB)
  9. Revision History:
  10. --*/
  11. #include "globals.h"
  12. #include "q931obj.h"
  13. #include "line.h"
  14. #include "q931pdu.h"
  15. #include "ras.h"
  16. #define OID_ELEMENT_LAST(Value) { NULL, Value }
  17. #define OID_ELEMENT(Index,Value) { (ASN1objectidentifier_s *) &_OID_H225ProtocolIdentifierV1 [Index], Value },
  18. // this stores an unrolled constant linked list
  19. const ASN1objectidentifier_s _OID_H225ProtocolIdentifierV1 [] = {
  20. OID_ELEMENT (1, 0) // 0 = ITU-T
  21. OID_ELEMENT (2, 0) // 0 = Recommendation
  22. OID_ELEMENT (3, 8) // 8 = H Series
  23. OID_ELEMENT (4, 2250) // 2250 = H.225.0
  24. OID_ELEMENT (5, 0) // 0 = Version
  25. OID_ELEMENT_LAST (1) // 1 = V1
  26. };
  27. #undef OID_ELEMENT
  28. #define OID_ELEMENT(Index,Value) { (ASN1objectidentifier_s *) &_OID_H225ProtocolIdentifierV2 [Index], Value },
  29. // this stores an unrolled constant linked list
  30. const ASN1objectidentifier_s _OID_H225ProtocolIdentifierV2 [] = {
  31. OID_ELEMENT (1, 0) // 0 = ITU-T
  32. OID_ELEMENT (2, 0) // 0 = Recommendation
  33. OID_ELEMENT (3, 8) // 8 = H Series
  34. OID_ELEMENT (4, 2250) // 2250 = H.225.0
  35. OID_ELEMENT (5, 0) // 0 = Version
  36. OID_ELEMENT_LAST (2) // 2 = V2
  37. };
  38. RAS_CLIENT g_RasClient;
  39. static LONG RasSequenceNumber;
  40. PH323_ALIASNAMES
  41. RASGetRegisteredAliasList()
  42. {
  43. return g_RasClient.GetRegisteredAliasList();
  44. }
  45. HRESULT RasStart (void)
  46. {
  47. H323DBG(( DEBUG_LEVEL_TRACE, "RasStart - entered." ));
  48. if( (g_RegistrySettings.saGKAddr.sin_addr.s_addr == NULL) ||
  49. (g_RegistrySettings.saGKAddr.sin_addr.s_addr == INADDR_NONE )
  50. )
  51. {
  52. return E_FAIL;
  53. }
  54. if (g_RegistrySettings.fIsGKEnabled)
  55. {
  56. if( !g_RasClient.Initialize (&g_RegistrySettings.saGKAddr) )
  57. return E_OUTOFMEMORY;
  58. //send the rrq message
  59. if( !g_RasClient.SendRRQ( NOT_RESEND_SEQ_NUM, NULL ) )
  60. {
  61. H323DBG(( DEBUG_LEVEL_TRACE, "couldn't send rrq." ));
  62. //m_RegisterState = RAS_REGISTER_STATE_IDLE;
  63. return E_FAIL;
  64. }
  65. }
  66. H323DBG(( DEBUG_LEVEL_TRACE, "RasStart - exited." ));
  67. return S_OK;
  68. }
  69. void RasStop (void)
  70. {
  71. H323DBG(( DEBUG_LEVEL_TRACE, "RasStop - entered." ));
  72. DWORD dwState = g_RasClient.GetRegState();
  73. if( (dwState==RAS_REGISTER_STATE_REGISTERED) ||
  74. (dwState==RAS_REGISTER_STATE_RRQSENT) )
  75. {
  76. //send urq
  77. g_RasClient.SendURQ( NOT_RESEND_SEQ_NUM, NULL );
  78. }
  79. g_RasClient.Shutdown();
  80. H323DBG(( DEBUG_LEVEL_TRACE, "RasStop - exited." ));
  81. }
  82. BOOL RasIsRegistered (void)
  83. {
  84. return g_RasClient.GetRegState() == RAS_REGISTER_STATE_REGISTERED;
  85. }
  86. HRESULT RasGetLocalAddress (
  87. OUT SOCKADDR_IN * ReturnLocalAddress)
  88. {
  89. return g_RasClient.GetLocalAddress (ReturnLocalAddress);
  90. }
  91. USHORT RasAllocSequenceNumber (void)
  92. {
  93. USHORT SequenceNumber;
  94. H323DBG(( DEBUG_LEVEL_TRACE, "RasAllocSequenceNumber - entered." ));
  95. do
  96. {
  97. SequenceNumber = (USHORT) InterlockedIncrement (&RasSequenceNumber);
  98. } while( SequenceNumber == 0 );
  99. H323DBG(( DEBUG_LEVEL_TRACE, "RasAllocSequenceNumber - exited." ));
  100. return SequenceNumber;
  101. }
  102. HRESULT RasEncodeSendMessage (
  103. IN RasMessage * pRasMessage)
  104. {
  105. return g_RasClient.IssueSend( pRasMessage ) ? S_OK : E_FAIL;
  106. }
  107. HRESULT RasGetEndpointID (
  108. OUT EndpointIdentifier * ReturnEndpointID)
  109. {
  110. return g_RasClient.GetEndpointID (ReturnEndpointID);
  111. }
  112. void RasHandleRegistryChange()
  113. {
  114. g_RasClient.HandleRegistryChange();
  115. }
  116. RAS_CLIENT::RAS_CLIENT()
  117. {
  118. //create the timer queue
  119. m_hRegTimer = NULL;
  120. m_hRegTTLTimer = NULL;
  121. m_hUnRegTimer = NULL;
  122. m_RegisterState = RAS_REGISTER_STATE_IDLE;
  123. m_IoRefCount = 0;
  124. m_dwState = RAS_CLIENT_STATE_NONE;
  125. m_pAliasList = NULL;
  126. m_Socket = INVALID_SOCKET;
  127. InitializeListHead( &m_sendPendingList );
  128. InitializeListHead( &m_sendFreeList );
  129. InitializeListHead( &m_aliasChangeRequestList );
  130. m_dwSendFreeLen = 0;
  131. m_lastRegisterSeqNum = 0;
  132. m_wTTLSeqNumber = 0;
  133. m_UnRegisterSeqNum = 0;
  134. m_wRASSeqNum = 0;
  135. m_dwRegRetryCount = 0;
  136. m_dwUnRegRetryCount = 0;
  137. m_dwCallsInProgress = 0;
  138. m_dwRegTimeToLive = 0;
  139. m_pRRQExpireContext = NULL;
  140. m_pURQExpireContext = NULL;
  141. ZeroMemory( (PVOID)&m_GKAddress, sizeof(SOCKADDR_IN) );
  142. ZeroMemory( (PVOID)&m_ASNCoderInfo, sizeof(ASN1_CODER_INFO) );
  143. ZeroMemory( (PVOID)&m_PendingURQ, sizeof(PENDINGURQ) );
  144. ZeroMemory( (PVOID)&m_RASEndpointID, sizeof(ENDPOINT_ID) );
  145. // No need to check the result of this one since this object is
  146. // not allocated on heap, right when the DLL is loaded.
  147. InitializeCriticalSectionAndSpinCount( &m_CriticalSection, 0x80000000 );
  148. }
  149. RAS_CLIENT::~RAS_CLIENT (void)
  150. {
  151. //free the various lists
  152. FreeSendList( &m_sendFreeList );
  153. FreeSendList( &m_sendPendingList );
  154. FreeSendList( &m_aliasChangeRequestList );
  155. DeleteCriticalSection( &m_CriticalSection );
  156. }
  157. HRESULT
  158. RAS_CLIENT::GetEndpointID(
  159. OUT EndpointIdentifier * ReturnEndpointID )
  160. {
  161. HRESULT hr;
  162. H323DBG(( DEBUG_LEVEL_TRACE, "GetEndpointID - entered." ));
  163. Lock();
  164. if (m_RegisterState == RAS_REGISTER_STATE_REGISTERED)
  165. {
  166. ReturnEndpointID->length = m_RASEndpointID.length;
  167. //m_RASEndpointID.value is an array and not a pointer.
  168. //so explicit assignment of each field is required
  169. ReturnEndpointID->value = m_RASEndpointID.value;
  170. hr = S_OK;
  171. }
  172. else
  173. {
  174. hr = S_OK;
  175. }
  176. Unlock();
  177. H323DBG(( DEBUG_LEVEL_TRACE, "GetEndpointID - exited." ));
  178. return hr;
  179. }
  180. //the addr and port are in network byte order
  181. BOOL
  182. RAS_CLIENT::Initialize(
  183. IN SOCKADDR_IN* psaGKAddr
  184. )
  185. {
  186. DWORD dwSize;
  187. int rc;
  188. H323DBG(( DEBUG_LEVEL_TRACE, "RAS Initialize entered:%p.",this ));
  189. //set the m_GKAddress here
  190. dwSize = sizeof m_RASEndpointID.value;
  191. GetComputerNameW( m_RASEndpointID.value, &dwSize );
  192. m_RASEndpointID.length = (WORD)wcslen(m_RASEndpointID.value);
  193. m_pAliasList = new H323_ALIASNAMES;
  194. if( m_pAliasList == NULL )
  195. {
  196. goto error2;
  197. }
  198. ZeroMemory( (PVOID)m_pAliasList, sizeof(H323_ALIASNAMES) );
  199. if( g_RegistrySettings.fIsGKLogOnPhoneEnabled )
  200. {
  201. if(!AddAliasItem( m_pAliasList,
  202. g_RegistrySettings.wszGKLogOnPhone,
  203. e164_chosen ))
  204. {
  205. goto error3;
  206. }
  207. }
  208. if( g_RegistrySettings.fIsGKLogOnAccountEnabled )
  209. {
  210. if(!AddAliasItem( m_pAliasList,
  211. g_RegistrySettings.wszGKLogOnAccount,
  212. h323_ID_chosen ))
  213. {
  214. goto error3;
  215. }
  216. }
  217. if( m_pAliasList->wCount == 0 )
  218. {
  219. //add the machine name as he default alias
  220. if(!AddAliasItem( m_pAliasList,
  221. m_RASEndpointID.value,
  222. h323_ID_chosen ))
  223. {
  224. goto error3;
  225. }
  226. }
  227. rc = InitASNCoder();
  228. if( rc != ASN1_SUCCESS )
  229. {
  230. H323DBG((DEBUG_LEVEL_TRACE, "RAS_InitCoder() returned: %d ", rc));
  231. goto error3;
  232. }
  233. m_GKAddress = *psaGKAddr;
  234. if(!InitializeIo() )
  235. {
  236. goto error4;
  237. }
  238. H323DBG((DEBUG_LEVEL_TRACE, "GK addr:%lx.", m_GKAddress.sin_addr.s_addr ));
  239. m_dwState = RAS_CLIENT_STATE_INITIALIZED;
  240. m_RegisterState = RAS_REGISTER_STATE_IDLE;
  241. H323DBG(( DEBUG_LEVEL_TRACE, "RAS Initialize exited:%p.",this ));
  242. return TRUE;
  243. error4:
  244. TermASNCoder();
  245. error3:
  246. FreeAliasNames( m_pAliasList );
  247. m_pAliasList = NULL;
  248. error2:
  249. return FALSE;
  250. }
  251. void
  252. RAS_CLIENT::Shutdown(void)
  253. {
  254. H323DBG(( DEBUG_LEVEL_TRACE, "RAS Shutdown entered:%p.",this ));
  255. Lock();
  256. switch (m_dwState)
  257. {
  258. case RAS_CLIENT_STATE_NONE:
  259. // nothing to do
  260. break;
  261. case RAS_CLIENT_STATE_INITIALIZED:
  262. if( m_Socket != INVALID_SOCKET )
  263. {
  264. closesocket(m_Socket);
  265. m_Socket = INVALID_SOCKET;
  266. }
  267. //free alias list
  268. FreeAliasNames( m_pAliasList );
  269. m_pAliasList = NULL;
  270. TermASNCoder();
  271. m_dwState = RAS_CLIENT_STATE_NONE;
  272. //delete if any timers
  273. if( m_hRegTTLTimer )
  274. {
  275. DeleteTimerQueueTimer( H323TimerQueue, m_hRegTTLTimer, NULL );
  276. m_hRegTTLTimer = NULL;
  277. }
  278. if( m_hUnRegTimer != NULL )
  279. {
  280. DeleteTimerQueueTimer( H323TimerQueue, m_hUnRegTimer, NULL );
  281. m_hUnRegTimer = NULL;
  282. m_dwUnRegRetryCount = 0;
  283. }
  284. if( m_hRegTimer != NULL )
  285. {
  286. DeleteTimerQueueTimer( H323TimerQueue, m_hRegTimer, NULL );
  287. m_hRegTimer = NULL;
  288. }
  289. if( m_pRRQExpireContext != NULL )
  290. {
  291. delete m_pRRQExpireContext;
  292. m_pRRQExpireContext = NULL;
  293. }
  294. if( m_pURQExpireContext != NULL )
  295. {
  296. delete m_pURQExpireContext;
  297. m_pURQExpireContext = NULL;
  298. }
  299. m_RegisterState = RAS_REGISTER_STATE_IDLE;
  300. m_dwSendFreeLen = 0;
  301. m_dwRegRetryCount = 0;
  302. m_dwUnRegRetryCount = 0;
  303. m_dwCallsInProgress = 0;
  304. m_lastRegisterSeqNum = 0;
  305. m_wTTLSeqNumber = 0;
  306. m_UnRegisterSeqNum = 0;
  307. m_wRASSeqNum = 0;
  308. m_dwRegTimeToLive = 0;
  309. ZeroMemory( (PVOID)&m_GKAddress, sizeof(SOCKADDR_IN) );
  310. ZeroMemory( (PVOID)&m_ASNCoderInfo, sizeof(ASN1_CODER_INFO) );
  311. ZeroMemory( (PVOID)&m_PendingURQ, sizeof(PENDINGURQ) );
  312. ZeroMemory( (PVOID)&m_RASEndpointID, sizeof(ENDPOINT_ID) );
  313. break;
  314. default:
  315. _ASSERTE(FALSE);
  316. break;
  317. }
  318. Unlock();
  319. H323DBG(( DEBUG_LEVEL_TRACE, "RAS Shutdown exited:%p.",this ));
  320. }
  321. BOOL
  322. RAS_CLIENT::FreeSendList(
  323. PLIST_ENTRY pListHead
  324. )
  325. {
  326. PLIST_ENTRY pLE;
  327. RAS_SEND_CONTEXT * pSendContext;
  328. H323DBG(( DEBUG_LEVEL_ERROR, "FreeSendList entered." ));
  329. // process list until empty
  330. while( IsListEmpty(pListHead) == FALSE )
  331. {
  332. // retrieve first entry
  333. pLE = RemoveHeadList(pListHead);
  334. // convert list entry to structure pointer
  335. pSendContext = CONTAINING_RECORD( pLE, RAS_SEND_CONTEXT, ListEntry );
  336. // release memory
  337. if( pSendContext != NULL )
  338. {
  339. delete pSendContext;
  340. pSendContext = NULL;
  341. }
  342. }
  343. H323DBG(( DEBUG_LEVEL_ERROR, "FreeSendList exited:%p.", this ));
  344. // success
  345. return TRUE;
  346. }
  347. //!!always called from a lock
  348. RAS_SEND_CONTEXT *
  349. RAS_CLIENT::AllocSendBuffer(void)
  350. {
  351. RAS_SEND_CONTEXT *pSendBuf;
  352. H323DBG(( DEBUG_LEVEL_TRACE, "AllocSendBuffer entered:%p.",this ));
  353. if( m_dwSendFreeLen )
  354. {
  355. m_dwSendFreeLen--;
  356. _ASSERTE( IsListEmpty(&m_sendFreeList) == FALSE );
  357. LIST_ENTRY *pLE = RemoveHeadList( &m_sendFreeList );
  358. pSendBuf = CONTAINING_RECORD( pLE, RAS_SEND_CONTEXT, ListEntry );
  359. }
  360. else
  361. {
  362. pSendBuf = (RAS_SEND_CONTEXT*)new RAS_SEND_CONTEXT;
  363. }
  364. H323DBG(( DEBUG_LEVEL_TRACE, "AllocSendBuffer exited:%p.",this ));
  365. return pSendBuf;
  366. }
  367. //!!always called from a lock
  368. void
  369. RAS_CLIENT::FreeSendBuffer(
  370. IN RAS_SEND_CONTEXT * pBuffer
  371. )
  372. {
  373. H323DBG(( DEBUG_LEVEL_TRACE, "FreeSendBuffer entered:%p.",this ));
  374. if(m_dwSendFreeLen < RASIO_SEND_BUFFER_LIST_MAX )
  375. {
  376. m_dwSendFreeLen++;
  377. InsertHeadList( &m_sendFreeList, &pBuffer->ListEntry );
  378. }
  379. else
  380. {
  381. delete pBuffer;
  382. }
  383. H323DBG(( DEBUG_LEVEL_TRACE, "FreeSendBuffer exited:%p.",this ));
  384. }
  385. //RAS client functions
  386. void
  387. NTAPI RAS_CLIENT::RegExpiredCallback (
  388. IN PVOID ContextParameter, // ExpContext
  389. IN BOOLEAN TimerFired) // not used
  390. {
  391. EXPIRE_CONTEXT * pExpireContext;
  392. RAS_CLIENT * This;
  393. H323DBG(( DEBUG_LEVEL_TRACE, "RegExpiredCallback - entered." ));
  394. _ASSERTE( ContextParameter );
  395. pExpireContext = (EXPIRE_CONTEXT *)ContextParameter;
  396. _ASSERTE( m_pRRQExpireContext == pExpireContext );
  397. _ASSERTE(pExpireContext -> RasClient);
  398. This = (RAS_CLIENT *) pExpireContext -> RasClient;
  399. This -> RegExpired (pExpireContext -> seqNumber);
  400. H323DBG(( DEBUG_LEVEL_TRACE, "RegExpiredCallback - exited." ));
  401. delete pExpireContext;
  402. }
  403. void
  404. NTAPI RAS_CLIENT::UnregExpiredCallback(
  405. IN PVOID ContextParameter, // ExpContext
  406. IN BOOLEAN TimerFired) // not used
  407. {
  408. EXPIRE_CONTEXT * pExpireContext;
  409. RAS_CLIENT * This;
  410. H323DBG(( DEBUG_LEVEL_TRACE, "UnregExpiredCallback - entered." ));
  411. _ASSERTE(ContextParameter);
  412. pExpireContext = (EXPIRE_CONTEXT *) ContextParameter;
  413. _ASSERTE( m_pURQExpireContext == pExpireContext );
  414. _ASSERTE( pExpireContext -> RasClient );
  415. This = (RAS_CLIENT *) pExpireContext -> RasClient;
  416. This -> UnregExpired( pExpireContext -> seqNumber );
  417. H323DBG(( DEBUG_LEVEL_TRACE, "UnregExpiredCallback - exited." ));
  418. delete pExpireContext;
  419. }
  420. void
  421. NTAPI RAS_CLIENT::TTLExpiredCallback(
  422. IN PVOID ContextParameter, // ExpContext
  423. IN BOOLEAN TimerFired) // not used
  424. {
  425. RAS_CLIENT * This;
  426. _ASSERTE(ContextParameter);
  427. This = (RAS_CLIENT*)ContextParameter;
  428. _ASSERTE(This == &g_RasClient);
  429. This -> TTLExpired();
  430. }
  431. //If we have already sent RRQ to this GK then this RRQ is supposed to rplace
  432. //the original alias list with the new list
  433. BOOL
  434. RAS_CLIENT::SendRRQ(
  435. IN long seqNumber,
  436. IN PALIASCHANGE_REQUEST pAliasChangeRequest
  437. )
  438. {
  439. RasMessage rasMessage;
  440. RegistrationRequest * RRQ;
  441. SOCKADDR_IN sockAddr;
  442. EXPIRE_CONTEXT * pExpireContext = NULL;
  443. RegistrationRequest_callSignalAddress CallSignalAddressSequence;
  444. RegistrationRequest_rasAddress RasAddressSequence;
  445. H323DBG(( DEBUG_LEVEL_TRACE, "SendRRQ entered:%p.",this ));
  446. pExpireContext = new EXPIRE_CONTEXT;
  447. if( pExpireContext == NULL )
  448. {
  449. return FALSE;
  450. }
  451. Lock();
  452. // initialize the structure
  453. ZeroMemory (&rasMessage, sizeof rasMessage);
  454. rasMessage.choice = registrationRequest_chosen;
  455. RRQ = &rasMessage.u.registrationRequest;
  456. RRQ -> bit_mask = 0;
  457. RRQ -> protocolIdentifier = OID_H225ProtocolIdentifierV2;
  458. // get sequence number
  459. if( seqNumber != NOT_RESEND_SEQ_NUM )
  460. {
  461. RRQ -> requestSeqNum = (WORD)seqNumber;
  462. }
  463. else
  464. {
  465. RRQ -> requestSeqNum = GetNextSeqNum();
  466. if( pAliasChangeRequest == NULL )
  467. {
  468. m_lastRegisterSeqNum = RRQ -> requestSeqNum;
  469. }
  470. else
  471. {
  472. pAliasChangeRequest->wRequestSeqNum = RRQ -> requestSeqNum;
  473. }
  474. }
  475. H323DBG(( DEBUG_LEVEL_TRACE, "RRQ seqNum:%d.", RRQ -> requestSeqNum ));
  476. sockAddr.sin_family = AF_INET;
  477. sockAddr.sin_port =
  478. htons(LOWORD(g_RegistrySettings.dwQ931ListenPort));
  479. //we are listening for Q931 conns on all local interfaces
  480. //so specify just one of the local IP addresses
  481. sockAddr.sin_addr.s_addr = m_sockAddr.sin_addr.s_addr;
  482. SetTransportAddress( &sockAddr, &CallSignalAddressSequence.value);
  483. CallSignalAddressSequence.next = NULL;
  484. RRQ -> callSignalAddress = &CallSignalAddressSequence;
  485. // ras address. The UDP socket for this GK
  486. RasAddressSequence.next = NULL;
  487. RasAddressSequence.value = m_transportAddress;
  488. RRQ -> rasAddress = &RasAddressSequence;
  489. // fill in endpoint type
  490. RRQ -> terminalType.bit_mask |= terminal_present;
  491. RRQ -> terminalType.terminal.bit_mask = 0;
  492. //fill in terminal alias list
  493. if( pAliasChangeRequest && pAliasChangeRequest->pAliasList )
  494. {
  495. RRQ -> terminalAlias = (RegistrationRequest_terminalAlias *)
  496. SetMsgAddressAlias( pAliasChangeRequest->pAliasList );
  497. if (NULL == RRQ -> terminalAlias)
  498. {
  499. goto cleanup;
  500. }
  501. RRQ -> bit_mask |= RegistrationRequest_terminalAlias_present;
  502. RRQ -> bit_mask |= RegistrationRequest_endpointIdentifier_present;
  503. RRQ->endpointIdentifier.length = pAliasChangeRequest->rasEndpointID.length;
  504. RRQ->endpointIdentifier.value = pAliasChangeRequest->rasEndpointID.value;
  505. }
  506. else if( m_pAliasList && m_pAliasList->wCount )
  507. {
  508. RRQ -> terminalAlias = (RegistrationRequest_terminalAlias *)
  509. SetMsgAddressAlias( m_pAliasList );
  510. if (NULL == RRQ -> terminalAlias)
  511. {
  512. goto cleanup;
  513. }
  514. RRQ -> bit_mask |= RegistrationRequest_terminalAlias_present;
  515. }
  516. else
  517. {
  518. _ASSERTE(0);
  519. }
  520. //endpointVendor
  521. CopyVendorInfo( &(RRQ -> endpointVendor) );
  522. //a few random booleans
  523. RRQ -> discoveryComplete = FALSE;
  524. RRQ -> keepAlive = FALSE;
  525. RRQ -> willSupplyUUIEs = FALSE;
  526. // encode and send
  527. if( !IssueSend(&rasMessage) )
  528. {
  529. goto cleanup;
  530. }
  531. //delete if any previous TTL timer
  532. if( m_hRegTTLTimer )
  533. {
  534. DeleteTimerQueueTimer(H323TimerQueue, m_hRegTTLTimer, NULL );
  535. m_hRegTTLTimer = NULL;
  536. }
  537. //delete if any previous RRQ sent timer
  538. if( m_hRegTimer != NULL )
  539. {
  540. DeleteTimerQueueTimer( H323TimerQueue, m_hRegTimer, NULL );
  541. m_hRegTimer = NULL;
  542. }
  543. pExpireContext -> RasClient = this;
  544. pExpireContext -> seqNumber = RRQ -> requestSeqNum;
  545. if( !CreateTimerQueueTimer(
  546. &m_hRegTimer,
  547. H323TimerQueue,
  548. RAS_CLIENT::RegExpiredCallback,
  549. pExpireContext,
  550. REG_EXPIRE_TIME, 0,
  551. WT_EXECUTEINIOTHREAD | WT_EXECUTEONLYONCE ) )
  552. {
  553. goto cleanup;
  554. }
  555. if( RRQ -> bit_mask & RegistrationRequest_terminalAlias_present )
  556. {
  557. FreeAddressAliases( (PSetup_UUIE_destinationAddress)
  558. RRQ -> terminalAlias);
  559. }
  560. m_dwRegRetryCount++;
  561. if( pAliasChangeRequest == NULL )
  562. {
  563. m_RegisterState = RAS_REGISTER_STATE_RRQSENT;
  564. }
  565. Unlock();
  566. H323DBG(( DEBUG_LEVEL_TRACE, "SendRRQ exited:%p.", this ));
  567. return TRUE;
  568. cleanup:
  569. if( RRQ -> bit_mask & RegistrationRequest_terminalAlias_present )
  570. {
  571. FreeAddressAliases( (PSetup_UUIE_destinationAddress)
  572. RRQ -> terminalAlias);
  573. }
  574. if( pExpireContext != NULL )
  575. {
  576. delete pExpireContext;
  577. }
  578. Unlock();
  579. H323DBG(( DEBUG_LEVEL_TRACE, "SendRRQ error:%p.",this ));
  580. return FALSE;
  581. }
  582. BOOL
  583. RAS_CLIENT::SendURQ(
  584. IN long seqNumber,
  585. IN EndpointIdentifier * pEndpointID
  586. )
  587. {
  588. RasMessage rasMessage;
  589. UnregistrationRequest * URQ;
  590. SOCKADDR_IN sockAddr;
  591. EXPIRE_CONTEXT * pExpireContext = NULL;
  592. UnregistrationRequest_callSignalAddress CallSignalAddressSequence;
  593. H323DBG(( DEBUG_LEVEL_TRACE, "SendURQ entered:%p.",this ));
  594. Lock();
  595. if( m_RegisterState == RAS_REGISTER_STATE_RRQSENT )
  596. {
  597. //store the seqNumber of this RRQ and send URQ if we recv RCF
  598. m_PendingURQ.RRQSeqNumber = m_lastRegisterSeqNum;
  599. Unlock();
  600. H323DBG(( DEBUG_LEVEL_TRACE, "rrq sent:so pending urq." ));
  601. return TRUE;
  602. }
  603. else if( m_RegisterState != RAS_REGISTER_STATE_REGISTERED )
  604. {
  605. //if already unregistered or URQ sent then return success
  606. Unlock();
  607. H323DBG(( DEBUG_LEVEL_TRACE, "current state:%d.", m_RegisterState ));
  608. return TRUE;
  609. }
  610. pExpireContext = new EXPIRE_CONTEXT;
  611. if( pExpireContext == NULL )
  612. {
  613. goto cleanup;
  614. }
  615. ZeroMemory (&rasMessage, sizeof RasMessage);
  616. rasMessage.choice = unregistrationRequest_chosen;
  617. URQ = &rasMessage.u.unregistrationRequest;
  618. // get sequence number
  619. if( seqNumber != NOT_RESEND_SEQ_NUM )
  620. {
  621. URQ -> requestSeqNum = (WORD)seqNumber;
  622. }
  623. else
  624. {
  625. m_UnRegisterSeqNum = GetNextSeqNum();
  626. URQ -> requestSeqNum = (WORD)m_UnRegisterSeqNum;
  627. }
  628. H323DBG(( DEBUG_LEVEL_TRACE, "RRQ seqNum:%d.", URQ -> requestSeqNum ));
  629. sockAddr.sin_family = AF_INET;
  630. sockAddr.sin_port =
  631. htons(LOWORD(g_RegistrySettings.dwQ931ListenPort));
  632. //we are listening for Q931 conns on all local interfaces
  633. //so specify just one of the local IP addresses
  634. sockAddr.sin_addr.s_addr = m_sockAddr.sin_addr.s_addr;
  635. SetTransportAddress( &sockAddr, &CallSignalAddressSequence.value);
  636. CallSignalAddressSequence.next = NULL;
  637. URQ -> callSignalAddress = &CallSignalAddressSequence;
  638. //get endpointidentifier by using GetComputerNameW
  639. URQ -> bit_mask |= UnregistrationRequest_endpointIdentifier_present;
  640. if( pEndpointID != NULL )
  641. {
  642. URQ->endpointIdentifier.length = pEndpointID ->length;
  643. URQ->endpointIdentifier.value = pEndpointID -> value;
  644. }
  645. else
  646. {
  647. URQ->endpointIdentifier.length = m_RASEndpointID.length;
  648. URQ->endpointIdentifier.value = m_RASEndpointID.value;
  649. }
  650. // encode and send
  651. if( !IssueSend( &rasMessage ) )
  652. {
  653. goto cleanup;
  654. }
  655. pExpireContext -> RasClient = this;
  656. pExpireContext -> seqNumber = URQ -> requestSeqNum;
  657. //delete if any previous RRQ sent timer
  658. if( m_hUnRegTimer != NULL )
  659. {
  660. DeleteTimerQueueTimer( H323TimerQueue, m_hUnRegTimer, NULL );
  661. m_hUnRegTimer = NULL;
  662. m_dwUnRegRetryCount = 0;
  663. }
  664. if( !CreateTimerQueueTimer(
  665. &m_hUnRegTimer,
  666. H323TimerQueue,
  667. RAS_CLIENT::UnregExpiredCallback,
  668. pExpireContext,
  669. REG_EXPIRE_TIME, 0,
  670. WT_EXECUTEINIOTHREAD | WT_EXECUTEONLYONCE) )
  671. {
  672. goto cleanup;
  673. }
  674. //delete if any TTL timer
  675. if( m_hRegTTLTimer )
  676. {
  677. DeleteTimerQueueTimer( H323TimerQueue, m_hRegTTLTimer, NULL );
  678. m_hRegTTLTimer = NULL;
  679. }
  680. m_dwUnRegRetryCount++;
  681. m_RegisterState = RAS_REGISTER_STATE_URQSENT;
  682. Unlock();
  683. H323DBG(( DEBUG_LEVEL_TRACE, "SendURQ exited:%p.",this ));
  684. return TRUE;
  685. cleanup:
  686. if( pExpireContext != NULL )
  687. {
  688. delete pExpireContext;
  689. }
  690. Unlock();
  691. return FALSE;
  692. }
  693. //!!always called from a lock
  694. BOOL
  695. RAS_CLIENT::SendUCF(
  696. IN WORD seqNumber
  697. )
  698. {
  699. RasMessage rasMessage;
  700. UnregistrationConfirm * UCF;
  701. H323DBG(( DEBUG_LEVEL_TRACE, "SendUCF entered:%p.",this ));
  702. // initialize the structure
  703. ZeroMemory (&rasMessage, sizeof rasMessage);
  704. rasMessage.choice = unregistrationConfirm_chosen;
  705. UCF = &rasMessage.u.unregistrationConfirm;
  706. UCF -> bit_mask = 0;
  707. UCF -> requestSeqNum = seqNumber;
  708. if( !IssueSend( &rasMessage ) )
  709. {
  710. return FALSE;
  711. }
  712. H323DBG(( DEBUG_LEVEL_TRACE, "SendUCF exited:%p.",this ));
  713. return TRUE;
  714. }
  715. //!!always called from a lock
  716. BOOL
  717. RAS_CLIENT::SendURJ(
  718. IN WORD seqNumber,
  719. IN DWORD dwReason
  720. )
  721. {
  722. RasMessage rasMessage;
  723. UnregistrationReject * URJ;
  724. H323DBG(( DEBUG_LEVEL_TRACE, "SendURJ entered:%p.",this ));
  725. // initialize the structure
  726. ZeroMemory (&rasMessage, sizeof rasMessage);
  727. rasMessage.choice = unregistrationReject_chosen;
  728. URJ = &rasMessage.u.unregistrationReject;
  729. URJ -> bit_mask = 0;
  730. URJ -> requestSeqNum = seqNumber;
  731. URJ -> rejectReason.choice = (WORD)dwReason;
  732. if( !IssueSend( &rasMessage ) )
  733. {
  734. return FALSE;
  735. }
  736. H323DBG(( DEBUG_LEVEL_TRACE, "SendURJ exited:%p.",this ));
  737. return TRUE;
  738. }
  739. //!!always called from a lock
  740. void
  741. RAS_CLIENT::ProcessRasMessage(
  742. IN RasMessage *pRasMessage
  743. )
  744. {
  745. PH323_CALL pCall = NULL;
  746. ASN1decoding_s ASN1decInfo;
  747. H323DBG(( DEBUG_LEVEL_TRACE, "RAS: processing RasMessage" ));
  748. //Verify that the RCF came from the expected gatekeeper
  749. switch( pRasMessage -> choice )
  750. {
  751. case registrationReject_chosen:
  752. OnRegistrationReject( &pRasMessage -> u.registrationReject );
  753. break;
  754. case registrationConfirm_chosen:
  755. OnRegistrationConfirm( &pRasMessage -> u.registrationConfirm );
  756. break;
  757. case unregistrationRequest_chosen:
  758. OnUnregistrationRequest( &pRasMessage -> u.unregistrationRequest );
  759. break;
  760. case unregistrationReject_chosen:
  761. OnUnregistrationReject( &pRasMessage -> u.unregistrationReject );
  762. break;
  763. case unregistrationConfirm_chosen:
  764. OnUnregistrationConfirm( &pRasMessage -> u.unregistrationConfirm );
  765. break;
  766. case infoRequest_chosen:
  767. CopyMemory( (PVOID)&ASN1decInfo, (PVOID)m_ASNCoderInfo.pDecInfo,
  768. sizeof(ASN1decoding_s) );
  769. //This function should be always called in
  770. //a lock and it unlocks the the ras client
  771. OnInfoRequest( &pRasMessage -> u.infoRequest );
  772. ASN1_FreeDecoded( &ASN1decInfo, pRasMessage, RasMessage_PDU );
  773. //return here since we have already unlocked and freed the buffer
  774. return;
  775. default:
  776. CopyMemory( (PVOID)&ASN1decInfo, (PVOID)m_ASNCoderInfo.pDecInfo,
  777. sizeof(ASN1decoding_s) );
  778. //Don't loclk the RAS client while locking the call object.
  779. Unlock();
  780. HandleRASCallMessage( pRasMessage );
  781. ASN1_FreeDecoded( &ASN1decInfo, pRasMessage, RasMessage_PDU );
  782. //return here since we have already unlocked and freed the buffer
  783. return;
  784. }
  785. ASN1_FreeDecoded( m_ASNCoderInfo.pDecInfo, pRasMessage, RasMessage_PDU );
  786. Unlock();
  787. H323DBG(( DEBUG_LEVEL_TRACE, "ProcessRasMessage exited:%p.",this ));
  788. }
  789. //!!always called from a lock
  790. void
  791. HandleRASCallMessage(
  792. IN RasMessage *pRasMessage
  793. )
  794. {
  795. PH323_CALL pCall = NULL;
  796. H323DBG(( DEBUG_LEVEL_TRACE, "RAS: processing RASCallMessage" ));
  797. switch( pRasMessage -> choice )
  798. {
  799. case admissionConfirm_chosen:
  800. pCall = g_pH323Line -> FindCallByARQSeqNumAndLock(
  801. pRasMessage -> u.admissionConfirm.requestSeqNum);
  802. if( pCall != NULL )
  803. {
  804. pCall -> OnAdmissionConfirm( &pRasMessage->u.admissionConfirm );
  805. pCall -> Unlock();
  806. }
  807. else
  808. H323DBG(( DEBUG_LEVEL_ERROR, "acf:call not found:%d.",
  809. pRasMessage -> u.admissionConfirm.requestSeqNum ));
  810. break;
  811. case admissionReject_chosen:
  812. pCall = g_pH323Line -> FindCallByARQSeqNumAndLock(
  813. pRasMessage -> u.admissionReject.requestSeqNum );
  814. if( pCall != NULL )
  815. {
  816. pCall -> OnAdmissionReject( &pRasMessage->u.admissionReject );
  817. pCall -> Unlock();
  818. }
  819. else
  820. H323DBG(( DEBUG_LEVEL_ERROR, "arj:call not found:%d.",
  821. pRasMessage -> u.admissionReject.requestSeqNum ));
  822. break;
  823. case disengageRequest_chosen:
  824. pCall = g_pH323Line -> FindCallByCallRefAndLock(
  825. pRasMessage -> u.disengageRequest.callReferenceValue );
  826. if( pCall != NULL )
  827. {
  828. pCall -> OnDisengageRequest( &pRasMessage -> u.disengageRequest );
  829. pCall -> Unlock();
  830. }
  831. else
  832. H323DBG(( DEBUG_LEVEL_ERROR, "drq:call not found:%d.",
  833. pRasMessage -> u.disengageRequest.callReferenceValue ));
  834. break;
  835. case disengageConfirm_chosen:
  836. pCall = g_pH323Line -> FindCallByDRQSeqNumAndLock(
  837. pRasMessage -> u.disengageConfirm.requestSeqNum );
  838. if( pCall != NULL )
  839. {
  840. pCall -> OnDisengageConfirm( &pRasMessage -> u.disengageConfirm );
  841. pCall -> Unlock();
  842. }
  843. else
  844. H323DBG(( DEBUG_LEVEL_ERROR, "dcf:call not found:%d.",
  845. pRasMessage -> u.disengageConfirm.requestSeqNum ));
  846. break;
  847. case disengageReject_chosen:
  848. pCall = g_pH323Line -> FindCallByDRQSeqNumAndLock(
  849. pRasMessage -> u.disengageReject.requestSeqNum );
  850. if( pCall != NULL )
  851. {
  852. pCall -> OnDisengageReject( &pRasMessage -> u.disengageReject );
  853. pCall -> Unlock();
  854. }
  855. else
  856. H323DBG(( DEBUG_LEVEL_ERROR, "drj:call not found:%d.",
  857. pRasMessage -> u.disengageReject.requestSeqNum));
  858. break;
  859. case requestInProgress_chosen:
  860. pCall = g_pH323Line -> FindCallByARQSeqNumAndLock(
  861. pRasMessage->u.requestInProgress.requestSeqNum );
  862. if( pCall != NULL )
  863. {
  864. pCall -> OnRequestInProgress( &pRasMessage->u.requestInProgress );
  865. pCall -> Unlock();
  866. }
  867. else
  868. H323DBG(( DEBUG_LEVEL_ERROR, "rip:call not found:%d.",
  869. pRasMessage->u.requestInProgress.requestSeqNum ));
  870. break;
  871. default:
  872. _ASSERTE(0);
  873. H323DBG(( DEBUG_LEVEL_ERROR, "ProcessRASMessage: wrong message:%d",
  874. pRasMessage -> choice));
  875. break;
  876. }
  877. H323DBG(( DEBUG_LEVEL_TRACE, "HandleRASCallMessage exited" ));
  878. }
  879. void
  880. RAS_CLIENT::RegExpired(
  881. IN WORD seqNumber
  882. )
  883. {
  884. H323DBG(( DEBUG_LEVEL_TRACE, "RegExpired entered:%p.", this ));
  885. Lock();
  886. m_pRRQExpireContext = NULL;
  887. if( m_hRegTimer != NULL )
  888. {
  889. DeleteTimerQueueTimer( H323TimerQueue, m_hRegTimer, NULL );
  890. m_hRegTimer = NULL;
  891. }
  892. /*
  893. 1. Registered:ignore this timeout
  894. 2. RRQ sent: (the endpoint has initiated the process of registering but
  895. hasn't heard from the GK yet) Resend the RRQ
  896. 3. Unregistered: ignore this imeout
  897. 4. URQ sent: (the endpoint has initiated the process of unregistering but
  898. hasn't heard from the GK yet) ignore this timeout
  899. 5. Idle: The GK client object has just been initialized and hasn't done
  900. anything. This should not happen.
  901. */
  902. switch( m_RegisterState )
  903. {
  904. case RAS_REGISTER_STATE_RRQSENT:
  905. if( m_dwRegRetryCount < REG_RETRY_MAX )
  906. {
  907. if( !SendRRQ( (long)seqNumber, NULL ) )
  908. {
  909. m_RegisterState = RAS_REGISTER_STATE_RRQEXPIRED;
  910. }
  911. }
  912. else
  913. {
  914. m_RegisterState = RAS_REGISTER_STATE_RRQEXPIRED;
  915. }
  916. break;
  917. case RAS_REGISTER_STATE_REGISTERED:
  918. case RAS_REGISTER_STATE_URQSENT:
  919. case RAS_REGISTER_STATE_UNREGISTERED:
  920. break;
  921. case RAS_REGISTER_STATE_IDLE:
  922. _ASSERTE(0);
  923. break;
  924. }
  925. Unlock();
  926. H323DBG(( DEBUG_LEVEL_TRACE, "RegExpired exited:%p.",this ));
  927. }
  928. void
  929. RAS_CLIENT::TTLExpired()
  930. {
  931. RasMessage rasMessage;
  932. RegistrationRequest * RRQ;
  933. H323DBG(( DEBUG_LEVEL_TRACE, "TTLExpired entered:%p.",this ));
  934. Lock();
  935. if( m_RegisterState == RAS_REGISTER_STATE_REGISTERED )
  936. {
  937. //send light weight RRQ
  938. // initialize the structure
  939. ZeroMemory (&rasMessage, sizeof rasMessage);
  940. rasMessage.choice = registrationRequest_chosen;
  941. RRQ = &rasMessage.u.registrationRequest;
  942. RRQ -> bit_mask = 0;
  943. RRQ -> protocolIdentifier = OID_H225ProtocolIdentifierV2;
  944. RRQ -> bit_mask |= keepAlive_present;
  945. RRQ -> keepAlive = TRUE;
  946. //copy TTL
  947. RRQ -> bit_mask |= RegistrationRequest_timeToLive_present;
  948. RRQ -> timeToLive = m_dwRegTimeToLive;
  949. //endpoint identifier
  950. RRQ -> bit_mask |= RegistrationRequest_endpointIdentifier_present;
  951. RRQ->endpointIdentifier.length = m_RASEndpointID.length;
  952. RRQ->endpointIdentifier.value = m_RASEndpointID.value;
  953. //seqNumber
  954. m_wTTLSeqNumber = GetNextSeqNum();
  955. RRQ -> requestSeqNum = (WORD)m_wTTLSeqNumber;
  956. //what about gatekeeperIdentifier, tokens?
  957. // encode and send
  958. if( !IssueSend(&rasMessage) )
  959. {
  960. H323DBG(( DEBUG_LEVEL_TRACE, "SendLwtRRQ error:%p.",this ));
  961. Unlock();
  962. return;
  963. }
  964. }
  965. Unlock();
  966. H323DBG(( DEBUG_LEVEL_TRACE, "TTLExpired exited:%p.",this ));
  967. }
  968. void
  969. RAS_CLIENT::UnregExpired(
  970. IN WORD seqNumber
  971. )
  972. {
  973. H323DBG(( DEBUG_LEVEL_TRACE, "UnregExpired entered:%p.",this ));
  974. Lock();
  975. m_pURQExpireContext = NULL;
  976. if( m_hUnRegTimer != NULL )
  977. {
  978. DeleteTimerQueueTimer( H323TimerQueue, m_hUnRegTimer, NULL);
  979. m_hUnRegTimer = NULL;
  980. m_dwUnRegRetryCount = 0;
  981. }
  982. switch( m_RegisterState )
  983. {
  984. case RAS_REGISTER_STATE_URQSENT:
  985. if( m_dwUnRegRetryCount < URQ_RETRY_MAX )
  986. {
  987. SendURQ( (long)seqNumber, NULL );
  988. }
  989. else
  990. {
  991. m_RegisterState = RAS_REGISTER_STATE_URQEXPIRED;
  992. }
  993. break;
  994. case RAS_REGISTER_STATE_REGISTERED:
  995. case RAS_REGISTER_STATE_RRQSENT:
  996. case RAS_REGISTER_STATE_UNREGISTERED:
  997. break;
  998. case RAS_REGISTER_STATE_IDLE:
  999. _ASSERTE(0);
  1000. break;
  1001. }
  1002. Unlock();
  1003. H323DBG(( DEBUG_LEVEL_TRACE, "UnregExpired exited:%p.",this ));
  1004. }
  1005. void
  1006. RAS_CLIENT::OnUnregistrationRequest(
  1007. IN UnregistrationRequest *URQ
  1008. )
  1009. {
  1010. H323DBG(( DEBUG_LEVEL_TRACE, "OnUnregistrationRequest entered:%p.", this ));
  1011. _ASSERTE( m_RegisterState != RAS_REGISTER_STATE_IDLE );
  1012. if( (m_RegisterState == RAS_REGISTER_STATE_UNREGISTERED) ||
  1013. (m_RegisterState == RAS_REGISTER_STATE_RRJ) )
  1014. {
  1015. SendURJ( URQ -> requestSeqNum, notCurrentlyRegistered_chosen );
  1016. }
  1017. else if( m_dwCallsInProgress )
  1018. {
  1019. SendURJ( URQ -> requestSeqNum, callInProgress_chosen );
  1020. }
  1021. else
  1022. {
  1023. m_RegisterState = RAS_REGISTER_STATE_UNREGISTERED;
  1024. SendUCF( URQ -> requestSeqNum );
  1025. //try to register again
  1026. if( !SendRRQ( NOT_RESEND_SEQ_NUM, NULL ) )
  1027. {
  1028. H323DBG(( DEBUG_LEVEL_ERROR,
  1029. "couldn't send rrq on urq request." ));
  1030. }
  1031. }
  1032. H323DBG(( DEBUG_LEVEL_TRACE, "OnUnregistrationRequest exited:%p.",this ));
  1033. }
  1034. //!!always called from a lock
  1035. void
  1036. RAS_CLIENT::OnUnregistrationConfirm(
  1037. IN UnregistrationConfirm *UCF
  1038. )
  1039. {
  1040. H323DBG((DEBUG_LEVEL_TRACE, "OnUnregistrationConfirm entered:%p.",this));
  1041. if( UCF -> requestSeqNum != m_UnRegisterSeqNum )
  1042. return;
  1043. _ASSERTE( m_hUnRegTimer );
  1044. if( m_hUnRegTimer != NULL )
  1045. {
  1046. DeleteTimerQueueTimer( H323TimerQueue, m_hUnRegTimer, NULL);
  1047. m_hUnRegTimer = NULL;
  1048. m_dwUnRegRetryCount = 0;
  1049. }
  1050. if( (m_RegisterState == RAS_REGISTER_STATE_URQSENT) ||
  1051. (m_RegisterState == RAS_REGISTER_STATE_URQEXPIRED) )
  1052. {
  1053. //delete if any TTL timer
  1054. if( m_hRegTTLTimer )
  1055. {
  1056. DeleteTimerQueueTimer( H323TimerQueue, m_hRegTTLTimer, NULL );
  1057. m_hRegTTLTimer = NULL;
  1058. }
  1059. m_RegisterState = RAS_REGISTER_STATE_UNREGISTERED;
  1060. }
  1061. H323DBG(( DEBUG_LEVEL_TRACE, "OnUnregistrationConfirm exited:%p.",this));
  1062. }
  1063. //!!always called from a lock
  1064. void
  1065. RAS_CLIENT::OnUnregistrationReject(
  1066. IN UnregistrationReject *URJ
  1067. )
  1068. {
  1069. H323DBG(( DEBUG_LEVEL_TRACE, "OnUnregistrationReject entered:%p.",this ));
  1070. if( URJ -> requestSeqNum != m_UnRegisterSeqNum )
  1071. {
  1072. return;
  1073. }
  1074. if( m_hUnRegTimer != NULL )
  1075. {
  1076. DeleteTimerQueueTimer( H323TimerQueue, m_hUnRegTimer, NULL);
  1077. m_hUnRegTimer = NULL;
  1078. m_dwUnRegRetryCount = 0;
  1079. }
  1080. if( (m_RegisterState == RAS_REGISTER_STATE_URQSENT) ||
  1081. (m_RegisterState == RAS_REGISTER_STATE_URQEXPIRED) )
  1082. {
  1083. m_RegisterState = RAS_REGISTER_STATE_UNREGISTERED;
  1084. }
  1085. H323DBG(( DEBUG_LEVEL_TRACE, "OnUnregistrationReject exited:%p.",this ));
  1086. }
  1087. //!!always called from a lock
  1088. void
  1089. RAS_CLIENT::OnRegistrationReject(
  1090. IN RegistrationReject * RRJ
  1091. )
  1092. {
  1093. H323DBG(( DEBUG_LEVEL_TRACE, "OnRegistrationReject entered:%p.",this ));
  1094. if( RRJ -> requestSeqNum == m_wTTLSeqNumber )
  1095. {
  1096. //Keep alive failed. So start registration process again.
  1097. //This will change the RAS registration state to RRQSENT from REGISTERED.
  1098. if( !SendRRQ( NOT_RESEND_SEQ_NUM, NULL ) )
  1099. {
  1100. H323DBG(( DEBUG_LEVEL_ERROR,
  1101. "couldn't send rrq on Keep alive failure." ));
  1102. m_RegisterState = RAS_REGISTER_STATE_UNREGISTERED;
  1103. }
  1104. }
  1105. else if( RRJ -> requestSeqNum == m_lastRegisterSeqNum )
  1106. {
  1107. if( m_hRegTimer != NULL )
  1108. {
  1109. DeleteTimerQueueTimer( H323TimerQueue, m_hRegTimer, NULL);
  1110. m_hRegTimer = NULL;
  1111. m_dwRegRetryCount = 0;
  1112. }
  1113. if( (m_RegisterState == RAS_REGISTER_STATE_RRQSENT) ||
  1114. (m_RegisterState == RAS_REGISTER_STATE_RRQEXPIRED) )
  1115. {
  1116. m_RegisterState = RAS_REGISTER_STATE_RRJ;
  1117. }
  1118. }
  1119. H323DBG(( DEBUG_LEVEL_TRACE, "OnRegistrationReject exitd:%p.",this ));
  1120. }
  1121. //!!always called in lock
  1122. void
  1123. RAS_CLIENT::OnRegistrationConfirm(
  1124. IN RegistrationConfirm * RCF )
  1125. {
  1126. LIST_ENTRY *pListEntry = NULL;
  1127. PALIASCHANGE_REQUEST pAliasChangeRequest = NULL;
  1128. H323DBG(( DEBUG_LEVEL_TRACE, "OnRegistrationConfirm entered:%p.", this ));
  1129. if( RCF -> requestSeqNum == m_PendingURQ.RRQSeqNumber )
  1130. {
  1131. //The timer could have been startd with the last RRQ,
  1132. //irrespective of the current state of registration.
  1133. if( m_hRegTimer != NULL )
  1134. {
  1135. DeleteTimerQueueTimer( H323TimerQueue, m_hRegTimer, NULL);
  1136. m_hRegTimer = NULL;
  1137. m_dwRegRetryCount = 0;
  1138. }
  1139. //send URQ with the endpointIdentifier
  1140. SendURQ( NOT_RESEND_SEQ_NUM, &RCF->endpointIdentifier );
  1141. H323DBG(( DEBUG_LEVEL_TRACE, "sending pending URQ for RRQ:%d",
  1142. RCF->requestSeqNum ));
  1143. return;
  1144. }
  1145. else if( RCF -> requestSeqNum == m_lastRegisterSeqNum )
  1146. {
  1147. //The timer could have been startd with the last RRQ,
  1148. //irrespective of the current state of registration.
  1149. if( m_hRegTimer != NULL )
  1150. {
  1151. DeleteTimerQueueTimer( H323TimerQueue, m_hRegTimer, NULL);
  1152. m_hRegTimer = NULL;
  1153. m_dwRegRetryCount = 0;
  1154. }
  1155. switch (m_RegisterState)
  1156. {
  1157. case RAS_REGISTER_STATE_REGISTERED:
  1158. if (RCF->requestSeqNum == m_wTTLSeqNumber)
  1159. {
  1160. H323DBG(( DEBUG_LEVEL_TRACE, "RCF for TTL-RRQ." ));
  1161. }
  1162. else
  1163. {
  1164. H323DBG(( DEBUG_LEVEL_WARNING,
  1165. "warning: received RCF, but was already registered-ignoring"));
  1166. }
  1167. break;
  1168. case RAS_REGISTER_STATE_RRQEXPIRED:
  1169. H323DBG(( DEBUG_LEVEL_TRACE,
  1170. "received RCF, but registration already expired, send URQ" ));
  1171. SendURQ (NOT_RESEND_SEQ_NUM, &RCF->endpointIdentifier);
  1172. break;
  1173. case RAS_REGISTER_STATE_RRQSENT:
  1174. //expecting RRQ. gatekeeper has responded.
  1175. m_RegisterState = RAS_REGISTER_STATE_REGISTERED;
  1176. CopyMemory( (PVOID)m_RASEndpointID.value,
  1177. (PVOID)RCF -> endpointIdentifier.value,
  1178. RCF -> endpointIdentifier.length * sizeof(WCHAR) );
  1179. m_RASEndpointID.value[RCF -> endpointIdentifier.length] = L'\0';
  1180. m_RASEndpointID.length = (WORD)RCF -> endpointIdentifier.length;
  1181. InitializeTTLTimer( RCF );
  1182. break;
  1183. default:
  1184. H323DBG(( DEBUG_LEVEL_TRACE,
  1185. "RAS: received RRQ, but was in unexpected state"));
  1186. break;
  1187. }
  1188. }
  1189. else if( RCF -> requestSeqNum == m_wTTLSeqNumber )
  1190. {
  1191. //The timer could have been startd with the last RRQ,
  1192. //irrespective of the current state of registration.
  1193. if( m_hRegTimer != NULL )
  1194. {
  1195. DeleteTimerQueueTimer( H323TimerQueue, m_hRegTimer, NULL);
  1196. m_hRegTimer = NULL;
  1197. m_dwRegRetryCount = 0;
  1198. }
  1199. //look for the change in keepalive interval.
  1200. InitializeTTLTimer( RCF );
  1201. }
  1202. else
  1203. {
  1204. //Try to find if this is a alias change request.
  1205. for( pListEntry = m_aliasChangeRequestList.Flink;
  1206. pListEntry != &m_aliasChangeRequestList;
  1207. pListEntry = pListEntry -> Flink )
  1208. {
  1209. pAliasChangeRequest = CONTAINING_RECORD( pListEntry,
  1210. ALIASCHANGE_REQUEST, listEntry );
  1211. if( pAliasChangeRequest -> wRequestSeqNum == RCF -> requestSeqNum )
  1212. {
  1213. break;
  1214. }
  1215. }
  1216. if( pListEntry != &m_aliasChangeRequestList )
  1217. {
  1218. //The timer could have been startd with the last RRQ,
  1219. //irrespective of the current state of registration.
  1220. if( m_hRegTimer != NULL )
  1221. {
  1222. DeleteTimerQueueTimer( H323TimerQueue, m_hRegTimer, NULL);
  1223. m_hRegTimer = NULL;
  1224. m_dwRegRetryCount = 0;
  1225. }
  1226. //if registration has changed since this request was made then
  1227. //ignore the message.
  1228. if( memcmp( (PVOID)pAliasChangeRequest -> rasEndpointID.value,
  1229. m_RASEndpointID.value, m_RASEndpointID.length * sizeof(WCHAR) )
  1230. == 0 )
  1231. {
  1232. //update the alias list.
  1233. FreeAliasNames( m_pAliasList );
  1234. m_pAliasList = pAliasChangeRequest->pAliasList;
  1235. RemoveEntryList( &pAliasChangeRequest->listEntry );
  1236. delete pAliasChangeRequest;
  1237. }
  1238. }
  1239. }
  1240. H323DBG(( DEBUG_LEVEL_TRACE, "OnRegistrationConfirm exited:%p.", this ));
  1241. }
  1242. //!!always called in a lock.
  1243. BOOL
  1244. RAS_CLIENT::InitializeTTLTimer(
  1245. IN RegistrationConfirm * RCF )
  1246. {
  1247. H323DBG(( DEBUG_LEVEL_TRACE, "InitializeTTLTimer - entered." ));
  1248. if( (RCF->bit_mask & RegistrationConfirm_timeToLive_present) &&
  1249. ( (m_dwRegTimeToLive != RCF->timeToLive) || (m_hRegTTLTimer == NULL) )
  1250. )
  1251. {
  1252. m_dwRegTimeToLive = RCF->timeToLive;
  1253. H323DBG(( DEBUG_LEVEL_TRACE, "timetolive value:%d.",
  1254. m_dwRegTimeToLive ));
  1255. //delete if any previous TTL timer
  1256. if( m_hRegTTLTimer )
  1257. {
  1258. DeleteTimerQueueTimer( H323TimerQueue, m_hRegTTLTimer, NULL );
  1259. m_hRegTTLTimer = NULL;
  1260. }
  1261. //start a timer to send lightweight RRQ afetr given time
  1262. if( !CreateTimerQueueTimer(
  1263. &m_hRegTTLTimer,
  1264. H323TimerQueue,
  1265. RAS_CLIENT::TTLExpiredCallback,
  1266. this,
  1267. (m_dwRegTimeToLive - REG_TTL_MARGIN)*1000,
  1268. (m_dwRegTimeToLive - REG_TTL_MARGIN)*1000,
  1269. WT_EXECUTEINIOTHREAD | WT_EXECUTEONLYONCE ) )
  1270. {
  1271. H323DBG ((DEBUG_LEVEL_ERROR, "failed to create timer queue timer"));
  1272. m_hRegTTLTimer = NULL;
  1273. return FALSE;
  1274. }
  1275. }
  1276. H323DBG(( DEBUG_LEVEL_TRACE, "InitializeTTLTimer - exited." ));
  1277. return TRUE;
  1278. }
  1279. void
  1280. RAS_CLIENT::OnInfoRequest (
  1281. IN InfoRequest * IRQ)
  1282. {
  1283. PH323_CALL pCall;
  1284. SOCKADDR_IN ReplyAddress;
  1285. InfoRequestResponse_perCallInfo CallInfoList;
  1286. InfoRequestResponse_perCallInfo * pCallInfoList = NULL;
  1287. InfoRequestResponse_perCallInfo_Seq * CallInfo;
  1288. HRESULT hr;
  1289. int iIndex, jIndex;
  1290. int iNumCalls = 0;
  1291. int iCallTableSize;
  1292. H323DBG(( DEBUG_LEVEL_TRACE, "OnInfoRequest - entered." ));
  1293. if (m_RegisterState != RAS_REGISTER_STATE_REGISTERED)
  1294. {
  1295. H323DBG ((DEBUG_LEVEL_ERROR, "RAS: received InfoRequest, but was not registered"));
  1296. Unlock();
  1297. return;
  1298. }
  1299. if (IRQ->bit_mask & replyAddress_present)
  1300. {
  1301. if (!GetTransportAddress (&IRQ -> replyAddress, &ReplyAddress))
  1302. {
  1303. H323DBG ((DEBUG_LEVEL_ERROR, "RAS: received InfoRequest, but replyAddress was malformed"));
  1304. Unlock();
  1305. return;
  1306. }
  1307. }
  1308. else
  1309. {
  1310. ReplyAddress = m_GKAddress;
  1311. }
  1312. //Don't loclk the RAS client while locking the call object.
  1313. Unlock();
  1314. if( IRQ -> callReferenceValue )
  1315. {
  1316. //query is for a specific call. So find the call and then send IRR
  1317. pCall = g_pH323Line ->
  1318. FindCallByCallRefAndLock( IRQ -> callReferenceValue );
  1319. if( pCall )
  1320. {
  1321. CallInfo = &CallInfoList.value;
  1322. CallInfoList.next = NULL;
  1323. ZeroMemory (CallInfo, sizeof (InfoRequestResponse_perCallInfo_Seq));
  1324. CallInfo -> callIdentifier.guid.length = sizeof (GUID);
  1325. CallInfo -> conferenceID.length = sizeof (GUID);
  1326. hr = pCall -> GetCallInfo (
  1327. (GUID *) &CallInfo -> callIdentifier.guid.value,
  1328. (GUID *) &CallInfo -> conferenceID.value);
  1329. if( hr != S_OK )
  1330. {
  1331. H323DBG ((DEBUG_LEVEL_ERROR,
  1332. "RAS: call is disconnected for crv (%04XH).",
  1333. IRQ -> callReferenceValue));
  1334. return;
  1335. }
  1336. pCall -> Unlock();
  1337. CallInfo -> callReferenceValue = IRQ -> callReferenceValue;
  1338. CallInfo -> callType.choice = pointToPoint_chosen;
  1339. CallInfo -> callModel.choice = direct_chosen;
  1340. }
  1341. else
  1342. {
  1343. H323DBG(( DEBUG_LEVEL_ERROR,
  1344. "RAS: received InfoRequest for nonexistent crv (%04XH).",
  1345. IRQ -> callReferenceValue));
  1346. return;
  1347. }
  1348. SendInfoRequestResponse (&ReplyAddress, IRQ -> requestSeqNum, &CallInfoList);
  1349. }
  1350. else
  1351. {
  1352. //send the info about all the active calls.
  1353. iNumCalls = g_pH323Line->GetNoOfCalls();
  1354. if( iNumCalls != 0 )
  1355. {
  1356. pCallInfoList = new InfoRequestResponse_perCallInfo[iNumCalls];
  1357. }
  1358. if( pCallInfoList != NULL )
  1359. {
  1360. //lock the call table
  1361. g_pH323Line -> LockCallTable();
  1362. iCallTableSize = g_pH323Line->GetCallTableSize();
  1363. //lock the call so that nobody else would be able to delete the call
  1364. for( jIndex=0, iIndex=0;
  1365. (iIndex < iCallTableSize) && (jIndex < iNumCalls);
  1366. iIndex++ )
  1367. {
  1368. pCall = g_pH323Line->GetCallAtIndex(iIndex);
  1369. if( pCall != NULL )
  1370. {
  1371. pCall -> Lock();
  1372. CallInfo = &(pCallInfoList[jIndex++].value);
  1373. ZeroMemory( CallInfo, sizeof (InfoRequestResponse_perCallInfo_Seq) );
  1374. CallInfo -> callIdentifier.guid.length = sizeof( GUID );
  1375. CallInfo -> conferenceID.length = sizeof( GUID );
  1376. pCall -> GetCallInfo(
  1377. (GUID *) &CallInfo -> callIdentifier.guid.value,
  1378. (GUID *) &CallInfo -> conferenceID.value);
  1379. CallInfo -> callReferenceValue = pCall->GetCallRef();
  1380. pCall -> Unlock();
  1381. CallInfo -> callType.choice = pointToPoint_chosen;
  1382. CallInfo -> callModel.choice = direct_chosen;
  1383. }
  1384. }
  1385. for( iIndex=0; iIndex < jIndex-1; iIndex++ )
  1386. {
  1387. pCallInfoList[iIndex].next = &(pCallInfoList[iIndex+1]);
  1388. }
  1389. pCallInfoList[iIndex].next = NULL;
  1390. //unlock the call table
  1391. g_pH323Line -> UnlockCallTable();
  1392. }
  1393. SendInfoRequestResponse( &ReplyAddress, IRQ -> requestSeqNum,
  1394. pCallInfoList );
  1395. if( pCallInfoList != NULL )
  1396. {
  1397. delete pCallInfoList;
  1398. }
  1399. }
  1400. H323DBG(( DEBUG_LEVEL_TRACE, "OnInfoRequest - exited." ));
  1401. }
  1402. HRESULT RAS_CLIENT::SendInfoRequestResponse (
  1403. IN SOCKADDR_IN * RasAddress,
  1404. IN USHORT SequenceNumber,
  1405. IN InfoRequestResponse_perCallInfo * CallInfoList)
  1406. {
  1407. RasMessage RasMessage;
  1408. InfoRequestResponse * IRR;
  1409. SOCKADDR_IN SocketAddress;
  1410. HRESULT hr;
  1411. H323DBG(( DEBUG_LEVEL_TRACE, "SendInfoRequestResponse - entered." ));
  1412. Lock();
  1413. if( m_RegisterState == RAS_REGISTER_STATE_REGISTERED )
  1414. {
  1415. InfoRequestResponse_callSignalAddress CallSignalAddressSequence;
  1416. H323DBG(( DEBUG_LEVEL_TRACE, "SendIRR entered:%p.",this ));
  1417. ZeroMemory (&RasMessage, sizeof RasMessage);
  1418. RasMessage.choice = infoRequestResponse_chosen;
  1419. IRR = &RasMessage.u.infoRequestResponse;
  1420. IRR -> requestSeqNum = SequenceNumber;
  1421. // we are listening for Q931 conns on all local interfaces
  1422. // so specify just one of the local IP addresses
  1423. // -XXX- fix for multihomed support later
  1424. SocketAddress.sin_family = AF_INET;
  1425. SocketAddress.sin_port = htons (LOWORD(g_RegistrySettings.dwQ931ListenPort));
  1426. SocketAddress.sin_addr.s_addr = m_sockAddr.sin_addr.s_addr;
  1427. // callSignalAddress
  1428. SetTransportAddress (&SocketAddress, &CallSignalAddressSequence.value);
  1429. CallSignalAddressSequence.next = NULL;
  1430. IRR -> callSignalAddress = &CallSignalAddressSequence;
  1431. // rasAddress
  1432. IRR -> rasAddress = m_transportAddress;
  1433. // endpointIdentifier
  1434. IRR -> endpointIdentifier.length = m_RASEndpointID.length;
  1435. IRR -> endpointIdentifier.value = m_RASEndpointID.value;
  1436. // fill in endpoint type
  1437. IRR -> endpointType.bit_mask |= terminal_present;
  1438. IRR -> endpointType.terminal.bit_mask = 0;
  1439. if( CallInfoList )
  1440. {
  1441. IRR -> bit_mask |= perCallInfo_present;
  1442. IRR -> perCallInfo = CallInfoList;
  1443. }
  1444. // send the pdu
  1445. hr = EncodeSendMessage (&RasMessage);
  1446. }
  1447. else
  1448. {
  1449. hr = E_FAIL;
  1450. }
  1451. Unlock();
  1452. H323DBG(( DEBUG_LEVEL_TRACE, "SendInfoRequestResponse - exited." ));
  1453. return TRUE;
  1454. }
  1455. //!!always called from a lock
  1456. BOOL
  1457. RAS_CLIENT::InitializeIo (void)
  1458. {
  1459. DWORD dwFlags = 0;
  1460. int AddressLength;
  1461. H323DBG(( DEBUG_LEVEL_TRACE, "InitializeIo entered:%p.",this ));
  1462. m_Socket = WSASocket (AF_INET,
  1463. SOCK_DGRAM,
  1464. IPPROTO_UDP,
  1465. NULL, 0,
  1466. WSA_FLAG_OVERLAPPED);
  1467. if( m_Socket == INVALID_SOCKET )
  1468. {
  1469. WSAGetLastError();
  1470. return FALSE;
  1471. }
  1472. if( !H323BindIoCompletionCallback ( (HANDLE)m_Socket,
  1473. RAS_CLIENT::IoCompletionCallback, 0))
  1474. {
  1475. GetLastError();
  1476. goto cleanup;
  1477. }
  1478. m_sockAddr.sin_family = AF_INET;
  1479. m_sockAddr.sin_port = htons (0);
  1480. m_sockAddr.sin_addr.s_addr =
  1481. GetLocalIPAddress( m_GKAddress.sin_addr.S_un.S_addr );
  1482. H323DBG(( DEBUG_LEVEL_TRACE,
  1483. "gk sock addr:%lx.", m_sockAddr.sin_addr.s_addr ));
  1484. if( bind( m_Socket, (SOCKADDR *)&m_sockAddr, sizeof(m_sockAddr) )
  1485. == SOCKET_ERROR )
  1486. {
  1487. H323DBG(( DEBUG_LEVEL_ERROR,
  1488. "Couldn't bind the RAS socket:%d, %p", WSAGetLastError(), this ));
  1489. goto cleanup;
  1490. }
  1491. // now that we've bound to a dynamic UDP port,
  1492. // query that port from the stack and store it.
  1493. AddressLength = sizeof m_sockAddr;
  1494. if( getsockname(m_Socket, (SOCKADDR *)&m_sockAddr, &AddressLength)
  1495. == SOCKET_ERROR )
  1496. {
  1497. H323DBG(( DEBUG_LEVEL_ERROR,
  1498. "getsockname failed :%d, %p", WSAGetLastError(), this ));
  1499. goto cleanup;
  1500. }
  1501. _ASSERTE( ntohs(m_sockAddr.sin_port) );
  1502. // fill in the IoTransportAddress structure.
  1503. // this structure is the ASN.1-friendly transport
  1504. // address of this client's endpoint.
  1505. SetTransportAddress( &m_sockAddr, &m_transportAddress );
  1506. // initiate i/o
  1507. ZeroMemory( (PVOID)&m_recvOverlapped, sizeof(RAS_RECV_CONTEXT) );
  1508. if( !IssueRecv() )
  1509. {
  1510. goto cleanup;
  1511. }
  1512. H323DBG(( DEBUG_LEVEL_TRACE, "InitializeIo exited:%p.",this ));
  1513. return TRUE;
  1514. cleanup:
  1515. closesocket(m_Socket);
  1516. m_Socket = INVALID_SOCKET;
  1517. return FALSE;
  1518. }
  1519. DWORD GetLocalIPAddress(
  1520. IN DWORD dwRemoteAddr
  1521. )
  1522. {
  1523. DWORD dwLocalAddr = INADDR_ANY;
  1524. SOCKADDR_IN sRemoteAddr;
  1525. SOCKADDR_IN sLocalAddr;
  1526. DWORD dwNumBytesReturned = 0;
  1527. SOCKET querySocket;
  1528. H323DBG(( DEBUG_LEVEL_TRACE, "GetLocalIPAddress - entered." ));
  1529. ZeroMemory( (PVOID)&sRemoteAddr, sizeof(SOCKADDR_IN) );
  1530. ZeroMemory( (PVOID)&sLocalAddr, sizeof(SOCKADDR_IN) );
  1531. sRemoteAddr.sin_family = AF_INET;
  1532. sRemoteAddr.sin_addr = *(struct in_addr *) &dwRemoteAddr;
  1533. querySocket = WSASocket(
  1534. AF_INET, // int af
  1535. SOCK_DGRAM, // int type
  1536. IPPROTO_UDP, // int protocol
  1537. NULL, // LPWSAPROTOCOL_INFO lpProtocolInfo
  1538. 0, // GROUP g
  1539. WSA_FLAG_OVERLAPPED // DWORD dwFlags
  1540. );
  1541. if( querySocket == INVALID_SOCKET )
  1542. {
  1543. H323DBG(( DEBUG_LEVEL_ERROR, "getlocalIP wsasocket:%d.",
  1544. WSAGetLastError() ));
  1545. return dwLocalAddr;
  1546. }
  1547. if( WSAIoctl(
  1548. querySocket, // SOCKET s
  1549. SIO_ROUTING_INTERFACE_QUERY, // DWORD dwIoControlCode
  1550. &sRemoteAddr, // LPVOID lpvInBuffer
  1551. sizeof(SOCKADDR_IN), // DWORD cbInBuffer
  1552. &sLocalAddr, // LPVOID lpvOUTBuffer
  1553. sizeof(SOCKADDR_IN), // DWORD cbOUTBuffer
  1554. &dwNumBytesReturned, // LPDWORD lpcbBytesReturned
  1555. NULL, // LPWSAOVERLAPPED lpOverlapped
  1556. NULL // LPWSAOVERLAPPED_COMPLETION_ROUTINE lpComplROUTINE
  1557. ) == SOCKET_ERROR)
  1558. {
  1559. H323DBG(( DEBUG_LEVEL_ERROR, "getlocalIP error wsaioctl:%d.",
  1560. WSAGetLastError() ));
  1561. }
  1562. else
  1563. {
  1564. dwLocalAddr = *(DWORD *)&sLocalAddr.sin_addr;
  1565. //if the remote address is on the same machine then...
  1566. H323DBG(( DEBUG_LEVEL_ERROR, "dwLocalAddr:%x.", dwLocalAddr ));
  1567. if( dwLocalAddr == NET_LOCAL_IP_ADDR_INTERFACE )
  1568. {
  1569. dwLocalAddr = dwRemoteAddr;
  1570. }
  1571. _ASSERTE( dwLocalAddr );
  1572. }
  1573. closesocket( querySocket );
  1574. H323DBG(( DEBUG_LEVEL_TRACE, "GetLocalIPAddress - exited." ));
  1575. return dwLocalAddr;
  1576. }
  1577. //!!always called from a lock
  1578. BOOL
  1579. RAS_CLIENT::IssueRecv(void)
  1580. {
  1581. int iError;
  1582. WSABUF BufferArray [1];
  1583. H323DBG(( DEBUG_LEVEL_TRACE, "IssueRecv entered:%p.",this ));
  1584. _ASSERTE(!m_recvOverlapped.IsPending);
  1585. if(m_Socket == INVALID_SOCKET)
  1586. {
  1587. return FALSE;
  1588. }
  1589. BufferArray [0].buf = (char *)(m_recvOverlapped.arBuf);
  1590. BufferArray [0].len = IO_BUFFER_SIZE;
  1591. ZeroMemory (&m_recvOverlapped.Overlapped, sizeof(OVERLAPPED));
  1592. m_recvOverlapped.Type = OVERLAPPED_TYPE_RECV;
  1593. m_recvOverlapped.RasClient = this;
  1594. m_recvOverlapped.AddressLength = sizeof (SOCKADDR_IN);
  1595. m_recvOverlapped.Flags = 0;
  1596. if( WSARecvFrom(m_Socket,
  1597. BufferArray, 1,
  1598. &m_recvOverlapped.BytesTransferred,
  1599. &m_recvOverlapped.Flags,
  1600. (SOCKADDR*)&m_recvOverlapped.Address,
  1601. &m_recvOverlapped.AddressLength,
  1602. &m_recvOverlapped.Overlapped,
  1603. NULL) == SOCKET_ERROR )
  1604. {
  1605. iError = WSAGetLastError();
  1606. if( iError == WSA_IO_PENDING )
  1607. {
  1608. m_recvOverlapped.IsPending = TRUE;
  1609. m_IoRefCount++;
  1610. }
  1611. else if( iError == WSAEMSGSIZE )
  1612. {
  1613. //We don't handle this condition right now as it should not happen
  1614. //In future with changes in the protocol this might be invoked and
  1615. //should be fixed
  1616. _ASSERTE( FALSE );
  1617. }
  1618. else if( iError == WSAECONNRESET )
  1619. {
  1620. //On a UPD-datagram socket this error would indicate that a
  1621. //previous send operation resulted in an ICMP "Port Unreachable"
  1622. //message. This will happen if GK is not listening on the specified
  1623. //port. This case would need special handling.
  1624. _ASSERTE( FALSE );
  1625. return FALSE;
  1626. }
  1627. else
  1628. {
  1629. //fatal error on the socket. shutdown the RAS client
  1630. return FALSE;
  1631. }
  1632. }
  1633. else
  1634. {
  1635. //data recvd immediately. IsPending is set beacause anyway a
  1636. //SendComplete event will be sent which will reset this BOOL
  1637. m_recvOverlapped.IsPending = TRUE;
  1638. m_IoRefCount++;
  1639. }
  1640. H323DBG(( DEBUG_LEVEL_TRACE, "IssueRecv exited:%p.",this ));
  1641. return TRUE;
  1642. }
  1643. HRESULT
  1644. RAS_CLIENT::EncodeSendMessage(
  1645. IN RasMessage * RasMessage)
  1646. {
  1647. RAS_SEND_CONTEXT * SendContext;
  1648. ASN1error_e AsnError;
  1649. WSABUF BufferArray [1];
  1650. DWORD dwStatus;
  1651. H323DBG(( DEBUG_LEVEL_TRACE, "EncodeSendMessage entered:%p.",this ));
  1652. Lock();
  1653. if (m_Socket == INVALID_SOCKET)
  1654. {
  1655. Unlock();
  1656. return E_FAIL;
  1657. }
  1658. SendContext = AllocSendBuffer();
  1659. if( SendContext == NULL )
  1660. {
  1661. Unlock();
  1662. return E_OUTOFMEMORY;
  1663. }
  1664. ZeroMemory( &SendContext -> Overlapped, sizeof (OVERLAPPED) );
  1665. AsnError = ASN1_Encode (
  1666. m_ASNCoderInfo.pEncInfo,
  1667. RasMessage,
  1668. RasMessage_PDU,
  1669. ASN1ENCODE_SETBUFFER,
  1670. SendContext -> arBuf,
  1671. IO_BUFFER_SIZE);
  1672. if (ASN1_FAILED (AsnError))
  1673. {
  1674. H323DBG ((DEBUG_LEVEL_ERROR, "RAS: failed to encode RAS PDU (%d).", AsnError));
  1675. FreeSendBuffer (SendContext);
  1676. Unlock();
  1677. return E_FAIL;
  1678. }
  1679. BufferArray [0].buf = (char *) SendContext -> arBuf;
  1680. BufferArray [0].len = m_ASNCoderInfo.pEncInfo -> len;
  1681. SendContext -> Type = OVERLAPPED_TYPE_SEND;
  1682. SendContext -> RasClient = this;
  1683. SendContext -> Address = m_GKAddress;
  1684. if( WSASendTo (m_Socket,
  1685. BufferArray,
  1686. 1,
  1687. &SendContext -> BytesTransferred,
  1688. 0,
  1689. (SOCKADDR *)&SendContext -> Address,
  1690. sizeof (SOCKADDR_IN),
  1691. &SendContext->Overlapped,
  1692. NULL) == SOCKET_ERROR
  1693. && WSAGetLastError() != WSA_IO_PENDING)
  1694. {
  1695. dwStatus = WSAGetLastError();
  1696. H323DBG(( DEBUG_LEVEL_ERROR, "failed to issue async send on RAS socket" ));
  1697. DumpError (dwStatus);
  1698. //fatal error: shut down the client
  1699. FreeSendBuffer (SendContext);
  1700. Unlock();
  1701. return HRESULT_FROM_WIN32 (dwStatus);
  1702. }
  1703. InsertHeadList( &m_sendPendingList, &SendContext -> ListEntry );
  1704. m_IoRefCount++;
  1705. Unlock();
  1706. H323DBG(( DEBUG_LEVEL_TRACE, "EncodeSendMessage exited:%p.",this ));
  1707. return S_OK;
  1708. }
  1709. // static
  1710. void
  1711. NTAPI RAS_CLIENT::IoCompletionCallback(
  1712. IN DWORD dwStatus,
  1713. IN DWORD BytesTransferred,
  1714. IN OVERLAPPED * Overlapped
  1715. )
  1716. {
  1717. RAS_OVERLAPPED * RasOverlapped;
  1718. RAS_CLIENT * pRASClient;
  1719. H323DBG(( DEBUG_LEVEL_TRACE, "ras-IoCompletionCallback entered." ));
  1720. _ASSERTE( Overlapped );
  1721. RasOverlapped = CONTAINING_RECORD( Overlapped, RAS_OVERLAPPED, Overlapped );
  1722. pRASClient = RasOverlapped -> RasClient;
  1723. switch (RasOverlapped -> Type)
  1724. {
  1725. case OVERLAPPED_TYPE_SEND:
  1726. pRASClient -> OnSendComplete( dwStatus,
  1727. static_cast<RAS_SEND_CONTEXT *> (RasOverlapped));
  1728. break;
  1729. case OVERLAPPED_TYPE_RECV:
  1730. RasOverlapped -> BytesTransferred = BytesTransferred;
  1731. pRASClient -> OnRecvComplete( dwStatus,
  1732. static_cast<RAS_RECV_CONTEXT *> (RasOverlapped));
  1733. break;
  1734. default:
  1735. _ASSERTE(FALSE);
  1736. }
  1737. H323DBG(( DEBUG_LEVEL_TRACE, "ras-IoCompletionCallback exited." ));
  1738. }
  1739. void
  1740. RAS_CLIENT::OnSendComplete(
  1741. IN DWORD dwStatus,
  1742. IN RAS_SEND_CONTEXT * pSendContext
  1743. )
  1744. {
  1745. H323DBG(( DEBUG_LEVEL_TRACE, "OnSendComplete entered:%p.",this ));
  1746. if( dwStatus != ERROR_SUCCESS )
  1747. {
  1748. return;
  1749. }
  1750. Lock();
  1751. m_IoRefCount--;
  1752. //if the RAS client is already shutdown, then reduce the I/O refcount and return.
  1753. if( m_dwState == RAS_CLIENT_STATE_NONE )
  1754. {
  1755. Unlock();
  1756. return;
  1757. }
  1758. //this buffer may have already been freed
  1759. if( IsInList( &m_sendPendingList, &pSendContext->ListEntry ) )
  1760. {
  1761. RemoveEntryList( &pSendContext->ListEntry );
  1762. FreeSendBuffer( pSendContext );
  1763. }
  1764. Unlock();
  1765. H323DBG(( DEBUG_LEVEL_TRACE, "OnSendComplete exited:%p.",this ));
  1766. }
  1767. void
  1768. RAS_CLIENT::OnRecvComplete(
  1769. IN DWORD dwStatus,
  1770. IN RAS_RECV_CONTEXT * RecvContext )
  1771. {
  1772. RasMessage * RasMessage = NULL;
  1773. ASN1error_e AsnError;
  1774. H323DBG(( DEBUG_LEVEL_TRACE, "OnRecvComplete enterd:%p.",this ));
  1775. Lock();
  1776. m_IoRefCount--;
  1777. //if the RAS client is already shutdown, then reduce the I/O refcount and return.
  1778. if( m_dwState == RAS_CLIENT_STATE_NONE )
  1779. {
  1780. Unlock();
  1781. return;
  1782. }
  1783. _ASSERTE(m_recvOverlapped.IsPending);
  1784. m_recvOverlapped.IsPending = FALSE;
  1785. switch( dwStatus )
  1786. {
  1787. case ERROR_SUCCESS:
  1788. //asn decode and process the message
  1789. if( m_recvOverlapped.BytesTransferred != 0 )
  1790. {
  1791. AsnError = ASN1_Decode (
  1792. m_ASNCoderInfo.pDecInfo, // ptr to encoder info
  1793. (PVOID *) &RasMessage, // pdu data structure
  1794. RasMessage_PDU, // pdu id
  1795. ASN1DECODE_SETBUFFER, // flags
  1796. m_recvOverlapped.arBuf, // buffer to decode
  1797. m_recvOverlapped.BytesTransferred); // size of buffer to decode
  1798. //issue another read
  1799. IssueRecv();
  1800. if( ASN1_SUCCEEDED(AsnError) )
  1801. {
  1802. _ASSERTE(RasMessage);
  1803. //This function should be always called in
  1804. //a lock and it unlocks the the ras client
  1805. ProcessRasMessage( RasMessage );
  1806. return;
  1807. }
  1808. else
  1809. {
  1810. H323DBG(( DEBUG_LEVEL_ERROR, "RAS ASNDecode returned error:%d.",
  1811. AsnError ));
  1812. H323DUMPBUFFER( (BYTE*)m_recvOverlapped.arBuf,
  1813. (DWORD)m_recvOverlapped.BytesTransferred);
  1814. }
  1815. }
  1816. break;
  1817. case STATUS_PORT_UNREACHABLE:
  1818. case STATUS_CANCELLED:
  1819. IssueRecv();
  1820. break;
  1821. default:
  1822. H323DBG ((DEBUG_LEVEL_ERROR, "failed to recv data on socket"));
  1823. DumpError (dwStatus);
  1824. break;
  1825. }
  1826. Unlock();
  1827. H323DBG(( DEBUG_LEVEL_TRACE, "OnRecvComplete exited:%p.",this ));
  1828. }
  1829. int
  1830. RAS_CLIENT::InitASNCoder(void)
  1831. {
  1832. int rc;
  1833. H323DBG((DEBUG_LEVEL_TRACE, "InitASNCoder entered: %p.", this ));
  1834. memset((PVOID)&m_ASNCoderInfo, 0, sizeof(m_ASNCoderInfo));
  1835. if( H225ASN_Module == NULL)
  1836. {
  1837. return ASN1_ERR_BADARGS;
  1838. }
  1839. rc = ASN1_CreateEncoder(
  1840. H225ASN_Module, // ptr to mdule
  1841. &(m_ASNCoderInfo.pEncInfo), // ptr to encoder info
  1842. NULL, // buffer ptr
  1843. 0, // buffer size
  1844. NULL); // parent ptr
  1845. if (rc == ASN1_SUCCESS)
  1846. {
  1847. _ASSERTE(m_ASNCoderInfo.pEncInfo );
  1848. rc = ASN1_CreateDecoder(
  1849. H225ASN_Module, // ptr to mdule
  1850. &(m_ASNCoderInfo.pDecInfo), // ptr to decoder info
  1851. NULL, // buffer ptr
  1852. 0, // buffer size
  1853. NULL); // parent ptr
  1854. _ASSERTE(m_ASNCoderInfo.pDecInfo );
  1855. }
  1856. if (rc != ASN1_SUCCESS)
  1857. {
  1858. TermASNCoder();
  1859. }
  1860. H323DBG((DEBUG_LEVEL_TRACE, "InitASNCoder exited: %p.", this ));
  1861. return rc;
  1862. }
  1863. //!!always called in a lock
  1864. int
  1865. RAS_CLIENT::TermASNCoder(void)
  1866. {
  1867. H323DBG(( DEBUG_LEVEL_TRACE, "RAS TermASNCoder entered:%p.",this ));
  1868. if (H225ASN_Module == NULL)
  1869. {
  1870. return ASN1_ERR_BADARGS;
  1871. }
  1872. ASN1_CloseEncoder(m_ASNCoderInfo.pEncInfo);
  1873. ASN1_CloseDecoder(m_ASNCoderInfo.pDecInfo);
  1874. memset( (PVOID)&m_ASNCoderInfo, 0, sizeof(m_ASNCoderInfo));
  1875. H323DBG(( DEBUG_LEVEL_TRACE, "RAS TermASNCoder exited:%p.",this ));
  1876. return ASN1_SUCCESS;
  1877. }
  1878. void
  1879. RAS_CLIENT::HandleRegistryChange()
  1880. {
  1881. PH323_ALIASNAMES pAliasList = NULL;
  1882. PH323_ALIASITEM pAliasItem = NULL;
  1883. PALIASCHANGE_REQUEST pAliasChangeRequest = NULL;
  1884. int iIndex;
  1885. H323DBG(( DEBUG_LEVEL_TRACE, "RAS HandleRegistryChange entered:%p.",this ));
  1886. //If line is not in listening mode then, return
  1887. if( g_pH323Line -> GetState() != H323_LINESTATE_LISTENING )
  1888. return;
  1889. Lock();
  1890. __try
  1891. {
  1892. //If registered with a GK, and GK disabled then send URQ.
  1893. if( g_RegistrySettings.fIsGKEnabled == FALSE )
  1894. {
  1895. RasStop();
  1896. }
  1897. else
  1898. {
  1899. switch( m_RegisterState )
  1900. {
  1901. //If not registered then send RRQ to the GK.
  1902. case RAS_REGISTER_STATE_IDLE:
  1903. //No need to send URQ.
  1904. //Shutdown the object.
  1905. g_RasClient.Shutdown();
  1906. RasStart();
  1907. break;
  1908. case RAS_REGISTER_STATE_REGISTERED:
  1909. case RAS_REGISTER_STATE_RRQSENT:
  1910. if( g_RegistrySettings.saGKAddr.sin_addr.s_addr !=
  1911. m_GKAddress.sin_addr.s_addr )
  1912. {
  1913. //change of GK address
  1914. //send URQ to the old GK and shutdown the RASClinet object.
  1915. RasStop();
  1916. //Initialize the GK object with new settings and send RRQ to the new GK.
  1917. RasStart();
  1918. }
  1919. else
  1920. {
  1921. //check for change in alias list.
  1922. for( iIndex=0; iIndex < m_pAliasList->wCount; iIndex++ )
  1923. {
  1924. pAliasItem = &(m_pAliasList->pItems[iIndex]);
  1925. if( pAliasItem->wType == e164_chosen )
  1926. {
  1927. if( g_RegistrySettings.fIsGKLogOnPhoneEnabled == FALSE )
  1928. {
  1929. break;
  1930. }
  1931. else if( memcmp(
  1932. (PVOID)g_RegistrySettings.wszGKLogOnPhone,
  1933. pAliasItem->pData,
  1934. (pAliasItem->wDataLength+1) * sizeof(WCHAR) ) != 0 )
  1935. {
  1936. break;
  1937. }
  1938. }
  1939. else if( pAliasItem->wType == h323_ID_chosen )
  1940. {
  1941. if( g_RegistrySettings.fIsGKLogOnAccountEnabled==FALSE )
  1942. {
  1943. break;
  1944. }
  1945. else if( memcmp(
  1946. (PVOID)g_RegistrySettings.wszGKLogOnAccount,
  1947. pAliasItem->pData,
  1948. (pAliasItem->wDataLength+1) * sizeof(WCHAR) ) != 0 )
  1949. {
  1950. break;
  1951. }
  1952. }
  1953. }
  1954. if( (iIndex < m_pAliasList->wCount ) ||
  1955. ( m_pAliasList->wCount !=
  1956. (g_RegistrySettings.fIsGKLogOnPhoneEnabled +
  1957. g_RegistrySettings.fIsGKLogOnAccountEnabled
  1958. )
  1959. )
  1960. )
  1961. {
  1962. //create the new alias list.
  1963. pAliasList = new H323_ALIASNAMES;
  1964. if( pAliasList != NULL )
  1965. {
  1966. ZeroMemory( (PVOID)pAliasList, sizeof(H323_ALIASNAMES) );
  1967. if( g_RegistrySettings.fIsGKLogOnPhoneEnabled )
  1968. {
  1969. if( !AddAliasItem( pAliasList,
  1970. g_RegistrySettings.wszGKLogOnPhone,
  1971. e164_chosen ) )
  1972. {
  1973. goto cleanup;
  1974. }
  1975. }
  1976. if( g_RegistrySettings.fIsGKLogOnAccountEnabled )
  1977. {
  1978. if( !AddAliasItem( pAliasList,
  1979. g_RegistrySettings.wszGKLogOnAccount,
  1980. h323_ID_chosen ) )
  1981. {
  1982. goto cleanup;
  1983. }
  1984. }
  1985. //queue the alias change request in the list
  1986. pAliasChangeRequest = new ALIASCHANGE_REQUEST;
  1987. if( pAliasChangeRequest == NULL )
  1988. {
  1989. goto cleanup;
  1990. }
  1991. pAliasChangeRequest->rasEndpointID.length = m_RASEndpointID.length;
  1992. CopyMemory( (PVOID)pAliasChangeRequest->rasEndpointID.value,
  1993. m_RASEndpointID.value,
  1994. (pAliasChangeRequest->rasEndpointID.length+1)*sizeof(WCHAR) );
  1995. pAliasChangeRequest->wRequestSeqNum = 0;
  1996. pAliasChangeRequest->pAliasList = pAliasList;
  1997. //Send RRQ with the new alias list.
  1998. if( !SendRRQ(NOT_RESEND_SEQ_NUM, pAliasChangeRequest) )
  1999. {
  2000. goto cleanup;
  2001. }
  2002. InsertHeadList( &m_aliasChangeRequestList,
  2003. &pAliasChangeRequest->listEntry );
  2004. }
  2005. }
  2006. }
  2007. break;
  2008. default:
  2009. //Shutdown the RASClinet object. Send RRQ to new GK.
  2010. RasStop();
  2011. RasStart();
  2012. break;
  2013. }
  2014. }
  2015. }
  2016. __except(1)
  2017. {
  2018. H323DBG(( DEBUG_LEVEL_TRACE, "except in HandleRegistryChange :%p.", this ));
  2019. _ASSERTE(0);
  2020. }
  2021. Unlock();
  2022. H323DBG(( DEBUG_LEVEL_TRACE, "RAS HandleRegistryChange exited:%p.", this ));
  2023. return;
  2024. cleanup:
  2025. if( pAliasList != NULL )
  2026. {
  2027. FreeAliasNames( pAliasList );
  2028. }
  2029. if( pAliasChangeRequest != NULL )
  2030. {
  2031. delete pAliasChangeRequest;
  2032. }
  2033. Unlock();
  2034. }