Skip to main content

MercadoPago integration for django

Project description

build status coverage report version on pypi licence

As of 4.2.0, this package will be renamed to django-mercadopago on PyPI. Please update your references. Imports and modules remain unchanged.

django-mercadopago-simple is a simple django application for interacting with MercadoPago, aiming to be rather simple, and only covers the basic uses cases.

Features

Our intention is not to cover 100% of the features of the upstream API, but rather provide a simple app that allows accepting and tracking payments. This should suffice for simple sites like shopping carts, online sales, etc.

Pull requests are always welcome. Please don’t hesitate to open an issue if you encounter a problem. New features will generally only be added as needed, but again, accepted if you submit a patch.

Installation

Installation should generally be done via pip:

pip install django-mercadopago-simple

Configuration

You’ll need to obtainer your API credentials (app id and secret key) here and create an Account object with them. This creation can be done via the django admin included with this app or programmatically.

You should also expose the notifications endpoints like this:

url(r'^mercadopago/', include('django_mercadopago.urls'), namespace='mp'),
# Make sure namespace is 'mp', since we assume it is for notification URL
# contruction.

Note that these endpoints are required, since notification callbacks won’t work without them.

There are also a few Django settings that configure the behaviour of this app:

MERCADOPAGO_AUTOPROCESS

Required

If MERCADOPAGO_AUTOPROCESS is True, notifications will be processed as soon as they are received. Otherwise, it’s up to the developer to process them. A signal is always fired when a notification has been created, and a common pattern if not auto-processing is to have a celery task to process them:

@receiver(notification_received)
def process_notification(sender, **kwargs):
    tasks.process_notification.delay(notification=sender)

MERCADOPAGO_POST_PAYMENT_VIEW

Required

The setting MERCADOPAGO_POST_PAYMENT_VIEW must define name of the view where users are redirected after a payment. This view will receive as an argument the id of the notification created for this payment.

MERCADOPAGO_BASE_HOST

Required

MERCADOPAGO_BASE_HOST defines the domain name to use for notification URLs. It’ll be prepended to the exact URL of the exposed notifications endpoint.

Usage

MercadoPago lets you create preferences, for which you’ll later receive notifications (indicating if it was paid, or what happened):

self.preference = Preference.objects.create(
    title='the product name',
    price=10.0,
    reference='order-38452',
    success_url='http://example.com/mp_done',
    account=account,
)

If your app will only be using a single MercadoPago account, just use:

account = Account.objects.first()

Finally, you can handle payment notifications in real time using a post_update hook:

@receiver(post_save, sender=MercadoPagoPayment)
def process_payment(sender, instance=None, created=False, **kwargs):
    do_stuff()

Backwards compatibility

Version 2.0.0 changes the database schema quite a bit. While older data is retained, some missing fields had to be filled. Auto-generated data will have negative key values, and should easily be recognizable.

Regrettably, filling in this data automatically is not possible. However, there is no data loss involved.

Licence

This software is distributed under the ISC licence. See LICENCE for details.

Copyright (c) 2015-2017 Hugo Osvaldo Barrera <hugo@barrera.io>

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-mercadopago-simple-4.1.1.tar.gz (17.9 kB view details)

Uploaded Source

Built Distribution

django_mercadopago_simple-4.1.1-py3-none-any.whl (24.1 kB view details)

Uploaded Python 3

File details

Details for the file django-mercadopago-simple-4.1.1.tar.gz.

File metadata

File hashes

Hashes for django-mercadopago-simple-4.1.1.tar.gz
Algorithm Hash digest
SHA256 3c715118717aca4ec1ed2738cfb5f6c1d50f7925a6ade79d5a630063935796ee
MD5 1196cccabad80dde11c6fb0162ef919f
BLAKE2b-256 2cebbe50192c9a7f17277a99f4e9d5d75cedfcc4556a781975a9599190ef1ce1

See more details on using hashes here.

File details

Details for the file django_mercadopago_simple-4.1.1-py3-none-any.whl.

File metadata

File hashes

Hashes for django_mercadopago_simple-4.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 0e437162364448a0d531ce6f72aef9dfe60c321cba6f00b521c36b63403701a9
MD5 8687b93e237a2f3e7647a24d785198a1
BLAKE2b-256 49d377839d4886cb99e4523731d59644accd6e164c66793a67d82646aea71651

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