Leaked source code of windows server 2003
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
13 KiB

  1. /****************************************************************************\
  2. OOBECUST.C / OPK Wizard (OPKWIZ.EXE)
  3. Microsoft Confidential
  4. Copyright (c) Microsoft Corporation 1998
  5. All rights reserved
  6. Source file for the OPK Wizard that contains the external and internal
  7. functions used by the "OOBE customization" wizard page.
  8. 03/99 - Added by PVSWAMI
  9. 06/99 - Jason Cohen (JCOHEN)
  10. Updated this source file for the OPK Wizard as part of the
  11. Millennium rewrite.
  12. 09/2000 - Stephen Lodwick (STELO)
  13. Ported OPK Wizard to Whistler
  14. \****************************************************************************/
  15. //
  16. // Include File(s):
  17. //
  18. #include "pch.h"
  19. #include "wizard.h"
  20. #include "resource.h"
  21. //
  22. // Internal Defined Value(s):
  23. //
  24. #define INI_SEC_BRANDING _T("Branding")
  25. #define INI_KEY_OEMNAME _T("OEMName")
  26. #define INI_KEY_OEMLOGO _T("OEMLogo")
  27. #define DIR_IMAGES DIR_OEM_OOBE _T("\\IMAGES")
  28. #define FILE_WATERMARK _T("watermrk.gif")
  29. #define FILE_LOGO _T("oemlogo.gif")
  30. //
  31. // Internal Function Prototype(s):
  32. //
  33. static BOOL OnInit(HWND, HWND, LPARAM);
  34. static void OnCommand(HWND, INT, HWND, UINT);
  35. static BOOL OnNext(HWND hwnd);
  36. static void EnableControls(HWND hwnd, UINT uId, BOOL fEnable);
  37. //
  38. // External Function(s):
  39. //
  40. LRESULT CALLBACK OobeCustDlgProc(HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam)
  41. {
  42. switch (uMsg)
  43. {
  44. HANDLE_MSG(hwnd, WM_INITDIALOG, OnInit);
  45. HANDLE_MSG(hwnd, WM_COMMAND, OnCommand);
  46. case WM_NOTIFY:
  47. switch ( ((NMHDR FAR *) lParam)->code )
  48. {
  49. case PSN_KILLACTIVE:
  50. case PSN_RESET:
  51. case PSN_WIZBACK:
  52. case PSN_WIZFINISH:
  53. break;
  54. case PSN_WIZNEXT:
  55. if ( !OnNext(hwnd) )
  56. WIZ_FAIL(hwnd);
  57. break;
  58. case PSN_QUERYCANCEL:
  59. WIZ_CANCEL(hwnd);
  60. break;
  61. case PSN_HELP:
  62. WIZ_HELP();
  63. break;
  64. case PSN_SETACTIVE:
  65. g_App.dwCurrentHelp = IDH_OEMCUST;
  66. WIZ_BUTTONS(hwnd, PSWIZB_BACK | PSWIZB_NEXT);
  67. // Press next if the user is in auto mode
  68. //
  69. WIZ_NEXTONAUTO(hwnd, PSBTN_NEXT);
  70. break;
  71. default:
  72. return FALSE;
  73. }
  74. break;
  75. default:
  76. return FALSE;
  77. }
  78. return TRUE;
  79. }
  80. //
  81. // Internal Function(s):
  82. //
  83. static BOOL OnInit(HWND hwnd, HWND hwndFocus, LPARAM lParam)
  84. {
  85. TCHAR szLocal[MAX_PATH] = NULLSTR,
  86. szSource[MAX_PATH] = NULLSTR,
  87. szPathBuffer[MAX_PATH] = NULLSTR;
  88. LPTSTR lpFilePart = NULL;
  89. // Populate the OEM name.
  90. //
  91. szSource[0] = NULLCHR;
  92. if ( !GET_FLAG(OPK_MAINTMODE) )
  93. GetPrivateProfileString(INI_SEC_GENERAL, INI_KEY_MANUFACT, NULLSTR, szSource, AS(szSource), g_App.szOemInfoIniFile);
  94. GetPrivateProfileString(INI_SEC_BRANDING, INI_KEY_OEMNAME, szSource, szSource, AS(szSource), GET_FLAG(OPK_BATCHMODE) ? g_App.szOpkWizIniFile : g_App.szOobeInfoIniFile);
  95. SendDlgItemMessage(hwnd, IDC_MANF_NAME, EM_LIMITTEXT, AS(szSource) - 1, 0);
  96. SetDlgItemText(hwnd, IDC_MANF_NAME, szSource);
  97. //
  98. // Take care of the OOBE watermark file.
  99. //
  100. // Should always look for the source file name.
  101. //
  102. szSource[0] = NULLCHR;
  103. GetPrivateProfileString(INI_SEC_OEMCUST, INI_KEY_LOGO1, NULLSTR, szSource, AS(szSource), g_App.szOpkWizIniFile);
  104. // Now figure out the local file name.
  105. //
  106. lstrcpyn(szLocal, g_App.szTempDir,AS(szLocal));
  107. AddPathN(szLocal, DIR_IMAGES,AS(szLocal));
  108. if ( GET_FLAG(OPK_BATCHMODE) )
  109. CreatePath(szLocal);
  110. AddPathN(szLocal, FILE_WATERMARK,AS(szLocal));
  111. // Limit the size of the edit box.
  112. //
  113. SendDlgItemMessage(hwnd, IDC_BACKLOGO, EM_LIMITTEXT, MAX_PATH - 1, 0);
  114. // Check for batch mode and copy the file if we need to.
  115. //
  116. if ( GET_FLAG(OPK_BATCHMODE) && szSource[0] && FileExists(szSource) )
  117. CopyResetFileErr(GetParent(hwnd), szSource, szLocal);
  118. // Check for the file to decide if we enable the
  119. // option or not.
  120. //
  121. if ( szSource[0] && FileExists(szLocal) )
  122. {
  123. CheckDlgButton(hwnd, IDC_CHECK_WATERMARK, TRUE);
  124. EnableControls(hwnd, IDC_CHECK_WATERMARK, TRUE);
  125. SetDlgItemText(hwnd, IDC_BACKLOGO, szSource);
  126. }
  127. else
  128. EnableControls(hwnd, IDC_CHECK_WATERMARK, FALSE);
  129. //
  130. // Take are of the OOBE logo file.
  131. //
  132. // Should always look for the source file name.
  133. //
  134. szSource[0] = NULLCHR;
  135. szLocal[0] = NULLCHR;
  136. if ( ( GetPrivateProfileString(INI_SEC_OEMCUST, INI_KEY_LOGO2, NULLSTR, szSource, AS(szSource), g_App.szOpkWizIniFile) ) &&
  137. ( szSource[0] ) &&
  138. ( GetFullPathName(szSource, AS(szPathBuffer), szPathBuffer, &lpFilePart) ) &&
  139. ( lpFilePart )
  140. )
  141. {
  142. lstrcpyn(szLocal, g_App.szTempDir,AS(szLocal));
  143. AddPathN(szLocal, DIR_IMAGES,AS(szLocal));
  144. AddPathN(szLocal, lpFilePart,AS(szLocal));
  145. }
  146. // Now figure out the local file name.
  147. //
  148. // Limit the size of the edit box.
  149. //
  150. SendDlgItemMessage(hwnd, IDC_TOPLOGO, EM_LIMITTEXT, MAX_PATH - 1, 0);
  151. // Check for batch mode and copy the file if we need to.
  152. //
  153. if ( GET_FLAG(OPK_BATCHMODE) && szLocal[0] && FileExists(szSource) )
  154. CopyResetFileErr(GetParent(hwnd), szSource, szLocal);
  155. // Check for the file to decide if we enable the
  156. // option or not.
  157. //
  158. if ( szSource[0] && FileExists(szLocal) )
  159. {
  160. CheckDlgButton(hwnd, IDC_CHECK_LOGO, TRUE);
  161. EnableControls(hwnd, IDC_CHECK_LOGO, TRUE);
  162. SetDlgItemText(hwnd, IDC_TOPLOGO, szSource);
  163. }
  164. else
  165. EnableControls(hwnd, IDC_CHECK_LOGO, FALSE);
  166. // Always return false to WM_INITDIALOG.
  167. //
  168. return FALSE;
  169. }
  170. static void OnCommand(HWND hwnd, INT id, HWND hwndCtl, UINT codeNotify)
  171. {
  172. TCHAR szFileName[MAX_PATH],
  173. szOldFile[MAX_PATH];
  174. switch ( id )
  175. {
  176. case IDC_CHECK_WATERMARK:
  177. case IDC_CHECK_LOGO:
  178. EnableControls(hwnd, id, IsDlgButtonChecked(hwnd, id) == BST_CHECKED);
  179. break;
  180. case IDC_BROWSE1:
  181. case IDC_BROWSE2:
  182. szFileName[0] = NULLCHR;
  183. GetDlgItemText(hwnd, (id == IDC_BROWSE1) ? IDC_BACKLOGO : IDC_TOPLOGO, szFileName, STRSIZE(szFileName));
  184. lstrcpyn(szOldFile, szFileName, AS(szOldFile));
  185. if ( BrowseForFile(GetParent(hwnd), IDS_BROWSE, IDS_GIFFILES, IDS_GIF, szFileName, STRSIZE(szFileName), g_App.szBrowseFolder, 0) )
  186. {
  187. LPTSTR lpFilePart = NULL;
  188. TCHAR szTargetFile[MAX_PATH],
  189. szFilePartBuffer[MAX_PATH] = NULLSTR;
  190. // Save the last browse directory.
  191. //
  192. if ( GetFullPathName(szFileName, AS(g_App.szBrowseFolder), g_App.szBrowseFolder, &lpFilePart) && g_App.szBrowseFolder[0] && lpFilePart )
  193. {
  194. lstrcpyn(szFilePartBuffer, lpFilePart, AS(szFilePartBuffer));
  195. *lpFilePart = NULLCHR;
  196. }
  197. // Copy file.
  198. //
  199. lstrcpyn(szTargetFile, g_App.szTempDir,AS(szTargetFile));
  200. AddPathN(szTargetFile, DIR_IMAGES,AS(szTargetFile));
  201. CreatePath(szTargetFile);
  202. AddPathN(szTargetFile, (id == IDC_BROWSE1) ? FILE_WATERMARK : szFilePartBuffer, AS(szTargetFile));
  203. if ( CopyResetFileErr(GetParent(hwnd), szFileName, szTargetFile) )
  204. {
  205. TCHAR szPathBuffer[MAX_PATH] = NULLSTR;
  206. SetDlgItemText(hwnd, (id == IDC_BROWSE1) ? IDC_BACKLOGO : IDC_TOPLOGO, szFileName);
  207. // Copy was successful, we should remove the old file
  208. //
  209. if ( ( szOldFile[0] ) &&
  210. ( GetFullPathName(szOldFile, AS(szPathBuffer), szPathBuffer, &lpFilePart) ) &&
  211. ( lpFilePart ) &&
  212. ( lstrcmpi(szFilePartBuffer, lpFilePart) != 0)
  213. )
  214. {
  215. // Get the local path to the old file
  216. //
  217. lstrcpyn(szOldFile, g_App.szTempDir, AS(szOldFile));
  218. AddPathN(szOldFile, DIR_IMAGES, AS(szOldFile));
  219. AddPathN(szOldFile, lpFilePart, AS(szOldFile));
  220. DeleteFile(szOldFile);
  221. }
  222. }
  223. }
  224. break;
  225. }
  226. }
  227. static BOOL OnNext(HWND hwnd)
  228. {
  229. TCHAR szWatermark[MAX_PATH],
  230. szLogo[MAX_PATH] = NULLSTR,
  231. szSourceFile[MAX_PATH] = NULLSTR,
  232. szPathBuffer[MAX_PATH] = NULLSTR;
  233. BOOL bSaveWatermark;
  234. LPTSTR lpFilePart = NULL;
  235. // Prepare the watermark target file name.
  236. //
  237. lstrcpyn(szWatermark, g_App.szTempDir,AS(szWatermark));
  238. AddPathN(szWatermark, DIR_IMAGES,AS(szWatermark));
  239. AddPathN(szWatermark, FILE_WATERMARK,AS(szWatermark));
  240. if ( bSaveWatermark = (IsDlgButtonChecked(hwnd, IDC_CHECK_WATERMARK) == BST_CHECKED) )
  241. {
  242. // Validation consists of verifying the files they have entered were actually copied.
  243. //
  244. szSourceFile[0] = NULLCHR;
  245. GetDlgItemText(hwnd, IDC_BACKLOGO, szSourceFile, AS(szSourceFile));
  246. if ( !szSourceFile[0] || !FileExists(szWatermark) )
  247. {
  248. MsgBox(GetParent(hwnd), szSourceFile[0] ? IDS_NOFILE : IDS_BLANKFILE, IDS_APPNAME, MB_ERRORBOX, szSourceFile);
  249. SetFocus(GetDlgItem(hwnd, IDC_BROWSE1));
  250. return FALSE;
  251. }
  252. // Save the source path in the batch file.
  253. //
  254. WritePrivateProfileString(INI_SEC_OEMCUST, INI_KEY_LOGO1, szSourceFile, g_App.szOpkWizIniFile);
  255. }
  256. szSourceFile[0] = NULLCHR;
  257. szPathBuffer[0] = NULLCHR;
  258. // Determine what the new filename is
  259. //
  260. if ( ( GetDlgItemText(hwnd, IDC_TOPLOGO, szSourceFile, AS(szSourceFile)) ) &&
  261. ( szSourceFile[0] ) &&
  262. ( GetFullPathName(szSourceFile, AS(szPathBuffer), szPathBuffer, &lpFilePart) ) &&
  263. ( lpFilePart )
  264. )
  265. {
  266. lstrcpyn(szLogo, g_App.szTempDir, AS(szLogo));
  267. AddPathN(szLogo, DIR_IMAGES, AS(szLogo));
  268. AddPathN(szLogo, lpFilePart, AS(szLogo));
  269. }
  270. if ( IsDlgButtonChecked(hwnd, IDC_CHECK_LOGO) == BST_CHECKED )
  271. {
  272. // Validation consists of verifying the files they have entered were actually copied.
  273. //
  274. if ( !szLogo[0] || !FileExists(szLogo) )
  275. {
  276. MsgBox(GetParent(hwnd), szSourceFile[0] ? IDS_NOFILE : IDS_BLANKFILE, IDS_APPNAME, MB_ERRORBOX, szSourceFile);
  277. SetFocus(GetDlgItem(hwnd, IDC_BROWSE2));
  278. return FALSE;
  279. }
  280. // Save the source path in the batch file.
  281. //
  282. WritePrivateProfileString(INI_SEC_OEMCUST, INI_KEY_LOGO2, szSourceFile, g_App.szOpkWizIniFile);
  283. WritePrivateProfileString(INI_SEC_BRANDING, INI_KEY_OEMLOGO, lpFilePart, g_App.szOobeInfoIniFile);
  284. }
  285. else
  286. {
  287. // Remove the logo and source path.
  288. //
  289. if ( szLogo[0] )
  290. {
  291. DeleteFile(szLogo);
  292. }
  293. WritePrivateProfileString(INI_SEC_OEMCUST, INI_KEY_LOGO2, NULL, g_App.szOpkWizIniFile);
  294. WritePrivateProfileString(INI_SEC_BRANDING, INI_KEY_OEMLOGO, NULL, g_App.szOobeInfoIniFile);
  295. SetDlgItemText(hwnd, IDC_TOPLOGO, NULLSTR);
  296. }
  297. // Now we want to remove the watermark file if need be (we don't do
  298. // this above because only want to remove files after we have
  299. // made it passed all the cases where we can return.
  300. //
  301. if ( !bSaveWatermark )
  302. {
  303. // Remove the logo and source path.
  304. //
  305. DeleteFile(szWatermark);
  306. WritePrivateProfileString(INI_SEC_OEMCUST, INI_KEY_LOGO1, NULL, g_App.szOpkWizIniFile);
  307. SetDlgItemText(hwnd, IDC_BACKLOGO, NULLSTR);
  308. }
  309. // Save the branding name.
  310. //
  311. szSourceFile[0] = NULLCHR;
  312. GetDlgItemText(hwnd, IDC_MANF_NAME, szSourceFile, AS(szSourceFile));
  313. WritePrivateProfileString(INI_SEC_BRANDING, INI_KEY_OEMNAME, szSourceFile, g_App.szOobeInfoIniFile);
  314. WritePrivateProfileString(INI_SEC_BRANDING, INI_KEY_OEMNAME, szSourceFile, g_App.szOpkWizIniFile);
  315. return TRUE;
  316. }
  317. static void EnableControls(HWND hwnd, UINT uId, BOOL fEnable)
  318. {
  319. switch ( uId )
  320. {
  321. case IDC_CHECK_WATERMARK:
  322. EnableWindow(GetDlgItem(hwnd, IDC_CAPTION_WATERMARK), fEnable);
  323. EnableWindow(GetDlgItem(hwnd, IDC_BACKLOGO), fEnable);
  324. EnableWindow(GetDlgItem(hwnd, IDC_BROWSE1), fEnable);
  325. break;
  326. case IDC_CHECK_LOGO:
  327. EnableWindow(GetDlgItem(hwnd, IDC_LOGO_CAPTION), fEnable);
  328. EnableWindow(GetDlgItem(hwnd, IDC_TOPLOGO), fEnable);
  329. EnableWindow(GetDlgItem(hwnd, IDC_BROWSE2), fEnable);
  330. break;
  331. }
  332. }