1
0
mirror of https://github.com/Sonarr/Sonarr.git synced 2025-01-04 06:38:28 +02:00

Fixed: Prevent exception when grabbing unparsable release

Closes #7494
This commit is contained in:
Mark McDowall 2024-12-17 17:05:39 -08:00
parent 82c526e15c
commit 9a69222c9a
3 changed files with 13 additions and 3 deletions

View File

@ -94,6 +94,11 @@ public List<SceneMapping> FindByTvdbId(int tvdbId)
public SceneMapping FindSceneMapping(string seriesTitle, string releaseTitle, int sceneSeasonNumber)
{
if (seriesTitle.IsNullOrWhiteSpace())
{
return null;
}
var mappings = FindMappings(seriesTitle, releaseTitle);
if (mappings == null)

View File

@ -836,6 +836,11 @@ public static string ParseSeriesName(string title)
public static string CleanSeriesTitle(this string title)
{
if (title.IsNullOrWhiteSpace())
{
return title;
}
// If Title only contains numbers return it as is.
if (long.TryParse(title, out _))
{

View File

@ -127,7 +127,7 @@ public async Task<object> DownloadRelease([FromBody] ReleaseResource release)
if (episodes.Empty())
{
throw new NzbDroneClientException(HttpStatusCode.NotFound, "Unable to parse episodes in the release");
throw new NzbDroneClientException(HttpStatusCode.NotFound, "Unable to parse episodes in the release, will need to be manually provided");
}
remoteEpisode.Series = series;
@ -135,7 +135,7 @@ public async Task<object> DownloadRelease([FromBody] ReleaseResource release)
}
else
{
throw new NzbDroneClientException(HttpStatusCode.NotFound, "Unable to find matching series and episodes");
throw new NzbDroneClientException(HttpStatusCode.NotFound, "Unable to find matching series and episodes, will need to be manually provided");
}
}
else if (remoteEpisode.Episodes.Empty())
@ -154,7 +154,7 @@ public async Task<object> DownloadRelease([FromBody] ReleaseResource release)
if (remoteEpisode.Episodes.Empty())
{
throw new NzbDroneClientException(HttpStatusCode.NotFound, "Unable to parse episodes in the release");
throw new NzbDroneClientException(HttpStatusCode.NotFound, "Unable to parse episodes in the release, will need to be manually provided");
}
await _downloadService.DownloadReport(remoteEpisode, release.DownloadClientId);