pmilinvest/monetico

dev-main 2022-02-11 20:40 UTC

This package is auto-updated.

Last update: 2025-04-12 03:16:51 UTC


README

Latest Version on Packagist Total Downloads GitHub Actions

Facilite l'utilisation de l'API Monetico sous Laravel

Installation

Vous pouvez installer le package avec composer:

composer require pmilinvest/monetico

Configuration

Vous devez renseigner les identifiants API grâce aux fichier .env de votre application.

MONETICO_EPT_CODE=
MONETICO_SECURITY_KEY=
MONETICO_COMPAGNY_CODE=

##Usage

Monetico

use Pmilinvest\Monetico\Monetico;

$monetico = new Monetico(
'EPT_CODE',
'SECURITY_KEY',
'COMPANY_CODE'
);

Purchase

use PmilInvest\Monetico\Monetico;
use PmilInvest\Monetico\Requests\PurchaseRequest;
use PmilInvest\Monetico\Resources\BillingAddressResource;
use PmilInvest\Monetico\Resources\ShippingAddressResource;
use PmilInvest\Monetico\Resources\ClientResource;

$monetico = new Monetico(
'EPT_CODE',
'SECURITY_KEY',
'COMPANY_CODE'
);

$purchase = new PurchaseRequest([
'reference' => 'ABCDEF123',
'description' => 'Documentation',
'language' => 'FR',
'email' => 'john@snow.stark',
'amount' => 42,
'currency' => 'EUR',
'dateTime' => new DateTime(),
'successUrl' => 'http://localhost/thanks',
'errorUrl' => 'http://localhost/oops',
]);

$billingAddress = new BillingAddressResource([
'name' => 'dans ma culotte',
'addressLine1' => '42 rue des serviettes',
'city' => 'Coupeville',
'postalCode' => '42000',
'country' => 'FR',
]);
$purchase->setBillingAddress($billingAddress);

$shippingAddress = new ShippingAddressResource([
'name' => 'dans ma culotte',
'addressLine1' => '42 rue des serviettes',
'city' => 'Coupeville',
'postalCode' => '42000',
'country' => 'FR',
]);
$purchase->setShippingAddress($shippingAddress);

$client = new ClientResource([
'civility' => 'Mr',
'firstName' => 'John',
'lastName' => 'Snow',
]);
$purchase->setClient($client);

$url = PurchaseRequest::getUrl();
$fields = $monetico->getFields($purchase);
use PmilInvest\Monetico\Monetico;
use PmilInvest\Monetico\Responses\PurchaseResponse;
use PmilInvest\Monetico\Receipts\PurchaseReceipt;

$data = json_decode([/* bank request body */], true);

$monetico = new Monetico(
'EPT_CODE',
'SECURITY_KEY',
'COMPANY_CODE'
);

$response = new PurchaseResponse($data);

$result = $monetico->validate($response);

$receipt = new PurchaseReceipt($result);

Recovery

use PmilInvest\Monetico\Monetico;
use PmilInvest\Monetico\Requests\RecoveryRequest;
use PmilInvest\Monetico\Responses\RecoveryResponse;

$monetico = new Monetico(
'EPT_CODE',
'SECURITY_KEY',
'COMPANY_CODE'
);

$recovery = new RecoveryRequest([
'reference' => 'AXCDEF123',
'language' => 'FR',
'amount' => 42.42,
'amountToRecover' => 0,
'amountRecovered' => 0,
'amountLeft' => 42.42,
'currency' => 'EUR',
'orderDate' => new DateTime(),
'dateTime' => new DateTime(),
]);

$url = RecoveryRequest::getUrl();
$fields = $monetico->getFields($recovery);

$client = new Http\Client();
$data = $client->request('POST', $url, $fields);

// $data = json_decode($data, true);

$response = new RecoveryResponse($data);

###Cancel

use PmilInvest\Monetico\Monetico;
use PmilInvest\Monetico\Requests\CancelRequest;
use PmilInvest\Monetico\Responses\CancelResponse;

$monetico = new Monetico(
'EPT_CODE',
'SECURITY_KEY',
'COMPANY_CODE'
);

$cancel = new CancelRequest([
'dateTime' => new DateTime(),
'orderDate' => new DateTime(),
'reference' => 'ABC123',
'language' => 'FR',
'currency' => 'EUR',
'amount' => 100,
'amountRecovered' => 0,
]);

$url = CancelRequest::getUrl();
$fields = $monetico->getFields($cancel);

$client = new GuzzleHttp\Client();
$data = $client->request('POST', $url, $fields);

// $data = json_decode($data, true);

$response = new CancelResponse($data);

###Refund

use PmilInvest\Monetico\Monetico;
use PmilInvest\Monetico\Requests\RefundRequest;
use PmilInvest\Monetico\Responses\RefundResponse;

$monetico = new Monetico(
'EPT_CODE',
'SECURITY_KEY',
'COMPANY_CODE'
);

$refund = new RefundRequest([
'dateTime' => new DateTime(),
'orderDatetime' => new DateTime(),
'recoveryDatetime' => new DateTime(),
'authorizationNumber' => '1222',
'reference' => 'ABC123',
'language' => 'FR',
'currency' => 'EUR',
'amount' => 100,
'refundAmount' => 50,
'maxRefundAmount' => 80,
]);

$url = RefundRequest::getUrl();
$fields = $monetico->getFields($refund);

$client = new GuzzleHttp\Client();
$data = $client->request('POST', $url, $fields);

// $data = json_decode($data, true);

$response = new RefundResponse($data);

Crédits

License

The MIT License (MIT). Please see License File for more information.