2021-10-16 16:19:51 +01:00
# include "stdafx.h"
# include "OptionsWindow.h"
# include "SandMan.h"
# include "SettingsWindow.h"
# include "../MiscHelpers/Common/Settings.h"
# include "../MiscHelpers/Common/Common.h"
# include "../MiscHelpers/Common/ComboInputDialog.h"
# include "../MiscHelpers/Common/SettingsWidgets.h"
# include "Helpers/WinAdmin.h"
void COptionsWindow : : CreateAdvanced ( )
{
connect ( ui . chkPreferExternalManifest , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnAdvancedChanged ( ) ) ) ;
connect ( ui . chkNoWindowRename , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnNoWindowRename ( ) ) ) ;
connect ( ui . chkNestedJobs , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnAdvancedChanged ( ) ) ) ;
connect ( ui . chkUseSbieWndStation , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnAdvancedChanged ( ) ) ) ;
2021-11-13 08:28:32 +00:00
connect ( ui . chkAddToJob , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnAdvancedChanged ( ) ) ) ;
2021-10-16 16:19:51 +01:00
connect ( ui . chkProtectSCM , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnAdvancedChanged ( ) ) ) ;
2021-12-20 11:55:02 +00:00
connect ( ui . chkRestrictServices , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnSysSvcChanged ( ) ) ) ;
2021-11-13 08:28:32 +00:00
connect ( ui . chkElevateRpcss , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnAdvancedChanged ( ) ) ) ;
connect ( ui . chkProtectSystem , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnAdvancedChanged ( ) ) ) ;
connect ( ui . chkDropPrivileges , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnAdvancedChanged ( ) ) ) ;
connect ( ui . chkOpenCOM , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnOpenCOM ( ) ) ) ;
2021-12-20 11:55:02 +00:00
connect ( ui . chkComTimeout , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnAdvancedChanged ( ) ) ) ;
2021-11-13 08:28:32 +00:00
connect ( ui . chkNoSecurityIsolation , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnIsolationChanged ( ) ) ) ;
2022-08-15 08:35:36 +01:00
connect ( ui . chkNoSecurityFiltering , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnAdvancedChanged ( ) ) ) ;
2021-10-16 16:19:51 +01:00
connect ( ui . chkOpenDevCMApi , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnAdvancedChanged ( ) ) ) ;
//connect(ui.chkOpenLsaSSPI, SIGNAL(clicked(bool)), this, SLOT(OnAdvancedChanged()));
connect ( ui . chkOpenSamEndpoint , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnAdvancedChanged ( ) ) ) ;
connect ( ui . chkOpenLsaEndpoint , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnAdvancedChanged ( ) ) ) ;
2022-09-29 17:28:48 +01:00
connect ( ui . chkSbieLogon , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnAdvancedChanged ( ) ) ) ;
m_AdvOptions . insert ( " UseWin32kHooks " , SAdvOption { eSpec , QStringList ( ) < < " y " < < " n " , tr ( " Enable the use of win32 hooks for selected processes. Note: You need to enable win32k syscall hook support globally first. " ) } ) ;
m_AdvOptions . insert ( " EnableMiniDump " , SAdvOption { eSpec , QStringList ( ) < < " y " < < " n " , tr ( " Enable crash dump creation in the sandbox folder " ) } ) ;
m_AdvOptions . insert ( " ApplyElevateCreateProcessFix " , SAdvOption { eSpec , QStringList ( ) < < " y " < < " n " , tr ( " Always use ElevateCreateProcess fix, as sometimes applied by the Program Compatibility Assistant. " ) } ) ;
m_AdvOptions . insert ( " PreferExternalManifest " , SAdvOption { eOnlySpec , QStringList ( ) < < " y " < < " n, tr( " " ) " } ) ;
m_AdvOptions . insert ( " ExternalManifestHack " , SAdvOption { eSpec , QStringList ( ) < < " y " < < " n " , tr ( " Enable special inconsistent PreferExternalManifest behavioure, as neede for some edge fixes " ) } ) ;
m_AdvOptions . insert ( " RpcMgmtSetComTimeout " , SAdvOption { eSpec , QStringList ( ) < < " n " < < " y " , tr ( " Set RpcMgmtSetComTimeout usage for specific processes " ) } ) ;
m_AdvOptions . insert ( " CopyBlockDenyWrite " , SAdvOption { eSpec , QStringList ( ) < < " y " < < " n " , tr ( " Makes a write open call to a file that won't be copied fail instead of turning it read-only. " ) } ) ;
m_AdvOptions . insert ( " UseSbieDeskHack " , SAdvOption { eSpec , QStringList ( ) < < " y " < < " n " , tr ( " " ) } ) ;
m_AdvOptions . insert ( " UseSbieWndStation " , SAdvOption { eSpec , QStringList ( ) < < " n " < < " y " , tr ( " " ) } ) ;
m_AdvOptions . insert ( " FakeAdminRights " , SAdvOption { eOnlySpec , QStringList ( ) < < " y " < < " n " , tr ( " Make specified processes think thay have admin permissions. " ) } ) ;
m_AdvOptions . insert ( " WaitForDebugger " , SAdvOption { eOnlySpec , QStringList ( ) < < " y " < < " n " , tr ( " Force specified processes to wait for a debugger to attach. " ) } ) ;
m_AdvOptions . insert ( " BoxNameTitle " , SAdvOption { eOnlySpec , QStringList ( ) < < " y " < < " n " < < " - " , tr ( " " ) } ) ;
m_AdvOptions . insert ( " UseFileDeleteV2 " , SAdvOption { eNoSpec , QStringList ( ) < < " y " < < " n " , tr ( " " ) } ) ;
m_AdvOptions . insert ( " UseRegDeleteV2 " , SAdvOption { eNoSpec , QStringList ( ) < < " y " < < " n " , tr ( " " ) } ) ;
m_AdvOptions . insert ( " FileRootPath " , SAdvOption { eNoSpec , QStringList ( ) , tr ( " Sandbox file system root " ) } ) ;
m_AdvOptions . insert ( " KeyRootPath " , SAdvOption { eNoSpec , QStringList ( ) , tr ( " Sandbox registry root " ) } ) ;
m_AdvOptions . insert ( " IpcRootPath " , SAdvOption { eNoSpec , QStringList ( ) , tr ( " Sandbox ipc root " ) } ) ;
connect ( ui . btnAddOption , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnAddOption ( ) ) ) ;
connect ( ui . chkShowOptionsTmpl , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnShowOptionTmpl ( ) ) ) ;
connect ( ui . btnDelOption , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnDelOption ( ) ) ) ;
//connect(ui.treeOptions, SIGNAL(itemClicked(QTreeWidgetItem*, int)), this, SLOT(OnOptionItemClicked(QTreeWidgetItem*, int)));
connect ( ui . treeOptions , SIGNAL ( itemDoubleClicked ( QTreeWidgetItem * , int ) ) , this , SLOT ( OnOptionItemDoubleClicked ( QTreeWidgetItem * , int ) ) ) ;
connect ( ui . treeOptions , SIGNAL ( itemSelectionChanged ( ) ) , this , SLOT ( OnOptionSelectionChanged ( ) ) ) ;
connect ( ui . treeOptions , SIGNAL ( itemChanged ( QTreeWidgetItem * , int ) ) , this , SLOT ( OnOptionChanged ( QTreeWidgetItem * , int ) ) ) ;
2021-10-16 16:19:51 +01:00
connect ( ui . chkDisableMonitor , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnAdvancedChanged ( ) ) ) ;
connect ( ui . chkCallTrace , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnAdvancedChanged ( ) ) ) ;
connect ( ui . chkFileTrace , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnAdvancedChanged ( ) ) ) ;
connect ( ui . chkPipeTrace , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnAdvancedChanged ( ) ) ) ;
connect ( ui . chkKeyTrace , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnAdvancedChanged ( ) ) ) ;
connect ( ui . chkIpcTrace , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnAdvancedChanged ( ) ) ) ;
connect ( ui . chkGuiTrace , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnAdvancedChanged ( ) ) ) ;
connect ( ui . chkComTrace , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnAdvancedChanged ( ) ) ) ;
connect ( ui . chkNetFwTrace , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnAdvancedChanged ( ) ) ) ;
2022-09-29 17:28:48 +01:00
connect ( ui . chkDnsTrace , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnAdvancedChanged ( ) ) ) ;
2021-10-16 16:19:51 +01:00
connect ( ui . chkApiTrace , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnAdvancedChanged ( ) ) ) ;
connect ( ui . chkDbgTrace , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnAdvancedChanged ( ) ) ) ;
connect ( ui . chkErrTrace , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnAdvancedChanged ( ) ) ) ;
2022-09-29 17:28:48 +01:00
connect ( ui . treeTriggers , SIGNAL ( itemChanged ( QTreeWidgetItem * , int ) ) , this , SLOT ( OnTriggerChanged ( QTreeWidgetItem * , int ) ) ) ;
2022-02-04 21:08:25 +00:00
connect ( ui . btnAddAutoRun , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnAddAutoRun ( ) ) ) ;
connect ( ui . btnAddAutoSvc , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnAddAutoSvc ( ) ) ) ;
2021-10-16 16:19:51 +01:00
connect ( ui . btnAddAutoExec , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnAddAutoExec ( ) ) ) ;
2022-09-29 17:28:48 +01:00
connect ( ui . btnAddRecoveryCmd , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnAddRecoveryCheck ( ) ) ) ;
2022-02-04 21:08:25 +00:00
connect ( ui . btnAddDeleteCmd , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnAddDeleteCmd ( ) ) ) ;
connect ( ui . btnDelAuto , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnDelAuto ( ) ) ) ;
connect ( ui . chkShowTriggersTmpl , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnShowTriggersTmpl ( ) ) ) ;
2021-10-16 16:19:51 +01:00
connect ( ui . chkHideOtherBoxes , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnAdvancedChanged ( ) ) ) ;
connect ( ui . btnAddProcess , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnAddProcess ( ) ) ) ;
connect ( ui . btnDelProcess , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnDelProcess ( ) ) ) ;
2022-09-29 17:28:48 +01:00
connect ( ui . chkShowHiddenProcTmpl , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnShowHiddenProcTmpl ( ) ) ) ;
connect ( ui . btnAddHostProcess , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnAddHostProcess ( ) ) ) ;
connect ( ui . btnDelHostProcess , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnDelHostProcess ( ) ) ) ;
connect ( ui . chkShowHostProcTmpl , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnShowHostProcTmpl ( ) ) ) ;
connect ( ui . chkConfidential , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnAdvancedChanged ( ) ) ) ; // todo norify premium feaure
2021-10-16 16:19:51 +01:00
connect ( ui . btnAddUser , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnAddUser ( ) ) ) ;
connect ( ui . btnDelUser , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnDelUser ( ) ) ) ;
connect ( ui . chkMonitorAdminOnly , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnAdvancedChanged ( ) ) ) ;
}
void COptionsWindow : : LoadAdvanced ( )
{
ui . chkPreferExternalManifest - > setChecked ( m_pBox - > GetBool ( " PreferExternalManifest " , false ) ) ;
2022-06-16 14:58:10 +01:00
ui . chkNestedJobs - > setChecked ( m_pBox - > GetBool ( " AllowBoxedJobs " , false ) ) ;
2021-12-26 09:19:31 +00:00
ui . chkUseSbieWndStation - > setChecked ( m_pBox - > GetBool ( " UseSbieWndStation " , true ) ) ;
2021-10-16 16:19:51 +01:00
2021-11-13 08:28:32 +00:00
ui . chkAddToJob - > setChecked ( ! m_pBox - > GetBool ( " NoAddProcessToJob " , false ) ) ;
2021-10-16 16:19:51 +01:00
ui . chkProtectSCM - > setChecked ( ! m_pBox - > GetBool ( " UnrestrictedSCM " , false ) ) ;
ui . chkRestrictServices - > setChecked ( ! m_pBox - > GetBool ( " RunServicesAsSystem " , false ) ) ;
2021-11-13 08:28:32 +00:00
ui . chkElevateRpcss - > setChecked ( m_pBox - > GetBool ( " RunRpcssAsSystem " , false ) ) ;
ui . chkProtectSystem - > setChecked ( ! m_pBox - > GetBool ( " ExposeBoxedSystem " , false ) ) ;
ui . chkDropPrivileges - > setChecked ( m_pBox - > GetBool ( " StripSystemPrivileges " , true ) ) ;
2021-10-16 16:19:51 +01:00
2022-08-28 11:43:08 +01:00
CheckOpenCOM ( ) ;
2021-12-20 11:55:02 +00:00
ui . chkComTimeout - > setChecked ( ! m_pBox - > GetBool ( " RpcMgmtSetComTimeout " , true ) ) ;
2021-11-13 08:28:32 +00:00
ui . chkNoSecurityIsolation - > setChecked ( m_pBox - > GetBool ( " NoSecurityIsolation " , false ) ) ;
ui . chkNoSecurityFiltering - > setChecked ( m_pBox - > GetBool ( " NoSecurityFiltering " , false ) ) ;
2021-10-16 16:19:51 +01:00
ui . chkOpenDevCMApi - > setChecked ( m_pBox - > GetBool ( " OpenDevCMApi " , false ) ) ;
//ui.chkOpenLsaSSPI->setChecked(!m_pBox->GetBool("BlockPassword", true)); // OpenLsaSSPI
ui . chkOpenSamEndpoint - > setChecked ( m_pBox - > GetBool ( " OpenSamEndpoint " , false ) ) ;
ui . chkOpenLsaEndpoint - > setChecked ( m_pBox - > GetBool ( " OpenLsaEndpoint " , false ) ) ;
2022-09-29 17:28:48 +01:00
ReadGlobalCheck ( ui . chkSbieLogon , " SandboxieLogon " , false ) ;
LoadOptionList ( ) ;
2021-10-16 16:19:51 +01:00
bool bGlobalNoMon = m_pBox - > GetAPI ( ) - > GetGlobalSettings ( ) - > GetBool ( " DisableResourceMonitor " , false ) ;
ui . chkDisableMonitor - > setChecked ( m_pBox - > GetBool ( " DisableResourceMonitor " , bGlobalNoMon ) ) ;
ReadAdvancedCheck ( " CallTrace " , ui . chkCallTrace , " * " ) ;
ReadAdvancedCheck ( " FileTrace " , ui . chkFileTrace , " * " ) ;
ReadAdvancedCheck ( " PipeTrace " , ui . chkPipeTrace , " * " ) ;
ReadAdvancedCheck ( " KeyTrace " , ui . chkKeyTrace , " * " ) ;
ReadAdvancedCheck ( " IpcTrace " , ui . chkIpcTrace , " * " ) ;
ReadAdvancedCheck ( " GuiTrace " , ui . chkGuiTrace , " * " ) ;
ReadAdvancedCheck ( " ClsidTrace " , ui . chkComTrace , " * " ) ;
ReadAdvancedCheck ( " NetFwTrace " , ui . chkNetFwTrace , " * " ) ;
2022-09-29 17:28:48 +01:00
ui . chkDnsTrace - > setChecked ( m_pBox - > GetBool ( " DnsTrace " , false ) ) ;
2021-10-16 16:19:51 +01:00
ui . chkDbgTrace - > setChecked ( m_pBox - > GetBool ( " DebugTrace " , false ) ) ;
ui . chkErrTrace - > setChecked ( m_pBox - > GetBool ( " ErrorTrace " , false ) ) ;
QSharedPointer < CSandBoxPlus > pBoxPlus = m_pBox . objectCast < CSandBoxPlus > ( ) ;
if ( pBoxPlus )
ui . chkApiTrace - > setChecked ( pBoxPlus - > HasLogApi ( ) ) ;
2022-02-04 21:08:25 +00:00
// triggers
ui . treeTriggers - > clear ( ) ;
foreach ( const QString & Value , m_pBox - > GetTextList ( " StartProgram " , m_Template ) )
AddTriggerItem ( Value , eOnStartCmd ) ;
foreach ( const QString & Value , m_pBox - > GetTextList ( " StartService " , m_Template ) )
AddTriggerItem ( Value , eOnStartSvc ) ;
foreach ( const QString & Value , m_pBox - > GetTextList ( " AutoExec " , m_Template ) )
AddTriggerItem ( Value , eAutoExec ) ;
2022-09-29 17:28:48 +01:00
foreach ( const QString & Value , m_pBox - > GetTextList ( " OnFileRecovery " , m_Template ) )
AddTriggerItem ( Value , eRecoveryCheck ) ;
2022-02-04 21:08:25 +00:00
foreach ( const QString & Value , m_pBox - > GetTextList ( " OnBoxDelete " , m_Template ) )
AddTriggerItem ( Value , eDeleteCmd ) ;
ShowTriggersTmpl ( ) ;
//
2022-08-10 20:03:59 +01:00
ui . chkHideOtherBoxes - > setChecked ( m_pBox - > GetBool ( " HideOtherBoxes " , true ) ) ;
2022-09-29 17:28:48 +01:00
ui . treeHideProc - > clear ( ) ;
foreach ( const QString & Value , m_pBox - > GetTextList ( " HideHostProcess " , m_Template ) )
AddHiddenProcEntry ( Value ) ;
ShowHiddenProcTmpl ( ) ;
ui . treeHostProc - > clear ( ) ;
foreach ( const QString & Value , m_pBox - > GetTextList ( " DenyHostAccess " , m_Template ) ) {
StrPair NameVal = Split2 ( Value , " , " ) ;
AddHostProcEntry ( NameVal . first , NameVal . second . left ( 0 ) . toLower ( ) ! = " y " ) ;
}
ShowHostProcTmpl ( ) ;
ui . chkConfidential - > setChecked ( m_pBox - > GetBool ( " ConfidentialBox " , false ) ) ;
2021-10-16 16:19:51 +01:00
QStringList Users = m_pBox - > GetText ( " Enabled " ) . split ( " , " ) ;
ui . lstUsers - > clear ( ) ;
if ( Users . count ( ) > 1 )
ui . lstUsers - > addItems ( Users . mid ( 1 ) ) ;
ui . chkMonitorAdminOnly - > setChecked ( m_pBox - > GetBool ( " MonitorAdminOnly " , false ) ) ;
2021-11-13 08:28:32 +00:00
UpdateBoxIsolation ( ) ;
2021-12-20 11:55:02 +00:00
OnSysSvcChanged ( ) ;
2021-11-13 08:28:32 +00:00
ui . chkOpenCredentials - > setEnabled ( ! ui . chkOpenProtectedStorage - > isChecked ( ) ) ;
if ( ! ui . chkOpenCredentials - > isEnabled ( ) ) ui . chkOpenCredentials - > setChecked ( true ) ;
2021-10-16 16:19:51 +01:00
m_AdvancedChanged = false ;
}
2022-08-14 17:57:18 +01:00
void COptionsWindow : : OnPSTChanged ( )
{
if ( ! ui . chkOpenProtectedStorage - > isChecked ( ) )
ui . chkOpenCredentials - > setChecked ( m_pBox - > GetBool ( " OpenCredentials " , false ) ) ;
OnGeneralChanged ( ) ;
}
2022-02-04 21:08:25 +00:00
void COptionsWindow : : ShowTriggersTmpl ( bool bUpdate )
{
2022-07-10 19:00:26 +01:00
if ( ui . chkShowTriggersTmpl - > isChecked ( ) )
2022-02-04 21:08:25 +00:00
{
foreach ( const QString & Template , m_pBox - > GetTemplates ( ) )
{
foreach ( const QString & Value , m_pBox - > GetTextListTmpl ( " StartProgram " , Template ) )
AddTriggerItem ( Value , eOnStartCmd , Template ) ;
foreach ( const QString & Value , m_pBox - > GetTextListTmpl ( " StartService " , Template ) )
AddTriggerItem ( Value , eOnStartSvc , Template ) ;
foreach ( const QString & Value , m_pBox - > GetTextListTmpl ( " AutoExec " , Template ) )
AddTriggerItem ( Value , eAutoExec , Template ) ;
2022-09-29 17:28:48 +01:00
foreach ( const QString & Value , m_pBox - > GetTextListTmpl ( " OnFileRecovery " , Template ) )
AddTriggerItem ( Value , eRecoveryCheck , Template ) ;
2022-02-04 21:08:25 +00:00
foreach ( const QString & Value , m_pBox - > GetTextListTmpl ( " OnBoxDelete " , Template ) )
AddTriggerItem ( Value , eDeleteCmd , Template ) ;
}
}
else if ( bUpdate )
{
for ( int i = 0 ; i < ui . treeRecovery - > topLevelItemCount ( ) ; )
{
QTreeWidgetItem * pItem = ui . treeRecovery - > topLevelItem ( i ) ;
int Type = pItem - > data ( 0 , Qt : : UserRole ) . toInt ( ) ;
if ( Type = = - 1 ) {
delete pItem ;
continue ; // entry from template
}
i + + ;
}
}
}
2021-10-16 16:19:51 +01:00
void COptionsWindow : : SaveAdvanced ( )
{
WriteAdvancedCheck ( ui . chkPreferExternalManifest , " PreferExternalManifest " , " y " , " " ) ;
2021-12-26 09:19:31 +00:00
WriteAdvancedCheck ( ui . chkUseSbieWndStation , " UseSbieWndStation " , " " , " n " ) ;
2021-10-16 16:19:51 +01:00
2021-11-13 08:28:32 +00:00
WriteAdvancedCheck ( ui . chkAddToJob , " NoAddProcessToJob " , " " , " y " ) ;
2021-10-16 16:19:51 +01:00
WriteAdvancedCheck ( ui . chkProtectSCM , " UnrestrictedSCM " , " " , " y " ) ;
2022-06-16 14:58:10 +01:00
WriteAdvancedCheck ( ui . chkNestedJobs , " AllowBoxedJobs " , " y " , " " ) ;
2021-10-16 16:19:51 +01:00
WriteAdvancedCheck ( ui . chkRestrictServices , " RunServicesAsSystem " , " " , " y " ) ;
2021-11-13 08:28:32 +00:00
WriteAdvancedCheck ( ui . chkElevateRpcss , " RunRpcssAsSystem " , " y " , " " ) ;
WriteAdvancedCheck ( ui . chkProtectSystem , " ExposeBoxedSystem " , " " , " y " ) ;
WriteAdvancedCheck ( ui . chkDropPrivileges , " StripSystemPrivileges " , " " , " n " ) ;
2021-12-20 11:55:02 +00:00
WriteAdvancedCheck ( ui . chkComTimeout , " RpcMgmtSetComTimeout " , " n " , " " ) ;
2021-11-13 08:28:32 +00:00
WriteAdvancedCheck ( ui . chkNoSecurityIsolation , " NoSecurityIsolation " , " y " , " " ) ;
WriteAdvancedCheck ( ui . chkNoSecurityFiltering , " NoSecurityFiltering " , " y " , " " ) ;
2021-10-16 16:19:51 +01:00
WriteAdvancedCheck ( ui . chkOpenDevCMApi , " OpenDevCMApi " , " y " , " " ) ;
//WriteAdvancedCheck(ui.chkOpenLsaSSPI, "BlockPassword", "n", ""); // OpenLsaSSPI
WriteAdvancedCheck ( ui . chkOpenSamEndpoint , " OpenSamEndpoint " , " y " , " " ) ;
WriteAdvancedCheck ( ui . chkOpenLsaEndpoint , " OpenLsaEndpoint " , " y " , " " ) ;
2022-09-29 17:28:48 +01:00
WriteGlobalCheck ( ui . chkSbieLogon , " SandboxieLogon " , false ) ;
SaveOptionList ( ) ;
2021-10-16 16:19:51 +01:00
bool bGlobalNoMon = m_pBox - > GetAPI ( ) - > GetGlobalSettings ( ) - > GetBool ( " DisableResourceMonitor " , false ) ;
WriteAdvancedCheck ( ui . chkDisableMonitor , " DisableResourceMonitor " , bGlobalNoMon ? " " : " y " , bGlobalNoMon ? " n " : " " ) ;
WriteAdvancedCheck ( ui . chkCallTrace , " CallTrace " , " * " ) ;
WriteAdvancedCheck ( ui . chkFileTrace , " FileTrace " , " * " ) ;
WriteAdvancedCheck ( ui . chkPipeTrace , " PipeTrace " , " * " ) ;
WriteAdvancedCheck ( ui . chkKeyTrace , " KeyTrace " , " * " ) ;
WriteAdvancedCheck ( ui . chkIpcTrace , " IpcTrace " , " * " ) ;
WriteAdvancedCheck ( ui . chkGuiTrace , " GuiTrace " , " * " ) ;
WriteAdvancedCheck ( ui . chkComTrace , " ClsidTrace " , " * " ) ;
WriteAdvancedCheck ( ui . chkNetFwTrace , " NetFwTrace " , " * " ) ;
2022-09-29 17:28:48 +01:00
WriteAdvancedCheck ( ui . chkDnsTrace , " chkDnsTrace " , " y " ) ;
2021-10-16 16:19:51 +01:00
WriteAdvancedCheck ( ui . chkDbgTrace , " DebugTrace " , " y " ) ;
WriteAdvancedCheck ( ui . chkErrTrace , " ErrorTrace " , " y " ) ;
QSharedPointer < CSandBoxPlus > pBoxPlus = m_pBox . objectCast < CSandBoxPlus > ( ) ;
if ( pBoxPlus )
pBoxPlus - > SetLogApi ( ui . chkApiTrace - > isChecked ( ) ) ;
2022-02-04 21:08:25 +00:00
// triggers
QStringList StartProgram ;
QStringList StartService ;
2022-09-29 17:28:48 +01:00
QStringList RecoveryCheck ;
2022-02-04 21:08:25 +00:00
QStringList DeleteCommand ;
QStringList AutoExec ;
for ( int i = 0 ; i < ui . treeTriggers - > topLevelItemCount ( ) ; i + + ) {
QTreeWidgetItem * pItem = ui . treeTriggers - > topLevelItem ( i ) ;
switch ( pItem - > data ( 0 , Qt : : UserRole ) . toInt ( ) )
{
case eOnStartCmd : StartProgram . append ( pItem - > text ( 2 ) ) ; break ;
case eOnStartSvc : StartService . append ( pItem - > text ( 2 ) ) ; break ;
case eAutoExec : AutoExec . append ( pItem - > text ( 2 ) ) ; break ;
2022-09-29 17:28:48 +01:00
case eRecoveryCheck : RecoveryCheck . append ( pItem - > text ( 2 ) ) ; break ;
2022-02-04 21:08:25 +00:00
case eDeleteCmd : DeleteCommand . append ( pItem - > text ( 2 ) ) ; break ;
}
}
WriteTextList ( " StartProgram " , StartProgram ) ;
WriteTextList ( " StartService " , StartService ) ;
WriteTextList ( " AutoExec " , AutoExec ) ;
2022-09-29 17:28:48 +01:00
WriteTextList ( " OnFileRecovery " , RecoveryCheck ) ;
2022-02-04 21:08:25 +00:00
WriteTextList ( " OnBoxDelete " , DeleteCommand ) ;
//
2022-09-29 17:28:48 +01:00
2022-08-28 11:43:08 +01:00
WriteAdvancedCheck ( ui . chkHideOtherBoxes , " HideOtherBoxes " , " " , " n " ) ;
2021-10-16 16:19:51 +01:00
2022-09-29 17:28:48 +01:00
QStringList HideProcesses ;
for ( int i = 0 ; i < ui . treeHideProc - > topLevelItemCount ( ) ; i + + )
{
QTreeWidgetItem * pItem = ui . treeHideProc - > topLevelItem ( i ) ;
int Type = pItem - > data ( 0 , Qt : : UserRole ) . toInt ( ) ;
if ( Type = = - 1 )
continue ; // entry from template
HideProcesses . append ( pItem - > text ( 0 ) ) ;
}
WriteTextList ( " HideHostProcess " , HideProcesses ) ;
QStringList DenyHostProcesses ;
for ( int i = 0 ; i < ui . treeHostProc - > topLevelItemCount ( ) ; i + + )
{
QTreeWidgetItem * pItem = ui . treeHostProc - > topLevelItem ( i ) ;
int Type = pItem - > data ( 0 , Qt : : UserRole ) . toInt ( ) ;
if ( Type = = - 1 )
continue ; // entry from template
DenyHostProcesses . append ( pItem - > text ( 0 ) + " , " + ( pItem - > data ( 1 , Qt : : UserRole ) . toBool ( ) ? " n " : " y " ) ) ;
}
WriteTextList ( " DenyHostAccess " , DenyHostProcesses ) ;
WriteAdvancedCheck ( ui . chkConfidential , " ConfidentialBox " , " y " , " " ) ;
2021-10-16 16:19:51 +01:00
QStringList Users ;
for ( int i = 0 ; i < ui . lstUsers - > count ( ) ; i + + )
Users . append ( ui . lstUsers - > item ( i ) - > text ( ) ) ;
WriteText ( " Enabled " , Users . count ( ) > 0 ? " y, " + Users . join ( " , " ) : " y " ) ;
WriteAdvancedCheck ( ui . chkMonitorAdminOnly , " MonitorAdminOnly " ) ;
m_AdvancedChanged = false ;
}
2021-11-13 08:28:32 +00:00
void COptionsWindow : : OnIsolationChanged ( )
2021-10-16 16:19:51 +01:00
{
2022-08-15 08:35:36 +01:00
if ( sender ( ) = = ui . chkNoSecurityIsolation ) {
// we can ignore chkNoSecurityFiltering as it requires chkNoSecurityIsolation
if ( ui . chkNoSecurityIsolation - > isChecked ( ) )
theGUI - > CheckCertificate ( this ) ;
}
2021-11-13 08:28:32 +00:00
UpdateBoxIsolation ( ) ;
2022-08-14 16:40:55 +01:00
if ( sender ( ) = = ui . chkNoSecurityIsolation & & ! ui . chkNoSecurityIsolation - > isChecked ( ) ) {
ui . chkCloseForBox - > setChecked ( m_pBox - > GetBool ( " AlwaysCloseForBoxed " , true ) ) ;
ui . chkNoOpenForBox - > setChecked ( m_pBox - > GetBool ( " DontOpenForBoxed " , true ) ) ;
}
2021-11-13 08:28:32 +00:00
m_AdvancedChanged = true ;
OnOptChanged ( ) ;
}
void COptionsWindow : : UpdateBoxIsolation ( )
{
ui . chkNoSecurityFiltering - > setEnabled ( ui . chkNoSecurityIsolation - > isChecked ( ) ) ;
2021-10-16 16:19:51 +01:00
2021-11-13 08:28:32 +00:00
ui . chkAddToJob - > setEnabled ( ! ui . chkNoSecurityIsolation - > isChecked ( ) ) ;
2021-12-21 13:57:27 +00:00
ui . chkNestedJobs - > setEnabled ( ! ui . chkNoSecurityIsolation - > isChecked ( ) ) ;
2021-11-13 08:28:32 +00:00
ui . chkOpenDevCMApi - > setEnabled ( ! ui . chkNoSecurityIsolation - > isChecked ( ) ) ;
ui . chkOpenSamEndpoint - > setEnabled ( ! ui . chkNoSecurityIsolation - > isChecked ( ) ) ;
ui . chkOpenLsaEndpoint - > setEnabled ( ! ui . chkNoSecurityIsolation - > isChecked ( ) ) ;
ui . chkRawDiskRead - > setEnabled ( ! ui . chkNoSecurityIsolation - > isChecked ( ) ) ; // without isolation only user mode
ui . chkRawDiskNotify - > setEnabled ( ! ui . chkNoSecurityIsolation - > isChecked ( ) ) ;
ui . chkBlockNetShare - > setEnabled ( ! ui . chkNoSecurityFiltering - > isChecked ( ) ) ;
ui . chkBlockSpooler - > setEnabled ( ! ui . chkNoSecurityIsolation - > isChecked ( ) ) ;
ui . chkOpenSpooler - > setEnabled ( ! ui . chkBlockSpooler - > isChecked ( ) & & ! ui . chkNoSecurityIsolation - > isChecked ( ) ) ;
ui . chkPrintToFile - > setEnabled ( ! ui . chkBlockSpooler - > isChecked ( ) & & ! ui . chkNoSecurityFiltering - > isChecked ( ) ) ;
ui . chkCloseClipBoard - > setEnabled ( ! ui . chkNoSecurityIsolation - > isChecked ( ) ) ;
2022-08-09 17:19:46 +01:00
ui . chkVmRead - > setEnabled ( ! ui . chkNoSecurityIsolation - > isChecked ( ) ) ;
2022-08-14 16:40:55 +01:00
ui . chkCloseForBox - > setEnabled ( ! ui . chkNoSecurityIsolation - > isChecked ( ) ) ;
ui . chkNoOpenForBox - > setEnabled ( ! ui . chkNoSecurityIsolation - > isChecked ( ) ) ;
2022-08-09 17:19:46 +01:00
if ( ui . chkNoSecurityIsolation - > isChecked ( ) ) {
ui . chkCloseForBox - > setChecked ( false ) ;
ui . chkNoOpenForBox - > setChecked ( false ) ;
}
2021-11-13 08:28:32 +00:00
}
2021-12-20 11:55:02 +00:00
void COptionsWindow : : OnSysSvcChanged ( )
{
ui . chkElevateRpcss - > setDisabled ( ui . chkNoSecurityIsolation - > isChecked ( ) & & ( ! ui . chkRestrictServices - > isChecked ( ) | | ui . chkMsiExemptions - > isChecked ( ) ) ) ;
m_AdvancedChanged = true ;
OnOptChanged ( ) ;
}
2021-11-13 08:28:32 +00:00
void COptionsWindow : : OnAdvancedChanged ( )
{
2021-10-16 16:19:51 +01:00
m_AdvancedChanged = true ;
2021-11-13 08:28:32 +00:00
OnOptChanged ( ) ;
}
2022-08-28 11:43:08 +01:00
void COptionsWindow : : CheckOpenCOM ( )
{
bool bComIpcOpen = GetAccessEntry ( eIPC , " " , eOpen , " \\ RPC Control \\ epmapper " ) ! = NULL | | GetAccessEntry ( eIPC , " " , eOpen , " * " ) ! = NULL ;
if ( bComIpcOpen )
ui . chkOpenCOM - > setChecked ( ! m_BoxTemplates . contains ( " BoxedCOM " ) ) ;
else
ui . chkOpenCOM - > setChecked ( m_BoxTemplates . contains ( " OpenCOM " ) ) ;
}
2021-11-13 08:28:32 +00:00
void COptionsWindow : : OnOpenCOM ( )
{
2022-08-28 11:43:08 +01:00
bool bComIpcOpen = GetAccessEntry ( eIPC , " " , eOpen , " \\ RPC Control \\ epmapper " ) ! = NULL | | GetAccessEntry ( eIPC , " " , eOpen , " * " ) ! = NULL ;
SetTemplate ( " OpenCOM " , ! bComIpcOpen & & ui . chkOpenCOM - > isChecked ( ) ) ;
SetTemplate ( " BoxedCOM " , bComIpcOpen & & ! ui . chkOpenCOM - > isChecked ( ) ) ;
2021-10-16 16:19:51 +01:00
}
void COptionsWindow : : OnNoWindowRename ( )
{
if ( ui . chkNoWindowRename - > isChecked ( ) )
2021-11-13 08:28:32 +00:00
SetAccessEntry ( eWnd , " " , eOpen , " # " ) ;
2021-10-16 16:19:51 +01:00
else
2021-11-13 08:28:32 +00:00
DelAccessEntry ( eWnd , " " , eOpen , " # " ) ;
2021-10-16 16:19:51 +01:00
m_AdvancedChanged = true ;
2021-11-13 08:28:32 +00:00
OnOptChanged ( ) ;
2021-10-16 16:19:51 +01:00
}
2022-09-29 17:28:48 +01:00
// options
void COptionsWindow : : LoadOptionList ( )
{
if ( ! ui . treeOptions ) return ;
ui . treeOptions - > clear ( ) ;
foreach ( const QString & Name , m_AdvOptions . keys ( ) ) {
foreach ( const QString & Value , m_pBox - > GetTextList ( Name , m_Template ) ) {
QStringList Values = Value . split ( " , " ) ;
if ( Values . count ( ) > = 2 )
AddOptionEntry ( Name , Values [ 0 ] , Values [ 1 ] ) ;
else if ( m_AdvOptions [ Name ] . ProcSpec ! = eOnlySpec ) // eOnlySpec shows only process specific entries, no global once
AddOptionEntry ( Name , " " , Values [ 0 ] ) ;
}
}
LoadOptionListTmpl ( ) ;
}
void COptionsWindow : : LoadOptionListTmpl ( bool bUpdate )
{
if ( ui . chkShowOptionsTmpl - > isChecked ( ) )
{
foreach ( const QString & Template , m_pBox - > GetTemplates ( ) )
{
foreach ( const QString & Name , m_AdvOptions . keys ( ) ) {
foreach ( const QString & Value , m_pBox - > GetTextListTmpl ( Name , Template ) ) {
QStringList Values = Value . split ( " , " ) ;
if ( Values . count ( ) > = 2 )
AddOptionEntry ( Name , Values [ 0 ] , Values [ 1 ] , Template ) ;
else // all programs
AddOptionEntry ( Name , " " , Values [ 0 ] , Template ) ;
}
}
}
}
else if ( bUpdate )
{
for ( int i = 0 ; i < ui . treeOptions - > topLevelItemCount ( ) ; )
{
QTreeWidgetItem * pItem = ui . treeOptions - > topLevelItem ( i ) ;
QString Name = pItem - > data ( 0 , Qt : : UserRole ) . toString ( ) ;
if ( Name . isEmpty ( ) ) {
delete pItem ;
continue ; // entry from template
}
i + + ;
}
}
}
void COptionsWindow : : SaveOptionList ( )
{
CloseOptionEdit ( true ) ;
QMap < QString , QList < QString > > OptionMap ;
for ( int i = 0 ; i < ui . treeOptions - > topLevelItemCount ( ) ; i + + )
{
QTreeWidgetItem * pItem = ui . treeOptions - > topLevelItem ( i ) ;
QString Name = pItem - > data ( 0 , Qt : : UserRole ) . toString ( ) ;
if ( Name . isEmpty ( ) )
continue ; // entry from template
QString Program = pItem - > data ( 1 , Qt : : UserRole ) . toString ( ) ;
QString Value = pItem - > data ( 2 , Qt : : UserRole ) . toString ( ) ;
if ( ! Program . isEmpty ( ) )
Value . prepend ( Program + " , " ) ;
OptionMap [ Name ] . append ( Value ) ;
}
foreach ( const QString & Key , m_AdvOptions . keys ( ) ) {
WriteTextList ( Key , OptionMap [ Key ] ) ;
}
}
void COptionsWindow : : AddOptionEntry ( const QString & Name , QString Program , const QString & Value , const QString & Template )
{
QTreeWidgetItem * pItem = new QTreeWidgetItem ( ) ;
pItem - > setText ( 0 , Name + ( Template . isEmpty ( ) ? " " : " ( " + Template + " ) " ) ) ;
pItem - > setData ( 0 , Qt : : UserRole , ! Template . isEmpty ( ) ? " " : Name ) ;
pItem - > setData ( 1 , Qt : : UserRole , Program ) ;
bool bAll = Program . isEmpty ( ) ;
if ( bAll )
Program = tr ( " All Programs " ) ;
bool Not = Program . left ( 1 ) = = " ! " ;
if ( Not )
Program . remove ( 0 , 1 ) ;
//if (Program.left(1) == "<")
// Program = tr("Group: %1").arg(Program.mid(1, Program.length() - 2));
//else if(!bAll)
// m_Programs.insert(Program);
pItem - > setText ( 1 , ( Not ? " NOT " : " " ) + Program ) ;
pItem - > setText ( 2 , Value ) ;
pItem - > setData ( 2 , Qt : : UserRole , Value ) ;
//if(Template.isEmpty())
// pItem->setCheckState(0, disabled ? Qt::Unchecked : Qt::Checked);
ui . treeOptions - > addTopLevelItem ( pItem ) ;
}
void COptionsWindow : : OnAddOption ( )
{
CComboInputDialog progDialog ( this ) ;
progDialog . setText ( tr ( " Add special option: " ) ) ;
progDialog . setEditable ( true ) ;
foreach ( const QString & Name , m_AdvOptions . keys ( ) )
progDialog . addItem ( Name , Name , m_AdvOptions [ Name ] . Description ) ;
progDialog . setValue ( " EnableMiniDump " ) ;
if ( ! progDialog . exec ( ) )
return ;
QString Name = progDialog . value ( ) ;
AddOptionEntry ( Name , " Program.exe " , " " ) ;
}
void COptionsWindow : : OnDelOption ( )
{
DeleteAccessEntry ( ui . treeOptions - > currentItem ( ) ) ;
m_AdvancedChanged = true ;
OnOptChanged ( ) ;
}
void COptionsWindow : : OnOptionItemDoubleClicked ( QTreeWidgetItem * pItem , int Column )
{
//if (Column == 0)
// return;
QString Name = pItem - > data ( 0 , Qt : : UserRole ) . toString ( ) ;
if ( Name . isEmpty ( ) ) {
QMessageBox : : warning ( this , " SandboxiePlus " , tr ( " Template values can not be edited. " ) ) ;
return ;
}
QString Program = pItem - > data ( 1 , Qt : : UserRole ) . toString ( ) ;
if ( m_AdvOptions [ Name ] . ProcSpec ! = eNoSpec )
{
QWidget * pProgram = new QWidget ( ) ;
pProgram - > setAutoFillBackground ( true ) ;
QHBoxLayout * pLayout = new QHBoxLayout ( ) ;
pLayout - > setContentsMargins ( 0 , 0 , 0 , 0 ) ;
pLayout - > setSpacing ( 0 ) ;
pProgram - > setLayout ( pLayout ) ;
QToolButton * pNot = new QToolButton ( pProgram ) ;
pNot - > setText ( " ! " ) ;
pNot - > setCheckable ( true ) ;
if ( Program . left ( 1 ) = = " ! " ) {
pNot - > setChecked ( true ) ;
Program . remove ( 0 , 1 ) ;
}
pLayout - > addWidget ( pNot ) ;
QComboBox * pCombo = new QComboBox ( pProgram ) ;
if ( m_AdvOptions [ Name ] . ProcSpec ! = eOnlySpec )
pCombo - > addItem ( tr ( " All Programs " ) , " " ) ;
//foreach(const QString Group, GetCurrentGroups()){
// QString GroupName = Group.mid(1, Group.length() - 2);
// pCombo->addItem(tr("Group: %1").arg(GroupName), Group);
//}
foreach ( const QString & Name , m_Programs )
pCombo - > addItem ( Name , Name ) ;
pCombo - > setEditable ( true ) ;
int Index = pCombo - > findData ( Program ) ;
pCombo - > setCurrentIndex ( Index ) ;
if ( Index = = - 1 )
pCombo - > setCurrentText ( Program ) ;
pLayout - > addWidget ( pCombo ) ;
ui . treeOptions - > setItemWidget ( pItem , 1 , pProgram ) ;
}
QComboBox * pValue = new QComboBox ( ) ;
pValue - > setEditable ( true ) ;
foreach ( const QString & Value , m_AdvOptions [ Name ] . Values )
pValue - > addItem ( Value ) ;
//pValue->setCurrentIndex(pValue->findData(pItem->data(2, Qt::UserRole)));
ui . treeOptions - > setItemWidget ( pItem , 2 , pValue ) ;
}
void COptionsWindow : : OnOptionChanged ( QTreeWidgetItem * pItem , int Column )
{
if ( Column ! = 0 )
return ;
m_AdvancedChanged = true ;
OnOptChanged ( ) ;
}
void COptionsWindow : : CloseOptionEdit ( bool bSave )
{
if ( ! ui . treeOptions ) return ;
for ( int i = 0 ; i < ui . treeOptions - > topLevelItemCount ( ) ; i + + )
{
QTreeWidgetItem * pItem = ui . treeOptions - > topLevelItem ( i ) ;
CloseOptionEdit ( pItem , bSave ) ;
}
}
void COptionsWindow : : CloseOptionEdit ( QTreeWidgetItem * pItem , bool bSave )
{
QComboBox * pValue = ( QComboBox * ) ui . treeOptions - > itemWidget ( pItem , 2 ) ;
if ( ! pValue )
return ;
if ( bSave )
{
QWidget * pProgram = ui . treeOptions - > itemWidget ( pItem , 1 ) ;
if ( pProgram )
{
QHBoxLayout * pLayout = ( QHBoxLayout * ) pProgram - > layout ( ) ;
QToolButton * pNot = ( QToolButton * ) pLayout - > itemAt ( 0 ) - > widget ( ) ;
QComboBox * pCombo = ( QComboBox * ) pLayout - > itemAt ( 1 ) - > widget ( ) ;
QString Program = pCombo - > currentText ( ) ;
int Index = pCombo - > findText ( Program ) ;
if ( Index ! = - 1 )
Program = pCombo - > itemData ( Index , Qt : : UserRole ) . toString ( ) ;
//if (!Program.isEmpty() && Program.left(1) != "<")
// m_Programs.insert(Program);
pItem - > setText ( 1 , ( pNot - > isChecked ( ) ? " NOT " : " " ) + pCombo - > currentText ( ) ) ;
pItem - > setData ( 1 , Qt : : UserRole , ( pNot - > isChecked ( ) ? " ! " : " " ) + Program ) ;
}
pItem - > setText ( 2 , pValue - > currentText ( ) ) ;
pItem - > setData ( 2 , Qt : : UserRole , pValue - > currentText ( ) ) ;
m_AdvancedChanged = true ;
OnOptChanged ( ) ;
}
ui . treeOptions - > setItemWidget ( pItem , 1 , NULL ) ;
ui . treeOptions - > setItemWidget ( pItem , 2 , NULL ) ;
}
//
2022-02-04 21:08:25 +00:00
// triggers
void COptionsWindow : : AddTriggerItem ( const QString & Value , ETriggerAction Type , const QString & Template )
2021-10-16 16:19:51 +01:00
{
2022-02-04 21:08:25 +00:00
QTreeWidgetItem * pItem = new QTreeWidgetItem ( ) ;
pItem - > setData ( 0 , Qt : : UserRole , Template . isEmpty ( ) ? Type : - 1 ) ;
switch ( Type )
{
case eOnStartCmd :
pItem - > setText ( 0 , tr ( " On Start " ) ) ;
pItem - > setText ( 1 , tr ( " Run Command " ) ) ;
break ;
case eOnStartSvc :
pItem - > setText ( 0 , tr ( " On Start " ) ) ;
pItem - > setText ( 1 , tr ( " Start Service " ) ) ;
break ;
case eAutoExec :
pItem - > setText ( 0 , tr ( " On Init " ) ) ;
pItem - > setText ( 1 , tr ( " Run Command " ) ) ;
break ;
2022-09-29 17:28:48 +01:00
case eRecoveryCheck :
pItem - > setText ( 0 , tr ( " On File Recovery " ) ) ;
pItem - > setText ( 1 , tr ( " Run Command " ) ) ;
break ;
2022-02-04 21:08:25 +00:00
case eDeleteCmd :
2022-09-29 17:28:48 +01:00
pItem - > setText ( 0 , tr ( " On Delete Content " ) ) ;
2022-02-04 21:08:25 +00:00
pItem - > setText ( 1 , tr ( " Run Command " ) ) ;
break ;
}
pItem - > setText ( 2 , Value ) ;
pItem - > setFlags ( pItem - > flags ( ) | Qt : : ItemIsEditable ) ;
ui . treeTriggers - > addTopLevelItem ( pItem ) ;
}
void COptionsWindow : : OnAddAutoRun ( )
{
QString Value = QInputDialog : : getText ( this , " Sandboxie-Plus " , tr ( " Please enter the command line to be executed " ) , QLineEdit : : Normal ) ;
if ( Value . isEmpty ( ) )
2021-10-16 16:19:51 +01:00
return ;
2022-02-04 21:08:25 +00:00
AddTriggerItem ( Value , eOnStartCmd ) ;
m_AdvancedChanged = true ;
OnOptChanged ( ) ;
}
void COptionsWindow : : OnAddAutoSvc ( )
{
QString Value = QInputDialog : : getText ( this , " Sandboxie-Plus " , tr ( " Please enter a service identifier " ) , QLineEdit : : Normal ) ;
if ( Value . isEmpty ( ) )
return ;
2021-10-16 16:19:51 +01:00
2022-02-04 21:08:25 +00:00
AddTriggerItem ( Value , eOnStartSvc ) ;
2021-10-16 16:19:51 +01:00
m_AdvancedChanged = true ;
2021-11-13 08:28:32 +00:00
OnOptChanged ( ) ;
2021-10-16 16:19:51 +01:00
}
2022-02-04 21:08:25 +00:00
void COptionsWindow : : OnAddAutoExec ( )
2021-10-16 16:19:51 +01:00
{
2022-02-04 21:08:25 +00:00
QString Value = QInputDialog : : getText ( this , " Sandboxie-Plus " , tr ( " Please enter the command line to be executed " ) , QLineEdit : : Normal ) ;
if ( Value . isEmpty ( ) )
return ;
2021-10-16 16:19:51 +01:00
2022-02-04 21:08:25 +00:00
AddTriggerItem ( Value , eAutoExec ) ;
m_AdvancedChanged = true ;
OnOptChanged ( ) ;
}
void COptionsWindow : : OnAddDeleteCmd ( )
{
QString Value = QInputDialog : : getText ( this , " Sandboxie-Plus " , tr ( " Please enter the command line to be executed " ) , QLineEdit : : Normal ) ;
if ( Value . isEmpty ( ) )
return ;
AddTriggerItem ( Value , eDeleteCmd ) ;
m_AdvancedChanged = true ;
OnOptChanged ( ) ;
}
2022-09-29 17:28:48 +01:00
void COptionsWindow : : OnAddRecoveryCheck ( )
{
QString Value = QInputDialog : : getText ( this , " Sandboxie-Plus " , tr ( " Please enter the command line to be executed " ) , QLineEdit : : Normal ) ;
if ( Value . isEmpty ( ) )
return ;
AddTriggerItem ( Value , eRecoveryCheck ) ;
m_AdvancedChanged = true ;
OnOptChanged ( ) ;
}
2022-02-04 21:08:25 +00:00
void COptionsWindow : : OnDelAuto ( )
{
DeleteAccessEntry ( ui . treeTriggers - > currentItem ( ) ) ;
2021-10-16 16:19:51 +01:00
m_AdvancedChanged = true ;
2021-11-13 08:28:32 +00:00
OnOptChanged ( ) ;
2021-10-16 16:19:51 +01:00
}
2022-02-04 21:08:25 +00:00
//
2021-10-16 16:19:51 +01:00
void COptionsWindow : : OnAddProcess ( )
{
2022-09-29 17:28:48 +01:00
QString Process = SelectProgram ( ) ;
2021-10-16 16:19:51 +01:00
if ( Process . isEmpty ( ) )
return ;
2022-09-29 17:28:48 +01:00
AddHiddenProcEntry ( Process ) ;
2021-10-16 16:19:51 +01:00
m_AdvancedChanged = true ;
2021-11-13 08:28:32 +00:00
OnOptChanged ( ) ;
2021-10-16 16:19:51 +01:00
}
void COptionsWindow : : OnDelProcess ( )
{
2022-09-29 17:28:48 +01:00
DeleteAccessEntry ( ui . treeHideProc - > currentItem ( ) ) ;
m_AdvancedChanged = true ;
OnOptChanged ( ) ;
}
void COptionsWindow : : OnAddHostProcess ( )
{
QString Process = QInputDialog : : getText ( this , " Sandboxie-Plus " , tr ( " Please enter a program file name " ) ) ;
if ( Process . isEmpty ( ) )
return ;
AddHostProcEntry ( Process ) ;
2021-10-16 16:19:51 +01:00
m_AdvancedChanged = true ;
2021-11-13 08:28:32 +00:00
OnOptChanged ( ) ;
2021-10-16 16:19:51 +01:00
}
2022-09-29 17:28:48 +01:00
void COptionsWindow : : OnDelHostProcess ( )
{
DeleteAccessEntry ( ui . treeHostProc - > currentItem ( ) ) ;
m_AdvancedChanged = true ;
OnOptChanged ( ) ;
}
void COptionsWindow : : ShowHiddenProcTmpl ( bool bUpdate )
{
if ( ui . chkShowHiddenProcTmpl - > isChecked ( ) )
{
foreach ( const QString & Template , m_pBox - > GetTemplates ( ) )
{
foreach ( const QString & Value , m_pBox - > GetTextListTmpl ( " HideHostProcess " , Template ) )
AddHiddenProcEntry ( Value , Template ) ;
}
}
else if ( bUpdate )
{
for ( int i = 0 ; i < ui . treeHideProc - > topLevelItemCount ( ) ; )
{
QTreeWidgetItem * pItem = ui . treeHideProc - > topLevelItem ( i ) ;
int Type = pItem - > data ( 0 , Qt : : UserRole ) . toInt ( ) ;
if ( Type = = - 1 ) {
delete pItem ;
continue ; // entry from template
}
i + + ;
}
}
}
void COptionsWindow : : ShowHostProcTmpl ( bool bUpdate )
{
if ( ui . chkShowHostProcTmpl - > isChecked ( ) )
{
foreach ( const QString & Template , m_pBox - > GetTemplates ( ) )
{
foreach ( const QString & Value , m_pBox - > GetTextListTmpl ( " DenyHostAccess " , Template ) ) {
StrPair NameVal = Split2 ( Value , " , " ) ;
AddHostProcEntry ( NameVal . first , NameVal . second . left ( 0 ) . toLower ( ) ! = " y " , Template ) ;
}
}
}
else if ( bUpdate )
{
for ( int i = 0 ; i < ui . treeHostProc - > topLevelItemCount ( ) ; )
{
QTreeWidgetItem * pItem = ui . treeHostProc - > topLevelItem ( i ) ;
int Type = pItem - > data ( 0 , Qt : : UserRole ) . toInt ( ) ;
if ( Type = = - 1 ) {
delete pItem ;
continue ; // entry from template
}
i + + ;
}
}
}
void COptionsWindow : : AddHiddenProcEntry ( const QString & Name , const QString & Template )
{
QTreeWidgetItem * pItem = new QTreeWidgetItem ( ) ;
pItem - > setText ( 0 , Name + ( Template . isEmpty ( ) ? " " : " ( " + Template + " ) " ) ) ;
pItem - > setData ( 0 , Qt : : UserRole , Template . isEmpty ( ) ? 0 : - 1 ) ;
ui . treeHideProc - > addTopLevelItem ( pItem ) ;
}
void COptionsWindow : : AddHostProcEntry ( const QString & Name , bool Value , const QString & Template )
{
QTreeWidgetItem * pItem = new QTreeWidgetItem ( ) ;
pItem - > setText ( 0 , Name + ( Template . isEmpty ( ) ? " " : " ( " + Template + " ) " ) ) ;
pItem - > setData ( 0 , Qt : : UserRole , Template . isEmpty ( ) ? 0 : - 1 ) ;
pItem - > setText ( 1 , Value ? tr ( " Deny " ) : tr ( " Allow " ) ) ;
pItem - > setData ( 1 , Qt : : UserRole , Value ) ;
ui . treeHostProc - > addTopLevelItem ( pItem ) ;
}
2021-10-16 16:19:51 +01:00
# include <wtypes.h>
# include <objsel.h>
void COptionsWindow : : OnAddUser ( )
{
QStringList Users ;
IDsObjectPicker * pObjectPicker = NULL ;
HRESULT hr = CoCreateInstance ( CLSID_DsObjectPicker , NULL , CLSCTX_INPROC_SERVER , IID_IDsObjectPicker , ( void * * ) & pObjectPicker ) ;
if ( FAILED ( hr ) )
return ;
DSOP_SCOPE_INIT_INFO ScopeInit ;
memset ( & ScopeInit , 0 , sizeof ( DSOP_SCOPE_INIT_INFO ) ) ;
ScopeInit . cbSize = sizeof ( DSOP_SCOPE_INIT_INFO ) ;
ScopeInit . flType = DSOP_SCOPE_TYPE_TARGET_COMPUTER | DSOP_SCOPE_TYPE_UPLEVEL_JOINED_DOMAIN | DSOP_SCOPE_TYPE_DOWNLEVEL_JOINED_DOMAIN ;
ScopeInit . flScope = DSOP_SCOPE_FLAG_STARTING_SCOPE | DSOP_SCOPE_FLAG_DEFAULT_FILTER_USERS | DSOP_SCOPE_FLAG_DEFAULT_FILTER_GROUPS ;
ScopeInit . FilterFlags . Uplevel . flBothModes = DSOP_FILTER_USERS | DSOP_FILTER_WELL_KNOWN_PRINCIPALS | DSOP_FILTER_BUILTIN_GROUPS
| DSOP_FILTER_UNIVERSAL_GROUPS_SE | DSOP_FILTER_GLOBAL_GROUPS_SE | DSOP_FILTER_DOMAIN_LOCAL_GROUPS_SE ;
ScopeInit . FilterFlags . flDownlevel = DSOP_DOWNLEVEL_FILTER_USERS | DSOP_DOWNLEVEL_FILTER_LOCAL_GROUPS | DSOP_DOWNLEVEL_FILTER_GLOBAL_GROUPS ;
DSOP_INIT_INFO InitInfo ;
memset ( & InitInfo , 0 , sizeof ( InitInfo ) ) ;
InitInfo . cbSize = sizeof ( InitInfo ) ;
InitInfo . pwzTargetComputer = NULL ;
InitInfo . cDsScopeInfos = 1 ;
InitInfo . aDsScopeInfos = & ScopeInit ;
InitInfo . flOptions = DSOP_FLAG_MULTISELECT ;
hr = pObjectPicker - > Initialize ( & InitInfo ) ;
if ( SUCCEEDED ( hr ) )
{
IDataObject * pDataObject = NULL ;
hr = pObjectPicker - > InvokeDialog ( ( HWND ) this - > winId ( ) , & pDataObject ) ;
if ( SUCCEEDED ( hr ) & & pDataObject )
{
FORMATETC formatEtc ;
formatEtc . cfFormat = ( CLIPFORMAT ) RegisterClipboardFormat ( CFSTR_DSOP_DS_SELECTION_LIST ) ;
formatEtc . ptd = NULL ;
formatEtc . dwAspect = DVASPECT_CONTENT ;
formatEtc . lindex = - 1 ;
formatEtc . tymed = TYMED_HGLOBAL ;
STGMEDIUM stgMedium ;
hr = pDataObject - > GetData ( & formatEtc , & stgMedium ) ;
if ( SUCCEEDED ( hr ) )
{
PDS_SELECTION_LIST pResults = ( PDS_SELECTION_LIST ) GlobalLock ( stgMedium . hGlobal ) ;
if ( pResults )
{
for ( ULONG i = 0 ; i < pResults - > cItems ; i + + )
Users . append ( QString : : fromWCharArray ( pResults - > aDsSelection [ i ] . pwzName ) ) ;
GlobalUnlock ( stgMedium . hGlobal ) ;
}
}
pDataObject - > Release ( ) ;
}
}
pObjectPicker - > Release ( ) ;
if ( Users . isEmpty ( ) )
return ;
ui . lstUsers - > addItems ( Users ) ;
m_AdvancedChanged = true ;
2021-11-13 08:28:32 +00:00
OnOptChanged ( ) ;
2021-10-16 16:19:51 +01:00
}
void COptionsWindow : : OnDelUser ( )
{
foreach ( QListWidgetItem * pItem , ui . lstUsers - > selectedItems ( ) )
delete pItem ;
}
void COptionsWindow : : CreateDebug ( )
{
QStringList DebugOptions = theConf - > ListKeys ( " DebugOptions " ) ;
if ( DebugOptions . isEmpty ( ) )
ui . tabsAdvanced - > removeTab ( ui . tabsAdvanced - > count ( ) - 1 ) ;
else
{
int RowCount = 0 ;
foreach ( const QString & DebugOption , DebugOptions )
{
QStringList ValueDescr = theConf - > GetString ( " DebugOptions/ " + DebugOption ) . split ( " | " ) ;
QString Description = ValueDescr . size ( ) > = 3 ? ValueDescr [ 2 ] : ValueDescr [ 0 ] ;
int Column = 0 ; // use - to add up to 10 indents
2022-08-09 17:19:46 +01:00
for ( ; Description [ 0 ] = = ' - ' & & Column < 10 ; Column + + ) Description . remove ( 0 , 1 ) ;
2021-10-16 16:19:51 +01:00
SDbgOpt DbgOption = { ValueDescr [ 0 ] , ValueDescr . size ( ) > = 2 ? ValueDescr [ 1 ] : " y " , false } ;
QString Info = DbgOption . Name + " = " + DbgOption . Value ;
QCheckBox * pCheck = new QCheckBox ( tr ( " %1 (%2) " ) . arg ( Description ) . arg ( Info ) ) ;
2021-12-26 09:19:31 +00:00
if ( ValueDescr . size ( ) > = 2 & & ValueDescr [ 1 ] = = " x " )
pCheck - > setDisabled ( true ) ;
2021-10-16 16:19:51 +01:00
//pCheck->setToolTip(Info);
ui . dbgLayout - > addWidget ( pCheck , RowCount + + , Column , 1 , 10 - Column ) ;
connect ( pCheck , SIGNAL ( clicked ( bool ) ) , this , SLOT ( OnDebugChanged ( ) ) ) ;
m_DebugOptions . insert ( pCheck , DbgOption ) ;
}
for ( int i = 0 ; i < 10 ; i + + )
ui . dbgLayout - > addItem ( new QSpacerItem ( 20 , 40 , QSizePolicy : : Minimum , QSizePolicy : : Expanding ) , RowCount , i ) ;
ui . dbgLayout - > addItem ( new QSpacerItem ( 40 , 20 , QSizePolicy : : Expanding , QSizePolicy : : Minimum ) , RowCount , 10 ) ;
}
}
void COptionsWindow : : OnDebugChanged ( )
{
QCheckBox * pCheck = qobject_cast < QCheckBox * > ( sender ( ) ) ;
m_DebugOptions [ pCheck ] . Changed = true ;
2021-11-13 08:28:32 +00:00
OnOptChanged ( ) ;
2021-10-16 16:19:51 +01:00
}
void COptionsWindow : : LoadDebug ( )
{
foreach ( QCheckBox * pCheck , m_DebugOptions . keys ( ) )
{
SDbgOpt & DbgOption = m_DebugOptions [ pCheck ] ;
DbgOption . Changed = false ;
ReadAdvancedCheck ( DbgOption . Name , pCheck , DbgOption . Value ) ;
}
}
void COptionsWindow : : SaveDebug ( )
{
foreach ( QCheckBox * pCheck , m_DebugOptions . keys ( ) )
{
SDbgOpt & DbgOption = m_DebugOptions [ pCheck ] ;
if ( ! DbgOption . Changed )
continue ;
WriteAdvancedCheck ( pCheck , DbgOption . Name , DbgOption . Value ) ;
DbgOption . Changed = false ;
}
2022-09-29 17:28:48 +01:00
}