From c6d4836737feff5a386a21117378b3f3b7d549d2 Mon Sep 17 00:00:00 2001 From: love-code-yeyixiao <188240888@qq.com> Date: Sun, 17 Mar 2024 11:14:03 +0800 Subject: [PATCH 1/3] Update Sandman --- SandboxiePlus/SandMan/Forms/OptionsWindow.ui | 391 +++++++++--------- SandboxiePlus/SandMan/SandMan.cpp | 7 +- .../SandMan/Windows/OptionsAdvanced.cpp | 9 +- 3 files changed, 211 insertions(+), 196 deletions(-) diff --git a/SandboxiePlus/SandMan/Forms/OptionsWindow.ui b/SandboxiePlus/SandMan/Forms/OptionsWindow.ui index 8d450811f7..633607399c 100644 --- a/SandboxiePlus/SandMan/Forms/OptionsWindow.ui +++ b/SandboxiePlus/SandMan/Forms/OptionsWindow.ui @@ -55,7 +55,7 @@ - 3 + 1 @@ -284,200 +284,203 @@ File Options - + - - - - - - 75 - true - true - - - - Disk/File access - - - - - - - Use volume serial numbers for drives, like: \drive\C~1234-ABCD - - - - - - - - 20 - 16777215 - - - - - - - - - - - Qt::Horizontal - - - - 40 - 0 - - - - - - - - Encrypt sandbox content - - - - - - - Auto delete content when last sandboxed process terminates - - - - - - - When <a href="sbie://docs/boxencryption">Box Encryption</a> is enabled the box’s root folder, including its registry hive, is stored in an encrypted disk image, using <a href="https://diskcryptor.org">Disk Cryptor's</a> AES-XTS implementation. - - - true - - - true - - - - - - - - 75 - true - true - - - - Box Delete options - - - - - - - Qt::Vertical - - - - 20 - 0 - - - - - - - - Allow elevated sandboxed applications to read the harddrive - - - - - - - Partially checked means prevent box removal but not content deletion. - - - Protect this sandbox from deletion or emptying - - - true - - - - - - - <a href="addon://ImDisk">Install ImDisk</a> driver to enable Ram Disk and Disk Image support. - - - - - - - Separate user folders - - - false - - - - - - - - 75 - true - true - - - - Box Structure - - - - - - - Store the sandbox content in a Ram Disk - - - - - - - Warn when an application opens a harddrive handle - - - - - - - - - - Set Password - - - - - - - Virtualization scheme - - - - - - - The box structure can only be changed when the sandbox is empty - - - - + + + + 75 + true + true + + + + Box Structure + + + + + + + The box structure can only be changed when the sandbox is empty + + + + + + + Virtualization scheme + + + + + + + + + + Separate user folders + + + false + + + + + + + Use volume serial numbers for drives, like: \drive\C~1234-ABCD + + + + + + + Store the sandbox content in a Ram Disk + + + + + + + Encrypt sandbox content + + + + + + + Set Password + + + + + + + When <a href="sbie://docs/boxencryption">Box Encryption</a> is enabled the box’s root folder, including its registry hive, is stored in an encrypted disk image, using <a href="https://diskcryptor.org">Disk Cryptor's</a> AES-XTS implementation. + + + true + + + true + + + + + + + <a href="addon://ImDisk">Install ImDisk</a> driver to enable Ram Disk and Disk Image support. + + + + + + + + 75 + true + true + + + + Box Delete options + + + + + + + Auto delete content when last sandboxed process terminates + + + + + + + Partially checked means prevent box removal but not content deletion. + + + Protect this sandbox from deletion or emptying + + + true + + + + + + + Lock the encrypted sandbox when all processes in the sandbox terminate. + + + + + + + + 75 + true + true + + + + Disk/File access + + + + + + + Allow elevated sandboxed applications to read the harddrive + + + + + + + + 20 + 16777215 + + + + + + + + + + + Warn when an application opens a harddrive handle + + + + + + + Qt::Vertical + + + + 20 + 52 + + + + + + + + Qt::Horizontal + + + + 410 + 13 + + + diff --git a/SandboxiePlus/SandMan/SandMan.cpp b/SandboxiePlus/SandMan/SandMan.cpp index 68e5980171..c1c0e0f49c 100644 --- a/SandboxiePlus/SandMan/SandMan.cpp +++ b/SandboxiePlus/SandMan/SandMan.cpp @@ -2283,7 +2283,12 @@ void CSandMan::OnBoxClosed(const CSandBoxPtr& pBox) AddAsyncOp(pProgress, true, tr("Executing OnBoxTerminate: %1").arg(Value2)); } } - + if (pBox->GetBool("LockWhenClose", false)) { + if (!pBox->GetMountRoot().isEmpty()) { + pBox->TerminateAll(); + pBox->ImBoxUnmount(); + } + } if (!pBox->GetBool("NeverDelete", false)) { if (pBox->GetBool("AutoDelete", false)) diff --git a/SandboxiePlus/SandMan/Windows/OptionsAdvanced.cpp b/SandboxiePlus/SandMan/Windows/OptionsAdvanced.cpp index 072c716e94..7700a7408b 100644 --- a/SandboxiePlus/SandMan/Windows/OptionsAdvanced.cpp +++ b/SandboxiePlus/SandMan/Windows/OptionsAdvanced.cpp @@ -106,6 +106,7 @@ void COptionsWindow::CreateAdvanced() connect(ui.chkLessConfidential, SIGNAL(clicked(bool)), this, SLOT(OnLessConfidentialChanged())); connect(ui.chkProtectWindow, SIGNAL(clicked(bool)), this, SLOT(OnProtectChanged())); connect(ui.chkBlockCapture, SIGNAL(clicked(bool)), this, SLOT(OnCaptureChanged())); + connect(ui.chkLockWhenClose, SIGNAL(clicked(bool)), this, SLOT(OnAdvancedChanged())); connect(ui.chkNotifyProtect, SIGNAL(clicked(bool)), this, SLOT(OnAdvancedChanged())); connect(ui.treeInjectDll, SIGNAL(itemChanged(QTreeWidgetItem *, int)), this, SLOT(OnToggleInjectDll(QTreeWidgetItem *, int))); @@ -265,7 +266,12 @@ void COptionsWindow::LoadAdvanced() ui.chkNotifyProtect->setChecked(m_pBox->GetBool("NotifyBoxProtected", false)); ui.chkProtectWindow->setChecked(m_pBox->GetBool("IsProtectScreen")); - ui.chkBlockCapture->setChecked(m_pBox->GetBool("IsBlockCapture")); + QString str = m_pBox->GetText("OpenWindowClass", ""); + ui.chkBlockCapture->setChecked(m_pBox->GetBool("IsBlockCapture")&& QString::compare(str, "*") != 0); + ui.chkBlockCapture->setCheckable(QString::compare(str, "*") != 0); + + ui.chkLockWhenClose->setChecked(m_pBox->GetBool("LockWhenClose", false)); + ui.chkLockWhenClose->setCheckable(m_pBox->GetBool("UseFileImage", false)); QStringList Users = m_pBox->GetText("Enabled").split(","); ui.lstUsers->clear(); @@ -471,6 +477,7 @@ void COptionsWindow::SaveAdvanced() WriteAdvancedCheck(ui.chkProtectWindow, "IsProtectScreen", "y", "n"); WriteAdvancedCheck(ui.chkBlockCapture, "IsBlockCapture", "y", "n"); + WriteAdvancedCheck(ui.chkLockWhenClose, "LockWhenClose", "y", "n"); QStringList Users; for (int i = 0; i < ui.lstUsers->count(); i++) From d49a0f579c8a4e251231954fbdca9078c7466244 Mon Sep 17 00:00:00 2001 From: love-code-yeyixiao <188240888@qq.com> Date: Sun, 17 Mar 2024 11:40:03 +0800 Subject: [PATCH 2/3] Only touch CI. --- SandboxiePlus/SandMan/SandMan.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/SandboxiePlus/SandMan/SandMan.cpp b/SandboxiePlus/SandMan/SandMan.cpp index c1c0e0f49c..07188c8fa1 100644 --- a/SandboxiePlus/SandMan/SandMan.cpp +++ b/SandboxiePlus/SandMan/SandMan.cpp @@ -2284,7 +2284,7 @@ void CSandMan::OnBoxClosed(const CSandBoxPtr& pBox) } } if (pBox->GetBool("LockWhenClose", false)) { - if (!pBox->GetMountRoot().isEmpty()) { + if (!pBox->GetMountRoot().isEmpty()){ pBox->TerminateAll(); pBox->ImBoxUnmount(); } From 673fc1552fd7949950733a0ef78a2b70b18f6b70 Mon Sep 17 00:00:00 2001 From: love-code-yeyixiao <188240888@qq.com> Date: Sun, 17 Mar 2024 14:30:06 +0800 Subject: [PATCH 3/3] Fix. --- SandboxiePlus/SandMan/Windows/OptionsAdvanced.cpp | 13 +++++++++++-- 1 file changed, 11 insertions(+), 2 deletions(-) diff --git a/SandboxiePlus/SandMan/Windows/OptionsAdvanced.cpp b/SandboxiePlus/SandMan/Windows/OptionsAdvanced.cpp index 7700a7408b..7938151097 100644 --- a/SandboxiePlus/SandMan/Windows/OptionsAdvanced.cpp +++ b/SandboxiePlus/SandMan/Windows/OptionsAdvanced.cpp @@ -272,6 +272,7 @@ void COptionsWindow::LoadAdvanced() ui.chkLockWhenClose->setChecked(m_pBox->GetBool("LockWhenClose", false)); ui.chkLockWhenClose->setCheckable(m_pBox->GetBool("UseFileImage", false)); + ui.chkLockWhenClose->setEnabled(m_pBox->GetBool("UseFileImage", false)); QStringList Users = m_pBox->GetText("Enabled").split(","); ui.lstUsers->clear(); @@ -1252,8 +1253,12 @@ void COptionsWindow::OnCaptureChanged() if (ui.chkBlockCapture->checkState()) { ui.chkProtectWindow->setChecked(FALSE); ui.chkProtectWindow->setCheckable(FALSE); - } else + ui.chkProtectWindow->setEnabled(FALSE); + } + else { ui.chkProtectWindow->setCheckable(TRUE); + ui.chkProtectWindow->setEnabled(TRUE); + } OnAdvancedChanged(); } @@ -1262,7 +1267,11 @@ void COptionsWindow::OnProtectChanged() if (ui.chkProtectWindow->checkState()) { ui.chkBlockCapture->setChecked(FALSE); ui.chkBlockCapture->setCheckable(FALSE); - } else + ui.chkBlockCapture->setEnabled(FALSE); + } + else { ui.chkBlockCapture->setCheckable(TRUE); + ui.chkBlockCapture->setEnabled(TRUE); + } OnAdvancedChanged(); }