Commit 415f147d367c83894bf5bcf1aca9c36c07a86782
1 parent
29ad99c6
Exists in
master
and in
5 other branches
Fixing professor permissions and relation error
Showing
2 changed files
with
28 additions
and
24 deletions
Show diff stats
courses/templates/course/view.html
| ... | ... | @@ -28,7 +28,7 @@ |
| 28 | 28 | </div> |
| 29 | 29 | </div> |
| 30 | 30 | |
| 31 | -{% if user|has_role:'professor' or user|has_role:'system_admin' %} | |
| 31 | +{% if user|has_role:'professor' and user in course.professors or user|has_role:'system_admin' %} | |
| 32 | 32 | |
| 33 | 33 | <div class="panel panel-primary navigation"> |
| 34 | 34 | <div class="panel-heading"> |
| ... | ... | @@ -56,7 +56,7 @@ |
| 56 | 56 | <div class="col-xs-8 col-md-10 titleTopic"> |
| 57 | 57 | <h4>{{course}}</h4> |
| 58 | 58 | </div> |
| 59 | - {% if user|has_role:'professor' or user|has_role:'system_admin' %} | |
| 59 | + {% if user|has_role:'professor' and user in course.professors or user|has_role:'system_admin' %} | |
| 60 | 60 | <div class="col-xs-4 col-md-2" id="divMoreActions"> |
| 61 | 61 | <div class="btn-group"> |
| 62 | 62 | <button class="btn btn-default btn-sm dropdown-toggle" type="button" id="moreActions" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false"> |
| ... | ... | @@ -199,17 +199,19 @@ |
| 199 | 199 | <h4 style="color:white">{{subject.name}}</h4> |
| 200 | 200 | </a> |
| 201 | 201 | </div> |
| 202 | - <div class="col-xs-3 col-md-2" id="divMoreActions"> | |
| 203 | - <div class="btn-group"> | |
| 204 | - <button class="btn btn-default btn-sm dropdown-toggle" type="button" id="moreActions" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false"> | |
| 205 | - <i class="fa fa-ellipsis-v fa-2x" aria-hidden="true"></i> | |
| 206 | - </button> | |
| 207 | - <ul class="dropdown-menu" aria-labelledby="moreActions"> | |
| 208 | - <li><a href="javascript:void(0)" data-toggle="modal" data-target="#myModal3"><i class="fa fa-pencil fa-fw" aria-hidden="true"></i> Replicate</a></li> | |
| 209 | - <li><a href="javascript:void(0)" data-toggle="modal" data-target="#removeSubject2"><i class="fa fa-trash fa-fw" aria-hidden="true"></i> Remove</a></li> | |
| 210 | - </ul> | |
| 202 | + {% if user|has_role:'professor' and user in subject.professors or user|has_role:'system_admin' %} | |
| 203 | + <div class="col-xs-3 col-md-2" id="divMoreActions"> | |
| 204 | + <div class="btn-group"> | |
| 205 | + <button class="btn btn-default btn-sm dropdown-toggle" type="button" id="moreActions" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false"> | |
| 206 | + <i class="fa fa-ellipsis-v fa-2x" aria-hidden="true"></i> | |
| 207 | + </button> | |
| 208 | + <ul class="dropdown-menu" aria-labelledby="moreActions"> | |
| 209 | + <li><a href="javascript:void(0)" data-toggle="modal" data-target="#myModal3"><i class="fa fa-pencil fa-fw" aria-hidden="true"></i> Replicate</a></li> | |
| 210 | + <li><a href="javascript:void(0)" data-toggle="modal" data-target="#removeSubject2"><i class="fa fa-trash fa-fw" aria-hidden="true"></i> Remove</a></li> | |
| 211 | + </ul> | |
| 212 | + </div> | |
| 211 | 213 | </div> |
| 212 | - </div> | |
| 214 | + {% endif %} | |
| 213 | 215 | </div> |
| 214 | 216 | </div> |
| 215 | 217 | <div class="panel-body"> |
| ... | ... | @@ -244,17 +246,19 @@ |
| 244 | 246 | <h4 style="color:white">{{subject.name}}</h4> |
| 245 | 247 | </a> |
| 246 | 248 | </div> |
| 247 | - <div class="col-xs-3 col-md-2" id="divMoreActions"> | |
| 248 | - <div class="btn-group"> | |
| 249 | - <button class="btn btn-default btn-sm dropdown-toggle" type="button" id="moreActions" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false"> | |
| 250 | - <i class="fa fa-ellipsis-v fa-2x" aria-hidden="true"></i> | |
| 251 | - </button> | |
| 252 | - <ul class="dropdown-menu" aria-labelledby="moreActions"> | |
| 253 | - <li><a href="javascript:void(0)" data-toggle="modal" data-target="#myModal3"><i class="fa fa-pencil fa-fw" aria-hidden="true"></i> Replicate</a></li> | |
| 254 | - <li><a href="javascript:void(0)" data-toggle="modal" data-target="#removeSubject2"><i class="fa fa-trash fa-fw" aria-hidden="true"></i> Remove</a></li> | |
| 255 | - </ul> | |
| 249 | + {% if user|has_role:'professor' and user in subject.professors or user|has_role:'system_admin' %} | |
| 250 | + <div class="col-xs-3 col-md-2" id="divMoreActions"> | |
| 251 | + <div class="btn-group"> | |
| 252 | + <button class="btn btn-default btn-sm dropdown-toggle" type="button" id="moreActions" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false"> | |
| 253 | + <i class="fa fa-ellipsis-v fa-2x" aria-hidden="true"></i> | |
| 254 | + </button> | |
| 255 | + <ul class="dropdown-menu" aria-labelledby="moreActions"> | |
| 256 | + <li><a href="javascript:void(0)" data-toggle="modal" data-target="#myModal3"><i class="fa fa-pencil fa-fw" aria-hidden="true"></i> Replicate</a></li> | |
| 257 | + <li><a href="javascript:void(0)" data-toggle="modal" data-target="#removeSubject2"><i class="fa fa-trash fa-fw" aria-hidden="true"></i> Remove</a></li> | |
| 258 | + </ul> | |
| 259 | + </div> | |
| 256 | 260 | </div> |
| 257 | - </div> | |
| 261 | + {% endif %} | |
| 258 | 262 | </div> |
| 259 | 263 | </div> |
| 260 | 264 | <div class="panel-body"> |
| ... | ... | @@ -281,7 +285,7 @@ |
| 281 | 285 | {% endfor %} |
| 282 | 286 | {% endif %} |
| 283 | 287 | |
| 284 | -{% if user|has_role:'professor' or user|has_role:'system_admin' %} | |
| 288 | +{% if user|has_role:'professor' and user in course.professors or user|has_role:'system_admin' %} | |
| 285 | 289 | |
| 286 | 290 | <div class="form-group"> |
| 287 | 291 | <a href="{% url 'course:create_subject' course.slug %}" data-toggle="modal" data-target="" class="btn btn-primary btn-lg btn-block btn-raised">{% trans 'Create Subject' %}<div class="ripple-container"></div></a> | ... | ... |
courses/views.py
| ... | ... | @@ -187,7 +187,7 @@ class CourseView(LoginRequiredMixin, NotificationMixin, generic.DetailView): |
| 187 | 187 | if has_role(self.request.user,'system_admin'): |
| 188 | 188 | courses = Course.objects.all() |
| 189 | 189 | elif has_role(self.request.user,'professor'): |
| 190 | - courses = self.request.user.courses.all() | |
| 190 | + courses = self.request.user.courses_professors.all() | |
| 191 | 191 | elif has_role(self.request.user, 'student'): |
| 192 | 192 | courses = self.request.user.courses_student.all() |
| 193 | 193 | ... | ... |