receiver1/omnipay-pzmpay

PZMPay gateway for Omnipay

v1.0.0 2024-10-03 20:58 UTC

This package is auto-updated.

Last update: 2025-01-04 15:24:48 UTC


README

PZMPay online acquiring support for Omnipay

Total Downloads Latest Version Software License

Already Implemented

  • Payment creation
  • Payment information
  • Incoming notifications

To Be Implemented

  • Payment cancellation
  • Project balance
  • Fiscalization under Federal Law 54
  • Testing mode
  • Error codes

Installation

composer require league/omnipay receiver1/omnipay-pzmpay

Usage

Gateway Initialization

// Create a new payment gateway
$gateway = Omnipay::create('PZMPay');

// Set the secret code
$gateway->setSecretCode('secretCode');

Payment Creation

// Create a new payment for 10 rubles 00 kopecks
$purchaseResponse = $gateway->purchase([
  'amount' => 10,
  'currency' => 'RUB',
  'description' => 'Balance top-up 1337 Cheats',
])->send();

if (!$purchaseResponse->isSuccessful()) {
  throw new Exception($response->getMessage());
}

// Get the payment identifier in PZMPay
$invoiceId = $purchaseResponse->getTransactionId();
// Get the link to the PZMPay payment form
$redirectUrl = $purchaseResponse->getRedirectUrl();

Payment Verification

$notification = $gateway->acceptNotification($data);
if ($notification->getTransactionStatus() === NotificationInterface::STATUS_COMPLETED) {
  /** @var TransactionModel $incomingTransaction */
  $incomingTransaction = $notification->getTransactionReference();

  $transactionResponse = $gateway->fetchTransaction([
    'transactionId' => $incomingTransaction->getId(),
  ])->send();

  /** @var TransactionModel $trustedTransaction */
  $trustedTransaction = $transactionResponse->getTransactionReference();

  print ($trustedTransaction->getAmount());
}