spell fix
This commit is contained in:
parent
ea6b1ac2d7
commit
e9867019a5
|
@ -15,7 +15,7 @@ This project adheres to [Semantic Versioning](http://semver.org/).
|
||||||
|
|
||||||
### Added
|
### Added
|
||||||
- added run boxed command to the sandbox menu
|
- added run boxed command to the sandbox menu
|
||||||
- DefaultBox can now be replaced with an otehr sandbox [#2445](https://github.com/sandboxie-plus/Sandboxie/issues/2445)
|
- DefaultBox can now be replaced with an other sandbox [#2445](https://github.com/sandboxie-plus/Sandboxie/issues/2445)
|
||||||
|
|
||||||
### Fixed
|
### Fixed
|
||||||
- improved fix for [#2495](https://github.com/sandboxie-plus/Sandboxie/issues/2495)
|
- improved fix for [#2495](https://github.com/sandboxie-plus/Sandboxie/issues/2495)
|
||||||
|
|
|
@ -108,7 +108,7 @@ ALIGNED BOOL my_DuplicateHandle(
|
||||||
if ((! ok) && GetLastError() == ERROR_ACCESS_DENIED) {
|
if ((! ok) && GetLastError() == ERROR_ACCESS_DENIED) {
|
||||||
|
|
||||||
//
|
//
|
||||||
// the client process for the CryptSvc service is ocassionally
|
// the client process for the CryptSvc service is occasionally
|
||||||
// running under LocalSystem (typically during MSI installations).
|
// running under LocalSystem (typically during MSI installations).
|
||||||
// CryptSvc tries to duplicate an event handle and fails so
|
// CryptSvc tries to duplicate an event handle and fails so
|
||||||
// we fake successful operation.
|
// we fake successful operation.
|
||||||
|
|
|
@ -400,7 +400,7 @@ int DoLingerLeader(void)
|
||||||
process_count += 128;
|
process_count += 128;
|
||||||
|
|
||||||
ULONG* pids = HeapAlloc(
|
ULONG* pids = HeapAlloc(
|
||||||
GetProcessHeap(), HEAP_GENERATE_EXCEPTIONS, sizeof(ULONG) * (process_count + 1)); // allocate oen more for the -1 marker
|
GetProcessHeap(), HEAP_GENERATE_EXCEPTIONS, sizeof(ULONG) * (process_count + 1)); // allocate one more for the -1 marker
|
||||||
SbieApi_EnumProcessEx(NULL, FALSE, -1, pids, &process_count); // query pids
|
SbieApi_EnumProcessEx(NULL, FALSE, -1, pids, &process_count); // query pids
|
||||||
pids[process_count] = -1; // set the end marker
|
pids[process_count] = -1; // set the end marker
|
||||||
|
|
||||||
|
@ -451,7 +451,7 @@ int DoLingerLeader(void)
|
||||||
// (via forced mechanism or as a child of start.exe)
|
// (via forced mechanism or as a child of start.exe)
|
||||||
// and then don't terminate it as a linger
|
// and then don't terminate it as a linger
|
||||||
//
|
//
|
||||||
// (note that sevice processes running as local system
|
// (note that service processes running as local system
|
||||||
// are also children of start.exe, but in that case,
|
// are also children of start.exe, but in that case,
|
||||||
// is_local_system_sid would be TRUE and we would not
|
// is_local_system_sid would be TRUE and we would not
|
||||||
// reach this point.)
|
// reach this point.)
|
||||||
|
|
|
@ -246,7 +246,7 @@ void CBorderGuard::Refresh()
|
||||||
//
|
//
|
||||||
// window rect is same as last recorded window rect
|
// window rect is same as last recorded window rect
|
||||||
// but if we track title area for border then also
|
// but if we track title area for border then also
|
||||||
// check the cursor is stil in the title area
|
// check the cursor is still in the title area
|
||||||
//
|
//
|
||||||
|
|
||||||
refresh = FALSE;
|
refresh = FALSE;
|
||||||
|
|
|
@ -233,7 +233,7 @@ BOOL CDeleteDialog::OnInitDialog()
|
||||||
pButton->ShowWindow(SW_HIDE);
|
pButton->ShowWindow(SW_HIDE);
|
||||||
|
|
||||||
//
|
//
|
||||||
// hide buttons accoording to dialog mode
|
// hide buttons according to dialog mode
|
||||||
//
|
//
|
||||||
|
|
||||||
pCtl = GetDlgItem(IDCLOSE);
|
pCtl = GetDlgItem(IDCLOSE);
|
||||||
|
|
|
@ -1248,7 +1248,7 @@ void CFileListCtrl::OnContextMenu(CWnd *pWnd, CPoint pt)
|
||||||
MyEnsureVisible(index);
|
MyEnsureVisible(index);
|
||||||
|
|
||||||
//
|
//
|
||||||
// proces selection and display context menu
|
// process selection and display context menu
|
||||||
//
|
//
|
||||||
|
|
||||||
CMenu *pMenu = m_pContextMenu->GetSubMenu(0);
|
CMenu *pMenu = m_pContextMenu->GetSubMenu(0);
|
||||||
|
|
|
@ -503,7 +503,7 @@ static BOOL CALLBACK FindBestChildProc(HWND hwnd, LPARAM lParam)
|
||||||
// the smallest window that fits, in fact.
|
// the smallest window that fits, in fact.
|
||||||
//
|
//
|
||||||
// I've tested this on a lot of different apps, and it seems
|
// I've tested this on a lot of different apps, and it seems
|
||||||
// to work flawlessly - in fact, I havn't found a situation yet
|
// to work flawlessly - in fact, I haven't found a situation yet
|
||||||
// that this method doesn't work on.....we'll see!
|
// that this method doesn't work on.....we'll see!
|
||||||
//
|
//
|
||||||
// Inputs:
|
// Inputs:
|
||||||
|
|
|
@ -24,7 +24,7 @@
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
///////////////////////////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////////////////////////
|
||||||
// Usefull macros
|
// Useful macros
|
||||||
//
|
//
|
||||||
#define KEYDOWN(Key) ((GetKeyState(Key)&0x8000)!=0)
|
#define KEYDOWN(Key) ((GetKeyState(Key)&0x8000)!=0)
|
||||||
#define ON_WM_MOUSEOUT() \
|
#define ON_WM_MOUSEOUT() \
|
||||||
|
|
|
@ -250,7 +250,7 @@ BOOL CMyApp::InitInstance()
|
||||||
CBoxes::GetInstance().RefreshProcesses();
|
CBoxes::GetInstance().RefreshProcesses();
|
||||||
|
|
||||||
//
|
//
|
||||||
// setup autoplay cancelation
|
// setup autoplay cancellation
|
||||||
//
|
//
|
||||||
|
|
||||||
CAutoPlay::Install();
|
CAutoPlay::Install();
|
||||||
|
|
|
@ -56,7 +56,7 @@ GetWnd() method, which
|
||||||
returns a pointer to the CWnd-obect of the window, that has been
|
returns a pointer to the CWnd-obect of the window, that has been
|
||||||
created by the call to the Create() method. An implementation can
|
created by the call to the Create() method. An implementation can
|
||||||
provide the CWnd-object by using it as a property or by deriving
|
provide the CWnd-object by using it as a property or by deriving
|
||||||
from CWnd or a more specialiced class. This way has been choosen
|
from CWnd or a more specialised class. This way has been chosen
|
||||||
instead of deriving CPropPageFrame from CWnd, to allow derived class
|
instead of deriving CPropPageFrame from CWnd, to allow derived class
|
||||||
to derive from more specialized classes than CWnd
|
to derive from more specialized classes than CWnd
|
||||||
(i.e. CStatic, etc.). From the WM_PAINT-handler of your derived class
|
(i.e. CStatic, etc.). From the WM_PAINT-handler of your derived class
|
||||||
|
@ -211,7 +211,7 @@ protected:
|
||||||
passed to DrawMsg().
|
passed to DrawMsg().
|
||||||
|
|
||||||
This default implementation calls the CalcCaptionArea() method,
|
This default implementation calls the CalcCaptionArea() method,
|
||||||
substracts the returned rectangle from the client area and returns
|
subtracts the returned rectangle from the client area and returns
|
||||||
the result.
|
the result.
|
||||||
*/
|
*/
|
||||||
virtual CRect CalcMsgArea();
|
virtual CRect CalcMsgArea();
|
||||||
|
@ -275,7 +275,7 @@ protected:
|
||||||
// Implementation helpers
|
// Implementation helpers
|
||||||
protected:
|
protected:
|
||||||
/**
|
/**
|
||||||
If the m_hWnd property of the CWnd-object returend by GetWnd()
|
If the m_hWnd property of the CWnd-object returned by GetWnd()
|
||||||
specifies a valid window, this method will invalidate the specified
|
specifies a valid window, this method will invalidate the specified
|
||||||
rectangle, to schedule it for repaint, otherwise the method will
|
rectangle, to schedule it for repaint, otherwise the method will
|
||||||
return without doing anything.
|
return without doing anything.
|
||||||
|
|
|
@ -530,7 +530,7 @@ CString CTreePropSheet::SplitPageTreePath(CString &strRest)
|
||||||
else if (nSeperatorPos>0)
|
else if (nSeperatorPos>0)
|
||||||
{
|
{
|
||||||
// if there is an odd number of backslashes infront of the
|
// if there is an odd number of backslashes infront of the
|
||||||
// seperator, than do not interpret it as separator
|
// separator, than do not interpret it as separator
|
||||||
int nBackslashCount = 0;
|
int nBackslashCount = 0;
|
||||||
for (int nPos = nSeperatorPos-1; nPos >= 0 && strRest[nPos]==_T('\\'); --nPos, ++nBackslashCount);
|
for (int nPos = nSeperatorPos-1; nPos >= 0 && strRest[nPos]==_T('\\'); --nPos, ++nBackslashCount);
|
||||||
if (nBackslashCount%2 == 0)
|
if (nBackslashCount%2 == 0)
|
||||||
|
@ -933,7 +933,7 @@ BOOL CTreePropSheet::OnInitDialog()
|
||||||
width_for_checkbox_text = AlignButtonsToRight();
|
width_for_checkbox_text = AlignButtonsToRight();
|
||||||
}
|
}
|
||||||
|
|
||||||
// finally create tht tree control
|
// finally create the tree control
|
||||||
DWORD dwTreeStyle = WS_TABSTOP|WS_CHILD|WS_VISIBLE
|
DWORD dwTreeStyle = WS_TABSTOP|WS_CHILD|WS_VISIBLE
|
||||||
| TVS_SHOWSELALWAYS|TVS_TRACKSELECT|TVS_HASLINES|TVS_LINESATROOT|TVS_HASBUTTONS|TVS_SINGLEEXPAND;
|
| TVS_SHOWSELALWAYS|TVS_TRACKSELECT|TVS_HASLINES|TVS_LINESATROOT|TVS_HASBUTTONS|TVS_SINGLEEXPAND;
|
||||||
ULONG dwTreeExStyle = WS_EX_CLIENTEDGE|WS_EX_NOPARENTNOTIFY;
|
ULONG dwTreeExStyle = WS_EX_CLIENTEDGE|WS_EX_NOPARENTNOTIFY;
|
||||||
|
|
|
@ -74,7 +74,7 @@ Appearance
|
||||||
Directories
|
Directories
|
||||||
\endverbatim
|
\endverbatim
|
||||||
If you would like to use a double colon, which should not be
|
If you would like to use a double colon, which should not be
|
||||||
interpreted as a path seperator, prefix it with a backslash ("\\::").
|
interpreted as a path separator, prefix it with a backslash ("\\::").
|
||||||
|
|
||||||
To disable tree view mode and use the standard tabbed mode, call
|
To disable tree view mode and use the standard tabbed mode, call
|
||||||
the SetTreeViewMode() method. This also allows you, to enable page
|
the SetTreeViewMode() method. This also allows you, to enable page
|
||||||
|
@ -197,7 +197,7 @@ public:
|
||||||
Resource identifier for the bitmap, that contains the default
|
Resource identifier for the bitmap, that contains the default
|
||||||
images. The resource should contain exactly to images.
|
images. The resource should contain exactly to images.
|
||||||
@param cx
|
@param cx
|
||||||
Width of a singe image in pixels.
|
Width of a single image in pixels.
|
||||||
@param crMask
|
@param crMask
|
||||||
Color that should be interpreted as transparent.
|
Color that should be interpreted as transparent.
|
||||||
|
|
||||||
|
@ -338,13 +338,13 @@ protected:
|
||||||
int AlignButtonsToRight();
|
int AlignButtonsToRight();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Moves all childs by the specified amount of pixels.
|
Moves all child's by the specified amount of pixels.
|
||||||
|
|
||||||
@param nDx
|
@param nDx
|
||||||
Pixels to move the childs in horizontal direction (can be
|
Pixels to move the child's in horizontal direction (can be
|
||||||
negative).
|
negative).
|
||||||
@param nDy
|
@param nDy
|
||||||
Pixels to move the childs in vertical direction (can be
|
Pixels to move the child's in vertical direction (can be
|
||||||
negative).
|
negative).
|
||||||
*/
|
*/
|
||||||
void MoveChildWindows(int nDx, int nDy);
|
void MoveChildWindows(int nDx, int nDy);
|
||||||
|
@ -377,7 +377,7 @@ protected:
|
||||||
CString SplitPageTreePath(CString &strRest);
|
CString SplitPageTreePath(CString &strRest);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Tries to deactivate the current page, and hides it if successfull,
|
Tries to deactivate the current page, and hides it if successful,
|
||||||
so that an empty page becomes visible.
|
so that an empty page becomes visible.
|
||||||
|
|
||||||
@return
|
@return
|
||||||
|
|
|
@ -1136,8 +1136,8 @@ int Program_Start(void)
|
||||||
//
|
//
|
||||||
|
|
||||||
//
|
//
|
||||||
// note: this workaround does nto work the path is still blocked
|
// note: this workaround does not work the path is still blocked
|
||||||
// and we still get problems, hence now the deriver has an excemption for start.exe
|
// and we still get problems, hence now the derive has an exemption for start.exe
|
||||||
//
|
//
|
||||||
|
|
||||||
//LoadLibrary(L"apphelp.dll");
|
//LoadLibrary(L"apphelp.dll");
|
||||||
|
@ -1284,7 +1284,7 @@ int Program_Start(void)
|
||||||
SetLastError(err);
|
SetLastError(err);
|
||||||
Show_Error(errmsg);
|
Show_Error(errmsg);
|
||||||
|
|
||||||
keep_alive = FALSE; // disable keep alive when the process cant be started in the first place
|
keep_alive = FALSE; // disable keep alive when the process can't be started in the first place
|
||||||
|
|
||||||
return EXIT_FAILURE;
|
return EXIT_FAILURE;
|
||||||
|
|
||||||
|
@ -1802,8 +1802,8 @@ int __stdcall WinMainCRTStartup(
|
||||||
rc = Program_Start();
|
rc = Program_Start();
|
||||||
|
|
||||||
// keep the process running unless it gracefully terminates
|
// keep the process running unless it gracefully terminates
|
||||||
if (keep_alive && rc != EXIT_SUCCESS && retry++ < 5) { // after to many initialization failures abbort
|
if (keep_alive && rc != EXIT_SUCCESS && retry++ < 5) { // after to many initialization failures abort
|
||||||
if (::GetTickCount() - start >= 5000) // if the process run for less than 5 seconts considder it a failure to initialize
|
if (::GetTickCount() - start >= 5000) // if the process run for less than 5 seconds consider it a failure to initialize
|
||||||
retry = 0; // reset failure counter on success ful start
|
retry = 0; // reset failure counter on success ful start
|
||||||
goto run_program;
|
goto run_program;
|
||||||
}
|
}
|
||||||
|
|
|
@ -547,7 +547,7 @@ typedef NTSTATUS (*P_NtLoadKey3)(
|
||||||
IN ULONG LoadArgumentCount,
|
IN ULONG LoadArgumentCount,
|
||||||
IN ACCESS_MASK DesiredAccess,
|
IN ACCESS_MASK DesiredAccess,
|
||||||
IN HANDLE KeyHandle,
|
IN HANDLE KeyHandle,
|
||||||
IN ULONG Unkown);
|
IN ULONG Unknown);
|
||||||
|
|
||||||
typedef NTSTATUS (*P_NtLoadKeyEx)(
|
typedef NTSTATUS (*P_NtLoadKeyEx)(
|
||||||
IN POBJECT_ATTRIBUTES TargetKey,
|
IN POBJECT_ATTRIBUTES TargetKey,
|
||||||
|
|
|
@ -305,7 +305,7 @@ _FX ULONG Pattern_Level(PATTERN *pat)
|
||||||
|
|
||||||
_FX USHORT Pattern_Wildcards(PATTERN *pat)
|
_FX USHORT Pattern_Wildcards(PATTERN *pat)
|
||||||
{
|
{
|
||||||
if (pat->info.num_cons == 0) return 0; // empty patters dont have wildcards
|
if (pat->info.num_cons == 0) return 0; // empty patterns don't have wildcards
|
||||||
return pat->info.num_cons - 1; // between every constant part there is a wildcard
|
return pat->info.num_cons - 1; // between every constant part there is a wildcard
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -644,7 +644,7 @@ _FX int Pattern_MatchPathList(
|
||||||
|
|
||||||
ULONG cur_level = Pattern_Level(pat);
|
ULONG cur_level = Pattern_Level(pat);
|
||||||
if (cur_level > level)
|
if (cur_level > level)
|
||||||
goto next; // no point testing patters with a to weak level
|
goto next; // no point testing patterns with a to weak level
|
||||||
|
|
||||||
BOOLEAN cur_exact = Pattern_Exact(pat);
|
BOOLEAN cur_exact = Pattern_Exact(pat);
|
||||||
if (!cur_exact && exact)
|
if (!cur_exact && exact)
|
||||||
|
@ -660,8 +660,8 @@ _FX int Pattern_MatchPathList(
|
||||||
wildc = cur_wildc;
|
wildc = cur_wildc;
|
||||||
if (patsrc) *patsrc = Pattern_Source(pat);
|
if (patsrc) *patsrc = Pattern_Source(pat);
|
||||||
|
|
||||||
// we need to test all entries to find the best match, so we dont break here
|
// we need to test all entries to find the best match, so we don't break here
|
||||||
// unless we found an exact match, than there cant be a batter one
|
// unless we found an exact match, than there can't be a batter one
|
||||||
if (exact)
|
if (exact)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
|
@ -77,7 +77,7 @@ ULONG Pattern_Level(PATTERN *pat);
|
||||||
USHORT Pattern_Wildcards(PATTERN *pat);
|
USHORT Pattern_Wildcards(PATTERN *pat);
|
||||||
|
|
||||||
//
|
//
|
||||||
// Pattern_Exact: returns true if the patter has no wildcard at the end
|
// Pattern_Exact: returns true if the pattern has no wildcard at the end
|
||||||
//
|
//
|
||||||
|
|
||||||
BOOLEAN Pattern_Exact(PATTERN *pat);
|
BOOLEAN Pattern_Exact(PATTERN *pat);
|
||||||
|
|
|
@ -657,7 +657,7 @@ _FX ULONG AdvApi_GetEffectiveRightsFromAclW(
|
||||||
PACL pacl, void *pTrustee, PACCESS_MASK pAccessRights)
|
PACL pacl, void *pTrustee, PACCESS_MASK pAccessRights)
|
||||||
{
|
{
|
||||||
//
|
//
|
||||||
// some programs (e.g HP printer software intaller) use
|
// some programs (e.g HP printer software installer) use
|
||||||
// GetEffectiveRightsFromAcl to confirm that an object (like a
|
// GetEffectiveRightsFromAcl to confirm that an object (like a
|
||||||
// registry key) was created with appropriate rights, so fake
|
// registry key) was created with appropriate rights, so fake
|
||||||
// a return value that always shows full access
|
// a return value that always shows full access
|
||||||
|
|
|
@ -466,7 +466,7 @@ _FX BOOLEAN EnableMsiDebugging(void)
|
||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
// DisableEdgeBoost
|
// DisableEdgeBoost
|
||||||
//
|
//
|
||||||
// Disable esge startup boost
|
// Disable edge startup boost
|
||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -61,7 +61,7 @@ typedef struct _VECTOR_TABLE {
|
||||||
int maxEntries;
|
int maxEntries;
|
||||||
} VECTOR_TABLE;
|
} VECTOR_TABLE;
|
||||||
|
|
||||||
#define VTABLE_SIZE 0x4000 //16k enough for 2048 8 byte entrys
|
#define VTABLE_SIZE 0x4000 //16k enough for 2048 8 byte entries
|
||||||
|
|
||||||
#endif _WIN64
|
#endif _WIN64
|
||||||
extern ULONG Dll_Windows;
|
extern ULONG Dll_Windows;
|
||||||
|
@ -748,7 +748,7 @@ typedef struct _DETOUR_TRAMPOLINE
|
||||||
// 3 instructions to form immediate
|
// 3 instructions to form immediate
|
||||||
// br or brl
|
// br or brl
|
||||||
//
|
//
|
||||||
// A theoretical maximum for rbCode is thefore 4*4*6 + 16 = 112 (another 16 for jmp to pbRemain).
|
// A theoretical maximum for rbCode is therefore 4*4*6 + 16 = 112 (another 16 for jmp to pbRemain).
|
||||||
//
|
//
|
||||||
// With literals, the maximum expansion is 5, including the literals: 4*4*5 + 16 = 96.
|
// With literals, the maximum expansion is 5, including the literals: 4*4*5 + 16 = 96.
|
||||||
//
|
//
|
||||||
|
@ -1047,7 +1047,7 @@ void* SbieDll_Hook_arm(
|
||||||
|
|
||||||
//
|
//
|
||||||
// if that fails just start at the exact offset and try again
|
// if that fails just start at the exact offset and try again
|
||||||
// without the hot patch area which we dont use anyways
|
// without the hot patch area which we don't use anyways
|
||||||
//
|
//
|
||||||
|
|
||||||
RegionBase = &func[0];
|
RegionBase = &func[0];
|
||||||
|
|
|
@ -379,7 +379,7 @@ _FX void Dll_InitInjected(void)
|
||||||
// // instead of using a separate namespace
|
// // instead of using a separate namespace
|
||||||
// // just replace all \ with _ and use it as a sufix rather then an actual path
|
// // just replace all \ with _ and use it as a sufix rather then an actual path
|
||||||
// // similarly a its done for named pipes already
|
// // similarly a its done for named pipes already
|
||||||
// // this approche can help to reduce teh footprint when running in portable mode
|
// // this approach can help to reduce the footprint when running in portable mode
|
||||||
// // alternatively we could create volatile entries under AppContainerNamedObjects
|
// // alternatively we could create volatile entries under AppContainerNamedObjects
|
||||||
// //
|
// //
|
||||||
//
|
//
|
||||||
|
@ -453,7 +453,7 @@ _FX void Dll_InitInjected(void)
|
||||||
if (ok) {
|
if (ok) {
|
||||||
|
|
||||||
//
|
//
|
||||||
// ipc must be initialized before anythign else to make delete v2 work
|
// ipc must be initialized before anything else to make delete v2 work
|
||||||
//
|
//
|
||||||
|
|
||||||
ok = Ipc_Init();
|
ok = Ipc_Init();
|
||||||
|
@ -783,7 +783,7 @@ _FX ULONG_PTR Dll_Ordinal1(
|
||||||
//
|
//
|
||||||
// on ARM64 we hook LdrLoadDll instead, using the prototype for
|
// on ARM64 we hook LdrLoadDll instead, using the prototype for
|
||||||
// RtlFindActCtx is fine though as arguments 1-8 are passed in registers
|
// RtlFindActCtx is fine though as arguments 1-8 are passed in registers
|
||||||
// so if we set x4 or not does not mater in the least
|
// so if we set x4 or not does not matter in the least
|
||||||
//
|
//
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -862,7 +862,7 @@ _FX ULONG_PTR Dll_Ordinal1(
|
||||||
Dll_InitInjected(); // install required hooks
|
Dll_InitInjected(); // install required hooks
|
||||||
|
|
||||||
//
|
//
|
||||||
// notify RPCSS that a new proces was created in the current sandbox
|
// notify RPCSS that a new process was created in the current sandbox
|
||||||
//
|
//
|
||||||
|
|
||||||
if (Dll_ImageType != DLL_IMAGE_SANDBOXIE_RPCSS) {
|
if (Dll_ImageType != DLL_IMAGE_SANDBOXIE_RPCSS) {
|
||||||
|
@ -903,7 +903,7 @@ _FX ULONG_PTR Dll_Ordinal1(
|
||||||
}
|
}
|
||||||
|
|
||||||
//
|
//
|
||||||
// explorer needs sandboxed COM show warnign and terminate when COM is not sandboxies
|
// explorer needs sandboxed COM show warning and terminate when COM is not sandboxies
|
||||||
//
|
//
|
||||||
|
|
||||||
if (Dll_ImageType == DLL_IMAGE_SHELL_EXPLORER && SbieDll_IsOpenCOM()) {
|
if (Dll_ImageType == DLL_IMAGE_SHELL_EXPLORER && SbieDll_IsOpenCOM()) {
|
||||||
|
|
|
@ -327,7 +327,7 @@ ALIGNED WCHAR *Dll_GetTlsNameBuffer(THREAD_DATA *data, ULONG which, ULONG size)
|
||||||
|
|
||||||
//
|
//
|
||||||
// since we have more places where we may need a name buffer now
|
// since we have more places where we may need a name buffer now
|
||||||
// instead of sticking to "which" and doing our best to not reuse a particualr buffer thats still needed
|
// instead of sticking to "which" and doing our best to not reuse a particular buffer that's still needed
|
||||||
// we just increment a counter and take a new buffer reach time we request one
|
// we just increment a counter and take a new buffer reach time we request one
|
||||||
//
|
//
|
||||||
|
|
||||||
|
@ -374,7 +374,7 @@ ALIGNED WCHAR *Dll_GetTlsNameBuffer(THREAD_DATA *data, ULONG which, ULONG size)
|
||||||
|
|
||||||
//
|
//
|
||||||
// debug checks: the name buffer is allocated at least 64 bytes
|
// debug checks: the name buffer is allocated at least 64 bytes
|
||||||
// more than needed. fill these with 0xCC, andd check that later
|
// more than needed. fill these with 0xCC, and check that later
|
||||||
//
|
//
|
||||||
|
|
||||||
#ifdef DEBUG_MEMORY
|
#ifdef DEBUG_MEMORY
|
||||||
|
@ -432,7 +432,7 @@ _FX void Dll_PopTlsNameBuffer(THREAD_DATA *data)
|
||||||
|
|
||||||
//
|
//
|
||||||
// debug checks: the name buffer is allocated at least 64 bytes
|
// debug checks: the name buffer is allocated at least 64 bytes
|
||||||
// more than needed. fill these with 0xCC, andd check that later
|
// more than needed. fill these with 0xCC, and check that later
|
||||||
//
|
//
|
||||||
|
|
||||||
#ifdef DEBUG_MEMORY
|
#ifdef DEBUG_MEMORY
|
||||||
|
|
|
@ -516,7 +516,7 @@ _FX ULONG SbieDll_MatchPath2(WCHAR path_code, const WCHAR *path, BOOLEAN bCheckO
|
||||||
|
|
||||||
if (Pattern_MatchPathListEx(path_lwr, path_len, normal_list, &level, &match_len, &exact, &wildc, NULL)) { //patsrc)) {
|
if (Pattern_MatchPathListEx(path_lwr, path_len, normal_list, &level, &match_len, &exact, &wildc, NULL)) { //patsrc)) {
|
||||||
mp_flags = 0;
|
mp_flags = 0;
|
||||||
// dont goto finish as open can overwrite this
|
// don't goto finish as open can overwrite this
|
||||||
}
|
}
|
||||||
|
|
||||||
//
|
//
|
||||||
|
|
|
@ -3130,7 +3130,7 @@ ReparseLoop:
|
||||||
//
|
//
|
||||||
// firefox starting with version 106 opens plugin exe's with GENERIC_WRITE
|
// firefox starting with version 106 opens plugin exe's with GENERIC_WRITE
|
||||||
// to mitigate this issue we strip this flag when we detect that it tries to
|
// to mitigate this issue we strip this flag when we detect that it tries to
|
||||||
// do that with an exe that exists outside teh sandbox
|
// do that with an exe that exists outside the sandbox
|
||||||
//
|
//
|
||||||
|
|
||||||
if (Dll_ImageType == DLL_IMAGE_MOZILLA_FIREFOX && (DesiredAccess & GENERIC_WRITE)) {
|
if (Dll_ImageType == DLL_IMAGE_MOZILLA_FIREFOX && (DesiredAccess & GENERIC_WRITE)) {
|
||||||
|
@ -4042,7 +4042,7 @@ _FX BOOLEAN File_CheckDeletedParent(WCHAR *CopyPath)
|
||||||
}
|
}
|
||||||
|
|
||||||
//
|
//
|
||||||
// If we have snapshots check thair status, if we have a entry in the most recent snapshot
|
// If we have snapshots check their status, if we have a entry in the most recent snapshot
|
||||||
// than older delete markings are not relevant
|
// than older delete markings are not relevant
|
||||||
//
|
//
|
||||||
|
|
||||||
|
@ -5047,7 +5047,7 @@ _FX NTSTATUS File_NtQueryFullAttributesFileImpl(
|
||||||
File_CreateBoxedPath(OriginalPath ? OriginalPath : TruePath);
|
File_CreateBoxedPath(OriginalPath ? OriginalPath : TruePath);
|
||||||
}
|
}
|
||||||
else if (OriginalPath) {
|
else if (OriginalPath) {
|
||||||
; // try TruePath which points by now to teh snapshot location
|
; // try TruePath which points by now to the snapshot location
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
|
||||||
|
@ -6324,8 +6324,8 @@ _FX LONG File_RenameOpenFile(
|
||||||
BOOLEAN replace_if_exists)
|
BOOLEAN replace_if_exists)
|
||||||
{
|
{
|
||||||
//
|
//
|
||||||
// in compartment mode we dont need driver assistance we can do things ourselvs
|
// in compartment mode we don't need driver assistance we can do things ourselves
|
||||||
// this code is a port of the same routine in teh driver
|
// this code is a port of the same routine in the driver
|
||||||
//
|
//
|
||||||
|
|
||||||
NTSTATUS status;
|
NTSTATUS status;
|
||||||
|
@ -6955,7 +6955,7 @@ after_rename:
|
||||||
else {
|
else {
|
||||||
|
|
||||||
//
|
//
|
||||||
// if it does nto exist check if it was a directory, it may be a boxed directroy
|
// if it does not exist check if it was a directory, it may be a boxed directory
|
||||||
// which is a relocation target in which case we will need to update the relocation data
|
// which is a relocation target in which case we will need to update the relocation data
|
||||||
//
|
//
|
||||||
|
|
||||||
|
|
|
@ -27,7 +27,7 @@
|
||||||
|
|
||||||
#define FILE_PATH_FILE_NAME L"FilePaths.dat"
|
#define FILE_PATH_FILE_NAME L"FilePaths.dat"
|
||||||
|
|
||||||
// path flages, saved to file
|
// path flags, saved to file
|
||||||
#define FILE_DELETED_FLAG 0x0001
|
#define FILE_DELETED_FLAG 0x0001
|
||||||
#define FILE_RELOCATION_FLAG 0x0002
|
#define FILE_RELOCATION_FLAG 0x0002
|
||||||
|
|
||||||
|
@ -564,7 +564,7 @@ _FX VOID File_RefreshPathTree()
|
||||||
if (WaitForSingleObject(File_BoxRootWatcher, 0) == WAIT_OBJECT_0) {
|
if (WaitForSingleObject(File_BoxRootWatcher, 0) == WAIT_OBJECT_0) {
|
||||||
|
|
||||||
//
|
//
|
||||||
// somethign changed, reload the path tree
|
// something changed, reload the path tree
|
||||||
//
|
//
|
||||||
|
|
||||||
File_LoadPathTree();
|
File_LoadPathTree();
|
||||||
|
|
|
@ -44,7 +44,7 @@ typedef struct _FILE_MERGE_CACHE_FILE {
|
||||||
typedef struct _FILE_MERGE_FILE {
|
typedef struct _FILE_MERGE_FILE {
|
||||||
|
|
||||||
HANDLE handle;
|
HANDLE handle;
|
||||||
FILE_SNAPSHOT* shapshot;
|
FILE_SNAPSHOT* snapshot;
|
||||||
FILE_ID_BOTH_DIR_INFORMATION *info;
|
FILE_ID_BOTH_DIR_INFORMATION *info;
|
||||||
ULONG info_len;
|
ULONG info_len;
|
||||||
WCHAR *name;
|
WCHAR *name;
|
||||||
|
@ -774,10 +774,10 @@ _FX NTSTATUS File_OpenForMerge(
|
||||||
merge->files[merge->files_count].handle = NULL;
|
merge->files[merge->files_count].handle = NULL;
|
||||||
|
|
||||||
TruePathDeleted = TRUE;
|
TruePathDeleted = TRUE;
|
||||||
break; // dont look any further
|
break; // don't look any further
|
||||||
}
|
}
|
||||||
|
|
||||||
merge->files[merge->files_count].shapshot = Cur_Snapshot;
|
merge->files[merge->files_count].snapshot = Cur_Snapshot;
|
||||||
|
|
||||||
//
|
//
|
||||||
// copy file passed all checks; indicate it is ready for use
|
// copy file passed all checks; indicate it is ready for use
|
||||||
|
@ -793,7 +793,7 @@ _FX NTSTATUS File_OpenForMerge(
|
||||||
|
|
||||||
//
|
//
|
||||||
// check if we have a relocation and update CopyPath for the next snapshot accordingly
|
// check if we have a relocation and update CopyPath for the next snapshot accordingly
|
||||||
// since we dont need opypath anyware anymore we can alter it
|
// since we don't need opypath anyware anymore we can alter it
|
||||||
//
|
//
|
||||||
|
|
||||||
if (File_Delete_v2) {
|
if (File_Delete_v2) {
|
||||||
|
@ -837,7 +837,7 @@ _FX NTSTATUS File_OpenForMerge(
|
||||||
// and can let the system work directly on the true file
|
// and can let the system work directly on the true file
|
||||||
//
|
//
|
||||||
|
|
||||||
if ((TruePathFlags & FILE_CHILDREN_DELETED_FLAG) == 0) // we ned to do full merge if children ar marked deleted
|
if ((TruePathFlags & FILE_CHILDREN_DELETED_FLAG) == 0) // we need to do full merge if children ar marked deleted
|
||||||
if (merge->files_count == 0) {
|
if (merge->files_count == 0) {
|
||||||
|
|
||||||
status = STATUS_BAD_INITIAL_PC;
|
status = STATUS_BAD_INITIAL_PC;
|
||||||
|
@ -915,7 +915,7 @@ _FX NTSTATUS File_OpenForMerge(
|
||||||
//
|
//
|
||||||
// if rule specificity is enabled we may not have access to this true path
|
// if rule specificity is enabled we may not have access to this true path
|
||||||
// but still have access to some sub paths, in this case instead of listing the
|
// but still have access to some sub paths, in this case instead of listing the
|
||||||
// true directory we parse the rule list and construst a cached dummy directory
|
// true directory we parse the rule list and construct a cached dummy directory
|
||||||
//
|
//
|
||||||
|
|
||||||
if (use_rule_specificity && File_MergeDummy(TruePath, merge->true_ptr, &merge->file_mask) == STATUS_SUCCESS) {
|
if (use_rule_specificity && File_MergeDummy(TruePath, merge->true_ptr, &merge->file_mask) == STATUS_SUCCESS) {
|
||||||
|
@ -1733,10 +1733,10 @@ _FX NTSTATUS File_GetMergedInformation(
|
||||||
*ptr = L'\0';
|
*ptr = L'\0';
|
||||||
|
|
||||||
//
|
//
|
||||||
// chekc if the file is listed as deleted
|
// check if the file is listed as deleted
|
||||||
//
|
//
|
||||||
|
|
||||||
if (File_IsDeletedEx(TruePath2, CopyPath2, best->shapshot))
|
if (File_IsDeletedEx(TruePath2, CopyPath2, best->snapshot))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
} //else // is in copy path - nothing to do
|
} //else // is in copy path - nothing to do
|
||||||
|
@ -2289,7 +2289,7 @@ _FX NTSTATUS File_NtCloseImpl(HANDLE FileHandle)
|
||||||
}
|
}
|
||||||
|
|
||||||
//
|
//
|
||||||
// preapre delete disposition if set
|
// prepare delete disposition if set
|
||||||
//
|
//
|
||||||
|
|
||||||
if (DeleteOnClose) {
|
if (DeleteOnClose) {
|
||||||
|
@ -3242,7 +3242,7 @@ _FX NTSTATUS File_SetReparsePoint(
|
||||||
//TargetPath = Dll_Alloc((wcslen(CopyPath) + 4) * sizeof(WCHAR));
|
//TargetPath = Dll_Alloc((wcslen(CopyPath) + 4) * sizeof(WCHAR));
|
||||||
//wcscpy(TargetPath, CopyPath);
|
//wcscpy(TargetPath, CopyPath);
|
||||||
|
|
||||||
WCHAR* OldPrintNameBuffer = PrintNameBuffer; // we dont need to change the display name
|
WCHAR* OldPrintNameBuffer = PrintNameBuffer; // we don't need to change the display name
|
||||||
|
|
||||||
SubstituteNameLength = wcslen(CopyPath) * sizeof(WCHAR);
|
SubstituteNameLength = wcslen(CopyPath) * sizeof(WCHAR);
|
||||||
|
|
||||||
|
|
|
@ -79,9 +79,9 @@ static void File_InitSnapshots(void);
|
||||||
_FX WCHAR File_Scramble_Char(WCHAR wValue, int Key, BOOLEAN scram)
|
_FX WCHAR File_Scramble_Char(WCHAR wValue, int Key, BOOLEAN scram)
|
||||||
{
|
{
|
||||||
//
|
//
|
||||||
// This function allows to scramble file name charakters properly,
|
// This function allows to scramble file name characters properly,
|
||||||
// i.e. no invalid cahacters can result fron this operation.
|
// i.e. no invalid characters can result from this operation.
|
||||||
// It does not scramble invalid charakters like: " * / : < > ? \ |
|
// It does not scramble invalid characters like: " * / : < > ? \ |
|
||||||
// And it does not scramble ~
|
// And it does not scramble ~
|
||||||
// The entropy of the scrambler is 25,5bit (i.e. 52 million values)
|
// The entropy of the scrambler is 25,5bit (i.e. 52 million values)
|
||||||
//
|
//
|
||||||
|
@ -275,7 +275,7 @@ _FX ULONG File_GetPathFlagsEx(const WCHAR *TruePath, const WCHAR *CopyPath, WCHA
|
||||||
EnterCriticalSection(File_PathRoot_CritSec);
|
EnterCriticalSection(File_PathRoot_CritSec);
|
||||||
|
|
||||||
//
|
//
|
||||||
// check true path relocation and deleteion for the active state
|
// check true path relocation and deletion for the active state
|
||||||
//
|
//
|
||||||
|
|
||||||
Flags = File_GetPathFlags_internal(&File_PathRoot, TruePath, &Relocation, TRUE); // this requires a name buffer
|
Flags = File_GetPathFlags_internal(&File_PathRoot, TruePath, &Relocation, TRUE); // this requires a name buffer
|
||||||
|
@ -304,7 +304,7 @@ _FX ULONG File_GetPathFlagsEx(const WCHAR *TruePath, const WCHAR *CopyPath, WCHA
|
||||||
//
|
//
|
||||||
// we need a few helper buffers here, to make it efficient we will exploit
|
// we need a few helper buffers here, to make it efficient we will exploit
|
||||||
// an implementation artefact of the TlsNameBuffer mechanism, namely
|
// an implementation artefact of the TlsNameBuffer mechanism, namely
|
||||||
// the property that after a pop the buffers remain valid untill the next push
|
// the property that after a pop the buffers remain valid until the next push
|
||||||
//
|
//
|
||||||
// so we can pop out of the current frame request a buffer of the required size
|
// so we can pop out of the current frame request a buffer of the required size
|
||||||
// and still read from the buffer that was filled in the previosue frame
|
// and still read from the buffer that was filled in the previosue frame
|
||||||
|
@ -369,7 +369,7 @@ _FX ULONG File_GetPathFlagsEx(const WCHAR *TruePath, const WCHAR *CopyPath, WCHA
|
||||||
if (File_Delete_v2)
|
if (File_Delete_v2)
|
||||||
{
|
{
|
||||||
//
|
//
|
||||||
// check true path relocation and deleteion for the current snapshot
|
// check true path relocation and deletion for the current snapshot
|
||||||
//
|
//
|
||||||
|
|
||||||
TmplRelocation = NULL;
|
TmplRelocation = NULL;
|
||||||
|
@ -444,21 +444,21 @@ _FX ULONG File_IsDeletedEx(const WCHAR* TruePath, const WCHAR* CopyPath, FILE_SN
|
||||||
|
|
||||||
_FX void File_InitSnapshots(void)
|
_FX void File_InitSnapshots(void)
|
||||||
{
|
{
|
||||||
WCHAR ShapshotsIni[MAX_PATH] = { 0 };
|
WCHAR SnapshotsIni[MAX_PATH] = { 0 };
|
||||||
wcscpy(ShapshotsIni, Dll_BoxFilePath);
|
wcscpy(SnapshotsIni, Dll_BoxFilePath);
|
||||||
wcscat(ShapshotsIni, L"\\Snapshots.ini");
|
wcscat(SnapshotsIni, L"\\Snapshots.ini");
|
||||||
SbieDll_TranslateNtToDosPath(ShapshotsIni);
|
SbieDll_TranslateNtToDosPath(SnapshotsIni);
|
||||||
|
|
||||||
WCHAR Shapshot[FILE_MAX_SNAPSHOT_ID] = { 0 };
|
WCHAR Snapshot[FILE_MAX_SNAPSHOT_ID] = { 0 };
|
||||||
GetPrivateProfileStringW(L"Current", L"Snapshot", L"", Shapshot, FILE_MAX_SNAPSHOT_ID, ShapshotsIni);
|
GetPrivateProfileStringW(L"Current", L"Snapshot", L"", Snapshot, FILE_MAX_SNAPSHOT_ID, SnapshotsIni);
|
||||||
|
|
||||||
if (*Shapshot == 0)
|
if (*Snapshot == 0)
|
||||||
return; // not using snapshots
|
return; // not using snapshots
|
||||||
|
|
||||||
File_Snapshot = Dll_Alloc(sizeof(FILE_SNAPSHOT));
|
File_Snapshot = Dll_Alloc(sizeof(FILE_SNAPSHOT));
|
||||||
memzero(File_Snapshot, sizeof(FILE_SNAPSHOT));
|
memzero(File_Snapshot, sizeof(FILE_SNAPSHOT));
|
||||||
wcscpy(File_Snapshot->ID, Shapshot);
|
wcscpy(File_Snapshot->ID, Snapshot);
|
||||||
File_Snapshot->IDlen = wcslen(Shapshot);
|
File_Snapshot->IDlen = wcslen(Snapshot);
|
||||||
FILE_SNAPSHOT* Cur_Snapshot = File_Snapshot;
|
FILE_SNAPSHOT* Cur_Snapshot = File_Snapshot;
|
||||||
File_Snapshot_Count = 1;
|
File_Snapshot_Count = 1;
|
||||||
|
|
||||||
|
@ -466,8 +466,8 @@ _FX void File_InitSnapshots(void)
|
||||||
{
|
{
|
||||||
Cur_Snapshot->ScramKey = CRC32(Cur_Snapshot->ID, Cur_Snapshot->IDlen * sizeof(WCHAR));
|
Cur_Snapshot->ScramKey = CRC32(Cur_Snapshot->ID, Cur_Snapshot->IDlen * sizeof(WCHAR));
|
||||||
|
|
||||||
WCHAR ShapshotId[26] = L"Snapshot_";
|
WCHAR SnapshotId[26] = L"Snapshot_";
|
||||||
wcscat(ShapshotId, Shapshot);
|
wcscat(SnapshotId, Snapshot);
|
||||||
|
|
||||||
if (File_Delete_v2)
|
if (File_Delete_v2)
|
||||||
{
|
{
|
||||||
|
@ -480,19 +480,19 @@ _FX void File_InitSnapshots(void)
|
||||||
File_LoadPathTree_internal(&Cur_Snapshot->PathRoot, PathFile);
|
File_LoadPathTree_internal(&Cur_Snapshot->PathRoot, PathFile);
|
||||||
}
|
}
|
||||||
|
|
||||||
//WCHAR ShapshotName[34] = { 0 };
|
//WCHAR SnapshotName[34] = { 0 };
|
||||||
//GetPrivateProfileStringW(ShapshotId, L"Name", L"", ShapshotName, 34, ShapshotsIni);
|
//GetPrivateProfileStringW(SnapshotId, L"Name", L"", SnapshotName, 34, SnapshotsIni);
|
||||||
//wcscpy(Cur_Snapshot->Name, ShapshotName);
|
//wcscpy(Cur_Snapshot->Name, SnapshotName);
|
||||||
|
|
||||||
GetPrivateProfileStringW(ShapshotId, L"Parent", L"", Shapshot, 16, ShapshotsIni);
|
GetPrivateProfileStringW(SnapshotId, L"Parent", L"", Snapshot, 16, SnapshotsIni);
|
||||||
|
|
||||||
if (*Shapshot == 0)
|
if (*Snapshot == 0)
|
||||||
break; // no more snapshots
|
break; // no more snapshots
|
||||||
|
|
||||||
Cur_Snapshot->Parent = Dll_Alloc(sizeof(FILE_SNAPSHOT));
|
Cur_Snapshot->Parent = Dll_Alloc(sizeof(FILE_SNAPSHOT));
|
||||||
memzero(Cur_Snapshot->Parent, sizeof(FILE_SNAPSHOT));
|
memzero(Cur_Snapshot->Parent, sizeof(FILE_SNAPSHOT));
|
||||||
wcscpy(Cur_Snapshot->Parent->ID, Shapshot);
|
wcscpy(Cur_Snapshot->Parent->ID, Snapshot);
|
||||||
Cur_Snapshot->Parent->IDlen = wcslen(Shapshot);
|
Cur_Snapshot->Parent->IDlen = wcslen(Snapshot);
|
||||||
Cur_Snapshot = Cur_Snapshot->Parent;
|
Cur_Snapshot = Cur_Snapshot->Parent;
|
||||||
File_Snapshot_Count++;
|
File_Snapshot_Count++;
|
||||||
}
|
}
|
||||||
|
|
|
@ -102,7 +102,7 @@ _FX VOID Handle_SetRelocationPath(HANDLE FileHandle, WCHAR* RelocationPath)
|
||||||
EnterCriticalSection(&Handle_StatusData_CritSec);
|
EnterCriticalSection(&Handle_StatusData_CritSec);
|
||||||
|
|
||||||
HANDLE_STATE* state = map_get(&Handle_StatusData, FileHandle);
|
HANDLE_STATE* state = map_get(&Handle_StatusData, FileHandle);
|
||||||
if (!state) { // this shoudl always be the case, as we only use Handle_SetRelocationPath when the handle is first created
|
if (!state) { // this should always be the case, as we only use Handle_SetRelocationPath when the handle is first created
|
||||||
state = map_insert(&Handle_StatusData, FileHandle, NULL, sizeof(HANDLE_STATE));
|
state = map_insert(&Handle_StatusData, FileHandle, NULL, sizeof(HANDLE_STATE));
|
||||||
} else if (state->RelocationPath) Dll_Free(state->RelocationPath); // should not happen but in case
|
} else if (state->RelocationPath) Dll_Free(state->RelocationPath); // should not happen but in case
|
||||||
|
|
||||||
|
|
|
@ -559,7 +559,7 @@ _FX NTSTATUS Ipc_GetName(
|
||||||
//if (Dll_AlernateIpcNaming) {
|
//if (Dll_AlernateIpcNaming) {
|
||||||
//
|
//
|
||||||
// //
|
// //
|
||||||
// // Since in this mode we don't call Ipc_CreateObjects we dont have a boxed namespace
|
// // Since in this mode we don't call Ipc_CreateObjects we don't have a boxed namespace
|
||||||
// // and are using existing namespaces only with a name suffix
|
// // and are using existing namespaces only with a name suffix
|
||||||
// // hence we can't use Global without system provileges, so we strip it
|
// // hence we can't use Global without system provileges, so we strip it
|
||||||
// //
|
// //
|
||||||
|
|
|
@ -162,7 +162,7 @@ _FX BOOLEAN Ipc_StartServer(const WCHAR *TruePath, BOOLEAN Async)
|
||||||
if (service == _rpcss) {
|
if (service == _rpcss) {
|
||||||
|
|
||||||
//
|
//
|
||||||
// starting rpcss: go thrugh SbieSvc ProcessServer
|
// starting rpcss: go through SbieSvc ProcessServer
|
||||||
//
|
//
|
||||||
|
|
||||||
if (! Proc_ImpersonateSelf(TRUE))
|
if (! Proc_ImpersonateSelf(TRUE))
|
||||||
|
|
|
@ -245,7 +245,7 @@ IEnumPStoreTypes *IEnumPStoreTypesImpl::CreateEnumSubtype(
|
||||||
|
|
||||||
|
|
||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
// IEnumPStoreTypesImpl Defeault Constructor
|
// IEnumPStoreTypesImpl Default Constructor
|
||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -266,7 +266,7 @@ static NTSTATUS Key_NtLoadKey2(
|
||||||
static NTSTATUS Key_NtLoadKey3(
|
static NTSTATUS Key_NtLoadKey3(
|
||||||
OBJECT_ATTRIBUTES *TargetObjectAttributes,
|
OBJECT_ATTRIBUTES *TargetObjectAttributes,
|
||||||
OBJECT_ATTRIBUTES *SourceObjectAttributes, ULONG Flags,
|
OBJECT_ATTRIBUTES *SourceObjectAttributes, ULONG Flags,
|
||||||
PVOID LoadArguments, ULONG LoadArgumentCount, ACCESS_MASK DesiredAccess, HANDLE KeyHandle, ULONG Unkown);
|
PVOID LoadArguments, ULONG LoadArgumentCount, ACCESS_MASK DesiredAccess, HANDLE KeyHandle, ULONG Unknown);
|
||||||
|
|
||||||
static NTSTATUS Key_NtLoadKeyEx(
|
static NTSTATUS Key_NtLoadKeyEx(
|
||||||
OBJECT_ATTRIBUTES *TargetObjectAttributes,
|
OBJECT_ATTRIBUTES *TargetObjectAttributes,
|
||||||
|
@ -1583,7 +1583,7 @@ _FX NTSTATUS Key_NtCreateKeyImpl(
|
||||||
TruePath = OldTruePath;
|
TruePath = OldTruePath;
|
||||||
}
|
}
|
||||||
|
|
||||||
// if key marked as deleted dont even try opening true path
|
// if key marked as deleted don't even try opening true path
|
||||||
if (KEY_PATH_DELETED(TruePathFlags) && CreateOptions == tzuk) {
|
if (KEY_PATH_DELETED(TruePathFlags) && CreateOptions == tzuk) {
|
||||||
status = STATUS_OBJECT_NAME_NOT_FOUND;
|
status = STATUS_OBJECT_NAME_NOT_FOUND;
|
||||||
__leave;
|
__leave;
|
||||||
|
@ -4455,7 +4455,7 @@ _FX NTSTATUS Key_NtRenameKey(
|
||||||
goto finish;
|
goto finish;
|
||||||
|
|
||||||
//
|
//
|
||||||
// rename the key ensuring we wil have a boxed copy
|
// rename the key ensuring we will have a boxed copy
|
||||||
// try renaming if it fails with access denided try again with a new handle
|
// try renaming if it fails with access denided try again with a new handle
|
||||||
//
|
//
|
||||||
|
|
||||||
|
@ -4782,7 +4782,7 @@ _FX NTSTATUS Key_NtLoadKey2(
|
||||||
_FX NTSTATUS Key_NtLoadKey3(
|
_FX NTSTATUS Key_NtLoadKey3(
|
||||||
OBJECT_ATTRIBUTES *TargetObjectAttributes,
|
OBJECT_ATTRIBUTES *TargetObjectAttributes,
|
||||||
OBJECT_ATTRIBUTES *SourceObjectAttributes, ULONG Flags,
|
OBJECT_ATTRIBUTES *SourceObjectAttributes, ULONG Flags,
|
||||||
PVOID LoadArguments, ULONG LoadArgumentCount, ACCESS_MASK DesiredAccess, HANDLE KeyHandle, ULONG Unkown)
|
PVOID LoadArguments, ULONG LoadArgumentCount, ACCESS_MASK DesiredAccess, HANDLE KeyHandle, ULONG Unknown)
|
||||||
{
|
{
|
||||||
NTSTATUS status;
|
NTSTATUS status;
|
||||||
WCHAR* WorkPath;
|
WCHAR* WorkPath;
|
||||||
|
@ -4802,7 +4802,7 @@ _FX NTSTATUS Key_NtLoadKey3(
|
||||||
}
|
}
|
||||||
|
|
||||||
status = __sys_NtLoadKey3(TargetObjectAttributes, SourceObjectAttributes, Flags,
|
status = __sys_NtLoadKey3(TargetObjectAttributes, SourceObjectAttributes, Flags,
|
||||||
LoadArguments, LoadArgumentCount, DesiredAccess, KeyHandle, Unkown);
|
LoadArguments, LoadArgumentCount, DesiredAccess, KeyHandle, Unknown);
|
||||||
if (status == STATUS_PRIVILEGE_NOT_HELD && !Dll_CompartmentMode)
|
if (status == STATUS_PRIVILEGE_NOT_HELD && !Dll_CompartmentMode)
|
||||||
SbieApi_Log(2205, L"NtLoadKey3");
|
SbieApi_Log(2205, L"NtLoadKey3");
|
||||||
//status = Key_NtLoadKeyImpl(TargetObjectAttributes, WorkPath);
|
//status = Key_NtLoadKeyImpl(TargetObjectAttributes, WorkPath);
|
||||||
|
|
|
@ -29,7 +29,7 @@
|
||||||
|
|
||||||
// Keep in sync with the FILE_..._FLAG's in file_del.c
|
// Keep in sync with the FILE_..._FLAG's in file_del.c
|
||||||
//
|
//
|
||||||
// path flages, saved to file
|
// path flags, saved to file
|
||||||
#define KEY_DELETED_FLAG 0x0001
|
#define KEY_DELETED_FLAG 0x0001
|
||||||
#define KEY_RELOCATION_FLAG 0x0002
|
#define KEY_RELOCATION_FLAG 0x0002
|
||||||
|
|
||||||
|
@ -75,7 +75,7 @@ static ULONG Key_IsDeleted_v2(const WCHAR* TruePath);
|
||||||
static ULONG Key_IsDeletedEx_v2(const WCHAR* TruePath, const WCHAR* ValueName, BOOLEAN IsValue);
|
static ULONG Key_IsDeletedEx_v2(const WCHAR* TruePath, const WCHAR* ValueName, BOOLEAN IsValue);
|
||||||
|
|
||||||
//
|
//
|
||||||
// we re use the _internal functions of the file implementation as thay all are generic enough
|
// we re use the _internal functions of the file implementation as they all are generic enough
|
||||||
//
|
//
|
||||||
|
|
||||||
VOID File_ClearPathBranche_internal(LIST* parent);
|
VOID File_ClearPathBranche_internal(LIST* parent);
|
||||||
|
@ -168,7 +168,7 @@ _FX VOID Key_RefreshPathTree()
|
||||||
if (WaitForSingleObject(Key_BoxRootWatcher, 0) == WAIT_OBJECT_0) {
|
if (WaitForSingleObject(Key_BoxRootWatcher, 0) == WAIT_OBJECT_0) {
|
||||||
|
|
||||||
//
|
//
|
||||||
// somethign changed, reload the path tree
|
// something changed, reload the path tree
|
||||||
//
|
//
|
||||||
|
|
||||||
Key_LoadPathTree();
|
Key_LoadPathTree();
|
||||||
|
@ -224,7 +224,7 @@ _FX NTSTATUS Key_MarkDeletedEx_v2(const WCHAR* TruePath, const WCHAR* ValueName)
|
||||||
THREAD_DATA *TlsData = Dll_GetTlsData(NULL);
|
THREAD_DATA *TlsData = Dll_GetTlsData(NULL);
|
||||||
|
|
||||||
WCHAR* FullPath = Dll_GetTlsNameBuffer(TlsData, TMPL_NAME_BUFFER,
|
WCHAR* FullPath = Dll_GetTlsNameBuffer(TlsData, TMPL_NAME_BUFFER,
|
||||||
(wcslen(TruePath) + (ValueName ? wcslen(ValueName) : 0) + 16) * sizeof(WCHAR)); // template buffer is not used for reg reputpose it here
|
(wcslen(TruePath) + (ValueName ? wcslen(ValueName) : 0) + 16) * sizeof(WCHAR)); // template buffer is not used for reg repurpose it here
|
||||||
|
|
||||||
wcscpy(FullPath, TruePath);
|
wcscpy(FullPath, TruePath);
|
||||||
if (ValueName) {
|
if (ValueName) {
|
||||||
|
@ -277,7 +277,7 @@ _FX ULONG Key_IsDeletedEx_v2(const WCHAR* TruePath, const WCHAR* ValueName, BOOL
|
||||||
THREAD_DATA *TlsData = Dll_GetTlsData(NULL);
|
THREAD_DATA *TlsData = Dll_GetTlsData(NULL);
|
||||||
|
|
||||||
WCHAR* FullPath = Dll_GetTlsNameBuffer(TlsData, TMPL_NAME_BUFFER,
|
WCHAR* FullPath = Dll_GetTlsNameBuffer(TlsData, TMPL_NAME_BUFFER,
|
||||||
(wcslen(TruePath) + (ValueName ? wcslen(ValueName) : 0) + 16) * sizeof(WCHAR)); // template buffer is not used for reg reputpose it here
|
(wcslen(TruePath) + (ValueName ? wcslen(ValueName) : 0) + 16) * sizeof(WCHAR)); // template buffer is not used for reg repurpose it here
|
||||||
|
|
||||||
wcscpy(FullPath, TruePath);
|
wcscpy(FullPath, TruePath);
|
||||||
if (ValueName) {
|
if (ValueName) {
|
||||||
|
|
|
@ -461,7 +461,7 @@ _FX NTSTATUS Key_OpenForMerge(
|
||||||
//
|
//
|
||||||
// if rule specificity is enabled we may not have access to this true path
|
// if rule specificity is enabled we may not have access to this true path
|
||||||
// but still have access to some sub paths, in this case instead of listing the
|
// but still have access to some sub paths, in this case instead of listing the
|
||||||
// true directory we parse the rule list and construst a cached dummy directory
|
// true directory we parse the rule list and construct a cached dummy directory
|
||||||
//
|
//
|
||||||
|
|
||||||
if (use_rule_specificity)
|
if (use_rule_specificity)
|
||||||
|
|
|
@ -651,7 +651,7 @@ _FX ULONG SbieDll_InjectLow_InitSyscalls(BOOLEAN drv_init)
|
||||||
if (drv_init)
|
if (drv_init)
|
||||||
{
|
{
|
||||||
//
|
//
|
||||||
// Search the ntdll.dll for teh unexported syscall wrapper functions
|
// Search the ntdll.dll for the unexported syscall wrapper functions
|
||||||
//
|
//
|
||||||
|
|
||||||
void* HandleStubHijack = NULL;
|
void* HandleStubHijack = NULL;
|
||||||
|
@ -659,7 +659,7 @@ _FX ULONG SbieDll_InjectLow_InitSyscalls(BOOLEAN drv_init)
|
||||||
|
|
||||||
if (aCode == NULL) {
|
if (aCode == NULL) {
|
||||||
SbieApi_Log(2303, L"syscall, wrappers not found");
|
SbieApi_Log(2303, L"syscall, wrappers not found");
|
||||||
return STATUS_SUCCESS; // we will fail process cration for ec processes later
|
return STATUS_SUCCESS; // we will fail process creation for ec processes later
|
||||||
}
|
}
|
||||||
|
|
||||||
void* EcExitThunkPtr = SbieDll_GetEcExitThunkPtr(HandleStubHijack);
|
void* EcExitThunkPtr = SbieDll_GetEcExitThunkPtr(HandleStubHijack);
|
||||||
|
@ -1219,7 +1219,7 @@ _FX BOOLEAN SbieDll_InjectLow_BuildTramp(
|
||||||
|
|
||||||
//
|
//
|
||||||
// skip past several bytes in the code copied from the top of the
|
// skip past several bytes in the code copied from the top of the
|
||||||
// LdrInitializeThunk fuction, where we will inject a jmp sequence.
|
// LdrInitializeThunk function, where we will inject a jmp sequence.
|
||||||
//
|
//
|
||||||
// a simple E9 relative JMP five byte instruction in most cases,
|
// a simple E9 relative JMP five byte instruction in most cases,
|
||||||
// a slightly longer seven byte version in case there is a long
|
// a slightly longer seven byte version in case there is a long
|
||||||
|
|
|
@ -453,7 +453,7 @@ static SOCKET WSA_WSASocketW(
|
||||||
else {
|
else {
|
||||||
|
|
||||||
//
|
//
|
||||||
// dont ask again on success
|
// don't ask again on success
|
||||||
//
|
//
|
||||||
|
|
||||||
WSA_WFPisBlocking = FALSE;
|
WSA_WFPisBlocking = FALSE;
|
||||||
|
@ -751,9 +751,9 @@ _FX int WSA_AcceptEx(
|
||||||
LPOVERLAPPED lpOverlapped)
|
LPOVERLAPPED lpOverlapped)
|
||||||
{
|
{
|
||||||
//
|
//
|
||||||
// this call can operate asynchroniusly, hence we can not simply filter here the incomming connection
|
// this call can operate asynchroniusly, hence we can not simply filter here the incoming connection
|
||||||
// as we have a proepr WFP filter in the driver for now this usermode filtering implementation
|
// as we have a proepr WFP filter in the driver for now this usermode filtering implementation
|
||||||
// will not filter incomming traffic at all, normally users ate beind NATs or other firewall so
|
// will not filter incoming traffic at all, normally users ate behind NATs or other firewall so
|
||||||
// blocking only outgoing connections should be good enough
|
// blocking only outgoing connections should be good enough
|
||||||
//
|
//
|
||||||
|
|
||||||
|
|
|
@ -401,7 +401,7 @@ _FX LONG SbieApi_LogMsgEx(
|
||||||
API_LOG_MESSAGE_ARGS *args = (API_LOG_MESSAGE_ARGS *)parms;
|
API_LOG_MESSAGE_ARGS *args = (API_LOG_MESSAGE_ARGS *)parms;
|
||||||
|
|
||||||
//
|
//
|
||||||
// the msg_data can contain multiple strings separated by L'\0' charakters
|
// the msg_data can contain multiple strings separated by L'\0' characters
|
||||||
//
|
//
|
||||||
|
|
||||||
msgtext.Buffer = (ULONG_PTR)msg_data;
|
msgtext.Buffer = (ULONG_PTR)msg_data;
|
||||||
|
|
|
@ -622,7 +622,7 @@ BOOLEAN Scm_HookRegisterServiceCtrlHandler(HMODULE module)
|
||||||
{
|
{
|
||||||
|
|
||||||
#ifndef _M_ARM64
|
#ifndef _M_ARM64
|
||||||
// $HookHack$ - Custom, not automated, Hook no longer applyes to later windows 10 builds
|
// $HookHack$ - Custom, not automated, Hook no longer applies to later windows 10 builds
|
||||||
#ifdef _WIN64
|
#ifdef _WIN64
|
||||||
static const UCHAR PrologW[] = {
|
static const UCHAR PrologW[] = {
|
||||||
0x45, 0x33, 0xC9, // xor r9d,r9d
|
0x45, 0x33, 0xC9, // xor r9d,r9d
|
||||||
|
|
|
@ -1361,7 +1361,7 @@ _FX BOOL Scm_StartServiceCtrlDispatcherX(
|
||||||
// if the service never started, report error
|
// if the service never started, report error
|
||||||
//
|
//
|
||||||
|
|
||||||
Sbie_snwprintf(text, 130, L"StartServiceCtrlDispatcher; result: %s", Scm_Started ? L"sucess" : L"failure");
|
Sbie_snwprintf(text, 130, L"StartServiceCtrlDispatcher; result: %s", Scm_Started ? L"success" : L"failure");
|
||||||
SbieApi_MonitorPutMsg(MONITOR_SCM, text);
|
SbieApi_MonitorPutMsg(MONITOR_SCM, text);
|
||||||
|
|
||||||
if (! Scm_Started) {
|
if (! Scm_Started) {
|
||||||
|
|
|
@ -205,7 +205,7 @@ _FX HANDLE Scm_CreateWaitableTimerW(
|
||||||
{
|
{
|
||||||
|
|
||||||
//
|
//
|
||||||
// When MsiServer is not started as system (missing the admin groupe) this call fails
|
// When MsiServer is not started as system (missing the admin group) this call fails
|
||||||
//
|
//
|
||||||
|
|
||||||
lpTimerAttributes = NULL;
|
lpTimerAttributes = NULL;
|
||||||
|
|
|
@ -226,7 +226,7 @@ _FX void SysInfo_DiscardProcesses(SYSTEM_PROCESS_INFORMATION *buf)
|
||||||
|
|
||||||
WCHAR* hiddenProcesses = NULL;
|
WCHAR* hiddenProcesses = NULL;
|
||||||
WCHAR* hiddenProcessesPtr = NULL;
|
WCHAR* hiddenProcessesPtr = NULL;
|
||||||
ULONG hiddenProcessesLen = 100 * 110; // we can hide up to 100 processes, sould be enough
|
ULONG hiddenProcessesLen = 100 * 110; // we can hide up to 100 processes, should be enough
|
||||||
WCHAR hiddenProcess[110];
|
WCHAR hiddenProcess[110];
|
||||||
|
|
||||||
for (ULONG index = 0; ; ++index) {
|
for (ULONG index = 0; ; ++index) {
|
||||||
|
|
|
@ -592,7 +592,7 @@ _FX void Taskbar_SetWindowAppUserModelId(HWND hwnd)
|
||||||
//
|
//
|
||||||
|
|
||||||
// Note: without the right value we may end up with multiple window groups
|
// Note: without the right value we may end up with multiple window groups
|
||||||
// so don't do anythign if we dont have Taskbar_SavedAppUserModelId
|
// so don't do anything if we don't have Taskbar_SavedAppUserModelId
|
||||||
// see also disabled Taskbar_SetProcessAppUserModelId
|
// see also disabled Taskbar_SetProcessAppUserModelId
|
||||||
//if (!Taskbar_SavedAppUserModelId)
|
//if (!Taskbar_SavedAppUserModelId)
|
||||||
// return;
|
// return;
|
||||||
|
|
|
@ -233,7 +233,7 @@ extern const WCHAR *Ipc_SandboxieRpcSs;
|
||||||
_FX BOOLEAN Terminal_DontHook(void)
|
_FX BOOLEAN Terminal_DontHook(void)
|
||||||
{
|
{
|
||||||
//
|
//
|
||||||
// In in app mode we have a full token and this wil be successfull, hence no need for a hook
|
// In in app mode we have a full token and this will be successful, hence no need for a hook
|
||||||
//
|
//
|
||||||
|
|
||||||
if (Dll_CompartmentMode)
|
if (Dll_CompartmentMode)
|
||||||
|
|
|
@ -799,7 +799,7 @@ _FX NTSTATUS Conf_Merge_Templates(CONF_DATA *data, ULONG session_id)
|
||||||
#ifdef USE_CONF_MAP
|
#ifdef USE_CONF_MAP
|
||||||
|
|
||||||
//
|
//
|
||||||
// use a keyed itterator to quickly go through all Template=Xxx settings
|
// use a keyed iterator to quickly go through all Template=Xxx settings
|
||||||
//
|
//
|
||||||
|
|
||||||
map_iter_t iter2 = map_key_iter(&sandbox->settings_map, Conf_Template);
|
map_iter_t iter2 = map_key_iter(&sandbox->settings_map, Conf_Template);
|
||||||
|
@ -1047,7 +1047,7 @@ _FX const WCHAR *Conf_Get_Helper(
|
||||||
if (section) {
|
if (section) {
|
||||||
#ifdef USE_CONF_MAP
|
#ifdef USE_CONF_MAP
|
||||||
//
|
//
|
||||||
// use a keyed itterator to quickly go through all matching settings
|
// use a keyed iterator to quickly go through all matching settings
|
||||||
//
|
//
|
||||||
|
|
||||||
map_iter_t iter2 = map_key_iter(§ion->settings_map, setting_name);
|
map_iter_t iter2 = map_key_iter(§ion->settings_map, setting_name);
|
||||||
|
|
|
@ -705,7 +705,7 @@ _FX BOOLEAN Driver_FindMissingServices(void)
|
||||||
|
|
||||||
|
|
||||||
//
|
//
|
||||||
// Retrive some unexported kernel functions which may be usefull
|
// Retrieve some unexported kernel functions which may be useful
|
||||||
//
|
//
|
||||||
|
|
||||||
#ifdef _M_ARM64
|
#ifdef _M_ARM64
|
||||||
|
@ -715,7 +715,7 @@ _FX BOOLEAN Driver_FindMissingServices(void)
|
||||||
// but out right lacks those functions entirely.
|
// but out right lacks those functions entirely.
|
||||||
// So in order to work around this limitation we implement a own system service wrapper
|
// So in order to work around this limitation we implement a own system service wrapper
|
||||||
// we invoke Sbie_CallZwServiceFunction_asm with all the arguments we need
|
// we invoke Sbie_CallZwServiceFunction_asm with all the arguments we need
|
||||||
// and the service numebr as last 20th argument, it sets IP0/X16 and invokes KiServiceInternal
|
// and the service number as last 20th argument, it sets IP0/X16 and invokes KiServiceInternal
|
||||||
//
|
//
|
||||||
|
|
||||||
SYSCALL_ENTRY *entry = Syscall_GetByName("CreateToken");
|
SYSCALL_ENTRY *entry = Syscall_GetByName("CreateToken");
|
||||||
|
|
|
@ -829,7 +829,7 @@ _FX BOOLEAN File_InitPaths(PROCESS *proc,
|
||||||
|
|
||||||
//
|
//
|
||||||
// many 3rd party drivers are a great attack vector to gain execution in the kernel,
|
// many 3rd party drivers are a great attack vector to gain execution in the kernel,
|
||||||
// so we clsoe all typical endpoints except a selected few.
|
// so we close all typical endpoints except a selected few.
|
||||||
//
|
//
|
||||||
|
|
||||||
ok = Process_AddPath(proc, closed_file_paths, NULL, FALSE, File_Device, TRUE);
|
ok = Process_AddPath(proc, closed_file_paths, NULL, FALSE, File_Device, TRUE);
|
||||||
|
|
|
@ -1190,7 +1190,7 @@ _FX BOOLEAN Process_NotifyProcess_Create(
|
||||||
#ifdef DRV_BREAKOUT
|
#ifdef DRV_BREAKOUT
|
||||||
//
|
//
|
||||||
// check if this process is set up as break out program,
|
// check if this process is set up as break out program,
|
||||||
// it must't be located in a sandboxed for this to work.
|
// it mustn't be located in a sandboxed for this to work.
|
||||||
//
|
//
|
||||||
|
|
||||||
BOX* breakout_box = NULL;
|
BOX* breakout_box = NULL;
|
||||||
|
|
|
@ -915,7 +915,7 @@ _FX ULONG Process_MatchPathEx(
|
||||||
//
|
//
|
||||||
// Rule priorities are implemented based on their specificity and match level with the process.
|
// Rule priorities are implemented based on their specificity and match level with the process.
|
||||||
// The specificity describes how well a pattern matches a given path,
|
// The specificity describes how well a pattern matches a given path,
|
||||||
// i.e. how many charakters of the path it matches, disregarding the last wild card.
|
// i.e. how many characters of the path it matches, disregarding the last wild card.
|
||||||
// The process match level describes in which way a rule applies to a given process:
|
// The process match level describes in which way a rule applies to a given process:
|
||||||
// 0 - exact match, eg. ...Path=program.exe,...
|
// 0 - exact match, eg. ...Path=program.exe,...
|
||||||
// 1 - match by negation, eg. ...Path=!program.exe,...
|
// 1 - match by negation, eg. ...Path=!program.exe,...
|
||||||
|
@ -966,7 +966,7 @@ _FX ULONG Process_MatchPathEx(
|
||||||
// //
|
// //
|
||||||
// // Note: as of 5.60.1 all locations are locked down explicitly while the root mode remains normal
|
// // Note: as of 5.60.1 all locations are locked down explicitly while the root mode remains normal
|
||||||
// //
|
// //
|
||||||
// // To enable privacy enchanced mode add UsePrivacyMode=y
|
// // To enable privacy enhanced mode add UsePrivacyMode=y
|
||||||
// //
|
// //
|
||||||
//
|
//
|
||||||
// mp_flags = TRUE_PATH_CLOSED_FLAG | COPY_PATH_OPEN_FLAG; // write path mode
|
// mp_flags = TRUE_PATH_CLOSED_FLAG | COPY_PATH_OPEN_FLAG; // write path mode
|
||||||
|
@ -984,7 +984,7 @@ _FX ULONG Process_MatchPathEx(
|
||||||
|
|
||||||
//
|
//
|
||||||
// write path list, behaved on the driver side like closed path list
|
// write path list, behaved on the driver side like closed path list
|
||||||
// these paths allow read acces to true location and read/write access to copy location
|
// these paths allow read access to true location and read/write access to copy location
|
||||||
//
|
//
|
||||||
|
|
||||||
if (Pattern_MatchPathListEx(path_lwr, path_len, write_list, &level, &match_len, &exact, &wildc, patsrc)) {
|
if (Pattern_MatchPathListEx(path_lwr, path_len, write_list, &level, &match_len, &exact, &wildc, patsrc)) {
|
||||||
|
@ -994,7 +994,7 @@ _FX ULONG Process_MatchPathEx(
|
||||||
|
|
||||||
//
|
//
|
||||||
// read path list behaves in the kernel like the default normal behavioure
|
// read path list behaves in the kernel like the default normal behavioure
|
||||||
// these paths allow read only acces to true path and copy locations
|
// these paths allow read only access to true path and copy locations
|
||||||
//
|
//
|
||||||
|
|
||||||
if (Pattern_MatchPathListEx(path_lwr, path_len, read_list, &level, &match_len, &exact, &wildc, patsrc)) {
|
if (Pattern_MatchPathListEx(path_lwr, path_len, read_list, &level, &match_len, &exact, &wildc, patsrc)) {
|
||||||
|
@ -1009,7 +1009,7 @@ _FX ULONG Process_MatchPathEx(
|
||||||
|
|
||||||
if (Pattern_MatchPathListEx(path_lwr, path_len, normal_list, &level, &match_len, &exact, &wildc, patsrc)) {
|
if (Pattern_MatchPathListEx(path_lwr, path_len, normal_list, &level, &match_len, &exact, &wildc, patsrc)) {
|
||||||
mp_flags = TRUE_PATH_READ_FLAG | COPY_PATH_OPEN_FLAG;
|
mp_flags = TRUE_PATH_READ_FLAG | COPY_PATH_OPEN_FLAG;
|
||||||
// dont goto finish as open can overwrite this
|
// don't goto finish as open can overwrite this
|
||||||
}
|
}
|
||||||
|
|
||||||
//
|
//
|
||||||
|
|
|
@ -205,7 +205,7 @@ _FX BOOLEAN Syscall_Init_List(void)
|
||||||
List_Init(&Syscall_List);
|
List_Init(&Syscall_List);
|
||||||
|
|
||||||
//
|
//
|
||||||
// preapre the approve and disabled lists
|
// prepare the approve and disabled lists
|
||||||
//
|
//
|
||||||
|
|
||||||
LIST disabled_hooks;
|
LIST disabled_hooks;
|
||||||
|
|
|
@ -131,7 +131,7 @@ Sbie_SepFilterTokenHandler_asm PROC
|
||||||
|
|
||||||
Sbie_CallZwServiceFunction_asm PROC
|
Sbie_CallZwServiceFunction_asm PROC
|
||||||
|
|
||||||
ldr x16,[sp,#0x58] ; preapre the sys call number
|
ldr x16,[sp,#0x58] ; prepare the sys call number
|
||||||
ldr x9, =Driver_KiServiceInternal
|
ldr x9, =Driver_KiServiceInternal
|
||||||
ldr x8, [x9]
|
ldr x8, [x9]
|
||||||
br x8 ; jump to KiServiceInternal
|
br x8 ; jump to KiServiceInternal
|
||||||
|
|
|
@ -490,7 +490,7 @@ union _SCertInfo {
|
||||||
valid : 1, // certificate is active
|
valid : 1, // certificate is active
|
||||||
expired : 1, // certificate is expired but may be active
|
expired : 1, // certificate is expired but may be active
|
||||||
outdated : 1, // certificate is expired, not anymore valid for the current build
|
outdated : 1, // certificate is expired, not anymore valid for the current build
|
||||||
business : 1, // certificate is siutable for business use
|
business : 1, // certificate is suitable for business use
|
||||||
evaluation: 1, // evaluation certificate
|
evaluation: 1, // evaluation certificate
|
||||||
reservd_1 : 3,
|
reservd_1 : 3,
|
||||||
reservd_2 : 8,
|
reservd_2 : 8,
|
||||||
|
|
|
@ -339,7 +339,7 @@ LdrLoadGood
|
||||||
|
|
||||||
ldr x0, [x19, 0x60] ; [x19].InjectData.ModuleHandle
|
ldr x0, [x19, 0x60] ; [x19].InjectData.ModuleHandle
|
||||||
mov x1, #0x00 ; FunctionName
|
mov x1, #0x00 ; FunctionName
|
||||||
mov x2, #0x01 ; Oridinal
|
mov x2, #0x01 ; Ordinal
|
||||||
add x3, x19, 0x68 ; [x19].InjectData.SbieDllOrdinal1
|
add x3, x19, 0x68 ; [x19].InjectData.SbieDllOrdinal1
|
||||||
mov x4, x19 ; [x19].InjectData
|
mov x4, x19 ; [x19].InjectData
|
||||||
|
|
||||||
|
|
|
@ -23,7 +23,7 @@
|
||||||
; SbieSrv.exe named Lowlevel. The code section is copied from this resource
|
; SbieSrv.exe named Lowlevel. The code section is copied from this resource
|
||||||
; and load directly in to memory and injected in to various targets. Thus the
|
; and load directly in to memory and injected in to various targets. Thus the
|
||||||
; code section of this dll is executed like shell code because of the manual
|
; code section of this dll is executed like shell code because of the manual
|
||||||
; load techinque used by SbieSrv.exe and needs to execute in various memory locations
|
; load technique used by SbieSrv.exe and needs to execute in various memory locations
|
||||||
; since it is the injected code. SbieSrv.exe will parse the PE Header of
|
; since it is the injected code. SbieSrv.exe will parse the PE Header of
|
||||||
; lowlevel.dll to locate the code section and copy it. To simplify the work
|
; lowlevel.dll to locate the code section and copy it. To simplify the work
|
||||||
; needed to locate key locations with in the object code generated
|
; needed to locate key locations with in the object code generated
|
||||||
|
|
|
@ -223,7 +223,7 @@ _FX void PrepSyscalls(SBIELOW_DATA *data, void * SystemService)
|
||||||
|
|
||||||
//
|
//
|
||||||
// Windows on arm64 uses a special syscall wrapper functions
|
// Windows on arm64 uses a special syscall wrapper functions
|
||||||
// when runnign in arm64ec / x64 mode hence we need to
|
// when running in arm64ec / x64 mode hence we need to
|
||||||
// point our SystemService's NtDeviceIoControlFile to
|
// point our SystemService's NtDeviceIoControlFile to
|
||||||
// a replica of the #NtDeviceIoControlFile EC variant
|
// a replica of the #NtDeviceIoControlFile EC variant
|
||||||
//
|
//
|
||||||
|
@ -369,7 +369,7 @@ _FX void InitSyscalls(SBIELOW_DATA *data, void * SystemService)
|
||||||
#ifdef _M_ARM64
|
#ifdef _M_ARM64
|
||||||
|
|
||||||
//
|
//
|
||||||
// On arm64 syscall wraper functions looks like this:
|
// On arm64 syscall wrapper functions looks like this:
|
||||||
// svc #0xXXX
|
// svc #0xXXX
|
||||||
// ret
|
// ret
|
||||||
// DCD 0
|
// DCD 0
|
||||||
|
@ -519,7 +519,7 @@ _FX void InitSyscalls(SBIELOW_DATA *data, void * SystemService)
|
||||||
_FX NTSTATUS MyImageOptionsEx(PUNICODE_STRING SubKey, PCWSTR ValueName,
|
_FX NTSTATUS MyImageOptionsEx(PUNICODE_STRING SubKey, PCWSTR ValueName,
|
||||||
ULONG Type, PVOID Buffer, ULONG BufferSize, PULONG ReturnedLength, BOOLEAN Wow64, SBIELOW_DATA* data)
|
ULONG Type, PVOID Buffer, ULONG BufferSize, PULONG ReturnedLength, BOOLEAN Wow64, SBIELOW_DATA* data)
|
||||||
{
|
{
|
||||||
// Note: A normal string like L"LoadCHPEBinaries" would not resultin position independant code !!!
|
// Note: A normal string like L"LoadCHPEBinaries" would not resultin position independent code !!!
|
||||||
wchar_t LoadCHPEBinaries[] = { 'L','o','a','d','C','H','P','E','B','i','n','a','r','i','e','s',0 };
|
wchar_t LoadCHPEBinaries[] = { 'L','o','a','d','C','H','P','E','B','i','n','a','r','i','e','s',0 };
|
||||||
PCWSTR ptr = ValueName;
|
PCWSTR ptr = ValueName;
|
||||||
for (PCWSTR tmp = LoadCHPEBinaries; *ptr && *tmp && *ptr == *tmp; ptr++, tmp++);
|
for (PCWSTR tmp = LoadCHPEBinaries; *ptr && *tmp && *ptr == *tmp; ptr++, tmp++);
|
||||||
|
|
|
@ -177,12 +177,12 @@ _FX UCHAR *FindDllExport2(
|
||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
|
|
||||||
|
|
||||||
_FX NTSTATUS MyGetProcedureAddress(HMODULE ModuleHandle, PANSI_STRING FunctionName, WORD Oridinal, PVOID*FunctionAddress, INJECT_DATA *inject)
|
_FX NTSTATUS MyGetProcedureAddress(HMODULE ModuleHandle, PANSI_STRING FunctionName, WORD Ordinal, PVOID*FunctionAddress, INJECT_DATA *inject)
|
||||||
{
|
{
|
||||||
SBIELOW_DATA* data = (SBIELOW_DATA*)*(ULONG64*)inject;
|
SBIELOW_DATA* data = (SBIELOW_DATA*)*(ULONG64*)inject;
|
||||||
|
|
||||||
typedef (*P_LdrGetProcedureAddress)(HMODULE, PANSI_STRING, WORD, PVOID*);
|
typedef (*P_LdrGetProcedureAddress)(HMODULE, PANSI_STRING, WORD, PVOID*);
|
||||||
NTSTATUS status = ((P_LdrGetProcedureAddress)inject->LdrGetProcAddr)(ModuleHandle, FunctionName, Oridinal, FunctionAddress);
|
NTSTATUS status = ((P_LdrGetProcedureAddress)inject->LdrGetProcAddr)(ModuleHandle, FunctionName, Ordinal, FunctionAddress);
|
||||||
|
|
||||||
//
|
//
|
||||||
// in ARM64EC mode unwrap the FFS and return the native function
|
// in ARM64EC mode unwrap the FFS and return the native function
|
||||||
|
@ -242,7 +242,7 @@ _FX void InitInject(SBIELOW_DATA *data, void *DetourCode)
|
||||||
if (data->flags.is_wow64) {
|
if (data->flags.is_wow64) {
|
||||||
|
|
||||||
//
|
//
|
||||||
// Instead of requiering the driver for this task, we can simplify it
|
// Instead of requiring the driver for this task, we can simplify it
|
||||||
// and use NtQueryVirtualMemory to find the mapped image directly.
|
// and use NtQueryVirtualMemory to find the mapped image directly.
|
||||||
// We do that in the injector, but we could also have done it here ourselves.
|
// We do that in the injector, but we could also have done it here ourselves.
|
||||||
//
|
//
|
||||||
|
@ -301,7 +301,7 @@ _FX void InitInject(SBIELOW_DATA *data, void *DetourCode)
|
||||||
|
|
||||||
//
|
//
|
||||||
// on ARM64EC we hook the native code hence we need the custom MyGetProcedureAddress
|
// on ARM64EC we hook the native code hence we need the custom MyGetProcedureAddress
|
||||||
// to obtain the address of the native orginal 1 from our SbieDll.dll
|
// to obtain the address of the native original 1 from our SbieDll.dll
|
||||||
// instead of the FFS sequence as given by NtGetProcedureAddress
|
// instead of the FFS sequence as given by NtGetProcedureAddress
|
||||||
//
|
//
|
||||||
|
|
||||||
|
@ -321,7 +321,7 @@ _FX void InitInject(SBIELOW_DATA *data, void *DetourCode)
|
||||||
|
|
||||||
//
|
//
|
||||||
// for ARM64EC we need native functions, FindDllExport can manage FFS's
|
// for ARM64EC we need native functions, FindDllExport can manage FFS's
|
||||||
// howeever this does not work for syscalls, hence we use the native function directly
|
// however this does not work for syscalls, hence we use the native function directly
|
||||||
//
|
//
|
||||||
inject->NtRaiseHardError = data->NativeNtRaiseHardError;
|
inject->NtRaiseHardError = data->NativeNtRaiseHardError;
|
||||||
|
|
||||||
|
|
|
@ -312,7 +312,7 @@ void DriverAssist::MsgWorkerThread(void *MyMsg)
|
||||||
// we update the ini cache each time the driver reloads the ini file.
|
// we update the ini cache each time the driver reloads the ini file.
|
||||||
//
|
//
|
||||||
// In newer builds the driver tells us which process issued the reload
|
// In newer builds the driver tells us which process issued the reload
|
||||||
// if we did it we dont need to purge the cached ini data
|
// if we did it we don't need to purge the cached ini data
|
||||||
//
|
//
|
||||||
|
|
||||||
if(data_len < sizeof(ULONG) || *(ULONG*)data_ptr != GetCurrentProcessId())
|
if(data_len < sizeof(ULONG) || *(ULONG*)data_ptr != GetCurrentProcessId())
|
||||||
|
@ -501,7 +501,7 @@ void DriverAssist::RestartHostInjectedSvcs()
|
||||||
// resulting in this function getting triggered way to often,
|
// resulting in this function getting triggered way to often,
|
||||||
// hence we implement a small workaround.
|
// hence we implement a small workaround.
|
||||||
// The first thread to hit this monitors how many
|
// The first thread to hit this monitors how many
|
||||||
// calls go in and waits untill the last one,
|
// calls go in and waits until the last one,
|
||||||
// then it starts the Job.
|
// then it starts the Job.
|
||||||
//
|
//
|
||||||
|
|
||||||
|
@ -538,7 +538,7 @@ typedef struct _FILE_FS_PERSISTENT_VOLUME_INFORMATION {
|
||||||
|
|
||||||
} FILE_FS_PERSISTENT_VOLUME_INFORMATION, *PFILE_FS_PERSISTENT_VOLUME_INFORMATION;
|
} FILE_FS_PERSISTENT_VOLUME_INFORMATION, *PFILE_FS_PERSISTENT_VOLUME_INFORMATION;
|
||||||
|
|
||||||
// FltFsControlFile or ZwFsControlFile call # to query persistant volume info (if used in DDK)
|
// FltFsControlFile or ZwFsControlFile call # to query persistent volume info (if used in DDK)
|
||||||
// CAN ALSO USE WITH: DeviceIOControl (which is what we will do)
|
// CAN ALSO USE WITH: DeviceIOControl (which is what we will do)
|
||||||
#define FSCTL_QUERY_PERSISTENT_VOLUME_STATE CTL_CODE(FILE_DEVICE_FILE_SYSTEM, 143, METHOD_BUFFERED, FILE_ANY_ACCESS) // FILE_FS_PERSISTENT_VOLUME_INFORMATION
|
#define FSCTL_QUERY_PERSISTENT_VOLUME_STATE CTL_CODE(FILE_DEVICE_FILE_SYSTEM, 143, METHOD_BUFFERED, FILE_ANY_ACCESS) // FILE_FS_PERSISTENT_VOLUME_INFORMATION
|
||||||
|
|
||||||
|
|
|
@ -244,7 +244,7 @@ void DriverAssist::LogMessage_Multi(
|
||||||
if (u.info.Type != REG_SZ || u.info.DataLength >= sizeof(u))
|
if (u.info.Type != REG_SZ || u.info.DataLength >= sizeof(u))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
// go through a ',' or ';' separated list of messge ID's, return message id is not listed
|
// go through a ',' or ';' separated list of message ID's, return message id is not listed
|
||||||
WCHAR *ptr = (WCHAR *)u.info.Data;
|
WCHAR *ptr = (WCHAR *)u.info.Data;
|
||||||
while (*ptr) {
|
while (*ptr) {
|
||||||
if (_wtoi(ptr) == (msgid & 0xFFFF))
|
if (_wtoi(ptr) == (msgid & 0xFFFF))
|
||||||
|
|
|
@ -1085,7 +1085,7 @@ HANDLE GuiServer::GetJobObjectForAssign(const WCHAR *boxname)
|
||||||
}
|
}
|
||||||
|
|
||||||
//
|
//
|
||||||
// we want to allow sandboxed processes to use jobs of thair own
|
// we want to allow sandboxed processes to use jobs of their own
|
||||||
// with windows 8 we can have nested, a boxed process may want to use BREAKAWAY
|
// with windows 8 we can have nested, a boxed process may want to use BREAKAWAY
|
||||||
// hence we no longer prevent breaking away from our job,
|
// hence we no longer prevent breaking away from our job,
|
||||||
// instead we re assign the job on each initialization, like it was done for the initial one
|
// instead we re assign the job on each initialization, like it was done for the initial one
|
||||||
|
|
|
@ -1025,7 +1025,7 @@ BOOL ProcessServer::RunSandboxedSetDacl(
|
||||||
// in Sandboxie version 5.57 instead of using the anonymous SID
|
// in Sandboxie version 5.57 instead of using the anonymous SID
|
||||||
// we can use box specific custom SIDs,
|
// we can use box specific custom SIDs,
|
||||||
// when comparing we skip the revision and the SubAuthorityCount
|
// when comparing we skip the revision and the SubAuthorityCount
|
||||||
// also we conpare only teh domain portion of the SID as the rest
|
// also we conpare only the domain portion of the SID as the rest
|
||||||
// will be different for each box
|
// will be different for each box
|
||||||
//
|
//
|
||||||
|
|
||||||
|
@ -1128,7 +1128,7 @@ BOOL ProcessServer::RunSandboxedStripPrivilege(HANDLE NewTokenHandle, LPCWSTR lp
|
||||||
BOOL ProcessServer::RunSandboxedStripPrivileges(HANDLE NewTokenHandle)
|
BOOL ProcessServer::RunSandboxedStripPrivileges(HANDLE NewTokenHandle)
|
||||||
{
|
{
|
||||||
BOOLEAN ok = RunSandboxedStripPrivilege(NewTokenHandle, SE_TCB_NAME); // security critical
|
BOOLEAN ok = RunSandboxedStripPrivilege(NewTokenHandle, SE_TCB_NAME); // security critical
|
||||||
if (ok) ok = RunSandboxedStripPrivilege(NewTokenHandle, SE_CREATE_TOKEN_NAME); // usualyl not held, but in case
|
if (ok) ok = RunSandboxedStripPrivilege(NewTokenHandle, SE_CREATE_TOKEN_NAME); // usually not held, but in case
|
||||||
//if (ok) ok = RunSandboxedStripPrivilege(NewTokenHandle, SE_ASSIGNPRIMARYTOKEN_NAME);
|
//if (ok) ok = RunSandboxedStripPrivilege(NewTokenHandle, SE_ASSIGNPRIMARYTOKEN_NAME);
|
||||||
return ok;
|
return ok;
|
||||||
}
|
}
|
||||||
|
|
|
@ -840,7 +840,7 @@ FunctionEnd
|
||||||
|
|
||||||
Function CheckUpdates
|
Function CheckUpdates
|
||||||
|
|
||||||
StrCpy $0 "instal"
|
StrCpy $0 "install"
|
||||||
StrCmp $InstallType "Install" DoCheck
|
StrCmp $InstallType "Install" DoCheck
|
||||||
StrCpy $0 "upgrade"
|
StrCpy $0 "upgrade"
|
||||||
|
|
||||||
|
|
|
@ -50,14 +50,14 @@ int CArchive::Open()
|
||||||
{
|
{
|
||||||
if(!theArc.IsOperational())
|
if(!theArc.IsOperational())
|
||||||
{
|
{
|
||||||
LogError("Couldnt open interface");
|
LogError("Couldn't open interface");
|
||||||
return 0; // failed
|
return 0; // failed
|
||||||
}
|
}
|
||||||
|
|
||||||
if(m_Archive)
|
if(m_Archive)
|
||||||
{
|
{
|
||||||
LogError("archive is already open");
|
LogError("archive is already open");
|
||||||
return 0; // failes
|
return 0; // fails
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!m_pDevice && !QFile::exists(m_ArchivePath))
|
if(!m_pDevice && !QFile::exists(m_ArchivePath))
|
||||||
|
@ -116,24 +116,24 @@ int CArchive::Open()
|
||||||
{
|
{
|
||||||
m_Archive->In->GetProperty(i, j, &prop);
|
m_Archive->In->GetProperty(i, j, &prop);
|
||||||
|
|
||||||
QVariant Propertie;
|
QVariant Property;
|
||||||
switch (prop.vt)
|
switch (prop.vt)
|
||||||
{
|
{
|
||||||
case VT_BSTR: Propertie = QString::fromStdWString(prop.bstrVal); break;
|
case VT_BSTR: Property = QString::fromStdWString(prop.bstrVal); break;
|
||||||
case VT_UI1: Propertie = prop.bVal; break;
|
case VT_UI1: Property = prop.bVal; break;
|
||||||
case VT_UI2: Propertie = prop.uiVal; break;
|
case VT_UI2: Property = prop.uiVal; break;
|
||||||
case VT_UI4: Propertie = (qint32)prop.ulVal; break;
|
case VT_UI4: Property = (qint32)prop.ulVal; break;
|
||||||
case VT_UI8: Propertie = (qint64)prop.uhVal.QuadPart; break;
|
case VT_UI8: Property = (qint64)prop.uhVal.QuadPart; break;
|
||||||
case VT_BOOL: Propertie = VARIANT_BOOLToBool(prop.boolVal); break;
|
case VT_BOOL: Property = VARIANT_BOOLToBool(prop.boolVal); break;
|
||||||
case VT_FILETIME: Propertie = *reinterpret_cast<qint64*>(&prop.filetime); break; // ToDo
|
case VT_FILETIME: Property = *reinterpret_cast<qint64*>(&prop.filetime); break; // ToDo
|
||||||
default:
|
default:
|
||||||
//TRACE(L"Unhandled archive property %S (%d)", QS2CS(GetPropertyName(j)), prop.vt);
|
//TRACE(L"Unhandled archive property %S (%d)", QS2CS(GetPropertyName(j)), prop.vt);
|
||||||
case VT_EMPTY:
|
case VT_EMPTY:
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
File.Properties.insert(GetPropertyName(j), Propertie);
|
File.Properties.insert(GetPropertyName(j), Property);
|
||||||
//TRACE(L" >> File %S: %S=%S", QS2CS(File.Properties["Path"].toString()), QS2CS(GetPropertyName(j)), QS2CS(Propertie.toString()));
|
//TRACE(L" >> File %S: %S=%S", QS2CS(File.Properties["Path"].toString()), QS2CS(GetPropertyName(j)), QS2CS(Property.toString()));
|
||||||
}
|
}
|
||||||
m_Files.append(File);
|
m_Files.append(File);
|
||||||
}
|
}
|
||||||
|
@ -213,7 +213,7 @@ bool CArchive::Update(QMap<int, QIODevice*> *FileList, bool bDelete, int Level)
|
||||||
{
|
{
|
||||||
if(!theArc.IsOperational())
|
if(!theArc.IsOperational())
|
||||||
{
|
{
|
||||||
LogError("Couldnt open interface");
|
LogError("Couldn't open interface");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -307,11 +307,11 @@ bool CArchive::Update(QMap<int, QIODevice*> *FileList, bool bDelete, int Level)
|
||||||
CMyComPtr<IArchiveUpdateCallback2> callback(new CArchiveUpdater(this, Files));
|
CMyComPtr<IArchiveUpdateCallback2> callback(new CArchiveUpdater(this, Files));
|
||||||
if(OutArchive->UpdateItems(new CArchiveIO(m_pDevice ? m_pDevice : pFile, QIODevice::WriteOnly, m_pDevice == NULL), FileCount(), callback) != S_OK)
|
if(OutArchive->UpdateItems(new CArchiveIO(m_pDevice ? m_pDevice : pFile, QIODevice::WriteOnly, m_pDevice == NULL), FileCount(), callback) != S_OK)
|
||||||
{
|
{
|
||||||
LogError("Error(s) while updateing Archive");
|
LogError("Error(s) while updating Archive");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
Close(); // close even if it wasnt open to clear the file list
|
Close(); // close even if it wasn't open to clear the file list
|
||||||
if(bUpdate)
|
if(bUpdate)
|
||||||
{
|
{
|
||||||
if(!m_pDevice)
|
if(!m_pDevice)
|
||||||
|
@ -449,7 +449,7 @@ SArcInfo GetArcInfo(const QString &FileName)
|
||||||
ArcInfo.FileName.remove(Pos, ArcInfo.FileName.length()-Pos);
|
ArcInfo.FileName.remove(Pos, ArcInfo.FileName.length()-Pos);
|
||||||
}
|
}
|
||||||
|
|
||||||
// RAR spetial case
|
// RAR special case
|
||||||
if(ArcInfo.ArchiveExt.indexOf(QRegularExpression("(rar|rev|r[0-9]{2,})", QRegularExpression::CaseInsensitiveOption)) == 0)
|
if(ArcInfo.ArchiveExt.indexOf(QRegularExpression("(rar|rev|r[0-9]{2,})", QRegularExpression::CaseInsensitiveOption)) == 0)
|
||||||
{
|
{
|
||||||
if(ArcInfo.ArchiveExt.compare("rar", Qt::CaseInsensitive) == 0 || ArcInfo.ArchiveExt.compare("rev", Qt::CaseInsensitive) == 0) // is this a new naming scheme
|
if(ArcInfo.ArchiveExt.compare("rar", Qt::CaseInsensitive) == 0 || ArcInfo.ArchiveExt.compare("rev", Qt::CaseInsensitive) == 0) // is this a new naming scheme
|
||||||
|
|
|
@ -74,17 +74,17 @@ STDMETHODIMP CArchiveExtractor::SetOperationResult (Int32 operationResult)
|
||||||
break;
|
break;
|
||||||
case NArchive::NExtract::NOperationResult::kUnSupportedMethod:
|
case NArchive::NExtract::NOperationResult::kUnSupportedMethod:
|
||||||
//TRACE(L"... Error (Un Supported Method)");
|
//TRACE(L"... Error (Un Supported Method)");
|
||||||
m_pArchive->LogError(QString("File Extraction Failes (Un Supported Method): %1").arg(m_pArchive->FileProperty(m_Index, "Path").toString()));
|
m_pArchive->LogError(QString("File Extraction Fails (Un Supported Method): %1").arg(m_pArchive->FileProperty(m_Index, "Path").toString()));
|
||||||
m_pArchive->FileProperty(m_Index, "Error", "Un Supported Method");
|
m_pArchive->FileProperty(m_Index, "Error", "Un Supported Method");
|
||||||
break;
|
break;
|
||||||
case NArchive::NExtract::NOperationResult::kCRCError:
|
case NArchive::NExtract::NOperationResult::kCRCError:
|
||||||
//TRACE(L"... Error (CRC)");
|
//TRACE(L"... Error (CRC)");
|
||||||
m_pArchive->LogError(QString("File Extraction Failes (CRC Error): %1").arg(m_pArchive->FileProperty(m_Index, "Path").toString()));
|
m_pArchive->LogError(QString("File Extraction Fails (CRC Error): %1").arg(m_pArchive->FileProperty(m_Index, "Path").toString()));
|
||||||
m_pArchive->FileProperty(m_Index, "Error", "CRC Error");
|
m_pArchive->FileProperty(m_Index, "Error", "CRC Error");
|
||||||
break;
|
break;
|
||||||
case NArchive::NExtract::NOperationResult::kDataError:
|
case NArchive::NExtract::NOperationResult::kDataError:
|
||||||
//TRACE(L"... Error (Data)");
|
//TRACE(L"... Error (Data)");
|
||||||
m_pArchive->LogError(QString("File Extraction Failes (Data Error): %1").arg(m_pArchive->FileProperty(m_Index, "Path").toString()));
|
m_pArchive->LogError(QString("File Extraction Fails (Data Error): %1").arg(m_pArchive->FileProperty(m_Index, "Path").toString()));
|
||||||
m_pArchive->FileProperty(m_Index, "Error", "Data Error");
|
m_pArchive->FileProperty(m_Index, "Error", "Data Error");
|
||||||
break;
|
break;
|
||||||
default: Q_ASSERT(0);
|
default: Q_ASSERT(0);
|
||||||
|
|
|
@ -117,7 +117,7 @@ SPropertyNames::SPropertyNames()
|
||||||
Map.insert(kpidPhySize, "PhySize");
|
Map.insert(kpidPhySize, "PhySize");
|
||||||
Map.insert(kpidHeadersSize, "HeadersSize");
|
Map.insert(kpidHeadersSize, "HeadersSize");
|
||||||
Map.insert(kpidChecksum, "Checksum");
|
Map.insert(kpidChecksum, "Checksum");
|
||||||
Map.insert(kpidCharacts, "Characts");
|
Map.insert(kpidCharacts, "Characters");
|
||||||
Map.insert(kpidVa, "Va");
|
Map.insert(kpidVa, "Va");
|
||||||
Map.insert(kpidId, "Id");
|
Map.insert(kpidId, "Id");
|
||||||
Map.insert(kpidShortName, "ShortName");
|
Map.insert(kpidShortName, "ShortName");
|
||||||
|
|
|
@ -62,7 +62,7 @@ HRESULT IsArchiveItemProp(IInArchive *archive, UInt32 index, PROPID propID, bool
|
||||||
QString GetPropertyName(PROPID PropID);
|
QString GetPropertyName(PROPID PropID);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
DEFINE_GUID(CLSID_7z, 0x23170F69, 0x40C1, 0x278A, 0x10, 0x00, 0x00, 0x01, 0x10, 0x07, 0x00, 0x00); // 7z - 7-Zip Arcive
|
DEFINE_GUID(CLSID_7z, 0x23170F69, 0x40C1, 0x278A, 0x10, 0x00, 0x00, 0x01, 0x10, 0x07, 0x00, 0x00); // 7z - 7-Zip Archive
|
||||||
DEFINE_GUID(CLSID_rar, 0x23170F69, 0x40C1, 0x278A, 0x10, 0x00, 0x00, 0x01, 0x10, 0x03, 0x00, 0x00); // rar r00 - WinRar Archive
|
DEFINE_GUID(CLSID_rar, 0x23170F69, 0x40C1, 0x278A, 0x10, 0x00, 0x00, 0x01, 0x10, 0x03, 0x00, 0x00); // rar r00 - WinRar Archive
|
||||||
DEFINE_GUID(CLSID_cab, 0x23170F69, 0x40C1, 0x278A, 0x10, 0x00, 0x00, 0x01, 0x10, 0x08, 0x00, 0x00); // cab - Cabinet File
|
DEFINE_GUID(CLSID_cab, 0x23170F69, 0x40C1, 0x278A, 0x10, 0x00, 0x00, 0x01, 0x10, 0x08, 0x00, 0x00); // cab - Cabinet File
|
||||||
DEFINE_GUID(CLSID_tar, 0x23170F69, 0x40C1, 0x278A, 0x10, 0x00, 0x00, 0x01, 0x10, 0xEE, 0x00, 0x00); // tar - Tar Archive
|
DEFINE_GUID(CLSID_tar, 0x23170F69, 0x40C1, 0x278A, 0x10, 0x00, 0x00, 0x01, 0x10, 0xEE, 0x00, 0x00); // tar - Tar Archive
|
||||||
|
|
|
@ -40,11 +40,11 @@ public:
|
||||||
|
|
||||||
STDMETHOD(Write)(const void *data, UInt32 size, UInt32 *processedSize)
|
STDMETHOD(Write)(const void *data, UInt32 size, UInt32 *processedSize)
|
||||||
{
|
{
|
||||||
quint64 writen = m_pFile->write((const char*)data, size);
|
quint64 written = m_pFile->write((const char*)data, size);
|
||||||
if(writen == -1)
|
if(written == -1)
|
||||||
return E_FAIL;
|
return E_FAIL;
|
||||||
if(processedSize)
|
if(processedSize)
|
||||||
*processedSize = writen;
|
*processedSize = written;
|
||||||
return S_OK;
|
return S_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -132,7 +132,7 @@ void C7zWorker::OnExtractAllFiles()
|
||||||
m_Lock.Release();
|
m_Lock.Release();
|
||||||
|
|
||||||
SArcInfo Info = GetArcInfo(m_ArchivePath);
|
SArcInfo Info = GetArcInfo(m_ArchivePath);
|
||||||
if(Info.FormatIndex == 0) // not an arcive just a split file
|
if(Info.FormatIndex == 0) // not an archive just a split file
|
||||||
{
|
{
|
||||||
if(!QDir().exists(m_WorkingPath))
|
if(!QDir().exists(m_WorkingPath))
|
||||||
QDir().mkpath(m_WorkingPath);
|
QDir().mkpath(m_WorkingPath);
|
||||||
|
|
|
@ -22,7 +22,7 @@ public:
|
||||||
STDMETHOD(GetStream)(UInt32 index, ISequentialInStream **inStream);
|
STDMETHOD(GetStream)(UInt32 index, ISequentialInStream **inStream);
|
||||||
STDMETHOD(SetOperationResult)(Int32 operationResult) {return S_OK;}
|
STDMETHOD(SetOperationResult)(Int32 operationResult) {return S_OK;}
|
||||||
|
|
||||||
// depricated
|
// deprecated
|
||||||
STDMETHOD(GetVolumeSize)(UInt32 index, UInt64 *size) {return S_FALSE;}
|
STDMETHOD(GetVolumeSize)(UInt32 index, UInt64 *size) {return S_FALSE;}
|
||||||
STDMETHOD(GetVolumeStream)(UInt32 index, ISequentialOutStream **volumeStream) {return S_FALSE;}
|
STDMETHOD(GetVolumeStream)(UInt32 index, ISequentialOutStream **volumeStream) {return S_FALSE;}
|
||||||
|
|
||||||
|
|
|
@ -158,8 +158,8 @@ qint64 CSplitFile::writeData(const char *data, qint64 len)
|
||||||
if(m_Index == -1)
|
if(m_Index == -1)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
quint64 writen = 0;
|
quint64 written = 0;
|
||||||
while(len - writen)
|
while(len - written)
|
||||||
{
|
{
|
||||||
if(m_Index >= m_FileParts.count())
|
if(m_Index >= m_FileParts.count())
|
||||||
{
|
{
|
||||||
|
@ -168,19 +168,19 @@ qint64 CSplitFile::writeData(const char *data, qint64 len)
|
||||||
m_FileParts.append(pFile);
|
m_FileParts.append(pFile);
|
||||||
}
|
}
|
||||||
|
|
||||||
quint64 uToGo = len - writen;
|
quint64 uToGo = len - written;
|
||||||
quint64 uAvail = m_PartSize - m_FileParts[m_Index]->pos();
|
quint64 uAvail = m_PartSize - m_FileParts[m_Index]->pos();
|
||||||
if(uToGo > uAvail)
|
if(uToGo > uAvail)
|
||||||
uToGo = uAvail;
|
uToGo = uAvail;
|
||||||
|
|
||||||
quint64 Tmp = m_FileParts[m_Index]->write(data + writen, uToGo);
|
quint64 Tmp = m_FileParts[m_Index]->write(data + written, uToGo);
|
||||||
if(Tmp == -1)
|
if(Tmp == -1)
|
||||||
return -1;
|
return -1;
|
||||||
writen += Tmp;
|
written += Tmp;
|
||||||
m_Position += Tmp;
|
m_Position += Tmp;
|
||||||
|
|
||||||
if(m_FileParts[m_Index]->pos() >= (qint64)m_PartSize)
|
if(m_FileParts[m_Index]->pos() >= (qint64)m_PartSize)
|
||||||
m_Index++;
|
m_Index++;
|
||||||
}
|
}
|
||||||
return writen;
|
return written;
|
||||||
}
|
}
|
|
@ -288,9 +288,9 @@ QString FormatUnit(quint64 Size, int Precision)
|
||||||
|
|
||||||
//QString FormatTime(quint64 Time, bool ms)
|
//QString FormatTime(quint64 Time, bool ms)
|
||||||
//{
|
//{
|
||||||
// int miliseconds = 0;
|
// int milliseconds = 0;
|
||||||
// if (ms) {
|
// if (ms) {
|
||||||
// miliseconds = Time % 1000;
|
// milliseconds = Time % 1000;
|
||||||
// Time /= 1000;
|
// Time /= 1000;
|
||||||
// }
|
// }
|
||||||
// int seconds = Time % 60;
|
// int seconds = Time % 60;
|
||||||
|
@ -300,7 +300,7 @@ QString FormatUnit(quint64 Size, int Precision)
|
||||||
// int hours = Time % 24;
|
// int hours = Time % 24;
|
||||||
// int days = Time / 24;
|
// int days = Time / 24;
|
||||||
// if(ms && (minutes == 0) && (hours == 0) && (days == 0))
|
// if(ms && (minutes == 0) && (hours == 0) && (days == 0))
|
||||||
// return QString().sprintf("%02d.%04d", seconds, miliseconds);
|
// return QString().sprintf("%02d.%04d", seconds, milliseconds);
|
||||||
// if((hours == 0) && (days == 0))
|
// if((hours == 0) && (days == 0))
|
||||||
// return QString().sprintf("%02d:%02d", minutes, seconds);
|
// return QString().sprintf("%02d:%02d", minutes, seconds);
|
||||||
// if (days == 0)
|
// if (days == 0)
|
||||||
|
|
|
@ -9,7 +9,7 @@
|
||||||
|
|
||||||
bool IsDebuggerAttached()
|
bool IsDebuggerAttached()
|
||||||
{
|
{
|
||||||
bool isDebuggerPresent = false; // Note: on linux change edit the value in debgger to indicate precense
|
bool isDebuggerPresent = false; // Note: on linux change edit the value in debgger to indicate presence
|
||||||
#ifdef WIN32
|
#ifdef WIN32
|
||||||
if (IsDebuggerPresent())
|
if (IsDebuggerPresent())
|
||||||
return true;
|
return true;
|
||||||
|
@ -200,7 +200,7 @@ static LONG __stdcall MyCrashHandlerExceptionFilter(EXCEPTION_POINTERS* pEx)
|
||||||
#ifdef _M_IX86
|
#ifdef _M_IX86
|
||||||
if (pEx->ExceptionRecord->ExceptionCode == EXCEPTION_STACK_OVERFLOW)
|
if (pEx->ExceptionRecord->ExceptionCode == EXCEPTION_STACK_OVERFLOW)
|
||||||
{
|
{
|
||||||
// be sure that we have enought space...
|
// be sure that we have enough space...
|
||||||
static char MyStack[1024*128];
|
static char MyStack[1024*128];
|
||||||
// it assumes that DS and SS are the same!!! (this is the case for Win32)
|
// it assumes that DS and SS are the same!!! (this is the case for Win32)
|
||||||
// change the stack only if the selectors are the same (this is the case for Win32)
|
// change the stack only if the selectors are the same (this is the case for Win32)
|
||||||
|
|
|
@ -111,7 +111,7 @@ public:
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// fill whats left of the line
|
// fill what's left of the line
|
||||||
/*top *= 4;
|
/*top *= 4;
|
||||||
if (top < m_Graph.bytesPerLine()) // fill rest white
|
if (top < m_Graph.bytesPerLine()) // fill rest white
|
||||||
memset(dest + top, 0xFF, m_Graph.bytesPerLine() - top);*/
|
memset(dest + top, 0xFF, m_Graph.bytesPerLine() - top);*/
|
||||||
|
|
|
@ -8,8 +8,8 @@
|
||||||
/**********************************************************************************************
|
/**********************************************************************************************
|
||||||
* CThreadLock
|
* CThreadLock
|
||||||
* This class allows to wait for events form a differet thread.
|
* This class allows to wait for events form a differet thread.
|
||||||
* When Lock returns successfuly it is guaranted that the other thread have issued a release.
|
* When Lock returns successfully it is guaranteed that the other thread have issued a release.
|
||||||
* This works undependant of the real order Lock and Release ware calles
|
* This works undependant of the real order Lock and Release ware called
|
||||||
*/
|
*/
|
||||||
|
|
||||||
class MISCHELPERS_EXPORT CThreadLock
|
class MISCHELPERS_EXPORT CThreadLock
|
||||||
|
|
|
@ -112,7 +112,7 @@ QStringList CPanelView::CopyHeader()
|
||||||
QAbstractItemModel* pModel = GetModel();
|
QAbstractItemModel* pModel = GetModel();
|
||||||
QTreeView * pView = GetView();
|
QTreeView * pView = GetView();
|
||||||
|
|
||||||
QStringList Headder;
|
QStringList Header;
|
||||||
for (int i = 0; i < pModel->columnCount(); i++)
|
for (int i = 0; i < pModel->columnCount(); i++)
|
||||||
{
|
{
|
||||||
if (/*!m_CopyAll &&*/ pView->isColumnHidden(i) && !m_ForcedColumns.contains(i))
|
if (/*!m_CopyAll &&*/ pView->isColumnHidden(i) && !m_ForcedColumns.contains(i))
|
||||||
|
@ -120,9 +120,9 @@ QStringList CPanelView::CopyHeader()
|
||||||
QString Cell = pModel->headerData(i, Qt::Horizontal, Qt::DisplayRole).toString();
|
QString Cell = pModel->headerData(i, Qt::Horizontal, Qt::DisplayRole).toString();
|
||||||
if (!m_SimpleFormat)
|
if (!m_SimpleFormat)
|
||||||
Cell = "|" + Cell + "|";
|
Cell = "|" + Cell + "|";
|
||||||
Headder.append(Cell);
|
Header.append(Cell);
|
||||||
}
|
}
|
||||||
return Headder;
|
return Header;
|
||||||
}
|
}
|
||||||
|
|
||||||
QStringList CPanelView::CopyRow(const QModelIndex& ModelIndex, int Level)
|
QStringList CPanelView::CopyRow(const QModelIndex& ModelIndex, int Level)
|
||||||
|
@ -176,11 +176,11 @@ void CPanelView::OnCopyPanel()
|
||||||
FormatAndCopy(DumpPanel());
|
FormatAndCopy(DumpPanel());
|
||||||
}
|
}
|
||||||
|
|
||||||
void CPanelView::FormatAndCopy(QList<QStringList> Rows, bool Headder)
|
void CPanelView::FormatAndCopy(QList<QStringList> Rows, bool Header)
|
||||||
{
|
{
|
||||||
int RowCount = Rows.length();
|
int RowCount = Rows.length();
|
||||||
|
|
||||||
if (Headder)
|
if (Header)
|
||||||
{
|
{
|
||||||
Rows.prepend(QStringList());
|
Rows.prepend(QStringList());
|
||||||
Rows.prepend(CopyHeader());
|
Rows.prepend(CopyHeader());
|
||||||
|
@ -188,14 +188,14 @@ void CPanelView::FormatAndCopy(QList<QStringList> Rows, bool Headder)
|
||||||
}
|
}
|
||||||
|
|
||||||
QStringList TextRows;
|
QStringList TextRows;
|
||||||
if (m_SimpleFormat || !Headder)
|
if (m_SimpleFormat || !Header)
|
||||||
{
|
{
|
||||||
foreach(const QStringList& Row, Rows)
|
foreach(const QStringList& Row, Rows)
|
||||||
TextRows.append(Row.join(m_CellSeparator));
|
TextRows.append(Row.join(m_CellSeparator));
|
||||||
}
|
}
|
||||||
else if(Rows.size() > (Headder ? 3 : 0))
|
else if(Rows.size() > (Header ? 3 : 0))
|
||||||
{
|
{
|
||||||
int Columns = Rows[Headder ? 3 : 0].count();
|
int Columns = Rows[Header ? 3 : 0].count();
|
||||||
QVector<int> ColumnWidths(Columns, 0);
|
QVector<int> ColumnWidths(Columns, 0);
|
||||||
|
|
||||||
foreach(const QStringList& Row, Rows)
|
foreach(const QStringList& Row, Rows)
|
||||||
|
|
|
@ -48,7 +48,7 @@ protected slots:
|
||||||
protected:
|
protected:
|
||||||
void UpdateCopyMenu();
|
void UpdateCopyMenu();
|
||||||
void AddCopyMenu(QMenu* pMenu, bool bAddSeparator = true);
|
void AddCopyMenu(QMenu* pMenu, bool bAddSeparator = true);
|
||||||
void FormatAndCopy(QList<QStringList> Rows, bool Headder = true);
|
void FormatAndCopy(QList<QStringList> Rows, bool Header = true);
|
||||||
|
|
||||||
QMenu* m_pMenu;
|
QMenu* m_pMenu;
|
||||||
|
|
||||||
|
|
|
@ -10,7 +10,7 @@ class MISCHELPERS_EXPORT CSortFilterProxyModel: public QSortFilterProxyModel
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
|
|
||||||
public:
|
public:
|
||||||
CSortFilterProxyModel(QObject* parrent = 0) : QSortFilterProxyModel(parrent)
|
CSortFilterProxyModel(QObject* parent = 0) : QSortFilterProxyModel(parent)
|
||||||
{
|
{
|
||||||
m_bHighLight = false;
|
m_bHighLight = false;
|
||||||
m_iColumn = 0;
|
m_iColumn = 0;
|
||||||
|
|
|
@ -49,7 +49,7 @@ CSplitTreeView::CSplitTreeView(QAbstractItemModel* pModel, QWidget *parent) : QW
|
||||||
|
|
||||||
|
|
||||||
// List
|
// List
|
||||||
// Note: It would be convinient to use QTreeViewEx here but qt does not scale well when there are too many columns
|
// Note: It would be convenient to use QTreeViewEx here but qt does not scale well when there are too many columns
|
||||||
// hence we will add and remove columns at the model level directly.
|
// hence we will add and remove columns at the model level directly.
|
||||||
// This way we can get out operational CPU usage to be quite comparable with TaskInfo na other advanced task managers
|
// This way we can get out operational CPU usage to be quite comparable with TaskInfo na other advanced task managers
|
||||||
// Plus there are to many columns to cram them into one simple context menu :-)
|
// Plus there are to many columns to cram them into one simple context menu :-)
|
||||||
|
|
|
@ -9,7 +9,7 @@ class MISCHELPERS_EXPORT COneColumnModel : public QIdentityProxyModel
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
public:
|
public:
|
||||||
COneColumnModel( QObject* parrent = 0) : QIdentityProxyModel(parrent) {}
|
COneColumnModel( QObject* parent = 0) : QIdentityProxyModel(parent) {}
|
||||||
|
|
||||||
int columnCount(const QModelIndex &parent = QModelIndex()) const { return 1; }
|
int columnCount(const QModelIndex &parent = QModelIndex()) const { return 1; }
|
||||||
};
|
};
|
||||||
|
|
|
@ -214,7 +214,7 @@ void CTreeItemModel::Purge(STreeNode* pParent, const QModelIndex &parent, QHash<
|
||||||
pNode->Icon.clear();
|
pNode->Icon.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
if(End != -1) // remove whats to be removed at once
|
if(End != -1) // remove what's to be removed at once
|
||||||
{
|
{
|
||||||
Begin = i + 1;
|
Begin = i + 1;
|
||||||
|
|
||||||
|
|
|
@ -256,7 +256,7 @@ struct SQVariants{
|
||||||
Map.insert("Point" , 25);
|
Map.insert("Point" , 25);
|
||||||
Map.insert("PointF" , 26);
|
Map.insert("PointF" , 26);
|
||||||
Map.insert("RegExp" , 27);*/
|
Map.insert("RegExp" , 27);*/
|
||||||
Map.insert("Hash" , QVariant::Hash); // conainter type
|
Map.insert("Hash" , QVariant::Hash); // container type
|
||||||
|
|
||||||
/*Map.insert("Font" , 64);
|
/*Map.insert("Font" , 64);
|
||||||
Map.insert("Pixmap" , 65);
|
Map.insert("Pixmap" , 65);
|
||||||
|
|
|
@ -308,8 +308,8 @@ void CBoxBorder::TimerProc()
|
||||||
|
|
||||||
//
|
//
|
||||||
// in windows 10 and 11 if this is truly fullscreen the taskbar does not appear when hidden
|
// in windows 10 and 11 if this is truly fullscreen the taskbar does not appear when hidden
|
||||||
// if its 1 px less on any side it works normally, so we pick bottom as thets where the taskbar usualyl is
|
// if its 1 px less on any side it works normally, so we pick bottom as that's where the taskbar usually is
|
||||||
// but with the taskbar to the side it woudl also work
|
// but with the taskbar to the side it would also work
|
||||||
//
|
//
|
||||||
|
|
||||||
if (rect.bottom == Monitor.rcWork.bottom)
|
if (rect.bottom == Monitor.rcWork.bottom)
|
||||||
|
|
|
@ -255,7 +255,7 @@ bool CBoxedProcess::InitProcessInfo()
|
||||||
#undef ProcessCommandLineInformation
|
#undef ProcessCommandLineInformation
|
||||||
}
|
}
|
||||||
|
|
||||||
if (m_CommandLine.isEmpty()) // fall back to teh win 7 method - requirers PROCESS_VM_READ
|
if (m_CommandLine.isEmpty()) // fall back to the win 7 method - requirers PROCESS_VM_READ
|
||||||
{
|
{
|
||||||
m_CommandLine = CBoxedProcess__GetPebString(ProcessHandle, PhpoCommandLine);
|
m_CommandLine = CBoxedProcess__GetPebString(ProcessHandle, PhpoCommandLine);
|
||||||
}
|
}
|
||||||
|
@ -330,7 +330,7 @@ bool CBoxedProcess::IsSuspended() const
|
||||||
{
|
{
|
||||||
bool isSuspended = true;
|
bool isSuspended = true;
|
||||||
|
|
||||||
// todo: do that globaly once per sec for all boxed processes
|
// todo: do that globally once per sec for all boxed processes
|
||||||
|
|
||||||
// Note: If the specified process is a 64-bit process and the caller is a 32-bit process, this function fails and the last error code is ERROR_PARTIAL_COPY (299).
|
// Note: If the specified process is a 64-bit process and the caller is a 32-bit process, this function fails and the last error code is ERROR_PARTIAL_COPY (299).
|
||||||
HANDLE hThreadSnap = CreateToolhelp32Snapshot(TH32CS_SNAPTHREAD, 0);
|
HANDLE hThreadSnap = CreateToolhelp32Snapshot(TH32CS_SNAPTHREAD, 0);
|
||||||
|
|
|
@ -268,7 +268,7 @@ SB_STATUS CSbieIni::RenameSection( const QString& NewName, bool deleteOld) // No
|
||||||
}
|
}
|
||||||
|
|
||||||
// if the name is the same we first delete than write,
|
// if the name is the same we first delete than write,
|
||||||
// else we first write and than delete, fro safety reasons
|
// else we first write and than delete, for safety reasons
|
||||||
if (deleteOld && SameName)
|
if (deleteOld && SameName)
|
||||||
goto do_delete;
|
goto do_delete;
|
||||||
|
|
||||||
|
|
|
@ -93,7 +93,7 @@ void CBoxMonitor::run()
|
||||||
|
|
||||||
void CBoxMonitor::UpdateBox(const QString& Path)
|
void CBoxMonitor::UpdateBox(const QString& Path)
|
||||||
{
|
{
|
||||||
// Note: this private functin runs in the main thread
|
// Note: this private function runs in the main thread
|
||||||
|
|
||||||
m_Mutex.lock();
|
m_Mutex.lock();
|
||||||
SBox Box = m_Boxes.value(Path);
|
SBox Box = m_Boxes.value(Path);
|
||||||
|
|
|
@ -79,7 +79,7 @@ static BOOL CALLBACK FindBestChildProc(HWND hwnd, LPARAM lParam)
|
||||||
// the smallest window that fits, in fact.
|
// the smallest window that fits, in fact.
|
||||||
//
|
//
|
||||||
// I've tested this on a lot of different apps, and it seems
|
// I've tested this on a lot of different apps, and it seems
|
||||||
// to work flawlessly - in fact, I havn't found a situation yet
|
// to work flawlessly - in fact, I haven't found a situation yet
|
||||||
// that this method doesn't work on.....we'll see!
|
// that this method doesn't work on.....we'll see!
|
||||||
//
|
//
|
||||||
// Inputs:
|
// Inputs:
|
||||||
|
|
|
@ -1494,7 +1494,7 @@ SB_STATUS CSandMan::DeleteBoxContent(const CSandBoxPtr& pBox, EDelMode Mode, boo
|
||||||
|
|
||||||
{
|
{
|
||||||
SB_PROGRESS Status;
|
SB_PROGRESS Status;
|
||||||
if (Mode != eForDelete && !DeleteShapshots && pBox->HasSnapshots()) { // in auto delete mdoe always return to last snapshot
|
if (Mode != eForDelete && !DeleteShapshots && pBox->HasSnapshots()) { // in auto delete mode always return to last snapshot
|
||||||
QString Current;
|
QString Current;
|
||||||
QString Default = pBox->GetDefaultSnapshot(&Current);
|
QString Default = pBox->GetDefaultSnapshot(&Current);
|
||||||
Status = pBox->SelectSnapshot(Mode == eAuto ? Current : Default);
|
Status = pBox->SelectSnapshot(Mode == eAuto ? Current : Default);
|
||||||
|
@ -1997,11 +1997,11 @@ void CSandMan::OnLogSbieMessage(quint32 MsgCode, const QStringList& MsgData, qui
|
||||||
|
|
||||||
OnLogMessage(Message);
|
OnLogMessage(Message);
|
||||||
|
|
||||||
if ((MsgCode & 0xFFFF) == 6004) // certificat error
|
if ((MsgCode & 0xFFFF) == 6004) // certificate error
|
||||||
return; // dont pop that one up
|
return; // don't pop that one up
|
||||||
|
|
||||||
if ((MsgCode & 0xFFFF) == 2111) // process open denided
|
if ((MsgCode & 0xFFFF) == 2111) // process open denided
|
||||||
return; // dont pop that one up
|
return; // don't pop that one up
|
||||||
|
|
||||||
if(MsgCode != 0 && theConf->GetBool("Options/ShowNotifications", true) && !IsDisableMessages())
|
if(MsgCode != 0 && theConf->GetBool("Options/ShowNotifications", true) && !IsDisableMessages())
|
||||||
m_pPopUpWindow->AddLogMessage(Message, MsgCode, MsgData, ProcessId);
|
m_pPopUpWindow->AddLogMessage(Message, MsgCode, MsgData, ProcessId);
|
||||||
|
|
|
@ -29,7 +29,7 @@ bool CSandMan::OpenRecovery(const CSandBoxPtr& pBox, bool& DeleteShapshots, bool
|
||||||
if (!pBoxEx) return false;
|
if (!pBoxEx) return false;
|
||||||
if (pBoxEx->m_pRecoveryWnd != NULL) {
|
if (pBoxEx->m_pRecoveryWnd != NULL) {
|
||||||
pBoxEx->m_pRecoveryWnd->close();
|
pBoxEx->m_pRecoveryWnd->close();
|
||||||
// todo: resuse window?
|
// todo: reuse window?
|
||||||
}
|
}
|
||||||
|
|
||||||
CRecoveryWindow* pRecoveryWindow = new CRecoveryWindow(pBox, false, this);
|
CRecoveryWindow* pRecoveryWindow = new CRecoveryWindow(pBox, false, this);
|
||||||
|
|
|
@ -410,7 +410,7 @@ void CSandMan::OnSysTray(QSystemTrayIcon::ActivationReason Reason)
|
||||||
|
|
||||||
bool bAdded = false;
|
bool bAdded = false;
|
||||||
if (m_pTrayBoxes->topLevelItemCount() == 0)
|
if (m_pTrayBoxes->topLevelItemCount() == 0)
|
||||||
bAdded = true; // triger size refresh
|
bAdded = true; // trigger size refresh
|
||||||
|
|
||||||
QMap<QString, QTreeWidgetItem*> OldBoxes;
|
QMap<QString, QTreeWidgetItem*> OldBoxes;
|
||||||
for (int i = 0; i < m_pTrayBoxes->topLevelItemCount(); ++i)
|
for (int i = 0; i < m_pTrayBoxes->topLevelItemCount(); ++i)
|
||||||
|
|
|
@ -267,7 +267,7 @@ void CFileView::OnFileMenu(const QPoint&)
|
||||||
QString LinkName = LinkPath.mid(LinkPath.lastIndexOf("\\") + 1);
|
QString LinkName = LinkPath.mid(LinkPath.lastIndexOf("\\") + 1);
|
||||||
|
|
||||||
QString Path = QStandardPaths::writableLocation(QStandardPaths::DesktopLocation).replace("/", "\\");
|
QString Path = QStandardPaths::writableLocation(QStandardPaths::DesktopLocation).replace("/", "\\");
|
||||||
//Path = QFileDialog::getExistingDirectory(this, tr("Select Directory to create Shorcut in"), Path).replace("/", "\\");
|
//Path = QFileDialog::getExistingDirectory(this, tr("Select Directory to create Shortcut in"), Path).replace("/", "\\");
|
||||||
//if (Path.isEmpty())
|
//if (Path.isEmpty())
|
||||||
// return;
|
// return;
|
||||||
|
|
||||||
|
|
|
@ -843,7 +843,7 @@ void CSbieView::OnGroupAction(QAction* Action)
|
||||||
{
|
{
|
||||||
QString Group = m_pSbieModel->GetID(ModelIndex).toString();
|
QString Group = m_pSbieModel->GetID(ModelIndex).toString();
|
||||||
|
|
||||||
QStringList Items = m_Groups.take(Group); // remove groupe
|
QStringList Items = m_Groups.take(Group); // remove group
|
||||||
|
|
||||||
// remove from parents
|
// remove from parents
|
||||||
for (auto I = m_Groups.begin(); I != m_Groups.end(); ++I) {
|
for (auto I = m_Groups.begin(); I != m_Groups.end(); ++I) {
|
||||||
|
@ -899,7 +899,7 @@ void CSbieView::OnGroupAction(QAction* Action)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else // move to groupe
|
else // move to group
|
||||||
{
|
{
|
||||||
QString Group = Action->data().toString();
|
QString Group = Action->data().toString();
|
||||||
|
|
||||||
|
@ -1391,7 +1391,7 @@ void CSbieView::OnSandBoxAction(QAction* Action, const QList<CSandBoxPtr>& SandB
|
||||||
}
|
}
|
||||||
|
|
||||||
QString Path = QStandardPaths::writableLocation(QStandardPaths::DesktopLocation).replace("/", "\\");
|
QString Path = QStandardPaths::writableLocation(QStandardPaths::DesktopLocation).replace("/", "\\");
|
||||||
//Path = QFileDialog::getExistingDirectory(this, tr("Select Directory to create Shorcut in"), Path).replace("/", "\\");
|
//Path = QFileDialog::getExistingDirectory(this, tr("Select Directory to create Shortcut in"), Path).replace("/", "\\");
|
||||||
//if (Path.isEmpty())
|
//if (Path.isEmpty())
|
||||||
// return;
|
// return;
|
||||||
|
|
||||||
|
@ -1461,7 +1461,7 @@ void CSbieView::OnProcessAction(QAction* Action, const QList<CBoxedProcessPtr>&
|
||||||
QString LinkPath = pProcess->GetFileName();
|
QString LinkPath = pProcess->GetFileName();
|
||||||
|
|
||||||
QString Path = QStandardPaths::writableLocation(QStandardPaths::DesktopLocation).replace("/", "\\");
|
QString Path = QStandardPaths::writableLocation(QStandardPaths::DesktopLocation).replace("/", "\\");
|
||||||
//Path = QFileDialog::getExistingDirectory(this, tr("Select Directory to create Shorcut in"), Path).replace("/", "\\");
|
//Path = QFileDialog::getExistingDirectory(this, tr("Select Directory to create Shortcut in"), Path).replace("/", "\\");
|
||||||
//if (Path.isEmpty())
|
//if (Path.isEmpty())
|
||||||
// return;
|
// return;
|
||||||
|
|
||||||
|
|
|
@ -10,7 +10,7 @@
|
||||||
//class CTraceFilterProxyModel : public CSortFilterProxyModel
|
//class CTraceFilterProxyModel : public CSortFilterProxyModel
|
||||||
//{
|
//{
|
||||||
//public:
|
//public:
|
||||||
// CTraceFilterProxyModel(QObject* parrent = 0) : CSortFilterProxyModel(parrent)
|
// CTraceFilterProxyModel(QObject* parent = 0) : CSortFilterProxyModel(parent)
|
||||||
// {
|
// {
|
||||||
// m_FilterPid = 0;
|
// m_FilterPid = 0;
|
||||||
// m_FilterTid = 0;
|
// m_FilterTid = 0;
|
||||||
|
|
|
@ -40,7 +40,7 @@ CNewBoxWindow::CNewBoxWindow(QWidget *parent)
|
||||||
ui.cmbBoxType->addItem(theGUI->GetBoxIcon(CSandBoxPlus::eHardened), tr("Security Hardened Sandbox"), (int)CSandBoxPlus::eHardened);
|
ui.cmbBoxType->addItem(theGUI->GetBoxIcon(CSandBoxPlus::eHardened), tr("Security Hardened Sandbox"), (int)CSandBoxPlus::eHardened);
|
||||||
ui.cmbBoxType->addItem(theGUI->GetBoxIcon(CSandBoxPlus::eDefaultPlus), tr("Sandbox with Data Protection"), (int)CSandBoxPlus::eDefaultPlus);
|
ui.cmbBoxType->addItem(theGUI->GetBoxIcon(CSandBoxPlus::eDefaultPlus), tr("Sandbox with Data Protection"), (int)CSandBoxPlus::eDefaultPlus);
|
||||||
ui.cmbBoxType->addItem(theGUI->GetBoxIcon(CSandBoxPlus::eDefault), tr("Standard Isolation Sandbox (Default)"), (int)CSandBoxPlus::eDefault);
|
ui.cmbBoxType->addItem(theGUI->GetBoxIcon(CSandBoxPlus::eDefault), tr("Standard Isolation Sandbox (Default)"), (int)CSandBoxPlus::eDefault);
|
||||||
//ui.cmbBoxType->addItem(theGUI->GetBoxIcon(CSandBoxPlus::eInsecure), tr("UNSECURE Configuration (please change)"), (int)CSandBoxPlus::eInsecure);
|
//ui.cmbBoxType->addItem(theGUI->GetBoxIcon(CSandBoxPlus::eInsecure), tr("INSECURE Configuration (please change)"), (int)CSandBoxPlus::eInsecure);
|
||||||
ui.cmbBoxType->addItem(theGUI->GetBoxIcon(CSandBoxPlus::eAppBoxPlus), tr("Application Compartment with Data Protection"), (int)CSandBoxPlus::eAppBoxPlus);
|
ui.cmbBoxType->addItem(theGUI->GetBoxIcon(CSandBoxPlus::eAppBoxPlus), tr("Application Compartment with Data Protection"), (int)CSandBoxPlus::eAppBoxPlus);
|
||||||
ui.cmbBoxType->addItem(theGUI->GetBoxIcon(CSandBoxPlus::eAppBox), tr("Application Compartment (NO Isolation)"), (int)CSandBoxPlus::eAppBox);
|
ui.cmbBoxType->addItem(theGUI->GetBoxIcon(CSandBoxPlus::eAppBox), tr("Application Compartment (NO Isolation)"), (int)CSandBoxPlus::eAppBox);
|
||||||
|
|
||||||
|
|
|
@ -391,7 +391,7 @@ void COptionsWindow::AddAccessEntry(EAccessType Type, EAccessMode Mode, QString
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////
|
||||||
// File and Registry entries auto append a '*' wildcard
|
// File and Registry entries auto append a '*' wildcard
|
||||||
// when thay don't contain any.
|
// when they don't contain any.
|
||||||
// Prepanding '|' disables this behavioure
|
// Prepanding '|' disables this behavioure
|
||||||
//
|
//
|
||||||
|
|
||||||
|
|
|
@ -56,7 +56,7 @@ void COptionsWindow::CreateGeneral()
|
||||||
ui.cmbBoxType->addItem(theGUI->GetBoxIcon(CSandBoxPlus::eHardened), tr("Security Hardened Sandbox"), (int)CSandBoxPlus::eHardened);
|
ui.cmbBoxType->addItem(theGUI->GetBoxIcon(CSandBoxPlus::eHardened), tr("Security Hardened Sandbox"), (int)CSandBoxPlus::eHardened);
|
||||||
ui.cmbBoxType->addItem(theGUI->GetBoxIcon(CSandBoxPlus::eDefaultPlus), tr("Sandbox with Data Protection"), (int)CSandBoxPlus::eDefaultPlus);
|
ui.cmbBoxType->addItem(theGUI->GetBoxIcon(CSandBoxPlus::eDefaultPlus), tr("Sandbox with Data Protection"), (int)CSandBoxPlus::eDefaultPlus);
|
||||||
ui.cmbBoxType->addItem(theGUI->GetBoxIcon(CSandBoxPlus::eDefault), tr("Standard Isolation Sandbox (Default)"), (int)CSandBoxPlus::eDefault);
|
ui.cmbBoxType->addItem(theGUI->GetBoxIcon(CSandBoxPlus::eDefault), tr("Standard Isolation Sandbox (Default)"), (int)CSandBoxPlus::eDefault);
|
||||||
//ui.cmbBoxType->addItem(theGUI->GetBoxIcon(CSandBoxPlus::eInsecure), tr("UNSECURE Configuration (please change)"), (int)CSandBoxPlus::eInsecure);
|
//ui.cmbBoxType->addItem(theGUI->GetBoxIcon(CSandBoxPlus::eInsecure), tr("INSECURE Configuration (please change)"), (int)CSandBoxPlus::eInsecure);
|
||||||
ui.cmbBoxType->addItem(theGUI->GetBoxIcon(CSandBoxPlus::eAppBoxPlus), tr("Application Compartment with Data Protection"), (int)CSandBoxPlus::eAppBoxPlus);
|
ui.cmbBoxType->addItem(theGUI->GetBoxIcon(CSandBoxPlus::eAppBoxPlus), tr("Application Compartment with Data Protection"), (int)CSandBoxPlus::eAppBoxPlus);
|
||||||
ui.cmbBoxType->addItem(theGUI->GetBoxIcon(CSandBoxPlus::eAppBox), tr("Application Compartment (NO Isolation)"), (int)CSandBoxPlus::eAppBox);
|
ui.cmbBoxType->addItem(theGUI->GetBoxIcon(CSandBoxPlus::eAppBox), tr("Application Compartment (NO Isolation)"), (int)CSandBoxPlus::eAppBox);
|
||||||
|
|
||||||
|
|
|
@ -123,7 +123,7 @@ void COptionsWindow::SaveGroups()
|
||||||
QTreeWidgetItem* pItem = ui.treeGroups->topLevelItem(i);
|
QTreeWidgetItem* pItem = ui.treeGroups->topLevelItem(i);
|
||||||
QString GroupName = pItem->data(0, Qt::UserRole).toString();
|
QString GroupName = pItem->data(0, Qt::UserRole).toString();
|
||||||
if (GroupName.isEmpty())
|
if (GroupName.isEmpty())
|
||||||
continue; // this is a template entry, dont save
|
continue; // this is a template entry, don't save
|
||||||
QStringList Programs;
|
QStringList Programs;
|
||||||
for (int j = 0; j < pItem->childCount(); j++)
|
for (int j = 0; j < pItem->childCount(); j++)
|
||||||
Programs.append(pItem->child(j)->data(0, Qt::UserRole).toString());
|
Programs.append(pItem->child(j)->data(0, Qt::UserRole).toString());
|
||||||
|
@ -265,12 +265,12 @@ void COptionsWindow::OnDelProg()
|
||||||
OnOptChanged();
|
OnOptChanged();
|
||||||
}
|
}
|
||||||
|
|
||||||
void COptionsWindow::CopyGroupToList(const QString& Groupe, QTreeWidget* pTree, bool disabled)
|
void COptionsWindow::CopyGroupToList(const QString& Group, QTreeWidget* pTree, bool disabled)
|
||||||
{
|
{
|
||||||
for (int i = 0; i < ui.treeGroups->topLevelItemCount(); i++)
|
for (int i = 0; i < ui.treeGroups->topLevelItemCount(); i++)
|
||||||
{
|
{
|
||||||
QTreeWidgetItem* pItem = ui.treeGroups->topLevelItem(i);
|
QTreeWidgetItem* pItem = ui.treeGroups->topLevelItem(i);
|
||||||
if (pItem->data(0, Qt::UserRole).toString().compare(Groupe, Qt::CaseInsensitive) == 0)
|
if (pItem->data(0, Qt::UserRole).toString().compare(Group, Qt::CaseInsensitive) == 0)
|
||||||
{
|
{
|
||||||
for (int j = 0; j < pItem->childCount(); j++)
|
for (int j = 0; j < pItem->childCount(); j++)
|
||||||
{
|
{
|
||||||
|
|
|
@ -44,7 +44,7 @@ void COptionsWindow::CreateNetwork()
|
||||||
void COptionsWindow::LoadINetAccess()
|
void COptionsWindow::LoadINetAccess()
|
||||||
{
|
{
|
||||||
m_IsEnabledWFP = m_pBox->GetAPI()->GetGlobalSettings()->GetBool("NetworkEnableWFP", false);
|
m_IsEnabledWFP = m_pBox->GetAPI()->GetGlobalSettings()->GetBool("NetworkEnableWFP", false);
|
||||||
// check if we are blockign globaly and if so adapt the behavioure accordingly
|
// check if we are blockign globally and if so adapt the behavioure accordingly
|
||||||
m_WFPisBlocking = !m_pBox->GetAPI()->GetGlobalSettings()->GetBool("AllowNetworkAccess", true);
|
m_WFPisBlocking = !m_pBox->GetAPI()->GetGlobalSettings()->GetBool("AllowNetworkAccess", true);
|
||||||
|
|
||||||
ui.lblNoWfp->setVisible(!m_IsEnabledWFP); // warn user that this is only user mode
|
ui.lblNoWfp->setVisible(!m_IsEnabledWFP); // warn user that this is only user mode
|
||||||
|
@ -918,7 +918,7 @@ void COptionsWindow::OnTestNetFwRule()
|
||||||
|
|
||||||
//
|
//
|
||||||
// rule merging
|
// rule merging
|
||||||
// if the rule is for the same prog and has teh same action
|
// if the rule is for the same prog and has the same action
|
||||||
// merge all rules with ip only together
|
// merge all rules with ip only together
|
||||||
// merge all rules with ports only together
|
// merge all rules with ports only together
|
||||||
//
|
//
|
||||||
|
|
|
@ -124,7 +124,7 @@ void COptionsWindow::ShowTemplates()
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
if (I.key().isEmpty())
|
if (I.key().isEmpty())
|
||||||
continue; // dont show templates without a category (these are usually deprecated templates)
|
continue; // don't show templates without a category (these are usually deprecated templates)
|
||||||
|
|
||||||
QString Name = I.value().first.mid(9);
|
QString Name = I.value().first.mid(9);
|
||||||
|
|
||||||
|
|
|
@ -380,7 +380,7 @@ COptionsWindow::COptionsWindow(const QSharedPointer<CSbieIni>& pBox, const QStri
|
||||||
|
|
||||||
CreateGeneral();
|
CreateGeneral();
|
||||||
|
|
||||||
// Groupes
|
// Groups
|
||||||
connect(ui.btnAddGroup, SIGNAL(clicked(bool)), this, SLOT(OnAddGroup()));
|
connect(ui.btnAddGroup, SIGNAL(clicked(bool)), this, SLOT(OnAddGroup()));
|
||||||
connect(ui.btnAddProg, SIGNAL(clicked(bool)), this, SLOT(OnAddProg()));
|
connect(ui.btnAddProg, SIGNAL(clicked(bool)), this, SLOT(OnAddProg()));
|
||||||
connect(ui.btnDelProg, SIGNAL(clicked(bool)), this, SLOT(OnDelProg()));
|
connect(ui.btnDelProg, SIGNAL(clicked(bool)), this, SLOT(OnDelProg()));
|
||||||
|
@ -1151,7 +1151,7 @@ void COptionsWindow::SaveIniSection()
|
||||||
void COptionsWindow::TriggerPathReload()
|
void COptionsWindow::TriggerPathReload()
|
||||||
{
|
{
|
||||||
//
|
//
|
||||||
// this message makes all boxes reload thair path presets
|
// this message makes all boxes reload their path presets
|
||||||
//
|
//
|
||||||
|
|
||||||
DWORD bsm_app = BSM_APPLICATIONS;
|
DWORD bsm_app = BSM_APPLICATIONS;
|
||||||
|
|
|
@ -308,7 +308,7 @@ protected:
|
||||||
bool DelProgramFromGroup(const QString& Program, const QString& Group);
|
bool DelProgramFromGroup(const QString& Program, const QString& Group);
|
||||||
QTreeWidgetItem* FindGroupByName(const QString& Group, bool bAdd = false);
|
QTreeWidgetItem* FindGroupByName(const QString& Group, bool bAdd = false);
|
||||||
|
|
||||||
void CopyGroupToList(const QString& Groupe, QTreeWidget* pTree, bool disabled = false);
|
void CopyGroupToList(const QString& Group, QTreeWidget* pTree, bool disabled = false);
|
||||||
QTreeWidgetItem* GetAccessEntry(EAccessType Type, const QString& Program, EAccessMode Mode, const QString& Path);
|
QTreeWidgetItem* GetAccessEntry(EAccessType Type, const QString& Program, EAccessMode Mode, const QString& Path);
|
||||||
void SetAccessEntry(EAccessType Type, const QString& Program, EAccessMode Mode, const QString& Path);
|
void SetAccessEntry(EAccessType Type, const QString& Program, EAccessMode Mode, const QString& Path);
|
||||||
void DelAccessEntry(EAccessType Type, const QString& Program, EAccessMode Mode, const QString& Path);
|
void DelAccessEntry(EAccessType Type, const QString& Program, EAccessMode Mode, const QString& Path);
|
||||||
|
|
|
@ -49,7 +49,7 @@ void FixTriStateBoxPallete(QWidget* pWidget)
|
||||||
if (QApplication::style()->objectName() == "windows") {
|
if (QApplication::style()->objectName() == "windows") {
|
||||||
|
|
||||||
//
|
//
|
||||||
// the built in "windows" theme of Qt does not properly renderd PartiallyChecked
|
// the built in "windows" theme of Qt does not properly rendered PartiallyChecked
|
||||||
// checkboxes, to remedi this issue we connect to the stateChanged slot
|
// checkboxes, to remedi this issue we connect to the stateChanged slot
|
||||||
// and change the pattern to improve the rendering.
|
// and change the pattern to improve the rendering.
|
||||||
//
|
//
|
||||||
|
|
|
@ -174,7 +174,7 @@ union SCertInfo {
|
||||||
valid : 1, // certificate is active
|
valid : 1, // certificate is active
|
||||||
expired : 1, // certificate is expired but may be active
|
expired : 1, // certificate is expired but may be active
|
||||||
outdated : 1, // certificate is expired, not anymore valid for the current build
|
outdated : 1, // certificate is expired, not anymore valid for the current build
|
||||||
business : 1, // certificate is siutable for business use
|
business : 1, // certificate is suitable for business use
|
||||||
evaluation: 1, // evaluation certificate
|
evaluation: 1, // evaluation certificate
|
||||||
reservd_1 : 3,
|
reservd_1 : 3,
|
||||||
reservd_2 : 8,
|
reservd_2 : 8,
|
||||||
|
|
|
@ -124,7 +124,7 @@ int main(int argc, char *argv[])
|
||||||
if (!g_PendingMessage.isEmpty()) {
|
if (!g_PendingMessage.isEmpty()) {
|
||||||
if(app.sendMessage(g_PendingMessage))
|
if(app.sendMessage(g_PendingMessage))
|
||||||
return 0;
|
return 0;
|
||||||
app.disableSingleApp(); // we start to do one job and exit, don't interfear with starting a regular instance
|
app.disableSingleApp(); // we start to do one job and exit, don't interfere with starting a regular instance
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
if (app.arguments().contains("-autorun") && app.isRunning())
|
if (app.arguments().contains("-autorun") && app.isRunning())
|
||||||
|
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue