Intial commit
This commit is contained in:
parent
7329fb8dea
commit
73f201bdac
268 changed files with 11220 additions and 5 deletions
20
no2all-wire-ojw/pom.xml
Normal file
20
no2all-wire-ojw/pom.xml
Normal file
|
|
@ -0,0 +1,20 @@
|
|||
<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-ojw</artifactId>
|
||||
<name>No2All-Wire-Org-Java-Websocket</name>
|
||||
<dependencies>
|
||||
<dependency>
|
||||
<groupId>${project.groupId}</groupId>
|
||||
<artifactId>no2all-wire</artifactId>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>org.java-websocket</groupId>
|
||||
<artifactId>Java-WebSocket</artifactId>
|
||||
</dependency>
|
||||
</dependencies>
|
||||
</project>
|
||||
|
|
@ -0,0 +1,41 @@
|
|||
package love.distributedrebirth.no2all.wire.ojw;
|
||||
|
||||
import java.net.URI;
|
||||
import java.nio.ByteBuffer;
|
||||
import java.util.Map;
|
||||
|
||||
import love.distributedrebirth.no2all.wire.WireClient;
|
||||
import love.distributedrebirth.no2all.wire.WireClientHandler;
|
||||
|
||||
public class OjwWireClient implements WireClient {
|
||||
|
||||
private final OjwWireClientHandler handler;
|
||||
|
||||
protected OjwWireClient(URI uri, Map<String, String> headers, int timeoutMs, WireClientHandler handler) {
|
||||
this.handler = new OjwWireClientHandler(uri, headers, timeoutMs, handler);
|
||||
}
|
||||
|
||||
public OjwWireClientHandler getHandler() {
|
||||
return handler;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void connect() {
|
||||
handler.connect();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void close(int code, String message) {
|
||||
handler.close(code, message);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void sendMessage(String message) {
|
||||
handler.send(message);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void sendBinary(ByteBuffer message) {
|
||||
handler.send(message);
|
||||
}
|
||||
}
|
||||
|
|
@ -0,0 +1,35 @@
|
|||
package love.distributedrebirth.no2all.wire.ojw;
|
||||
|
||||
import java.net.URI;
|
||||
import java.util.Map;
|
||||
|
||||
import love.distributedrebirth.no2all.wire.WireClient;
|
||||
import love.distributedrebirth.no2all.wire.WireClientEndpoint;
|
||||
import love.distributedrebirth.no2all.wire.WireClientHandler;
|
||||
|
||||
public class OjwWireClientEndpoint implements WireClientEndpoint {
|
||||
|
||||
private final URI uri;
|
||||
private final Map<String, String> headers;
|
||||
private final int timeoutMs;
|
||||
|
||||
public OjwWireClientEndpoint(URI uri) {
|
||||
this(uri, null, 60 * 1000);
|
||||
}
|
||||
|
||||
public OjwWireClientEndpoint(URI uri, Map<String, String> headers, int timeoutMs) {
|
||||
this.uri = uri;
|
||||
this.headers = headers;
|
||||
this.timeoutMs = timeoutMs;
|
||||
}
|
||||
|
||||
@Override
|
||||
public String wireId() {
|
||||
return uri.toString();
|
||||
}
|
||||
|
||||
@Override
|
||||
public WireClient wireClient(WireClientHandler handler) {
|
||||
return new OjwWireClient(uri, headers, timeoutMs, handler);
|
||||
}
|
||||
}
|
||||
|
|
@ -0,0 +1,46 @@
|
|||
package love.distributedrebirth.no2all.wire.ojw;
|
||||
|
||||
import java.net.URI;
|
||||
import java.nio.ByteBuffer;
|
||||
import java.util.Map;
|
||||
|
||||
import org.java_websocket.client.WebSocketClient;
|
||||
import org.java_websocket.drafts.Draft_6455;
|
||||
import org.java_websocket.handshake.ServerHandshake;
|
||||
|
||||
import love.distributedrebirth.no2all.wire.WireClientHandler;
|
||||
|
||||
public class OjwWireClientHandler extends WebSocketClient {
|
||||
|
||||
private final WireClientHandler handler;
|
||||
|
||||
protected OjwWireClientHandler(URI uri, Map<String, String> headers, int timeoutMs, WireClientHandler handler) {
|
||||
super(uri, new Draft_6455(), headers, timeoutMs);
|
||||
this.handler = handler;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onOpen(ServerHandshake handshakedata) {
|
||||
handler.onOpen();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onClose(int code, String reason, boolean remote) {
|
||||
handler.onClose(code, reason, remote);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onError(Exception ex) {
|
||||
handler.onError(ex);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onMessage(String message) {
|
||||
handler.onMessage(message);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onMessage(ByteBuffer message) {
|
||||
handler.onBinary(message);
|
||||
}
|
||||
}
|
||||
|
|
@ -0,0 +1,31 @@
|
|||
package love.distributedrebirth.no2all.wire.ojw;
|
||||
|
||||
import java.net.InetSocketAddress;
|
||||
import java.nio.ByteBuffer;
|
||||
|
||||
import love.distributedrebirth.no2all.wire.WireServer;
|
||||
import love.distributedrebirth.no2all.wire.WireServerHandler;
|
||||
|
||||
public class OjwWireServer implements WireServer {
|
||||
|
||||
private final OjwWireServerHandler handler;
|
||||
|
||||
protected OjwWireServer(InetSocketAddress port, int pingTimeoutSecs, WireServerHandler handler) {
|
||||
this.handler = new OjwWireServerHandler(port, pingTimeoutSecs, handler);
|
||||
this.handler.start();
|
||||
}
|
||||
|
||||
public OjwWireServerHandler getHandler() {
|
||||
return handler;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void broadcastMessage(String message) {
|
||||
handler.broadcast(message);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void broadcastBinary(ByteBuffer message) {
|
||||
handler.broadcast(message);
|
||||
}
|
||||
}
|
||||
|
|
@ -0,0 +1,28 @@
|
|||
package love.distributedrebirth.no2all.wire.ojw;
|
||||
|
||||
import java.net.InetSocketAddress;
|
||||
|
||||
import love.distributedrebirth.no2all.wire.WireServer;
|
||||
import love.distributedrebirth.no2all.wire.WireServerEndpoint;
|
||||
import love.distributedrebirth.no2all.wire.WireServerHandler;
|
||||
|
||||
public class OjwWireServerEndpoint implements WireServerEndpoint {
|
||||
|
||||
private final InetSocketAddress port;
|
||||
private final int pingTimeoutSecs;
|
||||
|
||||
public OjwWireServerEndpoint(InetSocketAddress port, int pingTimeoutSecs) {
|
||||
this.port = port;
|
||||
this.pingTimeoutSecs = pingTimeoutSecs;
|
||||
}
|
||||
|
||||
@Override
|
||||
public String wireId() {
|
||||
return port.toString();
|
||||
}
|
||||
|
||||
@Override
|
||||
public WireServer wireServer(WireServerHandler handler) {
|
||||
return new OjwWireServer(port, pingTimeoutSecs, handler);
|
||||
}
|
||||
}
|
||||
|
|
@ -0,0 +1,81 @@
|
|||
package love.distributedrebirth.no2all.wire.ojw;
|
||||
|
||||
import java.net.InetSocketAddress;
|
||||
import java.nio.ByteBuffer;
|
||||
import java.util.Map;
|
||||
import java.util.WeakHashMap;
|
||||
import java.util.concurrent.locks.Lock;
|
||||
import java.util.concurrent.locks.ReadWriteLock;
|
||||
import java.util.concurrent.locks.ReentrantReadWriteLock;
|
||||
|
||||
import org.java_websocket.WebSocket;
|
||||
import org.java_websocket.handshake.ClientHandshake;
|
||||
import org.java_websocket.server.WebSocketServer;
|
||||
|
||||
import love.distributedrebirth.no2all.wire.WireServerHandler;
|
||||
|
||||
public class OjwWireServerHandler extends WebSocketServer {
|
||||
|
||||
private final WireServerHandler handler;
|
||||
private final Map<WebSocket, OjwWireServerSocket> wraps = new WeakHashMap<>();
|
||||
private final ReadWriteLock lock = new ReentrantReadWriteLock();
|
||||
private final Lock lockRead = lock.readLock();
|
||||
private final Lock lockWrite = lock.writeLock();
|
||||
|
||||
protected OjwWireServerHandler(InetSocketAddress port, int pingTimeoutSecs, WireServerHandler handler) {
|
||||
super(port);
|
||||
setConnectionLostTimeout(pingTimeoutSecs);
|
||||
this.handler = handler;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onStart() {
|
||||
handler.onStart();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onOpen(WebSocket conn, ClientHandshake handshake) {
|
||||
handler.onOpen(wrap(conn));
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onClose(WebSocket conn, int code, String reason, boolean remote) {
|
||||
handler.onClose(wrap(conn), code, reason, remote);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onError(WebSocket conn, Exception ex) {
|
||||
handler.onError(wrap(conn), ex);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onMessage(WebSocket conn, String message) {
|
||||
handler.onMessage(wrap(conn), message);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onMessage(WebSocket conn, ByteBuffer message) {
|
||||
handler.onBinary(wrap(conn), message);
|
||||
}
|
||||
|
||||
private OjwWireServerSocket wrap(WebSocket conn) {
|
||||
OjwWireServerSocket result = null;
|
||||
lockRead.lock();
|
||||
try {
|
||||
result = wraps.get(conn);
|
||||
} finally {
|
||||
lockRead.unlock();
|
||||
}
|
||||
if (result != null) {
|
||||
return result;
|
||||
}
|
||||
result = new OjwWireServerSocket(conn);
|
||||
lockWrite.lock();
|
||||
try {
|
||||
wraps.put(conn, result);
|
||||
} finally {
|
||||
lockWrite.unlock();
|
||||
}
|
||||
return result;
|
||||
}
|
||||
}
|
||||
|
|
@ -0,0 +1,36 @@
|
|||
package love.distributedrebirth.no2all.wire.ojw;
|
||||
|
||||
import java.nio.ByteBuffer;
|
||||
|
||||
import org.java_websocket.WebSocket;
|
||||
|
||||
import love.distributedrebirth.no2all.wire.WireServerSocket;
|
||||
|
||||
public final class OjwWireServerSocket implements WireServerSocket {
|
||||
|
||||
private final WebSocket socket;
|
||||
|
||||
protected OjwWireServerSocket(WebSocket socket) {
|
||||
this.socket = socket;
|
||||
}
|
||||
|
||||
@Override
|
||||
public String getRemoteAddress() {
|
||||
return socket.getRemoteSocketAddress().getAddress().getHostAddress();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void sendMessage(String message) {
|
||||
socket.send(message);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void sendBinary(ByteBuffer message) {
|
||||
socket.send(message);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void close(int code, String message) {
|
||||
socket.close(code, message);
|
||||
}
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue