mirror of
https://github.com/fafhrd91/actix-web
synced 2025-01-18 13:51:50 +01:00
expose low level data
This commit is contained in:
parent
082ff46041
commit
483db7028c
@ -1,6 +1,6 @@
|
|||||||
#![cfg_attr(feature = "cargo-clippy", allow(redundant_field_names))]
|
#![cfg_attr(feature = "cargo-clippy", allow(redundant_field_names))]
|
||||||
|
|
||||||
use bytes::BufMut;
|
use bytes::{BytesMut, BufMut};
|
||||||
use futures::{Async, Poll};
|
use futures::{Async, Poll};
|
||||||
use std::io;
|
use std::io;
|
||||||
use std::rc::Rc;
|
use std::rc::Rc;
|
||||||
@ -45,7 +45,7 @@ impl<T: AsyncWrite, H: 'static> H1Writer<T, H> {
|
|||||||
stream: T, buf: SharedBytes, settings: Rc<WorkerSettings<H>>,
|
stream: T, buf: SharedBytes, settings: Rc<WorkerSettings<H>>,
|
||||||
) -> H1Writer<T, H> {
|
) -> H1Writer<T, H> {
|
||||||
H1Writer {
|
H1Writer {
|
||||||
flags: Flags::empty(),
|
flags: Flags::KEEPALIVE,
|
||||||
encoder: ContentEncoder::empty(buf.clone()),
|
encoder: ContentEncoder::empty(buf.clone()),
|
||||||
written: 0,
|
written: 0,
|
||||||
headers_size: 0,
|
headers_size: 0,
|
||||||
@ -62,7 +62,7 @@ impl<T: AsyncWrite, H: 'static> H1Writer<T, H> {
|
|||||||
|
|
||||||
pub fn reset(&mut self) {
|
pub fn reset(&mut self) {
|
||||||
self.written = 0;
|
self.written = 0;
|
||||||
self.flags = Flags::empty();
|
self.flags = Flags::KEEPALIVE;
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn disconnected(&mut self) {
|
pub fn disconnected(&mut self) {
|
||||||
@ -100,6 +100,16 @@ impl<T: AsyncWrite, H: 'static> Writer for H1Writer<T, H> {
|
|||||||
self.written
|
self.written
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[inline]
|
||||||
|
fn set_date(&self, dst: &mut BytesMut) {
|
||||||
|
self.settings.set_date(dst)
|
||||||
|
}
|
||||||
|
|
||||||
|
#[inline]
|
||||||
|
fn buffer(&self) -> &mut BytesMut {
|
||||||
|
self.buffer.get_mut()
|
||||||
|
}
|
||||||
|
|
||||||
fn start(
|
fn start(
|
||||||
&mut self, req: &mut HttpInnerMessage, msg: &mut HttpResponse,
|
&mut self, req: &mut HttpInnerMessage, msg: &mut HttpResponse,
|
||||||
encoding: ContentEncoding,
|
encoding: ContentEncoding,
|
||||||
@ -108,9 +118,9 @@ impl<T: AsyncWrite, H: 'static> Writer for H1Writer<T, H> {
|
|||||||
self.encoder =
|
self.encoder =
|
||||||
ContentEncoder::for_server(self.buffer.clone(), req, msg, encoding);
|
ContentEncoder::for_server(self.buffer.clone(), req, msg, encoding);
|
||||||
if msg.keep_alive().unwrap_or_else(|| req.keep_alive()) {
|
if msg.keep_alive().unwrap_or_else(|| req.keep_alive()) {
|
||||||
self.flags.insert(Flags::STARTED | Flags::KEEPALIVE);
|
self.flags = Flags::STARTED | Flags::KEEPALIVE;
|
||||||
} else {
|
} else {
|
||||||
self.flags.insert(Flags::STARTED);
|
self.flags = Flags::STARTED;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Connection upgrade
|
// Connection upgrade
|
||||||
|
@ -71,6 +71,16 @@ impl<H: 'static> Writer for H2Writer<H> {
|
|||||||
self.written
|
self.written
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[inline]
|
||||||
|
fn set_date(&self, dst: &mut BytesMut) {
|
||||||
|
self.settings.set_date(dst)
|
||||||
|
}
|
||||||
|
|
||||||
|
#[inline]
|
||||||
|
fn buffer(&self) -> &mut BytesMut {
|
||||||
|
self.buffer.get_mut()
|
||||||
|
}
|
||||||
|
|
||||||
fn start(
|
fn start(
|
||||||
&mut self, req: &mut HttpInnerMessage, msg: &mut HttpResponse,
|
&mut self, req: &mut HttpInnerMessage, msg: &mut HttpResponse,
|
||||||
encoding: ContentEncoding,
|
encoding: ContentEncoding,
|
||||||
|
@ -143,7 +143,7 @@ pub(crate) fn write_status_line(version: Version, mut n: u16, bytes: &mut BytesM
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// NOTE: bytes object has to contain enough space
|
/// NOTE: bytes object has to contain enough space
|
||||||
pub(crate) fn write_content_length(mut n: usize, bytes: &mut BytesMut) {
|
pub fn write_content_length(mut n: usize, bytes: &mut BytesMut) {
|
||||||
if n < 10 {
|
if n < 10 {
|
||||||
let mut buf: [u8; 21] = [
|
let mut buf: [u8; 21] = [
|
||||||
b'\r', b'\n', b'c', b'o', b'n', b't', b'e', b'n', b't', b'-', b'l', b'e',
|
b'\r', b'\n', b'c', b'o', b'n', b't', b'e', b'n', b't', b'-', b'l', b'e',
|
||||||
|
@ -3,7 +3,8 @@ use std::net::Shutdown;
|
|||||||
use std::{io, time};
|
use std::{io, time};
|
||||||
|
|
||||||
use actix;
|
use actix;
|
||||||
use futures::Poll;
|
use bytes::BytesMut;
|
||||||
|
use futures::{Async, Poll};
|
||||||
use tokio_core::net::TcpStream;
|
use tokio_core::net::TcpStream;
|
||||||
use tokio_io::{AsyncRead, AsyncWrite};
|
use tokio_io::{AsyncRead, AsyncWrite};
|
||||||
|
|
||||||
@ -24,6 +25,9 @@ mod worker;
|
|||||||
pub use self::settings::ServerSettings;
|
pub use self::settings::ServerSettings;
|
||||||
pub use self::srv::HttpServer;
|
pub use self::srv::HttpServer;
|
||||||
|
|
||||||
|
#[doc(hidden)]
|
||||||
|
pub use self::helpers::write_content_length;
|
||||||
|
|
||||||
use body::Binary;
|
use body::Binary;
|
||||||
use error::Error;
|
use error::Error;
|
||||||
use header::ContentEncoding;
|
use header::ContentEncoding;
|
||||||
@ -132,13 +136,15 @@ impl HttpHandler for Box<HttpHandler> {
|
|||||||
#[doc(hidden)]
|
#[doc(hidden)]
|
||||||
pub trait HttpHandlerTask {
|
pub trait HttpHandlerTask {
|
||||||
/// Poll task, this method is used before or after *io* object is available
|
/// Poll task, this method is used before or after *io* object is available
|
||||||
fn poll(&mut self) -> Poll<(), Error>;
|
fn poll(&mut self) -> Poll<(), Error>{
|
||||||
|
Ok(Async::Ready(()))
|
||||||
|
}
|
||||||
|
|
||||||
/// Poll task when *io* object is available
|
/// Poll task when *io* object is available
|
||||||
fn poll_io(&mut self, io: &mut Writer) -> Poll<bool, Error>;
|
fn poll_io(&mut self, io: &mut Writer) -> Poll<bool, Error>;
|
||||||
|
|
||||||
/// Connection is disconnected
|
/// Connection is disconnected
|
||||||
fn disconnected(&mut self);
|
fn disconnected(&mut self) {}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Conversion helper trait
|
/// Conversion helper trait
|
||||||
@ -168,8 +174,16 @@ pub enum WriterState {
|
|||||||
#[doc(hidden)]
|
#[doc(hidden)]
|
||||||
/// Stream writer
|
/// Stream writer
|
||||||
pub trait Writer {
|
pub trait Writer {
|
||||||
|
/// number of bytes written to the stream
|
||||||
fn written(&self) -> u64;
|
fn written(&self) -> u64;
|
||||||
|
|
||||||
|
#[doc(hidden)]
|
||||||
|
fn set_date(&self, st: &mut BytesMut);
|
||||||
|
|
||||||
|
#[doc(hidden)]
|
||||||
|
#[cfg_attr(feature = "cargo-clippy", allow(mut_from_ref))]
|
||||||
|
fn buffer(&self) -> &mut BytesMut;
|
||||||
|
|
||||||
fn start(
|
fn start(
|
||||||
&mut self, req: &mut HttpInnerMessage, resp: &mut HttpResponse,
|
&mut self, req: &mut HttpInnerMessage, resp: &mut HttpResponse,
|
||||||
encoding: ContentEncoding,
|
encoding: ContentEncoding,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user