272 lines
6.8 KiB
C++
272 lines
6.8 KiB
C++
/*++
|
||
|
||
Copyright (C) Microsoft Corporation, 1997 - 1999
|
||
|
||
Module Name:
|
||
|
||
onestop.hxx
|
||
|
||
Abstract:
|
||
|
||
This file contains the common functions that are helpful in notifying
|
||
OneStop of logon/logoff events.
|
||
|
||
Author:
|
||
|
||
Gopal Parupudi <GopalP>
|
||
|
||
Notes:
|
||
|
||
a. This is being used in senslogn.dll on NT5.
|
||
b. It is also being used in sens.dll on NT4 and Win9x.
|
||
|
||
Revision History:
|
||
|
||
GopalP 4/29/1998 Start.
|
||
|
||
--*/
|
||
|
||
|
||
#include <mobsyncp.h>
|
||
#include "onestop.hxx"
|
||
|
||
|
||
|
||
|
||
HRESULT
|
||
SensNotifyOneStop(
|
||
HANDLE hToken,
|
||
TCHAR *pCommandLine,
|
||
BOOL bSync
|
||
)
|
||
{
|
||
TCHAR szCommandLine[256];
|
||
DWORD dwLastError;
|
||
STARTUPINFO si;
|
||
PROCESS_INFORMATION ProcessInformation;
|
||
|
||
dwLastError = 0;
|
||
|
||
// CreateProcess* APIs require an editable buffer for command-line parameter
|
||
ASSERT(_tcslen(pCommandLine) < 255);
|
||
_tcscpy(szCommandLine, pCommandLine);
|
||
|
||
// Fill in the STARTUPINFO structure.
|
||
memset(&si, 0x0, sizeof(STARTUPINFO));
|
||
si.cb = sizeof(STARTUPINFO);
|
||
si.lpReserved = NULL;
|
||
si.lpTitle = NULL;
|
||
si.lpDesktop = NULL;
|
||
si.dwX = 0x0;
|
||
si.dwY = 0x0;
|
||
si.dwXSize = 0x0;
|
||
si.dwYSize = 0x0;
|
||
si.dwFlags = 0x0;
|
||
si.wShowWindow = SW_SHOW;
|
||
si.lpReserved2 = NULL;
|
||
si.cbReserved2 = 0;
|
||
|
||
LogMessage((SENSLOGN "[%d] Launching OneStop...\n", GetTickCount()));
|
||
#if !defined(SENS_CHICAGO)
|
||
if (CreateProcessAsUser(
|
||
hToken, // Handle to the Token of the logged-on user
|
||
#else // SENS_CHICAGO
|
||
if (CreateProcess(
|
||
#endif // SENS_CHICAGO
|
||
NULL, // Name of the executable module
|
||
szCommandLine, // Command-line string
|
||
NULL, // Security attributes
|
||
NULL, // Thread security attributes
|
||
FALSE, // Don't inherit handles
|
||
0, // Creation flags
|
||
NULL, // New environment block
|
||
NULL, // Current directory name
|
||
&si, // Startup info
|
||
&ProcessInformation // Process information
|
||
))
|
||
{
|
||
//
|
||
// Wait until the process terminates
|
||
//
|
||
if (bSync)
|
||
{
|
||
LogMessage((SENSLOGN "[%d] Waiting for OneStop to return...\n", GetTickCount()));
|
||
WaitForSingleObject(ProcessInformation.hProcess, INFINITE);
|
||
LogMessage((SENSLOGN "[%d] OneStop returned successfully.\n", GetTickCount()));
|
||
}
|
||
|
||
CloseHandle(ProcessInformation.hProcess);
|
||
CloseHandle(ProcessInformation.hThread);
|
||
|
||
return S_OK;
|
||
}
|
||
else
|
||
{
|
||
dwLastError = GetLastError();
|
||
SensPrintToDebugger(SENS_DBG, (SENSLOGN "SensNotifyOneStop() - CreateProcessXXX() "
|
||
"failed with 0x%x\n", dwLastError));
|
||
return HRESULT_FROM_WIN32(dwLastError);
|
||
}
|
||
|
||
LogMessage((SENSLOGN "[%d] Successfully notified OneStop.\n", GetTickCount()));
|
||
|
||
return S_OK;
|
||
}
|
||
|
||
|
||
|
||
|
||
BOOL
|
||
IsAutoSyncEnabled(
|
||
HANDLE hToken,
|
||
DWORD dwMask
|
||
)
|
||
{
|
||
HKEY hKeyAutoSync;
|
||
LONG lResult;
|
||
BOOL bEnabled;
|
||
BOOL bImpersonated;
|
||
DWORD dwType;
|
||
DWORD dwAutoSyncFlags;
|
||
DWORD cbData;
|
||
LPBYTE lpbData;
|
||
|
||
hKeyAutoSync = NULL;
|
||
lResult = 0;
|
||
bEnabled = FALSE;
|
||
bImpersonated = FALSE;
|
||
dwType = 0x0;
|
||
dwAutoSyncFlags = 0x0;
|
||
cbData = 0x0;
|
||
lpbData = NULL;
|
||
|
||
//
|
||
// Impersonate the Logged on user so that we can access the user-specific
|
||
// registry entries.
|
||
//
|
||
#if !defined(SENS_CHICAGO)
|
||
|
||
bImpersonated = ImpersonateLoggedOnUser(hToken);
|
||
if (bImpersonated == FALSE)
|
||
{
|
||
LogMessage((SENSLOGN "ImpersonateLoggedOnUser(token = 0x%x) failed - "
|
||
"0x%x\n", hToken, GetLastError()));
|
||
}
|
||
else
|
||
{
|
||
LogMessage((SENSLOGN "ImpersonateLoggedUser() succeeded!\n"));
|
||
}
|
||
|
||
#endif // SENS_CHICAGO
|
||
|
||
//
|
||
// Open AutoSync sub-key for this user.
|
||
//
|
||
lResult = RegOpenKeyEx(
|
||
HKEY_LOCAL_MACHINE, // Handle of the open Key
|
||
AUTOSYNC_KEY, // Name of the sub-key
|
||
0, // Reserved (MBZ)
|
||
KEY_QUERY_VALUE, // Security access mask
|
||
&hKeyAutoSync // Address of the handle of new key
|
||
);
|
||
if (lResult != ERROR_SUCCESS)
|
||
{
|
||
SensPrintToDebugger(SENS_DBG, (SENSLOGN "RegOpenKeyEx(AUTOSYNC) failed with 0x%x\n", lResult));
|
||
goto Cleanup;
|
||
}
|
||
|
||
//
|
||
// Query the Flags value
|
||
//
|
||
lpbData = (LPBYTE) &dwAutoSyncFlags;
|
||
cbData = sizeof(DWORD);
|
||
|
||
lResult = RegQueryValueEx(
|
||
hKeyAutoSync, // Handle of the sub-key
|
||
AUTOSYNC_FLAGS, // Name of the Value
|
||
NULL, // Reserved (MBZ)
|
||
&dwType, // Address of the type of the Value
|
||
lpbData, // Address of the data of the Value
|
||
&cbData // Address of size of data of the Value
|
||
);
|
||
if (lResult != ERROR_SUCCESS)
|
||
{
|
||
LogMessage((SENSLOGN "RegQueryValueEx(AUTOSYNC_FLAGS) failed with 0x%x\n", lResult));
|
||
goto Cleanup;
|
||
}
|
||
ASSERT(dwType == REG_DWORD);
|
||
|
||
//
|
||
// Check to see if the Mask bit is set
|
||
//
|
||
if (dwMask == AUTOSYNC_ON_STARTSHELL)
|
||
{
|
||
if ( (dwAutoSyncFlags & AUTOSYNC_LAN_LOGON)
|
||
|| (dwAutoSyncFlags & AUTOSYNC_WAN_LOGON))
|
||
{
|
||
LogMessage((SENSLOGN "AutoSync is enabled for StartShell\n"));
|
||
bEnabled = TRUE;
|
||
goto Cleanup;
|
||
}
|
||
else
|
||
{
|
||
LogMessage((SENSLOGN "AutoSync is NOT enabled for Logon\n"));
|
||
}
|
||
}
|
||
else
|
||
if (dwMask == AUTOSYNC_ON_LOGOFF)
|
||
{
|
||
if ( (dwAutoSyncFlags & AUTOSYNC_LAN_LOGOFF)
|
||
|| (dwAutoSyncFlags & AUTOSYNC_WAN_LOGOFF))
|
||
{
|
||
LogMessage((SENSLOGN "AutoSync is enabled for Logoff\n"));
|
||
bEnabled = TRUE;
|
||
goto Cleanup;
|
||
}
|
||
else
|
||
{
|
||
LogMessage((SENSLOGN "AutoSync is NOT enabled for Logoff\n"));
|
||
}
|
||
}
|
||
else
|
||
if (dwMask == AUTOSYNC_ON_SCHEDULE)
|
||
{
|
||
if (dwAutoSyncFlags != NULL)
|
||
{
|
||
LogMessage((SENSLOGN "AutoSync is enabled for Schedule\n"));
|
||
bEnabled = TRUE;
|
||
goto Cleanup;
|
||
}
|
||
else
|
||
{
|
||
LogMessage((SENSLOGN "AutoSync is NOT enabled for Schedule\n"));
|
||
}
|
||
}
|
||
|
||
//
|
||
// Autosync is not enabled.
|
||
//
|
||
|
||
|
||
Cleanup:
|
||
//
|
||
// Cleanup
|
||
//
|
||
if (hKeyAutoSync)
|
||
{
|
||
RegCloseKey(hKeyAutoSync);
|
||
}
|
||
|
||
#if !defined(SENS_CHICAGO)
|
||
|
||
// Stop Impersonating
|
||
if (bImpersonated)
|
||
{
|
||
RevertToSelf();
|
||
}
|
||
|
||
#endif // SENS_CHICAGO
|
||
|
||
return bEnabled;
|
||
}
|