alexminza / maib-checkout-sdk
PHP SDK for maib e-Commerce Checkout API
Installs: 2
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 0
Forks: 0
Open Issues: 0
pkg:composer/alexminza/maib-checkout-sdk
Requires
- php: >=7.2.5
- guzzlehttp/guzzle: ^7.0
- guzzlehttp/guzzle-services: ^1.0
Requires (Dev)
Suggests
- monolog/monolog: To enable logging of HTTP requests and responses.
This package is not auto-updated.
Last update: 2026-01-01 08:39:22 UTC
README
- maib e-Commerce Checkout API docs: https://docs.maibmerchants.md/checkout
- GitHub project https://github.com/alexminza/maib-checkout-sdk-php
- Composer package https://packagist.org/packages/alexminza/maib-checkout-sdk
Installation
To easily install or upgrade to the latest release, use composer:
composer require alexminza/maib-checkout-sdk
To enable logging add the monolog package:
composer require monolog/monolog
Getting started
Import SDK:
require_once __DIR__ . '/vendor/autoload.php'; use Maib\MaibCheckout\MaibCheckoutClient;
Add project configuration:
$DEBUG = getenv('DEBUG'); $MAIB_CHECKOUT_BASE_URI = getenv('MAIB_CHECKOUT_BASE_URI'); $MAIB_CHECKOUT_CLIENT_ID = getenv('MAIB_CHECKOUT_CLIENT_ID'); $MAIB_CHECKOUT_CLIENT_SECRET = getenv('MAIB_CHECKOUT_CLIENT_SECRET'); $MAIB_CHECKOUT_SIGNATURE_KEY = getenv('MAIB_CHECKOUT_SIGNATURE_KEY');
Initialize client:
$options = [ 'base_uri' => $MAIB_CHECKOUT_BASE_URI, 'timeout' => 15 ]; if ($DEBUG) { $logName = 'maib_checkout_guzzle'; $logFileName = "$logName.log"; $log = new \Monolog\Logger($logName); $log->pushHandler(new \Monolog\Handler\StreamHandler($logFileName, \Monolog\Logger::DEBUG)); $stack = \GuzzleHttp\HandlerStack::create(); $stack->push(\GuzzleHttp\Middleware::log($log, new \GuzzleHttp\MessageFormatter(\GuzzleHttp\MessageFormatter::DEBUG))); $options['handler'] = $stack; } $guzzleClient = new \GuzzleHttp\Client($options); $maibCheckoutClient = new MaibCheckoutClient($guzzleClient);
SDK usage examples
Get Access Token with Client ID and Client Secret
$tokenResponse = $maibCheckoutClient->getToken($MAIB_CHECKOUT_CLIENT_ID, $MAIB_CHECKOUT_CLIENT_SECRET); $accessToken = $tokenResponse['result']['accessToken'];
Register a new hosted checkout session
$checkoutData = [ 'amount' => 50.61, 'currency' => 'MDL', 'orderInfo' => [ 'id' => 'EK123123BV', 'description' => 'Order description', 'date' => '2025-11-03T09:28:40.814748+00:00', 'orderAmount' => null, 'orderCurrency' => null, 'deliveryAmount' => null, 'deliveryCurrency' => null, 'items' => [ [ 'externalId' => '243345345', 'title' => 'Product1', 'amount' => 50.61, 'currency' => 'MDL', 'quantity' => 3, 'displayOrder' => null, ], [ 'externalId' => '54353453', 'title' => 'Product2', 'amount' => 50.61, 'currency' => 'MDL', 'quantity' => 2, 'displayOrder' => null, ], ], ], 'payerInfo' => [ 'name' => 'John D.', 'email' => 'test@gmail.com', 'phone' => '+37377382716', 'ip' => '192.168.172.22', 'userAgent' => 'Mozilla/5.0', ], 'language' => 'ro', 'callbackUrl' => 'https://example.com/path', 'successUrl' => 'https://example.com/path', 'failUrl' => 'https://example.com/path', ]; $checkoutRegisterResponse = $maibCheckoutClient->checkoutRegister($checkoutData, $accessToken); $checkoutUrl = $checkoutRegisterResponse['result']['checkoutUrl'];
Validate callback signature
$callbackBody = '{"checkoutId":"5a4d27a4-79f5-426b-9403-cccdeee81747","paymentIntentId":"baa2a48d-b3ba-48b8-917e-07607d447c4f","merchantId":"37e48a96-37d7-49b3-8373-2e7e69ef8c2e","terminalId":"23456543","amount":193.54,"currency":"MDL","completedAt":"2024-11-23T19:35:00.6772285+02:00","payerName":"John","payerEmail":"Smith","payerPhone":"37368473653","payerIp":"192.175.12.22","orderId":"1142353","orderDescription":"OrderDescriptiondda760d7-a318-451b-8e47-f3377c06dcf5","orderDeliveryAmount":92.65,"orderDeliveryCurrency":8,"paymentId":"379b31a3-8283-43d4-8a7b-eef8c0736a32","paymentAmount":64.76,"paymentCurrency":"MDL","paymentStatus":"Executed","paymentExecutedAt":"2025-05-05T23:38:07.2760698+03:00","providerType":"Ips","senderIban":"NL43RABO1438227787","senderName":"Steven","senderCardNumber":"444433******1111","retrievalReferenceNumber":"ABC324353245"}'; $signatureHeader = 'sha256=h7/NNr0+SVwqfc1seJNl/m4M4/wzBiZwKHjE1gbmMKA='; $signatureTimestamp = '1761032516817'; $signatureKey = '67be8e54-ac28-485d-9369-27f6d3c55a27'; $validationResult = MaibCheckoutClient::validateCallbackSignature($callbackBody, $signatureHeader, $signatureTimestamp, $signatureKey);
Get checkout details
$checkoutId = $checkoutRegisterResponse['result']['checkoutId']; $checkoutDetailsResponse = $maibCheckoutClient->checkoutDetails($checkoutId, $accessToken);
Refund payment
$callbackData = json_decode($callbackBody, true); $paymentId = $callbackData['paymentId']; $refundData = [ 'reason' => 'Test refund reason', // 'amount' => 25.00, // Optional: for partial refund // 'callbackUrl' => 'https://example.com/refund' // Optional ]; $paymentRefundResponse = $maibCheckoutClient->paymentRefund($paymentId, $refundData, $accessToken);