// Copyright (c) 2012 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef CONTENT_BROWSER_SANDBOX_HOST_LINUX_H_ #define CONTENT_BROWSER_SANDBOX_HOST_LINUX_H_ #include #include "base/check.h" #include "base/macros.h" #include "base/no_destructor.h" #include "base/threading/simple_thread.h" #include "content/browser/sandbox_ipc_linux.h" #include "content/common/content_export.h" namespace content { // This is a singleton object which handles sandbox requests from the // sandboxed processes. class CONTENT_EXPORT SandboxHostLinux { public: // Returns the singleton instance. static SandboxHostLinux* GetInstance(); // Get the file descriptor which sandboxed processes should be given in order // to communicate with the browser. This is used for things like communicating // renderer crashes to the browser, as well as requesting fonts from sandboxed // processes. int GetChildSocket() const { DCHECK(initialized_); return child_socket_; } void Init(); bool IsInitialized() const { return initialized_; } private: friend class base::NoDestructor; // This object must be constructed on the main thread. It then lives for the // lifetime of the process (and resources are reclaimed by the OS when the // process dies). SandboxHostLinux(); ~SandboxHostLinux() = delete; // Whether Init() has been called yet. bool initialized_ = false; int child_socket_ = 0; int childs_lifeline_fd_ = 0; std::unique_ptr ipc_handler_; std::unique_ptr ipc_thread_; DISALLOW_COPY_AND_ASSIGN(SandboxHostLinux); }; } // namespace content #endif // CONTENT_BROWSER_SANDBOX_HOST_LINUX_H_