aboutsummaryrefslogtreecommitdiff
path: root/src/diplonat.rs
blob: 6b282eb5d0b4c433dfb12a0b6aebdd524b493b7a (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
use anyhow::Result;
use tokio::try_join;

use crate::{
  config::ConfigOpts, consul_actor::ConsulActor, fw_actor::FirewallActor, igd_actor::IgdActor,
  stun_actor::StunActor,
};

pub struct Diplonat {
  consul: ConsulActor,
  firewall: FirewallActor,
  igd: IgdActor,
  stun: StunActor,
}

impl Diplonat {
  pub async fn new() -> Result<Self> {
    let rt_cfg = ConfigOpts::from_env()?;
    println!("{:#?}", rt_cfg);

    let ca = ConsulActor::new(&rt_cfg.consul, &rt_cfg.consul.node_name);

    let fw = FirewallActor::new(rt_cfg.firewall.refresh_time, &ca.rx_open_ports).await?;

    let ia = IgdActor::new(
      rt_cfg.igd.private_ip.as_ref().map(String::as_str),
      rt_cfg.igd.refresh_time,
      rt_cfg.igd.expiration_time,
      &ca.rx_open_ports,
    )
    .await?;

    let sa = StunActor::new(
        &rt_cfg.consul,
        &rt_cfg.stun,
        &rt_cfg.consul.node_name,
    );

    let ctx = Self {
      consul: ca,
      igd: ia,
      firewall: fw,
      stun: sa,
    };

    Ok(ctx)
  }

  pub async fn listen(&mut self) -> Result<()> {
    try_join!(
      self.consul.listen(),
      self.igd.listen(),
      self.firewall.listen(),
      self.stun.listen(),
    )?;

    Ok(())
  }
}