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.

242 lines
7.0 KiB

  1. /****************************************************************************\
  2. LICENSE.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 "system builder EULA" wizard page.
  8. 5/99 - Jason Cohen (JCOHEN)
  9. Updated this old source file for the OPK Wizard as part of the
  10. Millennium rewrite.
  11. 09/2000 - Stephen Lodwick (STELO)
  12. Ported OPK Wizard to Whistler
  13. \****************************************************************************/
  14. //
  15. // Include File(s):
  16. //
  17. #include "pch.h"
  18. #ifndef NO_LICENSE
  19. #include "wizard.h"
  20. #include "resource.h"
  21. //
  22. // Internal Defined Value(s):
  23. //
  24. #define INI_KEY_CRC _T("wizlicns.txt")
  25. #define INI_KEY_SKIPEULA _T("skipeula")
  26. #define FILE_EULA INI_KEY_CRC
  27. #define STR_ULONG _T("%lu")
  28. //
  29. // Internal Function Prototype(s):
  30. //
  31. static BOOL OnInit(HWND, HWND, LPARAM);
  32. LONG CALLBACK EulaEditWndProc(HWND, UINT, WPARAM, LPARAM);
  33. //
  34. // External Function(s):
  35. //
  36. BOOL CALLBACK LicenseDlgProc(HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam)
  37. {
  38. switch (uMsg)
  39. {
  40. HANDLE_MSG(hwnd, WM_INITDIALOG, OnInit);
  41. case WM_COMMAND:
  42. switch ( LOWORD(wParam) )
  43. {
  44. case IDC_ACCEPT:
  45. case IDC_DONT:
  46. WIZ_BUTTONS(hwnd, ( IsDlgButtonChecked(hwnd, IDC_ACCEPT) == BST_CHECKED ) ? (PSWIZB_BACK | PSWIZB_NEXT) : PSWIZB_BACK);
  47. break;
  48. case IDC_EULA_TEXT:
  49. if ( HIWORD(wParam) == EN_SETFOCUS )
  50. SendMessage((HWND) lParam, EM_SETSEL, (WPARAM) 0, 0L);
  51. break;
  52. }
  53. return FALSE;
  54. case WM_NOTIFY:
  55. switch ( ((NMHDR FAR *) lParam)->code )
  56. {
  57. case PSN_KILLACTIVE:
  58. case PSN_RESET:
  59. case PSN_WIZBACK:
  60. case PSN_WIZFINISH:
  61. break;
  62. case PSN_WIZNEXT:
  63. //
  64. // ISSUE-2002/0s/28-stelo- Do we need to create an OPKWIZ.TAG file? I don't know
  65. // what it is used for. Also wouldn't it be nice if they
  66. // only got asked once for the EULA and then never again.
  67. //
  68. break;
  69. case PSN_QUERYCANCEL:
  70. WIZ_CANCEL(hwnd);
  71. break;
  72. case PSN_HELP:
  73. WIZ_HELP();
  74. break;
  75. case PSN_SETACTIVE:
  76. g_App.dwCurrentHelp = IDH_LICENSE;
  77. // Don't show the EULA for OEMs.
  78. //
  79. if ( GET_FLAG(OPK_OEM) )
  80. WIZ_SKIP(hwnd);
  81. else
  82. ShowWindow(GetParent(hwnd), SW_SHOW);
  83. // Setup the wizard buttons.
  84. //
  85. WIZ_BUTTONS(hwnd, ( IsDlgButtonChecked(hwnd, IDC_ACCEPT) == BST_CHECKED ) ? (PSWIZB_BACK | PSWIZB_NEXT) : PSWIZB_BACK);
  86. break;
  87. }
  88. break;
  89. default:
  90. return FALSE;
  91. }
  92. return TRUE;
  93. }
  94. //
  95. // Internal Function(s):
  96. //
  97. static BOOL OnInit(HWND hwnd, HWND hwndFocus, LPARAM lParam)
  98. {
  99. TCHAR szFullPath[MAX_PATH],
  100. szInfCRC[32],
  101. szCrc[32];
  102. LPTSTR lpEulaText = NULL;
  103. HANDLE hfEula = INVALID_HANDLE_VALUE;
  104. DWORD dwSize = 0xFFFFFFFF,
  105. dwBytes;
  106. HRESULT hrPrintf;
  107. // Now load the EULA if this isn't the OEM version.
  108. //
  109. if ( !GET_FLAG(OPK_OEM) )
  110. {
  111. // Get the CRC value from the inf file.
  112. //
  113. GetPrivateProfileString(INI_SEC_OPTIONS, INI_KEY_CRC, NULLSTR, szInfCRC, sizeof(szInfCRC), g_App.szOpkInputInfFile);
  114. // Get the CRC value from the eula file.
  115. ///
  116. lstrcpyn(szFullPath, g_App.szWizardDir,AS(szFullPath));
  117. AddPathN(szFullPath, FILE_EULA,AS(szFullPath));
  118. hrPrintf=StringCchPrintf(szCrc, AS(szCrc), STR_ULONG, CrcFile(szFullPath));
  119. // Check the CRC and read in the file.
  120. //
  121. if ( ( lstrcmpi(szInfCRC, szCrc) == 0 ) &&
  122. ( (hfEula = CreateFile(szFullPath, GENERIC_READ, 0, NULL, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, NULL)) != INVALID_HANDLE_VALUE ) &&
  123. ( (dwSize = GetFileSize(hfEula, NULL)) < 0xFFFF ) &&
  124. ( (lpEulaText = (LPTSTR) MALLOC(dwSize + 1)) != NULL ) &&
  125. ( ReadFile(hfEula, (LPVOID) lpEulaText, dwSize, &dwBytes, NULL) ) &&
  126. ( dwSize == dwBytes ) )
  127. {
  128. // Null terminate the string and put it in the edit box.
  129. //
  130. *(lpEulaText + dwSize) = NULLCHR;
  131. SetWindowText(GetDlgItem(hwnd, IDC_EULA_TEXT), lpEulaText);
  132. SendDlgItemMessage(hwnd, IDC_EULA_TEXT, EM_SETSEL, (WPARAM) 0, 0L);
  133. }
  134. else
  135. {
  136. // We need to error out, but first see if it was a memory error, or a problem with the EULA.
  137. //
  138. if ( ( dwSize < 0xFFFF ) && ( lpEulaText == NULL ) )
  139. MsgBox(GetParent(hwnd), IDS_OUTOFMEM, IDS_APPNAME, MB_ERRORBOX);
  140. else
  141. {
  142. LPTSTR lpBuffer = AllocateString(NULL, IDS_NDA_CORRUPT2);
  143. MsgBox(GetParent(hwnd), IDS_NDA_CORRUPT1, IDS_APPNAME, MB_ERRORBOX, lpBuffer ? lpBuffer : NULLSTR);
  144. FREE(lpBuffer);
  145. }
  146. // Exit out of the wizard.
  147. //
  148. WIZ_EXIT(hwnd);
  149. }
  150. // Close the file handle if we opened it.
  151. //
  152. if ( hfEula != INVALID_HANDLE_VALUE )
  153. CloseHandle(hfEula);
  154. // Make sure that we free the eula text buffer.
  155. //
  156. FREE(lpEulaText);
  157. // Replace the wndproc for the edit box.
  158. //
  159. EulaEditWndProc(GetDlgItem(hwnd, IDC_EULA_TEXT), WM_SUBWNDPROC, 0, 0L);
  160. }
  161. // Always return false to WM_INITDIALOG.
  162. //
  163. return FALSE;
  164. }
  165. LONG CALLBACK EulaEditWndProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam)
  166. {
  167. static FARPROC lpfnOldProc = NULL;
  168. switch ( msg )
  169. {
  170. case EM_SETSEL:
  171. wParam = lParam = 0;
  172. PostMessage(hwnd, EM_SCROLLCARET, 0, 0L);
  173. break;
  174. case WM_CHAR:
  175. if ( wParam == KEY_ESC )
  176. WIZ_PRESS(GetParent(hwnd), PSBTN_CANCEL);
  177. break;
  178. case WM_SUBWNDPROC:
  179. lpfnOldProc = (FARPROC) GetWindowLong(hwnd, GWL_WNDPROC);
  180. SetWindowLongPtr(hwnd, GWPL_WNDPROC, (LONG) EulaEditWndProc);
  181. return 1;
  182. }
  183. if ( lpfnOldProc )
  184. return (LONG) CallWindowProc((WNDPROC) lpfnOldProc, hwnd, msg, wParam, lParam);
  185. else
  186. return 0;
  187. }
  188. #endif // NO_LICENSE