Do you want to accept payments from mobile users in different countries, different payment system by writing just few of code lines? Paymentwall SDK is a global mobile payment gateway that accepts payments from more than 200 countries with 100+ alternative payment options. We now provide SDK for iOS which will become a native part of your application, it eliminates the necessity to open a web browser for payments. Less steps, faster process, there’s no doubt your conversion rate will get boost! All you have to do is import the library into your project and config it to start accepting in-app payment. It is quick and easy! We'll guide you through the process here.
- Add the framework to your project. With different areas, we provide corresponding external payment system framework files. You can add as many as you want. You can also enable/disable default payment options too. You can add any payment option as they want by importing the payment system framework and framework plugin provided by Paymentwall to your project
- User requests a purchase inside your application.
- Paymentwall SDK initializes payment screen with 3 core payment options (Brick, MINT, Mobiamo) and the other is “Local Payments” option.
- User initiates payment in-app With Brick, Mint, Mobiamo the payment process will totally be native. With local payments, local payment screen will be shown with payment methods corresponding to user’s current location. Here users can then select a payment option they prefer.
XCode 8.0+, iOS 8.0+
SDK integration requires a project key. Obtain these Paymentwall API credentials in the application settings of your Merchant Account at Paymentwall.com
Our SDK is delivered as static library or public repository.
- Install CocoaPods 0.39.0 or later
- In your Podfile, add
pod 'PWCoreSDK'
andpod 'PW[Local payment method]Plugin'
(optional) to your main and test targets - From the command line, run
pod install
- Use the .xcworkspace file generated by CocoaPods
- Add
-ObjC
toOther Linker Flags
in your project's Build settings - If you are using Swift, create a new Objective-C file in order to create new
bridging-header.h
files, then import the following files into the header file like:
#import <PWCoreSDK/PWCoreSDK.h>
- Download the latest release of the SDK and extract the zip.
- Go to your Xcode project’s “General” settings. Drag libPWCoreSDK.a and other plugin library to your project directory to the “Linked frameworks and libraries” section. Make sure Copy items if needed is selected and click Finish.
- In your unit test target’s “Build Settings”, add the parent path to libPWCoreSDK.a in the “Library Search Paths” section.
- Drag the bundle into your "Copy bundle resources" in project's "Build phase"
- Add
-ObjC
toOther Linker Flags
in your project's Build settings - If you are using Swift, create a new Objective-C file in order to create new
bridging-header.h
files, then import the following files into the header file like:
#import <PWCoreSDK/PWCoreSDK.h>
Update: If your CoreSDK got update during install any plugin, you should also check to update the rest of plugins.
- Setup the SDK with the following params, only need to setup (step 1-7) once:
PWCoreSDK.sharedInstance().setupPaymentwall(withProjectKey: "YOUR PUBLIC KEY", secretKey: "YOUR SECRET KEY", requestTimeout: 30)
Optional: Extra settings can be found in the Extra settings section below
Project key: All payment option will use this Project key if their Project key set to nil, you also can specify their own Project key
Secret key: PWLocal and local payment options plugins will use this Secret key as default if you specify it here
- Implement
PWCoreSDKDelegate
protocol to handle payment response:
func paymentResponse(_ response: PWCoreSDKResponse?) {
guard let response = response else { return }
switch response.responseCode {
case .SUCCESSFUL:
case .FAILED:
case .CANCEL:
case .MERCHANT_PROCESSING:
//Example when you use Brick and `useNativeFinishDialog == true` can be found below
}
switch response.paymentType {
case .NONE:
case .MINT:
case .PWLOCAL:
case .BRICK:
case .MOBIAMO:
case .OTHERS:
}
}
- Add Brick payment type, Brick is Paymentwall's credit card solution available for businesses in 200+ countries, please refer below on how to handle Brick payment flow, cardScannerPlugin is distributed as a plugin and is optional:
PWCoreSDK.sharedInstance().addBrickPayment(withPublicKey: nil, useNativeFinishDialog: true, cardScannerPlugin: PWCardScannerPlugin.sharedInstance())
- Add Mobiamo payment type, Mobiamo is a mobile carrier billing platform with global coverage via SMSs,
noPrice
specify if you want to use the default Mobiamo price for each country:
PWCoreSDK.sharedInstance().addMobiamoPayment(withAppID: nil, noPrice: true)
- Add Mint payment type, MINT is Paymentwall's cash payment solution designed to help monetize your digital goods and services all over the world via MINT prepaid card:
PWCoreSDK.sharedInstance().addMintPayment(withAppID: nil)
- Add PWLocal payment type,
type
can be VIRTUAL_CURRENCY / DIGITAL_GOODS_FLEXIBLE / DIGITAL_GOODS_DEFAULT / CART:
PWCoreSDK.sharedInstance().addPWLocalPayment(with: .DIGITAL_GOODS_FLEXIBLE, secretKey: nil)
- Add any other local payment option plugin if you want, please refer Implement local payment options section below on how to create them:
PWCoreSDK.sharedInstance().addCustomPaymentOptions([alipay, unionpay, ...])
Note: These payment options will be place in
Local payments
together with PWLocal.
- Create new payment with
PaymentObject
class and assign to the CoreSDK:
let payment = PaymentObject()
payment.name = choosenItem.name
payment.price = Double(choosenItem.price)!
payment.currency = "USD"
payment.image = choosenItem.image
payment.userID = "test_user"
payment.itemID = choosenItem.name+"id"
payment.signVersion = 3
let customSetting = ["widget":"pw",
"ag_type":"fixed"]
payment.pwLocalParams = customSetting
PWCoreSDK.sharedInstance().setPaymentObject(payment)
Note: pwLocalParams can be Dictionary or any of the defined class:
CartDefaultWidget
,DigitalGoodsDefaultWidget
,DigitalGoodsFlexibleWidget
,VirtualCurrency
, refer their headers for required property or PWLocal docs. Key and value like prices, amount, currencyCode, currencies, ag_name, ag_external_id, uid will be ignored and use the one you described inPaymentObject
- Present Payment options view controller:
PWCoreSDK.showPaymentOptionsViewController(withParentViewcontroller: self, delegate: self, showCompletion: nil)
- Default UI of the SDK is flat style, to use game UI, add this to your code:
PWCoreSDK.sharedInstance().setUseGameUI(true)
- If you wish to customize the flat UI to suit your app, you can get the PWCustomizationPlugin and set it while setup the SDK.
- By default (except Brick), all payments method will show success once the payment is finish, if you don't want to use the SDK's success dialog but return delegate for you to work with, add this to your code:
PWCoreSDK.sharedInstance().setUseNativeFinishDialogForAllMethods(false)
- To show bank processor adress for Brick, use
PWCoreSDK.sharedInstance().setShowBrickFooter(true)
- To use custom icon for local payments, use
PWCoreSDK.sharedInstance().setCustomLocalPaymentImage(image)
- After the token is successfully fetched, the
response: PWCoreSDKResponse
will contain thetoken: BrickToken
along with it - Send request to your server to handle the token:
-
If
useNativeFinishDialog
is set tofalse
, the SDK will dismiss after token is successfully fetched, theresponse.responseCode
will also be.MERCHANT_PROCESSING
, you will have to handle success/failed/3D secure yourself and store card feature wont be available -
If
useNativeFinishDialog
is set totrue
, the loading popup will keep showing, after you process the token in your sever, post aNotification
to use the SDK success or failed dialog, also the SDK will call delegate again to return.SUCCESS
or.FAILED
:
if response.paymentType == .BRICK {
if let returnedToken = response.token {
//Process the token with your server here asynchronous
//When done:
NotificationCenter.default.post(name: Notification.Name(BRICK_TOKEN_PROCESSED_FINISH), object: nil, userInfo: nil)
}
}
-
Pass the error in Dictionary as
["error": errorMessage]
viauserInfo
, the SDK will automatically show failed dialog instead of successful dialog -
If 3D secure happen, we also support 3D secure, pass the URL in Dictionary as
["secure": urlString]
viauserInfo
, the SDK will handle showing the 3D secure and passSUCCESS/FAILED
back to app after user finish enter secure info -
If you want to enable store card feature for user, pass the Charge object to our SDK via
userInfo
, Charge object format can be found in our Brick docs
If you wish to provide your PWLocal signature manually:
//Define all params in step 8., and extra custom settings, then get `stringToSign`:
let payment = PaymentObject()
payment.name = choosenItem.name
payment.price = Double(choosenItem.price)!
payment.currency = "USD"
payment.image = choosenItem.image
payment.userID = "test_user"
payment.itemID = choosenItem.name+"id"
payment.signVersion = 3
let customSetting = ["widget":"pw",
"ag_type":"fixed"]
let strToSign = PWCoreSDK.sharedInstance().getStringToSign(customSetting, paymentObject: payment)
//Calculate your sign and set it
customSetting["sign"] = sha256(text: "\(strToSign!)YOUR SECRET KEY")
payment.pwLocalParams = customSetting
Paymentwall SDK supports external payment system injection (which are in our defined payment system (PS) list). Each time you want to add a new payment system, you have to include it's native SDK into your project along with our plugin framework, our framework will handle creating all the necessary parameters then you can use them to show the native local payment SDK:
- Add the plugin with Cocoapods with
pod 'PW[Local payment method]Plugin'
or manually dragging thePW[Local payment method]Plugin.a
and it's headers file to your project - Import the library header into your project or via
bridging-headers.h
if you use Swift - Setup the plugin, each plugin have different requirements, details can be found in their headers or detailed docs below.
Note: All plugins support your own signature string if you don't specify Secret key in both CoreSDK and PluginSDK, use
plugin.getStringToSign()
to get the string to sign, then add your signed string toplugin.signString