Prerequisites
To use Para, you need an API key. This key authenticates your requests to Para services and is essential for integration.Don’t have an API key yet? Request access to the Developer Portal to create API keys, manage billing, teams, and more.
Install the SDK
Start by installing the Para SDK:Configure URL Scheme
Configure your app’s URL scheme for OAuth authentication flows. This enables OAuth providers to redirect back to your app after authentication.- iOS
- Android
- In Xcode, select your project in the navigator
- Select your app target
- Go to the Info tab
- Scroll down to URL Types and click + to add a new URL type
- Fill in the fields:
- URL Schemes: Enter your scheme name (e.g., yourapp,myflutterapp)
- Role: Select Editor
- Identifier: Use your bundle identifier or a descriptive name
 
- URL Schemes: Enter your scheme name (e.g., 
Make sure your URL scheme is unique to avoid conflicts with other apps. Use a scheme related to your app’s bundle ID (e.g., 
com.mycompany.myapp) for uniqueness.Optional: Configure Passkeys
Enable passkeys only if you’ve turned them on in the Para Developer Portal. Configure both iOS and Android platforms:- iOS
- Android
To enable passkeys on iOS, you need to configure Associated Domains:
- Open your Flutter project’s iOS folder in Xcode
- In Xcode, go to Signing & Capabilities for your app target
- Click + Capability and add Associated Domains
- Add the following entries:
- Register your Team ID + Bundle ID with Para via the Developer Portal
Without properly registering your Team ID and Bundle ID with Para, passkey authentication flows will fail. Contact Para support if you encounter issues with passkey registration.
Initialize Para
To use Para’s features, you’ll need to initialize a Para client instance that can be accessed throughout your app. This client handles all interactions with Para’s services, including authentication, wallet management, and transaction signing. Create a file (e.g.,lib/services/para_client.dart) to initialize your Para client:
lib/services/para_client.dart
You can access 
para from anywhere in your app by importing the file where you initialized it. This singleton pattern
ensures consistent state management across your application.Authenticate Users
Para provides a unified authentication experience that supports email, phone, and social login methods. The SDK automatically determines whether a user is new or existing and guides you through the appropriate flow.Beta Testing Credentials In the 
BETA Environment, you can use any email ending in @test.getpara.com (like
dev@test.getpara.com) or US phone numbers (+1) in the format (area code)-555-xxxx (like (425)-555-1234). Any OTP
code will work for verification with these test credentials. These credentials are for beta testing only. You can
delete test users anytime in the beta developer console to free up user slots.FlutterWebAuthSession and reuse it whenever you call handleLogin or handleSignup.
lib/views/authentication_view.dart
Build Your Authentication Flow
Para’s One-Click Login is the default path. As soon as you receive anAuthState, check for loginUrl and complete the inline flow before falling back to other methods. The pattern below mirrors the example app while keeping the logic compact.
- Email/Phone Authentication
Para supports authentication with both email addresses and phone numbers.
1
Handle Email/Phone Submission
Initiate authentication with email or phone:
lib/views/authentication_view.dart
Optional: Passkey/Password Signup
If you enable passkeys or passwords in the Para dashboard, you’ll need to handle the verification stage and callhandleSignup.
lib/views/authentication_view.dart
Returning Users
Existing users follow the same One-Click-first flow. If you’ve enabled passkey or password methods, fall back tohandleLogin
after the One-Click block. You can also call loginWithPasskey directly when you know a user has registered one.
Check Authentication Status
You can check if a user is already authenticated:lib/views/content_view.dart
Sign Out Users
To sign out a user and clear their session:lib/views/settings_view.dart
Create and Manage Wallets
After successful authentication, you can perform wallet operations:lib/views/wallet_view.dart
For detailed transaction signing with specific blockchains (EVM, Solana, Cosmos), please refer to the respective blockchain integration guides.