now with some SSL
This commit is contained in:
parent
5caf428d2f
commit
1bcd038ea6
|
@ -8,6 +8,7 @@ import com.rusefi.config.generated.Fields;
|
||||||
import com.rusefi.io.LinkManager;
|
import com.rusefi.io.LinkManager;
|
||||||
import com.rusefi.io.commands.HelloCommand;
|
import com.rusefi.io.commands.HelloCommand;
|
||||||
|
|
||||||
|
import javax.net.ssl.SSLServerSocketFactory;
|
||||||
import java.io.*;
|
import java.io.*;
|
||||||
import java.net.ServerSocket;
|
import java.net.ServerSocket;
|
||||||
import java.net.Socket;
|
import java.net.Socket;
|
||||||
|
@ -34,6 +35,23 @@ public class BinaryProtocolServer implements BinaryProtocolCommands {
|
||||||
|
|
||||||
public AtomicInteger unknownCommands = new AtomicInteger();
|
public AtomicInteger unknownCommands = new AtomicInteger();
|
||||||
|
|
||||||
|
public static final Function<Integer, ServerSocket> SECURE_SOCKET_FACTORY = port -> {
|
||||||
|
try {
|
||||||
|
return SSLServerSocketFactory.getDefault().createServerSocket(port);
|
||||||
|
} catch (IOException e) {
|
||||||
|
throw new IllegalStateException("Error binding secure server socket " + port, e);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
public static final Function<Integer, ServerSocket> PLAIN_SOCKET_FACTORY = port -> {
|
||||||
|
try {
|
||||||
|
return new ServerSocket(port);
|
||||||
|
} catch (IOException e) {
|
||||||
|
throw new IllegalStateException("Error binding server socket " + port, e);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
public BinaryProtocolServer(Logger logger) {
|
public BinaryProtocolServer(Logger logger) {
|
||||||
this.logger = logger;
|
this.logger = logger;
|
||||||
}
|
}
|
||||||
|
@ -61,35 +79,29 @@ public class BinaryProtocolServer implements BinaryProtocolCommands {
|
||||||
*
|
*
|
||||||
* @param port server port to accept connections
|
* @param port server port to accept connections
|
||||||
* @param threadName
|
* @param threadName
|
||||||
* @param clientSocketRunnableFactory method to invoke on a new thread for each new client connection
|
* @param socketRunnableFactory method to invoke on a new thread for each new client connection
|
||||||
* @param logger
|
* @param logger
|
||||||
* @param serverSocketCreationCallback this callback is invoked once we open the server socket
|
* @param serverSocketCreationCallback this callback is invoked once we open the server socket
|
||||||
*/
|
*/
|
||||||
public static void tcpServerSocket(int port, String threadName, Function<Socket, Runnable> clientSocketRunnableFactory, final Logger logger, Listener serverSocketCreationCallback) {
|
public static void tcpServerSocket(int port, String threadName, Function<Socket, Runnable> socketRunnableFactory, final Logger logger, Listener serverSocketCreationCallback) {
|
||||||
Runnable runnable = new Runnable() {
|
tcpServerSocket(logger, socketRunnableFactory, port, threadName, serverSocketCreationCallback, PLAIN_SOCKET_FACTORY);
|
||||||
@SuppressWarnings("InfiniteLoopStatement")
|
}
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
ServerSocket serverSocket;
|
|
||||||
try {
|
|
||||||
serverSocket = new ServerSocket(port, 1);
|
|
||||||
} catch (IOException e) {
|
|
||||||
logger.error(threadName + ": Error binding server socket " + port + ": " + e);
|
|
||||||
throw new IllegalStateException(e);
|
|
||||||
}
|
|
||||||
if (serverSocketCreationCallback != null)
|
|
||||||
serverSocketCreationCallback.onResult(null);
|
|
||||||
|
|
||||||
try {
|
public static void tcpServerSocket(Logger logger, Function<Socket, Runnable> clientSocketRunnableFactory, int port, String threadName, Listener serverSocketCreationCallback, Function<Integer, ServerSocket> nonSecureSocketFunction) {
|
||||||
while (true) {
|
Runnable runnable = () -> {
|
||||||
// Wait for a connection
|
ServerSocket serverSocket = nonSecureSocketFunction.apply(port);
|
||||||
final Socket clientSocket = serverSocket.accept();
|
if (serverSocketCreationCallback != null)
|
||||||
logger.info("Binary protocol proxy port connection");
|
serverSocketCreationCallback.onResult(null);
|
||||||
new Thread(clientSocketRunnableFactory.apply(clientSocket), "proxy connection").start();
|
|
||||||
}
|
try {
|
||||||
} catch (IOException e) {
|
while (true) {
|
||||||
throw new IllegalStateException(e);
|
// Wait for a connection
|
||||||
|
final Socket clientSocket = serverSocket.accept();
|
||||||
|
logger.info("Binary protocol proxy port connection");
|
||||||
|
new Thread(clientSocketRunnableFactory.apply(clientSocket), "proxy connection").start();
|
||||||
}
|
}
|
||||||
|
} catch (IOException e) {
|
||||||
|
throw new IllegalStateException(e);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
new Thread(runnable, threadName).start();
|
new Thread(runnable, threadName).start();
|
||||||
|
|
|
@ -9,6 +9,7 @@ import com.rusefi.server.ControllerInfo;
|
||||||
import com.rusefi.server.SessionDetails;
|
import com.rusefi.server.SessionDetails;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
|
import javax.net.ssl.SSLSocketFactory;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.net.Socket;
|
import java.net.Socket;
|
||||||
|
|
||||||
|
@ -28,7 +29,7 @@ public class NetworkConnector {
|
||||||
|
|
||||||
SessionDetails deviceSessionDetails = new SessionDetails(ci, authToken, SessionDetails.createOneTimeCode());
|
SessionDetails deviceSessionDetails = new SessionDetails(ci, authToken, SessionDetails.createOneTimeCode());
|
||||||
|
|
||||||
BaseBroadcastingThread baseBroadcastingThread = new BaseBroadcastingThread(new Socket(LOCALHOST, serverPortForControllers),
|
BaseBroadcastingThread baseBroadcastingThread = new BaseBroadcastingThread(SSLSocketFactory.getDefault().createSocket(LOCALHOST, serverPortForControllers),
|
||||||
deviceSessionDetails,
|
deviceSessionDetails,
|
||||||
logger) {
|
logger) {
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -4,6 +4,7 @@ import com.opensr5.Logger;
|
||||||
import com.rusefi.server.ControllerInfo;
|
import com.rusefi.server.ControllerInfo;
|
||||||
import com.rusefi.server.SessionDetails;
|
import com.rusefi.server.SessionDetails;
|
||||||
|
|
||||||
|
import javax.net.ssl.SSLSocketFactory;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.net.Socket;
|
import java.net.Socket;
|
||||||
|
|
||||||
|
@ -27,7 +28,8 @@ public class MockRusEfiDevice {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void connect(int serverPort) throws IOException {
|
public void connect(int serverPort) throws IOException {
|
||||||
BaseBroadcastingThread baseBroadcastingThread = new BaseBroadcastingThread(new Socket(LOCALHOST, serverPort),
|
Socket socket = SSLSocketFactory.getDefault().createSocket(LOCALHOST, serverPort);
|
||||||
|
BaseBroadcastingThread baseBroadcastingThread = new BaseBroadcastingThread(socket,
|
||||||
sessionDetails,
|
sessionDetails,
|
||||||
logger);
|
logger);
|
||||||
baseBroadcastingThread.start();
|
baseBroadcastingThread.start();
|
||||||
|
|
|
@ -54,7 +54,7 @@ public class ServerTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testControllerSessionTimeout() throws InterruptedException, IOException {
|
public void testControllerSessionTimeout() throws InterruptedException, IOException {
|
||||||
int serverPort = 7000;
|
int serverPortForControllers = 7000;
|
||||||
int httpPort = 8000;
|
int httpPort = 8000;
|
||||||
Function<String, UserDetails> userDetailsResolver = authToken -> new UserDetails(authToken.substring(0, 5), authToken.charAt(6));
|
Function<String, UserDetails> userDetailsResolver = authToken -> new UserDetails(authToken.substring(0, 5), authToken.charAt(6));
|
||||||
|
|
||||||
|
@ -77,15 +77,15 @@ public class ServerTest {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
backend.runControllerConnector(serverPort, parameter -> serverCreated.countDown());
|
backend.runControllerConnector(serverPortForControllers, parameter -> serverCreated.countDown());
|
||||||
assertTrue(serverCreated.await(30, TimeUnit.SECONDS));
|
assertTrue(serverCreated.await(30, TimeUnit.SECONDS));
|
||||||
assertEquals(0, backend.getCount());
|
assertEquals(0, backend.getCount());
|
||||||
|
|
||||||
|
|
||||||
new MockRusEfiDevice(MockRusEfiDevice.TEST_TOKEN_1, "rusEFI 2020.07.06.frankenso_na6.2468827536", logger).connect(serverPort);
|
new MockRusEfiDevice(MockRusEfiDevice.TEST_TOKEN_1, "rusEFI 2020.07.06.frankenso_na6.2468827536", logger).connect(serverPortForControllers);
|
||||||
new MockRusEfiDevice("12345678-1234-1234-1234-123456789012", "rusEFI 2020.07.11.proteus_f4.1986715563", logger).connect(serverPort);
|
new MockRusEfiDevice("12345678-1234-1234-1234-123456789012", "rusEFI 2020.07.11.proteus_f4.1986715563", logger).connect(serverPortForControllers);
|
||||||
|
|
||||||
assertTrue(onConnected.await(30, TimeUnit.SECONDS));
|
assertTrue("onConnected", onConnected.await(30, TimeUnit.SECONDS));
|
||||||
|
|
||||||
List<ControllerConnectionState> clients = backend.getClients();
|
List<ControllerConnectionState> clients = backend.getClients();
|
||||||
assertEquals(2, clients.size());
|
assertEquals(2, clients.size());
|
||||||
|
@ -93,7 +93,7 @@ public class ServerTest {
|
||||||
List<UserDetails> onlineUsers = ProxyClient.getOnlineUsers(httpPort);
|
List<UserDetails> onlineUsers = ProxyClient.getOnlineUsers(httpPort);
|
||||||
assertEquals(2, onlineUsers.size());
|
assertEquals(2, onlineUsers.size());
|
||||||
|
|
||||||
assertTrue(allClientsDisconnected.await(30, TimeUnit.SECONDS));
|
assertTrue("allClientsDisconnected", allClientsDisconnected.await(30, TimeUnit.SECONDS));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
|
|
@ -122,7 +122,7 @@ public class Backend {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void runControllerConnector(int serverPortForControllers, Listener serverSocketCreationCallback) {
|
public void runControllerConnector(int serverPortForControllers, Listener serverSocketCreationCallback) {
|
||||||
BinaryProtocolServer.tcpServerSocket(serverPortForControllers, "ControllerServer", new Function<Socket, Runnable>() {
|
BinaryProtocolServer.tcpServerSocket(logger, new Function<Socket, Runnable>() {
|
||||||
@Override
|
@Override
|
||||||
public Runnable apply(Socket controllerSocket) {
|
public Runnable apply(Socket controllerSocket) {
|
||||||
return new Runnable() {
|
return new Runnable() {
|
||||||
|
@ -141,7 +141,7 @@ public class Backend {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
}, logger, serverSocketCreationCallback);
|
}, serverPortForControllers, "ControllerServer", serverSocketCreationCallback, BinaryProtocolServer.SECURE_SOCKET_FACTORY);
|
||||||
}
|
}
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
|
|
Loading…
Reference in New Issue