blob: 7395a2db1eec5a949466a8cb2ad1a097ae011a55 [file] [log] [blame]
/*
* Copyright (C) 2008 Google Inc.
*
* 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 com.google.inject.servlet;
import com.google.inject.Binder;
import com.google.inject.Key;
import com.google.inject.internal.UniqueAnnotations;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import javax.servlet.Filter;
/**
* Builds the guice module that binds configured filters, with their wrapper FilterDefinitions. Is
* part of the binding EDSL. All Filters and Servlets are always bound as singletons.
*
* @author dhanji@gmail.com (Dhanji R. Prasanna)
*/
class FiltersModuleBuilder {
private final Binder binder;
public FiltersModuleBuilder(Binder binder) {
this.binder = binder;
}
public ServletModule.FilterKeyBindingBuilder filter(List<String> patterns) {
return new FilterKeyBindingBuilderImpl(parsePatterns(UriPatternType.SERVLET, patterns));
}
public ServletModule.FilterKeyBindingBuilder filterRegex(List<String> regexes) {
return new FilterKeyBindingBuilderImpl(parsePatterns(UriPatternType.REGEX, regexes));
}
private List<UriPatternMatcher> parsePatterns(UriPatternType type, List<String> patterns) {
List<UriPatternMatcher> patternMatchers = new ArrayList<>();
for (String pattern : patterns) {
UriPatternMatcher matcher = null;
try {
matcher = UriPatternType.get(type, pattern);
} catch (IllegalArgumentException iae) {
binder
.skipSources(ServletModule.class, FiltersModuleBuilder.class)
.addError("%s", iae.getMessage());
}
if (matcher != null) {
patternMatchers.add(matcher);
}
}
return patternMatchers;
}
//non-static inner class so it can access state of enclosing module class
class FilterKeyBindingBuilderImpl implements ServletModule.FilterKeyBindingBuilder {
private final List<UriPatternMatcher> uriPatterns;
private FilterKeyBindingBuilderImpl(List<UriPatternMatcher> uriPatterns) {
this.uriPatterns = uriPatterns;
}
@Override
public void through(Class<? extends Filter> filterKey) {
through(Key.get(filterKey));
}
@Override
public void through(Key<? extends Filter> filterKey) {
through(filterKey, new HashMap<String, String>());
}
@Override
public void through(Filter filter) {
through(filter, new HashMap<String, String>());
}
@Override
public void through(Class<? extends Filter> filterKey, Map<String, String> initParams) {
// Careful you don't accidentally make this method recursive, thank you IntelliJ IDEA!
through(Key.get(filterKey), initParams);
}
@Override
public void through(Key<? extends Filter> filterKey, Map<String, String> initParams) {
through(filterKey, initParams, null);
}
private void through(
Key<? extends Filter> filterKey, Map<String, String> initParams, Filter filterInstance) {
for (UriPatternMatcher pattern : uriPatterns) {
binder
.bind(FilterDefinition.class)
.annotatedWith(UniqueAnnotations.create())
.toProvider(new FilterDefinition(filterKey, pattern, initParams, filterInstance));
}
}
@Override
public void through(Filter filter, Map<String, String> initParams) {
Key<Filter> filterKey = Key.get(Filter.class, UniqueAnnotations.create());
binder.bind(filterKey).toInstance(filter);
through(filterKey, initParams, filter);
}
}
}