Add a script to convert proposals.
authorSverre Rabbelier <srabbelier@gmail.com>
Sat, 18 Apr 2009 15:05:56 +0000 (2009-04-18)
changeset 2218 84b0ce492cf5
parent 2217 2c6ec0357149
child 2219 6f835882160e
Add a script to convert proposals. Patch by: Sverre Rabbelier
scripts/stats.py
--- a/scripts/stats.py	Sat Apr 18 15:04:24 2009 +0000
+++ b/scripts/stats.py	Sat Apr 18 15:05:56 2009 +0000
@@ -26,6 +26,7 @@
 import datetime
 import operator
 import sys
+import time
 
 import interactive
 
@@ -205,6 +206,53 @@
   return result
 
 
+def convertProposals(org):
+  """Convert all proposals for the specified organization.
+
+  Args:
+    org: the organization for which all proposals will be converted
+  """
+
+  from soc.logic.models.student_proposal import logic as proposal_logic
+  from soc.logic.models.student_project import logic as project_logic
+
+  proposals = proposal_logic.getProposalsToBeAcceptedForOrg(org)
+
+  for proposal in proposals:
+    fields = {
+        'link_id': 't%i' % (int(time.time()*100)),
+        'scope_path': proposal.org.key().id_or_name(),
+        'scope': proposal.organization,
+        'program': proposal.program,
+        'student': proposal.scope,
+        'title': proposal.title,
+        'abstract': proposal.abstract,
+        'mentor': proposal.mentor,
+        }
+
+    project = project_logic.updateOrCreateFromFields(fields)
+
+    fields = {
+        'status':'accepted',
+        }
+    proposal_logic.updateEntityProperties(proposal, fields)
+
+  fields = {
+      'status': ['new', 'pending', 'invalid'],
+      'org': org,
+      }
+
+  query = proposal_logic.getQueryForFields(filter)
+  proposals = interactive.deepFetch(query)
+
+  fields = {
+      'status': 'rejected',
+      }
+
+  for proposal in proposals:
+    proposal_logic.updateEntityProperties(proposal, fields)
+
+
 def loadPickle(name):
   """Loads a pickle.
   """