OLD | NEW |
---|---|
(Empty) | |
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_MAC_LAUNCHD_INTERCEPTION_SERVER_H_ | |
6 #define SANDBOX_MAC_LAUNCHD_INTERCEPTION_SERVER_H_ | |
7 | |
8 #include <dispatch/dispatch.h> | |
9 #include <mach/mach.h> | |
10 | |
11 #include "base/mac/scoped_mach_port.h" | |
12 #include "base/mac/scoped_mach_vm.h" | |
13 #include "sandbox/mac/os_compatibility.h" | |
14 | |
15 namespace sandbox { | |
16 | |
17 class BootstrapSandbox; | |
18 | |
19 // This class is used to run a Mach IPC message server. This server can | |
20 // hold the receive right for a bootstrap_port of a process, and it filters | |
21 // a subset of the launchd/bootstrap IPC call set for sandboxing. It permits | |
22 // or rejects requests based on the per-process policy specified in the | |
23 // BootstrapSandbox. | |
24 class LaunchdInterceptionServer { | |
25 public: | |
26 explicit LaunchdInterceptionServer(const BootstrapSandbox* sandbox); | |
27 ~LaunchdInterceptionServer(); | |
28 | |
29 // Initializes the class and starts running the message server. | |
30 bool Initialize(); | |
31 | |
32 mach_port_t server_port() const { return server_port_.get(); } | |
33 | |
34 private: | |
35 // Event handler for the |server_source_| that reads a message from the queue | |
36 // and processes it. | |
37 void ReceiveMessage(); | |
38 | |
39 // Decodes a message header and handles it by either servicing the request | |
40 // itself, forwarding the message on to the real launchd, or rejecting the | |
41 // message with an error. | |
42 void DemuxMessage(mach_msg_header_t* request, mach_msg_header_t* reply); | |
43 | |
44 // Given a look_up2 request message, this looks up the appropriate sandbox | |
45 // policy for the service name then formulates and sends the reply message. | |
46 void HandleLookUp(mach_msg_header_t* request, | |
47 mach_msg_header_t* reply, | |
48 pid_t sender_pid); | |
49 | |
50 // Given a swap_integer request message, this verifies that it is safe, and | |
51 // if so, forwards it on to launchd for servicing. If the request is unsafe, | |
52 // it replies with an error. | |
53 void HandleSwapInteger(mach_msg_header_t* request, | |
54 mach_msg_header_t* reply, | |
55 pid_t sender_pid); | |
56 | |
57 // Sends a reply message. | |
58 void SendReply(mach_msg_header_t* reply); | |
59 | |
60 // Forwards the original |request| on to real bootstrap server for handling. | |
61 void ForwardMessage(mach_msg_header_t* request, mach_msg_header_t* reply); | |
62 | |
63 // Replies to the message with the specified |error_code| as a MIG | |
64 // error_reply RetCode. | |
65 void RejectMessage(mach_msg_header_t* request, | |
66 mach_msg_header_t* reply, | |
67 int error_code); | |
68 | |
69 // The sandbox for which this message server is running. | |
70 const BootstrapSandbox* sandbox_; | |
71 | |
72 // The Mach port on which the server is receiving requests. | |
73 base::mac::ScopedMachPort server_port_; | |
74 | |
75 // The dispatch queue used to service the server_source_. | |
76 dispatch_queue_t server_queue_; | |
77 | |
78 // A MACH_RECV dispatch source for the server_port_. | |
79 dispatch_source_t server_source_; | |
80 | |
81 // Request and reply buffers used in ReceiveMessage. | |
82 base::mac::ScopedMachVM request_buffer_; | |
83 base::mac::ScopedMachVM reply_buffer_; | |
84 | |
85 // The Mach port handed out in reply to denied look up requests. All denied | |
86 // requests share the same port, though nothing reads messages from it. | |
87 base::mac::ScopedMachPort sandbox_port_; | |
88 | |
89 // The compatiblity shim that handles differences in message header IDs and | |
Avi (use Gerrit)
2014/05/09 21:02:06
typo: compatibility
Robert Sesek
2014/05/09 22:04:03
Done.
| |
90 // request/reply structures between different OS X versions. | |
91 const LaunchdCompatibilityShim compat_shim_; | |
92 }; | |
93 | |
94 } // namespace sandbox | |
95 | |
96 #endif // SANDBOX_MAC_LAUNCHD_INTERCEPTION_SERVER_H_ | |
OLD | NEW |