| 
 | ||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||
java.lang.Objectorg.apache.turbine.services.BaseInitable
org.apache.turbine.services.BaseService
org.apache.turbine.services.TurbineBaseService
org.apache.turbine.services.template.TurbineTemplateService
public class TurbineTemplateService
This service provides a method for mapping templates to their appropriate Screens or Navigations. It also allows templates to define a layout/navigations/screen modularization within the template structure. It also performs caching if turned on in the properties file. This service is not bound to a specific templating engine but we will use the Velocity templating engine for the examples. It is available by using the VelocityService. This assumes the following properties in the Turbine configuration:
# Register the VelocityService for the "vm" extension. services.VelocityService.template.extension=vm # Default Java class for rendering a Page in this service # (must be found on the class path (org.apache.turbine.modules.page.VelocityPage)) services.VelocityService.default.page = VelocityPage # Default Java class for rendering a Screen in this service # (must be found on the class path (org.apache.turbine.modules.screen.VelocityScreen)) services.VelocityService.default.screen=VelocityScreen # Default Java class for rendering a Layout in this service # (must be found on the class path (org.apache.turbine.modules.layout.VelocityOnlyLayout)) services.VelocityService.default.layout = VelocityOnlyLayout # Default Java class for rendering a Navigation in this service # (must be found on the class path (org.apache.turbine.modules.navigation.VelocityNavigation)) services.VelocityService.default.navigation=VelocityNavigation # Default Template Name to be used as Layout. If nothing else is # found, return this as the default name for a layout services.VelocityService.default.layout.template = Default.vmIf you want to render a template, a search path is used to find a Java class which might provide information for the context of this template. If you request e.g. the template screen about,directions,Driving.vm then the following class names are searched (on the module search path): 1. about.directions.Driving <- direct matching the template to the class name 2. about.directions.Default <- matching the package, class name is Default 3. about.Default <- stepping up in the package hierarchy, looking for Default 4. Default <- Class called "Default" without package 5. VelocityScreen <- The class configured by the Service (VelocityService) to And if you have the following module packages configured: module.packages = org.apache.turbine.modules, com.mycorp.modules then the class loader will look for org.apache.turbine.modules.screens.about.directions.Driving com.mycorp.modules.screens.about.directions.Driving org.apache.turbine.modules.screens.about.directions.Default com.mycorp.modules.screens.about.directions.Default org.apache.turbine.modules.screens.about.Default com.mycorp.modules.screens.about.Default org.apache.turbine.modules.screens.Default com.mycorp.modules.screens.Default org.apache.turbine.modules.screens.VelocityScreen com.mycorp.modules.screens.VelocityScreen Most of the times, you don't have any backing Java class for a template screen, so the first match will be org.apache.turbine.modules.screens.VelocityScreen which then renders your screen. Please note, that your Screen Template (Driving.vm) must exist! If it does not exist, the Template Service will report an error. Once the screen is found, the template service will look for the Layout and Navigation templates of your Screen. Here, the template service looks for matching template names! Consider our example: about,directions,Driving.vm (Screen Name) Now the template service will look for the following Navigation and Layout templates: 1. about,directions,Driving.vm <- exact match 2. about,directions,Default.vm <- package match, Default name 3. about,Default.vm <- stepping up in the hierarchy 4. Default.vm <- The name configured as default.layout.template in the Velocity service. And now Hennings' two golden rules for using templates: Many examples and docs from older Turbine code show template pathes with a slashes. Repeat after me: "TEMPLATE NAMES NEVER CONTAIN SLASHES!" Many examples and docs from older Turbine code show templates that start with "/". This is not only a violation of the rule above but actively breaks things like loading templates from a jar with the velocity jar loader. Repeat after me: "TEMPLATE NAMES ARE NOT PATHES. THEY'RE NOT ABSOLUTE AND HAVE NO LEADING /". If you now wonder how a template name is mapped to a file name: This is scope of the templating engine. Velocity e.g. has this wonderful option to load templates from jar archives. There is no single file but you tell velocity "get about,directions,Driving.vm" and it returns the rendered template. This is not the job of the Templating Service but of the Template rendering services like VelocityService.
| Field Summary | |
|---|---|
| static int | LAYOUT_KEYRepresents Layout Objects | 
| static int | LAYOUT_TEMPLATE_KEYRepresents Layout Template Objects | 
| static java.lang.String | LAYOUT_TEMPLATE_NAMERepresents Layout Template Objects | 
| static int | NAVIGATION_KEYRepresents Navigation Objects | 
| static int | NAVIGATION_TEMPLATE_KEYRepresents Navigation Template Objects | 
| static java.lang.String | NAVIGATION_TEMPLATE_NAMERepresents Navigation Template Objects | 
| protected static java.lang.String | NO_FILE_EXTThe default file extension used as a registry key when a template's file extension cannot be determined. | 
| static int | PAGE_KEYRepresents Page Objects | 
| static int | SCREEN_KEYRepresents Screen Objects | 
| static int | SCREEN_TEMPLATE_KEYRepresents Screen Template Objects | 
| static java.lang.String | SCREEN_TEMPLATE_NAMERepresents Screen Template Objects | 
| static int | TEMPLATE_TYPESNumber of different Template Types that we know of | 
| Fields inherited from class org.apache.turbine.services.BaseService | 
|---|
| configuration, name, serviceBroker | 
| Fields inherited from class org.apache.turbine.services.BaseInitable | 
|---|
| initableBroker, isInitialized | 
| Fields inherited from interface org.apache.turbine.services.template.TemplateService | 
|---|
| DEFAULT_EXTENSION_KEY, DEFAULT_EXTENSION_VALUE, DEFAULT_NAME, DEFAULT_TEMPLATE_KEY, DEFAULT_TEMPLATE_VALUE, EXTENSION_SEPARATOR, SERVICE_NAME, TEMPLATE_PARTS_SEPARATOR | 
| Constructor Summary | |
|---|---|
| TurbineTemplateService()C'tor | |
| Method Summary | |
|---|---|
|  java.lang.String | getDefaultExtension()Get the default template name extension specified in the template service properties. | 
|  java.lang.String | getDefaultLayout()Get the default layout module name of the template engine service corresponding to the default template name extension. | 
|  java.lang.String | getDefaultLayoutName(RunData data)Find the default layout module name for the given request. | 
|  java.lang.String | getDefaultLayoutName(java.lang.String template)Get the default layout module name of the template engine service corresponding to the template name extension of the named template. | 
|  java.lang.String | getDefaultLayoutTemplate()Get the default layout template name of the template engine service corresponding to the default template name extension. | 
|  java.lang.String | getDefaultLayoutTemplateName(java.lang.String template)Get the default layout template name of the template engine service corresponding to the template name extension of the named template. | 
|  java.lang.String | getDefaultNavigation()Get the default navigation module name of the template engine service corresponding to the default template name extension. | 
|  java.lang.String | getDefaultNavigationName(java.lang.String template)Get the default navigation module name of the template engine service corresponding to the template name extension of the named template. | 
|  java.lang.String | getDefaultPage()Get the default page module name of the template engine service corresponding to the default template name extension. | 
|  java.lang.String | getDefaultPageName(RunData data)Find the default page module name for the given request. | 
|  java.lang.String | getDefaultPageName(java.lang.String template)Get the default page module name of the template engine service corresponding to the template name extension of the named template. | 
|  java.lang.String | getDefaultScreen()Get the default screen module name of the template engine service corresponding to the default template name extension. | 
|  java.lang.String | getDefaultScreenName(java.lang.String template)Get the default screen module name of the template engine service corresponding to the template name extension of the named template. | 
|  java.lang.String | getDefaultTemplate()Returns the Default Template Name with the Default Extension. | 
|  java.lang.String | getExtension(java.lang.String template)Return Extension for a supplied template | 
|  java.lang.String | getLayoutName(java.lang.String template)Locate and return the name of the layout module to be used with the named layout template. | 
|  java.lang.String | getLayoutTemplateName(java.lang.String template)Locate and return the name of the layout template corresponding to the given screen template name parameter. | 
|  java.lang.String | getNavigationName(java.lang.String template)Locate and return the name of the navigation module to be used with the named navigation template. | 
|  java.lang.String | getNavigationTemplateName(java.lang.String template)Locate and return the name of the navigation template corresponding to the given template name parameter. | 
|  java.lang.String | getScreenName(java.lang.String template)Locate and return the name of the screen module to be used with the named screen template. | 
|  java.lang.String | getScreenTemplateName(java.lang.String template)Locate and return the name of the screen template corresponding to the given template name parameter. | 
|  TemplateEngineService | getTemplateEngineService(java.lang.String template)The TemplateEngineServiceassociated with the specified template's file extension. | 
|  void | init()Called the first time the Service is used. | 
|  boolean | isCaching()Returns true if the Template Service has caching activated | 
|  void | registerTemplateEngineService(TemplateEngineService service)Registers the provided template engine for use by the TemplateService. | 
|  boolean | templateExists(java.lang.String template,
                             java.lang.String[] templatePaths)Deprecated. Use templateExists from the various Templating Engines | 
