Enabling payments via a payment link

Requirements for connecting

Supported version: Android 7.0 and higher.

Before you start the integration, obtain the following IDs and add them to your project:

  • Merchant ID
  • SHA256 Fingerprints
  • Client ID (YANDEX_CLIENT_ID)
  • Android package name (applicationId)

Step 1. Obtain the required IDs

  1. Get the SHA256 Fingerprints hash value using the keytool utility:

    keytool -list -v -alias <your-key-name> -keystore <path-to-production-keystore>
    

    Once you enter the command, the hash value will be shown under Certificate fingerprints: SHA256.

  2. To register the app, go to Yandex OAuth.

  3. In the Service name field, enter the name to be displayed to users on the authorization screen.

  4. Under Platforms, select Android app and set its parameters:

    • Android package name: Unique app name from the project config file's applicationId.
    • SHA256 Fingerprints: SHA256 hash value from step 1. The hash must contain capital letters only.
  5. Make sure that your app has access to Yandex Pay added in Yandex OAuth. To do this, select Payment via Yandex Pay in the Permission name field of the Data access section.

  6. Click Create application and copy the Client ID field value.

  7. On the Settings page of the Yandex Pay dashboard, specify the Client ID, SHA256, and Android package name values in the Client ID, SHA256 Fingerprints, and Android package name fields, respectively.

Step 2. Enable the Client ID

Specify the resulting Client ID in the build.gradle build script as the YANDEX_CLIENT_ID value in manifestPlaceholders:

   android {
     defaultConfig {
       manifestPlaceholders = [
         // Use your Client ID
         YANDEX_CLIENT_ID: "12345678901234567890",
       ]
     }
   }

Step 3. Initialize FirebaseApp in all the app's workflows

The Mobile SDK uses AppMetrica services to ensure the stable operation of the SDK. This step helps fix the Firebase and AppMetrica service compatibility issues.

If Firebase is used along with the Yandex Pay SDK, call FirebaseApp.initialize(context) in all the app's workflows.

If you use AppMetrica in your app, be sure to activate YandexMetrica after Firebase is initialized.

Example

// Don`t forget declare MyApplication in AndroidManifest.xml in <application/> block using android:name
class MyApplication: Application() {

    override fun onCreate() {
        // Inited at every app processes
        FirebaseApp.initializeApp(this)
    }
}

For details of the interaction, see AppMetrica is stopped after Firebase upgrade to version 31+.

Step 4. Enable the Yandex Pay SDK

Add the following dependency to your build.gradle build scripts:

dependencies {
    implementation 'com.yandex.pay.inapps:inapps:1.2.0'
}

Step 5. Get an object of the payment session

Get an object of the payment session using the  getYandexPaymentSession function:

  private val yaPayConfig = YPayConfig(
    merchantData = MerchantData(
        id = MerchantId("merchantId"),
        name = MerchantName("merchantName"),
        url = MerchantUrl("https://merchant.com/"),
    ),
    environment = YPayApiEnvironment.PROD,
  )

  private val paymentSessionKey = PaymentSessionKey(
    generateSessionKey()
  )

  private val paymentSession: PaymentSession = YPay.getYandexPaymentSession(
    context = this,
    config = yaPayConfig,
    sessionKey = paymentSessionKey  // Optional if you're using Kotlin for implementation
  )
  private YPayConfig getPayConfig() {
    return new YPayConfig(
        new MerchantData(
            new MerchantId("merchantId"),
            new MerchantName("MERCHANT_NAME"),
            new MerchantUrl("https://merchant.com/")
        ),
        YPayApiEnvironment.PROD
    );
  }

  private PaymentSessionKey getPaymentSessionKey() {
    return new PaymentSessionKey(
        generateSessionKey()
    );
  }

  private PaymentSession getPaymentSession() {
    return YPay.INSTANCE.getYandexPaymentSession(
        this,
        getPaymentSessionKey(),
        getPayConfig()
    );
  }

When getting a PaymentSession, be sure to pass:

  • Context: the context of the application or Activity.
  • PaymentSessionKey: Key of the payment session.
  • YPayConfig: Data about the Yandex Pay SDK configuration.

When creating YPayConfig, be sure to pass:

  • merchantData: Data of the merchant:

    • id: Unique merchant ID. You can get it when registering a merchant in Yandex Pay service.
    • name: The name of the merchant that the user will see.
    • url: The URL of the merchant that the user will see.
  • environment: The Yandex Pay SDK execution environment:

    • PROD: Production environment.
    • SANDBOX: A test environment.

Step 6. Initialize a contract for Yandex Pay launch

When initializing the contract, add a callback that obtains the YPayResult:

private val yandexPayLauncher = YPayLauncher(this) { result: YPayResult ->
    when (result) {
        is YPayResult.Success -> showToast("Finished with success")
        is YPayResult.Cancelled -> showToast("Finished with cancelled event")
        is YPayResult.Failure -> showToast("Finished with domain error")
    }
}
private final YPayLauncher launcher = new YPayLauncher(this, yPayResult -> {
    if (yPayResult instanceof YPayResult.Success) {
        handleResult("Finished with success");
    } else if (yPayResult instanceof YPayResult.Cancelled) {
        handleResult("Finished with cancelled event");
    } else if (yPayResult instanceof YPayResult.Failure) {
        handleResult("Finished with domain error");
    }
});

In the event of payment failure, the errorMsg error code is also returned:

Error code Description
incorrect payment url Invalid payment link
transaction error Error performing transaction
failed to parse order ID No orderId received with the results returned
invalid intent parsing No payment results received
invalid result code Invalid payment result code
unresolved payment strategy Couldn't handle the payment results because your app shut down in the background
session key not provided No session key provided
config data not provided The СonfigData object not provided
payment data not provided The PaymentData object not provided

Step 7. Generate data for launching Yandex Pay

Before launching Yandex Pay, generate payment data using the PaymentData.PaymentUrlFlowData class and payment session data. Create YPayContractParams based on this data.

val paymentData = PaymentData.PaymentUrlFlowData(
    // Order payment URL received from the Yandex Pay API
    paymentUrl = "payment-url"
)

val params = YPayContractParams(
    paymentSession = paymentSession,
    paymentData = paymentData,
)
final PaymentData paymentData = new PaymentData.PaymentUrlFlowData(
    // Order payment URL received from the Yandex Pay API
    "payment-url"
);

// Parameters for launching Yandex Pay
final YPayContractParams params = new YPayContractParams(
    getPaymentSession(),
    paymentData
);

Note

For more information about generating a payment link, see the backend documentation.

Step 8. Launch Yandex Pay

Run the service using the launcher, passing the YPayContractParams launch parameters:

val params = YPayContractParams(...)
yandexPayLauncher.launch(params)
final YPayContractParams params = new YPayContractParams(...);
yandexPayLauncher.launch(params);

Step 9. Handle the results

After Yandex Pay is launched, the SDK will launch a payment form, within which the payment will be made. The result will be obtained using the launch contract YPayLauncher.

Previous