-
Notifications
You must be signed in to change notification settings - Fork 5
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #13 from juriansluiman/feature/refactoring
Feature/refactoring
- Loading branch information
Showing
28 changed files
with
3,583 additions
and
474 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,4 +1,181 @@ | ||
SlmIdealPayment | ||
=============== | ||
[![Build Status](https://travis-ci.org/juriansluiman/SlmIdealPayment.png)](https://travis-ci.org/juriansluiman/SlmIdealPayment) | ||
[![Latest Stable Version](https://poser.pugx.org/slm/ideal-payment/v/stable.png)](https://packagist.org/packages/slm/ideal-payment) | ||
|
||
This module is a Zend Framework 2 module to provide iDEAL payments (a Dutch payment system). | ||
Created by Jurian Sluiman | ||
|
||
Introduction | ||
--- | ||
SlmIdealPayment is a Zend Framework 2 module to provide payments via the iDEAL | ||
system. iDEAL is a payment service for the Dutch market and allows integration | ||
of payments for almost all Dutch banks. | ||
|
||
The module provides integration for the so-called iDEAL professional / iDEAL | ||
advanced method. Integration via iDEAL basic / iDEAL lite is not included. | ||
|
||
> **Standalone usage:** | ||
> This module is developed for Zend Framework 2, but can be used without the | ||
> framework in your own application. There is no need to understand Zend | ||
> Framework 2 to use this module. | ||
### Supported acquirers | ||
|
||
SlmIdealPayment works with the following banks (or acquirers in iDEAL terms): | ||
|
||
1. Rabobank | ||
2. ING Bank | ||
3. ABN Amro | ||
|
||
Installation | ||
--- | ||
The module can be loaded via composer. Require `slm/ideal-payment` in your | ||
composer.json file. If you do not have a composer.json file in the root of your | ||
project, copy the contents below and put that into a file called composer.json | ||
and save it in the root of your project: | ||
|
||
``` | ||
{ | ||
"require": { | ||
"slm/ideal-payment": "@dev" | ||
} | ||
} | ||
``` | ||
|
||
Then execute the following commands in a CLI: | ||
|
||
``` | ||
curl -s http://getcomposer.org/installer | php | ||
php composer.phar install | ||
``` | ||
|
||
Now you should have a vendor directory, including a slm/ideal-payment. In your | ||
bootstrap code, make sure you include the vendor/autoload.php file to properly | ||
load the SlmIdealPayment module. | ||
|
||
Configuration | ||
--- | ||
The file `slmidealpayment.local.php.dist` eases the iDEAL configuration. Copy | ||
the file from `vendor/slm/ideal-payment/config/slmidealpayment.local.php.dist` | ||
to your autoload folder and remove the `.dist` extension. | ||
|
||
Open the file and update the values to your needs. If you do not have a SSL | ||
certificate, you can use a self-signed certificate and upload that one to the | ||
iDEAL dashboard of your acquirer. Generate a key with 2048 bits encryption with | ||
the following command: | ||
|
||
``` | ||
openssl genrsa –aes128 –out priv.pem –passout pass:[privateKeyPass] 2048 | ||
``` | ||
|
||
Then create a certificate valid for 5 years: | ||
|
||
``` | ||
openssl req –x509 –sha256 –new –key priv.pem –passin pass:[privateKeyPass] | ||
-days 1825 –out cert.cer | ||
``` | ||
|
||
Then use the `priv.pem` and `cert.cer` files for the iDEAL signatures. | ||
|
||
Usage | ||
--- | ||
SlmIdealPayments will setup the client with the correct properties. Use the | ||
following names to request an instance from the service manager: | ||
|
||
1. Rabobank: `SlmIdealPayment\Client\Standard\Rabobank` | ||
2. ING Bank: `SlmIdealPayment\Client\Standard\Ing` | ||
3. ABN Amro: `SlmIdealPayment\Client\Standard\AbnAmro` | ||
|
||
### Directory request | ||
Then use the client to perform the request. A directory request gives a list of | ||
supported issuers. The result is a `SlmIdealPayment\Response\DirectoryResponse`: | ||
|
||
```php | ||
$client = $sl->get('SlmIdealPayment\Client\Standard\Rabobank'); | ||
|
||
$request = new DirectoryRequest; | ||
$response = $client->send($request); | ||
|
||
foreach ($response->getContries() as $country) { | ||
echo sprintf("Country: %s\n", $country->getName()); | ||
|
||
foreach ($country->getIssuers() as $issuer) { | ||
echo sprintf("%s: %s\n", $issuer->getId(), $issuer->getName()); | ||
} | ||
} | ||
``` | ||
|
||
### Transaction request | ||
A transaction request needs a Transaction object. The result is a | ||
`SlmIdealPayment\Response\TransactionResponse` object: | ||
|
||
```php | ||
use SlmIdealPayment\Model; | ||
|
||
$client = $sl->get('SlmIdealPayment\Client\Standard\Rabobank'); | ||
|
||
// Set up the issuer | ||
$issuer = new Model\Issuer; | ||
$issuer->setId($issuerId); // set selected issuer here | ||
|
||
// Set up the transaction | ||
$transaction = new Model\Transaction; | ||
$transaction->setPurchaseId($purchaseId); | ||
$transaction->setAmount($amount); | ||
$transaction->setDescription($description); | ||
$transaction->setEntranceCode($ec); | ||
|
||
$request = new TransactionRequest; | ||
$request->setIssuer($issuer); | ||
$request->setTransaction($transaction); | ||
|
||
$response = $client->send($request); | ||
|
||
echo $response->getTransaction()->getTransactionId(); | ||
|
||
// Then perform redirect: | ||
// Redirect to $response->getAuthenticationUrl(); | ||
``` | ||
|
||
### Status request | ||
A status request also needs a transaction object, but then for its transaction | ||
id. The result is a `SlmIdealPayment\Response\StatusRequest`: | ||
|
||
```php | ||
use SlmIdealPayment\Model; | ||
|
||
$client = $sl->get('SlmIdealPayment\Client\Standard\Rabobank'); | ||
|
||
$transaction = new Model\Transaction; | ||
$transaction->setTransactionId($transactionId); | ||
|
||
$request = new StatusRequest; | ||
$request->setTransaction($transaction); | ||
|
||
$response = $client->send($request); | ||
|
||
echo $response->getTransaction()->getStatus(); | ||
``` | ||
|
||
Using SlmIdealPayment outside ZF2 | ||
=== | ||
You can use the client without Zend Framework 2. Only the HTTP client is used | ||
inside the client and it's a small dependency you can load in any project you | ||
have. However, you need to configure all variables yourself. | ||
|
||
```php | ||
use SlmIdealPayment\Client\StandardClient; | ||
|
||
$client = new StandardClient; | ||
$client->setRequestUrl('https://ideal.rabobank.nl/ideal/iDEALv3'); | ||
$client->setMerchantId('00X0XXXXX'); | ||
$client->setSubId('0'); | ||
|
||
$client->setPublicCertificate('data/ssl/rabobank.cer'); | ||
$client->setPrivateCertificate('data/ssl/cert.cer'); | ||
|
||
$client->setKeyFile('data/ssl/priv.pem'); | ||
$client->setKeyPassword('h4x0r'); | ||
``` | ||
|
||
Now `$client` is configured, use above methods to perform the various requests. |
This file was deleted.
Oops, something went wrong.
This file was deleted.
Oops, something went wrong.
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.