You've already forked AstralRinth
forked from didirus/AstralRinth
* search patch for accurate loader/gv filtering * backup * basic search test * finished test * incomplete commit; backing up * Working multipat reroute backup * working rough draft v3 * most tests passing * works * search v2 conversion * added some tags.rs v2 conversions * Worked through warnings, unwraps, prints * refactors * new search test * version files changes fixes * redesign to revs * removed old caches * removed games * fmt clippy * merge conflicts * fmt, prepare * moved v2 routes over to v3 * fixes; tests passing * project type changes * moved files over * fmt, clippy, prepare, etc * loaders to loader_fields, added tests * fmt, clippy, prepare * fixed sorting bug * reversed back- wrong order for consistency * fmt; clippy; prepare --------- Co-authored-by: Jai A <jaiagr+gpg@pm.me>
86 lines
2.5 KiB
Rust
86 lines
2.5 KiB
Rust
use crate::routes::ApiError;
|
|
use actix_web::{web, HttpResponse};
|
|
use serde_json::json;
|
|
use sqlx::PgPool;
|
|
|
|
pub fn config(cfg: &mut web::ServiceConfig) {
|
|
cfg.route("statistics", web::get().to(get_stats));
|
|
}
|
|
|
|
pub async fn get_stats(pool: web::Data<PgPool>) -> Result<HttpResponse, ApiError> {
|
|
let projects = sqlx::query!(
|
|
"
|
|
SELECT COUNT(id)
|
|
FROM mods
|
|
WHERE status = ANY($1)
|
|
",
|
|
&*crate::models::projects::ProjectStatus::iterator()
|
|
.filter(|x| x.is_searchable())
|
|
.map(|x| x.to_string())
|
|
.collect::<Vec<String>>(),
|
|
)
|
|
.fetch_one(&**pool)
|
|
.await?;
|
|
|
|
let versions = sqlx::query!(
|
|
"
|
|
SELECT COUNT(v.id)
|
|
FROM versions v
|
|
INNER JOIN mods m on v.mod_id = m.id AND m.status = ANY($1)
|
|
WHERE v.status = ANY($2)
|
|
",
|
|
&*crate::models::projects::ProjectStatus::iterator()
|
|
.filter(|x| x.is_searchable())
|
|
.map(|x| x.to_string())
|
|
.collect::<Vec<String>>(),
|
|
&*crate::models::projects::VersionStatus::iterator()
|
|
.filter(|x| x.is_listed())
|
|
.map(|x| x.to_string())
|
|
.collect::<Vec<String>>(),
|
|
)
|
|
.fetch_one(&**pool)
|
|
.await?;
|
|
|
|
let authors = sqlx::query!(
|
|
"
|
|
SELECT COUNT(DISTINCT u.id)
|
|
FROM users u
|
|
INNER JOIN team_members tm on u.id = tm.user_id AND tm.accepted = TRUE
|
|
INNER JOIN mods m on tm.team_id = m.team_id AND m.status = ANY($1)
|
|
",
|
|
&*crate::models::projects::ProjectStatus::iterator()
|
|
.filter(|x| x.is_searchable())
|
|
.map(|x| x.to_string())
|
|
.collect::<Vec<String>>(),
|
|
)
|
|
.fetch_one(&**pool)
|
|
.await?;
|
|
|
|
let files = sqlx::query!(
|
|
"
|
|
SELECT COUNT(f.id) FROM files f
|
|
INNER JOIN versions v on f.version_id = v.id AND v.status = ANY($2)
|
|
INNER JOIN mods m on v.mod_id = m.id AND m.status = ANY($1)
|
|
",
|
|
&*crate::models::projects::ProjectStatus::iterator()
|
|
.filter(|x| x.is_searchable())
|
|
.map(|x| x.to_string())
|
|
.collect::<Vec<String>>(),
|
|
&*crate::models::projects::VersionStatus::iterator()
|
|
.filter(|x| x.is_listed())
|
|
.map(|x| x.to_string())
|
|
.collect::<Vec<String>>(),
|
|
)
|
|
.fetch_one(&**pool)
|
|
.await?;
|
|
|
|
let json = json!({
|
|
"projects": projects.count,
|
|
"versions": versions.count,
|
|
"authors": authors.count,
|
|
"files": files.count,
|
|
});
|
|
|
|
Ok(HttpResponse::Ok().json(json))
|
|
}
|