Ошибка захвата при интеграции смарт-кнопок подписки с SDK - как в песочнице, так и в режиме реального времени - PullRequest
1 голос
/ 24 января 2020

Случай: ошибка при настройке подписки с помощью кнопок Smart Payment

Примечание: в среде Live мне удалось списать средства со счета в моей учетной записи для транзакции

Ошибка: ошибка захвата и за 3 дня тестирования в случаях Sandbox и Live не найдено ни одного решения

Для режима Sandbox я нашел несколько ссылок на точно такую ​​же ошибку, но для этих людей это a. кажется, исчезли за ночь и 2. это были не модели подписки, а обычные режимы покупки. Ниже приведены сценарии, и это не должно быть так сложно, как я делаю, мы создали похожую среду биллинга пару лет за go, и это сработало почти сразу, хотя это не была подписка.

Дополнительная информация: - Я установил правильные настройки env также в файлах composer. - Товар есть - План есть - Мы используем цены на основе мест (0,01 цента, а затем умножаем общую сумму в долларах * 100)

////////////////////////////////////
// Error 500
////////////////////////////////////

// Через консоль POST https://www.paypal.com/smart/api/order/9VU587...34202/capture 500

// по сети

{ack: «ошибка», сообщение: «ошибка необработанного API», мета: {cal c: «4ac27dc9b8a70»,…},… }

////////////////////////////////////
// Smart Button Script
////////////////////////////////////

<script src="https://www.paypal.com/sdk/js?vault=true&client-id=<?= $paypal_sandbox_id ?>&currency=<?php echo $currency ?? "USD"; ?>&debug=false"></script>

<script>
paypal.Buttons({

    // Set up the subscription        
    createSubscription: function (data, actions) {
        return actions.subscription.create({
            'plan_id': 'P-6NH76920JR31236564LYU3X4Y',
            'quantity': total_billed_vat * 100
        });
    },

    // Finalize the transaction
    onApprove: function (data, actions) {
        console.log('onApprove', data);

        // Authorize the transaction   
        return actions.order.capture().then(function (details) {
            console.log('capture', details);
            // Show a success message to the buyer 
            alert('Transaction completed by ' + details.payer.name.given_name + '!');

            // Call your server to save the transaction
            return fetch('../api/paypal/paypal-transaction-complete.php', {
                method: 'post',
                headers: {
                    'content-type': 'application/json'
                },
                body: JSON.stringify({
                    orderID: data.orderID
                })
            });

        }).then(function (response) {
            // Show a success message to the buyer                            
            alert('actions.order.capture done ' + details.payer.name.given_name + '!');
        });
    },
    onCancel: function (data, actions) {
        // Show a cancel page or return to cart
        alert('Feel free to retry when you are ready');
    }

}).render('#paypal-button-container');

</script>

Серверный скрипт PHP:

////////////////////////////////////
// ../api/paypal/paypal-transaction-complete.php 
////////////////////////////////////

<?php
namespace Sample;

require __DIR__ . '/vendor/autoload.php';

//1. Import the PayPal SDK client that was created in `Set up Server-Side SDK`.
use Sample\PayPalClient;
use PayPalCheckoutSdk\Orders\OrdersGetRequest;

class GetOrder
{

  // 2. Set up your server to receive a call from the client
  /**
   *You can use this function to retrieve an order by passing order ID as an argument.
   */
  public static function getOrder($orderId)
  {

    // 3. Call PayPal to get the transaction details
    $client = PayPalClient::client();
    $response = $client->execute(new OrdersGetRequest($orderId));
    /**
     *Enable the following line to print complete response as JSON.
     */
    //print json_encode($response->result);
    print "Status Code: {$response->statusCode}\n";
    print "Status: {$response->result->status}\n";
    print "Order ID: {$response->result->id}\n";
    print "Intent: {$response->result->intent}\n";
    print "Links:\n";
    foreach($response->result->links as $link)
    {
      print "\t{$link->rel}: {$link->href}\tCall Type: {$link->method}\n";
    }
    // 4. Save the transaction in your database. Implement logic to save transaction to your database for future reference.
    print "Gross Amount: {$response->result->purchase_units[0]->amount->currency_code} {$response->result->purchase_units[0]->amount->value}\n";

    // To print the whole response body, uncomment the following line
    // echo json_encode($response->result, JSON_PRETTY_PRINT);
  }
}

/**
 *This driver function invokes the getOrder function to retrieve
 *sample order details.
 *
 *To get the correct order ID, this sample uses createOrder to create a new order
 *and then uses the newly-created order ID with GetOrder.
 */

if (!count(debug_backtrace()))
{
  GetOrder::getOrder($data->orderID, true);
}

SDK Используется для v2 интеграции PayPal.

////////////////////////////////////
// SDK Installed in ../api/paypal/
////////////////////////////////////

{
    "require": {
        "paypal/paypal-checkout-sdk": "^1.0"
    }
}

Используется ручной источник: https://developer.paypal.com/docs/subscriptions/integrate/ Один из найденных ресурсов: https://www.paypal-community.com/t5/REST-APIs/BASIC-Smart-Payment-buttons-integration-help/td-p/1844051

1 Ответ

0 голосов
/ 26 января 2020

Это тип ответа API «500 Internal Service Error», который лучше всего использовать для поддержки PayPal (MTS), а не для переполнения стека, поскольку он фактически генерируется на стороне сервера PayPal без подробностей и нужно проследить. Однако у меня действительно есть некоторые знания, и в этом случае я подозреваю, что сумма транзакции не соответствует сумме единицы покупки. Может быть, это то, что вы можете исправить с помощью более простого запроса, то есть протестировать с помощью простого числа c, например, $ 10 от начала до конца sh, и посмотрите, не возникает ли проблема.

...