|  java.lang.String[] | translateTemplatePaths(java.lang.String[] templatePaths)Deprecated. Each template engine service should know how to translate a request onto a file. | 
| Methods inherited from class org.apache.turbine.services.TurbineBaseService | 
|---|
| init, init, init, shutdown | 
| Methods inherited from class org.apache.turbine.services.BaseService | 
|---|
| getConfiguration, getName, getProperties, getServiceBroker, setName, setServiceBroker | 
| Methods inherited from class org.apache.turbine.services.BaseInitable | 
|---|
| getInit, getInitableBroker, setInit, setInitableBroker | 
| Methods inherited from class java.lang.Object | 
|---|
| clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait | 
| Methods inherited from interface org.apache.turbine.services.Service | 
|---|
| getConfiguration, getName, getProperties, setName, setServiceBroker | 
| Methods inherited from interface org.apache.turbine.services.Initable | 
|---|
| getInit, init, setInitableBroker, shutdown | 
| Field Detail | 
|---|
public static final int PAGE_KEY
public static final int SCREEN_KEY
public static final int LAYOUT_KEY
public static final int NAVIGATION_KEY
public static final int LAYOUT_TEMPLATE_KEY
public static final java.lang.String LAYOUT_TEMPLATE_NAME
public static final int SCREEN_TEMPLATE_KEY
public static final java.lang.String SCREEN_TEMPLATE_NAME
public static final int NAVIGATION_TEMPLATE_KEY
public static final java.lang.String NAVIGATION_TEMPLATE_NAME
public static final int TEMPLATE_TYPES
protected static final java.lang.String NO_FILE_EXT
| Constructor Detail | 
|---|
public TurbineTemplateService()
| Method Detail | 
|---|
public void init()
          throws InitializationException
