Advanced Configuration
The Web3Auth SDK provides extensive configuration options that allow you to customize authentication flows, UI appearance, blockchain integrations, and security features to meet your application's specific requirements.
Configuration Structure
When setting up Web3Auth, you'll pass in the options to the constructor. This consists of:
import com.web3auth.core.Web3Auth
import com.web3auth.core.types.Web3AuthOptions
var web3Auth = Web3Auth(
  Web3AuthOptions(
    context = this,
    clientId = "YOUR_WEB3AUTH_CLIENT_ID", // Pass over your Web3Auth Client ID from Developer Dashboard
    network = Network.MAINNET,
    redirectUrl = Uri.parse("{YOUR_APP_PACKAGE_NAME}://auth"),
  )
)
// Handle user signing in when app is in background
web3Auth.setResultUrl(intent?.data)
Web3AuthOptions
The Web3Auth Constructor takes an object with Web3AuthOptions as input.
- Basic Parameters
- Advanced Parameters
- Interface
| Parameter | Description | 
|---|---|
| context | Android context to launch Web-based authentication, usually is the current activity. It's a mandatory field, and accepts android.content.Contextas a value. | 
| clientId | Your Web3Auth Client ID. You can get it from Web3Auth Dashboard under project details. It's a mandatory field of type String | 
| network | Defines the Web3Auth Network. It's a mandatory field of type Network. | 
| redirectUrl | URL that Web3Auth will redirect API responses upon successful authentication from browser. It's a mandatory field of type Uri. | 
| sessionTime? | It allows developers to configure the session management time. Session Time is in seconds, default is 86400 seconds which is 1 day. sessionTimecan be max 30 days | 
| useCoreKitKey? | Use CoreKit (or SFA) Key to get core kit key given by SFA SDKs. It's an optional field with default value as false. Useful for Wallet Pregeneration. | 
| chainNamespace? | Chain Namespace [ EIP155andSOLANA]. It takesChainNamespaceas a value. | 
| Parameter | Description | 
|---|---|
| whiteLabel? | WhiteLabel options for web3auth. It helps you define custom UI, branding, and translations for your brand app. It takes WhiteLabelDataas a value. | 
| loginConfig? | Login config for the custom verifiers. It takes HashMap<String, LoginConfigItem>as a value. | 
| mfaSettings? | Allows developers to configure the Mfa settings for authentication. It takes MfaSettingsas a value. | 
data class Web3AuthOptions(
    var context: Context,
    val clientId: String,
    val network: Network,
    var buildEnv: BuildEnv? = BuildEnv.PRODUCTION,
    @Transient var redirectUrl: Uri,
    var sdkUrl: String = getSdkUrl(buildEnv),
    val whiteLabel: WhiteLabelData? = null,
    val loginConfig: HashMap<String, LoginConfigItem>? = null,
    val useCoreKitKey: Boolean? = false,
    val chainNamespace: ChainNamespace? = ChainNamespace.EIP155,
    val mfaSettings: MfaSettings? = null,
    val sessionTime: Int? = 86400
)
Session Management
Control how long users stay authenticated and how sessions persist. The session key is stored in the device's encrypted Keystore.
Key Configuration Options:
- sessionTime- Session duration in seconds. Controls how long users remain authenticated before needing to log in again.- Minimum: 1 second (1).
- Maximum: 30 days (86400 * 30).
- Default: 7 days (86400 * 7).
 
- Minimum: 1 second (
var web3Auth = Web3Auth(
  Web3AuthOptions(
    context = this,
    clientId = "YOUR_WEB3AUTH_CLIENT_ID", // Pass over your Web3Auth Client ID from Developer Dashboard
    network = Network.MAINNET,
    sessionTime = 86400 * 7, // 7 days (in seconds)
    redirectUrl = Uri.parse("{YOUR_APP_PACKAGE_NAME}://auth"),
  )
)
Custom Authentication Methods
Control the login options presented to your users. For detailed configuration options and implementation examples, see the Custom Authentication section.
UI Customization
Create a seamless brand experience by customizing the Web3Auth Login Screens to match your application's design. For complete customization options, refer to the Whitelabeling & UI Customization section.
Multi-Factor Authentication (MFA)
Add additional security layers to protect user accounts with two-factor authentication. For detailed configuration options and implementation examples, see the Multi-Factor Authentication section.
Key Configuration Options:
- mfaSettings- Configure MFA settings for different authentication flows
- mfaLevel- Control when users are prompted to set up MFA