2017 © Pedro Peláez
 

symfony-bundle saferpay-bundle

Symfony2 bundle for providing access to Saferpay. This is an extension to the JMSCorePaymentBundle.

image

ongoing/saferpay-bundle

Symfony2 bundle for providing access to Saferpay. This is an extension to the JMSCorePaymentBundle.

  • Tuesday, November 21, 2017
  • by ongoing
  • Repository
  • 2 Watchers
  • 0 Stars
  • 4 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 4 Forks
  • 0 Open issues
  • 7 Versions
  • 0 % Grown

The README.md

Saferpay - Extension to the JMSPaymentCoreBundle providing access to Saferpay.

This bundle now uses the new Saferpay JSON API, (*1)

This is a Fork of valiton SaferpayBundle. On top of the parent functionalities, it adds the possibility to use the payment process with the Transaction Interface., (*2)

Install and enable

Install the bundle with composer:, (*3)

composer require ongoing/saferpay-bundle

Activate the bundle in your kernel., (*4)

<?php
// app/AppKernel.php

// ...
class AppKernel extends Kernel
{
    public function registerBundles()
    {
        $bundles = array(
            // ...
            new Ongoing\Payment\SaferpayBundle\OngoingPaymentSaferpayBundle()
        );
    }

    // ...
}

Example Configuration


ongoing_payment_saferpay: account: 155432-17638731 jsonapi_key: JsonApiPwd1_abc jsonapi_pwd: API_234234_234234 cardrefid: random_unique authorize_direct: true

saferpay_checkout (JMS ChoosePaymentMethodType Form creation)

<?php

    $form = $this->createForm(ChoosePaymentMethodType::class, null, [
        'amount'   => $order->getAmount(),
        'currency' => 'CHF',
        'predefined_data' => [          
            'saferpay_checkout' => [
                'checkout_params' => [
                    'orderid' => $order->getId(),
                    'description' => $order->getOrderItems()->first()->getName()
                ],
                'return_url' => 'example.com/saferpay/success',
                'cancel_url' => 'example.com/saferpay/cancel',
                'error_url' => 'example.com/saferpay/error'
            ]   
        ],
    ]);
}

URLS can be overwritten or set in predefined data, to generate dynamic URLS for Example!, (*5)

To additionally send user data with saferpay initialization, following fields could be added under array key checkout_params: - firstname, lastname, street, zip, languagecode, city and user_ip, (*6)

Credit Card Data

On a successful response, creditcard data is saved in extended data of the transaction with keys token, CARDREFID, CARDMASK, CARDBRAND, CARDVALIDMONTH, CARDVALIDYEAR (take a look at approve method in the SaferpayPlugin)., (*7)

The generated alias is saved under CARDREFID. The alias could be used to initialize, authorize and capture a transaction in one step. By setting authorize_direct to true or false, additional security step (like 3DS) could be skipped. Be aware of liability reversal., (*8)

To let the bundle use the alias, you only have to set the creditcard_alias key (and correct alias as value) on the extended data of a JMSPaymentCoreBundle transaction/paymentinstruction BEFORE the transaction is initialized. This could be done by a form listener, a controller or any other service which is able to modify extended data., (*9)

//showAction -> http://jmspaymentcorebundle.readthedocs.io/en/stable/guides/accepting_payments.html
$ppc = $this->get('payment.plugin_controller');
$ppc->createPaymentInstruction($instruction = $form->getData());
$instrucation->getExtendedData()->set('creditcard_alias', 'validcreditcardalias');

Be aware using Saferpay Transaction with 'authorize_direct', the redirect to a success/failure/error page needs to be implemented manually., (*10)

Configuration Reference

Configure the bundle according to your needs, full config example:, (*11)

valiton_payment_saferpay:
    account: <some account>                 # your saferpay account, usually account-terminalid (e.g. 123562-32173665)
    jsonapi_key: <some key>                 # API key generated  through saferpay backend
    jsonapi_pwd: <some pw>                  # API password generated through saferpay backend
    return_url: <some url>                  # url called on successfull payment
    error_url: <some url>                   # url called on error
    cancel_url: <some url>                  # url called on user cancel
    saferpay_test: true                     # use the saferpay test system at test.saferpay.com
    cardrefid: new|random|random_unique     # create card alias: new: alias is generated by saferpay, random: alias is generated by us, random_unique: 
    cardrefid_prefix: TST                   # prefix of the randomly generated alias
    cardrefid_length: 33                    # length of the randomly generated alias (inclusive prefix)
    authorize_direct: false                 # if Transaction Interface with CC alias is used, this option forces authorizeDirect method. A Transaction is initialized, authorized and captured without user interaction. 

The Versions

21/11 2017

dev-master

9999999-dev

Symfony2 bundle for providing access to Saferpay. This is an extension to the JMSCorePaymentBundle.

  Sources   Download

MIT

The Requires

 

by Sven Cludius
by Frederik Trostorf

payment saferpay

21/11 2017

0.3.3

0.3.3.0

Symfony2 bundle for providing access to Saferpay. This is an extension to the JMSCorePaymentBundle.

  Sources   Download

MIT

The Requires

 

by Sven Cludius
by Frederik Trostorf

payment saferpay

14/11 2017

0.3.2

0.3.2.0

Symfony2 bundle for providing access to Saferpay. This is an extension to the JMSCorePaymentBundle.

  Sources   Download

MIT

The Requires

 

by Sven Cludius
by Frederik Trostorf

payment saferpay

27/10 2017

0.3.1

0.3.1.0

Symfony2 bundle for providing access to Saferpay. This is an extension to the JMSCorePaymentBundle.

  Sources   Download

MIT

The Requires

 

by Sven Cludius
by Frederik Trostorf

payment saferpay

27/10 2017

0.3

0.3.0.0

Symfony2 bundle for providing access to Saferpay. This is an extension to the JMSCorePaymentBundle.

  Sources   Download

MIT

The Requires

 

by Sven Cludius
by Frederik Trostorf

payment saferpay

19/12 2016

0.2

0.2.0.0

Symfony2 bundle for providing access to Saferpay. This is an extension to the JMSCorePaymentBundle.

  Sources   Download

MIT

The Requires

 

by Sven Cludius

payment saferpay

15/12 2016

0.1.2

0.1.2.0

Symfony2 bundle for providing access to Saferpay. This is an extension to the JMSCorePaymentBundle.

  Sources   Download

MIT

The Requires

 

by Sven Cludius

payment saferpay