|
|
@ -4,6 +4,7 @@ using System.Linq;
|
|
|
|
using FluentValidation;
|
|
|
|
using FluentValidation;
|
|
|
|
using FluentValidation.Results;
|
|
|
|
using FluentValidation.Results;
|
|
|
|
using Nancy.Responses;
|
|
|
|
using Nancy.Responses;
|
|
|
|
|
|
|
|
using NzbDrone.Common;
|
|
|
|
using NzbDrone.Core.Organizer;
|
|
|
|
using NzbDrone.Core.Organizer;
|
|
|
|
using Nancy.ModelBinding;
|
|
|
|
using Nancy.ModelBinding;
|
|
|
|
using NzbDrone.Api.Mapping;
|
|
|
|
using NzbDrone.Api.Mapping;
|
|
|
@ -39,6 +40,7 @@ namespace NzbDrone.Api.Config
|
|
|
|
SharedValidator.RuleFor(c => c.StandardEpisodeFormat).ValidEpisodeFormat();
|
|
|
|
SharedValidator.RuleFor(c => c.StandardEpisodeFormat).ValidEpisodeFormat();
|
|
|
|
SharedValidator.RuleFor(c => c.DailyEpisodeFormat).ValidDailyEpisodeFormat();
|
|
|
|
SharedValidator.RuleFor(c => c.DailyEpisodeFormat).ValidDailyEpisodeFormat();
|
|
|
|
SharedValidator.RuleFor(c => c.SeriesFolderFormat).ValidSeriesFolderFormat();
|
|
|
|
SharedValidator.RuleFor(c => c.SeriesFolderFormat).ValidSeriesFolderFormat();
|
|
|
|
|
|
|
|
SharedValidator.RuleFor(c => c.SeasonFolderFormat).ValidSeasonFolderFormat();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private void UpdateNamingConfig(NamingConfigResource resource)
|
|
|
|
private void UpdateNamingConfig(NamingConfigResource resource)
|
|
|
@ -72,7 +74,6 @@ namespace NzbDrone.Api.Config
|
|
|
|
|
|
|
|
|
|
|
|
private JsonResponse<NamingSampleResource> GetExamples(NamingConfigResource config)
|
|
|
|
private JsonResponse<NamingSampleResource> GetExamples(NamingConfigResource config)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
//TODO: Validate that the format is valid
|
|
|
|
|
|
|
|
var nameSpec = config.InjectTo<NamingConfig>();
|
|
|
|
var nameSpec = config.InjectTo<NamingConfig>();
|
|
|
|
var sampleResource = new NamingSampleResource();
|
|
|
|
var sampleResource = new NamingSampleResource();
|
|
|
|
|
|
|
|
|
|
|
@ -92,8 +93,13 @@ namespace NzbDrone.Api.Config
|
|
|
|
? "Invalid format"
|
|
|
|
? "Invalid format"
|
|
|
|
: dailyEpisodeSampleResult.Filename;
|
|
|
|
: dailyEpisodeSampleResult.Filename;
|
|
|
|
|
|
|
|
|
|
|
|
sampleResource.SeriesFolderExample = _filenameSampleService.GetSeriesFolderSample(nameSpec);
|
|
|
|
sampleResource.SeriesFolderExample = nameSpec.SeriesFolderFormat.IsNullOrWhiteSpace()
|
|
|
|
sampleResource.SeasonFolderExample = _filenameSampleService.GetSeasonFolderSample(nameSpec);
|
|
|
|
? "Invalid format"
|
|
|
|
|
|
|
|
: _filenameSampleService.GetSeriesFolderSample(nameSpec);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
sampleResource.SeasonFolderExample = nameSpec.SeasonFolderFormat.IsNullOrWhiteSpace()
|
|
|
|
|
|
|
|
? "Invalid format"
|
|
|
|
|
|
|
|
: _filenameSampleService.GetSeasonFolderSample(nameSpec);
|
|
|
|
|
|
|
|
|
|
|
|
return sampleResource.AsResponse();
|
|
|
|
return sampleResource.AsResponse();
|
|
|
|
}
|
|
|
|
}
|
|
|
|