root / pykota / trunk / NEWS @ 2677

Revision 2677, 75.3 kB (checked in by jerome, 18 years ago)

Ensures that pkbcodes doesn't enter the modification loop if there's nothing to modify.

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