root / pykota / trunk / NEWS @ 2635

Revision 2635, 74.7 kB (checked in by jerome, 19 years ago)

Introduced the 'preaccounter' directive.

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