CloudPayments SDK позволяет интегрировать прием платежей в мобильные приложение.
Для работы CloudPayments SDK необходим Android версии 7.0 или выше, и следующие зависимости (API level 24)
минимальные версии окружения: compileSdkVersion 33, build:gradle 7.3.1, ndkVersion 21.4.7075529
yarn add react-native-cloudpayments-sdk
или
npm install react-native-cloudpayments-sdk
android/app/build.gradle
, для Yandex Pay (если Yandex Pay не используется, добавльте пустое значение)android {
...
defaultConfig {
...
manifestPlaceholders = [
YANDEX_CLIENT_ID: ""
]
...
}
...
}
<application>
файла AndroidManifest.xml.<meta-data
android:name="com.google.android.gms.wallet.api.enabled"
android:value="true" />
<application>
файла AndroidManifest.xml.<activity
android:name="com.reactnativecloudpayments.ThreeDSecureActivity"
/>
В файле /android/build.gradle
в разделе allprojects -> repositories
добавьте jcenter()
Убедитесь, что дебажная версия приложения подписана релизным ключом, чтобы тестировать Google Pay в режиме Production.
ios/Podfile
pod 'Cloudpayments', :git => "https://github.com/cloudpayments/CloudPayments-SDK-iOS", :tag => '1.1.9'
pod 'CloudpaymentsNetworking', :git => "https://github.com/cloudpayments/CloudPayments-SDK-iOS", :tag => '1.1.9'
Выполните pod install
в папке ios
Yandex Pay для ios пока не доступен
Для использования технологии Apple Pay вам необходимо зарегистрировать Merchant ID, сформировать платежный сертификат, сертификат для веб-платежей и подтвердить владение доменами сайтов, на которых будет производиться оплата.
import { Card } from 'react-native-cloudpayments-sdk';
const isCardNumber = await Card.isCardNumberValid(cardNumber);
const isExpDate = await Card.isExpDateValid(expDate); // expDate в формате MM/yy
const cardType = await Card.cardType(cardNumber);
const { bankName, logoUrl } = await Card.getBinInfo(cardNumber, merchantId);
const cryptogramPacket = await Card.makeCardCryptogramPacket({
cardNumber,
expDate,
cvv,
merchantId,
});
const cryptogramPacket = await Card.makeCardCryptogramPacket({
cvv,
});
const { TransactionId, PaRes } = await Card.requestThreeDSecure({
transactionId,
paReq,
acsUrl,
});
Смотрите документацию по API: Платёж - обработка 3-D Secure
import { CreditCardForm } from 'react-native-cloudpayments-sdk';
const PAYMENT_DATA_CARD = {
publicId: 'publicId',
accountId: '1202',
applePayMerchantId: 'merchant',
googlePayMerchantId: 'merchant',
ipAddress: '8.8.8.8',
cardHolderName: 'Votinov Anton',
yandexPayMerchantID: 'yandexPayMerchantID',
};
const PAYMENT_JSON_DATA_CARD = {
age: '24',
name: 'Anton',
phone: '+7912343569',
};
const creditCardForm = CreditCardForm.initialPaymentData(
PAYMENT_DATA_CARD,
PAYMENT_JSON_DATA_CARD
);
creditCardForm.setDetailsOfPayment({
currency: Currency.ruble,
totalAmount: '1000',
invoiceId: '123',
description: 'Test',
});
const result = await creditCardForm.showCreditCardForm({
useDualMessagePayment: true, // Использовать двухстадийную схему проведения платежа
disableApplePay: false, // Включить Apple Pay, по умолчанию выключен
disableGPay: false, // Включить Google Pay, по умолчанию выключен
disableYandexPay: false, // Включить Yandex Pay, по умолчанию выключен
});
import { CloudPaymentsApi } from 'react-native-cloudpayments-sdk';
const PAYMENT_DATA_CARD = {
publicId: 'publicId',
accountId: '1202',
ipAddress: '8.8.8.8',
cardHolderName: 'Votinov Anton',
};
const PAYMENT_JSON_DATA_CARD = {
age: '24',
name: 'Anton',
phone: '+7912343569',
};
const cloudPaymentsApi = CloudPaymentsApi.initialApi(
PAYMENT_DATA_CARD,
PAYMENT_JSON_DATA_CARD
);
cloudPaymentsApi.setDetailsOfPayment({
currency: Currency.ruble,
totalAmount: '1000',
invoiceId: '123',
description: 'Test',
});
const cryptogramPacket = await Card.makeCardCryptogramPacket({
cardNumber,
expDate,
cvv,
merchantId,
});
const results = await cloudPaymentsApi.auth(cryptogramPacket, email);
const results = await cloudPaymentsApi.charge(cryptogramPacket, email);
import {
PAYMENT_NETWORK,
PaymentService,
} from 'react-native-cloudpayments-sdk';
const PAYMENT_DATA = Platform.select({
ios: () => {
return {
merchantId: 'applePayMerchantID',
supportedNetworks: [
PAYMENT_NETWORK.masterCard,
PAYMENT_NETWORK.visa,
PAYMENT_NETWORK.amex,
PAYMENT_NETWORK.interac,
PAYMENT_NETWORK.discover,
PAYMENT_NETWORK.mir,
PAYMENT_NETWORK.jcb,
],
countryCode: 'RU',
currencyCode: 'RUB',
};
},
android: () => {
return {
merchantId: 'googlePayMerchantID',
merchantName: 'Example',
gateway: {
service: 'cloudpayments',
merchantId: 'cloudpaymentsPublicID',
},
supportedNetworks: [
PAYMENT_NETWORK.masterCard,
PAYMENT_NETWORK.visa,
PAYMENT_NETWORK.amex,
PAYMENT_NETWORK.interac,
PAYMENT_NETWORK.discover,
PAYMENT_NETWORK.jcb,
],
countryCode: 'RU',
currencyCode: 'RUB',
environmentRunning: 'Test',
};
},
})!();
const paymentService = PaymentService.initial(PAYMENT_DATA);
cloudpaymentsPublicID
: Ваш Public ID, его можно посмотреть в личном кабинете.
const isSupportPayments = await paymentService.canMakePayments();
const PRODUCTS = [
{ name: 'example_1', price: '1' },
{ name: 'example_2', price: '10' },
{ name: 'example_3', price: '15' },
];
paymentService.setProducts(PRODUCTS);
useEffect(() => {
paymentService.listenerCryptogramCard((cryptogram) => {
console.warn(cryptogram);
});
return () => {
paymentService.removeListenerCryptogramCard();
};
}, []);
paymentService.openServicePay();
Вотинов Антон
По возникающим вопросам техничечкого характера и предложениями обращайтесь на antonvotinov@gmail.com
Первая версия библиотеки писалась для проекта EnerGO, разработанным компанией Purrweb
MIT