root / pykota / trunk / bin / pkbcodes @ 2685

Revision 2685, 8.7 kB (checked in by jerome, 19 years ago)

Additionnal things removed from inner loop.

  • Property svn:executable set to *
  • Property svn:keywords set to Author Date Id Revision
RevLine 
[2332]1#! /usr/bin/env python
2# -*- coding: ISO-8859-15 -*-
3
4# PyKota Billing Codes manager
5#
6# PyKota - Print Quotas for CUPS and LPRng
7#
[2622]8# (c) 2003, 2004, 2005, 2006 Jerome Alet <alet@librelogiciel.com>
[2332]9# This program is free software; you can redistribute it and/or modify
10# it under the terms of the GNU General Public License as published by
11# the Free Software Foundation; either version 2 of the License, or
12# (at your option) any later version.
13#
14# This program is distributed in the hope that it will be useful,
15# but WITHOUT ANY WARRANTY; without even the implied warranty of
16# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17# GNU General Public License for more details.
18#
19# You should have received a copy of the GNU General Public License
20# along with this program; if not, write to the Free Software
21# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
22#
23# $Id$
24#
25#
26
27import os
28import sys
29import pwd
30
[2512]31from pykota.tool import PyKotaTool, PyKotaToolError, PyKotaCommandLineError, crashed, N_
[2332]32
[2344]33__doc__ = N_("""pkbcodes v%(__version__)s (c) %(__years__)s %(__author__)s
[2332]34
35A billing codes Manager for PyKota.
36
37command line usage :
38
39  pkbcodes [options] code1 code2 code3 ... codeN
40
41options :
42
43  -v | --version       Prints pkbcodes version number then exits.
44  -h | --help          Prints this message then exits.
45 
46  -a | --add           Adds billing codes if they don't exist in PyKota's
47                       database. If they exist, they are modified
48                       unless -s|--skipexisting is also used.
49
50  -d | --delete        Deletes billing codes from PyKota's database.
[2340]51                       NB : the history entries with this billing code
52                       are not deleted, voluntarily.
[2332]53
54  -D | --description d Adds a textual description to billing codes.
55
56  -l | --list          List informations about the billing codes.
57
[2554]58  -r | --reset         Resets the billing codes' balance and page counters
[2332]59                       to 0.
60
61  -s | --skipexisting  In combination with the --add option above, tells
[2337]62                       pkbcodes to not modify existing billing codes.
[2332]63
64  code1 through codeN can contain wildcards if the --add option
65  is not set.
66
67examples :                             
68
69  $ pkbcodes --add -D "My project" myproj
70
71  Will create the myproj billing code with "My project"
72  as the description.
73
74  $ pkbcodes --delete "*"
75
76  This will completely delete all the billing codes, but without
77  removing any matching job from the history. USE WITH CARE ANYWAY !
78 
79  $ pkbcodes --list "my*"
80 
[2344]81  This will list all billing codes which name begins with 'my'.
82""")
[2332]83       
84class PKBcodes(PyKotaTool) :       
[2337]85    """A class for a billing codes manager."""
[2332]86    def main(self, names, options) :
[2337]87        """Manage billing codes."""
[2332]88        if (not self.config.isAdmin) and (not options["list"]) :
[2512]89            raise PyKotaCommandLineError, "%s : %s" % (pwd.getpwuid(os.geteuid())[0], _("You're not allowed to use this command."))
[2332]90           
[2657]91        if options["delete"] :   
[2671]92            self.display("%s...\n" % _("Deletion"))
[2657]93            todelete = self.storage.getMatchingBillingCodes(",".join(names))
94            nbtotal = len(todelete)
95            for i in range(nbtotal) :
96                todelete[i].delete()
97                percent = 100.0 * float(i) / float(nbtotal)
98                self.display("\r%.02f%%" % percent)
99        else :
100            if options["add"] :   
[2671]101                self.display("%s...\n" % _("Creation"))
[2657]102                billingcodes = []
[2671]103                nbtotal = len(names)
104                for i in range(nbtotal) :
105                    bname = names[i]
[2657]106                    billingcode = self.storage.getBillingCode(bname)
107                    if billingcode.Exists :
108                        if options["skipexisting"] :
109                            self.printInfo(_("Billing code [%s] already exists, skipping.") % billingcode.BillingCode)
110                        else :   
111                            self.printInfo(_("Billing code [%s] already exists, will be modified.") % billingcode.BillingCode)
112                            billingcodes.append(billingcode)
113                    else :
114                        billingcode = self.storage.addBillingCode(bname)
115                        if not billingcode.Exists :
116                            raise PyKotaToolError, _("Impossible to add billingcode %s") % bname
117                        else :     
118                            billingcodes.append(billingcode)
[2671]119                    percent = 100.0 * float(i) / float(nbtotal)
120                    self.display("\r%.02f%%" % percent)
121                self.display("\r100.00%%\r        \r%s\n" % _("Done."))
[2657]122            else :       
[2671]123                if not names :
124                    names = ["*"]
[2657]125                billingcodes = self.storage.getMatchingBillingCodes(",".join(names))
126                if not billingcodes :
127                    raise PyKotaCommandLineError, _("There's no billingcode matching %s") % " ".join(names)
128                       
[2684]129            if options["list"] :
130                for billingcode in billingcodes :
131                    print "%s [%s] %s %s %s %.2f %s" % \
132                          (billingcode.BillingCode, billingcode.Description, \
133                           billingcode.PageCounter, \
134                           _("pages"), \
135                           _("and"), \
136                           billingcode.Balance, \
137                           _("credits"))
138            else :               
[2672]139                self.display("%s...\n" % _("Modification"))
[2685]140                reset = options["reset"]
141                if reset or options["description"] : # optimize when nothing to do
142                    if options["description"] :
143                        description = options["description"].strip()
[2684]144                    nbtotal = len(billingcodes)           
145                    for i in range(nbtotal) :       
146                        billingcode = billingcodes[i]
[2685]147                        if reset :
[2677]148                            billingcode.reset()   
[2685]149                        if description is not None : # NB : "" is allowed !
150                            billingcode.setDescription(description)
[2677]151                        billingcode.save()   
152                        percent = 100.0 * float(i) / float(nbtotal)
153                        self.display("\r%.02f%%" % percent)
[2671]154                       
155        if not options["list"] :               
156            self.display("\r100.00%%\r        \r%s\n" % _("Done."))
[2332]157                     
158if __name__ == "__main__" : 
159    retcode = 0
160    try :
161        short_options = "hvaD:dlrs"
162        long_options = ["help", "version", "add", "description=", "delete", "list", "reset", "skipexisting"]
163       
164        # Initializes the command line tool
165        manager = PKBcodes(doc=__doc__)
166        manager.deferredInit()
167       
168        # parse and checks the command line
169        (options, args) = manager.parseCommandline(sys.argv[1:], short_options, long_options)
170       
171        # sets long options
172        options["help"] = options["h"] or options["help"]
173        options["version"] = options["v"] or options["version"]
174        options["add"] = options["a"] or options["add"]
175        options["description"] = options["D"] or options["description"]
176        options["delete"] = options["d"] or options["delete"] 
177        options["list"] = options["l"] or options["list"]
178        options["reset"] = options["r"] or options["reset"]
179        options["skipexisting"] = options["s"] or options["skipexisting"]
180       
181        if options["help"] :
182            manager.display_usage_and_quit()
183        elif options["version"] :
184            manager.display_version_and_quit()
185        elif (options["delete"] and (options["add"] or options["reset"] or options["description"])) \
186           or (options["skipexisting"] and not options["add"]) \
187           or (options["list"] and (options["add"] or options["delete"] or options["reset"] or options["description"])) :
[2512]188            raise PyKotaCommandLineError, _("incompatible options, see help.")
[2332]189        elif (not args) and (options["add"] or options["delete"]) :   
[2512]190            raise PyKotaCommandLineError, _("You have to pass billing codes on the command line")
[2332]191        else :
192            retcode = manager.main(args, options)
193    except KeyboardInterrupt :       
194        sys.stderr.write("\nInterrupted with Ctrl+C !\n")
[2609]195        retcode = -3
[2512]196    except PyKotaCommandLineError, msg :   
197        sys.stderr.write("%s : %s\n" % (sys.argv[0], msg))
[2609]198        retcode = -2
[2332]199    except SystemExit :       
200        pass
201    except :
202        try :
203            manager.crashed("pkbcodes failed")
204        except :   
205            crashed("pkbcodes failed")
206        retcode = -1
207
208    try :
209        manager.storage.close()
210    except (TypeError, NameError, AttributeError) :   
211        pass
212       
213    sys.exit(retcode)   
Note: See TracBrowser for help on using the browser.