diff options
author | Samuel Holland <samuel@sholland.org> | 2017-08-04 00:37:58 -0500 |
---|---|---|
committer | Samuel Holland <samuel@sholland.org> | 2017-08-04 00:37:58 -0500 |
commit | eb391a084037e8d45bdb4e9a5c0d70adf51a08d2 (patch) | |
tree | 160728b95957ad2ecbcdb39b9fb040df89a453f1 /app | |
parent | f37ff3a1e65e6006be95108ec26f01e2c0d1f730 (diff) |
RootShell: Make shell command configurable
Diffstat (limited to 'app')
-rw-r--r-- | app/src/main/java/com/wireguard/android/RootShell.java | 8 |
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) |