mirror of
https://github.com/Steffo99/todocolors.git
synced 2024-11-25 17:54:18 +00:00
Endpoints which return the version now return a JSON object
This commit is contained in:
parent
823de0af36
commit
8bcedd9fbf
4 changed files with 23 additions and 10 deletions
|
@ -17,10 +17,10 @@ async fn main() {
|
||||||
.expect("to be able to connect to Redis");
|
.expect("to be able to connect to Redis");
|
||||||
|
|
||||||
let router = axum::Router::new()
|
let router = axum::Router::new()
|
||||||
.route("/", get(routes::root::version))
|
.route("/", get(routes::version_route))
|
||||||
.route("/version", get(routes::root::version))
|
.route("/version", get(routes::version_route))
|
||||||
.route("/", post(routes::root::healthcheck))
|
.route("/", post(routes::healthcheck_route))
|
||||||
.route("/healthcheck", post(routes::root::healthcheck))
|
.route("/healthcheck", post(routes::healthcheck_route))
|
||||||
.route("/board/:board/ws", get(routes::board::board_websocket))
|
.route("/board/:board/ws", get(routes::board::board_websocket))
|
||||||
.layer(axum::Extension(rclient))
|
.layer(axum::Extension(rclient))
|
||||||
.layer(tower_http::cors::CorsLayer::new()
|
.layer(tower_http::cors::CorsLayer::new()
|
||||||
|
|
|
@ -1,2 +1,6 @@
|
||||||
pub(crate) mod root;
|
pub mod board;
|
||||||
pub(crate) mod board;
|
pub mod structs;
|
||||||
|
pub(self) mod root;
|
||||||
|
|
||||||
|
pub(crate) use root::version as version_route;
|
||||||
|
pub(crate) use root::healthcheck as healthcheck_route;
|
||||||
|
|
|
@ -2,23 +2,26 @@ use axum::{Extension, Json};
|
||||||
use axum::http::StatusCode;
|
use axum::http::StatusCode;
|
||||||
|
|
||||||
use crate::outcome::{Response, LoggableOutcome};
|
use crate::outcome::{Response, LoggableOutcome};
|
||||||
|
use crate::routes::structs::VersionInfo;
|
||||||
|
|
||||||
const MAJOR: u32 = pkg_version::pkg_version_major!();
|
const MAJOR: u32 = pkg_version::pkg_version_major!();
|
||||||
const MINOR: u32 = pkg_version::pkg_version_minor!();
|
const MINOR: u32 = pkg_version::pkg_version_minor!();
|
||||||
const PATCH: u32 = pkg_version::pkg_version_patch!();
|
const PATCH: u32 = pkg_version::pkg_version_patch!();
|
||||||
|
|
||||||
fn compose_version() -> String {
|
fn compose_version() -> VersionInfo {
|
||||||
format!("{}.{}.{}", MAJOR, MINOR, PATCH)
|
VersionInfo {
|
||||||
|
version: format!("{}.{}.{}", MAJOR, MINOR, PATCH)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
pub async fn version() -> Response<Json<String>> {
|
pub async fn version() -> Response<Json<VersionInfo>> {
|
||||||
Ok(Json(compose_version()))
|
Ok(Json(compose_version()))
|
||||||
}
|
}
|
||||||
|
|
||||||
pub async fn healthcheck(
|
pub async fn healthcheck(
|
||||||
Extension(rclient): Extension<redis::Client>
|
Extension(rclient): Extension<redis::Client>
|
||||||
) -> Response<Json<String>> {
|
) -> Response<Json<VersionInfo>> {
|
||||||
let mut rconn = rclient.get_async_connection().await
|
let mut rconn = rclient.get_async_connection().await
|
||||||
.log_err_to_error("Failed to connect to Redis")
|
.log_err_to_error("Failed to connect to Redis")
|
||||||
.map_err(|_| StatusCode::INTERNAL_SERVER_ERROR)?;
|
.map_err(|_| StatusCode::INTERNAL_SERVER_ERROR)?;
|
||||||
|
|
6
todored/src/routes/structs.rs
Normal file
6
todored/src/routes/structs.rs
Normal file
|
@ -0,0 +1,6 @@
|
||||||
|
use serde::{Deserialize, Serialize};
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, Serialize, Deserialize)]
|
||||||
|
pub struct VersionInfo {
|
||||||
|
pub version: String,
|
||||||
|
}
|
Loading…
Reference in a new issue