mirror of
https://github.com/YGGverse/btracker.git
synced 2026-03-31 17:15:31 +00:00
implement row meta info
This commit is contained in:
parent
7da285ca69
commit
d014358028
5 changed files with 66 additions and 5 deletions
|
|
@ -40,6 +40,12 @@ pub struct Config {
|
|||
#[arg(long)]
|
||||
pub tracker: Option<Vec<Url>>,
|
||||
|
||||
/// Format timestamps (on the web view)
|
||||
///
|
||||
/// * tip: escape with `%%d/%%m/%%Y %%H:%%M` in the CLI/bash argument
|
||||
#[arg(long, short, default_value_t = String::from("%d/%m/%Y %H:%M"))]
|
||||
pub format_time: String,
|
||||
|
||||
/// Bind server on given host
|
||||
#[arg(long, short, default_value_t = IpAddr::V4(Ipv4Addr::LOCALHOST))]
|
||||
pub address: IpAddr,
|
||||
|
|
|
|||
10
src/main.rs
10
src/main.rs
|
|
@ -24,6 +24,7 @@ use url::Url;
|
|||
pub struct Meta {
|
||||
pub canonical: Option<Url>,
|
||||
pub description: Option<String>,
|
||||
pub format_time: String,
|
||||
pub stats: Option<Url>,
|
||||
pub title: String,
|
||||
pub trackers: Option<HashSet<Url>>,
|
||||
|
|
@ -34,8 +35,11 @@ fn index(storage: &State<Storage>, meta: &State<Meta>) -> Result<Template, Custo
|
|||
#[derive(Serialize)]
|
||||
#[serde(crate = "rocket::serde")]
|
||||
struct Row {
|
||||
torrent: Torrent,
|
||||
created: Option<String>,
|
||||
indexed: String,
|
||||
magnet: String,
|
||||
size: String,
|
||||
torrent: Torrent,
|
||||
}
|
||||
Ok(Template::render(
|
||||
"index",
|
||||
|
|
@ -49,7 +53,10 @@ fn index(storage: &State<Storage>, meta: &State<Meta>) -> Result<Template, Custo
|
|||
.map_err(|e| Custom(Status::InternalServerError, e.to_string()))?
|
||||
.into_iter()
|
||||
.map(|torrent| Row {
|
||||
created: torrent.creation_date.map(|t|t.format(&meta.format_time).to_string()),
|
||||
indexed: torrent.time.format(&meta.format_time).to_string(),
|
||||
magnet: format::magnet(&torrent.info_hash, meta.trackers.as_ref()),
|
||||
size: format::bytes(torrent.size),
|
||||
torrent,
|
||||
})
|
||||
.collect::<Vec<Row>>()
|
||||
|
|
@ -95,6 +102,7 @@ fn rocket() -> _ {
|
|||
.manage(Meta {
|
||||
canonical: config.link,
|
||||
description: config.description,
|
||||
format_time: config.format_time,
|
||||
stats: config.stats,
|
||||
title: config.title,
|
||||
trackers: config.tracker.map(|u| u.into_iter().collect()),
|
||||
|
|
|
|||
|
|
@ -40,6 +40,7 @@ pub struct Torrent {
|
|||
pub name: Option<String>,
|
||||
pub publisher_url: Option<String>,
|
||||
pub publisher: Option<String>,
|
||||
pub size: u64,
|
||||
/// File (modified)
|
||||
pub time: DateTime<Utc>,
|
||||
}
|
||||
|
|
@ -90,6 +91,7 @@ impl Storage {
|
|||
&fs::read(file.path()).map_err(|e| e.to_string())?,
|
||||
)
|
||||
.map_err(|e| e.to_string())?;
|
||||
|
||||
b.push(Torrent {
|
||||
info_hash: i.info_hash.as_string(),
|
||||
announce: i.announce.map(|a| a.to_string()),
|
||||
|
|
@ -98,6 +100,12 @@ impl Storage {
|
|||
creation_date: i
|
||||
.creation_date
|
||||
.map(|t| DateTime::from_timestamp_nanos(t as i64)),
|
||||
size: i.info.length.unwrap_or_default()
|
||||
+ i.info
|
||||
.files
|
||||
.as_ref()
|
||||
.map(|files| files.iter().map(|f| f.length).sum::<u64>())
|
||||
.unwrap_or_default(),
|
||||
files: i.info.files.map(|files| {
|
||||
let limit = 1000; // @TODO
|
||||
let mut b = Vec::with_capacity(files.len());
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue