admin.py 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264
  1. # -*- coding: utf-8 -*-
  2. from __future__ import unicode_literals
  3. from django.shortcuts import render, get_object_or_404
  4. from django.contrib import admin
  5. from django.contrib import messages
  6. from django.contrib.auth.admin import UserAdmin
  7. from django.contrib.auth.models import Group, Permission
  8. from django.http import HttpResponseRedirect
  9. from django.conf.urls import url
  10. from django.db.models.query import QuerySet
  11. from django.core.urlresolvers import reverse
  12. from django.utils.html import format_html
  13. from coin.members.models import (
  14. Member, CryptoKey, LdapUser, MembershipFee, Offer, OfferSubscription, RowLevelPermission)
  15. from coin.members.membershipfee_filter import MembershipFeeFilter
  16. from coin.members.forms import AdminMemberChangeForm, MemberCreationForm
  17. from coin.utils import delete_selected
  18. import autocomplete_light
  19. class CryptoKeyInline(admin.StackedInline):
  20. model = CryptoKey
  21. extra = 0
  22. class MembershipFeeInline(admin.TabularInline):
  23. model = MembershipFee
  24. extra = 0
  25. fields = ('start_date', 'end_date', 'amount', 'payment_method',
  26. 'reference', 'payment_date')
  27. class OfferSubscriptionInline(admin.TabularInline):
  28. model = OfferSubscription
  29. extra = 0
  30. writable_fields = ('subscription_date', 'resign_date', 'commitment', 'offer')
  31. all_fields = ('get_subscription_reference',) + writable_fields
  32. def get_fields(self, request, obj=None):
  33. if obj:
  34. return self.all_fields
  35. else:
  36. return self.writable_fields
  37. def get_readonly_fields(self, request, obj=None):
  38. # création ou superuser : lecture écriture
  39. if not obj or request.user.is_superuser:
  40. return ('get_subscription_reference',)
  41. # modification : lecture seule seulement
  42. else:
  43. return self.all_fields
  44. show_change_link = True
  45. def formfield_for_foreignkey(self, db_field, request, **kwargs):
  46. if request.user.is_superuser:
  47. return super(OfferSubscriptionInline, self).formfield_for_foreignkey(db_field, request, **kwargs)
  48. else:
  49. if db_field.name == "offer":
  50. kwargs["queryset"] = RowLevelPermission.get_manageable_offers(request.user)
  51. return super(OfferSubscriptionInline, self).formfield_for_foreignkey(db_field, request, **kwargs)
  52. # pas très beau
  53. # quand on créer un membre on autorise à ajouter un abonnement
  54. # sinon seulement en lecture seule (sinon ça permettrait de changer les abo qu'on n'a pas le droit de toucher)
  55. def has_add_permission(self, request):
  56. if request.path.split('/')[-2] == 'add':
  57. return True
  58. else:
  59. return request.user.is_superuser
  60. # sinon on pourrait supprimer les abo qu'on ne peut pas gérer
  61. def has_delete_permission(self, request, obj=None):
  62. return request.user.is_superuser
  63. class MemberAdmin(UserAdmin):
  64. list_display = ('id', 'status', 'username', 'first_name', 'last_name',
  65. 'nickname', 'organization_name', 'email',
  66. 'end_date_of_membership')
  67. list_display_links = ('id', 'username', 'first_name', 'last_name')
  68. list_filter = ('status', MembershipFeeFilter)
  69. search_fields = ['username', 'first_name', 'last_name', 'email', 'nickname']
  70. ordering = ('status', 'username')
  71. actions = [delete_selected, 'set_as_member', 'set_as_non_member',
  72. 'bulk_send_welcome_email', 'bulk_send_call_for_membership_fee_email']
  73. form = AdminMemberChangeForm
  74. add_form = MemberCreationForm
  75. def get_fieldsets(self, request, obj=None):
  76. coord_fieldset = ('Coordonnées', {'fields': (
  77. ('email', 'send_membership_fees_email'),
  78. ('home_phone_number', 'mobile_phone_number'),
  79. 'address',
  80. ('postal_code', 'city', 'country'))})
  81. auth_fieldset = ('Authentification', {'fields': (
  82. ('username', 'password'))})
  83. perm_fieldset = ('Permissions', {'fields': (
  84. ('is_active', 'is_staff', 'is_superuser', 'groups'))})
  85. # if obj is null then it is a creation, otherwise it is a modification
  86. if obj:
  87. return (
  88. ('Adhérent', {'fields': (
  89. ('status', 'date_joined', 'resign_date'),
  90. 'type',
  91. ('first_name', 'last_name', 'nickname'),
  92. 'organization_name',
  93. 'comments',
  94. 'balance' # XXX we shouldn't need this, the default value should be used
  95. )}),
  96. coord_fieldset,
  97. auth_fieldset,
  98. perm_fieldset,
  99. (None, {'fields': ('date_last_call_for_membership_fees_email',)})
  100. )
  101. else:
  102. return (
  103. ('Adhérent', {'fields': (
  104. ('status', 'date_joined'),
  105. 'type',
  106. ('first_name', 'last_name', 'nickname'),
  107. 'organization_name',
  108. 'comments',
  109. 'balance')}),
  110. coord_fieldset,
  111. auth_fieldset,
  112. perm_fieldset
  113. )
  114. radio_fields = {"type": admin.HORIZONTAL}
  115. save_on_top = True
  116. inlines = [CryptoKeyInline, MembershipFeeInline, OfferSubscriptionInline]
  117. def get_queryset(self, request):
  118. qs = super(MemberAdmin, self).get_queryset(request)
  119. if request.user.is_superuser:
  120. return qs
  121. else:
  122. offers = RowLevelPermission.get_manageable_offers(request.user)
  123. return qs.filter(offersubscription__offer__in=offers).distinct()
  124. def get_readonly_fields(self, request, obj=None):
  125. readonly_fields = []
  126. if obj:
  127. # Remove help_text for readonly field (can't do that in the Form
  128. # django seems to user help_text from model for readonly fields)
  129. username_field = [
  130. f for f in obj._meta.fields if f.name == 'username']
  131. username_field[0].help_text = ''
  132. readonly_fields.append('username')
  133. if not request.user.is_superuser:
  134. readonly_fields += ['is_active', 'is_staff', 'is_superuser', 'groups', 'date_last_call_for_membership_fees_email']
  135. return readonly_fields
  136. def set_as_member(self, request, queryset):
  137. rows_updated = queryset.update(status='member')
  138. self.message_user(
  139. request,
  140. '%d membre(s) définis comme adhérent(s).' % rows_updated)
  141. set_as_member.short_description = 'Définir comme adhérent'
  142. def set_as_non_member(self, request, queryset):
  143. rows_updated = queryset.update(status='not_member')
  144. self.message_user(
  145. request,
  146. '%d membre(s) définis comme non adhérent(s).' % rows_updated)
  147. set_as_non_member.short_description = "Définir comme non adhérent"
  148. def get_urls(self):
  149. """Custom admin urls"""
  150. urls = super(MemberAdmin, self).get_urls()
  151. my_urls = [
  152. url(r'^send_welcome_email/(?P<id>\d+)$',
  153. self.admin_site.admin_view(self.send_welcome_email),
  154. name='send_welcome_email'),
  155. ]
  156. return my_urls + urls
  157. def send_welcome_email(self, request, id, return_httpredirect=True):
  158. """
  159. Vue appelée lorsque l'admin souhaite envoyer l'email de bienvenue à un
  160. membre.
  161. """
  162. # TODO : Add better perm here
  163. if request.user.is_superuser:
  164. member = get_object_or_404(Member, pk=id)
  165. member.send_welcome_email()
  166. messages.success(request,
  167. 'Le courriel de bienvenue a été envoyé à %s' % member.email)
  168. else:
  169. messages.error(
  170. request, 'Vous n\'avez pas l\'autorisation d\'envoyer des '
  171. 'courriels de bienvenue.')
  172. if return_httpredirect:
  173. return HttpResponseRedirect(reverse('admin:members_member_changelist'))
  174. def bulk_send_welcome_email(self, request, queryset):
  175. """
  176. Action appelée lorsque l'admin souhaite envoyer un lot d'email de bienvenue
  177. depuis une sélection de membre dans la vue liste de l'admin
  178. """
  179. for member in queryset.all():
  180. self.send_welcome_email(
  181. request, member.id, return_httpredirect=False)
  182. messages.success(request,
  183. 'Le courriel de bienvenue a été envoyé à %d membre(s).' % queryset.count())
  184. bulk_send_welcome_email.short_description = "Envoyer le courriel de bienvenue"
  185. def bulk_send_call_for_membership_fee_email(self, request, queryset):
  186. # TODO : Add better perm here
  187. if not request.user.is_superuser:
  188. messages.error(
  189. request, 'Vous n\'avez pas l\'autorisation d\'envoyer des '
  190. 'courriels de relance.')
  191. return
  192. cpt_success = 0
  193. for member in queryset.all():
  194. if member.send_call_for_membership_fees_email():
  195. cpt_success += 1
  196. else:
  197. messages.warning(request,
  198. "Le courriel de relance de cotisation n\'a pas "
  199. "été envoyé à {member} ({email}) car il a déjà "
  200. "reçu une relance le {last_call_date}"\
  201. .format(member=member,
  202. email=member.email,
  203. last_call_date=member.date_last_call_for_membership_fees_email))
  204. if queryset.count() == 1 and cpt_success == 1:
  205. member = queryset.first()
  206. messages.success(request,
  207. "Le courriel de relance de cotisation a été "
  208. "envoyé à {member} ({email})"\
  209. .format(member=member, email=member.email))
  210. elif cpt_success>1:
  211. messages.success(request,
  212. "Le courriel de relance de cotisation a été "
  213. "envoyé à {cpt} membres"\
  214. .format(cpt=cpt_success))
  215. bulk_send_call_for_membership_fee_email.short_description = 'Envoyer le courriel de relance de cotisation'
  216. class MembershipFeeAdmin(admin.ModelAdmin):
  217. list_display = ('member', 'end_date', 'amount', 'payment_method',
  218. 'payment_date')
  219. form = autocomplete_light.modelform_factory(MembershipFee, fields='__all__')
  220. admin.site.register(Member, MemberAdmin)
  221. admin.site.register(MembershipFee, MembershipFeeAdmin)
  222. # admin.site.unregister(Group)
  223. # admin.site.register(LdapUser, LdapUserAdmin)
  224. admin.site.register(RowLevelPermission)