CMI PHP PAYMENT is an open source PHP payment handling library. it provides an easier way to communicate with CMI PAYMENT PLATEFORM cmi.co.ma in morocco.
The class is written OOP to make easier to communicate and understand how CMI work.
NB: The small library follows the FIG standard PSR-4 .
cmi-php requires the following components to work correctly
You can install the bindings via composer. Run the following command:
composer require mehdirochdi/cmi-payment-php
To use the bindings, use Composer's autoload
require_once('vendor/autoload.php');
If you do not wish to use Composer for some reason, you can usethe bindings, include the init.php file.
require_once('/path/to/cmi-php/init.php');
Example amount text fields example/formRequest.php
:
...
<h1>Payment form CMI</h1>
<form method="post" action="/example/process.php">
<label for="amount">Amount</label>
<input type="text" name="amount" class="input-control" placeholder="put amount here 10.65" value="10.60"> DHS<br/>
<button type="submit">Buy</button>
</form>
...
Keeping mind that storekey
and clientid
are given by CMI, you should contact them cmi.co.ma
<?php
// REQUIRED PARAMS
$client = new Mehdirochdi\CMI\CmiClient([
'storekey' => '', // STOREKEY
'clientid' => '', // CLIENTID
'oid' => '135ABC', // COMMAND ID IT MUST BE UNIQUE
'shopurl' => 'YOUR_DOMAIN_HERE', // SHOP URL FOR REDIRECTION
'okUrl' => 'YOUR_DOMAIN_HERE/okFail.php', // REDIRECTION AFTER SUCCEFFUL PAYMENT
'failUrl' => 'YOUR_DOMAIN_HERE/okFail.php', // REDIRECTION AFTER FAILED PAYMENT
'email' => 'mehdi.rochdi@gmail.com', // YOUR EMAIL APPEAR IN CMI PLATEFORM
'BillToName' => 'mehdi rochdi', // YOUR NAME APPEAR IN CMI PLATEFORM
'BillToCompany' => 'company name', // YOUR COMPANY NAME APPEAR IN CMI PLATEFORM
'amount' => $_POST['amount'], // RETRIEVE AMOUNT WITH METHOD POST
'CallbackURL' => 'YOUR_DOMAIN_HERE/callback.php', // CALLBACK
]);
$client->redirect_post(); // CREATE INPUTS HIDDEN, GENERATE A VALID HASH AND MAKE REDIRECT POST TO CMI
?>
Credit Card information cannot be used in test mode. instead, use any of the following test card numbers, a valid expiration date in the future, and any random CVC number, to create a successful payment.
Branch : visa
, PAN: 4000000000000010
, Expired date: make any date
CVC: 000
Branch : MasterCard
, PAN: 5453010000066100
, Expired date: make any date
CVC: 000
The following card information try to tests local payments such as Strong Customer Authentication SCA
Branch : MasterCard
, PAN: 5191630100004896
, Authentication code: 123
Expired date: make any date
CVC: 000
<?php
// REQUIRED PARAMS
$client = new Mehdirochdi\CMI\CmiClient([
...
'AutoRedirect' => 'true',
]);
OR
$client->AutoRedirect = 'true'; // REDIRECT THE CUSTOMER AUTOMATICALY BACK TO THE MERCHANT's WEB SITE WHEN TRANSACION IS ACCEPTED
$client->redirect_post(); // CREATE INPUTS HIDDEN, GENERATE A VALID HASH AND MAKE REDIRECT POST TO CMI