Я получаю вывод на firebase: «Невозможно определить способ оплаты»
Примечание: я не слишком разбираюсь в функциях JavaScript и Firebase и не могу заставить его работать.
Я следовал инструкциям Брэйнтри по настройке способа оплаты. Это поток событий:
Шаг 1 Ваш клиент запрашивает токен клиента с вашего сервера и инициализирует клиентский SDK.
Шаг 2 Сервер генерирует и отправляет клиентавозвратите токен своему клиенту, используя серверный SDK.
Шаг 3 Клиент отправляет информацию о платеже, клиентский SDK сообщает эту информацию Braintree и возвращает одноразовый способ оплаты.
Шаг 4end отправляет nonce метода оплаты на ваш сервер.
Шаг 5 Код вашего сервера получает nonce метода оплаты и затем использует SDK сервера для создания транзакции.
Пока что я 'я застрял на шаге 5. Одноразовый номер публикуется в моей базе данных Firebase в следующем формате:
-nonce
-LsHNQLklFEX48oiSt1H:"tokencc_bc_vbmypn_dvn4gy_xy47fw_th6vv9_bq6"
-LsHn2hilKlmVeT1g1Ow: tokencc_bf_8qrjsk_j7bg44_p8kk88_qz7vn2_vk6"
Как мне перейти к шагу 5?
Код функций:
'use strict';
const functions = require('firebase-functions');
const express = require('express');
const app = express();
const braintree = require('braintree');
const admin = require('firebase-admin');
admin.initializeApp();
var clientToken;
var nonceFromTheClient;
var transaction;
var gateway = braintree.connect({
environment: braintree.Environment.Sandbox,
merchantId:"",
publicKey: "",
privateKey: ""
});
exports.createToken = functions.https.onRequest((request, response) => {
gateway.clientToken.generate({}, function (err, response) {
if (err){
console.log('inside error',err);
} else {
clientToken = response.clientToken;
}
});
response.send(clientToken);
});
exports.createTransaction = functions.https.onRequest((req, res) => {
app.post("/nonce", function (req, res) {
nonceFromTheClient = req.body.payment_method_nonce;
console.log("nonce" + nonceFromTheClient)
});
gateway.transaction.sale({amount: '10.00', paymentMethodNonce: nonceFromTheClient, options: {submitForSettlement: true}}, function (err, result) {
if (err) {
console.error(err);
return;
}
if (result.success) {
console.log('Transaction status: ' + result.transaction.status);
} else {
console.error(result.message);
}
});
res.send(transaction);
});
Код деятельности:
if (cardPayment.isChecked) {
val client = AsyncHttpClient()
client.get(
"https://.../createToken",
object : TextHttpResponseHandler() {
override fun onFailure(
statusCode: Int,
headers: Array<out Header>?,
responseString: String?,
throwable: Throwable?
) {
}
override fun onSuccess(
statusCode: Int,
headers: Array<Header>,
clientToken: String
) {
mClientToken = clientToken
onBraintreeSubmit(it)
}
})
}
override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?) {
if (requestCode == REQUEST_CODE && data != null) {
if (resultCode == Activity.RESULT_OK) {
val result =
data.getParcelableExtra<DropInResult>(DropInResult.EXTRA_DROP_IN_RESULT)
val nonce = result.paymentMethodNonce?.nonce
if (nonce != null) {
FirebaseShoppingCartDatabase.postNonceToDatabase(nonce)
val client = AsyncHttpClient()
client.get(
"https://..../createTransaction",
object : TextHttpResponseHandler() {
override fun onFailure(
statusCode: Int,
headers: Array<out Header>?,
responseString: String?,
throwable: Throwable?
) {
}
override fun onSuccess(
statusCode: Int,
headers: Array<Header>,
clientToken: String
) {
}
})
}
} else if (resultCode == RESULT_CANCELED) {
} else {
// handle errors here, an exception may be available in
val error = data.getSerializableExtra(DropInActivity.EXTRA_ERROR) as Exception
System.out.println("eroare " + error)
}
}
}
fun onBraintreeSubmit(v: View) {
val dropInRequest = DropInRequest()
.clientToken(mClientToken)
dropInRequest
.disablePayPal()
startActivityForResult(dropInRequest.getIntent(context), REQUEST_CODE)
}
}