views.py 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338
  1. from django.core.urlresolvers import reverse as django_reverse
  2. from django.db.models import Q
  3. from django.utils.translation import ugettext as _
  4. from misago.admin import site
  5. from misago.admin.widgets import *
  6. from misago.users.forms import UserForm, NewUserForm, SearchUsersForm
  7. from misago.users.models import User
  8. from misago.utils import get_random_string
  9. def reverse(route, target=None):
  10. if target:
  11. return django_reverse(route, kwargs={'target': target.pk, 'slug': target.username_slug})
  12. return django_reverse(route)
  13. """
  14. Views
  15. """
  16. class List(ListWidget):
  17. admin = site.get_action('users')
  18. id = 'list'
  19. columns=(
  20. ('username_slug', _("User Name"), 35),
  21. ('join_date', _("Join Date")),
  22. )
  23. default_sorting = 'username'
  24. sortables={
  25. 'username_slug': 1,
  26. 'join_date': 0,
  27. }
  28. pagination = 25
  29. search_form = SearchUsersForm
  30. nothing_checked_message = _('You have to check at least one user.')
  31. actions=(
  32. ('activate', _("Activate users"), _("Are you sure you want to activate selected members?")),
  33. ('deactivate', _("Request e-mail validation"), _("Are you sure you want to deactivate selected members and request them to revalidate their e-mail addresses?")),
  34. ('remove_av', _("Remove and lock avatars"), _("Are you sure you want to remove selected members avatars and their ability to change them?")),
  35. ('remove_sig', _("Remove and lock signatures"), _("Are you sure you want to remove selected members signatures and their ability to edit them?")),
  36. ('remove_locks', _("Remove locks from avatars and signatures"), _("Are you sure you want to remove locks from selected members avatars and signatures?")),
  37. ('reset', _("Reset passwords"), _("Are you sure you want to reset selected members passwords?")),
  38. ('delete', _("Delete users"), _("Are you sure you want to delete selected users?")),
  39. )
  40. def set_filters(self, model, filters):
  41. if 'role' in filters:
  42. model = model.filter(roles__in=filters['role']).distinct()
  43. if 'rank' in filters:
  44. model = model.filter(rank__in=filters['rank'])
  45. if 'username' in filters:
  46. if ',' in filters['username']:
  47. qs = None
  48. for name in filters['username'].split(','):
  49. name = name.strip().lower()
  50. if name:
  51. if qs:
  52. qs = qs | Q(username_slug__contains=name)
  53. else:
  54. qs = Q(username_slug__contains=name)
  55. if qs:
  56. model = model.filter(qs)
  57. else:
  58. model = model.filter(username_slug__contains=filters['username'])
  59. if 'email' in filters:
  60. if ',' in filters['email']:
  61. qs = None
  62. for name in filters['email'].split(','):
  63. name = name.strip().lower()
  64. if name:
  65. if qs:
  66. qs = qs | Q(email__contains=name)
  67. else:
  68. qs = Q(email__contains=name)
  69. if qs:
  70. model = model.filter(qs)
  71. else:
  72. model = model.filter(email__contains=filters['email'])
  73. if 'activation' in filters:
  74. model = model.filter(activation__in=filters['activation'])
  75. return model
  76. def prefetch_related(self, items):
  77. return items.prefetch_related('roles')
  78. def get_item_actions(self, request, item):
  79. return (
  80. self.action('pencil', _("Edit User Details"), reverse('admin_users_edit', item)),
  81. self.action('remove', _("Delete User"), reverse('admin_users_delete', item), post=True, prompt=_("Are you sure you want to delete this user account?")),
  82. )
  83. def action_activate(self, request, items, checked):
  84. for user in items:
  85. if unicode(user.pk) in checked and user.activation > 0:
  86. request.monitor['users_inactive'] = int(request.monitor['users_inactive']) - 1
  87. user.activation = user.ACTIVATION_NONE
  88. user.save(force_update=True)
  89. user.email_user(
  90. request,
  91. 'users/activation/admin_done',
  92. _("Your Account has been activated"),
  93. )
  94. return Message(_('Selected users accounts have been activated.'), 'success'), reverse('admin_users')
  95. def action_deactivate(self, request, items, checked):
  96. # First loop - check for errors
  97. for user in items:
  98. if unicode(user.pk) in checked:
  99. if user.is_protected() and not request.user.is_god():
  100. return Message(_('You cannot force validation of protected members e-mails.'), 'error'), reverse('admin_users')
  101. # Second loop - reset passwords
  102. for user in items:
  103. if unicode(user.pk) in checked:
  104. user.activation = user.ACTIVATION_USER
  105. user.token = token = get_random_string(12)
  106. user.save(force_update=True)
  107. user.email_user(
  108. request,
  109. 'users/activation/invalidated',
  110. _("Account Activation"),
  111. )
  112. return Message(_('Selected users accounts have been deactivated and new activation links have been sent to them.'), 'success'), reverse('admin_users')
  113. def action_remove_av(self, request, items, checked):
  114. # First loop - check for errors
  115. for user in items:
  116. if unicode(user.pk) in checked:
  117. if user.is_protected() and not request.user.is_god():
  118. return Message(_('You cannot remove and block protected members avatars.'), 'error'), reverse('admin_users')
  119. # Second loop - reset passwords
  120. for user in items:
  121. if unicode(user.pk) in checked:
  122. user.lock_avatar()
  123. user.save(force_update=True)
  124. return Message(_('Selected users avatars were deleted and locked.'), 'success'), reverse('admin_users')
  125. def action_remove_sig(self, request, items, checked):
  126. # First loop - check for errors
  127. for user in items:
  128. if unicode(user.pk) in checked:
  129. if user.is_protected() and not request.user.is_god():
  130. return Message(_('You cannot remove and block protected members signatures.'), 'error'), reverse('admin_users')
  131. # Second loop - reset passwords
  132. for user in items:
  133. if unicode(user.pk) in checked:
  134. user.signature_ban = True
  135. user.signature = ''
  136. user.signature_preparsed = ''
  137. user.save(force_update=True)
  138. return Message(_('Selected users signatures were deleted and locked.'), 'success'), reverse('admin_users')
  139. def action_remove_locks(self, request, items, checked):
  140. for user in items:
  141. if unicode(user.pk) in checked:
  142. user.default_avatar(request.settings)
  143. user.avatar_ban = False
  144. user.signature_ban = False
  145. user.save(force_update=True)
  146. return Message(_('Selected users can now edit their avatars and signatures.'), 'success'), reverse('admin_users')
  147. def action_reset(self, request, items, checked):
  148. # First loop - check for errors
  149. for user in items:
  150. if unicode(user.pk) in checked:
  151. if user.is_protected() and not request.user.is_god():
  152. return Message(_('You cannot reset protected members passwords.'), 'error'), reverse('admin_users')
  153. # Second loop - reset passwords
  154. for user in items:
  155. if unicode(user.pk) in checked:
  156. new_password = get_random_string(8)
  157. user.set_password(new_password)
  158. user.save(force_update=True)
  159. user.email_user(
  160. request,
  161. 'users/password/new_admin',
  162. _("Your New Password"),
  163. {
  164. 'password': new_password,
  165. },
  166. )
  167. return Message(_('Selected users passwords have been reset successfully.'), 'success'), reverse('admin_users')
  168. def action_delete(self, request, items, checked):
  169. for user in items:
  170. if unicode(user.pk) in checked:
  171. if user.pk == request.user.id:
  172. return Message(_('You cannot delete yourself.'), 'error'), reverse('admin_users')
  173. if user.is_protected():
  174. return Message(_('You cannot delete protected members.'), 'error'), reverse('admin_users')
  175. for user in items:
  176. if unicode(user.pk) in checked:
  177. user.delete()
  178. User.objects.resync_monitor(request.monitor)
  179. return Message(_('Selected users have been deleted successfully.'), 'success'), reverse('admin_users')
  180. class New(FormWidget):
  181. admin = site.get_action('users')
  182. id = 'new'
  183. fallback = 'admin_users'
  184. form = NewUserForm
  185. submit_button = _("Save User")
  186. def get_new_url(self, request, model):
  187. return reverse('admin_users_new')
  188. def get_edit_url(self, request, model):
  189. return reverse('admin_users_edit', model)
  190. def submit_form(self, request, form, target):
  191. new_user = User.objects.create_user(
  192. form.cleaned_data['username'],
  193. form.cleaned_data['email'],
  194. form.cleaned_data['password'],
  195. request.settings['default_timezone'],
  196. request.META['REMOTE_ADDR'],
  197. no_roles=True,
  198. request=request,
  199. )
  200. new_user.title = form.cleaned_data['title']
  201. new_user.rank = form.cleaned_data['rank']
  202. for role in form.cleaned_data['roles']:
  203. new_user.roles.add(role)
  204. new_user.make_acl_key()
  205. new_user.save(force_update=True)
  206. return new_user, Message(_('New User has been created.'), 'success')
  207. class Edit(FormWidget):
  208. admin = site.get_action('users')
  209. id = 'edit'
  210. name = _("Edit User")
  211. fallback = 'admin_users'
  212. form = UserForm
  213. tabbed = True
  214. target_name = 'username'
  215. notfound_message = _('Requested User could not be found.')
  216. submit_fallback = True
  217. def get_form_instance(self, form, request, model, initial, post=False):
  218. if post:
  219. return form(model, request.POST, request=request, initial=self.get_initial_data(request, model))
  220. return form(model, request=request, initial=self.get_initial_data(request, model))
  221. def get_url(self, request, model):
  222. return reverse('admin_users_edit', model)
  223. def get_edit_url(self, request, model):
  224. return self.get_url(request, model)
  225. def get_initial_data(self, request, model):
  226. return {
  227. 'username': model.username,
  228. 'title': model.title,
  229. 'email': model.email,
  230. 'rank': model.rank,
  231. 'roles': model.roles.all(),
  232. 'avatar_ban': model.avatar_ban,
  233. 'avatar_ban_reason_user': model.avatar_ban_reason_user,
  234. 'avatar_ban_reason_admin': model.avatar_ban_reason_admin,
  235. 'signature': model.signature,
  236. 'signature_ban': model.signature_ban,
  237. 'signature_ban_reason_user': model.signature_ban_reason_user,
  238. 'signature_ban_reason_admin': model.signature_ban_reason_admin,
  239. }
  240. def submit_form(self, request, form, target):
  241. target.title = form.cleaned_data['title']
  242. target.rank = form.cleaned_data['rank']
  243. target.avatar_ban_reason_user = form.cleaned_data['avatar_ban_reason_user']
  244. target.avatar_ban_reason_admin = form.cleaned_data['avatar_ban_reason_admin']
  245. target.set_signature(form.cleaned_data['signature'])
  246. target.signature_ban = form.cleaned_data['signature_ban']
  247. target.signature_ban_reason_user = form.cleaned_data['signature_ban_reason_user']
  248. target.signature_ban_reason_admin = form.cleaned_data['signature_ban_reason_admin']
  249. # Do avatar ban mumbo-jumbo
  250. if target.avatar_ban != form.cleaned_data['avatar_ban']:
  251. if form.cleaned_data['avatar_ban']:
  252. target.lock_avatar()
  253. else:
  254. target.default_avatar(request.settings)
  255. target.avatar_ban = form.cleaned_data['avatar_ban']
  256. # Set custom avatar
  257. if form.cleaned_data['avatar_custom']:
  258. target.delete_avatar()
  259. target.avatar_image = form.cleaned_data['avatar_custom']
  260. target.avatar_type = 'gallery'
  261. # Update user roles
  262. if request.user.is_god():
  263. target.roles.clear()
  264. for role in form.cleaned_data['roles']:
  265. target.roles.add(role)
  266. else:
  267. for role in target.roles.all():
  268. if not role.protected:
  269. target.roles.remove(role)
  270. for role in form.cleaned_data['roles']:
  271. target.roles.add(role)
  272. target.make_acl_key()
  273. target.save(force_update=True)
  274. return target, Message(_('Changes in user\'s "%(name)s" account have been saved.') % {'name': self.original_name}, 'success')
  275. class Delete(ButtonWidget):
  276. admin = site.get_action('users')
  277. id = 'delete'
  278. fallback = 'admin_users'
  279. notfound_message = _('Requested User account could not be found.')
  280. def action(self, request, target):
  281. if target.pk == request.user.id:
  282. return Message(_('You cannot delete yourself.'), 'error'), False
  283. if target.is_protected():
  284. return Message(_('You cannot delete protected member.'), 'error'), False
  285. target.delete()
  286. User.objects.resync_monitor(request.monitor)
  287. return Message(_('User "%(name)s" has been deleted.') % {'name': target.username}, 'success'), False
  288. def inactive(request):
  289. token = 'list_filter_misago.users.models.User'
  290. request.session[token] = {'activation': ['1', '2', '3']}
  291. return redirect(reverse('admin_users'))