Crates.io | argos |
lib.rs | argos |
version | 0.1.0 |
source | src |
created_at | 2023-09-13 05:47:17.279579 |
updated_at | 2023-09-13 05:47:17.279579 |
description | Argos makes it easy to create a stand-alone web application backend server. |
homepage | https://github.com/jimmyseraph/argos |
repository | https://github.com/jimmyseraph/argos |
max_upload_size | |
id | 971237 |
size | 54,673 |
Argos makes it easy to create a stand-alone web application backend server.
API
functionYou can define your api function with a macro-attribute:
#[route(GET, path = "/api/hello", formatter = "text")]
pub fn hello(req: HttpRequest) -> Result<String, ReturnError<String>> {
let url_params = req.url_params();
let name = url_params.get("name");
match name {
Some(name) => Ok(format!("hello {}!", name)),
None => Err(
ReturnError::new(
400,
"name is required".to_string(),
)
),
}
}
this function define a http interface with
GET
method, and url path is/api/hello
.
You can start your server like this:
#[tokio::main]
async fn main() {
let server = Server::builder(([127, 0, 0, 1], 3000).into())
.build()
.await
.unwrap();
server.start().await.unwrap();
}
Your server will bind in 127.0.0.1:3000
, so you can send a http request to call this API:
curl http://127.0.0.1:3000/api/hello?name=liudao
You can define a filter to filt the request:
#[filter(path_pattern="/api/hello.*", order=1)]
pub fn path_filter(mut req: HttpRequest) -> Chain {
let attr = req.attributes_mut();
attr.insert("kk".to_string(), "value".to_string());
// let _method = req.method_mut();
if req.headers().contains_key("token") {
Chain::Continune(req)
} else {
let mut return_err = ReturnError::new(
401,
"not authorized".to_string(),
);
return_err.headers.append("filter", HeaderValue::from_str("rejected").unwrap());
Chain::Reject(return_err)
}
}
Filter now only support
path_pattern
, usingregexp
. The attributeorder
represents the priority of the filter, the smaller the number, the higher the priority.
See more examples in core/examples
.
Argos is provided under the MIT license. See LICENSE.