1 // Copyright 2014 The Chromium Authors. All rights reserved. 2 // Use of this source code is governed by a BSD-style license that can be 3 // found in the LICENSE file. 4 5 #ifndef SANDBOX_LINUX_SYSCALL_BROKER_BROKER_HOST_H_ 6 #define SANDBOX_LINUX_SYSCALL_BROKER_BROKER_HOST_H_ 7 8 #include "base/macros.h" 9 #include "sandbox/linux/syscall_broker/broker_channel.h" 10 11 namespace sandbox { 12 13 namespace syscall_broker { 14 15 class BrokerPolicy; 16 17 // The BrokerHost class should be embedded in a (presumably not sandboxed) 18 // process. It will honor IPC requests from a BrokerClient sent over 19 // |ipc_channel| according to |broker_policy|. 20 class BrokerHost { 21 public: 22 enum class RequestStatus { LOST_CLIENT = 0, SUCCESS, FAILURE }; 23 24 BrokerHost(const BrokerPolicy& broker_policy, 25 BrokerChannel::EndPoint ipc_channel); 26 ~BrokerHost(); 27 28 RequestStatus HandleRequest() const; 29 30 private: 31 const BrokerPolicy& broker_policy_; 32 const BrokerChannel::EndPoint ipc_channel_; 33 34 DISALLOW_COPY_AND_ASSIGN(BrokerHost); 35 }; 36 37 } // namespace syscall_broker 38 39 } // namespace sandbox 40 41 #endif // SANDBOX_LINUX_SYSCALL_BROKER_BROKER_HOST_H_ 42