All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.thymeleaf.templateresolver.TemplateResolution Maven / Gradle / Ivy

/*
 * =============================================================================
 * 
 *   Copyright (c) 2011-2012, The THYMELEAF team (http://www.thymeleaf.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.thymeleaf.templateresolver;

import org.thymeleaf.resourceresolver.IResourceResolver;
import org.thymeleaf.util.Validate;

/**
 * 

* Result of the execution of a Template Resolver. *

*

* A TemplateResolution object is created by implementations of {@link ITemplateResolver} * when templates are resolved, and it contains: *

*
    *
  • The resource name corresponding to the resolved template: this will be the name * that will be passed to the included Resource Resolver in order to read the template.
  • *
  • The Resource Resolver (implementation of {@link org.thymeleaf.resourceresolver.IResourceResolver}) * to be used for trying to read this template.
  • *
  • The Template Mode to be applied to this template.
  • *
  • The character encoding to be used when reading this template.
  • *
  • The validity of this template resolution, indicating whether this template can be included * in cache once resolved, and the logic that will determine for how long and in which * circumstances its cache entry will still be considered valid.
  • *
*

* The fact that a Template Resolver returns a {@link TemplateResolution} does not necessarily * mean that the template will be effectively be resolved by the Template Resolver. For this, * the Resource Resolver will also need to be able to resolve the declared template's resource. *

* * @author Daniel Fernández * * @since 1.0 * */ public final class TemplateResolution { private final String templateName; private final String resourceName; private final IResourceResolver resourceResolver; private final String characterEncoding; private final String templateMode; private final ITemplateResolutionValidity validity; public TemplateResolution( final String templateName, final String resourceName, final IResourceResolver resourceResolver, final String characterEncoding, final String templateMode, final ITemplateResolutionValidity validity) { super(); Validate.notNull(templateName, "Template name cannot be null"); Validate.notNull(resourceName, "Resource name cannot be null"); Validate.notNull(resourceResolver, "Resource resolver cannot be null"); Validate.notNull(templateMode, "Template mode cannot be null"); Validate.notNull(validity, "Validity cannot be null"); this.templateName = templateName; this.resourceName = resourceName; this.resourceResolver = resourceResolver; this.characterEncoding = characterEncoding; this.templateMode = templateMode; this.validity = validity; } /** *

* Returns the template name. *

*

* This should be the same name used for calling the * {@link org.thymeleaf.TemplateEngine#process(String, org.thymeleaf.context.IContext)} * method. *

* * @return the template name. */ public String getTemplateName() { return this.templateName; } /** *

* Returns the resource name. *

*

* The resource name is the identifier that will be used for actually reading * the template by means of the Resource Resolver (see {@link #getResourceResolver()}). *

*

* This resource name will typically be computed by the Template Resolver from the template * name. For example, a Template Resolver could have a prefix and a suffix configured * so that starting from the template name "home" it returns the resource name * "/WEB-INF/templates/web/home.html", which can be then read by a * {@link org.thymeleaf.resourceresolver.ClassLoaderResourceResolver} instance. *

* * @return the resource name. */ public String getResourceName() { return this.resourceName; } /** *

* Returns the resource resolver that should be used for actually reading the template * (using the provided resource name, see {@link #getResourceName()}). *

* * @return the resource resolver. */ public IResourceResolver getResourceResolver() { return this.resourceResolver; } /** *

* Returns the character encoding that should be used for reading the template * (using the Resource Resolver). *

* * @return the character encoding. */ public String getCharacterEncoding() { return this.characterEncoding; } /** *

* Returns the template mode to be applied. This template mode should be * resolvable to a configured Template Mode Handler * ({@link org.thymeleaf.templatemode.ITemplateModeHandler}). *

* * @return the template mode. */ public String getTemplateMode() { return this.templateMode; } /** *

* Returns the template resolution validity. *

*

* This validity establishes whether the template can be included in the * template cache, and also for how long its resolution will be considered valid. *

*

* When a cached template is not considered valid, its cache entry is discarded * and it is resolved again. *

* * @return the validity object */ public ITemplateResolutionValidity getValidity() { return this.validity; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy