Integrating PayHere with your Flutter App is super easy with our PayHere Flutter SDK. You just have to include the package in your project dependencies, call its methods to initiate a payment and fetch the payment status just after the payment. The beauty is, this SDK allows you to accept a payment within your app, without redirecting your app user to the web browser.
Open your Flutter project's pubspec.yaml
file and add the PayHere Flutter SDK dependency.
dependencies:
payhere_mobilesdk_flutter: ^3.0.10
Then run the following commands in your Flutter project directory.
flutter pub get
Open up the (outermost) build.gradle
file in your Android project and add the repository.
allprojects {
repositories {
mavenLocal()
maven {
url 'https://jitpack.io'
}
}
}
Open up the AndroidManifest.xml
file in your Anrdoid project and make the following changes.
i. Declare the Android tools
namespace in the <manifest>
element.
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.domain.name"
xmlns:tools="http://schemas.android.com/tools">
ii. Add the replace
merge rule for the android:label
attribute in the <application>
element.
<application tools:replace="android:label">
Run the following command in your iOS Project.
pod install
a. Login to your PayHere Merchant Account and navigate to Integrations.
b. Click the 'Add Domain/App' button.
c. Select 'App' from the first dropdown.
d. Add your Flutter App package name (e.g. lk.bhasha.helakuru).
e. Take note of the hash value in the last field. This is your Merchant Secret for this specific mobile App.
f. Click 'Request to Approve'.
If you are using a PayHere Live Merchant Account, your App Package Name must be manually reviewed by our operations team. Please allow upto a day for this review process to complete.
For more information, please contact techsupport@payhere.lk
Creates a one-time payment request charged only once. To capture the payment details from your server, read our docs.
import 'package:payhere_mobilesdk_flutter/payhere_mobilesdk_flutter.dart';
Map paymentObject = {
"sandbox": true, // true if using Sandbox Merchant ID
"merchant_id": "1211149", // Replace your Merchant ID
"notify_url": "https://ent13zfovoz7d.x.pipedream.net/",
"order_id": "ItemNo12345",
"items": "Hello from Flutter!",
"amount": 50.00,
"currency": "LKR",
"first_name": "Saman",
"last_name": "Perera",
"email": "samanp@gmail.com",
"phone": "0771234567",
"address": "No.1, Galle Road",
"city": "Colombo",
"country": "Sri Lanka",
"delivery_address": "No. 46, Galle road, Kalutara South",
"delivery_city": "Kalutara",
"delivery_country": "Sri Lanka",
"custom_1": "",
"custom_2": ""
};
PayHere.startPayment(
paymentObject, (paymentId) {
print("One Time Payment Success. Payment Id: $paymentId");
}, (error) {
print("One Time Payment Failed. Error: $error");
}, () {
print("One Time Payment Dismissed");
}
);
Creates a subscription payment that is charged at a fixed frequency. To capture the payment details from your server, read our docs.
Read more about Recurring Payments in our docs.
import 'package:payhere_mobilesdk_flutter/payhere_mobilesdk_flutter.dart';
Map paymentObject = {
"sandbox": true, // true if using Sandbox Merchant ID
"merchant_id": "1211149", // Replace your Merchant ID
"notify_url": "https://ent13zfovoz7d.x.pipedream.net/",
"order_id": "ItemNo12345",
"items": "Hello from Flutter!",
"amount": 100.00,
"recurrence": "1 Month", // Recurring payment frequency
"duration": "1 Year", // Recurring payment duration
"currency": "LKR",
"first_name": "Saman",
"last_name": "Perera",
"email": "samanp@gmail.com",
"phone": "0771234567",
"address": "No.1, Galle Road",
"city": "Colombo",
"country": "Sri Lanka",
"delivery_address": "No. 46, Galle road, Kalutara South",
"delivery_city": "Kalutara",
"delivery_country": "Sri Lanka",
"custom_1": "",
"custom_2": ""
};
PayHere.startPayment(
paymentObject, (paymentId) {
print("Recurring Payment Success. Payment Id: $paymentId");
}, (error) {
print("Recurring Payment Failed. Error: $error");
}, () {
print("Recurring Payment Dismissed");
}
);
Tokenize customer card details for later usage with the PayHere Charging API. To capture the payment details from your server, read our docs.
Read more about Automated Charging in our docs.
NOTE: Since version 3.0.4 you can pass an 'amount' parameter in the pre-approval request. If this is omitted the customer will only be pre-approved. If an amount is provided, it will be charged from the customer during pre-approval. In both scenarios a
customer_token
will still be generated.
import 'package:payhere_mobilesdk_flutter/payhere_mobilesdk_flutter.dart';
Map paymentObject = {
"sandbox": true, // true if using Sandbox Merchant ID
"preapprove": true, // Required
"merchant_id": "1211149", // Replace your Merchant ID
"notify_url": "http://sample.com/notify",
"order_id": "ItemNo12345",
"items": "Hello from Flutter!",
"currency": "LKR",
"first_name": "Saman",
"last_name": "Perera",
"email": "samanp@gmail.com",
"phone": "0771234567",
"address": "No.1, Galle Road",
"city": "Colombo",
"country": "Sri Lanka",
"amount": 30.00 // Optional. An amount to pass while pre-approving.
};
PayHere.startPayment(
paymentObject, (paymentId) {
print("Tokenization Payment Success. Payment Id: $paymentId");
}, (error) {
print("Tokenization Payment Failed. Error: $error");
}, () {
print("Tokenization Payment Dismissed");
}
);
Authorize (hold) charges on a customer's card for later use with the PayHere Capture API. To capture the payment hold details from your server, read out docs.
Read more about Hold-on-card in our docs.
import 'package:payhere_mobilesdk_flutter/payhere_mobilesdk_flutter.dart';
Map paymentObject = {
"sandbox": true, // true if using Sandbox Merchant ID
"authorize": true, // Required
"merchant_id": "1211149", // Replace your Merchant ID
"notify_url": "https://ent13zfovoz7d.x.pipedream.net/",
"order_id": "ItemNo12345",
"items": "Hello from Flutter!",
"currency": "LKR",
"amount": "50.00",
"first_name": "Saman",
"last_name": "Perera",
"email": "samanp@gmail.com",
"phone": "0771234567",
"address": "No.1, Galle Road",
"city": "Colombo",
"country": "Sri Lanka",
};
PayHere.startPayment(paymentObject, (paymentId) {
print("Hold-on-Card Payment Success.");
}, (error) {
print("Hold-on-Card Payment Failed. Error: $error");
}, () {
print("Hold-on-Card Payment Dismissed");
});
Starting with version 2.0.0
you can optionally pass the details of the line items in the order. These details will appear in the customer's invoice. Item-wise Details are supported in Onetime, Subscription and Authorization payment modes. It is not supported in Pre-approval payments.
Each item has four parameters. Their parameter names must be followed by the index of that item. For example:
"item_number_1": "ITM001",
"item_name_1": "PayHere Sticker",
"quantity_1": "2",
"amount_1": "25.0",
An example Onetime payment request with 2 items is shown below. If you have specific questions, please raise them in the Issues section.
import 'package:payhere_mobilesdk_flutter/payhere_mobilesdk_flutter.dart';
Map paymentObject = {
"sandbox": true,
"merchant_id": "1211149", // Replace your Merchant ID
"notify_url": "https://ent13zfovoz7d.x.pipedream.net/",
"order_id": "ItemNo12345",
"items": "Hello from Flutter!",
"item_number_1": "001", // ** Item 1 **
"item_name_1": "Test Item #1",
"amount_1": "15.00",
"quantity_1": "2",
"item_number_2": "002", // ** Item 2 **
"item_name_2": "Test Item #2",
"amount_2": "20.00",
"quantity_2": "1",
"amount": 50.00,
"currency": "LKR",
"first_name": "Saman",
"last_name": "Perera",
"email": "samanp@gmail.com",
"phone": "0771234567",
"address": "No.1, Galle Road",
"city": "Colombo",
"country": "Sri Lanka",
"delivery_address": "No. 46, Galle road, Kalutara South",
"delivery_city": "Kalutara",
"delivery_country": "Sri Lanka",
"custom_1": "",
"custom_2": ""
};
PayHere.startPayment(
paymentObject, (paymentId) {
print("One Time Payment Success. Payment Id: $paymentId");
}, (error) {
print("One Time Payment Failed. Error: $error");
}, () {
print("One Time Payment Dismissed");
}
);
Flutter versions above 1.20.0
are supported.
The iOS component for this SDK supports iOS Versions above 11.0.
The Android component for this SDK supports Android Versions above API Level 17.
PayHere.startPayment(
paymentObject,
onCompletedHandler,
onErrorHandler,
onDismissedHandler
);
-
paymentObject
- Object The payment parameters as a Map<String, dynamic>. -
onCompletedHandler
- Function Called with the PayHere Payment ID (String) as a parameter, for succesful payments. -
onErrorHandler
- Function Called with the Error (String) as a parameter, when an error occurs. -
onDismissedHandler
- Function Called with no parameters, when the payment popup is closed before payments are processed.
You must setup a Server Endpoint that accepts the asynchronous PayHere Payment Notification POST
request, and pass its URL to the notify_url
parameter of the paymentObject
.
Each payment request type (one-time/recurring/pre-approval) sends a different payment notification. Study the following sections for more information.
- One-time Payment Details: read docs
- Recurring Payment Details: read docs
- Preapproval Details: read docs
- Authorization (Hold) Details: read docs
I am getting an error saying, "Could not GET 'https://dl.bintray.com..."
PayHere Flutter Native SDK versions prior to 1.0.2 (1.0.1 and previous versions) depended on an older version of the PayHere Android SDK which is no longer available through the bintray.com Maven repository. Update to the latest version 1.0.2 and try again.
If you are still experiencing issues, make sure you have followed the new "2. Android Pre-requisites" section with updated instructions for SDK versions 1.0.2 and above.
To fix the issue, open the "./ios/Podfile" file. Find the line that says "use_modular_headers!". Above it, add the "use_frameworks!" line as shown below.
target 'Runner' do
# Add this line
use_frameworks!
use_modular_headers!
flutter_install_all_ios_pods File.dirname(File.realpath(__FILE__))
end
Clean and re-build your project and the issue should be resolved.
Yes! Version 1.0.3 and up opts into Flutter Null Safety.
If you are creating a new Flutter project, you will experience no issues. If you have project that you are planning to upgrade to Flutter 2 / migrate to Flutter Null Safety, there are no changes to be done in code other than updating to the latest version.
Yes! Starting from version 2.0.0
, the PayHere Flutter SDK supports Item-wise Parameters. Please read Section 6 above.
Yes and No. Starting from version 2.0.0
this SDK supports Authorization (also known as Hold on Card) requests. Authorizations generate an authorization_token
which is sent as a POST request to your notify_url
.
From there you must use the PayHere Capture API to use the genereated token and perform the capture. You can read more about the PayHere Hold on Card Feature by reading our docs.
- You can raise issues directly at the Issues section for the SDK's GitHub page.
- You can contact a PayHere Developer for technical support by mailing your issue and relevant code/screenshots to techsupport@payhere.lk