GDPR Compliant erasure requests
This commit is contained in:
@@ -1,3 +1,58 @@
|
||||
from django import forms
|
||||
from django.contrib import admin
|
||||
#
|
||||
# No custom models registered in accounts app. The legacy Account model has been removed.
|
||||
from django.utils import timezone
|
||||
from unfold.admin import ModelAdmin
|
||||
|
||||
from .models import ErasureRequest
|
||||
|
||||
|
||||
class ErasureRequestAdminForm(forms.ModelForm):
|
||||
class Meta:
|
||||
model = ErasureRequest
|
||||
fields = "__all__"
|
||||
|
||||
def clean(self):
|
||||
cleaned = super().clean()
|
||||
status = cleaned.get("status")
|
||||
decision_reason = (cleaned.get("decision_reason") or "").strip()
|
||||
if status in {ErasureRequest.Status.DENIED, ErasureRequest.Status.PROCESSED} and not decision_reason:
|
||||
raise forms.ValidationError("Decision reason is required for denied or processed requests.")
|
||||
return cleaned
|
||||
|
||||
|
||||
@admin.register(ErasureRequest)
|
||||
class ErasureRequestAdmin(ModelAdmin):
|
||||
form = ErasureRequestAdminForm
|
||||
list_display = ("id", "user", "status", "requested_at", "decided_at", "processed_at")
|
||||
list_filter = ("status", "requested_at", "processed_at")
|
||||
search_fields = ("user__username", "user__email")
|
||||
readonly_fields = ("requested_at", "decided_at", "processed_at", "decided_by", "processed_by")
|
||||
fieldsets = (
|
||||
(
|
||||
"Request",
|
||||
{
|
||||
"fields": ("user", "reason", "status", "requested_at"),
|
||||
},
|
||||
),
|
||||
(
|
||||
"Decision",
|
||||
{
|
||||
"fields": ("decision_reason", "decided_by", "decided_at"),
|
||||
},
|
||||
),
|
||||
(
|
||||
"Processing",
|
||||
{
|
||||
"fields": ("processed_by", "processed_at"),
|
||||
},
|
||||
),
|
||||
)
|
||||
|
||||
def save_model(self, request, obj, form, change) -> None:
|
||||
if obj.status == ErasureRequest.Status.PROCESSED:
|
||||
obj.process(request.user, decision_reason=obj.decision_reason)
|
||||
return
|
||||
if obj.status == ErasureRequest.Status.DENIED and not obj.decided_at:
|
||||
obj.decided_at = timezone.now()
|
||||
obj.decided_by = request.user
|
||||
super().save_model(request, obj, form, change)
|
||||
|
||||
Reference in New Issue
Block a user