Skip to content

Latest commit

 

History

History
46 lines (40 loc) · 1.21 KB

README.md

File metadata and controls

46 lines (40 loc) · 1.21 KB

butane_rocket_pool

Butane database adapter for Rocket framework

Usage

  1. Configure your database in Rocket.toml. Parameters url and backend_name are required.
[default.databases.test]
backend_name = "sqlite" #Butane's backend name
url = "test.db"
  1. Add and init database in your application's code
#[database("test")]
struct DbConn(butane_rocket_pool::Connection); 

#[launch]
fn rocket() -> _ {
    rocket::build().mount("/", routes![create])
    .attach(DbConn::fairing())
}
  1. To use the connection with Butane functions apply two dereference operators.
#[post("/", data = "<post>")]
async fn create(db: DbConn, post: Json<Post>) -> (Status, Value) {
    let result = db.run(move |db| -> Result<Post, butane::Error> {
        let mut result = post.0;
        result.save(&**db)?;
        Post::get(&**db, result.id)
    }).await;

    match result {
        Ok(res) => (Status::Created, json!({
            "message" : "Post is created!",
            "data" : res
        })),
        Err(err) => (Status::InternalServerError, json!({
            "message" : "Can't create post!",
            "error" : format!("{}", err)
        }))
    }
}