Merge remote-tracking branch 'origin/main' into svelte-5

This commit is contained in:
Niccolo Borgioli 2025-01-17 18:11:34 +01:00
commit e20f4626e7
4 changed files with 465 additions and 228 deletions

File diff suppressed because it is too large Load Diff

View File

@ -0,0 +1,10 @@
use std::collections::HashMap;
use std::sync::Arc;
use tokio::sync::Mutex;
#[derive(Clone)]
pub struct SharedState {
pub locks: LockMap,
}
pub type LockMap = Arc<Mutex<HashMap<String, Arc<Mutex<()>>>>>;

View File

@ -1,9 +1,13 @@
use std::{collections::HashMap, sync::Arc};
use axum::{ use axum::{
extract::{DefaultBodyLimit, Request}, extract::{DefaultBodyLimit, Request},
routing::{delete, get, post}, routing::{delete, get, post},
Router, ServiceExt, Router, ServiceExt,
}; };
use dotenv::dotenv; use dotenv::dotenv;
use lock::SharedState;
use tokio::sync::Mutex;
use tower::Layer; use tower::Layer;
use tower_http::{ use tower_http::{
compression::CompressionLayer, compression::CompressionLayer,
@ -16,6 +20,7 @@ extern crate lazy_static;
mod config; mod config;
mod health; mod health;
mod lock;
mod note; mod note;
mod status; mod status;
mod store; mod store;
@ -24,9 +29,13 @@ mod store;
async fn main() { async fn main() {
dotenv().ok(); dotenv().ok();
let shared_state = SharedState {
locks: Arc::new(Mutex::new(HashMap::new())),
};
if !store::can_reach_redis() { if !store::can_reach_redis() {
println!("cannot reach redis"); println!("cannot reach redis");
panic!("canont reach redis"); panic!("cannot reach redis");
} }
let notes_routes = Router::new() let notes_routes = Router::new()
@ -53,7 +62,8 @@ async fn main() {
.deflate(true) .deflate(true)
.gzip(true) .gzip(true)
.zstd(true), .zstd(true),
); )
.with_state(shared_state);
let app = NormalizePathLayer::trim_trailing_slash().layer(app); let app = NormalizePathLayer::trim_trailing_slash().layer(app);

View File

@ -5,11 +5,12 @@ use axum::{
Json, Json,
}; };
use serde::{Deserialize, Serialize}; use serde::{Deserialize, Serialize};
use std::time::SystemTime; use std::{sync::Arc, time::SystemTime};
use tokio::sync::Mutex;
use crate::config;
use crate::note::{generate_id, Note, NoteInfo}; use crate::note::{generate_id, Note, NoteInfo};
use crate::store; use crate::store;
use crate::{config, lock::SharedState};
use super::NotePublic; use super::NotePublic;
@ -80,11 +81,20 @@ pub async fn create(Json(mut n): Json<Note>) -> Response {
} }
} }
pub async fn delete(Path(OneNoteParams { id }): Path<OneNoteParams>) -> Response { pub async fn delete(
Path(OneNoteParams { id }): Path<OneNoteParams>,
state: axum::extract::State<SharedState>,
) -> Response {
let mut locks_map = state.locks.lock().await;
let lock = locks_map
.entry(id.clone())
.or_insert_with(|| Arc::new(Mutex::new(())))
.clone();
drop(locks_map);
let _guard = lock.lock().await;
let note = store::get(&id); let note = store::get(&id);
match note { match note {
// Err(e) => HttpResponse::InternalServerError().body(e.to_string()),
// Ok(None) => return HttpResponse::NotFound().finish(),
Err(e) => (StatusCode::INTERNAL_SERVER_ERROR, e.to_string()).into_response(), Err(e) => (StatusCode::INTERNAL_SERVER_ERROR, e.to_string()).into_response(),
Ok(None) => (StatusCode::NOT_FOUND).into_response(), Ok(None) => (StatusCode::NOT_FOUND).into_response(),
Ok(Some(note)) => { Ok(Some(note)) => {