Class UIWebsocket
- All Implemented Interfaces:
- ClientBehaviorHolder,- PartialStateHolder,- StateHolder,- TransientStateHolder,- ComponentSystemEventListener,- FacesListener,- SystemEventListenerHolder,- EventListener
 The <f:websocket> tag opens an one-way (server to client) websocket based push connection in
 client side which can be reached from server side via PushContext interface injected in any CDI/container
 managed artifact via @Push annotation.
 
 By default, the rendererType property must be set to "jakarta.faces.Websocket". This value
 can be changed by calling the setRendererType() method.
 
 For detailed usage instructions, see @Push javadoc.
 
- Since:
- 2.3
- See Also:
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final StringThe standard component family for this component.static final StringThe standard component type for this component.Fields inherited from class jakarta.faces.component.UIComponentATTRS_WITH_DECLARED_DEFAULT_VALUES, BEANINFO_KEY, bindings, COMPOSITE_COMPONENT_TYPE_KEY, COMPOSITE_FACET_NAME, CURRENT_COMPONENT, CURRENT_COMPOSITE_COMPONENT, FACETS_KEY, HONOR_CURRENT_COMPONENT_ATTRIBUTES_PARAM_NAME, VIEW_LOCATION_KEY
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionReturns the name of the websocket channel.Returns a non-null, empty, unmodifiableCollectionwhich returnstrueon anyCollection#contains()invocation, indicating that all client behavior event names are acceptable.ReturnsCOMPONENT_FAMILY.Returns the JavaScript event handler function that is invoked when the websocket is closed.Returns the JavaScript event handler function that is invoked when a push message is received from the server.Returns the JavaScript event handler function that is invoked when the websocket is opened.getScope()Returns the scope of the websocket channel.getUser()Returns the user identifier of the websocket channel.booleanReturns whether to (auto)connect the websocket or not.voidsetChannel(String channel) Sets the name of the websocket channel.voidsetConnected(boolean connected) Sets whether to (auto)connect the websocket or not.voidsetOnclose(String onclose) Sets the JavaScript event handler function that is invoked when the websocket is closed.voidsetOnmessage(String onmessage) Sets the JavaScript event handler function that is invoked when a push message is received from the server.voidSets the JavaScript event handler function that is invoked when the websocket is opened.voidSets the scope of the websocket channel.voidsetUser(Serializable user) Sets the user identifier of the websocket channel, so that user-targeted push messages can be sent.voidsetValueExpression(String name, ValueExpression binding) Set theValueExpressionused to calculate the value for the specified attribute or property name, if any.Methods inherited from class jakarta.faces.component.UIComponentBaseaddClientBehavior, addFacesListener, broadcast, clearInitialState, decode, encodeBegin, encodeChildren, encodeEnd, findComponent, getAttributes, getChildCount, getChildren, getClientBehaviors, getClientId, getDefaultEventName, getFacesContext, getFacesListeners, getFacet, getFacetCount, getFacets, getFacetsAndChildren, getId, getListenersForEventClass, getParent, getPassThroughAttributes, getRenderer, getRendererType, getRendersChildren, getValueBinding, invokeOnComponent, isRendered, isTransient, markInitialState, processDecodes, processRestoreState, processSaveState, processUpdates, processValidators, queueEvent, removeFacesListener, restoreAttachedState, restoreState, saveAttachedState, saveState, setId, setParent, setRendered, setRendererType, setTransient, setValueBinding, subscribeToEvent, unsubscribeFromEventMethods inherited from class jakarta.faces.component.UIComponentencodeAll, getClientId, getCompositeComponentParent, getContainerClientId, getCurrentComponent, getCurrentCompositeComponent, getNamingContainer, getPassThroughAttributes, getResourceBundleMap, getStateHelper, getStateHelper, getTransientStateHelper, getTransientStateHelper, getValueExpression, initialStateMarked, isCompositeComponent, isInView, isVisitable, popComponentFromEL, processEvent, pushComponentToEL, restoreTransientState, saveTransientState, setInView, visitTreeMethods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface jakarta.faces.component.behavior.ClientBehaviorHolderaddClientBehavior, getClientBehaviors, getDefaultEventName
- 
Field Details- 
COMPONENT_TYPEThe standard component type for this component. - See Also:
 
- 
COMPONENT_FAMILYThe standard component family for this component. - See Also:
 
 
- 
- 
Constructor Details- 
UIWebsocketpublic UIWebsocket()Create a new UIWebsocketinstance with default property values.- Throws:
- IllegalStateException- When Websocket endpoint is not enabled.
 
 
- 
- 
Method Details- 
getFamilyReturns COMPONENT_FAMILY.- Specified by:
- getFamilyin class- UIComponent
- Returns:
- the component family (not null).
 
