// 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 #include "base/logging.h" #include "base/macros.h" #include "base/threading/simple_thread.h" #include "content/browser/sandbox_ipc_linux.h" #include "content/common/content_export.h" namespace base { template struct DefaultSingletonTraits; } 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 struct base::DefaultSingletonTraits; // This object must be constructed on the main thread. SandboxHostLinux(); ~SandboxHostLinux(); bool ShutdownIPCChannel(); // 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_RENDERER_HOST_RENDER_SANDBOX_HOST_LINUX_H_