proxy progress - getting REALLY close?!

This commit is contained in:
rusefi 2020-07-23 16:59:47 -04:00
parent 50aad7496f
commit 09d14a4861
11 changed files with 89 additions and 55 deletions

View File

@ -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 {

View File

@ -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) {

View File

@ -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")

View File

@ -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;
}
}

View File

@ -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;

View File

@ -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;

View File

@ -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
*/ */

View File

@ -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");

View File

@ -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;

View File

@ -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 -> {
}); });
} }
} }

View File

@ -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;
} }