Class Application
- java.lang.Object
-
- jakarta.faces.application.Application
-
- Direct Known Subclasses:
ApplicationWrapper
public abstract class Application extends Object
Application represents a per-web-application singleton object where applications based on Jakarta Faces (or implementations wishing to provide extended functionality) can register application-wide singletons that provide functionality required by Jakarta Faces. Default implementations of each object are provided for cases where the application does not choose to customize the behavior.
The instance of
Applicationis created by calling thegetApplication()method ofApplicationFactory. Because this instance is shared, it must be implemented in a thread-safe manner.The application also acts as a factory for several types of Objects specified in the Faces Configuration file. Please see
createComponent(java.lang.String),createConverter(java.lang.String), andcreateValidator(java.lang.String).
-
-
Constructor Summary
Constructors Constructor Description Application()
-
Method Summary
All Methods Instance Methods Abstract Methods Concrete Methods Modifier and Type Method Description voidaddBehavior(String behaviorId, String behaviorClass)Register a new mapping of behavior id to the name of the correspondingBehaviorclass.abstract voidaddComponent(String componentType, String componentClass)Register a new mapping of component type to the name of the correspondingUIComponentclass.abstract voidaddConverter(Class<?> targetClass, String converterClass)Register a new converter class that is capable of performing conversions for the specified target class.abstract voidaddConverter(String converterId, String converterClass)Register a new mapping of converter id to the name of the correspondingConverterclass.voidaddDefaultValidatorId(String validatorId)Register a validator by its id that is applied to allUIInputcomponents in a view.voidaddELContextListener(ELContextListener listener)Provide a way for Faces applications to register anELContextListenerthat will be notified on creation ofELContextinstances.voidaddELResolver(ELResolver resolver)Cause an the argumentresolverto be added to the resolver chain as specified in section 5.3.2 "ELResolver" of the Jakarta Faces Specification Document.voidaddSearchKeywordResolver(SearchKeywordResolver resolver)Cause the argumentresolverto be added to the head of the resolver chain.abstract voidaddValidator(String validatorId, String validatorClass)Register a new mapping of validator id to the name of the correspondingValidatorclass.BehaviorcreateBehavior(String behaviorId)Instantiate and return a newBehaviorinstance of the class specified by a previous call toaddBehavior()for the specified behavior id.UIComponentcreateComponent(ValueExpression componentExpression, FacesContext context, String componentType)UIComponentcreateComponent(ValueExpression componentExpression, FacesContext context, String componentType, String rendererType)LikecreateComponent(ValueExpression, FacesContext, String)except theRendererfor the component to be returned must be inspected for the annotations mentioned increateComponent(ValueExpression, FacesContext, String)as specified in the documentation for that method.UIComponentcreateComponent(FacesContext context, Resource componentResource)UIComponentcreateComponent(FacesContext context, String componentType, String rendererType)LikecreateComponent(String)except theRendererfor the component to be returned must be inspected for the annotations mentioned increateComponent(ValueExpression, FacesContext, String)as specified in the documentation for that method.abstract UIComponentcreateComponent(String componentType)Instantiate and return a newUIComponentinstance of the class specified by a previous call toaddComponent()for the specified component type.abstract ConvertercreateConverter(Class<?> targetClass)Instantiate and return a newConverterinstance of the class that has registered itself as capable of performing conversions for objects of the specified type.abstract ConvertercreateConverter(String converterId)Instantiate and return a newConverterinstance of the class specified by a previous call toaddConverter()for the specified converter id.abstract ValidatorcreateValidator(String validatorId)Instantiate and return a newValidatorinstance of the class specified by a previous call toaddValidator()for the specified validator id.<T> TevaluateExpressionGet(FacesContext context, String expression, Class<? extends T> expectedType)Get a value by evaluating an expression.abstract ActionListenergetActionListener()Return the defaultActionListenerto be registered for allActionSourcecomponents in this application.Iterator<String>getBehaviorIds()Return anIteratorover the set of currently registered behavior ids for thisApplication.abstract Iterator<String>getComponentTypes()Return anIteratorover the set of currently defined component types for thisApplication.abstract Iterator<String>getConverterIds()Return anIteratorover the set of currently registered converter ids for thisApplication.abstract Iterator<Class<?>>getConverterTypes()Return anIteratorover the set ofClassinstances for whichConverterclasses have been explicitly registered.abstract LocalegetDefaultLocale()Return the defaultLocalefor this application.abstract StringgetDefaultRenderKitId()Return therenderKitIdto be used for rendering this application.Map<String,String>getDefaultValidatorInfo()Return an immutableMapover the set of currently registered default validator IDs and their class name for thisApplication.ELContextListener[]getELContextListeners()If no calls have been made toaddELContextListener(jakarta.el.ELContextListener), this method must return an empty array.ELResolvergetELResolver()Return the singletonELResolverinstance to be used for all Jakarta Expression Language resolution.ExpressionFactorygetExpressionFactory()Return theExpressionFactoryinstance for this application.FlowHandlergetFlowHandler()Return the thread-safe singletonFlowHandlerfor this application.abstract StringgetMessageBundle()Return the fully qualified class name of theResourceBundleto be used for Jakarta Faces messages for this application.abstract NavigationHandlergetNavigationHandler()Return theNavigationHandlerinstance that will be passed the outcome returned by any invoked application action for this web application.ProjectStagegetProjectStage()Return the project stage for the currently running application instance.ResourceBundlegetResourceBundle(FacesContext ctx, String name)Find aResourceBundleas defined in the application configuration resources under the specified name.ResourceHandlergetResourceHandler()Return the singleton, stateless, thread-safeResourceHandlerfor this application.SearchExpressionHandlergetSearchExpressionHandler()Return the thread-safe singletonSearchExpressionHandlerfor this application.SearchKeywordResolvergetSearchKeywordResolver()Return the singletonSearchKeywordResolverinstance to be used for all search keyword resolution.abstract StateManagergetStateManager()Return theStateManagerinstance that will be utilized during the Restore View and Render Response phases of the request processing lifecycle.abstract Iterator<Locale>getSupportedLocales()Return anIteratorover the supportedLocales for this appication.abstract Iterator<String>getValidatorIds()Return anIteratorover the set of currently registered validator ids for thisApplication.abstract ViewHandlergetViewHandler()Return theViewHandlerinstance that will be utilized during the Restore View and Render Response phases of the request processing lifecycle.voidpublishEvent(FacesContext context, Class<? extends SystemEvent> systemEventClass, Class<?> sourceBaseType, Object source)This method functions exactly likepublishEvent(FacesContext,Class,Object), except the run-time must use the argumentsourceBaseTypeto find the matching listener instead of using theClassof thesourceargument.voidpublishEvent(FacesContext context, Class<? extends SystemEvent> systemEventClass, Object source)IfFacesContext.isProcessingEvents()istrueand there are one or more listeners for events of the type represented bysystemEventClass, call those listeners, passingsourceas the source of the event.voidremoveELContextListener(ELContextListener listener)Remove the argumentlistenerfrom the list ofELContextListeners.abstract voidsetActionListener(ActionListener listener)Set the defaultActionListenerto be registered for allActionSourcecomponents.abstract voidsetDefaultLocale(Locale locale)Set the defaultLocalefor this application.abstract voidsetDefaultRenderKitId(String renderKitId)Set therenderKitIdto be used to render this application.voidsetFlowHandler(FlowHandler newHandler)Set theFlowHandlerinstance used by theNavigationHandlerto satisfy the requirements of the faces flows feature.abstract voidsetMessageBundle(String bundle)Set the fully qualified class name of theResourceBundleto be used for Jakarta Faces messages for this application.abstract voidsetNavigationHandler(NavigationHandler handler)Set theNavigationHandlerinstance that will be passed the outcome returned by any invoked application action for this web application.voidsetResourceHandler(ResourceHandler resourceHandler)Set theResourceHandlerinstance that will be utilized for rendering the markup for resources, and for satisfying client requests to serve up resources.voidsetSearchExpressionHandler(SearchExpressionHandler searchExpressionHandler)Set theSearchExpressionHandlerinstance used by the application.abstract voidsetStateManager(StateManager manager)Set theStateManagerinstance that will be utilized during the Restore View and Render Response phases of the request processing lifecycle.abstract voidsetSupportedLocales(Collection<Locale> locales)Set theLocaleinstances representing the supportedLocales for this application.abstract voidsetViewHandler(ViewHandler handler)Set theViewHandlerinstance that will be utilized during the Restore View and Render Response phases of the request processing lifecycle.voidsubscribeToEvent(Class<? extends SystemEvent> systemEventClass, SystemEventListener listener)Install the listener instance referenced by argumentlistenerinto application as a listener for events of typesystemEventClass.voidsubscribeToEvent(Class<? extends SystemEvent> systemEventClass, Class<?> sourceClass, SystemEventListener listener)Install the listener instance referenced by argumentlistenerinto the application as a listener for events of typesystemEventClassthat originate from objects of typesourceClass.voidunsubscribeFromEvent(Class<? extends SystemEvent> systemEventClass, SystemEventListener listener)Remove the listener instance referenced by argumentlistenerfrom the application as a listener for events of typesystemEventClass.voidunsubscribeFromEvent(Class<? extends SystemEvent> systemEventClass, Class<?> sourceClass, SystemEventListener listener)Remove the listener instance referenced by argumentlistenerfrom the application as a listener for events of typesystemEventClassthat originate from objects of typesourceClass.
-
-
-
Method Detail
-
getActionListener
public abstract ActionListener getActionListener()
Return the default
ActionListenerto be registered for allActionSourcecomponents in this application. If not explicitly set, a default implementation must be provided that performs the functions as specified in the section 7.1.1 "ActionListener Property" in the chapter 7 "Application Integration" of the Jakarta Faces Specification Document.Note that the specification for the default
ActionListenercontiues to call for the use of a deprecated property (action) and class (MethodBinding). Unfortunately, this is necessary because the defaultActionListenermust continue to work with components that do not implementActionSource2, and only implementActionSource.- Returns:
- the action listener.
-
setActionListener
public abstract void setActionListener(ActionListener listener)
Set the default
ActionListenerto be registered for allActionSourcecomponents.- Parameters:
listener- The new defaultActionListener- Throws:
NullPointerException- iflistenerisnull
-
getDefaultLocale
public abstract Locale getDefaultLocale()
Return the default
Localefor this application. If not explicitly set,nullis returned.- Returns:
- the default Locale, or
null.
-
setDefaultLocale
public abstract void setDefaultLocale(Locale locale)
Set the default
Localefor this application.- Parameters:
locale- The new defaultLocale- Throws:
NullPointerException- iflocaleisnull
-
getDefaultRenderKitId
public abstract String getDefaultRenderKitId()
Return the
renderKitIdto be used for rendering this application. If not explicitly set,nullis returned.- Returns:
- the default render kit id, or
null.
-
setDefaultRenderKitId
public abstract void setDefaultRenderKitId(String renderKitId)
Set the
renderKitIdto be used to render this application. Unless the client has provided a customViewHandlerthat supports the use of multipleRenderKitinstances in the same application, this method must only be called at application startup, before any Faces requests have been processed. This is a limitation of the current Specification, and may be lifted in a future release.- Parameters:
renderKitId- the render kit id to set.
-
getMessageBundle
public abstract String getMessageBundle()
Return the fully qualified class name of the
ResourceBundleto be used for Jakarta Faces messages for this application. If not explicitly set,nullis returned.- Returns:
- the message bundle class name, or
null.
-
setMessageBundle
public abstract void setMessageBundle(String bundle)
Set the fully qualified class name of the
ResourceBundleto be used for Jakarta Faces messages for this application. See the JavaDocs for thejava.util.ResourceBundleclass for more information about the syntax for resource bundle names.- Parameters:
bundle- Base name of the resource bundle to be used- Throws:
NullPointerException- ifbundleisnull
-
getNavigationHandler
public abstract NavigationHandler getNavigationHandler()
Return the
NavigationHandlerinstance that will be passed the outcome returned by any invoked application action for this web application. If not explicitly set, a default implementation must be provided that performs the functions described in theNavigationHandlerclass description.- The
NavigationHandlerimplementation is declared in the application configuration resources by giving the fully qualified class name as the value of the<navigation-handler>element within the<application>element.
The runtime must employ the decorator pattern as for every other pluggable artifact in Jakarta Faces.
- Returns:
- the navigation handler.
- The
-
setNavigationHandler
public abstract void setNavigationHandler(NavigationHandler handler)
Set the
NavigationHandlerinstance that will be passed the outcome returned by any invoked application action for this web application.- Parameters:
handler- The newNavigationHandlerinstance- Throws:
NullPointerException- ifhandlerisnull
-
getResourceHandler
public ResourceHandler getResourceHandler()
Return the singleton, stateless, thread-safe
ResourceHandlerfor this application. The Jakarta Faces implementation must support the following techniques for declaring an alternate implementation ofResourceHandler.-
The
ResourceHandlerimplementation is declared in the application configuration resources by giving the fully qualified class name as the value of the<resource-handler>element within the<application>element.
In all of the above cases, the runtime must employ the decorator pattern as for every other pluggable artifact in Jakarta Faces.
A default implementation is provided that throws
.UnsupportedOperationExceptionso that users that decorateApplicationcan continue to function- Returns:
- the resource handler.
- Since:
- 2.0
-
-
setResourceHandler
public void setResourceHandler(ResourceHandler resourceHandler)
Set the
ResourceHandlerinstance that will be utilized for rendering the markup for resources, and for satisfying client requests to serve up resources.- Parameters:
resourceHandler- The newResourceHandlerinstance- Throws:
IllegalStateException- if this method is called after at least one request has been processed by theLifecycleinstance for this application.NullPointerException- ifresourceHandlerisnull- Since:
- 2.0
-
getResourceBundle
public ResourceBundle getResourceBundle(FacesContext ctx, String name)
Find a
ResourceBundleas defined in the application configuration resources under the specified name. If aResourceBundlewas defined for the name, return an instance that uses the locale of the currentUIViewRoot.The default implementation throws
UnsupportedOperationExceptionand is provided for the sole purpose of not breaking existing applications that extend this class.- Parameters:
ctx- the Faces context.name- the name of the resource bundle.- Returns:
- the resource bundle.
- Throws:
FacesException- if a bundle was defined, but not resolvableNullPointerException- if ctx == null || name == null- Since:
- 1.2
-
getProjectStage
public ProjectStage getProjectStage()
Return the project stage for the currently running application instance. The default value is
ProjectStage.ProductionThe implementation of this method must perform the following algorithm or an equivalent with the same end result to determine the value to return.
If the value has already been determined by a previous call to this method, simply return that value.
Look for a
JNDIenvironment entry under the key given by the value ofProjectStage.PROJECT_STAGE_JNDI_NAME(return type ofjava.lang.String). If found, continue with the algorithm below, otherwise, look for an entry in theinitParamMapof theExternalContextfrom the currentFacesContextwith the key given by the value ofProjectStage.PROJECT_STAGE_PARAM_NAMEIf a value is found, see if an enum constant can be obtained by calling
ProjectStage.valueOf(), passing the value from theinitParamMap. If this succeeds without exception, save the value and return it.If not found, or any of the previous attempts to discover the enum constant value have failed, log a descriptive error message, assign the value as
ProjectStage.Productionand return it.A default implementation is provided that throws
.UnsupportedOperationExceptionso that users that decorateApplicationcan continue to function- Returns:
- the project stage.
- Since:
- 2.0
-
addELResolver
public void addELResolver(ELResolver resolver)
Cause an the argument
resolverto be added to the resolver chain as specified in section 5.3.2 "ELResolver" of the Jakarta Faces Specification Document.It is not possible to remove an
ELResolverregistered with this method, once it has been registered.It is illegal to register an
ELResolverafter the application has received any requests from the client. If an attempt is made to register a listener after that time, anIllegalStateExceptionmust be thrown. This restriction is in place to allow the Jakarta Server Pages container to optimize for the common case where no additionalELResolvers are in the chain, aside from the standard ones. It is permissible to addELResolvers before or after initialization to aCompositeELResolverthat is already in the chain.The default implementation throws
UnsupportedOperationExceptionand is provided for the sole purpose of not breaking existing applications that extendApplication.- Parameters:
resolver- the Jakarta Expression Language resolver to add.- Throws:
IllegalStateException- if called after the first request to theFacesServlethas been serviced.- Since:
- 1.2
-
getELResolver
public ELResolver getELResolver()
Return the singleton
ELResolverinstance to be used for all Jakarta Expression Language resolution. This is actually an instance ofCompositeELResolverthat must contain the followingELResolverinstances in the following order:-
ELResolverinstances declared using the <el-resolver> element in the application configuration resources. -
An
implementationthat wraps the head of the legacyVariableResolverchain, as per section VariableResolver ChainWrapper in Chapter 5 in the spec document. -
An
implementationthat wraps the head of the legacyPropertyResolverchain, as per section PropertyResolver ChainWrapper in Chapter 5 in the spec document. -
Any
ELResolverinstances added by calls toaddELResolver(jakarta.el.ELResolver).
The default implementation throws
UnsupportedOperationExceptionand is provided for the sole purpose of not breaking existing applications that extendApplication.- Returns:
- the Jakarta Expression Language resolver.
- Since:
- 1.2
-
-
getFlowHandler
public FlowHandler getFlowHandler()
Return the thread-safe singleton
FlowHandlerfor this application. For implementations declaring compliance with version 2.2 of the specification, this method must never returnnull, even if the application has no flows. This is necessary to enable dynamic flow creation during the application's lifetime.All implementations that declare compliance with version 2.2 of the specification must implement this method. For the purpose of backward compatibility with environments that extend
Applicationbut do not override this method, an implementation is provided that returnsnull. Due to the decoratable nature ofApplication, code calling this method should always check for anullreturn.- Returns:
- the flow handler.
- Since:
- 2.2
-
setFlowHandler
public void setFlowHandler(FlowHandler newHandler)
Set the
FlowHandlerinstance used by theNavigationHandlerto satisfy the requirements of the faces flows feature.- Parameters:
newHandler- the flow handler to set.- Throws:
NullPointerException- if newHandler isnullIllegalStateException- if this method is called after at least one request has been processed by theLifecycleinstance for this application.- Since:
- 2.2
-
getViewHandler
public abstract ViewHandler getViewHandler()
Return the
ViewHandlerinstance that will be utilized during the Restore View and Render Response phases of the request processing lifecycle. If not explicitly set, a default implementation must be provided that performs the functions described in theViewHandlerdescription in the Jakarta Faces Specification.- Returns:
- the view handler.
-
setViewHandler
public abstract void setViewHandler(ViewHandler handler)
Set the
ViewHandlerinstance that will be utilized during the Restore View and Render Response phases of the request processing lifecycle.- Parameters:
handler- The newViewHandlerinstance- Throws:
IllegalStateException- if this method is called after at least one request has been processed by theLifecycleinstance for this application.NullPointerException- ifhandlerisnull
-
getStateManager
public abstract StateManager getStateManager()
Return the
StateManagerinstance that will be utilized during the Restore View and Render Response phases of the request processing lifecycle. If not explicitly set, a default implementation must be provided that performs the functions described in theStateManagerdescription in the Jakarta Faces Specification.- Returns:
- the state manager.
-
setStateManager
public abstract void setStateManager(StateManager manager)
Set the
StateManagerinstance that will be utilized during the Restore View and Render Response phases of the request processing lifecycle.- Parameters:
manager- The newStateManagerinstance- Throws:
IllegalStateException- if this method is called after at least one request has been processed by theLifecycleinstance for this application.NullPointerException- ifmanagerisnull
-
addBehavior
public void addBehavior(String behaviorId, String behaviorClass)
Register a new mapping of behavior id to the name of the corresponding
Behaviorclass. This allows subsequent calls tocreateBehavior()to serve as a factory forBehaviorinstances.- Parameters:
behaviorId- The behavior id to be registeredbehaviorClass- The fully qualified class name of the correspondingBehaviorimplementation- Throws:
NullPointerException- ifbehaviorIdorbehaviorClassisnull- Since:
- 2.0
-
createBehavior
public Behavior createBehavior(String behaviorId) throws FacesException
Instantiate and return a new
Behaviorinstance of the class specified by a previous call toaddBehavior()for the specified behavior id.- Parameters:
behaviorId- The behavior id for which to create and return a newBehaviorinstance- Returns:
- the behavior.
- Throws:
FacesException- if theBehaviorcannot be createdNullPointerException- ifbehaviorIdisnull
-
getBehaviorIds
public Iterator<String> getBehaviorIds()
Return an
Iteratorover the set of currently registered behavior ids for thisApplication.- Returns:
- an iterator with behavior ids.
-
addComponent
public abstract void addComponent(String componentType, String componentClass)
Register a new mapping of component type to the name of the corresponding
UIComponentclass. This allows subsequent calls tocreateComponent()to serve as a factory forUIComponentinstances.- Parameters:
componentType- The component type to be registeredcomponentClass- The fully qualified class name of the correspondingUIComponentimplementation- Throws:
NullPointerException- ifcomponentTypeorcomponentClassisnull
-
createComponent
public abstract UIComponent createComponent(String componentType) throws FacesException
Instantiate and return a new
UIComponentinstance of the class specified by a previous call toaddComponent()for the specified component type.Before the component instance is returned, it must be inspected for the presence of a
ListenerFor(orListenersFor) orResourceDependency(orResourceDependencies) annotation. If any of these annotations are present, the action listed inListenerFororResourceDependencymust be taken on the component, before it is returned from this method. This variant ofcreateComponentmust not inspect theRendererfor the component to be returned for any of the afore mentioned annotations. Such inspection is the province ofcreateComponent(ValueExpression, FacesContext, String, String)orcreateComponent(FacesContext, String, String).- Parameters:
componentType- The component type for which to create and return a newUIComponentinstance- Returns:
- the UI component.
- Throws:
FacesException- if aUIComponentof the specified type cannot be createdNullPointerException- ifcomponentTypeisnull
-
createComponent
public UIComponent createComponent(ValueExpression componentExpression, FacesContext context, String componentType) throws FacesException
Call the
getValue()method on the specifiedValueExpression. If it returns aUIComponentinstance, return it as the value of this method. If it does not, instantiate a newUIComponentinstance of the specified component type, pass the new component to thesetValue()method of the specifiedValueExpression, and return it.Before the component instance is returned, it must be inspected for the presence of a
ListenerFor(orListenersFor) orResourceDependency(orResourceDependencies) annotation. If any of these annotations are present, the action listed inListenerFororResourceDependencymust be taken on the component, before it is returned from this method. This variant ofcreateComponentmust not inspect theRendererfor the component to be returned for any of the afore mentioned annotations. Such inspection is the province ofcreateComponent(ValueExpression, FacesContext, String, String)orcreateComponent(FacesContext, String, String).A default implementation is provided that throws
UnsupportedOperationExceptionso that users that decorateApplicationcan continue to function.- Parameters:
componentExpression-ValueExpressionrepresenting a component value expression (typically specified by thecomponentattribute of a custom tag)context-FacesContextfor the current requestcomponentType- Component type to create if theValueExpressiondoes not return a component instance- Returns:
- the UI component.
- Throws:
FacesException- if aUIComponentcannot be createdNullPointerException- if any parameter isnull- Since:
- 1.2
-
createComponent
public UIComponent createComponent(ValueExpression componentExpression, FacesContext context, String componentType, String rendererType)
Like
createComponent(ValueExpression, FacesContext, String)except theRendererfor the component to be returned must be inspected for the annotations mentioned increateComponent(ValueExpression, FacesContext, String)as specified in the documentation for that method. TheRendererinstance to inspect must be obtained by callingFacesContext.getRenderKit()and callingRenderKit.getRenderer(java.lang.String, java.lang.String)on the result, passing the argumentcomponentTypeas the first argument and the result of callingUIComponent.getFamily()on the newly created component as the second argument. If no suchRenderercan be found, a message must be logged with a helpful error message. Otherwise,UIComponent.setRendererType(java.lang.String)must be called on the newly createdUIComponentinstance, passing the argumentrendererTypeas the argument.A default implementation is provided that throws
UnsupportedOperationExceptionso that users that decorateApplicationcan continue to function.- Parameters:
componentExpression-ValueExpressionrepresenting a component value expression (typically specified by thecomponentattribute of a custom tag)context-FacesContextfor the current requestcomponentType- Component type to create if theValueExpressiondoes not return a component instancerendererType- The renderer-type of theRendererthat will render this component. Anullvalue must be accepted for this parameter.- Returns:
- the UI component.
- Throws:
FacesException- if aUIComponentcannot be createdNullPointerException- if any of the parameterscomponentExpression,context, orcomponentTypearenull- Since:
- 2.0
-
createComponent
public UIComponent createComponent(FacesContext context, String componentType, String rendererType)
Like
createComponent(String)except theRendererfor the component to be returned must be inspected for the annotations mentioned increateComponent(ValueExpression, FacesContext, String)as specified in the documentation for that method. TheRendererinstance to inspect must be obtained by callingFacesContext.getRenderKit()and callingRenderKit.getRenderer(java.lang.String, java.lang.String)on the result, passing the argumentcomponentTypeas the first argument and the result of callingUIComponent.getFamily()on the newly created component as the second argument. If no suchRenderercan be found, a message must be logged with a helpful error message. Otherwise,UIComponent.setRendererType(java.lang.String)must be called on the newly createdUIComponentinstance, passing the argumentrendererTypeas the argument.A default implementation is provided that throws
.UnsupportedOperationExceptionso that users that decorateApplicationcan continue to function- Parameters:
context-FacesContextfor the current requestcomponentType- Component type to createrendererType- The renderer-type of theRendererthat will render this component. Anullvalue must be accepted for this parameter.- Returns:
- the UI component.
- Throws:
FacesException- if aUIComponentcannot be createdNullPointerException- if any of the parameterscontext, orcomponentTypearenull- Since:
- 2.0
-
createComponent
public UIComponent createComponent(FacesContext context, Resource componentResource)
Instantiate and return a new
UIComponentinstance from the argumentResource. An algorithm semantically equivalent to the following must be followed to instantiate theUIComponentto return.-
Obtain a reference to the
ViewDeclarationLanguagefor thisApplicationinstance by callingViewHandler.getViewDeclarationLanguage(jakarta.faces.context.FacesContext, java.lang.String), passing theviewIdfound by callingUIViewRoot.getViewId()on theUIViewRootin the argumentFacesContext. -
Obtain a reference to the composite component metadata for this composite component by calling
ViewDeclarationLanguage.getComponentMetadata(jakarta.faces.context.FacesContext, jakarta.faces.application.Resource), passing thefacesContextandcomponentResourcearguments to this method. This version of the Jakarta Faces Specification uses JavaBeans as the API to the component metadata. -
Determine if the component author declared a
componentTypefor this component instance by obtaining theBeanDescriptorfrom the component metadata and calling itsgetValue()method, passingUIComponent.COMPOSITE_COMPONENT_TYPE_KEYas the argument. If non-null, the result must be aValueExpressionwhose value is thecomponent-typeof theUIComponentto be created for thisResourcecomponent. Call through tocreateComponent(java.lang.String)to create the component. -
Otherwise, determine if a script based component for this
Resourcecan be found by callingViewDeclarationLanguage.getScriptComponentResource(jakarta.faces.context.FacesContext, jakarta.faces.application.Resource). If the result is non-null, and is a script written in a language satisfying the content typetext/javascript, create aUIComponentinstance from the script resource. -
Otherwise, let library-name be the return from calling
Resource.getLibraryName()on the argumentcomponentResourceand resource-name be the return from callingResource.getResourceName()on the argumentcomponentResource. Create a fully qualified Java class name by removing any file extension from resource-name and let fqcn belibrary-name + "." + resource-name. If a class with the name of fqcn cannot be found, take no action and continue to the next step. If any ofInstantiationException,IllegalAccessException, orClassCastExceptionare thrown, wrap the exception in aFacesExceptionand re-throw it. If any other exception is thrown, log the exception and continue to the next step. -
If none of the previous steps have yielded a
UIComponentinstance, callcreateComponent(java.lang.String)passing "jakarta.faces.NamingContainer" as the argument. -
Call
UIComponent.setRendererType(java.lang.String)on theUIComponentinstance, passing "jakarta.faces.Composite" as the argument. -
Store the argument
Resourcein the attributesMapof theUIComponentunder the key,Resource.COMPONENT_RESOURCE_KEY. -
Store composite component metadata in the attributes
Mapof theUIComponentunder the key,UIComponent.BEANINFO_KEY.
Before the component instance is returned, it must be inspected for the presence of a
ListenerForannotation. If this annotation is present, the action listed inListenerFormust be taken on the component, before it is returned from this method.A default implementation is provided that throws
UnsupportedOperationExceptionso that users that decorateApplicationcan continue to function.- Parameters:
context-FacesContextfor the current requestcomponentResource- AResourcethat points to a source file that provides an implementation of a component.- Returns:
- the UI component.
- Throws:
FacesException- if aUIComponentfrom theResourcecannot be createdNullPointerException- if any parameter isnullNullPointerException- if unable, for any reason, to obtain aViewDeclarationLanguageinstance as described above.- Since:
- 2.0
-
-
getComponentTypes
public abstract Iterator<String> getComponentTypes()
Return an
Iteratorover the set of currently defined component types for thisApplication.- Returns:
- an iterator with component types.
-
addConverter
public abstract void addConverter(String converterId, String converterClass)
Register a new mapping of converter id to the name of the corresponding
Converterclass. This allows subsequent calls tocreateConverter()to serve as a factory forConverterinstances.- Parameters:
converterId- The converter id to be registeredconverterClass- The fully qualified class name of the correspondingConverterimplementation- Throws:
NullPointerException- ifconverterIdorconverterClassisnull
-
addConverter
public abstract void addConverter(Class<?> targetClass, String converterClass)
Register a new converter class that is capable of performing conversions for the specified target class.
- Parameters:
targetClass- The class for which this converter is registeredconverterClass- The fully qualified class name of the correspondingConverterimplementation- Throws:
NullPointerException- iftargetClassorconverterClassisnull
-
createConverter
public abstract Converter createConverter(String converterId)
Instantiate and return a new
Converterinstance of the class specified by a previous call toaddConverter()for the specified converter id.If the
toLowerCase()of theStringrepresenation of the value of the "jakarta.faces.DATETIMECONVERTER_DEFAULT_TIMEZONE_IS_SYSTEM_TIMEZONE" application configuration parameter is "true" (without the quotes) and theConverterinstance to be returned is an instance ofDateTimeConverter,DateTimeConverter.setTimeZone(java.util.TimeZone)must be called, passing the return fromTimeZone.getDefault().The argument
convertermust be inspected for the presence of theResourceDependencyannotation. If theResourceDependencyannotation is present, the action described inResourceDependencymust be taken. If theResourceDependencyannotation is not present, the argumentconvertermust be inspected for the presence of theResourceDependenciesannotation. If theResourceDependenciesannotation is present, the action described inResourceDependenciesmust be taken.- Parameters:
converterId- The converter id for which to create and return a newConverterinstance- Returns:
- the converter.
- Throws:
FacesException- if theConvertercannot be createdNullPointerException- ifconverterIdisnull
-
createConverter
public abstract Converter createConverter(Class<?> targetClass)
Instantiate and return a new
Converterinstance of the class that has registered itself as capable of performing conversions for objects of the specified type. If no suchConverterclass can be identified, returnnull.To locate an appropriate
Converterclass, the following algorithm is performed, stopping as soon as an appropriateConverterclass is found:- Locate a
Converterregistered for the target class itself. - Locate a
Converterregistered for interfaces that are implemented by the target class (directly or indirectly). - Locate a
Converterregistered for the superclass (if any) of the target class, recursively working up the inheritance hierarchy.
If the
Converterhas a single argument constructor that accepts aClass, instantiate theConverterusing that constructor, passing the argumenttargetClassas the sole argument. Otherwise, simply use the zero-argument constructor.If the
toLowerCase()of theStringrepresenation of the value of the "jakarta.faces.DATETIMECONVERTER_DEFAULT_TIMEZONE_IS_SYSTEM_TIMEZONE" application configuration parameter is "true" (without the quotes) and theConverterinstance to be returned is an instance ofDateTimeConverter,DateTimeConverter.setTimeZone(java.util.TimeZone)must be called, passing the return fromTimeZone.getDefault().- Parameters:
targetClass- Target class for which to return aConverter- Returns:
- the converter.
- Throws:
FacesException- if theConvertercannot be createdNullPointerException- iftargetClassisnull
- Locate a
-
getConverterIds
public abstract Iterator<String> getConverterIds()
Return an
Iteratorover the set of currently registered converter ids for thisApplication.- Returns:
- an iterator with converter ids.
-
getConverterTypes
public abstract Iterator<Class<?>> getConverterTypes()
Return an
Iteratorover the set ofClassinstances for whichConverterclasses have been explicitly registered.- Returns:
- an iterator with converter types.
-
addDefaultValidatorId
public void addDefaultValidatorId(String validatorId)
Register a validator by its id that is applied to all
UIInputcomponents in a view. The validator to most often serve this role is theBeanValidator. The usage contract for this method assumes that the validator has been registered using the normal “by-id” registration mechanism.An implementation is provided that takes no action so that users that decorate the
Applicationcontinue to work.- Parameters:
validatorId- the validator id.- Since:
- 2.0
-
getDefaultValidatorInfo
public Map<String,String> getDefaultValidatorInfo()
Return an immutable
Mapover the set of currently registered default validator IDs and their class name for thisApplication.An implementation is provided that returns
Collections.emptyMapso that users that decorate theApplicationcontinue to work.- Returns:
- a map of default validator information.
- Since:
- 2.0
-
getExpressionFactory
public ExpressionFactory getExpressionFactory()
Return the
ExpressionFactoryinstance for this application. This instance is used by the convenience methodevaluateExpressionGet(jakarta.faces.context.FacesContext, java.lang.String, java.lang.Class<? extends T>).The implementation must return the
ExpressionFactoryfrom the Expression Language container by callingjakarta.el.ELManager.getExpressionFactory().An implementation is provided that throws
UnsupportedOperationExceptionso that users that decorate theApplicationcontinue to work.- Returns:
- the expression factory.
- Since:
- 1.2
-
evaluateExpressionGet
public <T> T evaluateExpressionGet(FacesContext context, String expression, Class<? extends T> expectedType) throws ELException
Get a value by evaluating an expression.
Call
getExpressionFactory()then callExpressionFactory.createValueExpression(jakarta.el.ELContext, java.lang.String, java.lang.Class<?>)passing the argumentexpressionandexpectedType. CallFacesContext.getELContext()and pass it toValueExpression.getValue(jakarta.el.ELContext), returning the result.An implementation is provided that throws
UnsupportedOperationExceptionso that users that decorate theApplicationcontinue to work.- Type Parameters:
T- the return type.- Parameters:
context- the Faces context.expression- the expression.expectedType- the expected type.- Returns:
- the result of the evaluation.
- Throws:
ELException
-
getSupportedLocales
public abstract Iterator<Locale> getSupportedLocales()
Return an
Iteratorover the supportedLocales for this appication.- Returns:
- an iterator of the supported locales.
-
setSupportedLocales
public abstract void setSupportedLocales(Collection<Locale> locales)
Set the
Localeinstances representing the supportedLocales for this application.- Parameters:
locales- The set of supportedLocales for this application- Throws:
NullPointerException- if the argumentnewLocalesisnull.
-
addELContextListener
public void addELContextListener(ELContextListener listener)
Provide a way for Faces applications to register an
ELContextListenerthat will be notified on creation ofELContextinstances. This listener will be called once per request.An implementation is provided that throws
UnsupportedOperationExceptionso that users that decorate theApplicationcontinue to work.- Parameters:
listener- the Jakarta Expression Language context listener to add.- Since:
- 1.2
-
removeELContextListener
public void removeELContextListener(ELContextListener listener)
Remove the argument
listenerfrom the list ofELContextListeners. Iflisteneris null, no exception is thrown and no action is performed. Iflisteneris not in the list, no exception is thrown and no action is performed.An implementation is provided that throws
UnsupportedOperationExceptionso that users that decorate theApplicationcontinue to work.- Parameters:
listener- the Jakarta Expression Language context listener to remove.- Since:
- 1.2
-
getELContextListeners
public ELContextListener[] getELContextListeners()
If no calls have been made to
addELContextListener(jakarta.el.ELContextListener), this method must return an empty array.Otherwise, return an array representing the list of listeners added by calls to
addELContextListener(jakarta.el.ELContextListener).An implementation is provided that throws
UnsupportedOperationExceptionso that users that decorate theApplicationcontinue to work.- Returns:
- an array of Jakarta Expression Language context listeners.
- Since:
- 1.2
-
addValidator
public abstract void addValidator(String validatorId, String validatorClass)
Register a new mapping of validator id to the name of the corresponding
Validatorclass. This allows subsequent calls tocreateValidator()to serve as a factory forValidatorinstances.- Parameters:
validatorId- The validator id to be registeredvalidatorClass- The fully qualified class name of the correspondingValidatorimplementation- Throws:
NullPointerException- ifvalidatorIdorvalidatorClassisnull
-
createValidator
public abstract Validator createValidator(String validatorId) throws FacesException
Instantiate and return a new
Validatorinstance of the class specified by a previous call toaddValidator()for the specified validator id.The argument
validatormust be inspected for the presence of theResourceDependencyannotation. If theResourceDependencyannotation is present, the action described inResourceDependencymust be taken. If theResourceDependencyannotation is not present, the argumentvalidatormust be inspected for the presence of theResourceDependenciesannotation. If theResourceDependenciesannotation is present, the action described inResourceDependenciesmust be taken.- Parameters:
validatorId- The validator id for which to create and return a newValidatorinstance- Returns:
- the validator.
- Throws:
FacesException- if aValidatorof the specified id cannot be createdNullPointerException- ifvalidatorIdisnull
-
getValidatorIds
public abstract Iterator<String> getValidatorIds()
Return an
Iteratorover the set of currently registered validator ids for thisApplication.- Returns:
- an iterator of validator ids.
-
publishEvent
public void publishEvent(FacesContext context, Class<? extends SystemEvent> systemEventClass, Object source)
If
FacesContext.isProcessingEvents()istrueand there are one or more listeners for events of the type represented bysystemEventClass, call those listeners, passingsourceas the source of the event. The implementation should be as fast as possible in determining whether or not a listener for the givensystemEventClassandsourcehas been installed, and should return immediately once such a determination has been made. The implementation ofpublishEventmust honor the requirements stated insubscribeToEvent(java.lang.Class<? extends jakarta.faces.event.SystemEvent>, java.lang.Class<?>, jakarta.faces.event.SystemEventListener)regarding the storage and retrieval of listener instances. Specifically, ifsubscribeToEvent(Class,Class,SystemEventListener)was called, thesourceClassargument must match exactly theClassof thesourceargument in the call topublishEvent(). The implementation must not do any inheritance hierarachy inspection when looking for a match between thesourceClasspassed tosubscribeToEvent(Class,Class,SystemEventListener)and thesourceClasspassed topublishEvent()in order to find any listeners to which the event should be published. In the case where theClassof thesourceargument does not match theClassof thesourceClassused when the listener was subscribed usingsubscribeToEvent(),publishEvent(FacesContext,Class,Class,Object)can be used to provide theClassused to perform the listener lookup and match.The default implementation must implement an algorithm semantically equivalent to the following to locate listener instances and to invoke them.
-
If the
sourceargument implementsSystemEventListenerHolder, callSystemEventListenerHolder.getListenersForEventClass(java.lang.Class<? extends jakarta.faces.event.SystemEvent>)on it, passing thesystemEventClassargument. If the list is not empty, perform algorithm traverseListenerList on the list. -
If any view level listeners have been installed by previous calls to
subscribeToEvent(Class, Class, jakarta.faces.event.SystemEventListener)on theUIViewRoot, perform algorithm traverseListenerList on the list of listeners for that event installed on theUIViewRoot. -
If any
Applicationlevel listeners have been installed by previous calls tosubscribeToEvent(Class, Class, jakarta.faces.event.SystemEventListener), perform algorithm traverseListenerList on the list. -
If any
Applicationlevel listeners have been installed by previous calls tosubscribeToEvent(Class, jakarta.faces.event.SystemEventListener), perform algorithm traverseListenerList on the list.
If the act of invoking the
processListenermethod causes anAbortProcessingExceptionto be thrown, processing of the listeners must be aborted, no further processing of the listeners for this event must take place, and the exception must be logged withLevel.SEVERE.Algorithm traverseListenerList: For each listener in the list,
-
Call
SystemEventListener.isListenerForSource(java.lang.Object), passing thesourceargument. If this returnsfalse, take no action on the listener. -
Otherwise, if the event to be passed to the listener instances has not yet been constructed, construct the event, passing
sourceas the argument to the one-argument constructor that takes anObject. This same event instance must be passed to all listener instances. -
Call
SystemEvent.isAppropriateListener(jakarta.faces.event.FacesListener), passing the listener instance as the argument. If this returnsfalse, take no action on the listener. -
Call
SystemEvent.processListener(jakarta.faces.event.FacesListener), passing the listener instance.
A default implementation is provided that throws
.UnsupportedOperationExceptionso that users that decorateApplicationcan continue to function- Parameters:
context- theFacesContextfor the current requestsystemEventClass- TheClassof event that is being published.source- The source for the event of typesystemEventClass.- Throws:
NullPointerException- if eithercontext,systemEventClassorsourceisnull- Since:
- 2.0
-
-
publishEvent
public void publishEvent(FacesContext context, Class<? extends SystemEvent> systemEventClass, Class<?> sourceBaseType, Object source)
This method functions exactly like
publishEvent(FacesContext,Class,Object), except the run-time must use the argumentsourceBaseTypeto find the matching listener instead of using theClassof thesourceargument.A default implementation is provided that throws
.UnsupportedOperationExceptionso that users that decorateApplicationcan continue to function- Parameters:
context- theFacesContextfor the current requestsystemEventClass- TheClassof event that is being published.sourceBaseType- TheClassof the source event that must be used to lookup the listener to which this event must be published. If this argument isnullthe return fromsource.getClass()must be used as thesourceBaseType.source- The source for the event of typesystemEventClass.- Throws:
NullPointerException- if any arguments except forsourceBaseTypearenull- Since:
- 2.0
-
subscribeToEvent
public void subscribeToEvent(Class<? extends SystemEvent> systemEventClass, Class<?> sourceClass, SystemEventListener listener)
Install the listener instance referenced by argument
listenerinto the application as a listener for events of typesystemEventClassthat originate from objects of typesourceClass.If argument
sourceClassis non-null,sourceClassandsystemEventClassmust be used to store the argumentlistenerin the application in such a way that thelistenercan be quickly looked up by the implementation ofpublishEvent(jakarta.faces.context.FacesContext, java.lang.Class<? extends jakarta.faces.event.SystemEvent>, java.lang.Object)givensystemEventClassand an instance of theClassreferenced bysourceClass. If argumentsourceClassisnull, thelistenermust be discoverable by the implementation ofpublishEvent(jakarta.faces.context.FacesContext, java.lang.Class<? extends jakarta.faces.event.SystemEvent>, java.lang.Object)given onlysystemEventClass.It is valid to call this method during the processing of an event which was subscribed to by a previous call to this method.
- Parameters:
systemEventClass- theClassof event for whichlistenermust be fired.sourceClass- theClassof the instance which causes events of typesystemEventClassto be fired. May benull.listener- the implementation ofSystemEventListenerwhoseSystemEventListener.processEvent(jakarta.faces.event.SystemEvent)method must be called when events of typesystemEventClassare fired.- Throws:
NullPointerException- if any combination ofsystemEventClass, orlistenerarenull.- Since:
- 2.0
-
subscribeToEvent
public void subscribeToEvent(Class<? extends SystemEvent> systemEventClass, SystemEventListener listener)
Install the listener instance referenced by argument
listenerinto application as a listener for events of typesystemEventClass. The default implementation simply calls through tosubscribeToEvent(Class, Class, jakarta.faces.event.SystemEventListener)passingnullas thesourceClassargumentA default implementation is provided that throws
.UnsupportedOperationExceptionso that users that decorateApplicationcan continue to function- Parameters:
systemEventClass- theClassof event for whichlistenermust be fired.listener- the implementation ofSystemEventListenerwhoseSystemEventListener.processEvent(jakarta.faces.event.SystemEvent)method must be called when events of typesystemEventClassare fired.See
subscribeToEvent(java.lang.Class,java.lang.Class,jakarta.faces.event.SystemEventListener)for an additional requirement regarding when it is valid to call this method.- Throws:
NullPointerException- if any combination ofsystemEventClass, orlistenerarenull.- Since:
- 2.0
-
unsubscribeFromEvent
public void unsubscribeFromEvent(Class<? extends SystemEvent> systemEventClass, Class<?> sourceClass, SystemEventListener listener)
Remove the listener instance referenced by argument
listenerfrom the application as a listener for events of typesystemEventClassthat originate from objects of typesourceClass. SeesubscribeToEvent(Class, Class, jakarta.faces.event.SystemEventListener)for the specification of how the listener is stored, and therefore, how it must be removed.See
subscribeToEvent(java.lang.Class,java.lang.Class,jakarta.faces.event.SystemEventListener)for an additional requirement regarding when it is valid to call this method.- Parameters:
systemEventClass- theClassof event for whichlistenermust be fired.sourceClass- theClassof the instance which causes events of typesystemEventClassto be fired. May benull.listener- the implementation ofSystemEventListenerto remove from the internal data structure.- Throws:
NullPointerException- if any combination ofcontext,systemEventClass, orlistenerarenull.- Since:
- 2.0
-
unsubscribeFromEvent
public void unsubscribeFromEvent(Class<? extends SystemEvent> systemEventClass, SystemEventListener listener)
Remove the listener instance referenced by argument
listenerfrom the application as a listener for events of typesystemEventClass. The default implementation simply calls through tounsubscribeFromEvent(Class, jakarta.faces.event.SystemEventListener)passingnullas thesourceClassargumentSee
subscribeToEvent(java.lang.Class,java.lang.Class,jakarta.faces.event.SystemEventListener)for an additional requirement regarding when it is valid to call this method.- Parameters:
systemEventClass- theClassof event for whichlistenermust be fired.listener- the implementation ofSystemEventListenerto remove from the internal data structure.- Throws:
NullPointerException- if any combination ofcontext,systemEventClass, orlistenerarenull.- Since:
- 2.0
-
getSearchExpressionHandler
public SearchExpressionHandler getSearchExpressionHandler()
Return the thread-safe singleton
SearchExpressionHandlerfor this application.- Returns:
- the
SearchExpressionHandler. - Since:
- 2.3
-
setSearchExpressionHandler
public void setSearchExpressionHandler(SearchExpressionHandler searchExpressionHandler)
Set the
SearchExpressionHandlerinstance used by the application.- Parameters:
searchExpressionHandler- theSearchExpressionHandler.- Throws:
NullPointerException- if searchExpressionHandler isnullIllegalStateException- if this method is called after at least one request has been processed by theLifecycleinstance for this application.- Since:
- 2.3
-
addSearchKeywordResolver
public void addSearchKeywordResolver(SearchKeywordResolver resolver)
Cause the argument
resolverto be added to the head of the resolver chain.It is not possible to remove a
SearchKeywordResolverregistered with this method, once it has been registered.The default implementation throws
UnsupportedOperationExceptionand is provided for the sole purpose of not breaking existing applications that extendApplication.- Parameters:
resolver- the SearchKeywordResolver to add.- Throws:
IllegalStateException- if called after the first request to theFacesServlethas been serviced.NullPointerException- when resolver is null.- Since:
- 2.3
-
getSearchKeywordResolver
public SearchKeywordResolver getSearchKeywordResolver()
Return the singleton
SearchKeywordResolverinstance to be used for all search keyword resolution. This is actually an instance of a composite SearchKeywordResolver that must contain the followingSearchKeywordResolverinstances in the following order:-
SearchKeywordResolverinstances declared using the <search-keyword-resolver> element in the application configuration resources. -
Any
SearchKeywordResolverinstances added by calls toaddSearchKeywordResolver(jakarta.faces.component.search.SearchKeywordResolver). -
The
SearchKeywordResolverimplementations for@all,@child(n),@form,@id(...),@namingcontainer,@next,@none,@parent,@previous,@rootand@this.
The default implementation throws
UnsupportedOperationExceptionand is provided for the sole purpose of not breaking existing applications that extendApplication.- Returns:
- the
SearchKeywordResolver. - Since:
- 2.3
-
-
-