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.

410 lines
9.3 KiB

  1. //+-------------------------------------------------------------------------
  2. //
  3. // Microsoft Windows
  4. //
  5. // Copyright (C) Microsoft Corporation, 1997 - 1999
  6. //
  7. // File: simdata.cpp
  8. //
  9. //--------------------------------------------------------------------------
  10. /////////////////////////////////////////////////////////////////////
  11. // SimData.cpp - Implementation of Security Identity Mapping
  12. //
  13. // HISTORY
  14. // 23-Jun-97 t-danm Creation.
  15. /////////////////////////////////////////////////////////////////////
  16. #include "stdafx.h"
  17. #include "common.h"
  18. #include "dsutil.h"
  19. #include "helpids.h"
  20. #ifdef _DEBUG
  21. #define new DEBUG_NEW
  22. #undef THIS_FILE
  23. static char THIS_FILE[] = __FILE__;
  24. #endif
  25. /////////////////////////////////////////////////////////////////////
  26. TCHAR szSchemaSim[] = _T("altSecurityIdentities"); // per Murlis 6/16/98
  27. /////////////////////////////////////////////////////////////////////
  28. void CSimEntry::SetString(CString& rstrData)
  29. {
  30. m_strData = rstrData;
  31. LPCTSTR pszT = (LPCTSTR)rstrData;
  32. if (_wcsnicmp(szX509, pszT, wcslen (szX509)) == 0)
  33. {
  34. m_eDialogTarget = eX509;
  35. }
  36. else if (_wcsnicmp(szKerberos, pszT, wcslen (szKerberos)) == 0)
  37. {
  38. m_eDialogTarget = eKerberos;
  39. }
  40. else
  41. {
  42. m_eDialogTarget = eOther;
  43. TRACE1("INFO: Unknown string type \"%s\".\n", pszT);
  44. }
  45. } // CSimEntry::SetString()
  46. /////////////////////////////////////////////////////////////////////
  47. /////////////////////////////////////////////////////////////////////
  48. CSimData::CSimData()
  49. : m_hwndParent (0)
  50. {
  51. m_fIsDirty = FALSE;
  52. m_pSimEntryList = NULL;
  53. m_paPage1 = new CSimX509PropPage;
  54. m_paPage1->m_pData = this;
  55. m_paPage2 = new CSimKerberosPropPage;
  56. m_paPage2->m_pData = this;
  57. #ifdef _DEBUG
  58. m_paPage3 = new CSimOtherPropPage;
  59. m_paPage3->m_pData = this;
  60. #endif
  61. }
  62. CSimData::~CSimData()
  63. {
  64. delete m_paPage1;
  65. delete m_paPage2;
  66. #ifdef _DEBUG
  67. delete m_paPage3;
  68. #endif
  69. FlushSimList();
  70. }
  71. /////////////////////////////////////////////////////////////////////
  72. void CSimData::FlushSimList()
  73. {
  74. // Delete the list
  75. CSimEntry * pSimEntry = m_pSimEntryList;
  76. while (pSimEntry != NULL)
  77. {
  78. CSimEntry * pSimEntryT = pSimEntry;
  79. pSimEntry = pSimEntry->m_pNext;
  80. delete pSimEntryT;
  81. }
  82. m_pSimEntryList = NULL;
  83. }
  84. /////////////////////////////////////////////////////////////////////
  85. BOOL CSimData::FInit(CString strUserPath, CString strADsIPath, HWND hwndParent)
  86. {
  87. m_hwndParent = hwndParent;
  88. m_strUserPath = strUserPath;
  89. m_strADsIPath = strADsIPath;
  90. if (!FQuerySimData())
  91. {
  92. ReportErrorEx (hwndParent,IDS_SIM_ERR_CANNOT_READ_SIM_DATA,S_OK,
  93. MB_OK | MB_ICONERROR, NULL, 0);
  94. return FALSE;
  95. }
  96. return TRUE;
  97. }
  98. /////////////////////////////////////////////////////////////////////
  99. // Return FALSE if some data could not be written.
  100. // Otherwise return TRUE.
  101. BOOL CSimData::FOnApply(HWND hwndParent)
  102. {
  103. if (!m_fIsDirty)
  104. return TRUE;
  105. HRESULT hr = FUpdateSimData ();
  106. if ( FAILED (hr) )
  107. {
  108. ReportErrorEx (hwndParent, IDS_SIM_ERR_CANNOT_WRITE_SIM_DATA, hr,
  109. MB_OK | MB_ICONERROR, NULL, 0);
  110. return FALSE;
  111. }
  112. // Re-load the data
  113. (void)FQuerySimData();
  114. // We have successfully written all the data
  115. m_fIsDirty = FALSE; // Clear the dirty bit
  116. return TRUE;
  117. }
  118. /////////////////////////////////////////////////////////////////////
  119. void CSimData::GetUserAccountName(OUT CString * pstrName)
  120. {
  121. ASSERT(pstrName != NULL);
  122. *pstrName = m_strUserPath;
  123. }
  124. /////////////////////////////////////////////////////////////////////
  125. // Query the database for the list of security identities.
  126. //
  127. // Return FALSE if an error occured.
  128. //
  129. BOOL CSimData::FQuerySimData()
  130. {
  131. CWaitCursor wait;
  132. FlushSimList();
  133. HRESULT hr;
  134. IADs * pADs = NULL;
  135. hr = DSAdminOpenObject(m_strADsIPath,
  136. IID_IADs,
  137. OUT (void **)&pADs,
  138. TRUE /*bServer*/);
  139. if (FAILED(hr))
  140. {
  141. ASSERT(pADs == NULL);
  142. return FALSE;
  143. }
  144. ASSERT(pADs != NULL);
  145. CComVariant vtData;
  146. // Read data from database
  147. hr = pADs->Get(szSchemaSim, OUT &vtData);
  148. if (FAILED(hr))
  149. {
  150. if (hr == E_ADS_PROPERTY_NOT_FOUND)
  151. hr = S_OK;
  152. }
  153. else
  154. {
  155. CStringList stringlist;
  156. hr = HrVariantToStringList(IN vtData, OUT stringlist);
  157. if (FAILED(hr))
  158. goto End;
  159. POSITION pos = stringlist.GetHeadPosition();
  160. while (pos != NULL)
  161. {
  162. (void)PAddSimEntry(stringlist.GetNext(INOUT pos));
  163. } // while
  164. } // if...else
  165. End:
  166. if (pADs != NULL)
  167. pADs->Release();
  168. return SUCCEEDED(hr);
  169. } // FQuerySimData()
  170. /////////////////////////////////////////////////////////////////////
  171. // Update the list of security identities to the database.
  172. //
  173. // Return FALSE if an error occured.
  174. //
  175. HRESULT CSimData::FUpdateSimData()
  176. {
  177. CWaitCursor wait;
  178. HRESULT hr;
  179. IADs * pADs = NULL;
  180. hr = DSAdminOpenObject(m_strADsIPath,
  181. IID_IADs,
  182. OUT (void **)&pADs,
  183. TRUE /*bServer*/);
  184. if (FAILED(hr))
  185. {
  186. ASSERT(pADs == NULL);
  187. return FALSE;
  188. }
  189. ASSERT(pADs != NULL);
  190. // Build the string list
  191. CStringList stringlist;
  192. for (const CSimEntry * pSimEntry = m_pSimEntryList;
  193. pSimEntry != NULL;
  194. pSimEntry = pSimEntry->m_pNext)
  195. {
  196. switch (pSimEntry->m_eDialogTarget)
  197. {
  198. case eNone:
  199. ASSERT(FALSE && "Invalid Data");
  200. case eNil:
  201. case eOther:
  202. continue;
  203. } // switch
  204. stringlist.AddHead(pSimEntry->PchGetString());
  205. } // for
  206. CComVariant vtData;
  207. hr = HrStringListToVariant(OUT vtData, IN stringlist);
  208. if (FAILED(hr))
  209. goto End;
  210. // Put data back to database
  211. hr = pADs->Put(szSchemaSim, IN vtData);
  212. if (FAILED(hr))
  213. goto End;
  214. // Persist the data (write to database)
  215. hr = pADs->SetInfo();
  216. End:
  217. if (pADs != NULL)
  218. pADs->Release();
  219. return hr;
  220. } // FUpdateSimData()
  221. /////////////////////////////////////////////////////////////////////
  222. // Allocate a new CSimEntry node to the linked list
  223. //
  224. CSimEntry * CSimData::PAddSimEntry(CString& rstrData)
  225. {
  226. CSimEntry * pSimEntry = new CSimEntry;
  227. if (pSimEntry)
  228. {
  229. pSimEntry->SetString(rstrData);
  230. pSimEntry->m_pNext = m_pSimEntryList;
  231. }
  232. m_pSimEntryList = pSimEntry;
  233. return pSimEntry;
  234. }
  235. /////////////////////////////////////////////////////////////////////
  236. void CSimData::DeleteSimEntry(CSimEntry * pSimEntryDelete)
  237. {
  238. CSimEntry * p = m_pSimEntryList;
  239. CSimEntry * pPrev = NULL;
  240. while (p != NULL)
  241. {
  242. if (p == pSimEntryDelete)
  243. {
  244. if (pPrev == NULL)
  245. {
  246. ASSERT(pSimEntryDelete == m_pSimEntryList);
  247. m_pSimEntryList = p->m_pNext;
  248. }
  249. else
  250. {
  251. pPrev->m_pNext = p->m_pNext;
  252. }
  253. delete pSimEntryDelete;
  254. return;
  255. }
  256. pPrev = p;
  257. p = p->m_pNext;
  258. }
  259. TRACE0("ERROR: CSimData::DeleteSimEntry() - Node not found.\n");
  260. } // DeleteSimEntry()
  261. /////////////////////////////////////////////////////////////////////
  262. void CSimData::AddEntriesToListview(HWND hwndListview, DIALOG_TARGET_ENUM eDialogTarget)
  263. {
  264. CSimEntry * pSimEntry = m_pSimEntryList;
  265. while (pSimEntry != NULL)
  266. {
  267. if (pSimEntry->m_eDialogTarget == eDialogTarget)
  268. {
  269. ListView_AddString(hwndListview, pSimEntry->PchGetString());
  270. }
  271. pSimEntry = pSimEntry->m_pNext;
  272. }
  273. } // AddEntriesToListview()
  274. /////////////////////////////////////////////////////////////////////
  275. void CSimData::DoModal()
  276. {
  277. CWnd parentWnd;
  278. VERIFY (parentWnd.Attach (m_hwndParent));
  279. CSimPropertySheet ps(IDS_SIM_SECURITY_IDENTITY_MAPPING, &parentWnd);
  280. ps.AddPage(m_paPage1);
  281. ps.AddPage(m_paPage2);
  282. #ifdef _DEBUG
  283. ps.AddPage(m_paPage3);
  284. #endif
  285. (void)ps.DoModal();
  286. parentWnd.Detach ();
  287. }
  288. /////////////////////////////////////////////////////////////////////////////
  289. // CSimPropertySheet
  290. IMPLEMENT_DYNAMIC(CSimPropertySheet, CPropertySheet)
  291. CSimPropertySheet::CSimPropertySheet(UINT nIDCaption, CWnd* pParentWnd, UINT iSelectPage)
  292. :CPropertySheet(nIDCaption, pParentWnd, iSelectPage)
  293. {
  294. }
  295. CSimPropertySheet::CSimPropertySheet(LPCTSTR pszCaption, CWnd* pParentWnd, UINT iSelectPage)
  296. :CPropertySheet(pszCaption, pParentWnd, iSelectPage)
  297. {
  298. }
  299. CSimPropertySheet::~CSimPropertySheet()
  300. {
  301. }
  302. BEGIN_MESSAGE_MAP(CSimPropertySheet, CPropertySheet)
  303. //{{AFX_MSG_MAP(CSimPropertySheet)
  304. // NOTE - the ClassWizard will add and remove mapping macros here.
  305. //}}AFX_MSG_MAP
  306. ON_MESSAGE(WM_HELP, OnHelp)
  307. END_MESSAGE_MAP()
  308. /////////////////////////////////////////////////////////////////////////////
  309. // CSimPropertySheet message handlers
  310. BOOL CSimPropertySheet::OnInitDialog()
  311. {
  312. BOOL bResult = CPropertySheet::OnInitDialog();
  313. DWORD dwStyle = GetWindowLong (m_hWnd, GWL_STYLE);
  314. dwStyle |= DS_CONTEXTHELP;
  315. SetWindowLong (m_hWnd, GWL_STYLE, dwStyle);
  316. DWORD dwExStyle = GetWindowLong (m_hWnd, GWL_EXSTYLE);
  317. dwExStyle |= WS_EX_CONTEXTHELP;
  318. SetWindowLong (m_hWnd, GWL_EXSTYLE, dwExStyle);
  319. return bResult;
  320. }
  321. BOOL CSimPropertySheet::OnHelp(WPARAM /*wParam*/, LPARAM lParam)
  322. {
  323. const LPHELPINFO pHelpInfo = (LPHELPINFO)lParam;
  324. if (pHelpInfo && pHelpInfo->iContextType == HELPINFO_WINDOW)
  325. {
  326. DoContextHelp ((HWND) pHelpInfo->hItemHandle);
  327. }
  328. return TRUE;
  329. }
  330. void CSimPropertySheet::DoContextHelp (HWND hWndControl)
  331. {
  332. const int IDC_COMM_APPLYNOW = 12321;
  333. const int IDH_COMM_APPLYNOW = 28447;
  334. const DWORD aHelpIDs_PropSheet[]=
  335. {
  336. IDC_COMM_APPLYNOW, IDH_COMM_APPLYNOW,
  337. 0, 0
  338. };
  339. if ( !::WinHelp (
  340. hWndControl,
  341. IDC_COMM_APPLYNOW == ::GetDlgCtrlID (hWndControl) ?
  342. L"windows.hlp" : DSADMIN_CONTEXT_HELP_FILE,
  343. HELP_WM_HELP,
  344. (DWORD_PTR) aHelpIDs_PropSheet) )
  345. {
  346. TRACE1 ("WinHelp () failed: 0x%x\n", GetLastError ());
  347. }
  348. }