Sandboxie/SandboxiePlus/QSbieAPI/SbieAPI.h

242 lines
8.2 KiB
C
Raw Normal View History

2020-06-01 17:11:56 +01:00
/*
*
* Copyright (c) 2020, David Xanatos
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#pragma once
#include <QThread>
2020-06-08 16:17:37 +01:00
#include <QFileSystemWatcher>
2020-06-01 17:11:56 +01:00
#include "qsbieapi_global.h"
2020-09-05 16:45:39 +01:00
#include "SbieStatus.h"
2020-06-01 17:11:56 +01:00
2021-02-14 19:18:29 +00:00
#include "SbieTrace.h"
2020-06-01 17:11:56 +01:00
#include "./Sandboxie/SandBox.h"
#include "./Sandboxie/BoxedProcess.h"
class QSBIEAPI_EXPORT CSbieAPI : public QThread
{
Q_OBJECT
public:
CSbieAPI(QObject* parent = 0);
virtual ~CSbieAPI();
2020-07-04 11:07:36 +01:00
static bool IsSbieCtrlRunning();
static bool TerminateSbieCtrl();
2020-11-28 16:20:56 +00:00
virtual SB_STATUS Connect(bool withQueue = true);
2020-06-08 16:17:37 +01:00
virtual SB_STATUS Disconnect();
virtual bool IsConnected() const;
2020-06-01 17:11:56 +01:00
virtual QString GetVersion();
virtual SB_STATUS TakeOver();
2020-06-08 16:17:37 +01:00
virtual SB_STATUS WatchIni(bool bEnable = true);
2020-06-01 17:11:56 +01:00
virtual QString GetSbiePath() const { return m_SbiePath; }
virtual QString GetIniPath() const { return m_IniPath; }
virtual void UpdateDriveLetters();
2021-06-13 17:11:04 +01:00
virtual QString Nt2DosPath(QString NtPath, bool* pOk = NULL) const;
2020-06-01 17:11:56 +01:00
2021-01-30 18:10:49 +00:00
virtual SB_STATUS ReloadBoxes(bool bFullUpdate = false);
2020-12-22 14:50:58 +00:00
static SB_STATUS ValidateName(const QString& BoxName);
2021-07-05 21:33:33 +01:00
virtual SB_STATUS CreateBox(const QString& BoxName, bool bReLoad = true);
2020-06-01 17:11:56 +01:00
2021-08-22 20:20:22 +01:00
virtual SB_STATUS UpdateProcesses(bool bKeep, bool bAllSessions);
2021-07-05 12:37:28 +01:00
//virtual SB_STATUS UpdateProcesses(bool bKeep, const CSandBoxPtr& pBox);
2020-06-01 17:11:56 +01:00
virtual QMap<QString, CSandBoxPtr> GetAllBoxes() { return m_SandBoxes; }
2020-06-08 16:17:37 +01:00
virtual int TotalProcesses() const { return m_BoxedProxesses.count(); }
2020-11-28 16:20:56 +00:00
virtual CSandBoxPtr GetBoxByProcessId(quint32 ProcessId) const;
2020-07-04 11:07:36 +01:00
virtual CSandBoxPtr GetBoxByName(const QString &BoxName) const { return m_SandBoxes.value(BoxName.toLower()); }
2020-11-28 16:20:56 +00:00
virtual CBoxedProcessPtr GetProcessById(quint32 ProcessId) const;
2020-07-04 11:07:36 +01:00
2020-06-01 17:11:56 +01:00
virtual SB_STATUS TerminateAll();
2020-11-28 16:20:56 +00:00
virtual SB_STATUS SetProcessExemption(quint32 process_id, quint32 action_id, bool NewState);
virtual bool GetProcessExemption(quint32 process_id, quint32 action_id);
virtual QString GetBoxedPath(const QString& BoxName, const QString& Path);
virtual QString GetBoxedPath(const CSandBoxPtr& pBox, const QString& Path);
2021-01-18 12:04:14 +00:00
virtual QString GetRealPath(const CSandBoxPtr& pBox, const QString& Path);
2020-11-28 16:20:56 +00:00
2020-06-01 17:11:56 +01:00
enum ESetMode
{
eIniUpdate = 0,
eIniAppend,
eIniInsert,
eIniDelete
};
// Config
2021-08-07 09:32:48 +01:00
virtual SB_STATUS ReloadConfig(bool ReconfigureDrv = false);
virtual SB_STATUS ReloadCert();
2021-09-12 11:43:35 +01:00
virtual void CommitIniChanges();
2020-06-01 17:11:56 +01:00
virtual QString SbieIniGet(const QString& Section, const QString& Setting, quint32 Index = 0, qint32* ErrCode = NULL);
2021-09-12 11:43:35 +01:00
virtual QString SbieIniGetEx(const QString& Section, const QString& Setting);
virtual SB_STATUS SbieIniSet(const QString& Section, const QString& Setting, const QString& Value, ESetMode Mode = eIniUpdate, bool bRefresh = true);
2021-01-26 20:58:43 +00:00
virtual bool IsBox(const QString& BoxName, bool& bIsEnabled);
2020-07-19 21:09:02 +01:00
virtual CSbieIni* GetGlobalSettings() const { return m_pGlobalSection; }
2020-11-28 16:20:56 +00:00
virtual CSbieIni* GetUserSettings() const { return m_pUserSection; }
2021-04-11 14:36:13 +01:00
virtual QString GetCurrentUserName() const { return m_UserName; }
2021-06-13 17:11:04 +01:00
virtual QString GetCurrentUserSid() const { return m_UserSid; }
2020-07-19 21:09:02 +01:00
virtual bool IsConfigLocked();
virtual SB_STATUS UnlockConfig(const QString& Password);
virtual SB_STATUS LockConfig(const QString& NewPassword);
virtual void ClearPassword();
2021-08-07 09:32:48 +01:00
virtual quint32 GetFeatureFlags();
virtual QString GetFeatureStr();
2020-07-19 21:09:02 +01:00
// Forced Processes
2020-11-03 15:45:04 +00:00
virtual SB_STATUS DisableForceProcess(bool Set, int Seconds = 0);
2020-07-19 21:09:02 +01:00
virtual bool AreForceProcessDisabled();
2020-06-01 17:11:56 +01:00
// Monitor
virtual SB_STATUS EnableMonitor(bool Enable);
virtual bool IsMonitoring();
2021-02-14 19:18:29 +00:00
virtual void AddTraceEntry(const CTraceEntryPtr& LogEntry, bool bCanMerge = false);
virtual QVector<CTraceEntryPtr> GetTrace() const;
2021-06-13 17:11:04 +01:00
virtual void ClearTrace() { QWriteLocker Lock(&m_TraceMutex); m_TraceList.clear(); m_LastTraceEntry = 0; }
2020-06-01 17:11:56 +01:00
2020-07-19 21:09:02 +01:00
// Other
2020-11-28 16:20:56 +00:00
virtual QString GetSbieMsgStr(quint32 code, quint32 Lang = 1033);
2021-02-14 19:18:29 +00:00
virtual SB_STATUS RunStart(const QString& BoxName, const QString& Command, QProcess* pProcess = NULL, bool Elevated = false);
2020-11-28 16:20:56 +00:00
virtual QString GetStartPath() const;
2021-08-22 20:20:22 +01:00
virtual quint32 GetSessionID() const;
2020-11-28 16:20:56 +00:00
enum ESbieQueuedRequests
{
ePrintSpooler = -1,
eInvalidQueuedRequests = 0,
eFileMigration = 1,
eInetBlockade= 2,
};
public slots:
virtual void SendReplyData(quint32 RequestId, const QVariantMap& Result);
2020-07-19 21:09:02 +01:00
2020-06-01 17:11:56 +01:00
signals:
2020-06-08 16:17:37 +01:00
void StatusChanged();
2020-11-28 16:20:56 +00:00
void ConfigReloaded();
//void LogMessage(const QString& Message, bool bNotify = true);
void LogSbieMessage(quint32 MsgCode, const QStringList& MsgData, quint32 ProcessId);
void ProcessBoxed(quint32 ProcessId, const QString& Path, const QString& Box, quint32 ParentId);
2021-06-13 17:11:04 +01:00
void FileToRecover(const QString& BoxName, const QString& FilePath, const QString& BoxPath, quint32 ProcessId);
2020-09-12 09:09:24 +01:00
void BoxClosed(const QString& BoxName);
2020-07-19 21:09:02 +01:00
void NotAuthorized(bool bLoginRequired, bool &bRetry);
2020-11-28 16:20:56 +00:00
void QueuedRequest(quint32 ClientPid, quint32 ClientTid, quint32 RequestId, const QVariantMap& Data);
2020-06-01 17:11:56 +01:00
2020-12-22 14:50:58 +00:00
protected slots:
2020-11-28 16:20:56 +00:00
//virtual void OnMonitorEntry(quint32 ProcessId, quint32 Type, const QString& Value);
2020-06-08 16:17:37 +01:00
virtual void OnIniChanged(const QString &path);
2020-07-04 11:07:36 +01:00
virtual void OnReloadConfig();
2020-12-22 14:50:58 +00:00
virtual CBoxedProcessPtr OnProcessBoxed(quint32 ProcessId, const QString& Path, const QString& Box, quint32 ParentId);
2020-06-01 17:11:56 +01:00
protected:
friend class CSandBox;
friend class CBoxedProcess;
2021-08-07 09:32:48 +01:00
virtual SB_STATUS ReloadConf(quint32 flags, quint32 SessionId = -1);
2020-06-18 16:44:29 +01:00
virtual CSandBox* NewSandBox(const QString& BoxName, class CSbieAPI* pAPI);
2020-11-28 16:20:56 +00:00
virtual CBoxedProcess* NewBoxedProcess(quint32 ProcessId, class CSandBox* pBox);
2020-06-18 16:44:29 +01:00
2020-06-01 17:11:56 +01:00
virtual QString GetSbieHome() const;
2020-06-08 16:17:37 +01:00
virtual QString GetIniPath(bool* IsHome) const;
2021-04-11 14:36:13 +01:00
virtual QString GetUserSection(QString* pUserName = NULL, bool* pIsAdmin = NULL) const;
2020-06-01 17:11:56 +01:00
2020-09-05 16:45:39 +01:00
virtual bool HasProcesses(const QString& BoxName);
2020-11-28 16:20:56 +00:00
virtual bool GetQueue();
2020-06-01 17:11:56 +01:00
virtual bool GetLog();
virtual bool GetMonitor();
2021-06-13 17:11:04 +01:00
virtual quint32 GetImageType(quint32 ProcessId);
2020-06-01 17:11:56 +01:00
virtual SB_STATUS TerminateAll(const QString& BoxName);
2020-11-28 16:20:56 +00:00
virtual SB_STATUS Terminate(quint32 ProcessId);
2020-06-01 17:11:56 +01:00
virtual SB_STATUS RunSandboxed(const QString& BoxName, const QString& Command, QString WrkDir = QString(), quint32 Flags = 0);
2020-07-04 11:07:36 +01:00
virtual SB_STATUS UpdateBoxPaths(const CSandBoxPtr& pSandBox);
virtual SB_STATUS UpdateProcessInfo(const CBoxedProcessPtr& pProcess);
2020-06-01 17:11:56 +01:00
2020-11-28 16:20:56 +00:00
virtual void GetUserPaths();
2020-06-01 17:11:56 +01:00
virtual QString GetDeviceMap();
virtual QByteArray MakeEnvironment(bool AddDeviceMap);
virtual void run();
QMap<QString, CSandBoxPtr> m_SandBoxes;
2020-11-28 16:20:56 +00:00
QMap<quint32, CBoxedProcessPtr> m_BoxedProxesses;
2020-06-01 17:11:56 +01:00
2021-02-14 19:18:29 +00:00
mutable QReadWriteLock m_TraceMutex;
QVector<CTraceEntryPtr> m_TraceList;
2021-06-13 17:11:04 +01:00
int m_LastTraceEntry;
2020-06-01 17:11:56 +01:00
2020-11-28 16:20:56 +00:00
mutable QReadWriteLock m_DriveLettersMutex;
2021-06-13 17:11:04 +01:00
struct SDrive
{
QString Letter;
QString NtPath;
enum EType
{
EVolume = 0,
EShare
} Type;
QString Aux;
};
QMap<QString, SDrive> m_DriveLetters;
2020-06-01 17:11:56 +01:00
QString m_SbiePath;
QString m_IniPath;
2020-06-08 16:17:37 +01:00
QFileSystemWatcher m_IniWatcher;
2020-06-01 17:11:56 +01:00
2020-07-04 11:07:36 +01:00
bool m_bReloadPending;
2020-11-28 16:20:56 +00:00
bool m_bWithQueue;
2020-06-01 17:11:56 +01:00
bool m_bTerminate;
2020-06-08 16:17:37 +01:00
2020-11-28 16:20:56 +00:00
CSbieIni* m_pGlobalSection;
CSbieIni* m_pUserSection;
2021-04-11 14:36:13 +01:00
QString m_UserName;
2021-06-13 17:11:04 +01:00
QString m_UserSid;
2020-11-28 16:20:56 +00:00
QString m_ProgramDataDir;
QString m_PublicDir;
QString m_UserDir;
2020-07-19 21:09:02 +01:00
2020-06-01 17:11:56 +01:00
private:
2020-06-08 16:17:37 +01:00
mutable QMutex m_ThreadMutex;
mutable QWaitCondition m_ThreadWait;
SB_STATUS CallServer(void* req, void* rpl) const;
SB_STATUS SbieIniSet(void *RequestBuf, void *pPasswordWithinRequestBuf, const QString& SectionName, const QString& SettingName);
2020-06-01 17:11:56 +01:00
struct SSbieAPI* m;
};