aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/app/src/main/java/com/wireguard/android/Application.java
diff options
context:
space:
mode:
Diffstat (limited to 'app/src/main/java/com/wireguard/android/Application.java')
-rw-r--r--app/src/main/java/com/wireguard/android/Application.java124
1 files changed, 124 insertions, 0 deletions
diff --git a/app/src/main/java/com/wireguard/android/Application.java b/app/src/main/java/com/wireguard/android/Application.java
new file mode 100644
index 00000000..c0fb046a
--- /dev/null
+++ b/app/src/main/java/com/wireguard/android/Application.java
@@ -0,0 +1,124 @@
+package com.wireguard.android;
+
+import android.content.Context;
+import android.content.SharedPreferences;
+import android.os.AsyncTask;
+import android.os.Handler;
+import android.os.Looper;
+import android.preference.PreferenceManager;
+
+import com.gabrielittner.threetenbp.LazyThreeTen;
+import com.wireguard.android.backend.Backend;
+import com.wireguard.android.backend.WgQuickBackend;
+import com.wireguard.android.configStore.ConfigStore;
+import com.wireguard.android.configStore.FileConfigStore;
+import com.wireguard.android.model.TunnelManager;
+import com.wireguard.android.util.AsyncWorker;
+import com.wireguard.android.util.RootShell;
+
+import java.util.concurrent.Executor;
+
+import javax.inject.Qualifier;
+import javax.inject.Scope;
+
+import dagger.Component;
+import dagger.Module;
+import dagger.Provides;
+
+/**
+ * Base context for the WireGuard Android application. This class (instantiated once during the
+ * application lifecycle) maintains and mediates access to the global state of the application.
+ */
+
+public class Application extends android.app.Application {
+ private static ApplicationComponent component;
+
+ public static ApplicationComponent getComponent() {
+ if (component == null)
+ throw new IllegalStateException("Application instance not yet created");
+ return component;
+ }
+
+ @Override
+ public void onCreate() {
+ super.onCreate();
+ component = DaggerApplication_ApplicationComponent.builder()
+ .applicationModule(new ApplicationModule(this))
+ .build();
+ component.getTunnelManager().onCreate();
+ LazyThreeTen.init(this);
+ }
+
+ @ApplicationScope
+ @Component(modules = ApplicationModule.class)
+ public interface ApplicationComponent {
+ AsyncWorker getAsyncWorker();
+
+ SharedPreferences getPreferences();
+
+ TunnelManager getTunnelManager();
+ }
+
+ @Qualifier
+ public @interface ApplicationContext {
+ }
+
+ @Qualifier
+ public @interface ApplicationHandler {
+ }
+
+ @Scope
+ public @interface ApplicationScope {
+ }
+
+ @Module
+ public static final class ApplicationModule {
+ private final Context context;
+
+ private ApplicationModule(final Application application) {
+ context = application.getApplicationContext();
+ }
+
+ @ApplicationScope
+ @Provides
+ public static Backend getBackend(final AsyncWorker asyncWorker,
+ @ApplicationContext final Context context,
+ final RootShell rootShell) {
+ return new WgQuickBackend(asyncWorker, context, rootShell);
+ }
+
+ @ApplicationScope
+ @Provides
+ public static ConfigStore getConfigStore(final AsyncWorker asyncWorker,
+ @ApplicationContext final Context context) {
+ return new FileConfigStore(asyncWorker, context);
+ }
+
+
+ @ApplicationScope
+ @Provides
+ public static Executor getExecutor() {
+ return AsyncTask.SERIAL_EXECUTOR;
+ }
+
+ @ApplicationHandler
+ @ApplicationScope
+ @Provides
+ public static Handler getHandler() {
+ return new Handler(Looper.getMainLooper());
+ }
+
+ @ApplicationScope
+ @Provides
+ public static SharedPreferences getPreferences(@ApplicationContext final Context context) {
+ return PreferenceManager.getDefaultSharedPreferences(context);
+ }
+
+ @ApplicationContext
+ @ApplicationScope
+ @Provides
+ public Context getContext() {
+ return context;
+ }
+ }
+}