-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathserver.rs
More file actions
108 lines (100 loc) · 3.46 KB
/
server.rs
File metadata and controls
108 lines (100 loc) · 3.46 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
use crate::{autotag::MetadataSource, sync, util};
use axum::{Router, extract, routing};
use static_serve::embed_assets;
use std::sync::Arc;
embed_assets!(
"frontend/pkg",
compress = true,
strip_html_ext = true,
ignore_paths = [".gitignore"],
cache_busted_paths = ["index.html", "favicon.svg"]
);
pub async fn serve(configuration: util::Configuration) {
let address = configuration.address().unwrap();
let router = Router::new()
.merge(static_router())
.route("/health", routing::get(async || "Working!"))
.route("/trackadd", routing::post(trackadd))
.route("/tracks", routing::get(trackls))
.route("/track/{id}", routing::delete(trackrm))
.route("/track/{id}", routing::get(trackinfo))
.route("/track/{id}", routing::put(trackedit))
.route("/track/{id}", routing::patch(trackpatch))
.route("/track/{id}/autotag", routing::get(trackautotag))
.with_state(Arc::new(configuration));
let listener = tokio::net::TcpListener::bind(address).await.unwrap();
axum::serve(listener, router).await.unwrap();
}
async fn trackadd(
extract::State(cfg): extract::State<Arc<util::Configuration>>,
extract::Json(tracks): extract::Json<Vec<String>>,
) -> axum::response::Result<()> {
let Ok(tracks) = tracks
.iter()
.map(|s| axum::http::Uri::try_from(s))
.collect::<Result<Vec<_>, _>>()
else {
return Err((reqwest::StatusCode::BAD_REQUEST, "Invalid URL(s)").into());
};
let library = cfg.get_library()?;
for track in tracks {
sync::track_download(track, library.as_path()).await?
}
Ok(())
}
async fn trackls(
extract::State(cfg): extract::State<Arc<util::Configuration>>,
) -> axum::response::Result<extract::Json<Vec<String>>> {
Ok(extract::Json(sync::track_list(
cfg.get_library()?.as_path(),
)?))
}
async fn trackrm(
extract::State(cfg): extract::State<Arc<util::Configuration>>,
extract::Path(track): extract::Path<String>,
) -> axum::response::Result<()> {
Ok(sync::track_delete(&track, cfg.get_library()?.as_path())?)
}
async fn trackinfo(
extract::State(cfg): extract::State<Arc<util::Configuration>>,
extract::Path(track): extract::Path<String>,
) -> axum::response::Result<extract::Json<util::Metadata>> {
Ok(extract::Json(
sync::track_info(&track, cfg.get_library()?.as_path())?.into(),
))
}
async fn trackedit(
extract::State(cfg): extract::State<Arc<util::Configuration>>,
extract::Path(track): extract::Path<String>,
extract::Json(meta): extract::Json<util::Metadata>,
) -> axum::response::Result<()> {
Ok(sync::track_edit(
&track,
cfg.get_library()?.as_path(),
meta,
false,
)?)
}
async fn trackpatch(
extract::State(cfg): extract::State<Arc<util::Configuration>>,
extract::Path(track): extract::Path<String>,
extract::Json(meta): extract::Json<util::Metadata>,
) -> axum::response::Result<()> {
Ok(sync::track_edit(
&track,
cfg.get_library()?.as_path(),
meta,
true,
)?)
}
async fn trackautotag(
extract::State(cfg): extract::State<Arc<util::Configuration>>,
extract::Path(track): extract::Path<String>,
) -> axum::response::Result<extract::Json<Vec<util::Metadata>>> {
let meta = sync::track_info(&track, cfg.get_library()?.as_path())?.into();
Ok(extract::Json(
cfg.metadatasources
.get_track(&meta, meta.isrc.is_none())
.await?,
))
}