Intial commit
This commit is contained in:
parent
7329fb8dea
commit
73f201bdac
268 changed files with 11220 additions and 5 deletions
38
no2all-wire-jetty/pom.xml
Normal file
38
no2all-wire-jetty/pom.xml
Normal file
|
|
@ -0,0 +1,38 @@
|
|||
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||
<modelVersion>4.0.0</modelVersion>
|
||||
<parent>
|
||||
<groupId>love.distributedrebirth.no2all</groupId>
|
||||
<artifactId>no2all</artifactId>
|
||||
<version>0.0.1-SNAPSHOT</version>
|
||||
</parent>
|
||||
<artifactId>no2all-wire-jetty</artifactId>
|
||||
<name>No2All-Wire-Org-Java-Websocket</name>
|
||||
<dependencies>
|
||||
<dependency>
|
||||
<groupId>${project.groupId}</groupId>
|
||||
<artifactId>no2all-wire</artifactId>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>${project.groupId}</groupId>
|
||||
<artifactId>no2all-react-wire</artifactId>
|
||||
<scope>test</scope>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>org.eclipse.jetty.websocket</groupId>
|
||||
<artifactId>websocket-jetty-api</artifactId>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>org.eclipse.jetty.websocket</groupId>
|
||||
<artifactId>websocket-jetty-server</artifactId>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>org.eclipse.jetty.websocket</groupId>
|
||||
<artifactId>websocket-jetty-client</artifactId>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>org.eclipse.jetty</groupId>
|
||||
<artifactId>jetty-slf4j-impl</artifactId>
|
||||
<scope>test</scope>
|
||||
</dependency>
|
||||
</dependencies>
|
||||
</project>
|
||||
|
|
@ -0,0 +1,70 @@
|
|||
package love.distributedrebirth.no2all.wire.jetty;
|
||||
|
||||
import java.io.IOException;
|
||||
import java.net.URI;
|
||||
import java.nio.ByteBuffer;
|
||||
import java.util.concurrent.ExecutionException;
|
||||
|
||||
import org.eclipse.jetty.websocket.client.WebSocketClient;
|
||||
import org.eclipse.jetty.websocket.client.impl.JettyClientUpgradeRequest;
|
||||
|
||||
import love.distributedrebirth.no2all.wire.WireClient;
|
||||
import love.distributedrebirth.no2all.wire.WireClientHandler;
|
||||
|
||||
public class JettyWireClient implements WireClient {
|
||||
|
||||
private final URI uri;
|
||||
private final WebSocketClient client;
|
||||
private final JettyWireClientHandler handler;
|
||||
|
||||
protected JettyWireClient(URI uri, WebSocketClient client, WireClientHandler handler) {
|
||||
this.uri = uri;
|
||||
this.client = client;
|
||||
this.handler = new JettyWireClientHandler(handler);
|
||||
}
|
||||
|
||||
public JettyWireClientHandler getHandler() {
|
||||
return handler;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void connect() {
|
||||
try {
|
||||
client.connect(handler, uri).get();
|
||||
} catch (IOException | InterruptedException | ExecutionException e) {
|
||||
throw new IllegalStateException(e);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void close(int code, String message) {
|
||||
client.getOpenSessions().forEach(v -> {
|
||||
JettyClientUpgradeRequest req = JettyClientUpgradeRequest.class.cast(v.getUpgradeRequest());
|
||||
if (req.getURI().equals(uri)) {
|
||||
v.close(code, message);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
@Override
|
||||
public void sendMessage(String message) {
|
||||
client.getOpenSessions().forEach(v -> {
|
||||
try {
|
||||
v.getRemote().sendString(message);
|
||||
} catch (IOException e) {
|
||||
throw new IllegalStateException(e);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
@Override
|
||||
public void sendBinary(ByteBuffer message) {
|
||||
client.getOpenSessions().forEach(v -> {
|
||||
try {
|
||||
v.getRemote().sendBytes(message);
|
||||
} catch (IOException e) {
|
||||
throw new IllegalStateException(e);
|
||||
}
|
||||
});
|
||||
}
|
||||
}
|
||||
|
|
@ -0,0 +1,30 @@
|
|||
package love.distributedrebirth.no2all.wire.jetty;
|
||||
|
||||
import java.net.URI;
|
||||
|
||||
import org.eclipse.jetty.websocket.client.WebSocketClient;
|
||||
|
||||
import love.distributedrebirth.no2all.wire.WireClient;
|
||||
import love.distributedrebirth.no2all.wire.WireClientEndpoint;
|
||||
import love.distributedrebirth.no2all.wire.WireClientHandler;
|
||||
|
||||
public class JettyWireClientEndpoint implements WireClientEndpoint {
|
||||
|
||||
private final URI uri;
|
||||
private final WebSocketClient client;
|
||||
|
||||
public JettyWireClientEndpoint(URI uri, WebSocketClient client) {
|
||||
this.uri = uri;
|
||||
this.client = client;
|
||||
}
|
||||
|
||||
@Override
|
||||
public String wireId() {
|
||||
return uri.toString();
|
||||
}
|
||||
|
||||
@Override
|
||||
public WireClient wireClient(WireClientHandler handler) {
|
||||
return new JettyWireClient(uri, client, handler);
|
||||
}
|
||||
}
|
||||
|
|
@ -0,0 +1,43 @@
|
|||
package love.distributedrebirth.no2all.wire.jetty;
|
||||
|
||||
import java.nio.ByteBuffer;
|
||||
|
||||
import org.eclipse.jetty.websocket.api.Session;
|
||||
import org.eclipse.jetty.websocket.api.WebSocketListener;
|
||||
|
||||
import love.distributedrebirth.no2all.wire.WireClientHandler;
|
||||
|
||||
public class JettyWireClientHandler implements WebSocketListener {
|
||||
|
||||
private final WireClientHandler handler;
|
||||
|
||||
protected JettyWireClientHandler(WireClientHandler handler) {
|
||||
this.handler = handler;
|
||||
this.handler.onStart();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onWebSocketConnect(Session session) {
|
||||
handler.onOpen();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onWebSocketClose(int statusCode, String reason) {
|
||||
handler.onClose(statusCode, reason, false);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onWebSocketError(Throwable cause) {
|
||||
handler.onError(cause);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onWebSocketBinary(byte[] payload, int offset, int len) {
|
||||
handler.onBinary(ByteBuffer.wrap(payload, offset, len));
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onWebSocketText(String message) {
|
||||
handler.onMessage(message);
|
||||
}
|
||||
}
|
||||
|
|
@ -0,0 +1,41 @@
|
|||
package love.distributedrebirth.no2all.wire.jetty;
|
||||
|
||||
import java.io.IOException;
|
||||
import java.nio.ByteBuffer;
|
||||
|
||||
import org.eclipse.jetty.websocket.server.JettyWebSocketServerContainer;
|
||||
|
||||
import love.distributedrebirth.no2all.wire.WireServer;
|
||||
import love.distributedrebirth.no2all.wire.WireServerHandler;
|
||||
|
||||
public class JettyWireServer implements WireServer {
|
||||
|
||||
private final JettyWebSocketServerContainer wsContainer;
|
||||
|
||||
protected JettyWireServer(JettyWebSocketServerContainer wsContainer, String servletPath, WireServerHandler handler) {
|
||||
this.wsContainer = wsContainer;
|
||||
this.wsContainer.addMapping(servletPath, new JettyWireServerEndpointCreator(handler));
|
||||
}
|
||||
|
||||
@Override
|
||||
public void broadcastMessage(String message) {
|
||||
wsContainer.getOpenSessions().forEach(v -> {
|
||||
try {
|
||||
v.getRemote().sendString(message);
|
||||
} catch (IOException e) {
|
||||
throw new IllegalStateException(e);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
@Override
|
||||
public void broadcastBinary(ByteBuffer message) {
|
||||
wsContainer.getOpenSessions().forEach(v -> {
|
||||
try {
|
||||
v.getRemote().sendBytes(message);
|
||||
} catch (IOException e) {
|
||||
throw new IllegalStateException(e);
|
||||
}
|
||||
});
|
||||
}
|
||||
}
|
||||
|
|
@ -0,0 +1,28 @@
|
|||
package love.distributedrebirth.no2all.wire.jetty;
|
||||
|
||||
import org.eclipse.jetty.websocket.server.JettyWebSocketServerContainer;
|
||||
|
||||
import love.distributedrebirth.no2all.wire.WireServer;
|
||||
import love.distributedrebirth.no2all.wire.WireServerEndpoint;
|
||||
import love.distributedrebirth.no2all.wire.WireServerHandler;
|
||||
|
||||
public class JettyWireServerEndpoint implements WireServerEndpoint {
|
||||
|
||||
private final JettyWebSocketServerContainer wsContainer;
|
||||
private final String servletPath;
|
||||
|
||||
public JettyWireServerEndpoint(JettyWebSocketServerContainer wsContainer, String servletPath) {
|
||||
this.wsContainer = wsContainer;
|
||||
this.servletPath = servletPath;
|
||||
}
|
||||
|
||||
@Override
|
||||
public String wireId() {
|
||||
return servletPath;
|
||||
}
|
||||
|
||||
@Override
|
||||
public WireServer wireServer(WireServerHandler handler) {
|
||||
return new JettyWireServer(wsContainer, servletPath, handler);
|
||||
}
|
||||
}
|
||||
|
|
@ -0,0 +1,22 @@
|
|||
package love.distributedrebirth.no2all.wire.jetty;
|
||||
|
||||
import org.eclipse.jetty.websocket.server.JettyServerUpgradeRequest;
|
||||
import org.eclipse.jetty.websocket.server.JettyServerUpgradeResponse;
|
||||
import org.eclipse.jetty.websocket.server.JettyWebSocketCreator;
|
||||
|
||||
import love.distributedrebirth.no2all.wire.WireServerHandler;
|
||||
|
||||
public class JettyWireServerEndpointCreator implements JettyWebSocketCreator {
|
||||
|
||||
private final WireServerHandler handler;
|
||||
|
||||
public JettyWireServerEndpointCreator(WireServerHandler handler) {
|
||||
this.handler = handler;
|
||||
}
|
||||
|
||||
@Override
|
||||
public Object createWebSocket(JettyServerUpgradeRequest jettyServerUpgradeRequest,
|
||||
JettyServerUpgradeResponse jettyServerUpgradeResponse) {
|
||||
return new JettyWireServerHandler(handler);
|
||||
}
|
||||
}
|
||||
|
|
@ -0,0 +1,45 @@
|
|||
package love.distributedrebirth.no2all.wire.jetty;
|
||||
|
||||
import java.nio.ByteBuffer;
|
||||
|
||||
import org.eclipse.jetty.websocket.api.Session;
|
||||
import org.eclipse.jetty.websocket.api.WebSocketListener;
|
||||
|
||||
import love.distributedrebirth.no2all.wire.WireServerHandler;
|
||||
|
||||
public class JettyWireServerHandler implements WebSocketListener {
|
||||
|
||||
private final WireServerHandler handler;
|
||||
private JettyWireServerSocket conn;
|
||||
|
||||
protected JettyWireServerHandler(WireServerHandler handler) {
|
||||
this.handler = handler;
|
||||
this.handler.onStart();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onWebSocketConnect(Session session) {
|
||||
this.conn = new JettyWireServerSocket(session);
|
||||
handler.onOpen(conn);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onWebSocketClose(int statusCode, String reason) {
|
||||
handler.onClose(conn, statusCode, reason, false);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onWebSocketError(Throwable cause) {
|
||||
handler.onError(conn, cause);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onWebSocketBinary(byte[] payload, int offset, int len) {
|
||||
handler.onBinary(conn, ByteBuffer.wrap(payload, offset, len));
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onWebSocketText(String message) {
|
||||
handler.onMessage(conn, message);
|
||||
}
|
||||
}
|
||||
|
|
@ -0,0 +1,45 @@
|
|||
package love.distributedrebirth.no2all.wire.jetty;
|
||||
|
||||
import java.io.IOException;
|
||||
import java.nio.ByteBuffer;
|
||||
|
||||
import org.eclipse.jetty.websocket.api.Session;
|
||||
|
||||
import love.distributedrebirth.no2all.wire.WireServerSocket;
|
||||
|
||||
public final class JettyWireServerSocket implements WireServerSocket {
|
||||
|
||||
private final Session session;
|
||||
|
||||
protected JettyWireServerSocket(Session session) {
|
||||
this.session = session;
|
||||
}
|
||||
|
||||
@Override
|
||||
public String getRemoteAddress() {
|
||||
return session.getRemoteAddress().toString();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void sendMessage(String message) {
|
||||
try {
|
||||
session.getRemote().sendString(message);
|
||||
} catch (IOException e) {
|
||||
throw new IllegalStateException(e);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void sendBinary(ByteBuffer message) {
|
||||
try {
|
||||
session.getRemote().sendBytes(message);
|
||||
} catch (IOException e) {
|
||||
throw new IllegalStateException(e);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void close(int code, String message) {
|
||||
session.close(code, message);
|
||||
}
|
||||
}
|
||||
|
|
@ -0,0 +1,77 @@
|
|||
package love.distributedrebirth.no2all.wire.jetty;
|
||||
|
||||
import java.net.URI;
|
||||
import java.net.URISyntaxException;
|
||||
import java.nio.ByteBuffer;
|
||||
|
||||
import org.eclipse.jetty.websocket.client.WebSocketClient;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
import love.distributedrebirth.no2all.wire.WireClient;
|
||||
import love.distributedrebirth.no2all.wire.WireClientHandler;
|
||||
|
||||
public class EventClient implements WireClientHandler {
|
||||
|
||||
private static final Logger LOG = LoggerFactory.getLogger(EventClient.class);
|
||||
|
||||
public static void main(String[] args) throws Exception {
|
||||
EventClient client = new EventClient();
|
||||
client.start();
|
||||
client.sendHallo();
|
||||
client.stop();
|
||||
}
|
||||
|
||||
private WebSocketClient client;
|
||||
private JettyWireClientEndpoint endpoint1;
|
||||
|
||||
public EventClient() throws URISyntaxException {
|
||||
client = new WebSocketClient();
|
||||
endpoint1 = new JettyWireClientEndpoint(new URI("ws://localhost:8080"), client);
|
||||
}
|
||||
|
||||
public void start() throws Exception {
|
||||
client.start();
|
||||
LOG.info("client startup");
|
||||
}
|
||||
|
||||
public void stop() throws Exception {
|
||||
client.stop();
|
||||
}
|
||||
|
||||
public void sendHallo() {
|
||||
WireClient client1 = endpoint1.wireClient(this);
|
||||
client1.connect();
|
||||
client1.sendMessage("test me");
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onStart() {
|
||||
LOG.info("client.onStart()");
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onOpen() {
|
||||
LOG.info("client.onOpen()");
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onClose(int code, String reason, boolean remote) {
|
||||
LOG.info("client.onClose: "+code);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onError(Throwable error) {
|
||||
LOG.info("client.onError: "+error.getMessage());
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onMessage(String message) {
|
||||
LOG.info("client.onMessage: "+message);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onBinary(ByteBuffer message) {
|
||||
LOG.info("client.onBinary: "+message);
|
||||
}
|
||||
}
|
||||
|
|
@ -0,0 +1,102 @@
|
|||
package love.distributedrebirth.no2all.wire.jetty;
|
||||
|
||||
import java.net.URI;
|
||||
|
||||
import org.eclipse.jetty.server.Server;
|
||||
import org.eclipse.jetty.server.ServerConnector;
|
||||
import org.eclipse.jetty.servlet.ServletContextHandler;
|
||||
import org.eclipse.jetty.util.component.LifeCycle;
|
||||
import org.eclipse.jetty.util.component.LifeCycle.Listener;
|
||||
import org.eclipse.jetty.websocket.server.config.JettyWebSocketServletContainerInitializer;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
import love.distributedrebirth.no2all.react.No2AllReactSlot;
|
||||
import love.distributedrebirth.no2all.react.warp.No2AllReactWarpCore;
|
||||
import love.distributedrebirth.no2all.react.warp.No2AllRtsWarpSpeedMonitor;
|
||||
import love.distributedrebirth.no2all.react.wire.server.No2AllActServer;
|
||||
import love.distributedrebirth.no2all.react.wire.server.No2AllActServerSocketSendMessage;
|
||||
import love.distributedrebirth.no2all.react.wire.server.No2AllArtServer;
|
||||
import love.distributedrebirth.no2all.react.wire.server.No2AllArtServerSocket;
|
||||
import love.distributedrebirth.no2all.react.wire.server.No2AllArtServerSocketOnMessage;
|
||||
import love.distributedrebirth.no2all.react.wire.server.No2AllRtsServerLog;
|
||||
import love.distributedrebirth.no2all.react.wire.server.No2AllRtsServer;
|
||||
|
||||
public class EventServer {
|
||||
|
||||
private static final Logger LOG = LoggerFactory.getLogger(EventServer.class);
|
||||
|
||||
public static void main(String[] args) throws Exception {
|
||||
EventServer server = new EventServer();
|
||||
server.setPort(8080);
|
||||
server.start();
|
||||
server.join();
|
||||
}
|
||||
|
||||
private final Server server;
|
||||
private final ServerConnector connector;
|
||||
private JettyWireServerEndpoint endpoint1;
|
||||
private JettyWireServerEndpoint endpoint2;
|
||||
private JettyWireServerEndpoint endpoint3;
|
||||
|
||||
public EventServer() {
|
||||
server = new Server();
|
||||
connector = new ServerConnector(server);
|
||||
server.addConnector(connector);
|
||||
ServletContextHandler context = new ServletContextHandler(ServletContextHandler.SESSIONS);
|
||||
context.setContextPath("/");
|
||||
server.setHandler(context);
|
||||
JettyWebSocketServletContainerInitializer.configure(context, (servletContext, wsContainer) -> {
|
||||
wsContainer.setMaxTextMessageSize(65535);
|
||||
endpoint1 = new JettyWireServerEndpoint(wsContainer, "/");
|
||||
endpoint2 = new JettyWireServerEndpoint(wsContainer, "/event");
|
||||
endpoint3 = new JettyWireServerEndpoint(wsContainer, "/other");
|
||||
});
|
||||
server.addEventListener(new Listener() {
|
||||
|
||||
@Override
|
||||
public void lifeCycleStarted(LifeCycle event) {
|
||||
LOG.info("Startup No2AllReactWarpCore");
|
||||
No2AllReactWarpCore react = new No2AllReactWarpCore();
|
||||
react.load(new No2AllRtsWarpSpeedMonitor());
|
||||
react.load(new No2AllRtsServer());
|
||||
react.load(new No2AllRtsServerLog());
|
||||
|
||||
// auto reply
|
||||
react.registrate(No2AllRtsServer.API, No2AllArtServer.class, artServer -> {
|
||||
No2AllReactSlot serverSlot = artServer.getData().getSlot();
|
||||
react.registrate(serverSlot, No2AllArtServerSocket.class, artSocket -> {
|
||||
No2AllReactSlot socketSlot = artSocket.getData().getSlot();
|
||||
react.registrate(socketSlot, No2AllArtServerSocketOnMessage.class, artMsg -> {
|
||||
react.fire(socketSlot, new No2AllActServerSocketSendMessage("RE: "+artMsg.getData().getMessage()));
|
||||
});
|
||||
});
|
||||
});
|
||||
react.fire(No2AllRtsServer.API, new No2AllActServer(endpoint1));
|
||||
react.fire(No2AllRtsServer.API, new No2AllActServer(endpoint2));
|
||||
react.fire(No2AllRtsServer.API, new No2AllActServer(endpoint3));
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
public void setPort(int port) {
|
||||
connector.setPort(port);
|
||||
}
|
||||
|
||||
public void start() throws Exception {
|
||||
server.start();
|
||||
}
|
||||
|
||||
public URI getURI() {
|
||||
return server.getURI();
|
||||
}
|
||||
|
||||
public void stop() throws Exception {
|
||||
server.stop();
|
||||
}
|
||||
|
||||
public void join() throws InterruptedException {
|
||||
LOG.info("Use Ctrl+C to stop server");
|
||||
server.join();
|
||||
}
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue