add latest albums
This commit is contained in:
parent
c93f0ea403
commit
a5d3c14f0c
4 changed files with 49 additions and 4 deletions
|
@ -9,6 +9,11 @@ macro_rules! use_api_cache {
|
||||||
return Ok(serde_json::from_str(&ret).unwrap());
|
return Ok(serde_json::from_str(&ret).unwrap());
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
($route:literal, $id:literal, $cache:ident) => {
|
||||||
|
if let Some(ret) = $cache.get_only($route, $id).await {
|
||||||
|
return Ok(serde_json::from_str(&ret).unwrap());
|
||||||
|
}
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
pub struct RouteCache {
|
pub struct RouteCache {
|
||||||
|
|
|
@ -8,6 +8,8 @@ use serde_json::json;
|
||||||
use track::Track;
|
use track::Track;
|
||||||
use walkdir::WalkDir;
|
use walkdir::WalkDir;
|
||||||
|
|
||||||
|
use crate::cache::RouteCache;
|
||||||
|
|
||||||
pub mod album;
|
pub mod album;
|
||||||
pub mod artist;
|
pub mod artist;
|
||||||
pub mod metadata;
|
pub mod metadata;
|
||||||
|
@ -164,7 +166,9 @@ impl Libary {
|
||||||
Track::get(track_id).await
|
Track::get(track_id).await
|
||||||
}
|
}
|
||||||
|
|
||||||
pub async fn rescan(&self) {
|
pub async fn rescan(&self, cache: &RouteCache) {
|
||||||
|
cache.invalidate("albums", "latest").await;
|
||||||
|
|
||||||
log::info!("Rescanning library");
|
log::info!("Rescanning library");
|
||||||
for entry in WalkDir::new(self.root_dir.clone())
|
for entry in WalkDir::new(self.root_dir.clone())
|
||||||
.follow_links(true)
|
.follow_links(true)
|
||||||
|
|
|
@ -28,8 +28,9 @@ async fn rocket() -> _ {
|
||||||
.expect("error creating CORS options");
|
.expect("error creating CORS options");
|
||||||
|
|
||||||
let lib = Libary::new("./media".into());
|
let lib = Libary::new("./media".into());
|
||||||
|
let cache = cache::RouteCache::new();
|
||||||
|
|
||||||
lib.rescan().await;
|
lib.rescan(&cache).await;
|
||||||
|
|
||||||
// create initial admin user
|
// create initial admin user
|
||||||
if User::find(doc! { "username": "admin" }, None)
|
if User::find(doc! { "username": "admin" }, None)
|
||||||
|
@ -39,8 +40,6 @@ async fn rocket() -> _ {
|
||||||
User::create("admin", "admin", UserRole::Admin).await;
|
User::create("admin", "admin", UserRole::Admin).await;
|
||||||
}
|
}
|
||||||
|
|
||||||
let cache = cache::RouteCache::new();
|
|
||||||
|
|
||||||
rocket::build()
|
rocket::build()
|
||||||
.mount(
|
.mount(
|
||||||
"/",
|
"/",
|
||||||
|
@ -52,6 +51,7 @@ async fn rocket() -> _ {
|
||||||
route::artist::artist_image_route,
|
route::artist::artist_image_route,
|
||||||
route::album::albums_route,
|
route::album::albums_route,
|
||||||
route::album::album_route,
|
route::album::album_route,
|
||||||
|
route::album::latest_albums_route,
|
||||||
route::track::track_route,
|
route::track::track_route,
|
||||||
route::track::track_audio_route,
|
route::track::track_audio_route,
|
||||||
route::album::album_cover_route,
|
route::album::album_cover_route,
|
||||||
|
|
|
@ -3,6 +3,8 @@ use std::cmp::Ordering;
|
||||||
use super::api_error;
|
use super::api_error;
|
||||||
use super::FallibleApiResponse;
|
use super::FallibleApiResponse;
|
||||||
use super::ToAPI;
|
use super::ToAPI;
|
||||||
|
use mongod::Model;
|
||||||
|
use mongod::Referencable;
|
||||||
use mongodb::bson::doc;
|
use mongodb::bson::doc;
|
||||||
use rocket::fs::NamedFile;
|
use rocket::fs::NamedFile;
|
||||||
use rocket::{get, State};
|
use rocket::{get, State};
|
||||||
|
@ -10,6 +12,7 @@ use serde_json::json;
|
||||||
|
|
||||||
use crate::cache::RouteCache;
|
use crate::cache::RouteCache;
|
||||||
use crate::library::album::Album;
|
use crate::library::album::Album;
|
||||||
|
use crate::library::track::Track;
|
||||||
use crate::library::Libary;
|
use crate::library::Libary;
|
||||||
use crate::route::to_api;
|
use crate::route::to_api;
|
||||||
use crate::use_api_cache;
|
use crate::use_api_cache;
|
||||||
|
@ -55,6 +58,39 @@ pub async fn album_cover_route(
|
||||||
.ok()
|
.ok()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[get("/albums/latest")]
|
||||||
|
pub async fn latest_albums_route(cache: &State<RouteCache>) -> FallibleApiResponse {
|
||||||
|
use_api_cache!("albums", "latest", cache);
|
||||||
|
|
||||||
|
let albums = Album::find(doc! {}, None).await.unwrap();
|
||||||
|
|
||||||
|
let mut albums_tracks = vec![];
|
||||||
|
|
||||||
|
for album in &albums {
|
||||||
|
albums_tracks.push(
|
||||||
|
Track::find_one(doc! { "album_id": album.reference()})
|
||||||
|
.await
|
||||||
|
.unwrap(),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
let mut joined: Vec<(_, _)> = albums.into_iter().zip(albums_tracks).collect();
|
||||||
|
|
||||||
|
joined.sort_by(|a, b| a.1.date_added.cmp(&b.1.date_added));
|
||||||
|
|
||||||
|
joined.reverse();
|
||||||
|
|
||||||
|
let (albums, _): (Vec<_>, Vec<_>) = joined.into_iter().unzip();
|
||||||
|
|
||||||
|
let albums = to_api(&albums).await;
|
||||||
|
|
||||||
|
cache
|
||||||
|
.insert("albums", "latest", serde_json::to_string(&albums).unwrap())
|
||||||
|
.await;
|
||||||
|
|
||||||
|
Ok(json!(albums))
|
||||||
|
}
|
||||||
|
|
||||||
#[get("/album/<album_id>")]
|
#[get("/album/<album_id>")]
|
||||||
pub async fn album_route(
|
pub async fn album_route(
|
||||||
album_id: &str,
|
album_id: &str,
|
||||||
|
|
Loading…
Reference in a new issue