sansio_bootstrap/bootstrap_udp/
bootstrap_udp_server.rs

1use super::*;
2
3/// A Bootstrap that makes it easy to bootstrap a pipeline to use for UDP servers.
4pub struct BootstrapUdpServer<W> {
5    bootstrap_udp: BootstrapUdp<W>,
6}
7
8impl<W: 'static> Default for BootstrapUdpServer<W> {
9    fn default() -> Self {
10        Self::new()
11    }
12}
13
14impl<W: 'static> BootstrapUdpServer<W> {
15    /// Creates a new BootstrapUdpServer
16    pub fn new() -> Self {
17        Self {
18            bootstrap_udp: BootstrapUdp::new(),
19        }
20    }
21
22    /// Sets max payload size, default is 2048 bytes
23    pub fn max_payload_size(&mut self, max_payload_size: usize) -> &mut Self {
24        self.bootstrap_udp.max_payload_size(max_payload_size);
25        self
26    }
27
28    /// Creates pipeline instances from when calling [BootstrapUdpServer::bind].
29    pub fn pipeline(
30        &mut self,
31        pipeline_factory_fn: PipelineFactoryFn<TaggedBytesMut, W>,
32    ) -> &mut Self {
33        self.bootstrap_udp.pipeline(pipeline_factory_fn);
34        self
35    }
36
37    /// Binds local address and port
38    pub async fn bind<A: ToSocketAddrs>(&mut self, addr: A) -> Result<SocketAddr, Error> {
39        let local_addr = self.bootstrap_udp.bind(addr).await?;
40        let peer_addr: Option<SocketAddr> = None;
41        self.bootstrap_udp.connect(peer_addr).await?;
42        Ok(local_addr)
43    }
44
45    /// Stops the server
46    pub async fn stop(&self) {
47        self.bootstrap_udp.stop().await
48    }
49
50    /// Waits for stop of the server
51    pub async fn wait_for_stop(&self) {
52        self.bootstrap_udp.wait_for_stop().await
53    }
54
55    /// Gracefully stop the server
56    pub async fn graceful_stop(&self) {
57        self.bootstrap_udp.graceful_stop().await
58    }
59}