diff --git a/ElixxirDAppsSDK.xcworkspace/contents.xcworkspacedata b/ElixxirDAppsSDK.xcworkspace/contents.xcworkspacedata
index 9ca22f2ec7dc6801cd91f1e2b68ae885d4abb591..ca3329e1a18abe7249c23385b288436d85ed4b75 100644
--- a/ElixxirDAppsSDK.xcworkspace/contents.xcworkspacedata
+++ b/ElixxirDAppsSDK.xcworkspace/contents.xcworkspacedata
@@ -4,7 +4,4 @@
    <FileRef
       location = "group:">
    </FileRef>
-   <FileRef
-      location = "group:Example/Example.xcodeproj">
-   </FileRef>
 </Workspace>
diff --git a/ElixxirDAppsSDK.xcworkspace/xcshareddata/swiftpm/Package.resolved b/ElixxirDAppsSDK.xcworkspace/xcshareddata/swiftpm/Package.resolved
index 6829b18147b9023c7dac8a13beb9615666fcb45a..4dca92f3ab713290b103b3e4d345f6c391a200a9 100644
--- a/ElixxirDAppsSDK.xcworkspace/xcshareddata/swiftpm/Package.resolved
+++ b/ElixxirDAppsSDK.xcworkspace/xcshareddata/swiftpm/Package.resolved
@@ -1,14 +1,5 @@
 {
   "pins" : [
-    {
-      "identity" : "combine-schedulers",
-      "kind" : "remoteSourceControl",
-      "location" : "https://github.com/pointfreeco/combine-schedulers",
-      "state" : {
-        "revision" : "8fee20f993e64bbbf22bc3e3f444758ac2d05692",
-        "version" : "0.7.2"
-      }
-    },
     {
       "identity" : "keychainaccess",
       "kind" : "remoteSourceControl",
@@ -18,42 +9,6 @@
         "version" : "4.2.2"
       }
     },
-    {
-      "identity" : "swift-case-paths",
-      "kind" : "remoteSourceControl",
-      "location" : "https://github.com/pointfreeco/swift-case-paths",
-      "state" : {
-        "revision" : "a09839348486db8866f85a727b8550be1d671c50",
-        "version" : "0.9.1"
-      }
-    },
-    {
-      "identity" : "swift-collections",
-      "kind" : "remoteSourceControl",
-      "location" : "https://github.com/apple/swift-collections",
-      "state" : {
-        "revision" : "48254824bb4248676bf7ce56014ff57b142b77eb",
-        "version" : "1.0.2"
-      }
-    },
-    {
-      "identity" : "swift-composable-architecture",
-      "kind" : "remoteSourceControl",
-      "location" : "https://github.com/pointfreeco/swift-composable-architecture.git",
-      "state" : {
-        "revision" : "108e3a536fcebb16c4f247ef92c2d7326baf9fe3",
-        "version" : "0.39.0"
-      }
-    },
-    {
-      "identity" : "swift-composable-presentation",
-      "kind" : "remoteSourceControl",
-      "location" : "https://github.com/darrarski/swift-composable-presentation.git",
-      "state" : {
-        "revision" : "1f4d17fae1f7ed41cbed17929083190fd9a78ee6",
-        "version" : "0.5.2"
-      }
-    },
     {
       "identity" : "swift-custom-dump",
       "kind" : "remoteSourceControl",
@@ -63,24 +18,6 @@
         "version" : "0.5.0"
       }
     },
