mirror of
https://github.com/sirjonasxx/G-Earth.git
synced 2024-11-23 08:50:52 +01:00
support for installing extensions, working extensions filesystem
This commit is contained in:
parent
697be8af76
commit
86c546adc6
3
src/META-INF/MANIFEST.MF
Normal file
3
src/META-INF/MANIFEST.MF
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
Manifest-Version: 1.0
|
||||||
|
Main-Class: main.extensions.examples.AdminOnConnect
|
||||||
|
|
@ -4,10 +4,7 @@ import main.protocol.HMessage;
|
|||||||
import main.protocol.HPacket;
|
import main.protocol.HPacket;
|
||||||
import main.ui.extensions.Extensions;
|
import main.ui.extensions.Extensions;
|
||||||
|
|
||||||
import java.io.DataInputStream;
|
import java.io.*;
|
||||||
import java.io.IOException;
|
|
||||||
import java.io.InputStream;
|
|
||||||
import java.io.OutputStream;
|
|
||||||
import java.net.Socket;
|
import java.net.Socket;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
@ -63,7 +60,15 @@ public abstract class Extension {
|
|||||||
|
|
||||||
while (!gEarthExtensionServer.isClosed()) {
|
while (!gEarthExtensionServer.isClosed()) {
|
||||||
|
|
||||||
int length = dIn.readInt();
|
int length;
|
||||||
|
try {
|
||||||
|
length = dIn.readInt();
|
||||||
|
}
|
||||||
|
catch(EOFException exception) {
|
||||||
|
//g-earth closed the extension
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
byte[] headerandbody = new byte[length + 4];
|
byte[] headerandbody = new byte[length + 4];
|
||||||
|
|
||||||
int amountRead = 0;
|
int amountRead = 0;
|
||||||
@ -142,10 +147,11 @@ public abstract class Extension {
|
|||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
System.out.println("Extension closed");
|
||||||
|
|
||||||
} catch (IOException | ArrayIndexOutOfBoundsException e) {
|
} catch (IOException | ArrayIndexOutOfBoundsException e) {
|
||||||
e.printStackTrace();
|
System.err.println("Connection failed; is G-Earth open?");
|
||||||
|
// e.printStackTrace();
|
||||||
}
|
}
|
||||||
finally {
|
finally {
|
||||||
if (gEarthExtensionServer != null && !gEarthExtensionServer.isClosed()) {
|
if (gEarthExtensionServer != null && !gEarthExtensionServer.isClosed()) {
|
||||||
|
@ -20,7 +20,7 @@ public class AdminOnConnect extends Extension {
|
|||||||
private boolean done = true;
|
private boolean done = true;
|
||||||
|
|
||||||
protected void init() {
|
protected void init() {
|
||||||
intercept(HMessage.Side.TOCLIENT, -1, message -> {
|
intercept(HMessage.Side.TOCLIENT, message -> {
|
||||||
if (!done) {
|
if (!done) {
|
||||||
HPacket packet = message.getPacket();
|
HPacket packet = message.getPacket();
|
||||||
if (packet.length() == 11) {
|
if (packet.length() == 11) {
|
||||||
|
@ -83,7 +83,7 @@
|
|||||||
<Insets left="3.0" />
|
<Insets left="3.0" />
|
||||||
</GridPane.margin>
|
</GridPane.margin>
|
||||||
</Label>
|
</Label>
|
||||||
<Button fx:id="btn_install" disable="true" maxHeight="1.7976931348623157E308" maxWidth="1.7976931348623157E308" mnemonicParsing="false" onAction="#installBtnClicked" text="Install" GridPane.columnIndex="3" />
|
<Button fx:id="btn_install" maxHeight="1.7976931348623157E308" maxWidth="1.7976931348623157E308" mnemonicParsing="false" onAction="#installBtnClicked" text="Install" GridPane.columnIndex="3" />
|
||||||
</children>
|
</children>
|
||||||
</GridPane>
|
</GridPane>
|
||||||
</children>
|
</children>
|
||||||
|
@ -9,10 +9,19 @@ import javafx.scene.control.ScrollPane;
|
|||||||
import javafx.scene.control.TextField;
|
import javafx.scene.control.TextField;
|
||||||
import javafx.scene.layout.GridPane;
|
import javafx.scene.layout.GridPane;
|
||||||
import javafx.scene.layout.VBox;
|
import javafx.scene.layout.VBox;
|
||||||
|
import javafx.stage.FileChooser;
|
||||||
import main.Main;
|
import main.Main;
|
||||||
import main.protocol.*;
|
import main.protocol.*;
|
||||||
import main.ui.SubForm;
|
import main.ui.SubForm;
|
||||||
|
import main.ui.extensions.executer.ExecutionInfo;
|
||||||
|
import main.ui.extensions.executer.ExtensionRunner;
|
||||||
|
import main.ui.extensions.executer.ExtensionRunnerFactory;
|
||||||
|
import main.ui.scheduler.ScheduleItem;
|
||||||
|
import sun.misc.ExtensionInfo;
|
||||||
|
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileReader;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.net.ServerSocket;
|
import java.net.ServerSocket;
|
||||||
import java.util.*;
|
import java.util.*;
|
||||||
@ -108,6 +117,9 @@ public class Extensions extends SubForm {
|
|||||||
public GridPane header_ext;
|
public GridPane header_ext;
|
||||||
public ScrollPane scroller;
|
public ScrollPane scroller;
|
||||||
|
|
||||||
|
private ExtensionRunner extensionRunner = null;
|
||||||
|
private GEarthExtensionsRegistrer extensionsRegistrer = null;
|
||||||
|
|
||||||
public static class OUTGOING_MESSAGES_IDS {
|
public static class OUTGOING_MESSAGES_IDS {
|
||||||
public static final int ONDOUBLECLICK = 1;
|
public static final int ONDOUBLECLICK = 1;
|
||||||
public static final int INFOREQUEST = 2; // backend: implemented
|
public static final int INFOREQUEST = 2; // backend: implemented
|
||||||
@ -138,6 +150,8 @@ public class Extensions extends SubForm {
|
|||||||
}
|
}
|
||||||
|
|
||||||
protected void onParentSet() {
|
protected void onParentSet() {
|
||||||
|
|
||||||
|
|
||||||
getHConnection().addStateChangeListener((oldState, newState) -> {
|
getHConnection().addStateChangeListener((oldState, newState) -> {
|
||||||
if (newState == HConnection.State.CONNECTED) {
|
if (newState == HConnection.State.CONNECTED) {
|
||||||
for (GEarthExtension extension : gEarthExtensions) {
|
for (GEarthExtension extension : gEarthExtensions) {
|
||||||
@ -217,7 +231,6 @@ public class Extensions extends SubForm {
|
|||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
GEarthExtensionsRegistrer extensionsRegistrer = null;
|
|
||||||
HashMap<GEarthExtension, GEarthExtension.ReceiveMessageListener> messageListeners = new HashMap<>();
|
HashMap<GEarthExtension, GEarthExtension.ReceiveMessageListener> messageListeners = new HashMap<>();
|
||||||
try {
|
try {
|
||||||
extensionsRegistrer = new GEarthExtensionsRegistrer(new GEarthExtensionsRegistrer.ExtensionRegisterObserver() {
|
extensionsRegistrer = new GEarthExtensionsRegistrer(new GEarthExtensionsRegistrer.ExtensionRegisterObserver() {
|
||||||
@ -287,9 +300,22 @@ public class Extensions extends SubForm {
|
|||||||
|
|
||||||
ext_port.setText(extensionsRegistrer.getPort()+"");
|
ext_port.setText(extensionsRegistrer.getPort()+"");
|
||||||
// System.out.println("Extension server registered on port: " + extensionsRegistrer.getPort());
|
// System.out.println("Extension server registered on port: " + extensionsRegistrer.getPort());
|
||||||
|
|
||||||
|
extensionRunner = ExtensionRunnerFactory.get();
|
||||||
|
extensionRunner.runAllExtensions(extensionsRegistrer.getPort());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public void installBtnClicked(ActionEvent actionEvent) {
|
public void installBtnClicked(ActionEvent actionEvent) {
|
||||||
|
List<ScheduleItem> list = new ArrayList<>();
|
||||||
|
|
||||||
|
FileChooser fileChooser = new FileChooser();
|
||||||
|
fileChooser.setTitle("Install extension");
|
||||||
|
fileChooser.getExtensionFilters().addAll(
|
||||||
|
new FileChooser.ExtensionFilter("G-Earth extensions", ExecutionInfo.ALLOWEDEXTENSIONTYPES));
|
||||||
|
File selectedFile = fileChooser.showOpenDialog(parentController.getStage());
|
||||||
|
if (selectedFile != null) {
|
||||||
|
extensionRunner.installAndRunExtension(selectedFile.getPath(), extensionsRegistrer.getPort());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
32
src/main/ui/extensions/executer/ExecutionInfo.java
Normal file
32
src/main/ui/extensions/executer/ExecutionInfo.java
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
package main.ui.extensions.executer;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Created by Jonas on 22/09/18.
|
||||||
|
*/
|
||||||
|
public class ExecutionInfo {
|
||||||
|
|
||||||
|
private static Map<String, String> extensionTypeToExecutionCommand;
|
||||||
|
public final static List<String> ALLOWEDEXTENSIONTYPES;
|
||||||
|
public final static String EXTENSIONSDIRECTORY = "Extensions";
|
||||||
|
|
||||||
|
static {
|
||||||
|
extensionTypeToExecutionCommand = new HashMap<>();
|
||||||
|
extensionTypeToExecutionCommand.put("*.jar","java -jar {path} -p {port}");
|
||||||
|
extensionTypeToExecutionCommand.put("*.py","python {path} -p {port}");
|
||||||
|
extensionTypeToExecutionCommand.put("*.py3","python3 {path} -p {port}");
|
||||||
|
extensionTypeToExecutionCommand.put("*.sh","{path} -p {port}");
|
||||||
|
extensionTypeToExecutionCommand.put("*.exe","{path} -p {port}");
|
||||||
|
|
||||||
|
ALLOWEDEXTENSIONTYPES = new ArrayList<>(extensionTypeToExecutionCommand.keySet());
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String getExecutionCommand(String type) {
|
||||||
|
return extensionTypeToExecutionCommand.get(type);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
18
src/main/ui/extensions/executer/ExtensionRunner.java
Normal file
18
src/main/ui/extensions/executer/ExtensionRunner.java
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
package main.ui.extensions.executer;
|
||||||
|
|
||||||
|
import java.nio.file.Path;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Created by Jonas on 21/09/18.
|
||||||
|
*/
|
||||||
|
public interface ExtensionRunner {
|
||||||
|
|
||||||
|
void runAllExtensions(int port);
|
||||||
|
|
||||||
|
void installAndRunExtension(String path, int port);
|
||||||
|
|
||||||
|
}
|
14
src/main/ui/extensions/executer/ExtensionRunnerFactory.java
Normal file
14
src/main/ui/extensions/executer/ExtensionRunnerFactory.java
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
package main.ui.extensions.executer;
|
||||||
|
|
||||||
|
import main.misc.OSValidator;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Created by Jonas on 22/09/18.
|
||||||
|
*/
|
||||||
|
public class ExtensionRunnerFactory {
|
||||||
|
|
||||||
|
public static ExtensionRunner get() {
|
||||||
|
|
||||||
|
return new NormalExtensionRunner();
|
||||||
|
}
|
||||||
|
}
|
110
src/main/ui/extensions/executer/NormalExtensionRunner.java
Normal file
110
src/main/ui/extensions/executer/NormalExtensionRunner.java
Normal file
@ -0,0 +1,110 @@
|
|||||||
|
package main.ui.extensions.executer;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.nio.file.*;
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.Random;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Created by Jonas on 22/09/18.
|
||||||
|
*/
|
||||||
|
public class NormalExtensionRunner implements ExtensionRunner {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void runAllExtensions(int port) {
|
||||||
|
if (dirExists(ExecutionInfo.EXTENSIONSDIRECTORY)){
|
||||||
|
File folder =
|
||||||
|
new File(FileSystems.getDefault().getPath(".").toString() +
|
||||||
|
FileSystems.getDefault().getSeparator() +
|
||||||
|
ExecutionInfo.EXTENSIONSDIRECTORY);
|
||||||
|
|
||||||
|
File[] childs = folder.listFiles();
|
||||||
|
|
||||||
|
for (File file : childs) {
|
||||||
|
tryRunExtension(file.getPath(), port);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void installAndRunExtension(String path, int port) {
|
||||||
|
if (!dirExists(ExecutionInfo.EXTENSIONSDIRECTORY)) {
|
||||||
|
createDirectory(ExecutionInfo.EXTENSIONSDIRECTORY);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
String name = Paths.get(path).getFileName().toString();
|
||||||
|
String[] split = name.split("\\.");
|
||||||
|
String ext = "*." + split[split.length - 1];
|
||||||
|
|
||||||
|
String realname = String.join(".",Arrays.copyOf(split, split.length-1));
|
||||||
|
String newname = realname + "-" + getRandomString() + ext.substring(1);
|
||||||
|
|
||||||
|
|
||||||
|
Path originalPath = Paths.get(path);
|
||||||
|
Path newPath = Paths.get(
|
||||||
|
FileSystems.getDefault().getPath(".").toString(),
|
||||||
|
ExecutionInfo.EXTENSIONSDIRECTORY,
|
||||||
|
newname
|
||||||
|
);
|
||||||
|
|
||||||
|
try {
|
||||||
|
Files.copy(
|
||||||
|
originalPath,
|
||||||
|
newPath
|
||||||
|
);
|
||||||
|
|
||||||
|
addExecPermission(newPath.toString());
|
||||||
|
tryRunExtension(newPath.toString(), port);
|
||||||
|
|
||||||
|
} catch (IOException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
private void tryRunExtension(String path, int port) {
|
||||||
|
try {
|
||||||
|
Runtime.getRuntime().exec(
|
||||||
|
ExecutionInfo.getExecutionCommand(getFileExtension(path))
|
||||||
|
.replace("{path}", path)
|
||||||
|
.replace("{port}", port+"")
|
||||||
|
);
|
||||||
|
} catch (IOException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void addExecPermission(String path) {
|
||||||
|
//not needed at first sight
|
||||||
|
}
|
||||||
|
|
||||||
|
private String getFileExtension(String path) {
|
||||||
|
String name = Paths.get(path).getFileName().toString();
|
||||||
|
String[] split = name.split("\\.");
|
||||||
|
return "*." + split[split.length - 1];
|
||||||
|
}
|
||||||
|
private boolean dirExists(String dir) {
|
||||||
|
return Files.isDirectory(Paths.get(FileSystems.getDefault().getPath(".").toString(), dir));
|
||||||
|
}
|
||||||
|
private void createDirectory(String dir) {
|
||||||
|
if (!dirExists(dir)) {
|
||||||
|
try {
|
||||||
|
Files.createDirectories(Paths.get(FileSystems.getDefault().getPath(".").toString(), dir));
|
||||||
|
} catch (IOException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
private String getRandomString() {
|
||||||
|
StringBuilder builder = new StringBuilder();
|
||||||
|
Random r = new Random();
|
||||||
|
for (int i = 0; i < 10; i++) {
|
||||||
|
builder.append(r.nextInt(10));
|
||||||
|
}
|
||||||
|
|
||||||
|
return builder.toString();
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user