/**
* Copyright 2005-2016 hdiv.org
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.hdiv.config.annotation;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;
import org.hdiv.config.StartPage;
import org.hdiv.regex.PatternMatcherFactory;
import org.springframework.util.Assert;
/**
* <p>
* Registry to add exclusions to the validation phase.
* </p>
* <p>
* Can contain two types of exclusions, URL and parameter. The first to exclude URLs from validation and the second to exclude parameter
* names.
* </p>
*
* @since 2.1.7
*/
public class ExclusionRegistry {
private final PatternMatcherFactory patternMatcherFactory;
private final List<UrlExclusionRegistration> urlRegistrations = new ArrayList<UrlExclusionRegistration>();
private final List<ParamExclusionRegistration> paramRegistrations = new ArrayList<ParamExclusionRegistration>();
public ExclusionRegistry(final PatternMatcherFactory patternMatcherFactory) {
this.patternMatcherFactory = patternMatcherFactory;
}
/**
* <p>
* Configure one or more url exclusion.
* </p>
* <p>
* Excluded urls are not validated by HDIV.
* </p>
*
* @param urlPatterns Url patterns.
* @return more configuration options
*/
public UrlExclusionRegistration addUrlExclusions(final String... urlPatterns) {
Assert.notEmpty(urlPatterns, "Url patterns are required");
UrlExclusionRegistration registration = new UrlExclusionRegistration(urlPatterns);
urlRegistrations.add(registration);
return registration;
}
/**
* <p>
* Configure one or more parameter exclusion.
* </p>
* <p>
* Excluded parameters are not validated by HDIV.
* </p>
*
* @param parameterPatterns Parameter name patterns.
* @return more configuration options
*/
public ParamExclusionRegistration addParamExclusions(final String... parameterPatterns) {
Assert.notEmpty(parameterPatterns, "Parameter patterns are required");
ParamExclusionRegistration registration = new ParamExclusionRegistration(Arrays.asList(parameterPatterns));
paramRegistrations.add(registration);
return registration;
}
protected List<StartPage> getUrlExclusions() {
List<StartPage> allStartPages = new ArrayList<StartPage>();
for (UrlExclusionRegistration regitration : urlRegistrations) {
List<StartPage> startPages = regitration.getExclusions();
for (StartPage sp : startPages) {
// Compile Pattern
sp.setCompiledPattern(patternMatcherFactory.getPatternMatcher(sp.getPattern()));
allStartPages.add(sp);
}
}
return allStartPages;
}
protected List<String> getParamExclusions() {
List<String> paramExclusions = new ArrayList<String>();
for (ParamExclusionRegistration regitration : paramRegistrations) {
String urlPattern = regitration.getUrlPattern();
if (urlPattern == null) {
paramExclusions.addAll(regitration.getParameterPatterns());
}
}
return paramExclusions;
}
protected Map<String, List<String>> getParamExclusionsForUrl() {
Map<String, List<String>> paramExclusions = new LinkedHashMap<String, List<String>>();
for (ParamExclusionRegistration regitration : paramRegistrations) {
String urlPattern = regitration.getUrlPattern();
if (urlPattern != null) {
paramExclusions.put(urlPattern, regitration.getParameterPatterns());
}
}
return paramExclusions;
}
}