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.

1227 lines
24 KiB

  1. /*++
  2. Copyright (c) 1998 Microsoft Corporation
  3. Module Name:
  4. routing\monitor2\ip\mprip.c
  5. Abstract:
  6. Functions to modify transport header (global and interface)
  7. This file now contains all the function exported by ipmon.dll to
  8. the helpers
  9. Revision History:
  10. Anand Mahalingam 7/29/98 Created
  11. AmritanR
  12. --*/
  13. #include "precomp.h"
  14. #include <time.h>
  15. #pragma hdrstop
  16. #define MaxIfDisplayLength 1024
  17. #define SetErrorType(pdw) *(pdw) = IsRouterRunning()?ERROR_ADMIN:ERROR_CONFIG
  18. BOOL g_bRouterRunning;
  19. ULONG g_ulNumChecks;
  20. VOID
  21. FreeInfoBuffer(
  22. IN PVOID pvBuffer
  23. )
  24. {
  25. HeapFree(GetProcessHeap(),
  26. 0,
  27. pvBuffer);
  28. }
  29. DWORD
  30. WINAPI
  31. IpmontrSetInfoBlockInGlobalInfo(
  32. IN DWORD dwType,
  33. IN PBYTE pbInfoBlk,
  34. IN DWORD dwSize,
  35. IN DWORD dwCount
  36. )
  37. /*++
  38. Routine Description:
  39. Called to Set or Add an info block to the Global Info
  40. Arguments:
  41. pbInfoBlk - Info block to be added
  42. dwType - Type of the info block
  43. dwSize - Size of each item in the info block
  44. dwCount - Number of items in the info block
  45. Return Value:
  46. NO_ERROR
  47. --*/
  48. {
  49. PRTR_INFO_BLOCK_HEADER pOldInfo, pNewInfo;
  50. DWORD dwErr;
  51. //
  52. // Get/update global info
  53. //
  54. dwErr = ValidateGlobalInfo(&pOldInfo);
  55. if(dwErr isnot NO_ERROR)
  56. {
  57. return dwErr;
  58. }
  59. if(MprInfoBlockExists(pOldInfo,
  60. dwType))
  61. {
  62. //
  63. // The block already exists. So call set to replace it
  64. //
  65. dwErr = MprInfoBlockSet(pOldInfo,
  66. dwType,
  67. dwSize,
  68. dwCount,
  69. pbInfoBlk,
  70. &pNewInfo);
  71. }
  72. else
  73. {
  74. //
  75. // No info currently, add it
  76. //
  77. dwErr = MprInfoBlockAdd(pOldInfo,
  78. dwType,
  79. dwSize,
  80. dwCount,
  81. pbInfoBlk,
  82. &pNewInfo);
  83. }
  84. //
  85. // Dont need the old info
  86. //
  87. FREE_BUFFER(pOldInfo);
  88. if(dwErr isnot NO_ERROR)
  89. {
  90. if(!g_bCommit)
  91. {
  92. g_tiTransport.pibhInfo = NULL;
  93. g_tiTransport.bValid = FALSE;
  94. }
  95. return dwErr;
  96. }
  97. //
  98. // If in commit mode, set it to the router/registry
  99. // Otherwise update the local copy
  100. //
  101. if(g_bCommit)
  102. {
  103. dwErr = SetGlobalInfo(pNewInfo);
  104. FREE_BUFFER(pNewInfo);
  105. }
  106. else
  107. {
  108. ASSERT(g_tiTransport.bValid);
  109. g_tiTransport.pibhInfo = pNewInfo;
  110. dwErr = NO_ERROR;
  111. }
  112. return dwErr;
  113. }
  114. DWORD
  115. WINAPI
  116. IpmontrSetInfoBlockInInterfaceInfo(
  117. IN LPCWSTR pwszIfName,
  118. IN DWORD dwType,
  119. IN PBYTE pbInfoBlk,
  120. IN DWORD dwSize,
  121. IN DWORD dwCount
  122. )
  123. /*++
  124. Routine Description:
  125. Adds or Sets and infoblock in the interface info
  126. Arguments:
  127. pwszIfName - interface name
  128. pbInfoBlk - Info block to be added
  129. dwType - Type of the info block
  130. dwSize - Size of each item in the info block
  131. dwCount - Number of items in the info block
  132. Return Value:
  133. NO_ERROR
  134. --*/
  135. {
  136. PRTR_INFO_BLOCK_HEADER pOldInfo, pNewInfo;
  137. DWORD dwErr;
  138. PINTERFACE_STORE pii;
  139. pii = NULL;
  140. //
  141. // Get/Update the interface info
  142. //
  143. dwErr = ValidateInterfaceInfo(pwszIfName,
  144. &pOldInfo,
  145. NULL,
  146. &pii);
  147. if(dwErr isnot NO_ERROR)
  148. {
  149. return dwErr;
  150. }
  151. if(MprInfoBlockExists(pOldInfo,
  152. dwType))
  153. {
  154. //
  155. // The block already exists call Set to replace
  156. //
  157. dwErr = MprInfoBlockSet(pOldInfo,
  158. dwType,
  159. dwSize,
  160. dwCount,
  161. pbInfoBlk,
  162. &pNewInfo);
  163. }
  164. else
  165. {
  166. dwErr = MprInfoBlockAdd(pOldInfo,
  167. dwType,
  168. dwSize,
  169. dwCount,
  170. pbInfoBlk,
  171. &pNewInfo);
  172. }
  173. FREE_BUFFER(pOldInfo);
  174. if(dwErr isnot NO_ERROR)
  175. {
  176. //
  177. // Some error - invalidate info
  178. //
  179. if(!g_bCommit)
  180. {
  181. ASSERT(pii);
  182. ASSERT(pii->bValid);
  183. pii->pibhInfo = NULL;
  184. pii->bValid = FALSE;
  185. }
  186. return dwErr;
  187. }
  188. if(g_bCommit)
  189. {
  190. //
  191. // Set to router/registry
  192. //
  193. dwErr = SetInterfaceInfo(pNewInfo,
  194. pwszIfName);
  195. FREE_BUFFER(pNewInfo);
  196. }
  197. else
  198. {
  199. //
  200. // Update local copy with new info (old one has been freed)
  201. //
  202. ASSERT(pii);
  203. ASSERT(pii->bValid);
  204. pii->pibhInfo = pNewInfo;
  205. pii->bValid = TRUE;
  206. dwErr = NO_ERROR;
  207. }
  208. return dwErr;
  209. }
  210. DWORD
  211. WINAPI
  212. IpmontrDeleteInfoBlockFromGlobalInfo(
  213. IN DWORD dwType
  214. )
  215. /*++
  216. Routine Description:
  217. Deletes an infoblock from the global info.
  218. The Infoblock is deleted by setting its Size and Count to 0
  219. Arguments:
  220. dwType - Id of Protocol to be added
  221. Return Value:
  222. NO_ERROR
  223. --*/
  224. {
  225. DWORD dwErr = NO_ERROR;
  226. PRTR_INFO_BLOCK_HEADER pOldInfo, pNewInfo;
  227. dwErr = ValidateGlobalInfo(&pOldInfo);
  228. if(dwErr isnot NO_ERROR)
  229. {
  230. return dwErr;
  231. }
  232. if(!MprInfoBlockExists(pOldInfo,
  233. dwType))
  234. {
  235. if(g_bCommit)
  236. {
  237. //
  238. // Arent saving a local copy so free this info
  239. //
  240. FREE_BUFFER(pOldInfo);
  241. }
  242. return NO_ERROR;
  243. }
  244. //
  245. // The router manager will only delete config info if we set
  246. // the size to 0. However, we don't want to write 0-size
  247. // blocks to the registry, so we will strip them out when
  248. // we write to the registry.
  249. //
  250. dwErr = MprInfoBlockSet(pOldInfo,
  251. dwType,
  252. 0,
  253. 0,
  254. NULL,
  255. &pNewInfo);
  256. FREE_BUFFER(pOldInfo);
  257. if(dwErr isnot NO_ERROR)
  258. {
  259. if(!g_bCommit)
  260. {
  261. ASSERT(g_tiTransport.bValid);
  262. g_tiTransport.pibhInfo = NULL;
  263. g_tiTransport.bValid = FALSE;
  264. }
  265. return dwErr;
  266. }
  267. if(g_bCommit)
  268. {
  269. dwErr = SetGlobalInfo(pNewInfo);
  270. FREE_BUFFER(pNewInfo);
  271. }
  272. else
  273. {
  274. ASSERT(g_tiTransport.bValid);
  275. g_tiTransport.pibhInfo = pNewInfo;
  276. dwErr = NO_ERROR;
  277. }
  278. return dwErr;
  279. }
  280. DWORD
  281. WINAPI
  282. IpmontrDeleteInfoBlockFromInterfaceInfo(
  283. IN LPCWSTR pwszIfName,
  284. IN DWORD dwType
  285. )
  286. /*++
  287. Routine Description:
  288. Deletes an info block from the interface info. The info block is
  289. deleted by setting its Size and Count to 0
  290. Arguments:
  291. pwszIfName - Interface on which to add the protocol
  292. dwType - Id of Protocol to be added
  293. Return Value:
  294. NO_ERROR
  295. --*/
  296. {
  297. DWORD dwErr;
  298. PRTR_INFO_BLOCK_HEADER pOldInfo, pNewInfo;
  299. PINTERFACE_STORE pii;
  300. pii = NULL;
  301. dwErr = ValidateInterfaceInfo(pwszIfName,
  302. &pOldInfo,
  303. NULL,
  304. &pii);
  305. if (dwErr isnot NO_ERROR)
  306. {
  307. return dwErr;
  308. }
  309. if(!MprInfoBlockExists(pOldInfo,
  310. dwType))
  311. {
  312. if (g_bCommit)
  313. {
  314. FREE_BUFFER(pOldInfo);
  315. }
  316. return NO_ERROR;
  317. }
  318. //
  319. // If it does exist, remove it
  320. // This creates a new block
  321. // HACKHACK - Again we can interchangeably use info that is allocated
  322. // by GetXxx functions and MprInfoBlock functions since both allocations
  323. // are from ProcessHeap()
  324. //
  325. //
  326. // The router manager will only delete config info if we set
  327. // the size to 0. However, we don't want to write 0-size
  328. // blocks to the registry, so we will strip them out when
  329. // we write to the registry.
  330. //
  331. dwErr = MprInfoBlockSet(pOldInfo,
  332. dwType,
  333. 0,
  334. 0,
  335. NULL,
  336. &pNewInfo);
  337. //
  338. // One way or another, done with the old info
  339. //
  340. FREE_BUFFER(pOldInfo);
  341. if(dwErr isnot NO_ERROR)
  342. {
  343. if(!g_bCommit)
  344. {
  345. ASSERT(pii);
  346. ASSERT(pii->bValid);
  347. pii->pibhInfo = NULL;
  348. pii->bValid = FALSE;
  349. }
  350. return dwErr;
  351. }
  352. if(g_bCommit)
  353. {
  354. dwErr = SetInterfaceInfo(pNewInfo,
  355. pwszIfName);
  356. FREE_BUFFER(pNewInfo);
  357. }
  358. else
  359. {
  360. ASSERT(pii);
  361. ASSERT(pii->bValid);
  362. pii->pibhInfo = pNewInfo;
  363. pii->bValid = TRUE;
  364. dwErr = NO_ERROR;
  365. }
  366. return dwErr;
  367. }
  368. DWORD
  369. WINAPI
  370. IpmontrDeleteProtocol(
  371. IN DWORD dwProtoId
  372. )
  373. /*++
  374. Routine Description:
  375. Deletes Protocol from a transport
  376. Arguments:
  377. dwProtoId - Id of Protocol to be deleted
  378. Return Value:
  379. NO_ERROR
  380. --*/
  381. {
  382. DWORD dwRes;
  383. PMPR_INTERFACE_0 pmi0;
  384. DWORD dwCnt, dwTot, dwInd, dwCount, dwErrType;
  385. SetErrorType(&dwErrType);
  386. do
  387. {
  388. //
  389. // Protocol being deleted globally, so remove from
  390. // all interfaces.
  391. //
  392. dwRes = IpmontrInterfaceEnum((PBYTE *) &pmi0,
  393. &dwCnt,
  394. &dwTot);
  395. if(dwRes != NO_ERROR)
  396. {
  397. DisplayMessage(g_hModule, dwErrType, dwRes);
  398. break;
  399. }
  400. if (pmi0 == NULL)
  401. {
  402. dwCnt = 0;
  403. }
  404. for (dwInd = 0; dwInd < dwCnt; dwInd++)
  405. {
  406. dwRes =
  407. IpmontrDeleteInfoBlockFromInterfaceInfo(pmi0[dwInd].wszInterfaceName,
  408. dwProtoId);
  409. if (dwRes is ERROR_NOT_ENOUGH_MEMORY)
  410. {
  411. break;
  412. }
  413. }
  414. //
  415. // Remove protocol from global info
  416. //
  417. dwRes = IpmontrDeleteInfoBlockFromGlobalInfo(dwProtoId);
  418. if (dwRes != NO_ERROR)
  419. {
  420. break;
  421. }
  422. } while(FALSE);
  423. if (pmi0)
  424. {
  425. HeapFree(GetProcessHeap(), 0, pmi0);
  426. }
  427. return dwRes;
  428. }
  429. DWORD
  430. WINAPI
  431. IpmontrGetInfoBlockFromGlobalInfo(
  432. IN DWORD dwType,
  433. OUT BYTE **ppbInfoBlk, OPTIONAL
  434. OUT PDWORD pdwSize, OPTIONAL
  435. OUT PDWORD pdwCount OPTIONAL
  436. )
  437. /*++
  438. Routine Description:
  439. Gets the info block from global info. If we get a zero sized block
  440. we return ERROR_NOT_FOUND so as to not configure the caller
  441. Arguments:
  442. dwType - Type of the info block
  443. ppbInfoBlk - ptr to info block
  444. pdwSize - size of each item in block
  445. pdwCount - number of items in block
  446. Return Value:
  447. NO_ERROR
  448. ERROR_NOT_FOUND if the block doesnt exist.
  449. --*/
  450. {
  451. PRTR_INFO_BLOCK_HEADER pInfo;
  452. DWORD dwErr;
  453. BOOL *pbValid;
  454. PBYTE pbyTmp = NULL;
  455. DWORD dwSize, dwCnt;
  456. if(ppbInfoBlk)
  457. {
  458. *ppbInfoBlk = NULL;
  459. }
  460. if(pdwSize)
  461. {
  462. *pdwSize = 0;
  463. }
  464. if(pdwCount)
  465. {
  466. *pdwCount = 0;
  467. }
  468. dwErr = ValidateGlobalInfo(&pInfo);
  469. if(dwErr isnot NO_ERROR)
  470. {
  471. return dwErr;
  472. }
  473. dwErr = MprInfoBlockFind(pInfo,
  474. dwType,
  475. &dwSize,
  476. &dwCnt,
  477. &pbyTmp);
  478. if(dwErr is NO_ERROR)
  479. {
  480. if(dwSize is 0)
  481. {
  482. if(g_bCommit)
  483. {
  484. FREE_BUFFER(pInfo);
  485. }
  486. return ERROR_NOT_FOUND;
  487. }
  488. if(ppbInfoBlk)
  489. {
  490. *ppbInfoBlk = HeapAlloc(GetProcessHeap(),
  491. 0,
  492. dwSize * dwCnt);
  493. if(*ppbInfoBlk is NULL)
  494. {
  495. if(g_bCommit)
  496. {
  497. FREE_BUFFER(pInfo);
  498. }
  499. return ERROR_NOT_ENOUGH_MEMORY;
  500. }
  501. CopyMemory(*ppbInfoBlk,
  502. pbyTmp,
  503. dwSize * dwCnt);
  504. }
  505. if(pdwSize)
  506. {
  507. *pdwSize = dwSize;
  508. }
  509. if(pdwCount)
  510. {
  511. *pdwCount = dwCnt;
  512. }
  513. }
  514. if(g_bCommit)
  515. {
  516. FREE_BUFFER(pInfo);
  517. }
  518. return dwErr;
  519. }
  520. DWORD
  521. WINAPI
  522. IpmontrGetInfoBlockFromInterfaceInfo(
  523. IN LPCWSTR pwszIfName,
  524. IN DWORD dwType,
  525. OUT BYTE **ppbInfoBlk, OPTIONAL
  526. OUT PDWORD pdwSize, OPTIONAL
  527. OUT PDWORD pdwCount, OPTIONAL
  528. OUT PDWORD pdwIfType OPTIONAL
  529. )
  530. /*++
  531. Routine Description:
  532. Gets the info block from interface transport header
  533. Arguments:
  534. pwszIfName - Interface Name
  535. dwType - Type of the info block
  536. ppbInfoBlk - ptr to info block
  537. pdwSize - size of each item in block
  538. pdwCount - number of items in block
  539. pdwIfType - interface type
  540. Return Value:
  541. NO_ERROR
  542. ERROR_NOT_FOUND
  543. --*/
  544. {
  545. PRTR_INFO_BLOCK_HEADER pInfo, *ppInfo;
  546. DWORD dwErr;
  547. PBYTE pbTmp, pbyTmp;
  548. DWORD dwSize, dwCount;
  549. if(ppbInfoBlk)
  550. {
  551. *ppbInfoBlk = NULL;
  552. }
  553. if(pdwSize)
  554. {
  555. *pdwSize = 0;
  556. }
  557. if(pdwCount)
  558. {
  559. *pdwCount = 0;
  560. }
  561. //
  562. // If the user doesnt want any info, size or count, then we can optimize
  563. // a bit by passing NULL to validate
  564. //
  565. if(((ULONG_PTR)ppbInfoBlk | (ULONG_PTR)pdwSize | (ULONG_PTR)pdwCount))
  566. {
  567. ppInfo = &pInfo;
  568. }
  569. else
  570. {
  571. ppInfo = NULL;
  572. }
  573. dwErr = ValidateInterfaceInfo(pwszIfName,
  574. ppInfo,
  575. pdwIfType,
  576. NULL);
  577. if((dwErr isnot NO_ERROR) or
  578. (ppInfo is NULL))
  579. {
  580. //
  581. // If the user had an error or only wanted the ifType we are done
  582. //
  583. return dwErr;
  584. }
  585. //
  586. // Return protocol block info.
  587. //
  588. dwErr = MprInfoBlockFind(pInfo,
  589. dwType,
  590. &dwSize,
  591. &dwCount,
  592. &pbyTmp);
  593. if(dwErr is NO_ERROR)
  594. {
  595. if(dwSize is 0)
  596. {
  597. if(g_bCommit)
  598. {
  599. FREE_BUFFER(pInfo);
  600. }
  601. return ERROR_NOT_FOUND;
  602. }
  603. if(ppbInfoBlk)
  604. {
  605. *ppbInfoBlk = HeapAlloc(GetProcessHeap(),
  606. 0,
  607. dwSize * dwCount);
  608. if(*ppbInfoBlk is NULL)
  609. {
  610. if(g_bCommit)
  611. {
  612. FREE_BUFFER(pInfo);
  613. }
  614. return ERROR_NOT_ENOUGH_MEMORY;
  615. }
  616. CopyMemory(*ppbInfoBlk,
  617. pbyTmp,
  618. dwSize * dwCount);
  619. if(pdwSize)
  620. {
  621. *pdwSize = dwSize;
  622. }
  623. if(pdwCount)
  624. {
  625. *pdwCount = dwCount;
  626. }
  627. }
  628. }
  629. if(g_bCommit)
  630. {
  631. FREE_BUFFER(pInfo);
  632. }
  633. return dwErr;
  634. }
  635. DWORD WINAPI
  636. IpmontrGetInterfaceType(
  637. IN LPCWSTR pwszIfName,
  638. OUT PDWORD pdwIfType
  639. )
  640. {
  641. return GetInterfaceInfo(pwszIfName,
  642. NULL,
  643. NULL,
  644. pdwIfType);
  645. }
  646. DWORD
  647. WINAPI
  648. GetInterfaceName(
  649. IN LPCWSTR ptcArgument,
  650. OUT LPWSTR pwszIfName,
  651. IN DWORD dwSizeOfIfName,
  652. OUT PDWORD pdwNumParsed
  653. )
  654. /*++
  655. Description:
  656. Convert a friendly name to an interface name
  657. Arguments:
  658. ptcArgument - Buffer holding the Friendly Name of an interface
  659. pwszIfName - Buffer to hold the Guid Interface Name
  660. dwSizeOfIfName - Size (in Bytes) of the pwszIfName
  661. pdwNumParsed -
  662. --*/
  663. {
  664. DWORD dwErr;
  665. dwErr = IpmontrGetIfNameFromFriendlyName(
  666. ptcArgument,
  667. pwszIfName,
  668. &dwSizeOfIfName );
  669. *pdwNumParsed = (dwErr is NO_ERROR)? 1 : 0;
  670. return dwErr;
  671. }
  672. DWORD
  673. WINAPI
  674. GetInterfaceDescription(
  675. IN LPCWSTR pwszIfName,
  676. OUT LPWSTR pwszIfDesc,
  677. OUT PDWORD pdwNumParsed
  678. )
  679. {
  680. DWORD rc,dwSize;
  681. WCHAR IfNamBuffer[MaxIfDisplayLength];
  682. DWORD dwLen = (DWORD) wcslen(pwszIfName);
  683. if ( !dwLen || dwLen > MAX_INTERFACE_NAME_LEN )
  684. {
  685. *pdwNumParsed = 0;
  686. return ERROR_INVALID_PARAMETER;
  687. }
  688. dwSize = sizeof(IfNamBuffer);
  689. //======================================
  690. // Translate the Interface Name
  691. //======================================
  692. rc = IpmontrGetFriendlyNameFromIfName(pwszIfName, IfNamBuffer, &dwSize);
  693. if (rc == NO_ERROR)
  694. {
  695. wcscpy(pwszIfDesc,IfNamBuffer);
  696. *pdwNumParsed = 1;
  697. }
  698. else
  699. {
  700. *pdwNumParsed = 0;
  701. }
  702. return rc;
  703. }
  704. DWORD
  705. WINAPI
  706. IpmontrInterfaceEnum(
  707. OUT PBYTE *ppb,
  708. OUT PDWORD pdwCount,
  709. OUT PDWORD pdwTotal
  710. )
  711. {
  712. DWORD dwRes;
  713. PMPR_INTERFACE_0 pmi0;
  714. if(!IsRouterRunning())
  715. {
  716. dwRes = MprConfigInterfaceEnum(g_hMprConfig,
  717. 0,
  718. (LPBYTE*) &pmi0,
  719. (DWORD) -1,
  720. pdwCount,
  721. pdwTotal,
  722. NULL);
  723. if(dwRes == NO_ERROR)
  724. {
  725. *ppb = (PBYTE)pmi0;
  726. }
  727. }
  728. else
  729. {
  730. dwRes = MprAdminInterfaceEnum(g_hMprAdmin,
  731. 0,
  732. (LPBYTE*) &pmi0,
  733. (DWORD) -1,
  734. pdwCount,
  735. pdwTotal,
  736. NULL);
  737. if(dwRes == NO_ERROR)
  738. {
  739. *ppb = HeapAlloc(GetProcessHeap(),
  740. 0,
  741. sizeof(MPR_INTERFACE_0) * (*pdwCount));
  742. if(*ppb == NULL)
  743. {
  744. DisplayMessage(g_hModule, MSG_IP_NOT_ENOUGH_MEMORY);
  745. return ERROR_NOT_ENOUGH_MEMORY;
  746. }
  747. CopyMemory(*ppb, pmi0, sizeof(MPR_INTERFACE_0) * (*pdwCount));
  748. MprAdminBufferFree(pmi0);
  749. }
  750. }
  751. return dwRes;
  752. }
  753. DWORD
  754. WINAPI
  755. MatchRoutingProtoTag(
  756. IN LPCWSTR pwszToken
  757. )
  758. /*++
  759. Routine Description:
  760. Gets the protocol ID corresponding to a protocol tag.
  761. Arguments:
  762. pwszArg - protocol token
  763. Return Value:
  764. Protocol Id or (DWORD)-1
  765. --*/
  766. {
  767. DWORD dwRes, dwErr;
  768. TOKEN_VALUE rgEnums[] ={{TOKEN_VALUE_RIP, PROTO_IP_RIP},
  769. {TOKEN_VALUE_OSPF, PROTO_IP_OSPF},
  770. {TOKEN_VALUE_AUTOSTATIC, PROTO_IP_NT_AUTOSTATIC},
  771. {TOKEN_VALUE_STATIC, PROTO_IP_NT_STATIC},
  772. {TOKEN_VALUE_NETMGMT, PROTO_IP_NETMGMT},
  773. {TOKEN_VALUE_LOCAL, PROTO_IP_LOCAL},
  774. {TOKEN_VALUE_NONDOD, PROTO_IP_NT_STATIC_NON_DOD}};
  775. if (iswdigit(pwszToken[0]))
  776. {
  777. return wcstoul(pwszToken, NULL, 10);
  778. }
  779. dwErr = MatchEnumTag(g_hModule,
  780. pwszToken,
  781. sizeof(rgEnums)/sizeof(TOKEN_VALUE),
  782. rgEnums,
  783. &dwRes);
  784. if(dwErr != NO_ERROR)
  785. {
  786. return (DWORD)-1;
  787. }
  788. return dwRes;
  789. }
  790. BOOL
  791. WINAPI
  792. IsRouterRunning(
  793. VOID
  794. )
  795. /*++
  796. Routine Description:
  797. Gets the protocol ID corresponding to a protocol tag.
  798. Arguments:
  799. pwszArg - protocol token
  800. Return Value:
  801. Protocol Id or (DWORD)-1
  802. --*/
  803. {
  804. DWORD dwErr;
  805. //
  806. // Check at most once per second
  807. //
  808. // We don't care about wrapping, we just need a fast way to
  809. // get some identifier of the current "second".
  810. //
  811. static time_t dwPreviousTime = 0;
  812. time_t dwCurrentTime;
  813. time(&dwCurrentTime);
  814. if (dwCurrentTime == dwPreviousTime)
  815. {
  816. return g_bRouterRunning;
  817. }
  818. dwPreviousTime = dwCurrentTime;
  819. if(MprAdminIsServiceRunning(g_pwszRouter))
  820. {
  821. if(g_bRouterRunning)
  822. {
  823. return TRUE;
  824. }
  825. dwErr = MprAdminServerConnect(g_pwszRouter,
  826. &g_hMprAdmin);
  827. if(dwErr isnot NO_ERROR)
  828. {
  829. DisplayError(NULL,
  830. dwErr);
  831. DisplayMessage(g_hModule,
  832. MSG_IP_CAN_NOT_CONNECT_DIM,
  833. dwErr);
  834. return FALSE;
  835. }
  836. dwErr = MprAdminMIBServerConnect(g_pwszRouter,
  837. &g_hMIBServer);
  838. if(dwErr isnot NO_ERROR)
  839. {
  840. DisplayError(NULL,
  841. dwErr);
  842. DisplayMessage(g_hModule,
  843. MSG_IP_CAN_NOT_CONNECT_DIM,
  844. dwErr);
  845. MprAdminServerDisconnect(g_hMprAdmin);
  846. g_hMprAdmin = NULL;
  847. return FALSE;
  848. }
  849. g_bRouterRunning = TRUE;
  850. }
  851. else
  852. {
  853. if(g_bRouterRunning)
  854. {
  855. g_bRouterRunning = FALSE;
  856. g_hMprAdmin = NULL;
  857. g_hMIBServer = NULL;
  858. }
  859. }
  860. return g_bRouterRunning;
  861. }
  862. DWORD
  863. MibGetFirst(
  864. DWORD dwTransportId,
  865. DWORD dwRoutingPid,
  866. LPVOID lpInEntry,
  867. DWORD dwInEntrySize,
  868. LPVOID *lplpOutEntry,
  869. LPDWORD lpdwOutEntrySize
  870. )
  871. {
  872. DWORD dwErr;
  873. dwErr = MprAdminMIBEntryGetFirst( g_hMIBServer,
  874. dwTransportId,
  875. dwRoutingPid,
  876. lpInEntry,
  877. dwInEntrySize,
  878. lplpOutEntry,
  879. lpdwOutEntrySize );
  880. if (dwErr is RPC_S_INVALID_BINDING)
  881. {
  882. g_bRouterRunning = FALSE;
  883. g_hMprAdmin = NULL;
  884. g_hMIBServer = NULL;
  885. }
  886. return dwErr;
  887. }
  888. DWORD
  889. MibGetNext(
  890. DWORD dwTransportId,
  891. DWORD dwRoutingPid,
  892. LPVOID lpInEntry,
  893. DWORD dwInEntrySize,
  894. LPVOID *lplpOutEntry,
  895. LPDWORD lpdwOutEntrySize
  896. )
  897. {
  898. DWORD dwErr;
  899. dwErr = MprAdminMIBEntryGetNext( g_hMIBServer,
  900. dwTransportId,
  901. dwRoutingPid,
  902. lpInEntry,
  903. dwInEntrySize,
  904. lplpOutEntry,
  905. lpdwOutEntrySize );
  906. if (dwErr is RPC_S_INVALID_BINDING)
  907. {
  908. g_bRouterRunning = FALSE;
  909. g_hMprAdmin = NULL;
  910. g_hMIBServer = NULL;
  911. }
  912. return dwErr;
  913. }
  914. DWORD
  915. MibGet(
  916. DWORD dwTransportId,
  917. DWORD dwRoutingPid,
  918. LPVOID lpInEntry,
  919. DWORD dwInEntrySize,
  920. LPVOID *lplpOutEntry,
  921. LPDWORD lpdwOutEntrySize
  922. )
  923. {
  924. DWORD dwErr;
  925. dwErr = MprAdminMIBEntryGet( g_hMIBServer,
  926. dwTransportId,
  927. dwRoutingPid,
  928. lpInEntry,
  929. dwInEntrySize,
  930. lplpOutEntry,
  931. lpdwOutEntrySize );
  932. if (dwErr is RPC_S_INVALID_BINDING)
  933. {
  934. g_bRouterRunning = FALSE;
  935. g_hMprAdmin = NULL;
  936. g_hMIBServer = NULL;
  937. }
  938. return dwErr;
  939. }