14e11457f34addf5d10fe0c31cefd54c75c37b540sberlin/**
24e11457f34addf5d10fe0c31cefd54c75c37b540sberlin * Copyright (C) 2010 Google Inc.
34e11457f34addf5d10fe0c31cefd54c75c37b540sberlin *
44e11457f34addf5d10fe0c31cefd54c75c37b540sberlin * Licensed under the Apache License, Version 2.0 (the "License");
54e11457f34addf5d10fe0c31cefd54c75c37b540sberlin * you may not use this file except in compliance with the License.
64e11457f34addf5d10fe0c31cefd54c75c37b540sberlin * You may obtain a copy of the License at
74e11457f34addf5d10fe0c31cefd54c75c37b540sberlin *
84e11457f34addf5d10fe0c31cefd54c75c37b540sberlin * http://www.apache.org/licenses/LICENSE-2.0
94e11457f34addf5d10fe0c31cefd54c75c37b540sberlin *
104e11457f34addf5d10fe0c31cefd54c75c37b540sberlin * Unless required by applicable law or agreed to in writing, software
114e11457f34addf5d10fe0c31cefd54c75c37b540sberlin * distributed under the License is distributed on an "AS IS" BASIS,
124e11457f34addf5d10fe0c31cefd54c75c37b540sberlin * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
134e11457f34addf5d10fe0c31cefd54c75c37b540sberlin * See the License for the specific language governing permissions and
144e11457f34addf5d10fe0c31cefd54c75c37b540sberlin * limitations under the License.
154e11457f34addf5d10fe0c31cefd54c75c37b540sberlin */
164e11457f34addf5d10fe0c31cefd54c75c37b540sberlin
174e11457f34addf5d10fe0c31cefd54c75c37b540sberlinpackage com.google.inject.servlet;
184e11457f34addf5d10fe0c31cefd54c75c37b540sberlin
194e11457f34addf5d10fe0c31cefd54c75c37b540sberlinimport java.util.Map;
204e11457f34addf5d10fe0c31cefd54c75c37b540sberlin
214e11457f34addf5d10fe0c31cefd54c75c37b540sberlin/**
224e11457f34addf5d10fe0c31cefd54c75c37b540sberlin * A binding created by {@link ServletModule}.
234e11457f34addf5d10fe0c31cefd54c75c37b540sberlin *
244e11457f34addf5d10fe0c31cefd54c75c37b540sberlin * @author sameb@google.com (Sam Berlin)
254e11457f34addf5d10fe0c31cefd54c75c37b540sberlin * @since 3.0
264e11457f34addf5d10fe0c31cefd54c75c37b540sberlin */
274e11457f34addf5d10fe0c31cefd54c75c37b540sberlinpublic interface ServletModuleBinding {
284e11457f34addf5d10fe0c31cefd54c75c37b540sberlin
294e11457f34addf5d10fe0c31cefd54c75c37b540sberlin  /** Returns the pattern type that this binding was created with. */
304e11457f34addf5d10fe0c31cefd54c75c37b540sberlin  UriPatternType getUriPatternType();
314e11457f34addf5d10fe0c31cefd54c75c37b540sberlin
324e11457f34addf5d10fe0c31cefd54c75c37b540sberlin  /** Returns the pattern used to match against the binding. */
334e11457f34addf5d10fe0c31cefd54c75c37b540sberlin  String getPattern();
344e11457f34addf5d10fe0c31cefd54c75c37b540sberlin
354e11457f34addf5d10fe0c31cefd54c75c37b540sberlin  /** Returns any context params supplied when creating the binding. */
364e11457f34addf5d10fe0c31cefd54c75c37b540sberlin  Map<String, String> getInitParams();
374e11457f34addf5d10fe0c31cefd54c75c37b540sberlin
384e11457f34addf5d10fe0c31cefd54c75c37b540sberlin  /** Returns true if the given URI will match this binding. */
394e11457f34addf5d10fe0c31cefd54c75c37b540sberlin  boolean matchesUri(String uri);
404e11457f34addf5d10fe0c31cefd54c75c37b540sberlin}
41