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

org.thymeleaf.spring6.context.SpringContextUtils Maven / Gradle / Ivy

/*
 * =============================================================================
 *
 *   Copyright (c) 2011-2018, 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.spring6.context;

import org.springframework.context.ApplicationContext;
import org.thymeleaf.context.IExpressionContext;
import org.thymeleaf.context.ITemplateContext;
import org.thymeleaf.spring6.expression.IThymeleafEvaluationContext;
import org.thymeleaf.spring6.expression.ThymeleafEvaluationContext;
import org.thymeleaf.spring6.naming.SpringContextVariableNames;

/**
 * 

* Utility class for easy access of information stored at the context in a Spring-enabled application * (such as the Spring ApplicationContext). *

* * @author Daniel Fernández * * @since 3.0.3 * */ public class SpringContextUtils { /** *

* This is the name of the model attribute that will hold the (asychronously resolved) * {@code WebSession} object in order to be used whenever needed, avoiding the need to block * for obtaining it from the {@code ServerWebExchange}. *

*

* Note resolving the {@code WebSession} from the reactive {@code Mono} stream does * mean the creation of a {@code WebSession} instance, but not the real creation of a persisted session * sent to the browser. *

*

* Value: {@code "thymeleafWebSession"} *

* * @see org.springframework.web.server.WebSession */ public static final String WEB_SESSION_ATTRIBUTE_NAME = "thymeleafWebSession"; /** *

* This is the name of the model attribute that will hold the (asychronously resolved) * {@code Principal} object in order to be used whenever needed, avoiding the need to block * for obtaining it from the {@code ServerWebExchange}. *

*

* Value: {@code "thymeleafWebExchangePrincipal"} *

* * @see org.springframework.web.server.ServerWebExchange * @see java.security.Principal * * @since 3.1.0 */ public static final String WEB_EXCHANGE_PRINCIPAL_ATTRIBUTE_NAME = "thymeleafWebExchangePrincipal"; /** *

* Get the {@link ApplicationContext} from the Thymeleaf template context. *

*

* Note that the application context might not be always accessible (and thus this method * can return {@code null}). Application Context will be accessible when the template is being executed * as a Spring View, or else when an object of class {@link ThymeleafEvaluationContext} has been * explicitly set into the {@link ITemplateContext} {@code context} with variable name * {@link ThymeleafEvaluationContext#THYMELEAF_EVALUATION_CONTEXT_CONTEXT_VARIABLE_NAME}. *

* * @param context the template context. * @return the application context, or {@code null} if it could not be accessed. */ public static ApplicationContext getApplicationContext(final ITemplateContext context) { if (context == null) { return null; } // The ThymeleafEvaluationContext is set into the model by ThymeleafView (or wrapped by the SPEL evaluator) final IThymeleafEvaluationContext evaluationContext = (IThymeleafEvaluationContext) context.getVariable(ThymeleafEvaluationContext.THYMELEAF_EVALUATION_CONTEXT_CONTEXT_VARIABLE_NAME); if (evaluationContext == null || !(evaluationContext instanceof ThymeleafEvaluationContext)) { return null; } // Only when the evaluation context is a ThymeleafEvaluationContext we can access the ApplicationContext. // The reason is it could also be a wrapper on another EvaluationContext implementation, created at the // SPELVariableExpressionEvaluator on-the-fly (where ApplicationContext is not available because there might // even not exist one), instead of at ThymeleafView (where we are sure we are executing a Spring View and // have an ApplicationContext available). return ((ThymeleafEvaluationContext)evaluationContext).getApplicationContext(); } /** *

* Get the {@link IThymeleafRequestContext} from the Thymeleaf context. *

*

* The returned object is a wrapper on the Spring request context that hides the fact of this request * context corresponding to a Spring WebMVC or Spring WebFlux application. *

*

* This will be done by looking for a context variable called * {@link SpringContextVariableNames#THYMELEAF_REQUEST_CONTEXT}. *

* * @param context the context * @return the thymeleaf request context */ public static IThymeleafRequestContext getRequestContext(final IExpressionContext context) { if (context == null) { return null; } return (IThymeleafRequestContext) context.getVariable(SpringContextVariableNames.THYMELEAF_REQUEST_CONTEXT); } private SpringContextUtils() { super(); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy