summaryrefslogtreecommitdiffhomepage
path: root/app
diff options
context:
space:
mode:
authorSamuel Holland <samuel@sholland.org>2017-08-04 00:37:58 -0500
committerSamuel Holland <samuel@sholland.org>2017-08-04 00:37:58 -0500
commiteb391a084037e8d45bdb4e9a5c0d70adf51a08d2 (patch)
tree160728b95957ad2ecbcdb39b9fb040df89a453f1 /app
parentf37ff3a1e65e6006be95108ec26f01e2c0d1f730 (diff)
RootShell: Make shell command configurable
Diffstat (limited to 'app')
-rw-r--r--app/src/main/java/com/wireguard/android/RootShell.java8
1 files changed, 7 insertions, 1 deletions
diff --git a/app/src/main/java/com/wireguard/android/RootShell.java b/app/src/main/java/com/wireguard/android/RootShell.java
index c060c967..f5879f00 100644
--- a/app/src/main/java/com/wireguard/android/RootShell.java
+++ b/app/src/main/java/com/wireguard/android/RootShell.java
@@ -24,10 +24,16 @@ class RootShell {
private static final String TAG = "RootShell";
private final byte setupCommands[];
+ private final String shell;
RootShell(Context context) {
+ this(context, "su");
+ }
+
+ RootShell(Context context, String shell) {
final String tmpdir = context.getCacheDir().getPath();
setupCommands = String.format(SETUP_TEMPLATE, tmpdir).getBytes(StandardCharsets.UTF_8);
+ this.shell = shell;
}
/**
@@ -45,7 +51,7 @@ class RootShell {
int exitValue = -1;
try {
final ProcessBuilder builder = new ProcessBuilder().redirectErrorStream(true);
- final Process process = builder.command("su").start();
+ final Process process = builder.command(shell).start();
final OutputStream stdin = process.getOutputStream();
stdin.write(setupCommands);
for (String command : commands)