pub struct Request<'a, 'b: 'a> {
pub remote_addr: SocketAddr,
pub method: Method,
pub headers: Headers,
pub uri: RequestUri,
pub version: HttpVersion,
pub extra: Extensions,
pub body: HttpReader<&'a mut BufReader<&'b mut dyn NetworkStream>>,
}
Expand description
A request bundles several parts of an incoming NetworkStream
, given to a Handler
.
Fields§
§remote_addr: SocketAddr
The IP address of the remote connection.
method: Method
The Method
, such as Get
, Post
, etc.
headers: Headers
The headers of the incoming request.
uri: RequestUri
The target request-uri for this request.
version: HttpVersion
The version of HTTP for this request.
extra: Extensions
The extra User defined data
body: HttpReader<&'a mut BufReader<&'b mut dyn NetworkStream>>
http body
Implementations§
Source§impl<'a, 'b: 'a> Request<'a, 'b>
impl<'a, 'b: 'a> Request<'a, 'b>
Sourcepub fn new(
stream: &'a mut BufReader<&'b mut dyn NetworkStream>,
addr: SocketAddr,
) -> Result<Request<'a, 'b>>
pub fn new( stream: &'a mut BufReader<&'b mut dyn NetworkStream>, addr: SocketAddr, ) -> Result<Request<'a, 'b>>
Create a new Request, reading the StartLine and Headers so they are immediately useful.
Sourcepub fn set_read_timeout(&self, timeout: Option<Duration>) -> Result<()>
pub fn set_read_timeout(&self, timeout: Option<Duration>) -> Result<()>
Set the read timeout of the underlying NetworkStream.
Sourcepub fn downcast_ref<T: NetworkStream>(&self) -> Option<&T>
pub fn downcast_ref<T: NetworkStream>(&self) -> Option<&T>
Get a reference to the underlying NetworkStream
.
Sourcepub fn ssl<T: NetworkStream>(&self) -> Option<&T>
pub fn ssl<T: NetworkStream>(&self) -> Option<&T>
Get a reference to the underlying Ssl stream, if connected over HTTPS.
This is actually just an alias for downcast_ref
.
Sourcepub fn deconstruct(
self,
) -> (SocketAddr, Method, Headers, RequestUri, HttpVersion, HttpReader<&'a mut BufReader<&'b mut dyn NetworkStream>>)
pub fn deconstruct( self, ) -> (SocketAddr, Method, Headers, RequestUri, HttpVersion, HttpReader<&'a mut BufReader<&'b mut dyn NetworkStream>>)
Deconstruct a Request into its constituent parts.
Trait Implementations§
Source§impl<'a, 'b> Read for Request<'a, 'b>
impl<'a, 'b> Read for Request<'a, 'b>
Source§fn read(&mut self, buf: &mut [u8]) -> Result<usize>
fn read(&mut self, buf: &mut [u8]) -> Result<usize>
Pull some bytes from this source into the specified buffer, returning
how many bytes were read. Read more
1.36.0 · Source§fn read_vectored(&mut self, bufs: &mut [IoSliceMut<'_>]) -> Result<usize, Error>
fn read_vectored(&mut self, bufs: &mut [IoSliceMut<'_>]) -> Result<usize, Error>
Like
read
, except that it reads into a slice of buffers. Read moreSource§fn is_read_vectored(&self) -> bool
fn is_read_vectored(&self) -> bool
🔬This is a nightly-only experimental API. (
can_vector
)1.0.0 · Source§fn read_to_end(&mut self, buf: &mut Vec<u8>) -> Result<usize, Error>
fn read_to_end(&mut self, buf: &mut Vec<u8>) -> Result<usize, Error>
Reads all bytes until EOF in this source, placing them into
buf
. Read more1.0.0 · Source§fn read_to_string(&mut self, buf: &mut String) -> Result<usize, Error>
fn read_to_string(&mut self, buf: &mut String) -> Result<usize, Error>
Reads all bytes until EOF in this source, appending them to
buf
. Read more1.6.0 · Source§fn read_exact(&mut self, buf: &mut [u8]) -> Result<(), Error>
fn read_exact(&mut self, buf: &mut [u8]) -> Result<(), Error>
Reads the exact number of bytes required to fill
buf
. Read moreSource§fn read_buf(&mut self, buf: BorrowedCursor<'_>) -> Result<(), Error>
fn read_buf(&mut self, buf: BorrowedCursor<'_>) -> Result<(), Error>
🔬This is a nightly-only experimental API. (
read_buf
)Pull some bytes from this source into the specified buffer. Read more
Source§fn read_buf_exact(&mut self, cursor: BorrowedCursor<'_>) -> Result<(), Error>
fn read_buf_exact(&mut self, cursor: BorrowedCursor<'_>) -> Result<(), Error>
🔬This is a nightly-only experimental API. (
read_buf
)Reads the exact number of bytes required to fill
cursor
. Read more1.0.0 · Source§fn by_ref(&mut self) -> &mut Selfwhere
Self: Sized,
fn by_ref(&mut self) -> &mut Selfwhere
Self: Sized,
Creates a “by reference” adaptor for this instance of
Read
. Read moreAuto Trait Implementations§
impl<'a, 'b> Freeze for Request<'a, 'b>
impl<'a, 'b> !RefUnwindSafe for Request<'a, 'b>
impl<'a, 'b> Send for Request<'a, 'b>
impl<'a, 'b> !Sync for Request<'a, 'b>
impl<'a, 'b> Unpin for Request<'a, 'b>
impl<'a, 'b> !UnwindSafe for Request<'a, 'b>
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more