use crate::web::head; use serde::Deserialize; use std::collections::HashMap; use std::str; use warp::path; use warp::Filter; #[derive(Default, Deserialize, Debug, Clone)] pub struct Query { pub limit: Option, pub start: Option, } pub fn config() -> impl Filter + Clone { let base = warp::path("key"); // Set opts method let opts = base.and(warp::options()).map(warp::reply); // ------------------------------ // Routes for a table // ------------------------------ // Set base path for all let base = path!("key" / String).and(warp::path::end()); // Set select method let select = base.and(warp::get()).and(warp::query()).and_then(select_all); // Set create method let create = base .and(warp::post()) .and(warp::body::content_length_limit(1024 * 1)) // 1MiB .and(warp::body::bytes()) .and_then(create_all); // Set delete method let delete = base.and(warp::delete()).and_then(delete_all); // Specify route let all = select.or(create).or(delete); // ------------------------------ // Routes for a thing // ------------------------------ // Set base path for one let base = path!("key" / String / String).and(warp::path::end()); // Set select method let select = base.and(warp::get()).and_then(select_one); // Set create method let create = base .and(warp::post()) .and(warp::body::content_length_limit(1024 * 1)) // 1MiB .and(warp::body::bytes()) .and_then(create_one); // Set update method let update = base .and(warp::put()) .and(warp::body::content_length_limit(1024 * 1)) // 1MiB .and(warp::body::bytes()) .and_then(update_one); // Set modify method let modify = base .and(warp::patch()) .and(warp::body::content_length_limit(1024 * 1)) // 1MiB .and(warp::body::bytes()) .and_then(modify_one); // Set delete method let delete = base.and(warp::delete()).and_then(delete_one); // Specify route let one = select.or(create).or(update).or(modify).or(delete); // ------------------------------ // All routes // ------------------------------ // Specify route opts.or(all).or(one).with(head::cors()) } // ------------------------------ // Routes for a table // ------------------------------ async fn select_all(table: String, query: Query) -> Result { let sql = format!( "SELECT * FROM type::table($table) LIMIT {l} START {s}", l = query.limit.unwrap_or(String::from("100")), s = query.start.unwrap_or(String::from("0")), ); let mut var = HashMap::new(); var.insert("table", table); let res = crate::dbs::execute(sql.as_str(), Some(var)).unwrap(); Ok(warp::reply::json(&res)) } async fn create_all( table: String, body: bytes::Bytes, ) -> Result { let sql = "CREATE type::table($table) CONTENT $data"; let mut var = HashMap::new(); var.insert("table", table); var.insert("data", str::from_utf8(&body).unwrap().to_owned()); let res = crate::dbs::execute(sql, Some(var)).unwrap(); Ok(warp::reply::json(&res)) } async fn delete_all(table: String) -> Result { let sql = "DELETE type::table($table)"; let mut var = HashMap::new(); var.insert("table", table); let res = crate::dbs::execute(sql, Some(var)).unwrap(); Ok(warp::reply::json(&res)) } // ------------------------------ // Routes for a thing // ------------------------------ async fn select_one(table: String, id: String) -> Result { let sql = "SELECT * FROM type::thing($table, $id)"; let mut var = HashMap::new(); var.insert("table", table); var.insert("id", id); let res = crate::dbs::execute(sql, Some(var)).unwrap(); Ok(warp::reply::json(&res)) } async fn create_one( table: String, id: String, body: bytes::Bytes, ) -> Result { let sql = "CREATE type::thing($table, $id) CONTENT $data"; let mut var = HashMap::new(); var.insert("table", table); var.insert("id", id); var.insert("data", str::from_utf8(&body).unwrap().to_owned()); let res = crate::dbs::execute(sql, Some(var)).unwrap(); Ok(warp::reply::json(&res)) } async fn update_one( table: String, id: String, body: bytes::Bytes, ) -> Result { let sql = "UPDATE type::thing($table, $id) CONTENT $data"; let mut var = HashMap::new(); var.insert("table", table); var.insert("id", id); var.insert("data", str::from_utf8(&body).unwrap().to_owned()); let res = crate::dbs::execute(sql, Some(var)).unwrap(); Ok(warp::reply::json(&res)) } async fn modify_one( table: String, id: String, body: bytes::Bytes, ) -> Result { let sql = "UPDATE type::thing($table, $id) MERGE $data"; let mut var = HashMap::new(); var.insert("table", table); var.insert("id", id); var.insert("data", str::from_utf8(&body).unwrap().to_owned()); let res = crate::dbs::execute(sql, Some(var)).unwrap(); Ok(warp::reply::json(&res)) } async fn delete_one(table: String, id: String) -> Result { let sql = "DELETE type::thing($table, $id)"; let mut var = HashMap::new(); var.insert("table", table); var.insert("id", id); let res = crate::dbs::execute(sql, Some(var)).unwrap(); Ok(warp::reply::json(&res)) }