Wallet Setup
This API is available only to merchants with standaloneWallet access and walletSetup scope to the config token.
Introduction
The Wallet Setup service exposes operations for setting up the Paysafe Embedded Wallet:
- Initiate a customer data verification process
- Submit a customer data verification attempt
- Onboard a new customer
- Change customer credentials
Use the following code to obtain an instance of WalletSetupService:
- Kotlin
- Swift
val walletSetup = Wallet.getInstance().getWalletSetupService()
import PaysafeWallet
let walletSetup = Wallet.instance.walletSetupService
Initiate a customer data verification process
Use initiateDataVerificationProcess method to initiate a verification process for a specific customer attribute, such as email or mobile.
The method requires an object of type CustomerDataVerificationRequest. More information about it, you can find here for Android and here for iOS.
- Kotlin
- Swift
val emailDataVerificationRequest = CustomerDataVerificationRequest(
    CustomerDataVerificationAttribute(
        CustomerDataVerificationAttributeType.EMAIL,
        "john.doe@paysafe.com"
    ),
    CustomerDataVerificationFlow.WALLET_SETUP
)
try {
  val emailDataVerificationResponse = walletSetup.initiateDataVerificationProcess(emailDataVerificationRequest)
  Log.d(TAG, response.toString())
} catch (exception: Exception) {
  Log.d(TAG, exception.toString())
}
let emailDataVerificationRequest = Wallet.CustomerDataVerificationRequest(
    attribute: Wallet.CustomerDataVerificationAttribute(
        type: .email,
        value: "john.doe@paysafe.com"
    ),
    flow: .walletSetup
)
walletSetup.initiateDataVerificationProcess(request: emailDataVerificationRequest,
                                            completion: { result in
    switch result {
    case .success(let emailDataVerificationResponse):
        // Display status
    case .failure(let error):
        // Handle error
    }
})
After calling the initiateDataVerificationProcess you will receive a CustomerDataVerificationResponse object, containing a verificationId attribute.
This attribute is key for submitting a customer data verification attempt and onboarding a customer.
See Submit a customer data verification attempt and Onboard a customer.
Submit a customer data verification attempt
Use submitDataVerificationAttempt method to submit a verification attempt for a specific customer attribute tied to an already initiated verification process.
The method submitDataVerificationAttempt requires a verificationId. You should obtain it from the CustomerDataVerificationResponse object
that you received after calling initiateDataVerificationProcess. This verification id is the link to the data verification process initiated by the customer.
The second parameter, required by the submitDataVerificationAttempt method is a CustomerDataVerificationAttemptRequest object. A more detailed information about the object, you can find here for Android and here for iOS.
- Kotlin
- Swift
val dataVerificationAttemptRequest = CustomerDataVerificationAttemptRequest(
    attribute = CustomerDataVerificationAttribute(
        type = CustomerDataVerificationAttributeType.EMAIL,
        value = "john.doe@example.com"
    ),
    notificationType = CustomerDataVerificationNotificationType(
        method = CustomerDataVerificationNotificationMethod.OTP,
        channel = CustomerDataVerificationNotificationChannel.EMAIL
    ),
    value = "123456"
)
try {
  val dataVerificationAttemptResponse = walletSetup.submitDataVerificationAttempt(
      emailDataVerificationResponse.verificationid,
      dataVerificationAttemptRequest
  )
  Log.d(TAG, response.toString())
} catch (exception: Exception) {
  Log.d(TAG, exception.toString())
}
let dataVerificationAttemptRequest = Wallet.CustomerDataVerificationAttemptRequest(
    attribute: CustomerDataVerificationAttribute(
        type: .email,
        value: "john.doe@paysafe.com"
    ),
    notificationType: CustomerDataVerificationNotificationType(
        method: .otp,
        channel: .email
    ),
    value: "123456"
)
walletSetup.submitDataVerificationAttempt(verificationId: emailDataVerificationResponse.verificationId, 
                                          request: dataVerificationAttemptRequest,
                                          completion: { result in
    switch result {
    case .success(let dataVerificationAttemptResponse):
        // Display status
    case .failure(let error):
        // Handle error
    }
})
Onboard a customer
Use onboardCustomer method to onboard a new customer. You need to provide an object of type CustomerPersonRequest. Details about the object can be found here for Android and here for iOS.
By onboarding a customer, we will ensure that they meet all the necessary requirements to use the wallet. Once successful, customer can be authenticated using provided contact method and credentials.
The CustomerIdentifiersOnboarding consists of two CustomerIdentifier objects. Both identifiers must be provided in the request. Each identifier has a verificationId which will be used to ensure that the customer has been verified through the data verification process.
See Inititate a customer data verification process and Submit a customer data verification attempt and Onboard a customer for more details.
- Kotlin
- Swift
val customerPersonRequest = CustomerPersonRequest(
    title = null,
    firstName = "John",
    lastName = "Doe",
    birthDate = "1981-08-24",
    nationality = "GB",
    occupation = Occupation.ARCHITECTURE_CARTOGRAPHY_SURVEYOR,
    vulnerabilities = listOf(
        Vulnerability.PHYSICAL_DISABILITY
    ),
    additionalAttributes = mapOf("KEY_ALIGNED_WITH_PAYSAFE" to "VALUE_GIVEN_BY_CUSTOMER"),
    customerIdentifiers = CustomerIdentifiersOnboarding(
        email = CustomerIdentifier(
            value = "john.doe@paysafe.com",
            verificationId = emailDataVerificationResponse.verificationId
        ),
        mobile = CustomerIdentifier(
            value = "+359897765463",
            verificationId = mobileDataVerificationResponse.verificationId
        )
    ),
    customerCredentials = CustomerCredentials(
        password = "Password1.",
        pin = null,
    ),
    currencyCode = "EUR",
    address = Address(
        countryCode = "GB",
        stateProvince = null,
        city = "London",
        postalCode = "E1 8RU",
        address1 = "221b Baker St",
        address2 = null,
    ),
    preferences = Preferences(
        marketing = MarketingPreferences(
            receivePushNotifications = true,
            receiveMarketingEmails = true,
            receiveMarketingSms = true,
            receiveSocialAds = false,
            receiveTargetedAds = false,
            receiveThirdPartyAds = false,
        ),
        data = DataPreferences(
            consentForTargetedAds = true,
            consentForAnalytics = false,
            consentForPerformanceTracking = true
        )
    ),
    termsAndConditions = true,
    isPoliticallyExposed = false,
)
try {
    val customerInfo = walletSetup.onboardCustomer(customerPersonRequest)
    Log.d(TAG, customerInfo.toString())
} catch(e: Exception) {
    Log.d(TAG, exception.toString())
}
let customerPersonRequest = Wallet.CustomerPersonRequest(
    title: nil,
    firstName: "John",
    lastName: "Doe",
    birthDate: Date(timeIntervalSince1970: 367459200),
    nationality: "GB",
    occupation: .architectureCartographySurveyor,
    vulnerabilities: [.gamblingAddiction],
    additionalAttributes: ["KEY_ALIGNED_WITH_PAYSAFE" : "VALUE_GIVEN_BY_CUSTOMER"],
    customerIdentifiers: Wallet.CustomerIdentifiersOnboarding(
        email: Wallet.CustomerIdentifier(
            value: "john.doe@paysafe.com",
            verificationId: emailDataVerificationResponse.verificationId
        ),
        mobile: Wallet.CustomerIdentifier(
            value: "+359897765463",
            verificationId: mobileDataVerificationResponse.verificationId
        )
    ),
    customerCredentials: Wallet.CustomerCredentials(
        password: "Password1.",
        pin: nil
    ),
    currencyCode: "EUR",
    address: Wallet.CustomerPersonRequest.Address(
        countryCode: "GB",
        stateProvince: nil,
        city: "London",
        postalCode: "E1 8RU",
        address1: "221b Baker St",
        address2: nil
    ),
    preferences: Wallet.Preferences(
        marketing: Wallet.MarketingPreferences(
            receivePushNotifications: true,
            receiveMarketingEmails: true,
            receiveMarketingSms: true,
            receiveSocialAds: false,
            receiveTargetedAds: false,
            receiveThirdPartyAds: false
        ),
        data: Wallet.DataPreferences(
            consentForTargetedAds: true,
            consentForAnalytics: false,
            consentForPerformanceTracking: true
        )
    ),
    termsAndConditions: true,
    isPoliticallyExposed: false
)
walletSetup.onboardCustomer(customer: customerPersonRequest,
                                                    completion: { result in
    switch result {
    case .success(let customerInfo):
        // Display status
    case .failure(let error):
        // Handle error
    }
})
Change customer credentials
Use changeCredentials method to change a specific customer credential, such as password.
You need to provide an object of type ChangeCustomerCredentialsRequest to the method. The CustomerIdentifiers consists of two CustomerIdentifier objects. At least one identifier must be provided in the request. Each identifier has a verificationId which will be used to ensure that the customer has been verified through the data verification process.
See Inititate a customer data verification process and Submit a customer data verification attempt for more details how to obtain the verificationId parameter.
The CustomerCredentials is a struct representing the credentials you wish to change (e.g. password).
ChangeCustomerCredentialsRequest
| Parameter | Data type | Description | Example | 
|---|---|---|---|
| customerIdentifiers | CustomerIdentifiers | Required. The client's email or mobile. | CustomerIdentifiers(CustomerIdentifier("john.doe@paysafe.com", "06bdcd2c"), null) /CustomerIdentifiers(email: CustomerIdentifier(value: "john.doe@paysafe.com", verificationId: "06bdcd2c"), mobile: nil) | 
| customerCredentials | CustomerCredentials | Required. The new client credentials. | CustomerCredentials("Password1.")/CustomerCredentials(password: "Password1.") | 
- Kotlin
- Swift
val changeCustomerCredentialsRequest = ChangeCustomerCredentialsRequest(
    CustomerIdentifiers(
        email = CustomerIdentifier(
            value = "john.doe@paysafe.com",
            verificationId = "06bdcd2c-0cce-4b36-97ec-281c8f5d743c"
        ),
        mobile = null
    ),
    CustomerCredentials(
        password = "Password1."
    )
)
try {
    walletSetup.changeCredentials(changeCustomerCredentialsRequest)
    Log.d(TAG, "Credentials changed successfully")
} catch (exception: Exception) {
    Log.d(TAG, exception.toString())
}
let changeCustomerCredentialsRequest = Wallet.ChangeCustomerCredentialsRequest(
    customerIdentifiers: Wallet.CustomerIdentifiers(
        email: Wallet.CustomerIdentifier(
            value: "john.doe@paysafe.com",
            verificationId: "06bdcd2c-0cce-4b36-97ec-281c8f5d743c"
        ),
        mobile: nil
    ),
    customerCredentials: Wallet.CustomerCredentials(
        password: "Password1."
    )
)
walletSetup.changeCredentials(request: changeCustomerCredentialsRequest,
                              completion: { result in
    switch result {
    case .success:
        // Display status
    case .failure(let error):
        // Handle error
    }
})