- Added PricingPlan Model
- Implement a complete cycle for buying a Matrix Chat Host - Refactor the Payement cycle and stripe related methods
This commit is contained in:
parent
e205d8d07c
commit
b7aa1c6971
81 changed files with 5079 additions and 810 deletions
|
|
@ -1,6 +1,7 @@
|
|||
from django.core.management.base import BaseCommand
|
||||
from uncloud_auth.models import User
|
||||
from uncloud_pay.models import Order, Bill, PaymentMethod, get_balance_for_user
|
||||
from uncloud_pay.models import Order, Bill, get_balance_for_user
|
||||
import uncloud_pay.stripe as uncloud_stripe
|
||||
|
||||
from datetime import timedelta
|
||||
from django.utils import timezone
|
||||
|
|
@ -18,14 +19,10 @@ class Command(BaseCommand):
|
|||
balance = get_balance_for_user(user)
|
||||
if balance < 0:
|
||||
print("User {} has negative balance ({}), charging.".format(user.username, balance))
|
||||
payment_method = PaymentMethod.get_primary_for(user)
|
||||
if payment_method != None:
|
||||
amount_to_be_charged = abs(balance)
|
||||
charge_ok = payment_method.charge(amount_to_be_charged)
|
||||
if not charge_ok:
|
||||
print("ERR: charging {} with method {} failed"
|
||||
.format(user.username, payment_method.uuid)
|
||||
)
|
||||
else:
|
||||
print("ERR: no payment method registered for {}".format(user.username))
|
||||
amount_to_be_charged = abs(balance)
|
||||
result = uncloud_stripe.charge_customer(user, amount_to_be_charged)
|
||||
if result.status != 'succeeded':
|
||||
print("ERR: charging {} with method {} failed"
|
||||
.format(user.username, result)
|
||||
)
|
||||
print("=> Done.")
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue