浏览代码

WgQuickBackend: Ensure tools are available before use

Signed-off-by: Samuel Holland <samuel@sholland.org>
master
Samuel Holland 6 年前
父节点
当前提交
c806e655fa
共有 2 个文件被更改,包括 10 次插入3 次删除
  1. +3
    -2
      app/src/main/java/com/wireguard/android/Application.java
  2. +7
    -1
      app/src/main/java/com/wireguard/android/backend/WgQuickBackend.java

+ 3
- 2
app/src/main/java/com/wireguard/android/Application.java 查看文件

@@ -81,8 +81,9 @@ public class Application extends android.app.Application {
@ApplicationScope
@Provides
public static Backend getBackend(@ApplicationContext final Context context,
final RootShell rootShell) {
return new WgQuickBackend(context, rootShell);
final RootShell rootShell,
final ToolsInstaller toolsInstaller) {
return new WgQuickBackend(context, rootShell, toolsInstaller);
}

@ApplicationScope


+ 7
- 1
app/src/main/java/com/wireguard/android/backend/WgQuickBackend.java 查看文件

@@ -9,6 +9,7 @@ import com.wireguard.android.model.Tunnel;
import com.wireguard.android.model.Tunnel.State;
import com.wireguard.android.model.Tunnel.Statistics;
import com.wireguard.android.util.RootShell;
import com.wireguard.android.util.ToolsInstaller;
import com.wireguard.config.Config;

import java.io.File;
@@ -29,10 +30,13 @@ public final class WgQuickBackend implements Backend {

private final Context context;
private final RootShell rootShell;
private final ToolsInstaller toolsInstaller;

public WgQuickBackend(final Context context, final RootShell rootShell) {
public WgQuickBackend(final Context context, final RootShell rootShell,
final ToolsInstaller toolsInstaller) {
this.context = context;
this.rootShell = rootShell;
this.toolsInstaller = toolsInstaller;
}

@Override
@@ -47,6 +51,7 @@ public final class WgQuickBackend implements Backend {
final List<String> output = new ArrayList<>();
// Don't throw an exception here or nothing will show up in the UI.
try {
toolsInstaller.ensureToolsAvailable();
if (rootShell.run(output, "wg show interfaces") != 0 || output.isEmpty())
return Collections.emptySet();
} catch (final Exception ignored) {
@@ -75,6 +80,7 @@ public final class WgQuickBackend implements Backend {
state = originalState == State.UP ? State.DOWN : State.UP;
if (state == originalState)
return originalState;
toolsInstaller.ensureToolsAvailable();
final int result;
if (state == State.UP) {
if (!new File("/sys/module/wireguard").exists())


正在加载...
取消
保存