|
1 | 1 | from django.conf import settings |
2 | 2 | from django import forms |
3 | 3 | from django.contrib.formtools.preview import FormPreview |
4 | | -from django.http import HttpResponseRedirect, HttpResponseForbidden |
| 4 | +from django.http import HttpResponseRedirect |
5 | 5 | from django.shortcuts import get_object_or_404 |
6 | 6 | from django.core.urlresolvers import reverse |
7 | 7 | from django.template.loader import render_to_string |
| 8 | +from django.utils.decorators import method_decorator |
8 | 9 |
|
9 | 10 | from ietf.utils import unaccent |
10 | 11 | from ietf.utils.mail import send_mail |
11 | | -from ietf.ietfauth.decorators import has_role |
| 12 | +from ietf.ietfauth.decorators import role_required |
12 | 13 | from ietf.utils import fields as custom_fields |
13 | 14 | from ietf.group.models import Group, Role |
14 | 15 | from ietf.name.models import RoleName, FeedbackType |
|
17 | 18 | Position, Feedback |
18 | 19 | from ietf.nomcom.utils import QUESTIONNAIRE_TEMPLATE, NOMINATION_EMAIL_TEMPLATE, \ |
19 | 20 | INEXISTENT_PERSON_TEMPLATE, NOMINEE_EMAIL_TEMPLATE |
| 21 | +from ietf.nomcom.decorators import member_required |
20 | 22 |
|
21 | 23 | ROLODEX_URL = getattr(settings, 'ROLODEX_URL', None) |
22 | 24 |
|
@@ -50,23 +52,21 @@ def get_fieldsets(self): |
50 | 52 | yield fieldset_dict |
51 | 53 |
|
52 | 54 |
|
53 | | -class EditMembersForm(forms.Form): |
| 55 | +class EditMembersForm(BaseNomcomForm, forms.Form): |
54 | 56 |
|
55 | 57 | members = custom_fields.MultiEmailField(label="Members email", required=False) |
56 | 58 |
|
| 59 | + fieldsets = [('Members', ('members',))] |
| 60 | + |
57 | 61 |
|
58 | 62 | class EditMembersFormPreview(FormPreview): |
59 | 63 | form_template = 'nomcom/edit_members.html' |
60 | 64 | preview_template = 'nomcom/edit_members_preview.html' |
61 | 65 |
|
| 66 | + @method_decorator(member_required(role='chair')) |
62 | 67 | def __call__(self, request, *args, **kwargs): |
63 | 68 | year = kwargs['year'] |
64 | 69 | group = get_group_or_404(year) |
65 | | - is_group_chair = group.is_chair(request.user) |
66 | | - is_secretariat = has_role(request.user, "Secretariat") |
67 | | - if not is_secretariat and not is_group_chair: |
68 | | - return HttpResponseForbidden("Must be a secretariat or group chair") |
69 | | - |
70 | 70 | self.state['group'] = group |
71 | 71 | self.state['rolodex_url'] = ROLODEX_URL |
72 | 72 | self.group = group |
@@ -115,23 +115,22 @@ def done(self, request, cleaned_data): |
115 | 115 | return HttpResponseRedirect(reverse('edit_members', kwargs={'year': self.year})) |
116 | 116 |
|
117 | 117 |
|
118 | | -class EditChairForm(forms.Form): |
| 118 | +class EditChairForm(BaseNomcomForm, forms.Form): |
119 | 119 |
|
120 | 120 | chair = forms.EmailField(label="Chair email", required=False, |
121 | 121 | widget=forms.TextInput(attrs={'size': '40'})) |
122 | 122 |
|
| 123 | + fieldsets = [('Chair info', ('chair',))] |
| 124 | + |
123 | 125 |
|
124 | 126 | class EditChairFormPreview(FormPreview): |
125 | 127 | form_template = 'nomcom/edit_chair.html' |
126 | 128 | preview_template = 'nomcom/edit_chair_preview.html' |
127 | 129 |
|
| 130 | + @method_decorator(role_required("Secretariat")) |
128 | 131 | def __call__(self, request, *args, **kwargs): |
129 | 132 | year = kwargs['year'] |
130 | 133 | group = get_group_or_404(year) |
131 | | - is_secretariat = has_role(request.user, "Secretariat") |
132 | | - if not is_secretariat: |
133 | | - return HttpResponseForbidden("Must be a secretariat") |
134 | | - |
135 | 134 | self.state['group'] = group |
136 | 135 | self.state['rolodex_url'] = ROLODEX_URL |
137 | 136 | self.group = group |
@@ -171,12 +170,17 @@ def done(self, request, cleaned_data): |
171 | 170 | return HttpResponseRedirect(reverse('edit_chair', kwargs={'year': self.year})) |
172 | 171 |
|
173 | 172 |
|
174 | | -class EditPublicKeyForm(forms.ModelForm): |
175 | | - fieldsets = [('Edit the public key of NomCom', ('public_key',))] |
| 173 | +class EditPublicKeyForm(BaseNomcomForm, forms.ModelForm): |
| 174 | + |
| 175 | + fieldsets = [('Public Key', ('public_key',))] |
176 | 176 |
|
177 | 177 | class Meta: |
178 | 178 | model = NomCom |
179 | 179 |
|
| 180 | + def __init__(self, *args, **kwargs): |
| 181 | + super(EditPublicKeyForm, self).__init__(*args, **kwargs) |
| 182 | + self.fields['public_key'].required = True |
| 183 | + |
180 | 184 |
|
181 | 185 | class NominateForm(BaseNomcomForm, forms.ModelForm): |
182 | 186 | comments = forms.CharField(label='Comments', widget=forms.Textarea()) |
|
0 commit comments