From df7d18fb5d332a2aa341e97274dc6e53cc4ffe11 Mon Sep 17 00:00:00 2001 From: Samuel Holland Date: Sat, 6 Jan 2018 05:09:05 -0600 Subject: [PATCH] Tunnel: Require passing a state to the constructor Signed-off-by: Samuel Holland --- .../main/java/com/wireguard/android/model/Tunnel.java | 5 +++-- .../java/com/wireguard/android/model/TunnelManager.java | 9 +++++---- 2 files changed, 8 insertions(+), 6 deletions(-) diff --git a/app/src/main/java/com/wireguard/android/model/Tunnel.java b/app/src/main/java/com/wireguard/android/model/Tunnel.java index 8152381..e1a8045 100644 --- a/app/src/main/java/com/wireguard/android/model/Tunnel.java +++ b/app/src/main/java/com/wireguard/android/model/Tunnel.java @@ -31,15 +31,16 @@ public class Tunnel extends BaseObservable implements Keyed { private final ConfigStore configStore; private final String name; private Config config; - private State state = State.UNKNOWN; + private State state; private Statistics statistics; Tunnel(@NonNull final Backend backend, @NonNull final ConfigStore configStore, - @NonNull final String name, @Nullable final Config config) { + @NonNull final String name, @Nullable final Config config, @NonNull final State state) { this.backend = backend; this.configStore = configStore; this.name = name; this.config = config; + this.state = state; } public static boolean isNameValid(final CharSequence name) { diff --git a/app/src/main/java/com/wireguard/android/model/TunnelManager.java b/app/src/main/java/com/wireguard/android/model/TunnelManager.java index 53322ab..eaf8c0d 100644 --- a/app/src/main/java/com/wireguard/android/model/TunnelManager.java +++ b/app/src/main/java/com/wireguard/android/model/TunnelManager.java @@ -48,14 +48,14 @@ public final class TunnelManager { this.preferences = preferences; } - private Tunnel add(final String name, final Config config) { - final Tunnel tunnel = new Tunnel(backend, configStore, name, config); + private Tunnel add(final String name, final Config config, final State state) { + final Tunnel tunnel = new Tunnel(backend, configStore, name, config, state); tunnels.add(tunnel); return tunnel; } private Tunnel add(final String name) { - return add(name, null); + return add(name, null, State.UNKNOWN); } public CompletionStage create(final String name, final Config config) { @@ -66,7 +66,8 @@ public final class TunnelManager { final String message = "Tunnel " + name + " already exists"; return CompletableFuture.failedFuture(new IllegalArgumentException(message)); } - return configStore.create(name, config).thenApply(savedConfig -> add(name, savedConfig)); + return configStore.create(name, config) + .thenApply(savedConfig -> add(name, savedConfig, State.DOWN)); } public CompletionStage delete(final Tunnel tunnel) {