Compare commits

...

2 commits

Author SHA1 Message Date
Dmitry Isaenko
dc995e1bae Add CLI support for Tinfoil/Awoo USB-install mode. 2020-07-06 14:27:35 +03:00
Dmitry Isaenko
51938df434 Minor fixes for CLI Tinfoil/Awoo Net-install mode. 2020-07-06 14:06:59 +03:00
3 changed files with 70 additions and 6 deletions

View file

@ -61,6 +61,11 @@ public class CommandLineInterface {
new TinfoilNet(tfnArguments); new TinfoilNet(tfnArguments);
return; return;
} }
if (cli.hasOption("t") || cli.hasOption("tinfoil")){
final String[] tfArguments = cli.getOptionValues("tinfoil");
new TinfoilUsb(tfArguments);
return;
}
} }
catch (ParseException pe){ catch (ParseException pe){
System.out.println(pe.getLocalizedMessage() + System.out.println(pe.getLocalizedMessage() +
@ -116,6 +121,13 @@ public class CommandLineInterface {
.hasArgs() .hasArgs()
.argName("...") .argName("...")
.build(); .build();
/* Tinfoil/Awoo USB */
final Option tinfoilOption = Option.builder("t")
.longOpt("tinfoil")
.desc("Install via Tinfoil/Awoo USB mode.")
.hasArgs()
.argName("FILE1 ...")
.build();
final OptionGroup group = new OptionGroup(); final OptionGroup group = new OptionGroup();
@ -124,6 +136,7 @@ public class CommandLineInterface {
group.addOption(cleanSettingsOption); group.addOption(cleanSettingsOption);
group.addOption(versionOption); group.addOption(versionOption);
group.addOption(helpOption); group.addOption(helpOption);
group.addOption(tinfoilOption);
options.addOptionGroup(group); options.addOptionGroup(group);

View file

@ -27,7 +27,7 @@ import java.util.List;
// TODO: Add 'don't serve requests' option // TODO: Add 'don't serve requests' option
public class TinfoilNet { public class TinfoilNet {
private String[] arguments; private final String[] arguments;
private String nsIp; private String nsIp;
@ -43,7 +43,7 @@ public class TinfoilNet {
this.arguments = arguments; this.arguments = arguments;
checkArguments(); checkArguments();
parseNsIP(); parseNsIP();
parseHostIPAndExtras(); parseHostSettings();
parseFilesArguments(); parseFilesArguments();
runTinfoilNetBackend(); runTinfoilNetBackend();
} }
@ -73,8 +73,8 @@ public class TinfoilNet {
private boolean isHelpDirective(String argument){ private boolean isHelpDirective(String argument){
return argument.equals("help"); return argument.equals("help");
} }
private void showHelp(){ private void showHelp() throws IncorrectSetupException{
System.out.println("Usage:\n" throw new IncorrectSetupException("Usage:\n"
+ "\tns-usbloader -n nsip=<arg1> [hostip=<arg2>] FILE1 ...\n" + "\tns-usbloader -n nsip=<arg1> [hostip=<arg2>] FILE1 ...\n"
+ "\tns-usbloader --tfn nsip=<arg1> [hostip=<arg2>] FILE1 ..." + "\tns-usbloader --tfn nsip=<arg1> [hostip=<arg2>] FILE1 ..."
+ "\n\nOptions:" + "\n\nOptions:"
@ -96,7 +96,7 @@ public class TinfoilNet {
"Try 'ns-usbloader -n help' for more information."); "Try 'ns-usbloader -n help' for more information.");
} }
private void parseHostIPAndExtras(){ private void parseHostSettings(){
String argument2 = arguments[1]; String argument2 = arguments[1];
if (! argument2.startsWith("hostip=")) if (! argument2.startsWith("hostip="))
@ -123,7 +123,7 @@ public class TinfoilNet {
} }
if (filesList.size() == 0) { if (filesList.size() == 0) {
throw new IncorrectSetupException("File(s) doesn't exists.\n" + throw new IncorrectSetupException("File(s) doesn't exist.\n" +
"Try 'ns-usbloader -n help' for more information."); "Try 'ns-usbloader -n help' for more information.");
} }
} }

View file

@ -0,0 +1,51 @@
package nsusbloader.cli;
import nsusbloader.COM.ICommunications;
import nsusbloader.COM.USB.UsbCommunications;
import java.io.File;
import java.util.ArrayList;
import java.util.List;
public class TinfoilUsb {
private final String[] arguments;
private List<File> filesList;
public TinfoilUsb(String[] arguments) throws InterruptedException, IncorrectSetupException{
this.arguments = arguments;
checkArguments();
parseFilesArguments();
runTinfoilBackend();
}
private void checkArguments() throws IncorrectSetupException{
if (arguments == null || arguments.length == 0) {
throw new IncorrectSetupException("No files?\n" +
"Try 'ns-usbloader -h' for more information.");
}
}
private void parseFilesArguments() throws IncorrectSetupException{
filesList = new ArrayList<>();
File file;
for (String arg : arguments) {
file = new File(arg);
if (file.exists())
filesList.add(file);
}
if (filesList.size() == 0) {
throw new IncorrectSetupException("File(s) doesn't exist.\n" +
"Try 'ns-usbloader -n help' for more information.");
}
}
private void runTinfoilBackend() throws InterruptedException{
ICommunications task = new UsbCommunications(filesList, "TinFoil", false);
Thread thread = new Thread(task);
thread.start();
thread.join();
}
}