mirror of
https://github.com/actix/actix-extras.git
synced 2025-01-23 15:24:36 +01:00
rename ResourceHandler to Resource
This commit is contained in:
parent
db005af1af
commit
b8b90d9ec9
@ -9,8 +9,8 @@ use httpresponse::HttpResponse;
|
||||
use middleware::Middleware;
|
||||
use pipeline::{HandlerType, Pipeline, PipelineHandler};
|
||||
use pred::Predicate;
|
||||
use resource::ResourceHandler;
|
||||
use router::{Resource, RouteInfo, Router};
|
||||
use resource::Resource;
|
||||
use router::{ResourceDef, RouteInfo, Router};
|
||||
use scope::Scope;
|
||||
use server::{HttpHandler, HttpHandlerTask, IntoHttpHandler, Request};
|
||||
|
||||
@ -28,15 +28,15 @@ pub struct HttpApplication<S = ()> {
|
||||
#[doc(hidden)]
|
||||
pub struct Inner<S> {
|
||||
prefix: usize,
|
||||
default: Rc<ResourceHandler<S>>,
|
||||
default: Rc<Resource<S>>,
|
||||
encoding: ContentEncoding,
|
||||
resources: Vec<ResourceHandler<S>>,
|
||||
resources: Vec<Resource<S>>,
|
||||
handlers: Vec<PrefixHandlerType<S>>,
|
||||
}
|
||||
|
||||
enum PrefixHandlerType<S> {
|
||||
Handler(String, Box<RouteHandler<S>>),
|
||||
Scope(Resource, Box<RouteHandler<S>>, Vec<Box<Predicate<S>>>),
|
||||
Scope(ResourceDef, Box<RouteHandler<S>>, Vec<Box<Predicate<S>>>),
|
||||
}
|
||||
|
||||
impl<S: 'static> PipelineHandler<S> for Inner<S> {
|
||||
@ -154,10 +154,10 @@ impl<S: 'static> HttpHandler for HttpApplication<S> {
|
||||
struct ApplicationParts<S> {
|
||||
state: S,
|
||||
prefix: String,
|
||||
default: Rc<ResourceHandler<S>>,
|
||||
resources: Vec<(Resource, Option<ResourceHandler<S>>)>,
|
||||
default: Rc<Resource<S>>,
|
||||
resources: Vec<(ResourceDef, Option<Resource<S>>)>,
|
||||
handlers: Vec<PrefixHandlerType<S>>,
|
||||
external: HashMap<String, Resource>,
|
||||
external: HashMap<String, ResourceDef>,
|
||||
encoding: ContentEncoding,
|
||||
middlewares: Vec<Box<Middleware<S>>>,
|
||||
filters: Vec<Box<Predicate<S>>>,
|
||||
@ -204,7 +204,7 @@ where
|
||||
parts: Some(ApplicationParts {
|
||||
state,
|
||||
prefix: "/".to_owned(),
|
||||
default: Rc::new(ResourceHandler::default_not_found()),
|
||||
default: Rc::new(Resource::default_not_found()),
|
||||
resources: Vec::new(),
|
||||
handlers: Vec::new(),
|
||||
external: HashMap::new(),
|
||||
@ -332,9 +332,9 @@ where
|
||||
}
|
||||
}
|
||||
} else {
|
||||
let mut handler = ResourceHandler::default();
|
||||
let mut handler = Resource::default();
|
||||
handler.method(method).with(f);
|
||||
let pattern = Resource::new(handler.get_name(), path);
|
||||
let pattern = ResourceDef::new(handler.get_name(), path);
|
||||
break Some((pattern, Some(handler)));
|
||||
}
|
||||
}
|
||||
@ -382,7 +382,7 @@ where
|
||||
|
||||
let filters = scope.take_filters();
|
||||
parts.handlers.push(PrefixHandlerType::Scope(
|
||||
Resource::prefix("", &path),
|
||||
ResourceDef::prefix("", &path),
|
||||
scope,
|
||||
filters,
|
||||
));
|
||||
@ -423,16 +423,16 @@ where
|
||||
/// ```
|
||||
pub fn resource<F, R>(mut self, path: &str, f: F) -> App<S>
|
||||
where
|
||||
F: FnOnce(&mut ResourceHandler<S>) -> R + 'static,
|
||||
F: FnOnce(&mut Resource<S>) -> R + 'static,
|
||||
{
|
||||
{
|
||||
let parts = self.parts.as_mut().expect("Use after finish");
|
||||
|
||||
// add resource handler
|
||||
let mut handler = ResourceHandler::default();
|
||||
let mut handler = Resource::default();
|
||||
f(&mut handler);
|
||||
|
||||
let pattern = Resource::new(handler.get_name(), path);
|
||||
let pattern = ResourceDef::new(handler.get_name(), path);
|
||||
parts.resources.push((pattern, Some(handler)));
|
||||
}
|
||||
self
|
||||
@ -440,8 +440,8 @@ where
|
||||
|
||||
/// Configure resource for a specific path.
|
||||
#[doc(hidden)]
|
||||
pub fn register_resource(&mut self, path: &str, resource: ResourceHandler<S>) {
|
||||
let pattern = Resource::new(resource.get_name(), path);
|
||||
pub fn register_resource(&mut self, path: &str, resource: Resource<S>) {
|
||||
let pattern = ResourceDef::new(resource.get_name(), path);
|
||||
self.parts
|
||||
.as_mut()
|
||||
.expect("Use after finish")
|
||||
@ -452,7 +452,7 @@ where
|
||||
/// Default resource to be used if no matching route could be found.
|
||||
pub fn default_resource<F, R>(mut self, f: F) -> App<S>
|
||||
where
|
||||
F: FnOnce(&mut ResourceHandler<S>) -> R + 'static,
|
||||
F: FnOnce(&mut Resource<S>) -> R + 'static,
|
||||
{
|
||||
{
|
||||
let parts = self.parts.as_mut().expect("Use after finish");
|
||||
@ -508,7 +508,7 @@ where
|
||||
}
|
||||
parts.external.insert(
|
||||
String::from(name.as_ref()),
|
||||
Resource::external(name.as_ref(), url.as_ref()),
|
||||
ResourceDef::external(name.as_ref(), url.as_ref()),
|
||||
);
|
||||
}
|
||||
self
|
||||
|
@ -613,8 +613,8 @@ mod tests {
|
||||
use futures::{Async, Future};
|
||||
use http::header;
|
||||
use mime;
|
||||
use resource::ResourceHandler;
|
||||
use router::{Resource, Router};
|
||||
use resource::Resource;
|
||||
use router::{ResourceDef, Router};
|
||||
use test::TestRequest;
|
||||
|
||||
#[derive(Deserialize, Debug, PartialEq)]
|
||||
@ -710,10 +710,10 @@ mod tests {
|
||||
fn test_request_extract() {
|
||||
let req = TestRequest::with_uri("/name/user1/?id=test").finish();
|
||||
|
||||
let mut resource = ResourceHandler::<()>::default();
|
||||
let mut resource = Resource::<()>::default();
|
||||
resource.name("index");
|
||||
let mut routes = Vec::new();
|
||||
routes.push((Resource::new("index", "/{key}/{value}/"), Some(resource)));
|
||||
routes.push((ResourceDef::new("index", "/{key}/{value}/"), Some(resource)));
|
||||
let (router, _) = Router::new("", routes);
|
||||
let info = router.recognize(&req).unwrap().1;
|
||||
let req = req.with_route_info(info);
|
||||
@ -748,10 +748,10 @@ mod tests {
|
||||
|
||||
#[test]
|
||||
fn test_extract_path_single() {
|
||||
let mut resource = ResourceHandler::<()>::default();
|
||||
let mut resource = Resource::<()>::default();
|
||||
resource.name("index");
|
||||
let mut routes = Vec::new();
|
||||
routes.push((Resource::new("index", "/{value}/"), Some(resource)));
|
||||
routes.push((ResourceDef::new("index", "/{value}/"), Some(resource)));
|
||||
let (router, _) = Router::new("", routes);
|
||||
|
||||
let req = TestRequest::with_uri("/32/").finish_with_router(router.clone());
|
||||
@ -762,10 +762,10 @@ mod tests {
|
||||
|
||||
#[test]
|
||||
fn test_tuple_extract() {
|
||||
let mut resource = ResourceHandler::<()>::default();
|
||||
let mut resource = Resource::<()>::default();
|
||||
resource.name("index");
|
||||
let mut routes = Vec::new();
|
||||
routes.push((Resource::new("index", "/{key}/{value}/"), Some(resource)));
|
||||
routes.push((ResourceDef::new("index", "/{key}/{value}/"), Some(resource)));
|
||||
let (router, _) = Router::new("", routes);
|
||||
|
||||
let req = TestRequest::with_uri("/name/user1/?id=test")
|
||||
|
@ -9,7 +9,7 @@ use error::Error;
|
||||
use http::StatusCode;
|
||||
use httprequest::HttpRequest;
|
||||
use httpresponse::HttpResponse;
|
||||
use resource::ResourceHandler;
|
||||
use resource::Resource;
|
||||
|
||||
/// Trait defines object that could be registered as route handler
|
||||
#[allow(unused_variables)]
|
||||
@ -409,7 +409,7 @@ pub(crate) trait RouteHandler<S>: 'static {
|
||||
false
|
||||
}
|
||||
|
||||
fn default_resource(&mut self, _: Rc<ResourceHandler<S>>) {
|
||||
fn default_resource(&mut self, _: Rc<Resource<S>>) {
|
||||
unimplemented!()
|
||||
}
|
||||
}
|
||||
|
@ -20,7 +20,7 @@ use httpresponse::{HttpResponse, HttpResponseBuilder};
|
||||
use info::ConnectionInfo;
|
||||
use param::Params;
|
||||
use payload::Payload;
|
||||
use router::{Resource, RouteInfo};
|
||||
use router::{ResourceDef, RouteInfo};
|
||||
use server::Request;
|
||||
|
||||
struct Query(HashMap<String, String>);
|
||||
@ -211,7 +211,7 @@ impl<S> HttpRequest<S> {
|
||||
|
||||
/// This method returns reference to matched `Resource` object.
|
||||
#[inline]
|
||||
pub fn resource(&self) -> Option<&Resource> {
|
||||
pub fn resource(&self) -> Option<&ResourceDef> {
|
||||
self.route.resource()
|
||||
}
|
||||
|
||||
@ -370,8 +370,8 @@ impl<S> fmt::Debug for HttpRequest<S> {
|
||||
#[cfg(test)]
|
||||
mod tests {
|
||||
use super::*;
|
||||
use resource::ResourceHandler;
|
||||
use router::{Resource, Router};
|
||||
use resource::Resource;
|
||||
use router::{ResourceDef, Router};
|
||||
use test::TestRequest;
|
||||
|
||||
#[test]
|
||||
@ -422,10 +422,10 @@ mod tests {
|
||||
|
||||
#[test]
|
||||
fn test_request_match_info() {
|
||||
let mut resource = ResourceHandler::<()>::default();
|
||||
let mut resource = Resource::<()>::default();
|
||||
resource.name("index");
|
||||
let mut routes = Vec::new();
|
||||
routes.push((Resource::new("index", "/{key}/"), Some(resource)));
|
||||
routes.push((ResourceDef::new("index", "/{key}/"), Some(resource)));
|
||||
let (router, _) = Router::new("", routes);
|
||||
|
||||
let req = TestRequest::with_uri("/value/?id=test").finish();
|
||||
@ -435,10 +435,12 @@ mod tests {
|
||||
|
||||
#[test]
|
||||
fn test_url_for() {
|
||||
let mut resource = ResourceHandler::<()>::default();
|
||||
let mut resource = Resource::<()>::default();
|
||||
resource.name("index");
|
||||
let routes =
|
||||
vec![(Resource::new("index", "/user/{name}.{ext}"), Some(resource))];
|
||||
let routes = vec![(
|
||||
ResourceDef::new("index", "/user/{name}.{ext}"),
|
||||
Some(resource),
|
||||
)];
|
||||
let (router, _) = Router::new("/", routes);
|
||||
let info = router.default_route_info();
|
||||
assert!(info.has_route("/user/test.html"));
|
||||
@ -464,9 +466,12 @@ mod tests {
|
||||
|
||||
#[test]
|
||||
fn test_url_for_with_prefix() {
|
||||
let mut resource = ResourceHandler::<()>::default();
|
||||
let mut resource = Resource::<()>::default();
|
||||
resource.name("index");
|
||||
let routes = vec![(Resource::new("index", "/user/{name}.html"), Some(resource))];
|
||||
let routes = vec![(
|
||||
ResourceDef::new("index", "/user/{name}.html"),
|
||||
Some(resource),
|
||||
)];
|
||||
let (router, _) = Router::new("/prefix/", routes);
|
||||
let info = router.default_route_info();
|
||||
assert!(info.has_route("/user/test.html"));
|
||||
@ -483,9 +488,9 @@ mod tests {
|
||||
|
||||
#[test]
|
||||
fn test_url_for_static() {
|
||||
let mut resource = ResourceHandler::<()>::default();
|
||||
let mut resource = Resource::<()>::default();
|
||||
resource.name("index");
|
||||
let routes = vec![(Resource::new("index", "/index.html"), Some(resource))];
|
||||
let routes = vec![(ResourceDef::new("index", "/index.html"), Some(resource))];
|
||||
let (router, _) = Router::new("/prefix/", routes);
|
||||
let info = router.default_route_info();
|
||||
assert!(info.has_route("/index.html"));
|
||||
@ -503,10 +508,10 @@ mod tests {
|
||||
|
||||
#[test]
|
||||
fn test_url_for_external() {
|
||||
let mut resource = ResourceHandler::<()>::default();
|
||||
let mut resource = Resource::<()>::default();
|
||||
resource.name("index");
|
||||
let routes = vec![(
|
||||
Resource::external("youtube", "https://youtube.com/watch/{video_id}"),
|
||||
ResourceDef::external("youtube", "https://youtube.com/watch/{video_id}"),
|
||||
None,
|
||||
)];
|
||||
let router = Router::new::<()>("", routes).0;
|
||||
|
@ -244,9 +244,9 @@ pub mod dev {
|
||||
pub use info::ConnectionInfo;
|
||||
pub use json::{JsonBody, JsonConfig};
|
||||
pub use param::{FromParam, Params};
|
||||
pub use resource::ResourceHandler;
|
||||
pub use resource::Resource;
|
||||
pub use route::Route;
|
||||
pub use router::{Resource, ResourceType, Router};
|
||||
pub use router::{ResourceDef, ResourceType, Router};
|
||||
}
|
||||
|
||||
pub mod http {
|
||||
|
@ -11,7 +11,7 @@
|
||||
//! constructed backend.
|
||||
//!
|
||||
//! Cors middleware could be used as parameter for `App::middleware()` or
|
||||
//! `ResourceHandler::middleware()` methods. But you have to use
|
||||
//! `Resource::middleware()` methods. But you have to use
|
||||
//! `Cors::for_app()` method to support *preflight* OPTIONS request.
|
||||
//!
|
||||
//!
|
||||
@ -59,7 +59,7 @@ use httpmessage::HttpMessage;
|
||||
use httprequest::HttpRequest;
|
||||
use httpresponse::HttpResponse;
|
||||
use middleware::{Middleware, Response, Started};
|
||||
use resource::ResourceHandler;
|
||||
use resource::Resource;
|
||||
use server::Request;
|
||||
|
||||
/// A set of errors that can occur during processing CORS
|
||||
@ -277,9 +277,9 @@ impl Cors {
|
||||
/// adds route for *OPTIONS* preflight requests.
|
||||
///
|
||||
/// It is possible to register *Cors* middleware with
|
||||
/// `ResourceHandler::middleware()` method, but in that case *Cors*
|
||||
/// `Resource::middleware()` method, but in that case *Cors*
|
||||
/// middleware wont be able to handle *OPTIONS* requests.
|
||||
pub fn register<S: 'static>(self, resource: &mut ResourceHandler<S>) {
|
||||
pub fn register<S: 'static>(self, resource: &mut Resource<S>) {
|
||||
resource
|
||||
.method(Method::OPTIONS)
|
||||
.h(|_: &_| HttpResponse::Ok());
|
||||
@ -515,7 +515,7 @@ pub struct CorsBuilder<S = ()> {
|
||||
methods: bool,
|
||||
error: Option<http::Error>,
|
||||
expose_hdrs: HashSet<HeaderName>,
|
||||
resources: Vec<(String, ResourceHandler<S>)>,
|
||||
resources: Vec<(String, Resource<S>)>,
|
||||
app: Option<App<S>>,
|
||||
}
|
||||
|
||||
@ -795,10 +795,10 @@ impl<S: 'static> CorsBuilder<S> {
|
||||
/// ```
|
||||
pub fn resource<F, R>(&mut self, path: &str, f: F) -> &mut CorsBuilder<S>
|
||||
where
|
||||
F: FnOnce(&mut ResourceHandler<S>) -> R + 'static,
|
||||
F: FnOnce(&mut Resource<S>) -> R + 'static,
|
||||
{
|
||||
// add resource handler
|
||||
let mut handler = ResourceHandler::default();
|
||||
let mut handler = Resource::default();
|
||||
f(&mut handler);
|
||||
|
||||
self.resources.push((path.to_owned(), handler));
|
||||
|
@ -36,16 +36,16 @@ pub(crate) struct RouteId(usize);
|
||||
/// "/", |r| r.method(http::Method::GET).f(|r| HttpResponse::Ok()))
|
||||
/// .finish();
|
||||
/// }
|
||||
pub struct ResourceHandler<S = ()> {
|
||||
pub struct Resource<S = ()> {
|
||||
name: String,
|
||||
state: PhantomData<S>,
|
||||
routes: SmallVec<[Route<S>; 3]>,
|
||||
middlewares: Rc<Vec<Box<Middleware<S>>>>,
|
||||
}
|
||||
|
||||
impl<S> Default for ResourceHandler<S> {
|
||||
impl<S> Default for Resource<S> {
|
||||
fn default() -> Self {
|
||||
ResourceHandler {
|
||||
Resource {
|
||||
name: String::new(),
|
||||
state: PhantomData,
|
||||
routes: SmallVec::new(),
|
||||
@ -54,9 +54,9 @@ impl<S> Default for ResourceHandler<S> {
|
||||
}
|
||||
}
|
||||
|
||||
impl<S> ResourceHandler<S> {
|
||||
impl<S> Resource<S> {
|
||||
pub(crate) fn default_not_found() -> Self {
|
||||
ResourceHandler {
|
||||
Resource {
|
||||
name: String::new(),
|
||||
state: PhantomData,
|
||||
routes: SmallVec::new(),
|
||||
@ -74,7 +74,7 @@ impl<S> ResourceHandler<S> {
|
||||
}
|
||||
}
|
||||
|
||||
impl<S: 'static> ResourceHandler<S> {
|
||||
impl<S: 'static> Resource<S> {
|
||||
/// Register a new route and return mutable reference to *Route* object.
|
||||
/// *Route* is used for route configuration, i.e. adding predicates,
|
||||
/// setting up handler.
|
||||
|
110
src/router.rs
110
src/router.rs
@ -7,7 +7,7 @@ use url::Url;
|
||||
|
||||
use error::UrlGenerationError;
|
||||
use param::{ParamItem, Params};
|
||||
use resource::ResourceHandler;
|
||||
use resource::Resource;
|
||||
use server::Request;
|
||||
|
||||
#[derive(Debug, Copy, Clone, PartialEq)]
|
||||
@ -29,7 +29,7 @@ pub struct RouteInfo {
|
||||
impl RouteInfo {
|
||||
/// This method returns reference to matched `Resource` object.
|
||||
#[inline]
|
||||
pub fn resource(&self) -> Option<&Resource> {
|
||||
pub fn resource(&self) -> Option<&ResourceDef> {
|
||||
if let RouterResource::Normal(idx) = self.resource {
|
||||
Some(&self.router.patterns[idx as usize])
|
||||
} else {
|
||||
@ -113,15 +113,15 @@ impl RouteInfo {
|
||||
struct Inner {
|
||||
prefix: String,
|
||||
prefix_len: usize,
|
||||
named: HashMap<String, (Resource, bool)>,
|
||||
patterns: Vec<Resource>,
|
||||
named: HashMap<String, (ResourceDef, bool)>,
|
||||
patterns: Vec<ResourceDef>,
|
||||
}
|
||||
|
||||
impl Router {
|
||||
/// Create new router
|
||||
pub fn new<S>(
|
||||
prefix: &str, map: Vec<(Resource, Option<ResourceHandler<S>>)>,
|
||||
) -> (Router, Vec<ResourceHandler<S>>) {
|
||||
prefix: &str, map: Vec<(ResourceDef, Option<Resource<S>>)>,
|
||||
) -> (Router, Vec<Resource<S>>) {
|
||||
let prefix = prefix.trim().trim_right_matches('/').to_owned();
|
||||
let mut named = HashMap::new();
|
||||
let mut patterns = Vec::new();
|
||||
@ -240,7 +240,7 @@ pub enum ResourceType {
|
||||
|
||||
/// Resource type describes an entry in resources table
|
||||
#[derive(Clone, Debug)]
|
||||
pub struct Resource {
|
||||
pub struct ResourceDef {
|
||||
tp: PatternType,
|
||||
rtp: ResourceType,
|
||||
name: String,
|
||||
@ -248,12 +248,12 @@ pub struct Resource {
|
||||
elements: Vec<PatternElement>,
|
||||
}
|
||||
|
||||
impl Resource {
|
||||
impl ResourceDef {
|
||||
/// Parse path pattern and create new `Resource` instance.
|
||||
///
|
||||
/// Panics if path pattern is wrong.
|
||||
pub fn new(name: &str, path: &str) -> Self {
|
||||
Resource::with_prefix(name, path, "/", false)
|
||||
ResourceDef::with_prefix(name, path, "/", false)
|
||||
}
|
||||
|
||||
/// Parse path pattern and create new `Resource` instance.
|
||||
@ -262,14 +262,14 @@ impl Resource {
|
||||
///
|
||||
/// Panics if path regex pattern is wrong.
|
||||
pub fn prefix(name: &str, path: &str) -> Self {
|
||||
Resource::with_prefix(name, path, "/", true)
|
||||
ResourceDef::with_prefix(name, path, "/", true)
|
||||
}
|
||||
|
||||
/// Construct external resource
|
||||
///
|
||||
/// Panics if path pattern is wrong.
|
||||
pub fn external(name: &str, path: &str) -> Self {
|
||||
let mut resource = Resource::with_prefix(name, path, "/", false);
|
||||
let mut resource = ResourceDef::with_prefix(name, path, "/", false);
|
||||
resource.rtp = ResourceType::External;
|
||||
resource
|
||||
}
|
||||
@ -277,7 +277,7 @@ impl Resource {
|
||||
/// Parse path pattern and create new `Resource` instance with custom prefix
|
||||
pub fn with_prefix(name: &str, path: &str, prefix: &str, for_prefix: bool) -> Self {
|
||||
let (pattern, elements, is_dynamic, len) =
|
||||
Resource::parse(path, prefix, for_prefix);
|
||||
ResourceDef::parse(path, prefix, for_prefix);
|
||||
|
||||
let tp = if is_dynamic {
|
||||
let re = match Regex::new(&pattern) {
|
||||
@ -296,7 +296,7 @@ impl Resource {
|
||||
PatternType::Static(pattern.clone())
|
||||
};
|
||||
|
||||
Resource {
|
||||
ResourceDef {
|
||||
tp,
|
||||
elements,
|
||||
name: name.into(),
|
||||
@ -571,15 +571,15 @@ impl Resource {
|
||||
}
|
||||
}
|
||||
|
||||
impl PartialEq for Resource {
|
||||
fn eq(&self, other: &Resource) -> bool {
|
||||
impl PartialEq for ResourceDef {
|
||||
fn eq(&self, other: &ResourceDef) -> bool {
|
||||
self.pattern == other.pattern
|
||||
}
|
||||
}
|
||||
|
||||
impl Eq for Resource {}
|
||||
impl Eq for ResourceDef {}
|
||||
|
||||
impl Hash for Resource {
|
||||
impl Hash for ResourceDef {
|
||||
fn hash<H: Hasher>(&self, state: &mut H) {
|
||||
self.pattern.hash(state);
|
||||
}
|
||||
@ -593,34 +593,34 @@ mod tests {
|
||||
#[test]
|
||||
fn test_recognizer10() {
|
||||
let routes = vec![
|
||||
(Resource::new("", "/name"), Some(ResourceHandler::default())),
|
||||
(ResourceDef::new("", "/name"), Some(Resource::default())),
|
||||
(
|
||||
Resource::new("", "/name/{val}"),
|
||||
Some(ResourceHandler::default()),
|
||||
ResourceDef::new("", "/name/{val}"),
|
||||
Some(Resource::default()),
|
||||
),
|
||||
(
|
||||
Resource::new("", "/name/{val}/index.html"),
|
||||
Some(ResourceHandler::default()),
|
||||
ResourceDef::new("", "/name/{val}/index.html"),
|
||||
Some(Resource::default()),
|
||||
),
|
||||
(
|
||||
Resource::new("", "/file/{file}.{ext}"),
|
||||
Some(ResourceHandler::default()),
|
||||
ResourceDef::new("", "/file/{file}.{ext}"),
|
||||
Some(Resource::default()),
|
||||
),
|
||||
(
|
||||
Resource::new("", "/v{val}/{val2}/index.html"),
|
||||
Some(ResourceHandler::default()),
|
||||
ResourceDef::new("", "/v{val}/{val2}/index.html"),
|
||||
Some(Resource::default()),
|
||||
),
|
||||
(
|
||||
Resource::new("", "/v/{tail:.*}"),
|
||||
Some(ResourceHandler::default()),
|
||||
ResourceDef::new("", "/v/{tail:.*}"),
|
||||
Some(Resource::default()),
|
||||
),
|
||||
(
|
||||
Resource::new("", "/test2/{test}.html"),
|
||||
Some(ResourceHandler::default()),
|
||||
ResourceDef::new("", "/test2/{test}.html"),
|
||||
Some(Resource::default()),
|
||||
),
|
||||
(
|
||||
Resource::new("", "{test}/index.html"),
|
||||
Some(ResourceHandler::default()),
|
||||
ResourceDef::new("", "{test}/index.html"),
|
||||
Some(Resource::default()),
|
||||
),
|
||||
];
|
||||
let (rec, _) = Router::new::<()>("", routes);
|
||||
@ -681,12 +681,12 @@ mod tests {
|
||||
fn test_recognizer_2() {
|
||||
let routes = vec![
|
||||
(
|
||||
Resource::new("", "/index.json"),
|
||||
Some(ResourceHandler::default()),
|
||||
ResourceDef::new("", "/index.json"),
|
||||
Some(Resource::default()),
|
||||
),
|
||||
(
|
||||
Resource::new("", "/{source}.json"),
|
||||
Some(ResourceHandler::default()),
|
||||
ResourceDef::new("", "/{source}.json"),
|
||||
Some(Resource::default()),
|
||||
),
|
||||
];
|
||||
let (rec, _) = Router::new::<()>("", routes);
|
||||
@ -701,10 +701,10 @@ mod tests {
|
||||
#[test]
|
||||
fn test_recognizer_with_prefix() {
|
||||
let routes = vec![
|
||||
(Resource::new("", "/name"), Some(ResourceHandler::default())),
|
||||
(ResourceDef::new("", "/name"), Some(Resource::default())),
|
||||
(
|
||||
Resource::new("", "/name/{val}"),
|
||||
Some(ResourceHandler::default()),
|
||||
ResourceDef::new("", "/name/{val}"),
|
||||
Some(Resource::default()),
|
||||
),
|
||||
];
|
||||
let (rec, _) = Router::new::<()>("/test", routes);
|
||||
@ -724,10 +724,10 @@ mod tests {
|
||||
|
||||
// same patterns
|
||||
let routes = vec![
|
||||
(Resource::new("", "/name"), Some(ResourceHandler::default())),
|
||||
(ResourceDef::new("", "/name"), Some(Resource::default())),
|
||||
(
|
||||
Resource::new("", "/name/{val}"),
|
||||
Some(ResourceHandler::default()),
|
||||
ResourceDef::new("", "/name/{val}"),
|
||||
Some(Resource::default()),
|
||||
),
|
||||
];
|
||||
let (rec, _) = Router::new::<()>("/test2", routes);
|
||||
@ -747,29 +747,29 @@ mod tests {
|
||||
|
||||
#[test]
|
||||
fn test_parse_static() {
|
||||
let re = Resource::new("test", "/");
|
||||
let re = ResourceDef::new("test", "/");
|
||||
assert!(re.is_match("/"));
|
||||
assert!(!re.is_match("/a"));
|
||||
|
||||
let re = Resource::new("test", "/name");
|
||||
let re = ResourceDef::new("test", "/name");
|
||||
assert!(re.is_match("/name"));
|
||||
assert!(!re.is_match("/name1"));
|
||||
assert!(!re.is_match("/name/"));
|
||||
assert!(!re.is_match("/name~"));
|
||||
|
||||
let re = Resource::new("test", "/name/");
|
||||
let re = ResourceDef::new("test", "/name/");
|
||||
assert!(re.is_match("/name/"));
|
||||
assert!(!re.is_match("/name"));
|
||||
assert!(!re.is_match("/name/gs"));
|
||||
|
||||
let re = Resource::new("test", "/user/profile");
|
||||
let re = ResourceDef::new("test", "/user/profile");
|
||||
assert!(re.is_match("/user/profile"));
|
||||
assert!(!re.is_match("/user/profile/profile"));
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn test_parse_param() {
|
||||
let re = Resource::new("test", "/user/{id}");
|
||||
let re = ResourceDef::new("test", "/user/{id}");
|
||||
assert!(re.is_match("/user/profile"));
|
||||
assert!(re.is_match("/user/2345"));
|
||||
assert!(!re.is_match("/user/2345/"));
|
||||
@ -783,7 +783,7 @@ mod tests {
|
||||
let info = re.match_with_params(&req, 0, true).unwrap();
|
||||
assert_eq!(info.get("id").unwrap(), "1245125");
|
||||
|
||||
let re = Resource::new("test", "/v{version}/resource/{id}");
|
||||
let re = ResourceDef::new("test", "/v{version}/resource/{id}");
|
||||
assert!(re.is_match("/v1/resource/320120"));
|
||||
assert!(!re.is_match("/v/resource/1"));
|
||||
assert!(!re.is_match("/resource"));
|
||||
@ -796,14 +796,14 @@ mod tests {
|
||||
|
||||
#[test]
|
||||
fn test_resource_prefix() {
|
||||
let re = Resource::prefix("test", "/name");
|
||||
let re = ResourceDef::prefix("test", "/name");
|
||||
assert!(re.is_match("/name"));
|
||||
assert!(re.is_match("/name/"));
|
||||
assert!(re.is_match("/name/test/test"));
|
||||
assert!(re.is_match("/name1"));
|
||||
assert!(re.is_match("/name~"));
|
||||
|
||||
let re = Resource::prefix("test", "/name/");
|
||||
let re = ResourceDef::prefix("test", "/name/");
|
||||
assert!(re.is_match("/name/"));
|
||||
assert!(re.is_match("/name/gs"));
|
||||
assert!(!re.is_match("/name"));
|
||||
@ -811,7 +811,7 @@ mod tests {
|
||||
|
||||
#[test]
|
||||
fn test_reousrce_prefix_dynamic() {
|
||||
let re = Resource::prefix("test", "/{name}/");
|
||||
let re = ResourceDef::prefix("test", "/{name}/");
|
||||
assert!(re.is_match("/name/"));
|
||||
assert!(re.is_match("/name/gs"));
|
||||
assert!(!re.is_match("/name"));
|
||||
@ -831,12 +831,12 @@ mod tests {
|
||||
fn test_request_resource() {
|
||||
let routes = vec![
|
||||
(
|
||||
Resource::new("r1", "/index.json"),
|
||||
Some(ResourceHandler::default()),
|
||||
ResourceDef::new("r1", "/index.json"),
|
||||
Some(Resource::default()),
|
||||
),
|
||||
(
|
||||
Resource::new("r2", "/test.json"),
|
||||
Some(ResourceHandler::default()),
|
||||
ResourceDef::new("r2", "/test.json"),
|
||||
Some(Resource::default()),
|
||||
),
|
||||
];
|
||||
let (router, _) = Router::new::<()>("", routes);
|
||||
|
32
src/scope.rs
32
src/scope.rs
@ -14,14 +14,14 @@ use middleware::{
|
||||
Started as MiddlewareStarted,
|
||||
};
|
||||
use pred::Predicate;
|
||||
use resource::{ResourceHandler, RouteId};
|
||||
use router::Resource;
|
||||
use resource::{Resource, RouteId};
|
||||
use router::ResourceDef;
|
||||
use server::Request;
|
||||
|
||||
type ScopeResource<S> = Rc<ResourceHandler<S>>;
|
||||
type ScopeResource<S> = Rc<Resource<S>>;
|
||||
type Route<S> = Box<RouteHandler<S>>;
|
||||
type ScopeResources<S> = Rc<Vec<(Resource, ScopeResource<S>)>>;
|
||||
type NestedInfo<S> = (Resource, Route<S>, Vec<Box<Predicate<S>>>);
|
||||
type ScopeResources<S> = Rc<Vec<(ResourceDef, ScopeResource<S>)>>;
|
||||
type NestedInfo<S> = (ResourceDef, Route<S>, Vec<Box<Predicate<S>>>);
|
||||
|
||||
/// Resources scope
|
||||
///
|
||||
@ -147,7 +147,7 @@ impl<S: 'static> Scope<S> {
|
||||
})];
|
||||
let handler = Box::new(Wrapper { scope, state });
|
||||
self.nested
|
||||
.push((Resource::prefix("", &path), handler, filters));
|
||||
.push((ResourceDef::prefix("", &path), handler, filters));
|
||||
|
||||
self
|
||||
}
|
||||
@ -185,7 +185,7 @@ impl<S: 'static> Scope<S> {
|
||||
|
||||
let filters = scope.take_filters();
|
||||
self.nested
|
||||
.push((Resource::prefix("", &path), Box::new(scope), filters));
|
||||
.push((ResourceDef::prefix("", &path), Box::new(scope), filters));
|
||||
|
||||
self
|
||||
}
|
||||
@ -244,9 +244,9 @@ impl<S: 'static> Scope<S> {
|
||||
}
|
||||
}
|
||||
} else {
|
||||
let mut handler = ResourceHandler::default();
|
||||
let mut handler = Resource::default();
|
||||
handler.method(method).with(f);
|
||||
let pattern = Resource::with_prefix(
|
||||
let pattern = ResourceDef::with_prefix(
|
||||
handler.get_name(),
|
||||
path,
|
||||
if path.is_empty() { "" } else { "/" },
|
||||
@ -284,13 +284,13 @@ impl<S: 'static> Scope<S> {
|
||||
/// ```
|
||||
pub fn resource<F, R>(mut self, path: &str, f: F) -> Scope<S>
|
||||
where
|
||||
F: FnOnce(&mut ResourceHandler<S>) -> R + 'static,
|
||||
F: FnOnce(&mut Resource<S>) -> R + 'static,
|
||||
{
|
||||
// add resource handler
|
||||
let mut handler = ResourceHandler::default();
|
||||
let mut handler = Resource::default();
|
||||
f(&mut handler);
|
||||
|
||||
let pattern = Resource::with_prefix(
|
||||
let pattern = ResourceDef::with_prefix(
|
||||
handler.get_name(),
|
||||
path,
|
||||
if path.is_empty() { "" } else { "/" },
|
||||
@ -306,10 +306,10 @@ impl<S: 'static> Scope<S> {
|
||||
/// Default resource to be used if no matching route could be found.
|
||||
pub fn default_resource<F, R>(mut self, f: F) -> Scope<S>
|
||||
where
|
||||
F: FnOnce(&mut ResourceHandler<S>) -> R + 'static,
|
||||
F: FnOnce(&mut Resource<S>) -> R + 'static,
|
||||
{
|
||||
if self.default.is_none() {
|
||||
self.default = Some(Rc::new(ResourceHandler::default_not_found()));
|
||||
self.default = Some(Rc::new(Resource::default_not_found()));
|
||||
}
|
||||
{
|
||||
let default = Rc::get_mut(self.default.as_mut().unwrap())
|
||||
@ -439,7 +439,7 @@ struct ComposeInfo<S: 'static> {
|
||||
id: RouteId,
|
||||
req: HttpRequest<S>,
|
||||
mws: Rc<Vec<Box<Middleware<S>>>>,
|
||||
resource: Rc<ResourceHandler<S>>,
|
||||
resource: Rc<Resource<S>>,
|
||||
}
|
||||
|
||||
enum ComposeState<S: 'static> {
|
||||
@ -465,7 +465,7 @@ impl<S: 'static> ComposeState<S> {
|
||||
impl<S: 'static> Compose<S> {
|
||||
fn new(
|
||||
id: RouteId, req: HttpRequest<S>, mws: Rc<Vec<Box<Middleware<S>>>>,
|
||||
resource: Rc<ResourceHandler<S>>,
|
||||
resource: Rc<Resource<S>>,
|
||||
) -> Self {
|
||||
let mut info = ComposeInfo {
|
||||
id,
|
||||
|
@ -27,7 +27,7 @@ use httpresponse::HttpResponse;
|
||||
use middleware::Middleware;
|
||||
use param::Params;
|
||||
use payload::Payload;
|
||||
use resource::ResourceHandler;
|
||||
use resource::Resource;
|
||||
use router::Router;
|
||||
use server::message::{Request, RequestPool};
|
||||
use server::{HttpServer, IntoHttpHandler, ServerSettings};
|
||||
@ -353,7 +353,7 @@ impl<S: 'static> TestApp<S> {
|
||||
/// to `App::resource()` method.
|
||||
pub fn resource<F, R>(&mut self, path: &str, f: F) -> &mut TestApp<S>
|
||||
where
|
||||
F: FnOnce(&mut ResourceHandler<S>) -> R + 'static,
|
||||
F: FnOnce(&mut Resource<S>) -> R + 'static,
|
||||
{
|
||||
self.app = Some(self.app.take().unwrap().resource(path, f));
|
||||
self
|
||||
|
Loading…
x
Reference in New Issue
Block a user