9orky / espago-api-php
Client for Espago API
Installs: 60
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 3
Forks: 2
Open Issues: 0
pkg:composer/9orky/espago-api-php
Requires
- php: >=7.0
- guzzlehttp/guzzle: ~6.0
Requires (Dev)
- phpmd/phpmd: ^2.4
- phpspec/phpspec: ~3.1
- sebastian/phpcpd: *
- squizlabs/php_codesniffer: 2.*
- symfony/console: ~3.1
This package is not auto-updated.
Last update: 2025-10-26 01:42:21 UTC
README
Unofficial client of the Espago API written in PHP7.
Installation
To install via Composer just type in your console:
composer require "9orky/espago-api-php"
and you're done!
Usage
To avoid one huge file with all API methods, client was split into smaller functional pieces. The facade APIs are behind is at: Gorky\Espago\Factory\ApiFactory
Bootstrap
All you need to do is to instantiate an API Factory with:
- apiUrl - this is quite obvious, for development purposes your URL is: https://sandbox.espago.com
- apiCredentials - this is an object which resides at Gorky\Espago\Model\ApiCredentials and requires three arguments which should be provided to you by Espago: public key, app ID and password.
How does this look in a code?
$apiFactory = new \Gorky\Espago\Factory\ApiFactory( 'https://sandbox.espago.com', new \Gorky\Espago\Model\ApiCredentials('app_id', 'public_key', 'password') );
Conducting a simplest transaction
Ok, now with our Api Factory handy we can proceed to make our first transaction. What we needed is to ask a Customer for his card details and charge him.
Obtaining a Token
First step to our simple transaction is to generate a special Token which will be a Card's representation in Espago.
$tokensApi = $apiFactory->buildTokensApi(); // first we need Customer card's representation $unauthorizedCard = $tokensApi->createUnauthorizedCard( '4111111111111111', 'John', 'Doe', '04', '2020', '111' ); // so now we can transform it to a Token $token = $tokensApi->createToken($unauthorizedCard);
Token's model is a Response object so, together with others, it resides at: Gorky\Espago\Model directory. Explore the area to be familiar with what system can handle.
Making a Charge
We have a Token so now it's time to charge a Customer. To do this we have to call Charges API and provide some payment details.
$chargesApi = $apiFactory->buildChargesApi(); // carefuly study Gorky\Espago\Model\Response\Charge and corresponding API documents! $charge = $chargesApi->createChargeByToken($token, 12.66, 'PLN', 'doughnuts');
Yes, it was actually that easy :-)
Remembering the Card in Espago
At this moment payment transaction is executed and Customer is charged. But wait, he just forgot to buy his wife some flowers for their anniversary. Oh no, he must type all these numbers and letters once again! But no worries though, we can actually save Customer's Card in Espago for us to use it when needed.
To match Card with a Customer we need to create a Client. We have do this with a little help of our friend Token.
$tokensApi = $apiFactory->buildTokensApi(); $unauthorizedCard = $tokensApi->createUnauthorizedCard( '4111111111111111', 'John', 'Doe', '04', '2020', '111' ); $token = $tokensApi->createToken($unauthorizedCard); $clientsApi = $apiFactory->buildClientsApi(); $client = $clientsApi->createClient($token, 'john@example.com', 'Our precious client John'); $chargesApi = $apiFactory->buildChargesApi(); $charge = $chargesApi->createChargeByClient($client, 12.66, 'PLN', 'doughnuts');
All you have to do now is to persist a Client's ID and from now on you can charge Customer on demand. It's very convenient when your Customers are returning ones.
Fancy
There is a simple Console Application to play with using your sandbox account! :-) To make it usable we have to make some preparations.
Making credentials file
In a main directory create PHP file called: credentials.php:
// credentials.php return [ 'app_id' => 'your_app_id', 'public_key' => 'your_public_key', 'password' => 'your_password' ];
Time to play
Create new Client:
php espago.php customer:create
Charge Client:
php espago.php customer:charge --interactive
or
php espago.php customer:charge --clientId="1234" --amount="6.67" --currency="PLN" --description="flowers"
Capture Authorization hold:
php espago.php customer:charge --capture --chargeId="pay_COy6zH9fLj1d7K" --amount="23.44"
Refund Charge:
php espago.php customer:charge --refund --chargeId="pay_COy6zH9fLj1d7K" --amount="23.44"
Cancel Charge:
php espago.php customer:charge --cancel --chargeId="pay_COy6zH9fLj1d7K"
Note: Remember that you can always use --interactive switch which is more convenient:
php espago.php customer:charge --cancel --interactive
API documentation is right here: https://developers.espago.com/en/v3#201-preliminary-assumptions