dipnot/paytr-php

Unofficial PayTR API Wrapper for PHP

1.5.0 2023-06-13 11:16 UTC

This package is auto-updated.

Last update: 2024-12-13 14:24:20 UTC


README

Latest Stable Version Total Downloads

This is an unofficial PHP wrapper for the PayTR API

Requirements

  • PHP 5.6.36 or higher
  • ext-curl
  • ext-json

Installation

To install, run the following command using Composer.

composer require dipnot/paytr-php

Examples

Full usage examples can be found in the examples folder.

Config

Before making any requests, a Config object must be created and set with real merchant information.

use Dipnot\PayTR\Config;

$config = new Config();
$config->setMerchantId("TODO");
$config->setMerchantKey("TODO");
$config->setMerchantSalt("TODO");

Creating a payment form

use Dipnot\PayTR\Model\Buyer;
use Dipnot\PayTR\Model\Currency;
use Dipnot\PayTR\Model\Language;
use Dipnot\PayTR\Model\Product;
use Dipnot\PayTR\Request\CreatePaymentFormRequest;

$buyer = new Buyer();
$buyer->setEmailAddress("email@address.com");
$buyer->setFullName("Full Name");
$buyer->setAddress("The World");
$buyer->setPhoneNumber("0000000000");
$buyer->setIpAddress("0.0.0.0");

$product1 = new Product();
$product1->setTitle("Computer");
$product1->setPrice(4000);
$product1->setQuantity(1);

$product2 = new Product();
$product2->setTitle("Phone");
$product2->setPrice(5000);
$product2->setQuantity(2);

$orderId = "UNIQUEORDERCODE" . time();

$createPaymentFormRequest = new CreatePaymentFormRequest($config);
$createPaymentFormRequest->setBuyer($buyer);
$createPaymentFormRequest->setCurrency(Currency::TL);
$createPaymentFormRequest->setLanguage(Language::TR);
$createPaymentFormRequest->setAmount(9000);
$createPaymentFormRequest->setOrderId($orderId);
$createPaymentFormRequest->setSuccessUrl("http://localhost/paytr-php/examples/order.php?orderId={$orderId}&status=success");
$createPaymentFormRequest->setFailedUrl("http://localhost/paytr-php/examples/order.php?orderId={$orderId}&status=failed");
$createPaymentFormRequest->addProduct($product1);
$createPaymentFormRequest->addProduct($product2);
// $createPaymentFormRequest->addProducts([$product1, $product2]); // You can add multiple products at once
$createPaymentFormRequest->setTimeout(30);
$createPaymentFormRequest->setNoInstallment(true);
$createPaymentFormRequest->setMaxInstallment(0);

try {
  $paymentForm = $createPaymentFormRequest->execute();
  $paymentForm->printPaymentForm();
} catch(Exception $e) {
  echo $e->getMessage();
}

Getting a payment (Webhook)

use Dipnot\PayTR\Response\GetPayment;

$getPayment = new GetPayment($config);
$getPayment->setData($_POST);

try {
  $payment = $getPayment->execute();
  exit("OK");
} catch(Exception $exception) {
  exit($exception->getMessage());
}

License

License: MIT