blob: 4f79db93c92be389bd695befcc66304ab9595f27 [file] [log] [blame]
// Copyright 2019 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.
#include <fuchsia/modular/cpp/fidl.h>
#include <fuchsia/sys/cpp/fidl.h>
#include "base/containers/flat_map.h"
#include "base/fuchsia/service_directory_client.h"
#include "base/strings/string_piece.h"
namespace cr_fuchsia {
// Connects to the ComponentContext service from the supplied
// ServiceDirectoryClient, and uses it to connect-to and manage one or more
// Agents used by the caller.
class BASE_EXPORT AgentManager {
explicit AgentManager(const base::fuchsia::ServiceDirectoryClient* incoming);
// Connects to |agent| so satisfying the specified |request|.
// |agent| will be kept alive until this AgentManager is destroyed.
template <typename Interface>
void ConnectToAgentService(base::StringPiece agent,
fidl::InterfaceRequest<Interface> request) {
ConnectToAgentServiceUnsafe(agent, Interface::Name_, request.TakeChannel());
template <typename Interface>
fidl::InterfacePtr<Interface> ConnectToAgentService(base::StringPiece agent) {
fidl::InterfacePtr<Interface> ptr;
ConnectToAgentService(agent, ptr.NewRequest());
return ptr;
// Holds a pointer to Agent-provided services, and keeps the Agent alive.
struct AgentConnection {
AgentConnection(AgentConnection&& other);
AgentConnection& operator=(AgentConnection&& other);
fuchsia::sys::ServiceProviderPtr services;
fuchsia::modular::AgentControllerPtr controller;
void ConnectToAgentServiceUnsafe(base::StringPiece agent,
base::StringPiece interface,
zx::channel request);
const fuchsia::modular::ComponentContextPtr component_context_;
// Cache of resources for Agents which we're actively using. All |agents_|
// are kept alive until the AgentManager is torn down, for now.
base::flat_map<std::string, AgentConnection> agents_;
} // namespace cr_fuchsia