mirror of https://github.com/tongzx/nt5src
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.
1024 lines
25 KiB
1024 lines
25 KiB
|
|
/*++
|
|
|
|
Copyright (c) 2000 Microsoft Corporation
|
|
All rights reserved.
|
|
|
|
Module Name:
|
|
|
|
Nt.c
|
|
|
|
Abstract:
|
|
|
|
Routines to migrate Win95 printing components to NT
|
|
|
|
Author:
|
|
|
|
Keisuke Tsuchida (KeisukeT) 10-Oct-2000
|
|
|
|
Revision History:
|
|
|
|
--*/
|
|
|
|
|
|
#include "precomp.h"
|
|
|
|
//
|
|
// Extern
|
|
//
|
|
|
|
extern LPCSTR g_WorkingDirectory;
|
|
extern LPCSTR g_SourceDirectory;
|
|
extern LPCSTR g_MediaDirectory;
|
|
|
|
//
|
|
// Typedef
|
|
//
|
|
|
|
typedef BOOL (WINAPI *PMIGRATEDEVICE)(PDEVICE_INFO);
|
|
typedef DWORD (WINAPI *PSHDELETEKEY)(HKEY, LPCSTR);
|
|
|
|
|
|
VOID
|
|
DeleteWin95Files(
|
|
)
|
|
/*++
|
|
|
|
Routine Description:
|
|
Read the migrate.inf and delete the files which are not needed on NT.
|
|
|
|
Arguments:
|
|
None
|
|
|
|
Return Value:
|
|
None
|
|
|
|
--*/
|
|
{
|
|
HINF hInf;
|
|
CHAR szPath[MAX_PATH];
|
|
LONG Count, Index;
|
|
INFCONTEXT InfContext;
|
|
|
|
// sprintf(szPath, "%s\\%s", UpgradeData.pszDir, "migrate.inf");
|
|
|
|
hInf = SetupOpenInfFileA(szPath, NULL, INF_STYLE_WIN4, NULL);
|
|
|
|
if ( hInf == INVALID_HANDLE_VALUE )
|
|
return;
|
|
|
|
//
|
|
// We will only do the deleting part here. Files which are handled by
|
|
// the core migration dll do not have a destination directory since we
|
|
// are recreating the printing environment from scratch
|
|
//
|
|
if ( (Count = SetupGetLineCountA(hInf, "Moved")) != -1 ) {
|
|
|
|
for ( Index = 0 ; Index < Count ; ++Index ) {
|
|
|
|
if ( SetupGetLineByIndexA(hInf, "Moved", Index, &InfContext) &&
|
|
SetupGetStringFieldA(&InfContext, 0, szPath,
|
|
sizeof(szPath), NULL) )
|
|
DeleteFileA(szPath);
|
|
}
|
|
}
|
|
|
|
SetupCloseInfFile(hInf);
|
|
}
|
|
|
|
|
|
PSECURITY_DESCRIPTOR
|
|
GetSecurityDescriptor(
|
|
IN LPCSTR pszUser
|
|
)
|
|
/*++
|
|
|
|
Routine Description:
|
|
Get the users security
|
|
|
|
Arguments:
|
|
pszUser : sub key under HKEY_USER
|
|
|
|
Return Value:
|
|
NULL on error, else a valid SECURITY_DESCRIPTOR.
|
|
Memory is allocated in the heap and caller should free it.
|
|
|
|
--*/
|
|
{
|
|
HKEY hKey = NULL;
|
|
DWORD dwSize;
|
|
PSECURITY_DESCRIPTOR pSD = NULL;
|
|
|
|
if ( RegOpenKeyExA(HKEY_USERS,
|
|
pszUser,
|
|
0,
|
|
KEY_READ|KEY_WRITE,
|
|
&hKey) ||
|
|
RegGetKeySecurity(hKey,
|
|
DACL_SECURITY_INFORMATION,
|
|
NULL,
|
|
&dwSize) != ERROR_INSUFFICIENT_BUFFER ||
|
|
!(pSD = (PSECURITY_DESCRIPTOR) AllocMem(dwSize)) ||
|
|
RegGetKeySecurity(hKey,
|
|
DACL_SECURITY_INFORMATION,
|
|
pSD,
|
|
&dwSize) ) {
|
|
|
|
if ( hKey )
|
|
RegCloseKey(hKey);
|
|
|
|
FreeMem(pSD);
|
|
pSD = NULL;
|
|
}
|
|
|
|
return pSD;
|
|
}
|
|
|
|
|
|
LONG
|
|
CALLBACK
|
|
InitializeNT(
|
|
IN LPCWSTR pszWorkingDir,
|
|
IN LPCWSTR pszSourceDir,
|
|
IN LPCWSTR pszMediaDir
|
|
)
|
|
{
|
|
LONG lError;
|
|
|
|
//
|
|
// Initialize local.
|
|
//
|
|
|
|
lError = ERROR_SUCCESS;
|
|
|
|
//
|
|
// Save given parameters.
|
|
//
|
|
|
|
g_WorkingDirectory = AllocStrAFromStrW(pszWorkingDir);
|
|
g_SourceDirectory = AllocStrAFromStrW(pszSourceDir);
|
|
g_MediaDirectory = AllocStrAFromStrW(pszMediaDir);
|
|
|
|
if(NULL == g_WorkingDirectory){
|
|
SetupLogError("WIA Migration: InitializeNT: ERROR!! insufficient memory.", LogSevError);
|
|
|
|
lError = ERROR_NOT_ENOUGH_MEMORY;
|
|
goto InitializeNT_return;
|
|
}
|
|
|
|
InitializeNT_return:
|
|
|
|
if(ERROR_SUCCESS != lError){
|
|
|
|
//
|
|
// Can't process migration. Clean up.
|
|
//
|
|
|
|
if(NULL != g_WorkingDirectory){
|
|
FreeMem((PVOID)g_WorkingDirectory);
|
|
g_WorkingDirectory = NULL;
|
|
}
|
|
|
|
if(NULL != g_SourceDirectory){
|
|
FreeMem((PVOID)g_SourceDirectory);
|
|
g_SourceDirectory = NULL;
|
|
}
|
|
|
|
if(NULL != g_MediaDirectory){
|
|
FreeMem((PVOID)g_MediaDirectory);
|
|
g_MediaDirectory = NULL;
|
|
}
|
|
} // if(ERROR_SUCCESS != lError)
|
|
|
|
return lError;
|
|
}
|
|
|
|
|
|
LONG
|
|
CALLBACK
|
|
MigrateUserNT(
|
|
IN HINF hUnattendInf,
|
|
IN HKEY hUserRegKey,
|
|
IN LPCWSTR pszUserName,
|
|
LPVOID Reserved
|
|
)
|
|
{
|
|
return ERROR_SUCCESS;
|
|
}
|
|
|
|
|
|
LONG
|
|
CALLBACK
|
|
MigrateSystemNT(
|
|
IN HINF hUnattendInf,
|
|
LPVOID Reserved
|
|
)
|
|
{
|
|
LONG lError;
|
|
HANDLE hFile;
|
|
CHAR szFile[MAX_PATH];
|
|
|
|
//
|
|
// Initialize local.
|
|
//
|
|
|
|
lError = ERROR_SUCCESS;
|
|
hFile = (HANDLE)INVALID_HANDLE_VALUE;
|
|
|
|
//
|
|
// Check global initialization.
|
|
//
|
|
|
|
if(NULL == g_WorkingDirectory){
|
|
lError = ERROR_NOT_ENOUGH_MEMORY;
|
|
MyLogError("WIA Migration: MigrateSystemNT: ERROR!! Initialize failed. Err=0x%x\n", lError);
|
|
|
|
goto MigrateSystemNT_return;
|
|
} // if(NULL == g_WorkingDirectory)
|
|
|
|
//
|
|
// Create path to the files.
|
|
//
|
|
|
|
// wsprintfA(szFile, "%s\\%s", g_WorkingDirectory, NAME_WIN9X_SETTING_FILE_A);
|
|
_snprintf(szFile, sizeof(szFile), "%s\\%s", g_WorkingDirectory, NAME_WIN9X_SETTING_FILE_A);
|
|
|
|
//
|
|
// Open migration file.
|
|
//
|
|
|
|
hFile = CreateFileA(szFile,
|
|
GENERIC_READ,
|
|
FILE_SHARE_READ,
|
|
NULL,
|
|
OPEN_EXISTING,
|
|
FILE_ATTRIBUTE_NORMAL |
|
|
FILE_FLAG_SEQUENTIAL_SCAN,
|
|
NULL);
|
|
|
|
if (hFile == INVALID_HANDLE_VALUE){
|
|
lError = GetLastError();
|
|
MyLogError("WIA Migration: MigrateSystemNT: ERROR!! Unable to open setting file. Err=0x%x\n", lError);
|
|
|
|
goto MigrateSystemNT_return;
|
|
} // if (hFile == INVALID_HANDLE_VALUE)
|
|
|
|
//
|
|
// Process migration info file created on Win9x.
|
|
//
|
|
|
|
lError = MigNtProcessMigrationInfo(hFile);
|
|
|
|
//
|
|
// Remove certain reg if inbox Kodak Imaging for Win9x is installed.
|
|
//
|
|
|
|
if(MigNtIsWin9xImagingExisting()){
|
|
MigNtRemoveKodakImagingKey();
|
|
} // if(MigNtIsWin9xImagingExisting())
|
|
|
|
MigrateSystemNT_return:
|
|
|
|
//
|
|
// Clean up.
|
|
//
|
|
|
|
if(INVALID_HANDLE_VALUE == hFile){
|
|
CloseHandle(hFile);
|
|
}
|
|
|
|
return lError;
|
|
} // MigrateSystemNT()
|
|
|
|
|
|
LONG
|
|
MigNtProcessMigrationInfo(
|
|
HANDLE hFile
|
|
)
|
|
{
|
|
LONG lError;
|
|
DEVICE_INFO MigrateDevice;
|
|
HMODULE hInstaller;
|
|
PMIGRATEDEVICE pfnMigrateDevice;
|
|
|
|
|
|
//
|
|
// Initialize local.
|
|
//
|
|
|
|
lError = ERROR_SUCCESS;
|
|
hInstaller = (HMODULE)NULL;
|
|
pfnMigrateDevice = NULL;
|
|
|
|
memset(&MigrateDevice, 0, sizeof(MigrateDevice));
|
|
|
|
//
|
|
// Load STI_CI.DLL.
|
|
//
|
|
|
|
hInstaller = LoadLibrary(NAME_INSTALLER_A);
|
|
if(NULL == hInstaller){
|
|
|
|
//
|
|
// Unable to load sti_ci.dll.
|
|
//
|
|
|
|
lError = GetLastError();
|
|
MyLogError("WIA Migration: MigNtProcessMigrationInfo: ERROR!! Unable to load sti_ci.dll. Err=0x%x\n", lError);
|
|
|
|
goto MigNtProcessMigrationInfo_return;
|
|
|
|
} // if(NULL == hInstaller)
|
|
|
|
//
|
|
// Get address of MigrateDevice()
|
|
//
|
|
|
|
pfnMigrateDevice = (PMIGRATEDEVICE)GetProcAddress(hInstaller, NAME_PROC_MIGRATEDEVICE_A);
|
|
if(NULL == pfnMigrateDevice){
|
|
|
|
//
|
|
// Unable to get proc address.
|
|
//
|
|
|
|
lError = GetLastError();
|
|
MyLogError("WIA Migration: MigNtProcessMigrationInfo: ERROR!! Unable to get proc address. Err=0x%x\n", lError);
|
|
|
|
goto MigNtProcessMigrationInfo_return;
|
|
|
|
} // if(NULL == pfnMigrateDevice)
|
|
|
|
//
|
|
// Query migrating device.
|
|
//
|
|
|
|
while(ERROR_SUCCESS == MigNtGetDevice(hFile, &MigrateDevice)){
|
|
|
|
//
|
|
// Install only COM/LPT device.
|
|
//
|
|
|
|
if( (NULL != strstr(MigrateDevice.pszCreateFileName, "COM"))
|
|
|| (NULL != strstr(MigrateDevice.pszCreateFileName, "LPT"))
|
|
|| (NULL != strstr(MigrateDevice.pszCreateFileName, "AUTO")) )
|
|
{
|
|
pfnMigrateDevice(&MigrateDevice);
|
|
}
|
|
|
|
/***********
|
|
{
|
|
PPARAM_LIST pTemp;
|
|
|
|
printf("\"%s\" = \"%s\"\r\n", NAME_FRIENDLYNAME_A, MigrateDevice.pszFriendlyName);
|
|
printf("\"%s\" = \"%s\"\r\n", NAME_CREATEFILENAME_A, MigrateDevice.pszCreateFileName);
|
|
printf("\"%s\" = \"%s\"\r\n", NAME_INF_PATH_A, MigrateDevice.pszInfPath);
|
|
printf("\"%s\" = \"%s\"\r\n", NAME_INF_SECTION_A, MigrateDevice.pszInfSection);
|
|
|
|
for(pTemp = MigrateDevice.pDeviceDataParam; pTemp != NULL;){
|
|
printf("\"%s\" = \"%s\"\r\n", pTemp->pParam1, pTemp->pParam2);
|
|
pTemp = (PPARAM_LIST)pTemp->pNext;
|
|
} // for(pTemp = MigrateDevice.pDeviceDataParam; pTemp != NULL;)
|
|
|
|
printf("\r\n");
|
|
|
|
}
|
|
***********/
|
|
|
|
//
|
|
// Clean up.
|
|
//
|
|
|
|
MigNtFreeDeviceInfo(&MigrateDevice);
|
|
|
|
} // while(ERROR_SUCCESS == MigNtGetDevice(hFile, &MigrateDevice))
|
|
|
|
|
|
MigNtProcessMigrationInfo_return:
|
|
|
|
//
|
|
// Clean up.
|
|
//
|
|
|
|
if(NULL != hInstaller){
|
|
FreeLibrary(hInstaller);
|
|
}
|
|
|
|
return lError;
|
|
} // MigNtProcessMigrationInfo()
|
|
|
|
|
|
LONG
|
|
MigNtGetDevice(
|
|
HANDLE hFile,
|
|
PDEVICE_INFO pMigrateDevice
|
|
)
|
|
{
|
|
LONG lError;
|
|
LPSTR pParam1;
|
|
LPSTR pParam2;
|
|
BOOL bFound;
|
|
LPSTR pszFriendlyName;
|
|
LPSTR pszCreateFileName;
|
|
LPSTR pszInfPath;
|
|
LPSTR pszInfSection;
|
|
DWORD dwNumberOfDeviceDataKey;
|
|
PPARAM_LIST pDeviceDataParam;
|
|
PPARAM_LIST pTempParam;
|
|
//
|
|
// Initialize local.
|
|
//
|
|
|
|
lError = ERROR_SUCCESS;
|
|
pParam1 = NULL;
|
|
pParam2 = NULL;
|
|
bFound = FALSE;
|
|
|
|
pszFriendlyName = NULL;
|
|
pszCreateFileName = NULL;
|
|
pszInfPath = NULL;
|
|
pszInfSection = NULL;
|
|
pDeviceDataParam = NULL;
|
|
pTempParam = NULL;
|
|
dwNumberOfDeviceDataKey = 0;
|
|
|
|
//
|
|
// Find "Device = BEGIN"
|
|
//
|
|
|
|
while(FALSE == bFound){
|
|
|
|
ReadString(hFile, &pParam1, &pParam2);
|
|
if( (NULL == pParam1) && (NULL == pParam2) ){
|
|
//
|
|
// Error or EOF.
|
|
//
|
|
|
|
lError = ERROR_NO_MORE_ITEMS;
|
|
goto MigNtGetDevice_return;
|
|
}
|
|
|
|
if( (0 == lstrcmpiA(pParam1, NAME_DEVICE_A))
|
|
&& (0 == lstrcmpiA(pParam2, NAME_BEGIN_A)) )
|
|
{
|
|
|
|
//
|
|
// Found begining of device description.
|
|
//
|
|
|
|
bFound = TRUE;
|
|
}
|
|
|
|
//
|
|
// Free allocated memory.
|
|
//
|
|
|
|
FreeMem(pParam1);
|
|
FreeMem(pParam2);
|
|
pParam1 = NULL;
|
|
pParam2 = NULL;
|
|
} // while(FALSE == bFound)
|
|
|
|
//
|
|
// Get FriendlyName
|
|
//
|
|
|
|
ReadString(hFile, &pParam1, &pParam2);
|
|
if( (NULL == pParam1) || (NULL == pParam2) ){
|
|
lError = ERROR_NOT_ENOUGH_MEMORY;
|
|
goto MigNtGetDevice_return;
|
|
} // if( (NULL == pParam1) || (NULL == pParam2) )
|
|
if(0 != lstrcmpiA(pParam1, NAME_FRIENDLYNAME_A)){
|
|
|
|
//
|
|
// Invalid migration file.
|
|
//
|
|
|
|
lError = ERROR_INVALID_PARAMETER;
|
|
goto MigNtGetDevice_return;
|
|
} //if(0 != lstrcmpiA(pParam1, NAME_FRIENDLYNAME_A))
|
|
|
|
//
|
|
// Copy to allocated buffer.
|
|
//
|
|
|
|
pszFriendlyName = AllocStrA(pParam2);
|
|
FreeMem(pParam1);
|
|
FreeMem(pParam2);
|
|
pParam1 = NULL;
|
|
pParam2 = NULL;
|
|
|
|
//
|
|
// Get CreateFileName
|
|
//
|
|
|
|
ReadString(hFile, &pParam1, &pParam2);
|
|
if( (NULL == pParam1) || (NULL == pParam2) ){
|
|
lError = ERROR_NOT_ENOUGH_MEMORY;
|
|
goto MigNtGetDevice_return;
|
|
} // if( (NULL == pParam1) || (NULL == pParam2) )
|
|
if(0 != lstrcmpiA(pParam1, NAME_CREATEFILENAME_A)){
|
|
|
|
//
|
|
// Invalid migration file.
|
|
//
|
|
|
|
lError = ERROR_INVALID_PARAMETER;
|
|
goto MigNtGetDevice_return;
|
|
} //if(0 != lstrcmpiA(pParam1, NAME_CREATEFILENAME_A))
|
|
|
|
//
|
|
// Copy to allocated buffer.
|
|
//
|
|
|
|
pszCreateFileName = AllocStrA(pParam2);
|
|
FreeMem(pParam1);
|
|
FreeMem(pParam2);
|
|
pParam1 = NULL;
|
|
pParam2 = NULL;
|
|
|
|
//
|
|
// Get InfPath
|
|
//
|
|
|
|
ReadString(hFile, &pParam1, &pParam2);
|
|
if( (NULL == pParam1) || (NULL == pParam2) ){
|
|
lError = ERROR_NOT_ENOUGH_MEMORY;
|
|
goto MigNtGetDevice_return;
|
|
} // if( (NULL == pParam1) || (NULL == pParam2) )
|
|
if(0 != lstrcmpiA(pParam1, NAME_INF_PATH_A)){
|
|
|
|
//
|
|
// Invalid migration file.
|
|
//
|
|
|
|
lError = ERROR_INVALID_PARAMETER;
|
|
goto MigNtGetDevice_return;
|
|
} //if(0 != lstrcmpiA(pParam1, NAME_INF_PATH_A))
|
|
|
|
//
|
|
// Copy to allocated buffer.
|
|
//
|
|
|
|
pszInfPath = AllocStrA(pParam2);
|
|
FreeMem(pParam1);
|
|
FreeMem(pParam2);
|
|
pParam1 = NULL;
|
|
pParam2 = NULL;
|
|
|
|
//
|
|
// Get InfSection
|
|
//
|
|
|
|
ReadString(hFile, &pParam1, &pParam2);
|
|
if( (NULL == pParam1) || (NULL == pParam2) ){
|
|
lError = ERROR_NOT_ENOUGH_MEMORY;
|
|
goto MigNtGetDevice_return;
|
|
} // if( (NULL == pParam1) || (NULL == pParam2) )
|
|
if(0 != lstrcmpiA(pParam1, NAME_INF_SECTION_A)){
|
|
|
|
//
|
|
// Invalid migration file.
|
|
//
|
|
|
|
lError = ERROR_INVALID_PARAMETER;
|
|
goto MigNtGetDevice_return;
|
|
} //if(0 != lstrcmpiA(pParam1, NAME_INF_SECTION_A))
|
|
|
|
//
|
|
// Copy to allocated buffer.
|
|
//
|
|
|
|
pszInfSection = AllocStrA(pParam2);
|
|
FreeMem(pParam1);
|
|
FreeMem(pParam2);
|
|
pParam1 = NULL;
|
|
pParam2 = NULL;
|
|
|
|
//
|
|
// Get DeviceData section.
|
|
//
|
|
|
|
bFound = FALSE;
|
|
while(FALSE == bFound){
|
|
ReadString(hFile, &pParam1, &pParam2);
|
|
if( (NULL == pParam1) || (NULL == pParam2) ){
|
|
lError = ERROR_NOT_ENOUGH_MEMORY;
|
|
goto MigNtGetDevice_return;
|
|
} // if( (NULL == pParam1) || (NULL == pParam2) )
|
|
|
|
if(0 == lstrcmpiA(pParam1, REGKEY_DEVICEDATA_A)){
|
|
//
|
|
// Found beginning of DeviceData section.
|
|
//
|
|
|
|
bFound = TRUE;
|
|
|
|
} // if(0 == lstrcmpiA(pParam1, REGKEY_DEVICEDATA_A))
|
|
|
|
FreeMem(pParam1);
|
|
FreeMem(pParam2);
|
|
pParam1 = NULL;
|
|
pParam2 = NULL;
|
|
|
|
} // while(FALSE == bFound)
|
|
|
|
//
|
|
// Process until DeviceData = END is found.
|
|
//
|
|
|
|
bFound = FALSE;
|
|
while(FALSE == bFound){
|
|
ReadString(hFile, &pParam1, &pParam2);
|
|
if( (NULL == pParam1) || (NULL == pParam2) ){
|
|
lError = ERROR_NOT_ENOUGH_MEMORY;
|
|
goto MigNtGetDevice_return;
|
|
} // if( (NULL == pParam1) || (NULL == pParam2) )
|
|
|
|
if( (0 == lstrcmpiA(pParam1, REGKEY_DEVICEDATA_A))
|
|
&& (0 == lstrcmpiA(pParam2, NAME_END_A)) )
|
|
{
|
|
//
|
|
// Found beginning of DeviceData section.
|
|
//
|
|
|
|
bFound = TRUE;
|
|
|
|
FreeMem(pParam1);
|
|
FreeMem(pParam2);
|
|
pParam1 = NULL;
|
|
pParam2 = NULL;
|
|
break;
|
|
} // if(0 == lstrcmpiA(pParam1, REGKEY_DEVICEDATA_A))
|
|
|
|
//
|
|
// Increment counter.
|
|
//
|
|
|
|
dwNumberOfDeviceDataKey++;
|
|
|
|
//
|
|
// Allocate new structure for parameters.
|
|
//
|
|
|
|
pTempParam = (PPARAM_LIST)AllocMem(sizeof(PARAM_LIST));
|
|
if(NULL == pTempParam){
|
|
lError = ERROR_NOT_ENOUGH_MEMORY;
|
|
goto MigNtGetDevice_return;
|
|
} // if(NULL == pTempParam)
|
|
|
|
//
|
|
// Set parameters.
|
|
//
|
|
|
|
pTempParam->pNext = NULL;
|
|
pTempParam->pParam1 = AllocStrA(pParam1);
|
|
pTempParam->pParam2 = AllocStrA(pParam2);
|
|
|
|
//
|
|
// Add this parameter to list.
|
|
//
|
|
|
|
if(NULL == pDeviceDataParam){
|
|
pDeviceDataParam = pTempParam;
|
|
} else { // if(NULL == pDeviceDataParam)
|
|
PPARAM_LIST pTemp;
|
|
|
|
//
|
|
// Find the last data, and add.
|
|
//
|
|
|
|
for(pTemp = pDeviceDataParam; NULL !=pTemp->pNext; pTemp=(PPARAM_LIST)pTemp->pNext);
|
|
pTemp->pNext = (PVOID)pTempParam;
|
|
|
|
} // else(NULL == pDeviceDataParam)
|
|
|
|
FreeMem(pParam1);
|
|
FreeMem(pParam2);
|
|
pParam1 = NULL;
|
|
pParam2 = NULL;
|
|
|
|
} // while(FALSE == bFound)
|
|
|
|
//
|
|
// Copy all data.
|
|
//
|
|
|
|
pMigrateDevice->pszFriendlyName = pszFriendlyName;
|
|
pMigrateDevice->pszCreateFileName = pszCreateFileName;
|
|
pMigrateDevice->pszInfPath = pszInfPath;
|
|
pMigrateDevice->pszInfSection = pszInfSection;
|
|
pMigrateDevice->dwNumberOfDeviceDataKey = dwNumberOfDeviceDataKey;
|
|
pMigrateDevice->pDeviceDataParam = pDeviceDataParam;
|
|
|
|
//
|
|
// Operation succeeded.
|
|
//
|
|
|
|
lError = ERROR_SUCCESS;
|
|
|
|
MigNtGetDevice_return:
|
|
|
|
//
|
|
// Clean up.
|
|
//
|
|
|
|
if(ERROR_SUCCESS != lError){
|
|
PPARAM_LIST pTemp;
|
|
|
|
//
|
|
// Free all allocated parameters.
|
|
//
|
|
|
|
if(NULL != pszFriendlyName){
|
|
FreeMem(pszFriendlyName);
|
|
}
|
|
if(NULL != pszCreateFileName){
|
|
FreeMem(pszCreateFileName);
|
|
}
|
|
if(NULL != pszInfPath){
|
|
FreeMem(pszInfPath);
|
|
}
|
|
if(NULL != pszInfSection){
|
|
FreeMem(pszInfSection);
|
|
}
|
|
if(NULL != pDeviceDataParam){
|
|
pTemp = pDeviceDataParam;
|
|
while(NULL != pTemp){
|
|
pDeviceDataParam = (PPARAM_LIST)pDeviceDataParam->pNext;
|
|
FreeMem(pTemp);
|
|
pTemp = pDeviceDataParam;
|
|
} // while(NULL != pTemp)
|
|
} // if(NULL != pDeviceDataParam)
|
|
} // if(ERROR_SUCCESS != lError)
|
|
|
|
if(NULL != pParam1){
|
|
FreeMem(pParam1);
|
|
}
|
|
|
|
if(NULL != pParam2){
|
|
FreeMem(pParam2);
|
|
}
|
|
|
|
return lError;
|
|
} // MigNtGetDevice()
|
|
|
|
|
|
VOID
|
|
MigNtFreeDeviceInfo(
|
|
PDEVICE_INFO pMigrateDevice
|
|
)
|
|
{
|
|
PPARAM_LIST pCurrent;
|
|
PPARAM_LIST pNext;
|
|
|
|
if(NULL == pMigrateDevice){
|
|
goto MigNtFreeDeviceInfo_return;
|
|
} // if(NULL == pMigrateDevice)
|
|
|
|
//
|
|
// Free all allocated parameters.
|
|
//
|
|
|
|
if(NULL != pMigrateDevice->pszFriendlyName){
|
|
FreeMem(pMigrateDevice->pszFriendlyName);
|
|
}
|
|
if(NULL != pMigrateDevice->pszCreateFileName){
|
|
FreeMem(pMigrateDevice->pszCreateFileName);
|
|
}
|
|
if(NULL != pMigrateDevice->pszInfPath){
|
|
FreeMem(pMigrateDevice->pszInfPath);
|
|
}
|
|
if(NULL != pMigrateDevice->pszInfSection){
|
|
FreeMem(pMigrateDevice->pszInfSection);
|
|
}
|
|
if(NULL != pMigrateDevice->pDeviceDataParam){
|
|
pCurrent = pMigrateDevice->pDeviceDataParam;
|
|
while(NULL != pCurrent){
|
|
pNext = (PPARAM_LIST)pCurrent->pNext;
|
|
FreeMem(pCurrent);
|
|
pCurrent = pNext;
|
|
} // while(NULL != pTemp)
|
|
} // if(NULL != pDeviceDataParam)
|
|
|
|
//
|
|
// Null out the buffer.
|
|
//
|
|
|
|
memset(pMigrateDevice, 0, sizeof(DEVICE_INFO));
|
|
|
|
MigNtFreeDeviceInfo_return:
|
|
return;
|
|
} // MigNtFreeDeviceInfo()
|
|
|
|
BOOL
|
|
CALLBACK
|
|
MigNtIsWin9xImagingExisting(
|
|
VOID
|
|
)
|
|
{
|
|
BOOL bRet;
|
|
LONG lError;
|
|
HKEY hkKodak;
|
|
TCHAR szWindowsDirectory[MAX_PATH];
|
|
TCHAR szKodakImaging[MAX_PATH];
|
|
DWORD dwVersionInfoSize;
|
|
DWORD dwDummy;
|
|
PVOID pVersion;
|
|
PVOID pFileVersionInfo;
|
|
DWORD dwFileVersionInfoSize;
|
|
|
|
|
|
|
|
//
|
|
// Initialize local.
|
|
//
|
|
|
|
bRet = FALSE;
|
|
lError = ERROR_SUCCESS;
|
|
dwVersionInfoSize = 0;
|
|
dwFileVersionInfoSize = 0;
|
|
pVersion = NULL;
|
|
pFileVersionInfo = NULL;
|
|
|
|
memset(szWindowsDirectory, 0, sizeof(szWindowsDirectory));
|
|
memset(szKodakImaging, 0, sizeof(szKodakImaging));
|
|
|
|
//
|
|
// Get Windows directory.
|
|
//
|
|
|
|
if(0 == GetWindowsDirectory(szWindowsDirectory, sizeof(szWindowsDirectory)/sizeof(TCHAR))){
|
|
lError = GetLastError();
|
|
MyLogError("WIA Migration: MigNtIsWin9xImagingExisting: ERROR!! GetWindowsDirectory() failed. Err=0x%x\n", lError);
|
|
|
|
goto MigNtIsWin9xImagingExisting_return;
|
|
} // if(0 == GetWindowsDirectory(szTemp, sizeof(szTemp)/sizeof(TCHAR)))
|
|
|
|
//
|
|
// Create path to Kodak Imaging.
|
|
//
|
|
|
|
// wsprintf(szKodakImaging, "%s\\%s", szWindowsDirectory, NAME_KODAKIMAGING);
|
|
_sntprintf(szKodakImaging, sizeof(szKodakImaging)/sizeof(TCHAR), TEXT("%s\\%s"), szWindowsDirectory, NAME_KODAKIMAGING);
|
|
|
|
//
|
|
// Get size of version resource of the file.
|
|
//
|
|
|
|
dwVersionInfoSize = GetFileVersionInfoSize(szKodakImaging, &dwDummy);
|
|
if(0 == dwVersionInfoSize){
|
|
|
|
//
|
|
// Unable to get version info of the file. Most probably the file doesn't exist.
|
|
//
|
|
|
|
lError = GetLastError();
|
|
if(ERROR_FILE_NOT_FOUND == lError){
|
|
|
|
//
|
|
// File doesn't exist. Now it's safe to remove regkey for kodakimg.exe.
|
|
//
|
|
|
|
bRet = TRUE;
|
|
|
|
} // if(ERROR_FILE_NOT_FOUND == lError)
|
|
// MyLogError("WIA Migration: MigNtIsWin9xImagingExisting: ERROR!! GetFileVersionInfoSize() failed. Err=0x%x\n", lError);
|
|
|
|
goto MigNtIsWin9xImagingExisting_return;
|
|
} // if(0 == dwVersionInfoSize)
|
|
|
|
//
|
|
// Allocate required size of buffer.
|
|
//
|
|
|
|
pVersion = AllocMem(dwVersionInfoSize);
|
|
if(NULL == pVersion){
|
|
lError = ERROR_INSUFFICIENT_BUFFER;
|
|
MyLogError("WIA Migration: MigNtIsWin9xImagingExisting: ERROR!! InsufficientBuffer. Err=0x%x\n", lError);
|
|
|
|
goto MigNtIsWin9xImagingExisting_return;
|
|
} // if(NULL == pVersion)
|
|
|
|
//
|
|
// Get version info.
|
|
//
|
|
|
|
if(FALSE == GetFileVersionInfo(szKodakImaging, 0, dwVersionInfoSize, pVersion)){
|
|
lError = GetLastError();
|
|
MyLogError("WIA Migration: MigNtIsWin9xImagingExisting: ERROR!! GetVersionInfo() failed. Err=0x%x\n", lError);
|
|
|
|
goto MigNtIsWin9xImagingExisting_return;
|
|
} // if(FALSE == GetVersionInfo(szKodakImaging, 0, dwVersionInfoSize, pVersion))
|
|
|
|
//
|
|
// See if the binary is Win9x inbox.
|
|
//
|
|
|
|
if(FALSE == VerQueryValue(pVersion, TEXT("\\"), &pFileVersionInfo, &dwFileVersionInfoSize)){
|
|
lError = GetLastError();
|
|
MyLogError("WIA Migration: MigNtIsWin9xImagingExisting: ERROR!! VerQueryValue() failed. Err=0x%x\n", lError);
|
|
|
|
goto MigNtIsWin9xImagingExisting_return;
|
|
} // if(FALSE == VerQueryValue(pVersion, TEXT("\\"), &pFileVersionInfo, &dwFileVersionInfoSize))
|
|
|
|
if( (FILEVER_KODAKIMAGING_WIN98_MS == ((VS_FIXEDFILEINFO *)pFileVersionInfo)->dwFileVersionMS)
|
|
&& (FILEVER_KODAKIMAGING_WIN98_LS == ((VS_FIXEDFILEINFO *)pFileVersionInfo)->dwFileVersionLS)
|
|
&& (PRODVER_KODAKIMAGING_WIN98_MS == ((VS_FIXEDFILEINFO *)pFileVersionInfo)->dwProductVersionMS)
|
|
&& (PRODVER_KODAKIMAGING_WIN98_LS == ((VS_FIXEDFILEINFO *)pFileVersionInfo)->dwProductVersionLS) )
|
|
{
|
|
//
|
|
// This is Win98 inbox Kodak Imaging. Process regkey removal.
|
|
//
|
|
|
|
bRet = TRUE;
|
|
} else if( (FILEVER_KODAKIMAGING_WINME_MS == ((VS_FIXEDFILEINFO *)pFileVersionInfo)->dwFileVersionMS)
|
|
&& (FILEVER_KODAKIMAGING_WINME_LS == ((VS_FIXEDFILEINFO *)pFileVersionInfo)->dwFileVersionLS)
|
|
&& (PRODVER_KODAKIMAGING_WINME_MS == ((VS_FIXEDFILEINFO *)pFileVersionInfo)->dwProductVersionMS)
|
|
&& (PRODVER_KODAKIMAGING_WINME_LS == ((VS_FIXEDFILEINFO *)pFileVersionInfo)->dwProductVersionLS) )
|
|
{
|
|
//
|
|
// This is WinMe inbox Kodak Imaging. Process regkey removal.
|
|
//
|
|
|
|
bRet = TRUE;
|
|
}
|
|
|
|
MigNtIsWin9xImagingExisting_return:
|
|
|
|
//
|
|
// Cleanup.
|
|
//
|
|
|
|
if(NULL != pVersion){
|
|
FreeMem(pVersion);
|
|
} // if(NULL != pVersion)
|
|
|
|
return bRet;
|
|
|
|
} // MigNtIsWin9xImagingExisting()
|
|
|
|
|
|
VOID
|
|
CALLBACK
|
|
MigNtRemoveKodakImagingKey(
|
|
VOID
|
|
)
|
|
{
|
|
|
|
HMODULE hmShlwapi;
|
|
PSHDELETEKEY pfnSHDeleteKey;
|
|
|
|
//
|
|
// Initialize local.
|
|
//
|
|
|
|
hmShlwapi = (HMODULE)NULL;
|
|
pfnSHDeleteKey = (PSHDELETEKEY)NULL;
|
|
|
|
//
|
|
// Load shlwapi.dll.
|
|
//
|
|
|
|
hmShlwapi = LoadLibrary(TEXT("shlwapi.dll"));
|
|
if(NULL == hmShlwapi){
|
|
MyLogError("WIA Migration: MigNtRemoveKodakImagingKey: ERROR!! Unable to load hmShlwapi.dll. Err=0x%x.\n", GetLastError());
|
|
|
|
goto MigNtRemoveKodakImagingKey_return;
|
|
} // if(NULL == hmShlwapi)
|
|
|
|
//
|
|
// Get proc address of SHDeleteKey.
|
|
//
|
|
|
|
pfnSHDeleteKey = (PSHDELETEKEY)GetProcAddress(hmShlwapi, TEXT("SHDeleteKeyA"));
|
|
if(NULL == pfnSHDeleteKey){
|
|
MyLogError("WIA Migration: MigNtRemoveKodakImagingKey: ERROR!! Unable to find SHDeleteKeyA. Err=0x%x.\n", GetLastError());
|
|
|
|
goto MigNtRemoveKodakImagingKey_return;
|
|
} // if(NULL == hmShlwapi)
|
|
|
|
//
|
|
// Delete key.
|
|
//
|
|
|
|
if(ERROR_SUCCESS != pfnSHDeleteKey(HKEY_LOCAL_MACHINE, REGSTR_PATH_KODAKEVENT_A)){
|
|
MyLogError("WIA Migration: MigNtRemoveKodakImagingKey: ERROR!! Unable to delete key. Err=0x%x.\n", GetLastError());
|
|
|
|
goto MigNtRemoveKodakImagingKey_return;
|
|
} // if(ERROR_SUCCESS != pfnSHDeleteKey(HKEY_LOCAL_MACHINE, REGSTR_PATH_KODAKEVENT_A))
|
|
|
|
MigNtRemoveKodakImagingKey_return:
|
|
if(NULL != hmShlwapi){
|
|
FreeLibrary(hmShlwapi);
|
|
hmShlwapi = NULL;
|
|
} // if(NULL != hmShlwapi)
|
|
|
|
} // MigNtRemoveKodakImagingKey()
|
|
|
|
//
|
|
// The following are to make sure if setup changes the header file they
|
|
// first tell me (otherwise they will break build of this)
|
|
//
|
|
P_INITIALIZE_NT pfnInitializeNT = InitializeNT;
|
|
P_MIGRATE_USER_NT pfnMigrateUserNt = MigrateUserNT;
|
|
P_MIGRATE_SYSTEM_NT pfnMigrateSystemNT = MigrateSystemNT;
|