root / pykota / trunk / NEWS @ 2791

Revision 2791, 77.1 kB (checked in by jerome, 19 years ago)

Version number.

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