CloudPayments SDK позволяет интегрировать прием платежей в мобильные приложение для платформы iOS.
- В приложении необходимо получить данные карты: номер, срок действия, имя держателя и CVV;
- Создать криптограмму карточных данных при помощи SDK;
- Отправить криптограмму и все данные для платежа с мобильного устройства на ваш сервер;
- С сервера выполнить оплату через платежное API CloudPayments.
Для работы CloudPayments SDK необходим iOS версии 8.0 и выше.
Для подключения SDK мы рекомендуем использовать Cocoa Pods. Добавьте в файл Podfile зависимость:
pod 'SDK-iOS', :git => "https://github.com/cloudpayments/SDK-iOS", :branch => "master"
Если ваш проект написан на языке Swift, тогда для использования классов из Objective-C создайте файл моста {PROJECT_NAME}-Bridging-Header.h и импортируйте в нем классы которые вы планируете использовать:
#import <SDK-iOS/sdk/sdk/Card/Card.h> // Создание критограммы
#import <SDK-iOS/sdk/sdk/Card/Api/CPCardApi.h> // Получение информации о банке по номеру карты
#import <SDK-iOS/sdk/sdk/3DS/D3DS.h> // Обработка 3DS формы
#import <SDK-iOS/sdk/sdk/Utils/PKPaymentConverter.h> // Работа c Apple Pay
Чтобы использовать относительные пути к файлам в настройках проекта в переменную Header-Search Path добавьте следующее значение: "$(SOURCE_ROOT)/Pods"
- api - Пример файлов для проведения платежа через ваш сервер
- demo - Пример реализации приложения с использованием SDK
- sdk - Исходный код SDK
Для начала приема платежей через мобильные приложения вам понадобятся:
- Public ID;
- Пароль для API (Важно: Не храните пароль для API в приложении, выполняйте запросы через сервер согласно Схемы работы мобильного приложения).
Эти данные можно получить в личном кабинете: https://merchant.cloudpayments.ru/ после подключения к CloudPayments.
- Проверка карточного номера на корректность
Card.isCardNumberValid(cardNumber)
- Проверка срока действия карты
Card.isExpDateValid(expDate) // expDate в формате MM/yy
- Определение типа платежной системы
Card.cardType(toString: Card.cardType(fromCardNumber: textField.text))
- Определение банка эмитента
let api : CPCardApi = CPCardApi.init()
api.delegate = self
api.getBinInfo(cardNumber)
// Результат можно получить в методах делигата CPCardApiDelegate
func didFinish(_ info: BinInfo!) {
if let bankName = info.bankName {
print("BankName: \(bankName)")
} else {
print("BankName is empty")
}
if let logoUrl = info.logoUrl {
print("LogoUrl: \(logoUrl)")
} else {
print("LogoUrl is empty")
}
}
func didFailWithError(_ message: String!) {
if let error = message {
print("error: \(error)")
} else {
print("Error")
}
}
- Шифрование карточных данных и создание криптограммы для отправки на сервер
let card = Card()
let cardCryptogramPacket = card.makeCryptogramPacket(cardNumber, andExpDate: expDate, andCVV: cvv, andMerchantPublicID: Constants.merchantPulicId)
- Отображение 3DS формы и получении результата 3DS аутентификации
var d3ds: D3DS = D3DS.init()
d3ds.make3DSPayment(with: self, andAcsURLString: acsUrl, andPaReqString: paReq, andTransactionIdString: transactionId)
Переменную var d3ds: D3DS лучше объявить как член класса, который будет реализовывать делегата D3DSDelegate, в противном случае методы делегата могуть быть не вызванны, так как к моменту их вызова ссылка на экземпляр D3DS может быть автоматически удалена.
// Обязательно проверяйте входящие данные карты (номер, срок действия и cvc код) на корректность, иначе при попытке создания объекта CPCard будет вызвано исключение.
let card = Card()
let cardCryptogramPacket = card.makeCryptogramPacket(cardNumber, andExpDate: expDate, andCVV: cvv, andMerchantPublicID: Constants.merchantPulicId)
Платёж - оплата по криптограмме.
Для привязки карты (платёж "в один клик") используйте метод оплату по токену.
Токен можно получить при совершении оплаты по криптограмме, либо при получении уведомлений.
var d3ds: D3DS = D3DS.init()
d3ds.make3DSPayment(with: self, andAcsURLString: acsUrl, andPaReqString: paReq, andTransactionIdString: transactionId)
Для получения результатов прохождения 3DS аутентификации реализуйте делигат D3DSDelegate в ViewController из которого происходит создание и отображение 3DS формы.
class CheckoutViewController: UIViewController, D3DSDelegate {
...
func authorizationCompleted(withMD md: String!, andPares paRes: String!) {
post3ds(transactionId: md, paRes: paRes)
}
func authorizationFailed(withHtml html: String!) {
self.showAlert(title: .errorWord, message: html)
print("error: \(html)")
}
Смотрите документацию по API: Платёж - обработка 3-D Secure.
1) Создайте массив объектов PKPaymentSummaryItem используя информацию о товарах выбранных вашим клиентом
var paymentItems: [PKPaymentSummaryItem] = []
for product in CartManager.shared.products {
let paymentItem = PKPaymentSummaryItem.init(label: product.name, amount: NSDecimalNumber(value: Int(product.price)!))
paymentItems.append(paymentItem)
}
let applePayMerchantID = "merchant.com.YOURDOMAIN" // Ваш ID для Apple Pay
let paymentNetworks = [PKPaymentNetwork.visa, PKPaymentNetwork.masterCard] // Платежные системы для Apple Pay
buttonApplePay.isHidden = !PKPaymentAuthorizationViewController.canMakePayments(usingNetworks: paymentNetworks) // Скройте кнопку Apple Pay если пользователю недоступны указанные вами платежные системы
let request = PKPaymentRequest()
request.merchantIdentifier = applePayMerchantID
request.supportedNetworks = paymentNetworks
request.merchantCapabilities = PKMerchantCapability.capability3DS // Возможно использование 3DS
request.countryCode = "RU" // Код страны
request.currencyCode = "RUB" // Код валюты
request.paymentSummaryItems = paymentItems
let applePayController = PKPaymentAuthorizationViewController(paymentRequest: request)
applePayController?.delegate = self
self.present(applePayController!, animated: true, completion: nil)
extension CheckoutViewController: PKPaymentAuthorizationViewControllerDelegate {
func paymentAuthorizationViewController(_ controller: PKPaymentAuthorizationViewController, didAuthorizePayment payment: PKPayment, completion: @escaping ((PKPaymentAuthorizationStatus) -> Void)) {
completion(PKPaymentAuthorizationStatus.success)
// Конвертируйте объект PKPayment в строку криптограммы
guard let cryptogram = PKPaymentConverter.convert(toString: payment) else {
return
}
// Используйте методы API для выполнения оплаты по криптограмме
// (charge (для одностадийного платежа) или auth (для двухстадийного))
//charge(cardCryptogramPacket: cryptogram, cardHolderName: "")
auth(cardCryptogramPacket: cryptogram, cardHolderName: "")
}
func paymentAuthorizationViewControllerDidFinish(_ controller: PKPaymentAuthorizationViewController) {
controller.dismiss(animated: true, completion: nil)
}
}
При обработке успешного ответа от Apple Pay, обязательно выполните переобразование объекта PKPayment в криптограмму для передачи в платежное API CloudPayments
let cryptogram = PKPaymentConverter.convert(toString: payment)
После успешного преобразования криптограмму можно использовать для проведения оплаты.
По возникающим вопросам техничечкого характера обращайтесь на support@cloudpayments.ru