use a hashmap

This commit is contained in:
Daniel Løvbrøtte Olsen 2020-03-26 21:55:13 +01:00
parent 817655ef7e
commit 434d23ab06
2 changed files with 22 additions and 10 deletions

View File

@ -6,9 +6,12 @@ use rocket::response::status::NotFound;
use rocket_contrib::json::Json; use rocket_contrib::json::Json;
use serde_json::Value; use serde_json::Value;
use serde_json::json;
use serde::{Serialize, Deserialize};
use rocket_contrib::uuid::Uuid; use rocket_contrib::uuid::Uuid;
use std::sync::Mutex; use std::sync::Mutex;
use std::collections::HashMap;
mod workunit; mod workunit;
use workunit::WUnit; use workunit::WUnit;
@ -18,7 +21,7 @@ const VERSION: &str = "0.1.0";
#[derive(Default, Debug)] #[derive(Default, Debug)]
struct SharedState { struct SharedState {
list: Mutex<Vec<WUnit>> jobs: Mutex<HashMap<uuid::Uuid, WUnit>>
} }
#[get("/")] #[get("/")]
@ -33,15 +36,21 @@ fn version() -> &'static str {
#[get("/get_jobs")] #[get("/get_jobs")]
fn get_jobs(shared: State<SharedState>) -> Json<Value> { fn get_jobs(shared: State<SharedState>) -> Json<Value> {
let list = shared.list.lock().unwrap(); let list = shared.jobs.lock().unwrap().clone();
Json(serde_json::to_value(&list[..]).unwrap())
println!("{:#?}", list);
//Json(json!("god hlep me"))
Json(serde_json::to_value(&list).unwrap())
} }
#[get("/request_job")] #[get("/request_job")]
fn request_job(shared: State<SharedState>) -> Result<Json<Value>, NotFound<String>> { fn request_job(shared: State<SharedState>) -> Result<Json<Value>, NotFound<String>> {
let mut list = shared.list.lock().unwrap().clone(); let mut list: Vec<WUnit> = shared.jobs.lock().unwrap()
.values().cloned()
.filter(|x| x.status == EStatus::Queued)
.collect();
list.retain(|x| x.status == EStatus::Queued);
list.sort_by(|a, b| b.description.length.cmp(&a.description.length)); list.sort_by(|a, b| b.description.length.cmp(&a.description.length));
let job = list.get(0); let job = list.get(0);
@ -51,9 +60,9 @@ fn request_job(shared: State<SharedState>) -> Result<Json<Value>, NotFound<Strin
#[get("/get_job/<id>")] #[get("/get_job/<id>")]
fn get_job(id: Uuid, shared: State<SharedState>) -> Result<Json<Value>, NotFound<String>> { fn get_job(id: Uuid, shared: State<SharedState>) -> Result<Json<Value>, NotFound<String>> {
let list = shared.list.lock().unwrap().clone(); let list = shared.jobs.lock().unwrap();
let job = list.into_iter().find(|x| x.id == *id).ok_or(NotFound(format!("Job not Found: {id}", id = id))); let job = list.get(&id).ok_or(NotFound(format!("Job not Found: {id}", id = id)));
match job { match job {
Ok(j) => Ok(Json(serde_json::to_value(&j).unwrap())), Ok(j) => Ok(Json(serde_json::to_value(&j).unwrap())),
@ -65,7 +74,10 @@ fn get_job(id: Uuid, shared: State<SharedState>) -> Result<Json<Value>, NotFound
fn add_job(message: Json<workunit::WDesc>, shared: State<SharedState>) -> Result<String, String> { fn add_job(message: Json<workunit::WDesc>, shared: State<SharedState>) -> Result<String, String> {
println!("{:#?}", message); println!("{:#?}", message);
let job = message.into_inner(); let job = message.into_inner();
shared.list.lock().unwrap().push(WUnit::new(job));
let id = uuid::Uuid::new_v4();
shared.jobs.lock().unwrap().insert(id, WUnit::new(id, job));
Ok(format!("{:#?}", shared)) Ok(format!("{:#?}", shared))
} }

View File

@ -8,9 +8,9 @@ pub struct WUnit {
pub status: EStatus pub status: EStatus
} }
impl WUnit { impl WUnit {
pub fn new(description: WDesc) -> Self { pub fn new(id: Uuid, description: WDesc) -> Self {
WUnit { WUnit {
id: Uuid::new_v4(), id: id,
description: description, description: description,
status: EStatus::Queued status: EStatus::Queued
} }