gecko-dev/security/sandbox/mac/Sandbox.h

87 строки
2.5 KiB
C++

/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
#ifndef mozilla_Sandbox_h
#define mozilla_Sandbox_h
#include <string>
#include "SandboxPolicies.h"
enum MacSandboxType {
MacSandboxType_Default = 0,
MacSandboxType_Plugin,
MacSandboxType_Content,
MacSandboxType_Invalid
};
enum MacSandboxPluginType {
MacSandboxPluginType_Default = 0,
MacSandboxPluginType_GMPlugin_Default, // Any Gecko Media Plugin
MacSandboxPluginType_GMPlugin_OpenH264, // Gecko Media Plugin, OpenH264
MacSandboxPluginType_GMPlugin_EME, // Gecko Media Plugin, EME
MacSandboxPluginType_GMPlugin_EME_Widevine, // Gecko Media Plugin, Widevine
MacSandboxPluginType_Flash, // Flash
MacSandboxPluginType_Invalid
};
typedef struct _MacSandboxPluginInfo {
_MacSandboxPluginInfo() : type(MacSandboxPluginType_Default) {}
_MacSandboxPluginInfo(const struct _MacSandboxPluginInfo& other)
: type(other.type),
pluginPath(other.pluginPath),
pluginBinaryPath(other.pluginBinaryPath) {}
MacSandboxPluginType type;
std::string pluginPath;
std::string pluginBinaryPath;
} MacSandboxPluginInfo;
typedef struct _MacSandboxInfo {
_MacSandboxInfo()
: type(MacSandboxType_Default),
level(0),
hasFilePrivileges(false),
hasSandboxedProfile(false),
hasAudio(false),
hasWindowServer(false),
shouldLog(true) {}
_MacSandboxInfo(const struct _MacSandboxInfo& other) = default;
MacSandboxType type;
int32_t level;
bool hasFilePrivileges;
bool hasSandboxedProfile;
bool hasAudio;
bool hasWindowServer;
MacSandboxPluginInfo pluginInfo;
std::string appPath;
std::string appBinaryPath;
std::string appDir;
std::string profileDir;
std::string debugWriteDir;
std::string testingReadPath1;
std::string testingReadPath2;
std::string testingReadPath3;
std::string testingReadPath4;
std::string crashServerPort;
bool shouldLog;
} MacSandboxInfo;
namespace mozilla {
bool StartMacSandbox(MacSandboxInfo const& aInfo, std::string& aErrorMessage);
bool EarlyStartMacSandboxIfEnabled(int aArgc, char** aArgv,
std::string& aErrorMessage);
#ifdef DEBUG
void AssertMacSandboxEnabled();
#endif /* DEBUG */
} // namespace mozilla
#endif // mozilla_Sandbox_h