root / pykota / trunk / NEWS @ 2623

Revision 2623, 74.0 kB (checked in by jerome, 19 years ago)

Added a note about Matt's recent MySQL contribution

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
Line 
1# $Id$
2
3PyKota - Print Quotas for CUPS and LPRng
4
5(c) 2003, 2004, 2005, 2006 Jerome Alet <alet@librelogiciel.com>
6This program is free software; you can redistribute it and/or modify
7it under the terms of the GNU General Public License as published by
8the Free Software Foundation; either version 2 of the License, or
9(at your option) any later version.
10
11This program is distributed in the hope that it will be useful,
12but WITHOUT ANY WARRANTY; without even the implied warranty of
13MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14GNU General Public License for more details.
15
16You should have received a copy of the GNU General Public License
17along with this program; if not, write to the Free Software
18Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
19
20============================================================
21
22PyKota NEWS :
23       
24    - 1.24alpha7 :
25     
26        - Matt Hyclak contributed the possibility to store the printing
27          history in a MySQL database. See the contributed/ directory
28          for details.
29         
30        - Added 2006 to the copyright's years.
31       
32    - 1.24alpha6 :
33   
34        - Fixed internal SNMP and PJL handling code for very fast
35          printers : PyKota didn't see them going from 'idle'
36          to 'printing' to 'idle' again.
37         
38        - Now waitprinter.sh accepts SNMP version number and
39          community name as arguments, thanks to Brandon
40          Holbrook.
41         
42        - Now command line errors and Ctrl+C repectively cause
43          PyKota commands to exit with status -2 and -3.
44         
45    - 1.24alpha5 :
46   
47        - All command line tools now accept -A | --arguments filename.args
48          as a way to bypass the shell's maximal command line size :
49          just put each argument on a line by itself in a file, and
50          pass the file's name as the -A | --arguments command line
51          option's argument. For now this won't be documented in
52          commands' helps.
53         
54        - dumpykota can now dump the complete database in XML
55          format.
56         
57    - 1.24alpha4 :
58   
59        - Added support for the SQLite3 backend.
60          See pykota/initscripts/sqlite/README.sqlite
61       
62    - 1.24alpha3 :
63   
64        - Fix for mailandpopup.sh : smbstatus can't be run setuid,
65          so we regain priviledges before running an external
66          mailto directive.
67       
68    - 1.24alpha2 :
69   
70        - Introduce the "onbackenderror" directive in pykota.conf, to
71          control if the user must be charged or not whenever a real
72          CUPS backend fails. The default value is 'nocharge'.
73          Set it to 'charge' if you think your users can cause a CUPS
74          backend to fail.
75         
76        - Now mark original backends related problems as such in the
77          printing history. Modified printquota.cgi and pykota.css
78          to make them be more visible.
79         
80    - 1.24alpha1 :
81   
82        - Fixed a problem which caused backend errors to be ignored.
83       
84        - The sample LDIF file now contains the two necessary user
85          entries to have an LDAP PyKota Admin and an LDAP PyKota
86          ReadOnly user. The sample configuration files were updated
87          to contain the default passwords used in the LDIF file.
88         
89        - dumpykota is now more strict when checking arguments.   
90       
91    - 1.23 :
92   
93        - Many minor bug fixes and code cleaning.
94       
95        - Improved documentation.
96       
97        - Added Polish translation.
98       
99        - Improved French and Swedish translations.
100       
101    - 1.23beta :
102   
103        - Now the mailto directive is honored in all cases where the job is
104          denied or a warning has to be issued, and the correct reason
105          can be sent back to the user.
106         
107        - The PYKOTAREASON environment variable, if defined, contains the 
108          textual reason why the job was denied or a warning has to be
109          issued.
110       
111    - 1.23alpha31 :
112   
113        - Added support for --maxjobsize, --passthrough and --nopassthrough
114          in pkprinters. These modes are now also honored when printing.
115         
116        - Allows the admin to restrict the number of print queues which will
117          be treated by pkturnkey by passing queues' names as additionnal
118          arguments on pkturnkey's command line.
119         
120        - pkturnkey now supersedes pkhint with the help of the -c | --doconf
121          command line option.   
122         
123    - 1.23alpha30 :
124   
125        - Database changes : you MUST use upgrade-to-1.23.sql again if you
126          use PostgreSQL, or copy the new schema and restart your LDAP
127          server if you use LDAP.
128         
129        - The -C | --comment command line switch was added to edpykota to 
130          attach textual information to modifications done to a user's
131          account balance.
132         
133        - The -l | --limitby command line switch to edpykota was modified 
134          to allow 'noquota', 'nochange', and 'noprint'. See the edpykota
135          command's help or manual page for details.
136         
137        - The -i | --ingroups command line switch to repykota allows 
138          PyKota Administrators to only lists members of the specified
139          group or groups (separated with commas).
140         
141        - The -I | --increase command line switch to edpykota allows
142          to increase or decrease page limits.
143         
144        - Added the precomputed job's size and price to the history
145          for controlling purpose.
146       
147    - 1.23alpha29 :
148   
149        - Fixed a small problem with billing codes.
150       
151        - Exports some environment variables earlier, to render the script
152          launched by the overwrite_jobticket directive more powerful.
153         
154        - Now autopykota also creates print quota entries for the user on the
155          printers groups the current printer is a member of.
156         
157    - 1.23alpha28 :
158   
159        - Added users groups management to pkturnkey.
160       
161        - Fixed umask in setup script.
162       
163    - 1.23alpha27 :
164   
165        - Replaced the --dryrun command line option by the --force
166          command line option in pkturnkey, with exactly the opposite
167          effect (for security reasons).
168         
169    - 1.23alpha26 :
170   
171        - Allows parametrized pjl and snmp hardware accounting methods,
172          to be able to respectively set the TCP port and the SNMP
173          community.
174         
175    - 1.23alpha25 :
176   
177        - Added a --dryrun command line switch to pkturnkey.
178       
179        - Improved pkturnkey's general usability.
180       
181        - Added a manpage for pkturnkey.
182       
183    - 1.23alpha24 :
184   
185        - Allows different databases to be used depending on the
186          user's rights. This allows PyKota admins to directly
187          use a master LDAP server for read+write, while letting
188          normal users using the replicas for readonly access.
189          NB : using different storage backends is also possible,
190          but you're on your own there.
191         
192    - 1.23alpha23 :
193   
194        - Fixed a problem with banner accounting.
195   
196        - Introduction of the new 'pkturnkey' command line tool.
197       
198    - 1.23alpha22 :
199   
200        - The cupspykota backend was almost entirely rewritten from scratch.
201          It's now much more readable, maintainable, etc...
202         
203        - LPRng support is OFFICIALLY dropped for now. LPRng users are 
204          advised to download earlier releases or purchase the
205          PyKota v1.22HotFix1 Official release. LPRng support
206          MIGHT be re-added later.
207       
208    - 1.23alpha21 :
209     
210        - Fix for IPP requests which contain more than a single
211          job-originating-host-name attribute.
212         
213    - 1.23alpha20 :
214   
215        - Added the overwrite_jobticket directive. See pykota.conf.sample
216          for how to use it.
217         
218    - 1.23alpha19 :
219   
220        - Fixed an LDAP filtering problem when managing billing codes.
221       
222        - Added the unknown_billingcode directive. See pykota.conf.sample
223          for how to use it.
224       
225    - 1.23alpha18 :
226     
227        - Added the dump_bfd.php contribution.
228       
229        - Several fixes in the internal PJL accounter.
230       
231        - Now autopykota doesn't create unneeded print quota entries anymore.
232       
233        - Increased the timeout in the PJL hardware accounting code to
234          accomodate some printers (HP5000 at least).
235         
236    - 1.23alpha17 :
237   
238        - pkpgcounter is now distributed separately only. This
239          means that people must now download and install pkpgcounter
240          v1.56 or higher prior to being able to run PyKota.
241         
242        - Removed all the autoconf/automake stuff which was outdated 
243          and confusing.
244         
245    - 1.23alpha16 :
246     
247        - Extracted the GPL blurb from all commands' help, and use
248          a static version only once. This saves space big time, and
249          eases future translations.
250         
251    - 1.23alpha15 :
252   
253        - pkbcodes now works with the PostgreSQL backend.
254          NB : PLEASE RUN upgrade-to-1.23.sql AGAIN !!!
255       
256    - 1.23alpha14 :
257   
258        - Logs a warning when the user/group doesn't exist when running
259          edpykota.
260         
261    - 1.23alpha13 :
262   
263        - Minor fix for user groups because of latest database changes.
264       
265    - 1.23alpha12 :
266   
267        - Big database changes, use the migration scripts !
268       
269    - 1.23alpha11 :
270   
271        - Small fix to the PCL3/4/5 parser for some drivers.
272       
273    - 1.23alpha10 :
274   
275        - Fixed a bad exception name in cupspykota when parsing IPP messages.
276       
277        - Improved the IPP messages module : it can now generate IPP messages
278          in addition to parsing them.
279       
280    - 1.23alpha9 :   
281   
282        - The denyduplicates directive now accepts a command line as an
283          argument beside yes/no. The command is launched and must
284          print either ALLOW or DENY to its standard output. Then the
285          job gets allowed or denied by PyKota.
286          This will allow user interaction in the near future.
287         
288        - Introduced the new 'striptitle' directive to remove ugly prefixes
289          from print job's titles whenever a new print job is submitted.
290         
291        - Fixed internal SNMP accounter for printers which only have a life time
292          page counter, and not a volatile page counter.
293         
294    - 1.23alpha8 :
295   
296        - The data dumper can now summarize payments and history with the
297          help of the --sum command line option (or checkbox in the CGI).
298         
299        - The message used when the job's filename, title and options are
300          hidden because of the privacy directive is now translated at
301          retrieval time, instead of at saving time.
302         
303        - Minor fix in the LDAP backend code. 
304         
305    - 1.23alpha7 :
306   
307        - Improvements to the internal PJL and SNMP accounter : now should
308          support more printers and waste less time.
309         
310    - 1.23alpha6 :
311   
312        - The data dumper's start= and end= date filtering options now
313          accept a positive or negative offset to be added to the special
314          keywords 'yesterday', 'today', 'now', 'tomorrow'.
315          e.g. : dumpykota --data history start=yesterday-5 end=today
316         
317    - 1.23alpha5 :
318   
319        - The data dumper's start= and end= date filtering options now accept
320          the special keywords 'yesterday', 'today', 'now' and 'tomorrow'.
321         
322    - 1.23alpha4 :
323   
324        - The data dumper now accept start= and end= to specify the starting
325          and ending dates to dump the history.
326         
327    - 1.23alpha3 :
328   
329        - The destination link for the logo used in CGI scripts is
330          configurable.
331         
332        - Data dumper improved : it's faster and now datas are correctly
333          escaped.
334       
335        - The URL to the logo displayed in the CGI scripts is configurable.
336       
337    - 1.23alpha2 :
338   
339        - Fixed edpykota --prototype with balance.
340       
341        - Major rewrite of the IPP message parsing code to definitely
342          fix the job-originating-hostname IPP attribute problem.
343       
344    - 1.23alpha1 :   
345   
346        - Sets current username to the user CUPS runs as instead of "root"
347          when printing test pages from CUPS' web interface (because
348          the username is empty in this case).
349         
350        - Fix for strange values in job-originating-hostname
351       
352    - 1.22 :
353   
354        - Big improvements to the documentation.
355       
356    - 1.22beta :
357   
358        - Improved stability in pykotme and pykotme.cgi.
359       
360        - Fixed a permission problem in pykotme and pykosd.
361       
362        - Fixed an inconsitency between SQL and LDAP backends'
363          behavior in edpykota.
364         
365        - Improved stability and allowed tracebacks in CGI scripts.
366       
367        - Improved pykotme.cgi
368         
369    - 1.22alpha8 :
370   
371        - Fixed history retrieval for nonexisting printers or users.
372       
373        - Clicking on the billing code in printquota.cgi's job history
374          now shows all jobs matching this billing code.
375         
376        - Fixed the dump in CUPS' page_log format which didn't
377          dump the oldest entry.
378         
379        - The data dumper now accepts billingcode= and hostname= as
380          filters when dumping the job history.
381         
382        - The job billing code if present is now saved into the database,
383          and exported to subprocesses as the PYKOTAJOBBILLING environment
384          variable.
385         
386        - Ctrl+C now makes PyKota commands exit without a traceback.
387       
388        - Fixed an i18n problem with Python 2.1
389       
390    - 1.22alpha7 :
391   
392        - Fixed some problems with the retrieval of the history from LDAP.
393       
394    - 1.22alpha6 :
395   
396        - Early errors now produce meaningful error messages (finally !)
397       
398    - 1.22alpha5 :
399       
400        - SNMP and PJL improvements with regard to PowerSave / StandBy.
401       
402    - 1.22alpha4 :
403   
404        - Fixed charset problem under MacOSX.
405       
406        - Allows pkbanner to accept more info to display on its
407          command line.
408         
409    - 1.22alpha3 :
410   
411        - Fixes some case related problems with some LDAP backends.
412       
413        - Fixes some problem for printers which directly go from
414          "idle" to "warmup" and never to "printing" before
415          returning to "idle".
416         
417        - Some permissions settings may have prevented cupspykota
418          from parsing cupsd.conf, this is now fixed.
419         
420    - 1.22alpha2 :
421   
422        - Introduction of the web enabled print quote generator.
423       
424        - Fixed a potential race condition when several backend
425          wrappers were present in CUPS' backend directory.
426         
427        - Fixed dumpykota's output in CUPS' page_log format to better
428          match CUPS format.
429         
430    - 1.22alpha1 :
431   
432        - Import into Subversion.
433       
434    - 1.21 :
435   
436        - Improved documentation.
437       
438        - Improved dependencies checker.
439       
440        - Updated some translation files.
441       
442    - 1.21beta2 :
443   
444        - Fixed an LPRng specific bug.
445       
446        - Several improvements on stability issues with manually modified
447          LDAP trees.
448         
449        - Documentation improvements. 
450       
451    - 1.21beta :
452   
453        - Prepared translation files for next release.
454       
455    - 1.21alpha27 :
456   
457        - Allows software() (no arguments) to the software accounting
458          directive. This saves a lot of CPU since the job is not
459          parsed again : the precomputed size is used directly in this
460          case.
461         
462        - epykota's --prototype option now works fine with accounts
463          limited by balance.
464         
465    - 1.21alpha26 :
466   
467        - Fixed the handling of the 'maxdenybanners' directive.
468       
469        - Introduced the 'denyduplicates' directive.
470       
471        - Fixed some database related glitches.
472       
473    - 1.21alpha25 :
474   
475        - The job's size is now always precomputed, even when
476          'enforcement' is not set to 'strict'.
477         
478        - Introduction of the new 'trustjobsize' configuration directive
479          to workaround some problematic printers. See the sample
480          configuration file for details.
481         
482    - 1.21alpha24 :
483   
484        - Big database structure changes. An upgrade script
485          is now included for PostgreSQL. LDAP users may just
486          want to copy the new schema in place.
487         
488        - edpykota now recognizes the -o | --overcharge command line
489          option to set an overcharging or undercharging factor
490          on each print job's cost for a particular user.
491         
492        - repykota's output format has changed an is not limited to 
493          80 characters wide anymore. People who used to parse
494          repykota's output in their own tools are strongly advised
495          to parse dumpykota's output instead.
496         
497        - Introduction of the new 'maxdenybanners' configuration directive
498          to allow up to N (the directive's value) deny banners to be
499          printed even if the print account is forbidden to print.
500         
501        - Better detection of the number of copies in the PostScript parser.
502       
503    - 1.21alpha23 :
504   
505        - Traditional Chinese translation added.
506   
507        - Several fixes and performance improvements with the LDAP backend.
508       
509    - 1.21alpha22 :
510   
511        - edpykota's --delete command line option doesn't consider
512          '*' to be the default argument anymore :-)
513         
514    - 1.21alpha21 :
515   
516        - dumpykota.cgi can now be run as a normal user as opposed to
517          a PyKota administrator. No read access to pykotadmin.conf is
518          necessary anymore. This CGI scripts now honors the REMOTE_USER
519          environment variable just like printquota.cgi does, see
520          the file cgi-bin/README for details.
521          The command line tool dumpykota must still be run by a PyKota
522          administrator.
523         
524        - Fix exception's name error due to a change in recent versions
525          of PygreSQL.   
526         
527    - 1.21alpha20 :
528         
529        - Big bug fix wrt the datelimit field which was never reset.
530         
531    - 1.21alpha19 :
532   
533        - Introduction of the new dumpykota.cgi CGI script, which
534          allows third party tools like phpPrintAnalyzer to be
535          interfaced in real time with PyKota. To use it you
536          may have to change your web server's configuration,
537          please see pykota/cgi-bin/README
538         
539    - 1.21alpha18 :
540   
541        - Now dumpykota can dump the job history into CUPS' page_log
542          format (even when the printing system is LPRng). This allows
543          people to use tools like PrintAnalyzer or phpPrintAnalyzer
544          (two completely different beasts) with PyKota.
545         
546    - 1.21alpha17 :
547     
548        - Fixed field type's name in XML dumps.
549       
550        - Now drops priviledges to user 'pykota' when launched as root
551          (directly or as a CUPS backend), if such an user exists.
552         
553        - Fixed PCL3/4/5 parser for some drivers' output.
554       
555    - 1.21alpha16 :
556   
557        - fixed several recently introduced bugs in LDAP backend code,
558          thanks to Matt Hyclak.
559         
560    - 1.21alpha15 :
561     
562        - Normalized field names between LDAP and PostgreSQL backends
563          in dumpykota's output.
564         
565        - dumpykota filtering capabilities are now supported within
566          the LDAP backend too.
567         
568    - 1.21alpha14 :
569   
570        - dumpykota now supports extended filtering possibilities
571          with the PostgreSQL backend (LDAP support will come soon).
572         
573    - 1.21alpha13 :
574   
575        - Added a --debug command line option to pkpgcounter, so
576          that people may see what really happens, and what will
577          be available in the future :-)
578         
579    - 1.21alpha12 :
580   
581        - Fixed a bug with non standard pkbanner command lines.
582       
583        - Now logs as errors the differences between precomputed and
584          computed job sizes. **CUPS only for now**
585         
586    - 1.21alpha11 :
587   
588        - Now user and group print quota entries can be stored directly
589          below the user or group with the LDAP backend, using them
590          as branches. Thanks to Stefan Wold for the patch.
591          See the sample configuration file for details.
592         
593        - TLS is now supported with the LDAP backend. Thanks to Stefan
594          Wold for the patch.
595          See the sample configuration file for details.
596         
597        - edpkota now accepts the -U | --used value command line argument
598          to preset the page counters to an initial value. Thanks to
599          Wilson Roberto Afonso and Matt Hyclak for the patch.
600         
601    - 1.21alpha10 :
602   
603        - Now automatically reconnects up to three times if the LDAP server
604          returned an error, possibly due to a timeout.
605         
606    - 1.21alpha9 :
607   
608        - Now searches the configuration files in 'pykota' system user's
609          home directory. The 'pykota' system user and group have
610          to be created by the system administrator, and given
611          sufficient permissions to PyKota's configuration files.
612         
613    - 1.21alpha8 :
614   
615        - Added the new reject_unknown directive to reject the
616          creation of user or groups which are unknown to the system.
617         
618    - 1.21alpha7 :
619   
620        - Introduction of the pkmail email gateway.
621       
622    - 1.21alpha6 :
623   
624        - Fix for LPRng filenames.
625       
626        - Added Turkish translation thanks to Baris Cicek.
627       
628    - 1.21alpha5 :
629   
630        - Improved ESC/P2 miniparser for Stylus Photo printers.
631       
632        - Implemented the --savetoner command line option to pkbanner.
633       
634        - Improved pkbanner's help and messages.
635       
636    - 1.21alpha4 :
637   
638        - Fixed job's data file detection code for LPRng.
639       
640        - Fixed a problem with PJL and PowerSave mode,
641          thanks to Wilson Roberto Afonso.
642       
643    - 1.21alpha3 :
644   
645        - PyKota can now generate its own banners, and either account
646          for them or not, depending on newly introduced directives
647          in pykota.conf
648          Thanks to Matt Hyclak for the patch.
649         
650    - 1.21alpha2 :
651   
652        - Installation script is now non interactive again, as it should
653          have stayed from the beginning. Dependencies checking can
654          be done by launching the checkdeps.py command.
655         
656    - 1.21alpha1 :
657   
658        - added an IPP messages miniparser. Extraction of the client
659          hostname is now considered to be fiable, at least until
660          the CUPS developpers change something...
661       
662    - 1.20 :
663   
664        - Version number changed.
665       
666    - 1.20beta :
667   
668        - Norwegian (Bokm� preliminary translation added.
669       
670        - German translation was finalized.
671       
672        - Greek translation was finalized.
673       
674        - For urgent legal reasons, a "privacy" directive has been added
675          to pykota.conf, to hide jobs' title, filename and options
676          in the history.
677         
678        - Minor changes in the debian directory.
679       
680    - 1.20alpha27 :
681   
682        - Fixed many problems with translation files. In particular
683          the Brazilian Portuguese translation file was incorrectly
684          installed into the french "breton" locale directory.
685         
686        - Finished French translation. 
687         
688    - 1.20alpha26 :
689   
690        - LPRng support code should now better detect network
691          printers' hostnames or IP addresses.
692         
693        - Fix for recently introduced bug in LPRng support.
694       
695        - Fix for incorrect locale setting when starting.
696       
697    - 1.20alpha25 :
698   
699        - pkprinters allows --list to normal users, but require user
700          to be a PyKota administrator when another command line
701          option is used.
702         
703        - pkhint doesn't use absolute path to search for helper commands
704          anymore.
705         
706        - Spanish translation ready for 1.20.   
707       
708    - 1.20alpha24 :
709   
710        - Now warnpykota only warns users limited by balance once.
711       
712        - Now warnpykota only warns users who have ever printed,
713          to not cause confusion to users who have just opened
714          their account.
715       
716        - Prepared help messages for translations.
717       
718    - 1.20alpha23 :
719   
720        - Add workaround for locale problem.
721       
722    - 1.20alpha22 :
723   
724        - Hopefully final fix for data encoding charset.
725       
726        - edpykota now refuse to work if the user is not a PyKota admin.
727       
728        - Fixes a recently introduced bug with users groups and PostgreSQL.
729       
730    - 1.20alpha21 :
731   
732        - Now dumpykota refuses to launch if the current user is not
733          a PyKota administrator (a PyKota administrator is an user
734          allowed to read the pykotadmin.conf file).
735         
736        - Now any PyKota administrator can use repykota and warnpykota
737          with additionnal arguments, not only the root user.
738         
739        - Improved documentation a bit.
740       
741    - 1.20alpha20 :
742   
743        - Reduced delay in internal SNMP and PJL_over_TCP handlers
744          from 2 to 1 second.
745       
746        - dumpykota can now output XML.
747       
748    - 1.20alpha19 :
749   
750        - Improved user groups and user groups quotas dumps in dumpykota.
751       
752        - Finished implementation of LDAP support in dumpykota.
753       
754        - The md5 sum of the job's datas is now available as an
755          hexadecimal digest in the PYKOTAMD5SUM environment variable.
756         
757        - The description, filename, title, and options fields
758          are now stored as UTF-8 strings in both LDAP and PostgreSQL.
759          Proper charset is used during extraction from the database.
760         
761    - 1.20alpha18 :
762   
763        - Experimental autopykota command to initialize user
764          account and quota entries on first print while not
765          resetting the balance value if not needed.
766         
767        - Added the new "winbind_separator" directive to strip
768          out the Samba/Winbind domain name while printing if
769          needed (Off by default).
770         
771    - 1.20alpha17 :
772   
773        - Added --hardreset command line option to edpykota.
774       
775        - Fixed problem with accented chars in title, filename
776          or options and LDAP backend.
777         
778    - 1.20alpha16 :
779   
780        - Internal handling of socket based PJL queries over
781          port tcp/9100 is now available with the magic
782          'pjl' value in the hardware accounter.
783         
784    - 1.20alpha15 :
785   
786        - LDAP pykotaAccountBalance objects were always created
787          attached to the pykotaUser objects. This is now
788          fixed and the value of balancebase in pykota.conf
789          is now correctly used.
790         
791    - 1.20alpha14 :
792   
793        - Belgian translations added (copy of the french ones).
794       
795        - External hardware accounter now loops until
796          a result can be read correctly.
797         
798        - pkhint now suggest the internal snmp handling instead
799          of the external one.
800         
801    - 1.20alpha13 :
802     
803        - Hardware accounter now accepts the special
804          'snmp' value, meaning ALL is done from main code
805          without launching any subprocess.
806          You need the http://pysnmp.sf.net Python module
807          for this to work (tested with v3.4.2)
808         
809        - Increased delay between two loops iterations 
810          to 2 seconds in waitprinter.sh to diminish
811          CPU load.
812         
813    - 1.20alpha12 :
814   
815        - waitprinter.sh rewritten from scratch to wait
816          for printer status stabilization.
817       
818    - 1.20alpha11 :
819   
820        - Generic data dumper 'dumpykota' introduced.
821          Works only with PostgreSQL backend for now.
822         
823    - 1.20alpha10 :
824   
825        - Added fix for incorrect job's size computation when
826          hardware accounting fails.
827         
828    - 1.20alpha9 :
829   
830        - Small fixes wrt subprocesses.
831       
832    - 1.20alpha8 :
833   
834        - Added full support of PCL3 : HP Deskjet printers are now
835          supported.
836       
837    - 1.20alpha7 :
838   
839        - First draft of PCL3GUI (Deskjet 640C for example) analyzer.
840          Needs more work, but no documentation is available.
841       
842    - 1.20alpha6 :
843     
844        - Improved mailandpopup.sh script.
845       
846        - Small fixes for LPRng.
847       
848        - Now exports PYKOTAPRINTERHOSTNAME for network printers'
849          hostname or IP address. Set to 'localhost' when not
850          meaningful.
851         
852        - Fixed issue with how mod_auth_ldap Apache modules
853          fills the REMOTE_USER environment variable.
854         
855        - Fixed a bug in LDAP user deletion code.
856       
857    - 1.20alpha5 :
858     
859        - Introduces the new configuration directive 'onaccountererror'
860          to specify what must be done whenever the software or
861          hardware accounter fails. Allowed values are 'continue' and
862          'stop' (default).
863         
864        - Minor fix in software accounter for a recently introduced
865          problem.
866         
867    - 1.20alpha4 :
868   
869        - Added support for more ghostscript devices in ESC/P2
870          analyzer : stcolor, st800, escp, escpc are now supported.
871         
872    - 1.20alpha3 :
873       
874        - Small improvement in PostScript parser to avoid being
875          fooled by a change in number of copies :
876          The user can't ask for 200 copies of page 1 and 1 copy
877          of page 2 to fool PyKota anymore :
878          this would have been accounted for as 1 copy only, but
879          now the maximum value seen is used.
880         
881        - Relax checks for PCL5 header to accomodate some strange
882          printer drivers.
883         
884        - Now hardware accounting method works like software
885          accounting method wrt the subprocess' output.
886         
887        - Hardware and Software accounting stop the print queue 
888          when the accounting subprocess didn't work. This will
889          be configurable in the near future.
890         
891    - 1.20alpha2 :
892   
893        - Now software accounting method reads accounter's
894          answer until a line with a single integer is
895          obtained or until all of its output has been read.
896          This should fix the problem some people have
897          when strange locale related messages are sent
898          when running subprocesses (Solaris only ?).
899         
900        - First version of ESC/P2 analyzer. Seems to work
901          ok at least with 'epson', 'epsonc', 'eps9mid'
902          and 'esp9high' ghostscript devices. Needs more
903          work to correctly analyze other devices.
904       
905    - 1.20alpha1 :
906   
907        - Fixed problem with number of copies in PCLXL parser.
908       
909        - Fixed problem with number of copies in PCL5 parser,
910          when number of copies was set outside of and before first
911          page.
912       
913        - Added workaround for number of copies directly set in
914          PostScript code.
915         
916        - Added german translation.
917       
918        - Fixed problem on first print for user group quota when
919          "enforcement: strict" is used.
920       
921        - Fixed interpolation problem in french translation.
922       
923    - 1.19 :
924   
925        - Updated existing translations.   
926       
927        - Added final Thai and Greek translations.
928       
929        - Minor last minute bug fixes.
930       
931    - 1.19beta :
932   
933        - LPRng support for both software and hardware accounting seems
934          to be OK.
935         
936        - Translation files fixed because of fuzzy matching problem. 
937       
938        - Fixed path to Swedish translation: 'sv' instead of 'se'.
939       
940        - Added first draft of Thai translation.
941       
942        - Fixed some minor bugs with Pychecker.
943       
944    - 1.19alpha35 :
945   
946        - Generic PDL analyzer now supports Binary PostScript documents
947          in addition to DSC compliant ones.
948       
949    - 1.19alpha34 :
950   
951        - LPRng support : software accounting seems to work fine,
952          but hardware accounting doesn't work yet.
953   
954    - 1.19alpha33 :
955   
956        - pykosd now accepts command line arguments. Enjoy !
957          NB : due to a bug in xosd, you need xosd version 2.2.8
958          or higher if you don't use the default C locale.
959         
960    - 1.19alpha32 :
961   
962        - Early (not working) version of the LPRng support rewrite.
963       
964        - Saner default configuration file.
965       
966    - 1.19alpha31 :
967   
968        - Fixed a double Python2.1 incompatibility with newer versions,
969          which prevented the PCL5 and the PCLXL parsers to work with
970          this older version of Python.
971         
972    - 1.19alpha30 :
973   
974        - Introduction of preliminary version of the pykosd command
975       
976        - Usernames, Groupnames and Printernames can now contain
977          ANY character, expected '/' and '@'.
978       
979        - Integrated most of the Debian work from Sergio
980          Gonz�z Gonz�z
981         
982    - 1.19alpha29 :
983   
984        - PCLXL parser should now correctly handle number of
985          copies set for each page.
986         
987        - Added testsuite for generic PDL analyzer.
988       
989        - Typo fixed in PCLXL parser.
990       
991        - Correctly dispatches error messages depending on the
992          situation : tools which can be run interactively will
993          ALWAYS output their logs to stderr, excepted for
994          their DEBUG messages, for which the "logger:"
995          directive as set in pykota.conf will be honored.
996          Tools which can't be run interactively will ALWAYS
997          honor the "logger:" directive as set in pykota.conf
998         
999    - 1.19alpha28 :
1000   
1001        - The description field for printers can now be set,
1002          and is displayed in reports.
1003         
1004        - Fixed a small problem in SQL backend code.
1005         
1006        - Improved pkhint
1007       
1008        - First working PCL6 (aka PCLXL) parser !
1009          Doesn't handle copies yet.
1010       
1011    - 1.19alpha27 :
1012   
1013        - Additionnal 10% speed increase in PCL5 parser for GhostScript
1014          generated files (untested yet with other PCL files).
1015         
1016        - Reintroduced the use of mmap in PCL5 parser : this speedups
1017          PCL5 parsing by almost 4 times.
1018          This 4x with the 3x below give us in fact a twelvefold increase
1019          in performance for PCL5 parsing !
1020         
1021        - The Python accelerator Psyco is now used if available
1022          in the generic PDL parser : it speedups PCL5 parsing by
1023          almost three times automagically.
1024         
1025    - 1.19alpha26 :
1026   
1027        - Fixed PCL5 parser according to the sources of rastertohp.
1028       
1029        - Fixed number of copies handling in PCL5 parser : the number
1030          of copies could vary from page to page.
1031         
1032        - Added more debug information to PCLXL parser. 
1033       
1034    - 1.19alpha25 :
1035   
1036        - Added new "description" field to printers in both
1037          PostgreSQL and LDAP. No code to handle this yet.
1038         
1039        - Reversed the fix for power save mode in printers : 
1040          no paper or tray open would have caused people to
1041          be undercharged.
1042         
1043        - Preliminary version of MySQL initialization script.
1044         
1045    - 1.19alpha24 :
1046   
1047        - Native PDF parsing code now works perfectly with
1048          Python 2.1 and above, and is way faster than before.
1049          GhostScript is not used anymore to convert PDF to PS,
1050          because PDF is parsed directly.
1051         
1052    - 1.19alpha23 :
1053   
1054        - Fixed waitprinter.sh wrt PowerSave mode and some
1055          printers. Thanks to Ryan Suarez.
1056       
1057        - Smart PDL analyzer now recognizes PDF too : two
1058          PDF parsing methods are used : a native one which
1059          is very fast but requires Python 2.3 or above, and
1060          a slower one which uses Ghostscript. PyKota detects
1061          automatically which method to use depending on your
1062          version of Python.
1063       
1064        - All tracebacks now include PyKota's version number.
1065         
1066    - 1.19alpha22 :
1067   
1068        - Ensures that the file pointer for job's data is
1069          reset to the start of the job's datas after the
1070          job's size pre-computation phase.
1071         
1072        - Improved PostScript detection code for bad drivers
1073          which don't correctly switch languages between PJL
1074          and PS.
1075       
1076        - Even better debugging code.
1077       
1078    - 1.19alpha21 :
1079   
1080        - Additionnal check.
1081       
1082    - 1.19alpha20 :
1083   
1084        - More complete logging messages wrt accounters.
1085       
1086        - Now catches early failures occuring when the configuration
1087          files are parsed.
1088       
1089    - 1.19alpha19 :
1090   
1091        - Fixed over-verbose exits when displaying help
1092          or version.
1093         
1094        - Extended some PATH in the shell scripts 
1095       
1096        - Deleting an user now also deletes his payments history.
1097       
1098        - Doesn't explicitely ignore SIGCHLD anymore. This seems to
1099          cause problems.
1100
1101    - 1.19alpha18 :
1102   
1103        - History of payments is now stored in the database, and
1104          updated each time an user's balance is modified with
1105          edpykota --balance. This history represents each time
1106          the user was given some positive or negative credit,
1107          but doesn't reflect price paid for jobs, which appear
1108          in the jobs history instead.
1109         
1110        - Jobs history web reports now include the job's size in
1111          bytes. Also columns were reordered to render the report
1112          more easily readable.
1113         
1114    - 1.19alpha17 :
1115   
1116        - Mysterious bug (program exited unexpectedly without leaving
1117          any log message) which occured once in a while when
1118          cancelling jobs should be fixed now.
1119         
1120        - New 'crashrecipient' directive. Disabled by 
1121          default. See sample configuration file to see how
1122          to activate it. It is suggested that you activate it.
1123         
1124        - New PYKOTAJOBSIZEBYTES environment variable exported, 
1125          which contains the job's size in bytes. Empty jobs
1126          are now denied. This value is now stored in the job
1127          history (but not yet displayed from the web interface)
1128         
1129        - Preliminary work on payments storage : the PostgreSQL 
1130          and LDAP schemas should be OK now, but no code is written
1131          yet to support this functionnality.
1132         
1133    - 1.19alpha16 :
1134   
1135        - the newuser and newgroup LDAP specific directives now accept
1136          a second parameter to attach(), "fail" or "warn". If no entry
1137          is found to attach PyKota attributes to, and "fail" was used,
1138          then action is aborted and program exits in error. If "warn"
1139          is used, a new entry is created but a warning message is logged.
1140         
1141        - The job's originating hostname is now stored in the database,
1142          and exported as PYKOTAJOBORIGINATINGHOSTNAME in the environment.
1143       
1144    - 1.19alpha15 :
1145   
1146        - The old pykota filter is now removed. This means that
1147          currently PyKota doesn't support LPRng anymore, but
1148          LPRng support will be re-added, improved, in the near future.
1149         
1150    - 1.19alpha14 :
1151   
1152        - PYKOTAPRECOMPUTEDJOBSIZE and PYKOTAPRECOMPUTEDJOBPRICE
1153          are now exported as environment variables.
1154         
1155        - Heavy CPU usage is now completely fixed it seems, by
1156          introducing some 0.01 second sleeping when nothing to do.
1157         
1158        - Pre-computation of the job's size is now only
1159          done when enforcement is "STRICT", this saves
1160          CPU for people who don't want to use this new
1161          feature.
1162         
1163        - New 'enforcement' directive which accepts either
1164          STRICT or LAXIST. See sample configuration file
1165          for details.
1166         
1167    - 1.19alpha13 :
1168   
1169        - Get back to an old version of the polling loop which
1170          worked fine, but non-optimally. Will be optimized
1171          as time permits.
1172         
1173    - 1.19alpha12 :
1174   
1175        - Job's size is now precomputed unconditionnally using
1176          the generic PDL analyzer.
1177          NB : This value is not yet used to pre-allow/deny the
1178          job.
1179       
1180    - 1.19alpha11 :
1181   
1182        - The pykota filter is now completely deprecated and
1183          can't be used anymore. LPRng users MUST download
1184          an older version of PyKota. CUPS users MUST use
1185          cupspykota. Better support for LPRng will come
1186          in the near future.
1187         
1188    - 1.19alpha10 :
1189   
1190        - pykotme now uses generic PDL Analyzer directly instead
1191          of spawning a new process.
1192         
1193        - Improvements to generic PDL Analyzer.
1194       
1195        - 25% Speedup in PCL parser. Getting more of the Python version
1196          will probably be difficult, since the completely table driven
1197          parser I wrote is slower than the original algorithm. Then,
1198          the original algorithm is still used for now.
1199          Probable that more speed could be achieved using mmap, at the
1200          expense of severe memory consumption.
1201       
1202        - configuration simplifications : the "accounter" directive's
1203          'hardware' arguments now accepts what was in the "requester"
1204          directive as it's content. The "requester" directive is not
1205          supported anymore. See sample configuration file for details.
1206       
1207    - 1.19alpha9 :
1208       
1209        - pkpgcounter is now just a wrapper around the PDLAnalyzer class
1210       
1211        - pykotaOptions LDAP attribute now accepts non-ascii characters
1212          too.
1213         
1214        - First try at cupspykota main loop rewrite
1215       
1216    - 1.19alpha8 :
1217   
1218        - 'querying' accounting method is now called 'hardware'
1219       
1220        - 'external' accounting method is now called 'software'
1221       
1222        - 'stupid' accounting method doesn't exist anymore
1223       
1224        - 'snmp' requester doesn't exist anymore
1225       
1226        - code simplifications in external requester
1227       
1228    - 1.19alpha7 :
1229     
1230        - Database schema change (both LDAP and PostgreSQL) to
1231          allow storage of the job-originating-hostname attribute.
1232          An SQL upgrade script is present. The code is not yet
1233          capable of setting/retrieving this attribute. Support
1234          for this functionnality will be added in the future.
1235         
1236    - 1.19alpha6 :
1237   
1238        - problems connecting to SMTP servers are now catched.
1239       
1240        - pykotme now uses pkpgcounter to compute the size of the
1241          job. This modification adds PCL5 and soon PCLXL (PCL6)
1242          support. You can now get quotes for PCL in addition to
1243          PostScript.
1244         
1245        - pkpgcounter now includes first try at PCLXL parser. 
1246          It is currently disabled until it's finished.
1247         
1248    - 1.19alpha5 :
1249   
1250        - cupspykota polling loop fix for MacOSX (at least)
1251       
1252        - logging subsystem now logs PID too, to ease diagnosing
1253          problems under heavy load.
1254         
1255        - pkpgcounter enhancements.
1256       
1257        - pkprinters --skipexisting now tells pkprinters to not
1258          modify existing printers when --add is used.
1259          pkprinters logs a warning message whenever --add is
1260          used and a printer already exists.
1261         
1262        - LDAP schema now allows accented chars in pykotaFileName
1263          and pykotaTitle attributes.
1264       
1265    - 1.19alpha4 :
1266   
1267        - a bad copy&paste prevented pkpgcounter to work at all, this
1268          is now fixed.
1269         
1270        - improved PCL support in pkpgcounter, with the use of
1271          HP PCL/PJL Reference Set
1272          PCL5 Printer Language Technical Quick Reference Guide
1273       
1274        - pkpgcounter now uses mmap to speed things up : duration
1275          is halved with the sample 87 pages PCL document I use for
1276          testing.
1277         
1278    - 1.19alpha3 :
1279   
1280        - pkprinters now accepts the --list command line argument
1281          to list informations about printers.
1282         
1283    - 1.19alpha2 :
1284   
1285        - pkpgcounter is now included as a smart external
1286          accounter which can handle both PostScript and PCL.
1287         
1288    - 1.19alpha1 :
1289   
1290        - PYKOTALIMITBY environment variable is now exported too.
1291       
1292        - Inclusion of Michele Baldessari's work on autotools.
1293       
1294    - 1.18 :
1295   
1296        - Improved documentation
1297       
1298    - 1.18beta2 :
1299     
1300        - Fix for raw jobs with cupspykota
1301       
1302    - 1.18beta :
1303   
1304        - Small fix for new waitprinter.sh script
1305       
1306        - Better tracebacks on error conditions
1307       
1308        - Improved translations
1309       
1310        - Improved documentation
1311       
1312    - 1.18alpha15 :
1313
1314        - waitprinter.sh replaced by a new and possibly faster
1315          and more powerful one.
1316   
1317        - Names can now begin with a digit.
1318       
1319        - Stability improvement for quotas set on printers groups.
1320       
1321    - 1.18alpha14 :
1322   
1323        - Catches more (all ?) problems with SMTP servers instead
1324          of breaking.
1325         
1326        - Italian translation added.
1327       
1328    - 1.18alpha13 :
1329   
1330        - Pre and Post hooks are now available in the pykota
1331          filter as well.
1332         
1333        - The pykota filter doesn't check last user's quota
1334          anymore when delayed hardware accounting is used :
1335          this will be done anyway the next time the last
1336          user will print again. This saves some database
1337          queries which are unneeded.
1338       
1339    - 1.18alpha12 :
1340   
1341        - Pre and Post hooks to external commands with many
1342          many environment variables available are useable
1343          from the cupspykota backend.
1344          See sample configuration file for details and help.
1345         
1346    - 1.18alpha11 :
1347   
1348        - Hopefully final fix wrt groups (users and printers)
1349       
1350    - 1.18alpha10 :
1351   
1352        - Fixed nested printer groups accounting.
1353       
1354        - Fixed user groups + printer groups problem.
1355       
1356    - 1.18alpha9 :
1357   
1358        - Fix for LDAP problem when job price was 0.
1359       
1360        - Fix for empty user groups with LDAP.
1361       
1362        - Preliminary version of the snmpprinterstatus command added.
1363       
1364    - 1.18alpha8 :
1365   
1366        - Don't retrieve data when not needed.
1367          This avoids many database queries.
1368       
1369    - 1.18alpha7 :
1370   
1371        - New experimental ldapcache directive to improve
1372          LDAP caching.
1373         
1374    - 1.18alpha6 :
1375       
1376        - New configuration directive added : maildomain
1377          to specify the domain to send mail to when user
1378          email address is not set in PyKota database.
1379         
1380        - More complete email message headers. 
1381         
1382    - 1.18alpha5 :
1383   
1384        - Debian packaging specific files, contributed by
1385          Peter Hawkins are now included in the project's tree.
1386         
1387        - Preliminary work on future low-level LDAP caching to speed
1388          up modifications (at least).
1389         
1390    - 1.18alpha4 :
1391   
1392        - Applied some of the modifications suggested by
1393          Peter Hawkins, for better Debian integration.
1394          Most notably cupspykota, pykota, and the shell
1395          scripts are now installed into /usr/share/pykota
1396          instead of into /usr/bin
1397          BEWARE : double check that your symbolic link
1398          to cupspykota is correct, and that your pykota.conf
1399          file use correct path for the shell scripts like
1400          waitprinter.sh and al.
1401         
1402        - pkhint command added, to help in configuring correct
1403          accounting method for PyKota.
1404         
1405    - 1.18alpha3 :
1406   
1407        - Fixed a rare bug in cupspykota backend which gave
1408          incorrect "CUPS backend died abnormally" messages.
1409       
1410    - 1.18alpha2 :
1411   
1412        - Added the pkprinters command line tool to manage printers
1413          exclusively.
1414       
1415    - 1.18alpha1 :
1416   
1417        - Preliminary work on Relationnal Database Independance.
1418       
1419        - Sample report made from OpenOffice.org added as PDF and SXC.
1420       
1421    - 1.17 :
1422   
1423        - Finalized release.
1424       
1425    - 1.17alpha2 :
1426   
1427        - Fix stupid software accounting bug in the CUPS backend.
1428       
1429    - 1.17alpha1 :
1430   
1431        - User/Group deletion code in edpykota rewritten.
1432       
1433    - 1.16 :
1434   
1435        - Preliminary documentation on how to use OpenOffice.org
1436          to create personnalized reports for PyKota + PostgreSQL.
1437         
1438        - Spanish installation guide for CUPS+PyKota+PostgreSQL
1439          added to the documentation. Doesn't yet document v1.16
1440          though.
1441       
1442        - Portuguese Portuguese translation replaces Brazilian
1443          Portuguese Translation. Brazilian portuguese
1444          translation is still available under the 'br' locale.
1445       
1446    - 1.16beta3 :
1447   
1448        - Swedish translation added.
1449       
1450        - Small fix in documentation.
1451       
1452    - 1.16beta2 :
1453   
1454        - Small fix for job cancelling code while job already
1455          printing in CUPS backend.
1456         
1457        - Big fix wrt printing policies for unknown users. 
1458       
1459    - 1.16beta1 :
1460   
1461        - Manpages upgraded.
1462       
1463    - 1.16alpha26 :
1464   
1465        - Job price is now computed like this :
1466       
1467          SUM((NbPages * PricePerPage) + PricePerJob)
1468         
1469          For current printer and all the printers groups it is
1470          a member of, if any.
1471         
1472          This may be difficult to grasp, but offers unprecedented
1473          flexibility.
1474         
1475    - 1.16alpha25 :
1476   
1477        - Email address can be set at user creation time,
1478          using the following syntax :
1479         
1480            $ edpykota --add username/email@yourdomain.com
1481       
1482    - 1.16alpha24 :
1483   
1484        - CGI script now can show the printing history.
1485       
1486        - Bug wrt number of copies should be fixed.
1487       
1488        - Major code refactoring => It is now possible to
1489          automatically add printers on first print.
1490       
1491    - 1.16alpha23 :
1492   
1493        - Fixed potential accuracy problem if a user printed on
1494          several printers at the very same time.
1495       
1496    - 1.16alpha22 :
1497   
1498        - edpykota now allows adding printers to printer groups
1499       
1500    - 1.16alpha21 :
1501   
1502        - Allows the dot in user and printer names.
1503       
1504        - Printer groups are now cached too.
1505       
1506    - 1.16alpha20 :
1507   
1508        - Fixed several small bugs with the help of PyChecker.
1509       
1510    - 1.16alpha19 :
1511     
1512        - Fixed a bug in PostgreSQL backend's code.
1513       
1514    - 1.16alpha18 :
1515   
1516        - Initial code for printer groups support. Printer groups have
1517          to be added with external tools like psql or gq for example.
1518          Printer groups seems to work fine with users. Untested with user
1519          groups for now.
1520
1521        - Several minor visual problems fixed in reports.
1522       
1523        - Fixed a bug in LDAP date handling.
1524       
1525        - Fix for LDAP problem with some combination of OpenLDAP + Python-LDAP
1526          + some particular settings.
1527         
1528        - mailandpopup.sh shell script added. See sample configuration file
1529          for details.
1530       
1531        - Several environment variables are now exported when executing
1532          external commands (accounters, requesters, mailers) :
1533           
1534            PYKOTAUSERNAME => user who is printing
1535            PYKOTAPRINTERNAME => printer on which the job is being sent
1536            PYKOTATITLE => Job's title
1537            PYKOTAFILENAME => Job's filename
1538            PYKOTACOPIES => number of copies asked
1539            PYKOTAOPTIONS => print command options (-o with CUPS)
1540         
1541    - 1.16alpha17 :
1542   
1543        - Added portugues translation.
1544       
1545        - Major code refactoring in accounters.
1546       
1547    - 1.16alpha16 :
1548   
1549        - Code refactoring, and addition of a real HTML reporter, to
1550          have nice looking and useful web based reports (in the future).
1551       
1552        - Added utolower configuration option to convert all usernames
1553          to lowercase during printing.
1554         
1555    - 1.15alpha15 :
1556   
1557        - Now includes the papwaitprinter.sh shell script to wait for
1558          AppleTalk enabled printers.
1559         
1560    - 1.16alpha14 :
1561   
1562        - Now printing on a printer not defined in the Quota Storage,
1563          results in the job being cancelled or stopped, depending
1564          on the printing system.
1565         
1566    - 1.16alpha13 :
1567   
1568        - Small bugfix wrt Python v2.1
1569       
1570        - If username is an empty string, user root is assumed.
1571       
1572        - 'postgresql' is not recognized anymore as a storage backend,
1573          you have to use 'pgstorage' instead. 'postgresql' used to
1574          be supported for compatibility with very old PyKota versions,
1575          this is not the case anymore.
1576         
1577    - 1.16alpha12 :
1578   
1579        - Job price added to job history, to keep accounting correct
1580          if a printer price per page or per job is modified and the
1581          history is not reset : the history would have given a false
1582          amount of money charged before the printer's prices were
1583          modified, this addition solves the problem.
1584         
1585    - 1.16alpha11 :
1586   
1587        - Some preliminary modifications to the database structure for
1588          PostgreSQL and OpenLDAP. A script to upgrade a PostgreSQL
1589          database is now provided. LDAP attributes now support
1590          eq, pres and sub indexes.
1591         
1592        - Job history now contains additional informations : 
1593          number of copies, filename, title and print options.
1594         
1595    - 1.16alpha10 :
1596       
1597        - Some modifications done to external policy handling.
1598          See sample configuration file for details.
1599   
1600        - Spanish translation added.
1601       
1602    - 1.16alpha9 :
1603   
1604        - mailto can be set to external(...) to warn users above
1605          quota with any command of your choice (e.g. linpopup).
1606          Several parameters are available, see sample configuration
1607          file for details.
1608         
1609    - 1.16alpha8 :
1610   
1611        - Now cupspykota transmits SIGTERMS to the original 
1612          backend when the user deletes a job being processed.
1613         
1614        - The documentation is now licensed under the terms of the
1615          GNU GPL too.
1616         
1617    - 1.16alpha7 :
1618   
1619        - The CUPS backend is now fully functionnal (it seems).
1620       
1621        - From now on, the use of the pykota filter with CUPS
1622          is deprecated. The pykota filter still has to be
1623          used with LPRng though.
1624       
1625    - 1.16alpha6 :
1626   
1627        - Bug fixed : when edpykota was used to add a printer
1628          with no user or group name, a bad user/group name "*" was
1629          added to the database.
1630         
1631    - 1.16alpha5 :
1632   
1633        - New CUPS backend supports device enumeration !
1634          This means that NO manual CUPS configuration has to
1635          be done. All can now be done from CUPS web interface.
1636       
1637    - 1.16alpha4 :
1638   
1639        - New CUPS backend added.
1640       
1641    - 1.16alpha3 :
1642       
1643        - Minimal FAQ document added.
1644       
1645    - 1.16alpha2 :
1646   
1647        - CGI script now partially supports browser's language preference
1648       
1649    - 1.16alpha1 :
1650   
1651        - Ensures that the LDAP connection is really closed at end.
1652       
1653        - More complete error messages in case of LDAP operation failure.
1654       
1655    - 1.15 :
1656     
1657        - Documentation improved.
1658       
1659    - 1.15beta :
1660   
1661        - Command line tools now accept multiple printer
1662          names or wildcards, separated with commas.
1663         
1664    - 1.15alpha9 :
1665   
1666        - External policy can be used to auto-add unknown users
1667          and any other interesting things you may want to do.
1668          WARNING : You can't auto-add printers for now.
1669          They have to be created manually before.
1670          Look at sample configuration file for examples.
1671         
1672    - 1.15alpha8 :
1673   
1674        - Job history can be disabled if needed.
1675          This feature may be useful for people who use the LDAP
1676          backend and don't want their LDAP tree to grow out of
1677          control.
1678       
1679    - 1.15alpha7 :
1680   
1681        - More work done on caching wrt groups.
1682       
1683    - 1.15alpha6 :
1684   
1685        - Performance bottleneck with LDAP solved.
1686       
1687    - 1.15alpha5 :
1688   
1689        - Caching mechanism for all database queries.
1690
1691    - 1.15alpha4 :
1692   
1693        - Problem with Python 2.3 fixed. Needs some definitive
1694          modification.
1695         
1696    - 1.15alpha3 :
1697   
1698        - CGI script now tries to restrict view when the
1699          REMOTE_USER environment variable is set. This allows
1700          people to protect its use with .htaccess files.
1701          When unprotected, or if REMOTE_USER is 'root', then
1702          unrestricted access is granted.
1703          NB : REMOTE_USER is automatically set by the web server
1704          (e.g. Apache) when a page with restricted access is viewed.
1705         
1706    - 1.15alpha2 :
1707   
1708        - Better detection of LPRng.
1709       
1710        - Outputs a warning if printing system is unknown.
1711       
1712    - 1.15alpha1 :
1713   
1714        - Bug fix in SQL code.
1715       
1716    - 1.14 :
1717   
1718        - The PostgreSQL database connection is now always closed before
1719          exit. The LDAP database connection too, but it didn't suffer
1720          from the problem anyway, AFAICT.
1721       
1722    - 1.14beta2 :
1723   
1724        - An LDAP-specific configuration field was introduced, usermail.
1725          Use it to specify which LDAP attribute contains a valid email
1726          address for the user. See sample configuration file for
1727          details.
1728       
1729    - 1.14beta :
1730   
1731        - Two new LDAP-specific configuration fields were introduced,
1732          newuser and newgroup. Use them to specify if you want to add
1733          quota information to existing entries or elsewhere.
1734          See sample configuration file for details.
1735         
1736    - 1.14alpha9 :
1737   
1738        - Documentation improved.
1739       
1740        - pykotme now also prints the user's account balance value
1741          if the user is registered in the Quota Storage and his
1742          limiting factor is "balance".
1743         
1744    - 1.14alpha8 :
1745   
1746        - bin/waitprinter.sh is now included to wait for
1747          SNMP enabled printers to be idle again before
1748          asking for their internal page counter.
1749          See sample configuration file for details.
1750         
1751    - 1.14alpha7 :
1752   
1753        - edpykota now doesn't check if the user/group is above
1754          quota. The check is only done at print time. This
1755          prevents the sending of email messages when creating
1756          user quotas if quota is already reached at creation
1757          time.
1758         
1759    - 1.14alpha6 :
1760   
1761        - Configuration file split and moved to /etc/pykota/pykota.conf
1762          and /etc/pykota/pykotadmin.conf to prevent simple users to
1763          have Read/Write access to the Quota Database.
1764          Don't forget to :
1765         
1766                $ chmod 640 /etc/pykota/pykotadmin.conf
1767               
1768        - storageuser and storageuserpw configuration fields reintroduced
1769          for the same reason.
1770         
1771        - Code cleaning for future implementation of email addresses
1772          support in the PostgreSQL and LDAP backends.
1773         
1774    - 1.14alpha5 :
1775       
1776        - Big bug fixed when changing the prices for a printer
1777       
1778    - 1.14alpha4 :
1779   
1780        - When adding an user, the user itself and its account balance
1781          are now added in the same LDAP entry. Before they were added
1782          as two different LDAP entries.
1783         
1784    - 1.14alpha3 :
1785   
1786        - Email field added to PostgreSQL database. An upgrade script
1787          is included in initscripts/postgresql.
1788       
1789    - 1.14alpha2 :
1790   
1791        - Typo fixed when using the --prototype option to edpykota
1792       
1793    - 1.14alpha1 :
1794   
1795        - Poor man's treshold included : users with a low account
1796          balance (below 1.0 by default, configurable) are sent
1797          a warning message.
1798         
1799        - All warning messages to users are now configurable. 
1800          NB : Warning messages to the administrator are not.
1801       
1802    - 1.13 :
1803   
1804        - Some small fixes wrt group handling.
1805       
1806        - The whole module code was passed through PyChecker and
1807          several small code inconsistencies were fixed,
1808          as well as a bug in the groups code.
1809         
1810    - 1.13alpha1 :
1811   
1812        - Bug fix wrt LDAP.
1813       
1814    - 1.12 :
1815   
1816        - More complete test added in edpykota.
1817       
1818    - 1.12alpha2 :
1819   
1820        - The previous bug fix was incomplete. This is corrected.
1821       
1822    - 1.12alpha1 :
1823   
1824        - Small bug fix.
1825       
1826    - 1.11 :
1827   
1828        - Now includes the pykotme command line tool, to produce
1829          printing quotes for users.
1830         
1831    - 1.10 :
1832   
1833        - Bug fixed wrt quota reports when print limiting is by
1834          account balance.
1835         
1836    - 1.09 :
1837   
1838        - Translations finalized.
1839       
1840        - Manpages updated.
1841       
1842        - Installation documentation improved wrt LDAP support.
1843       
1844    - 1.09beta2 :
1845   
1846        - The CGI script for quota reports works again, and
1847          is much more powerful.
1848       
1849    - 1.09beta :
1850   
1851        - edpykota finalized
1852       
1853    - 1.09alpha2 :
1854   
1855        - LDAP schema modified a bit. Please upgrade.
1856       
1857        - LDAP backend works !
1858       
1859        - repykota and warnpykota allow the root user to pass
1860          users or groups names on the command line. Users
1861          and groups names may contain wildcards.
1862         
1863        - repykota and warnpykota only reports or warns the
1864          current user when launched by non-root users.
1865         
1866        - Minor bug fixes. 
1867   
1868    - 1.09alpha1 :
1869   
1870        - More work on LDAP storage backend. Many options
1871          were added to /etc/pykota.conf to give some
1872          hints to the LDAP storage backend.
1873         
1874        - Severe database access optimizations were done by
1875          rewriting most of the Quota Storage backends drivers.
1876     
1877    - 1.08 :
1878   
1879        - Major bug fix wrt LPRng support for remote jobs.
1880       
1881        - Major bug fix wrt increase/decrease account balances.
1882       
1883    - 1.08alpha8 :
1884   
1885        - Code refactoring.
1886       
1887        - A single user/password pair is used to connect
1888          to the database backend. The storageuser configuration
1889          field, and its associated passwords storageuserpw, are
1890          not used anymore.
1891         
1892        - You can now set PyKota in debug mode, see sample configuration 
1893          file for details.
1894          WARNING : only Quota Storage backend queries are logged in
1895          debug mode, for now.
1896       
1897    - 1.08alpha7 :
1898   
1899        - Very latest LDAP schema.
1900       
1901        - Code enhancement wrt easy pluggability of PyKota attributes
1902          and object classes into an existing LDAP directory.
1903       
1904    - 1.08alpha6 :
1905   
1906        - Minor bug corrections
1907       
1908        - More work on LDAP : new schema
1909       
1910    - 1.08alpha5 :
1911   
1912        - More good work on LDAP storage.
1913          repykota now works reasonably well with the sample LDAP directory.
1914       
1915    - 1.08alpha4 :
1916   
1917        - LDAP schema included.
1918          THIS IS JUST FOR PEOPLE TO DISCUSS ABOUT THIS.
1919          LDAP SUPPORT DOESN'T WORK YET, AND THE SCHEMA
1920          MAY CHANGE IN THE FUTURE. PLEASE TELL US
1921          WHAT YOU THINK ABOUT THIS SCHEMA ON THE
1922          MAILING LIST.
1923         
1924    - 1.08alpha3 :
1925   
1926        - External accounting methods were partly rewritten :
1927         
1928          - No more "broken pipe" should happen.
1929         
1930          - They now take care of the number of copies
1931            This may be unneeded though, if the postscript
1932            file already does this, because this would
1933            overcharge users (number of copies counted
1934            two times). NEEDS MORE TESTING.
1935           
1936          - The sample configuration file now contains 
1937            an external accounting method example which should
1938            work with all DSC compliant Postscript files.
1939           
1940        - Some small bugs were fixed.   
1941       
1942    - 1.08alpha2 :
1943   
1944        - Now works with net-snmp v5.0 and above.
1945          It already worked, but the sample configuration
1946          file didn't contain appropriate values...
1947       
1948    - 1.07 : Release of the Shame !
1949   
1950        - The external accounting methods driver was left out of
1951          the CVS tree. Nobody could use it since it wasn't included !
1952         
1953    - 1.06 :
1954   
1955        - Severe bug fixed : if you had a printer in
1956          power saving state which couldn't answer immediately,
1957          a bug was triggered.
1958          It was caused by a bad copy/paste which
1959          forgot to import a Python module at run time.
1960         
1961    - 1.05 :
1962   
1963        - External accounters are finally available !
1964          This means that you can plug any page accounting
1965          method you like by setting the appropriate
1966          'accounter' field in /etc/pykota.conf
1967          See the sample conf/pykota.conf.sample to
1968          learn how to do.
1969         
1970          NB : Both 'external' and 'stupid' accounting methods
1971               account a job size just before *this* job is
1972               sent to the printer.
1973               The original 'querying' method accounts a job
1974               size just before *the next* job is sent to
1975               the printer.
1976       
1977    - 1.05alpha3 :
1978   
1979        - A 'stupid' and unreliable accounting method was
1980          implemented to serve as an example on how to
1981          do this sort of things. This method only counts
1982          the 'showpage' statements in the input data.
1983          See sample configuration file for details.
1984          Pluggable accounting methods work, but I advise
1985          you TO NOT USE THIS ONE WHICH IS JUST AN EXAMPLE.
1986          It is not reliable enough to be used.
1987          Use the 'querying' accounting method instead.
1988         
1989    - 1.05alpha2 :
1990   
1991        - Pluggable accounting methods.
1992       
1993        - Better error handling.
1994       
1995    - 1.05alpha1 :
1996   
1997        - SECURITY file added to help improve PyKota's security.
1998       
1999        - Extracting the printer's internal page counter is now
2000          tried several times, waiting several seconds between
2001          two tries. This lets the time to warm up for some printers
2002          which don't answer when they are sleeping (my Apple
2003          LaserWriter 16/600 PS is in this case, maybe others too)
2004         
2005        - Small display bug fixed in repykota
2006         
2007    - 1.04 :
2008   
2009        - Default print policy for users/groups unknown from
2010          the print quota system is now DENY instead of ALLOW,
2011          since ALLOW can generate inaccurate results
2012          (incorrect job sizes charged to the wrong persons)
2013         
2014        - LPRng support works !
2015       
2016        - A bug was introduced some time ago wrt printers' default
2017          policy for unknown users. It is now corrected.
2018       
2019        - repykota now displays prices per job and per page for each
2020          printer, if they are defined.
2021         
2022        - Minor display bug fixed in repykota.
2023       
2024        - Problem when running repykota with an empty database was fixed.
2025       
2026    - 1.03 :
2027   
2028        - Upgrade script included for earlier versions.
2029          Please look inside the initscripts subdirectory.
2030          THE DATABASE SCHEMA HAS CHANGED, PLEASE UPGRADE.
2031         
2032        - repykota now reports account balances too.
2033       
2034        - PyKota now has a nice logo, see the logos
2035          subdirectory.
2036       
2037        - Manual pages were finally updated.
2038       
2039        - Group quotas seem to work now !
2040       
2041        - The new database schema allows to keep an history of all
2042          jobs as well as charge users per page and/or per job,
2043          and track users' account balance.
2044         
2045        - edpykota now accepts much more command line options to 
2046          use the new functionnalities. See edpykota --help for
2047          details.
2048         
2049        - The installation script now allows to install the sample
2050          configuration file during first installation.
2051         
2052        - More group quota code works, but still not finished. 
2053       
2054        - The CGI script displays a link to PyKota's website.
2055       
2056        - The job history is now kept, this will allow per-period
2057          reports in the future.
2058         
2059        - After having modified the quota for an user with edpykota,
2060          a quota check is done to eventually warn the user/admin about
2061          a quota which is too low to print.
2062         
2063        - A workaround is provided for HP Printers : their internal
2064          page counter is only saved to NVRAM in a 10 increment, so
2065          if you switch them off and then on, the reported page counter
2066          may be lower than the real number of pages printed.
2067          See http://web.mit.edu/source/third/lprng/doc/LPRng-HOWTO-15.html
2068          We unconditionnally set the last job's page count to
2069          abs(int((10 - abs(lastcounter(snmp) - lastcounter(storage)) / 2))
2070          in this case.
2071          For a more accurate accounting, never switch your HP printers
2072          off.
2073         
2074        - A fix is provided for printers which only have a volatile 
2075          page counter (reset to 0 every time you switch the printer on)
2076          This should allow PyKota to work reasonably fine with HP Laserjet
2077          4L/5L/6L, not perfect, but better than nothing.
2078          See http://web.mit.edu/source/third/lprng/doc/LPRng-HOWTO-15.html
2079          For a more accurate accounting, never switch your HP printers
2080          off. This is untested, please report any problem.
2081         
2082        - A bug was fixed when edpykota --add was used with users who already
2083          had a quota on the specified printer.
2084         
2085        - A small display bug in repykota was introduced in preliminary
2086          1.03 versions, and fixed later on.
2087         
2088        - Some minor bugs which happened in rare situations were fixed.
2089       
2090        - Support for AppleTalk printers was added, see sample configuration
2091          file for details.
2092         
2093        - Users and group printing can now be controlled (limited) either by 
2094          print quota or by account balance.
2095       
2096    - 1.02 :
2097   
2098        - The installation script now checks for software availability
2099          and in case a software is missing asks the user if he
2100          wants to continue with the installation or abort it.
2101         
2102        - The configuration file pykota.conf is now expected to be
2103          found in /etc instead of in /etc/cups
2104          The installation script prompts the user to see if he
2105          wants to move an old configuration file to the new location
2106          if needed.
2107         
2108        - Improved documentation.
2109       
2110        - You can now set the tcp/ip port on which the Quota Storage
2111          Server is listening, see sample configuration file for details.
2112       
2113        - Better general error handling.
2114       
2115        - Upgrade script for pre 1.01 PostgreSQL database schema is now
2116          included as well.
2117       
2118    - 1.01 :
2119   
2120        - The configuration file now accepts an option   
2121          to choose the recipient(s) of the email messages :
2122         
2123            - DevNull means no one will receive them.
2124            - User means only the user will receive them.
2125            - Admin means only the admin will receive them.
2126            - Both means the User and the Admin will receive them.
2127           
2128        - The configuration file now uses hard-coded default values
2129          when an option is not set. See sample configuration file
2130          for details.
2131         
2132        - Manual pages are included since 1.00, but I forgot to   
2133          add this information to this file.
2134         
2135        - Redistribution terms for the official package have 
2136          softened and are now fully GPL compatible :
2137          unrestricted modification is now allowed even for
2138          the version number.
2139         
2140    - 1.00 :
2141   
2142        - edpykota now accepts a --noquota option. This
2143          disable quota checking while still doing page
2144          accounting. This is really useful for people
2145          who don't want to limit their users but want
2146          to know how much pages they print.
2147         
2148        - Some untested scripts were added to retrieve
2149          the life time page counter of non-SNMP printers.
2150         
2151        - Every directory now has a specific README file. 
2152       
2153    - 0.99 :
2154   
2155        - Under some circumstances while the user wasn't allowed
2156          to print, he didn't receive any email message. It is
2157          now fixed.
2158         
2159        - When an user wasn't allowed to print, the quota for
2160          the previous user wasn't updated. This is now fixed.
2161         
2162    - 0.98 :
2163   
2164        - Correctly handle the case where the printer is switched off.
2165       
2166        - Small bug wrt syslog fixed.
2167       
2168    - 0.97 :
2169   
2170        - edpykota accepts wildcards on its command line for users/groups too
2171          if the --add option is not set, e.g. :
2172         
2173              $ edpykota --printer lp --softlimit 50 --hardlimit 100 "jer*"
2174             
2175        - If no user name is passed at all, then a default wildcard of "*"
2176          which means apply the command on ALL users for this printer is used.
2177         
2178        - Small bug fixes.
2179       
2180    - 0.96 :
2181
2182        - Options requester, policy, admin, adminmail and gracedelay can now
2183          be set either globally or per printer. The printer option has
2184          priority if both are defined.
2185
2186        - More powerful configuration parser.
2187       
2188        - If all options are defined globally, there's no need to
2189          define a section for each printer in the configuration
2190          file anymore. Just define a [global] section and it's ok.
2191
2192    - 0.95 :
2193
2194        - External requesters for printers finally added.
2195
2196        - Full internationalization (english and french are supported)
2197 
2198        - More complete quota usage report
2199
2200        - CGI script to access to the quota usage report
2201
2202        - Several bugs fixed.
2203
2204
2205    - 0.9 :
2206
2207        - First public version
Note: See TracBrowser for help on using the browser.