use crate::entity::ChimesLogInfo;
use actix_web::{web, HttpResponse, Result};
use chimes_auth::ApiResult;
use chimes_utils::get_rbatis;
use rbatis::Page;
#[post("/api/v1/logs/save")]
pub async fn logs_save(req: web::Json<ChimesLogInfo>) -> Result<HttpResponse> {
let rb = get_rbatis();
let mut val = req.to_owned();
val.create_time = Some(rbatis::DateTimeNative::now());
match val.save(rb).await {
Ok(_st) => {
let ret: web::Json<ApiResult<ChimesLogInfo>> = web::Json(ApiResult::ok(val));
Ok(HttpResponse::Ok().json(ret))
}
Err(err) => {
let ret: web::Json<ApiResult<ChimesLogInfo>> =
web::Json(ApiResult::error(5010, &err.to_string()));
Ok(HttpResponse::Ok().json(ret))
}
}
}
#[post("/api/v1/logs/update")]
async fn logs_update(req: web::Json<ChimesLogInfo>) -> Result<HttpResponse> {
let rb = get_rbatis();
let val = req.to_owned();
match val.update_selective(rb).await {
Ok(_st) => {
let ret: web::Json<ApiResult<ChimesLogInfo>> = web::Json(ApiResult::ok(val));
Ok(HttpResponse::Ok().json(ret))
}
Err(err) => {
let ret: web::Json<ApiResult<ChimesLogInfo>> =
web::Json(ApiResult::error(5010, &err.to_string()));
Ok(HttpResponse::Ok().json(ret))
}
}
}
#[post("/api/v1/logs/delete")]
pub async fn logs_delete(req: web::Json<ChimesLogInfo>) -> Result<HttpResponse> {
let rb = get_rbatis();
let mut val = req.to_owned();
match val.remove(rb).await {
Ok(_st) => {
let ret: web::Json<ApiResult<ChimesLogInfo>> = web::Json(ApiResult::ok(val));
Ok(HttpResponse::Ok().json(ret))
}
Err(err) => {
let ret: web::Json<ApiResult<ChimesLogInfo>> =
web::Json(ApiResult::error(5010, &err.to_string()));
Ok(HttpResponse::Ok().json(ret))
}
}
}
#[post("/api/v1/logs/delete_ids")]
pub async fn logs_delete_ids(req: web::Json<Vec<i64>>) -> Result<HttpResponse> {
let rb = get_rbatis();
let ids = req.as_slice();
match ChimesLogInfo::remove_ids(rb, ids).await {
Ok(st) => {
let ret: web::Json<ApiResult<u64>> = web::Json(ApiResult::ok(st));
Ok(HttpResponse::Ok().json(ret))
}
Err(err) => {
let ret: web::Json<ApiResult<u64>> =
web::Json(ApiResult::error(5010, &err.to_string()));
Ok(HttpResponse::Ok().json(ret))
}
}
}
#[post("/api/v1/logs/search")]
pub async fn logs_search(req: web::Json<ChimesLogInfo>) -> Result<HttpResponse> {
let rb = get_rbatis();
let val = req.to_owned();
match val.query_list(rb).await {
Ok(st) => {
let ret: web::Json<ApiResult<Vec<ChimesLogInfo>>> = web::Json(ApiResult::ok(st));
Ok(HttpResponse::Ok().json(ret))
}
Err(err) => {
let ret: web::Json<ApiResult<Vec<ChimesLogInfo>>> =
web::Json(ApiResult::error(5010, &err.to_string()));
Ok(HttpResponse::Ok().json(ret))
}
}
}
#[post("/api/v1/logs/paged/{current}/{size}")]
pub async fn logs_paged(
req: web::Json<ChimesLogInfo>,
path_param: web::Path<(u64, u64)>,
) -> Result<HttpResponse> {
let rb = get_rbatis();
let val = req.to_owned();
let (current, size) = path_param.into_inner();
match val.query_paged(rb, current, size).await {
Ok(st) => {
let ret: web::Json<ApiResult<Page<ChimesLogInfo>>> = web::Json(ApiResult::ok(st));
Ok(HttpResponse::Ok().json(ret))
}
Err(err) => {
let ret: web::Json<ApiResult<Page<ChimesLogInfo>>> =
web::Json(ApiResult::error(5010, &err.to_string()));
Ok(HttpResponse::Ok().json(ret))
}
}
}
#[get("/api/v1/logs/get/{id}")]
pub async fn logs_get(log_id_req: web::Path<i64>) -> Result<HttpResponse> {
let rb = get_rbatis();
let log_id = log_id_req.to_owned();
match ChimesLogInfo::from_id(rb, &log_id).await {
Ok(st) => match st {
Some(tv) => {
let ret: web::Json<ApiResult<ChimesLogInfo>> = web::Json(ApiResult::ok(tv));
Ok(HttpResponse::Ok().json(ret))
}
None => {
let ret: web::Json<ApiResult<ChimesLogInfo>> =
web::Json(ApiResult::error(5040, &"Not-Found".to_string()));
Ok(HttpResponse::Ok().json(ret))
}
},
Err(err) => {
let ret: web::Json<ApiResult<ChimesLogInfo>> =
web::Json(ApiResult::error(5010, &err.to_string()));
Ok(HttpResponse::Ok().json(ret))
}
}
}