feat(network): Support for deleting tags from Sonarr

This commit is contained in:
2024-11-22 15:02:30 -07:00
parent 57eced64c0
commit 208acafc73
4 changed files with 56 additions and 5 deletions
+25 -1
View File
@@ -38,6 +38,7 @@ pub enum SonarrEvent {
DeleteDownload(Option<i64>),
DeleteIndexer(Option<i64>),
DeleteRootFolder(Option<i64>),
DeleteTag(i64),
GetAllIndexerSettings,
GetBlocklist,
GetDownloads,
@@ -64,7 +65,7 @@ pub enum SonarrEvent {
impl NetworkResource for SonarrEvent {
fn resource(&self) -> &'static str {
match &self {
SonarrEvent::AddTag(_) => "/tag",
SonarrEvent::AddTag(_) | SonarrEvent::DeleteTag(_) => "/tag",
SonarrEvent::ClearBlocklist => "/blocklist/bulk",
SonarrEvent::DeleteBlocklistItem(_) => "/blocklist",
SonarrEvent::GetAllIndexerSettings => "/config/indexer",
@@ -130,6 +131,10 @@ impl<'a, 'b> Network<'a, 'b> {
.delete_sonarr_root_folder(root_folder_id)
.await
.map(SonarrSerdeable::from),
SonarrEvent::DeleteTag(tag_id) => self
.delete_sonarr_tag(tag_id)
.await
.map(SonarrSerdeable::from),
SonarrEvent::GetBlocklist => self.get_sonarr_blocklist().await.map(SonarrSerdeable::from),
SonarrEvent::GetDownloads => self.get_sonarr_downloads().await.map(SonarrSerdeable::from),
SonarrEvent::GetEpisodes(series_id) => self
@@ -414,6 +419,25 @@ impl<'a, 'b> Network<'a, 'b> {
.await
}
async fn delete_sonarr_tag(&mut self, id: i64) -> Result<()> {
info!("Deleting Sonarr tag with id: {id}");
let event = SonarrEvent::DeleteTag(id);
let request_props = self
.request_props_from(
event,
RequestMethod::Delete,
None::<()>,
Some(format!("/{id}")),
None,
)
.await;
self
.handle_request::<(), ()>(request_props, |_, _| ())
.await
}
async fn get_all_sonarr_indexer_settings(&mut self) -> Result<IndexerSettings> {
info!("Fetching Sonarr indexer settings");
let event = SonarrEvent::GetAllIndexerSettings;