EmbeddedWallet
A wallet configurator for Embedded Wallet (email or Socials Sign In) which allows integrating the wallet with React Native.
import { embeddedWallet } from "@thirdweb-dev/react-native";
const embeddedWalletConfig = embeddedWallet();
customize (optional)
authentication options (optional)
walletConnectReceiver
Installation
To use the embeddedWallet
you need to add the following dependencies to your project. Find the
command to add them all for convenience below.
yarn:
yarn add amazon-cognito-identity-js@6.3.3 react-native-quick-base64 react-native-quick-crypto react-native-aes-gcm-crypto @react-native-community/netinfo react-native-inappbrowser-reborn@3.7.0
npm:
npm install amazon-cognito-identity-js@6.3.3 react-native-quick-base64 react-native-quick-crypto react-native-aes-gcm-crypto @react-native-community/netinfo react-native-inappbrowser-reborn@3.7.0
Here are the dependencies added:
amazon-cognito-identity-js: "^6.3.3"
react-native-quick-base64
react-native-quick-crypto
react-native-aes-gcm-crypto
- This package requires minSdkVersion = 26 on Android
@react-native-community/netinfo
react-native-inappbrowser-reborn: "^3.7.0" (for Socials Sign In)
There's an open issue on RN > 0.72: https://github.com/margelo/react-native-quick-crypto/issues/186 which you can fix by adding the following to your
android/app/build.gradle
file:packagingOptions {
pickFirst 'lib/x86/libcrypto.so'
pickFirst 'lib/x86_64/libcrypto.so'
pickFirst 'lib/armeabi-v7a/libcrypto.so'
pickFirst 'lib/arm64-v8a/libcrypto.so'
}When building the iOS app in release mode for RN 0.71 you need to enable the OpenSSL framework in XCode. There are several solutions for this here:
Usage with ConnectWallet
To allow users to connect to this wallet using the ConnectWallet component, you can add it to ThirdwebProvider's supportedWallets prop.
<ThirdwebProvider
clientId="your-client-id"
supportedWallets={[embeddedWallet()]}
>
<YourApp />
</ThirdwebProvider>
Usage with useEmbeddedWallet
You can use the useEmbeddedWallet
hook to programmatically connect to the wallet without using the ConnectWallet component.
The wallet also needs to be added in ThirdwebProvider's supportedWallets if you want the wallet to auto-connect on next page load.
The hook will return all the necessary functions you'll need to authenticate and connect to the embedded wallet.
Connecting with Google sign in:
Note that if you want to sign in with Facebook or Apple you'll need pass "apple" or "facebook" to the strategy
parameter.
function App() {
const { connect } = useEmbeddedWallet();
const handleConnect = async () => {
await connect({
strategy: "google",
redirectUrl: "deep-link-to-your-app://",
});
};
return <View> ... </View>;
}
Connecting with email verification:
function App() {
const { connect, sendVerificationEmail } = useEmbeddedWallet();
const preLogin = async (email: string) => {
// send email verification code
await sendVerificationEmail({ email });
};
const handleLogin = async (email: string, verificationCode: string) => {
// verify email and connect
await connect({
strategy: "email_verification",
email,
verificationCode,
});
};
return <View> ... </View>;
}
Available connection strategies
// email verification
type EmailVerificationAuthParams = {
strategy: "email_verification";
email: string;
verificationCode: string;
recoveryCode?: string;
};
type SocialAuthParams = {
strategy: "google" | "apple" | "facebook";
redirectUrl: string;
};
// bring your own authentication
type JwtAuthParams = {
strategy: "jwt";
jwt: string;
encryptionKey?: string;
};