pub struct UnsupportedVirtualNetworking {}

Trait Implementations§

source§

impl Debug for UnsupportedVirtualNetworking

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl Default for UnsupportedVirtualNetworking

source§

fn default() -> UnsupportedVirtualNetworking

Returns the “default value” for a type. Read more
source§

impl VirtualNetworking for UnsupportedVirtualNetworking

source§

fn bridge<'life0, 'life1, 'life2, 'async_trait>( &'life0 self, network: &'life1 str, access_token: &'life2 str, security: StreamSecurity ) -> Pin<Box<dyn Future<Output = Result<()>> + Send + 'async_trait>>where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait, 'life2: 'async_trait,

Bridges this local network with a remote network, which is required in order to make lower level networking calls (such as UDP/TCP)
source§

fn unbridge<'life0, 'async_trait>( &'life0 self ) -> Pin<Box<dyn Future<Output = Result<()>> + Send + 'async_trait>>where Self: 'async_trait, 'life0: 'async_trait,

Disconnects from the remote network essentially unbridging it
source§

fn dhcp_acquire<'life0, 'async_trait>( &'life0 self ) -> Pin<Box<dyn Future<Output = Result<Vec<IpAddr>>> + Send + 'async_trait>>where Self: 'async_trait, 'life0: 'async_trait,

Acquires an IP address on the network and configures the routing tables
source§

fn ip_add(&self, ip: IpAddr, prefix: u8) -> Result<()>

Adds a static IP address to the interface with a netmask prefix
source§

fn ip_remove(&self, ip: IpAddr) -> Result<()>

Removes a static (or dynamic) IP address from the interface
source§

fn ip_clear(&self) -> Result<()>

Clears all the assigned IP addresses for this interface
source§

fn ip_list(&self) -> Result<Vec<IpCidr>>

Lists all the IP addresses currently assigned to this interface
source§

fn mac(&self) -> Result<[u8; 6]>

Returns the hardware MAC address for this interface
source§

fn gateway_set(&self, ip: IpAddr) -> Result<()>

Adds a default gateway to the routing table
source§

fn route_add( &self, cidr: IpCidr, via_router: IpAddr, preferred_until: Option<Duration>, expires_at: Option<Duration> ) -> Result<()>

Adds a specific route to the routing table
source§

fn route_remove(&self, cidr: IpAddr) -> Result<()>

Removes a routing rule from the routing table
source§

fn route_clear(&self) -> Result<()>

Clears the routing table for this interface
source§

fn route_list(&self) -> Result<Vec<IpRoute>>

Lists all the routes defined in the routing table for this interface
source§

fn bind_raw<'life0, 'async_trait>( &'life0 self ) -> Pin<Box<dyn Future<Output = Result<Box<dyn VirtualRawSocket + Sync>>> + Send + 'async_trait>>where Self: 'async_trait, 'life0: 'async_trait,

Creates a low level socket that can read and write Ethernet packets directly to the interface
source§

fn listen_tcp<'life0, 'async_trait>( &'life0 self, addr: SocketAddr, only_v6: bool, reuse_port: bool, reuse_addr: bool ) -> Pin<Box<dyn Future<Output = Result<Box<dyn VirtualTcpListener + Sync>>> + Send + 'async_trait>>where Self: 'async_trait, 'life0: 'async_trait,

Lists for TCP connections on a specific IP and Port combination Multiple servers (processes or threads) can bind to the same port if they each set the reuse-port and-or reuse-addr flags
source§

fn bind_udp<'life0, 'async_trait>( &'life0 self, addr: SocketAddr, reuse_port: bool, reuse_addr: bool ) -> Pin<Box<dyn Future<Output = Result<Box<dyn VirtualUdpSocket + Sync>>> + Send + 'async_trait>>where Self: 'async_trait, 'life0: 'async_trait,

Opens a UDP socket that listens on a specific IP and Port combination Multiple servers (processes or threads) can bind to the same port if they each set the reuse-port and-or reuse-addr flags
source§

fn bind_icmp<'life0, 'async_trait>( &'life0 self, addr: IpAddr ) -> Pin<Box<dyn Future<Output = Result<Box<dyn VirtualIcmpSocket + Sync>>> + Send + 'async_trait>>where Self: 'async_trait, 'life0: 'async_trait,

Creates a socket that can be used to send and receive ICMP packets from a paritcular IP address
source§

fn connect_tcp<'life0, 'async_trait>( &'life0 self, addr: SocketAddr, peer: SocketAddr ) -> Pin<Box<dyn Future<Output = Result<Box<dyn VirtualTcpSocket + Sync>>> + Send + 'async_trait>>where Self: 'async_trait, 'life0: 'async_trait,

Opens a TCP connection to a particular destination IP address and port
source§

fn resolve<'life0, 'life1, 'async_trait>( &'life0 self, host: &'life1 str, port: Option<u16>, dns_server: Option<IpAddr> ) -> Pin<Box<dyn Future<Output = Result<Vec<IpAddr>>> + Send + 'async_trait>>where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Performs DNS resolution for a specific hostname

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for Twhere T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for Twhere T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for Twhere U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T, U> TryFrom<U> for Twhere U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for Twhere U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.