Epay
TODO
Usage, (*1)
- Create a
Forci\Component\Epay\Client\ClientOptions
instance, responsible for providing all the options the Forci\Component\Epay\Client\Client
needs. Its constructor needs the merchant ID and secret, provided by epay.bg. Remember to set the third constructor parameter to true or false depending on whether you're testing or not.
- Create a handler that implements the
Forci\Component\Epay\Client\PaymentHandlerInterface
interface. This interface has methods that are being called by the client
- Create an instance of
Forci\Component\Epay\Client\Client
, passing the above two
- To create a payment form, call
$client->getEpayForm($id, $amount, $description, $expiry, $formId, $okUrl, $cancelUrl)
- To create an EasyPay payment ID, call
$response = $this->client->getEasyPayIdn($id, $amount, $description, $expiry)
. This will return a Forci\Component\Epay\Response\EasyPayResponse
response. Call $response->getIdn()
to get the ID. Beware, this method throws a Forci\Component\Epay\Exception\EasyPayGetIdnError
exception.
The WucdbmEpayBundle https://packagist.org/packages/wucdbm/epay-bundle uses this library, head there for more examples., (*2)
$options = new \Forci\Component\Epay\Client\ClientOptions($merchantId, $merchantSecret, $isDebug);
// $options->set... to alter any options
$handler = new \My\Project\Payments\Epay\PaymentHandler(LogManager $some, PaymentManager $dependencies);
$client = new \Forci\Component\Epay\Client\Client($options, $handler);
Getting a payment form is done like this, (*3)
$uniqId = uniqid(); // this is to make autosubmitting easy - $('#formId').submit();
$expiry = new \DateTime('today + 2 days');
// ... other parameters
$form = $client->getEpayForm($id, $amount, $description, $expiry, $formId, $okUrl, $cancelUrl);
// Display the form and optionally auto submit it. Another option is to alter the submit button through the options and let the user do that
Getting an EasyPay IDN, (*4)
$id = $payment->getId();
$amount = $payment->getAmount();
$description = 'Payment #' . $payment->getId();
$expiry = $payment->getExpiryDate();
try {
$response = $this->client->getEasyPayIdn($id, $amount, $description, $expiry);
$idn = $response->getIdn();
// display idn to the user, do some logging.
// the response body is available at $response->getBody();
return $idn;
} catch (\Forci\Component\Epay\Exception\EasyPayGetIdnError $ex) {
$this->logEasyPayRequest($payment, $ex->getBody(), true);
throw $ex;
}
Receiving payments, (*5)
$response = $client->receiveResponse($post);
// the client will call your handler, which must deal with the payments received
// $response is an \Forci\Component\Epay\Response\ReceiveResponseInterface instance
// exceptions are caught internally and transformed into responses, the no data exception and checksum mismatch exceptions in particular generate a global error response for epay
echo $response->toString();
exit();
// alternatively, if you use Symfony's HttpFoundation component
$response = \Symfony\Component\HttpFoundation\Response($response->toString());