public virtual Decision IsSatisfiedBy(RemoteEpisode subject, SearchCriteriaBase searchCriteria) { _logger.Debug("Checking if release meets restrictions: {0}", subject); var title = subject.Release.Title; var restrictions = _restrictionService.AllForTags(subject.Series.Tags); var required = restrictions.Where(r => r.Required.IsNotNullOrWhiteSpace()); var ignored = restrictions.Where(r => r.Ignored.IsNotNullOrWhiteSpace()); foreach (var r in required) { var split = r.Required.Split(new[] { ',' }, StringSplitOptions.RemoveEmptyEntries).ToList(); if (!ContainsAny(split, title)) { _logger.Debug("[{0}] does not contain one of the required terms: {1}", title, r.Required); return(Decision.Reject("Does not contain one of the required terms: {0}", r.Required)); } } foreach (var r in ignored) { var split = r.Ignored.Split(new[] { ',' }, StringSplitOptions.RemoveEmptyEntries).ToList(); if (ContainsAny(split, title)) { _logger.Debug("[{0}] contains one or more ignored terms: {1}", title, r.Ignored); return(Decision.Reject("Contains one or more ignored terms: {0}", r.Ignored)); } } _logger.Debug("[{0}] No restrictions apply, allowing", subject); return(Decision.Accept()); }