![JAR search and dependency download from the Maven repository](/logo.png)
com.github.kklisura.cdt.services.impl.WebSocketServiceImpl Maven / Gradle / Ivy
Show all versions of cdt-java-client Show documentation
package com.github.kklisura.cdt.services.impl;
/*-
* #%L
* cdt-java-client
* %%
* Copyright (C) 2018 Kenan Klisura
* %%
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
* #L%
*/
import com.github.kklisura.cdt.services.WebSocketService;
import com.github.kklisura.cdt.services.exceptions.WebSocketServiceException;
import java.io.IOException;
import java.net.URI;
import java.util.function.Consumer;
import javax.websocket.ContainerProvider;
import javax.websocket.DeploymentException;
import javax.websocket.Endpoint;
import javax.websocket.EndpointConfig;
import javax.websocket.MessageHandler;
import javax.websocket.Session;
import javax.websocket.WebSocketContainer;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
/**
* Web socket service implementation.
*
* @author Kenan Klisura
*/
public class WebSocketServiceImpl implements WebSocketService {
private static final Logger LOGGER = LoggerFactory.getLogger(WebSocketServiceImpl.class);
private static final WebSocketContainer WEB_SOCKET_CONTAINER =
ContainerProvider.getWebSocketContainer();
private Session session;
/**
* Instantiates a new Web socket service.
*
* @param session Session.
*/
public WebSocketServiceImpl(Session session) {
this.session = session;
}
/** Private ctor. */
private WebSocketServiceImpl() {
// Empty body.
}
/**
* Creates a web socket service implementation factory method.
*
* Creates a WebSocketService and connects to a specified uri.
*
* @param uri URI to connect to.
* @return WebSocketService implementation.
* @throws WebSocketServiceException If it fails to connect.
*/
public static WebSocketService create(URI uri) throws WebSocketServiceException {
WebSocketServiceImpl webSocketService = new WebSocketServiceImpl();
webSocketService.connect(uri);
return webSocketService;
}
@Override
public void connect(URI uri) throws WebSocketServiceException {
LOGGER.debug("Connecting to ws server {}", uri);
try {
session =
WEB_SOCKET_CONTAINER.connectToServer(
new Endpoint() {
@Override
public void onOpen(Session session, EndpointConfig config) {
LOGGER.info("Connected to ws server {}", uri);
}
// TODO(kklisura): Add close handler.
},
uri);
} catch (DeploymentException | IOException e) {
LOGGER.warn("Failed connecting to ws server {}...", uri, e);
throw new WebSocketServiceException("Failed connecting to ws server {}", e);
}
}
@Override
public void send(String message) throws WebSocketServiceException {
try {
LOGGER.debug("Sending message {} on {}", message, session.getRequestURI());
session.getBasicRemote().sendText(message);
} catch (Exception e) {
LOGGER.error("Failed sending data to ws server {}...", session.getRequestURI(), e);
throw new WebSocketServiceException("Failed sending data to ws server.", e);
}
}
@Override
public void addMessageHandler(Consumer consumer) throws WebSocketServiceException {
if (session == null) {
throw new WebSocketServiceException(
"You first must connect to ws server in order to receive messages.");
}
if (!session.getMessageHandlers().isEmpty()) {
throw new WebSocketServiceException("You are already subscribed to this web socket service.");
}
session.addMessageHandler(
new MessageHandler.Whole() {
@Override
public void onMessage(String message) {
LOGGER.debug("Received message {} on {}", message, session.getRequestURI());
consumer.accept(message);
}
});
}
@Override
public void close() {
try {
session.close();
} catch (IOException e) {
LOGGER.error("Failed closing ws session on {}...", session.getRequestURI(), e);
}
}
}