use of org.eclipse.jetty.websocket.jsr356.endpoints.EndpointInstance in project jetty.project by eclipse.
the class ClientContainer method newClientEndpointInstance.
public EndpointInstance newClientEndpointInstance(Object endpoint, ClientEndpointConfig config) {
EndpointMetadata metadata = getClientEndpointMetadata(endpoint.getClass(), config);
ClientEndpointConfig cec = config;
if (config == null) {
if (metadata instanceof AnnotatedClientEndpointMetadata) {
cec = ((AnnotatedClientEndpointMetadata) metadata).getConfig();
} else {
cec = new EmptyClientEndpointConfig();
}
}
return new EndpointInstance(endpoint, cec, metadata);
}
use of org.eclipse.jetty.websocket.jsr356.endpoints.EndpointInstance in project jetty.project by eclipse.
the class ClientContainer method connect.
private Session connect(EndpointInstance instance, URI path) throws IOException {
Objects.requireNonNull(instance, "EndpointInstance cannot be null");
Objects.requireNonNull(path, "Path cannot be null");
ClientEndpointConfig config = (ClientEndpointConfig) instance.getConfig();
ClientUpgradeRequest req = new ClientUpgradeRequest();
UpgradeListener upgradeListener = null;
for (Extension ext : config.getExtensions()) {
req.addExtensions(new JsrExtensionConfig(ext));
}
if (config.getPreferredSubprotocols().size() > 0) {
req.setSubProtocols(config.getPreferredSubprotocols());
}
if (config.getConfigurator() != null) {
upgradeListener = new JsrUpgradeListener(config.getConfigurator());
}
Future<org.eclipse.jetty.websocket.api.Session> futSess = client.connect(instance, path, req, upgradeListener);
try {
return (JsrSession) futSess.get();
} catch (InterruptedException e) {
throw new IOException("Connect failure", e);
} catch (ExecutionException e) {
// Unwrap Actual Cause
Throwable cause = e.getCause();
if (cause instanceof IOException) {
// Just rethrow
throw (IOException) cause;
} else {
throw new IOException("Connect failure", cause);
}
}
}
use of org.eclipse.jetty.websocket.jsr356.endpoints.EndpointInstance in project jetty.project by eclipse.
the class JsrServerExtendsEndpointImpl method supports.
@Override
public boolean supports(Object websocket) {
if (!(websocket instanceof EndpointInstance)) {
return false;
}
EndpointInstance ei = (EndpointInstance) websocket;
Object endpoint = ei.getEndpoint();
return (endpoint instanceof javax.websocket.Endpoint);
}
use of org.eclipse.jetty.websocket.jsr356.endpoints.EndpointInstance in project jetty.project by eclipse.
the class ServerContainer method newClientEndpointInstance.
public EndpointInstance newClientEndpointInstance(Object endpoint, ServerEndpointConfig config, String path) {
EndpointMetadata metadata = getClientEndpointMetadata(endpoint.getClass(), config);
ServerEndpointConfig cec = config;
if (config == null) {
if (metadata instanceof AnnotatedServerEndpointMetadata) {
cec = ((AnnotatedServerEndpointMetadata) metadata).getConfig();
} else {
cec = new BasicServerEndpointConfig(this, endpoint.getClass(), path);
}
}
return new EndpointInstance(endpoint, cec, metadata);
}
use of org.eclipse.jetty.websocket.jsr356.endpoints.EndpointInstance in project jetty.project by eclipse.
the class JsrCreator method createWebSocket.
@Override
public Object createWebSocket(ServletUpgradeRequest req, ServletUpgradeResponse resp) {
JsrHandshakeRequest jsrHandshakeRequest = new JsrHandshakeRequest(req);
JsrHandshakeResponse jsrHandshakeResponse = new JsrHandshakeResponse(resp);
// Get raw config, as defined when the endpoint was added to the container
ServerEndpointConfig config = metadata.getConfig();
// Establish a copy of the config, so that the UserProperties are unique
// per upgrade request.
config = new BasicServerEndpointConfig(containerScope, config);
// Bug 444617 - Expose localAddress and remoteAddress for jsr modify handshake to use
// This is being implemented as an optional set of userProperties so that
// it is not JSR api breaking. A few users on #jetty and a few from cometd
// have asked for access to this information.
Map<String, Object> userProperties = config.getUserProperties();
userProperties.put(PROP_LOCAL_ADDRESS, req.getLocalSocketAddress());
userProperties.put(PROP_REMOTE_ADDRESS, req.getRemoteSocketAddress());
userProperties.put(PROP_LOCALES, Collections.list(req.getLocales()));
// Get Configurator from config object (not guaranteed to be unique per endpoint upgrade)
ServerEndpointConfig.Configurator configurator = config.getConfigurator();
// [JSR] Step 1: check origin
if (!configurator.checkOrigin(req.getOrigin())) {
try {
resp.sendForbidden("Origin mismatch");
} catch (IOException e) {
if (LOG.isDebugEnabled())
LOG.debug("Unable to send error response", e);
}
return null;
}
// [JSR] Step 2: deal with sub protocols
List<String> supported = config.getSubprotocols();
List<String> requested = req.getSubProtocols();
String subprotocol = configurator.getNegotiatedSubprotocol(supported, requested);
if (StringUtil.isNotBlank(subprotocol)) {
resp.setAcceptedSubProtocol(subprotocol);
}
// [JSR] Step 3: deal with extensions
List<Extension> installedExtensions = new ArrayList<>();
for (String extName : extensionFactory.getAvailableExtensions().keySet()) {
installedExtensions.add(new JsrExtension(extName));
}
List<Extension> requestedExts = new ArrayList<>();
for (ExtensionConfig reqCfg : req.getExtensions()) {
requestedExts.add(new JsrExtension(reqCfg));
}
List<Extension> usedExtensions = configurator.getNegotiatedExtensions(installedExtensions, requestedExts);
List<ExtensionConfig> configs = new ArrayList<>();
if (usedExtensions != null) {
for (Extension used : usedExtensions) {
ExtensionConfig ecfg = new ExtensionConfig(used.getName());
for (Parameter param : used.getParameters()) {
ecfg.setParameter(param.getName(), param.getValue());
}
configs.add(ecfg);
}
}
resp.setExtensions(configs);
// [JSR] Step 4: build out new ServerEndpointConfig
PathSpec pathSpec = jsrHandshakeRequest.getRequestPathSpec();
if (pathSpec instanceof UriTemplatePathSpec) {
// We have a PathParam path spec
UriTemplatePathSpec wspathSpec = (UriTemplatePathSpec) pathSpec;
String requestPath = req.getRequestPath();
// Wrap the config with the path spec information
config = new PathParamServerEndpointConfig(containerScope, config, wspathSpec, requestPath);
}
// [JSR] Step 5: Call modifyHandshake
configurator.modifyHandshake(config, jsrHandshakeRequest, jsrHandshakeResponse);
try {
// [JSR] Step 6: create endpoint class
Class<?> endpointClass = config.getEndpointClass();
Object endpoint = config.getConfigurator().getEndpointInstance(endpointClass);
// This will allow CDI to see Session for injection into Endpoint classes.
return new EndpointInstance(endpoint, config, metadata);
} catch (InstantiationException e) {
if (LOG.isDebugEnabled())
LOG.debug("Unable to create websocket: " + config.getEndpointClass().getName(), e);
return null;
}
}
Aggregations