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.
6126 lines
175 KiB
6126 lines
175 KiB
//Copyright (c) 1998 - 1999 Microsoft Corporation
|
|
|
|
#include"stdafx.h"
|
|
#include"tsprsht.h"
|
|
#include"resource.h"
|
|
#include"tarray.h"
|
|
#include<tscfgex.h>
|
|
#include<shellapi.h>
|
|
#include <shlobj.h>
|
|
#include <shlobjp.h>
|
|
#include "regapi.h"
|
|
#include <ntsecapi.h>
|
|
|
|
#ifndef NT_SUCCESS
|
|
#define NT_SUCCESS(Status) ((NTSTATUS)(Status) >= 0)
|
|
#endif //NT_SUCCESS
|
|
|
|
#ifndef STATUS_NO_MORE_ENTRIES
|
|
#define STATUS_NO_MORE_ENTRIES ((NTSTATUS)0x8000001AL)
|
|
#endif //STATUS_NO_MORE_ENTRIES
|
|
|
|
#ifndef STATUS_SUCCESS
|
|
#define STATUS_SUCCESS ((NTSTATUS)0x00000000L)
|
|
#endif //STATUS_SUCCESS
|
|
|
|
void InitLsaString(PLSA_UNICODE_STRING LsaString,LPWSTR String);
|
|
|
|
|
|
void ErrMessage( HWND hwndOwner , INT_PTR iResourceID );
|
|
|
|
void TscAccessDeniedMsg( HWND hwnd );
|
|
|
|
void TscGeneralErrMsg( HWND hwnd );
|
|
|
|
void xxxErrMessage( HWND , INT_PTR , INT_PTR , UINT );
|
|
|
|
void ReportStatusError( HWND hwnd , DWORD dwStatus );
|
|
|
|
DWORD xxxLegacyLogoffCleanup( PSECURITY_DESCRIPTOR *ppSD , PBOOL );
|
|
//extern BOOL g_bEditMode = FALSE;
|
|
|
|
//
|
|
INT_PTR APIENTRY CustomSecurityDlgProc( HWND, UINT, WPARAM, LPARAM );
|
|
|
|
extern void EnableGroup( HWND hParent , LPINT rgID , BOOL bEnable );
|
|
|
|
//-----------------------------------------------------------------------------
|
|
typedef enum _AcluiApiIndex
|
|
{
|
|
ACLUI_CREATE_PAGE = 0,
|
|
ACLUI_EDIT_SECURITY
|
|
};
|
|
|
|
//-----------------------------------------------------------------------------
|
|
typedef struct _DLL_FUNCTIONS
|
|
{
|
|
LPCSTR pcstrFunctionName;
|
|
LPVOID lpfnFunction;
|
|
HINSTANCE hInst;
|
|
|
|
} DLL_FUNCTIONS;
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// not subject to localization
|
|
//-----------------------------------------------------------------------------
|
|
static DLL_FUNCTIONS g_aAclFunctions[] =
|
|
{
|
|
"CreateSecurityPage", NULL, NULL ,
|
|
NULL , NULL , NULL
|
|
};
|
|
|
|
|
|
|
|
//-----------------------------------------------------------------------------
|
|
CPropsheet::CPropsheet( )
|
|
{
|
|
m_cref = 0;
|
|
|
|
m_hNotify = 0;
|
|
|
|
m_pResNode = NULL;
|
|
|
|
m_bGotUC = FALSE;
|
|
|
|
m_puc = NULL;
|
|
|
|
m_bPropertiesChange = FALSE;
|
|
|
|
m_hMMCWindow = NULL;
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
int CPropsheet::AddRef( )
|
|
{
|
|
DBGMSG( L"Propsheet Refcount at %d\n", ( m_cref + 1 ) );
|
|
|
|
return InterlockedIncrement( ( LPLONG )&m_cref );
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// called before the destructor
|
|
//-----------------------------------------------------------------------------
|
|
void CPropsheet::PreDestruct( )
|
|
{
|
|
ICfgComp *pCfgcomp = NULL;
|
|
|
|
if( m_bPropertiesChange )
|
|
{
|
|
// check to see if any users are logged on
|
|
|
|
LONG lCount;
|
|
|
|
if( m_pResNode->GetServer( &pCfgcomp ) > 0 )
|
|
{
|
|
if( SUCCEEDED( pCfgcomp->QueryLoggedOnCount( m_pResNode->GetConName( ) , &lCount ) ) )
|
|
{
|
|
TCHAR tchTitle[ 80 ];
|
|
|
|
TCHAR tchMessage[ 256 ];
|
|
|
|
TCHAR tchBuffer[ 336 ];
|
|
|
|
UINT nFlags = MB_OK | MB_ICONINFORMATION;
|
|
|
|
VERIFY_E( 0 , LoadString( _Module.GetResourceInstance( ) , IDS_TERMSERPROP , tchTitle , SIZE_OF_BUFFER( tchTitle ) ) );
|
|
|
|
if( lCount > 0 )
|
|
{
|
|
// Notify user that settings will not affect connected users
|
|
|
|
if( lCount == 1 )
|
|
{
|
|
VERIFY_E( 0 , LoadString( _Module.GetResourceInstance( ) , IDS_PROPCHANGE_WRN , tchMessage , SIZE_OF_BUFFER( tchMessage ) ) );
|
|
}
|
|
else if( lCount > 1 )
|
|
{
|
|
VERIFY_E( 0 , LoadString( _Module.GetResourceInstance( ) , IDS_PROPCHANGE_WRN_2, tchMessage , SIZE_OF_BUFFER( tchMessage ) ) );
|
|
|
|
wsprintf( tchBuffer , tchMessage , m_pResNode->GetConName( ) );
|
|
}
|
|
|
|
wsprintf( tchBuffer , tchMessage , m_pResNode->GetConName( ) );
|
|
|
|
if( m_hMMCWindow == NULL )
|
|
{
|
|
nFlags |= MB_TASKMODAL;
|
|
}
|
|
|
|
MessageBox( m_hMMCWindow , tchBuffer , tchTitle , MB_OK | MB_ICONINFORMATION );
|
|
}
|
|
}
|
|
|
|
pCfgcomp->Release( );
|
|
}
|
|
|
|
}
|
|
|
|
if( m_puc != NULL )
|
|
{
|
|
CoTaskMemFree( m_puc );
|
|
}
|
|
|
|
// FreeStrings( );
|
|
|
|
g_aAclFunctions[ ACLUI_CREATE_PAGE ].lpfnFunction = NULL;
|
|
|
|
for( INT x = 0; x < NUM_OF_PRSHT ; ++x )
|
|
{
|
|
if( m_pDlg[ x ] != NULL )
|
|
{
|
|
delete[] m_pDlg[x];
|
|
}
|
|
}
|
|
|
|
m_pResNode->m_bEditMode = FALSE;
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
int CPropsheet::Release( )
|
|
{
|
|
if( InterlockedDecrement( ( LPLONG )&m_cref ) == 0 )
|
|
{
|
|
MMCFreeNotifyHandle( m_hNotify );
|
|
|
|
ODS( L"Propsheet Released\n" );
|
|
|
|
PreDestruct( );
|
|
|
|
delete this;
|
|
|
|
return 0;
|
|
}
|
|
|
|
DBGMSG( L"Propsheet Refcount at %d\n", m_cref );
|
|
|
|
return m_cref;
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
HRESULT CPropsheet::InitDialogs( HWND hMMC , LPPROPERTYSHEETCALLBACK pPsc , CResultNode *pResNode , LONG_PTR lNotifyHandle )
|
|
{
|
|
PROPSHEETPAGE psp;
|
|
|
|
if( pPsc == NULL || pResNode == NULL )
|
|
{
|
|
return E_INVALIDARG;
|
|
}
|
|
|
|
m_pResNode = pResNode;
|
|
|
|
m_hNotify = lNotifyHandle;
|
|
|
|
BOOL bAlloc = FALSE;
|
|
|
|
m_hMMCWindow = hMMC;
|
|
|
|
m_pResNode->m_bEditMode = TRUE;
|
|
|
|
// init array
|
|
|
|
for( int x = 0; x < NUM_OF_PRSHT; x++ )
|
|
{
|
|
m_pDlg[ x ] = NULL;
|
|
}
|
|
|
|
do
|
|
{
|
|
m_pDlg[ 0 ] = ( CDialogPropBase * )new CGeneral( this );
|
|
|
|
if( m_pDlg[ 0 ] == NULL )
|
|
{
|
|
ODS( L"CGeneral object allocation failed @ CPropsheet::InitDialogs\n" );
|
|
|
|
break;
|
|
}
|
|
|
|
m_pDlg[ 1 ] = ( CDialogPropBase * )new CLogonSetting( this );
|
|
|
|
if( m_pDlg[ 1 ] == NULL )
|
|
{
|
|
ODS( L"CLogonSetting object allocation failed @ CPropsheet::InitDialogs\n" );
|
|
|
|
break;
|
|
}
|
|
|
|
m_pDlg[ 2 ] = ( CDialogPropBase * )new CTimeSetting( this );
|
|
|
|
if( m_pDlg[ 2 ] == NULL )
|
|
{
|
|
ODS( L"CTimeSetting object allocation failed @ CPropsheet::InitDialogs\n" );
|
|
|
|
break;
|
|
}
|
|
|
|
// m_pDlg[ 3 ] = ( CDialogPropBase * )new CPerm( this );
|
|
|
|
m_pDlg[ 3 ] = ( CDialogPropBase * )new CEnviro( this );
|
|
|
|
if( m_pDlg[ 3 ] == NULL )
|
|
{
|
|
ODS( L"CEnviro object allocation failed @ CPropsheet::InitDialogs\n" );
|
|
|
|
break;
|
|
}
|
|
|
|
m_pDlg[ 4 ] = ( CDialogPropBase * )new CRemote( this );
|
|
|
|
if( m_pDlg[ 4 ] == NULL )
|
|
{
|
|
ODS( L"CRemote object allocation failed @ CPropsheet::InitDialogs\n" );
|
|
|
|
break;
|
|
}
|
|
|
|
m_pDlg[ 5 ] = ( CDialogPropBase * )new CClient( this );
|
|
|
|
if( m_pDlg[ 5 ] == NULL )
|
|
{
|
|
ODS( L"CClient object allocation failed @ CPropsheet::InitDialogs\n" );
|
|
|
|
break;
|
|
}
|
|
|
|
m_pDlg[ 6 ] = ( CDialogPropBase * )new CTransNetwork( this );
|
|
|
|
if( m_pDlg[ 6 ] == NULL )
|
|
{
|
|
ODS( L"CTransNetwork object allocation failed @ CPropsheet::InitDialogs\n" );
|
|
|
|
break;
|
|
}
|
|
|
|
m_pDlg[ 7 ] = ( CDialogPropBase * )new CTransAsync( this );
|
|
|
|
if( m_pDlg[ 7 ] == NULL )
|
|
{
|
|
ODS( L"CTransAsync object allocation failed @ CPropsheet::InitDialogs\n" );
|
|
|
|
break;
|
|
}
|
|
|
|
bAlloc = TRUE;
|
|
|
|
}while( 0 );
|
|
|
|
if( !bAlloc )
|
|
{
|
|
// try cleaning up before leaving
|
|
|
|
for( x = 0; x < NUM_OF_PRSHT ; ++x )
|
|
{
|
|
if( m_pDlg[ x ] != NULL )
|
|
{
|
|
delete[] m_pDlg[x];
|
|
}
|
|
}
|
|
|
|
return E_OUTOFMEMORY;
|
|
}
|
|
|
|
for( int idx = 0; idx < 5; ++idx )
|
|
{
|
|
if( m_pDlg[ idx ] != NULL )
|
|
{
|
|
if( !m_pDlg[ idx ]->GetPropertySheetPage( psp ) )
|
|
{
|
|
return E_UNEXPECTED;
|
|
}
|
|
|
|
if( FAILED( pPsc->AddPage( CreatePropertySheetPage( &psp ) ) ) )
|
|
{
|
|
return E_FAIL;
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
HRESULT hr = E_FAIL;
|
|
|
|
if( m_pResNode != NULL )
|
|
{
|
|
ICfgComp *pCfgcomp = NULL;
|
|
|
|
PWS pWinsta = NULL;
|
|
|
|
// don't fail here third party vendor may want to use their own page
|
|
|
|
if( m_pResNode->GetServer( &pCfgcomp ) > 0 )
|
|
{
|
|
LONG cbSize;
|
|
|
|
hr = pCfgcomp->GetWSInfo( m_pResNode->GetConName( ) , &cbSize , &pWinsta );
|
|
|
|
if( SUCCEEDED( hr ) )
|
|
{
|
|
CDialogPropBase *pDlg = NULL;
|
|
|
|
CDialogPropBase *pDlgClientSettings = m_pDlg[ 5 ]; // client settings
|
|
|
|
if( pWinsta->PdClass == SdNetwork )
|
|
{
|
|
pDlg = m_pDlg[ 6 ];
|
|
}
|
|
else if( pWinsta->PdClass == SdAsync )
|
|
{
|
|
pDlg = m_pDlg[ 7 ];
|
|
}
|
|
|
|
if( pDlg != NULL )
|
|
{
|
|
if( !pDlgClientSettings->GetPropertySheetPage( psp ) )
|
|
{
|
|
ODS( L"Client settings page failed to load\n" );
|
|
|
|
hr = E_UNEXPECTED;
|
|
}
|
|
|
|
if( SUCCEEDED( hr ) )
|
|
{
|
|
hr = pPsc->AddPage( CreatePropertySheetPage( &psp ) );
|
|
|
|
}
|
|
|
|
if( SUCCEEDED( hr ) )
|
|
{
|
|
if( !pDlg->GetPropertySheetPage( psp ) )
|
|
{
|
|
ODS( L"Transport page failed to load\n" );
|
|
|
|
hr = E_UNEXPECTED;
|
|
}
|
|
}
|
|
|
|
if( SUCCEEDED( hr ) )
|
|
{
|
|
hr = pPsc->AddPage( CreatePropertySheetPage( &psp ) );
|
|
}
|
|
}
|
|
|
|
CoTaskMemFree( pWinsta );
|
|
|
|
}
|
|
|
|
pCfgcomp->Release();
|
|
}
|
|
}
|
|
|
|
if( SUCCEEDED( hr ) )
|
|
{
|
|
hr = pPsc->AddPage( GetSecurityPropertyPage( this ) );
|
|
}
|
|
|
|
return hr;
|
|
|
|
}
|
|
|
|
//The UC structure will contain data from a merger between the TSCC data and the machine policy data. We
|
|
//don't want all that written to the TSCC data though. If there's a machine policy for a given field, we
|
|
//want to replace its data with the data that currently exists in the TSCC section of the registry
|
|
BOOL CPropsheet::ExcludeMachinePolicySettings(USERCONFIG& uc)
|
|
{
|
|
POLICY_TS_MACHINE p;
|
|
RegGetMachinePolicy(&p);
|
|
USERCONFIG origUC;
|
|
|
|
//The default is to call GetUserConfig with a TRUE merge
|
|
//parameter, so we have to do that before we can call
|
|
//GetCurrentUserConfig which just returns the cached USERCONFIG structure
|
|
if (!GetUserConfig(FALSE))
|
|
return FALSE;
|
|
if (!GetCurrentUserConfig(origUC, FALSE))
|
|
return FALSE;
|
|
//We have to do this so that the cached USERCONFIG structure
|
|
//will again have the expected (merged) data
|
|
if (!GetUserConfig(TRUE))
|
|
return FALSE;
|
|
|
|
//CRemote fields
|
|
if (p.fPolicyShadow)
|
|
{
|
|
uc.fInheritShadow = origUC.fInheritShadow;
|
|
uc.Shadow = origUC.Shadow;
|
|
}
|
|
|
|
//CEnviro fields
|
|
if (p.fPolicyInitialProgram)
|
|
{
|
|
uc.fInheritInitialProgram = origUC.fInheritInitialProgram;
|
|
wcscpy(uc.InitialProgram, origUC.InitialProgram);
|
|
wcscpy(uc.WorkDirectory, origUC.WorkDirectory);
|
|
}
|
|
|
|
//CClient fields
|
|
if (p.fPolicyColorDepth)
|
|
{
|
|
uc.fInheritColorDepth = origUC.fInheritColorDepth;
|
|
uc.ColorDepth = origUC.ColorDepth;
|
|
}
|
|
|
|
if (p.fPolicyForceClientLptDef)
|
|
uc.fForceClientLptDef = origUC.fForceClientLptDef;
|
|
|
|
if (p.fPolicyDisableCdm)
|
|
uc.fDisableCdm = origUC.fDisableCdm;
|
|
|
|
if (p.fPolicyDisableCpm)
|
|
uc.fDisableCpm = origUC.fDisableCpm;
|
|
|
|
if (p.fPolicyDisableLPT)
|
|
uc.fDisableLPT = origUC.fDisableLPT;
|
|
|
|
if (p.fPolicyDisableCcm)
|
|
uc.fDisableCcm = origUC.fDisableCcm;
|
|
|
|
if (p.fPolicyDisableClip)
|
|
uc.fDisableClip = origUC.fDisableClip;
|
|
|
|
if (p.fPolicyDisableCam)
|
|
uc.fDisableCam = origUC.fDisableCam;
|
|
|
|
//CLogonSetting fields
|
|
if (p.fPolicyPromptForPassword)
|
|
uc.fPromptForPassword = origUC.fPromptForPassword;
|
|
|
|
//CGeneral fields
|
|
if (p.fPolicyMinEncryptionLevel)
|
|
uc.MinEncryptionLevel = origUC.MinEncryptionLevel;
|
|
|
|
//CTimeSetting fields
|
|
if (p.fPolicyMaxSessionTime)
|
|
uc.MaxConnectionTime = origUC.MaxConnectionTime;
|
|
|
|
if (p.fPolicyMaxDisconnectionTime)
|
|
uc.MaxDisconnectionTime = origUC.MaxDisconnectionTime;
|
|
|
|
if (p.fPolicyMaxIdleTime)
|
|
uc.MaxIdleTime = origUC.MaxIdleTime;
|
|
|
|
if (p.fPolicyResetBroken)
|
|
uc.fResetBroken = origUC.fResetBroken;
|
|
|
|
if (p.fPolicyReconnectSame)
|
|
uc.fReconnectSame = origUC.fReconnectSame;
|
|
|
|
if (p.fPolicyMaxSessionTime || p.fPolicyMaxDisconnectionTime || p.fPolicyMaxIdleTime)
|
|
uc.fInheritMaxSessionTime = origUC.fInheritMaxSessionTime;
|
|
|
|
if (p.fPolicyResetBroken)
|
|
uc.fInheritResetBroken = origUC.fInheritResetBroken;
|
|
|
|
if (p.fPolicyReconnectSame)
|
|
uc.fInheritReconnectSame = origUC.fInheritReconnectSame;
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
|
|
|
|
//-------------------------------------------------------------------------------
|
|
// Use custom interface to persist uc to winstation
|
|
//-------------------------------------------------------------------------------
|
|
HRESULT CPropsheet::SetUserConfig( USERCONFIG& uc , PDWORD pdwStatus )
|
|
{
|
|
ICfgComp *pCfgcomp;
|
|
|
|
*pdwStatus = ERROR_INVALID_PARAMETER;
|
|
|
|
if( m_pResNode == NULL )
|
|
return E_FAIL;
|
|
|
|
if( m_pResNode->GetServer( &pCfgcomp ) == 0 )
|
|
return E_FAIL;
|
|
|
|
if (!ExcludeMachinePolicySettings(uc))
|
|
return E_FAIL;
|
|
|
|
HRESULT hr = pCfgcomp->SetUserConfig( m_pResNode->GetConName( ) , 0, &uc , pdwStatus );
|
|
|
|
if( SUCCEEDED( hr ) )
|
|
{
|
|
m_bGotUC = FALSE;
|
|
}
|
|
|
|
|
|
pCfgcomp->Release( );
|
|
|
|
return hr;
|
|
|
|
}
|
|
|
|
//-------------------------------------------------------------------------------
|
|
// Use custom interface to obtain the winstation userconfig
|
|
// store it in m_puc -- and return t | f
|
|
//-------------------------------------------------------------------------------
|
|
BOOL CPropsheet::GetUserConfig(BOOLEAN bPerformMerger)
|
|
{
|
|
ICfgComp *pCfgcomp;
|
|
|
|
if( m_pResNode == NULL )
|
|
{
|
|
return FALSE;
|
|
}
|
|
|
|
if( m_pResNode->GetServer( &pCfgcomp ) == 0 )
|
|
{
|
|
return FALSE;
|
|
}
|
|
|
|
LONG lSzReqd;
|
|
|
|
if( m_puc != NULL )
|
|
{
|
|
CoTaskMemFree( m_puc );
|
|
|
|
m_puc = NULL;
|
|
}
|
|
|
|
HRESULT hr = pCfgcomp->GetUserConfig( m_pResNode->GetConName( ) , &lSzReqd , &m_puc, bPerformMerger );
|
|
|
|
if( FAILED( hr ) )
|
|
{
|
|
hr = pCfgcomp->GetDefaultUserConfig( m_pResNode->GetConName( ) , &lSzReqd , &m_puc );
|
|
}
|
|
|
|
pCfgcomp->Release( );
|
|
|
|
return ( FAILED( hr ) ? FALSE: TRUE );
|
|
|
|
}
|
|
|
|
//-------------------------------------------------------------------------------
|
|
// Cache the uc
|
|
//-------------------------------------------------------------------------------
|
|
BOOL CPropsheet::GetCurrentUserConfig( USERCONFIG& uc, BOOLEAN bPerformMerger )
|
|
{
|
|
if( !m_bGotUC )
|
|
{
|
|
m_bGotUC = GetUserConfig(bPerformMerger);
|
|
}
|
|
|
|
if( m_puc != NULL )
|
|
{
|
|
uc = *m_puc;
|
|
}
|
|
|
|
return m_bGotUC;
|
|
}
|
|
|
|
//*******************************************************************************
|
|
//-------------------------------------------------------------------------------
|
|
// OnNotify - base class method
|
|
//-------------------------------------------------------------------------------
|
|
BOOL CDialogPropBase::OnNotify( int idCtrl , LPNMHDR pnmh , HWND hDlg )
|
|
{
|
|
UNREFERENCED_PARAMETER( idCtrl );
|
|
|
|
if( pnmh->code == PSN_APPLY )
|
|
{
|
|
if( !m_bPersisted )
|
|
{
|
|
m_bPersisted = PersistSettings( hDlg );
|
|
}
|
|
}
|
|
|
|
else if( pnmh->code == PSN_KILLACTIVE )
|
|
{
|
|
if( !m_bPersisted )
|
|
{
|
|
if( !IsValidSettings( hDlg ) )
|
|
{
|
|
SetWindowLongPtr( hDlg , DWLP_MSGRESULT , PSNRET_INVALID_NOCHANGEPAGE );
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
}
|
|
}
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
//-------------------------------------------------------------------------------
|
|
// OnCOntextMenu -- base class operation
|
|
//-------------------------------------------------------------------------------
|
|
BOOL CDialogPropBase::OnContextMenu( HWND hwnd , POINT& pt )
|
|
{
|
|
UNREFERENCED_PARAMETER( pt );
|
|
|
|
TCHAR tchHelpFile[ MAX_PATH ];
|
|
|
|
ODS( L"CDialogPropBase::OnContextMenu\n" );
|
|
|
|
if( m_hWnd == GetParent( hwnd ) )
|
|
{
|
|
//
|
|
// Make sure its not a dummy window
|
|
//
|
|
|
|
if( GetDlgCtrlID( hwnd ) <= ( int )-1 )
|
|
{
|
|
return FALSE;
|
|
}
|
|
|
|
ULONG_PTR rgdw[ 2 ];
|
|
|
|
rgdw[ 0 ] = GetDlgCtrlID( hwnd );
|
|
|
|
rgdw[ 1 ] = GetWindowContextHelpId( hwnd );
|
|
|
|
LoadString( _Module.GetModuleInstance( ) , IDS_HELPFILE , tchHelpFile , SIZE_OF_BUFFER( tchHelpFile ) );
|
|
|
|
WinHelp( hwnd , tchHelpFile , HELP_CONTEXTMENU , ( ULONG_PTR )&rgdw );
|
|
|
|
}
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
//-------------------------------------------------------------------------------
|
|
// Each control has a helpid assign to them. Some controls share the same topic
|
|
// check for these.
|
|
//-------------------------------------------------------------------------------
|
|
BOOL CDialogPropBase::OnHelp( HWND hwnd , LPHELPINFO lphi )
|
|
{
|
|
UNREFERENCED_PARAMETER( hwnd );
|
|
|
|
TCHAR tchHelpFile[ MAX_PATH ];
|
|
|
|
//
|
|
// For the information to winhelp api
|
|
//
|
|
|
|
if( IsBadReadPtr( lphi , sizeof( HELPINFO ) ) )
|
|
{
|
|
return FALSE;
|
|
}
|
|
|
|
if( (short)lphi->iCtrlId <= -1 )
|
|
{
|
|
return FALSE;
|
|
}
|
|
|
|
LoadString( _Module.GetModuleInstance( ) , IDS_HELPFILE , tchHelpFile , SIZE_OF_BUFFER( tchHelpFile ) );
|
|
|
|
DWORD rgdw[ 4 ] = {0,0,0,0};
|
|
|
|
rgdw[ 0 ] = ( DWORD )lphi->iCtrlId;
|
|
|
|
rgdw[ 1 ] = ( DWORD )lphi->dwContextId;
|
|
|
|
WinHelp( ( HWND )lphi->hItemHandle , tchHelpFile , HELP_WM_HELP , ( ULONG_PTR )&rgdw );//lphi->dwContextId );
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
//*****************************************************************************
|
|
// General dialog
|
|
|
|
CGeneral::CGeneral( CPropsheet *pSheet )
|
|
{
|
|
m_pParent = pSheet;
|
|
|
|
m_pEncrypt = NULL;
|
|
|
|
m_DefaultEncryptionLevelIndex = 0;
|
|
|
|
m_nOldSel = ( INT_PTR )-1;
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
BOOL CGeneral::OnInitDialog( HWND hDlg , WPARAM wp , LPARAM lp )
|
|
{
|
|
if( m_pParent == NULL )
|
|
{
|
|
ODS( L"CGeneral::OnInitDialog - PropertySheet: Parent object lost!!!\n" );
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
m_pParent->AddRef( );
|
|
|
|
USERCONFIG uc;
|
|
|
|
ZeroMemory( &uc , sizeof( USERCONFIG ) );
|
|
|
|
if( !m_pParent->GetCurrentUserConfig( uc, TRUE ) )
|
|
{
|
|
ODS( L"CGeneral::OnInitDialog - PropertySheet: GetCurrentUserConfig failed!!!\n" );
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
// Security
|
|
|
|
SendMessage( GetDlgItem( hDlg , IDC_CHECK_GEN_AUTHEN ) , BM_SETCHECK , ( WPARAM )uc.fUseDefaultGina , 0 );
|
|
|
|
// Network Transport
|
|
|
|
if( m_pParent->m_pResNode == NULL )
|
|
{
|
|
return FALSE;
|
|
}
|
|
|
|
ICfgComp *pCfgcomp;
|
|
|
|
ULONG cbSize = 0;
|
|
|
|
ULONG ulItems = 0;
|
|
|
|
do
|
|
{
|
|
if( m_pParent->m_pResNode->GetServer( &pCfgcomp ) == 0 )
|
|
{
|
|
break;
|
|
}
|
|
|
|
// Set Connection name
|
|
|
|
SetWindowText( GetDlgItem( hDlg , IDC_STATIC_CONNAME ) , m_pParent->m_pResNode->GetConName( ) );
|
|
|
|
PWS pWinSta = NULL;
|
|
|
|
if( SUCCEEDED( pCfgcomp->GetWSInfo( m_pParent->m_pResNode->GetConName( ) , ( PLONG )&cbSize , &pWinSta ) ) )
|
|
{
|
|
|
|
SendMessage( GetDlgItem( hDlg , IDC_EDIT_GEN_COMMENT ) , EM_SETLIMITTEXT , ( WPARAM )WINSTATIONCOMMENT_LENGTH , 0 );
|
|
|
|
SetWindowText( GetDlgItem( hDlg , IDC_EDIT_GEN_COMMENT ) , pWinSta->Comment );
|
|
|
|
//m_pParent->m_pResNode->GetComment( ) );
|
|
|
|
SetWindowText( GetDlgItem( hDlg , IDC_STATIC_GEN_TYPE ) , m_pParent->m_pResNode->GetTypeName( ) );
|
|
|
|
SetWindowText( GetDlgItem( hDlg , IDC_EDIT_GENERAL_TRANSPORT ) , pWinSta->pdName );
|
|
|
|
// security
|
|
|
|
// Encryption *pEncrypt;
|
|
|
|
if( SUCCEEDED( pCfgcomp->GetEncryptionLevels( m_pParent->m_pResNode->GetConName( ) , WsName , &ulItems , &m_pEncrypt ) ) )
|
|
{
|
|
BOOL bSet = FALSE;
|
|
|
|
for( ULONG i = 0; i < ulItems; ++i )
|
|
{
|
|
SendMessage( GetDlgItem( hDlg , IDC_COMBO_GEN_ENCRYPT ) , CB_ADDSTRING , 0 , ( LPARAM )m_pEncrypt[ i ].szLevel );
|
|
if(m_pEncrypt[ i ].Flags & ELF_DEFAULT)
|
|
{
|
|
m_DefaultEncryptionLevelIndex = i;
|
|
}
|
|
|
|
if( uc.MinEncryptionLevel == m_pEncrypt[ i ].RegistryValue )
|
|
{
|
|
SendMessage( GetDlgItem( hDlg , IDC_COMBO_GEN_ENCRYPT ) , CB_SETCURSEL , ( WPARAM )i , 0);
|
|
|
|
bSet = TRUE;
|
|
|
|
}
|
|
}
|
|
|
|
POLICY_TS_MACHINE p;
|
|
RegGetMachinePolicy(&p);
|
|
EnableWindow(GetDlgItem(hDlg, IDC_COMBO_GEN_ENCRYPT), !p.fPolicyMinEncryptionLevel);
|
|
|
|
if (p.fPolicyFipsEnabled)
|
|
{
|
|
// FIPS is always the last item in the list so set it as selected
|
|
SendMessage(GetDlgItem(hDlg, IDC_COMBO_GEN_ENCRYPT), CB_SETCURSEL, (WPARAM)ulItems - 1 , 0);
|
|
EnableWindow(GetDlgItem(hDlg, IDC_COMBO_GEN_ENCRYPT), FALSE);
|
|
}
|
|
|
|
if(!bSet)
|
|
{
|
|
uc.MinEncryptionLevel = (UCHAR)(m_pEncrypt[m_DefaultEncryptionLevelIndex].RegistryValue);
|
|
|
|
SendMessage( GetDlgItem( hDlg , IDC_COMBO_GEN_ENCRYPT ) , CB_SETCURSEL , ( WPARAM )m_DefaultEncryptionLevelIndex, 0 );
|
|
}
|
|
|
|
OnCommand( CBN_SELCHANGE , IDC_COMBO_GEN_ENCRYPT , GetDlgItem( hDlg , IDC_COMBO_GEN_ENCRYPT ) );
|
|
|
|
if( !IsWindowEnabled( GetDlgItem( hDlg , IDC_STATIC_GEN_DESCR ) ) )
|
|
{
|
|
RECT rc;
|
|
RECT rc2;
|
|
|
|
GetWindowRect( GetDlgItem( hDlg , IDC_STATIC_CONGRP ) , &rc );
|
|
|
|
GetWindowRect( GetDlgItem( hDlg , IDC_STATIC_GEN_DESCR ) , &rc2 );
|
|
|
|
rc.bottom = rc2.top;
|
|
|
|
MapWindowPoints( NULL , hDlg , ( LPPOINT )&rc , 2 );
|
|
|
|
SetWindowPos( GetDlgItem( hDlg , IDC_STATIC_CONGRP ) , 0 , 0 , 0 , rc.right - rc.left , rc.bottom - rc.top , SWP_NOMOVE | SWP_SHOWWINDOW );
|
|
|
|
|
|
//resize window
|
|
}
|
|
}
|
|
else
|
|
{
|
|
// no encryption info insert value to none and grey out the control
|
|
TCHAR tchNone[ 80 ];
|
|
|
|
LoadString( _Module.GetResourceInstance( ) , IDS_NONE , tchNone , SIZE_OF_BUFFER( tchNone ) );
|
|
|
|
SendMessage( GetDlgItem( hDlg , IDC_COMBO_GEN_ENCRYPT ) , CB_ADDSTRING , 0 , ( LPARAM )tchNone );
|
|
|
|
SendMessage( GetDlgItem( hDlg , IDC_COMBO_GEN_ENCRYPT ) , CB_SETCURSEL , 0 , 0 );
|
|
|
|
EnableWindow( GetDlgItem( hDlg , IDC_COMBO_GEN_ENCRYPT ) , FALSE );
|
|
|
|
EnableWindow( GetDlgItem( hDlg , IDC_STATIC_CONGRP ) , FALSE );
|
|
}
|
|
|
|
CoTaskMemFree( pWinSta );
|
|
}
|
|
|
|
// check to see if session is readonly
|
|
|
|
BOOL bReadOnly;
|
|
|
|
if( SUCCEEDED( pCfgcomp->IsSessionReadOnly( &bReadOnly ) ) )
|
|
{
|
|
if( bReadOnly )
|
|
{
|
|
// make edit controls read-only
|
|
|
|
SendMessage( GetDlgItem( hDlg , IDC_EDIT_GEN_COMMENT ) , EM_SETREADONLY , ( WPARAM )TRUE , 0 );
|
|
|
|
// disable the remaining controls
|
|
INT rgIds[] = { IDC_CHECK_GEN_AUTHEN , IDC_STATIC_CONGRP, IDC_COMBO_GEN_ENCRYPT , -1 };
|
|
|
|
EnableGroup( hDlg , &rgIds[ 0 ] , FALSE );
|
|
}
|
|
}
|
|
|
|
pCfgcomp->Release( );
|
|
|
|
|
|
}while( 0 );
|
|
|
|
m_bPersisted = TRUE;
|
|
|
|
return CDialogPropBase::OnInitDialog( hDlg , wp , lp );
|
|
}
|
|
|
|
|
|
//-----------------------------------------------------------------------------
|
|
INT_PTR CALLBACK CGeneral::DlgProc( HWND hwnd , UINT msg , WPARAM wp , LPARAM lp )
|
|
{
|
|
CGeneral *pDlg;
|
|
|
|
if( msg == WM_INITDIALOG )
|
|
{
|
|
CGeneral *pDlg = ( CGeneral * )( ( PROPSHEETPAGE *)lp )->lParam ;
|
|
|
|
SetWindowLongPtr( hwnd , DWLP_USER , ( LONG_PTR )pDlg );
|
|
|
|
if( !IsBadReadPtr( pDlg , sizeof( CGeneral ) ) )
|
|
{
|
|
pDlg->OnInitDialog( hwnd , wp , lp );
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
else
|
|
{
|
|
pDlg = ( CGeneral * )GetWindowLongPtr( hwnd , DWLP_USER );
|
|
|
|
if( IsBadReadPtr( pDlg , sizeof( CGeneral ) ) )
|
|
{
|
|
return FALSE;
|
|
}
|
|
}
|
|
|
|
switch( msg )
|
|
{
|
|
|
|
case WM_NCDESTROY:
|
|
|
|
pDlg->OnDestroy( );
|
|
|
|
break;
|
|
|
|
case WM_COMMAND:
|
|
|
|
pDlg->OnCommand( HIWORD( wp ) , LOWORD( wp ) , ( HWND )lp );
|
|
|
|
break;
|
|
|
|
case WM_CONTEXTMENU:
|
|
{
|
|
POINT pt;
|
|
|
|
pt.x = LOWORD( lp );
|
|
|
|
pt.y = HIWORD( lp );
|
|
|
|
pDlg->OnContextMenu( ( HWND )wp , pt );
|
|
}
|
|
|
|
break;
|
|
|
|
case WM_HELP:
|
|
|
|
pDlg->OnHelp( hwnd , ( LPHELPINFO )lp );
|
|
|
|
break;
|
|
|
|
case WM_NOTIFY:
|
|
|
|
return pDlg->OnNotify( ( int )wp , ( LPNMHDR )lp , hwnd );
|
|
}
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
BOOL CGeneral::OnCommand( WORD wNotifyCode , WORD wID , HWND hwndCtrl )
|
|
{
|
|
if( wNotifyCode == BN_CLICKED || wNotifyCode == EN_CHANGE )
|
|
{
|
|
m_bPersisted = FALSE;
|
|
}
|
|
else if( wNotifyCode == CBN_SELCHANGE && wID == IDC_COMBO_GEN_ENCRYPT )
|
|
{
|
|
if( SendMessage( hwndCtrl , CB_GETDROPPEDSTATE , 0 , 0 ) == FALSE )
|
|
{
|
|
INT_PTR nSel = SendMessage( hwndCtrl , CB_GETCURSEL , 0 , 0 );
|
|
|
|
if( nSel != CB_ERR )
|
|
{
|
|
if( nSel != m_nOldSel && m_pEncrypt != NULL )
|
|
{
|
|
if( m_pEncrypt[ nSel ].szDescr[ 0 ] == 0 )
|
|
{
|
|
EnableWindow( GetDlgItem( GetParent( hwndCtrl ) , IDC_STATIC_GEN_DESCRTITLE ) , FALSE );
|
|
|
|
EnableWindow( GetDlgItem( GetParent( hwndCtrl ) , IDC_STATIC_GEN_DESCR ) , FALSE );
|
|
|
|
ShowWindow( GetDlgItem( GetParent( hwndCtrl ) , IDC_STATIC_GEN_DESCRTITLE ) , SW_HIDE );
|
|
|
|
ShowWindow( GetDlgItem( GetParent( hwndCtrl ) , IDC_STATIC_GEN_DESCR ) , SW_HIDE );
|
|
}
|
|
else
|
|
{
|
|
ShowWindow( GetDlgItem( GetParent( hwndCtrl ) , IDC_STATIC_GEN_DESCRTITLE ) , SW_SHOW );
|
|
|
|
ShowWindow( GetDlgItem( GetParent( hwndCtrl ) , IDC_STATIC_GEN_DESCR ) , SW_SHOW );
|
|
|
|
EnableWindow( GetDlgItem( GetParent( hwndCtrl ) , IDC_STATIC_GEN_DESCR ) , TRUE );
|
|
|
|
EnableWindow( GetDlgItem( GetParent( hwndCtrl ) , IDC_STATIC_GEN_DESCRTITLE ) , TRUE );
|
|
|
|
SetWindowText( GetDlgItem( GetParent( hwndCtrl ) , IDC_STATIC_GEN_DESCR ) , m_pEncrypt[ nSel ].szDescr );
|
|
}
|
|
|
|
m_bPersisted = FALSE;
|
|
|
|
m_nOldSel = nSel;
|
|
}
|
|
}
|
|
}
|
|
|
|
}
|
|
else if( wNotifyCode == ALN_APPLY )
|
|
{
|
|
SendMessage( GetParent( hwndCtrl ) , PSM_CANCELTOCLOSE , 0 , 0 );
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
|
|
if( !m_bPersisted )
|
|
{
|
|
SendMessage( GetParent( GetParent( hwndCtrl ) ) , PSM_CHANGED , ( WPARAM )GetParent( hwndCtrl ) , 0 );
|
|
}
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
|
|
//-----------------------------------------------------------------------------
|
|
BOOL CGeneral::GetPropertySheetPage( PROPSHEETPAGE& psp )
|
|
{
|
|
ZeroMemory( &psp , sizeof( PROPSHEETPAGE ) );
|
|
|
|
psp.dwSize = sizeof( PROPSHEETPAGE );
|
|
|
|
psp.dwFlags = PSP_DEFAULT;
|
|
|
|
psp.hInstance = _Module.GetResourceInstance( );
|
|
|
|
psp.pszTemplate = MAKEINTRESOURCE( IDD_GENERAL );
|
|
|
|
psp.lParam = ( LPARAM )this;
|
|
|
|
psp.pfnDlgProc = CGeneral::DlgProc;
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
BOOL CGeneral::PersistSettings( HWND hDlg )
|
|
{
|
|
HRESULT hr;
|
|
|
|
if( IsValidSettings( hDlg ) )
|
|
{
|
|
ICfgComp *pCfgcomp;
|
|
|
|
if( m_pParent->m_pResNode->GetServer( &pCfgcomp ) == 0 )
|
|
{
|
|
return FALSE;
|
|
}
|
|
|
|
WS *pWinsta = NULL;
|
|
|
|
LONG lSize = 0;
|
|
|
|
hr = pCfgcomp->GetWSInfo( m_pParent->m_pResNode->GetConName( ) , &lSize , &pWinsta );
|
|
|
|
if( SUCCEEDED( hr ) )
|
|
{
|
|
GetWindowText( GetDlgItem( hDlg , IDC_EDIT_GEN_COMMENT ) , pWinsta->Comment , WINSTATIONCOMMENT_LENGTH + 1 );
|
|
|
|
m_pParent->m_pResNode->SetComment( pWinsta->Comment , lstrlen( pWinsta->Comment ) );
|
|
|
|
DWORD dwStatus;
|
|
|
|
hr = pCfgcomp->UpDateWS( pWinsta , UPDATE_COMMENT , &dwStatus, FALSE );
|
|
|
|
if( FAILED( hr ) )
|
|
{
|
|
// report error
|
|
|
|
ReportStatusError( GetDlgItem( hDlg , IDC_EDIT_GEN_COMMENT ) , dwStatus );
|
|
}
|
|
|
|
CoTaskMemFree( pWinsta );
|
|
}
|
|
|
|
if( SUCCEEDED( hr ) )
|
|
{
|
|
|
|
USERCONFIG uc;
|
|
|
|
if( m_pParent->GetCurrentUserConfig( uc, TRUE ) )
|
|
{
|
|
if( m_pEncrypt != NULL )
|
|
{
|
|
UINT index = ( UCHAR )SendMessage( GetDlgItem( hDlg , IDC_COMBO_GEN_ENCRYPT ) , CB_GETCURSEL , 0 , 0 );
|
|
|
|
if(index == CB_ERR )
|
|
{
|
|
uc.MinEncryptionLevel =(UCHAR) m_pEncrypt[m_DefaultEncryptionLevelIndex].RegistryValue;
|
|
}
|
|
else
|
|
{
|
|
uc.MinEncryptionLevel = (UCHAR) m_pEncrypt[index].RegistryValue;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
uc.MinEncryptionLevel = 0;
|
|
}
|
|
|
|
uc.fUseDefaultGina = SendMessage( GetDlgItem( hDlg , IDC_CHECK_GEN_AUTHEN ) , BM_GETCHECK , 0 , 0 ) == BST_CHECKED;
|
|
|
|
DWORD dwStatus = 0;
|
|
|
|
hr = m_pParent->SetUserConfig( uc , &dwStatus );
|
|
|
|
if( FAILED( hr ) )
|
|
{
|
|
// report error
|
|
|
|
ReportStatusError( hDlg , dwStatus );
|
|
}
|
|
}
|
|
}
|
|
|
|
if( SUCCEEDED( hr ) )
|
|
{
|
|
ODS( L"TSCC : Forcing reg update on General Page\n" );
|
|
|
|
VERIFY_S( S_OK , pCfgcomp->ForceUpdate( ) );
|
|
|
|
VERIFY_S( S_OK , pCfgcomp->Refresh( ) );
|
|
|
|
// global flag can only be set to true
|
|
|
|
m_pParent->m_bPropertiesChange = TRUE;
|
|
|
|
PostMessage( hDlg , WM_COMMAND , MAKELPARAM( 0 , ALN_APPLY ) , ( LPARAM )hDlg );
|
|
|
|
SendMessage( GetParent( hDlg ) , PSM_UNCHANGED , ( WPARAM )hDlg , 0 );
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
|
|
pCfgcomp->Release( );
|
|
}
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
|
|
//-----------------------------------------------------------------------------
|
|
BOOL CGeneral::OnDestroy( )
|
|
{
|
|
if( m_pEncrypt != NULL )
|
|
{
|
|
CoTaskMemFree( m_pEncrypt );
|
|
|
|
m_pEncrypt = NULL;
|
|
}
|
|
|
|
m_pParent->Release( );
|
|
|
|
return CDialogPropBase::OnDestroy( );
|
|
|
|
}
|
|
|
|
//*****************************************************************************
|
|
|
|
CTransNetwork::CTransNetwork( CPropsheet *pSheet )
|
|
{
|
|
ASSERT( pSheet != NULL );
|
|
|
|
m_pParent = pSheet;
|
|
|
|
// this now behaves as the last combx selection
|
|
|
|
m_ulOldLanAdapter = ( ULONG )-1;
|
|
|
|
m_oldID = ( WORD )-1;
|
|
|
|
m_uMaxInstOld = ( ULONG )-1;
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
INT_PTR CALLBACK CTransNetwork::DlgProc( HWND hwnd , UINT msg , WPARAM wp , LPARAM lp )
|
|
{
|
|
CTransNetwork *pDlg;
|
|
|
|
if( msg == WM_INITDIALOG )
|
|
{
|
|
CTransNetwork *pDlg = ( CTransNetwork * )( ( PROPSHEETPAGE *)lp )->lParam ;
|
|
|
|
SetWindowLongPtr( hwnd , DWLP_USER , ( LONG_PTR )pDlg );
|
|
|
|
if( !IsBadReadPtr( pDlg , sizeof( CTransNetwork ) ) )
|
|
{
|
|
pDlg->OnInitDialog( hwnd , wp , lp );
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
else
|
|
{
|
|
pDlg = ( CTransNetwork * )GetWindowLongPtr( hwnd , DWLP_USER );
|
|
|
|
if( IsBadReadPtr( pDlg , sizeof( CTransNetwork ) ) )
|
|
{
|
|
return FALSE;
|
|
}
|
|
}
|
|
|
|
switch( msg )
|
|
{
|
|
|
|
case WM_NCDESTROY:
|
|
|
|
pDlg->OnDestroy( );
|
|
|
|
break;
|
|
|
|
case WM_COMMAND:
|
|
|
|
pDlg->OnCommand( HIWORD( wp ) , LOWORD( wp ) , ( HWND )lp );
|
|
|
|
break;
|
|
|
|
case WM_CONTEXTMENU:
|
|
{
|
|
POINT pt;
|
|
|
|
pt.x = LOWORD( lp );
|
|
|
|
pt.y = HIWORD( lp );
|
|
|
|
pDlg->OnContextMenu( ( HWND )wp , pt );
|
|
}
|
|
|
|
break;
|
|
|
|
case WM_HELP:
|
|
|
|
pDlg->OnHelp( hwnd , ( LPHELPINFO )lp );
|
|
|
|
break;
|
|
|
|
case WM_NOTIFY:
|
|
|
|
return pDlg->OnNotify( ( int )wp , ( LPNMHDR )lp , hwnd );
|
|
}
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
BOOL CTransNetwork::OnInitDialog( HWND hDlg , WPARAM wp , LPARAM lp )
|
|
{
|
|
BOOL bReadOnly;
|
|
HICON hIcon;
|
|
|
|
m_pParent->AddRef( );
|
|
|
|
SendMessage( GetDlgItem( hDlg , IDC_SPINCTR_GEN ) , UDM_SETRANGE32 , 0 , ( LPARAM )999999 );
|
|
|
|
if( m_pParent->m_pResNode == NULL )
|
|
{
|
|
m_bPersisted = TRUE;
|
|
return FALSE;
|
|
}
|
|
|
|
ICfgComp *pCfgcomp = NULL;
|
|
|
|
ULONG cbSize = 0;
|
|
|
|
ULONG ulItems = 0;
|
|
|
|
PGUIDTBL pGuidtbl = NULL;
|
|
|
|
do
|
|
{
|
|
if( m_pParent->m_pResNode->GetServer( &pCfgcomp ) == 0 )
|
|
{
|
|
ODS( L"CTransNetwork::OnInitDialog - GetServer failed\n" );
|
|
|
|
break;
|
|
}
|
|
|
|
WS *pWinSta = NULL;
|
|
|
|
pCfgcomp->ForceUpdate();
|
|
pCfgcomp->Refresh();
|
|
if( FAILED( pCfgcomp->GetWSInfo( m_pParent->m_pResNode->GetConName( ) , ( PLONG )&cbSize , &pWinSta ) ) )
|
|
{
|
|
ODS( L"TSCC: GetWSInfo failed in TransNetwork::OnInitDialog\n" );
|
|
|
|
break;
|
|
}
|
|
|
|
ISettingsComp* pISettingComp = NULL;
|
|
HRESULT hr;
|
|
DWORD dwStatus;
|
|
DWORD nVal;
|
|
|
|
hr = pCfgcomp->QueryInterface( IID_ISettingsComp, (void **) &pISettingComp );
|
|
|
|
//
|
|
// Assume we are not remote admin if anything go wrong
|
|
//
|
|
m_RemoteAdminMode = FALSE;
|
|
|
|
if( SUCCEEDED(hr) && NULL != pISettingComp )
|
|
{
|
|
hr = pISettingComp->GetTermSrvMode( &nVal, &dwStatus );
|
|
if( SUCCEEDED(hr) && nVal == 0 )
|
|
{
|
|
// we are in RA mode
|
|
m_RemoteAdminMode = TRUE;
|
|
}
|
|
|
|
pISettingComp->Release();
|
|
}
|
|
|
|
if( FAILED(hr) )
|
|
{
|
|
//
|
|
// QueryInterface() or GetTermSrvMode() failed
|
|
// bring up a error message
|
|
//
|
|
TCHAR tchMessage[ 256 ];
|
|
|
|
TCHAR tchWarn[ 40 ];
|
|
|
|
VERIFY_E( 0 , LoadString( _Module.GetResourceInstance( ) , IDS_ERR_TERMSRVMODE , tchMessage , SIZE_OF_BUFFER( tchMessage ) ) );
|
|
|
|
VERIFY_E( 0 , LoadString( _Module.GetResourceInstance( ) , IDS_WARN_TITLE , tchWarn , SIZE_OF_BUFFER( tchWarn ) ) );
|
|
|
|
MessageBox( hDlg , tchMessage , tchWarn , MB_ICONWARNING | MB_OK );
|
|
|
|
}
|
|
|
|
|
|
// certain operations cannot be performed if the user is not part of the admin group
|
|
|
|
pCfgcomp->IsSessionReadOnly( &bReadOnly );
|
|
|
|
|
|
// Set Connection name
|
|
|
|
SetWindowText( GetDlgItem( hDlg , IDC_STATIC_CONNAME ) , m_pParent->m_pResNode->GetConName( ) );
|
|
|
|
// List all supported lan adapters for transport type
|
|
|
|
ULONG idx;
|
|
|
|
if( SUCCEEDED( pCfgcomp->GetLanAdapterList2( m_pParent->m_pResNode->GetTTName() , &ulItems , &pGuidtbl ) ) )
|
|
{
|
|
// verify table is valid
|
|
|
|
BOOL bFound = FALSE;
|
|
|
|
for( idx = 0 ; idx < ulItems ; ++idx )
|
|
{
|
|
if( pGuidtbl[ idx ].dwStatus != ERROR_SUCCESS && !bReadOnly )
|
|
{
|
|
pCfgcomp->BuildGuidTable( &pGuidtbl , ulItems , m_pParent->m_pResNode->GetTTName() );
|
|
|
|
break;
|
|
}
|
|
}
|
|
|
|
for( idx = 0 ; idx < ulItems ; ++idx )
|
|
{
|
|
if( pGuidtbl[ idx ].dwLana == pWinSta->LanAdapter )
|
|
{
|
|
bFound = TRUE;
|
|
|
|
break;
|
|
}
|
|
}
|
|
|
|
if( !bFound )
|
|
{
|
|
if( !bReadOnly )
|
|
{
|
|
// Notify user we must rebuild guid table
|
|
TCHAR tchMessage[ 256 ];
|
|
|
|
TCHAR tchTitle[ 80 ];
|
|
|
|
VERIFY_E( 0 , LoadString( _Module.GetResourceInstance( ) , IDS_INVALNETWORK , tchMessage , SIZE_OF_BUFFER( tchMessage ) ) );
|
|
|
|
VERIFY_E( 0 , LoadString( _Module.GetResourceInstance( ) , IDS_TSCERRTITLE , tchTitle , SIZE_OF_BUFFER( tchTitle ) ) );
|
|
|
|
MessageBox( hDlg , tchMessage , tchTitle , MB_OK | MB_ICONINFORMATION );
|
|
|
|
m_bPersisted = FALSE;
|
|
|
|
SendMessage( GetParent( hDlg ) , PSM_CHANGED , ( WPARAM )hDlg , 0 );
|
|
}
|
|
|
|
// reset lana index
|
|
|
|
pWinSta->LanAdapter = ( DWORD )-1;
|
|
|
|
}
|
|
|
|
for( idx = 0 ; idx < ulItems; ++idx )
|
|
{
|
|
if( pGuidtbl[ idx ].dwLana == pWinSta->LanAdapter )
|
|
{
|
|
// make sure we only set this once
|
|
// invalid entries will have dwLana set to zero
|
|
|
|
if( m_ulOldLanAdapter == ( DWORD )-1 )
|
|
{
|
|
m_ulOldLanAdapter = idx;
|
|
}
|
|
}
|
|
|
|
SendMessage( GetDlgItem( hDlg , IDC_COMBO_GEN_LANADAPTER ) , CB_ADDSTRING , 0 , ( LPARAM )pGuidtbl[ idx ].DispName );
|
|
|
|
SendMessage( GetDlgItem( hDlg , IDC_COMBO_GEN_LANADAPTER ) , CB_SETITEMDATA , idx , ( LPARAM )pGuidtbl[ idx ].dwLana );
|
|
}
|
|
|
|
CoTaskMemFree( pGuidtbl );
|
|
}
|
|
|
|
|
|
SendMessage( GetDlgItem( hDlg , IDC_COMBO_GEN_LANADAPTER ) , CB_SETCURSEL , ( WPARAM )m_ulOldLanAdapter , 0 );
|
|
|
|
|
|
if( !m_bPersisted )
|
|
{
|
|
// force IsValidSettings to confirm on the lana uniqueness
|
|
|
|
m_ulOldLanAdapter = ( DWORD )-1;
|
|
}
|
|
|
|
|
|
TCHAR tchMaxConnectionsBuf[6]; // max digits
|
|
SendMessage( GetDlgItem( hDlg , IDC_EDIT_GEN_MAXCONS ) , EM_SETLIMITTEXT , SIZE_OF_BUFFER(tchMaxConnectionsBuf) , 0 );
|
|
|
|
BOOL bUnlimitedConnections = FALSE;
|
|
|
|
m_uMaxInstOld = pWinSta->uMaxInstanceCount;
|
|
|
|
if( TRUE == m_RemoteAdminMode )
|
|
{
|
|
//Display the warning icon
|
|
hIcon = LoadIcon(_Module.GetModuleInstance() , MAKEINTRESOURCE(IDI_ICON_WARNING));
|
|
hIcon = (HICON)LoadImage(_Module.GetModuleInstance(), MAKEINTRESOURCE(IDI_ICON_WARNING), IMAGE_ICON, 0, 0, 0);
|
|
SendMessage(GetDlgItem(hDlg, IDC_USERPERM_ICON) , STM_SETICON, (WPARAM)hIcon, 0);
|
|
ShowWindow(GetDlgItem(hDlg, IDC_USERPERM_ICON), SW_SHOW);
|
|
|
|
//Display the warning text
|
|
ShowWindow(GetDlgItem(hDlg, IDC_TSMSTATIC_RA), SW_SHOW);
|
|
|
|
//Limit the max connections to 2
|
|
wsprintf(tchMaxConnectionsBuf, L"%d" ,
|
|
(pWinSta->uMaxInstanceCount > 2 || pWinSta->uMaxInstanceCount == (ULONG) -1) ? 2 : pWinSta->uMaxInstanceCount);
|
|
SendMessage(GetDlgItem(hDlg , IDC_SPINCTR_GEN), UDM_SETRANGE32, 0, (LPARAM)2);
|
|
|
|
//Unlimited connections isn't an option
|
|
bUnlimitedConnections = FALSE;
|
|
EnableWindow(GetDlgItem(hDlg, IDC_CHECK_GEN_UNLIMITED), FALSE);
|
|
}
|
|
else
|
|
{
|
|
bUnlimitedConnections = (pWinSta->uMaxInstanceCount == (ULONG)-1);
|
|
|
|
//Set the max number of connections
|
|
wsprintf(tchMaxConnectionsBuf, L"%d", pWinSta->uMaxInstanceCount);
|
|
}
|
|
|
|
//If we're in read only mode, the NIC selector control should be disabled
|
|
if(bReadOnly)
|
|
EnableWindow(GetDlgItem(hDlg, IDC_COMBO_GEN_LANADAPTER), FALSE);
|
|
|
|
//If we're in read only mode or a global policy exists, the user shouldn't
|
|
//be able to change the max number of connections
|
|
POLICY_TS_MACHINE p;
|
|
RegGetMachinePolicy(&p);
|
|
if (bReadOnly || p.fPolicyMaxInstanceCount)
|
|
{
|
|
//Disable the radio buttons
|
|
EnableWindow(GetDlgItem(hDlg, IDC_CHECK_GEN_UNLIMITED), FALSE);
|
|
EnableWindow(GetDlgItem(hDlg, IDC_RADIO_MAXPROP), FALSE);
|
|
|
|
// if user have only read access, disable MAX connection and its associated spin control
|
|
EnableWindow(GetDlgItem(hDlg, IDC_EDIT_GEN_MAXCONS), FALSE);
|
|
EnableWindow(GetDlgItem(hDlg, IDC_SPINCTR_GEN), FALSE);
|
|
}
|
|
|
|
if (!bUnlimitedConnections)
|
|
{
|
|
m_oldID = IDC_RADIO_MAXPROP;
|
|
SetWindowText(GetDlgItem(hDlg, IDC_EDIT_GEN_MAXCONS), tchMaxConnectionsBuf);
|
|
}
|
|
else
|
|
{
|
|
m_oldID = IDC_CHECK_GEN_UNLIMITED;
|
|
EnableWindow(GetDlgItem(hDlg, IDC_EDIT_GEN_MAXCONS), FALSE);
|
|
EnableWindow(GetDlgItem(hDlg, IDC_SPINCTR_GEN), FALSE);
|
|
}
|
|
|
|
//Select the appropriate radio button
|
|
SendMessage(GetDlgItem(hDlg, IDC_CHECK_GEN_UNLIMITED), BM_SETCHECK, (WPARAM)(bUnlimitedConnections), 0);
|
|
SendMessage(GetDlgItem(hDlg, IDC_RADIO_MAXPROP), BM_SETCHECK, (WPARAM)(!bUnlimitedConnections), 0);
|
|
|
|
CoTaskMemFree( pWinSta );
|
|
|
|
pCfgcomp->Release( );
|
|
|
|
}while( 0 );
|
|
|
|
m_bPersisted = TRUE;
|
|
|
|
return CDialogPropBase::OnInitDialog( hDlg , wp , lp );
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
BOOL CTransNetwork::GetPropertySheetPage( PROPSHEETPAGE& psp )
|
|
{
|
|
ZeroMemory( &psp , sizeof( PROPSHEETPAGE ) );
|
|
|
|
psp.dwSize = sizeof( PROPSHEETPAGE );
|
|
|
|
psp.dwFlags = PSP_DEFAULT;
|
|
|
|
psp.hInstance = _Module.GetResourceInstance( );
|
|
|
|
psp.pszTemplate = MAKEINTRESOURCE( IDD_NETWORK_FACE );
|
|
|
|
psp.lParam = ( LPARAM )this;
|
|
|
|
psp.pfnDlgProc = CTransNetwork::DlgProc;
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
BOOL CTransNetwork::OnDestroy( )
|
|
{
|
|
m_pParent->Release( );
|
|
|
|
return CDialogPropBase::OnDestroy( );
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
BOOL CTransNetwork::OnCommand( WORD wNotifyCode , WORD wID , HWND hwndCtrl )
|
|
{
|
|
if( wNotifyCode == BN_CLICKED || wNotifyCode == EN_CHANGE )// || wNotifyCode == CBN_SELCHANGE )
|
|
{
|
|
if( wID == IDC_CHECK_GEN_UNLIMITED )
|
|
{
|
|
EnableWindow( GetDlgItem( GetParent( hwndCtrl ) , IDC_EDIT_GEN_MAXCONS ) ,
|
|
|
|
SendMessage( hwndCtrl , BM_GETCHECK , 0 , 0 ) == BST_UNCHECKED );
|
|
|
|
EnableWindow( GetDlgItem( GetParent( hwndCtrl ) , IDC_SPINCTR_GEN ) ,
|
|
|
|
SendMessage( hwndCtrl , BM_GETCHECK , 0 , 0 ) == BST_UNCHECKED );
|
|
|
|
SendMessage(GetDlgItem(GetParent(hwndCtrl), IDC_RADIO_MAXPROP),BM_SETCHECK,(WPARAM)BST_UNCHECKED,0);
|
|
|
|
|
|
}
|
|
|
|
else if(wID == IDC_RADIO_MAXPROP)
|
|
{
|
|
EnableWindow( GetDlgItem( GetParent( hwndCtrl ) , IDC_EDIT_GEN_MAXCONS ) ,
|
|
|
|
SendMessage( hwndCtrl , BM_GETCHECK , 0 , 0 ) == BST_CHECKED );
|
|
|
|
EnableWindow( GetDlgItem( GetParent( hwndCtrl ) , IDC_SPINCTR_GEN ) ,
|
|
|
|
SendMessage( hwndCtrl , BM_GETCHECK , 0 , 0 ) == BST_CHECKED );
|
|
|
|
SendMessage(GetDlgItem(GetParent(hwndCtrl), IDC_CHECK_GEN_UNLIMITED),BM_SETCHECK,(WPARAM)BST_UNCHECKED,0);
|
|
|
|
SetFocus( GetDlgItem( GetParent( hwndCtrl ) , IDC_EDIT_GEN_MAXCONS ) );
|
|
|
|
SendMessage( GetDlgItem( GetParent( hwndCtrl ) , IDC_EDIT_GEN_MAXCONS ) , EM_SETSEL , ( WPARAM )0 , ( LPARAM )-1 );
|
|
|
|
}
|
|
|
|
if ((wID == IDC_CHECK_GEN_UNLIMITED) || (wID == IDC_RADIO_MAXPROP))
|
|
{
|
|
if( wID != m_oldID )
|
|
{
|
|
m_bPersisted = FALSE;
|
|
m_oldID = wID;
|
|
}
|
|
}
|
|
|
|
if (wID == IDC_EDIT_GEN_MAXCONS)
|
|
m_bPersisted = FALSE;
|
|
}
|
|
|
|
else if( wNotifyCode == CBN_SELCHANGE )
|
|
{
|
|
INT_PTR iSel = SendMessage( hwndCtrl , CB_GETCURSEL , 0 , 0 );
|
|
|
|
if( iSel != ( INT_PTR )m_ulOldLanAdapter )
|
|
{
|
|
m_bPersisted = FALSE;
|
|
}
|
|
}
|
|
|
|
|
|
else if( wNotifyCode == ALN_APPLY )
|
|
{
|
|
SendMessage( GetParent( hwndCtrl ) , PSM_CANCELTOCLOSE , 0 , 0 );
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
if( !m_bPersisted )
|
|
{
|
|
SendMessage( GetParent( GetParent( hwndCtrl ) ) , PSM_CHANGED , ( WPARAM )GetParent( hwndCtrl ) , 0 );
|
|
}
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
BOOL CTransNetwork::PersistSettings( HWND hDlg )
|
|
{
|
|
BOOL bOk = FALSE;
|
|
|
|
if( IsValidSettings( hDlg ) )
|
|
{
|
|
ICfgComp *pCfgcomp;
|
|
|
|
bOk = TRUE;
|
|
|
|
if( m_pParent->m_pResNode->GetServer( &pCfgcomp ) == 0 )
|
|
{
|
|
return FALSE;
|
|
}
|
|
|
|
WS winsta;
|
|
|
|
ZeroMemory( &winsta , sizeof( WS ) );
|
|
|
|
//If a group policy exists, its data will be in the winsta structure. We don't want to write that to
|
|
//the TSCC registry, so read the TSCC data by getting the User Config without merging the machine policy
|
|
POLICY_TS_MACHINE p;
|
|
RegGetMachinePolicy(&p);
|
|
|
|
if (p.fPolicyMaxInstanceCount)
|
|
{
|
|
POLICY_TS_MACHINE pTemp;
|
|
ULONG Length = 0;
|
|
WINSTATIONCONFIG2W WSConfig;
|
|
|
|
memset(&pTemp, 0, sizeof(POLICY_TS_MACHINE));
|
|
if((ERROR_SUCCESS != RegWinStationQueryEx(NULL,&pTemp,m_pParent->m_pResNode->GetConName( ),&WSConfig,sizeof(WINSTATIONCONFIG2W),&Length,FALSE)))
|
|
return FALSE;
|
|
|
|
winsta.uMaxInstanceCount = WSConfig.Create.MaxInstanceCount;
|
|
}
|
|
else
|
|
{
|
|
if( SendMessage( GetDlgItem( hDlg , IDC_CHECK_GEN_UNLIMITED ), BM_GETCHECK , 0 , 0 ) == BST_CHECKED )
|
|
winsta.uMaxInstanceCount = ( ULONG )-1;
|
|
else
|
|
winsta.uMaxInstanceCount = GetDlgItemInt( hDlg , IDC_EDIT_GEN_MAXCONS , &bOk , FALSE );
|
|
}
|
|
|
|
INT_PTR iSel = SendMessage( GetDlgItem( hDlg , IDC_COMBO_GEN_LANADAPTER ) , CB_GETCURSEL , 0 , 0 );
|
|
|
|
winsta.LanAdapter = ( ULONG )SendMessage(
|
|
GetDlgItem( hDlg , IDC_COMBO_GEN_LANADAPTER ) ,
|
|
CB_GETITEMDATA ,
|
|
( WPARAM )iSel ,
|
|
0 );
|
|
|
|
if( iSel != CB_ERR )
|
|
{
|
|
if( iSel != ( INT_PTR )m_ulOldLanAdapter )
|
|
{
|
|
LONG lCount;
|
|
|
|
pCfgcomp->QueryLoggedOnCount( m_pParent->m_pResNode->GetConName( ) , &lCount );
|
|
|
|
if( lCount > 0 )
|
|
{
|
|
// Warn user, changing an active lan adapter will cause all connections to disconnect
|
|
|
|
TCHAR tchMessage[ 256 ];
|
|
|
|
TCHAR tchWarn[ 40 ];
|
|
|
|
VERIFY_E( 0 , LoadString( _Module.GetResourceInstance( ) , IDS_ERR_LANCHANGE , tchMessage , SIZE_OF_BUFFER( tchMessage ) ) );
|
|
|
|
VERIFY_E( 0 , LoadString( _Module.GetResourceInstance( ) , IDS_WARN_TITLE , tchWarn , SIZE_OF_BUFFER( tchWarn ) ) );
|
|
|
|
if( MessageBox( hDlg , tchMessage , tchWarn , MB_ICONWARNING | MB_YESNO ) == IDNO )
|
|
{
|
|
bOk = FALSE;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
if( bOk && iSel != CB_ERR )
|
|
{
|
|
lstrcpyn( winsta.Name , m_pParent->m_pResNode->GetConName( ) , SIZE_OF_BUFFER( winsta.Name ) - 1 );
|
|
|
|
DWORD dwStatus;
|
|
|
|
DWORD dwUpdateFlags = UPDATE_LANADAPTER;
|
|
if (!p.fPolicyMaxInstanceCount)
|
|
dwUpdateFlags |= UPDATE_MAXINSTANCECOUNT;
|
|
|
|
if( FAILED( pCfgcomp->UpDateWS( &winsta , dwUpdateFlags , &dwStatus, FALSE ) ) )
|
|
{
|
|
// report error and get out
|
|
|
|
ReportStatusError( hDlg , dwStatus );
|
|
|
|
pCfgcomp->Release( );
|
|
|
|
}
|
|
else
|
|
{
|
|
ODS( L"Connection LANA persisted\n" );
|
|
|
|
m_ulOldLanAdapter = ( ULONG )iSel;
|
|
|
|
ODS( L"TSCC : Forcing reg update - CTransNetwork\n" );
|
|
|
|
VERIFY_S( S_OK , pCfgcomp->ForceUpdate( ) );
|
|
|
|
VERIFY_S( S_OK , pCfgcomp->Refresh( ) );
|
|
|
|
// global flag can only be set to true
|
|
|
|
m_pParent->m_bPropertiesChange = TRUE;
|
|
|
|
PostMessage( hDlg , WM_COMMAND , MAKELPARAM( 0 , ALN_APPLY ) , ( LPARAM )hDlg );
|
|
|
|
SendMessage( GetParent( hDlg ) , PSM_UNCHANGED , ( WPARAM )hDlg , 0 );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
pCfgcomp->Release( );
|
|
|
|
}
|
|
|
|
return bOk;
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
BOOL CTransNetwork::IsValidSettings( HWND hDlg )
|
|
{
|
|
BOOL ret = TRUE;
|
|
|
|
ICfgComp *pCfgcomp;
|
|
|
|
TCHAR tchMessage[ 256 ];
|
|
|
|
TCHAR tchWarn[ 40 ];
|
|
|
|
if( SendMessage( GetDlgItem( hDlg , IDC_CHECK_GEN_UNLIMITED ), BM_GETCHECK , 0 , 0 ) == BST_UNCHECKED )
|
|
{
|
|
UINT uMax;
|
|
|
|
BOOL bOK = FALSE;
|
|
|
|
uMax = GetDlgItemInt( hDlg , IDC_EDIT_GEN_MAXCONS , &bOK , FALSE );
|
|
|
|
if( !bOK )
|
|
{
|
|
ErrMessage( hDlg , IDS_ERR_CONREADFAIL );
|
|
|
|
SetFocus( GetDlgItem( hDlg , IDC_EDIT_GEN_MAXCONS ) );
|
|
|
|
SendMessage( GetDlgItem( hDlg , IDC_EDIT_GEN_MAXCONS ) , EM_SETSEL , ( WPARAM )0 , ( LPARAM )-1 );
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
if( uMax > 999999UL )
|
|
{
|
|
ErrMessage( hDlg , IDS_ERR_CONMAX );
|
|
|
|
SetFocus( GetDlgItem( hDlg , IDC_EDIT_GEN_MAXCONS ) );
|
|
|
|
SendMessage( GetDlgItem( hDlg , IDC_EDIT_GEN_MAXCONS ) , EM_SETSEL , ( WPARAM )0 , ( LPARAM )-1 );
|
|
|
|
return FALSE;
|
|
}
|
|
}
|
|
|
|
if( m_pParent != NULL && m_pParent->m_pResNode != NULL )
|
|
{
|
|
if( m_pParent->m_pResNode->GetServer( &pCfgcomp ) == 0 )
|
|
{
|
|
return FALSE;
|
|
}
|
|
|
|
// PDNAMEW pName;
|
|
|
|
PWS pWinSta;
|
|
|
|
LONG cbSize;
|
|
|
|
if( SUCCEEDED( pCfgcomp->GetWSInfo( m_pParent->m_pResNode->GetConName( ) , ( PLONG )&cbSize , &pWinSta ) ) )
|
|
{
|
|
INT_PTR iSel = SendMessage( GetDlgItem( hDlg , IDC_COMBO_GEN_LANADAPTER ) , CB_GETCURSEL , 0 , 0 );
|
|
|
|
BOOL bUnique = TRUE;
|
|
|
|
if( iSel != CB_ERR )
|
|
{
|
|
if( iSel != ( int )m_ulOldLanAdapter )
|
|
{
|
|
ULONG nStations;
|
|
|
|
VERIFY_S( S_OK , pCfgcomp->GetNumofWinStations(pWinSta->wdName,pWinSta->pdName,&nStations ) );
|
|
|
|
DBGMSG( L"TSCC: Number of winstations equals = %d\n" , nStations );
|
|
|
|
if( nStations > 1 )
|
|
{
|
|
ODS( L"TSCC: We have more than one winstation verify unique lana settings\n" );
|
|
|
|
ULONG ulLana = ( ULONG )SendMessage( GetDlgItem( hDlg , IDC_COMBO_GEN_LANADAPTER ) , CB_GETITEMDATA , ( WPARAM )iSel , 0 );
|
|
|
|
VERIFY_S( S_OK , pCfgcomp->IsNetWorkConnectionUnique( m_pParent->m_pResNode->GetTypeName( ) , pWinSta->pdName , ulLana , &bUnique ) );
|
|
}
|
|
|
|
if( !bUnique )
|
|
{
|
|
//ErrMessage( hDlg , IDS_ERR_UNIQUECON );
|
|
VERIFY_E( 0 , LoadString( _Module.GetResourceInstance( ) , IDS_ERR_UNIQUECON , tchMessage , SIZE_OF_BUFFER( tchMessage ) ) );
|
|
|
|
VERIFY_E( 0 , LoadString( _Module.GetResourceInstance( ) , IDS_WARN_TITLE , tchWarn , SIZE_OF_BUFFER( tchWarn ) ) );
|
|
|
|
MessageBox( hDlg , tchMessage , tchWarn , MB_ICONINFORMATION | MB_OK );
|
|
|
|
ret = FALSE;
|
|
}
|
|
else
|
|
{
|
|
LONG lCount;
|
|
|
|
pCfgcomp->QueryLoggedOnCount( m_pParent->m_pResNode->GetConName( ) , &lCount );
|
|
|
|
if( lCount > 0 )
|
|
{
|
|
// Warn user, changing an active lan adapter will cause all connections to disconnect
|
|
TCHAR tchMessage[ 256 ];
|
|
|
|
TCHAR tchWarn[ 40 ];
|
|
|
|
VERIFY_E( 0 , LoadString( _Module.GetResourceInstance( ) , IDS_ERR_LANCHANGE , tchMessage , SIZE_OF_BUFFER( tchMessage ) ) );
|
|
|
|
VERIFY_E( 0 , LoadString( _Module.GetResourceInstance( ) , IDS_WARN_TITLE , tchWarn , SIZE_OF_BUFFER( tchWarn ) ) );
|
|
|
|
if( MessageBox( hDlg , tchMessage , tchWarn , MB_ICONWARNING | MB_YESNO ) == IDNO )
|
|
{
|
|
ret = FALSE;
|
|
}
|
|
}
|
|
}
|
|
|
|
if( ret )
|
|
{
|
|
m_ulOldLanAdapter = (ULONG)iSel;
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
CoTaskMemFree( pWinSta );
|
|
}
|
|
|
|
pCfgcomp->Release( );
|
|
}
|
|
|
|
if( !ret )
|
|
{
|
|
if( m_uMaxInstOld == ( ULONG )-1 )
|
|
{
|
|
EnableWindow( GetDlgItem( hDlg , IDC_EDIT_GEN_MAXCONS ) , FALSE );
|
|
|
|
EnableWindow( GetDlgItem( hDlg , IDC_SPINCTR_GEN ) , FALSE );
|
|
|
|
SendMessage( GetDlgItem( hDlg , IDC_CHECK_GEN_UNLIMITED ) , BM_CLICK , 0 , 0 );
|
|
|
|
m_oldID = IDC_CHECK_GEN_UNLIMITED;
|
|
}
|
|
else
|
|
{
|
|
TCHAR tchBuf[ 16 ];
|
|
|
|
EnableWindow( GetDlgItem( hDlg , IDC_EDIT_GEN_MAXCONS ) , TRUE );
|
|
|
|
EnableWindow( GetDlgItem( hDlg , IDC_SPINCTR_GEN ) , TRUE );
|
|
|
|
wsprintf( tchBuf , L"%d" , m_uMaxInstOld );
|
|
|
|
SetWindowText( GetDlgItem( hDlg , IDC_EDIT_GEN_MAXCONS ) , tchBuf );
|
|
|
|
SendMessage( GetDlgItem( hDlg , IDC_RADIO_MAXPROP) , BM_CLICK , 0 , 0 );
|
|
|
|
m_oldID = IDC_RADIO_MAXPROP;
|
|
|
|
}
|
|
|
|
SendMessage( GetDlgItem( hDlg , IDC_COMBO_GEN_LANADAPTER ) , CB_SETCURSEL , ( WPARAM )m_ulOldLanAdapter , 0 );
|
|
|
|
SendMessage( GetParent( hDlg ) , PSM_UNCHANGED , ( WPARAM )hDlg , 0 );
|
|
|
|
m_bPersisted = TRUE;
|
|
}
|
|
|
|
return ret;
|
|
}
|
|
|
|
//*****************************************************************************
|
|
CTransAsync::CTransAsync( CPropsheet * pSheet )
|
|
{
|
|
m_pParent = pSheet;
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
BOOL CTransAsync::OnInitDialog( HWND hwnd , WPARAM wp , LPARAM lp )
|
|
{
|
|
ICfgComp *pCfgcomp = NULL;
|
|
|
|
m_pParent->AddRef( );
|
|
|
|
if( m_pParent->m_pResNode->GetServer( &pCfgcomp ) == 0 )
|
|
{
|
|
ODS( L"Cound not obtain backend interface @ CTransAsync::OnInitDialog\n" );
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
|
|
VERIFY_S( TRUE , m_pParent->GetCurrentUserConfig( m_uc, TRUE ) );
|
|
|
|
pCfgcomp->GetAsyncConfig( m_pParent->m_pResNode->GetConName() , WsName , &m_ac );
|
|
|
|
VERIFY_S( TRUE , CAsyncDlg::OnInitDialog( hwnd , m_pParent->m_pResNode->GetTypeName( ) , m_pParent->m_pResNode->GetConName( ) , pCfgcomp ) ) ;
|
|
|
|
BOOL bReadOnly;
|
|
|
|
if( SUCCEEDED( pCfgcomp->IsSessionReadOnly( &bReadOnly ) ) )
|
|
{
|
|
if( bReadOnly )
|
|
{
|
|
// disable the remaining controls
|
|
INT rgIds[] = {
|
|
IDC_ASYNC_DEVICENAME,
|
|
IDC_ASYNC_CONNECT,
|
|
IDC_ASYNC_BAUDRATE,
|
|
IDC_ASYNC_MODEMCALLBACK_PHONENUMBER,
|
|
IDC_ASYNC_MODEMCALLBACK_PHONENUMBER_INHERIT,
|
|
IDC_ASYNC_MODEMCALLBACK,
|
|
IDC_ASYNC_MODEMCALLBACK_INHERIT,
|
|
IDC_MODEM_PROP_PROP,
|
|
IDC_ASYNC_DEFAULTS,
|
|
IDC_ASYNC_ADVANCED,
|
|
IDC_ASYNC_TEST, -1
|
|
};
|
|
|
|
|
|
EnableGroup( hwnd , &rgIds[ 0 ] , FALSE );
|
|
|
|
}
|
|
}
|
|
|
|
pCfgcomp->Release( );
|
|
|
|
m_bPersisted = TRUE;
|
|
|
|
return CDialogPropBase::OnInitDialog( hwnd , wp , lp );
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
INT_PTR CALLBACK CTransAsync::DlgProc( HWND hwnd , UINT msg , WPARAM wp , LPARAM lp )
|
|
{
|
|
CTransAsync *pDlg;
|
|
|
|
if( msg == WM_INITDIALOG )
|
|
{
|
|
CTransAsync *pDlg = ( CTransAsync * )( ( PROPSHEETPAGE *)lp )->lParam ;
|
|
|
|
SetWindowLongPtr( hwnd , DWLP_USER , ( LONG_PTR )pDlg );
|
|
|
|
if( !IsBadReadPtr( pDlg , sizeof( CTransAsync ) ) )
|
|
{
|
|
pDlg->OnInitDialog( hwnd , wp , lp );
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
else
|
|
{
|
|
pDlg = ( CTransAsync * )GetWindowLongPtr( hwnd , DWLP_USER );
|
|
|
|
if( IsBadReadPtr( pDlg , sizeof( CTransAsync ) ) )
|
|
{
|
|
return FALSE;
|
|
}
|
|
}
|
|
|
|
switch( msg )
|
|
{
|
|
|
|
case WM_NCDESTROY:
|
|
|
|
pDlg->OnDestroy( );
|
|
|
|
break;
|
|
|
|
case WM_COMMAND:
|
|
|
|
pDlg->OnCommand( HIWORD( wp ) , LOWORD( wp ) , ( HWND )lp );
|
|
|
|
break;
|
|
|
|
case WM_CONTEXTMENU:
|
|
{
|
|
POINT pt;
|
|
|
|
pt.x = LOWORD( lp );
|
|
|
|
pt.y = HIWORD( lp );
|
|
|
|
pDlg->OnContextMenu( ( HWND )wp , pt );
|
|
}
|
|
|
|
break;
|
|
|
|
case WM_HELP:
|
|
|
|
pDlg->OnHelp( hwnd , ( LPHELPINFO )lp );
|
|
|
|
break;
|
|
|
|
case WM_NOTIFY:
|
|
|
|
return pDlg->OnNotify( ( int )wp , ( LPNMHDR )lp , hwnd );
|
|
}
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
BOOL CTransAsync::GetPropertySheetPage( PROPSHEETPAGE& psp )
|
|
{
|
|
ZeroMemory( &psp , sizeof( PROPSHEETPAGE ) );
|
|
|
|
psp.dwSize = sizeof( PROPSHEETPAGE );
|
|
|
|
psp.dwFlags = PSP_DEFAULT;
|
|
|
|
psp.hInstance = _Module.GetResourceInstance( );
|
|
|
|
psp.pszTemplate = MAKEINTRESOURCE( IDD_ASYNC_FACE );
|
|
|
|
psp.lParam = ( LPARAM )this;
|
|
|
|
psp.pfnDlgProc = CTransAsync::DlgProc;
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
BOOL CTransAsync::OnDestroy( )
|
|
{
|
|
AsyncRelease( );
|
|
|
|
m_pParent->Release( );
|
|
|
|
return CDialogPropBase::OnDestroy( );
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
BOOL CTransAsync::OnCommand( WORD wNotifyCode , WORD wID , HWND hwndCtrl )
|
|
{
|
|
|
|
CAsyncDlg::OnCommand( wNotifyCode , wID , hwndCtrl , &m_bPersisted );
|
|
|
|
if( wNotifyCode == ALN_APPLY )
|
|
{
|
|
SendMessage( GetParent( hwndCtrl ) , PSM_CANCELTOCLOSE , 0 , 0 );
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
if( !m_bPersisted )
|
|
{
|
|
SendMessage( GetParent( GetParent( hwndCtrl ) ) , PSM_CHANGED , ( WPARAM )GetParent( hwndCtrl ) , 0 );
|
|
}
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
BOOL CTransAsync::PersistSettings( HWND hDlg )
|
|
{
|
|
if( !IsValidSettings( hDlg ) )
|
|
{
|
|
return FALSE;
|
|
}
|
|
|
|
ICfgComp * pCfgcomp = NULL;
|
|
|
|
if( m_pParent->m_pResNode->GetServer( &pCfgcomp ) == 0 )
|
|
{
|
|
ODS( L"Cound not obtain backend interface @ CTransAsync::OnInitDialog\n" );
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
DWORD dwStatus;
|
|
|
|
HRESULT hr = pCfgcomp->SetAsyncConfig( m_pParent->m_pResNode->GetConName() , WsName , &m_ac , &dwStatus );
|
|
|
|
if( FAILED( hr ) )
|
|
{
|
|
ReportStatusError( hDlg , dwStatus );
|
|
}
|
|
|
|
if( SUCCEEDED( hr ) )
|
|
{
|
|
DWORD dwStatus;
|
|
|
|
hr = m_pParent->SetUserConfig( m_uc , &dwStatus );
|
|
|
|
if( FAILED( hr ) )
|
|
{
|
|
ReportStatusError( hDlg , dwStatus );
|
|
}
|
|
}
|
|
|
|
if( SUCCEEDED( hr ) )
|
|
{
|
|
ODS( L"TSCC : Forcing reg update - CTransAsync\n" );
|
|
|
|
VERIFY_S( S_OK , pCfgcomp->ForceUpdate( ) );
|
|
|
|
VERIFY_S( S_OK , pCfgcomp->Refresh( ) );
|
|
|
|
// global flag can only be set to true
|
|
|
|
m_pParent->m_bPropertiesChange = TRUE;
|
|
|
|
PostMessage( hDlg , WM_COMMAND , MAKELPARAM( 0 , ALN_APPLY ) , ( LPARAM )hDlg );
|
|
|
|
SendMessage( GetParent( hDlg ) , PSM_UNCHANGED , ( WPARAM )hDlg , 0 );
|
|
}
|
|
|
|
|
|
pCfgcomp->Release( );
|
|
|
|
return SUCCEEDED( hr ) ? TRUE : FALSE;
|
|
}
|
|
|
|
BOOL CTransAsync::IsValidSettings(HWND hDlg)
|
|
{
|
|
UNREFERENCED_PARAMETER( hDlg );
|
|
// all async connections are checked for usage
|
|
// thus no two connections can use the same port
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
|
|
//*****************************************************************************
|
|
// Logon settings dialog
|
|
|
|
CLogonSetting::CLogonSetting( CPropsheet *pSheet )
|
|
{
|
|
m_pParent = pSheet;
|
|
|
|
m_wOldId = ( WORD )-1;
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
BOOL CLogonSetting::OnInitDialog( HWND hDlg , WPARAM wp , LPARAM lp )
|
|
{
|
|
if( !IsBadReadPtr( m_pParent , sizeof( CPropsheet ) ) )
|
|
{
|
|
m_pParent->AddRef( );
|
|
}
|
|
|
|
USERCONFIG uc;
|
|
|
|
if( !m_pParent->GetCurrentUserConfig( uc, TRUE ) )
|
|
{
|
|
ODS( L"CLogonSetting::OnInitDialog - GetCurrentUserConfig failed!!!\n" );
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
/*
|
|
SendMessage( GetDlgItem( hDlg , IDC_CHECK_LOGON_INHERIT ) , BM_SETCHECK ,
|
|
|
|
uc.fInheritAutoLogon ? BST_CHECKED : BST_UNCHECKED , 0 );*/
|
|
|
|
if( uc.fInheritAutoLogon == BST_CHECKED )
|
|
{
|
|
CheckRadioButton( hDlg , IDC_CHECK_LOGON_INHERIT , IDC_RADIO_LOGON , IDC_CHECK_LOGON_INHERIT );
|
|
|
|
m_wOldId = IDC_CHECK_LOGON_INHERIT;
|
|
}
|
|
else
|
|
{
|
|
CheckRadioButton( hDlg , IDC_CHECK_LOGON_INHERIT , IDC_RADIO_LOGON , IDC_RADIO_LOGON );
|
|
|
|
m_wOldId = IDC_RADIO_LOGON;
|
|
}
|
|
|
|
|
|
SendMessage( GetDlgItem( hDlg , IDC_CHECK_LOGON_PROMPTPASSWD ), BM_SETCHECK ,
|
|
uc.fPromptForPassword ? BST_CHECKED : BST_UNCHECKED , 0 );
|
|
|
|
POLICY_TS_MACHINE p;
|
|
RegGetMachinePolicy(&p);
|
|
EnableWindow( GetDlgItem( hDlg, IDC_CHECK_LOGON_PROMPTPASSWD ), !p.fPolicyPromptForPassword);
|
|
|
|
//int rgID[] = { IDC_EDIT_LOGON_USRNAME , IDC_EDIT_LOGON_DOMAIN , IDC_EDIT_LOGON_PASSWD , IDC_EDIT_LOGON_CONFIRMPASSWD , -1 };
|
|
|
|
SendMessage( GetDlgItem( hDlg , IDC_EDIT_LOGON_USRNAME ) , EM_SETLIMITTEXT , ( WPARAM )USERNAME_LENGTH , 0 );
|
|
|
|
SendMessage( GetDlgItem( hDlg , IDC_EDIT_LOGON_DOMAIN ) , EM_SETLIMITTEXT , ( WPARAM )DOMAIN_LENGTH , 0 );
|
|
|
|
SendMessage( GetDlgItem( hDlg , IDC_EDIT_LOGON_PASSWD ) , EM_SETLIMITTEXT , ( WPARAM )PASSWORD_LENGTH , 0 );
|
|
|
|
SendMessage( GetDlgItem( hDlg , IDC_EDIT_LOGON_CONFIRMPASSWD ) , EM_SETLIMITTEXT , ( WPARAM )PASSWORD_LENGTH , 0 );
|
|
|
|
if( !uc.fInheritAutoLogon )
|
|
{
|
|
SetWindowText( GetDlgItem( hDlg , IDC_EDIT_LOGON_USRNAME ) , ( LPTSTR )uc.UserName );
|
|
|
|
SetWindowText( GetDlgItem( hDlg , IDC_EDIT_LOGON_DOMAIN ) , ( LPTSTR )uc.Domain );
|
|
}
|
|
|
|
if( !uc.fPromptForPassword )
|
|
{
|
|
SetWindowText( GetDlgItem( hDlg , IDC_EDIT_LOGON_PASSWD ) , ( LPTSTR )uc.Password );
|
|
|
|
SetWindowText( GetDlgItem( hDlg , IDC_EDIT_LOGON_CONFIRMPASSWD ) , ( LPTSTR )uc.Password );
|
|
}
|
|
|
|
int rgID[] = { IDC_EDIT_LOGON_USRNAME , IDC_STATIC_LSUSR , IDC_EDIT_LOGON_DOMAIN , IDC_STATIC_LSDOMAIN , IDC_EDIT_LOGON_PASSWD , IDC_STATIC_LSPWD , IDC_EDIT_LOGON_CONFIRMPASSWD , IDC_STATIC_LSCONPWD , -1 };
|
|
|
|
EnableGroup( hDlg , &rgID[0] , !uc.fInheritAutoLogon );
|
|
|
|
if( !uc.fInheritAutoLogon )
|
|
{
|
|
EnableGroup( hDlg , &rgID[4] , !uc.fPromptForPassword );
|
|
}
|
|
|
|
ICfgComp *pCfgcomp = NULL;
|
|
|
|
if( m_pParent->m_pResNode->GetServer( &pCfgcomp ) != 0 )
|
|
{
|
|
BOOL bReadOnly;
|
|
|
|
if( SUCCEEDED( pCfgcomp->IsSessionReadOnly( &bReadOnly ) ) )
|
|
{
|
|
if( bReadOnly )
|
|
{
|
|
// make edit controls read-only
|
|
|
|
SendMessage( GetDlgItem( hDlg , IDC_EDIT_LOGON_USRNAME ) , EM_SETREADONLY , ( WPARAM )TRUE , 0 );
|
|
|
|
SendMessage( GetDlgItem( hDlg , IDC_EDIT_LOGON_DOMAIN ) , EM_SETREADONLY , ( WPARAM )TRUE , 0 );
|
|
|
|
// disable the remaining controls
|
|
|
|
INT rgIds[] = {
|
|
IDC_EDIT_LOGON_PASSWD,
|
|
IDC_EDIT_LOGON_CONFIRMPASSWD,
|
|
IDC_CHECK_LOGON_PROMPTPASSWD,
|
|
IDC_CHECK_LOGON_INHERIT,
|
|
IDC_RADIO_LOGON,
|
|
-1
|
|
};
|
|
|
|
EnableGroup( hDlg , &rgIds[ 0 ] , FALSE );
|
|
}
|
|
}
|
|
|
|
pCfgcomp->Release( );
|
|
}
|
|
|
|
|
|
|
|
m_bPersisted = TRUE;
|
|
|
|
return CDialogPropBase::OnInitDialog( hDlg , wp , lp );
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
INT_PTR CALLBACK CLogonSetting::DlgProc( HWND hwnd , UINT msg , WPARAM wp , LPARAM lp )
|
|
{
|
|
CLogonSetting *pDlg;
|
|
|
|
if( msg == WM_INITDIALOG )
|
|
{
|
|
CLogonSetting *pDlg = ( CLogonSetting * )( ( PROPSHEETPAGE *)lp )->lParam ;
|
|
|
|
SetWindowLongPtr( hwnd , DWLP_USER , ( LONG_PTR )pDlg );
|
|
|
|
if( !IsBadReadPtr( pDlg , sizeof( CLogonSetting ) ) )
|
|
{
|
|
pDlg->OnInitDialog( hwnd , wp , lp );
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
else
|
|
{
|
|
pDlg = ( CLogonSetting * )GetWindowLongPtr( hwnd , DWLP_USER );
|
|
|
|
if( IsBadReadPtr( pDlg , sizeof( CLogonSetting ) ) )
|
|
{
|
|
return FALSE;
|
|
}
|
|
}
|
|
|
|
switch( msg )
|
|
{
|
|
|
|
case WM_NCDESTROY:
|
|
|
|
pDlg->OnDestroy( );
|
|
|
|
break;
|
|
|
|
case WM_COMMAND:
|
|
|
|
pDlg->OnCommand( HIWORD( wp ) , LOWORD( wp ) , ( HWND )lp );
|
|
|
|
break;
|
|
|
|
case WM_CONTEXTMENU:
|
|
{
|
|
POINT pt;
|
|
|
|
pt.x = LOWORD( lp );
|
|
|
|
pt.y = HIWORD( lp );
|
|
|
|
pDlg->OnContextMenu( ( HWND )wp , pt );
|
|
}
|
|
|
|
break;
|
|
|
|
case WM_HELP:
|
|
|
|
pDlg->OnHelp( hwnd , ( LPHELPINFO )lp );
|
|
|
|
break;
|
|
|
|
case WM_NOTIFY:
|
|
|
|
return pDlg->OnNotify( ( int )wp , ( LPNMHDR )lp , hwnd );
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
BOOL CLogonSetting::GetPropertySheetPage( PROPSHEETPAGE& psp )
|
|
{
|
|
ZeroMemory( &psp , sizeof( PROPSHEETPAGE ) );
|
|
|
|
psp.dwSize = sizeof( PROPSHEETPAGE );
|
|
|
|
psp.dwFlags = PSP_DEFAULT;
|
|
|
|
psp.hInstance = _Module.GetResourceInstance( );
|
|
|
|
psp.pszTemplate = MAKEINTRESOURCE( IDD_LOGONSETTINGS );
|
|
|
|
psp.lParam = ( LPARAM )this;
|
|
|
|
psp.pfnDlgProc = CLogonSetting::DlgProc;
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
//---------------------------------------------------------------------------
|
|
BOOL CLogonSetting::OnCommand( WORD wNotifyCode , WORD wID , HWND hwndCtrl )
|
|
{
|
|
if( wNotifyCode == BN_CLICKED )
|
|
{
|
|
int rgID[] = { IDC_EDIT_LOGON_USRNAME , IDC_STATIC_LSUSR , IDC_EDIT_LOGON_DOMAIN , IDC_STATIC_LSDOMAIN , IDC_EDIT_LOGON_PASSWD , IDC_STATIC_LSPWD , IDC_EDIT_LOGON_CONFIRMPASSWD , IDC_STATIC_LSCONPWD , -1 };
|
|
|
|
BOOL bEnable = ( BOOL )SendMessage( GetDlgItem( GetParent( hwndCtrl ) , IDC_CHECK_LOGON_INHERIT ) , BM_GETCHECK , 0 , 0 ) == BST_UNCHECKED;
|
|
|
|
|
|
if( wID == IDC_CHECK_LOGON_INHERIT )
|
|
{
|
|
EnableGroup( GetParent( hwndCtrl ) , &rgID[ 0 ] , bEnable );
|
|
|
|
if( bEnable )
|
|
{
|
|
EnableGroup( GetParent( hwndCtrl ) , &rgID[ 4 ] , SendMessage( GetDlgItem( GetParent( hwndCtrl ) , IDC_CHECK_LOGON_PROMPTPASSWD ) , BM_GETCHECK , 0 , 0 ) == BST_UNCHECKED );
|
|
|
|
SendMessage(GetDlgItem(GetParent(hwndCtrl), IDC_RADIO_LOGON),BM_SETCHECK,(WPARAM)BST_CHECKED,0);
|
|
|
|
}
|
|
else
|
|
{
|
|
SendMessage(GetDlgItem(GetParent(hwndCtrl), IDC_RADIO_LOGON),BM_SETCHECK,(WPARAM)BST_UNCHECKED,0);
|
|
}
|
|
}
|
|
else if( wID == IDC_CHECK_LOGON_PROMPTPASSWD )
|
|
{
|
|
if( bEnable )
|
|
{
|
|
EnableGroup( GetParent( hwndCtrl ) , &rgID[ 4 ] , SendMessage( hwndCtrl , BM_GETCHECK , 0 , 0 ) == BST_UNCHECKED );
|
|
}
|
|
|
|
// make sure apply button becomes enabled when user checks this box
|
|
|
|
m_bPersisted = FALSE;
|
|
}
|
|
else if( wID == IDC_RADIO_LOGON )
|
|
{
|
|
BOOL bChecked = SendMessage( hwndCtrl , BM_GETCHECK , 0 , 0 ) == BST_CHECKED ;
|
|
|
|
if(bChecked)
|
|
{
|
|
//SendMessage(GetDlgItem(GetParent(hwndCtrl), IDC_CHECK_LOGON_INHERIT),BM_SETCHECK,(WPARAM)BST_UNCHECKED,0);
|
|
|
|
EnableGroup( GetParent( hwndCtrl ) , &rgID[ 0 ] , TRUE );
|
|
|
|
EnableGroup( GetParent( hwndCtrl ) , &rgID[ 4 ] , !( SendMessage( GetDlgItem( GetParent( hwndCtrl ) , IDC_CHECK_LOGON_PROMPTPASSWD ) , BM_GETCHECK , 0 , 0 ) == BST_CHECKED ) );
|
|
|
|
}
|
|
else
|
|
{
|
|
SendMessage(GetDlgItem(GetParent(hwndCtrl), IDC_CHECK_LOGON_INHERIT),BM_SETCHECK,(WPARAM)BST_CHECKED,0);
|
|
}
|
|
//SendMessage(GetDlgItem(GetParent(hwndCtrl), IDC_CHECK_ICCP_WZ),BM_CLICK,0,0);
|
|
|
|
}
|
|
|
|
// if radio button from the last is different enabled the apply button
|
|
|
|
if( m_wOldId != wID )
|
|
{
|
|
m_wOldId = wID;
|
|
|
|
m_bPersisted = FALSE;
|
|
}
|
|
|
|
|
|
}
|
|
|
|
else if( wNotifyCode == EN_CHANGE )
|
|
{
|
|
m_bPersisted = FALSE;
|
|
}
|
|
|
|
else if( wNotifyCode == ALN_APPLY )
|
|
{
|
|
SendMessage( GetParent( hwndCtrl ) , PSM_CANCELTOCLOSE , 0 , 0 );
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
|
|
if( !m_bPersisted )
|
|
{
|
|
SendMessage( GetParent( GetParent( hwndCtrl ) ) , PSM_CHANGED , ( WPARAM )GetParent( hwndCtrl ) , 0 );
|
|
}
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
BOOL CLogonSetting::OnDestroy( )
|
|
{
|
|
m_pParent->Release( );
|
|
|
|
return CDialogPropBase::OnDestroy( );
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
BOOL CLogonSetting::PersistSettings( HWND hDlg )
|
|
{
|
|
if( m_pParent != NULL )
|
|
{
|
|
USERCONFIG uc;
|
|
|
|
m_pParent->GetCurrentUserConfig( uc, TRUE );
|
|
|
|
uc.fPromptForPassword = SendMessage( GetDlgItem( hDlg , IDC_CHECK_LOGON_PROMPTPASSWD ) , BM_GETCHECK , 0 , 0 ) == BST_CHECKED ? TRUE : FALSE;
|
|
|
|
if( !uc.fPromptForPassword )
|
|
{
|
|
if( !ConfirmPassWd( hDlg ) )
|
|
{
|
|
return FALSE;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
SecureZeroMemory( ( PVOID )uc.Password , sizeof( uc.Password ) );
|
|
}
|
|
|
|
if( SendMessage( GetDlgItem( hDlg , IDC_CHECK_LOGON_INHERIT ) , BM_GETCHECK , 0 , 0 ) == BST_CHECKED )
|
|
{
|
|
uc.fInheritAutoLogon = TRUE;
|
|
|
|
ZeroMemory( ( PVOID )uc.UserName , sizeof( uc.UserName ) );
|
|
|
|
ZeroMemory( ( PVOID )uc.Domain , sizeof( uc.Domain ) );
|
|
|
|
SecureZeroMemory( ( PVOID )uc.Password , sizeof( uc.Password ) );
|
|
}
|
|
else
|
|
{
|
|
uc.fInheritAutoLogon = FALSE;
|
|
|
|
GetWindowText( GetDlgItem( hDlg , IDC_EDIT_LOGON_USRNAME ) , uc.UserName , USERNAME_LENGTH + 1 );
|
|
|
|
GetWindowText( GetDlgItem( hDlg , IDC_EDIT_LOGON_DOMAIN ) , uc.Domain , DOMAIN_LENGTH + 1 );
|
|
|
|
GetWindowText( GetDlgItem( hDlg , IDC_EDIT_LOGON_PASSWD ) , uc.Password , PASSWORD_LENGTH + 1 );
|
|
}
|
|
|
|
DWORD dwStatus;
|
|
|
|
if( FAILED( m_pParent->SetUserConfig( uc , &dwStatus ) ) )
|
|
{
|
|
ReportStatusError( hDlg , dwStatus );
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
ICfgComp *pCfgcomp = NULL;
|
|
|
|
if( m_pParent->m_pResNode->GetServer( &pCfgcomp ) > 0 )
|
|
{
|
|
VERIFY_S( S_OK , pCfgcomp->ForceUpdate( ) );
|
|
|
|
VERIFY_S( S_OK , pCfgcomp->Refresh( ) );
|
|
|
|
// global flag can only be set to true
|
|
|
|
m_pParent->m_bPropertiesChange = TRUE;
|
|
|
|
pCfgcomp->Release( );
|
|
}
|
|
|
|
PostMessage( hDlg , WM_COMMAND , MAKELPARAM( 0 , ALN_APPLY ) , ( LPARAM )hDlg );
|
|
|
|
SendMessage( GetParent( hDlg ) , PSM_UNCHANGED , ( WPARAM )hDlg , 0 );
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
BOOL CLogonSetting::IsValidSettings( HWND hDlg )
|
|
{
|
|
if( SendMessage( GetDlgItem( hDlg , IDC_CHECK_LOGON_PROMPTPASSWD ) , BM_GETCHECK , 0 , 0 ) == BST_UNCHECKED )
|
|
{
|
|
return ConfirmPassWd( hDlg );
|
|
}
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
BOOL CLogonSetting::ConfirmPassWd( HWND hDlg )
|
|
{
|
|
TCHAR tchPzWd[ PASSWORD_LENGTH + 1];
|
|
|
|
TCHAR tchConfirm[ PASSWORD_LENGTH + 1];
|
|
|
|
if( SendMessage( GetDlgItem( hDlg , IDC_CHECK_LOGON_INHERIT ) , BM_GETCHECK , 0 , 0 ) == BST_CHECKED )
|
|
{
|
|
return TRUE;
|
|
}
|
|
|
|
int iSz = GetWindowText( GetDlgItem( hDlg , IDC_EDIT_LOGON_PASSWD ) , tchPzWd , PASSWORD_LENGTH + 1 );
|
|
|
|
// warn on the minimum and maximum sizes
|
|
|
|
if( iSz > PASSWORD_LENGTH ) //if( iSz > 0 && ( iSz < 6 || iSz > PASSWORD_LENGTH ) )
|
|
{
|
|
|
|
ErrMessage( hDlg , IDS_ERR_PASSWD );
|
|
|
|
// set focus back on password and erase the confirm entry
|
|
|
|
SetFocus( GetDlgItem( hDlg , IDC_EDIT_LOGON_PASSWD ) );
|
|
|
|
SendMessage( GetDlgItem( hDlg , IDC_EDIT_LOGON_PASSWD ) , EM_SETSEL , ( WPARAM )0 , ( LPARAM )-1 );
|
|
|
|
SetWindowText( GetDlgItem( hDlg , IDC_EDIT_LOGON_CONFIRMPASSWD ) , L"" );
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
int iSz2 = GetWindowText( GetDlgItem( hDlg , IDC_EDIT_LOGON_CONFIRMPASSWD ) , tchConfirm , PASSWORD_LENGTH + 1 );
|
|
|
|
if( iSz == iSz2 )
|
|
{
|
|
if( iSz == 0 )
|
|
{
|
|
return TRUE;
|
|
}
|
|
|
|
if( lstrcmp( tchPzWd , tchConfirm ) == 0 )
|
|
{
|
|
return TRUE;
|
|
}
|
|
}
|
|
|
|
ErrMessage( hDlg , IDS_ERR_PASSCONFIRM );
|
|
|
|
SetFocus( GetDlgItem( hDlg , IDC_EDIT_LOGON_CONFIRMPASSWD ) );
|
|
|
|
SetWindowText( GetDlgItem( hDlg , IDC_EDIT_LOGON_CONFIRMPASSWD ) , L"" );
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
//*****************************************************************************
|
|
// Time out settings dialog
|
|
|
|
|
|
CTimeSetting::CTimeSetting( CPropsheet *pSheet )
|
|
{
|
|
m_pParent = pSheet;
|
|
|
|
m_wOldAction = ( WORD )-1;
|
|
|
|
m_wOldCon = ( WORD )-1;
|
|
|
|
m_bPrevClient = FALSE;
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
BOOL CTimeSetting::OnInitDialog( HWND hwnd , WPARAM wp , LPARAM lp )
|
|
{
|
|
TCHAR tchBuffer[ 80 ];
|
|
|
|
if( m_pParent == NULL )
|
|
{
|
|
ODS( L"CTimeSetting::OnInitDialog - PropertySheet: We've lost our parent node!!!\n" );
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
m_pParent->AddRef( );
|
|
|
|
USERCONFIG uc;
|
|
|
|
HWND hCombo[ 3 ] =
|
|
{
|
|
GetDlgItem( hwnd , IDC_COMBO_TIMEOUTS_CON_PS ),
|
|
|
|
GetDlgItem( hwnd , IDC_COMBO_TIMEOUTS_DISCON_PS ),
|
|
|
|
GetDlgItem( hwnd , IDC_COMBO_TIMEOUTS_IDLE_PS )
|
|
};
|
|
|
|
DWORD rgdwTime[] = { 0 , 1 , 5 , 10 , 15 , 30 , 60 , 120 , 180 , 1440 , 2880 , ( DWORD )-1 };
|
|
|
|
|
|
for( int idx = 0; rgdwTime[ idx ] != ( DWORD)-1; ++idx )
|
|
{
|
|
if( rgdwTime[ idx ] == 0 )
|
|
{
|
|
LoadString( _Module.GetResourceInstance( ) , IDS_NOTIMEOUT , tchBuffer , SIZE_OF_BUFFER( tchBuffer ) );
|
|
}
|
|
else
|
|
{
|
|
ConvertToDuration( rgdwTime[ idx ] , tchBuffer );
|
|
}
|
|
|
|
for( int inner = 0 ; inner < 3 ; ++inner )
|
|
{
|
|
SendMessage( hCombo[ inner ] , CB_ADDSTRING , 0 , ( LPARAM )&tchBuffer[0] );
|
|
|
|
SendMessage( hCombo[ inner ] , CB_SETITEMDATA , idx , rgdwTime[ idx ] );
|
|
}
|
|
}
|
|
|
|
|
|
if( !m_pParent->GetCurrentUserConfig( uc, TRUE ) )
|
|
{
|
|
ODS( L"CTimeSetting::OnInitDialog - PropertySheet: Could not get current USERCONFIG\n" );
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
ULONG ulTime;
|
|
|
|
if( uc.MaxConnectionTime > 0 )
|
|
{
|
|
ulTime = uc.MaxConnectionTime / kMilliMinute;
|
|
|
|
InsertSortedAndSetCurSel( hCombo[ 0 ] , ulTime );
|
|
|
|
}
|
|
else
|
|
{
|
|
SendMessage( hCombo[ 0 ] , CB_SETCURSEL , 0 , 0 );
|
|
}
|
|
|
|
CTimeOutDlg::InitControl( hCombo[ 0 ] );
|
|
|
|
//
|
|
// Set the current or default disconnection timeout
|
|
//
|
|
|
|
if( uc.MaxDisconnectionTime > 0 )
|
|
{
|
|
ulTime = uc.MaxDisconnectionTime / kMilliMinute;
|
|
|
|
InsertSortedAndSetCurSel( hCombo[ 1 ] , ulTime );
|
|
|
|
}
|
|
else
|
|
{
|
|
SendMessage( hCombo[ 1] , CB_SETCURSEL , 0 , 0 );
|
|
}
|
|
|
|
CTimeOutDlg::InitControl( hCombo[ 1 ] );
|
|
|
|
//
|
|
// Set the current or default idle timeout
|
|
//
|
|
|
|
if( uc.MaxIdleTime > 0 )
|
|
{
|
|
ulTime = uc.MaxIdleTime / kMilliMinute;
|
|
|
|
InsertSortedAndSetCurSel( hCombo[ 2 ] , ulTime );
|
|
|
|
}
|
|
else
|
|
{
|
|
SendMessage( hCombo[ 2 ] , CB_SETCURSEL , 0 , 0 );
|
|
}
|
|
|
|
CTimeOutDlg::InitControl( hCombo[ 2 ] );
|
|
|
|
//
|
|
// all the timeout settings will have the same inherit status (NOT!)
|
|
//
|
|
// GP made all these settings orthogonal. When we write son of TSCC
|
|
// in Blackcomb, we should allow individual settings.
|
|
//
|
|
|
|
// ASSERT( ( BOOL )uc.fInheritMaxSessionTime == ( BOOL )uc.fInheritMaxDisconnectionTime );
|
|
|
|
// ASSERT( ( BOOL )uc.fInheritMaxSessionTime == ( BOOL )uc.fInheritMaxIdleTime );
|
|
|
|
DBGMSG( L"uc.fInheritMaxSessionTime %d\n" , uc.fInheritMaxSessionTime );
|
|
|
|
DBGMSG( L"uc.fInheritMaxDisconnectionTime %d\n" , uc.fInheritMaxDisconnectionTime );
|
|
|
|
DBGMSG( L"uc.fInheritMaxIdleTime %d\n" , uc.fInheritMaxIdleTime );
|
|
|
|
SendMessage( GetDlgItem( hwnd , IDC_CHECK_INHERITTIMEOUT_PS ) , BM_SETCHECK , ( WPARAM )( BOOL )!uc.fInheritMaxSessionTime , 0 );
|
|
|
|
SetTimeoutControls(hwnd);
|
|
|
|
SendMessage( GetDlgItem( hwnd , IDC_CHECK_TIMEOUTS_INHERITBKCON_PS ) , BM_SETCHECK , ( WPARAM )!uc.fInheritResetBroken , 0 );
|
|
|
|
if( uc.fResetBroken ) //BST_CHECKED : BST_UNCHECKED
|
|
{
|
|
CheckDlgButton( hwnd , IDC_RADIO_TIMEOUTS_RESET_PS , BST_CHECKED );
|
|
|
|
m_wOldAction = IDC_RADIO_TIMEOUTS_RESET_PS;
|
|
}
|
|
else
|
|
{
|
|
CheckDlgButton( hwnd , IDC_RADIO_TIMEOUTS_DISCON_PS , BST_CHECKED );
|
|
|
|
m_wOldAction = IDC_RADIO_TIMEOUTS_DISCON_PS;
|
|
}
|
|
|
|
/*
|
|
if( uc.fReconnectSame )
|
|
{
|
|
CheckDlgButton( hwnd , IDC_RADIO_TIMEOUTS_PREVCLNT_PS , BST_CHECKED );
|
|
|
|
m_wOldCon = IDC_RADIO_TIMEOUTS_PREVCLNT_PS;
|
|
}
|
|
else
|
|
{
|
|
CheckDlgButton( hwnd , IDC_RADIO_TIMEOUTS_ANYCLIENT_PS , BST_CHECKED );
|
|
|
|
m_wOldCon = IDC_RADIO_TIMEOUTS_ANYCLIENT_PS;
|
|
}
|
|
*/
|
|
|
|
SetBkResetControls(hwnd);
|
|
|
|
SendMessage( GetDlgItem( hwnd , IDC_CHECK_TIMEOUTS_INHERITRECON_PS ) , BM_SETCHECK , ( WPARAM )!uc.fInheritReconnectSame , 0 );
|
|
|
|
//SetReconControls( hwnd , !uc.fInheritReconnectSame );
|
|
|
|
LoadAbbreviates( );
|
|
|
|
ICfgComp *pCfgcomp = NULL;
|
|
|
|
if( m_pParent->m_pResNode->GetServer( &pCfgcomp ) != 0 )
|
|
{
|
|
|
|
BOOL bReadOnly = FALSE;
|
|
|
|
if( SUCCEEDED( pCfgcomp->IsSessionReadOnly( &bReadOnly ) ) )
|
|
{
|
|
if( bReadOnly )
|
|
{
|
|
// disable the remaining controls
|
|
int rgID[] = {
|
|
IDC_COMBO_TIMEOUTS_CON_PS ,
|
|
IDC_COMBO_TIMEOUTS_DISCON_PS ,
|
|
IDC_COMBO_TIMEOUTS_IDLE_PS ,
|
|
|
|
IDC_RADIO_TIMEOUTS_DISCON_PS ,
|
|
IDC_RADIO_TIMEOUTS_RESET_PS ,
|
|
|
|
IDC_RADIO_TIMEOUTS_ANYCLIENT_PS ,
|
|
IDC_RADIO_TIMEOUTS_PREVCLNT_PS ,
|
|
|
|
IDC_CHECK_INHERITTIMEOUT_PS,
|
|
IDC_CHECK_TIMEOUTS_INHERITBKCON_PS,
|
|
IDC_CHECK_TIMEOUTS_INHERITRECON_PS,
|
|
|
|
-1
|
|
};
|
|
|
|
|
|
EnableGroup( hwnd , &rgID[ 0 ] , FALSE );
|
|
}
|
|
}
|
|
|
|
if( !bReadOnly )
|
|
{
|
|
ULONG mask = 0;
|
|
|
|
if( SUCCEEDED( pCfgcomp->GetCaps( m_pParent->m_pResNode->GetTypeName( ) , &mask ) ) )
|
|
{
|
|
// citrix only flag
|
|
|
|
m_bPrevClient = mask & WDC_RECONNECT_PREVCLIENT;
|
|
|
|
if( !m_bPrevClient )
|
|
{
|
|
EnableWindow( GetDlgItem( hwnd , IDC_CHECK_TIMEOUTS_INHERITRECON_PS ) , FALSE );
|
|
}
|
|
|
|
SetReconControls(hwnd);
|
|
}
|
|
}
|
|
|
|
|
|
pCfgcomp->Release( );
|
|
}
|
|
|
|
if( uc.fReconnectSame )
|
|
{
|
|
CheckDlgButton( hwnd , IDC_RADIO_TIMEOUTS_PREVCLNT_PS , BST_CHECKED );
|
|
|
|
m_wOldCon = IDC_RADIO_TIMEOUTS_PREVCLNT_PS;
|
|
}
|
|
else
|
|
{
|
|
CheckDlgButton( hwnd , IDC_RADIO_TIMEOUTS_ANYCLIENT_PS , BST_CHECKED );
|
|
|
|
m_wOldCon = IDC_RADIO_TIMEOUTS_ANYCLIENT_PS;
|
|
}
|
|
|
|
|
|
m_bPersisted = TRUE;
|
|
|
|
return CDialogPropBase::OnInitDialog( hwnd , wp , lp );
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// the next set of functions manage the enabling and disabling of the controls
|
|
//-----------------------------------------------------------------------------
|
|
|
|
void CTimeSetting::SetTimeoutControls(HWND hDlg)
|
|
{
|
|
POLICY_TS_MACHINE p;
|
|
RegGetMachinePolicy(&p);
|
|
|
|
BOOL bOverride =
|
|
(SendMessage(GetDlgItem(hDlg, IDC_CHECK_INHERITTIMEOUT_PS), BM_GETCHECK, 0, 0) == BST_CHECKED);
|
|
|
|
EnableWindow(GetDlgItem(hDlg, IDC_COMBO_TIMEOUTS_CON_PS), (bOverride && !p.fPolicyMaxSessionTime));
|
|
EnableWindow(GetDlgItem(hDlg, IDC_STATIC_TIMCON), (bOverride && !p.fPolicyMaxSessionTime));
|
|
|
|
EnableWindow(GetDlgItem(hDlg, IDC_COMBO_TIMEOUTS_DISCON_PS), (bOverride && !p.fPolicyMaxDisconnectionTime));
|
|
EnableWindow(GetDlgItem(hDlg, IDC_STATIC_TIMDISCON), (bOverride && !p.fPolicyMaxDisconnectionTime));
|
|
|
|
EnableWindow(GetDlgItem(hDlg, IDC_COMBO_TIMEOUTS_IDLE_PS), (bOverride && !p.fPolicyMaxIdleTime));
|
|
EnableWindow(GetDlgItem(hDlg, IDC_STATIC_TIMIDLE), (bOverride && !p.fPolicyMaxIdleTime));
|
|
|
|
EnableWindow(GetDlgItem(hDlg, IDC_CHECK_INHERITTIMEOUT_PS),
|
|
!(p.fPolicyMaxSessionTime && p.fPolicyMaxDisconnectionTime && p.fPolicyMaxIdleTime));
|
|
}
|
|
|
|
void CTimeSetting::SetBkResetControls(HWND hDlg)
|
|
{
|
|
POLICY_TS_MACHINE p;
|
|
RegGetMachinePolicy(&p);
|
|
|
|
BOOL bOverride =
|
|
(SendMessage(GetDlgItem(hDlg, IDC_CHECK_TIMEOUTS_INHERITBKCON_PS), BM_GETCHECK, 0, 0) == BST_CHECKED);
|
|
|
|
EnableWindow(GetDlgItem(hDlg, IDC_RADIO_TIMEOUTS_DISCON_PS), bOverride && !p.fPolicyResetBroken);
|
|
EnableWindow(GetDlgItem(hDlg, IDC_RADIO_TIMEOUTS_RESET_PS), bOverride && !p.fPolicyResetBroken);
|
|
|
|
EnableWindow(GetDlgItem(hDlg, IDC_CHECK_TIMEOUTS_INHERITBKCON_PS), !p.fPolicyResetBroken);
|
|
}
|
|
|
|
void CTimeSetting::SetReconControls(HWND hDlg)
|
|
{
|
|
POLICY_TS_MACHINE p;
|
|
RegGetMachinePolicy(&p);
|
|
|
|
BOOL bOverride =
|
|
(SendMessage(GetDlgItem(hDlg, IDC_CHECK_TIMEOUTS_INHERITRECON_PS), BM_GETCHECK, 0, 0) == BST_CHECKED);
|
|
|
|
if( !m_bPrevClient )
|
|
{
|
|
EnableWindow(GetDlgItem(hDlg, IDC_RADIO_TIMEOUTS_ANYCLIENT_PS), FALSE);
|
|
EnableWindow(GetDlgItem(hDlg, IDC_RADIO_TIMEOUTS_PREVCLNT_PS), FALSE);
|
|
EnableWindow(GetDlgItem(hDlg, IDC_CHECK_TIMEOUTS_INHERITRECON_PS), FALSE);
|
|
}
|
|
else
|
|
{
|
|
EnableWindow(GetDlgItem(hDlg, IDC_RADIO_TIMEOUTS_ANYCLIENT_PS), bOverride && !p.fPolicyReconnectSame);
|
|
EnableWindow(GetDlgItem(hDlg, IDC_RADIO_TIMEOUTS_PREVCLNT_PS), bOverride && !p.fPolicyReconnectSame);
|
|
EnableWindow(GetDlgItem(hDlg, IDC_CHECK_TIMEOUTS_INHERITRECON_PS), !p.fPolicyReconnectSame);
|
|
}
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
INT_PTR CALLBACK CTimeSetting::DlgProc( HWND hwnd , UINT msg , WPARAM wp , LPARAM lp )
|
|
{
|
|
CTimeSetting *pDlg;
|
|
|
|
if( msg == WM_INITDIALOG )
|
|
{
|
|
CTimeSetting *pDlg = ( CTimeSetting * )( ( PROPSHEETPAGE *)lp )->lParam ;
|
|
|
|
SetWindowLongPtr( hwnd , DWLP_USER , ( LONG_PTR )pDlg );
|
|
|
|
if( !IsBadReadPtr( pDlg , sizeof( CTimeSetting ) ) )
|
|
{
|
|
pDlg->OnInitDialog( hwnd , wp , lp );
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
else
|
|
{
|
|
pDlg = ( CTimeSetting * )GetWindowLongPtr( hwnd , DWLP_USER );
|
|
|
|
if( IsBadReadPtr( pDlg , sizeof( CTimeSetting ) ) )
|
|
{
|
|
return FALSE;
|
|
}
|
|
}
|
|
|
|
switch( msg )
|
|
{
|
|
|
|
case WM_NCDESTROY:
|
|
|
|
pDlg->OnDestroy( );
|
|
|
|
break;
|
|
|
|
case WM_COMMAND:
|
|
|
|
pDlg->OnCommand( HIWORD( wp ) , LOWORD( wp ) , ( HWND )lp );
|
|
|
|
break;
|
|
|
|
case WM_CONTEXTMENU:
|
|
{
|
|
POINT pt;
|
|
|
|
pt.x = LOWORD( lp );
|
|
|
|
pt.y = HIWORD( lp );
|
|
|
|
pDlg->OnContextMenu( ( HWND )wp , pt );
|
|
}
|
|
|
|
break;
|
|
|
|
case WM_HELP:
|
|
|
|
pDlg->OnHelp( hwnd , ( LPHELPINFO )lp );
|
|
|
|
break;
|
|
|
|
case WM_NOTIFY:
|
|
|
|
return pDlg->OnNotify( ( int )wp , ( LPNMHDR )lp , hwnd );
|
|
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
BOOL CTimeSetting::GetPropertySheetPage( PROPSHEETPAGE& psp )
|
|
{
|
|
ZeroMemory( &psp , sizeof( PROPSHEETPAGE ) );
|
|
|
|
psp.dwSize = sizeof( PROPSHEETPAGE );
|
|
|
|
psp.dwFlags = PSP_DEFAULT;
|
|
|
|
psp.hInstance = _Module.GetResourceInstance( );
|
|
|
|
psp.pszTemplate = MAKEINTRESOURCE( IDD_TIMEOUTS_PS );
|
|
|
|
psp.lParam = ( LPARAM )this;
|
|
|
|
psp.pfnDlgProc = CTimeSetting::DlgProc;
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
BOOL CTimeSetting::OnCommand( WORD wNotifyCode , WORD wID , HWND hwndCtrl )
|
|
{
|
|
if( wNotifyCode == BN_CLICKED )
|
|
{
|
|
if( wID == IDC_CHECK_INHERITTIMEOUT_PS )
|
|
{
|
|
SetTimeoutControls(GetParent(hwndCtrl));
|
|
|
|
m_bPersisted = FALSE;
|
|
}
|
|
else if( wID == IDC_CHECK_TIMEOUTS_INHERITBKCON_PS )
|
|
{
|
|
SetBkResetControls(GetParent(hwndCtrl));
|
|
|
|
m_bPersisted = FALSE;
|
|
}
|
|
else if( wID == IDC_CHECK_TIMEOUTS_INHERITRECON_PS )
|
|
{
|
|
SetReconControls(GetParent(hwndCtrl));
|
|
|
|
m_bPersisted = FALSE;
|
|
}
|
|
else if( wID == IDC_RADIO_TIMEOUTS_DISCON_PS || wID == IDC_RADIO_TIMEOUTS_RESET_PS )
|
|
{
|
|
if( wID != m_wOldAction )
|
|
{
|
|
m_wOldAction = wID;
|
|
|
|
m_bPersisted = FALSE;
|
|
}
|
|
}
|
|
else if( wID == IDC_RADIO_TIMEOUTS_ANYCLIENT_PS || wID == IDC_RADIO_TIMEOUTS_PREVCLNT_PS )
|
|
{
|
|
if( wID != m_wOldCon )
|
|
{
|
|
m_wOldCon = wID;
|
|
|
|
m_bPersisted = FALSE;
|
|
}
|
|
}
|
|
|
|
|
|
}
|
|
else if( wNotifyCode == ALN_APPLY )
|
|
{
|
|
SendMessage( GetParent( hwndCtrl ) , PSM_CANCELTOCLOSE , 0 , 0 );
|
|
|
|
return FALSE;
|
|
}
|
|
else
|
|
{
|
|
CTimeOutDlg::OnCommand( wNotifyCode , wID , hwndCtrl , &m_bPersisted );
|
|
}
|
|
|
|
if( !m_bPersisted )
|
|
{
|
|
SendMessage( GetParent( GetParent( hwndCtrl ) ) , PSM_CHANGED , ( WPARAM )GetParent( hwndCtrl ) , 0 );
|
|
}
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
int CTimeSetting::GetCBXSTATEindex( HWND hCombo )
|
|
{
|
|
int idx = -1;
|
|
|
|
switch( GetDlgCtrlID( hCombo ) )
|
|
{
|
|
case IDC_COMBO_TIMEOUTS_CON_PS:
|
|
|
|
idx = 0;
|
|
|
|
break;
|
|
|
|
case IDC_COMBO_TIMEOUTS_DISCON_PS:
|
|
|
|
idx = 1;
|
|
|
|
break;
|
|
|
|
case IDC_COMBO_TIMEOUTS_IDLE_PS:
|
|
|
|
idx = 2;
|
|
|
|
break;
|
|
}
|
|
|
|
return idx;
|
|
}
|
|
|
|
|
|
|
|
//-------------------------------------------------------------------------------
|
|
// PersistSettings
|
|
//-------------------------------------------------------------------------------
|
|
BOOL CTimeSetting::PersistSettings( HWND hDlg )
|
|
{
|
|
if( m_pParent == NULL )
|
|
{
|
|
return FALSE;
|
|
}
|
|
|
|
USERCONFIG uc;
|
|
|
|
if( !m_pParent->GetCurrentUserConfig( uc, TRUE ) )
|
|
{
|
|
return FALSE;
|
|
}
|
|
|
|
if( SendMessage( GetDlgItem( hDlg , IDC_CHECK_INHERITTIMEOUT_PS ) , BM_GETCHECK , 0 , 0 ) == BST_UNCHECKED )
|
|
{
|
|
uc.fInheritMaxSessionTime = 1;
|
|
|
|
uc.fInheritMaxDisconnectionTime = 1;
|
|
|
|
uc.fInheritMaxIdleTime = 1;
|
|
|
|
// reset timeout values to no timeout
|
|
|
|
uc.MaxConnectionTime = 0;
|
|
|
|
uc.MaxDisconnectionTime = 0;
|
|
|
|
uc.MaxIdleTime = 0;
|
|
|
|
}
|
|
else
|
|
{
|
|
uc.fInheritMaxSessionTime = 0;
|
|
|
|
uc.fInheritMaxDisconnectionTime = 0;
|
|
|
|
uc.fInheritMaxIdleTime = 0;
|
|
|
|
if( !ConvertToMinutes( GetDlgItem( hDlg , IDC_COMBO_TIMEOUTS_CON_PS ) , &uc.MaxConnectionTime ) )
|
|
{
|
|
return FALSE;
|
|
}
|
|
|
|
if( !ConvertToMinutes( GetDlgItem( hDlg , IDC_COMBO_TIMEOUTS_DISCON_PS ) , &uc.MaxDisconnectionTime ) )
|
|
{
|
|
return FALSE;
|
|
}
|
|
|
|
if( !ConvertToMinutes( GetDlgItem( hDlg , IDC_COMBO_TIMEOUTS_IDLE_PS ) , &uc.MaxIdleTime ) )
|
|
{
|
|
return FALSE;
|
|
}
|
|
}
|
|
|
|
if( SendMessage( GetDlgItem( hDlg , IDC_CHECK_TIMEOUTS_INHERITBKCON_PS ) , BM_GETCHECK , 0 , 0 ) == BST_UNCHECKED )
|
|
{
|
|
uc.fInheritResetBroken = 1;
|
|
}
|
|
else
|
|
{
|
|
uc.fInheritResetBroken = 0;
|
|
|
|
uc.fResetBroken = SendMessage( GetDlgItem( hDlg , IDC_RADIO_TIMEOUTS_RESET_PS ) , BM_GETCHECK , 0 , 0 ) == BST_CHECKED ? TRUE : FALSE;
|
|
}
|
|
|
|
if( SendMessage( GetDlgItem( hDlg , IDC_CHECK_TIMEOUTS_INHERITRECON_PS ) , BM_GETCHECK , 0 , 0 ) == BST_UNCHECKED )
|
|
{
|
|
uc.fInheritReconnectSame = 1;
|
|
}
|
|
else
|
|
{
|
|
uc.fInheritReconnectSame = 0;
|
|
|
|
uc.fReconnectSame = ( ULONG )SendMessage( GetDlgItem( hDlg , IDC_RADIO_TIMEOUTS_PREVCLNT_PS ) , BM_GETCHECK , 0 , 0 ) == BST_CHECKED ? TRUE : FALSE;
|
|
}
|
|
|
|
DWORD dwStatus;
|
|
|
|
if( FAILED( m_pParent->SetUserConfig( uc , &dwStatus ) ) )
|
|
{
|
|
ReportStatusError( hDlg , dwStatus );
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
ICfgComp *pCfgcomp = NULL;
|
|
|
|
if( m_pParent->m_pResNode->GetServer( &pCfgcomp ) > 0 )
|
|
{
|
|
VERIFY_S( S_OK , pCfgcomp->ForceUpdate( ) );
|
|
|
|
VERIFY_S( S_OK , pCfgcomp->Refresh( ) );
|
|
|
|
// global flag can only be set to true
|
|
|
|
m_pParent->m_bPropertiesChange = TRUE;
|
|
|
|
pCfgcomp->Release( );
|
|
}
|
|
|
|
PostMessage( hDlg , WM_COMMAND , MAKELPARAM( 0 , ALN_APPLY ) , ( LPARAM )hDlg );
|
|
|
|
SendMessage( GetParent( hDlg ) , PSM_UNCHANGED , ( WPARAM )hDlg , 0 );
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
//-------------------------------------------------------------------------------
|
|
// Making sure the user has entered valid info
|
|
//-------------------------------------------------------------------------------
|
|
BOOL CTimeSetting::IsValidSettings( HWND hDlg )
|
|
{
|
|
if( m_pParent == NULL )
|
|
{
|
|
return FALSE;
|
|
}
|
|
|
|
USERCONFIG uc;
|
|
|
|
if( !m_pParent->GetCurrentUserConfig( uc, TRUE ) )
|
|
{
|
|
return FALSE;
|
|
}
|
|
|
|
if( SendMessage( GetDlgItem( hDlg , IDC_CHECK_INHERITTIMEOUT_PS ) , BM_GETCHECK , 0 , 0 ) == BST_CHECKED )
|
|
{
|
|
if( !ConvertToMinutes( GetDlgItem( hDlg , IDC_COMBO_TIMEOUTS_CON_PS ) , &uc.MaxConnectionTime ) )
|
|
{
|
|
return FALSE;
|
|
}
|
|
|
|
if( !ConvertToMinutes( GetDlgItem( hDlg , IDC_COMBO_TIMEOUTS_DISCON_PS ) , &uc.MaxDisconnectionTime ) )
|
|
{
|
|
return FALSE;
|
|
}
|
|
|
|
if( !ConvertToMinutes( GetDlgItem( hDlg , IDC_COMBO_TIMEOUTS_IDLE_PS ) , &uc.MaxIdleTime ) )
|
|
{
|
|
return FALSE;
|
|
}
|
|
}
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
|
|
//-----------------------------------------------------------------------------
|
|
BOOL CTimeSetting::OnDestroy( )
|
|
{
|
|
m_pParent->Release( );
|
|
|
|
ReleaseAbbreviates( );
|
|
|
|
return CDialogPropBase::OnDestroy( );
|
|
}
|
|
|
|
//*****************************************************************************
|
|
// Environment dialog
|
|
|
|
CEnviro::CEnviro( CPropsheet *pSheet )
|
|
{
|
|
m_pParent = pSheet;
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
BOOL CEnviro::OnInitDialog( HWND hwnd , WPARAM wp , LPARAM lp )
|
|
{
|
|
if( m_pParent == NULL )
|
|
{
|
|
ODS( L"CEnviro::OnInitDialog - PropertySheet: Parent object is lost!!!\n" );
|
|
return FALSE;
|
|
}
|
|
|
|
m_pParent->AddRef( );
|
|
|
|
USERCONFIG uc;
|
|
|
|
if( !m_pParent->GetCurrentUserConfig( uc, TRUE ) )
|
|
{
|
|
ODS( L"CEnviro::OnInitDialog - PropertySheet: Failed to obtain USERCONFIG\n" );
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
SendMessage( GetDlgItem( hwnd , IDC_EDIT_ENVIRO_CMDLINE ) , EM_SETLIMITTEXT , ( WPARAM )INITIALPROGRAM_LENGTH , 0 );
|
|
|
|
SendMessage( GetDlgItem( hwnd , IDC_EDIT_ENVIRO_WD ) , EM_SETLIMITTEXT , ( WPARAM )DIRECTORY_LENGTH , 0 );
|
|
|
|
if(uc.fInheritInitialProgram)
|
|
{
|
|
SendMessage( GetDlgItem( hwnd , IDC_CHECK_ENVIRO_INHERIT ) , BM_SETCHECK , ( WPARAM )BST_UNCHECKED , 0 );
|
|
|
|
}
|
|
else
|
|
{
|
|
SendMessage( GetDlgItem( hwnd , IDC_CHECK_ENVIRO_INHERIT ) , BM_SETCHECK , ( WPARAM )BST_CHECKED, 0 );
|
|
|
|
}
|
|
|
|
if(uc.fInheritInitialProgram)
|
|
{
|
|
SetControls( hwnd , FALSE );
|
|
}
|
|
else
|
|
{
|
|
SetWindowText( GetDlgItem( hwnd , IDC_EDIT_ENVIRO_CMDLINE ) , ( LPCTSTR )uc.InitialProgram );
|
|
|
|
SetWindowText( GetDlgItem( hwnd , IDC_EDIT_ENVIRO_WD ) , ( LPCTSTR )uc.WorkDirectory );
|
|
}
|
|
|
|
// SendMessage( GetDlgItem( hwnd , IDC_CHECK_ENVIRO_DISABLEWALL ) , BM_SETCHECK , ( WPARAM )uc.fWallPaperDisabled , 0 );
|
|
|
|
ICfgComp *pCfgcomp = NULL;
|
|
|
|
if( m_pParent->m_pResNode->GetServer( &pCfgcomp ) != 0 )
|
|
{
|
|
|
|
BOOL bReadOnly;
|
|
|
|
if( SUCCEEDED( pCfgcomp->IsSessionReadOnly( &bReadOnly ) ) )
|
|
{
|
|
if( bReadOnly )
|
|
{
|
|
// make edit controls read-only
|
|
|
|
SendMessage( GetDlgItem( hwnd , IDC_EDIT_ENVIRO_CMDLINE ) , EM_SETREADONLY , ( WPARAM )TRUE , 0 );
|
|
|
|
SendMessage( GetDlgItem( hwnd , IDC_EDIT_ENVIRO_WD ) , EM_SETREADONLY , ( WPARAM )TRUE , 0 );
|
|
|
|
// disable the remaining controls
|
|
int rgID[] = {
|
|
IDC_CHECK_ENVIRO_INHERIT ,
|
|
// IDC_CHECK_ENVIRO_DISABLEWALL,
|
|
-1
|
|
};
|
|
|
|
|
|
EnableGroup( hwnd , &rgID[ 0 ] , FALSE );
|
|
}
|
|
}
|
|
|
|
pCfgcomp->Release( );
|
|
}
|
|
|
|
POLICY_TS_MACHINE p;
|
|
RegGetMachinePolicy(&p);
|
|
if (p.fPolicyInitialProgram)
|
|
{
|
|
int rgID[] =
|
|
{
|
|
IDC_CHECK_ENVIRO_INHERIT,
|
|
IDC_EDIT_ENVIRO_CMDLINE,
|
|
IDC_EDIT_ENVIRO_WD, -1
|
|
};
|
|
EnableGroup(hwnd, &rgID[0], FALSE);
|
|
}
|
|
|
|
m_bPersisted = TRUE;
|
|
|
|
return CDialogPropBase::OnInitDialog( hwnd , wp , lp );
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
INT_PTR CALLBACK CEnviro::DlgProc( HWND hwnd , UINT msg , WPARAM wp , LPARAM lp )
|
|
{
|
|
CEnviro *pDlg;
|
|
|
|
if( msg == WM_INITDIALOG )
|
|
{
|
|
CEnviro *pDlg = ( CEnviro * )( ( PROPSHEETPAGE *)lp )->lParam ;
|
|
|
|
SetWindowLongPtr( hwnd , DWLP_USER , ( LONG_PTR )pDlg );
|
|
|
|
if( !IsBadReadPtr( pDlg , sizeof( CEnviro ) ) )
|
|
{
|
|
pDlg->OnInitDialog( hwnd , wp , lp );
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
else
|
|
{
|
|
pDlg = ( CEnviro * )GetWindowLongPtr( hwnd , DWLP_USER );
|
|
|
|
if( IsBadReadPtr( pDlg , sizeof( CEnviro ) ) )
|
|
{
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
switch( msg )
|
|
{
|
|
|
|
case WM_NCDESTROY:
|
|
|
|
pDlg->OnDestroy( );
|
|
|
|
break;
|
|
|
|
case WM_COMMAND:
|
|
|
|
pDlg->OnCommand( HIWORD( wp ) , LOWORD( wp ) , ( HWND )lp );
|
|
|
|
break;
|
|
|
|
case WM_CONTEXTMENU:
|
|
{
|
|
POINT pt;
|
|
|
|
pt.x = LOWORD( lp );
|
|
|
|
pt.y = HIWORD( lp );
|
|
|
|
pDlg->OnContextMenu( ( HWND )wp , pt );
|
|
}
|
|
|
|
break;
|
|
|
|
case WM_HELP:
|
|
|
|
pDlg->OnHelp( hwnd , ( LPHELPINFO )lp );
|
|
|
|
break;
|
|
|
|
case WM_NOTIFY:
|
|
|
|
return pDlg->OnNotify( ( int )wp , ( LPNMHDR )lp , hwnd );
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
BOOL CEnviro::GetPropertySheetPage( PROPSHEETPAGE& psp )
|
|
{
|
|
ZeroMemory( &psp , sizeof( PROPSHEETPAGE ) );
|
|
|
|
psp.dwSize = sizeof( PROPSHEETPAGE );
|
|
|
|
psp.dwFlags = PSP_DEFAULT;
|
|
|
|
psp.hInstance = _Module.GetResourceInstance( );
|
|
|
|
psp.pszTemplate = MAKEINTRESOURCE( IDD_ENVIRONMENT );
|
|
|
|
psp.lParam = ( LPARAM )this;
|
|
|
|
psp.pfnDlgProc = CEnviro::DlgProc;
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
BOOL CEnviro::OnCommand( WORD wNotifyCode , WORD wID , HWND hwndCtrl )
|
|
{
|
|
if( wNotifyCode == BN_CLICKED )
|
|
{
|
|
if( wID == IDC_CHECK_ENVIRO_INHERIT )
|
|
{
|
|
SetControls( GetParent( hwndCtrl ) , SendMessage( hwndCtrl , BM_GETCHECK , 0 , 0 ) == BST_CHECKED );
|
|
}
|
|
|
|
m_bPersisted = FALSE;
|
|
}
|
|
else if( wNotifyCode == EN_CHANGE )
|
|
{
|
|
m_bPersisted = FALSE;
|
|
}
|
|
else if( wNotifyCode == ALN_APPLY )
|
|
{
|
|
SendMessage( GetParent( hwndCtrl ) , PSM_CANCELTOCLOSE , 0 , 0 );
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
if( !m_bPersisted )
|
|
{
|
|
SendMessage( GetParent( GetParent( hwndCtrl ) ) , PSM_CHANGED , ( WPARAM )GetParent( hwndCtrl ) , 0 );
|
|
}
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
void CEnviro::SetControls( HWND hDlg , BOOL bEnable )
|
|
{
|
|
int rgID[] = { IDC_EDIT_ENVIRO_CMDLINE , IDC_STATIC_ENCL , IDC_EDIT_ENVIRO_WD , IDC_STATIC_WD ,-1 };
|
|
|
|
EnableGroup( hDlg , &rgID[ 0 ] , bEnable );
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
BOOL CEnviro::PersistSettings( HWND hDlg )
|
|
{
|
|
if( m_pParent == NULL )
|
|
{
|
|
return FALSE;
|
|
}
|
|
|
|
USERCONFIG uc;
|
|
|
|
if( !m_pParent->GetCurrentUserConfig( uc, TRUE ) )
|
|
{
|
|
return FALSE;
|
|
}
|
|
|
|
uc.fInheritInitialProgram = (( ULONG )SendMessage( GetDlgItem( hDlg , IDC_CHECK_ENVIRO_INHERIT ) , BM_GETCHECK , 0 , 0 )) == BST_UNCHECKED;
|
|
|
|
if( !uc.fInheritInitialProgram )
|
|
{
|
|
GetWindowText( GetDlgItem( hDlg , IDC_EDIT_ENVIRO_CMDLINE ) , uc.InitialProgram , INITIALPROGRAM_LENGTH + 1);
|
|
|
|
GetWindowText( GetDlgItem( hDlg , IDC_EDIT_ENVIRO_WD ) , uc.WorkDirectory , DIRECTORY_LENGTH + 1 );
|
|
}
|
|
else
|
|
{
|
|
ZeroMemory( ( PVOID )uc.InitialProgram , sizeof( uc.InitialProgram ) );
|
|
|
|
ZeroMemory( ( PVOID )uc.WorkDirectory , sizeof( uc.WorkDirectory ) );
|
|
}
|
|
|
|
// uc.fWallPaperDisabled = ( ULONG )SendMessage( GetDlgItem( hDlg , IDC_CHECK_ENVIRO_DISABLEWALL ) , BM_GETCHECK , 0 , 0 );
|
|
|
|
DWORD dwStatus;
|
|
|
|
if( FAILED( m_pParent->SetUserConfig( uc , &dwStatus ) ) )
|
|
{
|
|
ReportStatusError( hDlg , dwStatus );
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
ICfgComp *pCfgcomp = NULL;
|
|
|
|
if( m_pParent->m_pResNode->GetServer( &pCfgcomp ) > 0 )
|
|
{
|
|
VERIFY_S( S_OK , pCfgcomp->ForceUpdate( ) );
|
|
|
|
VERIFY_S( S_OK , pCfgcomp->Refresh( ) );
|
|
|
|
// global flag can only be set to true
|
|
|
|
m_pParent->m_bPropertiesChange = TRUE;
|
|
|
|
pCfgcomp->Release( );
|
|
}
|
|
|
|
PostMessage( hDlg , WM_COMMAND , MAKELPARAM( 0 , ALN_APPLY ) , ( LPARAM )hDlg );
|
|
|
|
SendMessage( GetParent( hDlg ) , PSM_UNCHANGED , ( WPARAM )hDlg , 0 );
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
BOOL CEnviro::OnDestroy( )
|
|
{
|
|
m_pParent->Release( );
|
|
|
|
return CDialogPropBase::OnDestroy( );
|
|
}
|
|
|
|
//*****************************************************************************
|
|
// Shadow dialog
|
|
|
|
CRemote::CRemote( CPropsheet *pSheet )
|
|
{
|
|
m_pParent = pSheet;
|
|
|
|
m_wOldRadioID = ( WORD )-1;
|
|
|
|
m_wOldSel = ( WORD )-1;
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
BOOL CRemote::OnInitDialog( HWND hwnd , WPARAM wp , LPARAM lp )
|
|
{
|
|
if( m_pParent == NULL )
|
|
{
|
|
ODS( L"CRemote::OnInitDialog - PropertySheet: Parent object lost!!\n" );
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
m_pParent->AddRef( );
|
|
|
|
USERCONFIG uc;
|
|
|
|
if( !m_pParent->GetCurrentUserConfig( uc, TRUE ) )
|
|
{
|
|
ODS( L"CRemote::OnInitDialog - PropertySheet: GetCurrentUserConfig failed!!\n" );
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
if( uc.fInheritShadow || uc.Shadow == Shadow_Disable )
|
|
{
|
|
// setup some default values
|
|
|
|
SendMessage( GetDlgItem( hwnd , IDC_CHECK_NOTIFY ) , BM_SETCHECK , ( WPARAM )TRUE , 0 );
|
|
|
|
SendMessage( GetDlgItem( hwnd , IDC_RADIO_WATCH ) , BM_SETCHECK , ( WPARAM )TRUE , 0 );
|
|
|
|
m_wOldSel = IDC_RADIO_WATCH;
|
|
|
|
if( uc.fInheritShadow )
|
|
{
|
|
SendMessage( GetDlgItem( hwnd , IDC_RADIO_REMOTE_INHERIT ) , BM_SETCHECK , ( WPARAM )uc.fInheritShadow , 0 );
|
|
|
|
}
|
|
else
|
|
{
|
|
SendMessage( GetDlgItem( hwnd , IDC_RADIO_NOREMOTE ) , BM_SETCHECK , ( WPARAM )TRUE , 0 );
|
|
|
|
}
|
|
|
|
m_wOldRadioID = ( WORD )( uc.fInheritShadow ? IDC_RADIO_REMOTE_INHERIT : IDC_RADIO_NOREMOTE );
|
|
|
|
SetControls( hwnd , FALSE );
|
|
}
|
|
else
|
|
{
|
|
// Controls are initially enabled, set current status
|
|
|
|
SendMessage( GetDlgItem( hwnd , IDC_RADIO_ENABLE_REMOTE ) , BM_SETCHECK , ( WPARAM )TRUE , 0 );
|
|
|
|
m_wOldRadioID = IDC_RADIO_ENABLE_REMOTE;
|
|
|
|
switch( uc.Shadow )
|
|
{
|
|
case Shadow_EnableInputNotify:
|
|
|
|
SendMessage( GetDlgItem( hwnd , IDC_CHECK_NOTIFY ) , BM_SETCHECK , ( WPARAM )TRUE , 0 );
|
|
|
|
SendMessage( GetDlgItem( hwnd , IDC_RADIO_CONTROL ) , BM_SETCHECK , ( WPARAM )TRUE , 0 );
|
|
|
|
break;
|
|
|
|
case Shadow_EnableInputNoNotify:
|
|
|
|
SendMessage( GetDlgItem( hwnd , IDC_CHECK_NOTIFY ) , BM_SETCHECK , ( WPARAM )FALSE , 0 );
|
|
|
|
SendMessage( GetDlgItem( hwnd , IDC_RADIO_CONTROL ) , BM_SETCHECK , ( WPARAM )TRUE , 0 );
|
|
|
|
break;
|
|
|
|
case Shadow_EnableNoInputNotify:
|
|
|
|
SendMessage( GetDlgItem( hwnd , IDC_CHECK_NOTIFY ) , BM_SETCHECK , ( WPARAM )TRUE , 0 );
|
|
|
|
SendMessage( GetDlgItem( hwnd , IDC_RADIO_WATCH ) , BM_SETCHECK , ( WPARAM )TRUE , 0 );
|
|
|
|
break;
|
|
|
|
case Shadow_EnableNoInputNoNotify:
|
|
|
|
SendMessage( GetDlgItem( hwnd , IDC_CHECK_NOTIFY ) , BM_SETCHECK , ( WPARAM )FALSE , 0 );
|
|
|
|
SendMessage( GetDlgItem( hwnd , IDC_RADIO_WATCH ) , BM_SETCHECK , ( WPARAM )TRUE , 0 );
|
|
|
|
break;
|
|
}
|
|
|
|
if( IsDlgButtonChecked( hwnd , IDC_RADIO_WATCH ) == BST_CHECKED )
|
|
{
|
|
m_wOldSel = IDC_RADIO_WATCH;
|
|
}
|
|
else
|
|
{
|
|
m_wOldSel = IDC_RADIO_CONTROL;
|
|
}
|
|
}
|
|
|
|
ICfgComp *pCfgcomp = NULL;
|
|
|
|
if( m_pParent->m_pResNode->GetServer( &pCfgcomp ) != 0 )
|
|
{
|
|
|
|
BOOL bReadOnly;
|
|
|
|
if( SUCCEEDED( pCfgcomp->IsSessionReadOnly( &bReadOnly ) ) )
|
|
{
|
|
if( bReadOnly )
|
|
{
|
|
// disable the remaining controls
|
|
int rgID[] = {
|
|
IDC_RADIO_ENABLE_REMOTE ,
|
|
IDC_RADIO_NOREMOTE,
|
|
IDC_RADIO_CONTROL,
|
|
IDC_RADIO_REMOTE_INHERIT,
|
|
IDC_RADIO_WATCH,
|
|
IDC_CHECK_NOTIFY,
|
|
-1
|
|
};
|
|
|
|
|
|
EnableGroup( hwnd , &rgID[ 0 ] , FALSE );
|
|
}
|
|
}
|
|
|
|
pCfgcomp->Release( );
|
|
}
|
|
|
|
//Disable all the controls if there is a group policy set
|
|
POLICY_TS_MACHINE p;
|
|
RegGetMachinePolicy(&p);
|
|
|
|
if (p.fPolicyShadow)
|
|
{
|
|
int rgID[] =
|
|
{
|
|
IDC_RADIO_ENABLE_REMOTE ,
|
|
IDC_RADIO_NOREMOTE,
|
|
IDC_RADIO_CONTROL,
|
|
IDC_RADIO_REMOTE_INHERIT,
|
|
IDC_RADIO_WATCH,
|
|
IDC_CHECK_NOTIFY,
|
|
-1
|
|
};
|
|
|
|
EnableGroup( hwnd , &rgID[ 0 ] , FALSE );
|
|
}
|
|
|
|
m_bPersisted = TRUE;
|
|
|
|
return CDialogPropBase::OnInitDialog( hwnd , wp , lp );
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
void CRemote::SetControls( HWND hDlg , BOOL bEnable )
|
|
{
|
|
int rgID[] = { IDC_RADIO_WATCH , IDC_RADIO_CONTROL , IDC_CHECK_NOTIFY , IDC_STATIC_LEVELOFCTRL , -1 };
|
|
|
|
EnableGroup( hDlg , &rgID[ 0 ] , bEnable );
|
|
}
|
|
|
|
|
|
//-----------------------------------------------------------------------------
|
|
INT_PTR CALLBACK CRemote::DlgProc( HWND hwnd , UINT msg , WPARAM wp , LPARAM lp )
|
|
{
|
|
CRemote *pDlg;
|
|
|
|
if( msg == WM_INITDIALOG )
|
|
{
|
|
CRemote *pDlg = ( CRemote * )( ( PROPSHEETPAGE *)lp )->lParam ;
|
|
|
|
SetWindowLongPtr( hwnd , DWLP_USER , ( LONG_PTR )pDlg );
|
|
|
|
if( !IsBadReadPtr( pDlg , sizeof( CRemote ) ) )
|
|
{
|
|
pDlg->OnInitDialog( hwnd , wp , lp );
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
else
|
|
{
|
|
pDlg = ( CRemote * )GetWindowLongPtr( hwnd , DWLP_USER );
|
|
|
|
if( IsBadReadPtr( pDlg , sizeof( CRemote ) ) )
|
|
{
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
switch( msg )
|
|
{
|
|
|
|
case WM_NCDESTROY:
|
|
|
|
pDlg->OnDestroy( );
|
|
|
|
break;
|
|
|
|
case WM_COMMAND:
|
|
|
|
pDlg->OnCommand( HIWORD( wp ) , LOWORD( wp ) , ( HWND )lp );
|
|
|
|
break;
|
|
|
|
case WM_CONTEXTMENU:
|
|
{
|
|
POINT pt;
|
|
|
|
pt.x = LOWORD( lp );
|
|
|
|
pt.y = HIWORD( lp );
|
|
|
|
pDlg->OnContextMenu( ( HWND )wp , pt );
|
|
}
|
|
|
|
break;
|
|
|
|
case WM_HELP:
|
|
|
|
pDlg->OnHelp( hwnd , ( LPHELPINFO )lp );
|
|
|
|
break;
|
|
|
|
case WM_NOTIFY:
|
|
|
|
return pDlg->OnNotify( ( int )wp , ( LPNMHDR )lp , hwnd );
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
BOOL CRemote::GetPropertySheetPage( PROPSHEETPAGE& psp )
|
|
{
|
|
ZeroMemory( &psp , sizeof( PROPSHEETPAGE ) );
|
|
|
|
psp.dwSize = sizeof( PROPSHEETPAGE );
|
|
|
|
psp.dwFlags = PSP_DEFAULT;
|
|
|
|
psp.hInstance = _Module.GetResourceInstance( );
|
|
|
|
psp.pszTemplate = MAKEINTRESOURCE( IDD_PAGE_SHADOW );
|
|
|
|
psp.lParam = ( LPARAM )this;
|
|
|
|
psp.pfnDlgProc = CRemote::DlgProc;
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
BOOL CRemote::OnCommand( WORD wNotifyCode , WORD wID , HWND hwndCtrl )
|
|
{
|
|
if( wNotifyCode == BN_CLICKED )
|
|
{
|
|
if( wID == IDC_CHECK_NOTIFY )
|
|
{
|
|
m_bPersisted = FALSE;
|
|
}
|
|
else if( wID == IDC_RADIO_REMOTE_INHERIT || wID == IDC_RADIO_NOREMOTE || wID == IDC_RADIO_ENABLE_REMOTE )
|
|
{
|
|
if( m_wOldRadioID != wID )
|
|
{
|
|
if( wID == IDC_RADIO_REMOTE_INHERIT || wID == IDC_RADIO_NOREMOTE )
|
|
{
|
|
SetControls( GetParent( hwndCtrl ) , FALSE );
|
|
}
|
|
else if( wID == IDC_RADIO_ENABLE_REMOTE )
|
|
{
|
|
SetControls( GetParent( hwndCtrl ) , TRUE );
|
|
}
|
|
|
|
m_wOldRadioID = wID;
|
|
|
|
m_bPersisted = FALSE;
|
|
}
|
|
}
|
|
else if( wID == IDC_RADIO_CONTROL || wID == IDC_RADIO_WATCH )
|
|
{
|
|
if( wID != m_wOldSel )
|
|
{
|
|
m_wOldSel = wID;
|
|
|
|
m_bPersisted = FALSE;
|
|
}
|
|
}
|
|
}
|
|
else if( wNotifyCode == ALN_APPLY )
|
|
{
|
|
SendMessage( GetParent( hwndCtrl ) , PSM_CANCELTOCLOSE , 0 , 0 );
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
if( !m_bPersisted )
|
|
{
|
|
SendMessage( GetParent( GetParent( hwndCtrl ) ) , PSM_CHANGED , ( WPARAM )GetParent( hwndCtrl ) , 0 );
|
|
}
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
BOOL CRemote::OnDestroy( )
|
|
{
|
|
m_pParent->Release( );
|
|
|
|
return CDialogPropBase::OnDestroy( );
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// The nesting may appear scary but its has a nice logic flow to a weird
|
|
// datatype called shadow
|
|
//-----------------------------------------------------------------------------
|
|
BOOL CRemote::PersistSettings( HWND hDlg )
|
|
{
|
|
if( m_pParent != NULL )
|
|
{
|
|
USERCONFIG uc;
|
|
m_pParent->GetCurrentUserConfig( uc, TRUE );
|
|
|
|
if( SendMessage( GetDlgItem( hDlg , IDC_RADIO_REMOTE_INHERIT ) , BM_GETCHECK , 0 , 0 ) == BST_UNCHECKED )
|
|
{
|
|
uc.fInheritShadow = FALSE;
|
|
|
|
if( SendMessage( GetDlgItem( hDlg , IDC_RADIO_NOREMOTE ) , BM_GETCHECK , 0 , 0 ) == BST_UNCHECKED )
|
|
{
|
|
BOOL bCheckNotify = ( BOOL )SendMessage( GetDlgItem( hDlg , IDC_CHECK_NOTIFY ) , BM_GETCHECK , 0 , 0 );
|
|
|
|
BOOL bRadioControl = ( BOOL )SendMessage( GetDlgItem( hDlg , IDC_RADIO_CONTROL ) , BM_GETCHECK , 0 , 0 );
|
|
|
|
if( bCheckNotify )
|
|
{
|
|
if( bRadioControl )
|
|
{
|
|
uc.Shadow = Shadow_EnableInputNotify;
|
|
}
|
|
else
|
|
{
|
|
uc.Shadow = Shadow_EnableNoInputNotify;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if( bRadioControl )
|
|
{
|
|
uc.Shadow = Shadow_EnableInputNoNotify;
|
|
}
|
|
else
|
|
{
|
|
uc.Shadow = Shadow_EnableNoInputNoNotify;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
uc.Shadow = Shadow_Disable;
|
|
}
|
|
|
|
}
|
|
else
|
|
{
|
|
uc.fInheritShadow = TRUE;
|
|
}
|
|
|
|
DWORD dwStatus;
|
|
|
|
if( FAILED( m_pParent->SetUserConfig( uc , &dwStatus ) ) )
|
|
{
|
|
ReportStatusError( hDlg , dwStatus );
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
ICfgComp *pCfgcomp = NULL;
|
|
|
|
if( m_pParent->m_pResNode->GetServer( &pCfgcomp ) > 0 )
|
|
{
|
|
VERIFY_S( S_OK , pCfgcomp->ForceUpdate( ) );
|
|
|
|
VERIFY_S( S_OK , pCfgcomp->Refresh( ) );
|
|
|
|
// global flag can only be set to true
|
|
|
|
m_pParent->m_bPropertiesChange = TRUE;
|
|
|
|
pCfgcomp->Release( );
|
|
}
|
|
|
|
PostMessage( hDlg , WM_COMMAND , MAKELPARAM( 0 , ALN_APPLY ) , ( LPARAM )hDlg );
|
|
|
|
SendMessage( GetParent( hDlg ) , PSM_UNCHANGED , ( WPARAM )hDlg , 0 );
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
//*****************************************************************************
|
|
// Client settings dialog
|
|
|
|
CClient::CClient( CPropsheet *pSheet )
|
|
{
|
|
m_pParent = pSheet;
|
|
m_nColorDepth = TS_8BPP_SUPPORT;
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
BOOL CClient::OnInitDialog( HWND hDlg , WPARAM wp , LPARAM lp )
|
|
{
|
|
if( m_pParent == NULL )
|
|
{
|
|
ODS( L"CClient::OnInitDialog - PropertySheet: Parent object lost!!\n" );
|
|
return FALSE;
|
|
}
|
|
|
|
m_pParent->AddRef( );
|
|
|
|
USERCONFIG uc;
|
|
|
|
if( !m_pParent->GetCurrentUserConfig( uc, TRUE ) )
|
|
{
|
|
ODS( L"CClient::OnInitDialog - PropertySheet: GetCurrentUserConfig failed!!\n" );
|
|
return FALSE;
|
|
}
|
|
|
|
// Obtain capabilities mask
|
|
|
|
ICfgComp *pCfgcomp = NULL;
|
|
|
|
if( m_pParent->m_pResNode->GetServer( &pCfgcomp ) == 0 )
|
|
{
|
|
ODS( L"CClient::OnInitDialog GetServer failed\n" );
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
SendMessage( GetDlgItem( hDlg , IDC_CHECK_CONCLIENT_INHERIT ) , BM_SETCHECK , ( WPARAM )uc.fInheritAutoClient , 0 );
|
|
|
|
SendMessage( GetDlgItem( hDlg , IDC_CHECK_CCDL_PS ) , BM_SETCHECK , ( WPARAM )uc.fAutoClientDrives , 0 );
|
|
|
|
SendMessage( GetDlgItem( hDlg , IDC_CHECK_CCPL_PS ) , BM_SETCHECK , ( WPARAM )uc.fAutoClientLpts , 0 );
|
|
|
|
SendMessage( GetDlgItem( hDlg , IDC_CHECK_DMCP_PS ) , BM_SETCHECK , ( WPARAM )uc.fForceClientLptDef , 0 );
|
|
|
|
|
|
TCHAR tchBuffer[80];
|
|
int nColorDepthIndex = 0;
|
|
|
|
LoadString( _Module.GetResourceInstance( ) , IDS_COLORDEPTH_24 , tchBuffer , SIZE_OF_BUFFER( tchBuffer ) );
|
|
SendMessage( GetDlgItem( hDlg, IDC_COLORDEPTH_OVERRIDE ), CB_ADDSTRING , 0 , ( LPARAM )&tchBuffer[0] );
|
|
SendMessage( GetDlgItem( hDlg, IDC_COLORDEPTH_OVERRIDE ), CB_SETITEMDATA , nColorDepthIndex++ , TS_24BPP_SUPPORT );
|
|
|
|
LoadString( _Module.GetResourceInstance( ) , IDS_COLORDEPTH_16 , tchBuffer , SIZE_OF_BUFFER( tchBuffer ) );
|
|
SendMessage( GetDlgItem( hDlg, IDC_COLORDEPTH_OVERRIDE ), CB_ADDSTRING , 0 , ( LPARAM )&tchBuffer[0] );
|
|
SendMessage( GetDlgItem( hDlg, IDC_COLORDEPTH_OVERRIDE ), CB_SETITEMDATA , nColorDepthIndex++ , TS_16BPP_SUPPORT );
|
|
|
|
LoadString( _Module.GetResourceInstance( ) , IDS_COLORDEPTH_15 , tchBuffer , SIZE_OF_BUFFER( tchBuffer ) );
|
|
SendMessage( GetDlgItem( hDlg, IDC_COLORDEPTH_OVERRIDE ), CB_ADDSTRING , 0 , ( LPARAM )&tchBuffer[0] );
|
|
SendMessage( GetDlgItem( hDlg, IDC_COLORDEPTH_OVERRIDE ), CB_SETITEMDATA , nColorDepthIndex++ , TS_15BPP_SUPPORT );
|
|
|
|
LoadString( _Module.GetResourceInstance( ) , IDS_COLORDEPTH_8 , tchBuffer , SIZE_OF_BUFFER( tchBuffer ) );
|
|
SendMessage( GetDlgItem( hDlg, IDC_COLORDEPTH_OVERRIDE ), CB_ADDSTRING , 0 , ( LPARAM )&tchBuffer[0] );
|
|
SendMessage( GetDlgItem( hDlg, IDC_COLORDEPTH_OVERRIDE ), CB_SETITEMDATA , nColorDepthIndex++ , TS_8BPP_SUPPORT );
|
|
|
|
if(uc.fInheritColorDepth)
|
|
SendMessage( GetDlgItem( hDlg , IDC_CHECK_COLORDEPTH_OVERRIDE ) , BM_SETCHECK , ( WPARAM )BST_UNCHECKED , 0 );
|
|
else
|
|
SendMessage( GetDlgItem( hDlg , IDC_CHECK_COLORDEPTH_OVERRIDE ) , BM_SETCHECK , ( WPARAM )BST_CHECKED, 0 );
|
|
|
|
if (uc.ColorDepth < TS_8BPP_SUPPORT)
|
|
m_nColorDepth = TS_8BPP_SUPPORT;
|
|
else if (uc.ColorDepth > TS_24BPP_SUPPORT)
|
|
m_nColorDepth = TS_24BPP_SUPPORT;
|
|
else
|
|
m_nColorDepth = (int)uc.ColorDepth;
|
|
|
|
//Mapping fields
|
|
ULONG mask = 0;
|
|
VERIFY_S(S_OK, pCfgcomp->GetCaps(m_pParent->m_pResNode->GetTypeName(), &mask));
|
|
|
|
EnableWindow(GetDlgItem(hDlg, IDC_CHECK_DCDM_PS), mask & WDC_CLIENT_DRIVE_MAPPING);
|
|
EnableWindow(GetDlgItem(hDlg, IDC_CHECK_DWCPM_PS), mask & WDC_WIN_CLIENT_PRINTER_MAPPING);
|
|
EnableWindow(GetDlgItem(hDlg, IDC_CHECK_DCLPM_PS), mask & WDC_CLIENT_LPT_PORT_MAPPING);
|
|
EnableWindow(GetDlgItem(hDlg, IDC_CHECK_DCCPM_PS), mask & WDC_CLIENT_COM_PORT_MAPPING);
|
|
EnableWindow(GetDlgItem(hDlg, IDC_CHECK_DCCM_PS), mask & WDC_CLIENT_CLIPBOARD_MAPPING);
|
|
EnableWindow(GetDlgItem(hDlg, IDC_CHECK_DCAM_PS), mask & WDC_CLIENT_AUDIO_MAPPING);
|
|
|
|
if (!(mask & WDC_CLIENT_DRIVE_MAPPING))
|
|
SendMessage(GetDlgItem(hDlg, IDC_CHECK_DCDM_PS), BM_SETCHECK, (WPARAM)TRUE, 0);
|
|
else
|
|
SendMessage(GetDlgItem(hDlg, IDC_CHECK_DCDM_PS), BM_SETCHECK, (WPARAM)uc.fDisableCdm, 0);
|
|
|
|
if(!(mask & WDC_WIN_CLIENT_PRINTER_MAPPING))
|
|
SendMessage(GetDlgItem(hDlg, IDC_CHECK_DWCPM_PS), BM_SETCHECK, (WPARAM)TRUE, 0 );
|
|
else
|
|
SendMessage(GetDlgItem(hDlg, IDC_CHECK_DWCPM_PS), BM_SETCHECK, (WPARAM)uc.fDisableCpm, 0);
|
|
|
|
if(!(mask & WDC_CLIENT_LPT_PORT_MAPPING))
|
|
SendMessage(GetDlgItem(hDlg, IDC_CHECK_DCLPM_PS), BM_SETCHECK, (WPARAM)TRUE, 0);
|
|
else
|
|
SendMessage(GetDlgItem(hDlg, IDC_CHECK_DCLPM_PS), BM_SETCHECK, (WPARAM)uc.fDisableLPT, 0);
|
|
|
|
SendMessage( GetDlgItem( hDlg , IDC_CHECK_DCCPM_PS ) , BM_SETCHECK , ( WPARAM )uc.fDisableCcm , 0 );
|
|
SendMessage( GetDlgItem( hDlg , IDC_CHECK_DCCM_PS ) , BM_SETCHECK , ( WPARAM )uc.fDisableClip , 0 );
|
|
SendMessage( GetDlgItem( hDlg , IDC_CHECK_DCAM_PS ) , BM_SETCHECK , ( WPARAM )uc.fDisableCam , 0 );
|
|
|
|
DetermineFieldEnabling(hDlg);
|
|
SetColorDepthEntry(hDlg);
|
|
|
|
BOOL bReadOnly;
|
|
if (SUCCEEDED(pCfgcomp->IsSessionReadOnly(&bReadOnly)))
|
|
{
|
|
if(bReadOnly)
|
|
{
|
|
// disable the remaining controls
|
|
int rgID[] =
|
|
{
|
|
IDC_CHECK_DCDM_PS ,
|
|
IDC_CHECK_DWCPM_PS ,
|
|
IDC_CHECK_DCLPM_PS ,
|
|
IDC_CHECK_DCCPM_PS ,
|
|
IDC_CHECK_DCCM_PS ,
|
|
IDC_CHECK_DCAM_PS ,
|
|
IDC_CHECK_CCDL_PS ,
|
|
IDC_CHECK_CCPL_PS ,
|
|
IDC_CHECK_DMCP_PS ,
|
|
IDC_CHECK_CONCLIENT_INHERIT,
|
|
IDC_CHECK_COLORDEPTH_OVERRIDE,
|
|
IDC_COLORDEPTH_OVERRIDE,
|
|
-1
|
|
};
|
|
EnableGroup( hDlg , &rgID[ 0 ] , FALSE );
|
|
}
|
|
}
|
|
|
|
pCfgcomp->Release( );
|
|
|
|
m_bPersisted = TRUE;
|
|
|
|
return CDialogPropBase::OnInitDialog( hDlg , wp , lp );
|
|
}
|
|
|
|
|
|
//-----------------------------------------------------------------------------
|
|
//Disable fields if a group policy is set
|
|
void CClient::DetermineFieldEnabling(HWND hDlg)
|
|
{
|
|
POLICY_TS_MACHINE p;
|
|
RegGetMachinePolicy(&p);
|
|
|
|
//Mapping fields
|
|
//EnableWindow(GetDlgItem(hDlg, IDC_CHECK_DMCP_PS), !p.fPolicyForceClientLptDef); //Done below since it depends on 2 things
|
|
EnableWindow(GetDlgItem(hDlg, IDC_CHECK_DCDM_PS), !p.fPolicyDisableCdm);
|
|
EnableWindow(GetDlgItem(hDlg, IDC_CHECK_DWCPM_PS), !p.fPolicyDisableCpm);
|
|
EnableWindow(GetDlgItem(hDlg, IDC_CHECK_DCLPM_PS), !p.fPolicyDisableLPT);
|
|
EnableWindow(GetDlgItem(hDlg, IDC_CHECK_DCCPM_PS), !p.fPolicyDisableCcm);
|
|
EnableWindow(GetDlgItem(hDlg, IDC_CHECK_DCCM_PS), !p.fPolicyDisableClip);
|
|
EnableWindow(GetDlgItem(hDlg, IDC_CHECK_DCAM_PS), !p.fPolicyDisableCam);
|
|
|
|
//Connection fields
|
|
BOOL bEnableConnectionSettings = (SendMessage(GetDlgItem(hDlg, IDC_CHECK_CONCLIENT_INHERIT), BM_GETCHECK, 0, 0) != BST_CHECKED);
|
|
|
|
// check to see if client drive mapping is selected if so disable
|
|
EnableWindow(GetDlgItem(hDlg, IDC_CHECK_CCDL_PS), bEnableConnectionSettings &&
|
|
(SendMessage(GetDlgItem(hDlg, IDC_CHECK_DCDM_PS), BM_GETCHECK, 0, 0) != BST_CHECKED));
|
|
|
|
EnableWindow( GetDlgItem( hDlg , IDC_CHECK_CCPL_PS ) , bEnableConnectionSettings );
|
|
|
|
EnableWindow( GetDlgItem( hDlg , IDC_CHECK_DMCP_PS ) , bEnableConnectionSettings && !p.fPolicyForceClientLptDef);
|
|
|
|
//Color Depth fields
|
|
EnableWindow(GetDlgItem(hDlg, IDC_CHECK_COLORDEPTH_OVERRIDE), (!p.fPolicyColorDepth));
|
|
|
|
BOOL bEnableColorDepthSetting = SendMessage( GetDlgItem( hDlg , IDC_CHECK_COLORDEPTH_OVERRIDE ) , BM_GETCHECK , 0 , 0 ) == BST_CHECKED;
|
|
EnableWindow(GetDlgItem(hDlg, IDC_COLORDEPTH_OVERRIDE), (bEnableColorDepthSetting && !p.fPolicyColorDepth));
|
|
|
|
}
|
|
|
|
|
|
//-----------------------------------------------------------------------------
|
|
void CClient::SetColorDepthEntry(HWND hwnd)
|
|
{
|
|
BOOL bEnableColorDepthSetting = TRUE;
|
|
|
|
// check to see if override Color Depth setting is checked
|
|
bEnableColorDepthSetting = SendMessage( GetDlgItem( hwnd , IDC_CHECK_COLORDEPTH_OVERRIDE ) , BM_GETCHECK , 0 , 0 ) == BST_CHECKED;
|
|
|
|
//Select the correct combo box entry
|
|
if (bEnableColorDepthSetting)
|
|
{
|
|
//Select the correct value in the combo box based on the current value
|
|
INT_PTR iColorDepthListCount = 0;
|
|
iColorDepthListCount = SendMessage( GetDlgItem( hwnd, IDC_COLORDEPTH_OVERRIDE ), CB_GETCOUNT , 0 , 0 );
|
|
|
|
//Traverse the list looking an entry with value equal to m_nColorDepth
|
|
for (int iColorDepthListIndex = 0; iColorDepthListIndex < iColorDepthListCount; iColorDepthListIndex++)
|
|
{
|
|
INT_PTR iMatchingColorDepthValue = 0;
|
|
iMatchingColorDepthValue = SendMessage( GetDlgItem( hwnd, IDC_COLORDEPTH_OVERRIDE ), CB_GETITEMDATA , iColorDepthListIndex , 0 ) ;
|
|
|
|
if (iMatchingColorDepthValue == m_nColorDepth )
|
|
{
|
|
//Value found, set the combo box selection to the correct index
|
|
SendMessage( GetDlgItem( hwnd, IDC_COLORDEPTH_OVERRIDE ), CB_SETCURSEL , iColorDepthListIndex , 0 );
|
|
break;
|
|
}
|
|
}
|
|
|
|
//Make sure something's been selected - if not, just select the first value in the list
|
|
INT_PTR iSelection = SendMessage ( GetDlgItem( hwnd, IDC_COLORDEPTH_OVERRIDE ), CB_GETCURSEL, 0, 0 );
|
|
if (iSelection == CB_ERR)
|
|
SendMessage( GetDlgItem( hwnd, IDC_COLORDEPTH_OVERRIDE ), CB_SETCURSEL , 0 , 0 );
|
|
}
|
|
else
|
|
{
|
|
//Clear the contents of the combo box window if the color depth isn't editable
|
|
SendMessage( GetDlgItem( hwnd, IDC_COLORDEPTH_OVERRIDE ), CB_SETCURSEL , (WPARAM)CB_ERR , 0 );
|
|
}
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
BOOL CClient::PersistSettings( HWND hDlg )
|
|
{
|
|
if( m_pParent == NULL )
|
|
{
|
|
return FALSE;
|
|
}
|
|
|
|
USERCONFIG uc;
|
|
|
|
if( !m_pParent->GetCurrentUserConfig( uc, TRUE ) )
|
|
{
|
|
return FALSE;
|
|
}
|
|
|
|
uc.fInheritAutoClient = SendMessage( GetDlgItem( hDlg , IDC_CHECK_CONCLIENT_INHERIT ) , BM_GETCHECK , 0 , 0 );
|
|
|
|
if( !uc.fInheritAutoClient )
|
|
{
|
|
uc.fAutoClientDrives = SendMessage( GetDlgItem( hDlg , IDC_CHECK_CCDL_PS ) , BM_GETCHECK , 0 , 0 );
|
|
|
|
uc.fAutoClientLpts = SendMessage( GetDlgItem( hDlg , IDC_CHECK_CCPL_PS ) , BM_GETCHECK , 0 , 0 );
|
|
|
|
uc.fForceClientLptDef = SendMessage( GetDlgItem( hDlg , IDC_CHECK_DMCP_PS ) , BM_GETCHECK , 0 , 0 );
|
|
}
|
|
|
|
uc.fDisableCdm = SendMessage( GetDlgItem( hDlg , IDC_CHECK_DCDM_PS ) , BM_GETCHECK , 0 , 0 );
|
|
|
|
uc.fDisableCpm = SendMessage( GetDlgItem( hDlg , IDC_CHECK_DWCPM_PS ) , BM_GETCHECK , 0 , 0 );
|
|
|
|
uc.fDisableLPT = SendMessage( GetDlgItem( hDlg , IDC_CHECK_DCLPM_PS ) , BM_GETCHECK , 0 , 0 );
|
|
|
|
uc.fDisableCcm = SendMessage( GetDlgItem( hDlg , IDC_CHECK_DCCPM_PS ) , BM_GETCHECK , 0 , 0 );
|
|
|
|
uc.fDisableClip = SendMessage( GetDlgItem( hDlg , IDC_CHECK_DCCM_PS ) , BM_GETCHECK , 0 , 0 );
|
|
|
|
uc.fDisableCam = SendMessage( GetDlgItem( hDlg , IDC_CHECK_DCAM_PS ) , BM_GETCHECK , 0 , 0 );
|
|
|
|
|
|
uc.fInheritColorDepth = (( ULONG )SendMessage( GetDlgItem( hDlg , IDC_CHECK_COLORDEPTH_OVERRIDE ) , BM_GETCHECK , 0 , 0 )) == BST_UNCHECKED;
|
|
|
|
if( !uc.fInheritColorDepth )
|
|
{
|
|
INT_PTR iColorDepthSel = CB_ERR;
|
|
iColorDepthSel = SendMessage( GetDlgItem( hDlg , IDC_COLORDEPTH_OVERRIDE ) , CB_GETCURSEL, 0 , 0 );
|
|
|
|
INT_PTR iColorDepthValue = 0;
|
|
iColorDepthValue = SendMessage( GetDlgItem( hDlg , IDC_COLORDEPTH_OVERRIDE ) , CB_GETITEMDATA , iColorDepthSel , 0 );
|
|
|
|
uc.ColorDepth = iColorDepthValue;
|
|
}
|
|
else
|
|
{
|
|
uc.ColorDepth = TS_24BPP_SUPPORT;
|
|
}
|
|
|
|
|
|
DWORD dwStatus;
|
|
|
|
if( FAILED( m_pParent->SetUserConfig( uc , &dwStatus ) ) )
|
|
{
|
|
ReportStatusError( hDlg , dwStatus );
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
ICfgComp *pCfgcomp = NULL;
|
|
|
|
if( m_pParent->m_pResNode->GetServer( &pCfgcomp ) > 0 )
|
|
{
|
|
VERIFY_S( S_OK , pCfgcomp->ForceUpdate( ) );
|
|
|
|
VERIFY_S( S_OK , pCfgcomp->Refresh( ) );
|
|
|
|
// global flag can only be set to true
|
|
|
|
m_pParent->m_bPropertiesChange = TRUE;
|
|
|
|
pCfgcomp->Release( );
|
|
}
|
|
|
|
PostMessage( hDlg , WM_COMMAND , MAKELPARAM( 0 , ALN_APPLY ) , ( LPARAM )hDlg );
|
|
|
|
SendMessage( GetParent( hDlg ) , PSM_UNCHANGED , ( WPARAM )hDlg , 0 );
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
INT_PTR CALLBACK CClient::DlgProc( HWND hwnd , UINT msg , WPARAM wp , LPARAM lp )
|
|
{
|
|
CClient *pDlg;
|
|
|
|
if( msg == WM_INITDIALOG )
|
|
{
|
|
CClient *pDlg = ( CClient * )( ( PROPSHEETPAGE *)lp )->lParam ;
|
|
|
|
SetWindowLongPtr( hwnd , DWLP_USER , ( LONG_PTR )pDlg );
|
|
|
|
if( !IsBadReadPtr( pDlg , sizeof( CClient ) ) )
|
|
{
|
|
pDlg->OnInitDialog( hwnd , wp , lp );
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
else
|
|
{
|
|
pDlg = ( CClient * )GetWindowLongPtr( hwnd , DWLP_USER );
|
|
|
|
if( IsBadReadPtr( pDlg , sizeof( CClient ) ) )
|
|
{
|
|
return FALSE;
|
|
}
|
|
}
|
|
|
|
switch( msg )
|
|
{
|
|
|
|
case WM_NCDESTROY:
|
|
|
|
pDlg->OnDestroy( );
|
|
|
|
break;
|
|
|
|
case WM_COMMAND:
|
|
|
|
pDlg->OnCommand( HIWORD( wp ) , LOWORD( wp ) , ( HWND )lp );
|
|
|
|
break;
|
|
|
|
case WM_CONTEXTMENU:
|
|
{
|
|
POINT pt;
|
|
|
|
pt.x = LOWORD( lp );
|
|
|
|
pt.y = HIWORD( lp );
|
|
|
|
pDlg->OnContextMenu( ( HWND )wp , pt );
|
|
}
|
|
|
|
break;
|
|
|
|
case WM_HELP:
|
|
|
|
pDlg->OnHelp( hwnd , ( LPHELPINFO )lp );
|
|
|
|
break;
|
|
|
|
case WM_NOTIFY:
|
|
|
|
return pDlg->OnNotify( ( int )wp , ( LPNMHDR )lp , hwnd );
|
|
|
|
break;
|
|
}
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
BOOL CClient::GetPropertySheetPage( PROPSHEETPAGE& psp )
|
|
{
|
|
ZeroMemory( &psp , sizeof( PROPSHEETPAGE ) );
|
|
|
|
psp.dwSize = sizeof( PROPSHEETPAGE );
|
|
|
|
psp.dwFlags = PSP_DEFAULT;
|
|
|
|
psp.hInstance = _Module.GetResourceInstance( );
|
|
|
|
psp.pszTemplate = MAKEINTRESOURCE( IDD_TSCC_CLIENT );
|
|
|
|
psp.lParam = ( LPARAM )this;
|
|
|
|
psp.pfnDlgProc = CClient::DlgProc;
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
BOOL CClient::OnCommand( WORD wNotifyCode , WORD wID , HWND hwndCtrl )
|
|
{
|
|
if( wNotifyCode == BN_CLICKED )
|
|
{
|
|
if ((wID == IDC_CHECK_CONCLIENT_INHERIT) || (wID == IDC_CHECK_COLORDEPTH_OVERRIDE) ||
|
|
(wID == IDC_CHECK_DWCPM_PS ) || (wID == IDC_CHECK_DCDM_PS))
|
|
{
|
|
DetermineFieldEnabling(GetParent(hwndCtrl));
|
|
}
|
|
|
|
if (wID == IDC_CHECK_COLORDEPTH_OVERRIDE)
|
|
SetColorDepthEntry(GetParent(hwndCtrl));
|
|
}
|
|
else if( wNotifyCode == ALN_APPLY )
|
|
{
|
|
SendMessage( GetParent( hwndCtrl ) , PSM_CANCELTOCLOSE , 0 , 0 );
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
m_bPersisted = FALSE;
|
|
|
|
SendMessage( GetParent( GetParent( hwndCtrl ) ) , PSM_CHANGED , ( WPARAM )GetParent( hwndCtrl ) , 0 );
|
|
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
BOOL CClient::OnDestroy( )
|
|
{
|
|
m_pParent->Release( );
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
|
|
/*************************************************************************************************************************/
|
|
|
|
/*EXTERN_C const GUID IID_ISecurityInformation =
|
|
{ 0x965fc360, 0x16ff, 0x11d0, 0x91, 0xcb, 0x0, 0xaa, 0x0, 0xbb, 0xb7, 0x23 };
|
|
*/
|
|
//
|
|
// WinStation General Permissions
|
|
//
|
|
|
|
/*
|
|
SI_ACCESS siWinStationAccesses[] =
|
|
{
|
|
{ &GUID_NULL , WINSTATION_QUERY , NULL ,SI_ACCESS_SPECIFIC },
|
|
{ &GUID_NULL , WINSTATION_SET , NULL ,SI_ACCESS_SPECIFIC },
|
|
{ &GUID_NULL , WINSTATION_RESET , NULL ,SI_ACCESS_SPECIFIC },
|
|
{ &GUID_NULL , WINSTATION_SHADOW , NULL ,SI_ACCESS_SPECIFIC },
|
|
{ &GUID_NULL , WINSTATION_LOGON , NULL ,SI_ACCESS_SPECIFIC },
|
|
{ &GUID_NULL , WINSTATION_LOGOFF , NULL ,SI_ACCESS_SPECIFIC },
|
|
{ &GUID_NULL , WINSTATION_MSG , NULL ,SI_ACCESS_SPECIFIC },
|
|
{ &GUID_NULL , WINSTATION_CONNECT , NULL ,SI_ACCESS_SPECIFIC },
|
|
{ &GUID_NULL , WINSTATION_DISCONNECT , NULL , SI_ACCESS_SPECIFIC},
|
|
{ &GUID_NULL , WINSTATION_VIRTUAL | STANDARD_RIGHTS_REQUIRED, NULL , SI_ACCESS_SPECIFIC},
|
|
{ &GUID_NULL , WINSTATION_ALL_ACCESS , NULL , SI_ACCESS_GENERAL },
|
|
{ &GUID_NULL , WINSTATION_USER_ACCESS , NULL , SI_ACCESS_GENERAL },
|
|
{ &GUID_NULL , WINSTATION_GUEST_ACCESS , NULL , SI_ACCESS_GENERAL }
|
|
};
|
|
|
|
*/
|
|
|
|
SI_ACCESS siWinStationAccesses[] =
|
|
{
|
|
{ &GUID_NULL , WINSTATION_QUERY , MAKEINTRESOURCE ( IDS_PERMS_SPECIAL_QUERY ),SI_ACCESS_SPECIFIC },
|
|
{ &GUID_NULL , WINSTATION_SET , MAKEINTRESOURCE ( IDS_PERMS_SPECIAL_SET ) ,SI_ACCESS_SPECIFIC },
|
|
//{ &GUID_NULL , WINSTATION_RESET , MAKEINTRESOURCE ( IDS_PERMS_SPECIAL_RESET ) ,SI_ACCESS_SPECIFIC },
|
|
{ &GUID_NULL , WINSTATION_SHADOW , MAKEINTRESOURCE ( IDS_PERMS_SPECIAL_SHADOW ) ,SI_ACCESS_SPECIFIC },
|
|
{ &GUID_NULL , WINSTATION_LOGON , MAKEINTRESOURCE ( IDS_PERMS_SPECIAL_LOGON ) ,SI_ACCESS_SPECIFIC },
|
|
{ &GUID_NULL , WINSTATION_RESET , MAKEINTRESOURCE ( IDS_PERMS_SPECIAL_LOGOFF ) ,SI_ACCESS_SPECIFIC },
|
|
{ &GUID_NULL , WINSTATION_MSG , MAKEINTRESOURCE ( IDS_PERMS_SPECIAL_MSG ) ,SI_ACCESS_SPECIFIC },
|
|
{ &GUID_NULL , WINSTATION_CONNECT , MAKEINTRESOURCE ( IDS_PERMS_SPECIAL_CONNECT ) ,SI_ACCESS_SPECIFIC },
|
|
{ &GUID_NULL , WINSTATION_DISCONNECT , MAKEINTRESOURCE ( IDS_PERMS_SPECIAL_DISCONNECT ) , SI_ACCESS_SPECIFIC},
|
|
{ &GUID_NULL , WINSTATION_VIRTUAL | STANDARD_RIGHTS_REQUIRED, MAKEINTRESOURCE ( IDS_PERMS_SPECIAL_DELETE ) , SI_ACCESS_SPECIFIC},
|
|
{ &GUID_NULL , WINSTATION_ALL_ACCESS , MAKEINTRESOURCE ( IDS_PERMS_RESOURCE_ADMIN ) , SI_ACCESS_GENERAL },
|
|
{ &GUID_NULL , WINSTATION_USER_ACCESS , MAKEINTRESOURCE ( IDS_PERMS_RESOURCE_USER ) , SI_ACCESS_GENERAL },
|
|
{ &GUID_NULL , WINSTATION_GUEST_ACCESS , MAKEINTRESOURCE ( IDS_PERMS_RESOURCE_GUEST ) , SI_ACCESS_GENERAL }
|
|
};
|
|
|
|
#define MAX_PERM 12
|
|
#define iWinStationDefAccess 11 // index of value in array siWinStationAccesses
|
|
|
|
|
|
|
|
//-----------------------------------------------------------------------------
|
|
STDMETHODIMP CSecurityPage::GetAccessRights(
|
|
const GUID *pguidObjectType,
|
|
DWORD dwFlags,
|
|
PSI_ACCESS *ppAccess,
|
|
PULONG pcAccesses,
|
|
PULONG piDefaultAccess
|
|
)
|
|
{
|
|
UNREFERENCED_PARAMETER( dwFlags );
|
|
|
|
UNREFERENCED_PARAMETER( pguidObjectType );
|
|
|
|
ASSERT( ppAccess != NULL );
|
|
|
|
ASSERT( pcAccesses != NULL );
|
|
|
|
ASSERT( piDefaultAccess != NULL );
|
|
|
|
*ppAccess = siWinStationAccesses;
|
|
|
|
*pcAccesses = MAX_PERM;
|
|
|
|
*piDefaultAccess = iWinStationDefAccess;
|
|
|
|
return S_OK;
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// This is consistent with the termsrv code
|
|
//-----------------------------------------------------------------------------
|
|
GENERIC_MAPPING WinStationMap =
|
|
{
|
|
WINSTATION_QUERY , /* GenericRead */
|
|
WINSTATION_USER_ACCESS, /* GenericWrite */
|
|
WINSTATION_USER_ACCESS, /* GenericExecute */
|
|
WINSTATION_ALL_ACCESS /* GenericAll */
|
|
};
|
|
|
|
//-----------------------------------------------------------------------------
|
|
void CSecurityPage::SetParent( CPropsheet *pParent )
|
|
{
|
|
m_pParent = pParent;
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
STDMETHODIMP CSecurityPage::MapGeneric( const GUID *pguidObjectType , PUCHAR pAceFlags , ACCESS_MASK *pMask )
|
|
{
|
|
UNREFERENCED_PARAMETER( pguidObjectType );
|
|
UNREFERENCED_PARAMETER( pAceFlags );
|
|
|
|
ASSERT( pMask != NULL );
|
|
|
|
MapGenericMask( pMask , &WinStationMap );
|
|
|
|
return S_OK;
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
STDMETHODIMP CSecurityPage::GetInheritTypes( PSI_INHERIT_TYPE *ppInheritTypes , PULONG pcInheritTypes )
|
|
{
|
|
UNREFERENCED_PARAMETER( ppInheritTypes );
|
|
UNREFERENCED_PARAMETER( pcInheritTypes );
|
|
|
|
|
|
return E_NOTIMPL;
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
STDMETHODIMP CSecurityPage::PropertySheetPageCallback( HWND hwnd , UINT uMsg , SI_PAGE_TYPE uPage )
|
|
{
|
|
UNREFERENCED_PARAMETER( hwnd );
|
|
UNREFERENCED_PARAMETER( uPage );
|
|
|
|
if( uMsg == PSPCB_SI_INITDIALOG )
|
|
{
|
|
ODS( L"CSecurityPage::PropertySheetPageCallback -- Init\n" );
|
|
|
|
if (!m_WritablePermissionsTab )
|
|
{
|
|
|
|
LinkWindow_RegisterClass();
|
|
|
|
DialogBox( _Module.GetResourceInstance( ), MAKEINTRESOURCE(IDD_CUSTOM_SECURITY),
|
|
|
|
hwnd, CustomSecurityDlgProc);
|
|
|
|
LinkWindow_UnregisterClass(_Module.GetModuleInstance( ));
|
|
|
|
}
|
|
|
|
}
|
|
else if( uMsg == PSPCB_RELEASE )
|
|
{
|
|
|
|
|
|
ODS( L"CSecurityPage::PropertySheetPageCallback -- Release\n" );
|
|
|
|
}
|
|
|
|
|
|
return S_FALSE; //Be sure to return S_FALSE, This supresses other popups.
|
|
}
|
|
|
|
/*
|
|
Change to TSCC's permissions TAB such that the default state is READ-ONLY unless
|
|
group policy is used to override it.
|
|
|
|
If TRUE, permissions TAB can be edited by local Adimn.
|
|
if FALSE, the local Admin should not edit permissions TAB, it is read only
|
|
*/
|
|
|
|
BOOLEAN QueryWriteAccess()
|
|
{
|
|
DWORD ValueType;
|
|
DWORD ValueSize = sizeof(DWORD);
|
|
DWORD valueData ;
|
|
LONG errorCode;
|
|
|
|
HKEY hTSControlKey = NULL;
|
|
|
|
//
|
|
// first check the policy tree,
|
|
//
|
|
|
|
POLICY_TS_MACHINE p;
|
|
RegGetMachinePolicy(&p);
|
|
|
|
if ( p.fPolicyWritableTSCCPermissionsTAB )
|
|
{
|
|
return (BOOLEAN)( p.fWritableTSCCPermissionsTAB ? TRUE : FALSE );
|
|
}
|
|
|
|
// if we got this far, then no policy was set. Check the local machine now.
|
|
|
|
errorCode = RegOpenKeyEx( HKEY_LOCAL_MACHINE, REG_CONTROL_TSERVER, 0,
|
|
KEY_READ, &hTSControlKey );
|
|
|
|
if ( ( errorCode == ERROR_SUCCESS ) && hTSControlKey )
|
|
{
|
|
errorCode = RegQueryValueEx( hTSControlKey,
|
|
POLICY_TS_TSCC_PERM_TAB_WRITABLE , NULL, &ValueType,
|
|
(LPBYTE) &valueData, &ValueSize );
|
|
|
|
RegCloseKey(hTSControlKey);
|
|
|
|
if (errorCode == ERROR_SUCCESS )
|
|
{
|
|
return (BOOLEAN)( valueData ? TRUE : FALSE ) ;
|
|
}
|
|
|
|
}
|
|
|
|
// if no localKey, gee... the registry is missing data... return FALSE to be on the secure side
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
/*-----------------------------------------------------------------------------
|
|
JeffreyS 1/24/97:
|
|
If you don't set the SI_RESET flag in
|
|
ISecurityInformation::GetObjectInformation, then fDefault should never be TRUE
|
|
so you can ignore it. Returning E_NOTIMPL in this case is OK too.
|
|
|
|
If you want the user to be able to reset the ACL to some default state
|
|
(defined by you) then turn on SI_RESET and return your default ACL
|
|
when fDefault is TRUE. This happens if/when the user pushes a button
|
|
that is only visible when SI_RESET is on.
|
|
-----------------------------------------------------------------------------*/
|
|
|
|
STDMETHODIMP CSecurityPage::GetObjectInformation( PSI_OBJECT_INFO pObjectInfo )
|
|
{
|
|
ASSERT( pObjectInfo != NULL && !IsBadWritePtr(pObjectInfo, sizeof(*pObjectInfo ) ) );
|
|
|
|
pObjectInfo->dwFlags = SI_OWNER_READONLY | SI_EDIT_PERMS | SI_NO_ACL_PROTECT | SI_PAGE_TITLE | SI_EDIT_AUDITS | SI_ADVANCED | SI_RESET;
|
|
|
|
m_WritablePermissionsTab = QueryWriteAccess() ;
|
|
|
|
if( ! m_WritablePermissionsTab ) {
|
|
pObjectInfo->dwFlags |= SI_READONLY;
|
|
}
|
|
|
|
|
|
pObjectInfo->hInstance = _Module.GetResourceInstance( );
|
|
|
|
pObjectInfo->pszServerName = NULL;
|
|
|
|
pObjectInfo->pszObjectName = m_pParent->m_pResNode->GetConName();
|
|
|
|
VERIFY_E( 0 , LoadString( _Module.GetResourceInstance( ) , IDS_SECURPAGENAME , m_szPageName , SIZE_OF_BUFFER( m_szPageName ) ) );
|
|
|
|
pObjectInfo->pszPageTitle = m_szPageName;
|
|
|
|
return S_OK;
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
STDMETHODIMP CSecurityPage::GetSecurity( SECURITY_INFORMATION RequestedInformation , PSECURITY_DESCRIPTOR *ppSecurityDescriptor , BOOL bDefault )
|
|
{
|
|
#ifdef DBG
|
|
if( RequestedInformation & OWNER_SECURITY_INFORMATION )
|
|
{
|
|
ODS( L"CSecurityPage::GetSecurity - OWNER_SECURITY_INFORMATION\n");
|
|
}
|
|
if( RequestedInformation & GROUP_SECURITY_INFORMATION )
|
|
{
|
|
ODS( L"CSecurityPage::GetSecurity - GROUP_SECURITY_INFORMATION\n");
|
|
}
|
|
if( RequestedInformation & DACL_SECURITY_INFORMATION )
|
|
{
|
|
ODS( L"CSecurityPage::GetSecurity - DACL_SECURITY_INFORMATION\n");
|
|
}
|
|
if( RequestedInformation & SACL_SECURITY_INFORMATION )
|
|
{
|
|
ODS( L"CSecurityPage::GetSecurity - SACL_SECURITY_INFORMATION\n");
|
|
}
|
|
|
|
#endif
|
|
|
|
if( 0 == RequestedInformation || NULL == ppSecurityDescriptor )
|
|
{
|
|
ASSERT( FALSE );
|
|
|
|
return E_INVALIDARG;
|
|
}
|
|
|
|
ICfgComp *pCfgcomp = NULL;
|
|
|
|
if( m_pParent->m_pResNode->GetServer( &pCfgcomp ) == 0 )
|
|
{
|
|
return FALSE;
|
|
}
|
|
|
|
LONG lSDsize;
|
|
|
|
HRESULT hr;
|
|
|
|
PSECURITY_DESCRIPTOR pSD = NULL;
|
|
|
|
if( bDefault )
|
|
{
|
|
hr = pCfgcomp->GetDefaultSecurityDescriptor( &lSDsize , &pSD );
|
|
|
|
*ppSecurityDescriptor = pSD;
|
|
|
|
}
|
|
else
|
|
{
|
|
BOOL bChanged = FALSE;
|
|
|
|
hr = pCfgcomp->GetSecurityDescriptor( m_pParent->m_pResNode->GetConName( ) , &lSDsize , &pSD );
|
|
|
|
// check for legacy "denied logoff" ace and remove.
|
|
if( xxxLegacyLogoffCleanup( &pSD , &bChanged ) != ERROR_SUCCESS )
|
|
{
|
|
hr = pCfgcomp->GetDefaultSecurityDescriptor( &lSDsize , &pSD );
|
|
}
|
|
*ppSecurityDescriptor = pSD;
|
|
}
|
|
|
|
pCfgcomp->Release( );
|
|
|
|
if(SUCCEEDED(hr))
|
|
{
|
|
MakeLocalSDCopy( *ppSecurityDescriptor );
|
|
}
|
|
|
|
return hr;
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
STDMETHODIMP CSecurityPage::SetSecurity( SECURITY_INFORMATION SecurityInformation ,PSECURITY_DESCRIPTOR pSecurityDescriptor )
|
|
{
|
|
HRESULT hr = S_OK;
|
|
|
|
ICfgComp *pCfgcomp = NULL;
|
|
|
|
PSECURITY_DESCRIPTOR pSD1;
|
|
|
|
if( m_pParent == NULL || m_pParent->m_pResNode == NULL )
|
|
{
|
|
hr = E_UNEXPECTED;
|
|
}
|
|
|
|
else if( m_pParent->m_pResNode->GetServer( &pCfgcomp ) != 0 )
|
|
{
|
|
long lSDsize;
|
|
|
|
|
|
hr = pCfgcomp->GetSecurityDescriptor( m_pParent->m_pResNode->GetConName( ) , &lSDsize , &pSD1 );
|
|
|
|
if( FAILED( hr ) )
|
|
{
|
|
pCfgcomp->Release( );
|
|
|
|
return hr;
|
|
}
|
|
|
|
SECURITY_DESCRIPTOR_CONTROL sdc;
|
|
DWORD dwREV;
|
|
PACL pDacl = NULL;
|
|
PACL pSacl = NULL;
|
|
SECURITY_DESCRIPTOR absSD;
|
|
BOOL bSaclPresent = FALSE;
|
|
BOOL bSaclDefaulted = FALSE;
|
|
BOOL bDaclPresent = FALSE;
|
|
BOOL bDaclDefaulted = FALSE;
|
|
|
|
//
|
|
// Convert SelfRel to Absolute
|
|
// ignore owner and group
|
|
//
|
|
|
|
|
|
GetSecurityDescriptorControl( pSD1 , &sdc , &dwREV );
|
|
|
|
if( !InitializeSecurityDescriptor( &absSD , dwREV ) )
|
|
{
|
|
DBGMSG( L"TSCC!CSecurityPage_SetSecurity InitializeSecurityDescriptor failed with 0x%x\n" , GetLastError( ) );
|
|
|
|
return E_FAIL;
|
|
}
|
|
|
|
GetSecurityDescriptorDacl( pSD1 , &bDaclPresent , &pDacl , &bDaclDefaulted );
|
|
|
|
SetSecurityDescriptorDacl( &absSD , bDaclPresent , pDacl , bDaclDefaulted );
|
|
|
|
GetSecurityDescriptorSacl( pSD1 , &bSaclPresent , &pSacl , &bSaclDefaulted );
|
|
|
|
SetSecurityDescriptorSacl( &absSD , bSaclPresent , pSacl , bSaclDefaulted );
|
|
|
|
// now call SetDACL or SACL depending on SecurityInformation
|
|
|
|
if( SecurityInformation & OWNER_SECURITY_INFORMATION )
|
|
{
|
|
ODS( L"CSecurityPage::SetSecurity - OWNER_SECURITY_INFORMATION ( default value set )\n");
|
|
}
|
|
if( SecurityInformation & GROUP_SECURITY_INFORMATION )
|
|
{
|
|
ODS( L"CSecurityPage::SetSecurity - GROUP_SECURITY_INFORMATION ( default value set )\n");
|
|
}
|
|
if( SecurityInformation & DACL_SECURITY_INFORMATION )
|
|
{
|
|
ODS( L"CSecurityPage::SetSecurity - DACL_SECURITY_INFORMATION\n");
|
|
|
|
GetSecurityDescriptorDacl( pSecurityDescriptor , &bDaclPresent , &pDacl , &bDaclDefaulted );
|
|
|
|
SetSecurityDescriptorDacl( &absSD , bDaclPresent , pDacl , bDaclDefaulted );
|
|
|
|
}
|
|
if( SecurityInformation & SACL_SECURITY_INFORMATION )
|
|
{
|
|
ODS( L"CSecurityPage::SetSecurity - SACL_SECURITY_INFORMATION\n");
|
|
|
|
GetSecurityDescriptorSacl( pSecurityDescriptor , &bSaclPresent , &pSacl , &bSaclDefaulted );
|
|
|
|
SetSecurityDescriptorSacl( &absSD , bSaclPresent , pSacl , bSaclDefaulted );
|
|
}
|
|
|
|
PSID SystemSid = NULL;
|
|
|
|
SID_IDENTIFIER_AUTHORITY NtSidAuthority = SECURITY_NT_AUTHORITY;
|
|
|
|
hr = E_OUTOFMEMORY;
|
|
|
|
if( AllocateAndInitializeSid( &NtSidAuthority,
|
|
1,
|
|
SECURITY_LOCAL_SYSTEM_RID,
|
|
0, 0, 0, 0, 0, 0, 0,
|
|
&SystemSid ) )
|
|
{
|
|
|
|
if( SystemSid != NULL )
|
|
{
|
|
hr = S_OK;
|
|
}
|
|
}
|
|
|
|
PSECURITY_DESCRIPTOR pSD = NULL;
|
|
|
|
DWORD dwSDLen;
|
|
|
|
if( SUCCEEDED( hr ) )
|
|
{
|
|
VERIFY_S( TRUE , SetSecurityDescriptorOwner( &absSD , SystemSid , FALSE ) );
|
|
|
|
VERIFY_S( TRUE, SetSecurityDescriptorGroup( &absSD , SystemSid , FALSE ) );
|
|
|
|
dwSDLen = 0;
|
|
|
|
MakeSelfRelativeSD( &absSD, pSD, &dwSDLen);
|
|
|
|
if (dwSDLen != 0)
|
|
{
|
|
pSD = ( LPBYTE )new BYTE[ dwSDLen ];
|
|
}
|
|
|
|
}
|
|
|
|
if( pSD == NULL )
|
|
{
|
|
ODS( L"TSCC!CSecurityPage::SetSecurity - SD allocation failed\n" );
|
|
|
|
hr = E_OUTOFMEMORY;
|
|
}
|
|
|
|
|
|
if( SUCCEEDED( hr ) )
|
|
{
|
|
if( !MakeSelfRelativeSD( &absSD , pSD , &dwSDLen ) )
|
|
{
|
|
hr = E_UNEXPECTED;
|
|
|
|
DBGMSG( L"MakeSelfRelativeSD - failed in CSecurityPage::SetSecurity With error %x\n" , GetLastError( ) );
|
|
}
|
|
|
|
if( SUCCEEDED( hr ) )
|
|
{
|
|
hr = pCfgcomp->SetSecurityDescriptor( m_pParent->m_pResNode->GetConName( ) , dwSDLen , pSD );
|
|
}
|
|
|
|
if( SUCCEEDED( hr ) )
|
|
{
|
|
ODS( L"TSCC : Update SD for TERMSRV\n" );
|
|
|
|
hr = pCfgcomp->ForceUpdate( );
|
|
|
|
// global flag can only be set to true
|
|
|
|
m_pParent->m_bPropertiesChange = TRUE;
|
|
|
|
UpdateTSLogonRight(m_pParent->m_pResNode->GetConName( ), pSD);
|
|
}
|
|
delete[] pSD;
|
|
}
|
|
|
|
if( SystemSid != NULL )
|
|
{
|
|
FreeSid( SystemSid );
|
|
}
|
|
|
|
// free originally stored SD.
|
|
|
|
LocalFree( pSD1 );
|
|
|
|
pCfgcomp->Release( );
|
|
}
|
|
return hr;
|
|
}
|
|
|
|
//*************************************************************
|
|
//
|
|
// CSecurityPage::MakeLocalSDCopy()
|
|
//
|
|
// Purpose: Makes a copy of the original SD.
|
|
// We'll need it for comparing with SD returned
|
|
// by Access Control Editor.
|
|
//
|
|
// Parameters: IN PSECURITY_DESCRIPTOR pSecurityDescriptor
|
|
//
|
|
// Return: NONE
|
|
//
|
|
// Comments:
|
|
//
|
|
// History: Date Author Comment
|
|
// 6/19/01 skuzin Created
|
|
//
|
|
//*************************************************************
|
|
void
|
|
CSecurityPage::MakeLocalSDCopy(
|
|
IN PSECURITY_DESCRIPTOR pSecurityDescriptor )
|
|
{
|
|
if(m_pOriginalSD)
|
|
{
|
|
delete m_pOriginalSD;
|
|
}
|
|
|
|
DWORD dwSDLength = GetSecurityDescriptorLength(pSecurityDescriptor);
|
|
m_pOriginalSD = (PSECURITY_DESCRIPTOR)new BYTE[dwSDLength];
|
|
|
|
if(m_pOriginalSD)
|
|
{
|
|
CopyMemory(m_pOriginalSD, pSecurityDescriptor, dwSDLength);
|
|
}
|
|
}
|
|
|
|
//*************************************************************
|
|
//
|
|
// CSecurityPage::UpdateTSLogonRight()
|
|
//
|
|
// Purpose: Grants SE_REMOTE_INTERACTIVE_LOGON_NAME right to all users,
|
|
// who gained Logon permission, but does not have this right yet.
|
|
// Revokes SE_REMOTE_INTERACTIVE_LOGON_NAME right from all users,
|
|
// who lost Logon permission and don't have Logon permission to
|
|
// any other winstation (connection).
|
|
//
|
|
// Parameters: IN PWINSTATIONNAMEW pWSName - connection name
|
|
// IN PSECURITY_DESCRIPTOR pSecurityDescriptor -
|
|
// new security descriptor
|
|
//
|
|
// Return: NONE
|
|
//
|
|
// Comments:
|
|
//
|
|
// History: Date Author Comment
|
|
// 6/19/01 skuzin Created
|
|
//
|
|
//*************************************************************
|
|
void
|
|
CSecurityPage::UpdateTSLogonRight(
|
|
IN PWINSTATIONNAMEW pWSName,
|
|
IN PSECURITY_DESCRIPTOR pSecurityDescriptor )
|
|
{
|
|
PSID *ppLogonAllowSIDs = NULL, *ppLogonDenySIDs = NULL;
|
|
DWORD cLogonAllowSIDs = 0, cLogonDenySIDs = 0;
|
|
|
|
//No SD to compare to. Do nothing.
|
|
if(!m_pOriginalSD)
|
|
{
|
|
return;
|
|
}
|
|
|
|
//Get Everyone's SID. All subsequent functions implicitly use it.
|
|
SID_IDENTIFIER_AUTHORITY WorldSidAuthority = SECURITY_WORLD_SID_AUTHORITY;
|
|
|
|
if(!AllocateAndInitializeSid( &WorldSidAuthority, 1,
|
|
SECURITY_WORLD_RID,
|
|
0, 0, 0, 0, 0, 0, 0,
|
|
&m_pWorldSid ))
|
|
{
|
|
return;
|
|
}
|
|
|
|
//Get SIDs of all users, who have gained or lost Logon permission.
|
|
if(!GetChangedUsers(pSecurityDescriptor, ppLogonAllowSIDs, ppLogonDenySIDs,
|
|
&cLogonAllowSIDs, &cLogonDenySIDs))
|
|
{
|
|
FreeSid(m_pWorldSid);
|
|
m_pWorldSid = NULL;
|
|
return;
|
|
}
|
|
|
|
PSID *ppLogonRightSIDs;
|
|
DWORD cLogonRightSIDs = 0;
|
|
DWORD i, j;
|
|
|
|
//Get SIDs of all users who have SE_REMOTE_INTERACTIVE_LOGON_NAME right.
|
|
if(GetUsersWhoAlreadyHasTSLogonRight(ppLogonRightSIDs, &cLogonRightSIDs))
|
|
{
|
|
|
|
//Grant SE_REMOTE_INTERACTIVE_LOGON_NAME right to all users who gained Logon
|
|
//permission, but does not have this right yet.
|
|
for(i = 0; i<cLogonAllowSIDs; i++)
|
|
{
|
|
for(j = 0; j<cLogonRightSIDs; j++)
|
|
{
|
|
if(EqualSid(ppLogonAllowSIDs[i],ppLogonRightSIDs[j]))
|
|
{
|
|
break;
|
|
}
|
|
}
|
|
//user does not have this right, let's give it to him.
|
|
if(j == cLogonRightSIDs)
|
|
{
|
|
GrantRightToUser(ppLogonAllowSIDs[i]);
|
|
}
|
|
}
|
|
|
|
//Revoke SE_REMOTE_INTERACTIVE_LOGON_NAME right from all users
|
|
//who lost Logon permission and don't have Logon permission to
|
|
//any other winstation (connection).
|
|
for(i = 0; i<cLogonDenySIDs; i++)
|
|
{
|
|
for(j = 0; j<cLogonRightSIDs; j++)
|
|
{
|
|
if(EqualSid(ppLogonDenySIDs[i],ppLogonRightSIDs[j]))
|
|
{
|
|
if(CanRevokeRight(pWSName, ppLogonDenySIDs[i]))
|
|
{
|
|
RevokeRightFromUser(ppLogonDenySIDs[i]);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
if(ppLogonAllowSIDs)
|
|
{
|
|
delete ppLogonAllowSIDs;
|
|
}
|
|
|
|
if(ppLogonDenySIDs)
|
|
{
|
|
delete ppLogonDenySIDs;
|
|
}
|
|
|
|
if(ppLogonRightSIDs)
|
|
{
|
|
delete ppLogonRightSIDs;
|
|
}
|
|
|
|
FreeSid(m_pWorldSid);
|
|
m_pWorldSid = NULL;
|
|
}
|
|
|
|
//*************************************************************
|
|
//
|
|
// CSecurityPage::GetChangedUsers()
|
|
//
|
|
// Purpose: Compares original security descriptor with the new one
|
|
// Creates an array of SIDs of all users, who have gained Logon permission,
|
|
// Creates an array of SIDs of all users, who have lost Logon permission,
|
|
//
|
|
// Parameters: PSECURITY_DESCRIPTOR pSecurityDescriptor -
|
|
// new security descriptor to investigate
|
|
// OUT PSID *&ppLogonAllowSIDs - array of SIDs of users,
|
|
// who have gained Logon permission
|
|
// OUT PSID *&ppLogonDenySIDs - array of SIDs of users,
|
|
// who have lost Logon permission
|
|
// OUT LPDWORD pcLogonAllowSIDs - number of entries in ppLogonAllowSIDs
|
|
// OUT LPDWORD pcLogonDenySIDs - number of entries in ppLogonDenySIDs
|
|
//
|
|
// Return: TRUE if success
|
|
// FALSE in case of any error.
|
|
//
|
|
// Comments:
|
|
//
|
|
// History: Date Author Comment
|
|
// 6/19/01 skuzin Created
|
|
//
|
|
//*************************************************************
|
|
BOOL
|
|
CSecurityPage::GetChangedUsers(
|
|
IN PSECURITY_DESCRIPTOR pSecurityDescriptor,
|
|
OUT PSID *&ppLogonAllowSIDs,
|
|
OUT PSID *&ppLogonDenySIDs,
|
|
OUT LPDWORD pcLogonAllowSIDs,
|
|
OUT LPDWORD pcLogonDenySIDs)
|
|
{
|
|
PACL pNewDacl = NULL;
|
|
PACL pOldDacl = NULL;
|
|
BOOL bNewDaclPresent = FALSE;
|
|
BOOL bOldDaclPresent = FALSE;
|
|
BOOL bDaclDefaulted = FALSE;
|
|
|
|
ppLogonAllowSIDs = NULL;
|
|
ppLogonDenySIDs = NULL;
|
|
*pcLogonAllowSIDs = 0;
|
|
*pcLogonDenySIDs = 0;
|
|
|
|
ASSERT(m_pWorldSid);
|
|
ASSERT(m_pOriginalSD);
|
|
|
|
if(!GetSecurityDescriptorDacl(pSecurityDescriptor,&bNewDaclPresent,&pNewDacl,&bDaclDefaulted))
|
|
{
|
|
return FALSE;
|
|
}
|
|
|
|
if(!GetSecurityDescriptorDacl(m_pOriginalSD,&bOldDaclPresent,&pOldDacl,&bDaclDefaulted))
|
|
{
|
|
return FALSE;
|
|
}
|
|
|
|
ACL_SIZE_INFORMATION asiAclSize;
|
|
DWORD dwBufLength=sizeof(asiAclSize);
|
|
ACCESS_ALLOWED_ACE *pAce;
|
|
DWORD dwAcl_i;
|
|
|
|
BOOL bResult = FALSE;
|
|
|
|
DWORD dwAllowSIDsIndex = 0;
|
|
|
|
if(pNewDacl)
|
|
{
|
|
if (GetAclInformation(pNewDacl,
|
|
(LPVOID)&asiAclSize,
|
|
(DWORD)dwBufLength,
|
|
(ACL_INFORMATION_CLASS)AclSizeInformation))
|
|
{
|
|
ppLogonAllowSIDs = new PSID[asiAclSize.AceCount];
|
|
|
|
if(ppLogonAllowSIDs)
|
|
{
|
|
for (dwAcl_i = 0; dwAcl_i < asiAclSize.AceCount; dwAcl_i++)
|
|
{
|
|
|
|
if(GetAce( pNewDacl, dwAcl_i, (LPVOID *)&pAce) &&
|
|
pAce->Header.AceType == ACCESS_ALLOWED_ACE_TYPE &&
|
|
pAce->Mask & WINSTATION_LOGON)
|
|
{
|
|
if(UserHasLogonPermission(pNewDacl,PSID(&pAce->SidStart)) &&
|
|
!UserHasLogonPermission(pOldDacl,PSID(&pAce->SidStart)))
|
|
{
|
|
ppLogonAllowSIDs[dwAllowSIDsIndex] = PSID(&pAce->SidStart);
|
|
dwAllowSIDsIndex++;
|
|
}
|
|
|
|
}
|
|
}
|
|
|
|
*pcLogonAllowSIDs = dwAllowSIDsIndex;
|
|
bResult = TRUE;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
//No DACL in new SD. Let's if Everyone already had Logon permission
|
|
if(!UserHasLogonPermission(pOldDacl,m_pWorldSid))
|
|
{
|
|
ppLogonAllowSIDs = new PSID[1];
|
|
|
|
if(ppLogonAllowSIDs)
|
|
{
|
|
ppLogonAllowSIDs[0] = m_pWorldSid;
|
|
*pcLogonAllowSIDs = 1;
|
|
bResult = TRUE;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
bResult = TRUE;
|
|
}
|
|
}
|
|
|
|
if(!bResult)
|
|
{
|
|
return FALSE;
|
|
}
|
|
|
|
bResult = FALSE;
|
|
|
|
DWORD dwDenySIDsIndex = 0;
|
|
|
|
if(pOldDacl)
|
|
{
|
|
if (GetAclInformation(pOldDacl,
|
|
(LPVOID)&asiAclSize,
|
|
(DWORD)dwBufLength,
|
|
(ACL_INFORMATION_CLASS)AclSizeInformation))
|
|
{
|
|
ppLogonDenySIDs = new PSID[asiAclSize.AceCount];
|
|
|
|
if(ppLogonDenySIDs)
|
|
{
|
|
for (dwAcl_i = 0; dwAcl_i < asiAclSize.AceCount; dwAcl_i++)
|
|
{
|
|
|
|
if(GetAce( pOldDacl, dwAcl_i, (LPVOID *)&pAce) &&
|
|
pAce->Header.AceType == ACCESS_ALLOWED_ACE_TYPE &&
|
|
pAce->Mask & WINSTATION_LOGON)
|
|
{
|
|
if(UserHasLogonPermission(pOldDacl,PSID(&pAce->SidStart)) &&
|
|
!UserHasLogonPermission(pNewDacl,PSID(&pAce->SidStart)))
|
|
{
|
|
ppLogonDenySIDs[dwDenySIDsIndex] = PSID(&pAce->SidStart);
|
|
dwDenySIDsIndex++;
|
|
}
|
|
|
|
}
|
|
}
|
|
|
|
*pcLogonDenySIDs = dwDenySIDsIndex;
|
|
bResult = TRUE;
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if(!UserHasLogonPermission(pNewDacl,m_pWorldSid))
|
|
{
|
|
ppLogonDenySIDs = new PSID[1];
|
|
|
|
if(ppLogonDenySIDs)
|
|
{
|
|
ppLogonDenySIDs[0] = m_pWorldSid;
|
|
*pcLogonDenySIDs = 1;
|
|
bResult = TRUE;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
bResult = TRUE;
|
|
}
|
|
|
|
}
|
|
|
|
if(!bResult && ppLogonAllowSIDs)
|
|
{
|
|
delete ppLogonAllowSIDs;
|
|
ppLogonAllowSIDs = NULL;
|
|
*pcLogonAllowSIDs = 0;
|
|
}
|
|
|
|
return bResult;
|
|
}
|
|
|
|
//*************************************************************
|
|
//
|
|
// CSecurityPage::UserHasLogonPermission()
|
|
//
|
|
// Purpose: Checks if a user represented by a pSid has explicit
|
|
// Logon permission
|
|
//
|
|
// Parameters: PACL pDacl - ACL to search for user
|
|
// PSID pSid - User's SID.
|
|
//
|
|
// Return: TRUE if a user represented by a pSid has explicit
|
|
// Logon permission.
|
|
// FALSE if not, or in case of any error.
|
|
//
|
|
// Comments:
|
|
//
|
|
// History: Date Author Comment
|
|
// 6/19/01 skuzin Created
|
|
//
|
|
//*************************************************************
|
|
BOOL
|
|
CSecurityPage::UserHasLogonPermission(
|
|
PACL pDacl,
|
|
PSID pSid)
|
|
{
|
|
ASSERT(m_pWorldSid);
|
|
|
|
if(!pDacl)
|
|
{
|
|
//DACL == NULL means Everyone - Full Control
|
|
//Let's see if pSid is Everyone's SID
|
|
return EqualSid(pSid, m_pWorldSid);
|
|
}
|
|
|
|
|
|
ACL_SIZE_INFORMATION asiAclSize;
|
|
DWORD dwBufLength=sizeof(asiAclSize);
|
|
ACCESS_ALLOWED_ACE *pAce;
|
|
DWORD dwAcl_i;
|
|
|
|
if (GetAclInformation(pDacl,
|
|
(LPVOID)&asiAclSize,
|
|
(DWORD)dwBufLength,
|
|
(ACL_INFORMATION_CLASS)AclSizeInformation))
|
|
{
|
|
|
|
for (dwAcl_i = 0; dwAcl_i < asiAclSize.AceCount; dwAcl_i++)
|
|
{
|
|
|
|
if(GetAce( pDacl, dwAcl_i, (LPVOID *)&pAce) &&
|
|
(pAce->Header.AceType == ACCESS_DENIED_ACE_TYPE ||
|
|
pAce->Header.AceType == ACCESS_ALLOWED_ACE_TYPE) )
|
|
{
|
|
if(EqualSid(pSid,PSID(&pAce->SidStart)) &&
|
|
pAce->Mask & WINSTATION_LOGON)
|
|
{
|
|
//Denied ACEs always go first
|
|
if(pAce->Header.AceType == ACCESS_DENIED_ACE_TYPE)
|
|
{
|
|
return FALSE;
|
|
}
|
|
else
|
|
{
|
|
return TRUE;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
//*************************************************************
|
|
//
|
|
// CSecurityPage::UserHasLogonPermission()
|
|
//
|
|
// Purpose: Checks if a user represented by a pSid has explicit
|
|
// Logon permission
|
|
//
|
|
// Parameters: PSECURITY_DESCRIPTOR pSecurityDescriptor -
|
|
// SD to search for user
|
|
// PSID pSid - User's SID.
|
|
//
|
|
// Return: TRUE if a user represented by a pSid has explicit
|
|
// Logon permission.
|
|
// FALSE if not, or in case of any error.
|
|
//
|
|
// Comments:
|
|
//
|
|
// History: Date Author Comment
|
|
// 6/19/01 skuzin Created
|
|
//
|
|
//*************************************************************
|
|
BOOL
|
|
CSecurityPage::UserHasLogonPermission(
|
|
PSECURITY_DESCRIPTOR pSecurityDescriptor,
|
|
PSID pSid)
|
|
{
|
|
PACL pDacl;
|
|
BOOL bDaclPresent;
|
|
BOOL bDaclDefaulted;
|
|
|
|
if(!GetSecurityDescriptorDacl(pSecurityDescriptor,&bDaclPresent,&pDacl,&bDaclDefaulted))
|
|
{
|
|
return FALSE;
|
|
}
|
|
|
|
return UserHasLogonPermission(pDacl, pSid);
|
|
}
|
|
|
|
//*************************************************************
|
|
//
|
|
// CSecurityPage::GetUsersWhoAlreadyHasTSLogonRight()
|
|
//
|
|
// Purpose: Creates an array of SIDs of all users, who have
|
|
// SE_REMOTE_INTERACTIVE_LOGON_NAME right.
|
|
//
|
|
// Parameters: OUT PSID *&ppLogonRightSIDs - array of SIDs of users,
|
|
// who have SE_REMOTE_INTERACTIVE_LOGON_NAME right
|
|
// OUT LPDWORD pcLogonRightSIDs - number of entries
|
|
// in ppLogonRightSIDs
|
|
//
|
|
// Return: TRUE if success
|
|
// FALSE in case of any error.
|
|
//
|
|
// Comments:
|
|
//
|
|
// History: Date Author Comment
|
|
// 6/19/01 skuzin Created
|
|
//
|
|
//*************************************************************
|
|
BOOL
|
|
CSecurityPage::GetUsersWhoAlreadyHasTSLogonRight(
|
|
PSID *&ppLogonRightSIDs,
|
|
LPDWORD pcLogonRightSIDs)
|
|
{
|
|
ppLogonRightSIDs = NULL;
|
|
*pcLogonRightSIDs = 0;
|
|
|
|
//Open Lsa Policy on a local machine
|
|
LSA_OBJECT_ATTRIBUTES ObjectAttributes;
|
|
LSA_UNICODE_STRING ServerString;
|
|
LSA_HANDLE hPolicy = NULL;
|
|
NTSTATUS Status;
|
|
|
|
ZeroMemory(&ObjectAttributes, sizeof(ObjectAttributes));
|
|
ZeroMemory(&ServerString, sizeof(ServerString));
|
|
|
|
Status = LsaOpenPolicy(&ServerString, &ObjectAttributes,
|
|
POLICY_VIEW_LOCAL_INFORMATION | POLICY_LOOKUP_NAMES, &hPolicy);
|
|
|
|
if(!NT_SUCCESS(Status))
|
|
{
|
|
return FALSE;
|
|
}
|
|
|
|
LSA_UNICODE_STRING UserRight;
|
|
PLSA_ENUMERATION_INFORMATION EnumerationBuffer;
|
|
ULONG CountReturned;
|
|
DWORD dwSidBufferSize = 0;
|
|
|
|
InitLsaString( &UserRight, T2W(SE_REMOTE_INTERACTIVE_LOGON_NAME));
|
|
|
|
Status=LsaEnumerateAccountsWithUserRight(
|
|
hPolicy,
|
|
&UserRight,
|
|
(PVOID *)&EnumerationBuffer,
|
|
&CountReturned);
|
|
if(NT_SUCCESS(Status))
|
|
{
|
|
dwSidBufferSize = CountReturned * sizeof(PSID);
|
|
|
|
DWORD i;
|
|
|
|
for(i=0; i<CountReturned; i++)
|
|
{
|
|
dwSidBufferSize += GetLengthSid(EnumerationBuffer[i].Sid);
|
|
}
|
|
|
|
ppLogonRightSIDs = (PSID *)new BYTE[dwSidBufferSize];
|
|
|
|
if(ppLogonRightSIDs)
|
|
{
|
|
DWORD_PTR CurOffset = DWORD_PTR(CountReturned * sizeof(PSID));
|
|
DWORD CurSidLength = 0;
|
|
|
|
for(i=0; i<CountReturned; i++)
|
|
{
|
|
ppLogonRightSIDs[i] = PSID( DWORD_PTR(ppLogonRightSIDs) + CurOffset);
|
|
CurSidLength = GetLengthSid(EnumerationBuffer[i].Sid);
|
|
CopySid(CurSidLength, ppLogonRightSIDs[i], EnumerationBuffer[i].Sid);
|
|
CurOffset += CurSidLength;
|
|
}
|
|
|
|
*pcLogonRightSIDs = CountReturned;
|
|
}
|
|
else
|
|
{
|
|
Status = STATUS_NO_MEMORY;
|
|
}
|
|
|
|
LsaFreeMemory( EnumerationBuffer );
|
|
}
|
|
else
|
|
{
|
|
//Nobody has this right
|
|
if(Status == STATUS_NO_MORE_ENTRIES)
|
|
{
|
|
Status = STATUS_SUCCESS;
|
|
}
|
|
}
|
|
|
|
LsaClose(hPolicy);
|
|
|
|
return (NT_SUCCESS(Status));
|
|
|
|
}
|
|
|
|
//*************************************************************
|
|
//
|
|
// CSecurityPage::GrantRightToUser()
|
|
//
|
|
// Purpose: Grants SE_REMOTE_INTERACTIVE_LOGON_NAME
|
|
// right to a user.
|
|
//
|
|
// Parameters: IN PSID pSID - User's SID
|
|
//
|
|
// Return: TRUE if success
|
|
// FALSE in case of any error.
|
|
//
|
|
// Comments:
|
|
//
|
|
// History: Date Author Comment
|
|
// 6/19/01 skuzin Created
|
|
//
|
|
//*************************************************************
|
|
BOOL
|
|
CSecurityPage::GrantRightToUser(
|
|
IN PSID pSID )
|
|
{
|
|
//Open Lsa Policy on a local machine
|
|
LSA_OBJECT_ATTRIBUTES ObjectAttributes;
|
|
LSA_UNICODE_STRING ServerString;
|
|
LSA_HANDLE hPolicy = NULL;
|
|
NTSTATUS Status;
|
|
|
|
ZeroMemory(&ObjectAttributes, sizeof(ObjectAttributes));
|
|
ZeroMemory(&ServerString, sizeof(ServerString));
|
|
|
|
Status = LsaOpenPolicy(&ServerString, &ObjectAttributes,
|
|
POLICY_LOOKUP_NAMES | POLICY_CREATE_ACCOUNT, &hPolicy);
|
|
|
|
if(!NT_SUCCESS(Status))
|
|
{
|
|
return FALSE;
|
|
}
|
|
|
|
LSA_UNICODE_STRING UserRight;
|
|
|
|
InitLsaString( &UserRight, T2W(SE_REMOTE_INTERACTIVE_LOGON_NAME));
|
|
|
|
Status=LsaAddAccountRights( hPolicy, pSID, &UserRight, 1 );
|
|
|
|
LsaClose(hPolicy);
|
|
|
|
return (NT_SUCCESS(Status));
|
|
}
|
|
|
|
//*************************************************************
|
|
//
|
|
// CSecurityPage::RevokeRightFromUser()
|
|
//
|
|
// Purpose: Revokes SE_REMOTE_INTERACTIVE_LOGON_NAME
|
|
// right from a user.
|
|
//
|
|
// Parameters: IN PSID pSID - User's SID
|
|
//
|
|
// Return: TRUE if success
|
|
// FALSE in case of any error.
|
|
//
|
|
// Comments:
|
|
//
|
|
// History: Date Author Comment
|
|
// 6/19/01 skuzin Created
|
|
//
|
|
//*************************************************************
|
|
BOOL
|
|
CSecurityPage::RevokeRightFromUser(
|
|
IN PSID pSID )
|
|
{
|
|
//Open Lsa Policy on a local machine
|
|
LSA_OBJECT_ATTRIBUTES ObjectAttributes;
|
|
LSA_UNICODE_STRING ServerString;
|
|
LSA_HANDLE hPolicy = NULL;
|
|
NTSTATUS Status;
|
|
|
|
ZeroMemory(&ObjectAttributes, sizeof(ObjectAttributes));
|
|
ZeroMemory(&ServerString, sizeof(ServerString));
|
|
|
|
Status = LsaOpenPolicy(&ServerString, &ObjectAttributes, POLICY_LOOKUP_NAMES, &hPolicy);
|
|
|
|
if(!NT_SUCCESS(Status))
|
|
{
|
|
return FALSE;
|
|
}
|
|
|
|
LSA_UNICODE_STRING UserRight;
|
|
|
|
InitLsaString( &UserRight, T2W(SE_REMOTE_INTERACTIVE_LOGON_NAME));
|
|
|
|
Status=LsaRemoveAccountRights(hPolicy, pSID, FALSE, &UserRight, 1);
|
|
|
|
LsaClose(hPolicy);
|
|
|
|
return (NT_SUCCESS(Status));
|
|
}
|
|
|
|
//*************************************************************
|
|
//
|
|
// CSecurityPage::CanRevokeRight()
|
|
//
|
|
// Purpose: Checks out that user represented by pSid does not
|
|
// have Logon permission to any connection,
|
|
// excluding connection referred by pWSName.
|
|
//
|
|
// Parameters: IN PWINSTATIONNAMEW pWSName - connection name.
|
|
// IN PSID pSID - User's SID
|
|
//
|
|
// Return: TRUE if it is safe to take this right from the user
|
|
// FALSE if not (i.e. the user has Logon permission to at
|
|
// least one connection excluding connection referred by
|
|
// pWSName), or in case of any error.
|
|
//
|
|
// Comments:
|
|
//
|
|
// History: Date Author Comment
|
|
// 6/19/01 skuzin Created
|
|
//
|
|
//*************************************************************
|
|
BOOL
|
|
CSecurityPage::CanRevokeRight(
|
|
IN PWINSTATIONNAMEW pWSName,
|
|
IN PSID pSID )
|
|
{
|
|
ICfgComp *pCfgcomp = NULL;
|
|
|
|
if( m_pParent == NULL || m_pParent->m_pResNode == NULL ||
|
|
m_pParent->m_pResNode->GetServer( &pCfgcomp ) == 0)
|
|
{
|
|
return FALSE;
|
|
}
|
|
|
|
WS *pWs;
|
|
ULONG ulitems = 0;
|
|
ULONG cbSize = 0;
|
|
|
|
if( !SUCCEEDED( pCfgcomp->GetWinstationList( &ulitems , &cbSize , &pWs ) ) )
|
|
{
|
|
return FALSE;
|
|
}
|
|
|
|
PSECURITY_DESCRIPTOR pSD;
|
|
long lSDsize;
|
|
BOOL bResult = TRUE;
|
|
|
|
for( ULONG i = 0 ; i < ulitems ; ++i )
|
|
{
|
|
|
|
if( lstrcmpi( pWs[ i ].Name , pWSName ) )
|
|
{
|
|
if( SUCCEEDED( pCfgcomp->GetSecurityDescriptor( pWs[ i ].Name , &lSDsize , &pSD ) ) )
|
|
{
|
|
if(UserHasLogonPermission(pSD,pSID))
|
|
{
|
|
bResult = FALSE;
|
|
LocalFree(pSD);
|
|
break;
|
|
}
|
|
|
|
LocalFree(pSD);
|
|
}
|
|
else
|
|
{
|
|
bResult = FALSE;
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
|
|
if(bResult)
|
|
{
|
|
|
|
//Check also default security descriptor
|
|
if( SUCCEEDED( pCfgcomp->GetDefaultSecurityDescriptor( &lSDsize , &pSD ) ) )
|
|
{
|
|
if(UserHasLogonPermission(pSD,pSID))
|
|
{
|
|
bResult = FALSE;
|
|
}
|
|
|
|
LocalFree(pSD);
|
|
}
|
|
else
|
|
{
|
|
bResult = FALSE;
|
|
}
|
|
}
|
|
|
|
CoTaskMemFree( pWs );
|
|
return bResult;
|
|
}
|
|
|
|
void
|
|
InitLsaString(
|
|
OUT PLSA_UNICODE_STRING LsaString,
|
|
IN LPWSTR String)
|
|
{
|
|
DWORD StringLength;
|
|
|
|
if (String == NULL) {
|
|
LsaString->Buffer = NULL;
|
|
LsaString->Length = 0;
|
|
LsaString->MaximumLength = 0;
|
|
return;
|
|
}
|
|
|
|
StringLength = wcslen(String);
|
|
LsaString->Buffer = String;
|
|
LsaString->Length = (USHORT) StringLength * sizeof(WCHAR);
|
|
LsaString->MaximumLength=(USHORT)(StringLength+1) * sizeof(WCHAR);
|
|
}
|
|
|
|
typedef HPROPSHEETPAGE (*CREATEPAGE_PROC) (LPSECURITYINFO);
|
|
|
|
//-----------------------------------------------------------------------------
|
|
HPROPSHEETPAGE GetSecurityPropertyPage( CPropsheet *pParent )
|
|
{
|
|
LPVOID *pvFunction = &g_aAclFunctions[ ACLUI_CREATE_PAGE ].lpfnFunction;
|
|
|
|
if( *pvFunction == NULL )
|
|
{
|
|
g_aAclFunctions[ ACLUI_CREATE_PAGE ].hInst = LoadLibrary( TEXT("ACLUI.DLL") );
|
|
|
|
ASSERT( g_aAclFunctions[ ACLUI_CREATE_PAGE ].hInst != NULL );
|
|
|
|
if( g_aAclFunctions[ ACLUI_CREATE_PAGE ].hInst == NULL )
|
|
{
|
|
return NULL;
|
|
}
|
|
|
|
*pvFunction = ( LPVOID )GetProcAddress( g_aAclFunctions[ ACLUI_CREATE_PAGE ].hInst , g_aAclFunctions[ ACLUI_CREATE_PAGE ].pcstrFunctionName );
|
|
|
|
ASSERT( *pvFunction != NULL );
|
|
|
|
if( *pvFunction == NULL )
|
|
{
|
|
return NULL;
|
|
}
|
|
|
|
CComObject< CSecurityPage > *psecinfo = NULL;
|
|
|
|
HRESULT hRes = CComObject< CSecurityPage >::CreateInstance( &psecinfo );
|
|
|
|
if( SUCCEEDED( hRes ) )
|
|
{
|
|
// InitStrings();
|
|
|
|
psecinfo->SetParent( pParent );
|
|
|
|
return ( ( CREATEPAGE_PROC )*pvFunction )( psecinfo );
|
|
}
|
|
|
|
}
|
|
|
|
return NULL;
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
// Error messag boxes
|
|
//
|
|
void ErrMessage( HWND hwndOwner , INT_PTR iResourceID )
|
|
{
|
|
xxxErrMessage( hwndOwner , iResourceID , IDS_ERROR_TITLE , MB_OK | MB_ICONERROR );
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
void TscAccessDeniedMsg( HWND hwnd )
|
|
{
|
|
xxxErrMessage( hwnd , IDS_TSCACCESSDENIED , IDS_TSCERRTITLE , MB_OK | MB_ICONERROR );
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
void TscGeneralErrMsg( HWND hwnd )
|
|
{
|
|
xxxErrMessage( hwnd , IDS_TSCERRGENERAL , IDS_TSCERRTITLE , MB_OK | MB_ICONERROR );
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
void xxxErrMessage( HWND hwnd , INT_PTR nResMessageId , INT_PTR nResTitleId , UINT nFlags )
|
|
{
|
|
TCHAR tchErrMsg[ 256 ];
|
|
|
|
TCHAR tchErrTitle[ 80 ];
|
|
|
|
VERIFY_E( 0 , LoadString( _Module.GetResourceInstance( ) , ( UINT )nResMessageId , tchErrMsg , SIZE_OF_BUFFER( tchErrMsg ) ) );
|
|
|
|
VERIFY_E( 0 , LoadString( _Module.GetResourceInstance( ) , ( UINT )nResTitleId , tchErrTitle , SIZE_OF_BUFFER( tchErrTitle ) ) );
|
|
|
|
if( hwnd == NULL )
|
|
{
|
|
nFlags |= MB_TASKMODAL;
|
|
}
|
|
|
|
MessageBox( hwnd , tchErrMsg , tchErrTitle , nFlags ) ; //MB_OK|MB_ICONERROR );
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------
|
|
|
|
void ReportStatusError( HWND hwnd , DWORD dwStatus )
|
|
{
|
|
LPTSTR pBuffer = NULL;
|
|
|
|
TCHAR tchTitle[ 80 ];
|
|
|
|
TCHAR tchBuffer[ 256 ];
|
|
|
|
TCHAR tchErr[ 256 ];
|
|
|
|
if( dwStatus != 0 )
|
|
{
|
|
|
|
VERIFY_E( 0 , LoadString( _Module.GetResourceInstance( ) , IDS_TSCERRTITLE , tchTitle , SIZE_OF_BUFFER( tchTitle ) ) );
|
|
|
|
VERIFY_E( 0 , LoadString( _Module.GetResourceInstance( ) , IDS_REPORTERROR , tchBuffer , SIZE_OF_BUFFER( tchBuffer ) ) );
|
|
|
|
|
|
FormatMessage (FORMAT_MESSAGE_ALLOCATE_BUFFER |
|
|
FORMAT_MESSAGE_FROM_SYSTEM,
|
|
NULL, //ignored
|
|
dwStatus , //message ID
|
|
MAKELANGID( LANG_NEUTRAL, SUBLANG_NEUTRAL ), //message language
|
|
(LPTSTR)&pBuffer, //address of buffer pointer
|
|
0, //minimum buffer size
|
|
NULL); //no other arguments
|
|
|
|
wsprintf( tchErr , tchBuffer , pBuffer );
|
|
|
|
::MessageBox( hwnd , tchErr , tchTitle , MB_OK | MB_ICONERROR );
|
|
|
|
if( pBuffer != NULL )
|
|
{
|
|
LocalFree( pBuffer );
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
//=------------------------------------------------------------------------------------------------
|
|
// xxxLegacDenyCleanup -- checked for the old LOGOFF bit
|
|
//=------------------------------------------------------------------------------------------------
|
|
DWORD xxxLegacyLogoffCleanup( PSECURITY_DESCRIPTOR *ppSD , PBOOL pfDaclChanged )
|
|
{
|
|
ACL_SIZE_INFORMATION asi;
|
|
BOOL bDaclPresent;
|
|
BOOL bDaclDefaulted;
|
|
PACL pDacl = NULL;
|
|
SECURITY_DESCRIPTOR_CONTROL sdc;
|
|
DWORD dwREV;
|
|
SECURITY_DESCRIPTOR absSD;
|
|
BOOL bSaclPresent;
|
|
BOOL bSaclDefaulted;
|
|
BOOL bOwnerDefaulted;
|
|
PSID psidOwner = NULL;
|
|
PVOID pAce = NULL;
|
|
PACL pSacl = NULL;
|
|
PSECURITY_DESCRIPTOR pOldSD = NULL;
|
|
|
|
DWORD dwStatus = ERROR_SUCCESS;
|
|
|
|
ZeroMemory( &asi , sizeof( ACL_SIZE_INFORMATION ) );
|
|
|
|
if( !GetSecurityDescriptorDacl( *ppSD ,
|
|
&bDaclPresent ,
|
|
&pDacl,
|
|
&bDaclDefaulted ) )
|
|
{
|
|
dwStatus = GetLastError();
|
|
DBGMSG( L"xxxLegacyLogoffCleanup@GetSecurityDescriptorDacl returned 0x%x\n" , dwStatus );
|
|
return dwStatus;
|
|
}
|
|
|
|
do
|
|
{
|
|
*pfDaclChanged = FALSE;
|
|
|
|
if( !GetAclInformation( pDacl , &asi , sizeof( asi ) , AclSizeInformation ) )
|
|
{
|
|
dwStatus = GetLastError( );
|
|
|
|
DBGMSG( L"xxxLegacyLogoffCleanup@GetAclInformation returned 0x%x\n" , dwStatus );
|
|
|
|
break;
|
|
}
|
|
|
|
// killed denied logoff.
|
|
|
|
BYTE bAceType;
|
|
|
|
for( int i = 0 ; i < ( int )asi.AceCount ; ++i )
|
|
{
|
|
if( !GetAce( pDacl , i , &pAce ) )
|
|
{
|
|
dwStatus = GetLastError( );
|
|
|
|
DBGMSG( L"xxxLegacyLogoffCleanup@GetAce returned 0x%x\n" , dwStatus );
|
|
|
|
break;
|
|
}
|
|
|
|
bAceType = ( ( PACE_HEADER )pAce )->AceType;
|
|
|
|
if( bAceType == ACCESS_DENIED_ACE_TYPE || bAceType == ACCESS_ALLOWED_ACE_TYPE )
|
|
{
|
|
// if the denied ace represents a single bit get rid of it
|
|
if( ( ( ACCESS_DENIED_ACE * )pAce )->Mask == WINSTATION_LOGOFF )
|
|
{
|
|
if( DeleteAce( pDacl , i ) )
|
|
{
|
|
// pDacl should have been reallocated to we need to re-obtain the acl info
|
|
GetAclInformation( pDacl , &asi , sizeof( asi ) , AclSizeInformation );
|
|
|
|
// reset the loop to point to the first ace
|
|
i=-1;
|
|
|
|
*pfDaclChanged = TRUE;
|
|
}
|
|
}
|
|
else if( ( ( ACCESS_DENIED_ACE * )pAce )->Mask & WINSTATION_LOGOFF )
|
|
{
|
|
// if the denied ace is a collection of bits with one as logoff turn the bit off
|
|
( ( ACCESS_DENIED_ACE * )pAce )->Mask ^= WINSTATION_LOGOFF;
|
|
|
|
*pfDaclChanged = TRUE;
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
|
|
if( dwStatus == ERROR_SUCCESS && *pfDaclChanged )
|
|
{
|
|
//
|
|
// Convert SelfRel to Absolute
|
|
//
|
|
|
|
DWORD dwSDLen = 0;
|
|
|
|
pOldSD = *ppSD;
|
|
|
|
GetSecurityDescriptorControl( *ppSD , &sdc , &dwREV );
|
|
|
|
InitializeSecurityDescriptor( &absSD , dwREV );
|
|
|
|
SetSecurityDescriptorDacl( &absSD , bDaclPresent , pDacl , bDaclDefaulted );
|
|
|
|
GetSecurityDescriptorSacl( *ppSD , &bSaclPresent , &pSacl , &bSaclDefaulted );
|
|
|
|
SetSecurityDescriptorSacl( &absSD , bSaclPresent , pSacl , bSaclDefaulted );
|
|
|
|
GetSecurityDescriptorOwner( *ppSD , &psidOwner , &bOwnerDefaulted );
|
|
|
|
SetSecurityDescriptorOwner( &absSD , psidOwner , FALSE );
|
|
|
|
SetSecurityDescriptorGroup( &absSD , psidOwner , FALSE );
|
|
|
|
*ppSD = NULL;
|
|
|
|
if( !MakeSelfRelativeSD( &absSD , *ppSD , &dwSDLen ) )
|
|
{
|
|
ODS( L"xxxLegacyLogoffCleanup -- MakeSelfRelativeSD failed as expected\n" );
|
|
|
|
*ppSD = ( PSECURITY_DESCRIPTOR )LocalAlloc( LMEM_FIXED , dwSDLen );
|
|
|
|
if( *ppSD == NULL )
|
|
{
|
|
dwStatus = ERROR_NOT_ENOUGH_MEMORY;
|
|
|
|
DBGMSG( L"xxxLegacyLogoffCleanup -- LocalAlloc failed 0x%x\n" , dwStatus );
|
|
|
|
break;
|
|
}
|
|
|
|
if( !MakeSelfRelativeSD( &absSD , *ppSD , &dwSDLen ) )
|
|
{
|
|
dwStatus = GetLastError( );
|
|
|
|
DBGMSG( L"xxxLegacyLogoffCleanup -- MakeSelfRelativeSD failed 0x%x\n" , dwStatus );
|
|
|
|
break;
|
|
}
|
|
|
|
}
|
|
}
|
|
|
|
}while( 0 );
|
|
|
|
if( pOldSD != NULL )
|
|
{
|
|
LocalFree( pOldSD );
|
|
}
|
|
|
|
return dwStatus;
|
|
|
|
}
|
|
|
|
//
|
|
INT_PTR APIENTRY
|
|
CustomSecurityDlgProc (
|
|
HWND hDlg,
|
|
UINT uMsg,
|
|
WPARAM wParam,
|
|
LPARAM lParam)
|
|
{
|
|
UNREFERENCED_PARAMETER( hDlg );
|
|
|
|
switch (uMsg)
|
|
{
|
|
case WM_INITDIALOG:
|
|
// This may seem that it does nothin, but it casues this function to return TRUE
|
|
// otherwise, you won't get this dialog!
|
|
break;
|
|
|
|
case WM_NOTIFY:
|
|
|
|
switch (((NMHDR FAR*)lParam)->code)
|
|
{
|
|
|
|
case NM_CLICK:
|
|
case NM_RETURN:
|
|
if(wParam == IDC_GP_LINK)
|
|
{
|
|
ShellExecute(NULL,TEXT("open"),TEXT("gpedit.msc"),NULL,NULL,SW_SHOW);
|
|
break;
|
|
}
|
|
else
|
|
{
|
|
return FALSE;
|
|
}
|
|
|
|
|
|
default:
|
|
return FALSE;
|
|
}
|
|
|
|
break;
|
|
|
|
case WM_COMMAND:
|
|
switch(LOWORD(wParam))
|
|
{
|
|
case IDOK:
|
|
case IDCANCEL:
|
|
EndDialog(hDlg,0);
|
|
break;
|
|
default:
|
|
return FALSE;
|
|
}
|
|
|
|
default:
|
|
return FALSE;
|
|
}
|
|
|
|
return TRUE;
|
|
}
|