UnixListener

Struct UnixListener 

Source
pub struct UnixListener<S> { /* private fields */ }
Available on target_family="unix" only.
Expand description

A Unix (domain) socket server, listening for incoming connections once served using one of the serve methods such as UnixListener::serve.

Note that the underlying socket (file) is only cleaned up by this listener’s Drop implementation if the listener was created using the bind_path constructor. Otherwise it is assumed that the creator of this listener is in charge of that cleanup.

Implementations§

Source§

impl UnixListener<()>

Source

pub fn build() -> UnixListenerBuilder<()>

Create a new UnixListenerBuilder without a state, which can be used to configure a UnixListener.

Source

pub fn build_with_state<S>(state: S) -> UnixListenerBuilder<S>
where S: Clone + Send + Sync + 'static,

Create a new UnixListenerBuilder with the given state, which can be used to configure a UnixListener.

Source

pub async fn bind_path(path: impl AsRef<Path>) -> Result<Self, Error>

Creates a new UnixListener, which will be bound to the specified path.

The returned listener is ready for accepting connections.

Source

pub fn bind_socket(socket: Socket) -> Result<Self, Error>

Creates a new UnixListener, which will be bound to the specified socket.

The returned listener is ready for accepting connections.

Source

pub async fn bind_socket_opts(opts: SocketOptions) -> Result<Self, BoxError>

Available on Android or Fuchsia or Linux only.

Creates a new TcpListener, which will be bound to the specified (interface) device name.

The returned listener is ready for accepting connections.

Source§

impl<S> UnixListener<S>

Source

pub fn local_addr(&self) -> Result<SocketAddr>

Returns the local address that this listener is bound to.

This can be useful, for example, when binding to port 0 to figure out which port was actually bound.

Source

pub fn state(&self) -> &S

Gets a reference to the listener’s state.

Source

pub fn state_mut(&mut self) -> &mut S

Gets an exclusive reference to the listener’s state.

Source§

impl UnixListener<()>

Source

pub fn with_state<S>(self, state: S) -> UnixListener<S>

Define the TcpListener’s state after it was created, useful in case it wasn’t built using the builder.

Source§

impl<State> UnixListener<State>
where State: Clone + Send + Sync + 'static,

Source

pub async fn accept(&self) -> Result<(UnixStream, UnixSocketAddress)>

Accept a single connection from this listener, what you can do with whatever you want.

Source

pub async fn serve<S>(self, service: S)
where S: Service<State, UnixStream>,

Serve connections from this listener with the given service.

This method will block the current listener for each incoming connection, the underlying service can choose to spawn a task to handle the accepted stream.

Source

pub async fn serve_graceful<S>(self, guard: ShutdownGuard, service: S)
where S: Service<State, UnixStream>,

Serve gracefully connections from this listener with the given service.

This method does the same as Self::serve but it will respect the given rama_core::graceful::ShutdownGuard, and also pass it to the service.

Trait Implementations§

Source§

impl<S> AsFd for UnixListener<S>

Source§

fn as_fd(&self) -> BorrowedFd<'_>

Borrows the file descriptor. Read more
Source§

impl<S> AsRawFd for UnixListener<S>

Source§

fn as_raw_fd(&self) -> RawFd

Extracts the raw file descriptor. Read more
Source§

impl<S> Debug for UnixListener<S>
where S: Debug,

Source§

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

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

impl From<UnixListener> for UnixListener<()>

Source§

fn from(value: TokioUnixListener) -> Self

Converts to this type from the input type.
Source§

impl TryFrom<Socket> for UnixListener<()>

Source§

type Error = Error

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

fn try_from(socket: Socket) -> Result<Self, Self::Error>

Performs the conversion.
Source§

impl TryFrom<UnixListener> for UnixListener<()>

Source§

type Error = Error

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

fn try_from(listener: StdUnixListener) -> Result<Self, Self::Error>

Performs the conversion.

Auto Trait Implementations§

§

impl<S> !Freeze for UnixListener<S>

§

impl<S> RefUnwindSafe for UnixListener<S>
where S: RefUnwindSafe,

§

impl<S> Send for UnixListener<S>
where S: Send,

§

impl<S> Sync for UnixListener<S>
where S: Sync,

§

impl<S> Unpin for UnixListener<S>
where S: Unpin,

§

impl<S> UnwindSafe for UnixListener<S>
where S: UnwindSafe,

Blanket Implementations§

Source§

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

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

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

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where 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> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where 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 T
where U: Into<T>,

Source§

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 T
where U: TryFrom<T>,

Source§

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.
Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more