blob: 1ddb100055e2362ace10407a985cbd24e7bbe5f6 [file] [log] [blame]
// Copyright 2018 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::Error;
use fuchsia_async as fasync;
use futures::channel::mpsc;
use parking_lot::RwLock;
use std::sync::Arc;
use std::thread;
use fuchsia_syslog::macros::*;
use sl4f_lib::server::sl4f::{serve, Sl4f, Sl4fClients};
use sl4f_lib::server::sl4f_executor::run_fidl_loop;
// Config, flexible for any ip/port combination
const SERVER_IP: &str = "[::]";
const SERVER_PORT: &str = "80";
// HTTP Server using Rouille
fn main() -> Result<(), Error> {
fuchsia_syslog::init_with_tags(&["sl4f"]).expect("Can't init logger");
fx_log_info!("Starting sl4f server");
let mut executor = fasync::Executor::new().expect("Failed to create an executor!");
let address = format!("{}:{}", SERVER_IP, SERVER_PORT);
fx_log_info!("Now listening on: {:?}", address);
// State for clients that utilize the /init endpoint
let sl4f_clients = Arc::new(RwLock::new(Sl4fClients::new()));
// State for facades
let sl4f = Arc::new(Sl4f::new(Arc::clone(&sl4f_clients))?);
// Create channel for communication: rouille sync side -> async exec side
let (rouille_sender, async_receiver) = mpsc::unbounded();
// Create thread for listening to test commands
thread::spawn(move || {
// Start listening on address
rouille::start_server(address, move |request| {
serve(&request, Arc::clone(&sl4f_clients), rouille_sender.clone())
executor.run_singlethreaded(run_fidl_loop(sl4f, async_receiver));