diff --git a/x/examples/outline-connectivity-app/app_mobile/android/.gitignore b/x/examples/outline-connectivity-app/app_mobile/android/.gitignore
new file mode 100644
index 00000000..48354a3d
--- /dev/null
+++ b/x/examples/outline-connectivity-app/app_mobile/android/.gitignore
@@ -0,0 +1,101 @@
+# Using Android gitignore template: https://github.com/github/gitignore/blob/HEAD/Android.gitignore
+
+# Built application files
+*.apk
+*.aar
+*.ap_
+*.aab
+
+# Files for the ART/Dalvik VM
+*.dex
+
+# Java class files
+*.class
+
+# Generated files
+bin/
+gen/
+out/
+# Uncomment the following line in case you need and you don't have the release build type files in your app
+# release/
+
+# Gradle files
+.gradle/
+build/
+
+# Local configuration file (sdk path, etc)
+local.properties
+
+# Proguard folder generated by Eclipse
+proguard/
+
+# Log Files
+*.log
+
+# Android Studio Navigation editor temp files
+.navigation/
+
+# Android Studio captures folder
+captures/
+
+# IntelliJ
+*.iml
+.idea/workspace.xml
+.idea/tasks.xml
+.idea/gradle.xml
+.idea/assetWizardSettings.xml
+.idea/dictionaries
+.idea/libraries
+# Android Studio 3 in .gitignore file.
+.idea/caches
+.idea/modules.xml
+# Comment next line if keeping position of elements in Navigation Editor is relevant for you
+.idea/navEditor.xml
+
+# Keystore files
+# Uncomment the following lines if you do not want to check your keystore files in.
+#*.jks
+#*.keystore
+
+# External native build folder generated in Android Studio 2.2 and later
+.externalNativeBuild
+.cxx/
+
+# Google Services (e.g. APIs or Firebase)
+# google-services.json
+
+# Freeline
+freeline.py
+freeline/
+freeline_project_description.json
+
+# fastlane
+fastlane/report.xml
+fastlane/Preview.html
+fastlane/screenshots
+fastlane/test_output
+fastlane/readme.md
+
+# Version control
+vcs.xml
+
+# lint
+lint/intermediates/
+lint/generated/
+lint/outputs/
+lint/tmp/
+# lint/reports/
+
+# Android Profiling
+*.hprof
+
+# Cordova plugins for Capacitor
+capacitor-cordova-android-plugins
+
+# Copied web assets
+app/src/main/assets/public
+
+# Generated Config files
+app/src/main/assets/capacitor.config.json
+app/src/main/assets/capacitor.plugins.json
+app/src/main/res/xml/config.xml
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/app/.gitignore b/x/examples/outline-connectivity-app/app_mobile/android/app/.gitignore
new file mode 100644
index 00000000..043df802
--- /dev/null
+++ b/x/examples/outline-connectivity-app/app_mobile/android/app/.gitignore
@@ -0,0 +1,2 @@
+/build/*
+!/build/.npmkeep
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/app/build.gradle b/x/examples/outline-connectivity-app/app_mobile/android/app/build.gradle
new file mode 100644
index 00000000..5cd1c12e
--- /dev/null
+++ b/x/examples/outline-connectivity-app/app_mobile/android/app/build.gradle
@@ -0,0 +1,54 @@
+apply plugin: 'com.android.application'
+
+android {
+ namespace "org.outline.sdk.connectivity"
+ compileSdkVersion rootProject.ext.compileSdkVersion
+ defaultConfig {
+ applicationId "org.outline.sdk.connectivity"
+ minSdkVersion rootProject.ext.minSdkVersion
+ targetSdkVersion rootProject.ext.targetSdkVersion
+ versionCode 1
+ versionName "1.0"
+ testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
+ aaptOptions {
+ // Files and dirs to omit from the packaged assets dir, modified to accommodate modern web apps.
+ // Default: https://android.googlesource.com/platform/frameworks/base/+/282e181b58cf72b6ca770dc7ca5f91f135444502/tools/aapt/AaptAssets.cpp#61
+ ignoreAssetsPattern '!.svn:!.git:!.ds_store:!*.scc:.*:!CVS:!thumbs.db:!picasa.ini:!*~'
+ }
+ }
+ buildTypes {
+ release {
+ minifyEnabled false
+ proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
+ }
+ }
+}
+
+repositories {
+ flatDir{
+ dirs '../capacitor-cordova-android-plugins/src/main/libs', 'libs'
+ }
+}
+
+dependencies {
+ implementation fileTree(include: ['*.jar'], dir: 'libs')
+ implementation "androidx.appcompat:appcompat:$androidxAppCompatVersion"
+ implementation "androidx.coordinatorlayout:coordinatorlayout:$androidxCoordinatorLayoutVersion"
+ implementation "androidx.core:core-splashscreen:$coreSplashScreenVersion"
+ implementation project(':capacitor-android')
+ testImplementation "junit:junit:$junitVersion"
+ androidTestImplementation "androidx.test.ext:junit:$androidxJunitVersion"
+ androidTestImplementation "androidx.test.espresso:espresso-core:$androidxEspressoCoreVersion"
+ implementation project(':capacitor-cordova-android-plugins')
+}
+
+apply from: 'capacitor.build.gradle'
+
+try {
+ def servicesJSON = file('google-services.json')
+ if (servicesJSON.text) {
+ apply plugin: 'com.google.gms.google-services'
+ }
+} catch(Exception e) {
+ logger.info("google-services.json not found, google-services plugin not applied. Push Notifications won't work")
+}
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/app/capacitor.build.gradle b/x/examples/outline-connectivity-app/app_mobile/android/app/capacitor.build.gradle
new file mode 100644
index 00000000..40e69700
--- /dev/null
+++ b/x/examples/outline-connectivity-app/app_mobile/android/app/capacitor.build.gradle
@@ -0,0 +1,21 @@
+// DO NOT EDIT THIS FILE! IT IS GENERATED EACH TIME "capacitor update" IS RUN
+
+android {
+ compileOptions {
+ sourceCompatibility JavaVersion.VERSION_17
+ targetCompatibility JavaVersion.VERSION_17
+ }
+}
+
+apply from: "../capacitor-cordova-android-plugins/cordova.variables.gradle"
+dependencies {
+
+
+implementation 'org.jetbrains.kotlinx:kotlinx-serialization-json:1.6.0'
+ implementation files('../../../shared_backend/output/SharedBackend.aar')
+}
+
+
+if (hasProperty('postBuildExtras')) {
+ postBuildExtras()
+}
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/app/proguard-rules.pro b/x/examples/outline-connectivity-app/app_mobile/android/app/proguard-rules.pro
new file mode 100644
index 00000000..f1b42451
--- /dev/null
+++ b/x/examples/outline-connectivity-app/app_mobile/android/app/proguard-rules.pro
@@ -0,0 +1,21 @@
+# Add project specific ProGuard rules here.
+# You can control the set of applied configuration files using the
+# proguardFiles setting in build.gradle.
+#
+# For more details, see
+# http://developer.android.com/guide/developing/tools/proguard.html
+
+# If your project uses WebView with JS, uncomment the following
+# and specify the fully qualified class name to the JavaScript interface
+# class:
+#-keepclassmembers class fqcn.of.javascript.interface.for.webview {
+# public *;
+#}
+
+# Uncomment this to preserve the line number information for
+# debugging stack traces.
+#-keepattributes SourceFile,LineNumberTable
+
+# If you keep the line number information, uncomment this to
+# hide the original source file name.
+#-renamesourcefileattribute SourceFile
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/app/src/androidTest/java/com/getcapacitor/myapp/ExampleInstrumentedTest.java b/x/examples/outline-connectivity-app/app_mobile/android/app/src/androidTest/java/com/getcapacitor/myapp/ExampleInstrumentedTest.java
new file mode 100644
index 00000000..f2c2217e
--- /dev/null
+++ b/x/examples/outline-connectivity-app/app_mobile/android/app/src/androidTest/java/com/getcapacitor/myapp/ExampleInstrumentedTest.java
@@ -0,0 +1,26 @@
+package com.getcapacitor.myapp;
+
+import static org.junit.Assert.*;
+
+import android.content.Context;
+import androidx.test.ext.junit.runners.AndroidJUnit4;
+import androidx.test.platform.app.InstrumentationRegistry;
+import org.junit.Test;
+import org.junit.runner.RunWith;
+
+/**
+ * Instrumented test, which will execute on an Android device.
+ *
+ * @see Testing documentation
+ */
+@RunWith(AndroidJUnit4.class)
+public class ExampleInstrumentedTest {
+
+ @Test
+ public void useAppContext() throws Exception {
+ // Context of the app under test.
+ Context appContext = InstrumentationRegistry.getInstrumentation().getTargetContext();
+
+ assertEquals("com.getcapacitor.app", appContext.getPackageName());
+ }
+}
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/AndroidManifest.xml b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/AndroidManifest.xml
new file mode 100644
index 00000000..4d7ca380
--- /dev/null
+++ b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/AndroidManifest.xml
@@ -0,0 +1,41 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/java/org/outline/sdk/connectivity/FrontendRequest.kt b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/java/org/outline/sdk/connectivity/FrontendRequest.kt
new file mode 100644
index 00000000..33ac9251
--- /dev/null
+++ b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/java/org/outline/sdk/connectivity/FrontendRequest.kt
@@ -0,0 +1,9 @@
+package org.outline.sdk.connectivity
+
+import kotlinx.serialization.Serializable;
+
+@Serializable
+data class FrontendRequest(
+ val resourceName: String,
+ val parameters: String
+)
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/java/org/outline/sdk/connectivity/FrontendResponse.kt b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/java/org/outline/sdk/connectivity/FrontendResponse.kt
new file mode 100644
index 00000000..550af59e
--- /dev/null
+++ b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/java/org/outline/sdk/connectivity/FrontendResponse.kt
@@ -0,0 +1,9 @@
+package org.outline.sdk.connectivity
+
+import kotlinx.serialization.Serializable
+
+@Serializable
+data class FrontendResponse(
+ val body: String,
+ val error: String
+)
\ No newline at end of file
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/java/org/outline/sdk/connectivity/MainActivity.kt b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/java/org/outline/sdk/connectivity/MainActivity.kt
new file mode 100644
index 00000000..82fc6ef8
--- /dev/null
+++ b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/java/org/outline/sdk/connectivity/MainActivity.kt
@@ -0,0 +1,12 @@
+package org.outline.sdk.connectivity
+
+import android.os.Bundle
+import com.getcapacitor.BridgeActivity
+
+class MainActivity : BridgeActivity() {
+ @Override
+ fun onCreate(state: Bundle) {
+ registerPlugin(MobileBackendPlugin::class.java);
+ super.onCreate(state);
+ }
+}
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/java/org/outline/sdk/connectivity/MobileBackendPlugin.kt b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/java/org/outline/sdk/connectivity/MobileBackendPlugin.kt
new file mode 100644
index 00000000..0afecb2d
--- /dev/null
+++ b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/java/org/outline/sdk/connectivity/MobileBackendPlugin.kt
@@ -0,0 +1,49 @@
+package org.outline.sdk.connectivity
+
+import com.getcapacitor.JSObject;
+import com.getcapacitor.Plugin;
+import com.getcapacitor.PluginCall;
+import com.getcapacitor.PluginMethod;
+import com.getcapacitor.annotation.CapacitorPlugin;
+
+import kotlinx.serialization.json.Json;
+import kotlinx.serialization.encodeToString;
+
+import shared_backend.Shared_backend;
+import java.nio.charset.Charset;
+
+@CapacitorPlugin(name = "MobilePlugin")
+class MobileBackendPlugin: Plugin() {
+ @PluginMethod()
+ fun Request(call: PluginCall) {
+ val output = JSObject();
+ val response: FrontendResponse;
+
+ try {
+ // TODO: encode directly to byte array
+ val rawInputMessage = Json.encodeToString(
+ FrontendRequest(
+ call.getString("resourceName")!!,
+ call.getString("parameters")!!
+ )
+ );
+
+ response = Json.decodeFromString(
+ Shared_backend.handleRequest(
+ rawInputMessage.toByteArray(
+ Charset.forName("utf8")
+ )
+ ).toString()
+ );
+ } catch (error: Exception) {
+ output.put("error", error.message);
+
+ return call.resolve(output);
+ }
+
+ output.put("body", response.body);
+ output.put("error", response.error);
+
+ return call.resolve(output);
+ }
+}
\ No newline at end of file
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/drawable-land-hdpi/splash.png b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/drawable-land-hdpi/splash.png
new file mode 100644
index 00000000..e31573b4
Binary files /dev/null and b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/drawable-land-hdpi/splash.png differ
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/drawable-land-mdpi/splash.png b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/drawable-land-mdpi/splash.png
new file mode 100644
index 00000000..f7a64923
Binary files /dev/null and b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/drawable-land-mdpi/splash.png differ
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/drawable-land-xhdpi/splash.png b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/drawable-land-xhdpi/splash.png
new file mode 100644
index 00000000..80772550
Binary files /dev/null and b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/drawable-land-xhdpi/splash.png differ
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/drawable-land-xxhdpi/splash.png b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/drawable-land-xxhdpi/splash.png
new file mode 100644
index 00000000..14c6c8fe
Binary files /dev/null and b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/drawable-land-xxhdpi/splash.png differ
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/drawable-land-xxxhdpi/splash.png b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/drawable-land-xxxhdpi/splash.png
new file mode 100644
index 00000000..244ca250
Binary files /dev/null and b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/drawable-land-xxxhdpi/splash.png differ
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/drawable-port-hdpi/splash.png b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/drawable-port-hdpi/splash.png
new file mode 100644
index 00000000..74faaa58
Binary files /dev/null and b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/drawable-port-hdpi/splash.png differ
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/drawable-port-mdpi/splash.png b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/drawable-port-mdpi/splash.png
new file mode 100644
index 00000000..e944f4ad
Binary files /dev/null and b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/drawable-port-mdpi/splash.png differ
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/drawable-port-xhdpi/splash.png b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/drawable-port-xhdpi/splash.png
new file mode 100644
index 00000000..564a82ff
Binary files /dev/null and b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/drawable-port-xhdpi/splash.png differ
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/drawable-port-xxhdpi/splash.png b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/drawable-port-xxhdpi/splash.png
new file mode 100644
index 00000000..bfabe687
Binary files /dev/null and b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/drawable-port-xxhdpi/splash.png differ
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/drawable-port-xxxhdpi/splash.png b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/drawable-port-xxxhdpi/splash.png
new file mode 100644
index 00000000..69290712
Binary files /dev/null and b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/drawable-port-xxxhdpi/splash.png differ
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/drawable-v24/ic_launcher_foreground.xml b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/drawable-v24/ic_launcher_foreground.xml
new file mode 100644
index 00000000..c7bd21db
--- /dev/null
+++ b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/drawable-v24/ic_launcher_foreground.xml
@@ -0,0 +1,34 @@
+
+
+
+
+
+
+
+
+
+
+
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/drawable/ic_launcher_background.xml b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/drawable/ic_launcher_background.xml
new file mode 100644
index 00000000..d5fccc53
--- /dev/null
+++ b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/drawable/ic_launcher_background.xml
@@ -0,0 +1,170 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/drawable/splash.png b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/drawable/splash.png
new file mode 100644
index 00000000..f7a64923
Binary files /dev/null and b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/drawable/splash.png differ
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/layout/activity_main.xml b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/layout/activity_main.xml
new file mode 100644
index 00000000..b5ad1387
--- /dev/null
+++ b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/layout/activity_main.xml
@@ -0,0 +1,12 @@
+
+
+
+
+
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/mipmap-anydpi-v26/ic_launcher.xml b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/mipmap-anydpi-v26/ic_launcher.xml
new file mode 100644
index 00000000..036d09bc
--- /dev/null
+++ b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/mipmap-anydpi-v26/ic_launcher.xml
@@ -0,0 +1,5 @@
+
+
+
+
+
\ No newline at end of file
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/mipmap-anydpi-v26/ic_launcher_round.xml b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/mipmap-anydpi-v26/ic_launcher_round.xml
new file mode 100644
index 00000000..036d09bc
--- /dev/null
+++ b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/mipmap-anydpi-v26/ic_launcher_round.xml
@@ -0,0 +1,5 @@
+
+
+
+
+
\ No newline at end of file
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/mipmap-hdpi/ic_launcher.png b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/mipmap-hdpi/ic_launcher.png
new file mode 100644
index 00000000..c023e505
Binary files /dev/null and b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/mipmap-hdpi/ic_launcher.png differ
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/mipmap-hdpi/ic_launcher_foreground.png b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/mipmap-hdpi/ic_launcher_foreground.png
new file mode 100644
index 00000000..2127973b
Binary files /dev/null and b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/mipmap-hdpi/ic_launcher_foreground.png differ
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/mipmap-hdpi/ic_launcher_round.png b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/mipmap-hdpi/ic_launcher_round.png
new file mode 100644
index 00000000..b441f37d
Binary files /dev/null and b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/mipmap-hdpi/ic_launcher_round.png differ
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/mipmap-mdpi/ic_launcher.png b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/mipmap-mdpi/ic_launcher.png
new file mode 100644
index 00000000..72905b85
Binary files /dev/null and b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/mipmap-mdpi/ic_launcher.png differ
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/mipmap-mdpi/ic_launcher_foreground.png b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/mipmap-mdpi/ic_launcher_foreground.png
new file mode 100644
index 00000000..8ed0605c
Binary files /dev/null and b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/mipmap-mdpi/ic_launcher_foreground.png differ
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/mipmap-mdpi/ic_launcher_round.png b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/mipmap-mdpi/ic_launcher_round.png
new file mode 100644
index 00000000..9502e47a
Binary files /dev/null and b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/mipmap-mdpi/ic_launcher_round.png differ
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/mipmap-xhdpi/ic_launcher.png b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/mipmap-xhdpi/ic_launcher.png
new file mode 100644
index 00000000..4d1e0771
Binary files /dev/null and b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/mipmap-xhdpi/ic_launcher.png differ
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/mipmap-xhdpi/ic_launcher_foreground.png b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/mipmap-xhdpi/ic_launcher_foreground.png
new file mode 100644
index 00000000..df0f1588
Binary files /dev/null and b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/mipmap-xhdpi/ic_launcher_foreground.png differ
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/mipmap-xhdpi/ic_launcher_round.png b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/mipmap-xhdpi/ic_launcher_round.png
new file mode 100644
index 00000000..853db043
Binary files /dev/null and b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/mipmap-xhdpi/ic_launcher_round.png differ
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/mipmap-xxhdpi/ic_launcher.png b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/mipmap-xxhdpi/ic_launcher.png
new file mode 100644
index 00000000..6cdf97c1
Binary files /dev/null and b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/mipmap-xxhdpi/ic_launcher.png differ
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/mipmap-xxhdpi/ic_launcher_foreground.png b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/mipmap-xxhdpi/ic_launcher_foreground.png
new file mode 100644
index 00000000..2960cbb6
Binary files /dev/null and b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/mipmap-xxhdpi/ic_launcher_foreground.png differ
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/mipmap-xxhdpi/ic_launcher_round.png b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/mipmap-xxhdpi/ic_launcher_round.png
new file mode 100644
index 00000000..8e3093a8
Binary files /dev/null and b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/mipmap-xxhdpi/ic_launcher_round.png differ
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png
new file mode 100644
index 00000000..46de6e25
Binary files /dev/null and b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png differ
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/mipmap-xxxhdpi/ic_launcher_foreground.png b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/mipmap-xxxhdpi/ic_launcher_foreground.png
new file mode 100644
index 00000000..d2ea9abe
Binary files /dev/null and b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/mipmap-xxxhdpi/ic_launcher_foreground.png differ
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/mipmap-xxxhdpi/ic_launcher_round.png b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/mipmap-xxxhdpi/ic_launcher_round.png
new file mode 100644
index 00000000..a40d73e9
Binary files /dev/null and b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/mipmap-xxxhdpi/ic_launcher_round.png differ
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/values/ic_launcher_background.xml b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/values/ic_launcher_background.xml
new file mode 100644
index 00000000..c5d5899f
--- /dev/null
+++ b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/values/ic_launcher_background.xml
@@ -0,0 +1,4 @@
+
+
+ #FFFFFF
+
\ No newline at end of file
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/values/strings.xml b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/values/strings.xml
new file mode 100644
index 00000000..9799722c
--- /dev/null
+++ b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/values/strings.xml
@@ -0,0 +1,7 @@
+
+
+ @outline_sdk_connectivity_demo/app_mobile
+ @outline_sdk_connectivity_demo/app_mobile
+ org.outline.sdk.connectivity
+ org.outline.sdk.connectivity
+
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/values/styles.xml b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/values/styles.xml
new file mode 100644
index 00000000..be874e54
--- /dev/null
+++ b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/values/styles.xml
@@ -0,0 +1,22 @@
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/xml/file_paths.xml b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/xml/file_paths.xml
new file mode 100644
index 00000000..bd0c4d80
--- /dev/null
+++ b/x/examples/outline-connectivity-app/app_mobile/android/app/src/main/res/xml/file_paths.xml
@@ -0,0 +1,5 @@
+
+
+
+
+
\ No newline at end of file
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/app/src/test/java/com/getcapacitor/myapp/ExampleUnitTest.java b/x/examples/outline-connectivity-app/app_mobile/android/app/src/test/java/com/getcapacitor/myapp/ExampleUnitTest.java
new file mode 100644
index 00000000..02973278
--- /dev/null
+++ b/x/examples/outline-connectivity-app/app_mobile/android/app/src/test/java/com/getcapacitor/myapp/ExampleUnitTest.java
@@ -0,0 +1,18 @@
+package com.getcapacitor.myapp;
+
+import static org.junit.Assert.*;
+
+import org.junit.Test;
+
+/**
+ * Example local unit test, which will execute on the development machine (host).
+ *
+ * @see Testing documentation
+ */
+public class ExampleUnitTest {
+
+ @Test
+ public void addition_isCorrect() throws Exception {
+ assertEquals(4, 2 + 2);
+ }
+}
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/build.gradle b/x/examples/outline-connectivity-app/app_mobile/android/build.gradle
new file mode 100644
index 00000000..ed577065
--- /dev/null
+++ b/x/examples/outline-connectivity-app/app_mobile/android/build.gradle
@@ -0,0 +1,29 @@
+// Top-level build file where you can add configuration options common to all sub-projects/modules.
+
+buildscript {
+
+ repositories {
+ google()
+ mavenCentral()
+ }
+ dependencies {
+ classpath 'com.android.tools.build:gradle:8.1.1'
+ classpath 'com.google.gms:google-services:4.3.15'
+
+ // NOTE: Do not place your application dependencies here; they belong
+ // in the individual module build.gradle files
+ }
+}
+
+apply from: "variables.gradle"
+
+allprojects {
+ repositories {
+ google()
+ mavenCentral()
+ }
+}
+
+task clean(type: Delete) {
+ delete rootProject.buildDir
+}
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/capacitor.settings.gradle b/x/examples/outline-connectivity-app/app_mobile/android/capacitor.settings.gradle
new file mode 100644
index 00000000..a4583a2f
--- /dev/null
+++ b/x/examples/outline-connectivity-app/app_mobile/android/capacitor.settings.gradle
@@ -0,0 +1,3 @@
+// DO NOT EDIT THIS FILE! IT IS GENERATED EACH TIME "capacitor update" IS RUN
+include ':capacitor-android'
+project(':capacitor-android').projectDir = new File('../../.yarn/unplugged/@capacitor-android-virtual-f08a65e5d8/node_modules/@capacitor/android/capacitor')
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/gradle.properties b/x/examples/outline-connectivity-app/app_mobile/android/gradle.properties
new file mode 100644
index 00000000..2e87c52f
--- /dev/null
+++ b/x/examples/outline-connectivity-app/app_mobile/android/gradle.properties
@@ -0,0 +1,22 @@
+# Project-wide Gradle settings.
+
+# IDE (e.g. Android Studio) users:
+# Gradle settings configured through the IDE *will override*
+# any settings specified in this file.
+
+# For more details on how to configure your build environment visit
+# http://www.gradle.org/docs/current/userguide/build_environment.html
+
+# Specifies the JVM arguments used for the daemon process.
+# The setting is particularly useful for tweaking memory settings.
+org.gradle.jvmargs=-Xmx1536m
+
+# When configured, Gradle will run in incubating parallel mode.
+# This option should only be used with decoupled projects. More details, visit
+# http://www.gradle.org/docs/current/userguide/multi_project_builds.html#sec:decoupled_projects
+# org.gradle.parallel=true
+
+# AndroidX package structure to make it clearer which packages are bundled with the
+# Android operating system, and which are packaged with your app's APK
+# https://developer.android.com/topic/libraries/support-library/androidx-rn
+android.useAndroidX=true
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/gradle/wrapper/gradle-wrapper.jar b/x/examples/outline-connectivity-app/app_mobile/android/gradle/wrapper/gradle-wrapper.jar
new file mode 100644
index 00000000..ccebba77
Binary files /dev/null and b/x/examples/outline-connectivity-app/app_mobile/android/gradle/wrapper/gradle-wrapper.jar differ
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/gradle/wrapper/gradle-wrapper.properties b/x/examples/outline-connectivity-app/app_mobile/android/gradle/wrapper/gradle-wrapper.properties
new file mode 100644
index 00000000..761b8f08
--- /dev/null
+++ b/x/examples/outline-connectivity-app/app_mobile/android/gradle/wrapper/gradle-wrapper.properties
@@ -0,0 +1,6 @@
+distributionBase=GRADLE_USER_HOME
+distributionPath=wrapper/dists
+distributionUrl=https\://services.gradle.org/distributions/gradle-8.0.2-all.zip
+networkTimeout=10000
+zipStoreBase=GRADLE_USER_HOME
+zipStorePath=wrapper/dists
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/gradlew b/x/examples/outline-connectivity-app/app_mobile/android/gradlew
new file mode 100755
index 00000000..79a61d42
--- /dev/null
+++ b/x/examples/outline-connectivity-app/app_mobile/android/gradlew
@@ -0,0 +1,244 @@
+#!/bin/sh
+
+#
+# Copyright © 2015-2021 the original authors.
+#
+# Licensed under the Apache License, Version 2.0 (the "License");
+# you may not use this file except in compliance with the License.
+# You may obtain a copy of the License at
+#
+# https://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+#
+
+##############################################################################
+#
+# Gradle start up script for POSIX generated by Gradle.
+#
+# Important for running:
+#
+# (1) You need a POSIX-compliant shell to run this script. If your /bin/sh is
+# noncompliant, but you have some other compliant shell such as ksh or
+# bash, then to run this script, type that shell name before the whole
+# command line, like:
+#
+# ksh Gradle
+#
+# Busybox and similar reduced shells will NOT work, because this script
+# requires all of these POSIX shell features:
+# * functions;
+# * expansions «$var», «${var}», «${var:-default}», «${var+SET}»,
+# «${var#prefix}», «${var%suffix}», and «$( cmd )»;
+# * compound commands having a testable exit status, especially «case»;
+# * various built-in commands including «command», «set», and «ulimit».
+#
+# Important for patching:
+#
+# (2) This script targets any POSIX shell, so it avoids extensions provided
+# by Bash, Ksh, etc; in particular arrays are avoided.
+#
+# The "traditional" practice of packing multiple parameters into a
+# space-separated string is a well documented source of bugs and security
+# problems, so this is (mostly) avoided, by progressively accumulating
+# options in "$@", and eventually passing that to Java.
+#
+# Where the inherited environment variables (DEFAULT_JVM_OPTS, JAVA_OPTS,
+# and GRADLE_OPTS) rely on word-splitting, this is performed explicitly;
+# see the in-line comments for details.
+#
+# There are tweaks for specific operating systems such as AIX, CygWin,
+# Darwin, MinGW, and NonStop.
+#
+# (3) This script is generated from the Groovy template
+# https://github.com/gradle/gradle/blob/HEAD/subprojects/plugins/src/main/resources/org/gradle/api/internal/plugins/unixStartScript.txt
+# within the Gradle project.
+#
+# You can find Gradle at https://github.com/gradle/gradle/.
+#
+##############################################################################
+
+# Attempt to set APP_HOME
+
+# Resolve links: $0 may be a link
+app_path=$0
+
+# Need this for daisy-chained symlinks.
+while
+ APP_HOME=${app_path%"${app_path##*/}"} # leaves a trailing /; empty if no leading path
+ [ -h "$app_path" ]
+do
+ ls=$( ls -ld "$app_path" )
+ link=${ls#*' -> '}
+ case $link in #(
+ /*) app_path=$link ;; #(
+ *) app_path=$APP_HOME$link ;;
+ esac
+done
+
+# This is normally unused
+# shellcheck disable=SC2034
+APP_BASE_NAME=${0##*/}
+APP_HOME=$( cd "${APP_HOME:-./}" && pwd -P ) || exit
+
+# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
+DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"'
+
+# Use the maximum available, or set MAX_FD != -1 to use that value.
+MAX_FD=maximum
+
+warn () {
+ echo "$*"
+} >&2
+
+die () {
+ echo
+ echo "$*"
+ echo
+ exit 1
+} >&2
+
+# OS specific support (must be 'true' or 'false').
+cygwin=false
+msys=false
+darwin=false
+nonstop=false
+case "$( uname )" in #(
+ CYGWIN* ) cygwin=true ;; #(
+ Darwin* ) darwin=true ;; #(
+ MSYS* | MINGW* ) msys=true ;; #(
+ NONSTOP* ) nonstop=true ;;
+esac
+
+CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar
+
+
+# Determine the Java command to use to start the JVM.
+if [ -n "$JAVA_HOME" ] ; then
+ if [ -x "$JAVA_HOME/jre/sh/java" ] ; then
+ # IBM's JDK on AIX uses strange locations for the executables
+ JAVACMD=$JAVA_HOME/jre/sh/java
+ else
+ JAVACMD=$JAVA_HOME/bin/java
+ fi
+ if [ ! -x "$JAVACMD" ] ; then
+ die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME
+
+Please set the JAVA_HOME variable in your environment to match the
+location of your Java installation."
+ fi
+else
+ JAVACMD=java
+ which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
+
+Please set the JAVA_HOME variable in your environment to match the
+location of your Java installation."
+fi
+
+# Increase the maximum file descriptors if we can.
+if ! "$cygwin" && ! "$darwin" && ! "$nonstop" ; then
+ case $MAX_FD in #(
+ max*)
+ # In POSIX sh, ulimit -H is undefined. That's why the result is checked to see if it worked.
+ # shellcheck disable=SC3045
+ MAX_FD=$( ulimit -H -n ) ||
+ warn "Could not query maximum file descriptor limit"
+ esac
+ case $MAX_FD in #(
+ '' | soft) :;; #(
+ *)
+ # In POSIX sh, ulimit -n is undefined. That's why the result is checked to see if it worked.
+ # shellcheck disable=SC3045
+ ulimit -n "$MAX_FD" ||
+ warn "Could not set maximum file descriptor limit to $MAX_FD"
+ esac
+fi
+
+# Collect all arguments for the java command, stacking in reverse order:
+# * args from the command line
+# * the main class name
+# * -classpath
+# * -D...appname settings
+# * --module-path (only if needed)
+# * DEFAULT_JVM_OPTS, JAVA_OPTS, and GRADLE_OPTS environment variables.
+
+# For Cygwin or MSYS, switch paths to Windows format before running java
+if "$cygwin" || "$msys" ; then
+ APP_HOME=$( cygpath --path --mixed "$APP_HOME" )
+ CLASSPATH=$( cygpath --path --mixed "$CLASSPATH" )
+
+ JAVACMD=$( cygpath --unix "$JAVACMD" )
+
+ # Now convert the arguments - kludge to limit ourselves to /bin/sh
+ for arg do
+ if
+ case $arg in #(
+ -*) false ;; # don't mess with options #(
+ /?*) t=${arg#/} t=/${t%%/*} # looks like a POSIX filepath
+ [ -e "$t" ] ;; #(
+ *) false ;;
+ esac
+ then
+ arg=$( cygpath --path --ignore --mixed "$arg" )
+ fi
+ # Roll the args list around exactly as many times as the number of
+ # args, so each arg winds up back in the position where it started, but
+ # possibly modified.
+ #
+ # NB: a `for` loop captures its iteration list before it begins, so
+ # changing the positional parameters here affects neither the number of
+ # iterations, nor the values presented in `arg`.
+ shift # remove old arg
+ set -- "$@" "$arg" # push replacement arg
+ done
+fi
+
+# Collect all arguments for the java command;
+# * $DEFAULT_JVM_OPTS, $JAVA_OPTS, and $GRADLE_OPTS can contain fragments of
+# shell script including quotes and variable substitutions, so put them in
+# double quotes to make sure that they get re-expanded; and
+# * put everything else in single quotes, so that it's not re-expanded.
+
+set -- \
+ "-Dorg.gradle.appname=$APP_BASE_NAME" \
+ -classpath "$CLASSPATH" \
+ org.gradle.wrapper.GradleWrapperMain \
+ "$@"
+
+# Stop when "xargs" is not available.
+if ! command -v xargs >/dev/null 2>&1
+then
+ die "xargs is not available"
+fi
+
+# Use "xargs" to parse quoted args.
+#
+# With -n1 it outputs one arg per line, with the quotes and backslashes removed.
+#
+# In Bash we could simply go:
+#
+# readarray ARGS < <( xargs -n1 <<<"$var" ) &&
+# set -- "${ARGS[@]}" "$@"
+#
+# but POSIX shell has neither arrays nor command substitution, so instead we
+# post-process each arg (as a line of input to sed) to backslash-escape any
+# character that might be a shell metacharacter, then use eval to reverse
+# that process (while maintaining the separation between arguments), and wrap
+# the whole thing up as a single "set" statement.
+#
+# This will of course break if any of these variables contains a newline or
+# an unmatched quote.
+#
+
+eval "set -- $(
+ printf '%s\n' "$DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS" |
+ xargs -n1 |
+ sed ' s~[^-[:alnum:]+,./:=@_]~\\&~g; ' |
+ tr '\n' ' '
+ )" '"$@"'
+
+exec "$JAVACMD" "$@"
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/gradlew.bat b/x/examples/outline-connectivity-app/app_mobile/android/gradlew.bat
new file mode 100644
index 00000000..6689b85b
--- /dev/null
+++ b/x/examples/outline-connectivity-app/app_mobile/android/gradlew.bat
@@ -0,0 +1,92 @@
+@rem
+@rem Copyright 2015 the original author or authors.
+@rem
+@rem Licensed under the Apache License, Version 2.0 (the "License");
+@rem you may not use this file except in compliance with the License.
+@rem You may obtain a copy of the License at
+@rem
+@rem https://www.apache.org/licenses/LICENSE-2.0
+@rem
+@rem Unless required by applicable law or agreed to in writing, software
+@rem distributed under the License is distributed on an "AS IS" BASIS,
+@rem WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+@rem See the License for the specific language governing permissions and
+@rem limitations under the License.
+@rem
+
+@if "%DEBUG%"=="" @echo off
+@rem ##########################################################################
+@rem
+@rem Gradle startup script for Windows
+@rem
+@rem ##########################################################################
+
+@rem Set local scope for the variables with windows NT shell
+if "%OS%"=="Windows_NT" setlocal
+
+set DIRNAME=%~dp0
+if "%DIRNAME%"=="" set DIRNAME=.
+@rem This is normally unused
+set APP_BASE_NAME=%~n0
+set APP_HOME=%DIRNAME%
+
+@rem Resolve any "." and ".." in APP_HOME to make it shorter.
+for %%i in ("%APP_HOME%") do set APP_HOME=%%~fi
+
+@rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
+set DEFAULT_JVM_OPTS="-Xmx64m" "-Xms64m"
+
+@rem Find java.exe
+if defined JAVA_HOME goto findJavaFromJavaHome
+
+set JAVA_EXE=java.exe
+%JAVA_EXE% -version >NUL 2>&1
+if %ERRORLEVEL% equ 0 goto execute
+
+echo.
+echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
+echo.
+echo Please set the JAVA_HOME variable in your environment to match the
+echo location of your Java installation.
+
+goto fail
+
+:findJavaFromJavaHome
+set JAVA_HOME=%JAVA_HOME:"=%
+set JAVA_EXE=%JAVA_HOME%/bin/java.exe
+
+if exist "%JAVA_EXE%" goto execute
+
+echo.
+echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME%
+echo.
+echo Please set the JAVA_HOME variable in your environment to match the
+echo location of your Java installation.
+
+goto fail
+
+:execute
+@rem Setup the command line
+
+set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar
+
+
+@rem Execute Gradle
+"%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %*
+
+:end
+@rem End local scope for the variables with windows NT shell
+if %ERRORLEVEL% equ 0 goto mainEnd
+
+:fail
+rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of
+rem the _cmd.exe /c_ return code!
+set EXIT_CODE=%ERRORLEVEL%
+if %EXIT_CODE% equ 0 set EXIT_CODE=1
+if not ""=="%GRADLE_EXIT_CONSOLE%" exit %EXIT_CODE%
+exit /b %EXIT_CODE%
+
+:mainEnd
+if "%OS%"=="Windows_NT" endlocal
+
+:omega
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/settings.gradle b/x/examples/outline-connectivity-app/app_mobile/android/settings.gradle
new file mode 100644
index 00000000..3b4431d7
--- /dev/null
+++ b/x/examples/outline-connectivity-app/app_mobile/android/settings.gradle
@@ -0,0 +1,5 @@
+include ':app'
+include ':capacitor-cordova-android-plugins'
+project(':capacitor-cordova-android-plugins').projectDir = new File('./capacitor-cordova-android-plugins/')
+
+apply from: 'capacitor.settings.gradle'
\ No newline at end of file
diff --git a/x/examples/outline-connectivity-app/app_mobile/android/variables.gradle b/x/examples/outline-connectivity-app/app_mobile/android/variables.gradle
new file mode 100644
index 00000000..5946adab
--- /dev/null
+++ b/x/examples/outline-connectivity-app/app_mobile/android/variables.gradle
@@ -0,0 +1,16 @@
+ext {
+ minSdkVersion = 22
+ compileSdkVersion = 33
+ targetSdkVersion = 33
+ androidxActivityVersion = '1.7.0'
+ androidxAppCompatVersion = '1.6.1'
+ androidxCoordinatorLayoutVersion = '1.2.0'
+ androidxCoreVersion = '1.10.0'
+ androidxFragmentVersion = '1.5.6'
+ coreSplashScreenVersion = '1.0.0'
+ androidxWebkitVersion = '1.6.1'
+ junitVersion = '4.13.2'
+ androidxJunitVersion = '1.1.5'
+ androidxEspressoCoreVersion = '3.5.1'
+ cordovaAndroidVersion = '10.1.1'
+}
\ No newline at end of file
diff --git a/x/examples/outline-connectivity-app/app_mobile/package.json b/x/examples/outline-connectivity-app/app_mobile/package.json
index 460ea6ac..6b29a431 100644
--- a/x/examples/outline-connectivity-app/app_mobile/package.json
+++ b/x/examples/outline-connectivity-app/app_mobile/package.json
@@ -1,6 +1,7 @@
{
"author": "Daniel LaCosse",
"dependencies": {
+ "@capacitor/android": "^5.3.0",
"@capacitor/core": "latest",
"@capacitor/ios": "^5.2.2",
"lit": "^2.7.6",
diff --git a/x/examples/outline-connectivity-app/yarn.lock b/x/examples/outline-connectivity-app/yarn.lock
index 0ac28161..1755631a 100644
--- a/x/examples/outline-connectivity-app/yarn.lock
+++ b/x/examples/outline-connectivity-app/yarn.lock
@@ -23,6 +23,15 @@ __metadata:
languageName: node
linkType: hard
+"@capacitor/android@npm:^5.3.0":
+ version: 5.3.0
+ resolution: "@capacitor/android@npm:5.3.0"
+ peerDependencies:
+ "@capacitor/core": ^5.3.0
+ checksum: f8ab19135943cbec1f75e210ab814272219fd04c6b0c66e9a548d3d92f6dd1ad0cea25846dc49ddf3a4a9e91c06df9edc91c201260e183770e124dff0b7dd382
+ languageName: node
+ linkType: hard
+
"@capacitor/cli@npm:latest":
version: 5.2.2
resolution: "@capacitor/cli@npm:5.2.2"
@@ -616,6 +625,7 @@ __metadata:
version: 0.0.0-use.local
resolution: "app_mobile@workspace:app_mobile"
dependencies:
+ "@capacitor/android": ^5.3.0
"@capacitor/cli": latest
"@capacitor/core": latest
"@capacitor/ios": ^5.2.2