SandboxFilter.h (1342B)
1 /* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ 2 /* vim: set ts=8 sts=2 et sw=2 tw=80: */ 3 /* This Source Code Form is subject to the terms of the Mozilla Public 4 * License, v. 2.0. If a copy of the MPL was not distributed with this file, 5 * You can obtain one at http://mozilla.org/MPL/2.0/. */ 6 7 #ifndef mozilla_SandboxFilter_h 8 #define mozilla_SandboxFilter_h 9 10 #include "mozilla/UniquePtr.h" 11 12 namespace sandbox { 13 namespace bpf_dsl { 14 class Policy; 15 } 16 } // namespace sandbox 17 18 namespace mozilla { 19 class SandboxBrokerClient; 20 21 struct ContentProcessSandboxParams; 22 struct SocketProcessSandboxParams; 23 24 UniquePtr<sandbox::bpf_dsl::Policy> GetContentSandboxPolicy( 25 SandboxBrokerClient* aMaybeBroker, ContentProcessSandboxParams&& aParams); 26 27 class SandboxOpenedFiles; 28 29 // The SandboxOpenedFiles object must live until the process exits. 30 UniquePtr<sandbox::bpf_dsl::Policy> GetMediaSandboxPolicy( 31 const SandboxOpenedFiles* aFiles); 32 33 UniquePtr<sandbox::bpf_dsl::Policy> GetDecoderSandboxPolicy( 34 SandboxBrokerClient* aMaybeBroker); 35 36 UniquePtr<sandbox::bpf_dsl::Policy> GetSocketProcessSandboxPolicy( 37 SandboxBrokerClient* aMaybeBroker, SocketProcessSandboxParams&& aParams); 38 39 UniquePtr<sandbox::bpf_dsl::Policy> GetUtilitySandboxPolicy( 40 SandboxBrokerClient* aMaybeBroker); 41 42 } // namespace mozilla 43 44 #endif