feat(network): Added netwwork support for fetching all indexer settings for Sonarr

This commit is contained in:
2024-11-18 21:19:20 -07:00
parent 4fc2d3c94b
commit 7870bb4b5b
7 changed files with 137 additions and 8 deletions
+2 -2
View File
@@ -187,7 +187,7 @@ impl<'a, 'b> Network<'a, 'b> {
}
RadarrEvent::EditMovie(params) => self.edit_movie(params).await.map(RadarrSerdeable::from),
RadarrEvent::GetAllIndexerSettings => self
.get_all_indexer_settings()
.get_all_radarr_indexer_settings()
.await
.map(RadarrSerdeable::from),
RadarrEvent::GetBlocklist => self.get_radarr_blocklist().await.map(RadarrSerdeable::from),
@@ -1417,7 +1417,7 @@ impl<'a, 'b> Network<'a, 'b> {
.await
}
async fn get_all_indexer_settings(&mut self) -> Result<IndexerSettings> {
async fn get_all_radarr_indexer_settings(&mut self) -> Result<IndexerSettings> {
info!("Fetching Radarr indexer settings");
let event = RadarrEvent::GetAllIndexerSettings;
+28 -3
View File
@@ -2,7 +2,7 @@ use std::collections::BTreeMap;
use anyhow::Result;
use indoc::formatdoc;
use log::info;
use log::{debug, info};
use managarr_tree_widget::TreeItem;
use serde_json::{json, Value};
@@ -11,8 +11,8 @@ use crate::{
servarr_data::sonarr::{modals::EpisodeDetailsModal, sonarr_data::ActiveSonarrBlock},
servarr_models::{HostConfig, Indexer, SecurityConfig},
sonarr_models::{
BlocklistResponse, DownloadRecord, DownloadsResponse, Episode, LogResponse, QualityProfile,
Series, SonarrSerdeable, SystemStatus,
BlocklistResponse, DownloadRecord, DownloadsResponse, Episode, IndexerSettings, LogResponse,
QualityProfile, Series, SonarrSerdeable, SystemStatus,
},
HorizontallyScrollableText, Route, Scrollable, ScrollableText,
},
@@ -29,6 +29,7 @@ mod sonarr_network_tests;
pub enum SonarrEvent {
ClearBlocklist,
DeleteBlocklistItem(Option<i64>),
GetAllIndexerSettings,
GetBlocklist,
GetDownloads,
GetHostConfig,
@@ -48,6 +49,7 @@ impl NetworkResource for SonarrEvent {
match &self {
SonarrEvent::ClearBlocklist => "/blocklist/bulk",
SonarrEvent::DeleteBlocklistItem(_) => "/blocklist",
SonarrEvent::GetAllIndexerSettings => "/config/indexer",
SonarrEvent::GetBlocklist => "/blocklist?page=1&pageSize=10000",
SonarrEvent::GetDownloads => "/queue",
SonarrEvent::GetEpisodes(_) | SonarrEvent::GetEpisodeDetails(_) => "/episode",
@@ -78,6 +80,10 @@ impl<'a, 'b> Network<'a, 'b> {
.clear_sonarr_blocklist()
.await
.map(SonarrSerdeable::from),
SonarrEvent::GetAllIndexerSettings => self
.get_all_sonarr_indexer_settings()
.await
.map(SonarrSerdeable::from),
SonarrEvent::DeleteBlocklistItem(blocklist_item_id) => self
.delete_sonarr_blocklist_item(blocklist_item_id)
.await
@@ -182,6 +188,25 @@ impl<'a, 'b> Network<'a, 'b> {
.await
}
async fn get_all_sonarr_indexer_settings(&mut self) -> Result<IndexerSettings> {
info!("Fetching Sonarr indexer settings");
let event = SonarrEvent::GetAllIndexerSettings;
let request_props = self
.request_props_from(event, RequestMethod::Get, None::<()>, None, None)
.await;
self
.handle_request::<(), IndexerSettings>(request_props, |indexer_settings, mut app| {
if app.data.sonarr_data.indexer_settings.is_none() {
app.data.sonarr_data.indexer_settings = Some(indexer_settings);
} else {
debug!("Indexer Settings are being modified. Ignoring update...");
}
})
.await
}
async fn get_sonarr_healthcheck(&mut self) -> Result<()> {
info!("Performing Sonarr health check");
let event = SonarrEvent::HealthCheck;