Skip to content

Commit

Permalink
use better name Route::data instead of Route::config
Browse files Browse the repository at this point in the history
  • Loading branch information
fafhrd91 committed Mar 16, 2019
1 parent 1f9467e commit d93fe15
Show file tree
Hide file tree
Showing 6 changed files with 22 additions and 40 deletions.
2 changes: 1 addition & 1 deletion src/extract/form.rs
Original file line number Diff line number Diff line change
Expand Up @@ -130,7 +130,7 @@ impl<T: fmt::Display> fmt::Display for Form<T> {
/// web::resource("/index.html")
/// .route(web::get()
/// // change `Form` extractor configuration
/// .config(web::FormConfig::default().limit(4097))
/// .data(web::FormConfig::default().limit(4097))
/// .to(index))
/// );
/// }
Expand Down
2 changes: 1 addition & 1 deletion src/extract/json.rs
Original file line number Diff line number Diff line change
Expand Up @@ -215,7 +215,7 @@ where
/// fn main() {
/// let app = App::new().service(
/// web::resource("/index.html").route(
/// web::post().config(
/// web::post().data(
/// // change json extractor configuration
/// web::JsonConfig::default().limit(4096)
/// .error_handler(|err, req| { // <- create custom error response
Expand Down
2 changes: 1 addition & 1 deletion src/extract/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -262,7 +262,7 @@ mod tests {
header::CONTENT_TYPE,
"application/x-www-form-urlencoded",
)
.config(FormConfig::default().limit(4096))
.route_data(FormConfig::default().limit(4096))
.to_from();

let r = block_on(Option::<Form<Info>>::from_request(&mut req)).unwrap();
Expand Down
2 changes: 1 addition & 1 deletion src/extract/payload.rs
Original file line number Diff line number Diff line change
Expand Up @@ -177,7 +177,7 @@ where
/// let app = App::new().service(
/// web::resource("/index.html").route(
/// web::get()
/// .config(web::PayloadConfig::new(4096)) // <- limit size of the payload
/// .data(web::PayloadConfig::new(4096)) // <- limit size of the payload
/// .to(index)) // <- register handler with extractor params
/// );
/// }
Expand Down
50 changes: 16 additions & 34 deletions src/route.rs
Original file line number Diff line number Diff line change
Expand Up @@ -40,28 +40,28 @@ type BoxedRouteNewService<Req, Res> = Box<
pub struct Route<P> {
service: BoxedRouteNewService<ServiceRequest<P>, ServiceResponse>,
guards: Rc<Vec<Box<Guard>>>,
config: Option<Extensions>,
config_ref: Rc<RefCell<Option<Rc<Extensions>>>>,
data: Option<Extensions>,
data_ref: Rc<RefCell<Option<Rc<Extensions>>>>,
}

impl<P: 'static> Route<P> {
/// Create new route which matches any request.
pub fn new() -> Route<P> {
let config_ref = Rc::new(RefCell::new(None));
let data_ref = Rc::new(RefCell::new(None));
Route {
service: Box::new(RouteNewService::new(
Extract::new(config_ref.clone()).and_then(
Extract::new(data_ref.clone()).and_then(
Handler::new(HttpResponse::NotFound).map_err(|_| panic!()),
),
)),
guards: Rc::new(Vec::new()),
config: None,
config_ref,
data: None,
data_ref,
}
}

pub(crate) fn finish(mut self) -> Self {
*self.config_ref.borrow_mut() = self.config.take().map(|e| Rc::new(e));
*self.data_ref.borrow_mut() = self.data.take().map(|e| Rc::new(e));
self
}

Expand Down Expand Up @@ -180,24 +180,6 @@ impl<P: 'static> Route<P> {
self
}

// pub fn map<T, U, F: IntoNewService<T>>(
// self,
// md: F,
// ) -> RouteServiceBuilder<T, S, (), U>
// where
// T: NewService<
// Request = HandlerRequest<S>,
// Response = HandlerRequest<S, U>,
// InitError = Error,
// >,
// {
// RouteServiceBuilder {
// service: md.into_new_service(),
// guards: self.guards,
// _t: PhantomData,
// }
// }

/// Set handler function, use request extractors for parameters.
///
/// ```rust
Expand Down Expand Up @@ -253,7 +235,7 @@ impl<P: 'static> Route<P> {
R: Responder + 'static,
{
self.service = Box::new(RouteNewService::new(
Extract::new(self.config_ref.clone())
Extract::new(self.data_ref.clone())
.and_then(Handler::new(handler).map_err(|_| panic!())),
));
self
Expand Down Expand Up @@ -295,14 +277,14 @@ impl<P: 'static> Route<P> {
R::Error: Into<Error>,
{
self.service = Box::new(RouteNewService::new(
Extract::new(self.config_ref.clone())
Extract::new(self.data_ref.clone())
.and_then(AsyncHandler::new(handler).map_err(|_| panic!())),
));
self
}

/// This method allows to add extractor configuration
/// for specific route.
/// Provide route specific data. This method allows to add extractor
/// configuration or specific state available via `RouteData<T>` extractor.
///
/// ```rust
/// use actix_web::{web, App};
Expand All @@ -317,17 +299,17 @@ impl<P: 'static> Route<P> {
/// web::resource("/index.html").route(
/// web::get()
/// // limit size of the payload
/// .config(web::PayloadConfig::new(4096))
/// .data(web::PayloadConfig::new(4096))
/// // register handler
/// .to(index)
/// ));
/// }
/// ```
pub fn config<C: 'static>(mut self, config: C) -> Self {
if self.config.is_none() {
self.config = Some(Extensions::new());
pub fn data<C: 'static>(mut self, data: C) -> Self {
if self.data.is_none() {
self.data = Some(Extensions::new());
}
self.config.as_mut().unwrap().insert(config);
self.data.as_mut().unwrap().insert(data);
self
}
}
Expand Down
4 changes: 2 additions & 2 deletions src/test.rs
Original file line number Diff line number Diff line change
Expand Up @@ -265,8 +265,8 @@ impl TestRequest {
self
}

/// Set request config
pub fn config<T: 'static>(self, data: T) -> Self {
/// Set route data
pub fn route_data<T: 'static>(self, data: T) -> Self {
self.config.extensions.borrow_mut().insert(data);
self
}
Expand Down

0 comments on commit d93fe15

Please sign in to comment.