-
Notifications
You must be signed in to change notification settings - Fork 28
Expand file tree
/
Copy pathadmin.py
More file actions
133 lines (110 loc) · 3.62 KB
/
admin.py
File metadata and controls
133 lines (110 loc) · 3.62 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
from datetime import datetime
from django.contrib import admin
from django.contrib.auth.models import User
from django.contrib.auth.admin import UserAdmin as DjangoUserAdmin
from apps.constants import USER_TYPE_ALIGNED_NETWORKS_BENEFICIARY, USER_TYPE_DEV
from .models import (
ValidPasswordResetKey,
UserProfile,
ActivationKey,
UserIdentificationLabel,
)
admin.site.register(ActivationKey)
admin.site.register(ValidPasswordResetKey)
class UserTypeFilter(admin.SimpleListFilter):
title = 'User type'
parameter_name = 'userprofile__type'
def lookups(self, request, model_admin):
return [
(USER_TYPE_ALIGNED_NETWORKS_BENEFICIARY, 'Beneficiary'),
(USER_TYPE_DEV, 'Developer'),
(USER_TYPE_ALIGNED_NETWORKS_BENEFICIARY, 'Aligned Network Beneficiary'),
]
def queryset(self, request, queryset):
if self.value():
return queryset.filter(userprofile__user_type=self.value())
return queryset
class ActiveAccountFilter(admin.SimpleListFilter):
title = 'User activation status'
parameter_name = 'status'
def lookups(self, request, model_admin):
return [('active', 'Active'), ('inactive_all', 'Inactive'), ('inactive_expired', 'Inactive (expired activation key)')]
def queryset(self, request, queryset):
if self.value() == 'inactive_expired':
return queryset.filter(
is_active=False,
activationkey__key_status='expired',
) | queryset.filter(
# Since the activation keys only reach "expired" status when they are
# used post-expiration, we need to check the "created" status as well
is_active=False,
activationkey__key_status='created',
activationkey__expires__lt=(datetime.today()),
)
elif self.value() == 'inactive_all':
return queryset.filter(is_active=False)
elif self.value() == 'active':
return queryset.filter(is_active=True)
class UserAdmin(DjangoUserAdmin):
list_display = (
'username',
'get_type',
'email',
'first_name',
'last_name',
'is_staff',
'is_superuser',
'is_active',
'date_joined',
)
list_filter = (
UserTypeFilter,
ActiveAccountFilter,
)
@admin.display(
description='Type',
ordering='userprofile__user_type',
)
def get_type(self, obj):
return obj.userprofile.user_type
admin.site.unregister(User)
admin.site.register(User, UserAdmin)
@admin.register(UserProfile)
class UserProfileAdmin(admin.ModelAdmin):
@admin.display(
description='Email Address',
ordering='user__email',
)
def get_user_email(self, obj):
return obj.user.email
@admin.display(
description='Date Joined',
ordering='user__date_joined',
)
def get_user_joined(self, obj):
return obj.user.date_joined
list_display = (
'user',
'name',
'user_type',
'organization_name',
'get_user_email',
'get_user_joined',
)
search_fields = (
'user__username',
'user__email',
'user__first_name',
'user__last_name',
'user_type',
'organization_name',
'user__date_joined',
)
raw_id_fields = ('user',)
@admin.register(UserIdentificationLabel)
class UserIdentificationLabelAdmin(admin.ModelAdmin):
model = UserIdentificationLabel
filter_horizontal = ('users',)
list_display = ('name', 'slug', 'weight')
list_filter = ('name', 'slug')
ordering = ('weight',)