Issue #1604 - WebSocketContainer stop is now smarter
This commit is contained in:
parent
ab98caafbb
commit
5b72d8a733
|
@ -149,8 +149,6 @@ public class ClientContainer extends ContainerLifeCycle implements WebSocketCont
|
||||||
this.endpointClientMetadataCache = new ConcurrentHashMap<>();
|
this.endpointClientMetadataCache = new ConcurrentHashMap<>();
|
||||||
this.decoderFactory = new DecoderFactory(this,PrimitiveDecoderMetadataSet.INSTANCE);
|
this.decoderFactory = new DecoderFactory(this,PrimitiveDecoderMetadataSet.INSTANCE);
|
||||||
this.encoderFactory = new EncoderFactory(this,PrimitiveEncoderMetadataSet.INSTANCE);
|
this.encoderFactory = new EncoderFactory(this,PrimitiveEncoderMetadataSet.INSTANCE);
|
||||||
|
|
||||||
ShutdownThread.register(this);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -23,6 +23,9 @@ import java.lang.reflect.Method;
|
||||||
import javax.websocket.ContainerProvider;
|
import javax.websocket.ContainerProvider;
|
||||||
import javax.websocket.WebSocketContainer;
|
import javax.websocket.WebSocketContainer;
|
||||||
|
|
||||||
|
import org.eclipse.jetty.util.component.ContainerLifeCycle;
|
||||||
|
import org.eclipse.jetty.util.thread.ShutdownThread;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Client {@link ContainerProvider} implementation.
|
* Client {@link ContainerProvider} implementation.
|
||||||
* <p>
|
* <p>
|
||||||
|
@ -59,6 +62,28 @@ public class JettyClientContainerProvider extends ContainerProvider
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Object getContextHandler()
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
// Equiv of: ContextHandler.Context context = ContextHandler.getCurrentContext()
|
||||||
|
Class<?> clazzContextHandler = Class.forName("org.eclipse.jetty.server.handler.ContextHandler");
|
||||||
|
Method methodGetContext = clazzContextHandler.getMethod("getCurrentContext");
|
||||||
|
Object objContext = methodGetContext.invoke(null);
|
||||||
|
if (objContext == null)
|
||||||
|
return null;
|
||||||
|
|
||||||
|
// Equiv of: ContextHandler handler = ContextHandler.getContextHandler(context);
|
||||||
|
Class<?> clazzContext = objContext.getClass();
|
||||||
|
Method methodGetContextHandler = clazzContextHandler.getMethod("getContextHandler", clazzContext);
|
||||||
|
return methodGetContextHandler.invoke(objContext);
|
||||||
|
}
|
||||||
|
catch (Throwable ignore)
|
||||||
|
{
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Used by {@link ContainerProvider#getWebSocketContainer()} to get a new instance
|
* Used by {@link ContainerProvider#getWebSocketContainer()} to get a new instance
|
||||||
* of the Client {@link WebSocketContainer}.
|
* of the Client {@link WebSocketContainer}.
|
||||||
|
@ -85,7 +110,19 @@ public class JettyClientContainerProvider extends ContainerProvider
|
||||||
if (INSTANCE == null)
|
if (INSTANCE == null)
|
||||||
{
|
{
|
||||||
INSTANCE = new ClientContainer();
|
INSTANCE = new ClientContainer();
|
||||||
|
|
||||||
|
Object contextHandler = getContextHandler();
|
||||||
|
if (contextHandler != null && contextHandler instanceof ContainerLifeCycle)
|
||||||
|
{
|
||||||
|
// Add as bean to contextHandler
|
||||||
|
// Allow startup to follow Jetty lifecycle
|
||||||
|
((ContainerLifeCycle) contextHandler).addBean(INSTANCE, true);
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// Static Initialization
|
||||||
|
// register JVM wide shutdown thread
|
||||||
|
ShutdownThread.register(INSTANCE);
|
||||||
|
|
||||||
if (!INSTANCE.isStarted())
|
if (!INSTANCE.isStarted())
|
||||||
{
|
{
|
||||||
|
@ -98,6 +135,8 @@ public class JettyClientContainerProvider extends ContainerProvider
|
||||||
throw new RuntimeException("Unable to start Client Container", e);
|
throw new RuntimeException("Unable to start Client Container", e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return INSTANCE;
|
return INSTANCE;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue