File: isolated_connection.h

package info (click to toggle)
chromium 135.0.7049.95-1~deb12u1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 5,959,392 kB
  • sloc: cpp: 34,198,526; ansic: 7,100,035; javascript: 3,985,800; python: 1,395,489; asm: 896,754; xml: 722,891; pascal: 180,504; sh: 94,909; perl: 88,388; objc: 79,739; sql: 53,020; cs: 41,358; fortran: 24,137; makefile: 22,501; php: 13,699; tcl: 10,142; yacc: 8,822; ruby: 7,350; lisp: 3,096; lex: 1,327; ada: 727; jsp: 228; awk: 197; sed: 36
file content (69 lines) | stat: -rw-r--r-- 3,017 bytes parent folder | download | duplicates (9)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
// Copyright 2018 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

#ifndef MOJO_PUBLIC_CPP_SYSTEM_ISOLATED_CONNECTION_H_
#define MOJO_PUBLIC_CPP_SYSTEM_ISOLATED_CONNECTION_H_

#include "base/process/process.h"
#include "base/unguessable_token.h"
#include "mojo/public/cpp/platform/platform_channel_endpoint.h"
#include "mojo/public/cpp/platform/platform_channel_server_endpoint.h"
#include "mojo/public/cpp/system/message_pipe.h"
#include "mojo/public/cpp/system/system_export.h"

namespace mojo {

// IsolatedConnection establishes a one-off Mojo IPC connection between two
// processes. Unlike more common connections established by invitation
// (see OutgoingInvitation and IncomingInvitation), isolated connections
// do not result in the two processes becoming part of the same connected
// graph of processes. As such, any message pipe established over this
// connection can only be used for direct IPC between the two processes in
// question.
//
// This means that if one of the processes sends a Mojo handle (e.g. another
// message pipe endpoint) to the other process, the receiving process cannot
// pass that handle to yet another process in its own graph. This limitation is
// subtle and can be difficult to work around, so use of IsolatedConnection
// should be rare.
//
// This is primarily useful when you already have two established Mojo process
// graphs isolated form each other, and you want to do some IPC between two
// processes, one in each graph.
//
// A connection established via |Connect()|, and any opened message pipes
// spanning that connection, will remain valid and connected as long as this
// object remains alive.
class MOJO_CPP_SYSTEM_EXPORT IsolatedConnection {
 public:
  IsolatedConnection();

  IsolatedConnection(const IsolatedConnection&) = delete;
  IsolatedConnection& operator=(const IsolatedConnection&) = delete;

  ~IsolatedConnection();

  // Connects to a process at the other end of the channel. Returns a primordial
  // message pipe that can be used for Mojo IPC. The connection
  // will be connected to a corresponding peer pipe in the remote process.
  ScopedMessagePipeHandle Connect(PlatformChannelEndpoint endpoint);

  // Connects to a process at the other end of the channel. Returns a primordial
  // message pipe that can be used for Mojo IPC. The connection
  // will be connected to a corresponding peer pipe in the remote process.
  // `process` identifies the remote process.
  ScopedMessagePipeHandle Connect(PlatformChannelEndpoint endpoint,
                                  base::Process process);

  // Same as above but works with a server endpoint. The corresponding client
  // could use the above signature with NamedPlatformChannel::ConnectToServer.
  ScopedMessagePipeHandle Connect(PlatformChannelServerEndpoint endpoint);

 private:
  const base::UnguessableToken token_;
};

}  // namespace mojo

#endif  // MOJO_PUBLIC_CPP_SYSTEM_ISOLATED_CONNECTION_H_