diff options
author | Ilion Beyst <ilion.beyst@gmail.com> | 2022-01-27 19:22:48 +0100 |
---|---|---|
committer | Ilion Beyst <ilion.beyst@gmail.com> | 2022-01-27 19:22:48 +0100 |
commit | bfbcc173f88c67bc8e6b3a8079204739f72e7ebc (patch) | |
tree | 826b5120970e994985ef25612d057b46950758de /planetwars-server/src/routes/demo.rs | |
parent | 4a7229b175abfe782696d29cfe664e092c3d970e (diff) | |
download | planetwars.dev-bfbcc173f88c67bc8e6b3a8079204739f72e7ebc.tar.xz planetwars.dev-bfbcc173f88c67bc8e6b3a8079204739f72e7ebc.zip |
allow retrieving match log for submitted bot
Diffstat (limited to 'planetwars-server/src/routes/demo.rs')
-rw-r--r-- | planetwars-server/src/routes/demo.rs | 9 |
1 files changed, 8 insertions, 1 deletions
diff --git a/planetwars-server/src/routes/demo.rs b/planetwars-server/src/routes/demo.rs index 16ec8f1..ea57079 100644 --- a/planetwars-server/src/routes/demo.rs +++ b/planetwars-server/src/routes/demo.rs @@ -1,6 +1,6 @@ use std::path::PathBuf; -use axum::Json; +use axum::{extract::Path, Json}; use hyper::StatusCode; use planetwars_matchrunner::{docker_runner::DockerBotSpec, run_match, MatchConfig, MatchPlayer}; use rand::{distributions::Alphanumeric, Rng}; @@ -68,3 +68,10 @@ pub async fn submit_bot( Ok(Json(SubmitBotResponse { match_id })) } + +// TODO: unify this with existing match API +pub async fn get_submission_match_log(Path(match_id): Path<String>) -> Result<String, StatusCode> { + let log_path = PathBuf::from(MATCHES_DIR).join(format!("{}.log", match_id)); + + std::fs::read_to_string(&log_path).map_err(|_| StatusCode::NOT_FOUND) +} |