Découpler un peu les chercheurs et l'authentification Django
[auf_savoirs_en_partage_django.git] / auf_savoirs_en_partage / chercheurs / views.py
CommitLineData
588d6b93 1# -*- encoding: utf-8 -*-
518d0b44 2from chercheurs.decorators import chercheur_required
43ed73e7
EMS
3from chercheurs.forms import RepertoireSearchForm, SetPasswordForm, ChercheurFormGroup
4from chercheurs.models import Chercheur
695930dd 5from chercheurs.utils import get_django_user_for_email
43ed73e7 6from datamaster_modeles.models import Etablissement
932eef9a 7from django.shortcuts import render_to_response
0e9597af 8from django.http import HttpResponseRedirect, HttpResponse
932eef9a 9from django.template import Context, RequestContext
e427f068 10from django.template.loader import get_template
51515982 11from django.core.urlresolvers import reverse as url
0e9597af 12from django.core.mail import send_mail
43ed73e7 13from django.contrib.sites.models import RequestSite
219710da 14from django.utils import simplejson
43ed73e7 15from django.utils.http import int_to_base36, base36_to_int
a7b16ec9 16from django.views.decorators.cache import never_cache
72923b8e 17from django.contrib.auth import authenticate, login
3eb00212 18from django.shortcuts import get_object_or_404
510b5321 19
f0692c02 20def index(request):
f8c16b3d 21 """Répertoire des chercheurs"""
f0692c02 22 search_form = RepertoireSearchForm(request.GET)
13ec4813 23 chercheurs = search_form.get_query_set().select_related('etablissement')
7020ea3d
EMS
24 sort = request.GET.get('tri')
25 if sort is not None and sort.endswith('_desc'):
26 sort = sort[:-5]
27 direction = '-'
28 else:
29 direction = ''
30 if sort == 'nom':
acd5cd8f 31 chercheurs = chercheurs.order_by_nom(direction)
7020ea3d 32 elif sort == 'etablissement':
acd5cd8f 33 chercheurs = chercheurs.order_by_etablissement(direction)
7020ea3d 34 elif sort == 'pays':
acd5cd8f 35 chercheurs = chercheurs.order_by_pays(direction)
7020ea3d
EMS
36 else:
37 chercheurs = chercheurs.order_by('-date_modification')
38
9f7c169e 39 nb_chercheurs = chercheurs.count()
3efbacbe 40 return render_to_response("chercheurs/index.html",
e9b0d630 41 dict(chercheurs=chercheurs, nb_chercheurs=nb_chercheurs, search_form=search_form),
3efbacbe 42 context_instance=RequestContext(request))
588d6b93 43
f0692c02 44def inscription(request):
932eef9a 45 if request.method == 'POST':
a7b16ec9
EMS
46 forms = ChercheurFormGroup(request.POST)
47 if forms.is_valid():
43ed73e7
EMS
48 chercheur = forms.save()
49 id_base36 = int_to_base36(chercheur.id)
50 token = chercheur.activation_token()
51 template = get_template('chercheurs/activation_email.txt')
52 domain = RequestSite(request).domain
53 message = template.render(Context(dict(chercheur=chercheur, id_base36=id_base36, token=token, domain=domain)))
54 send_mail('Votre inscription à Savoirs en partage', message, None, [chercheur.courriel])
55 return HttpResponseRedirect(url('chercheurs-inscription-faite'))
932eef9a 56 else:
a7b16ec9 57 forms = ChercheurFormGroup()
932eef9a 58
a7b16ec9
EMS
59 return render_to_response("chercheurs/inscription.html",
60 dict(forms=forms),
61 context_instance=RequestContext(request))
9af73c99 62
43ed73e7
EMS
63def activation(request, id_base36, token):
64 """Activation d'un chercheur"""
65 id = base36_to_int(id_base36)
66 chercheur = get_object_or_404(Chercheur, id=id)
67 if token == chercheur.activation_token():
68 validlink = True
69 if request.method == 'POST':
70 form = SetPasswordForm(request.POST)
71 if form.is_valid():
72 password = form.cleaned_data['password']
73 email = chercheur.courriel
74 chercheur.actif = True
75 chercheur.save()
695930dd
EMS
76 user = get_django_user_for_email(email)
77 user.set_password(password)
78 user.save()
43ed73e7
EMS
79
80 # Auto-login
81 login(request, authenticate(username=email, password=password))
82 return HttpResponseRedirect(url('chercheurs.views.perso'))
83 else:
84 form = SetPasswordForm()
85 else:
86 form = None
87 validlink = False
88 return render_to_response('chercheurs/activation.html', dict(form=form, validlink=validlink),
89 context_instance=RequestContext(request))
90
518d0b44 91@chercheur_required
8baa2a56
EMS
92def desinscription(request):
93 """Désinscription du chercheur"""
518d0b44 94 chercheur = request.chercheur
8baa2a56
EMS
95 if request.method == 'POST':
96 if request.POST.get('confirmer'):
13ec4813
EMS
97 chercheur.actif = False
98 chercheur.save()
8baa2a56
EMS
99 request.flash['message'] = "Vous avez été désinscrit du répertoire des chercheurs."
100 return HttpResponseRedirect(url('django.contrib.auth.views.logout'))
101 else:
102 request.flash['message'] = "Opération annulée."
103 return HttpResponseRedirect(url('chercheurs.views.perso'))
104 return render_to_response("chercheurs/desinscription.html", {},
105 context_instance=RequestContext(request))
106
518d0b44 107@chercheur_required
a7b16ec9 108@never_cache
f0692c02 109def edit(request):
b3e1079e 110 """Edition d'un chercheur"""
518d0b44 111 chercheur = request.chercheur
b3e1079e 112 if request.method == 'POST':
a7b16ec9
EMS
113 forms = ChercheurFormGroup(request.POST, chercheur=chercheur)
114 if forms.is_valid():
115 forms.save()
91112855
EMS
116 request.flash['message'] = "Votre fiche a bien été enregistrée."
117 return HttpResponseRedirect(url('chercheurs.views.perso'))
b3e1079e 118 else:
a7b16ec9 119 forms = ChercheurFormGroup(chercheur=chercheur)
b3e1079e 120
a7b16ec9
EMS
121 return render_to_response("chercheurs/edit.html",
122 dict(forms=forms, chercheur=chercheur),
595ab4d6 123 context_instance=RequestContext(request))
b3e1079e 124
518d0b44 125@chercheur_required
f0692c02 126def perso(request):
0d9d1c4d 127 """Espace chercheur (espace personnel du chercheur)"""
518d0b44 128 chercheur = request.chercheur
2a36714f 129 modification = request.GET.get('modification')
e4d01d1d
EMS
130 return render_to_response("chercheurs/perso.html",
131 dict(chercheur=chercheur, modification=modification),
518d0b44 132 context_instance=RequestContext(request))
da091176 133
f0692c02 134def retrieve(request, id):
da091176 135 """Fiche du chercheur"""
3eb00212 136 chercheur = get_object_or_404(Chercheur, id=id)
e4d01d1d
EMS
137 return render_to_response("chercheurs/retrieve.html",
138 dict(chercheur=chercheur),
c1b134f8 139 context_instance=RequestContext(request))
d9885bf7 140
f0692c02 141def conversion(request):
c1b134f8
EMS
142 return render_to_response("chercheurs/conversion.html", {},
143 context_instance=RequestContext(request))
8baa2a56 144
e836f6f7 145def etablissements_autocomplete(request, pays=None):
219710da 146 term = request.GET.get('term')
73915492 147 noms = Etablissement.objects.all().filter(membre=True)
e836f6f7
EMS
148 for word in term.split():
149 noms = noms.filter(nom__icontains=word)
150 if pays:
151 noms = noms.filter(pays=pays)
152 noms = list(noms.values_list('nom', flat=True)[:20])
219710da
EMS
153 json = simplejson.dumps(noms)
154 return HttpResponse(json, mimetype='application/json')