add category folders for yt-dlp

This commit is contained in:
JMARyA 2024-05-05 16:29:20 +02:00
parent ebff54a8ba
commit 2cfd3b4f54
Signed by: jmarya
GPG key ID: 901B2ADDF27C2263
3 changed files with 48 additions and 31 deletions

View file

@ -15,7 +15,7 @@ pub struct SoundCloudConfig {
/// Amount of items to query /// Amount of items to query
pub limit: Option<u64>, pub limit: Option<u64>,
// Items to check // Items to check
pub artists: HashMap<String, String>, pub artists: HashMap<String, toml::Value>,
// Output Template for yt-dlp // Output Template for yt-dlp
pub output_format: Option<String>, pub output_format: Option<String>,
// Download comments // Download comments

View file

@ -15,7 +15,7 @@ pub struct YouTubeConfig {
/// Amount of videos to query /// Amount of videos to query
limit: Option<u64>, limit: Option<u64>,
// Channels to check // Channels to check
channels: HashMap<String, String>, channels: HashMap<String, toml::Value>,
// Format of the Thumbnail // Format of the Thumbnail
thumbnail_format: Option<String>, thumbnail_format: Option<String>,
// Output Template for yt-dlp // Output Template for yt-dlp

View file

@ -19,7 +19,7 @@ pub struct YtDlpConfig {
/// Amount of items to query /// Amount of items to query
pub limit: Option<u64>, pub limit: Option<u64>,
// Items to check // Items to check
pub items: HashMap<String, String>, pub items: HashMap<String, toml::Value>,
// Format of the Thumbnail // Format of the Thumbnail
pub thumbnail_format: Option<String>, pub thumbnail_format: Option<String>,
// Output Template for yt-dlp // Output Template for yt-dlp
@ -73,6 +73,36 @@ impl YtDlpModule {
root_dir, root_dir,
} }
} }
fn check_item(&self, item: &str, item_url: &str, cwd: &PathBuf) {
log::info!("Fetching \"{item}\" videos");
match Self::get_latest_entries(item_url, self.config.limit.unwrap_or(10)) {
Ok(latest_videos) => {
for (video_title, video_url) in latest_videos {
if self.db.check_for_url(&video_url) {
log::trace!("Skipping \"{video_title}\" because it was already downloaded");
} else {
match self.download(&video_url, cwd) {
Ok(()) => {
// mark as downloaded
self.db.insert_url(&video_url);
self.db.update_new_downloads(&self.name(), item, item_url);
log::info!("Downloaded \"{video_title}\"");
self.webhook_notify(&video_url, &video_title, item, true);
}
Err(e) => {
log::error!("Error downloading \"{video_title}\"; Reason: {e}");
self.webhook_notify(&video_url, &video_title, item, false);
}
}
}
}
}
Err(e) => {
log::error!("Could not get videos from \"{item}\". Reason: {e}");
}
}
}
} }
impl Module for YtDlpModule { impl Module for YtDlpModule {
@ -88,36 +118,23 @@ impl Module for YtDlpModule {
log::info!("Running {} Module", self.name()); log::info!("Running {} Module", self.name());
log::info!("Checking {} items", self.config.items.len()); log::info!("Checking {} items", self.config.items.len());
for (item, item_url) in &self.config.items { for (item, item_url) in &self.config.items {
log::info!("Fetching \"{item}\" videos"); match item_url {
match Self::get_latest_entries(item_url, self.config.limit.unwrap_or(10)) { toml::Value::String(item_url) => {
Ok(latest_videos) => { self.check_item(item, item_url, &self.root_dir.join(item));
for (video_title, video_url) in latest_videos { }
if self.db.check_for_url(&video_url) { toml::Value::Array(_) => todo!(),
log::trace!( toml::Value::Table(cat) => {
"Skipping \"{video_title}\" because it was already downloaded" let category = item;
); for (item, item_url) in cat {
} else { let item_url = item_url.as_str().unwrap();
match self.download(&video_url, &self.root_dir.join(item)) { self.check_item(
Ok(()) => { item,
// mark as downloaded item_url,
self.db.insert_url(&video_url); &self.root_dir.join(category).join(item),
self.db.update_new_downloads(&self.name(), item, item_url); );
log::info!("Downloaded \"{video_title}\"");
self.webhook_notify(&video_url, &video_title, item, true);
}
Err(e) => {
log::error!(
"Error downloading \"{video_title}\"; Reason: {e}"
);
self.webhook_notify(&video_url, &video_title, item, false);
}
}
}
} }
} }
Err(e) => { _ => {}
log::error!("Could not get videos from \"{item}\". Reason: {e}");
}
} }
} }
log::info!( log::info!(