First Atlantic Commerce gateway for the Omnipay PHP payment processing library
Omnipay is a framework agnostic, multi-gateway payment processing library for PHP 5.3+. This package implements First Atlantic Commerce (FAC) support for Omnipay.
Via Composer
$ composer require cloudcogsio/omnipay-firstatlanticcommerce-gateway
This gateway driver operates in 3DS mode by default and requires a callback URL to be provided via the 'setReturnUrl' method. The return URL must then implement the 'acceptNotification' method to capture the transaction response from FAC.
The gateway can process non-3DS transactions by explicitly turning off 3DS during gateway configuration.
$gateway->set3DS(false);
For general usage instructions, please see the main Omnipay repository.
use Omnipay\Omnipay;
try {
$gateway = Omnipay::create('FirstAtlanticCommerce_FAC');
$gateway
->setTestMode(true)
->setIntegrationOption(\Omnipay\FirstAtlanticCommerce\Constants::GATEWAY_INTEGRATION_DIRECT)
->setFacId('xxxxxxxx')
->setFacPwd('xxxxxxxx')
->set3DS(false);
$cardData = [
'number' => '4111111111111111',
'expiryMonth' => '01',
'expiryYear' => '2025',
'cvv' => '123'
];
$transactionData = [
'card' => $cardData,
'currency' => 'USD',
'amount' => '1.00',
'transactionId' => 'OrderNo-2100001'
];
$response = $gateway->purchase($transactionData)->send();
if($response->isSuccessful())
{
// Verify response
$response->verifySignature();
// Purchase was succussful, continue order processing
...
}
} catch (Exception $e){
$e->getMessage();
}
'returnUrl' required. URL must be https://
use Omnipay\Omnipay;
try {
$gateway = Omnipay::create('FirstAtlanticCommerce_FAC');
$gateway
->setTestMode(true)
->setIntegrationOption(\Omnipay\FirstAtlanticCommerce\Constants::GATEWAY_INTEGRATION_DIRECT)
->setFacId('xxxxxxxx')
->setFacPwd('xxxxxxxx')
->set3DS(true)
// **Required and must be https://
->setReturnUrl('https://localhost/accept-notification.php');
$cardData = [
'number' => '4111111111111111',
'expiryMonth' => '01',
'expiryYear' => '2025',
'cvv' => '123'
];
$transactionData = [
'card' => $cardData,
'currency' => 'USD',
'amount' => '1.00',
'transactionId' => 'OrderNo-2100001'
];
$response = $gateway->purchase($transactionData)->send();
if($response->isRedirect())
{
// Redirect to continue 3DS verification
$response->redirect();
}
else
{
// 3DS transaction failed setup, show error reason.
echo $response->getMessage();
}
} catch (Exception $e){
$e->getMessage();
}
accept-notification.php Accept transaction response from FAC.
$gateway = Omnipay::create('FirstAtlanticCommerce_FAC');
$gateway
// Password is required to perform response signature verification
->setFacPwd('xxxxxxxx');
// Signature verification is performed implicitly once the gateway was initialized with the password.
$response = $gateway->acceptNotification($_POST)->send();
if($response->isSuccessful())
{
// Purchase was succussful, continue order processing
...
}
else
{
// Transaction failed
echo $response->getMessage();
}
If you are having general issues with Omnipay, we suggest posting on Stack Overflow. Be sure to add the omnipay tag so it can be easily found.
If you believe you have found a bug, please report it using the GitHub issue tracker, or better yet, fork the library and submit a pull request.