Skip to content
MultiSafepay integration for Django
Python
Branch: master
Clone or download
Latest commit 616d22d Nov 13, 2018
Permalink
Type Name Latest commit message Commit time
Failed to load latest commit information.
django_multisafepay Bump to v1.1.1 Nov 13, 2018
docs/multisafepay Update MultiSafePay docs May 19, 2015
.gitignore Add wheel support Nov 27, 2014
AUTHORS First base version Feb 26, 2014
CHANGES.rst Bump to v1.1.1 Nov 13, 2018
LICENSE First base version Feb 26, 2014
LICENSE.rst First base version Feb 26, 2014
MANIFEST.in First base version Feb 26, 2014
README.rst Bump and improve for 1.0 release May 19, 2015
setup.cfg Add wheel support Nov 27, 2014
setup.py Bump and improve for 1.0 release May 19, 2015

README.rst

django-multisafepay

Payment gateway integration for MultiSafepay. MultiSafepay is a large payment gateway based in The Netherlands that supports many international payment methods.

MultiSafepay offers two methods for payments, see https://www.multisafepay.com/en/Payment-services/:

  • Fast checkout requires customers to create a MultiSafePay account. You only have to pay a transaction fee, but the account system is not very user-friendly.
  • Connect provides direct payments. As a merchant, you have to pay a monthly subscription.

Installation

Install via pip:

pip install django-multisafepay

Configuration

In the MultiSafepay merchant site settings, add a new website. Use those settings to configure the application:

MULTISAFEPAY_ACCOUNT_ID
The account ID, provided by MultiSafepay.
MULTISAFEPAY_SITE_ID
The site ID, found in the MultiSafepay website settings panel.
MULTISAFEPAY_SITE_CODE
The site security code, found in the MultiSafepay website settings panel.
MULTISAFEPAY_TESTING
Whether or not to run in testing mode. Defaults to True.

Add to urls.py:

urlpatterns += patterns('',
    url(r'^api/multisafepay/', include('django_multisafepay.urls')),
)

As recommendation, temporary log all events from this package as well:

LOGGING = {
    # ...

    'handlers': {
        # ...

        'console': {
            'level': 'DEBUG',
            'class': 'logging.StreamHandler',
        },
    },
    'loggers': {
        # ...

        'django_multisafepay': {
            'handlers': ['console'],
            'level': 'DEBUG',
            'propagate': True,
        },
    },
}

Usage

Creating a new payment transaction:

from django_multisafepay.client import MultiSafepayClient
from django_multisafepay.data import Transaction, Customer
from django.shortcuts import redirect

def pay(request):

    client = MultiSafepayClient()
    reply = client.start_checkout(
        transaction = Transaction(

        ),
        customer = Customer(

        )
    )

    return redirect(reply.payment_url)
  • For the Fast Checkout, use the start_checkout() method.
  • For the Connect method, use the redirect_transaction() method.

Both methods return an URL to redirect the user to.

Fetching status:

client = MultiSafepayClient()
statusreply = client.status(self.transaction_id)

TODO

  • checkout-shopping-cart
  • custom-fields
  • shipping
  • iDEAL issuers request (simple to add)
You can’t perform that action at this time.