-
Notifications
You must be signed in to change notification settings - Fork 132
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'main' into rob/doc-eoa
- Loading branch information
Showing
63 changed files
with
2,977 additions
and
535 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,36 @@ | ||
# Learn more https://docs.github.com/en/get-started/getting-started-with-git/ignoring-files | ||
|
||
# dependencies | ||
node_modules/ | ||
|
||
# Expo | ||
.expo/ | ||
dist/ | ||
web-build/ | ||
expo-env.d.ts | ||
|
||
# Native | ||
*.orig.* | ||
*.jks | ||
*.p8 | ||
*.p12 | ||
*.key | ||
*.mobileprovision | ||
|
||
# Metro | ||
.metro-health-check* | ||
|
||
# debug | ||
npm-debug.* | ||
yarn-debug.* | ||
yarn-error.* | ||
|
||
# macOS | ||
.DS_Store | ||
*.pem | ||
|
||
# local env files | ||
.env*.local | ||
|
||
# typescript | ||
*.tsbuildinfo |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,87 @@ | ||
# Account Kit RN Example using Expo | ||
|
||
This is a sample repo that used expo to get started and integrates with Account Kit | ||
|
||
<img width="434" alt="image" src="https://github.com/alchemyplatform/aa-sdk-rn-expo/assets/4642570/e0dab7bc-f980-46eb-966c-13be7e79bc15"> | ||
|
||
## How it was made | ||
|
||
1. First create a new expo project (we used `yarn`): | ||
|
||
```bash | ||
yarn create expo-app --template | ||
``` | ||
|
||
This project used a `Blank (typescript)` template. | ||
|
||
2. Ensure you have the latest version of expo and that the new architecture is enabled | ||
|
||
```bash | ||
yarn expo install expo@latest --fix | ||
``` | ||
|
||
```json | ||
// app.json | ||
{ | ||
"newArchEnabled": true | ||
} | ||
``` | ||
|
||
3. Install shims for crypto libraries | ||
|
||
```bash | ||
yarn expo install node-libs-react-native crypto-browserify stream-browserify react-native-get-random-values | ||
``` | ||
|
||
4. Add shims to `metro.config.js`: | ||
|
||
```javascript | ||
// Learn more https://docs.expo.io/guides/customizing-metro | ||
const { getDefaultConfig } = require("expo/metro-config"); | ||
|
||
/** @type {import('expo/metro-config').MetroConfig} */ | ||
const config = getDefaultConfig(__dirname); | ||
config.resolver.extraNodeModules = { | ||
...config.resolver.extraNodeModules, | ||
...require("node-libs-react-native"), | ||
crypto: require.resolve("crypto-browserify"), | ||
stream: require.resolve("stream-browserify"), | ||
}; | ||
|
||
module.exports = config; | ||
``` | ||
|
||
5. Setup Expo Router. | ||
|
||
Follow the [expo router docs](https://docs.expo.dev/router/installation/) to setup the router. | ||
|
||
```bash | ||
yarn expo install expo-router | ||
``` | ||
|
||
6. Import global shims in the root layout file: `_layout.tsx`: | ||
|
||
```typescript | ||
import "node-libs-react-native/globals.js"; | ||
import "react-native-get-random-values"; | ||
|
||
// rest of _layout.tsx | ||
``` | ||
|
||
6. Install [Account Kit](https://accountkit.alchemy.com) Packages. At this point you're ready to use the aa-sdk in your project. | ||
|
||
```bash | ||
yarn add @account-kit/react-native-signer @account-kit/signer @account-kit/smart-contracts @account-kit/infra | ||
``` | ||
|
||
7. Add a redirect server to handle the auth request. This is needed to redirect users back to the app after clicking the auth magic link in their email. | ||
|
||
```bash | ||
yarn add express | ||
``` | ||
|
||
8. Run the redirect server: | ||
|
||
```bash | ||
yarn start:redirect-server | ||
``` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,16 @@ | ||
# OSX | ||
# | ||
.DS_Store | ||
|
||
# Android/IntelliJ | ||
# | ||
build/ | ||
.idea | ||
.gradle | ||
local.properties | ||
*.iml | ||
*.hprof | ||
.cxx/ | ||
|
||
# Bundle artifacts | ||
*.jsbundle |
176 changes: 176 additions & 0 deletions
176
examples/react-native-expo-example/android/app/build.gradle
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,176 @@ | ||
apply plugin: "com.android.application" | ||
apply plugin: "org.jetbrains.kotlin.android" | ||
apply plugin: "com.facebook.react" | ||
|
||
def projectRoot = rootDir.getAbsoluteFile().getParentFile().getAbsolutePath() | ||
|
||
/** | ||
* This is the configuration block to customize your React Native Android app. | ||
* By default you don't need to apply any configuration, just uncomment the lines you need. | ||
*/ | ||
react { | ||
entryFile = file(["node", "-e", "require('expo/scripts/resolveAppEntry')", projectRoot, "android", "absolute"].execute(null, rootDir).text.trim()) | ||
reactNativeDir = new File(["node", "--print", "require.resolve('react-native/package.json')"].execute(null, rootDir).text.trim()).getParentFile().getAbsoluteFile() | ||
hermesCommand = new File(["node", "--print", "require.resolve('react-native/package.json')"].execute(null, rootDir).text.trim()).getParentFile().getAbsolutePath() + "/sdks/hermesc/%OS-BIN%/hermesc" | ||
codegenDir = new File(["node", "--print", "require.resolve('@react-native/codegen/package.json', { paths: [require.resolve('react-native/package.json')] })"].execute(null, rootDir).text.trim()).getParentFile().getAbsoluteFile() | ||
|
||
// Use Expo CLI to bundle the app, this ensures the Metro config | ||
// works correctly with Expo projects. | ||
cliFile = new File(["node", "--print", "require.resolve('@expo/cli', { paths: [require.resolve('expo/package.json')] })"].execute(null, rootDir).text.trim()) | ||
bundleCommand = "export:embed" | ||
|
||
/* Folders */ | ||
// The root of your project, i.e. where "package.json" lives. Default is '../..' | ||
// root = file("../../") | ||
// The folder where the react-native NPM package is. Default is ../../node_modules/react-native | ||
// reactNativeDir = file("../../node_modules/react-native") | ||
// The folder where the react-native Codegen package is. Default is ../../node_modules/@react-native/codegen | ||
// codegenDir = file("../../node_modules/@react-native/codegen") | ||
|
||
/* Variants */ | ||
// The list of variants to that are debuggable. For those we're going to | ||
// skip the bundling of the JS bundle and the assets. By default is just 'debug'. | ||
// If you add flavors like lite, prod, etc. you'll have to list your debuggableVariants. | ||
// debuggableVariants = ["liteDebug", "prodDebug"] | ||
|
||
/* Bundling */ | ||
// A list containing the node command and its flags. Default is just 'node'. | ||
// nodeExecutableAndArgs = ["node"] | ||
|
||
// | ||
// The path to the CLI configuration file. Default is empty. | ||
// bundleConfig = file(../rn-cli.config.js) | ||
// | ||
// The name of the generated asset file containing your JS bundle | ||
// bundleAssetName = "MyApplication.android.bundle" | ||
// | ||
// The entry file for bundle generation. Default is 'index.android.js' or 'index.js' | ||
// entryFile = file("../js/MyApplication.android.js") | ||
// | ||
// A list of extra flags to pass to the 'bundle' commands. | ||
// See https://github.com/react-native-community/cli/blob/main/docs/commands.md#bundle | ||
// extraPackagerArgs = [] | ||
|
||
/* Hermes Commands */ | ||
// The hermes compiler command to run. By default it is 'hermesc' | ||
// hermesCommand = "$rootDir/my-custom-hermesc/bin/hermesc" | ||
// | ||
// The list of flags to pass to the Hermes compiler. By default is "-O", "-output-source-map" | ||
// hermesFlags = ["-O", "-output-source-map"] | ||
|
||
/* Autolinking */ | ||
autolinkLibrariesWithApp() | ||
} | ||
|
||
/** | ||
* Set this to true to Run Proguard on Release builds to minify the Java bytecode. | ||
*/ | ||
def enableProguardInReleaseBuilds = (findProperty('android.enableProguardInReleaseBuilds') ?: false).toBoolean() | ||
|
||
/** | ||
* The preferred build flavor of JavaScriptCore (JSC) | ||
* | ||
* For example, to use the international variant, you can use: | ||
* `def jscFlavor = 'org.webkit:android-jsc-intl:+'` | ||
* | ||
* The international variant includes ICU i18n library and necessary data | ||
* allowing to use e.g. `Date.toLocaleString` and `String.localeCompare` that | ||
* give correct results when using with locales other than en-US. Note that | ||
* this variant is about 6MiB larger per architecture than default. | ||
*/ | ||
def jscFlavor = 'org.webkit:android-jsc:+' | ||
|
||
android { | ||
ndkVersion rootProject.ext.ndkVersion | ||
|
||
buildToolsVersion rootProject.ext.buildToolsVersion | ||
compileSdk rootProject.ext.compileSdkVersion | ||
|
||
namespace 'com.accountkit.reactnativeexpoexample' | ||
defaultConfig { | ||
applicationId 'com.accountkit.reactnativeexpoexample' | ||
minSdkVersion rootProject.ext.minSdkVersion | ||
targetSdkVersion rootProject.ext.targetSdkVersion | ||
versionCode 1 | ||
versionName "1.0.0" | ||
} | ||
signingConfigs { | ||
debug { | ||
storeFile file('debug.keystore') | ||
storePassword 'android' | ||
keyAlias 'androiddebugkey' | ||
keyPassword 'android' | ||
} | ||
} | ||
buildTypes { | ||
debug { | ||
signingConfig signingConfigs.debug | ||
} | ||
release { | ||
// Caution! In production, you need to generate your own keystore file. | ||
// see https://reactnative.dev/docs/signed-apk-android. | ||
signingConfig signingConfigs.debug | ||
shrinkResources (findProperty('android.enableShrinkResourcesInReleaseBuilds')?.toBoolean() ?: false) | ||
minifyEnabled enableProguardInReleaseBuilds | ||
proguardFiles getDefaultProguardFile("proguard-android.txt"), "proguard-rules.pro" | ||
crunchPngs (findProperty('android.enablePngCrunchInReleaseBuilds')?.toBoolean() ?: true) | ||
} | ||
} | ||
packagingOptions { | ||
jniLibs { | ||
useLegacyPackaging (findProperty('expo.useLegacyPackaging')?.toBoolean() ?: false) | ||
} | ||
} | ||
androidResources { | ||
ignoreAssetsPattern '!.svn:!.git:!.ds_store:!*.scc:!CVS:!thumbs.db:!picasa.ini:!*~' | ||
} | ||
} | ||
|
||
// Apply static values from `gradle.properties` to the `android.packagingOptions` | ||
// Accepts values in comma delimited lists, example: | ||
// android.packagingOptions.pickFirsts=/LICENSE,**/picasa.ini | ||
["pickFirsts", "excludes", "merges", "doNotStrip"].each { prop -> | ||
// Split option: 'foo,bar' -> ['foo', 'bar'] | ||
def options = (findProperty("android.packagingOptions.$prop") ?: "").split(","); | ||
// Trim all elements in place. | ||
for (i in 0..<options.size()) options[i] = options[i].trim(); | ||
// `[] - ""` is essentially `[""].filter(Boolean)` removing all empty strings. | ||
options -= "" | ||
|
||
if (options.length > 0) { | ||
println "android.packagingOptions.$prop += $options ($options.length)" | ||
// Ex: android.packagingOptions.pickFirsts += '**/SCCS/**' | ||
options.each { | ||
android.packagingOptions[prop] += it | ||
} | ||
} | ||
} | ||
|
||
dependencies { | ||
// The version of react-native is set by the React Native Gradle Plugin | ||
implementation("com.facebook.react:react-android") | ||
|
||
def isGifEnabled = (findProperty('expo.gif.enabled') ?: "") == "true"; | ||
def isWebpEnabled = (findProperty('expo.webp.enabled') ?: "") == "true"; | ||
def isWebpAnimatedEnabled = (findProperty('expo.webp.animated') ?: "") == "true"; | ||
|
||
if (isGifEnabled) { | ||
// For animated gif support | ||
implementation("com.facebook.fresco:animated-gif:${reactAndroidLibs.versions.fresco.get()}") | ||
} | ||
|
||
if (isWebpEnabled) { | ||
// For webp support | ||
implementation("com.facebook.fresco:webpsupport:${reactAndroidLibs.versions.fresco.get()}") | ||
if (isWebpAnimatedEnabled) { | ||
// Animated webp support | ||
implementation("com.facebook.fresco:animated-webp:${reactAndroidLibs.versions.fresco.get()}") | ||
} | ||
} | ||
|
||
if (hermesEnabled.toBoolean()) { | ||
implementation("com.facebook.react:hermes-android") | ||
} else { | ||
implementation jscFlavor | ||
} | ||
} |
Binary file not shown.
14 changes: 14 additions & 0 deletions
14
examples/react-native-expo-example/android/app/proguard-rules.pro
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,14 @@ | ||
# Add project specific ProGuard rules here. | ||
# By default, the flags in this file are appended to flags specified | ||
# in /usr/local/Cellar/android-sdk/24.3.3/tools/proguard/proguard-android.txt | ||
# You can edit the include path and order by changing the proguardFiles | ||
# directive in build.gradle. | ||
# | ||
# For more details, see | ||
# http://developer.android.com/guide/developing/tools/proguard.html | ||
|
||
# react-native-reanimated | ||
-keep class com.swmansion.reanimated.** { *; } | ||
-keep class com.facebook.react.turbomodule.** { *; } | ||
|
||
# Add any project specific keep options here: |
7 changes: 7 additions & 0 deletions
7
examples/react-native-expo-example/android/app/src/debug/AndroidManifest.xml
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,7 @@ | ||
<manifest xmlns:android="http://schemas.android.com/apk/res/android" | ||
xmlns:tools="http://schemas.android.com/tools"> | ||
|
||
<uses-permission android:name="android.permission.SYSTEM_ALERT_WINDOW"/> | ||
|
||
<application android:usesCleartextTraffic="true" tools:targetApi="28" tools:ignore="GoogleAppIndexingWarning" tools:replace="android:usesCleartextTraffic" /> | ||
</manifest> |
Oops, something went wrong.