Struct Pipe

Source
pub struct Pipe<Front: SocketHandler, L: ListenerHandler> {
    pub backend_readiness: Readiness,
    pub backend: Option<Rc<RefCell<Backend>>>,
    pub container_backend_timeout: Option<TimeoutContainer>,
    pub container_frontend_timeout: Option<TimeoutContainer>,
    pub frontend_readiness: Readiness,
    /* private fields */
}

Fields§

§backend_readiness: Readiness§backend: Option<Rc<RefCell<Backend>>>§container_backend_timeout: Option<TimeoutContainer>§container_frontend_timeout: Option<TimeoutContainer>§frontend_readiness: Readiness

Implementations§

Source§

impl<Front: SocketHandler, L: ListenerHandler> Pipe<Front, L>

Source

pub fn new( backend_buffer: Checkout, backend_id: Option<String>, backend_socket: Option<TcpStream>, backend: Option<Rc<RefCell<Backend>>>, container_backend_timeout: Option<TimeoutContainer>, container_frontend_timeout: Option<TimeoutContainer>, cluster_id: Option<String>, frontend_buffer: Checkout, frontend_token: Token, frontend: Front, listener: Rc<RefCell<L>>, protocol: Protocol, request_id: Ulid, session_address: Option<SocketAddr>, websocket_context: WebSocketContext, ) -> Pipe<Front, L>

Instantiate a new Pipe SessionState with:

  • frontend_interest: READABLE | WRITABLE | HUP | ERROR
  • frontend_event: EMPTY
  • backend_interest: READABLE | WRITABLE | HUP | ERROR
  • backend_event: EMPTY

Remember to set the events from the previous State!

Source

pub fn front_socket(&self) -> &TcpStream

Source

pub fn front_socket_mut(&mut self) -> &mut TcpStream

Source

pub fn back_socket(&self) -> Option<&TcpStream>

Source

pub fn back_socket_mut(&mut self) -> Option<&mut TcpStream>

Source

pub fn set_back_socket(&mut self, socket: TcpStream)

Source

pub fn back_token(&self) -> Vec<Token>

Source

pub fn set_cluster_id(&mut self, cluster_id: Option<String>)

Source

pub fn set_backend_id(&mut self, backend_id: Option<String>)

Source

pub fn set_back_token(&mut self, token: Token)

Source

pub fn get_session_address(&self) -> Option<SocketAddr>

Source

pub fn get_backend_address(&self) -> Option<SocketAddr>

Source

pub fn log_request( &self, metrics: &SessionMetrics, error: bool, message: Option<&str>, )

Source

pub fn log_request_success(&self, metrics: &SessionMetrics)

Source

pub fn log_request_error(&self, metrics: &SessionMetrics, message: &str)

Source

pub fn check_connections(&self) -> bool

Wether the session should be kept open, depending on endpoints status and buffer usage (both in memory and in kernel)

Source

pub fn frontend_hup(&mut self, metrics: &mut SessionMetrics) -> SessionResult

Source

pub fn backend_hup(&mut self, metrics: &mut SessionMetrics) -> SessionResult

Source

pub fn readable(&mut self, metrics: &mut SessionMetrics) -> SessionResult

Source

pub fn writable(&mut self, metrics: &mut SessionMetrics) -> SessionResult

Source

pub fn backend_writable( &mut self, metrics: &mut SessionMetrics, ) -> SessionResult

Source

pub fn backend_readable( &mut self, metrics: &mut SessionMetrics, ) -> SessionResult

Source

pub fn log_context(&self) -> LogContext<'_>

Trait Implementations§

Source§

impl<Front: SocketHandler, L: ListenerHandler> SessionState for Pipe<Front, L>

Source§

fn ready( &mut self, _session: Rc<RefCell<dyn ProxySession>>, _proxy: Rc<RefCell<dyn L7Proxy>>, metrics: &mut SessionMetrics, ) -> SessionResult

if a session received an event or can still execute, the event loop will call this method. Its result indicates if it can still execute or if the session can be closed
Source§

fn update_readiness(&mut self, token: Token, events: Ready)

if the event loop got an event for a token associated with the session, it will call this method
Source§

fn timeout(&mut self, token: Token, metrics: &mut SessionMetrics) -> StateResult

if a timeout associated with the session triggers, the event loop will call this method with the timeout’s token
Source§

fn cancel_timeouts(&mut self)

cancel frontend timeout (and backend timeout if present)
Source§

fn close( &mut self, _proxy: Rc<RefCell<dyn L7Proxy>>, _metrics: &mut SessionMetrics, )

close the state
Source§

fn print_state(&self, context: &str)

display the session’s internal state (for debugging purpose), Read more
Source§

fn shutting_down(&mut self) -> bool

tell the session it has to shut down if possible Read more

Auto Trait Implementations§

§

impl<Front, L> !Freeze for Pipe<Front, L>

§

impl<Front, L> !RefUnwindSafe for Pipe<Front, L>

§

impl<Front, L> !Send for Pipe<Front, L>

§

impl<Front, L> !Sync for Pipe<Front, L>

§

impl<Front, L> Unpin for Pipe<Front, L>
where Front: Unpin,

§

impl<Front, L> !UnwindSafe for Pipe<Front, L>

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<'a, T, E> AsTaggedExplicit<'a, E> for T
where T: 'a,

Source§

fn explicit(self, class: Class, tag: u32) -> TaggedParser<'a, Explicit, Self, E>

Source§

impl<'a, T, E> AsTaggedImplicit<'a, E> for T
where T: 'a,

Source§

fn implicit( self, class: Class, constructed: bool, tag: u32, ) -> TaggedParser<'a, Implicit, Self, E>

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, 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> Same for T

Source§

type Output = T

Should always be Self
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<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> ErasedDestructor for T
where T: 'static,