public class ScriptTemplateConfigurer extends java.lang.Object implements ScriptTemplateConfig
ScriptTemplateConfig for creating
 a ScriptEngine for use in a web application.
 
 // Add the following to an @Configuration class
 @Bean
 public ScriptTemplateConfigurer mustacheConfigurer() {
    ScriptTemplateConfigurer configurer = new ScriptTemplateConfigurer();
    configurer.setEngineName("nashorn");
    configurer.setScripts("mustache.js");
    configurer.setRenderObject("Mustache");
    configurer.setRenderFunction("render");
    return configurer;
 }
 
 NOTE: It is possible to use non thread-safe script engines with
 templating libraries not designed for concurrency, like Handlebars or React running on
 Nashorn, by setting the sharedEngine property to false.
ScriptTemplateView| Constructor and Description | 
|---|
| ScriptTemplateConfigurer() | 
| Modifier and Type | Method and Description | 
|---|---|
| java.nio.charset.Charset | getCharset()Return the charset used to read script and template files. | 
| java.lang.String | getContentType()Return the content type to use for the response. | 
| javax.script.ScriptEngine | getEngine()Return the  ScriptEngineto use by the views. | 
| java.lang.String | getEngineName()Return the engine name that will be used to instantiate the  ScriptEngine. | 
| java.lang.String | getRenderFunction()Return the render function name (mandatory). | 
| java.lang.String | getRenderObject()Return the object where the render function belongs (optional). | 
| java.lang.String | getResourceLoaderPath()Return the resource loader path(s) via a Spring resource location. | 
| java.lang.String[] | getScripts()Return the scripts to be loaded by the script engine (library or user provided). | 
| java.lang.Boolean | isSharedEngine()Return whether to use a shared engine for all threads or whether to create
 thread-local engine instances for each thread. | 
| void | setCharset(java.nio.charset.Charset charset)Set the charset used to read script and template files. | 
| void | setContentType(java.lang.String contentType)Set the content type to use for the response. | 
| void | setEngine(javax.script.ScriptEngine engine)Set the  ScriptEngineto use by the view. | 
| void | setEngineName(java.lang.String engineName)Set the engine name that will be used to instantiate the  ScriptEngine. | 
| void | setRenderFunction(java.lang.String renderFunction)Set the render function name (mandatory). | 
| void | setRenderObject(java.lang.String renderObject)Set the object where the render function belongs (optional). | 
| void | setResourceLoaderPath(java.lang.String resourceLoaderPath)Set the resource loader path(s) via a Spring resource location. | 
| void | setScripts(java.lang.String... scriptNames)Set the scripts to be loaded by the script engine (library or user provided). | 
| void | setSharedEngine(java.lang.Boolean sharedEngine)When set to  false, use thread-localScriptEngineinstances instead
 of one single shared instance. | 
public void setEngine(javax.script.ScriptEngine engine)
ScriptEngine to use by the view.
 The script engine must implement Invocable.
 You must define engine or engineName, not both.
 When the sharedEngine flag is set to false, you should not specify
 the script engine with this setter, but with the setEngineName(String)
 one (since it implies multiple lazy instantiations of the script engine).
setEngineName(String)public javax.script.ScriptEngine getEngine()
ScriptTemplateConfigScriptEngine to use by the views.getEngine in interface ScriptTemplateConfigpublic void setEngineName(java.lang.String engineName)
ScriptEngine.
 The script engine must implement Invocable.
 You must define engine or engineName, not both.setEngine(ScriptEngine)public java.lang.String getEngineName()
ScriptTemplateConfigScriptEngine.getEngineName in interface ScriptTemplateConfigpublic void setSharedEngine(java.lang.Boolean sharedEngine)
false, use thread-local ScriptEngine instances instead
 of one single shared instance. This flag should be set to false for those
 using non thread-safe script engines with templating libraries not designed for
 concurrency, like Handlebars or React running on Nashorn for example.
 In this case, Java 8u60 or greater is required due to
 this bug.
 When this flag is set to false, the script engine must be specified using
 setEngineName(String). Using setEngine(ScriptEngine) is not
 possible because multiple instances of the script engine need to be created lazily
 (one per thread).
public java.lang.Boolean isSharedEngine()
ScriptTemplateConfigisSharedEngine in interface ScriptTemplateConfigpublic void setScripts(java.lang.String... scriptNames)
resourceLoaderPath default value is "classpath:", you can load easily
 any script available on the classpath.
 For example, in order to use a JavaScript library available as a WebJars dependency
 and a custom "render.js" file, you should call
 configurer.setScripts("/META-INF/resources/webjars/library/version/library.js",
 "com/myproject/script/render.js");.
setResourceLoaderPath(java.lang.String), 
WebJarspublic java.lang.String[] getScripts()
ScriptTemplateConfiggetScripts in interface ScriptTemplateConfigpublic void setRenderObject(java.lang.String renderObject)
Mustache.render(), renderObject
 should be set to "Mustache" and renderFunction to "render".public java.lang.String getRenderObject()
ScriptTemplateConfiggetRenderObject in interface ScriptTemplateConfigpublic void setRenderFunction(java.lang.String renderFunction)
This function will be called with the following parameters:
String template: the template contentMap model: the view modelString url: the template url (since 4.2.2)public java.lang.String getRenderFunction()
ScriptTemplateConfiggetRenderFunction in interface ScriptTemplateConfigpublic void setContentType(java.lang.String contentType)
text/html by default).public java.lang.String getContentType()
getContentType in interface ScriptTemplateConfigpublic void setCharset(java.nio.charset.Charset charset)
UTF-8 by default).public java.nio.charset.Charset getCharset()
ScriptTemplateConfiggetCharset in interface ScriptTemplateConfigpublic void setResourceLoaderPath(java.lang.String resourceLoaderPath)
ResourceLoader.
 Relative paths are allowed when running in an ApplicationContext.
 Default is "classpath:".
public java.lang.String getResourceLoaderPath()
ScriptTemplateConfiggetResourceLoaderPath in interface ScriptTemplateConfig