rusproj/uniteller-php-sdk

PHP库,用于与Uniteller支付处理系统集成。

0.3.9 2020-06-23 10:46 UTC

This package is auto-updated.

Last update: 2024-09-23 20:35:18 UTC


README





Uniteller互联网支付集成的PHP(5.6+)SDK(非官方)。此文档提供俄语版本。此外,此SDK与Payum库集成,您可以使用网关

功能

  • 支付(方法 pay
  • 定期支付(方法 recurrent
  • 取消支付(方法 unblock
  • 接收结果
  • 回调(验证传入签名的方法)
  • 任何请求的一般错误处理器
  • 一般状态(请求/响应中可能遇到 canceledcancelled 变体。它们将被转换为一般状态如 cancelled。)

待办事项

  • 将注释和系统(错误)消息翻译成英语
  • 验证
  • 实现方法 card
  • 实现方法 confirm

安装

要安装包,请执行以下命令

composer require tmconsulting/uniteller-php-sdk

用法

您可以在当前SDK的examples文件夹中找到一些使用示例。只需按照README.md文件中的说明操作。

配置凭证

<?php
$uniteller = new \Tmconsulting\Uniteller\Client();
$uniteller->setShopId('you_shop_id');
$uniteller->setLogin('you_login_number');
$uniteller->setPassword('you_password');
$uniteller->setBaseUri('https://wpay.uniteller.ru');

重定向到支付页面

因此,要重定向到页面,您只需运行具有以下参数的payment方法

<?php
use Tmconsulting\Uniteller\Payment\PaymentBuilder;

$builder = new PaymentBuilder();
$builder
    ->setOrderIdp(mt_rand(10000, 99999))
    ->setSubtotalP(10)
    ->setCustomerIdp(mt_rand(10000, 99999))
    ->setUrlReturnOk('http://google.ru/?q=success')
    ->setUrlReturnNo('http://google.ru/?q=failure');

$uniteller->payment($builder)->go();
// if you don't need redirect
// $uniteller->payment($builder)->getUri();

或使用纯数组

<?php
$uniteller->payment([
    'Order_IDP' => mt_rand(10000, 99999),
    // ... other parameters
])->go();

定期支付

<?php
use Tmconsulting\Uniteller\Recurrent\RecurrentBuilder;

$builder = (new RecurrentBuilder())
    ->setOrderIdp(mt_rand(10000, 99999))
    ->setSubtotalP(15)
    ->setParentOrderIdp(00000) // order id of any past payment
    ->setParentShopIdp($uniteller->getShopId()); // optional

$results = $uniteller->recurrent($builder);

或使用纯数组

<?php
$results = $uniteller->recurrent([
    'Order_IDP' => mt_rand(10000, 99999),
    // ... other parameters
]);

取消支付

<?php
use Tmconsulting\Uniteller\Cancel\CancelBuilder;

$builder = (new CancelBuilder())->setBillNumber('RRN Number, (12 digits)');
$results = $uniteller->cancel($builder);

<?php
use Tmconsulting\Uniteller\Order\Status;

$results = $uniteller->cancel([
    'Billnumber' => 'RRN Number, (12 digits)',
    // ...
]);

foreach ($results as $payment) {
    // see Tmconsulting\Uniteller\Order\Order for other methods.
    if ($payment->getStatus() === Status::CANCELLED) {
        // payment was cancelled
    }    
} 

接收结果

<?php

$results = $uniteller->results([
    'ShopOrderNumber' => 'Order_IDP number'
]);

var_dump($results);

// $results[0]->getCardNumber();

回调(网关通知)

接收来自网关的传入参数并验证签名。

<?php
if (! $uniteller->verifyCallbackRequest(['all_parameters_from_post_with_signature'])) {
    return 'invalid_signature';
}

测试

vendor/bin/phpunit

许可证

MIT。