- 
setValueExpressionSet the ValueExpressionused to calculate the value for the specified attribute or property name, if any. If aValueExpressionis set for thechannelorscopeproperty, regardless of the value, throw an illegal argument exception. If aValueExpressionis set for theuserproperty, and the non-null value is not an instance ofSerializable, throw an illegal argument exception.- Overrides:
- setValueExpressionin class- UIComponent
- Parameters:
- name- Name of the attribute or property for which to set a- ValueExpression
- binding- The- ValueExpressionto set, or- nullto remove any currently set- ValueExpression
- Throws:
- IllegalArgumentException- If- nameis one of- id,- parent,- channelor- scope, or it- nameis- userand the non-null value is not an instance of- Serializable.
- NullPointerException- If- nameis- null.
 
- 
getEventNamesReturns a non-null, empty, unmodifiable Collectionwhich returnstrueon anyCollection#contains()invocation, indicating that all client behavior event names are acceptable.- Specified by:
- getEventNamesin interface- ClientBehaviorHolder
- Overrides:
- getEventNamesin class- UIComponentBase
- Returns:
- the collection of event names.
 
- 
getChannelReturns the name of the websocket channel.- Returns:
- The name of the websocket channel.
 
- 
setChannelSets the name of the websocket channel. It may not be an Jakarta Expression Language expression and it may only contain alphanumeric characters, hyphens, underscores and periods. All open websockets on the same channel will receive the same push message from the server.- Parameters:
- channel- The name of the websocket channel.
- Throws:
- IllegalArgumentException- When the value does not represent a valid channel name.
 
- 
getScopeReturns the scope of the websocket channel.- Returns:
- The scope of the websocket channel.
 
- 
setScopeSets the scope of the websocket channel. It may not be an Jakarta Expression Language expression and allowed values areapplication,sessionandview, case insensitive. When the value isapplication, then all channels with the same name throughout the application will receive the same push message. When the value issession, then only the channels with the same name in the current user session will receive the same push message. When the value isview, then only the channel in the current view will receive the push message. The default scope isapplication. When theuserattribute is specified, then the default scope issession.- Parameters:
- scope- The scope of the websocket channel.
 
- 
getUserReturns the user identifier of the websocket channel.- Returns:
- The user identifier of the websocket channel.
 
- 
setUserSets the user identifier of the websocket channel, so that user-targeted push messages can be sent. All open websockets on the same channel and user will receive the same push message from the server. It must implementSerializableand preferably have low memory footprint. Suggestion: use#{request.remoteUser}or#{someLoggedInUser.id}.- Parameters:
- user- The user identifier of the websocket channel.
 
- 
getOnopenReturns the JavaScript event handler function that is invoked when the websocket is opened.- Returns:
- The JavaScript event handler function that is invoked when the websocket is opened.
 
- 
setOnopenSets the JavaScript event handler function that is invoked when the websocket is opened. The function will be invoked with one argument: the channel name.- Parameters:
- onopen- The JavaScript event handler function that is invoked when the websocket is opened.
 
- 
getOnmessageReturns the JavaScript event handler function that is invoked when a push message is received from the server.- Returns:
- The JavaScript event handler function that is invoked when a push message is received from the server.
 
- 
setOnmessageSets the JavaScript event handler function that is invoked when a push message is received from the server. The function will be invoked with three arguments: the push message, the channel name and the raw MessageEvent itself.- Parameters:
- onmessage- The JavaScript event handler function that is invoked when a push message is received from the server.
 
- 
getOncloseReturns the JavaScript event handler function that is invoked when the websocket is closed.- Returns:
- The JavaScript event handler function that is invoked when the websocket is closed.
 
- 
setOncloseSets the JavaScript event handler function that is invoked when the websocket is closed. The function will be invoked with three arguments: the close reason code, the channel name and the rawCloseEventitself. Note that this will also be invoked on errors and that you can inspect the close reason code if an error occurred and which one (i.e. when the code is not 1000). See also RFC 6455 section 7.4.1 andCloseReason.CloseCodesAPI for an elaborate list of all close codes.- Parameters:
- onclose- The JavaScript event handler function that is invoked when the websocket is closed.
 
- 
isConnectedpublic boolean isConnected()Returns whether to (auto)connect the websocket or not.- Returns:
- Whether to (auto)connect the websocket or not.
 
- 
setConnectedpublic void setConnected(boolean connected) Sets whether to (auto)connect the websocket or not. Defaults totrue. It's interpreted as a JavaScript instruction whether to open or close the websocket push connection. Note that this attribute is re-evaluated on every ajax request. You can also explicitly set it tofalseand then manually control in JavaScript byOmniFaces.Push.open("channelName")andOmniFaces.Push.close("channelName").- Parameters:
- connected- Whether to (auto)connect the websocket or not.
 
 
-