# This file is part of Wolnelektury, licensed under GNU Affero GPLv3 or later.
# Copyright © Fundacja Nowoczesna Polska. See NOTICE for more information.
#
+import json
from django.contrib import admin
+from django.utils.html import conditional_escape
+from django.utils.safestring import mark_safe
from modeltranslation.admin import TranslationAdmin
from . import models
class PayUOrderInline(admin.TabularInline):
model = models.PayUOrder
+ fields = ['order_id', 'status', 'customer_ip']
+ readonly_fields = fields
extra = 0
show_change_link = True
+ can_delete = False
+
+ def has_add_permission(self, request, obj):
+ return False
class PayUCardTokenInline(admin.TabularInline):
model = models.PayUCardToken
+ fields = ['created_at', 'disposable_token', 'reusable_token']
+ readonly_fields = fields
extra = 0
show_change_link = True
+ can_delete = False
+ show_change_link = True
+
+ def has_add_permission(self, request, obj):
+ return False
class ScheduleAdmin(admin.ModelAdmin):
- list_display = ['email', 'started_at', 'expires_at', 'plan', 'amount', 'is_cancelled']
+ list_display = ['email', 'started_at', 'payed_at', 'expires_at', 'plan', 'amount', 'is_cancelled']
list_search = ['email']
list_filter = ['is_cancelled']
date_hierarchy = 'started_at'
class ScheduleInline(admin.TabularInline):
model = models.Schedule
+ fields = ['email', 'plan', 'amount', 'method', 'is_cancelled', 'started_at', 'payed_at', 'expires_at', 'email_sent']
+ readonly_fields = fields
extra = 0
show_change_link = True
+ can_delete = False
+
+ def has_add_permission(self, request, obj):
+ return False
+
class MembershipAdmin(admin.ModelAdmin):
list_display = ['user']
admin.site.register(models.ReminderEmail, TranslationAdmin)
-admin.site.register(models.PayUNotification)
+class PayUNotificationAdmin(admin.ModelAdmin):
+ list_display = ['received_at', 'order']
+ fields = ['received_at', 'order', 'body_']
+ readonly_fields = ['received_at', 'body_']
+ raw_id_fields = ['order']
+
+ def body_(self, obj):
+ return mark_safe(
+ "<pre>" +
+ conditional_escape(json.dumps(json.loads(obj.body), indent=4))
+ + "</pre>")
+
+
+admin.site.register(models.PayUNotification, PayUNotificationAdmin)
+
+
+class PayUNotificationInline(admin.TabularInline):
+ model = models.PayUNotification
+ fields = ['received_at', 'body_']
+ readonly_fields = fields
+ extra = 0
+ show_change_link = True
+ can_delete = False
+
+ def body_(self, obj):
+ return mark_safe(
+ "<pre>" +
+ conditional_escape(json.dumps(json.loads(obj.body), indent=4))
+ + "</pre>")
+
+ def has_add_permission(self, request, obj):
+ return False
+
+
+class PayUOrderAdmin(admin.ModelAdmin):
+ list_display = ['schedule']
+ raw_id_fields = ['schedule']
+ inlines = [PayUNotificationInline]
+
+
+admin.site.register(models.PayUOrder, PayUOrderAdmin)