Class VelocityConfigurer

java.lang.Object
net.shibboleth.shared.spring.velocity.VelocityEngineFactory
net.shibboleth.shared.spring.velocity.VelocityConfigurer
All Implemented Interfaces:
VelocityConfig, Aware, InitializingBean, ResourceLoaderAware, ServletContextAware

JavaBean to configure Velocity for web usage, via the "configLocation" and/or "velocityProperties" and/or "resourceLoaderPath" bean properties. The simplest way to use this class is to specify just a "resourceLoaderPath"; you do not need any further configuration then.
 <bean id="velocityConfig" class="org.springframework.web.servlet.view.velocity.VelocityConfigurer">
   <property name="resourceLoaderPath"><value>/WEB-INF/velocity/</value></property>
 </bean>
This bean must be included in the application context of any application using Spring's VelocityView for web MVC. It exists purely to configure Velocity; it is not meant to be referenced by application components (just internally by VelocityView). This class implements VelocityConfig in order to be found by VelocityView without depending on the bean name of this configurer. Each DispatcherServlet may define its own VelocityConfigurer if desired, potentially with different template loader paths.

Note that you can also refer to a pre-configured VelocityEngine instance via the "velocityEngine" property, e.g. set up by VelocityEngineFactoryBean, This allows to share a VelocityEngine for web and email usage, for example.

This configurer registers the "spring.vm" Velocimacro library for web views (contained in this package and thus in spring.jar), which makes all of Spring's default Velocity macros available to the views. This allows for using the Spring-provided macros such as follows:

 #springBind("person.age")
 age is ${status.value}
Since:
6.0.0
  • Field Details

    • SPRING_MACRO_RESOURCE_LOADER_NAME

      @Nonnull @NotEmpty private static final String SPRING_MACRO_RESOURCE_LOADER_NAME
      Name of the resource loader for Spring's bind macros.
      See Also:
    • SPRING_MACRO_RESOURCE_LOADER_CLASS

      @Nonnull @NotEmpty private static final String SPRING_MACRO_RESOURCE_LOADER_CLASS
      Key for the class of Spring's bind macro resource loader.
      See Also:
    • SPRING_MACRO_LIBRARY

      @Nonnull @NotEmpty private static final String SPRING_MACRO_LIBRARY
      Name of Spring's default bind macro library.
      See Also:
    • servletContext

      @Nullable private ServletContext servletContext
      Servlet context.
    • velocityEngine

      @Nullable private org.apache.velocity.app.VelocityEngine velocityEngine
      Velocity engine.
  • Constructor Details

    • VelocityConfigurer

      public VelocityConfigurer()
  • Method Details

    • setServletContext

      public void setServletContext(@Nonnull ServletContext context)
      Specified by:
      setServletContext in interface ServletContextAware
    • afterPropertiesSet

      public void afterPropertiesSet() throws IOException, org.apache.velocity.exception.VelocityException
      Initialize VelocityEngineFactory's VelocityEngine if not overridden by a pre-configured VelocityEngine.
      Specified by:
      afterPropertiesSet in interface InitializingBean
      Throws:
      IOException
      org.apache.velocity.exception.VelocityException
      See Also:
    • postProcessVelocityEngine

      protected void postProcessVelocityEngine(@Nonnull org.apache.velocity.app.VelocityEngine engine)
      Provides a ClasspathResourceLoader in addition to any default or user-defined loader in order to load the spring Velocity macros from the class path.
      Overrides:
      postProcessVelocityEngine in class VelocityEngineFactory
      Parameters:
      engine - the current VelocityEngine
      See Also:
      • ClasspathResourceLoader
    • getVelocityEngine

      @Nonnull public org.apache.velocity.app.VelocityEngine getVelocityEngine()
      Return the VelocityEngine for the current web application context.

      May be unique to one servlet, or shared in the root context.

      Specified by:
      getVelocityEngine in interface VelocityConfig
      Returns:
      the VelocityEngine