// 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_