blob: 5877e1308349abc368e9c0cb7538de0486dd25fd [file] [log] [blame]
// Copyright 2021 The Fuchsia Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
use anyhow::{Context, Error};
use fidl_fidl_test_components::{TriggerRequest, TriggerRequestStream};
use fuchsia_async as fasync;
use fuchsia_component::server::ServiceFs;
use futures::{StreamExt, TryStreamExt};
use log::*;
/// Wraps all hosted protocols into a single type that can be matched against
/// and dispatched.
enum IncomingRequest {
/// A request to the fuchsia.component.resolution.Resolver protocol.
TriggerProtocol(TriggerRequestStream),
}
#[fasync::run_singlethreaded]
async fn main() -> Result<(), Error> {
let mut service_fs = ServiceFs::new_local();
service_fs.dir("svc").add_fidl_service(IncomingRequest::TriggerProtocol);
service_fs.take_and_serve_directory_handle().context("failed to serve outgoing namespace")?;
service_fs
.for_each_concurrent(None, |request: IncomingRequest| async move {
match request {
IncomingRequest::TriggerProtocol(stream) => match serve_trigger(stream).await {
Ok(()) => {}
Err(err) => error!("trigger failed: {}", err),
},
}
})
.await;
Ok(())
}
async fn serve_trigger(mut stream: TriggerRequestStream) -> Result<(), Error> {
while let Some(TriggerRequest::Run { responder }) =
stream.try_next().await.context("failed to read request from stream")?
{
responder.send("Triggered").context("failed to send trigger response")?;
}
Ok(())
}