From 3671d7fc65301f0038e03f5730576908e6438b0e Mon Sep 17 00:00:00 2001 From: Bastien Orivel Date: Tue, 6 Feb 2024 01:28:44 +0100 Subject: [PATCH] Turns out the game name could be a map if you want to submit undecisive yamls Handle that as bes we can --- src/api.rs | 25 ++++++++++++++++++++++--- 1 file changed, 22 insertions(+), 3 deletions(-) diff --git a/src/api.rs b/src/api.rs index d3a9884..7279ce2 100644 --- a/src/api.rs +++ b/src/api.rs @@ -1,3 +1,5 @@ +use std::collections::HashMap; + use crate::diesel_uuid::Uuid as DieselUuid; use crate::error::Result; use crate::schema::{rooms, yamls}; @@ -50,9 +52,16 @@ pub struct Yaml { pub game: String, } -#[derive(serde::Deserialize)] +#[derive(serde::Deserialize, Debug)] +#[serde(untagged)] +pub enum YamlGame { + Name(String), + Map(HashMap), +} + +#[derive(serde::Deserialize, Debug)] pub struct YamlFile { - pub game: String, + pub game: YamlGame, pub name: String, } @@ -111,6 +120,16 @@ pub fn add_yaml_to_room( ctx: &State, ) -> Result<()> { let mut conn = ctx.db_pool.get()?; + let game_name = match &parsed.game { + YamlGame::Name(name) => name.clone(), + YamlGame::Map(map) => { + if map.len() == 1 { + map.keys().next().unwrap().clone() + } else { + "Unknown".to_string() + } + } + }; let new_yaml = NewYaml { id: DieselUuid::random(), @@ -118,7 +137,7 @@ pub fn add_yaml_to_room( room_id: DieselUuid(uuid), content, player_name: &parsed.name, - game: &parsed.game, + game: &game_name, }; diesel::insert_into(yamls::table) .values(new_yaml)