2014-09-18 15:07:39 +00:00
|
|
|
from functools import partial
|
|
|
|
|
2014-09-10 16:53:09 +00:00
|
|
|
from django.contrib import messages
|
2014-09-16 17:14:24 +00:00
|
|
|
from django.db import transaction
|
2014-09-10 16:53:09 +00:00
|
|
|
from django.shortcuts import render
|
2014-09-18 15:07:39 +00:00
|
|
|
from django.utils.safestring import mark_safe
|
|
|
|
from django.utils.text import capfirst
|
2014-10-21 15:29:36 +00:00
|
|
|
from django.utils.translation import ungettext, ugettext_lazy as _
|
2014-09-10 16:53:09 +00:00
|
|
|
|
2014-09-16 17:14:24 +00:00
|
|
|
from orchestra.admin.decorators import action_with_confirmation
|
2014-09-18 15:07:39 +00:00
|
|
|
from orchestra.admin.utils import change_url
|
2014-09-16 17:14:24 +00:00
|
|
|
|
2014-09-08 10:03:42 +00:00
|
|
|
from .methods import PaymentMethod
|
2014-09-10 16:53:09 +00:00
|
|
|
from .models import Transaction
|
|
|
|
|
2014-09-16 17:14:24 +00:00
|
|
|
|
|
|
|
@transaction.atomic
|
2014-07-30 12:55:33 +00:00
|
|
|
def process_transactions(modeladmin, request, queryset):
|
2014-09-10 16:53:09 +00:00
|
|
|
processes = []
|
|
|
|
if queryset.exclude(state=Transaction.WAITTING_PROCESSING).exists():
|
|
|
|
msg = _("Selected transactions must be on '{state}' state")
|
|
|
|
messages.error(request, msg.format(state=Transaction.WAITTING_PROCESSING))
|
|
|
|
return
|
2014-09-16 14:35:00 +00:00
|
|
|
for method, transactions in queryset.group_by('source__method').iteritems():
|
2014-09-08 10:03:42 +00:00
|
|
|
if method is not None:
|
2014-09-10 16:53:09 +00:00
|
|
|
method = PaymentMethod.get_plugin(method)
|
|
|
|
procs = method.process(transactions)
|
|
|
|
processes += procs
|
2014-09-26 15:05:20 +00:00
|
|
|
for trans in transactions:
|
2014-10-07 13:50:59 +00:00
|
|
|
modeladmin.log_change(request, trans, _("Processed"))
|
2014-09-10 16:53:09 +00:00
|
|
|
if not processes:
|
|
|
|
return
|
|
|
|
opts = modeladmin.model._meta
|
|
|
|
context = {
|
|
|
|
'title': _("Huston, be advised"),
|
|
|
|
'action_name': _("Process"),
|
|
|
|
'processes': processes,
|
|
|
|
'opts': opts,
|
|
|
|
'app_label': opts.app_label,
|
|
|
|
}
|
|
|
|
return render(request, 'admin/payments/transaction/get_processes.html', context)
|
2014-09-16 17:14:24 +00:00
|
|
|
|
|
|
|
|
|
|
|
@transaction.atomic
|
|
|
|
@action_with_confirmation()
|
2014-09-18 15:07:39 +00:00
|
|
|
def mark_as_executed(modeladmin, request, queryset, extra_context={}):
|
2014-09-26 15:05:20 +00:00
|
|
|
for trans in queryset:
|
|
|
|
trans.mark_as_executed()
|
2014-10-07 13:50:59 +00:00
|
|
|
modeladmin.log_change(request, trans, _("Executed"))
|
2014-10-21 15:29:36 +00:00
|
|
|
num = len(queryset)
|
|
|
|
msg = ungettext(
|
|
|
|
_("One selected transaction has been marked as executed."),
|
|
|
|
_("%s selected transactions have been marked as executed.") % num,
|
|
|
|
num)
|
2014-09-16 17:14:24 +00:00
|
|
|
modeladmin.message_user(request, msg)
|
|
|
|
mark_as_executed.url_name = 'execute'
|
|
|
|
mark_as_executed.verbose_name = _("Mark as executed")
|
|
|
|
|
|
|
|
|
|
|
|
@transaction.atomic
|
|
|
|
@action_with_confirmation()
|
|
|
|
def mark_as_secured(modeladmin, request, queryset):
|
2014-09-26 15:05:20 +00:00
|
|
|
for trans in queryset:
|
|
|
|
trans.mark_as_secured()
|
2014-10-07 13:50:59 +00:00
|
|
|
modeladmin.log_change(request, trans, _("Secured"))
|
2014-10-21 15:29:36 +00:00
|
|
|
num = len(queryset)
|
|
|
|
msg = ungettext(
|
|
|
|
_("One selected transaction has been marked as secured."),
|
|
|
|
_("%s selected transactions have been marked as secured.") % num,
|
|
|
|
num)
|
2014-09-16 17:14:24 +00:00
|
|
|
modeladmin.message_user(request, msg)
|
|
|
|
mark_as_secured.url_name = 'secure'
|
|
|
|
mark_as_secured.verbose_name = _("Mark as secured")
|
|
|
|
|
|
|
|
|
|
|
|
@transaction.atomic
|
|
|
|
@action_with_confirmation()
|
|
|
|
def mark_as_rejected(modeladmin, request, queryset):
|
2014-09-26 15:05:20 +00:00
|
|
|
for trans in queryset:
|
|
|
|
trans.mark_as_rejected()
|
2014-10-07 13:50:59 +00:00
|
|
|
modeladmin.log_change(request, trans, _("Rejected"))
|
2014-10-21 15:29:36 +00:00
|
|
|
num = len(queryset)
|
|
|
|
msg = ungettext(
|
|
|
|
_("One selected transaction has been marked as rejected."),
|
|
|
|
_("%s selected transactions have been marked as rejected.") % num,
|
|
|
|
num)
|
2014-09-16 17:14:24 +00:00
|
|
|
modeladmin.message_user(request, msg)
|
|
|
|
mark_as_rejected.url_name = 'reject'
|
|
|
|
mark_as_rejected.verbose_name = _("Mark as rejected")
|
2014-09-18 15:07:39 +00:00
|
|
|
|
|
|
|
|
|
|
|
def _format_display_objects(modeladmin, request, queryset, related):
|
|
|
|
objects = []
|
|
|
|
opts = modeladmin.model._meta
|
|
|
|
for obj in queryset:
|
|
|
|
objects.append(
|
|
|
|
mark_safe('{0}: <a href="{1}">{2}</a>'.format(
|
|
|
|
capfirst(opts.verbose_name), change_url(obj), obj))
|
|
|
|
)
|
|
|
|
subobjects = []
|
|
|
|
attr, verb = related
|
|
|
|
for related in getattr(obj.transactions, attr)():
|
|
|
|
subobjects.append(
|
2014-10-21 15:29:36 +00:00
|
|
|
mark_safe('Transaction: <a href="{}">{}</a> will be marked as {}'.format(
|
|
|
|
change_url(related), related, verb))
|
2014-09-18 15:07:39 +00:00
|
|
|
)
|
|
|
|
objects.append(subobjects)
|
|
|
|
return {'display_objects': objects}
|
|
|
|
|
|
|
|
_format_executed = partial(_format_display_objects, related=('all', 'executed'))
|
|
|
|
_format_abort = partial(_format_display_objects, related=('processing', 'aborted'))
|
|
|
|
_format_commit = partial(_format_display_objects, related=('all', 'secured'))
|
|
|
|
|
|
|
|
|
|
|
|
@transaction.atomic
|
|
|
|
@action_with_confirmation(extra_context=_format_executed)
|
|
|
|
def mark_process_as_executed(modeladmin, request, queryset):
|
|
|
|
for process in queryset:
|
|
|
|
process.mark_as_executed()
|
2014-10-07 13:50:59 +00:00
|
|
|
modeladmin.log_change(request, process, _("Executed"))
|
2014-10-21 15:29:36 +00:00
|
|
|
num = len(queryset)
|
|
|
|
msg = ungettext(
|
|
|
|
_("One selected process has been marked as executed."),
|
|
|
|
_("%s selected processes have been marked as executed.") % num,
|
|
|
|
num)
|
2014-09-18 15:07:39 +00:00
|
|
|
modeladmin.message_user(request, msg)
|
|
|
|
mark_process_as_executed.url_name = 'executed'
|
|
|
|
mark_process_as_executed.verbose_name = _("Mark as executed")
|
|
|
|
|
|
|
|
|
|
|
|
@transaction.atomic
|
|
|
|
@action_with_confirmation(extra_context=_format_abort)
|
|
|
|
def abort(modeladmin, request, queryset):
|
|
|
|
for process in queryset:
|
|
|
|
process.abort()
|
2014-10-07 13:50:59 +00:00
|
|
|
modeladmin.log_change(request, process, _("Aborted"))
|
2014-10-21 15:29:36 +00:00
|
|
|
num = len(queryset)
|
|
|
|
msg = ungettext(
|
|
|
|
_("One selected process has been aborted."),
|
|
|
|
_("%s selected processes have been aborted.") % num,
|
|
|
|
num)
|
2014-09-18 15:07:39 +00:00
|
|
|
modeladmin.message_user(request, msg)
|
|
|
|
abort.url_name = 'abort'
|
|
|
|
abort.verbose_name = _("Abort")
|
|
|
|
|
|
|
|
|
|
|
|
@transaction.atomic
|
|
|
|
@action_with_confirmation(extra_context=_format_commit)
|
|
|
|
def commit(modeladmin, request, queryset):
|
2014-09-26 15:05:20 +00:00
|
|
|
for trans in queryset:
|
|
|
|
trans.mark_as_rejected()
|
2014-10-07 13:50:59 +00:00
|
|
|
modeladmin.log_change(request, trans, _("Rejected"))
|
2014-10-21 15:29:36 +00:00
|
|
|
num = len(queryset)
|
|
|
|
msg = ungettext(
|
|
|
|
_("One selected transaction has been marked as rejected."),
|
|
|
|
_("%s selected transactions have been marked as rejected.") % num,
|
|
|
|
num)
|
2014-09-18 15:07:39 +00:00
|
|
|
modeladmin.message_user(request, msg)
|
|
|
|
commit.url_name = 'commit'
|
|
|
|
commit.verbose_name = _("Commit")
|