Compare commits
2 commits
3690c63399
...
dc995e1bae
Author | SHA1 | Date | |
---|---|---|---|
|
dc995e1bae | ||
|
51938df434 |
3 changed files with 70 additions and 6 deletions
|
@ -61,6 +61,11 @@ public class CommandLineInterface {
|
|||
new TinfoilNet(tfnArguments);
|
||||
return;
|
||||
}
|
||||
if (cli.hasOption("t") || cli.hasOption("tinfoil")){
|
||||
final String[] tfArguments = cli.getOptionValues("tinfoil");
|
||||
new TinfoilUsb(tfArguments);
|
||||
return;
|
||||
}
|
||||
}
|
||||
catch (ParseException pe){
|
||||
System.out.println(pe.getLocalizedMessage() +
|
||||
|
@ -116,6 +121,13 @@ public class CommandLineInterface {
|
|||
.hasArgs()
|
||||
.argName("...")
|
||||
.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();
|
||||
|
@ -124,6 +136,7 @@ public class CommandLineInterface {
|
|||
group.addOption(cleanSettingsOption);
|
||||
group.addOption(versionOption);
|
||||
group.addOption(helpOption);
|
||||
group.addOption(tinfoilOption);
|
||||
|
||||
options.addOptionGroup(group);
|
||||
|
||||
|
|
|
@ -27,7 +27,7 @@ import java.util.List;
|
|||
// TODO: Add 'don't serve requests' option
|
||||
public class TinfoilNet {
|
||||
|
||||
private String[] arguments;
|
||||
private final String[] arguments;
|
||||
|
||||
private String nsIp;
|
||||
|
||||
|
@ -43,7 +43,7 @@ public class TinfoilNet {
|
|||
this.arguments = arguments;
|
||||
checkArguments();
|
||||
parseNsIP();
|
||||
parseHostIPAndExtras();
|
||||
parseHostSettings();
|
||||
parseFilesArguments();
|
||||
runTinfoilNetBackend();
|
||||
}
|
||||
|
@ -73,8 +73,8 @@ public class TinfoilNet {
|
|||
private boolean isHelpDirective(String argument){
|
||||
return argument.equals("help");
|
||||
}
|
||||
private void showHelp(){
|
||||
System.out.println("Usage:\n"
|
||||
private void showHelp() throws IncorrectSetupException{
|
||||
throw new IncorrectSetupException("Usage:\n"
|
||||
+ "\tns-usbloader -n nsip=<arg1> [hostip=<arg2>] FILE1 ...\n"
|
||||
+ "\tns-usbloader --tfn nsip=<arg1> [hostip=<arg2>] FILE1 ..."
|
||||
+ "\n\nOptions:"
|
||||
|
@ -96,7 +96,7 @@ public class TinfoilNet {
|
|||
"Try 'ns-usbloader -n help' for more information.");
|
||||
}
|
||||
|
||||
private void parseHostIPAndExtras(){
|
||||
private void parseHostSettings(){
|
||||
String argument2 = arguments[1];
|
||||
|
||||
if (! argument2.startsWith("hostip="))
|
||||
|
@ -123,7 +123,7 @@ public class TinfoilNet {
|
|||
}
|
||||
|
||||
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.");
|
||||
}
|
||||
}
|
||||
|
|
51
src/main/java/nsusbloader/cli/TinfoilUsb.java
Normal file
51
src/main/java/nsusbloader/cli/TinfoilUsb.java
Normal 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();
|
||||
}
|
||||
}
|
Loading…
Reference in a new issue