root / pykota / trunk / NEWS @ 2631

Revision 2631, 74.4 kB (checked in by jerome, 19 years ago)

Added support for the CANCEL command in subprocesses launched from the
overwrite_jobticket directive : this will allow end users to be asked
if they really want to proceed to printing once the new version
of pykoticon will be ready.
Several minor fixes.

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