]> asedeno.scripts.mit.edu Git - bluechips.git/blobdiff - bluechips/controllers/transfer.py
added email notifications. requires schema change to add email column to users table.
[bluechips.git] / bluechips / controllers / transfer.py
index 68d8b44a4d73ffa2ab32c9292a5d0ac80c7dc431..016f508df07f7d379d468db895be23454dd2ec8e 100644 (file)
@@ -4,47 +4,66 @@ Handle transfers
 
 import logging
 
+from datetime import date
+
 from bluechips.lib.base import *
-from bluechips.widgets import transfer
 
-from pylons import request
+from pylons import request, app_globals as g
+from pylons.decorators import validate
+
+from formencode import Schema, validators
+
+from mailer import Message
 
 log = logging.getLogger(__name__)
 
+
+class TransferSchema(Schema):
+    "Validate a transfer."
+    allow_extra_fields = False
+    debtor_id = validators.Int(not_empty=True)
+    creditor_id = validators.Int(not_empty=True)
+    amount = model.types.CurrencyValidator(not_empty=True)
+    description = validators.UnicodeString()
+    date = validators.DateConverter()
+
 class TransferController(BaseController):
     def index(self):
-        c.title = 'Add a New Transfer'
-        
-        c.transfer = dict()
-        c.transfer['debtor'] = request.environ['user']
-        
-        return render('/transfer/index.mako')
+       return self.edit()
     
-    def edit(self, id):
-        c.title = 'Edit a Transfer'
-        
-        c.transfer = meta.Session.query(model.Transfer).get(id)
-        
+    def edit(self, id=None):
+        c.users = meta.Session.query(model.User.id, model.User.name)
+        if id is None:
+            c.title = 'Add a New Transfer'
+            c.transfer = model.Transfer()
+            c.transfer.debtor_id = request.environ['user'].id
+            c.transfer.date = date.today()
+        else:
+            c.title = 'Edit a Transfer'
+            c.transfer = meta.Session.query(model.Transfer).get(id)
         return render('/transfer/index.mako')
     
-    @validate(form=transfer.new_transfer_form, error_handler='index')
+    @validate(schema=TransferSchema(), form='edit')
     def update(self, id=None):
-        # Validate the submission
-        if not valid(self, transfer.new_transfer_form):
-            if id is None:
-                return self.index()
-            else:
-                return self.edit(id)
-        
         if id is None:
             t = model.Transfer()
+            meta.Session.add(t)
+            op = 'created'
         else:
             t = meta.Session.query(model.Transfer).get(id)
+            op = 'updated'
         
         update_sar(t, self.form_result)
-        meta.Session.save_or_update(t)
         meta.Session.commit()
-        
-        h.flash('Transfer recorded.')
-        
+       
+        show = ('Transfer of %s from %s to %s %s.' %
+                (t.amount, t.debtor, t.creditor, op))
+        h.flash(show)
+
+        # Send email notification to involved users if they have an email set.
+        body = render('/emails/transfer.txt', extra_vars={'transfer': t,
+                                                          'op': op})
+        g.handle_notification((t.debtor, t.creditor), show, body)
+
         return h.redirect_to('/')