init in interface Initableinit in class TurbineBaseServiceInitializationException - Something went wrong when
                                     setting up the Template Service.public boolean isCaching()
isCaching in interface TemplateServicepublic java.lang.String getDefaultExtension()
getDefaultExtension in interface TemplateServicepublic java.lang.String getExtension(java.lang.String template)
getExtension in interface TemplateServicetemplate - The template name
public java.lang.String getDefaultTemplate()
getDefaultTemplate in interface TemplateServicepublic java.lang.String getDefaultPage()
getDefaultPage in interface TemplateServicepublic java.lang.String getDefaultScreen()
getDefaultScreen in interface TemplateServicepublic java.lang.String getDefaultLayout()
getDefaultLayout in interface TemplateServicepublic java.lang.String getDefaultNavigation()
getDefaultNavigation in interface TemplateServicepublic java.lang.String getDefaultLayoutTemplate()
getDefaultLayoutTemplate in interface TemplateServicepublic java.lang.String getDefaultPageName(java.lang.String template)
getDefaultPageName in interface TemplateServicetemplate - The template name.
public java.lang.String getDefaultScreenName(java.lang.String template)
getDefaultScreenName in interface TemplateServicetemplate - The template name.
public java.lang.String getDefaultLayoutName(java.lang.String template)
getDefaultLayoutName in interface TemplateServicetemplate - The template name.
public java.lang.String getDefaultNavigationName(java.lang.String template)
getDefaultNavigationName in interface TemplateServicetemplate - The template name.
public java.lang.String getDefaultLayoutTemplateName(java.lang.String template)
getDefaultLayoutTemplateName in interface TemplateServicetemplate - The template name.
public java.lang.String getDefaultPageName(RunData data)
getDefaultPageName in interface TemplateServicedata - The encapsulation of the request to retrieve the
             default page for.
public java.lang.String getDefaultLayoutName(RunData data)
getDefaultLayoutName in interface TemplateServicedata - The encapsulation of the request to retrieve the
             default layout for.
public java.lang.String getScreenName(java.lang.String template)
                               throws java.lang.Exception
getScreenName in interface TemplateServicetemplate - The screen template name.
Exception, - a generic exception.
java.lang.Exception
public java.lang.String getLayoutName(java.lang.String template)
                               throws java.lang.Exception
getLayoutName in interface TemplateServicetemplate - The layout template name.
Exception, - a generic exception.
java.lang.Exception
public java.lang.String getNavigationName(java.lang.String template)
                                   throws java.lang.Exception
getNavigationName in interface TemplateServicetemplate - The navigation template name.
Exception, - a generic exception.
java.lang.Exception
public java.lang.String getScreenTemplateName(java.lang.String template)
                                       throws java.lang.Exception
getScreenTemplateName in interface TemplateServicetemplate - The template name parameter.
Exception, - a generic exception.
java.lang.Exception
public java.lang.String getLayoutTemplateName(java.lang.String template)
                                       throws java.lang.Exception
getLayoutTemplateName in interface TemplateServicetemplate - The template name parameter.
Exception, - a generic exception.
java.lang.Exception
public java.lang.String getNavigationTemplateName(java.lang.String template)
                                           throws java.lang.Exception
getNavigationTemplateName in interface TemplateServicetemplate - The template name parameter.
Exception, - a generic exception.
java.lang.Exception@Deprecated public java.lang.String[] translateTemplatePaths(java.lang.String[] templatePaths)
translateTemplatePaths in interface TemplateServicetemplatePaths - An array of template paths.
@Deprecated
public boolean templateExists(java.lang.String template,
                                         java.lang.String[] templatePaths)
TemplateEngineService to
 check the existance of the specified template.
templateExists in interface TemplateServicetemplate - The template to check for the existance of.templatePaths - The paths to check for the template.public void registerTemplateEngineService(TemplateEngineService service)
TemplateService.
registerTemplateEngineService in interface TemplateServiceservice - The TemplateEngineService to register.public TemplateEngineService getTemplateEngineService(java.lang.String template)
TemplateEngineService
 associated with the specified template's file extension.
getTemplateEngineService in interface TemplateServicetemplate - The template name.
| 
 | ||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||