Skip to main content

MultiSafepay Payments Gateway integration for Django

Project description

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)

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

django-multisafepay-1.1.1.tar.gz (17.1 kB view details)

Uploaded Source

Built Distribution

django_multisafepay-1.1.1-py3-none-any.whl (22.8 kB view details)

Uploaded Python 3

File details

Details for the file django-multisafepay-1.1.1.tar.gz.

File metadata

  • Download URL: django-multisafepay-1.1.1.tar.gz
  • Upload date:
  • Size: 17.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.11.0 pkginfo/1.4.2 requests/2.18.4 setuptools/38.5.2 requests-toolbelt/0.8.0 tqdm/4.19.6 CPython/3.6.1

File hashes

Hashes for django-multisafepay-1.1.1.tar.gz
Algorithm Hash digest
SHA256 31fcda10cdcbbaf119235a30ffa43c100136bee77ccaad148299be0ee3deb2ed
MD5 713a6724f88c01434323d55279150afe
BLAKE2b-256 56c753fca41392e98a0907a111d8555991eab0670d16a40b896cfa1d47d3dcf6

See more details on using hashes here.

File details

Details for the file django_multisafepay-1.1.1-py3-none-any.whl.

File metadata

  • Download URL: django_multisafepay-1.1.1-py3-none-any.whl
  • Upload date:
  • Size: 22.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.11.0 pkginfo/1.4.2 requests/2.18.4 setuptools/38.5.2 requests-toolbelt/0.8.0 tqdm/4.19.6 CPython/3.6.1

File hashes

Hashes for django_multisafepay-1.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 61cbe8afdd1028d2e62fc9ef14e2652d0a0e4b46395652e10981aa6e15a19c30
MD5 d8cbc3a270a09ce700f56d1da9a83298
BLAKE2b-256 3e73c738d1af6f2a43999138985ac3e722716080a2541fe24491ab4f641b7f72

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page