Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/django-getpaid/django-getpaid
Django payments processor.
https://github.com/django-getpaid/django-getpaid
django payments python
Last synced: 3 months ago
JSON representation
Django payments processor.
- Host: GitHub
- URL: https://github.com/django-getpaid/django-getpaid
- Owner: django-getpaid
- License: mit
- Created: 2012-07-15T15:11:34.000Z (over 12 years ago)
- Default Branch: master
- Last Pushed: 2021-12-12T18:31:41.000Z (about 3 years ago)
- Last Synced: 2024-10-03T09:21:22.612Z (3 months ago)
- Topics: django, payments, python
- Language: Python
- Size: 979 KB
- Stars: 441
- Watchers: 21
- Forks: 121
- Open Issues: 4
-
Metadata Files:
- Readme: README.rst
- Changelog: HISTORY.rst
- Contributing: CONTRIBUTING.rst
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
README
.. image:: https://img.shields.io/pypi/v/django-getpaid.svg
:target: https://pypi.org/project/django-getpaid/
:alt: Latest PyPI version
.. image:: https://github.com/django-getpaid/django-getpaid/actions/workflows/run_tox.yml/badge.svg
:target: https://github.com/django-getpaid/django-getpaid/actions/
.. image:: https://img.shields.io/pypi/wheel/django-getpaid.svg
:target: https://pypi.org/project/django-getpaid/
.. image:: https://img.shields.io/pypi/l/django-getpaid.svg
:target: https://pypi.org/project/django-getpaid/=============================
Welcome to django-getpaid
=============================django-getpaid is payment processing framework for Django
Documentation
=============The full documentation is at https://django-getpaid.readthedocs.io.
Features
========* support for multiple payment brokers at the same time
* very flexible architecture
* support for asynchronous status updates - both push and pull
* support for modern REST-based broker APIs
* support for multiple currencies (but one per payment)
* support for global and per-plugin validators
* easy customization with provided base abstract models and swappable mechanic (same as with Django's User model)Quickstart
==========Install django-getpaid and at least one payment backend:
.. code-block:: console
pip install django-getpaid
pip install django-getpaid-payuDefine an ``Order`` model by subclassing ``getpaid.abstracts.AbstractOrder``
and define some required methods:.. code-block:: python
from getpaid.abstracts import AbstractOrder
class MyCustomOrder(AbstractOrder):
amount = models.DecimalField(decimal_places=2, max_digits=8)
description = models.CharField(max_length=128)
buyer = models.ForeignKey(settings.AUTH_USER_MODEL, on_delete=models.CASCADE)def get_absolute_url(self):
return reverse('order-detail', kwargs={"pk": self.pk})def get_total_amount(self):
return self.amountdef get_buyer_info(self):
return {"email": self.buyer.email}def get_currency(self):
return "EUR"def get_description(self):
return self.description.. note:: If you already have an Order model and don't want to subclass ``AbstractOrder``
just make sure you implement all methods.Inform getpaid of your Order model in ``settings.py`` and provide settings for payment backends:
.. code-block:: python
GETPAID_ORDER_MODEL = 'yourapp.MyCustomOrder'
GETPAID_BACKEND_SETTINGS = {
"getpaid_payu": {
# take these from your merchant panel:
"pos_id": 12345,
"second_key": "91ae651578c5b5aa93f2d38a9be8ce11",
"oauth_id": 12345,
"oauth_secret": "12f071174cb7eb79d4aac5bc2f07563f",
},
}Create a migration for your model BEFORE adding ``getpaid`` to ``INSTALLED_APPS``:
.. code-block:: console
./manage.py makemigrations
Add ``getpaid`` and broker plugin to your ``INSTALLED_APPS``:
.. code-block:: python
INSTALLED_APPS = [
...
'getpaid',
'getpaid_payu', # one of plugins
...
]Migrate the database:
.. code-block:: console
./manage.py migrate
Add getpaid to URL patterns:
.. code-block:: python
urlpatterns = [
...
path('payments/', include('getpaid.urls')),
...
]Write a view that will create the Payment.
An example view and its hookup to urls.py can look like this:
.. code-block:: python
# orders/views.py
from getpaid.forms import PaymentMethodFormclass OrderView(DetailView):
model = Orderdef get_context_data(self, **kwargs):
context = super(OrderView, self).get_context_data(**kwargs)
context["payment_form"] = PaymentMethodForm(
initial={"order": self.object, "currency": self.object.currency}
)
return context# main urls.py
urlpatterns = [
# ...
path("order//", OrderView.as_view(), name="order_detail"),
]You'll also need a template (``order_detail.html`` in this case) for this view.
Here's the important part:.. code-block::
Choose payment broker:
{% csrf_token %}
{{ payment_form.as_p }}
Running Tests
=============.. code-block:: console
poetry install
poetry run toxAlternatives
============* `django-payments `_
Credits
=======Created by `Krzysztof Dorosz `_.
Redesigned and rewritten by `Dominik Kozaczko `_.Development of version 2.0 sponsored by `SUNSCRAPERS `_
Disclaimer
==========This project has nothing in common with `getpaid `_ plone project.