1
0
Fork 0
You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
This repo is archived. You can view files and clone it, but cannot push or open issues/pull-requests.

98 lines
3.3 KiB
Markdown

7 years ago
# Omnipay: Inforbank
**Inforbank gateway for the Omnipay PHP payment processing library**
[Omnipay](https://github.com/omnipay/omnipay) is a framework agnostic, multi-gateway payment
processing library for PHP 5.3+. This package implements Inforbank support for Omnipay.
## Installation
Omnipay is installed via [Composer](http://getcomposer.org/). To install, simply add it
to your `composer.json` file:
```json
{
"repositories": [
{
"url": "https://git.verictas.com/InformaticaD4p/omnipay-plugin.git",
"type": "git"
}
],
"require": {
"inforbank/omnipay-inforbank": "dev-master"
}
}
```
And run composer to update your dependencies:
$ curl -s http://getcomposer.org/installer | php
$ php composer.phar update
## Basic Usage
The following gateways are provided by this package:
* Inforbank
For general usage instructions, please see the main [Omnipay](https://github.com/omnipay/omnipay)
repository.
## Example
```php
$gateway = \Omnipay\Omnipay::create('Inforbank');
$gateway->initialize(array(
'clientId' => 'PUT THE CLIENT_ID HERE',
'clientSecret' => 'PUT THE CLIENT_SECRET HERE'
));
// Start the purchase
if (!isset($_GET['trxid']) && !isset($_GET['error'])) {
7 years ago
$url = "http://".$_SERVER['HTTP_HOST'].$_SERVER['REQUEST_URI'];
$response = $gateway->purchase(array(
'amount' => "1.50",
'description' => "Testorder #1234",
'transactionId' => 1234,
'returnUrl' => $url
))->send();
if ($response->isRedirect()) {
// redirect to offsite payment gateway
$response->redirect();
} elseif ($response->isPending()) {
// This will never occur, because the gateway always returns a redirect to the bank pages.
return "Pending, Reference: ". $response->getTransactionReference();
} else {
// payment failed: display message to customer
return "Error " .$response->getError();
7 years ago
}
} elseif (isset($_GET['error'])) {
echo "Error " . $_GET['error'];
7 years ago
} else {
/**
* Because the 'status' GET parameter is present, this is a return URL request and the purchase should be completed.
*/
// Check the status
$response = $gateway->completePurchase()->send();
if ($response->isSuccessful()) {
$transaction = $response->getTransaction();
7 years ago
} else {
return "Error " .$response->getError();
7 years ago
}
}
```
## Server response
After sending the purchaseRequest, the server at Inforbank will return a POST body with the redirect URL. After redirecting to the redirect URL, the user will interact with Inforbank. Inforbank will then, depending on user interaction and configuration, return to your application with either ?trxid={ID} or ?error={ERRORMESSAGE}.
7 years ago
## Support
If you are having general issues with Omnipay, we suggest posting on
[Stack Overflow](http://stackoverflow.com/). Be sure to add the
[omnipay tag](http://stackoverflow.com/questions/tagged/omnipay) so it can be easily found.
If you want to keep up to date with release anouncements, discuss ideas for the project,
or ask more detailed questions, there is also a [mailing list](https://groups.google.com/forum/#!forum/omnipay) which
you can subscribe to.