Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

https://github.com/tobyapi/craft


https://github.com/tobyapi/craft

Last synced: 10 days ago
JSON representation

Lists

README

        

# Craft
Craft is a lightweight HTTP framework.

*Status:* **proof-of-concept**

## Installation
Add this to your application's `Cargo.toml`.
```sh
[dependencies]
craft = "0.1.0"
```

## Usage
```rust
use craft;
use hyper::*;

fn hello(_request: &Request) -> Response {
Response::new(Body::from("Hello, World!"))
}

#[runtime::main]
async fn main() {
let config = craft::Config::new("127.0.0.1", 3000);

let mut handler_stack = craft::Stack::empty();
handler_stack.set(hello);
craft::get("/hello", handler_stack);

craft::start(&config).await;
}
```

Craft takes a modular-first approach to middlewares
```rust
use craft;
use hyper::*;

fn first_handler(_request: &Request, next: &dyn Fn() -> Response) -> Response {
println!("begin first_handler");
let response = next();
println!("end first_handler");
response
}

fn second_handler(_request: &Request, next: &dyn Fn() -> Response) -> Response {
println!("begin second_handler");
let response = next();
println!("end second_handler");
response
}

fn hello(_request: &Request) -> Response {
Response::new(Body::from("Hello, World!"))
}

#[runtime::main]
async fn main() {
let config = craft::Config::new("127.0.0.1", 3000);
let mut handler_stack = craft::Stack::empty();
handler_stack.push(first_handler);
handler_stack.push(second_handler);
handler_stack.set(hello);
craft::get("/hello", handler_stack);
craft::start(&config).await;
}
```

## Development
```sh
$ cargo +nightly run --example hello
$ cargo +nightly run --example multi_handler

$ curl -X GET localhost:3000/hello
Hello, World!
```