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.

237 lines
8.6 KiB

  1. //----------------------------------------------------------------------------
  2. //
  3. // Microsoft Windows
  4. // Copyright (C) Microsoft Corporation, 2001.
  5. //
  6. // File: snapin.cpp
  7. //
  8. // Contents: WiF Policy Snapin
  9. //
  10. //
  11. // History: TaroonM
  12. // 10/30/01
  13. //
  14. //----------------------------------------------------------------------------
  15. #include "stdafx.h"
  16. #include "initguid.h"
  17. #include "about.h"
  18. CComModule _Module;
  19. BEGIN_OBJECT_MAP(ObjectMap)
  20. OBJECT_ENTRY(CLSID_Snapin, CComponentDataPrimaryImpl)
  21. OBJECT_ENTRY(CLSID_Extension, CComponentDataExtensionImpl)
  22. OBJECT_ENTRY(CLSID_About, CSnapinAboutImpl)
  23. END_OBJECT_MAP()
  24. #ifdef _DEBUG
  25. #define new DEBUG_NEW
  26. #undef THIS_FILE
  27. static char THIS_FILE[] = __FILE__;
  28. #endif
  29. class CSnapinApp : public CWinApp
  30. {
  31. public:
  32. virtual BOOL InitInstance();
  33. virtual int ExitInstance();
  34. };
  35. CSnapinApp theApp;
  36. BOOL CSnapinApp::InitInstance()
  37. {
  38. _Module.Init(ObjectMap, m_hInstance);
  39. // set the application name:
  40. //First free the string allocated by MFC at CWinApp startup.
  41. //The string is allocated before InitInstance is called.
  42. free((void*)m_pszAppName);
  43. //Change the name of the application file.
  44. //The CWinApp destructor will free the memory.
  45. CString strName;
  46. strName.LoadString (IDS_NAME);
  47. m_pszAppName=_tcsdup(strName);
  48. SHFusionInitializeFromModuleID (m_hInstance, 2);
  49. return CWinApp::InitInstance();
  50. }
  51. int CSnapinApp::ExitInstance()
  52. {
  53. SHFusionUninitialize();
  54. _Module.Term();
  55. DEBUG_VERIFY_INSTANCE_COUNT(CComponentImpl);
  56. DEBUG_VERIFY_INSTANCE_COUNT(CComponentDataImpl);
  57. return CWinApp::ExitInstance();
  58. }
  59. /////////////////////////////////////////////////////////////////////////////
  60. // Used to determine whether the DLL can be unloaded by OLE
  61. STDAPI DllCanUnloadNow(void)
  62. {
  63. AFX_MANAGE_STATE(AfxGetStaticModuleState());
  64. return (AfxDllCanUnloadNow()==S_OK && _Module.GetLockCount()==0) ? S_OK : S_FALSE;
  65. }
  66. /////////////////////////////////////////////////////////////////////////////
  67. // Returns a class factory to create an object of the requested type
  68. STDAPI DllGetClassObject(REFCLSID rclsid, REFIID riid, LPVOID* ppv)
  69. {
  70. return _Module.GetClassObject(rclsid, riid, ppv);
  71. }
  72. /////////////////////////////////////////////////////////////////////////////
  73. // DllRegisterServer - Adds entries to the system registry
  74. STDAPI DllRegisterServer(void)
  75. {
  76. AFX_MANAGE_STATE(AfxGetStaticModuleState());
  77. // registers object, typelib and all interfaces in typelib
  78. HRESULT hr = _Module.RegisterServer(FALSE);
  79. if (hr == S_OK)
  80. {
  81. // the dll was registered ok, so proceed to do the MMC registry fixups
  82. // open the registry at \\My Computer\HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\MMC\SnapIns
  83. HKEY hkMMC = NULL;
  84. LONG lErr = RegOpenKeyEx (HKEY_LOCAL_MACHINE, _T("SOFTWARE\\Microsoft\\MMC\\SnapIns"), 0, KEY_ALL_ACCESS, &hkMMC);
  85. if (lErr == ERROR_SUCCESS)
  86. {
  87. // create our subkey(s)
  88. HKEY hkSub = NULL;
  89. lErr = RegCreateKey (hkMMC, cszSnapin, &hkSub);
  90. if (lErr == ERROR_SUCCESS)
  91. {
  92. // A couple of simple values into our subkey
  93. // NameString = IP Security Management
  94. // NodeType = {36703241-D16C-11d0-9CE4-0080C7221EBD}
  95. // Version = 1.0
  96. // TODO: resource hardcoded strings
  97. CString strName;
  98. strName.LoadString (IDS_NAME);
  99. lErr = RegSetValueEx (hkSub, _T("NameString"), 0, REG_SZ, (CONST BYTE *)(LPCTSTR)strName, strName.GetLength() * sizeof (TCHAR));
  100. ASSERT (lErr == ERROR_SUCCESS);
  101. TCHAR szModuleFileName[MAX_PATH * 2 + 1];
  102. ZeroMemory(szModuleFileName, sizeof(szModuleFileName));
  103. DWORD dwRet = ::GetModuleFileName(_Module.GetModuleInstance(),
  104. szModuleFileName,
  105. DimensionOf(szModuleFileName));
  106. if (0 != dwRet)
  107. {
  108. CString strNameIndirect;
  109. strNameIndirect.Format(_T("@%s,-%u"),
  110. szModuleFileName,
  111. IDS_NAME);
  112. lErr = RegSetValueEx(hkSub,
  113. _T("NameStringIndirect"),
  114. 0,
  115. REG_SZ,
  116. (CONST BYTE *)(LPCTSTR)strNameIndirect,
  117. strNameIndirect.GetLength() * sizeof (TCHAR));
  118. ASSERT (lErr == ERROR_SUCCESS);
  119. }
  120. //lErr = RegSetValueEx (hkSub, _T("NodeType"), 0, REG_SZ, (CONST BYTE *)&(_T("{36703241-D16C-11d0-9CE4-0080C7221EBD}")), wcslen (_T("{36703241-D16C-11d0-9CE4-0080C7221EBD}")) * sizeof (TCHAR));
  121. //ASSERT (lErr == ERROR_SUCCESS);
  122. lErr = RegSetValueEx (hkSub, _T("NodeType"), 0, REG_SZ, (CONST BYTE *)&(_T("{36D6CA65-3367-49de-BB22-1907554F6075}")), wcslen (_T("{36D6CA65-3367-49de-BB22-1907554F6075}")) * sizeof (TCHAR));
  123. ASSERT (lErr == ERROR_SUCCESS);
  124. lErr = RegSetValueEx (hkSub, _T("Provider"), 0, REG_SZ, (CONST BYTE *)&(_T("Microsoft Corporation")), wcslen (_T("Microsoft Corporation")) * sizeof (TCHAR));
  125. ASSERT (lErr == ERROR_SUCCESS);
  126. lErr = RegSetValueEx (hkSub, _T("Version"), 0, REG_SZ, (CONST BYTE *)&(_T("1.0")), wcslen (_T("1.01")) * sizeof (TCHAR));
  127. ASSERT (lErr == ERROR_SUCCESS);
  128. lErr = RegSetValueEx (hkSub, _T("About"), 0, REG_SZ, (CONST BYTE *)&(_T("{DD468E14-AF42-4d63-8908-EDAC4A9E67AE}")), wcslen (_T("{DD468E14-AF42-4d63-8908-EDAC4A9E67AE}")) * sizeof (TCHAR));
  129. ASSERT (lErr == ERROR_SUCCESS);
  130. HKEY hkType = NULL;
  131. /*
  132. // create "StandAlone" subkey
  133. lErr = RegCreateKey (hkSub, _T("StandAlone"), &hkType);
  134. ASSERT (lErr == ERROR_SUCCESS);
  135. RegCloseKey( hkType );
  136. */
  137. hkType = NULL;
  138. // create "Extension" subkey
  139. lErr = RegCreateKey (hkSub, _T("Extension"), &hkType);
  140. ASSERT (lErr == ERROR_SUCCESS);
  141. RegCloseKey( hkType );
  142. hkType = NULL;
  143. // close the hkSub
  144. RegCloseKey (hkSub);
  145. }
  146. // close the hkMMC
  147. RegCloseKey (hkMMC);
  148. hkMMC = NULL;
  149. // Register as an extension to the Security Template snap-in
  150. {
  151. #define WIRELESS_POLMGR_NAME _T("Wireless Network Policy Manager Extension")
  152. // lstruuidNodetypeSceTemplate is defined as L"{668A49ED-8888-11d1-AB72-00C04FB6C6FA}" in sceattch.h
  153. // open the registry at \\My Computer\HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\MMC\Node Types
  154. lErr = RegOpenKeyEx( HKEY_LOCAL_MACHINE, _T("SOFTWARE\\Microsoft\\MMC\\NodeTypes"), 0, KEY_ALL_ACCESS, &hkMMC );
  155. ASSERT( lErr == ERROR_SUCCESS );
  156. if (lErr == ERROR_SUCCESS)
  157. {
  158. HKEY hkNameSpace = NULL;
  159. // Now open the Security Template entry: {668A49ED-8888-11d1-AB72-00C04FB6C6FA}\Extensions\NameSpace
  160. lErr = RegCreateKey( hkMMC, _T("{668A49ED-8888-11d1-AB72-00C04FB6C6FA}\\Extensions\\NameSpace"), &hkNameSpace );
  161. ASSERT( lErr == ERROR_SUCCESS );
  162. if (lErr == ERROR_SUCCESS)
  163. {
  164. // We want to add ourselves as an extension to the Security editor
  165. //lErr = RegSetValueEx( hkNameSpace, _T("{DEA8AFA0-CC85-11d0-9CE2-0080C7221EBD}" ),
  166. lErr = RegSetValueEx( hkNameSpace, cszSnapin,
  167. 0, REG_SZ, (CONST BYTE *)&(WIRELESS_POLMGR_NAME),
  168. wcslen( WIRELESS_POLMGR_NAME ) * sizeof (TCHAR));
  169. ASSERT( lErr == ERROR_SUCCESS );
  170. }
  171. }
  172. }
  173. } else
  174. {
  175. ASSERT (0);
  176. hr = E_UNEXPECTED;
  177. }
  178. }
  179. return hr;
  180. }
  181. /////////////////////////////////////////////////////////////////////////////
  182. // DllUnregisterServer - Removes entries from the system registry
  183. STDAPI DllUnregisterServer(void)
  184. {
  185. _Module.UnregisterServer();
  186. return S_OK;
  187. }