chromium/mojo/proxy/node_proxy.h

// Copyright 2024 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_PROXY_NODE_PROXY_H_
#define MOJO_PROXY_NODE_PROXY_H_

#include <memory>
#include <set>

#include "base/containers/unique_ptr_adapters.h"
#include "base/functional/callback.h"
#include "base/memory/raw_ref.h"
#include "mojo/core/scoped_ipcz_handle.h"
#include "mojo/public/cpp/system/message_pipe.h"
#include "third_party/ipcz/include/ipcz/ipcz.h"

namespace mojo_proxy {

class PortalProxy;

// A NodeProxy hosts a PortalProxy object for each proxied endpoint between a
// legacy Mojo Core node and a MojoIpcz network. As messages arrive from either
// side of these proxies, they're forwarded along; and if they contain other
// message pipes, new proxies are established for those new endpoints.
class NodeProxy {
 public:
  // Constructs a new NodeProxy which will call `dead_callback` once its last
  // proxy is removed.
  NodeProxy(const IpczAPI& ipcz, base::OnceClosure dead_callback);
  ~NodeProxy();

  // Registers a new PortalProxy to forward messages between `portal` and
  // `pipe`. The proxy is activated before this call returns.
  void AddPortalProxy(mojo::core::ScopedIpczHandle portal,
                      mojo::ScopedMessagePipeHandle pipe);

  // Removes `proxy` from this NodeProxy, effectively destroying it. Calls
  // `dead_callback_` if this was our last remaining portal proxy.
  void RemovePortalProxy(PortalProxy* proxy);

 private:
  const raw_ref<const IpczAPI> ipcz_;
  base::OnceClosure dead_callback_;
  std::set<std::unique_ptr<PortalProxy>, base::UniquePtrComparator>
      portal_proxies_;
};

}  // namespace mojo_proxy

#endif  // MOJO_PROXY_NODE_PROXY_H_