add category folders for yt-dlp
This commit is contained in:
parent
ebff54a8ba
commit
2cfd3b4f54
3 changed files with 48 additions and 31 deletions
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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 {
|
||||||
|
let item_url = item_url.as_str().unwrap();
|
||||||
|
self.check_item(
|
||||||
|
item,
|
||||||
|
item_url,
|
||||||
|
&self.root_dir.join(category).join(item),
|
||||||
);
|
);
|
||||||
} else {
|
|
||||||
match self.download(&video_url, &self.root_dir.join(item)) {
|
|
||||||
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}");
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
log::info!(
|
log::info!(
|
||||||
|
|
Loading…
Reference in a new issue