2019-10-14 00:59:02 +02:00
|
|
|
/*!
|
|
|
|
This crate is an extension to the popular [gotham web framework][gotham] for Rust. The idea is to
|
|
|
|
have several RESTful resources that can be added to the gotham router. This crate will take care
|
|
|
|
of everything else, like parsing path/query parameters, request bodies, and writing response
|
|
|
|
bodies, relying on [`serde`][serde] and [`serde_json`][serde_json] for (de)serializing. If you
|
|
|
|
enable the `openapi` feature, you can also generate an OpenAPI Specification from your RESTful
|
|
|
|
resources.
|
|
|
|
|
|
|
|
# Usage
|
|
|
|
|
|
|
|
To use this crate, add the following to your `Cargo.toml`:
|
|
|
|
|
|
|
|
```toml
|
|
|
|
[dependencies]
|
|
|
|
gotham_restful = "0.0.1"
|
|
|
|
```
|
|
|
|
|
|
|
|
A basic server with only one resource, handling a simple `GET` request, could look like this:
|
|
|
|
|
|
|
|
```rust,no_run
|
|
|
|
# #[macro_use] extern crate gotham_restful_derive;
|
|
|
|
# use gotham::{router::builder::*, state::State};
|
|
|
|
# use gotham_restful::{DrawResources, Resource, Success};
|
|
|
|
# use serde::{Deserialize, Serialize};
|
|
|
|
#
|
|
|
|
/// Our RESTful Resource.
|
|
|
|
#[derive(Resource)]
|
|
|
|
#[rest_resource(read_all)]
|
|
|
|
struct UsersResource;
|
|
|
|
|
|
|
|
/// Our return type.
|
|
|
|
#[derive(Deserialize, Serialize)]
|
|
|
|
# #[derive(OpenapiType)]
|
|
|
|
struct User {
|
|
|
|
id: i64,
|
|
|
|
username: String,
|
|
|
|
email: String
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Our handler method.
|
|
|
|
#[rest_read_all(UsersResource)]
|
|
|
|
fn read_all(_state: &mut State) -> Success<Vec<User>> {
|
|
|
|
vec![User {
|
|
|
|
id: 1,
|
|
|
|
username: "h4ck3r".to_string(),
|
|
|
|
email: "h4ck3r@example.org".to_string()
|
|
|
|
}].into()
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Our main method.
|
|
|
|
fn main() {
|
|
|
|
gotham::start("127.0.0.1:8080", build_simple_router(|route| {
|
|
|
|
route.resource::<UsersResource, _>("users");
|
|
|
|
}));
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
Look at the [example] for more methods and usage with the `openapi` feature.
|
|
|
|
|
|
|
|
# License
|
|
|
|
|
|
|
|
THE ACCOMPANYING PROGRAM IS PROVIDED UNDER THE TERMS OF THE ECLIPSE <br/>
|
|
|
|
PUBLIC LICENSE VERSION 2.0. ANY USE, REPRODUCTION OR DISTRIBUTION <br/>
|
|
|
|
OF THE PROGRAM CONSTITUTES RECIPIENT'S ACCEPTANCE OF THIS LICENSE.
|
|
|
|
|
|
|
|
|
|
|
|
[example]: https://gitlab.com/msrd0/gotham-restful/tree/master/example
|
|
|
|
[gotham]: https://gotham.rs/
|
|
|
|
[serde]: https://github.com/serde-rs/serde#serde-----
|
|
|
|
[serde_json]: https://github.com/serde-rs/json#serde-json----
|
|
|
|
*/
|
|
|
|
|
2019-09-27 16:36:38 +02:00
|
|
|
#[macro_use] extern crate gotham_derive;
|
|
|
|
#[macro_use] extern crate serde;
|
2019-09-26 17:24:40 +02:00
|
|
|
|
|
|
|
pub use hyper::StatusCode;
|
|
|
|
|
2019-10-06 15:03:30 +02:00
|
|
|
pub use gotham_restful_derive::*;
|
2019-10-13 23:19:34 +02:00
|
|
|
|
2019-10-06 15:03:30 +02:00
|
|
|
/// Not public API
|
|
|
|
#[doc(hidden)]
|
|
|
|
pub mod export
|
|
|
|
{
|
|
|
|
#[cfg(feature = "openapi")]
|
|
|
|
pub use indexmap::IndexMap;
|
|
|
|
#[cfg(feature = "openapi")]
|
2019-10-13 23:19:34 +02:00
|
|
|
pub use openapiv3 as openapi;
|
2019-10-06 15:03:30 +02:00
|
|
|
}
|
|
|
|
|
2019-09-29 21:15:22 +02:00
|
|
|
#[cfg(feature = "openapi")]
|
2019-10-14 00:59:02 +02:00
|
|
|
mod openapi;
|
2019-09-30 18:18:10 +02:00
|
|
|
#[cfg(feature = "openapi")]
|
2019-09-30 20:58:15 +02:00
|
|
|
pub use openapi::{
|
|
|
|
router::{GetOpenapi, OpenapiRouter},
|
2019-10-01 15:33:05 +02:00
|
|
|
types::{OpenapiSchema, OpenapiType}
|
2019-09-30 20:58:15 +02:00
|
|
|
};
|
2019-09-29 21:15:22 +02:00
|
|
|
|
2019-09-26 17:24:40 +02:00
|
|
|
mod resource;
|
|
|
|
pub use resource::{
|
|
|
|
Resource,
|
2019-09-28 13:38:08 +02:00
|
|
|
ResourceReadAll,
|
|
|
|
ResourceRead,
|
2019-10-13 17:43:42 +02:00
|
|
|
ResourceSearch,
|
2019-09-28 13:38:08 +02:00
|
|
|
ResourceCreate,
|
|
|
|
ResourceUpdateAll,
|
2019-09-29 19:19:38 +02:00
|
|
|
ResourceUpdate,
|
|
|
|
ResourceDeleteAll,
|
|
|
|
ResourceDelete
|
2019-09-26 17:24:40 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
mod result;
|
2019-10-05 14:50:05 +02:00
|
|
|
pub use result::{
|
|
|
|
NoContent,
|
|
|
|
ResourceResult,
|
|
|
|
Success
|
|
|
|
};
|
2019-09-26 17:24:40 +02:00
|
|
|
|
|
|
|
mod routing;
|
2019-09-26 17:42:28 +02:00
|
|
|
pub use routing::{DrawResources, DrawResourceRoutes};
|
2019-09-30 18:18:10 +02:00
|
|
|
#[cfg(feature = "openapi")]
|
|
|
|
pub use routing::WithOpenapi;
|
2019-09-30 20:58:15 +02:00
|
|
|
|
2019-10-14 00:59:02 +02:00
|
|
|
mod types;
|
|
|
|
pub use types::ResourceType;
|