proxy progress - getting REALLY close?!
This commit is contained in:
parent
50aad7496f
commit
09d14a4861
|
@ -4,6 +4,7 @@ import com.opensr5.Logger;
|
||||||
import com.rusefi.io.IoStream;
|
import com.rusefi.io.IoStream;
|
||||||
import com.rusefi.io.commands.HelloCommand;
|
import com.rusefi.io.commands.HelloCommand;
|
||||||
import com.rusefi.io.tcp.BinaryProtocolProxy;
|
import com.rusefi.io.tcp.BinaryProtocolProxy;
|
||||||
|
import com.rusefi.io.tcp.ServerHolder;
|
||||||
import com.rusefi.io.tcp.TcpIoStream;
|
import com.rusefi.io.tcp.TcpIoStream;
|
||||||
import com.rusefi.server.ApplicationRequest;
|
import com.rusefi.server.ApplicationRequest;
|
||||||
import com.rusefi.server.rusEFISSLContext;
|
import com.rusefi.server.rusEFISSLContext;
|
||||||
|
@ -29,7 +30,7 @@ public class LocalApplicationProxy {
|
||||||
* @param authenticatorPort local port we would bind for TunerStudio to connect to
|
* @param authenticatorPort local port we would bind for TunerStudio to connect to
|
||||||
* @param httpPort
|
* @param httpPort
|
||||||
*/
|
*/
|
||||||
static void startAndRun(Logger logger, int serverPortForRemoteUsers, ApplicationRequest applicationRequest, int authenticatorPort, int httpPort) throws IOException {
|
public static ServerHolder startAndRun(Logger logger, int serverPortForRemoteUsers, ApplicationRequest applicationRequest, int authenticatorPort, int httpPort) throws IOException {
|
||||||
HttpResponse httpResponse = HttpUtil.executeGet(ProxyClient.getHttpAddress(httpPort) + ProxyClient.VERSION_PATH);
|
HttpResponse httpResponse = HttpUtil.executeGet(ProxyClient.getHttpAddress(httpPort) + ProxyClient.VERSION_PATH);
|
||||||
String version = HttpUtil.getResponse(httpResponse);
|
String version = HttpUtil.getResponse(httpResponse);
|
||||||
logger.info("Version=" + version);
|
logger.info("Version=" + version);
|
||||||
|
@ -40,7 +41,7 @@ public class LocalApplicationProxy {
|
||||||
LocalApplicationProxy localApplicationProxy = new LocalApplicationProxy(logger, applicationRequest);
|
LocalApplicationProxy localApplicationProxy = new LocalApplicationProxy(logger, applicationRequest);
|
||||||
localApplicationProxy.run(authenticatorToProxyStream);
|
localApplicationProxy.run(authenticatorToProxyStream);
|
||||||
|
|
||||||
BinaryProtocolProxy.createProxy(logger, authenticatorToProxyStream, authenticatorPort);
|
return BinaryProtocolProxy.createProxy(logger, authenticatorToProxyStream, authenticatorPort);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void run(IoStream authenticatorToProxyStream) throws IOException {
|
public void run(IoStream authenticatorToProxyStream) throws IOException {
|
||||||
|
|
|
@ -15,30 +15,23 @@ import static com.rusefi.binaryprotocol.BinaryProtocolCommands.COMMAND_PROTOCOL;
|
||||||
import static com.rusefi.config.generated.Fields.TS_PROTOCOL;
|
import static com.rusefi.config.generated.Fields.TS_PROTOCOL;
|
||||||
|
|
||||||
public class BinaryProtocolProxy {
|
public class BinaryProtocolProxy {
|
||||||
public static void createProxy(Logger logger, IoStream targetEcuSocket, int serverProxyPort) {
|
public static ServerHolder createProxy(Logger logger, IoStream targetEcuSocket, int serverProxyPort) {
|
||||||
Function<Socket, Runnable> clientSocketRunnableFactory = new Function<Socket, Runnable>() {
|
Function<Socket, Runnable> clientSocketRunnableFactory = clientSocket -> () -> {
|
||||||
@Override
|
|
||||||
public Runnable apply(Socket clientSocket) {
|
|
||||||
return new Runnable() {
|
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
try {
|
try {
|
||||||
TcpIoStream clientStream = new TcpIoStream("[[proxy]] ", logger, clientSocket);
|
TcpIoStream clientStream = new TcpIoStream("[[proxy]] ", logger, clientSocket);
|
||||||
runProxy(targetEcuSocket, clientStream);
|
runProxy(targetEcuSocket, clientStream);
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
logger.error("BinaryProtocolProxy::run" + e);
|
logger.error("BinaryProtocolProxy::run" + e);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
};
|
};
|
||||||
}
|
return BinaryProtocolServer.tcpServerSocket(serverProxyPort, "proxy", clientSocketRunnableFactory, Logger.CONSOLE, null);
|
||||||
};
|
|
||||||
BinaryProtocolServer.tcpServerSocket(serverProxyPort, "proxy", clientSocketRunnableFactory, Logger.CONSOLE, null);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void runProxy(IoStream targetEcu, IoStream clientStream) throws IOException {
|
public static void runProxy(IoStream targetEcu, IoStream clientStream) throws IOException {
|
||||||
/*
|
/*
|
||||||
* Each client socket is running on it's own thread
|
* Each client socket is running on it's own thread
|
||||||
*/
|
*/
|
||||||
|
//noinspection InfiniteLoopStatement
|
||||||
while (true) {
|
while (true) {
|
||||||
byte firstByte = clientStream.getDataBuffer().readByte();
|
byte firstByte = clientStream.getDataBuffer().readByte();
|
||||||
if (firstByte == COMMAND_PROTOCOL) {
|
if (firstByte == COMMAND_PROTOCOL) {
|
||||||
|
|
|
@ -10,6 +10,7 @@ import com.rusefi.io.IoStream;
|
||||||
import com.rusefi.io.LinkManager;
|
import com.rusefi.io.LinkManager;
|
||||||
import com.rusefi.io.commands.HelloCommand;
|
import com.rusefi.io.commands.HelloCommand;
|
||||||
import com.rusefi.server.rusEFISSLContext;
|
import com.rusefi.server.rusEFISSLContext;
|
||||||
|
import com.rusefi.shared.FileUtil;
|
||||||
|
|
||||||
import java.io.*;
|
import java.io.*;
|
||||||
import java.net.ServerSocket;
|
import java.net.ServerSocket;
|
||||||
|
@ -75,24 +76,33 @@ public class BinaryProtocolServer implements BinaryProtocolCommands {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Starts a new thread
|
* Starts a new thread
|
||||||
*
|
|
||||||
* @param port server port to accept connections
|
* @param port server port to accept connections
|
||||||
* @param threadName
|
* @param threadName
|
||||||
* @param socketRunnableFactory 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
|
||||||
|
* @return
|
||||||
*/
|
*/
|
||||||
public static void tcpServerSocket(int port, String threadName, Function<Socket, Runnable> socketRunnableFactory, final Logger logger, Listener serverSocketCreationCallback) {
|
public static ServerHolder tcpServerSocket(int port, String threadName, Function<Socket, Runnable> socketRunnableFactory, final Logger logger, Listener serverSocketCreationCallback) {
|
||||||
tcpServerSocket(logger, socketRunnableFactory, port, threadName, serverSocketCreationCallback, PLAIN_SOCKET_FACTORY);
|
return tcpServerSocket(logger, socketRunnableFactory, port, threadName, serverSocketCreationCallback, PLAIN_SOCKET_FACTORY);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void tcpServerSocket(Logger logger, Function<Socket, Runnable> clientSocketRunnableFactory, int port, String threadName, Listener serverSocketCreationCallback, Function<Integer, ServerSocket> nonSecureSocketFunction) {
|
public static ServerHolder tcpServerSocket(Logger logger, Function<Socket, Runnable> clientSocketRunnableFactory, int port, String threadName, Listener serverSocketCreationCallback, Function<Integer, ServerSocket> nonSecureSocketFunction) {
|
||||||
ServerSocket serverSocket = nonSecureSocketFunction.apply(port);
|
ServerSocket serverSocket = nonSecureSocketFunction.apply(port);
|
||||||
|
|
||||||
|
ServerHolder holder = new ServerHolder() {
|
||||||
|
@Override
|
||||||
|
public void close() {
|
||||||
|
super.close();
|
||||||
|
FileUtil.close(serverSocket);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
if (serverSocketCreationCallback != null)
|
if (serverSocketCreationCallback != null)
|
||||||
serverSocketCreationCallback.onResult(null);
|
serverSocketCreationCallback.onResult(null);
|
||||||
Runnable runnable = () -> {
|
Runnable runnable = () -> {
|
||||||
try {
|
try {
|
||||||
while (true) {
|
while (!holder.isClosed()) {
|
||||||
// Wait for a connection
|
// Wait for a connection
|
||||||
final Socket clientSocket = serverSocket.accept();
|
final Socket clientSocket = serverSocket.accept();
|
||||||
logger.info("Binary protocol proxy port connection");
|
logger.info("Binary protocol proxy port connection");
|
||||||
|
@ -103,6 +113,7 @@ public class BinaryProtocolServer implements BinaryProtocolCommands {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
new Thread(runnable, threadName).start();
|
new Thread(runnable, threadName).start();
|
||||||
|
return holder;
|
||||||
}
|
}
|
||||||
|
|
||||||
@SuppressWarnings("InfiniteLoopStatement")
|
@SuppressWarnings("InfiniteLoopStatement")
|
||||||
|
|
|
@ -0,0 +1,15 @@
|
||||||
|
package com.rusefi.io.tcp;
|
||||||
|
|
||||||
|
import java.io.Closeable;
|
||||||
|
|
||||||
|
public class ServerHolder implements Closeable {
|
||||||
|
private boolean isClosed;
|
||||||
|
|
||||||
|
public void close() {
|
||||||
|
isClosed = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean isClosed() {
|
||||||
|
return isClosed;
|
||||||
|
}
|
||||||
|
}
|
|
@ -2,8 +2,6 @@ package com.rusefi.server;
|
||||||
|
|
||||||
import com.rusefi.tools.online.HttpUtil;
|
import com.rusefi.tools.online.HttpUtil;
|
||||||
import org.json.simple.JSONObject;
|
import org.json.simple.JSONObject;
|
||||||
import org.json.simple.parser.JSONParser;
|
|
||||||
import org.json.simple.parser.ParseException;
|
|
||||||
|
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
|
|
||||||
|
|
|
@ -3,8 +3,6 @@ package com.rusefi.server;
|
||||||
import com.rusefi.tools.online.HttpUtil;
|
import com.rusefi.tools.online.HttpUtil;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
import org.json.simple.JSONObject;
|
import org.json.simple.JSONObject;
|
||||||
import org.json.simple.parser.JSONParser;
|
|
||||||
import org.json.simple.parser.ParseException;
|
|
||||||
|
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
|
|
||||||
|
|
|
@ -15,7 +15,7 @@ import java.io.IOException;
|
||||||
public class HttpUtil {
|
public class HttpUtil {
|
||||||
// todo: migrate proxy http json API server to TLS
|
// todo: migrate proxy http json API server to TLS
|
||||||
public static final String RUSEFI_PROXY_JSON_PROTOCOL = "http://";
|
public static final String RUSEFI_PROXY_JSON_PROTOCOL = "http://";
|
||||||
public static final int HTTP_PORT = 8001;
|
public static final int PROXY_JSON_API_HTTP_PORT = 8001;
|
||||||
/**
|
/**
|
||||||
* hostname of PROXY server, not primary rusEFI web server - those are two separate hosts at the moment
|
* hostname of PROXY server, not primary rusEFI web server - those are two separate hosts at the moment
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -62,7 +62,7 @@ public class ConsoleTools {
|
||||||
registerTool("compile_fsio_line", ConsoleTools::invokeCompileExpressionTool, "Convert a line to RPN form.");
|
registerTool("compile_fsio_line", ConsoleTools::invokeCompileExpressionTool, "Convert a line to RPN form.");
|
||||||
registerTool("compile_fsio_file", ConsoleTools::runCompileTool, "Convert all lines from a file to RPN form.");
|
registerTool("compile_fsio_file", ConsoleTools::runCompileTool, "Convert all lines from a file to RPN form.");
|
||||||
|
|
||||||
registerTool("proxy_server", BackendLauncher::start, "NOT A USER TOOL");
|
registerTool("proxy_server", a -> BackendLauncher.start(), "NOT A USER TOOL");
|
||||||
registerTool("network_connector", NetworkConnectorStartup::start, "Connect your rusEFI ECU to rusEFI Online");
|
registerTool("network_connector", NetworkConnectorStartup::start, "Connect your rusEFI ECU to rusEFI Online");
|
||||||
registerTool("network_authenticator", LocalApplicationProxy::start, "rusEFI Online Authenticator");
|
registerTool("network_authenticator", LocalApplicationProxy::start, "rusEFI Online Authenticator");
|
||||||
|
|
||||||
|
|
|
@ -33,6 +33,7 @@ import static com.rusefi.Timeouts.SECOND;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* See NetworkConnectorStartup
|
* See NetworkConnectorStartup
|
||||||
|
* @see BackendLauncher
|
||||||
*/
|
*/
|
||||||
public class Backend implements Closeable {
|
public class Backend implements Closeable {
|
||||||
public static final int SERVER_PORT_FOR_CONTROLLERS = 8003;
|
public static final int SERVER_PORT_FOR_CONTROLLERS = 8003;
|
||||||
|
|
|
@ -4,24 +4,21 @@ import com.opensr5.Logger;
|
||||||
import com.rusefi.LocalApplicationProxy;
|
import com.rusefi.LocalApplicationProxy;
|
||||||
import com.rusefi.tools.online.HttpUtil;
|
import com.rusefi.tools.online.HttpUtil;
|
||||||
|
|
||||||
import java.net.MalformedURLException;
|
|
||||||
|
|
||||||
public class BackendLauncher {
|
public class BackendLauncher {
|
||||||
/**
|
/**
|
||||||
* need this method to be not in Backend class for console to work without all backend classes
|
* need this method to be not in Backend class for console to work without all backend classes
|
||||||
*/
|
*/
|
||||||
public static void start(String[] args) throws MalformedURLException {
|
public static void start() {
|
||||||
/* todo
|
/* todo
|
||||||
rusEFISSLContext.setupCertificates(new File("keystore.jks"), System.getProperty("RUSEFI_PROXY_PASSWORD"));
|
rusEFISSLContext.setupCertificates(new File("keystore.jks"), System.getProperty("RUSEFI_PROXY_PASSWORD"));
|
||||||
*/
|
*/
|
||||||
|
|
||||||
UserDetailsResolver userDetailsFunction = new JsonUserDetailsResolver();
|
UserDetailsResolver userDetailsFunction = new JsonUserDetailsResolver();
|
||||||
|
|
||||||
Backend backend = new Backend(userDetailsFunction, HttpUtil.HTTP_PORT, Logger.CONSOLE);
|
Backend backend = new Backend(userDetailsFunction, HttpUtil.PROXY_JSON_API_HTTP_PORT, Logger.CONSOLE);
|
||||||
backend.runApplicationConnector(LocalApplicationProxy.SERVER_PORT_FOR_APPLICATIONS, parameter -> {
|
backend.runApplicationConnector(LocalApplicationProxy.SERVER_PORT_FOR_APPLICATIONS, parameter -> {
|
||||||
});
|
});
|
||||||
backend.runControllerConnector(Backend.SERVER_PORT_FOR_CONTROLLERS, parameter -> {
|
backend.runControllerConnector(Backend.SERVER_PORT_FOR_CONTROLLERS, parameter -> {
|
||||||
});
|
});
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,18 +1,24 @@
|
||||||
package com.rusefi.ts_plugin;
|
package com.rusefi.ts_plugin;
|
||||||
|
|
||||||
|
import com.opensr5.Logger;
|
||||||
import com.rusefi.LocalApplicationProxy;
|
import com.rusefi.LocalApplicationProxy;
|
||||||
import com.rusefi.NamedThreadFactory;
|
import com.rusefi.NamedThreadFactory;
|
||||||
import com.rusefi.SignatureHelper;
|
import com.rusefi.SignatureHelper;
|
||||||
import com.rusefi.autoupdate.AutoupdateUtil;
|
import com.rusefi.autoupdate.AutoupdateUtil;
|
||||||
|
import com.rusefi.server.ApplicationRequest;
|
||||||
import com.rusefi.server.ControllerInfo;
|
import com.rusefi.server.ControllerInfo;
|
||||||
|
import com.rusefi.server.SessionDetails;
|
||||||
import com.rusefi.tools.online.HttpUtil;
|
import com.rusefi.tools.online.HttpUtil;
|
||||||
import com.rusefi.tools.online.ProxyClient;
|
import com.rusefi.tools.online.ProxyClient;
|
||||||
import com.rusefi.tools.online.PublicSession;
|
import com.rusefi.tools.online.PublicSession;
|
||||||
|
import com.rusefi.ui.AuthTokenPanel;
|
||||||
import com.rusefi.ui.util.URLLabel;
|
import com.rusefi.ui.util.URLLabel;
|
||||||
import org.putgemin.VerticalFlowLayout;
|
import org.putgemin.VerticalFlowLayout;
|
||||||
|
|
||||||
import javax.swing.*;
|
import javax.swing.*;
|
||||||
import java.awt.*;
|
import java.awt.*;
|
||||||
|
import java.awt.event.ActionEvent;
|
||||||
|
import java.awt.event.ActionListener;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.concurrent.Executor;
|
import java.util.concurrent.Executor;
|
||||||
|
@ -37,7 +43,7 @@ public class RemoteTab {
|
||||||
refresh.addActionListener(e -> requestListDownload());
|
refresh.addActionListener(e -> requestListDownload());
|
||||||
|
|
||||||
JTextField applicationPort = new JTextField();
|
JTextField applicationPort = new JTextField();
|
||||||
String portProperty = getConfig().getRoot().getProperty(APPLICATION_PORT, Integer.toString(LocalApplicationProxy.SERVER_PORT_FOR_APPLICATIONS));
|
String portProperty = getLocalPort();
|
||||||
applicationPort.setText(portProperty);
|
applicationPort.setText(portProperty);
|
||||||
|
|
||||||
|
|
||||||
|
@ -52,26 +58,20 @@ public class RemoteTab {
|
||||||
requestListDownload();
|
requestListDownload();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private String getLocalPort() {
|
||||||
|
return getConfig().getRoot().getProperty(APPLICATION_PORT, Integer.toString(LocalApplicationProxy.SERVER_PORT_FOR_APPLICATIONS));
|
||||||
|
}
|
||||||
|
|
||||||
private void requestListDownload() {
|
private void requestListDownload() {
|
||||||
listDownloadExecutor.execute(new Runnable() {
|
listDownloadExecutor.execute(() -> {
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
List<PublicSession> userDetails;
|
List<PublicSession> userDetails;
|
||||||
try {
|
try {
|
||||||
userDetails = ProxyClient.getOnlineApplications(HttpUtil.HTTP_PORT);
|
userDetails = ProxyClient.getOnlineApplications(HttpUtil.RUSEFI_PROXY_JSON_PROTOCOL);
|
||||||
SwingUtilities.invokeLater(new Runnable() {
|
SwingUtilities.invokeLater(() -> showList(userDetails));
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
showList(userDetails);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
System.out.println(userDetails);
|
|
||||||
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -92,7 +92,27 @@ public class RemoteTab {
|
||||||
userPanel.add(new URLLabel(SignatureHelper.getUrl(controllerInfo.getSignature())));
|
userPanel.add(new URLLabel(SignatureHelper.getUrl(controllerInfo.getSignature())));
|
||||||
|
|
||||||
|
|
||||||
userPanel.add(new JButton("Connect"));
|
JButton connect = new JButton("Connect");
|
||||||
|
connect.addActionListener(event -> {
|
||||||
|
|
||||||
|
SessionDetails sessionDetails = new SessionDetails(controllerInfo, AuthTokenPanel.getAuthToken(),
|
||||||
|
Integer.parseInt(oneTimePasswordControl.getText()));
|
||||||
|
|
||||||
|
ApplicationRequest applicationRequest = new ApplicationRequest(sessionDetails, publicSession.getUserDetails().getUserId());
|
||||||
|
|
||||||
|
try {
|
||||||
|
LocalApplicationProxy.startAndRun(Logger.CONSOLE,
|
||||||
|
LocalApplicationProxy.SERVER_PORT_FOR_APPLICATIONS,
|
||||||
|
applicationRequest,
|
||||||
|
HttpUtil.PROXY_JSON_API_HTTP_PORT,
|
||||||
|
Integer.parseInt(getLocalPort()));
|
||||||
|
} catch (IOException e) {
|
||||||
|
// todo: proper handling
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
|
||||||
|
});
|
||||||
|
userPanel.add(connect);
|
||||||
|
|
||||||
return userPanel;
|
return userPanel;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue