antennas endpoints working

This commit is contained in:
2023-07-21 20:15:51 +02:00
parent 9fd99acf2e
commit 0ddbb21f52
2 changed files with 92 additions and 2 deletions

View File

@@ -0,0 +1,63 @@
use diesel::prelude::*;
use rocket::{http::Status, serde::json::Json, State};
use kairo_common::{postgres, schema::antennas, Antenna, NewAntenna};
#[rocket::get("/id/<id>")]
pub fn get_by_id(db_pool: &State<postgres::DbPool>, id: String) -> Option<Json<Antenna>> {
let mut db = db_pool.get().unwrap();
let res = antennas::table
.select(antennas::all_columns)
.find(id)
.get_result::<Antenna>(&mut db);
match res {
Ok(v) => Some(rocket::serde::json::Json(v)),
_ => None,
}
}
#[rocket::get("/")]
pub fn get_list(db_pool: &State<postgres::DbPool>) -> Json<Vec<Antenna>> {
let mut db = db_pool.get().unwrap();
let res = antennas::table
.select(antennas::all_columns)
.load::<Antenna>(&mut db);
match res {
Ok(v) => rocket::serde::json::Json(v),
_ => rocket::serde::json::Json(vec![]),
}
}
#[rocket::post("/new", format = "json", data = "<antenna>")]
pub fn new(db_pool: &State<postgres::DbPool>, antenna: Json<NewAntenna<'_>>) -> Status {
let mut db = db_pool.get().unwrap();
let res = diesel::insert_into(antennas::table)
.values(*antenna)
.execute(&mut db);
match res {
Ok(_) => Status::Ok,
_ => Status::NotAcceptable,
}
}
#[rocket::patch("/update", format = "json", data = "<antenna>")]
pub fn update(db_pool: &State<postgres::DbPool>, antenna: Json<NewAntenna<'_>>) -> Status {
let mut db = db_pool.get().unwrap();
let res = diesel::update(antennas::table)
.filter(antennas::id.eq(antenna.id))
.set(*antenna)
.execute(&mut db);
match res {
Ok(0) => Status::NotModified,
Ok(1) => Status::Ok,
_ => Status::BadRequest,
}
}