root / pykota / trunk / NEWS @ 1526

Revision 1526, 37.8 kB (checked in by jalet, 20 years ago)

Fixed over-verbose exits when displaying help or version number

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
Line 
1# $Id$
2
3PyKota - Print Quota for CUPS
4
5(c) 2003-2004 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., 59 Temple Place, Suite 330, Boston, MA 02111-1307, USA.
19
20============================================================
21
22PyKota NEWS :
23
24    - 1.19alpha19 :
25   
26        - Fixed over-verbose exits when displaying help
27          or version.
28
29    - 1.19alpha18 :
30   
31        - History of payments is now stored in the database, and
32          updated each time an user's balance is modified with
33          edpykota --balance. This history represents each time
34          the user was given some positive or negative credit,
35          but doesn't reflect price paid for jobs, which appear
36          in the jobs history instead.
37         
38        - Jobs history web reports now include the job's size in
39          bytes. Also columns were reordered to render the report
40          more easily readable.
41         
42    - 1.19alpha17 :
43   
44        - Mysterious bug (program exited unexpectedly without leaving
45          any log message) which occured once in a while when
46          cancelling jobs should be fixed now.
47         
48        - New 'crashrecipient' directive. Disabled by 
49          default. See sample configuration file to see how
50          to activate it. It is suggested that you activate it.
51         
52        - New PYKOTAJOBSIZEBYTES environment variable exported, 
53          which contains the job's size in bytes. Empty jobs
54          are now denied. This value is now stored in the job
55          history (but not yet displayed from the web interface)
56         
57        - Preliminary work on payments storage : the PostgreSQL 
58          and LDAP schemas should be OK now, but no code is written
59          yet to support this functionnality.
60         
61    - 1.19alpha16 :
62   
63        - the newuser and newgroup LDAP specific directives now accept
64          a second parameter to attach(), "fail" or "warn". If no entry
65          is found to attach PyKota attributes to, and "fail" was used,
66          then action is aborted and program exits in error. If "warn"
67          is used, a new entry is created but a warning message is logged.
68         
69        - The job's originating hostname is now stored in the database,
70          and exported as PYKOTAJOBORIGINATINGHOSTNAME in the environment.
71       
72    - 1.19alpha15 :
73   
74        - The old pykota filter is now removed. This means that
75          currently PyKota doesn't support LPRng anymore, but
76          LPRng support will be re-added, improved, in the near future.
77         
78    - 1.19alpha14 :
79   
80        - PYKOTAPRECOMPUTEDJOBSIZE and PYKOTAPRECOMPUTEDJOBPRICE
81          are now exported as environment variables.
82         
83        - Heavy CPU usage is now completely fixed it seems, by
84          introducing some 0.01 second sleeping when nothing to do.
85         
86        - Pre-computation of the job's size is now only
87          done when enforcement is "STRICT", this saves
88          CPU for people who don't want to use this new
89          feature.
90         
91        - New 'enforcement' directive which accepts either
92          STRICT or LAXIST. See sample configuration file
93          for details.
94         
95    - 1.19alpha13 :
96   
97        - Get back to an old version of the polling loop which
98          worked fine, but non-optimally. Will be optimized
99          as time permits.
100         
101    - 1.19alpha12 :
102   
103        - Job's size is now precomputed unconditionnally using
104          the generic PDL analyzer.
105          NB : This value is not yet used to pre-allow/deny the
106          job.
107       
108    - 1.19alpha11 :
109   
110        - The pykota filter is now completely deprecated and
111          can't be used anymore. LPRng users MUST download
112          an older version of PyKota. CUPS users MUST use
113          cupspykota. Better support for LPRng will come
114          in the near future.
115         
116    - 1.19alpha10 :
117   
118        - pykotme now uses generic PDL Analyzer directly instead
119          of spawning a new process.
120         
121        - Improvements to generic PDL Analyzer.
122       
123        - 25% Speedup in PCL parser. Getting more of the Python version
124          will probably be difficult, since the completely table driven
125          parser I wrote is slower than the original algorithm. Then,
126          the original algorithm is still used for now.
127          Probable that more speed could be achieved using mmap, at the
128          expense of severe memory consumption.
129       
130        - configuration simplifications : the "accounter" directive's
131          'hardware' arguments now accepts what was in the "requester"
132          directive as it's content. The "requester" directive is not
133          supported anymore. See sample configuration file for details.
134       
135    - 1.19alpha9 :
136       
137        - pkpgcounter is now just a wrapper around the PDLAnalyzer class
138       
139        - pykotaOptions LDAP attribute now accepts non-ascii characters
140          too.
141         
142        - First try at cupspykota main loop rewrite
143       
144    - 1.19alpha8 :
145   
146        - 'querying' accounting method is now called 'hardware'
147       
148        - 'external' accounting method is now called 'software'
149       
150        - 'stupid' accounting method doesn't exist anymore
151       
152        - 'snmp' requester doesn't exist anymore
153       
154        - code simplifications in external requester
155       
156    - 1.19alpha7 :
157     
158        - Database schema change (both LDAP and PostgreSQL) to
159          allow storage of the job-originating-hostname attribute.
160          An SQL upgrade script is present. The code is not yet
161          capable of setting/retrieving this attribute. Support
162          for this functionnality will be added in the future.
163         
164    - 1.19alpha6 :
165   
166        - problems connecting to SMTP servers are now catched.
167       
168        - pykotme now uses pkpgcounter to compute the size of the
169          job. This modification adds PCL5 and soon PCLXL (PCL6)
170          support. You can now get quotes for PCL in addition to
171          PostScript.
172         
173        - pkpgcounter now includes first try at PCLXL parser. 
174          It is currently disabled until it's finished.
175         
176    - 1.19alpha5 :
177   
178        - cupspykota polling loop fix for MacOSX (at least)
179       
180        - logging subsystem now logs PID too, to ease diagnosing
181          problems under heavy load.
182         
183        - pkpgcounter enhancements.
184       
185        - pkprinters --skipexisting now tells pkprinters to not
186          modify existing printers when --add is used.
187          pkprinters logs a warning message whenever --add is
188          used and a printer already exists.
189         
190        - LDAP schema now allows accented chars in pykotaFileName
191          and pykotaTitle attributes.
192       
193    - 1.19alpha4 :
194   
195        - a bad copy&paste prevented pkpgcounter to work at all, this
196          is now fixed.
197         
198        - improved PCL support in pkpgcounter, with the use of
199          HP PCL/PJL Reference Set
200          PCL5 Printer Language Technical Quick Reference Guide
201       
202        - pkpgcounter now uses mmap to speed things up : duration
203          is halved with the sample 87 pages PCL document I use for
204          testing.
205         
206    - 1.19alpha3 :
207   
208        - pkprinters now accepts the --list command line argument
209          to list informations about printers.
210         
211    - 1.19alpha2 :
212   
213        - pkpgcounter is now included as a smart external
214          accounter which can handle both PostScript and PCL.
215         
216    - 1.19alpha1 :
217   
218        - PYKOTALIMITBY environment variable is now exported too.
219       
220        - Inclusion of Michele Baldessari's work on autotools.
221       
222    - 1.18 :
223   
224        - Improved documentation
225       
226    - 1.18beta2 :
227     
228        - Fix for raw jobs with cupspykota
229       
230    - 1.18beta :
231   
232        - Small fix for new waitprinter.sh script
233       
234        - Better tracebacks on error conditions
235       
236        - Improved translations
237       
238        - Improved documentation
239       
240    - 1.18alpha15 :
241
242        - waitprinter.sh replaced by a new and possibly faster
243          and more powerful one.
244   
245        - Names can now begin with a digit.
246       
247        - Stability improvement for quotas set on printers groups.
248       
249    - 1.18alpha14 :
250   
251        - Catches more (all ?) problems with SMTP servers instead
252          of breaking.
253         
254        - Italian translation added.
255       
256    - 1.18alpha13 :
257   
258        - Pre and Post hooks are now available in the pykota
259          filter as well.
260         
261        - The pykota filter doesn't check last user's quota
262          anymore when delayed hardware accounting is used :
263          this will be done anyway the next time the last
264          user will print again. This saves some database
265          queries which are unneeded.
266       
267    - 1.18alpha12 :
268   
269        - Pre and Post hooks to external commands with many
270          many environment variables available are useable
271          from the cupspykota backend.
272          See sample configuration file for details and help.
273         
274    - 1.18alpha11 :
275   
276        - Hopefully final fix wrt groups (users and printers)
277       
278    - 1.18alpha10 :
279   
280        - Fixed nested printer groups accounting.
281       
282        - Fixed user groups + printer groups problem.
283       
284    - 1.18alpha9 :
285   
286        - Fix for LDAP problem when job price was 0.
287       
288        - Fix for empty user groups with LDAP.
289       
290        - Preliminary version of the snmpprinterstatus command added.
291       
292    - 1.18alpha8 :
293   
294        - Don't retrieve data when not needed.
295          This avoids many database queries.
296       
297    - 1.18alpha7 :
298   
299        - New experimental ldapcache directive to improve
300          LDAP caching.
301         
302    - 1.18alpha6 :
303       
304        - New configuration directive added : maildomain
305          to specify the domain to send mail to when user
306          email address is not set in PyKota database.
307         
308        - More complete email message headers. 
309         
310    - 1.18alpha5 :
311   
312        - Debian packaging specific files, contributed by
313          Peter Hawkins are now included in the project's tree.
314         
315        - Preliminary work on future low-level LDAP caching to speed
316          up modifications (at least).
317         
318    - 1.18alpha4 :
319   
320        - Applied some of the modifications suggested by
321          Peter Hawkins, for better Debian integration.
322          Most notably cupspykota, pykota, and the shell
323          scripts are now installed into /usr/share/pykota
324          instead of into /usr/bin
325          BEWARE : double check that your symbolic link
326          to cupspykota is correct, and that your pykota.conf
327          file use correct path for the shell scripts like
328          waitprinter.sh and al.
329         
330        - pkhint command added, to help in configuring correct
331          accounting method for PyKota.
332         
333    - 1.18alpha3 :
334   
335        - Fixed a rare bug in cupspykota backend which gave
336          incorrect "CUPS backend died abnormally" messages.
337       
338    - 1.18alpha2 :
339   
340        - Added the pkprinters command line tool to manage printers
341          exclusively.
342       
343    - 1.18alpha1 :
344   
345        - Preliminary work on Relationnal Database Independance.
346       
347        - Sample report made from OpenOffice.org added as PDF and SXC.
348       
349    - 1.17 :
350   
351        - Finalized release.
352       
353    - 1.17alpha2 :
354   
355        - Fix stupid software accounting bug in the CUPS backend.
356       
357    - 1.17alpha1 :
358   
359        - User/Group deletion code in edpykota rewritten.
360       
361    - 1.16 :
362   
363        - Preliminary documentation on how to use OpenOffice.org
364          to create personnalized reports for PyKota + PostgreSQL.
365         
366        - Spanish installation guide for CUPS+PyKota+PostgreSQL
367          added to the documentation. Doesn't yet document v1.16
368          though.
369       
370        - Portuguese Portuguese translation replaces Brasilian
371          Portuguese Translation. Brasilian portuguese
372          translation is still available under the 'br' locale.
373       
374    - 1.16beta3 :
375   
376        - Swedish translation added.
377       
378        - Small fix in documentation.
379       
380    - 1.16beta2 :
381   
382        - Small fix for job cancelling code while job already
383          printing in CUPS backend.
384         
385        - Big fix wrt printing policies for unknown users. 
386       
387    - 1.16beta1 :
388   
389        - Manpages upgraded.
390       
391    - 1.16alpha26 :
392   
393        - Job price is now computed like this :
394       
395          SUM((NbPages * PricePerPage) + PricePerJob)
396         
397          For current printer and all the printers groups it is
398          a member of, if any.
399         
400          This may be difficult to grasp, but offers unprecedented
401          flexibility.
402         
403    - 1.16alpha25 :
404   
405        - Email address can be set at user creation time,
406          using the following syntax :
407         
408            $ edpykota --add username/email@yourdomain.com
409       
410    - 1.16alpha24 :
411   
412        - CGI script now can show the printing history.
413       
414        - Bug wrt number of copies should be fixed.
415       
416        - Major code refactoring => It is now possible to
417          automatically add printers on first print.
418       
419    - 1.16alpha23 :
420   
421        - Fixed potential accuracy problem if a user printed on
422          several printers at the very same time.
423       
424    - 1.16alpha22 :
425   
426        - edpykota now allows adding printers to printer groups
427       
428    - 1.16alpha21 :
429   
430        - Allows the dot in user and printer names.
431       
432        - Printer groups are now cached too.
433       
434    - 1.16alpha20 :
435   
436        - Fixed several small bugs with the help of PyChecker.
437       
438    - 1.16alpha19 :
439     
440        - Fixed a bug in PostgreSQL backend's code.
441       
442    - 1.16alpha18 :
443   
444        - Initial code for printer groups support. Printer groups have
445          to be added with external tools like psql or gq for example.
446          Printer groups seems to work fine with users. Untested with user
447          groups for now.
448
449        - Several minor visual problems fixed in reports.
450       
451        - Fixed a bug in LDAP date handling.
452       
453        - Fix for LDAP problem with some combination of OpenLDAP + Python-LDAP
454          + some particular settings.
455         
456        - mailandpopup.sh shell script added. See sample configuration file
457          for details.
458       
459        - Several environment variables are now exported when executing
460          external commands (accounters, requesters, mailers) :
461           
462            PYKOTAUSERNAME => user who is printing
463            PYKOTAPRINTERNAME => printer on which the job is being sent
464            PYKOTATITLE => Job's title
465            PYKOTAFILENAME => Job's filename
466            PYKOTACOPIES => number of copies asked
467            PYKOTAOPTIONS => print command options (-o with CUPS)
468         
469    - 1.16alpha17 :
470   
471        - Added portugues translation.
472       
473        - Major code refactoring in accounters.
474       
475    - 1.16alpha16 :
476   
477        - Code refactoring, and addition of a real HTML reporter, to
478          have nice looking and useful web based reports (in the future).
479       
480        - Added utolower configuration option to convert all usernames
481          to lowercase during printing.
482         
483    - 1.15alpha15 :
484   
485        - Now includes the papwaitprinter.sh shell script to wait for
486          AppleTalk enabled printers.
487         
488    - 1.16alpha14 :
489   
490        - Now printing on a printer not defined in the Quota Storage,
491          results in the job being cancelled or stopped, depending
492          on the printing system.
493         
494    - 1.16alpha13 :
495   
496        - Small bugfix wrt Python v2.1
497       
498        - If username is an empty string, user root is assumed.
499       
500        - 'postgresql' is not recognized anymore as a storage backend,
501          you have to use 'pgstorage' instead. 'postgresql' used to
502          be supported for compatibility with very old PyKota versions,
503          this is not the case anymore.
504         
505    - 1.16alpha12 :
506   
507        - Job price added to job history, to keep accounting correct
508          if a printer price per page or per job is modified and the
509          history is not reset : the history would have given a false
510          amount of money charged before the printer's prices were
511          modified, this addition solves the problem.
512         
513    - 1.16alpha11 :
514   
515        - Some preliminary modifications to the database structure for
516          PostgreSQL and OpenLDAP. A script to upgrade a PostgreSQL
517          database is now provided. LDAP attributes now support
518          eq, pres and sub indexes.
519         
520        - Job history now contains additional informations : 
521          number of copies, filename, title and print options.
522         
523    - 1.16alpha10 :
524       
525        - Some modifications done to external policy handling.
526          See sample configuration file for details.
527   
528        - Spanish translation added.
529       
530    - 1.16alpha9 :
531   
532        - mailto can be set to external(...) to warn users above
533          quota with any command of your choice (e.g. linpopup).
534          Several parameters are available, see sample configuration
535          file for details.
536         
537    - 1.16alpha8 :
538   
539        - Now cupspykota transmits SIGTERMS to the original 
540          backend when the user deletes a job being processed.
541         
542        - The documentation is now licensed under the terms of the
543          GNU GPL too.
544         
545    - 1.16alpha7 :
546   
547        - The CUPS backend is now fully functionnal (it seems).
548       
549        - From now on, the use of the pykota filter with CUPS
550          is deprecated. The pykota filter still has to be
551          used with LPRng though.
552       
553    - 1.16alpha6 :
554   
555        - Bug fixed : when edpykota was used to add a printer
556          with no user or group name, a bad user/group name "*" was
557          added to the database.
558         
559    - 1.16alpha5 :
560   
561        - New CUPS backend supports device enumeration !
562          This means that NO manual CUPS configuration has to
563          be done. All can now be done from CUPS web interface.
564       
565    - 1.16alpha4 :
566   
567        - New CUPS backend added.
568       
569    - 1.16alpha3 :
570       
571        - Minimal FAQ document added.
572       
573    - 1.16alpha2 :
574   
575        - CGI script now partially supports browser's language preference
576       
577    - 1.16alpha1 :
578   
579        - Ensures that the LDAP connection is really closed at end.
580       
581        - More complete error messages in case of LDAP operation failure.
582       
583    - 1.15 :
584     
585        - Documentation improved.
586       
587    - 1.15beta :
588   
589        - Command line tools now accept multiple printer
590          names or wildcards, separated with commas.
591         
592    - 1.15alpha9 :
593   
594        - External policy can be used to auto-add unknown users
595          and any other interesting things you may want to do.
596          WARNING : You can't auto-add printers for now.
597          They have to be created manually before.
598          Look at sample configuration file for examples.
599         
600    - 1.15alpha8 :
601   
602        - Job history can be disabled if needed.
603          This feature may be useful for people who use the LDAP
604          backend and don't want their LDAP tree to grow out of
605          control.
606       
607    - 1.15alpha7 :
608   
609        - More work done on caching wrt groups.
610       
611    - 1.15alpha6 :
612   
613        - Performance bottleneck with LDAP solved.
614       
615    - 1.15alpha5 :
616   
617        - Caching mechanism for all database queries.
618
619    - 1.15alpha4 :
620   
621        - Problem with Python 2.3 fixed. Needs some definitive
622          modification.
623         
624    - 1.15alpha3 :
625   
626        - CGI script now tries to restrict view when the
627          REMOTE_USER environment variable is set. This allows
628          people to protect its use with .htaccess files.
629          When unprotected, or if REMOTE_USER is 'root', then
630          unrestricted access is granted.
631          NB : REMOTE_USER is automatically set by the web server
632          (e.g. Apache) when a page with restricted access is viewed.
633         
634    - 1.15alpha2 :
635   
636        - Better detection of LPRng.
637       
638        - Outputs a warning if printing system is unknown.
639       
640    - 1.15alpha1 :
641   
642        - Bug fix in SQL code.
643       
644    - 1.14 :
645   
646        - The PostgreSQL database connection is now always closed before
647          exit. The LDAP database connection too, but it didn't suffer
648          from the problem anyway, AFAICT.
649       
650    - 1.14beta2 :
651   
652        - An LDAP-specific configuration field was introduced, usermail.
653          Use it to specify which LDAP attribute contains a valid email
654          address for the user. See sample configuration file for
655          details.
656       
657    - 1.14beta :
658   
659        - Two new LDAP-specific configuration fields were introduced,
660          newuser and newgroup. Use them to specify if you want to add
661          quota information to existing entries or elsewhere.
662          See sample configuration file for details.
663         
664    - 1.14alpha9 :
665   
666        - Documentation improved.
667       
668        - pykotme now also prints the user's account balance value
669          if the user is registered in the Quota Storage and his
670          limiting factor is "balance".
671         
672    - 1.14alpha8 :
673   
674        - bin/waitprinter.sh is now included to wait for
675          SNMP enabled printers to be idle again before
676          asking for their internal page counter.
677          See sample configuration file for details.
678         
679    - 1.14alpha7 :
680   
681        - edpykota now doesn't check if the user/group is above
682          quota. The check is only done at print time. This
683          prevents the sending of email messages when creating
684          user quotas if quota is already reached at creation
685          time.
686         
687    - 1.14alpha6 :
688   
689        - Configuration file split and moved to /etc/pykota/pykota.conf
690          and /etc/pykota/pykotadmin.conf to prevent simple users to
691          have Read/Write access to the Quota Database.
692          Don't forget to :
693         
694                $ chmod 640 /etc/pykota/pykotadmin.conf
695               
696        - storageuser and storageuserpw configuration fields reintroduced
697          for the same reason.
698         
699        - Code cleaning for future implementation of email addresses
700          support in the PostgreSQL and LDAP backends.
701         
702    - 1.14alpha5 :
703       
704        - Big bug fixed when changing the prices for a printer
705       
706    - 1.14alpha4 :
707   
708        - When adding an user, the user itself and its account balance
709          are now added in the same LDAP entry. Before they were added
710          as two different LDAP entries.
711         
712    - 1.14alpha3 :
713   
714        - Email field added to PostgreSQL database. An upgrade script
715          is included in initscripts/postgresql.
716       
717    - 1.14alpha2 :
718   
719        - Typo fixed when using the --prototype option to edpykota
720       
721    - 1.14alpha1 :
722   
723        - Poor man's treshold included : users with a low account
724          balance (below 1.0 by default, configurable) are sent
725          a warning message.
726         
727        - All warning messages to users are now configurable. 
728          NB : Warning messages to the administrator are not.
729       
730    - 1.13 :
731   
732        - Some small fixes wrt group handling.
733       
734        - The whole module code was passed through PyChecker and
735          several small code inconsistencies were fixed,
736          as well as a bug in the groups code.
737         
738    - 1.13alpha1 :
739   
740        - Bug fix wrt LDAP.
741       
742    - 1.12 :
743   
744        - More complete test added in edpykota.
745       
746    - 1.12alpha2 :
747   
748        - The previous bug fix was incomplete. This is corrected.
749       
750    - 1.12alpha1 :
751   
752        - Small bug fix.
753       
754    - 1.11 :
755   
756        - Now includes the pykotme command line tool, to produce
757          printing quotes for users.
758         
759    - 1.10 :
760   
761        - Bug fixed wrt quota reports when print limiting is by
762          account balance.
763         
764    - 1.09 :
765   
766        - Translations finalized.
767       
768        - Manpages updated.
769       
770        - Installation documentation improved wrt LDAP support.
771       
772    - 1.09beta2 :
773   
774        - The CGI script for quota reports works again, and
775          is much more powerful.
776       
777    - 1.09beta :
778   
779        - edpykota finalized
780       
781    - 1.09alpha2 :
782   
783        - LDAP schema modified a bit. Please upgrade.
784       
785        - LDAP backend works !
786       
787        - repykota and warnpykota allow the root user to pass
788          users or groups names on the command line. Users
789          and groups names may contain wildcards.
790         
791        - repykota and warnpykota only reports or warns the
792          current user when launched by non-root users.
793         
794        - Minor bug fixes. 
795   
796    - 1.09alpha1 :
797   
798        - More work on LDAP storage backend. Many options
799          were added to /etc/pykota.conf to give some
800          hints to the LDAP storage backend.
801         
802        - Severe database access optimizations were done by
803          rewriting most of the Quota Storage backends drivers.
804     
805    - 1.08 :
806   
807        - Major bug fix wrt LPRng support for remote jobs.
808       
809        - Major bug fix wrt increase/decrease account balances.
810       
811    - 1.08alpha8 :
812   
813        - Code refactoring.
814       
815        - A single user/password pair is used to connect
816          to the database backend. The storageuser configuration
817          field, and its associated passwords storageuserpw, are
818          not used anymore.
819         
820        - You can now set PyKota in debug mode, see sample configuration 
821          file for details.
822          WARNING : only Quota Storage backend queries are logged in
823          debug mode, for now.
824       
825    - 1.08alpha7 :
826   
827        - Very latest LDAP schema.
828       
829        - Code enhancement wrt easy pluggability of PyKota attributes
830          and object classes into an existing LDAP directory.
831       
832    - 1.08alpha6 :
833   
834        - Minor bug corrections
835       
836        - More work on LDAP : new schema
837       
838    - 1.08alpha5 :
839   
840        - More good work on LDAP storage.
841          repykota now works reasonably well with the sample LDAP directory.
842       
843    - 1.08alpha4 :
844   
845        - LDAP schema included.
846          THIS IS JUST FOR PEOPLE TO DISCUSS ABOUT THIS.
847          LDAP SUPPORT DOESN'T WORK YET, AND THE SCHEMA
848          MAY CHANGE IN THE FUTURE. PLEASE TELL US
849          WHAT YOU THINK ABOUT THIS SCHEMA ON THE
850          MAILING LIST.
851         
852    - 1.08alpha3 :
853   
854        - External accounting methods were partly rewritten :
855         
856          - No more "broken pipe" should happen.
857         
858          - They now take care of the number of copies
859            This may be unneeded though, if the postscript
860            file already does this, because this would
861            overcharge users (number of copies counted
862            two times). NEEDS MORE TESTING.
863           
864          - The sample configuration file now contains 
865            an external accounting method example which should
866            work with all DSC compliant Postscript files.
867           
868        - Some small bugs were fixed.   
869       
870    - 1.08alpha2 :
871   
872        - Now works with net-snmp v5.0 and above.
873          It already worked, but the sample configuration
874          file didn't contain appropriate values...
875       
876    - 1.07 : Release of the Shame !
877   
878        - The external accounting methods driver was left out of
879          the CVS tree. Nobody could use it since it wasn't included !
880         
881    - 1.06 :
882   
883        - Severe bug fixed : if you had a printer in
884          power saving state which couldn't answer immediately,
885          a bug was triggered.
886          It was caused by a bad copy/paste which
887          forgot to import a Python module at run time.
888         
889    - 1.05 :
890   
891        - External accounters are finally available !
892          This means that you can plug any page accounting
893          method you like by setting the appropriate
894          'accounter' field in /etc/pykota.conf
895          See the sample conf/pykota.conf.sample to
896          learn how to do.
897         
898          NB : Both 'external' and 'stupid' accounting methods
899               account a job size just before *this* job is
900               sent to the printer.
901               The original 'querying' method accounts a job
902               size just before *the next* job is sent to
903               the printer.
904       
905    - 1.05alpha3 :
906   
907        - A 'stupid' and unreliable accounting method was
908          implemented to serve as an example on how to
909          do this sort of things. This method only counts
910          the 'showpage' statements in the input data.
911          See sample configuration file for details.
912          Pluggable accounting methods work, but I advise
913          you TO NOT USE THIS ONE WHICH IS JUST AN EXAMPLE.
914          It is not reliable enough to be used.
915          Use the 'querying' accounting method instead.
916         
917    - 1.05alpha2 :
918   
919        - Pluggable accounting methods.
920       
921        - Better error handling.
922       
923    - 1.05alpha1 :
924   
925        - SECURITY file added to help improve PyKota's security.
926       
927        - Extracting the printer's internal page counter is now
928          tried several times, waiting several seconds between
929          two tries. This lets the time to warm up for some printers
930          which don't answer when they are sleeping (my Apple
931          LaserWriter 16/600 PS is in this case, maybe others too)
932         
933        - Small display bug fixed in repykota
934         
935    - 1.04 :
936   
937        - Default print policy for users/groups unknown from
938          the print quota system is now DENY instead of ALLOW,
939          since ALLOW can generate inaccurate results
940          (incorrect job sizes charged to the wrong persons)
941         
942        - LPRng support works !
943       
944        - A bug was introduced some time ago wrt printers' default
945          policy for unknown users. It is now corrected.
946       
947        - repykota now displays prices per job and per page for each
948          printer, if they are defined.
949         
950        - Minor display bug fixed in repykota.
951       
952        - Problem when running repykota with an empty database was fixed.
953       
954    - 1.03 :
955   
956        - Upgrade script included for earlier versions.
957          Please look inside the initscripts subdirectory.
958          THE DATABASE SCHEMA HAS CHANGED, PLEASE UPGRADE.
959         
960        - repykota now reports account balances too.
961       
962        - PyKota now has a nice logo, see the logos
963          subdirectory.
964       
965        - Manual pages were finally updated.
966       
967        - Group quotas seem to work now !
968       
969        - The new database schema allows to keep an history of all
970          jobs as well as charge users per page and/or per job,
971          and track users' account balance.
972         
973        - edpykota now accepts much more command line options to 
974          use the new functionnalities. See edpykota --help for
975          details.
976         
977        - The installation script now allows to install the sample
978          configuration file during first installation.
979         
980        - More group quota code works, but still not finished. 
981       
982        - The CGI script displays a link to PyKota's website.
983       
984        - The job history is now kept, this will allow per-period
985          reports in the future.
986         
987        - After having modified the quota for an user with edpykota,
988          a quota check is done to eventually warn the user/admin about
989          a quota which is too low to print.
990         
991        - A workaround is provided for HP Printers : their internal
992          page counter is only saved to NVRAM in a 10 increment, so
993          if you switch them off and then on, the reported page counter
994          may be lower than the real number of pages printed.
995          See http://web.mit.edu/source/third/lprng/doc/LPRng-HOWTO-15.html
996          We unconditionnally set the last job's page count to
997          abs(int((10 - abs(lastcounter(snmp) - lastcounter(storage)) / 2))
998          in this case.
999          For a more accurate accounting, never switch your HP printers
1000          off.
1001         
1002        - A fix is provided for printers which only have a volatile 
1003          page counter (reset to 0 every time you switch the printer on)
1004          This should allow PyKota to work reasonably fine with HP Laserjet
1005          4L/5L/6L, not perfect, but better than nothing.
1006          See http://web.mit.edu/source/third/lprng/doc/LPRng-HOWTO-15.html
1007          For a more accurate accounting, never switch your HP printers
1008          off. This is untested, please report any problem.
1009         
1010        - A bug was fixed when edpykota --add was used with users who already
1011          had a quota on the specified printer.
1012         
1013        - A small display bug in repykota was introduced in preliminary
1014          1.03 versions, and fixed later on.
1015         
1016        - Some minor bugs which happened in rare situations were fixed.
1017       
1018        - Support for AppleTalk printers was added, see sample configuration
1019          file for details.
1020         
1021        - Users and group printing can now be controlled (limited) either by 
1022          print quota or by account balance.
1023       
1024    - 1.02 :
1025   
1026        - The installation script now checks for software availability
1027          and in case a software is missing asks the user if he
1028          wants to continue with the installation or abort it.
1029         
1030        - The configuration file pykota.conf is now expected to be
1031          found in /etc instead of in /etc/cups
1032          The installation script prompts the user to see if he
1033          wants to move an old configuration file to the new location
1034          if needed.
1035         
1036        - Improved documentation.
1037       
1038        - You can now set the tcp/ip port on which the Quota Storage
1039          Server is listening, see sample configuration file for details.
1040       
1041        - Better general error handling.
1042       
1043        - Upgrade script for pre 1.01 PostgreSQL database schema is now
1044          included as well.
1045       
1046    - 1.01 :
1047   
1048        - The configuration file now accepts an option   
1049          to choose the recipient(s) of the email messages :
1050         
1051            - DevNull means no one will receive them.
1052            - User means only the user will receive them.
1053            - Admin means only the admin will receive them.
1054            - Both means the User and the Admin will receive them.
1055           
1056        - The configuration file now uses hard-coded default values
1057          when an option is not set. See sample configuration file
1058          for details.
1059         
1060        - Manual pages are included since 1.00, but I forgot to   
1061          add this information to this file.
1062         
1063        - Redistribution terms for the official package have 
1064          softened and are now fully GPL compatible :
1065          unrestricted modification is now allowed even for
1066          the version number.
1067         
1068    - 1.00 :
1069   
1070        - edpykota now accepts a --noquota option. This
1071          disable quota checking while still doing page
1072          accounting. This is really useful for people
1073          who don't want to limit their users but want
1074          to know how much pages they print.
1075         
1076        - Some untested scripts were added to retrieve
1077          the life time page counter of non-SNMP printers.
1078         
1079        - Every directory now has a specific README file. 
1080       
1081    - 0.99 :
1082   
1083        - Under some circumstances while the user wasn't allowed
1084          to print, he didn't receive any email message. It is
1085          now fixed.
1086         
1087        - When an user wasn't allowed to print, the quota for
1088          the previous user wasn't updated. This is now fixed.
1089         
1090    - 0.98 :
1091   
1092        - Correctly handle the case where the printer is switched off.
1093       
1094        - Small bug wrt syslog fixed.
1095       
1096    - 0.97 :
1097   
1098        - edpykota accepts wildcards on its command line for users/groups too
1099          if the --add option is not set, e.g. :
1100         
1101              $ edpykota --printer lp --softlimit 50 --hardlimit 100 "jer*"
1102             
1103        - If no user name is passed at all, then a default wildcard of "*"
1104          which means apply the command on ALL users for this printer is used.
1105         
1106        - Small bug fixes.
1107       
1108    - 0.96 :
1109
1110        - Options requester, policy, admin, adminmail and gracedelay can now
1111          be set either globally or per printer. The printer option has
1112          priority if both are defined.
1113
1114        - More powerful configuration parser.
1115       
1116        - If all options are defined globally, there's no need to
1117          define a section for each printer in the configuration
1118          file anymore. Just define a [global] section and it's ok.
1119
1120    - 0.95 :
1121
1122        - External requesters for printers finally added.
1123
1124        - Full internationalization (english and french are supported)
1125 
1126        - More complete quota usage report
1127
1128        - CGI script to access to the quota usage report
1129
1130        - Several bugs fixed.
1131
1132
1133    - 0.9 :
1134
1135        - First public version
Note: See TracBrowser for help on using the browser.