-    {
-      "identity" : "swift-identified-collections",
-      "kind" : "remoteSourceControl",
-      "location" : "https://github.com/pointfreeco/swift-identified-collections",
-      "state" : {
-        "revision" : "2d6b7ffcc67afd9077fac5e5a29bcd6d39b71076",
-        "version" : "0.4.0"
-      }
-    },
-    {
-      "identity" : "swiftui-app-icon-creator",
-      "kind" : "remoteSourceControl",
-      "location" : "https://github.com/darrarski/swiftui-app-icon-creator.git",
-      "state" : {
-        "revision" : "f0c7ba4e66d3dc8135ccf9146afc05f9dff3c4ff",
-        "version" : "1.2.0"
-      }
-    },
     {
       "identity" : "xctest-dynamic-overlay",
       "kind" : "remoteSourceControl",
diff --git a/Example/Example.xcodeproj/project.pbxproj b/Example/Example.xcodeproj/project.pbxproj
deleted file mode 100644
index 6147b07eb28b1d32c4af098309f1427b4a2b2884..0000000000000000000000000000000000000000
--- a/Example/Example.xcodeproj/project.pbxproj
+++ /dev/null
@@ -1,344 +0,0 @@
-// !$*UTF8*$!
-{
-	archiveVersion = 1;
-	classes = {
-	};
-	objectVersion = 55;
-	objects = {
-
-/* Begin PBXBuildFile section */
-		312C371E28475E63003E9E39 /* Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 312C371D28475E63003E9E39 /* Assets.xcassets */; };
-		316D95EE28477B0E008475F9 /* AppFeature in Frameworks */ = {isa = PBXBuildFile; productRef = 316D95ED28477B0E008475F9 /* AppFeature */; };
-/* End PBXBuildFile section */
-
-/* Begin PBXFileReference section */
-		312C371628475E62003E9E39 /* dApps Example.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = "dApps Example.app"; sourceTree = BUILT_PRODUCTS_DIR; };
-		312C371D28475E63003E9E39 /* Assets.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = Assets.xcassets; sourceTree = "<group>"; };
-		312C3728284761DC003E9E39 /* Info.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = "<group>"; };
-		316D95EB28477ACA008475F9 /* example-app */ = {isa = PBXFileReference; lastKnownFileType = wrapper; path = "example-app"; sourceTree = "<group>"; };
-		31B3342F2847669900865D82 /* example-app-icon */ = {isa = PBXFileReference; lastKnownFileType = wrapper; path = "example-app-icon"; sourceTree = "<group>"; };
-/* End PBXFileReference section */
-
-/* Begin PBXFrameworksBuildPhase section */
-		312C371328475E62003E9E39 /* Frameworks */ = {
-			isa = PBXFrameworksBuildPhase;
-			buildActionMask = 2147483647;
-			files = (
-				316D95EE28477B0E008475F9 /* AppFeature in Frameworks */,
-			);
-			runOnlyForDeploymentPostprocessing = 0;
-		};
-/* End PBXFrameworksBuildPhase section */
-
-/* Begin PBXGroup section */
-		312C370D28475E62003E9E39 = {
-			isa = PBXGroup;
-			children = (
-				312C3727284761C7003E9E39 /* ExampleApp (iOS) */,
-				316D95EB28477ACA008475F9 /* example-app */,
-				31B3342F2847669900865D82 /* example-app-icon */,
-				312C371728475E62003E9E39 /* Products */,
-			);
-			sourceTree = "<group>";
-		};
-		312C371728475E62003E9E39 /* Products */ = {
-			isa = PBXGroup;
-			children = (
-				312C371628475E62003E9E39 /* dApps Example.app */,
-			);
-			name = Products;
-			sourceTree = "<group>";
-		};
-		312C3727284761C7003E9E39 /* ExampleApp (iOS) */ = {
-			isa = PBXGroup;
-			children = (
-				312C371D28475E63003E9E39 /* Assets.xcassets */,
-				312C3728284761DC003E9E39 /* Info.plist */,
-			);
-			path = "ExampleApp (iOS)";
-			sourceTree = "<group>";
-		};
-/* End PBXGroup section */
-
-/* Begin PBXNativeTarget section */
-		312C371528475E62003E9E39 /* ExampleApp (iOS) */ = {
-			isa = PBXNativeTarget;
-			buildConfigurationList = 312C372428475E63003E9E39 /* Build configuration list for PBXNativeTarget "ExampleApp (iOS)" */;
-			buildPhases = (
-				312C371228475E62003E9E39 /* Sources */,
-				312C371328475E62003E9E39 /* Frameworks */,
-				312C371428475E62003E9E39 /* Resources */,
-			);
-			buildRules = (
-			);
-			dependencies = (
-			);
-			name = "ExampleApp (iOS)";
-			packageProductDependencies = (
-				316D95ED28477B0E008475F9 /* AppFeature */,
-			);
-			productName = ExampleApp;
-			productReference = 312C371628475E62003E9E39 /* dApps Example.app */;
-			productType = "com.apple.product-type.application";
-		};
-/* End PBXNativeTarget section */
-
-/* Begin PBXProject section */
-		312C370E28475E62003E9E39 /* Project object */ = {
-			isa = PBXProject;
-			attributes = {
-				BuildIndependentTargetsInParallel = 1;
-				LastSwiftUpdateCheck = 1340;
-				LastUpgradeCheck = 1340;
-				TargetAttributes = {
-					312C371528475E62003E9E39 = {
-						CreatedOnToolsVersion = 13.4;
-					};
-				};
-			};
-			buildConfigurationList = 312C371128475E62003E9E39 /* Build configuration list for PBXProject "Example" */;
-			compatibilityVersion = "Xcode 13.0";
-			developmentRegion = en;
-			hasScannedForEncodings = 0;
-			knownRegions = (
-				en,
-				Base,
-			);
-			mainGroup = 312C370D28475E62003E9E39;
-			productRefGroup = 312C371728475E62003E9E39 /* Products */;
-			projectDirPath = "";
-			projectRoot = "";
-			targets = (
-				312C371528475E62003E9E39 /* ExampleApp (iOS) */,
-			);
-		};
-/* End PBXProject section */
-
-/* Begin PBXResourcesBuildPhase section */
-		312C371428475E62003E9E39 /* Resources */ = {
-			isa = PBXResourcesBuildPhase;
-			buildActionMask = 2147483647;
-			files = (
-				312C371E28475E63003E9E39 /* Assets.xcassets in Resources */,
-			);
-			runOnlyForDeploymentPostprocessing = 0;
-		};
-/* End PBXResourcesBuildPhase section */
-
-/* Begin PBXSourcesBuildPhase section */
-		312C371228475E62003E9E39 /* Sources */ = {
-			isa = PBXSourcesBuildPhase;
-			buildActionMask = 2147483647;
-			files = (
-			);
-			runOnlyForDeploymentPostprocessing = 0;
-		};
-/* End PBXSourcesBuildPhase section */
-
-/* Begin XCBuildConfiguration section */
-		312C372228475E63003E9E39 /* Debug */ = {
-			isa = XCBuildConfiguration;
-			buildSettings = {
-				ALWAYS_SEARCH_USER_PATHS = NO;
-				CLANG_ANALYZER_NONNULL = YES;
-				CLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE;
-				CLANG_CXX_LANGUAGE_STANDARD = "gnu++17";
-				CLANG_ENABLE_MODULES = YES;
-				CLANG_ENABLE_OBJC_ARC = YES;
-				CLANG_ENABLE_OBJC_WEAK = YES;
-				CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES;
-				CLANG_WARN_BOOL_CONVERSION = YES;
-				CLANG_WARN_COMMA = YES;
-				CLANG_WARN_CONSTANT_CONVERSION = YES;
-				CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES;
-				CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;
-				CLANG_WARN_DOCUMENTATION_COMMENTS = YES;
-				CLANG_WARN_EMPTY_BODY = YES;
-				CLANG_WARN_ENUM_CONVERSION = YES;
-				CLANG_WARN_INFINITE_RECURSION = YES;
-				CLANG_WARN_INT_CONVERSION = YES;
-				CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES;
-				CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES;
-				CLANG_WARN_OBJC_LITERAL_CONVERSION = YES;
-				CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;
-				CLANG_WARN_QUOTED_INCLUDE_IN_FRAMEWORK_HEADER = YES;
-				CLANG_WARN_RANGE_LOOP_ANALYSIS = YES;
-				CLANG_WARN_STRICT_PROTOTYPES = YES;
-				CLANG_WARN_SUSPICIOUS_MOVE = YES;
-				CLANG_WARN_UNGUARDED_AVAILABILITY = YES_AGGRESSIVE;
-				CLANG_WARN_UNREACHABLE_CODE = YES;
-				CLANG_WARN__DUPLICATE_METHOD_MATCH = YES;
-				COPY_PHASE_STRIP = NO;
-				DEBUG_INFORMATION_FORMAT = dwarf;
-				ENABLE_STRICT_OBJC_MSGSEND = YES;
-				ENABLE_TESTABILITY = YES;
-				GCC_C_LANGUAGE_STANDARD = gnu11;
-				GCC_DYNAMIC_NO_PIC = NO;
-				GCC_NO_COMMON_BLOCKS = YES;
-				GCC_OPTIMIZATION_LEVEL = 0;
-				GCC_PREPROCESSOR_DEFINITIONS = (
-					"DEBUG=1",
-					"$(inherited)",
-				);
-				GCC_WARN_64_TO_32_BIT_CONVERSION = YES;
-				GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;
-				GCC_WARN_UNDECLARED_SELECTOR = YES;
-				GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
-				GCC_WARN_UNUSED_FUNCTION = YES;
-				GCC_WARN_UNUSED_VARIABLE = YES;
-				IPHONEOS_DEPLOYMENT_TARGET = 15.3;
-				MTL_ENABLE_DEBUG_INFO = INCLUDE_SOURCE;
-				MTL_FAST_MATH = YES;
-				ONLY_ACTIVE_ARCH = YES;
-				SDKROOT = iphoneos;
-				SWIFT_ACTIVE_COMPILATION_CONDITIONS = DEBUG;
-				SWIFT_OPTIMIZATION_LEVEL = "-Onone";
-			};
-			name = Debug;
-		};
-		312C372328475E63003E9E39 /* Release */ = {
-			isa = XCBuildConfiguration;
-			buildSettings = {
-				ALWAYS_SEARCH_USER_PATHS = NO;
-				CLANG_ANALYZER_NONNULL = YES;
-				CLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE;
-				CLANG_CXX_LANGUAGE_STANDARD = "gnu++17";
-				CLANG_ENABLE_MODULES = YES;
-				CLANG_ENABLE_OBJC_ARC = YES;
-				CLANG_ENABLE_OBJC_WEAK = YES;
-				CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES;
-				CLANG_WARN_BOOL_CONVERSION = YES;
-				CLANG_WARN_COMMA = YES;
-				CLANG_WARN_CONSTANT_CONVERSION = YES;
-				CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES;
-				CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;
-				CLANG_WARN_DOCUMENTATION_COMMENTS = YES;
-				CLANG_WARN_EMPTY_BODY = YES;
-				CLANG_WARN_ENUM_CONVERSION = YES;
-				CLANG_WARN_INFINITE_RECURSION = YES;
-				CLANG_WARN_INT_CONVERSION = YES;
-				CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES;
-				CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES;
-				CLANG_WARN_OBJC_LITERAL_CONVERSION = YES;
-				CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;
-				CLANG_WARN_QUOTED_INCLUDE_IN_FRAMEWORK_HEADER = YES;
-				CLANG_WARN_RANGE_LOOP_ANALYSIS = YES;
-				CLANG_WARN_STRICT_PROTOTYPES = YES;
-				CLANG_WARN_SUSPICIOUS_MOVE = YES;
-				CLANG_WARN_UNGUARDED_AVAILABILITY = YES_AGGRESSIVE;
-				CLANG_WARN_UNREACHABLE_CODE = YES;
-				CLANG_WARN__DUPLICATE_METHOD_MATCH = YES;
-				COPY_PHASE_STRIP = NO;
-				DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym";
-				ENABLE_NS_ASSERTIONS = NO;
-				ENABLE_STRICT_OBJC_MSGSEND = YES;
-				GCC_C_LANGUAGE_STANDARD = gnu11;
-				GCC_NO_COMMON_BLOCKS = YES;
-				GCC_WARN_64_TO_32_BIT_CONVERSION = YES;
-				GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;
-				GCC_WARN_UNDECLARED_SELECTOR = YES;
-				GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
-				GCC_WARN_UNUSED_FUNCTION = YES;
-				GCC_WARN_UNUSED_VARIABLE = YES;
-				IPHONEOS_DEPLOYMENT_TARGET = 15.3;
-				MTL_ENABLE_DEBUG_INFO = NO;
-				MTL_FAST_MATH = YES;
-				SDKROOT = iphoneos;
-				SWIFT_COMPILATION_MODE = wholemodule;
-				SWIFT_OPTIMIZATION_LEVEL = "-O";
-				VALIDATE_PRODUCT = YES;
-			};
-			name = Release;
-		};
-		312C372528475E63003E9E39 /* Debug */ = {
-			isa = XCBuildConfiguration;
-			buildSettings = {
-				ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
-				ASSETCATALOG_COMPILER_GLOBAL_ACCENT_COLOR_NAME = AccentColor;
-				CODE_SIGN_STYLE = Automatic;
-				CURRENT_PROJECT_VERSION = 0;
-				ENABLE_PREVIEWS = YES;
-				GENERATE_INFOPLIST_FILE = YES;
-				INFOPLIST_FILE = "ExampleApp (iOS)/Info.plist";
-				INFOPLIST_KEY_CFBundleDisplayName = "dApps Example";
-				INFOPLIST_KEY_UIApplicationSupportsIndirectInputEvents = YES;
-				INFOPLIST_KEY_UILaunchScreen_Generation = YES;
-				INFOPLIST_KEY_UISupportedInterfaceOrientations_iPad = "UIInterfaceOrientationPortrait UIInterfaceOrientationPortraitUpsideDown UIInterfaceOrientationLandscapeLeft UIInterfaceOrientationLandscapeRight";
-				INFOPLIST_KEY_UISupportedInterfaceOrientations_iPhone = "UIInterfaceOrientationPortrait UIInterfaceOrientationLandscapeLeft UIInterfaceOrientationLandscapeRight";
-				LD_RUNPATH_SEARCH_PATHS = (
-					"$(inherited)",
-					"@executable_path/Frameworks",
-				);
-				MARKETING_VERSION = 1.0.0;
-				PRODUCT_BUNDLE_IDENTIFIER = xx.network.dApps.ExampleApp;
-				PRODUCT_MODULE_NAME = ExampleApp;
-				PRODUCT_NAME = "dApps Example";
-				SWIFT_EMIT_LOC_STRINGS = YES;
-				SWIFT_VERSION = 5.0;
-				TARGETED_DEVICE_FAMILY = "1,2";
-				VERSIONING_SYSTEM = "apple-generic";
-			};
-			name = Debug;
-		};
-		312C372628475E63003E9E39 /* Release */ = {
-			isa = XCBuildConfiguration;
-			buildSettings = {
-				ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
-				ASSETCATALOG_COMPILER_GLOBAL_ACCENT_COLOR_NAME = AccentColor;
-				CODE_SIGN_STYLE = Automatic;
-				CURRENT_PROJECT_VERSION = 0;
-				ENABLE_PREVIEWS = YES;
-				GENERATE_INFOPLIST_FILE = YES;
-				INFOPLIST_FILE = "ExampleApp (iOS)/Info.plist";
-				INFOPLIST_KEY_CFBundleDisplayName = "dApps Example";
-				INFOPLIST_KEY_UIApplicationSupportsIndirectInputEvents = YES;
-				INFOPLIST_KEY_UILaunchScreen_Generation = YES;
-				INFOPLIST_KEY_UISupportedInterfaceOrientations_iPad = "UIInterfaceOrientationPortrait UIInterfaceOrientationPortraitUpsideDown UIInterfaceOrientationLandscapeLeft UIInterfaceOrientationLandscapeRight";
-				INFOPLIST_KEY_UISupportedInterfaceOrientations_iPhone = "UIInterfaceOrientationPortrait UIInterfaceOrientationLandscapeLeft UIInterfaceOrientationLandscapeRight";
-				LD_RUNPATH_SEARCH_PATHS = (
-					"$(inherited)",
-					"@executable_path/Frameworks",
-				);
-				MARKETING_VERSION = 1.0.0;
-				PRODUCT_BUNDLE_IDENTIFIER = xx.network.dApps.ExampleApp;
-				PRODUCT_MODULE_NAME = ExampleApp;
-				PRODUCT_NAME = "dApps Example";
-				SWIFT_EMIT_LOC_STRINGS = YES;
-				SWIFT_VERSION = 5.0;
-				TARGETED_DEVICE_FAMILY = "1,2";
-				VERSIONING_SYSTEM = "apple-generic";
-			};
-			name = Release;
-		};
-/* End XCBuildConfiguration section */
-
-/* Begin XCConfigurationList section */
-		312C371128475E62003E9E39 /* Build configuration list for PBXProject "Example" */ = {
-			isa = XCConfigurationList;
-			buildConfigurations = (
-				312C372228475E63003E9E39 /* Debug */,
-				312C372328475E63003E9E39 /* Release */,
-			);
-			defaultConfigurationIsVisible = 0;
-			defaultConfigurationName = Release;
-		};
-		312C372428475E63003E9E39 /* Build configuration list for PBXNativeTarget "ExampleApp (iOS)" */ = {
-			isa = XCConfigurationList;
-			buildConfigurations = (
-				312C372528475E63003E9E39 /* Debug */,
-				312C372628475E63003E9E39 /* Release */,
-			);
-			defaultConfigurationIsVisible = 0;
-			defaultConfigurationName = Release;
-		};
-/* End XCConfigurationList section */
-
-/* Begin XCSwiftPackageProductDependency section */
-		316D95ED28477B0E008475F9 /* AppFeature */ = {
-			isa = XCSwiftPackageProductDependency;
-			productName = AppFeature;
-		};
-/* End XCSwiftPackageProductDependency section */
-	};
-	rootObject = 312C370E28475E62003E9E39 /* Project object */;
-}
diff --git a/Example/Example.xcodeproj/project.xcworkspace/contents.xcworkspacedata b/Example/Example.xcodeproj/project.xcworkspace/contents.xcworkspacedata
deleted file mode 100644
index 919434a6254f0e9651f402737811be6634a03e9c..0000000000000000000000000000000000000000
--- a/Example/Example.xcodeproj/project.xcworkspace/contents.xcworkspacedata
+++ /dev/null
@@ -1,7 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<Workspace
-   version = "1.0">
-   <FileRef
-      location = "self:">
-   </FileRef>
-</Workspace>
diff --git a/Example/Example.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist b/Example/Example.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist
deleted file mode 100644
index 18d981003d68d0546c4804ac2ff47dd97c6e7921..0000000000000000000000000000000000000000
--- a/Example/Example.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist
+++ /dev/null
@@ -1,8 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
-<plist version="1.0">
-<dict>
-	<key>IDEDidComputeMac32BitWarning</key>
-	<true/>
-</dict>
-</plist>
diff --git a/Example/Example.xcodeproj/project.xcworkspace/xcshareddata/WorkspaceSettings.xcsettings b/Example/Example.xcodeproj/project.xcworkspace/xcshareddata/WorkspaceSettings.xcsettings
deleted file mode 100644
index 08de0be8d3c8c1786ebe04545dd772526853eef4..0000000000000000000000000000000000000000
--- a/Example/Example.xcodeproj/project.xcworkspace/xcshareddata/WorkspaceSettings.xcsettings
+++ /dev/null
@@ -1,8 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
-<plist version="1.0">
-<dict>
-	<key>IDEWorkspaceSharedSettings_AutocreateContextsIfNeeded</key>
-	<false/>
-</dict>
-</plist>
diff --git a/Example/Example.xcodeproj/xcshareddata/xcschemes/ExampleApp (iOS).xcscheme b/Example/Example.xcodeproj/xcshareddata/xcschemes/ExampleApp (iOS).xcscheme
deleted file mode 100644
index 6ae359a987e276d0151fecdeff0fc8854e31bea1..0000000000000000000000000000000000000000
--- a/Example/Example.xcodeproj/xcshareddata/xcschemes/ExampleApp (iOS).xcscheme	
+++ /dev/null
@@ -1,119 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<Scheme
-   LastUpgradeVersion = "1340"
-   version = "1.3">
-   <BuildAction
-      parallelizeBuildables = "YES"
-      buildImplicitDependencies = "YES">
-      <BuildActionEntries>
-         <BuildActionEntry
-            buildForTesting = "YES"
-            buildForRunning = "YES"
-            buildForProfiling = "YES"
-            buildForArchiving = "YES"
-            buildForAnalyzing = "YES">
-            <BuildableReference
-               BuildableIdentifier = "primary"
-               BlueprintIdentifier = "312C371528475E62003E9E39"
-               BuildableName = "dApps Example.app"
-               BlueprintName = "ExampleApp (iOS)"
-               ReferencedContainer = "container:Example.xcodeproj">
-            </BuildableReference>
-         </BuildActionEntry>
-      </BuildActionEntries>
-   </BuildAction>
-   <TestAction
-      buildConfiguration = "Debug"
-      selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB"
-      selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB"
-      shouldUseLaunchSchemeArgsEnv = "YES"
-      codeCoverageEnabled = "YES">
-      <Testables>
-         <TestableReference
-            skipped = "NO">
-            <BuildableReference
-               BuildableIdentifier = "primary"
-               BlueprintIdentifier = "AppFeatureTests"
-               BuildableName = "AppFeatureTests"
-               BlueprintName = "AppFeatureTests"
-               ReferencedContainer = "container:example-app">
-            </BuildableReference>
-         </TestableReference>
-         <TestableReference
-            skipped = "NO">
-            <BuildableReference
-               BuildableIdentifier = "primary"
-               BlueprintIdentifier = "ErrorFeatureTests"
-               BuildableName = "ErrorFeatureTests"
-               BlueprintName = "ErrorFeatureTests"
-               ReferencedContainer = "container:example-app">
-            </BuildableReference>
-         </TestableReference>
-         <TestableReference
-            skipped = "NO">
-            <BuildableReference
-               BuildableIdentifier = "primary"
-               BlueprintIdentifier = "LandingFeatureTests"
-               BuildableName = "LandingFeatureTests"
-               BlueprintName = "LandingFeatureTests"
-               ReferencedContainer = "container:example-app">
-            </BuildableReference>
-         </TestableReference>
-         <TestableReference
-            skipped = "NO">
-            <BuildableReference
-               BuildableIdentifier = "primary"
-               BlueprintIdentifier = "SessionFeatureTests"
-               BuildableName = "SessionFeatureTests"
-               BlueprintName = "SessionFeatureTests"
-               ReferencedContainer = "container:example-app">
-            </BuildableReference>
-         </TestableReference>
-      </Testables>
-   </TestAction>
-   <LaunchAction
-      buildConfiguration = "Debug"
-      selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB"
-      selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB"
-      launchStyle = "0"
-      useCustomWorkingDirectory = "NO"
-      ignoresPersistentStateOnLaunch = "NO"
-      debugDocumentVersioning = "YES"
-      debugServiceExtension = "internal"
-      allowLocationSimulation = "YES">
-      <BuildableProductRunnable
-         runnableDebuggingMode = "0">
-         <BuildableReference
-            BuildableIdentifier = "primary"
-            BlueprintIdentifier = "312C371528475E62003E9E39"
-            BuildableName = "dApps Example.app"
-            BlueprintName = "ExampleApp (iOS)"
-            ReferencedContainer = "container:Example.xcodeproj">
-         </BuildableReference>
-      </BuildableProductRunnable>
-   </LaunchAction>
-   <ProfileAction
-      buildConfiguration = "Release"
-      shouldUseLaunchSchemeArgsEnv = "YES"
-      savedToolIdentifier = ""
-      useCustomWorkingDirectory = "NO"
-      debugDocumentVersioning = "YES">
-      <BuildableProductRunnable
-         runnableDebuggingMode = "0">
-         <BuildableReference
-            BuildableIdentifier = "primary"
-            BlueprintIdentifier = "312C371528475E62003E9E39"
-            BuildableName = "dApps Example.app"
-            BlueprintName = "ExampleApp (iOS)"
-            ReferencedContainer = "container:Example.xcodeproj">
-         </BuildableReference>
-      </BuildableProductRunnable>
-   </ProfileAction>
-   <AnalyzeAction
-      buildConfiguration = "Debug">
-   </AnalyzeAction>
-   <ArchiveAction
-      buildConfiguration = "Release"
-      revealArchiveInOrganizer = "YES">
-   </ArchiveAction>
-</Scheme>
diff --git a/Example/ExampleApp (iOS)/Assets.xcassets/AccentColor.colorset/Contents.json b/Example/ExampleApp (iOS)/Assets.xcassets/AccentColor.colorset/Contents.json
deleted file mode 100644
index eb8789700816459c1e1480e0b34781d9fb78a1ca..0000000000000000000000000000000000000000
--- a/Example/ExampleApp (iOS)/Assets.xcassets/AccentColor.colorset/Contents.json	
+++ /dev/null
@@ -1,11 +0,0 @@
-{
-  "colors" : [
-    {
-      "idiom" : "universal"
-    }
-  ],
-  "info" : {
-    "author" : "xcode",
-    "version" : 1
-  }
-}
diff --git a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/Contents.json b/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/Contents.json
deleted file mode 100644
index 84c0167b1a1045edaaee154e355e3d9362bb03c2..0000000000000000000000000000000000000000
--- a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/Contents.json	
+++ /dev/null
@@ -1,116 +0,0 @@
-{
-  "images" : [
-    {
-      "filename" : "iPhone Notification 20pt 2x.png",
-      "idiom" : "iphone",
-      "scale" : "2x",
-      "size" : "20x20"
-    },
-    {
-      "filename" : "iPhone Notification 20pt 3x.png",
-      "idiom" : "iphone",
-      "scale" : "3x",
-      "size" : "20x20"
-    },
-    {
-      "filename" : "iPhone Settings 29pt 2x.png",
-      "idiom" : "iphone",
-      "scale" : "2x",
-      "size" : "29x29"
-    },
-    {
-      "filename" : "iPhone Settings 29pt 3x.png",
-      "idiom" : "iphone",
-      "scale" : "3x",
-      "size" : "29x29"
-    },
-    {
-      "filename" : "iPhone Spotlight 40pt 2x.png",
-      "idiom" : "iphone",
-      "scale" : "2x",
-      "size" : "40x40"
-    },
-    {
-      "filename" : "iPhone Spotlight 40pt 3x.png",
-      "idiom" : "iphone",
-      "scale" : "3x",
-      "size" : "40x40"
-    },
-    {
-      "filename" : "iPhone App 60pt 2x.png",
-      "idiom" : "iphone",
-      "scale" : "2x",
-      "size" : "60x60"
-    },
-    {
-      "filename" : "iPhone App 60pt 3x.png",
-      "idiom" : "iphone",
-      "scale" : "3x",
-      "size" : "60x60"
-    },
-    {
-      "filename" : "iPad Notification 20pt 1x.png",
-      "idiom" : "ipad",
-      "scale" : "1x",
-      "size" : "20x20"
-    },
-    {
-      "filename" : "iPad Notification 20pt 2x.png",
-      "idiom" : "ipad",
-      "scale" : "2x",
-      "size" : "20x20"
-    },
-    {
-      "filename" : "iPad Settings 29pt 1x.png",
-      "idiom" : "ipad",
-      "scale" : "1x",
-      "size" : "29x29"
-    },
-    {
-      "filename" : "iPad Settings 29pt 2x.png",
-      "idiom" : "ipad",
-      "scale" : "2x",
-      "size" : "29x29"
-    },
-    {
-      "filename" : "iPad Spotlight 40pt 1x.png",
-      "idiom" : "ipad",
-      "scale" : "1x",
-      "size" : "40x40"
-    },
-    {
-      "filename" : "iPad Spotlight 40pt 2x.png",
-      "idiom" : "ipad",
-      "scale" : "2x",
-      "size" : "40x40"
-    },
-    {
-      "filename" : "iPad App 76pt 1x.png",
-      "idiom" : "ipad",
-      "scale" : "1x",
-      "size" : "76x76"
-    },
-    {
-      "filename" : "iPad App 76pt 2x.png",
-      "idiom" : "ipad",
-      "scale" : "2x",
-      "size" : "76x76"
-    },
-    {
-      "filename" : "iPad Pro (12.9-inch) App 83.5pt 2x.png",
-      "idiom" : "ipad",
-      "scale" : "2x",
-      "size" : "83.5x83.5"
-    },
-    {
-      "filename" : "iOS App Store 1024pt 1x.png",
-      "idiom" : "ios-marketing",
-      "scale" : "1x",
-      "size" : "1024x1024"
-    }
-  ],
-  "info" : {
-    "author" : "xcode",
-    "version" : 1
-  }
-}
diff --git a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iOS App Store 1024pt 1x.png b/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iOS App Store 1024pt 1x.png
deleted file mode 100644
index f74bafba9a74e2c0f9a075ef11c390612af07c69..0000000000000000000000000000000000000000
Binary files a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iOS App Store 1024pt 1x.png and /dev/null differ
diff --git a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad App 76pt 1x.png b/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad App 76pt 1x.png
deleted file mode 100644
index 33755231d84723c6cfc3f823bad05eb5c8961ba2..0000000000000000000000000000000000000000
Binary files a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad App 76pt 1x.png and /dev/null differ
diff --git a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad App 76pt 2x.png b/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad App 76pt 2x.png
deleted file mode 100644
index 2b5ae552b64790957d1a355d80eec642bf93d100..0000000000000000000000000000000000000000
Binary files a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad App 76pt 2x.png and /dev/null differ
diff --git a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad Notification 20pt 1x.png b/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad Notification 20pt 1x.png
deleted file mode 100644
index ca9a346232d62f79579473062b9758afb7f8907f..0000000000000000000000000000000000000000
Binary files a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad Notification 20pt 1x.png and /dev/null differ
diff --git a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad Notification 20pt 2x.png b/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad Notification 20pt 2x.png
deleted file mode 100644
index 4a5a33677bdedee2496d9f1bf25f34dc88b0a473..0000000000000000000000000000000000000000
Binary files a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad Notification 20pt 2x.png and /dev/null differ
diff --git a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad Pro (12.9-inch) App 83.5pt 2x.png b/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad Pro (12.9-inch) App 83.5pt 2x.png
deleted file mode 100644
index 35bcfba03a28d1a7e50573e9e6438cce84e75363..0000000000000000000000000000000000000000
Binary files a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad Pro (12.9-inch) App 83.5pt 2x.png and /dev/null differ
diff --git a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad Settings 29pt 1x.png b/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad Settings 29pt 1x.png
deleted file mode 100644
index 907b2832c75cded4bca5e65ec9da25f3c04d572a..0000000000000000000000000000000000000000
Binary files a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad Settings 29pt 1x.png and /dev/null differ
diff --git a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad Settings 29pt 2x.png b/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad Settings 29pt 2x.png
deleted file mode 100644
index 2aade831c23ada90101c8fc4cd8b07442a68fcb8..0000000000000000000000000000000000000000
Binary files a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad Settings 29pt 2x.png and /dev/null differ
diff --git a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad Spotlight 40pt 1x.png b/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad Spotlight 40pt 1x.png
deleted file mode 100644
index 4a5a33677bdedee2496d9f1bf25f34dc88b0a473..0000000000000000000000000000000000000000
Binary files a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad Spotlight 40pt 1x.png and /dev/null differ
diff --git a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad Spotlight 40pt 2x.png b/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad Spotlight 40pt 2x.png
deleted file mode 100644
index c35f34b4c2a4bea13a14c6901964057817ec0a0c..0000000000000000000000000000000000000000
Binary files a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPad Spotlight 40pt 2x.png and /dev/null differ
diff --git a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPhone App 60pt 2x.png b/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPhone App 60pt 2x.png
deleted file mode 100644
index 911a010e155c39f2a82f8dd2b472a2dfbcfa486e..0000000000000000000000000000000000000000
Binary files a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPhone App 60pt 2x.png and /dev/null differ
diff --git a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPhone App 60pt 3x.png b/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPhone App 60pt 3x.png
deleted file mode 100644
index fc5a7a7ac44be361e8fb67318af7b3028630d2f0..0000000000000000000000000000000000000000
Binary files a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPhone App 60pt 3x.png and /dev/null differ
diff --git a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPhone Notification 20pt 2x.png b/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPhone Notification 20pt 2x.png
deleted file mode 100644
index 4a5a33677bdedee2496d9f1bf25f34dc88b0a473..0000000000000000000000000000000000000000
Binary files a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPhone Notification 20pt 2x.png and /dev/null differ
diff --git a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPhone Notification 20pt 3x.png b/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPhone Notification 20pt 3x.png
deleted file mode 100644
index 3561cb40fa8325368092ed54c78d8ebaa670d170..0000000000000000000000000000000000000000
Binary files a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPhone Notification 20pt 3x.png and /dev/null differ
diff --git a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPhone Settings 29pt 2x.png b/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPhone Settings 29pt 2x.png
deleted file mode 100644
index 2aade831c23ada90101c8fc4cd8b07442a68fcb8..0000000000000000000000000000000000000000
Binary files a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPhone Settings 29pt 2x.png and /dev/null differ
diff --git a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPhone Settings 29pt 3x.png b/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPhone Settings 29pt 3x.png
deleted file mode 100644
index 2719654ceaa888998261e08e89b94143165c1b50..0000000000000000000000000000000000000000
Binary files a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPhone Settings 29pt 3x.png and /dev/null differ
diff --git a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPhone Spotlight 40pt 2x.png b/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPhone Spotlight 40pt 2x.png
deleted file mode 100644
index c35f34b4c2a4bea13a14c6901964057817ec0a0c..0000000000000000000000000000000000000000
Binary files a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPhone Spotlight 40pt 2x.png and /dev/null differ
diff --git a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPhone Spotlight 40pt 3x.png b/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPhone Spotlight 40pt 3x.png
deleted file mode 100644
index 911a010e155c39f2a82f8dd2b472a2dfbcfa486e..0000000000000000000000000000000000000000
Binary files a/Example/ExampleApp (iOS)/Assets.xcassets/AppIcon.appiconset/iPhone Spotlight 40pt 3x.png and /dev/null differ
diff --git a/Example/ExampleApp (iOS)/Assets.xcassets/Contents.json b/Example/ExampleApp (iOS)/Assets.xcassets/Contents.json
deleted file mode 100644
index 73c00596a7fca3f3d4bdd64053b69d86745f9e10..0000000000000000000000000000000000000000
--- a/Example/ExampleApp (iOS)/Assets.xcassets/Contents.json	
+++ /dev/null
@@ -1,6 +0,0 @@
-{
-  "info" : {
-    "author" : "xcode",
-    "version" : 1
-  }
-}
diff --git a/Example/ExampleApp (iOS)/Info.plist b/Example/ExampleApp (iOS)/Info.plist
deleted file mode 100644
index 669a5ca760ffe22bd5f4fec92e67939fa64476af..0000000000000000000000000000000000000000
--- a/Example/ExampleApp (iOS)/Info.plist	
+++ /dev/null
@@ -1,13 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
-<plist version="1.0">
-<dict>
-	<key>ITSAppUsesNonExemptEncryption</key>
-	<false/>
-	<key>UIApplicationSceneManifest</key>
-	<dict>
-		<key>UIApplicationSupportsMultipleScenes</key>
-		<false/>
-	</dict>
-</dict>
-</plist>
diff --git a/Example/Package.swift b/Example/Package.swift
deleted file mode 100644
index d0a31fe81dd861a3d33bf4eaeb4f59fb7c9f4947..0000000000000000000000000000000000000000
--- a/Example/Package.swift
+++ /dev/null
@@ -1,4 +0,0 @@
-// swift-tools-version:5.6
-// This file makes Xcode doesn't display this directory inside swift package.
-import PackageDescription
-let package = Package(name: "", products: [], targets: [])
diff --git a/Example/example-app-icon/.gitignore b/Example/example-app-icon/.gitignore
deleted file mode 100644
index 3b29812086f28a2b21884e57ead495ffd9434178..0000000000000000000000000000000000000000
--- a/Example/example-app-icon/.gitignore
+++ /dev/null
@@ -1,9 +0,0 @@
-.DS_Store
-/.build
-/Packages
-/*.xcodeproj
-xcuserdata/
-DerivedData/
-.swiftpm/config/registries.json
-.swiftpm/xcode/package.xcworkspace/contents.xcworkspacedata
-.netrc
diff --git a/Example/example-app-icon/.swiftpm/xcode/xcshareddata/xcschemes/ExampleAppIcon.xcscheme b/Example/example-app-icon/.swiftpm/xcode/xcshareddata/xcschemes/ExampleAppIcon.xcscheme
deleted file mode 100644
index 577a588463331de08076d97e67d30ddfa7eb6e70..0000000000000000000000000000000000000000
--- a/Example/example-app-icon/.swiftpm/xcode/xcshareddata/xcschemes/ExampleAppIcon.xcscheme
+++ /dev/null
@@ -1,67 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<Scheme
-   LastUpgradeVersion = "1330"
-   version = "1.3">
-   <BuildAction
-      parallelizeBuildables = "YES"
-      buildImplicitDependencies = "YES">
-      <BuildActionEntries>
-         <BuildActionEntry
-            buildForTesting = "YES"
-            buildForRunning = "YES"
-            buildForProfiling = "YES"
-            buildForArchiving = "YES"
-            buildForAnalyzing = "YES">
-            <BuildableReference
-               BuildableIdentifier = "primary"
-               BlueprintIdentifier = "ExampleAppIcon"
-               BuildableName = "ExampleAppIcon"
-               BlueprintName = "ExampleAppIcon"
-               ReferencedContainer = "container:">
-            </BuildableReference>
-         </BuildActionEntry>
-      </BuildActionEntries>
-   </BuildAction>
-   <TestAction
-      buildConfiguration = "Debug"
-      selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB"
-      selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB"
-      shouldUseLaunchSchemeArgsEnv = "YES">
-      <Testables>
-      </Testables>
-   </TestAction>
-   <LaunchAction
-      buildConfiguration = "Debug"
-      selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB"
-      selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB"
-      launchStyle = "0"
-      useCustomWorkingDirectory = "NO"
-      ignoresPersistentStateOnLaunch = "NO"
-      debugDocumentVersioning = "YES"
-      debugServiceExtension = "internal"
-      allowLocationSimulation = "YES">
-   </LaunchAction>
-   <ProfileAction
-      buildConfiguration = "Release"
-      shouldUseLaunchSchemeArgsEnv = "YES"
-      savedToolIdentifier = ""
-      useCustomWorkingDirectory = "NO"
-      debugDocumentVersioning = "YES">
-      <MacroExpansion>
-         <BuildableReference
-            BuildableIdentifier = "primary"
-            BlueprintIdentifier = "ExampleAppIcon"
-            BuildableName = "ExampleAppIcon"
-            BlueprintName = "ExampleAppIcon"
-            ReferencedContainer = "container:">
-         </BuildableReference>
-      </MacroExpansion>
-   </ProfileAction>
-   <AnalyzeAction
-      buildConfiguration = "Debug">
-   </AnalyzeAction>
-   <ArchiveAction
-      buildConfiguration = "Release"
-      revealArchiveInOrganizer = "YES">
-   </ArchiveAction>
-</Scheme>
diff --git a/Example/example-app-icon/.swiftpm/xcode/xcshareddata/xcschemes/example-app-icon-export.xcscheme b/Example/example-app-icon/.swiftpm/xcode/xcshareddata/xcschemes/example-app-icon-export.xcscheme
deleted file mode 100644
index e903b8e44600283e207b4b588d9799cbd1a78f8e..0000000000000000000000000000000000000000
--- a/Example/example-app-icon/.swiftpm/xcode/xcshareddata/xcschemes/example-app-icon-export.xcscheme
+++ /dev/null
@@ -1,78 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<Scheme
-   LastUpgradeVersion = "1330"
-   version = "1.3">
-   <BuildAction
-      parallelizeBuildables = "YES"
-      buildImplicitDependencies = "YES">
-      <BuildActionEntries>
-         <BuildActionEntry
-            buildForTesting = "YES"
-            buildForRunning = "YES"
-            buildForProfiling = "YES"
-            buildForArchiving = "YES"
-            buildForAnalyzing = "YES">
-            <BuildableReference
-               BuildableIdentifier = "primary"
-               BlueprintIdentifier = "example-app-icon-export"
-               BuildableName = "example-app-icon-export"
-               BlueprintName = "example-app-icon-export"
-               ReferencedContainer = "container:">
-            </BuildableReference>
-         </BuildActionEntry>
-      </BuildActionEntries>
-   </BuildAction>
-   <TestAction
-      buildConfiguration = "Debug"
-      selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB"
-      selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB"
-      shouldUseLaunchSchemeArgsEnv = "YES">
-      <Testables>
-      </Testables>
-   </TestAction>
-   <LaunchAction
-      buildConfiguration = "Debug"
-      selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB"
-      selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB"
-      launchStyle = "0"
-      useCustomWorkingDirectory = "NO"
-      ignoresPersistentStateOnLaunch = "NO"
-      debugDocumentVersioning = "YES"
-      debugServiceExtension = "internal"
-      allowLocationSimulation = "YES">
-      <BuildableProductRunnable
-         runnableDebuggingMode = "0">
-         <BuildableReference
-            BuildableIdentifier = "primary"
-            BlueprintIdentifier = "example-app-icon-export"
-            BuildableName = "example-app-icon-export"
-            BlueprintName = "example-app-icon-export"
-            ReferencedContainer = "container:">
-         </BuildableReference>
-      </BuildableProductRunnable>
-   </LaunchAction>
-   <ProfileAction
-      buildConfiguration = "Release"
-      shouldUseLaunchSchemeArgsEnv = "YES"
-      savedToolIdentifier = ""
-      useCustomWorkingDirectory = "NO"
-      debugDocumentVersioning = "YES">
-      <BuildableProductRunnable
-         runnableDebuggingMode = "0">
-         <BuildableReference
-            BuildableIdentifier = "primary"
-            BlueprintIdentifier = "example-app-icon-export"
-            BuildableName = "example-app-icon-export"
-            BlueprintName = "example-app-icon-export"
-            ReferencedContainer = "container:">
-         </BuildableReference>
-      </BuildableProductRunnable>
-   </ProfileAction>
-   <AnalyzeAction
-      buildConfiguration = "Debug">
-   </AnalyzeAction>
-   <ArchiveAction
-      buildConfiguration = "Release"
-      revealArchiveInOrganizer = "YES">
-   </ArchiveAction>
-</Scheme>
diff --git a/Example/example-app-icon/Package.swift b/Example/example-app-icon/Package.swift
deleted file mode 100644
index d7a9c8bdd343f98a34609faa7f18f473c534833f..0000000000000000000000000000000000000000
--- a/Example/example-app-icon/Package.swift
+++ /dev/null
@@ -1,42 +0,0 @@
-// swift-tools-version: 5.6
-import PackageDescription
-
-let package = Package(
-  name: "example-app-icon",
-  platforms: [
-    .macOS(.v12),
-  ],
-  products: [
-    .library(
-      name: "ExampleAppIcon",
-      targets: ["ExampleAppIcon"]
-    ),
-    .executable(
-      name: "example-app-icon-export",
-      targets: ["ExampleAppIconExport"]
-    ),
-  ],
-  dependencies: [
-    .package(
-      url: "https://github.com/darrarski/swiftui-app-icon-creator.git",
-      .upToNextMajor(from: "1.2.0")
-    ),
-  ],
-  targets: [
-    .target(
-      name: "ExampleAppIcon",
-      dependencies: [
-        .product(
-          name: "AppIconCreator",
-          package: "swiftui-app-icon-creator"
-        ),
-      ]
-    ),
-    .executableTarget(
-      name: "ExampleAppIconExport",
-      dependencies: [
-        .target(name: "ExampleAppIcon"),
-      ]
-    )
-  ]
-)
diff --git a/Example/example-app-icon/Sources/ExampleAppIcon/ExampleAppIcon.swift b/Example/example-app-icon/Sources/ExampleAppIcon/ExampleAppIcon.swift
deleted file mode 100644
index 0c24ca0094213d7c58dc5b02361b6bc45cbf96a1..0000000000000000000000000000000000000000
--- a/Example/example-app-icon/Sources/ExampleAppIcon/ExampleAppIcon.swift
+++ /dev/null
@@ -1,73 +0,0 @@
-import SwiftUI
-import AppIconCreator
-
-public struct ExampleAppIconView: View {
-  public init() {}
-
-  public var body: some View {
-    GeometryReader { geometry in
-      ZStack {
-        Image(systemName: "cube.transparent")
-          .resizable()
-          .scaledToFit()
-          .foregroundColor(.black.opacity(0.2))
-          .padding(geometry.size.width * 0.1)
-          .mask(
-            ZStack {
-              Rectangle()
-
-              Image(systemName: "cube")
-                .resizable()
-                .scaledToFit()
-                .blendMode(.destinationOut)
-                .padding(geometry.size.width * 0.1)
-
-              Circle()
-                .blendMode(.destinationOut)
-                .padding(geometry.size.width * 0.24)
-            }
-          )
-
-        Circle()
-          .fill(.black.opacity(0.3))
-          .padding(geometry.size.width * 0.3)
-          .mask {
-            ZStack {
-              Rectangle()
-              Image(systemName: "cube")
-                .resizable()
-                .scaledToFit()
-                .blendMode(.destinationOut)
-                .padding(geometry.size.width * 0.1)
-            }
-          }
-
-        Image(systemName: "cube")
-          .resizable()
-          .scaledToFit()
-          .foregroundColor(.black.opacity(0.5))
-          .padding(geometry.size.width * 0.1)
-      }
-      .frame(maxWidth: .infinity, maxHeight: .infinity)
-      .background {
-        LinearGradient(
-          gradient: Gradient(colors: [
-            Color(cgColor: CGColor(red: 0.49, green: 0.94, blue: 0.94, alpha: 1)),
-            Color(cgColor: CGColor(red: 0.16, green: 0.81, blue: 0.86, alpha: 1)),
-          ]),
-          startPoint: .top,
-          endPoint: .bottom
-        )
-      }
-    }
-  }
-}
-
-struct ExampleAppIconView_Previews: PreviewProvider {
-  static var previews: some View {
-    IconPreviews(
-      icon: ExampleAppIconView(),
-      configs: .iOS
-    )
-  }
-}
diff --git a/Example/example-app-icon/Sources/ExampleAppIconExport/main.swift b/Example/example-app-icon/Sources/ExampleAppIconExport/main.swift
deleted file mode 100644
index 87afce21a46c6c01c1d08dc08cfeed6cd11cfb87..0000000000000000000000000000000000000000
--- a/Example/example-app-icon/Sources/ExampleAppIconExport/main.swift
+++ /dev/null
@@ -1,24 +0,0 @@
-import AppIconCreator
-import ExampleAppIcon
-import Foundation
-
-extension URL {
-  func deletingLastPathComponent() -> URL {
-    var url = self
-    url.deleteLastPathComponent()
-    return url
-  }
-}
-
-let exportURL = URL(fileURLWithPath: #file)
-  .deletingLastPathComponent()
-  .deletingLastPathComponent()
-  .deletingLastPathComponent()
-  .deletingLastPathComponent()
-  .appendingPathComponent("ExampleApp (iOS)")
-  .appendingPathComponent("Assets.xcassets")
-  .appendingPathComponent("AppIcon.appiconset")
-
-[IconImage]
-  .images(for: ExampleAppIconView(), with: .iOS)
-  .forEach { $0.save(to: exportURL) }
diff --git a/Example/example-app/.gitignore b/Example/example-app/.gitignore
deleted file mode 100644
index 3b29812086f28a2b21884e57ead495ffd9434178..0000000000000000000000000000000000000000
--- a/Example/example-app/.gitignore
+++ /dev/null
@@ -1,9 +0,0 @@
-.DS_Store
-/.build
-/Packages
-/*.xcodeproj
-xcuserdata/
-DerivedData/
-.swiftpm/config/registries.json
-.swiftpm/xcode/package.xcworkspace/contents.xcworkspacedata
-.netrc
diff --git a/Example/example-app/.swiftpm/xcode/xcshareddata/xcschemes/AppFeature.xcscheme b/Example/example-app/.swiftpm/xcode/xcshareddata/xcschemes/AppFeature.xcscheme
deleted file mode 100644
index 076cfa82379a4f3c57008017aa6f356892754cc9..0000000000000000000000000000000000000000
--- a/Example/example-app/.swiftpm/xcode/xcshareddata/xcschemes/AppFeature.xcscheme
+++ /dev/null
@@ -1,78 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<Scheme
-   LastUpgradeVersion = "1340"
-   version = "1.3">
-   <BuildAction
-      parallelizeBuildables = "YES"
-      buildImplicitDependencies = "YES">
-      <BuildActionEntries>
-         <BuildActionEntry
-            buildForTesting = "YES"
-            buildForRunning = "YES"
-            buildForProfiling = "YES"
-            buildForArchiving = "YES"
-            buildForAnalyzing = "YES">
-            <BuildableReference
-               BuildableIdentifier = "primary"
-               BlueprintIdentifier = "AppFeature"
-               BuildableName = "AppFeature"
-               BlueprintName = "AppFeature"
-               ReferencedContainer = "container:">
-            </BuildableReference>
-         </BuildActionEntry>
-      </BuildActionEntries>
-   </BuildAction>
-   <TestAction
-      buildConfiguration = "Debug"
-      selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB"
-      selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB"
-      shouldUseLaunchSchemeArgsEnv = "YES"
-      codeCoverageEnabled = "YES">
-      <Testables>
-         <TestableReference
-            skipped = "NO">
-            <BuildableReference
-               BuildableIdentifier = "primary"
-               BlueprintIdentifier = "AppFeatureTests"
-               BuildableName = "AppFeatureTests"
-               BlueprintName = "AppFeatureTests"
-               ReferencedContainer = "container:">
-            </BuildableReference>
-         </TestableReference>
-      </Testables>
-   </TestAction>
-   <LaunchAction
-      buildConfiguration = "Debug"
-      selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB"
-      selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB"
-      launchStyle = "0"
-      useCustomWorkingDirectory = "NO"
-      ignoresPersistentStateOnLaunch = "NO"
-      debugDocumentVersioning = "YES"
-      debugServiceExtension = "internal"
-      allowLocationSimulation = "YES">
-   </LaunchAction>
-   <ProfileAction
-      buildConfiguration = "Release"
-      shouldUseLaunchSchemeArgsEnv = "YES"
-      savedToolIdentifier = ""
-      useCustomWorkingDirectory = "NO"
-      debugDocumentVersioning = "YES">
-      <MacroExpansion>
-         <BuildableReference
-            BuildableIdentifier = "primary"
-            BlueprintIdentifier = "AppFeature"
-            BuildableName = "AppFeature"
-            BlueprintName = "AppFeature"
-            ReferencedContainer = "container:">
-         </BuildableReference>
-      </MacroExpansion>
-   </ProfileAction>
-   <AnalyzeAction
-      buildConfiguration = "Debug">
-   </AnalyzeAction>
-   <ArchiveAction
-      buildConfiguration = "Release"
-      revealArchiveInOrganizer = "YES">
-   </ArchiveAction>
-</Scheme>
diff --git a/Example/example-app/.swiftpm/xcode/xcshareddata/xcschemes/ErrorFeature.xcscheme b/Example/example-app/.swiftpm/xcode/xcshareddata/xcschemes/ErrorFeature.xcscheme
deleted file mode 100644
index 95ae136eb336e7590ebc8e1d791912f4c0393a84..0000000000000000000000000000000000000000
--- a/Example/example-app/.swiftpm/xcode/xcshareddata/xcschemes/ErrorFeature.xcscheme
+++ /dev/null
@@ -1,78 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<Scheme
-   LastUpgradeVersion = "1340"
-   version = "1.3">
-   <BuildAction
-      parallelizeBuildables = "YES"
-      buildImplicitDependencies = "YES">
-      <BuildActionEntries>
-         <BuildActionEntry
-            buildForTesting = "YES"
-            buildForRunning = "YES"
-            buildForProfiling = "YES"
-            buildForArchiving = "YES"
-            buildForAnalyzing = "YES">
-            <BuildableReference
-               BuildableIdentifier = "primary"
-               BlueprintIdentifier = "ErrorFeature"
-               BuildableName = "ErrorFeature"
-               BlueprintName = "ErrorFeature"
-               ReferencedContainer = "container:">
-            </BuildableReference>
-         </BuildActionEntry>
-      </BuildActionEntries>
-   </BuildAction>
-   <TestAction
-      buildConfiguration = "Debug"
-      selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB"
-      selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB"
-      shouldUseLaunchSchemeArgsEnv = "YES"
-      codeCoverageEnabled = "YES">
-      <Testables>
-         <TestableReference
-            skipped = "NO">
-            <BuildableReference
-               BuildableIdentifier = "primary"
-               BlueprintIdentifier = "ErrorFeatureTests"
-               BuildableName = "ErrorFeatureTests"
-               BlueprintName = "ErrorFeatureTests"
-               ReferencedContainer = "container:">
-            </BuildableReference>
-         </TestableReference>
-      </Testables>
-   </TestAction>
-   <LaunchAction
-      buildConfiguration = "Debug"
-      selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB"
-      selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB"
-      launchStyle = "0"
-      useCustomWorkingDirectory = "NO"
-      ignoresPersistentStateOnLaunch = "NO"
-      debugDocumentVersioning = "YES"
-      debugServiceExtension = "internal"
-      allowLocationSimulation = "YES">
-   </LaunchAction>
-   <ProfileAction
-      buildConfiguration = "Release"
-      shouldUseLaunchSchemeArgsEnv = "YES"
-      savedToolIdentifier = ""
-      useCustomWorkingDirectory = "NO"
-      debugDocumentVersioning = "YES">
-      <MacroExpansion>
-         <BuildableReference
-            BuildableIdentifier = "primary"
-            BlueprintIdentifier = "ErrorFeature"
-            BuildableName = "ErrorFeature"
-            BlueprintName = "ErrorFeature"
-            ReferencedContainer = "container:">
-         </BuildableReference>
-      </MacroExpansion>
-   </ProfileAction>
-   <AnalyzeAction
-      buildConfiguration = "Debug">
-   </AnalyzeAction>
-   <ArchiveAction
-      buildConfiguration = "Release"
-      revealArchiveInOrganizer = "YES">
-   </ArchiveAction>
-</Scheme>
diff --git a/Example/example-app/.swiftpm/xcode/xcshareddata/xcschemes/LandingFeature.xcscheme b/Example/example-app/.swiftpm/xcode/xcshareddata/xcschemes/LandingFeature.xcscheme
deleted file mode 100644
index 7d203fde1b21e22854fa66dfc0b2f4253280f862..0000000000000000000000000000000000000000
--- a/Example/example-app/.swiftpm/xcode/xcshareddata/xcschemes/LandingFeature.xcscheme
+++ /dev/null
@@ -1,78 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<Scheme
-   LastUpgradeVersion = "1340"
-   version = "1.3">
-   <BuildAction
-      parallelizeBuildables = "YES"
-      buildImplicitDependencies = "YES">
-      <BuildActionEntries>
-         <BuildActionEntry
-            buildForTesting = "YES"
-            buildForRunning = "YES"
-            buildForProfiling = "YES"
-            buildForArchiving = "YES"
-            buildForAnalyzing = "YES">
-            <BuildableReference
-               BuildableIdentifier = "primary"
-               BlueprintIdentifier = "LandingFeature"
-               BuildableName = "LandingFeature"
-               BlueprintName = "LandingFeature"
-               ReferencedContainer = "container:">
-            </BuildableReference>
-         </BuildActionEntry>
-      </BuildActionEntries>
-   </BuildAction>
-   <TestAction
-      buildConfiguration = "Debug"
-      selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB"
-      selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB"
-      shouldUseLaunchSchemeArgsEnv = "YES"
-      codeCoverageEnabled = "YES">
-      <Testables>
-         <TestableReference
-            skipped = "NO">
-            <BuildableReference
-               BuildableIdentifier = "primary"
-               BlueprintIdentifier = "LandingFeatureTests"
-               BuildableName = "LandingFeatureTests"
-               BlueprintName = "LandingFeatureTests"
-               ReferencedContainer = "container:">
-            </BuildableReference>
-         </TestableReference>
-      </Testables>
-   </TestAction>
-   <LaunchAction
-      buildConfiguration = "Debug"
-      selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB"
-      selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB"
-      launchStyle = "0"
-      useCustomWorkingDirectory = "NO"
-      ignoresPersistentStateOnLaunch = "NO"
-      debugDocumentVersioning = "YES"
-      debugServiceExtension = "internal"
-      allowLocationSimulation = "YES">
-   </LaunchAction>
-   <ProfileAction
-      buildConfiguration = "Release"
-      shouldUseLaunchSchemeArgsEnv = "YES"
-      savedToolIdentifier = ""
-      useCustomWorkingDirectory = "NO"
-      debugDocumentVersioning = "YES">
-      <MacroExpansion>
-         <BuildableReference
-            BuildableIdentifier = "primary"
-            BlueprintIdentifier = "LandingFeature"
-            BuildableName = "LandingFeature"
-            BlueprintName = "LandingFeature"
-            ReferencedContainer = "container:">
-         </BuildableReference>
-      </MacroExpansion>
-   </ProfileAction>
-   <AnalyzeAction
-      buildConfiguration = "Debug">
-   </AnalyzeAction>
-   <ArchiveAction
-      buildConfiguration = "Release"
-      revealArchiveInOrganizer = "YES">
-   </ArchiveAction>
-</Scheme>
diff --git a/Example/example-app/.swiftpm/xcode/xcshareddata/xcschemes/SessionFeature.xcscheme b/Example/example-app/.swiftpm/xcode/xcshareddata/xcschemes/SessionFeature.xcscheme
deleted file mode 100644
index 9361c5551eb399da5f095ac23edd410d6b284503..0000000000000000000000000000000000000000
--- a/Example/example-app/.swiftpm/xcode/xcshareddata/xcschemes/SessionFeature.xcscheme
+++ /dev/null
@@ -1,78 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<Scheme
-   LastUpgradeVersion = "1340"
-   version = "1.3">
-   <BuildAction
-      parallelizeBuildables = "YES"
-      buildImplicitDependencies = "YES">
-      <BuildActionEntries>
-         <BuildActionEntry
-            buildForTesting = "YES"
-            buildForRunning = "YES"
-            buildForProfiling = "YES"
-            buildForArchiving = "YES"
-            buildForAnalyzing = "YES">
-            <BuildableReference
-               BuildableIdentifier = "primary"
-               BlueprintIdentifier = "SessionFeature"
-               BuildableName = "SessionFeature"
-               BlueprintName = "SessionFeature"
-               ReferencedContainer = "container:">
-            </BuildableReference>
-         </BuildActionEntry>
-      </BuildActionEntries>
-   </BuildAction>
-   <TestAction
-      buildConfiguration = "Debug"
-      selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB"
-      selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB"
-      shouldUseLaunchSchemeArgsEnv = "YES"
-      codeCoverageEnabled = "YES">
-      <Testables>
-         <TestableReference
-            skipped = "NO">
-            <BuildableReference
-               BuildableIdentifier = "primary"
-               BlueprintIdentifier = "SessionFeatureTests"
-               BuildableName = "SessionFeatureTests"
-               BlueprintName = "SessionFeatureTests"
-               ReferencedContainer = "container:">
-            </BuildableReference>
-         </TestableReference>
-      </Testables>
-   </TestAction>
-   <LaunchAction
-      buildConfiguration = "Debug"
-      selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB"
-      selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB"
-      launchStyle = "0"
-      useCustomWorkingDirectory = "NO"
-      ignoresPersistentStateOnLaunch = "NO"
-      debugDocumentVersioning = "YES"
-      debugServiceExtension = "internal"
-      allowLocationSimulation = "YES">
-   </LaunchAction>
-   <ProfileAction
-      buildConfiguration = "Release"
-      shouldUseLaunchSchemeArgsEnv = "YES"
-      savedToolIdentifier = ""
-      useCustomWorkingDirectory = "NO"
-      debugDocumentVersioning = "YES">
-      <MacroExpansion>
-         <BuildableReference
-            BuildableIdentifier = "primary"
-            BlueprintIdentifier = "SessionFeature"
-            BuildableName = "SessionFeature"
-            BlueprintName = "SessionFeature"
-            ReferencedContainer = "container:">
-         </BuildableReference>
-      </MacroExpansion>
-   </ProfileAction>
-   <AnalyzeAction
-      buildConfiguration = "Debug">
-   </AnalyzeAction>
-   <ArchiveAction
-      buildConfiguration = "Release"
-      revealArchiveInOrganizer = "YES">
-   </ArchiveAction>
-</Scheme>
diff --git a/Example/example-app/.swiftpm/xcode/xcshareddata/xcschemes/example-app.xcscheme b/Example/example-app/.swiftpm/xcode/xcshareddata/xcschemes/example-app.xcscheme
deleted file mode 100644
index c6edd5dda410050c40e6df64bd48b668c357afde..0000000000000000000000000000000000000000
--- a/Example/example-app/.swiftpm/xcode/xcshareddata/xcschemes/example-app.xcscheme
+++ /dev/null
@@ -1,198 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<Scheme
-   LastUpgradeVersion = "1340"
-   version = "1.3">
-   <BuildAction
-      parallelizeBuildables = "YES"
-      buildImplicitDependencies = "YES">
-      <BuildActionEntries>
-         <BuildActionEntry
-            buildForTesting = "YES"
-            buildForRunning = "YES"
-            buildForProfiling = "YES"
-            buildForArchiving = "YES"
-            buildForAnalyzing = "YES">
-            <BuildableReference
-               BuildableIdentifier = "primary"
-               BlueprintIdentifier = "AppFeature"
-               BuildableName = "AppFeature"
-               BlueprintName = "AppFeature"
-               ReferencedContainer = "container:">
-            </BuildableReference>
-         </BuildActionEntry>
-         <BuildActionEntry
-            buildForTesting = "YES"
-            buildForRunning = "YES"
-            buildForProfiling = "YES"
-            buildForArchiving = "YES"
-            buildForAnalyzing = "YES">
-            <BuildableReference
-               BuildableIdentifier = "primary"
-               BlueprintIdentifier = "ErrorFeature"
-               BuildableName = "ErrorFeature"
-               BlueprintName = "ErrorFeature"
-               ReferencedContainer = "container:">
-            </BuildableReference>
-         </BuildActionEntry>
-         <BuildActionEntry
-            buildForTesting = "YES"
-            buildForRunning = "YES"
-            buildForProfiling = "YES"
-            buildForArchiving = "YES"
-            buildForAnalyzing = "YES">
-            <BuildableReference
-               BuildableIdentifier = "primary"
-               BlueprintIdentifier = "LandingFeature"
-               BuildableName = "LandingFeature"
-               BlueprintName = "LandingFeature"
-               ReferencedContainer = "container:">
-            </BuildableReference>
-         </BuildActionEntry>
-         <BuildActionEntry
-            buildForTesting = "YES"
-            buildForRunning = "YES"
-            buildForProfiling = "YES"
-            buildForArchiving = "YES"
-            buildForAnalyzing = "YES">
-            <BuildableReference
-               BuildableIdentifier = "primary"
-               BlueprintIdentifier = "MyContactFeature"
-               BuildableName = "MyContactFeature"
-               BlueprintName = "MyContactFeature"
-               ReferencedContainer = "container:">
-            </BuildableReference>
-         </BuildActionEntry>
-         <BuildActionEntry
-            buildForTesting = "YES"
-            buildForRunning = "YES"
-            buildForProfiling = "YES"
-            buildForArchiving = "YES"
-            buildForAnalyzing = "YES">
-            <BuildableReference
-               BuildableIdentifier = "primary"
-               BlueprintIdentifier = "MyIdentityFeature"
-               BuildableName = "MyIdentityFeature"
-               BlueprintName = "MyIdentityFeature"
-               ReferencedContainer = "container:">
-            </BuildableReference>
-         </BuildActionEntry>
-         <BuildActionEntry
-            buildForTesting = "YES"
-            buildForRunning = "YES"
-            buildForProfiling = "YES"
-            buildForArchiving = "YES"
-            buildForAnalyzing = "YES">
-            <BuildableReference
-               BuildableIdentifier = "primary"
-               BlueprintIdentifier = "SessionFeature"
-               BuildableName = "SessionFeature"
-               BlueprintName = "SessionFeature"
-               ReferencedContainer = "container:">
-            </BuildableReference>
-         </BuildActionEntry>
-      </BuildActionEntries>
-   </BuildAction>
-   <TestAction
-      buildConfiguration = "Debug"
-      selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB"
-      selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB"
-      shouldUseLaunchSchemeArgsEnv = "YES"
-      codeCoverageEnabled = "YES">
-      <Testables>
-         <TestableReference
-            skipped = "NO">
-            <BuildableReference
-               BuildableIdentifier = "primary"
-               BlueprintIdentifier = "AppFeatureTests"
-               BuildableName = "AppFeatureTests"
-               BlueprintName = "AppFeatureTests"
-               ReferencedContainer = "container:">
-            </BuildableReference>
-         </TestableReference>
-         <TestableReference
-            skipped = "NO">
-            <BuildableReference
-               BuildableIdentifier = "primary"
-               BlueprintIdentifier = "ErrorFeatureTests"
-               BuildableName = "ErrorFeatureTests"
-               BlueprintName = "ErrorFeatureTests"
-               ReferencedContainer = "container:">
-            </BuildableReference>
-         </TestableReference>
-         <TestableReference
-            skipped = "NO">
-            <BuildableReference
-               BuildableIdentifier = "primary"
-               BlueprintIdentifier = "LandingFeatureTests"
-               BuildableName = "LandingFeatureTests"
-               BlueprintName = "LandingFeatureTests"
-               ReferencedContainer = "container:">
-            </BuildableReference>
-         </TestableReference>
-         <TestableReference
-            skipped = "NO">
-            <BuildableReference
-               BuildableIdentifier = "primary"
-               BlueprintIdentifier = "MyContactFeatureTests"
-               BuildableName = "MyContactFeatureTests"
-               BlueprintName = "MyContactFeatureTests"
-               ReferencedContainer = "container:">
-            </BuildableReference>
-         </TestableReference>
-         <TestableReference
-            skipped = "NO">
-            <BuildableReference
-               BuildableIdentifier = "primary"
-               BlueprintIdentifier = "MyIdentityFeatureTests"
-               BuildableName = "MyIdentityFeatureTests"
-               BlueprintName = "MyIdentityFeatureTests"
-               ReferencedContainer = "container:">
-            </BuildableReference>
-         </TestableReference>
-         <TestableReference
-            skipped = "NO">
-            <BuildableReference
-               BuildableIdentifier = "primary"
-               BlueprintIdentifier = "SessionFeatureTests"
-               BuildableName = "SessionFeatureTests"
-               BlueprintName = "SessionFeatureTests"
-               ReferencedContainer = "container:">
-            </BuildableReference>
-         </TestableReference>
-      </Testables>
-   </TestAction>
-   <LaunchAction
-      buildConfiguration = "Debug"
-      selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB"
-      selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB"
-      launchStyle = "0"
-      useCustomWorkingDirectory = "NO"
-      ignoresPersistentStateOnLaunch = "NO"
-      debugDocumentVersioning = "YES"
-      debugServiceExtension = "internal"
-      allowLocationSimulation = "YES">
-   </LaunchAction>
-   <ProfileAction
-      buildConfiguration = "Release"
-      shouldUseLaunchSchemeArgsEnv = "YES"
-      savedToolIdentifier = ""
-      useCustomWorkingDirectory = "NO"
-      debugDocumentVersioning = "YES">
-      <MacroExpansion>
-         <BuildableReference
-            BuildableIdentifier = "primary"
-            BlueprintIdentifier = "AppFeature"
-            BuildableName = "AppFeature"
-            BlueprintName = "AppFeature"
-            ReferencedContainer = "container:">
-         </BuildableReference>
-      </MacroExpansion>
-   </ProfileAction>
-   <AnalyzeAction
-      buildConfiguration = "Debug">
-   </AnalyzeAction>
-   <ArchiveAction
-      buildConfiguration = "Release"
-      revealArchiveInOrganizer = "YES">
-   </ArchiveAction>
-</Scheme>
diff --git a/Example/example-app/Package.swift b/Example/example-app/Package.swift
deleted file mode 100644
index ec68a31a650f1ce9d1e4fc5a0282894c9e61a5b7..0000000000000000000000000000000000000000
--- a/Example/example-app/Package.swift
+++ /dev/null
@@ -1,121 +0,0 @@
-// swift-tools-version: 5.6
-import PackageDescription
-
-let swiftSettings: [SwiftSetting] = [
-  .unsafeFlags(
-    [
-      "-Xfrontend", "-debug-time-function-bodies",
-      "-Xfrontend", "-debug-time-expression-type-checking",
-    ],
-    .when(configuration: .debug)
-  ),
-]
-
-let package = Package(
-  name: "example-app",
-  platforms: [
-    .iOS(.v15),
-  ],
-  products: [
-    .library(name: "AppFeature", targets: ["AppFeature"]),
-    .library(name: "ErrorFeature", targets: ["ErrorFeature"]),
-    .library(name: "LandingFeature", targets: ["LandingFeature"]),
-    .library(name: "SessionFeature", targets: ["SessionFeature"]),
-  ],
-  dependencies: [
-    .package(
-      path: "../../"
-    ),
-    .package(
-      url: "https://github.com/pointfreeco/swift-composable-architecture.git",
-      .upToNextMajor(from: "0.39.0")
-    ),
-    .package(
-      url: "https://github.com/darrarski/swift-composable-presentation.git",
-      .upToNextMajor(from: "0.5.2")
-    ),
-    .package(
-      url: "https://github.com/kishikawakatsumi/KeychainAccess.git",
-      .upToNextMajor(from: "4.2.2")
-    ),
-    .package(
-      url: "https://github.com/pointfreeco/xctest-dynamic-overlay.git",
-      .upToNextMajor(from: "0.4.0")
-    ),
-  ],
-  targets: [
-    .target(
-      name: "AppFeature",
-      dependencies: [
-        .target(name: "ErrorFeature"),
-        .target(name: "LandingFeature"),
-        .target(name: "SessionFeature"),
-        .product(name: "ComposableArchitecture", package: "swift-composable-architecture"),
-        .product(name: "ComposablePresentation", package: "swift-composable-presentation"),
-        .product(name: "KeychainAccess", package: "KeychainAccess"),
-        .product(name: "XCTestDynamicOverlay", package: "xctest-dynamic-overlay"),
-        .product(name: "XXClient", package: "elixxir-dapps-sdk-swift"),
-      ],
-      swiftSettings: swiftSettings
-    ),
-    .testTarget(
-      name: "AppFeatureTests",
-      dependencies: [
-        .target(name: "AppFeature"),
-      ],
-      swiftSettings: swiftSettings
-    ),
-    .target(
-      name: "ErrorFeature",
-      dependencies: [
-        .product(name: "ComposableArchitecture", package: "swift-composable-architecture"),
-        .product(name: "XCTestDynamicOverlay", package: "xctest-dynamic-overlay"),
-        .product(name: "XXClient", package: "elixxir-dapps-sdk-swift"),
-      ],
-      swiftSettings: swiftSettings
-    ),
-    .testTarget(
-      name: "ErrorFeatureTests",
-      dependencies: [
-        .target(name: "ErrorFeature"),
-      ],
-      swiftSettings: swiftSettings
-    ),
-    .target(
-      name: "LandingFeature",
-      dependencies: [
-        .target(name: "ErrorFeature"),
-        .product(name: "ComposableArchitecture", package: "swift-composable-architecture"),
-        .product(name: "ComposablePresentation", package: "swift-composable-presentation"),
-        .product(name: "XCTestDynamicOverlay", package: "xctest-dynamic-overlay"),
-        .product(name: "XXClient", package: "elixxir-dapps-sdk-swift"),
-      ],
-      swiftSettings: swiftSettings
-    ),
-    .testTarget(
-      name: "LandingFeatureTests",
-      dependencies: [
-        .target(name: "LandingFeature"),
-      ],
-      swiftSettings: swiftSettings
-    ),
-    .target(
-      name: "SessionFeature",
-      dependencies: [
-        .target(name: "ErrorFeature"),
-        .product(name: "ComposableArchitecture", package: "swift-composable-architecture"),
-        .product(name: "ComposablePresentation", package: "swift-composable-presentation"),
-        .product(name: "XCTestDynamicOverlay", package: "xctest-dynamic-overlay"),
-        .product(name: "XXClient", package: "elixxir-dapps-sdk-swift"),
-      ],
-      swiftSettings: swiftSettings
-    ),
-    .testTarget(
-      name: "SessionFeatureTests",
-      dependencies: [
-        .target(name: "SessionFeature"),
-      ],
-      swiftSettings: swiftSettings
-    ),
-  ]
-)
diff --git a/Example/example-app/Sources/AppFeature/App.swift b/Example/example-app/Sources/AppFeature/App.swift
deleted file mode 100644
index c1fa59417c089cbf3e9371ced8a3bb80225f0b37..0000000000000000000000000000000000000000
--- a/Example/example-app/Sources/AppFeature/App.swift
+++ /dev/null
@@ -1,52 +0,0 @@
-import Combine
-import ComposableArchitecture
-import ErrorFeature
-import LandingFeature
-import SessionFeature
-import SwiftUI
-import XXClient
-
-@main
-struct App: SwiftUI.App {
-  var body: some Scene {
-    WindowGroup {
-      AppView(store: Store(
-        initialState: AppState(),
-        reducer: appReducer,
-        environment: .live()
-      ))
-    }
-  }
-}
-
-extension AppEnvironment {
-  static func live() -> AppEnvironment {
-    let cMixSubject = CurrentValueSubject<CMix?, Never>(nil)
-    let mainScheduler = DispatchQueue.main.eraseToAnyScheduler()
-    let bgScheduler = DispatchQueue(
-      label: "xx.network.dApps.ExampleApp.bg",
-      qos: .background
-    ).eraseToAnyScheduler()
-
-    return AppEnvironment(
-      makeId: UUID.init,
-      hasCMix: { cMixSubject.map { $0 != nil }.eraseToAnyPublisher() },
-      mainScheduler: mainScheduler,
-      landing: LandingEnvironment(
-        cMixManager: .live(
-          passwordStorage: .keychain
-        ),
-        setCMix: { cMixSubject.value = $0 },
-        bgScheduler: bgScheduler,
-        mainScheduler: mainScheduler,
-        error: ErrorEnvironment()
-      ),
-      session: SessionEnvironment(
-        getCMix: { cMixSubject.value },
-        bgScheduler: bgScheduler,
-        mainScheduler: mainScheduler,
-        error: ErrorEnvironment()
-      )
-    )
-  }
-}
diff --git a/Example/example-app/Sources/AppFeature/AppFeature.swift b/Example/example-app/Sources/AppFeature/AppFeature.swift
deleted file mode 100644
index cc871972d695b8e0f35d56ba3d9b8d4d94d12a1e..0000000000000000000000000000000000000000
--- a/Example/example-app/Sources/AppFeature/AppFeature.swift
+++ /dev/null
@@ -1,107 +0,0 @@
-import Combine
-import ComposableArchitecture
-import ComposablePresentation
-import LandingFeature
-import SessionFeature
-import XCTestDynamicOverlay
-
-struct AppState: Equatable {
-  enum Scene: Equatable {
-    case landing(LandingState)
-    case session(SessionState)
-  }
-
-  var id: UUID = UUID()
-  var scene: Scene = .landing(LandingState(id: UUID()))
-}
-
-extension AppState.Scene {
-  var asLanding: LandingState? {
-    get {
-      guard case .landing(let state) = self else { return nil }
-      return state
-    }
-    set {
-      guard let newValue = newValue else { return }
-      self = .landing(newValue)
-    }
-  }
-
-  var asSession: SessionState? {
-    get {
-      guard case .session(let state) = self else { return nil }
-      return state
-    }
-    set {
-      guard let newValue = newValue else { return }
-      self = .session(newValue)
-    }
-  }
-}
-
-enum AppAction: Equatable {
-  case viewDidLoad
-  case cMixDidChange(hasCMix: Bool)
-  case landing(LandingAction)
-  case session(SessionAction)
-}
-
-struct AppEnvironment {
-  var makeId: () -> UUID
-  var hasCMix: () -> AnyPublisher<Bool, Never>
-  var mainScheduler: AnySchedulerOf<DispatchQueue>
-  var landing: LandingEnvironment
-  var session: SessionEnvironment
-}
-
-let appReducer = Reducer<AppState, AppAction, AppEnvironment>
-{ state, action, env in
-  enum HasCMixEffectId {}
-
-  switch action {
-  case .viewDidLoad:
-    return env.hasCMix()
-      .removeDuplicates()
-      .map(AppAction.cMixDidChange(hasCMix:))
-      .receive(on: env.mainScheduler)
-      .eraseToEffect()
-      .cancellable(id: HasCMixEffectId.self, cancelInFlight: true)
-
-  case .cMixDidChange(let hasClient):
-    if hasClient {
-      let sessionState = state.scene.asSession ?? SessionState(id: env.makeId())
-      state.scene = .session(sessionState)
-    } else {
-      let landingState = state.scene.asLanding ?? LandingState(id: env.makeId())
-      state.scene = .landing(landingState)
-    }
-    return .none
-
-  case .landing(_), .session(_):
-    return .none
-  }
-}
-.presenting(
-  landingReducer,
-  state: .keyPath(\.scene.asLanding),
-  id: .notNil(),
-  action: /AppAction.landing,
-  environment: \.landing
-)
-.presenting(
-  sessionReducer,
-  state: .keyPath(\.scene.asSession),
-  id: .notNil(),
-  action: /AppAction.session,
-  environment: \.session
-)
-
-extension AppEnvironment {
-  static let unimplemented = AppEnvironment(
-    makeId: XCTUnimplemented("\(Self.self).makeId", placeholder: UUID()),
-    hasCMix: XCTUnimplemented("\(Self.self).hasCMix", placeholder: Empty().eraseToAnyPublisher()),
-    mainScheduler: .unimplemented,
-    landing: .unimplemented,
-    session: .unimplemented
-  )
-}
diff --git a/Example/example-app/Sources/AppFeature/AppView.swift b/Example/example-app/Sources/AppFeature/AppView.swift
deleted file mode 100644
index bf7bcd3d7718f938986b9d1401ef96231a212720..0000000000000000000000000000000000000000
--- a/Example/example-app/Sources/AppFeature/AppView.swift
+++ /dev/null
@@ -1,82 +0,0 @@
-import ComposableArchitecture
-import LandingFeature
-import SessionFeature
-import SwiftUI
-
-struct AppView: View {
-  let store: Store<AppState, AppAction>
-
-  struct ViewState: Equatable {
-    enum Scene: Equatable {
-      case landing
-      case session
-    }
-
-    let scene: Scene
-
-    init(state: AppState) {
-      switch state.scene {
-      case .landing(_):
-        self.scene = .landing
-
-      case .session(_):
-        self.scene = .session
-      }
-    }
-  }
-
-  var body: some View {
-    WithViewStore(store.scope(state: ViewState.init)) { viewStore in
-      ZStack {
-        SwitchStore(store.scope(state: \.scene)) {
-          CaseLet(
-            state: /AppState.Scene.landing,
-            action: AppAction.landing,
-            then: { store in
-              NavigationView {
-                LandingView(store: store)
-              }
-              .navigationViewStyle(.stack)
-              .transition(.asymmetric(
-                insertion: .move(edge: .leading),
-                removal: .opacity
-              ))
-            }
-          )
-
-          CaseLet(
-            state: /AppState.Scene.session,
-            action: AppAction.session,
-            then: { store in
-              NavigationView {
-                SessionView(store: store)
-              }
-              .navigationViewStyle(.stack)
-              .transition(.asymmetric(
-                insertion: .move(edge: .trailing),
-                removal: .opacity
-              ))
-            }
-          )
-        }
-        .frame(maxWidth: .infinity, maxHeight: .infinity)
-      }
-      .animation(.default, value: viewStore.scene)
-      .task {
-        viewStore.send(.viewDidLoad)
-      }
-    }
-  }
-}
-
-#if DEBUG
-struct AppView_Previews: PreviewProvider {
-  static var previews: some View {
-    AppView(store: Store(
-      initialState: AppState(),
-      reducer: .empty,
-      environment: ()
-    ))
-  }
-}
-#endif
diff --git a/Example/example-app/Sources/AppFeature/PasswordStorage+Keychain.swift b/Example/example-app/Sources/AppFeature/PasswordStorage+Keychain.swift
deleted file mode 100644
index 1b1a26de96c3fc947daf479a4d7eb528754aeada..0000000000000000000000000000000000000000
--- a/Example/example-app/Sources/AppFeature/PasswordStorage+Keychain.swift
+++ /dev/null
@@ -1,14 +0,0 @@
-import KeychainAccess
-import XXClient
-
-extension PasswordStorage {
-  static let keychain: PasswordStorage = {
-    let keychain = KeychainAccess.Keychain(
-      service: "xx.network.dApps.ExampleApp"
-    )
-    return PasswordStorage(
-      save: { password in keychain[data: "password"] = password},
-      load: { try keychain[data: "password"] ?? { throw MissingPasswordError() }() }
-    )
-  }()
-}
diff --git a/Example/example-app/Sources/ErrorFeature/ErrorFeature.swift b/Example/example-app/Sources/ErrorFeature/ErrorFeature.swift
deleted file mode 100644
index eb1671e8424a7db0ee5ccb12c8fef9289d1277da..0000000000000000000000000000000000000000
--- a/Example/example-app/Sources/ErrorFeature/ErrorFeature.swift
+++ /dev/null
@@ -1,22 +0,0 @@
-import ComposableArchitecture
-import XCTestDynamicOverlay
-
-public struct ErrorState: Equatable {
-  public init(error: NSError) {
-    self.error = error
-  }
-
-  public var error: NSError
-}
-
-public enum ErrorAction: Equatable {}
-
-public struct ErrorEnvironment {
-  public init() {}
-}
-
-public let errorReducer = Reducer<ErrorState, ErrorAction, ErrorEnvironment>.empty
-
-extension ErrorEnvironment {
-  public static let unimplemented = ErrorEnvironment()
-}
diff --git a/Example/example-app/Sources/ErrorFeature/ErrorView.swift b/Example/example-app/Sources/ErrorFeature/ErrorView.swift
deleted file mode 100644
index 35d9b84785a2906d677008ea64440a4952f84654..0000000000000000000000000000000000000000
--- a/Example/example-app/Sources/ErrorFeature/ErrorView.swift
+++ /dev/null
@@ -1,53 +0,0 @@
-import ComposableArchitecture
-import SwiftUI
-
-public struct ErrorView: View {
-  public init(store: Store<ErrorState, ErrorAction>) {
-    self.store = store
-  }
-
-  let store: Store<ErrorState, ErrorAction>
-  @Environment(\.dismiss) var dismiss
-
-  struct ViewState: Equatable {
-    let error: NSError
-
-    init(state: ErrorState) {
-      error = state.error
-    }
-  }
-
-  public var body: some View {
-    WithViewStore(store.scope(state: ViewState.init)) { viewStore in
-      NavigationView {
-        Form {
-          Text("\(viewStore.error)")
-        }
-        .navigationTitle("Error")
-        .toolbar {
-          ToolbarItem(placement: .cancellationAction) {
-            Button {
-              dismiss()
-            } label: {
-              Image(systemName: "xmark")
-            }
-          }
-        }
-      }
-    }
-  }
-}
-
-#if DEBUG
-public struct ErrorView_Previews: PreviewProvider {
-  public static var previews: some View {
-    ErrorView(store: .init(
-      initialState: .init(
-        error: NSError(domain: "preview", code: 1234)
-      ),
-      reducer: .empty,
-      environment: ()
-    ))
-  }
-}
-#endif
diff --git a/Example/example-app/Sources/LandingFeature/LandingFeature.swift b/Example/example-app/Sources/LandingFeature/LandingFeature.swift
deleted file mode 100644
index 294b53f8ed023f78dd566fd6e5e6581fe4e68e7e..0000000000000000000000000000000000000000
--- a/Example/example-app/Sources/LandingFeature/LandingFeature.swift
+++ /dev/null
@@ -1,145 +0,0 @@
-import Combine
-import ComposableArchitecture
-import ErrorFeature
-import XCTestDynamicOverlay
-import XXClient
-
-public struct LandingState: Equatable {
-  public init(
-    id: UUID,
-    hasStoredCMix: Bool = false,
-    isMakingCMix: Bool = false,
-    isRemovingCMix: Bool = false,
-    error: ErrorState? = nil
-  ) {
-    self.id = id
-    self.hasStoredCMix = hasStoredCMix
-    self.isMakingCMix = isMakingCMix
-    self.isRemovingCMix = isRemovingCMix
-    self.error = error
-  }
-
-  var id: UUID
-  var hasStoredCMix: Bool
-  var isMakingCMix: Bool
-  var isRemovingCMix: Bool
-  var error: ErrorState?
-}
-
-public enum LandingAction: Equatable {
-  case viewDidLoad
-  case makeCMix
-  case didMakeCMix
-  case didFailMakingCMix(NSError)
-  case removeStoredCMix
-  case didRemoveStoredCMix
-  case didFailRemovingStoredCMix(NSError)
-  case didDismissError
-  case error(ErrorAction)
-}
-
-public struct LandingEnvironment {
-  public init(
-    cMixManager: CMixManager,
-    setCMix: @escaping (CMix) -> Void,
-    bgScheduler: AnySchedulerOf<DispatchQueue>,
-    mainScheduler: AnySchedulerOf<DispatchQueue>,
-    error: ErrorEnvironment
-  ) {
-    self.cMixManager = cMixManager
-    self.setCMix = setCMix
-    self.bgScheduler = bgScheduler
-    self.mainScheduler = mainScheduler
-    self.error = error
-  }
-
-  public var cMixManager: CMixManager
-  public var setCMix: (CMix) -> Void
-  public var bgScheduler: AnySchedulerOf<DispatchQueue>
-  public var mainScheduler: AnySchedulerOf<DispatchQueue>
-  public var error: ErrorEnvironment
-}
-
-public let landingReducer = Reducer<LandingState, LandingAction, LandingEnvironment>
-{ state, action, env in
-  switch action {
-  case .viewDidLoad:
-    state.hasStoredCMix = env.cMixManager.hasStorage()
-    return .none
-
-  case .makeCMix:
-    state.isMakingCMix = true
-    return Effect.future { fulfill in
-      do {
-        if env.cMixManager.hasStorage() {
-          env.setCMix(try env.cMixManager.load())
-        } else {
-          env.setCMix(try env.cMixManager.create())
-        }
-        fulfill(.success(.didMakeCMix))
-      } catch {
-        fulfill(.success(.didFailMakingCMix(error as NSError)))
-      }
-    }
-    .subscribe(on: env.bgScheduler)
-    .receive(on: env.mainScheduler)
-    .eraseToEffect()
-
-  case .didMakeCMix:
-    state.isMakingCMix = false
-    state.hasStoredCMix = env.cMixManager.hasStorage()
-    return .none
-
-  case .didFailMakingCMix(let error):
-    state.isMakingCMix = false
-    state.hasStoredCMix = env.cMixManager.hasStorage()
-    state.error = ErrorState(error: error)
-    return .none
-
-  case .removeStoredCMix:
-    state.isRemovingCMix = true
-    return Effect.future { fulfill in
-      do {
-        try env.cMixManager.remove()
-        fulfill(.success(.didRemoveStoredCMix))
-      } catch {
-        fulfill(.success(.didFailRemovingStoredCMix(error as NSError)))
-      }
-    }
-    .subscribe(on: env.bgScheduler)
-    .receive(on: env.mainScheduler)
-    .eraseToEffect()
-
-  case .didRemoveStoredCMix:
-    state.isRemovingCMix = false
-    state.hasStoredCMix = env.cMixManager.hasStorage()
-    return .none
-
-  case .didFailRemovingStoredCMix(let error):
-    state.isRemovingCMix = false
-    state.hasStoredCMix = env.cMixManager.hasStorage()
-    state.error = ErrorState(error: error)
-    return .none
-
-  case .didDismissError:
-    state.error = nil
-    return .none
-  }
-}
-.presenting(
-  errorReducer,
-  state: .keyPath(\.error),
-  id: .keyPath(\.?.error),
-  action: /LandingAction.error,
-  environment: \.error
-)
-
-extension LandingEnvironment {
-  public static let unimplemented = LandingEnvironment(
-    cMixManager: .unimplemented,
-    setCMix: XCTUnimplemented("\(Self.self).setCMix"),
-    bgScheduler: .unimplemented,
-    mainScheduler: .unimplemented,
-    error: .unimplemented
-  )
-}
diff --git a/Example/example-app/Sources/LandingFeature/LandingView.swift b/Example/example-app/Sources/LandingFeature/LandingView.swift
deleted file mode 100644
index e6903c2e957a9c40913b5f3635824fa43ef93ef5..0000000000000000000000000000000000000000
--- a/Example/example-app/Sources/LandingFeature/LandingView.swift
+++ /dev/null
@@ -1,91 +0,0 @@
-import ComposableArchitecture
-import ComposablePresentation
-import ErrorFeature
-import SwiftUI
-
-public struct LandingView: View {
-  public init(store: Store<LandingState, LandingAction>) {
-    self.store = store
-  }
-
-  let store: Store<LandingState, LandingAction>
-
-  struct ViewState: Equatable {
-    let hasStoredCMix: Bool
-    let isMakingCMix: Bool
-    let isRemovingCMix: Bool
-
-    init(state: LandingState) {
-      hasStoredCMix = state.hasStoredCMix
-      isMakingCMix = state.isMakingCMix
-      isRemovingCMix = state.isRemovingCMix
-    }
-
-    var isLoading: Bool {
-      isMakingCMix ||
-      isRemovingCMix
-    }
-  }
-
-  public var body: some View {
-    WithViewStore(store.scope(state: ViewState.init)) { viewStore in
-      Form {
-        Button {
-          viewStore.send(.makeCMix)
-        } label: {
-          HStack {
-            Text(viewStore.hasStoredCMix ? "Load stored cMix" : "Create new cMix")
-            Spacer()
-            if viewStore.isMakingCMix {
-              ProgressView()
-            }
-          }
-        }
-
-        if viewStore.hasStoredCMix {
-          Button(role: .destructive) {
-            viewStore.send(.removeStoredCMix)
-          } label: {
-            HStack {
-              Text("Remove stored cMix")
-              Spacer()
-              if viewStore.isRemovingCMix {
-                ProgressView()
-              }
-            }
-          }
-        }
-      }
-      .navigationTitle("Landing")
-      .disabled(viewStore.isLoading)
-      .task {
-        viewStore.send(.viewDidLoad)
-      }
-      .sheet(
-        store.scope(
-          state: \.error,
-          action: LandingAction.error
-        ),
-        onDismiss: {
-          viewStore.send(.didDismissError)
-        },
-        content: ErrorView.init(store:)
-      )
-    }
-  }
-}
-
-#if DEBUG
-public struct LandingView_Previews: PreviewProvider {
-  public static var previews: some View {
-    NavigationView {
-      LandingView(store: .init(
-        initialState: .init(id: UUID()),
-        reducer: .empty,
-        environment: ()
-      ))
-    }
-    .navigationViewStyle(.stack)
-  }
-}
-#endif
diff --git a/Example/example-app/Sources/SessionFeature/NetworkFollowerStatusView.swift b/Example/example-app/Sources/SessionFeature/NetworkFollowerStatusView.swift
deleted file mode 100644
index 7b478312477ca5f898952a4ab50213dd9f3c9b3f..0000000000000000000000000000000000000000
--- a/Example/example-app/Sources/SessionFeature/NetworkFollowerStatusView.swift
+++ /dev/null
@@ -1,40 +0,0 @@
-import SwiftUI
-import XXClient
-
-struct NetworkFollowerStatusView: View {
-  var status: NetworkFollowerStatus?
-
-  var body: some View {
-    switch status {
-    case .stopped:
-      Label("Stopped", systemImage: "stop.fill")
-
-    case .running:
-      Label("Running", systemImage: "play.fill")
-
-    case .stopping:
-      Label("Stopping...", systemImage: "stop")
-
-    case .unknown(let code):
-      Label("Status \(code)", systemImage: "questionmark")
-
-    case .none:
-      Label("Unknown", systemImage: "questionmark")
-    }
-  }
-}
-
-#if DEBUG
-struct NetworkFollowerStatusView_Previews: PreviewProvider {
-  static var previews: some View {
-    Group {
-      NetworkFollowerStatusView(status: .stopped)
-      NetworkFollowerStatusView(status: .running)
-      NetworkFollowerStatusView(status: .stopping)
-      NetworkFollowerStatusView(status: .unknown(code: -1))
-      NetworkFollowerStatusView(status: nil)
-    }
-    .previewLayout(.sizeThatFits)
-  }
-}
-#endif
diff --git a/Example/example-app/Sources/SessionFeature/NetworkHealthStatusView.swift b/Example/example-app/Sources/SessionFeature/NetworkHealthStatusView.swift
deleted file mode 100644
index e13cb6fc56378fc9717b4b7e5fe3469c0b7f3162..0000000000000000000000000000000000000000
--- a/Example/example-app/Sources/SessionFeature/NetworkHealthStatusView.swift
+++ /dev/null
@@ -1,33 +0,0 @@
-import SwiftUI
-
-struct NetworkHealthStatusView: View {
-  var status: Bool?
-
-  var body: some View {
-    switch status {
-    case .some(true):
-      Label("Healthy", systemImage: "wifi")
-        .foregroundColor(.green)
-
-    case .some(false):
-      Label("Unhealthy", systemImage: "bolt.horizontal.fill")
-        .foregroundColor(.red)
-
-    case .none:
-      Label("Unknown", systemImage: "questionmark")
-    }
-  }
-}
-
-#if DEBUG
-struct NetworkHealthStatusView_Previews: PreviewProvider {
-  static var previews: some View {
-    Group {
-      NetworkHealthStatusView(status: true)
-      NetworkHealthStatusView(status: false)
-      NetworkHealthStatusView(status: nil)
-    }
-    .previewLayout(.sizeThatFits)
-  }
-}
-#endif
diff --git a/Example/example-app/Sources/SessionFeature/SessionFeature.swift b/Example/example-app/Sources/SessionFeature/SessionFeature.swift
deleted file mode 100644
index 6e0931cb84253f7dba686529e2fb16f19fec99e2..0000000000000000000000000000000000000000
--- a/Example/example-app/Sources/SessionFeature/SessionFeature.swift
+++ /dev/null
@@ -1,155 +0,0 @@
-import Combine
-import ComposableArchitecture
-import ErrorFeature
-import XCTestDynamicOverlay
-import XXClient
-
-public struct SessionState: Equatable {
-  public init(
-    id: UUID,
-    networkFollowerStatus: NetworkFollowerStatus? = nil,
-    isNetworkHealthy: Bool? = nil,
-    error: ErrorState? = nil
-  ) {
-    self.id = id
-    self.networkFollowerStatus = networkFollowerStatus
-    self.isNetworkHealthy = isNetworkHealthy
-    self.error = error
-  }
-
-  public var id: UUID
-  public var networkFollowerStatus: NetworkFollowerStatus?
-  public var isNetworkHealthy: Bool?
-  public var error: ErrorState?
-}
-
-public enum SessionAction: Equatable {
-  case viewDidLoad
-  case updateNetworkFollowerStatus
-  case didUpdateNetworkFollowerStatus(NetworkFollowerStatus?)
-  case runNetworkFollower(Bool)
-  case networkFollowerDidFail(NSError)
-  case monitorNetworkHealth(Bool)
-  case didUpdateNetworkHealth(Bool?)
-  case didDismissError
-  case error(ErrorAction)
-}
-
-public struct SessionEnvironment {
-  public init(
-    getCMix: @escaping () -> CMix?,
-    bgScheduler: AnySchedulerOf<DispatchQueue>,
-    mainScheduler: AnySchedulerOf<DispatchQueue>,
-    error: ErrorEnvironment
-  ) {
-    self.getCMix = getCMix
-    self.bgScheduler = bgScheduler
-    self.mainScheduler = mainScheduler
-    self.error = error
-  }
-
-  public var getCMix: () -> CMix?
-  public var bgScheduler: AnySchedulerOf<DispatchQueue>
-  public var mainScheduler: AnySchedulerOf<DispatchQueue>
-  public var error: ErrorEnvironment
-}
-
-public let sessionReducer = Reducer<SessionState, SessionAction, SessionEnvironment>
-{ state, action, env in
-  switch action {
-  case .viewDidLoad:
-    return .merge([
-      .init(value: .updateNetworkFollowerStatus),
-      .init(value: .monitorNetworkHealth(true)),
-    ])
-
-  case .updateNetworkFollowerStatus:
-    return Effect.future { fulfill in
-      let status = env.getCMix()?.networkFollowerStatus()
-      fulfill(.success(.didUpdateNetworkFollowerStatus(status)))
-    }
-    .subscribe(on: env.bgScheduler)
-    .receive(on: env.mainScheduler)
-    .eraseToEffect()
-
-  case .didUpdateNetworkFollowerStatus(let status):
-    state.networkFollowerStatus = status
-    return .none
-
-  case .runNetworkFollower(let start):
-    return Effect.run { subscriber in
-      do {
-        if start {
-          try env.getCMix()?.startNetworkFollower(timeoutMS: 30_000)
-        } else {
-          try env.getCMix()?.stopNetworkFollower()
-        }
-      } catch {
-        subscriber.send(.networkFollowerDidFail(error as NSError))
-      }
-      let status = env.getCMix()?.networkFollowerStatus()
-      subscriber.send(.didUpdateNetworkFollowerStatus(status))
-      subscriber.send(completion: .finished)
-      return AnyCancellable {}
-    }
-    .subscribe(on: env.bgScheduler)
-    .receive(on: env.mainScheduler)
-    .eraseToEffect()
-
-  case .networkFollowerDidFail(let error):
-    state.error = ErrorState(error: error)
-    return .none
-
-  case .monitorNetworkHealth(let start):
-    struct MonitorEffectId: Hashable {
-      var id: UUID
-    }
-    let effectId = MonitorEffectId(id: state.id)
-    if start {
-      return Effect.run { subscriber in
-        let callback = HealthCallback { isHealthy in
-          subscriber.send(.didUpdateNetworkHealth(isHealthy))
-        }
-        let cancellable = env.getCMix()?.addHealthCallback(callback)
-        return AnyCancellable {
-          cancellable?.cancel()
-        }
-      }
-      .subscribe(on: env.bgScheduler)
-      .receive(on: env.mainScheduler)
-      .eraseToEffect()
-      .cancellable(id: effectId, cancelInFlight: true)
-    } else {
-      return Effect.cancel(id: effectId)
-        .subscribe(on: env.bgScheduler)
-        .eraseToEffect()
-    }
-
-  case .didUpdateNetworkHealth(let isHealthy):
-    state.isNetworkHealthy = isHealthy
-    return .none
-
-  case .didDismissError:
-    state.error = nil
-    return .none
-
-  case .error(_):
-    return .none
-  }
-}
-.presenting(
-  errorReducer,
-  state: .keyPath(\.error),
-  id: .keyPath(\.?.error),
-  action: /SessionAction.error,
-  environment: \.error
-)
-
-extension SessionEnvironment {
-  public static let unimplemented = SessionEnvironment(
-    getCMix: XCTUnimplemented("\(Self.self).getCMix"),
-    bgScheduler: .unimplemented,
-    mainScheduler: .unimplemented,
-    error: .unimplemented
-  )
-}
diff --git a/Example/example-app/Sources/SessionFeature/SessionView.swift b/Example/example-app/Sources/SessionFeature/SessionView.swift
deleted file mode 100644
index d095a4211a67d0e0e6b0c027a40641be66347cfb..0000000000000000000000000000000000000000
--- a/Example/example-app/Sources/SessionFeature/SessionView.swift
+++ /dev/null
@@ -1,81 +0,0 @@
-import ComposableArchitecture
-import ComposablePresentation
-import ErrorFeature
-import SwiftUI
-import XXClient
-
-public struct SessionView: View {
-  public init(store: Store<SessionState, SessionAction>) {
-    self.store = store
-  }
-
-  let store: Store<SessionState, SessionAction>
-
-  struct ViewState: Equatable {
-    let networkFollowerStatus: NetworkFollowerStatus?
-    let isNetworkHealthy: Bool?
-
-    init(state: SessionState) {
-      networkFollowerStatus = state.networkFollowerStatus
-      isNetworkHealthy = state.isNetworkHealthy
-    }
-  }
-
-  public var body: some View {
-    WithViewStore(store.scope(state: ViewState.init)) { viewStore in
-      Form {
-        Section {
-          NetworkFollowerStatusView(status: viewStore.networkFollowerStatus)
-
-          Button {
-            viewStore.send(.runNetworkFollower(true))
-          } label: {
-            Text("Start")
-          }
-          .disabled(viewStore.networkFollowerStatus != .stopped)
-
-          Button {
-            viewStore.send(.runNetworkFollower(false))
-          } label: {
-            Text("Stop")
-          }
-          .disabled(viewStore.networkFollowerStatus != .running)
-        } header: {
-          Text("Network follower")
-        }
-
-        Section {
-          NetworkHealthStatusView(status: viewStore.isNetworkHealthy)
-        } header: {
-          Text("Network health")
-        }
-      }
-      .navigationTitle("Session")
-      .task {
-        viewStore.send(.viewDidLoad)
-      }
-      .sheet(
-        store.scope(
-          state: \.error,
-          action: SessionAction.error
-        ),
-        onDismiss: {
-          viewStore.send(.didDismissError)
-        },
-        content: ErrorView.init(store:)
-      )
-    }
-  }
-}
-
-#if DEBUG
-public struct SessionView_Previews: PreviewProvider {
-  public static var previews: some View {
-    SessionView(store: .init(
-      initialState: .init(id: UUID()),
-      reducer: .empty,
-      environment: ()
-    ))
-  }
-}
-#endif
diff --git a/Example/example-app/Tests/AppFeatureTests/AppFeatureTests.swift b/Example/example-app/Tests/AppFeatureTests/AppFeatureTests.swift
deleted file mode 100644
index d5cd1cef41315d31db675122547d3f1f55d83525..0000000000000000000000000000000000000000
--- a/Example/example-app/Tests/AppFeatureTests/AppFeatureTests.swift
+++ /dev/null
@@ -1,51 +0,0 @@
-import Combine
-import ComposableArchitecture
-import LandingFeature
-import SessionFeature
-import XCTest
-@testable import AppFeature
-
-final class AppFeatureTests: XCTestCase {
-  func testViewDidLoad() throws {
-    let newId = UUID()
-    let hasCMix = PassthroughSubject<Bool, Never>()
-    let mainScheduler = DispatchQueue.test
-
-    let store = TestStore(
-      initialState: AppState(),
-      reducer: appReducer,
-      environment: .unimplemented
-    )
-
-    store.environment.makeId = { newId }
-    store.environment.hasCMix = { hasCMix.eraseToAnyPublisher() }
-    store.environment.mainScheduler = mainScheduler.eraseToAnyScheduler()
-
-    store.send(.viewDidLoad)
-
-    hasCMix.send(false)
-    mainScheduler.advance()
-
-    store.receive(.cMixDidChange(hasCMix: false))
-
-    hasCMix.send(true)
-    mainScheduler.advance()
-
-    store.receive(.cMixDidChange(hasCMix: true)) {
-      $0.scene = .session(SessionState(id: newId))
-    }
-
-    hasCMix.send(true)
-    mainScheduler.advance()
-
-    hasCMix.send(false)
-    mainScheduler.advance()
-
-    store.receive(.cMixDidChange(hasCMix: false)) {
-      $0.scene = .landing(LandingState(id: newId))
-    }
-
-    hasCMix.send(completion: .finished)
-    mainScheduler.advance()
-  }
-}
diff --git a/Example/example-app/Tests/ErrorFeatureTests/ErrorFeatureTests.swift b/Example/example-app/Tests/ErrorFeatureTests/ErrorFeatureTests.swift
deleted file mode 100644
index 50dabc308273fc6c77beafab3ab8733397b462bc..0000000000000000000000000000000000000000
--- a/Example/example-app/Tests/ErrorFeatureTests/ErrorFeatureTests.swift
+++ /dev/null
@@ -1,8 +0,0 @@
-import XCTest
-@testable import ErrorFeature
-
-final class ErrorFeatureTests: XCTestCase {
-  func testExample() {
-    XCTAssert(true)
-  }
-}
diff --git a/Example/example-app/Tests/LandingFeatureTests/LandingFeatureTests.swift b/Example/example-app/Tests/LandingFeatureTests/LandingFeatureTests.swift
deleted file mode 100644
index 9018641dbf895d99919c8234600d304a65d8f0ce..0000000000000000000000000000000000000000
--- a/Example/example-app/Tests/LandingFeatureTests/LandingFeatureTests.swift
+++ /dev/null
@@ -1,182 +0,0 @@
-import ComposableArchitecture
-import ErrorFeature
-import XCTest
-@testable import LandingFeature
-
-final class LandingFeatureTests: XCTestCase {
-  func testViewDidLoad() throws {
-    let store = TestStore(
-      initialState: LandingState(id: UUID()),
-      reducer: landingReducer,
-      environment: .unimplemented
-    )
-
-    store.environment.cMixManager.hasStorage.run = { true }
-
-    store.send(.viewDidLoad) {
-      $0.hasStoredCMix = true
-    }
-  }
-
-  func testCreateCMix() {
-    var hasStoredCMix = false
-    var didSetCMix = false
-    let bgScheduler = DispatchQueue.test
-    let mainScheduler = DispatchQueue.test
-
-    let store = TestStore(
-      initialState: LandingState(id: UUID()),
-      reducer: landingReducer,
-      environment: .unimplemented
-    )
-
-    store.environment.cMixManager.hasStorage.run = { hasStoredCMix }
-    store.environment.cMixManager.create.run = { .unimplemented }
-    store.environment.setCMix = { _ in didSetCMix = true }
-    store.environment.bgScheduler = bgScheduler.eraseToAnyScheduler()
-    store.environment.mainScheduler = mainScheduler.eraseToAnyScheduler()
-
-    store.send(.makeCMix) {
-      $0.isMakingCMix = true
-    }
-
-    bgScheduler.advance()
-
-    XCTAssertTrue(didSetCMix)
-
-    hasStoredCMix = true
-    mainScheduler.advance()
-
-    store.receive(.didMakeCMix) {
-      $0.isMakingCMix = false
-      $0.hasStoredCMix = true
-    }
-  }
-
-  func testLoadStoredCMix() {
-    var didSetCMix = false
-    let bgScheduler = DispatchQueue.test
-    let mainScheduler = DispatchQueue.test
-
-    let store = TestStore(
-      initialState: LandingState(id: UUID()),
-      reducer: landingReducer,
-      environment: .unimplemented
-    )
-
-    store.environment.cMixManager.hasStorage.run = { true }
-    store.environment.cMixManager.load.run = { .unimplemented }
-    store.environment.setCMix = { _ in didSetCMix = true }
-    store.environment.bgScheduler = bgScheduler.eraseToAnyScheduler()
-    store.environment.mainScheduler = mainScheduler.eraseToAnyScheduler()
-
-    store.send(.makeCMix) {
-      $0.isMakingCMix = true
-    }
-
-    bgScheduler.advance()
-
-    XCTAssertTrue(didSetCMix)
-
-    mainScheduler.advance()
-
-    store.receive(.didMakeCMix) {
-      $0.isMakingCMix = false
-      $0.hasStoredCMix = true
-    }
-  }
-
-  func testMakeCMixFailure() {
-    let error = NSError(domain: "test", code: 1234)
-    let bgScheduler = DispatchQueue.test
-    let mainScheduler = DispatchQueue.test
-
-    let store = TestStore(
-      initialState: LandingState(id: UUID()),
-      reducer: landingReducer,
-      environment: .unimplemented
-    )
-
-    store.environment.cMixManager.hasStorage.run = { false }
-    store.environment.cMixManager.create.run = { throw error }
-    store.environment.bgScheduler = bgScheduler.eraseToAnyScheduler()
-    store.environment.mainScheduler = mainScheduler.eraseToAnyScheduler()
-
-    store.send(.makeCMix) {
-      $0.isMakingCMix = true
-    }
-
-    bgScheduler.advance()
-    mainScheduler.advance()
-
-    store.receive(.didFailMakingCMix(error)) {
-      $0.isMakingCMix = false
-      $0.hasStoredCMix = false
-      $0.error = ErrorState(error: error)
-    }
-  }
-
-  func testRemoveStoredCMix() {
-    var hasStoredCMix = true
-    var didRemoveCMix = false
-    let bgScheduler = DispatchQueue.test
-    let mainScheduler = DispatchQueue.test
-
-    let store = TestStore(
-      initialState: LandingState(id: UUID()),
-      reducer: landingReducer,
-      environment: .unimplemented
-    )
-
-    store.environment.cMixManager.hasStorage.run = { hasStoredCMix }
-    store.environment.cMixManager.remove.run = { didRemoveCMix = true }
-    store.environment.bgScheduler = bgScheduler.eraseToAnyScheduler()
-    store.environment.mainScheduler = mainScheduler.eraseToAnyScheduler()
-
-    store.send(.removeStoredCMix) {
-      $0.isRemovingCMix = true
-    }
-
-    bgScheduler.advance()
-
-    XCTAssertTrue(didRemoveCMix)
-
-    hasStoredCMix = false
-    mainScheduler.advance()
-
-    store.receive(.didRemoveStoredCMix) {
-      $0.isRemovingCMix = false
-      $0.hasStoredCMix = false
-    }
-  }
-
-  func testRemoveStoredCMixFailure() {
-    let error = NSError(domain: "test", code: 1234)
-    let bgScheduler = DispatchQueue.test
-    let mainScheduler = DispatchQueue.test
-
-    let store = TestStore(
-      initialState: LandingState(id: UUID()),
-      reducer: landingReducer,
-      environment: .unimplemented
-    )
-
-    store.environment.cMixManager.hasStorage.run = { true }
-    store.environment.cMixManager.remove.run = { throw error }
-    store.environment.bgScheduler = bgScheduler.eraseToAnyScheduler()
-    store.environment.mainScheduler = mainScheduler.eraseToAnyScheduler()
-
-    store.send(.removeStoredCMix) {
-      $0.isRemovingCMix = true
-    }
-
-    bgScheduler.advance()
-    mainScheduler.advance()
-
-    store.receive(.didFailRemovingStoredCMix(error)) {
-      $0.isRemovingCMix = false
-      $0.hasStoredCMix = true
-      $0.error = ErrorState(error: error)
-    }
-  }
-}
diff --git a/Example/example-app/Tests/SessionFeatureTests/SessionFeatureTests.swift b/Example/example-app/Tests/SessionFeatureTests/SessionFeatureTests.swift
deleted file mode 100644
index 33261ec67e11aa5494103216ccc5cdfd6f135eb6..0000000000000000000000000000000000000000
--- a/Example/example-app/Tests/SessionFeatureTests/SessionFeatureTests.swift
+++ /dev/null
@@ -1,146 +0,0 @@
-import ComposableArchitecture
-import ErrorFeature
-import XCTest
-import XXClient
-@testable import SessionFeature
-
-final class SessionFeatureTests: XCTestCase {
-  func testViewDidLoad() {
-    var networkFollowerStatus: NetworkFollowerStatus!
-    var didStartMonitoringNetworkHealth = 0
-    var didStopMonitoringNetworkHealth = 0
-    var networkHealthCallback: HealthCallback!
-    let bgScheduler = DispatchQueue.test
-    let mainScheduler = DispatchQueue.test
-
-    let store = TestStore(
-      initialState: SessionState(id: UUID()),
-      reducer: sessionReducer,
-      environment: .unimplemented
-    )
-
-    store.environment.getCMix = {
-      var cMix = CMix.unimplemented
-      cMix.networkFollowerStatus.run = { networkFollowerStatus }
-      cMix.addHealthCallback.run = { callback in
-        networkHealthCallback = callback
-        didStartMonitoringNetworkHealth += 1
-        return Cancellable {
-          didStopMonitoringNetworkHealth += 1
-        }
-      }
-      return cMix
-    }
-    store.environment.bgScheduler = bgScheduler.eraseToAnyScheduler()
-    store.environment.mainScheduler = mainScheduler.eraseToAnyScheduler()
-
-    store.send(.viewDidLoad)
-
-    store.receive(.updateNetworkFollowerStatus)
-    store.receive(.monitorNetworkHealth(true))
-
-    networkFollowerStatus = .stopped
-    bgScheduler.advance()
-    mainScheduler.advance()
-
-    store.receive(.didUpdateNetworkFollowerStatus(.stopped)) {
-      $0.networkFollowerStatus = .stopped
-    }
-
-    XCTAssertEqual(didStartMonitoringNetworkHealth, 1)
-    XCTAssertEqual(didStopMonitoringNetworkHealth, 0)
-
-    networkHealthCallback.handle(true)
-    bgScheduler.advance()
-    mainScheduler.advance()
-
-    store.receive(.didUpdateNetworkHealth(true)) {
-      $0.isNetworkHealthy = true
-    }
-
-    store.send(.monitorNetworkHealth(false))
-
-    bgScheduler.advance()
-
-    XCTAssertEqual(didStartMonitoringNetworkHealth, 1)
-    XCTAssertEqual(didStopMonitoringNetworkHealth, 1)
-  }
-
-  func testStartStopNetworkFollower() {
-    var networkFollowerStatus: NetworkFollowerStatus!
-    var didStartNetworkFollowerWithTimeout = [Int]()
-    var didStopNetworkFollower = 0
-    var networkFollowerStartError: NSError?
-    let bgScheduler = DispatchQueue.test
-    let mainScheduler = DispatchQueue.test
-
-    let store = TestStore(
-      initialState: SessionState(id: UUID()),
-      reducer: sessionReducer,
-      environment: .unimplemented
-    )
-
-    store.environment.getCMix = {
-      var cMix = CMix.unimplemented
-      cMix.networkFollowerStatus.run = { networkFollowerStatus }
-      cMix.startNetworkFollower.run = {
-        didStartNetworkFollowerWithTimeout.append($0)
-        if let error = networkFollowerStartError {
-          throw error
-        }
-      }
-      cMix.stopNetworkFollower.run = {
-        didStopNetworkFollower += 1
-      }
-      return cMix
-    }
-    store.environment.bgScheduler = bgScheduler.eraseToAnyScheduler()
-    store.environment.mainScheduler = mainScheduler.eraseToAnyScheduler()
-
-    store.send(.runNetworkFollower(true))
-
-    networkFollowerStatus = .running
-    bgScheduler.advance()
-    mainScheduler.advance()
-
-    XCTAssertEqual(didStartNetworkFollowerWithTimeout, [30_000])
-    XCTAssertEqual(didStopNetworkFollower, 0)
-
-    store.receive(.didUpdateNetworkFollowerStatus(.running)) {
-      $0.networkFollowerStatus = .running
-    }
-
-    store.send(.runNetworkFollower(false))
-
-    networkFollowerStatus = .stopped
-    bgScheduler.advance()
-    mainScheduler.advance()
-
-    XCTAssertEqual(didStartNetworkFollowerWithTimeout, [30_000])
-    XCTAssertEqual(didStopNetworkFollower, 1)
-
-    store.receive(.didUpdateNetworkFollowerStatus(.stopped)) {
-      $0.networkFollowerStatus = .stopped
-    }
-
-    store.send(.runNetworkFollower(true))
-
-    networkFollowerStartError = NSError(domain: "test", code: 1234)
-    networkFollowerStatus = .stopped
-    bgScheduler.advance()
-    mainScheduler.advance()
-
-    XCTAssertEqual(didStartNetworkFollowerWithTimeout, [30_000, 30_000])
-    XCTAssertEqual(didStopNetworkFollower, 1)
-
-    store.receive(.networkFollowerDidFail(networkFollowerStartError!)) {
-      $0.error = ErrorState(error: networkFollowerStartError!)
-    }
-
-    store.receive(.didUpdateNetworkFollowerStatus(.stopped))
-
-    store.send(.didDismissError) {
-      $0.error = nil
-    }
-  }
-}