|  | // Copyright 2014 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 SANDBOX_MAC_MESSAGE_SERVER_H_ | 
|  | #define SANDBOX_MAC_MESSAGE_SERVER_H_ | 
|  |  | 
|  | #include <mach/mach.h> | 
|  | #include <unistd.h> | 
|  |  | 
|  | #include "sandbox/mac/xpc.h" | 
|  |  | 
|  | namespace sandbox { | 
|  |  | 
|  | // A message received by a MessageServer. Each concrete implementation of | 
|  | // that interface will handle the fields of this union appropriately. | 
|  | // Consumers should treat this as an opaque handle. | 
|  | union IPCMessage { | 
|  | mach_msg_header_t* mach; | 
|  | xpc_object_t xpc; | 
|  | }; | 
|  |  | 
|  | // A delegate interface for MessageServer that handles processing of | 
|  | // incoming intercepted IPC messages. | 
|  | class MessageDemuxer { | 
|  | public: | 
|  | // Handle a |request| message. The message is owned by the server. Use the | 
|  | // server's methods to create and send a reply message. | 
|  | virtual void DemuxMessage(IPCMessage request) = 0; | 
|  |  | 
|  | protected: | 
|  | virtual ~MessageDemuxer() {} | 
|  | }; | 
|  |  | 
|  | // An interaface for an IPC server that implements Mach messaging semantics. | 
|  | // The concrete implementation may be powered by raw Mach messages, XPC, or | 
|  | // some other technology. This interface is the abstraction on top of those | 
|  | // that enables message interception. | 
|  | class MessageServer { | 
|  | public: | 
|  | virtual ~MessageServer() {} | 
|  |  | 
|  | // Initializes the class and starts running the message server. If this | 
|  | // returns false, no other methods may be called on this class. | 
|  | virtual bool Initialize() = 0; | 
|  |  | 
|  | // Blocks the calling thread while the server shuts down. This prevents | 
|  | // the server from receiving new messages. After this method is called, | 
|  | // no other methods may be called on this class. | 
|  | virtual void Shutdown() = 0; | 
|  |  | 
|  | // Given a received request message, returns the PID of the sending process. | 
|  | virtual pid_t GetMessageSenderPID(IPCMessage request) = 0; | 
|  |  | 
|  | // Creates a reply message from a request message. The result is owned by | 
|  | // the server. | 
|  | virtual IPCMessage CreateReply(IPCMessage request) = 0; | 
|  |  | 
|  | // Sends a reply message. Returns true if the message was sent successfully. | 
|  | virtual bool SendReply(IPCMessage reply) = 0; | 
|  |  | 
|  | // Forwards the original |request| to the |destination| for handling. | 
|  | virtual void ForwardMessage(IPCMessage request, mach_port_t destination) = 0; | 
|  |  | 
|  | // Replies to the received |request| message by creating a reply and setting | 
|  | // the specified |error_code| in a field that is interpreted by the | 
|  | // underlying IPC system. | 
|  | virtual void RejectMessage(IPCMessage request, int error_code) = 0; | 
|  |  | 
|  | // Returns the Mach port on which the MessageServer is listening. | 
|  | virtual mach_port_t GetServerPort() const = 0; | 
|  | }; | 
|  |  | 
|  | }  // namespace sandbox | 
|  |  | 
|  | #endif  // SANDBOX_MAC_MESSAGE_SERVER_H_ |