1
0
Fork 0
mirror of https://github.com/actix/actix-web.git synced 2025-01-03 13:58:44 +00:00

unhide SessionBackend and SessionImpl traits and cleanup warnings

This commit is contained in:
Nikolay Kim 2018-09-07 20:46:43 -07:00
parent 51982b3fec
commit 002bb24b26
7 changed files with 46 additions and 19 deletions

View file

@ -5,8 +5,14 @@
### Fixed ### Fixed
* Fix system_exit in HttpServer #501 * Fix system_exit in HttpServer #501
* Fix parsing of route param containin regexes with repetition #500 * Fix parsing of route param containin regexes with repetition #500
### Changes
* Unhide `SessionBackend` and `SessionImpl` traits #455
## [0.7.5] - 2018-09-04 ## [0.7.5] - 2018-09-04
### Added ### Added

View file

@ -101,6 +101,7 @@ tokio-io = "0.1"
tokio-tcp = "0.1" tokio-tcp = "0.1"
tokio-timer = "0.2" tokio-timer = "0.2"
tokio-reactor = "0.1" tokio-reactor = "0.1"
tokio-current-thread = "0.1"
# native-tls # native-tls
native-tls = { version="0.2", optional = true } native-tls = { version="0.2", optional = true }

View file

@ -204,6 +204,7 @@ impl Paused {
/// `ClientConnector` type is responsible for transport layer of a /// `ClientConnector` type is responsible for transport layer of a
/// client connection. /// client connection.
pub struct ClientConnector { pub struct ClientConnector {
#[allow(dead_code)]
connector: SslConnector, connector: SslConnector,
stats: ClientConnectorStats, stats: ClientConnectorStats,

View file

@ -118,6 +118,7 @@ extern crate parking_lot;
extern crate rand; extern crate rand;
extern crate slab; extern crate slab;
extern crate tokio; extern crate tokio;
extern crate tokio_current_thread;
extern crate tokio_io; extern crate tokio_io;
extern crate tokio_reactor; extern crate tokio_reactor;
extern crate tokio_tcp; extern crate tokio_tcp;

View file

@ -270,14 +270,17 @@ impl<S: 'static, T: SessionBackend<S>> Middleware<S> for SessionStorage<T, S> {
} }
/// A simple key-value storage interface that is internally used by `Session`. /// A simple key-value storage interface that is internally used by `Session`.
#[doc(hidden)]
pub trait SessionImpl: 'static { pub trait SessionImpl: 'static {
/// Get session value by key
fn get(&self, key: &str) -> Option<&str>; fn get(&self, key: &str) -> Option<&str>;
/// Set session value
fn set(&mut self, key: &str, value: String); fn set(&mut self, key: &str, value: String);
/// Remove specific key from session
fn remove(&mut self, key: &str); fn remove(&mut self, key: &str);
/// Remove all values from session
fn clear(&mut self); fn clear(&mut self);
/// Write session to storage backend. /// Write session to storage backend.
@ -285,9 +288,10 @@ pub trait SessionImpl: 'static {
} }
/// Session's storage backend trait definition. /// Session's storage backend trait definition.
#[doc(hidden)]
pub trait SessionBackend<S>: Sized + 'static { pub trait SessionBackend<S>: Sized + 'static {
/// Session item
type Session: SessionImpl; type Session: SessionImpl;
/// Future that reads session
type ReadFuture: Future<Item = Self::Session, Error = Error>; type ReadFuture: Future<Item = Self::Session, Error = Error>;
/// Parse the session from request and load data from a storage backend. /// Parse the session from request and load data from a storage backend.

View file

@ -815,16 +815,21 @@ impl ResourceDef {
Ok(()) Ok(())
} }
fn parse_param( fn parse_param(pattern: &str) -> (PatternElement, String, &str) {
pattern: &str,
) -> (PatternElement, String, &str) {
const DEFAULT_PATTERN: &str = "[^/]+"; const DEFAULT_PATTERN: &str = "[^/]+";
let mut params_nesting = 0usize; let mut params_nesting = 0usize;
let close_idx = pattern.find(|c| match c { let close_idx = pattern
'{' => {params_nesting += 1; false}, .find(|c| match c {
'}' => {params_nesting -= 1; params_nesting == 0}, '{' => {
_ => false params_nesting += 1;
}).expect("malformed param"); false
}
'}' => {
params_nesting -= 1;
params_nesting == 0
}
_ => false,
}).expect("malformed param");
let (mut param, rem) = pattern.split_at(close_idx + 1); let (mut param, rem) = pattern.split_at(close_idx + 1);
param = &param[1..param.len() - 1]; // Remove outer brackets param = &param[1..param.len() - 1]; // Remove outer brackets
let (name, pattern) = match param.find(":") { let (name, pattern) = match param.find(":") {
@ -832,16 +837,25 @@ impl ResourceDef {
let (name, pattern) = param.split_at(idx); let (name, pattern) = param.split_at(idx);
(name, &pattern[1..]) (name, &pattern[1..])
} }
None => (param, DEFAULT_PATTERN) None => (param, DEFAULT_PATTERN),
}; };
(PatternElement::Var(name.to_string()), format!(r"(?P<{}>{})", &name, &pattern), rem) (
PatternElement::Var(name.to_string()),
format!(r"(?P<{}>{})", &name, &pattern),
rem,
)
} }
fn parse( fn parse(
mut pattern: &str, for_prefix: bool, mut pattern: &str, for_prefix: bool,
) -> (String, Vec<PatternElement>, bool, usize) { ) -> (String, Vec<PatternElement>, bool, usize) {
if pattern.find("{").is_none() { if pattern.find("{").is_none() {
return (String::from(pattern), vec![PatternElement::Str(String::from(pattern))], false, pattern.chars().count()) return (
String::from(pattern),
vec![PatternElement::Str(String::from(pattern))],
false,
pattern.chars().count(),
);
}; };
let mut elems = Vec::new(); let mut elems = Vec::new();

View file

@ -3,12 +3,12 @@ use std::rc::Rc;
use std::sync::Arc; use std::sync::Arc;
use std::{io, mem, net, time}; use std::{io, mem, net, time};
use actix::{Actor, Addr, Arbiter, AsyncContext, Context, Handler, System}; use actix::{Actor, Addr, AsyncContext, Context, Handler, System};
use futures::{Future, Stream}; use futures::{Future, Stream};
use net2::{TcpBuilder, TcpStreamExt}; use net2::{TcpBuilder, TcpStreamExt};
use num_cpus; use num_cpus;
use tokio::executor::current_thread; use tokio_current_thread::spawn;
use tokio_io::{AsyncRead, AsyncWrite}; use tokio_io::{AsyncRead, AsyncWrite};
use tokio_tcp::TcpStream; use tokio_tcp::TcpStream;
@ -585,7 +585,7 @@ where
type Result = (); type Result = ();
fn handle(&mut self, msg: Conn<T>, _: &mut Context<Self>) -> Self::Result { fn handle(&mut self, msg: Conn<T>, _: &mut Context<Self>) -> Self::Result {
Arbiter::spawn(HttpChannel::new( spawn(HttpChannel::new(
Rc::clone(&self.settings), Rc::clone(&self.settings),
msg.io, msg.io,
msg.peer, msg.peer,
@ -693,7 +693,7 @@ where
}; };
let _ = io.set_nodelay(true); let _ = io.set_nodelay(true);
current_thread::spawn(HttpChannel::new(h, io, peer)); spawn(HttpChannel::new(h, io, peer));
} }
} }
@ -753,10 +753,10 @@ where
let _ = io.set_nodelay(true); let _ = io.set_nodelay(true);
let rate = h.connection_rate(); let rate = h.connection_rate();
current_thread::spawn(self.acceptor.accept(io).then(move |res| { spawn(self.acceptor.accept(io).then(move |res| {
drop(rate); drop(rate);
match res { match res {
Ok(io) => current_thread::spawn(HttpChannel::new(h, io, peer)), Ok(io) => spawn(HttpChannel::new(h, io, peer)),
Err(err) => trace!("Can not establish connection: {}", err), Err(err) => trace!("Can not establish connection: {}", err),
} }
Ok(()) Ok(())