syndicate-rs/syndicate-server/src/services/tcp_relay_listener.rs

60 lines
2.1 KiB
Rust
Raw Normal View History

use preserves_schema::Codec;
2021-08-28 16:50:55 +00:00
use std::convert::TryFrom;
use std::sync::Arc;
use syndicate::actor::*;
2021-09-23 19:46:10 +00:00
use syndicate::enclose;
use syndicate::supervise::{Supervisor, SupervisorConfiguration};
use tokio::net::TcpListener;
use crate::language::language;
use crate::protocol::detect_protocol;
2021-08-28 16:50:55 +00:00
use crate::schemas::internal_services;
2021-09-20 13:10:31 +00:00
use syndicate_macros::during;
2021-08-28 16:50:55 +00:00
pub fn on_demand(t: &mut Activation, ds: Arc<Cap>, gateway: Arc<Cap>) {
t.spawn(syndicate::name!("on_demand", module = module_path!()), move |t| {
2021-09-24 14:15:26 +00:00
Ok(during!(t, ds, language(), <run-service $spec: internal_services::TcpRelayListener>,
2021-09-20 13:10:31 +00:00
|t| {
Supervisor::start(
t,
syndicate::name!(parent: None, "relay", addr = ?spec),
SupervisorConfiguration::default(),
2021-09-23 19:46:10 +00:00
enclose!((ds, gateway) move |t|
enclose!((ds, gateway, spec) run(t, ds, gateway, spec))));
2021-09-20 13:10:31 +00:00
Ok(())
}))
2021-09-01 15:31:01 +00:00
});
}
2021-08-28 16:50:55 +00:00
fn run(
t: &'_ mut Activation,
ds: Arc<Cap>,
gateway: Arc<Cap>,
2021-09-20 13:10:31 +00:00
spec: internal_services::TcpRelayListener,
) -> ActorResult {
2021-08-28 16:50:55 +00:00
let host = spec.addr.host.clone();
let port = u16::try_from(&spec.addr.port).map_err(|_| "Invalid TCP port number")?;
{
let spec = language().unparse(&spec);
ds.assert(t, &(), &syndicate_macros::template!("<service-running =spec>"));
}
2021-08-28 16:50:55 +00:00
let parent_span = tracing::Span::current();
t.linked_task(syndicate::name!("listener"), async move {
let listen_addr = format!("{}:{}", host, port);
let listener = TcpListener::bind(listen_addr).await?;
tracing::info!("listening");
loop {
let (stream, addr) = listener.accept().await?;
Actor::new().boot(syndicate::name!(parent: parent_span.clone(), "conn"),
2021-09-23 19:46:10 +00:00
enclose!((gateway) move |t| Ok(t.linked_task(
2021-08-28 16:50:55 +00:00
tracing::Span::current(),
2021-09-23 19:46:10 +00:00
detect_protocol(t.facet.clone(), stream, gateway, addr)))));
2021-08-28 16:50:55 +00:00
}
});
Ok(())
}