diff --git a/src/NzbDrone.Api/Restrictions/RestrictionModule.cs b/src/NzbDrone.Api/Restrictions/RestrictionModule.cs index 376db6e13..85a135cf8 100644 --- a/src/NzbDrone.Api/Restrictions/RestrictionModule.cs +++ b/src/NzbDrone.Api/Restrictions/RestrictionModule.cs @@ -1,6 +1,8 @@ using System; using System.Collections.Generic; +using FluentValidation.Results; using NzbDrone.Api.Mapping; +using NzbDrone.Common.Extensions; using NzbDrone.Core.Restrictions; namespace NzbDrone.Api.Restrictions @@ -19,6 +21,16 @@ public RestrictionModule(IRestrictionService restrictionService) CreateResource = Create; UpdateResource = Update; DeleteResource = Delete; + + SharedValidator.Custom(restriction => + { + if (restriction.Ignored.IsNullOrWhiteSpace() && restriction.Required.IsNullOrWhiteSpace()) + { + return new ValidationFailure("", "Either 'Must contaion' or 'Must not contain' is required"); + } + + return null; + }); } private RestrictionResource Get(Int32 id)