Django models for Omise
Project description
django-omise Django + Omise
Django models for Omise. Currently, we support the following features:
-
Creating a customer
-
Allowing customer to add/delete credit/debit cards
-
Collect payments with new card with the option to keep the card
-
Collect payments with saved cards
-
Collect payments with Internet Banking
-
Collect payments with TrueMoney Wallet
-
Collect payments with Promptpay
-
Collect payments with Rabbit LINE Pay
-
Webhook handler, saving raw data as an Event object and update related objects, currently supporting
- Customer
- Card
- Charge
- Source
- Refund
- Schedule
- Scheduled Charge
- Schedule Occurrence
-
3DS pending charges handling
See the roadmap for the plan of this project. Contributions are welcome!
Quick start
- Add "django_omise" to your INSTALLED_APPS setting like this:
INSTALLED_APPS = [
...
"django_omise",
]
- Include the django_omise URLconf in your project urls.py like this:
path("payments/", include("django_omise.urls")),
- Add Omise keys and operating mode in settings.py:
OMISE_PUBLIC_KEY = xxxx
OMISE_SECRET_KEY = xxxx
OMISE_LIVE_MODE = True | False
OMISE_CHARGE_RETURN_HOST = localhost:8000
# Optional. The default payment method is credit/debit card only.
# You must specify additional payment methods.
OMISE_PAYMENT_METHODS = [
"card",
"internet_banking", # Internet Banking
"truemoney_wallet", # TrueMoney Wallet
"promptpay", # Promptpay
"rabbit_linepay", # Rabbit LINE Pay
]
-
Run
python manage.py migrate
to create the Omise models. -
Add Omise endpoint webhook url
https://www.your-own-domain.com/payments/webhook/
Basic usage
-
Create an Omise customer from User:
from django.contrib.auth import get_user_model from django_omise.models.core import Customer User = get_user_model() user = User.objects.first() customer = Customer.get_or_create(user=user)
-
Add card to Customer
2.1 With the built-in view (Recommended)
We have built a basic card collecting view where logged in users can add and remove their cards. Run Django server and visit /payments/payment_methods/ to see it in action. You could override the template used in the view by creating a new template in your project's directory /templates/django_omise/manage_payment_methods.html.
2.2 Manually
from django_omise.models.core import Customer from django_omise.omise import omise omise_token = omise.Token.retrieve(token_id) Customer.objects.live().first().add_card(token=omise_token)
-
Charge a customer (Currently supporting new/saved cards, Internet Banking, TrueMoney Wallet, Promptpay)
3.1 With the build-in mixin
This package comes with a built-in mixin, with which you can create a class-based-view and write a few methods to charge a customer. See below for an example or see Example 1:
from django.contrib.auth.mixins import LoginRequiredMixin from django_omise.mixins import CheckoutMixin from django_omise.models.choices import Currency # Your own class-based-view class CheckoutView(LoginRequiredMixin, CheckoutMixin): template_name = "yourapp/template.html" success_url = ... def get_charge_details(self): return { "amount": 100000, "currency": Currency.THB, } def process_charge_and_form(self, charge, form): if charge.status in [ChargeStatus.SUCCESSFUL, ChargeStatus.PENDING]: # Create new order and attach a charge object # And handle form data handle_form_data(form.cleaned_data)
3.2 Manually
from django_omise.models.choices import Currency, ChargeStatus from django_omise.models.core import Customer customer = Customer.objects.first() card = customer.cards.live().first() charge = customer.charge_with_card( amount=100000, currency=Currency.THB, card=card, ) if charge.status == ChargeStatus.SUCCESSFUL: # Do something elif charge.status == ChargeStatus.FAILED: # Do something else
-
Create a charge schedule for a customer:
At the moment, you can create a new schedule for a customer manually by calling the method create_schedule from a Custoemr object. See below for an example:
import datetime
from django_omise.models.choices import Currency
from django_omise.models.core import Customer
customer = Customer.objects.first()
card = customer.default_card
customer.create_schedule(
amount=100000,
currency=Currency.THB,
card=card,
every=1,
period="month",
start_date=datetime.date(year=2022, month=5, day=22),
end_date=datetime.date(year=2032, month=5, day=22),
on={
'days_of_month': [22],
},
description="Monthly subscription",
)
Roadmap and contributions
Here are our immediate plans for this package, and more will be added! All contributions are welcome. I am new to publishing a public package, so if you have any recommendations, please feel free to create an issue on this repository or feel free to send me an email at siwatjames@gmail.com.
Omise Features
- Handle refunds API
- Handle webhook events and update related objects
- Create charge with Sources
- Internet banking
- TrueMoney Wallet
- Promptpay
- Rabbit LINE Pay
- Installment
- Schedule
- Scheduled Charges
- Scheduled Transfer
Others
- Implement tests
- Add documentations
Development
You can run tests with either coverage or pytest.
To run with pytest
pip install pytest-django
python -m pytest [path_to_file] [--verbose -s --cov-report=html --cov=.]
To run with coverage
pip install coverage
coverage run run_tests.py
coverage report
coverage html
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file django_omise-0.2.20.tar.gz
.
File metadata
- Download URL: django_omise-0.2.20.tar.gz
- Upload date:
- Size: 166.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.3 CPython/3.12.2 Linux/6.5.0-1021-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | d5ca1d3d9ee41b04cfc1cab87284d93d605ffb0b4945566065b74898aef81508 |
|
MD5 | 3f9d8fca748dfe9789c921be3fdadfba |
|
BLAKE2b-256 | aec9907ed25df74d95fe5b10003787707876b1f6219410a0ea6c7f891265d846 |
File details
Details for the file django_omise-0.2.20-py3-none-any.whl
.
File metadata
- Download URL: django_omise-0.2.20-py3-none-any.whl
- Upload date:
- Size: 205.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.3 CPython/3.12.2 Linux/6.5.0-1021-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 110a5840691770981404db21a17ca286c86f450ae6210d2b6006cfafe93455d3 |
|
MD5 | 70af1efa538eae9aae83fe2cf8bd0dd7 |
|
BLAKE2b-256 | f35ad89557646aff26f2111707b483a2b67dca236ad1e55099ca074ec4fca8e4 |