root / pykota / trunk / NEWS @ 2762

Revision 2762, 76.7 kB (checked in by jerome, 18 years ago)

Make pkusers --list behave like edpykota --list : allowed to normal users,
but restricted in what can be seen.

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