Flutter plugin for Razorpay Custom SDK.
This flutter plugin is a wrapper around our Android and iOS SDKs.
The following documentation is only focused on the wrapper around our native Android and iOS SDKs. To know more about our SDKs and how to link them within the projects, refer to the following documentation:
iOS / Android: https://razorpay.com/docs/
To know more about Razorpay payment flow and steps involved, read up here: https://razorpay.com/docs/
- Learn about the Razorpay Payment Flow.
- Sign up for a Razorpay Account and generate the API Keys from the Razorpay Dashboard. Using the Test keys helps simulate a sandbox environment. No actual monetary transaction happens when using the Test keys. Use Live keys once you have thoroughly tested the application and are ready to go live.
This plugin is available on Pub: https://pub.dev/packages/razorpay_flutter_customui
Add this to dependencies
in your app's pubspec.yaml
Frazorpay_flutter_customui: ^1.3.0
Note for Android: Make sure that the minimum API level for your app is 19 or higher.
If you are using proguard for your builds, you need to add following lines to proguard files
-keepattributes *Annotation*
-dontwarn com.razorpay.**
-keep class com.razorpay.** {*;}
-optimizations !method/inlining/
-keepclasseswithmembers class * {
public void onPayment*(...);
}
Follow this for more details.
Note for iOS: Make sure that the minimum deployment target for your app is iOS 10.0 or higher. Also, don't forget to enable bitcode for your project.
Run flutter packages get
in the root directory of your app.
Sample code to integrate can be found in example/lib/main.dart.
import 'package:razorpay_flutter_customui/razorpay_flutter_customui.dart';
_razorpay = Razorpay();
The plugin uses event-based communication, and emits events when payment fails or succeeds.
The event names are exposed via the constants EVENT_PAYMENT_SUCCESS
, EVENT_PAYMENT_ERROR
and EVENT_EXTERNAL_WALLET
from the Razorpay
class.
Use the on(String event, Function handler)
method on the Razorpay
instance to attach event listeners.
_razorpay.on(Razorpay.EVENT_PAYMENT_SUCCESS, _handlePaymentSuccess);
_razorpay.on(Razorpay.EVENT_PAYMENT_ERROR, _handlePaymentError);
The handlers would be defined somewhere as
void _handlePaymentSuccess(Map<dynamic, dynamic> response) {
// Do something when payment succeeds
}
void _handlePaymentError(Map<dynamic, dynamic> response) {
// Do something when payment fails
}
To clear event listeners, use the clear
method on the Razorpay
instance.
_razorpay.clear(); // Removes all listeners
var options = {
'key': '<YOUR_KEY_HERE>',
'amount': 100,
'name': 'Acme Corp.',
'description': 'Fine T-Shirt',
'prefill': {
'contact': '8888888888',
'email': '[email protected]'
}
};
A detailed list of options can be found here.
_razorpay.submit(options);
Open ios/Podfile
and find this section:
post_install do |installer|
installer.pods_project.targets.each do |target|
target.build_configurations.each do |config|
config.build_settings['ENABLE_BITCODE'] = 'NO'
end
end
end
Set config.build_settings['ENABLE_BITCODE'] = 'YES'
.
Add the following line below config.build_settings['ENABLE_BITCODE'] = 'YES'
:
config.build_settings['SWIFT_VERSION'] = '5.0'
Specs satisfying the `razorpay_flutter (from
`.symlinks/plugins/razorpay_flutter/ios`)` dependency were found, but they
required a higher minimum deployment target.
This is due to your minimum deployment target being less than iOS 10.0. To change this, open ios/Podfile
in your project and add/uncomment this line at the top:
# platform :ios, '9.0'
and change it to
platform :ios, '10.0'
and run pod install
again in the ios
directory.
Add use_frameworks! in ios/Podfile
and run pod install
again in the ios
directory.
Gradle build fails with Error: uses-sdk:minSdkVersion 16 cannot be smaller than version 19 declared in library [:razorpay_flutter]
This is due to your Android minimum SDK version being less than 19. To change this, open android/app/build.gradle
, find minSdkVersion
in defaultConfig
and set it to at least 19
.
We export a class Razorpay
from package:razorpay_flutter/razorpay_flutter.dart
. Check if your code is redeclaring the Razorpay
class.
[VERBOSE-2:ui_dart_state.cc(148)] Unhandled Exception: type 'PaymentFailureResponse' is not a subtype of type 'PaymentSuccessResponse' of 'response'
#0 Razorpay.on.<anonymous closure> (package:razorpay_flutter/razorpay_flutter.dart:87:14)
#1 EventEmitter.emit.<anonymous closure> (package:eventify/src/event_emitter.dart:94:14)
#2 List.forEach (dart:core-patch/growable_array.dart:278:8)
#3 EventEmitter.emit (package:eventify/src/event_emitter.dart:90:15)
#4 Razorpay._handleResult (package:razorpay_flutter/razorpay_flutter.dart:81:19)
#5 Razorpay.open (package:razorpay_flutter/razorpay_flutter.dart:49:5)
Check the signatures of the callbacks for payment events. They should match the ones described here.
Open Razorpay Checkout.
The options
map has key
as a required property. All other properties are optional.
For a complete list of options, please see the Checkout documentation.
Register event listeners for payment events.
eventName
: The name of the event.listener
: The function to be called. The listener should accept a single argument of the following type:PaymentSuccessResponse
forEVENT_PAYMENT_SUCCESS
PaymentFailureResponse
forEVENT_PAYMENT_FAILURE
Clear all event listeners.
The error codes have been exposed as integers by the Razorpay
class.
The error code is available as the code
field of the PaymentFailureResponse
instance passed to the callback.
Error Code | Description |
---|---|
NETWORK_ERROR | There was a network error, for example loss of internet connectivity |
INVALID_OPTIONS | An issue with options passed in Razorpay.open |
PAYMENT_CANCELLED | User cancelled the payment |
TLS_ERROR | Device does not support TLS v1.1 or TLS v1.2 |
UNKNOWN_ERROR | An unknown error occurred. |
The event names have also been exposed as Strings by the Razorpay
class.
Event Name | Description |
---|---|
EVENT_PAYMENT_SUCCESS | The payment was successful. |
EVENT_PAYMENT_ERROR | The payment was not successful. |
Field Name | Type | Description |
---|---|---|
paymentId | String | The ID for the payment. |
orderId | String | The order ID if the payment was for an order, null otherwise. |
signature | String | The signature to be used for payment verification. (Only valid for orders, null otherwise) |
Field Name | Type | Description |
---|---|---|
code | int | The error code. |
message | String | The error message. |