source: WAeUP_SRP/base/skins/waeup_epayment/upgradePayments.py @ 2940

Last change on this file since 2940 was 2931, checked in by Henrik Bettermann, 17 years ago

log only if payment has been updated

  • Property svn:keywords set to Id
File size: 1.9 KB
RevLine 
[2859]1## Script (Python) "upgradePayments.py"
2##bind container=container
3##bind context=context
4##bind namespace=
5##bind script=script
6##bind subpath=traverse_subpath
7##parameters=
8##title=
9##
10# $Id: upgradePayments.py 2931 2007-12-13 06:32:18Z henrik $
11"""
12"""
13try:
14    from Products.zdb import set_trace
15except:
16    def set_trace():
17        pass
18
19mtool = context.portal_membership
20member = mtool.getAuthenticatedMember()
21if str(member) not in ('admin','joachim'):
22    return
23
24
25import logging
26import DateTime
27logger = logging.getLogger('Skins.upgradePayments')
28from Products.AdvancedQuery import Eq, Between, Le,In
29aq_portal = context.portal_catalog_real.evalAdvancedQuery
30aq_student = context.students_catalog.evalAdvancedQuery
31students_folder = context.portal_url.getPortalObject().campus.students
32
33request = context.REQUEST
34session = request.SESSION
35response = request.RESPONSE
36setheader = request.RESPONSE.setHeader
[2923]37#def rwrite(s):
38#    response.setHeader('Content-type','text/html; charset=ISO-8859-15')
39#    response.write("%s<br>\n\r" % s)
[2859]40
41count = 1
42d = {}
43l = []
44sum_total = 0.0
45log_after = 100
46logger.info("start")
47query = Eq('portal_type','Payment')
48payments = aq_portal(query,sortSpecs=('container_path',))
49total = len(payments)
50logger.info("found %d payments" % total)
51sid = "xxx"
[2918]52count = 0
[2927]53commit_after = 500
[2925]54commit_count = 0
[2859]55
[2897]56student_id = ''
[2886]57for payment_brain in payments:
[2918]58    count += 1
[2886]59    payment = payment_brain.getObject()
[2897]60    if payment_brain.getPath().split('/')[-3] != student_id:
61        student_id = payment_brain.getPath().split('/')[-3]
62        student_record = context.students_catalog.getRecordByKey(student_id)
63    payment['updatePayment'](student_record)
[2931]64    #logger.info('upgraded student %s payment %s' % (student_record.id,payment.getId()))
[2925]65    if not count % commit_after:
66        logger.info("committing %d total %d" % (commit_after,count))
67        commit_count += 1
68        context.waeup_tool.doCommit()
[2927]69        #if not commit_count % 2:
70        #    break
[2859]71logger.info("%d of %d upgraded" % (count,total))
Note: See TracBrowser for help on using the repository browser.