Overwrite _getSurveyRecordFor in ProjectSurvey view to take StudentProject into account.
authorLennard de Rijk <ljvderijk@gmail.com>
Fri, 03 Jul 2009 12:02:57 +0200
changeset 2498 fd51f2159bff
parent 2497 996f381d458c
child 2499 62e8f6e45d9a
Overwrite _getSurveyRecordFor in ProjectSurvey view to take StudentProject into account.
app/soc/views/models/project_survey.py
--- a/app/soc/views/models/project_survey.py	Fri Jul 03 12:00:53 2009 +0200
+++ b/app/soc/views/models/project_survey.py	Fri Jul 03 12:02:57 2009 +0200
@@ -106,6 +106,32 @@
     return super(View, self).take(request, 'any_access', page_name=page_name,
                                   params=params, **kwargs)
 
+  def _getSurveyRecordFor(self, survey, request, params):
+    """Returns the SurveyRecord for the given Survey and request.
+
+    This method also take the StudentProject specified as GET param into
+    account when querying for the SurveyRecord.
+
+    For params see base.View._getSurveyRecordFor().
+    """
+
+    from soc.logic.models.student_project import logic as student_project_logic
+
+    survey_logic = params['logic']
+    record_logic = survey_logic.getRecordLogic()
+
+    user_entity = user_logic.getForCurrentAccount()
+
+    # get the StudentProject specified in the GET params
+    project_key_name = request.GET['project']
+    project_entity = student_project_logic.getFromKeyName(project_key_name)
+
+    filter = {'survey': survey,
+              'user': user_entity,
+              'project': project_entity}
+
+    return record_logic.getForFields(filter, unique=True)
+
   def _takeGet(self, request, template, context, params, entity, record,
               **kwargs):
     """Hooking into the view for the take's page GET request.