mirror of
https://github.com/sparrowwallet/sparrow.git
synced 2024-12-25 05:06:45 +00:00
handle quotes in connected device passphrase on windows
This commit is contained in:
parent
4cbb402931
commit
d76aecb34d
1 changed files with 11 additions and 2 deletions
|
@ -43,7 +43,7 @@ public class Hwi {
|
||||||
try {
|
try {
|
||||||
List<String> command;
|
List<String> command;
|
||||||
if(passphrase != null && !passphrase.isEmpty()) {
|
if(passphrase != null && !passphrase.isEmpty()) {
|
||||||
command = List.of(getHwiExecutable(Command.ENUMERATE).getAbsolutePath(), "--password", passphrase, Command.ENUMERATE.toString());
|
command = List.of(getHwiExecutable(Command.ENUMERATE).getAbsolutePath(), "--password", escape(passphrase), Command.ENUMERATE.toString());
|
||||||
} else {
|
} else {
|
||||||
command = List.of(getHwiExecutable(Command.ENUMERATE).getAbsolutePath(), Command.ENUMERATE.toString());
|
command = List.of(getHwiExecutable(Command.ENUMERATE).getAbsolutePath(), Command.ENUMERATE.toString());
|
||||||
}
|
}
|
||||||
|
@ -414,7 +414,7 @@ public class Hwi {
|
||||||
}
|
}
|
||||||
|
|
||||||
private List<String> getDeviceCommand(Device device, String passphrase, Command command, String... commandData) throws IOException {
|
private List<String> getDeviceCommand(Device device, String passphrase, Command command, String... commandData) throws IOException {
|
||||||
List<String> elements = new ArrayList<>(List.of(getHwiExecutable(command).getAbsolutePath(), "--device-path", device.getPath(), "--device-type", device.getType(), "--password", passphrase, command.toString()));
|
List<String> elements = new ArrayList<>(List.of(getHwiExecutable(command).getAbsolutePath(), "--device-path", device.getPath(), "--device-type", device.getType(), "--password", escape(passphrase), command.toString()));
|
||||||
addChainType(elements);
|
addChainType(elements);
|
||||||
elements.addAll(Arrays.stream(commandData).filter(Objects::nonNull).collect(Collectors.toList()));
|
elements.addAll(Arrays.stream(commandData).filter(Objects::nonNull).collect(Collectors.toList()));
|
||||||
return elements;
|
return elements;
|
||||||
|
@ -437,6 +437,15 @@ public class Hwi {
|
||||||
return network.toString();
|
return network.toString();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private String escape(String passphrase) {
|
||||||
|
Platform platform = Platform.getCurrent();
|
||||||
|
if(platform == Platform.WINDOWS) {
|
||||||
|
return passphrase.replace("\"", "\\\"");
|
||||||
|
}
|
||||||
|
|
||||||
|
return passphrase;
|
||||||
|
}
|
||||||
|
|
||||||
public static class EnumerateService extends Service<List<Device>> {
|
public static class EnumerateService extends Service<List<Device>> {
|
||||||
private final String passphrase;
|
private final String passphrase;
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue