#include #include #include #include #include #include #include #include extern "C" { #include #include } #include "appdefs.h" #include "util.h" #include "msg.h" #include #include #include #include #include #include #include #include #define REGSTR_PATH_SYSTEMSETUPKEY L"System\\Setup" #define REGSTR_VALUE_CMDLINE L"CmdLine" ICOMLicenseAgent* m_pLicenseAgent = NULL; TCHAR File[MAX_PATH]; TCHAR msg[1024]; BOOL SaveProxySettings(LPTSTR ProxySave); BOOL RestoreProxySettings(LPTSTR ProxySave); BOOL ApplyProxySettings(LPTSTR ProxyPath); void RemoveCmdline(HINSTANCE hInstance); void OpenLogFile(); void WriteToLog(LPWSTR pszFormatString, ...); void CloseLogFile(); void RemoveActivationShortCut() { HINF hinf; hinf = SetupOpenInfFile(L"syssetup.inf",NULL,INF_STYLE_WIN4,NULL); if(hinf != INVALID_HANDLE_VALUE) { if (SetupInstallFromInfSection(NULL, hinf, L"DEL_OOBE_ACTIVATE", SPINST_PROFILEITEMS , //SPINST_ALL, NULL, NULL, 0, NULL, NULL, NULL, NULL) != 0) { // Success WriteToLog(L"Remove Activation shortcut succeeded\r\n"); } else { // Failure WriteToLog(L"Remove Activation shortcut failed. GetLastError=%1!ld!\r\n",GetLastError()); } SetupCloseInfFile(hinf); } } HRESULT InitActivation() { HRESULT hr = E_FAIL; //CoCreate LicenseAgent hr = CoCreateInstance(CLSID_COMLicenseAgent, NULL, CLSCTX_INPROC_SERVER, IID_ICOMLicenseAgent, (LPVOID*)&m_pLicenseAgent); if (SUCCEEDED(hr)) { DWORD Status; m_pLicenseAgent->Initialize( WINDOWSBPC, LA_MODE_ONLINE_CH, NULL, &Status ); if ( Status != ERROR_SUCCESS ) { TRACE1( L"m_pLicenseAgent->Initialize() failed. Error = %d", Status ); WriteToLog(L"m_pLicenseAgent->Initialize() failed. Error = %1!ld!\r\n", Status); hr = HRESULT_FROM_WIN32(Status); } } else { TRACE1( L"CoCreate m_pLicenseAgent failed. Error = 0x%08lx", hr ); WriteToLog( L"CoCreate m_pLicenseAgent failed. Error = 0x%08lx", hr ); } return hr; } HRESULT ActivationHandShake() { DWORD Status; DWORD dwType; DWORD Data; DWORD cbData = sizeof(Data); MYASSERT( m_pLicenseAgent ); if ( !m_pLicenseAgent ) { TRACE( L"License Agent is inaccessible" ); WriteToLog(L"License Agent is inaccessible\r\n" ); return ERR_ACT_INTERNAL_WINDOWS_ERR; } Status = m_pLicenseAgent->SetIsoLanguage( GetSystemDefaultLCID() ); if ( Status != ERROR_SUCCESS ) { TRACE1( L"m_pLicenseAgent->SetIsoLanguage() failed. Error = %d", Status ); WriteToLog( L"m_pLicenseAgent->SetIsoLanguage() failed. Error = %1!ld!\r\n", Status ); return Status; } Status = m_pLicenseAgent->AsyncProcessHandshakeRequest( FALSE ); return Status; } HRESULT ActivationLicenseRequest(BOOL bReissueLicense) { DWORD Status; if (bReissueLicense) { Status = m_pLicenseAgent->AsyncProcessReissueLicenseRequest(); } else { Status = m_pLicenseAgent->AsyncProcessNewLicenseRequest(); } if ( Status != ERROR_SUCCESS ) { TRACE1( L"m_pLicenseAgent->AsyncProcessXxxLicenseRequest() failed. Error = %d", Status ); WriteToLog(L"m_pLicenseAgent->AsyncProcessXxxLicenseRequest() failed. Error = %1!ld!\r\n", Status); } return Status; } HRESULT WaitForActivationPhase() { DWORD Status; MSG msg; do { m_pLicenseAgent->GetAsyncProcessReturnCode( &Status ); if( LA_ERR_REQUEST_IN_PROGRESS == Status ) { Sleep(1000); } } while (LA_ERR_REQUEST_IN_PROGRESS == Status); return Status; } HRESULT DoActivationEx() { static const WCHAR OOBE_HTTP_AGENT_NAME[] = L"Mozilla/4.0 (compatible; MSIE 6.0b; Windows NT 5.1)"; HRESULT hr = E_FAIL; DWORD WPADaysLeft; DWORD EvalDaysLeft; DWORD dwValue = 1; BOOL bReissueLicense = FALSE; DWORD time = GetTickCount(); HINTERNET hInternet = NULL; TRACE(L"DoActivation."); WriteToLog(L"DoActivation.\r\n"); hInternet = InternetOpen( OOBE_HTTP_AGENT_NAME, PRE_CONFIG_INTERNET_ACCESS, NULL, NULL, 0); if (!hInternet) { TRACE(L"InternetOpen Failed."); WriteToLog(L"InternetOpen Failed.\r\n"); } else { if (!InternetSetOption( hInternet, INTERNET_OPTION_DISABLE_AUTODIAL, &dwValue, sizeof(DWORD))) { dwValue = GetLastError(); TRACE1(L"InternetSetOption INTERNET_OPTION_DISABLE_AUTODIAL Failed. GetLastError=%1!lx!", dwValue); WriteToLog(L"InternetSetOption INTERNET_OPTION_DISABLE_AUTODIAL Failed. GetLastError=%1!lx!\r\n", dwValue); } else { hr = S_OK; } } if (hr == S_OK) { hr = InitActivation(); } else { TRACE1(L"InitActivation failed with error code:%d.", hr); WriteToLog(L"InitActivation failed with error code:%1!ld!.\r\n", hr); } if (hr == S_OK) { hr = m_pLicenseAgent->GetExpirationInfo( &WPADaysLeft, &EvalDaysLeft ); if ( hr == S_OK && WPADaysLeft != INT_MAX ) { hr = ActivationHandShake(); if (hr == S_OK) { hr = WaitForActivationPhase(); TRACE1(L"ActivationHandShake returned with :%d.", hr); WriteToLog(L"ActivationHandShake returned with :%1!ld!.\r\n", hr); if ( hr == ESL_ERR_NEW_LICENSE ) { bReissueLicense = FALSE; hr = S_OK; } else if ( hr == ESL_ERR_ORW_REISSUE ) { bReissueLicense = TRUE; hr = S_OK; } if (hr == S_OK) { hr = ActivationLicenseRequest(bReissueLicense); if (hr == S_OK) { hr = WaitForActivationPhase(); TRACE1(L"ActivationLicenseRequest returned with :%d.", hr); WriteToLog(L"ActivationLicenseRequest returned with :%1!ld!.\r\n", hr); if (hr == S_OK) { RemoveActivationShortCut(); } } else { TRACE1(L"ActivationLicenseRequest failed with error code:%d.", hr); WriteToLog(L"ActivationLicenseRequest failed with error code:%1!ld!.\r\n", hr); } } } else { TRACE1(L"ActivationHandShake failed with error code:%d.", hr); WriteToLog(L"ActivationHandShake failed with error code:%1!ld!.\r\n", hr); } } else { TRACE(L"Product already activated."); WriteToLog(L"Product already activated.\r\n"); } } TRACE(L"DoActivation is done."); WriteToLog(L"DoActivation is done.\r\n"); time = GetTickCount() - time; WriteToLog(L"Activation took %1!ld! msec.\r\n", time); if (m_pLicenseAgent) { m_pLicenseAgent->Release(); m_pLicenseAgent = NULL; } if (hInternet) { InternetCloseHandle(hInternet); } return hr; } HRESULT DoActivation(HINSTANCE hInstance) { HRESULT hr = E_FAIL; WCHAR WinntPath[MAX_PATH]; WCHAR ProxyPath[MAX_PATH]; WCHAR ProxySave[MAX_PATH]; WCHAR Answer[50]; BOOL bSaveRestoreProxy = FALSE; // Need to see if we need to remove the CmdLine reg entry OpenLogFile(); if(GetCanonicalizedPath(WinntPath, WINNT_INF_FILENAME)) { // See if we should autoactivate if( GetPrivateProfileString( TEXT("Unattended"), TEXT("AutoActivate"), TEXT(""), Answer, sizeof(Answer)/sizeof(TCHAR), WinntPath ) && !lstrcmpi(Answer, YES_ANSWER)) { // Check if there is a proxy section specified if( GetPrivateProfileString( TEXT("Unattended"), TEXT("ActivateProxy"), TEXT(""), Answer, sizeof(Answer)/sizeof(TCHAR), WinntPath ) ) { // We have a section // Now we should create a temp file with the entries from that section // and pass them to iedkcs32.dll so that they can get applied to the registry // Before calling iedkcs32.dll save the registry if (GetOOBEPath(ProxyPath)) { WCHAR section[1024]; lstrcpy(ProxySave, ProxyPath); lstrcat(ProxySave, L"\\oobeact.pry"); lstrcat(ProxyPath, L"\\oobeact.prx"); DeleteFile(ProxyPath); // Read the proxy section GetPrivateProfileSection(Answer, section, 1024, WinntPath); // Write it to the temp file under section [Proxy] WritePrivateProfileSection(TEXT("Proxy"), section, ProxyPath); bSaveRestoreProxy = TRUE; // Save the internet setting registry key SaveProxySettings(ProxySave); // Apply the settings ApplyProxySettings(ProxyPath); // Don't need the temp file for iedkcs32.dll any more. DeleteFile(ProxyPath); } else { WriteToLog(L"Cannot the path for OOBE\r\n"); } } hr = DoActivationEx(); if (bSaveRestoreProxy) { // Restore the internet settings registry key RestoreProxySettings(ProxySave); // Don;t need the file DeleteFile(ProxySave); } } else { WriteToLog(L"No AutoActivate in %1\r\n",WinntPath); } } else { WriteToLog(L"Cannot get the location for %1\r\n",WINNT_INF_FILENAME); } RemoveCmdline(hInstance); CloseLogFile(); return hr; } BOOL SaveProxySettings(LPTSTR ProxySave) { BOOL bRet = FALSE; HKEY hkey = NULL; HANDLE Token; LUID Luid; TOKEN_PRIVILEGES NewPrivileges; // Make sure the file does not exist. DeleteFile(ProxySave); if(OpenProcessToken(GetCurrentProcess(),TOKEN_ADJUST_PRIVILEGES,&Token)) { if(LookupPrivilegeValue(NULL,SE_BACKUP_NAME,&Luid)) { NewPrivileges.PrivilegeCount = 1; NewPrivileges.Privileges[0].Luid = Luid; NewPrivileges.Privileges[0].Attributes = SE_PRIVILEGE_ENABLED; AdjustTokenPrivileges(Token,FALSE,&NewPrivileges,0,NULL,NULL); } } if (RegOpenKeyEx(HKEY_CURRENT_USER, TEXT("Software\\Microsoft\\windows\\currentVersion\\Internet Settings"), 0, KEY_ALL_ACCESS, &hkey) == ERROR_SUCCESS) { bRet = (RegSaveKey(hkey,ProxySave, NULL) == ERROR_SUCCESS); RegCloseKey(hkey); } WriteToLog(L"SaveProxySettings returned with :%1!ld!.\r\n", bRet); return bRet; } BOOL RestoreProxySettings(LPTSTR ProxySave) { BOOL bRet = FALSE; HKEY hkey = NULL; HANDLE Token; LUID Luid; TOKEN_PRIVILEGES NewPrivileges; if(OpenProcessToken(GetCurrentProcess(),TOKEN_ADJUST_PRIVILEGES,&Token)) { if(LookupPrivilegeValue(NULL,SE_RESTORE_NAME,&Luid)) { NewPrivileges.PrivilegeCount = 1; NewPrivileges.Privileges[0].Luid = Luid; NewPrivileges.Privileges[0].Attributes = SE_PRIVILEGE_ENABLED; AdjustTokenPrivileges(Token,FALSE,&NewPrivileges,0,NULL,NULL); } } if (RegOpenKeyEx(HKEY_CURRENT_USER, TEXT("Software\\Microsoft\\windows\\currentVersion\\Internet Settings"), 0, KEY_ALL_ACCESS, &hkey) == ERROR_SUCCESS) { bRet = (RegRestoreKey(hkey, ProxySave, REG_FORCE_RESTORE) == ERROR_SUCCESS); RegCloseKey(hkey); } WriteToLog(L"RestoreProxySettings returned with :%1!ld!.\r\n", bRet); return bRet; } BOOL ApplyProxySettings(LPTSTR ProxyPath) { typedef BOOL (*BRANDINTRAPROC) ( LPCSTR ); // typedef BOOL (*BRANDCLEANSTUBPROC) (HWND, HINSTANCE, LPCSTR, int); HMODULE IedkHandle = NULL; BRANDINTRAPROC BrandIntraProc; // BRANDCLEANSTUBPROC BrandCleanStubProc; CHAR BrandingFileA[MAX_PATH]; BOOL bRet = FALSE; __try { if( IedkHandle = LoadLibrary(L"IEDKCS32") ) { // BrandCleanStubProc = (BRANDCLEANSTUBPROC) GetProcAddress(IedkHandle,"BrandCleanInstallStubs"); BrandIntraProc = (BRANDINTRAPROC) GetProcAddress(IedkHandle,"BrandIntra"); if( BrandIntraProc ) { if (!WideCharToMultiByte( CP_ACP, 0, ProxyPath, -1, BrandingFileA, sizeof(BrandingFileA), NULL, NULL )) { bRet = FALSE; } else { // bRet = BrandCleanStubProc( NULL, NULL, "", 0); // if( bRet ) { bRet = BrandIntraProc( BrandingFileA ); } } } else { bRet = FALSE; } FreeLibrary(IedkHandle); } else { bRet = FALSE; } } __except(EXCEPTION_EXECUTE_HANDLER) { bRet = FALSE; } WriteToLog(L"ApplyProxySettings returned with :%1!ld!.\r\n", bRet); return bRet; } HANDLE hLogFile = INVALID_HANDLE_VALUE; void CloseLogFile() { if (hLogFile != INVALID_HANDLE_VALUE) { CloseHandle(hLogFile); hLogFile = INVALID_HANDLE_VALUE; } } void OpenLogFile() { WCHAR File[MAX_PATH]; DWORD Result; if (hLogFile == INVALID_HANDLE_VALUE) { Result = GetWindowsDirectory( File, MAX_PATH ); if(Result == 0) { return; } lstrcat(File,TEXT("\\oobeact.log")); hLogFile = CreateFile( File, GENERIC_READ | GENERIC_WRITE, FILE_SHARE_READ, NULL, CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL | FILE_FLAG_WRITE_THROUGH, NULL ); } return; } void WriteToLog(LPWSTR pszFormatString, ...) { va_list args; LPWSTR pszFullErrMsg = NULL; DWORD dwBytesWritten; if (hLogFile != INVALID_HANDLE_VALUE) { va_start(args, pszFormatString); FormatMessage(FORMAT_MESSAGE_ALLOCATE_BUFFER|FORMAT_MESSAGE_FROM_STRING, (LPCVOID) pszFormatString, 0, 0, (LPTSTR) &pszFullErrMsg, 0, &args); if (pszFullErrMsg) { PSTR str; ULONG Bytes; Bytes = (wcslen( pszFullErrMsg )*2) + 4; str = (PSTR)malloc( Bytes ); if (str) { WideCharToMultiByte( CP_ACP, 0, pszFullErrMsg, -1, str, Bytes, NULL, NULL ); WriteFile(hLogFile, str, lstrlenA(str), &dwBytesWritten, NULL); free(str); } LocalFree(pszFullErrMsg); } } } void RemoveCmdline(HINSTANCE hInstance) { HKEY hkey; LONG lRet = RegOpenKeyEx(HKEY_LOCAL_MACHINE, REGSTR_PATH_SYSTEMSETUPKEY, 0, KEY_ALL_ACCESS, &hkey ); if (lRet == ERROR_SUCCESS) { WCHAR rgchCommandLine[MAX_PATH + 1]; DWORD dwSize = sizeof(rgchCommandLine); LRESULT lResult = RegQueryValueEx( hkey, REGSTR_VALUE_CMDLINE, 0, NULL, (LPBYTE)rgchCommandLine, &dwSize ); if (ERROR_SUCCESS == lResult) { WCHAR file[MAX_PATH]; if (MyGetModuleFileName(hInstance, file, MAX_PATH) == 0) { lstrcpy(file, L"OOBEBALN"); } // Check if oobebaln is on the cmd line if (StrStrI(rgchCommandLine, file) != NULL) { // Remove the entry RegDeleteValue(hkey,REGSTR_VALUE_CMDLINE); } } RegCloseKey(hkey); } }