Class JettyWebSocketFrameHandlerFactory
- All Implemented Interfaces:
Container
,Destroyable
,Dumpable
,Dumpable.DumpableContainer
,LifeCycle
- Direct Known Subclasses:
JettyServerFrameHandlerFactory
JettyWebSocketFrameHandler
instances suitable for
use with jetty-native websocket API.
Will create a FrameHandler
suitable for use with classes/objects that:
- Is @
WebSocket
annotated - Extends
WebSocketAdapter
- Implements
WebSocketListener
- Implements
WebSocketConnectionListener
- Implements
WebSocketPartialListener
- Implements
WebSocketPingPongListener
- Implements
WebSocketFrameListener
-
Nested Class Summary
Nested classes/interfaces inherited from class org.eclipse.jetty.util.component.AbstractLifeCycle
AbstractLifeCycle.AbstractLifeCycleListener, AbstractLifeCycle.StopException
Nested classes/interfaces inherited from interface org.eclipse.jetty.util.component.Container
Container.InheritedListener, Container.Listener
Nested classes/interfaces inherited from interface org.eclipse.jetty.util.component.Dumpable
Dumpable.DumpableContainer
Nested classes/interfaces inherited from interface org.eclipse.jetty.util.component.LifeCycle
LifeCycle.Listener
-
Field Summary
-
Constructor Summary
ConstructorDescriptionJettyWebSocketFrameHandlerFactory
(WebSocketContainer container, WebSocketComponents components) -
Method Summary
Modifier and TypeMethodDescriptionstatic MessageSink
createMessageSink
(MethodHandle msgHandle, Class<? extends MessageSink> sinkClass, Executor executor, WebSocketSession session) createMetadata
(Class<?> endpointClass) void
dump
(Appendable out, String indent) Dump this object (and children) into an Appendable using the provided indent after any new lines.static MethodHandles.Lookup
getApplicationMethodHandleLookup
(Class<?> lookupClass) Gives aMethodHandles.Lookup
instance to be used to find public methods in application classes.getMetadata
(Class<?> endpointClass) static MethodHandles.Lookup
Gives aMethodHandles.Lookup
instance to be used to find methods in server classes.newJettyFrameHandler
(Object endpointInstance) Methods inherited from class org.eclipse.jetty.util.component.ContainerLifeCycle
addBean, addBean, addEventListener, addManaged, contains, destroy, doStart, doStop, dump, dump, dumpObjects, dumpStdErr, getBean, getBeans, getBeans, getContainedBeans, getContainedBeans, isAuto, isManaged, isUnmanaged, manage, removeBean, removeBeans, removeEventListener, setBeans, start, stop, unmanage, updateBean, updateBean, updateBeans, updateBeans
Methods inherited from class org.eclipse.jetty.util.component.AbstractLifeCycle
getEventListeners, getState, getState, isFailed, isRunning, isStarted, isStarting, isStopped, isStopping, setEventListeners, start, stop, toString
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
Methods inherited from interface org.eclipse.jetty.util.component.Container
getCachedBeans, getEventListeners
Methods inherited from interface org.eclipse.jetty.util.component.Dumpable.DumpableContainer
isDumpable
-
Constructor Details
-
JettyWebSocketFrameHandlerFactory
public JettyWebSocketFrameHandlerFactory(WebSocketContainer container, WebSocketComponents components)
-
-
Method Details
-
getWebSocketComponents
-
getMetadata
-
createMetadata
-
newJettyFrameHandler
-
createMessageSink
public static MessageSink createMessageSink(MethodHandle msgHandle, Class<? extends MessageSink> sinkClass, Executor executor, WebSocketSession session) -
getServerMethodHandleLookup
Gives a
MethodHandles.Lookup
instance to be used to find methods in server classes. For lookups on application classes usegetApplicationMethodHandleLookup(Class)
instead.This uses the caller sensitive
MethodHandles.lookup()
, this will allow MethodHandle access to server classes we need to use and will give access permissions to private methods as well.- Returns:
- a lookup object to be used to find methods on server classes.
-
getApplicationMethodHandleLookup
Gives a
MethodHandles.Lookup
instance to be used to find public methods in application classes. For lookups on server classes usegetServerMethodHandleLookup()
instead.This uses
MethodHandles.publicLookup()
as we only need access to public method of the lookupClass. To look up a method on the lookupClass, it must be public and the class must be accessible from this module, so if the lookupClass is in a JPMS module it must be exported so that the public methods of the lookupClass are accessible outside of the module.The
MethodHandles.Lookup.in(Class)
allows us to search specifically in the endpoint Class to avoid any potential linkage errors which could occur if the same class is present in multiple web apps. Unlike usingMethodHandles.publicLookup()
usingMethodHandles.lookup()
withMethodHandles.Lookup.in(Class)
will cause the lookup to lose its public access to the lookup class if they are in different modules.MethodHandles.privateLookupIn(Class, MethodHandles.Lookup)
is also unsuitable because it requires the caller module to read the target module, and the target module to open reflective access to the lookupClasses private methods. This is possible but requires extra configuration to provide private access which is not necessary for the purpose of accessing the public methods.- Parameters:
lookupClass
- the desired lookup class for the new lookup object.- Returns:
- a lookup object to be used to find methods on the lookupClass.
-
dump
Description copied from interface:Dumpable
Dump this object (and children) into an Appendable using the provided indent after any new lines. The indent should not be applied to the first object dumped.- Specified by:
dump
in interfaceDumpable
- Overrides:
dump
in classContainerLifeCycle
- Parameters:
out
- The appendable to dump toindent
- The indent to apply after any new lines.- Throws:
IOException
- if unable to write to Appendable
-