Added getRankerFor method to student_proposal logic.
authorLennard de Rijk <ljvderijk@gmail.com>
Tue, 10 Mar 2009 19:06:16 +0000 (2009-03-10)
changeset 1786 d9694a1f1a56
parent 1785 d7c5112b1d44
child 1787 b623d96bc830
Added getRankerFor method to student_proposal logic. Patch by: Lennard de Rijk Reviewed by: to-be-reviewed
app/soc/logic/models/student_proposal.py
--- a/app/soc/logic/models/student_proposal.py	Tue Mar 10 15:53:26 2009 +0000
+++ b/app/soc/logic/models/student_proposal.py	Tue Mar 10 19:06:16 2009 +0000
@@ -24,7 +24,6 @@
 
 from soc.logic.models import base
 from soc.logic.models import student as student_logic
-from soc.logic.models.ranker_root import logic as ranker_root_logic
 from soc.models import student_proposal
 
 import soc.models.linkable
@@ -44,15 +43,32 @@
     super(Logic, self).__init__(model=model, base_model=base_model,
                                 scope_logic=scope_logic)
 
+
+  def getRankerFor(self, entity):
+    """Returns the ranker for the given Student Proposal.
+
+    Args:
+      entity: Student Proposal entity for which the ranker should be returned
+
+    Returns:
+      Ranker object which is used to rank the given entity
+    """
+
+    from soc.logic.models.ranker_root import logic as ranker_root_logic
+
+    fields = {'link_id': student_proposal.DEF_RANKER_NAME,
+        'scope': entity.org}
+
+    ranker_root = ranker_root_logic.getForFields(fields, unique=True)
+    ranker = ranker_root_logic.getRootFromEntity(ranker_root)
+
+    return ranker
+
   def _onCreate(self, entity):
     """Adds this proposal to the organization ranker entity.
     """
 
-    fields = {'link_id': student_proposal.DEF_RANKER_NAME,
-              'scope': entity.org}
-
-    ranker_root = ranker_root_logic.getForFields(fields, unique=True)
-    ranker = ranker_root_logic.getRootFromEntity(ranker_root) 
+    ranker = self.getRankerFor(entity)
     ranker.SetScore(entity.key().name(), [entity.score])
 
     super(Logic, self)._onCreate(entity)
@@ -74,11 +90,7 @@
       entity_properties[name] = value
 
       # update the ranker
-      fields = {'link_id': student_proposal.DEF_RANKER_NAME,
-                'scope': entity.org}
-
-      ranker_root = ranker_root_logic.getForFields(fields, unique=True)
-      ranker = ranker_root_logic.getRootFromEntity(ranker_root)
+      ranker = self.getRankerFor(entity)
       ranker.SetScore(entity.key().name(), [value])
 
     if name == 'status':
@@ -86,11 +98,7 @@
       if value in ['invalid', 'rejected'] and entity.status != value:
         # the proposal is going into invalid or rejected state
         # remove the score from the ranker
-        fields = {'link_id': student_proposal.DEF_RANKER_NAME,
-                  'scope': entity.org}
-
-        ranker_root = ranker_root_logic.getForFields(fields, unique=True)
-        ranker = ranker_root_logic.getRootFromEntity(ranker_root)
+        ranker = self.getRankerFor(entity)
 
         # entries in the ranker can be removed by setting the score to None
         ranker.SetScore(entity.key().name(), None)