You've already forked AstralRinth
forked from didirus/AstralRinth
* typos :help_me: * (part 1/?) massive cleanup to make the code more Rust-ic and cut down heap allocations. * (part 2/?) massive cleanup to make the code more Rust-ic and cut down heap allocations. * (part 3/?) cut down some pretty major heap allocations here - more Bytes and BytesMuts, less Vec<u8>s also I don't really understand why you need to `to_vec` when you don't really use it again afterwards * (part 4/?) deduplicate error handling in backblaze logic * (part 5/?) fixes, cleanups, refactors, and reformatting * (part 6/?) cleanups and refactors * remove loads of `as_str` in types that already are `Display` * Revert "remove loads of `as_str` in types that already are `Display`" This reverts commit 4f974310cfb167ceba03001d81388db4f0fbb509. * reformat and move routes util to the util module * use streams * Run prepare + formatting issues Co-authored-by: Jai A <jaiagr+gpg@pm.me> Co-authored-by: Geometrically <18202329+Geometrically@users.noreply.github.com>
32 lines
922 B
Rust
32 lines
922 B
Rust
use crate::health::status::test_database;
|
|
use crate::health::SEARCH_READY;
|
|
use actix_web::web::Data;
|
|
use actix_web::{get, HttpResponse};
|
|
use serde_json::json;
|
|
use sqlx::PgPool;
|
|
use std::sync::atomic::Ordering;
|
|
|
|
#[get("/health")]
|
|
pub async fn health_get(client: Data<PgPool>) -> HttpResponse {
|
|
// Check database connection:
|
|
let result = test_database(client).await;
|
|
if result.is_err() {
|
|
let data = json!({
|
|
"ready": false,
|
|
"reason": "Database connection error"
|
|
});
|
|
return HttpResponse::InternalServerError().json(data);
|
|
}
|
|
if !SEARCH_READY.load(Ordering::Acquire) {
|
|
let data = json!({
|
|
"ready": false,
|
|
"reason": "Indexing is not finished"
|
|
});
|
|
return HttpResponse::InternalServerError().json(data);
|
|
}
|
|
HttpResponse::Ok().json(json!({
|
|
"ready": true,
|
|
"reason": "Everything is OK"
|
|
}))
|
|
}
|