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.

1833 lines
42 KiB

  1. /*++
  2. Copyright (c) 1998 Microsoft Corporation
  3. Module Name:
  4. routing\monitor2\ip\ipcfg.c
  5. Abstract:
  6. Fns to change configuration at the IP Rtr Mgr level
  7. Revision History:
  8. Anand Mahalingam 7/10/98 Created
  9. --*/
  10. #include "precomp.h"
  11. #pragma hdrstop
  12. DWORD
  13. AddDeleteRoutePrefLevel (
  14. IN PPROTOCOL_METRIC ppm,
  15. IN DWORD dwNumProto,
  16. IN BOOL bAdd
  17. )
  18. /*++
  19. Routine Description:
  20. Adds, deletes route preferences
  21. Arguments:
  22. ppm - array of protocols to be added/deleted
  23. dwNumProto - Number of protocols to be added/deleted
  24. bAdd - To add or not to add
  25. Return Value:
  26. NO_ERROR
  27. --*/
  28. {
  29. DWORD dwRes = (DWORD) -1, dwSize = 0;
  30. PPRIORITY_INFO ppi = NULL, ppiNew = NULL;
  31. DWORD dwBlkSize, dwNewBlkSize, dwCount;
  32. DEBUG("In AddDelRoutePrefLevel");
  33. if (dwNumProto is 0)
  34. {
  35. return NO_ERROR;
  36. }
  37. do
  38. {
  39. dwRes = IpmontrGetInfoBlockFromGlobalInfo(IP_PROT_PRIORITY_INFO,
  40. (PBYTE *) &ppi,
  41. &dwBlkSize,
  42. &dwCount);
  43. if(dwRes != NO_ERROR)
  44. {
  45. break;
  46. }
  47. if(bAdd)
  48. {
  49. dwRes = AddNewRoutePrefToBlock(ppi,
  50. dwBlkSize,
  51. ppm,
  52. dwNumProto,
  53. &ppiNew,
  54. &dwNewBlkSize);
  55. }
  56. else
  57. {
  58. dwRes = DeleteRoutePrefFromBlock(ppi,
  59. dwBlkSize,
  60. ppm,
  61. dwNumProto,
  62. &ppiNew,
  63. &dwNewBlkSize);
  64. }
  65. if(dwRes != NO_ERROR)
  66. {
  67. if(dwRes is ERROR_NO_CHANGE)
  68. {
  69. //
  70. // No Change in config, proceed to change in router
  71. //
  72. dwRes = NO_ERROR;
  73. ppiNew = NULL;
  74. break;
  75. }
  76. }
  77. else
  78. {
  79. if(ppiNew)
  80. {
  81. dwRes = IpmontrSetInfoBlockInGlobalInfo(IP_PROT_PRIORITY_INFO,
  82. (PBYTE) ppiNew,
  83. dwNewBlkSize,
  84. dwCount);
  85. }
  86. }
  87. }while(FALSE);
  88. //
  89. // free allocations
  90. //
  91. if(ppi)
  92. {
  93. FreeInfoBuffer(ppi);
  94. ppi = NULL;
  95. }
  96. if(ppiNew)
  97. {
  98. FREE(ppiNew);
  99. ppiNew = NULL;
  100. }
  101. switch(dwRes)
  102. {
  103. case NO_ERROR:
  104. break;
  105. case ERROR_NOT_FOUND:
  106. DisplayMessage(g_hModule, EMSG_IP_NO_PRIO_INFO, L"Router");
  107. break;
  108. case ERROR_NOT_ENOUGH_MEMORY:
  109. DisplayMessage(g_hModule, MSG_IP_NOT_ENOUGH_MEMORY);
  110. break;
  111. default:
  112. DisplayError(g_hModule, dwRes);
  113. break;
  114. }
  115. return dwRes;
  116. }
  117. DWORD
  118. AddNewRoutePrefToBlock (
  119. IN PPRIORITY_INFO ppi,
  120. IN DWORD dwBlkSize,
  121. IN PPROTOCOL_METRIC ppm,
  122. IN DWORD dwNumProto,
  123. OUT PPRIORITY_INFO *pppi,
  124. OUT PDWORD pdwSize
  125. )
  126. /*++
  127. Routine Description:
  128. creates route preference block
  129. Arguments:
  130. ppi - preference block
  131. dwNumBlkSize - size of block
  132. ppm - protocols to be added
  133. dwNumProto - number of protocols
  134. pppi - new preference block
  135. pdwSize - size of new block
  136. Return Value:
  137. NO_ERROR
  138. --*/
  139. {
  140. PPRIORITY_INFO pPriorInfoOld = NULL, pPriorInfoNew = NULL;
  141. DWORD i = 0, dwNewSize = 0, dwRes = NO_ERROR;
  142. BOOL bFound = FALSE;
  143. PDWORD pdwValid;
  144. DWORD j, dwProtoCount;
  145. //
  146. // Have an array to tell which ones are valid.
  147. //
  148. pdwValid = MALLOC( dwNumProto * sizeof(DWORD));
  149. if (pdwValid is NULL)
  150. {
  151. DisplayMessage(g_hModule, MSG_IP_NOT_ENOUGH_MEMORY);
  152. return ERROR_NOT_ENOUGH_MEMORY;
  153. }
  154. ZeroMemory(pdwValid, dwNumProto * sizeof(DWORD));
  155. //
  156. // find the PrefLevel block
  157. //
  158. pPriorInfoOld = ppi;
  159. if ( pPriorInfoOld == (PPRIORITY_INFO) NULL )
  160. {
  161. DisplayMessage(g_hModule, MSG_IP_CORRUPT_INFO );
  162. FREE(pdwValid);
  163. return ERROR_INVALID_PARAMETER;
  164. }
  165. for ( j = 0, dwNewSize = 0; j < dwNumProto; j++)
  166. {
  167. //
  168. // make sure preference level for the protocol does not already exist.
  169. //
  170. for ( i = 0; i < pPriorInfoOld-> dwNumProtocols; i++ )
  171. {
  172. if (pPriorInfoOld->ppmProtocolMetric[ i ].dwProtocolId
  173. == ppm[j].dwProtocolId)
  174. {
  175. bFound = TRUE;
  176. break;
  177. }
  178. }
  179. if (bFound)
  180. {
  181. pdwValid[j] = 0;
  182. DisplayMessage(g_hModule, MSG_IP_PROTO_PREF_LEVEL_EXISTS,
  183. pPriorInfoOld->ppmProtocolMetric[ i ].dwMetric);
  184. bFound = FALSE;
  185. }
  186. else
  187. {
  188. pdwValid[j] = 1;
  189. dwNewSize += sizeof(PROTOCOL_METRIC);
  190. }
  191. }
  192. //
  193. // allocate new info block
  194. //
  195. if (dwNewSize is 0)
  196. {
  197. //
  198. // All specified protocols already present
  199. //
  200. FREE(pdwValid);
  201. return ERROR_NO_CHANGE;
  202. }
  203. dwProtoCount = dwNewSize / sizeof(PROTOCOL_METRIC);
  204. dwNewSize += dwBlkSize;
  205. pPriorInfoNew = MALLOC(dwNewSize);
  206. if ( pPriorInfoNew == NULL )
  207. {
  208. DisplayMessage(g_hModule, MSG_IP_NOT_ENOUGH_MEMORY );
  209. dwRes = ERROR_NOT_ENOUGH_MEMORY;
  210. return dwRes;
  211. }
  212. do
  213. {
  214. //
  215. // copy the old PrefLevels and set the number of protocols
  216. //
  217. CopyMemory((PBYTE) &pPriorInfoNew-> ppmProtocolMetric,
  218. (PBYTE) &pPriorInfoOld-> ppmProtocolMetric,
  219. sizeof(PROTOCOL_METRIC)*pPriorInfoOld-> dwNumProtocols);
  220. pPriorInfoNew-> dwNumProtocols = pPriorInfoOld-> dwNumProtocols +
  221. dwProtoCount;
  222. //
  223. // add the new PrefLevel and increment count of protocols
  224. // with PrefLevels
  225. //
  226. i = pPriorInfoOld-> dwNumProtocols;
  227. for ( j = 0 ; j < dwNumProto ; j++)
  228. {
  229. if (pdwValid[j])
  230. {
  231. //
  232. // Add the protocol priority
  233. //
  234. pPriorInfoNew-> ppmProtocolMetric[i].dwProtocolId
  235. = ppm[j].dwProtocolId;
  236. pPriorInfoNew-> ppmProtocolMetric[i++].dwMetric
  237. = ppm[j].dwMetric;
  238. }
  239. }
  240. } while (FALSE);
  241. FREE(pdwValid);
  242. if ( dwRes == NO_ERROR )
  243. {
  244. *pppi = pPriorInfoNew;
  245. *pdwSize = dwNewSize;
  246. }
  247. return dwRes;
  248. }
  249. DWORD
  250. DeleteRoutePrefFromBlock (
  251. IN PPRIORITY_INFO ppi,
  252. IN DWORD dwBlkSize,
  253. IN PPROTOCOL_METRIC ppm,
  254. IN DWORD dwNumProto,
  255. OUT PPRIORITY_INFO *pppi,
  256. OUT PDWORD pdwSize
  257. )
  258. /*++
  259. Routine Description:
  260. creates route preference block
  261. Arguments:
  262. ppi - preference block
  263. dwNumBlkSize - size of block
  264. ppm - protocols to be added
  265. dwNumProto - number of protocols
  266. pppi - new preference block
  267. pdwSize - size of new block
  268. Return Value:
  269. NO_ERROR
  270. --*/
  271. {
  272. PPRIORITY_INFO pPriorInfoOld = NULL, pPriorInfoNew = NULL;
  273. DWORD dwInd = 0, dwNewSize = 0, dwRes = NO_ERROR, i, j;
  274. BOOL bFound = FALSE;
  275. PDWORD pdwToDelete;
  276. // find the PrefLevel block
  277. pPriorInfoOld = ppi;
  278. if ( pPriorInfoOld == (PPRIORITY_INFO) NULL )
  279. {
  280. DisplayMessage(g_hModule, MSG_IP_CORRUPT_INFO );
  281. return ERROR_INVALID_PARAMETER;
  282. }
  283. pdwToDelete = MALLOC( pPriorInfoOld-> dwNumProtocols * sizeof(DWORD));
  284. if (pdwToDelete is NULL)
  285. {
  286. return ERROR_NOT_ENOUGH_MEMORY;
  287. }
  288. ZeroMemory(pdwToDelete, pPriorInfoOld-> dwNumProtocols * sizeof(DWORD));
  289. for ( i = 0, dwNewSize = 0; i < dwNumProto; i++)
  290. {
  291. //
  292. // make sure preference level for the protocol already exists.
  293. //
  294. for ( dwInd = 0; dwInd < pPriorInfoOld-> dwNumProtocols; dwInd++ )
  295. {
  296. if (pPriorInfoOld-> ppmProtocolMetric[ dwInd ].dwProtocolId
  297. == ppm[i].dwProtocolId)
  298. {
  299. bFound = TRUE;
  300. break;
  301. }
  302. }
  303. if (!bFound)
  304. {
  305. DisplayMessage(g_hModule, MSG_IP_PROTO_PREF_LEVEL_NOT_FOUND,
  306. ppm[i].dwProtocolId);
  307. }
  308. else
  309. {
  310. bFound = FALSE;
  311. pdwToDelete[dwInd] = 1;
  312. dwNewSize += sizeof(PROTOCOL_METRIC);
  313. }
  314. }
  315. if (dwNewSize is 0)
  316. {
  317. //
  318. // None of the protocols specified were found.
  319. //
  320. FREE(pdwToDelete);
  321. return ERROR_NO_CHANGE;
  322. }
  323. //
  324. // allocate new info block
  325. //
  326. dwNewSize = dwBlkSize - dwNewSize;
  327. pPriorInfoNew = MALLOC(dwNewSize);
  328. if ( pPriorInfoNew == NULL )
  329. {
  330. FREE(pdwToDelete);
  331. dwRes = ERROR_NOT_ENOUGH_MEMORY;
  332. return dwRes;
  333. }
  334. do
  335. {
  336. for ( i = 0, j = 0; i < pPriorInfoOld-> dwNumProtocols; i++)
  337. {
  338. if (pdwToDelete[i])
  339. {
  340. //
  341. // Do not copy this protocol
  342. //
  343. }
  344. else
  345. {
  346. pPriorInfoNew->ppmProtocolMetric[j].dwProtocolId =
  347. pPriorInfoOld->ppmProtocolMetric[i].dwProtocolId;
  348. pPriorInfoNew->ppmProtocolMetric[j++].dwMetric =
  349. pPriorInfoOld->ppmProtocolMetric[i].dwMetric;
  350. }
  351. }
  352. pPriorInfoNew-> dwNumProtocols = j;
  353. } while (FALSE);
  354. FREE(pdwToDelete);
  355. if ( dwRes == NO_ERROR )
  356. {
  357. *pppi = pPriorInfoNew;
  358. *pdwSize = dwNewSize;
  359. }
  360. return dwRes;
  361. }
  362. DWORD
  363. SetRoutePrefLevel (
  364. IN PROTOCOL_METRIC pm
  365. )
  366. /*++
  367. Routine Description:
  368. sets route preference
  369. Arguments:
  370. ppm - preference to set
  371. Return Value:
  372. NO_ERROR
  373. --*/
  374. {
  375. DWORD dwRes = (DWORD) -1, dwSize = 0;
  376. PPRIORITY_INFO ppi = NULL;
  377. DWORD dwBlkSize, dwCount;
  378. DEBUG("In SetRoutePrefLevel");
  379. do
  380. {
  381. //
  382. // get router config, add new router preference level,
  383. // and set the config
  384. //
  385. dwRes = IpmontrGetInfoBlockFromGlobalInfo(IP_PROT_PRIORITY_INFO,
  386. (PBYTE *) &ppi,
  387. &dwBlkSize,
  388. &dwCount);
  389. if (dwRes != NO_ERROR)
  390. {
  391. break;
  392. }
  393. dwRes = UpdateRtrPriority(ppi, pm);
  394. if ( dwRes != NO_ERROR )
  395. {
  396. break;
  397. }
  398. dwRes = IpmontrSetInfoBlockInGlobalInfo(IP_PROT_PRIORITY_INFO,
  399. (PBYTE) ppi,
  400. dwBlkSize,
  401. dwCount);
  402. if ( dwRes != NO_ERROR )
  403. {
  404. break;
  405. }
  406. PRINT(L"Made Changes to Router Config");
  407. if (!IsRouterRunning())
  408. {
  409. break;
  410. }
  411. } while (FALSE);
  412. //
  413. // Free all allocations
  414. //
  415. if ( ppi )
  416. {
  417. FREE(ppi);
  418. }
  419. switch(dwRes)
  420. {
  421. case NO_ERROR:
  422. break;
  423. case ERROR_NOT_FOUND:
  424. DisplayMessage(g_hModule, EMSG_IP_NO_PRIO_INFO, L"Router");
  425. break;
  426. case ERROR_NOT_ENOUGH_MEMORY:
  427. DisplayMessage(g_hModule, MSG_IP_NOT_ENOUGH_MEMORY);
  428. break;
  429. case ERROR_INVALID_PARAMETER:
  430. break;
  431. default:
  432. DisplayError(g_hModule, dwRes);
  433. break;
  434. }
  435. return dwRes;
  436. }
  437. DWORD
  438. UpdateRtrPriority(
  439. IN PPRIORITY_INFO ppi,
  440. IN PROTOCOL_METRIC pm
  441. )
  442. /*++
  443. Routine Description:
  444. sets route preference
  445. Arguments:
  446. ppi - route preference block
  447. ppm - preference to set
  448. Return Value:
  449. NO_ERROR
  450. --*/
  451. {
  452. BOOL bFound = FALSE;
  453. DWORD i = 0;
  454. if ( ppi == (PPRIORITY_INFO) NULL )
  455. {
  456. DisplayMessage(g_hModule, MSG_IP_CORRUPT_INFO );
  457. return ERROR_INVALID_PARAMETER;
  458. }
  459. // search for the protocol
  460. for ( i = 0; i < ppi-> dwNumProtocols; i++ )
  461. {
  462. if (ppi-> ppmProtocolMetric[ i ].dwProtocolId
  463. == pm.dwProtocolId )
  464. {
  465. ppi-> ppmProtocolMetric[ i ].dwMetric = pm.dwMetric;
  466. bFound = TRUE;
  467. break;
  468. }
  469. }
  470. if (!bFound)
  471. {
  472. // preference level for that protocolId does not exist
  473. DisplayMessage(g_hModule, MSG_IP_NO_PREF_FOR_PROTOCOL_ID,
  474. pm.dwProtocolId );
  475. return ERROR_INVALID_PARAMETER;
  476. }
  477. return NO_ERROR;
  478. }
  479. DWORD
  480. SetGlobalConfigInfo(
  481. IN DWORD dwLoggingLevel
  482. )
  483. /*++
  484. Routine Description:
  485. sets global logging level
  486. Arguments:
  487. dwLoggingLevel - Loggging level
  488. Return Value:
  489. NO_ERROR
  490. --*/
  491. {
  492. PGLOBAL_INFO pgi = NULL;
  493. DWORD dwBlkSize, dwCount, dwErr = NO_ERROR;
  494. do
  495. {
  496. //
  497. // Get the IP_GLOBAL_INFO block from router config
  498. //
  499. dwErr = IpmontrGetInfoBlockFromGlobalInfo(IP_GLOBAL_INFO,
  500. (PBYTE *) &pgi,
  501. &dwBlkSize,
  502. &dwCount);
  503. if (dwErr isnot NO_ERROR)
  504. {
  505. break;
  506. }
  507. pgi->dwLoggingLevel = dwLoggingLevel;
  508. //
  509. // Set the IP_GLOBAL_INFO block in router config
  510. //
  511. dwErr = IpmontrSetInfoBlockInGlobalInfo(IP_GLOBAL_INFO,
  512. (PBYTE) pgi,
  513. dwBlkSize,
  514. dwCount);
  515. if (dwErr isnot NO_ERROR)
  516. {
  517. break;
  518. }
  519. FREE(pgi);
  520. pgi = NULL;
  521. DEBUG("Set logging level in router config\n");
  522. }while (FALSE);
  523. if (pgi)
  524. {
  525. FREE(pgi);
  526. }
  527. switch(dwErr)
  528. {
  529. case NO_ERROR:
  530. break;
  531. case ERROR_NOT_FOUND:
  532. DisplayMessage(g_hModule, EMSG_IP_NO_PRIO_INFO, L"Router");
  533. break;
  534. case ERROR_NOT_ENOUGH_MEMORY:
  535. DisplayMessage(g_hModule, MSG_IP_NOT_ENOUGH_MEMORY);
  536. break;
  537. default:
  538. DisplayError(g_hModule, dwErr);
  539. break;
  540. }
  541. return dwErr;
  542. }
  543. DWORD
  544. UpdateInterfaceStatusInfo(
  545. IN DWORD dwAction,
  546. IN LPCWSTR pwszIfName,
  547. IN DWORD dwStatus
  548. )
  549. /*++
  550. Routine Description:
  551. Sets interface discovery information
  552. Arguments:
  553. pwszIfName - interface name
  554. dwStatus - enabled or disabled
  555. Return Value:
  556. NO_ERROR
  557. --*/
  558. {
  559. PINTERFACE_STATUS_INFO pifStat = (PINTERFACE_STATUS_INFO) NULL;
  560. DWORD dwRes = NO_ERROR, dwBlkSize;
  561. DWORD dwCount, dwIfType;
  562. do
  563. {
  564. dwRes = IpmontrGetInfoBlockFromInterfaceInfo(pwszIfName,
  565. IP_INTERFACE_STATUS_INFO,
  566. (PBYTE *) &pifStat,
  567. &dwBlkSize,
  568. &dwCount,
  569. &dwIfType);
  570. if (dwRes is ERROR_NOT_FOUND)
  571. {
  572. //
  573. // No info of this type is currently present
  574. //
  575. dwRes = NO_ERROR;
  576. dwCount = 0;
  577. // Add interface
  578. if (dwAction is ADD_COMMAND) {
  579. pifStat = (PINTERFACE_STATUS_INFO)MALLOC(
  580. sizeof(INTERFACE_STATUS_INFO));
  581. if (pifStat is NULL) {
  582. dwRes = ERROR_NOT_ENOUGH_MEMORY;
  583. break;
  584. }
  585. dwCount++;
  586. }
  587. }
  588. if (dwRes != NO_ERROR)
  589. {
  590. break;
  591. }
  592. if (dwCount is 0)
  593. return ERROR_NOT_FOUND;
  594. if (dwAction is DELETE_COMMAND)
  595. {
  596. dwCount = 0;
  597. }
  598. else
  599. {
  600. pifStat->dwAdminStatus = dwStatus;
  601. }
  602. dwRes = IpmontrSetInfoBlockInInterfaceInfo( pwszIfName,
  603. IP_INTERFACE_STATUS_INFO,
  604. (PBYTE) pifStat,
  605. dwBlkSize,
  606. dwCount);
  607. } while (FALSE);
  608. //
  609. // Free all allocations
  610. //
  611. if ( pifStat )
  612. {
  613. FREE(pifStat);
  614. }
  615. switch(dwRes)
  616. {
  617. case NO_ERROR:
  618. break;
  619. case ERROR_NOT_FOUND:
  620. DisplayMessage(g_hModule, EMSG_IP_NO_IF_STATUS_INFO, L"Router");
  621. break;
  622. case ERROR_NOT_ENOUGH_MEMORY:
  623. DisplayMessage(g_hModule, MSG_IP_NOT_ENOUGH_MEMORY);
  624. break;
  625. default:
  626. DisplayError(g_hModule, dwRes);
  627. break;
  628. }
  629. return dwRes;
  630. }
  631. DWORD
  632. ShowRoutePref(
  633. HANDLE hFile
  634. )
  635. /*++
  636. Routine Description:
  637. Displays the protocol route preferences.
  638. Arguments:
  639. Return Value:
  640. NO_ERROR
  641. --*/
  642. {
  643. PPRIORITY_INFO ppi;
  644. DWORD dwBlkSize, dwCount, dwNumProto, i;
  645. DWORD dwErr;
  646. WCHAR wszBuff[80];
  647. dwErr = IpmontrGetInfoBlockFromGlobalInfo(IP_PROT_PRIORITY_INFO,
  648. (PBYTE *)&ppi,
  649. &dwBlkSize,
  650. &dwCount);
  651. if (dwErr isnot NO_ERROR)
  652. {
  653. DisplayError(g_hModule, dwErr);
  654. return ERROR_SUPPRESS_OUTPUT;
  655. }
  656. dwNumProto = ppi-> dwNumProtocols;
  657. if (dwNumProto &&
  658. (hFile == NULL))
  659. {
  660. DisplayMessage(g_hModule, MSG_RTR_PRIO_INFO_HDR);
  661. }
  662. for (i=0; i < dwNumProto; i++)
  663. {
  664. PTCHAR ptszProto, ptszToken;
  665. switch (ppi-> ppmProtocolMetric[ i ].dwProtocolId)
  666. {
  667. case PROTO_IP_LOCAL:
  668. {
  669. ptszProto = MakeString(g_hModule, STRING_LOCAL );
  670. ptszToken = TOKEN_VALUE_LOCAL;
  671. break;
  672. }
  673. case PROTO_IP_NETMGMT:
  674. {
  675. ptszProto = MakeString(g_hModule, STRING_NETMGMT );
  676. ptszToken = TOKEN_VALUE_NETMGMT;
  677. break;
  678. }
  679. case PROTO_IP_OSPF :
  680. {
  681. ptszProto = MakeString(g_hModule, STRING_OSPF );
  682. ptszToken = TOKEN_VALUE_OSPF;
  683. break;
  684. }
  685. case PROTO_IP_RIP :
  686. {
  687. ptszProto = MakeString(g_hModule, STRING_RIP );
  688. ptszToken = TOKEN_VALUE_RIP;
  689. break;
  690. }
  691. case PROTO_IP_NT_AUTOSTATIC :
  692. {
  693. ptszProto = MakeString(g_hModule, STRING_NT_AUTOSTATIC );
  694. ptszToken = TOKEN_VALUE_AUTOSTATIC;
  695. break;
  696. }
  697. case PROTO_IP_NT_STATIC :
  698. {
  699. ptszProto = MakeString(g_hModule, STRING_STATIC );
  700. ptszToken = TOKEN_VALUE_STATIC;
  701. break;
  702. }
  703. case PROTO_IP_NT_STATIC_NON_DOD :
  704. {
  705. ptszProto = MakeString(g_hModule, STRING_NONDOD );
  706. ptszToken = TOKEN_VALUE_NONDOD;
  707. break;
  708. }
  709. default:
  710. {
  711. ptszProto = NULL;
  712. ptszToken = NULL;
  713. break;
  714. }
  715. }
  716. if ( ptszProto == NULL || ptszToken == NULL )
  717. {
  718. swprintf( wszBuff,
  719. L"%d",
  720. ppi-> ppmProtocolMetric[ i ].dwProtocolId );
  721. }
  722. if(hFile != NULL)
  723. {
  724. DisplayMessageT( DMP_IP_SET_PROTOPREF,
  725. (ptszToken)? ptszToken : wszBuff,
  726. ppi->ppmProtocolMetric[i].dwMetric);
  727. }
  728. else
  729. {
  730. DisplayMessage(g_hModule,
  731. MSG_RTR_PRIO_INFO,
  732. (ptszProto)? ptszProto : wszBuff,
  733. ppi->ppmProtocolMetric[i].dwMetric);
  734. }
  735. if(ptszProto)
  736. {
  737. FreeString(ptszProto);
  738. }
  739. }
  740. FREE(ppi);
  741. return NO_ERROR;
  742. }
  743. DWORD
  744. ShowIpGlobal(
  745. HANDLE hFile
  746. )
  747. /*++
  748. Routine Description:
  749. Displays the logging level for IP
  750. Arguments:
  751. Return Value:
  752. NO_ERROR
  753. --*/
  754. {
  755. PGLOBAL_INFO pgi = NULL;
  756. DWORD dwBlkSize, dwCount;
  757. DWORD dwErr;
  758. PWCHAR ptszLoglevel, ptszLog;
  759. WCHAR wszBuff[80];
  760. dwErr = IpmontrGetInfoBlockFromGlobalInfo(IP_GLOBAL_INFO,
  761. (PBYTE *)&pgi,
  762. &dwBlkSize,
  763. &dwCount);
  764. if (dwErr isnot NO_ERROR)
  765. {
  766. DisplayError(g_hModule, dwErr);
  767. return dwErr;
  768. }
  769. switch (pgi->dwLoggingLevel)
  770. {
  771. case IPRTR_LOGGING_NONE:
  772. {
  773. ptszLoglevel = MakeString(g_hModule, STRING_LOGGING_NONE);
  774. ptszLog = TOKEN_VALUE_NONE;
  775. break;
  776. }
  777. case IPRTR_LOGGING_ERROR:
  778. {
  779. ptszLoglevel = MakeString(g_hModule, STRING_LOGGING_ERROR);
  780. ptszLog = TOKEN_VALUE_ERROR;
  781. break;
  782. }
  783. case IPRTR_LOGGING_WARN:
  784. {
  785. ptszLoglevel = MakeString(g_hModule, STRING_LOGGING_WARN);
  786. ptszLog = TOKEN_VALUE_WARN;
  787. break;
  788. }
  789. case IPRTR_LOGGING_INFO:
  790. {
  791. ptszLoglevel = MakeString(g_hModule, STRING_LOGGING_INFO);
  792. ptszLog = TOKEN_VALUE_INFO;
  793. break;
  794. }
  795. }
  796. if ( ptszLoglevel == NULL || ptszLog == NULL )
  797. {
  798. swprintf( wszBuff,
  799. L"%d",
  800. pgi->dwLoggingLevel);
  801. }
  802. if(hFile)
  803. {
  804. DisplayMessageT( DMP_IP_SET_LOGLEVEL,
  805. (ptszLog) ? ptszLog : wszBuff);
  806. }
  807. else
  808. {
  809. DisplayMessage(g_hModule, MSG_IP_GLOBAL_HDR);
  810. DisplayMessage(g_hModule, MSG_IP_LOG_LEVEL,
  811. (ptszLoglevel) ? ptszLoglevel : wszBuff);
  812. }
  813. if ( ptszLoglevel )
  814. {
  815. FreeString(ptszLoglevel);
  816. }
  817. FREE(pgi);
  818. return NO_ERROR;
  819. }
  820. PWCHAR
  821. GetIfTypeString(
  822. DWORD dwIfType
  823. )
  824. {
  825. PWCHAR pwszStr;
  826. static WCHAR buff[80];
  827. VALUE_STRING ppsList[] = {{ROUTER_IF_TYPE_CLIENT, STRING_CLIENT},
  828. {ROUTER_IF_TYPE_HOME_ROUTER, STRING_HOME_ROUTER},
  829. {ROUTER_IF_TYPE_FULL_ROUTER, STRING_FULL_ROUTER},
  830. {ROUTER_IF_TYPE_DEDICATED, STRING_DEDICATED},
  831. {ROUTER_IF_TYPE_INTERNAL, STRING_INTERNAL},
  832. {ROUTER_IF_TYPE_LOOPBACK, STRING_LOOPBACK},
  833. {ROUTER_IF_TYPE_TUNNEL1, STRING_TUNNEL},
  834. };
  835. DWORD dwNum = sizeof(ppsList)/sizeof(VALUE_STRING), i;
  836. DWORD dwMsgId = 0;
  837. for (i=0; i<dwNum; i++)
  838. {
  839. if (dwIfType == ppsList[i].dwValue)
  840. {
  841. dwMsgId = ppsList[i].dwStringId;
  842. break;
  843. }
  844. }
  845. if (dwMsgId)
  846. {
  847. pwszStr = MakeString( g_hModule, dwMsgId);
  848. if ( pwszStr )
  849. {
  850. wcscpy(buff, pwszStr);
  851. FreeString(pwszStr);
  852. }
  853. else
  854. {
  855. wsprintf(buff, L"%d", dwIfType);
  856. }
  857. }
  858. else
  859. {
  860. wsprintf(buff, L"%d", dwIfType);
  861. }
  862. return buff;
  863. }
  864. PWCHAR
  865. GetProtoTypeString(
  866. DWORD dwProtoType
  867. )
  868. {
  869. PWCHAR pwszStr;
  870. static WCHAR buff[80];
  871. VALUE_STRING ppsList[] = {{PROTO_TYPE_UCAST, STRING_UNICAST},
  872. {PROTO_TYPE_MCAST, STRING_MULTICAST},
  873. {PROTO_TYPE_MS1, STRING_GENERAL},
  874. {PROTO_TYPE_MS0, STRING_GENERAL},
  875. };
  876. DWORD dwNum = sizeof(ppsList)/sizeof(VALUE_STRING), i;
  877. DWORD dwMsgId = 0;
  878. for (i=0; i<dwNum; i++)
  879. {
  880. if (dwProtoType == ppsList[i].dwValue)
  881. {
  882. dwMsgId = ppsList[i].dwStringId;
  883. break;
  884. }
  885. }
  886. if (dwMsgId)
  887. {
  888. pwszStr = MakeString( g_hModule, dwMsgId);
  889. if ( pwszStr )
  890. {
  891. wcscpy(buff, pwszStr);
  892. FreeString(pwszStr);
  893. }
  894. else
  895. {
  896. wsprintf(buff, L"%d", dwProtoType);
  897. }
  898. }
  899. else
  900. {
  901. wsprintf(buff, L"%d", dwProtoType);
  902. }
  903. return buff;
  904. }
  905. PWCHAR
  906. GetProtoVendorString(
  907. DWORD dwProtoVendor
  908. )
  909. {
  910. PWCHAR pwszStr;
  911. static WCHAR buff[80];
  912. VALUE_TOKEN ppsList[] = {{PROTO_VENDOR_MS0, TOKEN_MICROSOFT0},
  913. {PROTO_VENDOR_MS1, TOKEN_MICROSOFT1},
  914. {PROTO_VENDOR_MS2, TOKEN_MICROSOFT2},
  915. };
  916. DWORD dwNum = sizeof(ppsList)/sizeof(VALUE_STRING), i;
  917. DWORD dwMsgId = 0;
  918. for (i=0; i<dwNum; i++)
  919. {
  920. if (dwProtoVendor == ppsList[i].dwValue)
  921. {
  922. return (PWCHAR)ppsList[i].pwszToken;
  923. break;
  924. }
  925. }
  926. wsprintf(buff, L"%d", dwProtoVendor);
  927. return buff;
  928. }
  929. PWCHAR
  930. GetProtoProtoString(
  931. DWORD dwProtoType,
  932. DWORD dwProtoVendor,
  933. DWORD dwProtoProto
  934. )
  935. {
  936. PWCHAR pwszStr;
  937. static WCHAR buff[80];
  938. VALUE_STRING ppsUList[] = {{PROTO_IP_RIP, STRING_RIP},
  939. {PROTO_IP_OSPF, STRING_OSPF},
  940. {PROTO_IP_BOOTP, STRING_BOOTP},
  941. {PROTO_IP_NAT, STRING_NAT},
  942. {PROTO_IP_LOCAL, STRING_LOCAL},
  943. {PROTO_IP_OTHER, STRING_OTHER},
  944. {PROTO_IP_NETMGMT,STRING_NETMGMT},
  945. {PROTO_IP_NT_AUTOSTATIC,STRING_NT_AUTOSTATIC},
  946. {PROTO_IP_NT_STATIC, STRING_STATIC},
  947. {PROTO_IP_NT_STATIC_NON_DOD,STRING_NONDOD},
  948. #ifdef MS_IP_BGP
  949. {PROTO_IP_BGP, STRING_BGP},
  950. #endif
  951. };
  952. VALUE_STRING ppsMList[] = {{PROTO_IP_IGMP, STRING_IGMP},
  953. };
  954. VALUE_STRING ppsGList[] = {{IP_IN_FILTER_INFO, STRING_IN_FILTER},
  955. {IP_OUT_FILTER_INFO, STRING_OUT_FILTER},
  956. {IP_GLOBAL_INFO, STRING_GLOBAL_INFO},
  957. {IP_INTERFACE_STATUS_INFO, STRING_IF_STATUS},
  958. {IP_ROUTE_INFO, STRING_ROUTE_INFO},
  959. {IP_PROT_PRIORITY_INFO, STRING_PROT_PRIORITY},
  960. {IP_ROUTER_DISC_INFO, STRING_RTRDISC},
  961. {IP_DEMAND_DIAL_FILTER_INFO, STRING_DD_FILTER},
  962. {IP_MCAST_HEARBEAT_INFO, STRING_MC_HEARTBEAT},
  963. {IP_MCAST_BOUNDARY_INFO, STRING_MC_BOUNDARY},
  964. {IP_IPINIP_CFG_INFO, STRING_IPIP},
  965. {IP_IFFILTER_INFO, STRING_IF_FILTER},
  966. {IP_MCAST_LIMIT_INFO, STRING_MC_LIMIT},
  967. };
  968. VALUE_STRING pps2List[] = {{PROTO_IP_DNS_PROXY, STRING_DNS_PROXY},
  969. {PROTO_IP_DHCP_ALLOCATOR,STRING_DHCP_ALLOCATOR},
  970. {PROTO_IP_NAT, STRING_NAT},
  971. {PROTO_IP_DIFFSERV, STRING_DIFFSERV},
  972. {PROTO_IP_VRRP, STRING_VRRP},
  973. };
  974. VALUE_STRING *pVS;
  975. DWORD dwNum, i;
  976. DWORD dwMsgId = 0;
  977. switch (dwProtoType) {
  978. case PROTO_TYPE_UCAST:
  979. pVS = ppsUList;
  980. dwNum = sizeof(ppsUList)/sizeof(VALUE_STRING);
  981. break;
  982. case PROTO_TYPE_MCAST:
  983. pVS = ppsMList;
  984. dwNum = sizeof(ppsMList)/sizeof(VALUE_STRING);
  985. break;
  986. case PROTO_TYPE_MS1:
  987. pVS = ppsGList;
  988. dwNum = sizeof(ppsGList)/sizeof(VALUE_STRING);
  989. break;
  990. case PROTO_TYPE_MS0:
  991. pVS = pps2List;
  992. dwNum = sizeof(pps2List)/sizeof(VALUE_STRING);
  993. break;
  994. default:
  995. dwNum = 0;
  996. }
  997. for (i=0; i<dwNum; i++)
  998. {
  999. if (dwProtoProto == PROTO_FROM_PROTO_ID(pVS[i].dwValue))
  1000. {
  1001. dwMsgId = pVS[i].dwStringId;
  1002. break;
  1003. }
  1004. }
  1005. if (dwMsgId)
  1006. {
  1007. pwszStr = MakeString( g_hModule, dwMsgId);
  1008. if ( pwszStr )
  1009. {
  1010. wcscpy(buff, pwszStr);
  1011. FreeString(pwszStr);
  1012. }
  1013. else
  1014. {
  1015. wsprintf(buff, L"%d", dwProtoProto);
  1016. }
  1017. }
  1018. else
  1019. {
  1020. wsprintf(buff, L"%d", dwProtoProto);
  1021. }
  1022. return buff;
  1023. }
  1024. DWORD
  1025. ShowIpIfProtocols(
  1026. IN LPCWSTR pwszIfName
  1027. )
  1028. {
  1029. DWORD dwNumProto, dwErr, i;
  1030. PBYTE pby;
  1031. DWORD dwBlkSize, dwCount;
  1032. RTR_INFO_BLOCK_HEADER *pInfoHdr;
  1033. DWORD dwProtoType, dwProtoVendor, dwProtoProto;
  1034. dwErr = ValidateInterfaceInfo(pwszIfName, &pInfoHdr, NULL, NULL);
  1035. if (dwErr isnot NO_ERROR)
  1036. {
  1037. return dwErr;
  1038. }
  1039. // Do this check just to keep the prefix checker happy
  1040. if (!pInfoHdr)
  1041. {
  1042. return ERROR_NOT_ENOUGH_MEMORY;
  1043. }
  1044. DisplayMessage(g_hModule, MSG_RTR_INTERFACE_PROTOCOL_HDR);
  1045. DisplayMessage(g_hModule, MSG_IP_PROTOCOL_HDR);
  1046. // Walk pInfo and output a line for each protocol found
  1047. for (i=0; i<pInfoHdr->TocEntriesCount; i++)
  1048. {
  1049. // Extract type, vendorid, and protocolid
  1050. dwProtoType = TYPE_FROM_PROTO_ID( pInfoHdr->TocEntry[i].InfoType);
  1051. dwProtoVendor = VENDOR_FROM_PROTO_ID(pInfoHdr->TocEntry[i].InfoType);
  1052. dwProtoProto = PROTO_FROM_PROTO_ID( pInfoHdr->TocEntry[i].InfoType);
  1053. DisplayMessageT(L"%1!-11s! %2!-13s! %3!s!\n",
  1054. GetProtoTypeString( dwProtoType),
  1055. GetProtoVendorString(dwProtoVendor),
  1056. GetProtoProtoString( dwProtoType, dwProtoVendor, dwProtoProto));
  1057. }
  1058. if (i is 0)
  1059. {
  1060. DisplayMessage(g_hModule, MSG_IP_NO_PROTOCOL);
  1061. }
  1062. return NO_ERROR;
  1063. }
  1064. DWORD
  1065. ShowIpProtocol(
  1066. VOID
  1067. )
  1068. /*++
  1069. Routine Description:
  1070. Displays all the protocols under IP RTR MGR.
  1071. Arguments:
  1072. Return Value:
  1073. NO_ERROR
  1074. --*/
  1075. {
  1076. DWORD dwNumProto, dwErr, i;
  1077. PBYTE pby;
  1078. DWORD dwBlkSize, dwCount;
  1079. RTR_INFO_BLOCK_HEADER *pInfoHdr;
  1080. DWORD dwProtoType, dwProtoVendor, dwProtoProto;
  1081. dwErr = ValidateGlobalInfo(&pInfoHdr);
  1082. if (dwErr isnot NO_ERROR)
  1083. {
  1084. return dwErr;
  1085. }
  1086. DisplayMessage(g_hModule, MSG_IP_PROTOCOL_HDR);
  1087. // Walk pInfo and output a line for each protocol found
  1088. for (i=0; i<pInfoHdr->TocEntriesCount; i++)
  1089. {
  1090. // Extract type, vendorid, and protocolid
  1091. dwProtoType = TYPE_FROM_PROTO_ID( pInfoHdr->TocEntry[i].InfoType);
  1092. dwProtoVendor = VENDOR_FROM_PROTO_ID(pInfoHdr->TocEntry[i].InfoType);
  1093. dwProtoProto = PROTO_FROM_PROTO_ID( pInfoHdr->TocEntry[i].InfoType);
  1094. DisplayMessageT(L"%1!-11s! %2!-13s! %3!s!\n",
  1095. GetProtoTypeString( dwProtoType),
  1096. GetProtoVendorString(dwProtoVendor),
  1097. GetProtoProtoString( dwProtoType, dwProtoVendor, dwProtoProto));
  1098. }
  1099. if (i is 0)
  1100. {
  1101. DisplayMessage(g_hModule, MSG_IP_NO_PROTOCOL);
  1102. }
  1103. return NO_ERROR;
  1104. }
  1105. DWORD
  1106. ListIpInterface(
  1107. VOID
  1108. )
  1109. /*++
  1110. Routine Description:
  1111. Lists all interfaces under ip
  1112. Arguments:
  1113. Return Value:
  1114. NO_ERROR
  1115. --*/
  1116. {
  1117. DWORD dwErr;
  1118. DWORD dwCount, dwTotal, i, dwNumParsed = 0;
  1119. PMPR_INTERFACE_0 pmi0;
  1120. WCHAR wszIfDesc[MAX_INTERFACE_NAME_LEN + 1];
  1121. HANDLE hIfTransport = (HANDLE) NULL,
  1122. hInterface;
  1123. DisplayMessage(g_hModule, MSG_IP_INTERFACE_HDR);
  1124. //
  1125. // No interface name specified. List all interfaces under IP
  1126. //
  1127. dwErr = IpmontrInterfaceEnum((PBYTE *) &pmi0, &dwCount, &dwTotal);
  1128. if (dwErr isnot NO_ERROR)
  1129. {
  1130. DisplayError(g_hModule, dwErr);
  1131. return dwErr;
  1132. }
  1133. for ( i = 0; i < dwCount; i++)
  1134. {
  1135. // Make sure IP is enabled on this interface
  1136. dwErr = MprConfigInterfaceGetHandle(g_hMprConfig,
  1137. pmi0[i].wszInterfaceName,
  1138. &hInterface);
  1139. dwErr = MprConfigInterfaceTransportGetHandle(g_hMprConfig,
  1140. hInterface,
  1141. PID_IP,
  1142. &hIfTransport);
  1143. if (dwErr isnot NO_ERROR)
  1144. continue;
  1145. dwErr = GetInterfaceDescription(pmi0[i].wszInterfaceName,
  1146. wszIfDesc,
  1147. &dwNumParsed);
  1148. if (!dwNumParsed)
  1149. {
  1150. wcscpy(wszIfDesc, pmi0[i].wszInterfaceName);
  1151. }
  1152. DisplayMessage(g_hModule, MSG_IP_INTERFACE_INFO, wszIfDesc);
  1153. }
  1154. if (dwCount is 0)
  1155. {
  1156. DisplayMessage(g_hModule, MSG_IP_NO_INTERFACE);
  1157. }
  1158. return NO_ERROR;
  1159. }
  1160. DWORD
  1161. ShowIpInIpInfo(
  1162. IN DWORD dwFormat,
  1163. IN LPCWSTR pwszIfName,
  1164. IN LPCWSTR pwszQuoted
  1165. )
  1166. {
  1167. PIPINIP_CONFIG_INFO pIpIpInfo;
  1168. WCHAR rgwcLocalAddr[ADDR_LENGTH + 1];
  1169. WCHAR rgwcRemAddr[ADDR_LENGTH + 1];
  1170. DWORD dwBlkSize, dwCount, dwIfType, dwErr;
  1171. // IP-in-IP info
  1172. dwErr = IpmontrGetInfoBlockFromInterfaceInfo(pwszIfName,
  1173. IP_IPINIP_CFG_INFO,
  1174. (PBYTE *) &pIpIpInfo,
  1175. &dwBlkSize,
  1176. &dwCount,
  1177. &dwIfType);
  1178. if(dwErr is NO_ERROR)
  1179. {
  1180. ASSERT(dwIfType is ROUTER_IF_TYPE_TUNNEL1);
  1181. IP_TO_WSTR(rgwcLocalAddr, ((PBYTE)&(pIpIpInfo->dwLocalAddress)));
  1182. IP_TO_WSTR(rgwcRemAddr, ((PBYTE)&(pIpIpInfo->dwRemoteAddress)));
  1183. switch (dwFormat)
  1184. {
  1185. case FORMAT_VERBOSE:
  1186. DisplayMessage(g_hModule,
  1187. MSG_RTR_INTERFACE_IPIP_INFO,
  1188. rgwcLocalAddr,
  1189. rgwcRemAddr,
  1190. MAKELONG(MAKEWORD(pIpIpInfo->byTtl, 0x00), 0x0000));
  1191. break;
  1192. // IP-in-IP tunnels need to be added in the interface context in
  1193. // ifmon.dll, not here. But this is how it works for now!!! So
  1194. // we'll just dump the command that works.
  1195. case FORMAT_DUMP:
  1196. DisplayMessageT(DMP_IP_ADD_IPIPTUNNEL,
  1197. pwszQuoted,
  1198. rgwcLocalAddr,
  1199. rgwcRemAddr,
  1200. MAKELONG(MAKEWORD(pIpIpInfo->byTtl,0x00), 0x0000));
  1201. break;
  1202. default:
  1203. break;
  1204. }
  1205. }
  1206. if (pIpIpInfo)
  1207. {
  1208. FREE_BUFFER(pIpIpInfo);
  1209. }
  1210. return dwErr;
  1211. }
  1212. DWORD
  1213. ShowIpInterface(
  1214. IN DWORD dwFormat,
  1215. IN LPCWSTR pwszIfName,
  1216. IN OUT PDWORD pdwNumRows
  1217. )
  1218. /*++
  1219. Routine Description:
  1220. Show the interface info for the interface
  1221. The interface info consists of
  1222. AdminStatus
  1223. Router Discovery Info
  1224. Protocols on the interface
  1225. Other information like filters and routes are should using different
  1226. commands
  1227. Arguments:
  1228. pwszIfName - Interface name
  1229. Return Value:
  1230. NO_ERROR
  1231. --*/
  1232. {
  1233. DWORD dwErr;
  1234. WCHAR wszIfDesc[MAX_INTERFACE_NAME_LEN + 1];
  1235. PVALUE_STRING pps;
  1236. DWORD dwNumProto, dwBlkSize, dwCount, dwNumParsed;
  1237. DWORD dwIfType , i;
  1238. PBYTE pby;
  1239. PWCHAR pwszStatus, pwszQuoted;
  1240. PWCHAR pwszTokenStatus, pwszIfType;
  1241. PINTERFACE_STATUS_INFO pifStat;
  1242. //
  1243. // Interface status info
  1244. //
  1245. dwErr = IpmontrGetInfoBlockFromInterfaceInfo(pwszIfName,
  1246. IP_INTERFACE_STATUS_INFO,
  1247. (PBYTE *) &pifStat,
  1248. &dwBlkSize,
  1249. &dwCount,
  1250. &dwIfType);
  1251. if (dwErr != NO_ERROR)
  1252. {
  1253. // DisplayMessage(g_hModule, EMSG_IP_NO_STATUS_INFO);
  1254. return dwErr;
  1255. }
  1256. if (pifStat->dwAdminStatus is IF_ADMIN_STATUS_UP)
  1257. {
  1258. pwszStatus = MakeString(g_hModule, STRING_ENABLED);
  1259. pwszTokenStatus = TOKEN_VALUE_ENABLE;
  1260. }
  1261. else
  1262. {
  1263. pwszStatus = MakeString(g_hModule, STRING_DISABLED);
  1264. pwszTokenStatus = TOKEN_VALUE_DISABLE;
  1265. }
  1266. FREE_BUFFER(pifStat);
  1267. // Get description
  1268. dwErr = GetInterfaceDescription(pwszIfName,
  1269. wszIfDesc,
  1270. &dwNumParsed);
  1271. if (!dwNumParsed)
  1272. {
  1273. wcscpy(wszIfDesc, pwszIfName);
  1274. }
  1275. if(dwFormat is FORMAT_DUMP)
  1276. {
  1277. pwszQuoted = MakeQuotedString(wszIfDesc);
  1278. }
  1279. else
  1280. {
  1281. pwszQuoted = NULL;
  1282. }
  1283. pwszIfType = GetIfTypeString(dwIfType);
  1284. // Display generic interface info
  1285. switch (dwFormat) {
  1286. case FORMAT_VERBOSE:
  1287. DisplayMessage(g_hModule,
  1288. MSG_RTR_INTERFACE_HDR,
  1289. wszIfDesc);
  1290. DisplayMessage(g_hModule,
  1291. MSG_IP_IF_STATUS,
  1292. pwszStatus);
  1293. ShowIpIfProtocols(pwszIfName);
  1294. break;
  1295. case FORMAT_TABLE:
  1296. if (*pdwNumRows is 0)
  1297. {
  1298. DisplayMessage(g_hModule, MSG_IP_IF_HEADER);
  1299. }
  1300. DisplayMessage(g_hModule, MSG_IP_IF_ENTRY, pwszStatus, pwszIfType,
  1301. wszIfDesc);
  1302. break;
  1303. case FORMAT_DUMP:
  1304. DisplayMessageT(DMP_IP_ADD_IF, pwszQuoted, pwszTokenStatus);
  1305. break;
  1306. }
  1307. (*pdwNumRows)++;
  1308. ShowIpInIpInfo(dwFormat, pwszIfName, pwszQuoted);
  1309. FreeQuotedString(pwszQuoted);
  1310. FreeString(pwszStatus);
  1311. return NO_ERROR;
  1312. }
  1313. DWORD
  1314. CreateDumpFile(
  1315. IN LPCWSTR pwszName,
  1316. OUT PHANDLE phFile
  1317. )
  1318. {
  1319. HANDLE hFile;
  1320. *phFile = NULL;
  1321. hFile = CreateFileW(pwszName,
  1322. GENERIC_WRITE,
  1323. FILE_SHARE_READ | FILE_SHARE_DELETE,
  1324. NULL,
  1325. OPEN_ALWAYS,
  1326. FILE_ATTRIBUTE_NORMAL,
  1327. NULL);
  1328. if(hFile == INVALID_HANDLE_VALUE)
  1329. return GetLastError();
  1330. *phFile = hFile;
  1331. return NO_ERROR;
  1332. }
  1333. VOID
  1334. DumpIpInformation(
  1335. HANDLE hFile
  1336. )
  1337. /*++
  1338. Routine Description:
  1339. Dumps all the IP Router manager information to the given file
  1340. Arguments:
  1341. hFile Handle of file
  1342. Return Value:
  1343. None
  1344. --*/
  1345. {
  1346. DWORD dwErr, dwCount, dwTotal;
  1347. DWORD dwNumParsed, i;
  1348. PMPR_INTERFACE_0 pmi0;
  1349. WCHAR wszIfDesc[MAX_INTERFACE_NAME_LEN + 1];
  1350. DWORD dwNumRows = 0;
  1351. // Display dump header
  1352. DisplayMessage(g_hModule, DMP_IP_HEADER_COMMENTS);
  1353. DisplayMessageT(DMP_IP_HEADER);
  1354. //
  1355. // First dump the global information
  1356. //
  1357. ShowIpGlobal(hFile);
  1358. ShowRoutePref(hFile);
  1359. ShowScopes(hFile);
  1360. //
  1361. // Dump the per interface info
  1362. //
  1363. dwErr = IpmontrInterfaceEnum((PBYTE *) &pmi0,
  1364. &dwCount,
  1365. &dwTotal);
  1366. if(dwErr != NO_ERROR)
  1367. {
  1368. DisplayError(g_hModule,
  1369. dwErr);
  1370. return;
  1371. }
  1372. for(i = 0; i < dwCount; i++)
  1373. {
  1374. ShowIpInterface(FORMAT_DUMP,
  1375. pmi0[i].wszInterfaceName, &dwNumRows);
  1376. ShowIpIfFilter(hFile,
  1377. FORMAT_DUMP,
  1378. pmi0[i].wszInterfaceName, &dwNumRows);
  1379. ShowIpPersistentRoute(hFile,
  1380. pmi0[i].wszInterfaceName, &dwNumRows);
  1381. ShowBoundaryInfoForInterface(hFile,
  1382. pmi0[i].wszInterfaceName,
  1383. &dwNumRows);
  1384. }
  1385. // Display dump footer
  1386. DisplayMessageT(DMP_POPD);
  1387. DisplayMessage(g_hModule, DMP_IP_FOOTER_COMMENTS);
  1388. }
  1389. DWORD
  1390. UpdateAutoStaticRoutes(
  1391. IN LPCWSTR pwszIfName
  1392. )
  1393. {
  1394. return NO_ERROR;
  1395. }