1. Go to this page and download the library: Download academe/omnipay-wirecard library. Choose the download type require.
2. Extract the ZIP file and open the index.php.
3. Add this code to the index.php.
<?php
require_once('vendor/autoload.php');
/* Start to develop here. Best regards https://php-download.com/ */
academe / omnipay-wirecard example snippets
$gateway = Omnipay\Omnipay::create('Wirecard_CheckoutPage');
// This customer ID invokes demo mode. Try credit card MC: 9500000000000002
$gateway->setCustomerId('D200001');
$gateway->setSecret('B8AKTPWBRMNBV455FG6M2DANE99WU2');
// Because failureUrl and serviceUrl are gateway-specific, they can also be set
// as gateway configuration options:
$gateway->setFailureUrl('https://example.com/complete?status=failure');
$gateway->setServiceUrl('https://example.com/terms_of_service_and_contact');
// Most other gateway and API-specific parameters (i.e. those not recognised by
// the Omnipay core) can be set at the gateway or the message level.
$request = $gateway->purchase([
'transactionId' => $transactionId, // merchant site generated ID
'amount' => "9.00",
'currency' => 'EUR',
'invoiceId' => 'FOOOO',
'description' => 'An order',
'paymentType' => 'CCARD',
'card' => $card, // billing and shipping details
'items' => $items, // array or ItemBag of Omnipay\Common\Item or Omnipay\Wirecard\Extend\Item objects
//
// These three URLs are _contact',
//
'confirmMail' => '[email protected]',
]);
$response = $request->send();
// Quick and dirty way to POST to the gateway, to get to the
// remote hosted payment form.
// This is ignoring error checking, as detailed in the Omnipay documentation.
echo $response->getRedirectResponse();
exit;
// This form could target an iframe.
echo '<form action="' . $response->getRedirectUrl() . '" method="POST" accept-charset="UTF-8">';
foreach($response->getRedirectData() as $name => $value) {
echo '<input type="hidden" name="'.htmlspecialchars($name).'" value="'.htmlspecialchars($value).'" />';
}
echo '<button type="submit">Pay Now</button>';
echo "</form>";
$gateway->setCustomerId('D200411');
$gateway->setSecret('DP4TMTPQQWFJW34647RM798E9A5X7E8ATP462Z4VGZK53YEJ3JWXS98B9P4F');
$gateway->setShopId('3D'); // Or leave not set if using the non-3D Secure test cards.
$gateway->setToolkitPassword('2g4f9q2m');
$transactionReference = $completeResponse->getTransactionReference();
// or
$transactionReference = $serverResponse->getTransactionReference();
$request = $gateway->capture([
'amount' => '1.00',
'currency' => 'EUR',
'orderNumber' => $transactionReference,
// or
'transactionReference' => $transactionReference,
]);
$response = $request->send();
// If successfully captured you will get this response:
$response->isSuccessful(); // true
// If not successful, details will be available:
// Code and message from the gateway:
$response->getCode();
$response->getMessage();
// Message from the remote financial merchant, if available:
$response->getPaySysMessage();
// The request must be used to generate a response with the final results.
$completePurchaseResponse = $completePurchaseRequest->send();
// Checks if the authorisation was successful and the message is valid.
// If the fingerprint signing fails, then this will return `false`.
// If the delivered `transactionId` differs from the expected `transactionId`
// then this will also return `false`
$completePurchaseResponse->isSuccessful();
// Get the success or failure message.
// Some messages are generated by the gateway, and some are filled
// in by this driver.
$completePurchaseResponse->getMessage();
// Checks if the authorisation was cancelled by the user.
$completePurchaseResponse->isCancelled();
// Get the raw data.
$completePurchaseResponse->getData();
// Get the transaction ID (generated by the merchant site).
$completePurchaseResponse->getTransactonId();
// Get the transaction reference (generated by the gateway).
$completePurchaseResponse->getTransactonReference();
// Just confirms if the message signature is valid.
$completePurchaseResponse->isValid();
// Also `$gateway->recurAuthorize([...])`
$recurRequest = $gateway->recurPurchase([
'amount' => 3.10,
'currency' => 'GBP',
'description' => 'A recurring payment',
'sourceOrderNumber' => $originalTransactionReference,
]);
$recurResponse = $recurRequest->send();
// The order reference is needed to capture the payment if just authorizing.
$newOrderNumber = $recurResponse->getOrderReference();
$gateway = Omnipay\Omnipay::create('Wirecard_CheckoutSeamless');
$gateway->initialize([
'customerId' => 'D200411',
'shopId' => 'seamless',
'secret' => 'CHCSH7UGHVVX2P7EHDHSY4T2S4CGYK4QBE4M5YUUG2ND5BEZWNRZW5EJYVJQ',
'toolkitPassword' => '2g4f9q2m',
...
]);
$request = $gateway->storageInit([
'paymentMethod' => 'CCARD',
'returnUrl' => $returnUrl,
'transactionId' => $merchantTransactionId,
]);
$response = $request->send();
// The storageId will be needed by the front end JS library, and also
// when submitting the order at the back end.
$storageId = $response->getStorageId();
$response = $gateway->createOrderNumber()->send();
$orderNumber = $response->getOrderNumber();
// This is aliased in more Omnipay terms:
$transactionReference = $response->getTransactionReference();