]> git.ipfire.org Git - thirdparty/cups.git/blob - CHANGES.md
The scheduler did not always idle exit as quickly as it could...
[thirdparty/cups.git] / CHANGES.md
1 CHANGES - 2.2.11 - 2019-02-21
2 =============================
3
4
5 Changes in CUPS v2.2.11
6 -----------------------
7
8 - Running ppdmerge with the same input and output filenames did not work as
9 advertised (Issue #5455)
10 - Fixed a potential memory leak when reading at the end of a file (Issue #5473)
11 - Fixed potential unaligned accesses in the string pool (Issue #5474)
12 - Fixed a potential memory leak when loading a PPD file (Issue #5475)
13 - Added a USB quirks rule for the Lexmark E120n (Issue #5478)
14 - Updated the USB quirks rule for Zebra label printers (Issue #5395)
15 - Fixed a compile error on Linux (Issue #5483)
16 - The lpadmin command, web interface, and scheduler all queried an IPP
17 Everywhere printer differently, resulting in different PPDs for the same
18 printer (Issue #5484)
19 - Fixed an issue with the self-signed certificates generated by GNU TLS
20 (Issue #5506)
21 - The `ippValidateAttribute` function did not catch all instances of invalid
22 UTF-8 strings (Issue #5509)
23 - Non-Kerberized printing to Windows via IPP was broken (Issue #5515)
24 - The scheduler no longer stops a printer if an error occurs when a job is
25 canceled or aborted (Issue #5517)
26 - Added a USB quirks rule for the DYMO 450 Turbo (Issue #5521)
27 - Added a USB quirks rule for Xerox printers (Issue #5523)
28 - The scheduler's self-signed certificate did not include all of the alternate
29 names for the server when using GNU TLS (Issue #5525)
30 - Fixed a potential crash bug in cups-driverd (rdar://46625579)
31 - Fixed a performance regression with large PPDs (rdar://47040759)
32 - The scheduler did not always idle exit as quickly as it could.
33
34
35 Changes in CUPS v2.2.10
36 -----------------------
37
38 - CVE-2018-4700: Linux session cookies used a predictable random number seed.
39 - The `lpoptions` command now works with IPP Everywhere printers that have not
40 yet been added as local queues (Issue #5045)
41 - Added USB quirk rules (Issue #5395, Issue #5443)
42 - The generated PPD files for IPP Everywhere printers did not contain the
43 cupsManualCopies keyword (Issue #5433)
44 - Kerberos credentials might be truncated (Issue #5435)
45 - The handling of `MaxJobTime 0` did not match the documentation (Issue #5438)
46 - Incorporated the page accounting changes from CUPS 2.3 (Issue #5439)
47 - Fixed a bug adding a queue with the `-E` option (Issue #5440)
48 - Fixed a crash bug when mapping PPD duplex options to IPP attributes
49 (rdar://46183976)
50
51
52 Changes in CUPS v2.2.9
53 ----------------------
54
55 - Localization changes (Issue #5348, Issue #5362, Issue #5408)
56 - Documentation updates (Issue #5369)
57 - The lpadmin command would create a non-working printer in some error cases
58 (Issue #5305)
59 - The scheduler would crash if an empty `AccessLog` directive was specified
60 (Issue #5309)
61 - Fixed a regression in the changes to ippValidateAttribute (Issue #5322,
62 Issue #5330)
63 - Fixed a crash bug in the Epson dot matrix driver (Issue #5323)
64 - Automatic debug logging of job errors did not work with systemd (Issue #5337)
65 - The web interface did not list the IPP Everywhere "driver" (Issue #5338)
66 - The IPP Everywhere "driver" now properly supports face-up printers
67 (Issue #5345)
68 - Fixed some typos in the label printer drivers (Issue #5350)
69 - Multi-file jobs could get stuck if the backend failed (Issue #5359,
70 Issue #5413)
71 - The IPP Everywhere "driver" no longer does local filtering when printing to
72 a shared CUPS printer (Issue #5361)
73 - The lpadmin command now correctly reports IPP errors when configuring an
74 IPP Everywhere printer (Issue #5370)
75 - Fixed some memory leaks discovered by Coverity (Issue #5375)
76 - The PPD compiler incorrectly terminated JCL options (Issue #5379)
77 - The cupstestppd utility did not generate errors for missing/mismatched
78 CloseUI/JCLCloseUI keywords (Issue #5381)
79 - The scheduler now reports the actual location of the log file (Issue #5398)
80 - Added a USB quirk rule (Issue #5420)
81 - The scheduler was being backgrounded on macOS, causing applications to spin
82 (rdar://40436080)
83 - The scheduler did not validate that required initial request attributes were
84 in the operation group (rdar://41098178)
85 - Authentication in the web interface did not work on macOS (rdar://41444473)
86 - Fixed an issue with HTTP Digest authentication (rdar://41709086)
87 - The scheduler could crash when job history was purged (rdar://42198057)
88 - Dropped non-working RSS subscriptions UI from web interface templates.
89 - Fixed a memory leak for some IPP (extension) syntaxes.
90
91
92 Changes in CUPS v2.2.8
93 ----------------------
94
95 - Additional changes for the scheduler to substitute default values for invalid
96 job attributes when running in "relaxed conformance" mode (Issue #5229)
97 - The `ipptool` program no longer checks for duplicate attributes when running
98 in list or CSV mode (Issue #5278)
99 - Fixed builds without PAM (Issue #5283)
100 - Fixed `lpoptions` man page (Issue #5286)
101 - The `cupsCreateJob`, `cupsPrintFile2`, and `cupsPrintFiles2` APIs did not use
102 the supplied HTTP connection (Issue #5288)
103 - Fixed another crash in the scheduler when adding an IPP Everywhere printer
104 (Issue #5290)
105 - Added a workaround for certain web browsers that do not support multiple
106 authentication schemes in a single response header (Issue #5289)
107 - Fixed policy limits containing the `All` operation (Issue #5296)
108 - The scheduler was always restarted after idle-exit with systemd (Issue #5297)
109 - Added a USB quirks rule for the HP LaserJet P1102 (Issue #5310)
110 - The mailto notifier did not wait for the welcome message (Issue #5312)
111 - Fixed a parsing bug in the pstops filter (Issue #5321)
112 - Documentation updates (Issue #5299, Issue #5301, Issue #5306)
113 - Localization updates (Issue #5317)
114 - The scheduler allowed environment variables to be specified in the
115 `cupsd.conf` file (rdar://37836779, rdar://37836995, rdar://37837252,
116 rdar://37837581)
117 - Fax queues did not support pause (p) or wait-for-dialtone (w) characters
118 (rdar://39212256)
119 - The scheduler did not validate notify-recipient-uri values properly
120 (rdar://40068936)
121 - The IPP parser allowed invalid group tags (rdar://40442124)
122 - Fixed a parsing bug in the new authentication code.
123
124
125 Changes in CUPS v2.2.7
126 ----------------------
127
128 - NOTICE: Raw print queues are now deprecated (Issue #5269)
129 - Fixed an Avahi crash bug in the scheduler (Issue #5268)
130 - The IPP Everywhere PPD generator did not include the `cupsJobPassword`
131 keyword, when supported (Issue #5265)
132 - Systemd did not restart cupsd when configuration changes were made that
133 required a restart (Issue #5263)
134 - The Lexmark Optra E310 printer needs the "no-reattach" USB quirk rule
135 (Issue #5259)
136 - The scheduler could crash while adding an IPP Everywhere printer (Issue #5258)
137 - Label printers supported by the rastertolabel driver don't support SNMP, so
138 don't delay printing to test it (Issue #5256)
139 - Fixed a compile issue when PAM is not available (Issue #5253)
140 - Documentation fixes (Issue #5252)
141 - Star Micronics printers need the "unidir" USB quirk rule (Issue #5251)
142 - The scheduler now supports using temporary print queues for older IPP/1.1
143 print queues like those shared by CUPS 1.3 and earlier (Issue #5241)
144 - Fixed printing to some IPP Everywhere printers (Issue #5238)
145 - Kerberized printing to another CUPS server did not work correctly
146 (Issue #5233)
147 - The `cupsRasterWritePixels` function did not correctly swap bytes for some
148 formats (Issue #5225)
149 - Added a USB quirk rule for Canon MP280 series printers (Issue #5221)
150 - The `ppdInstallableConflict` tested too many constraints (Issue #5213)
151 - More fixes for printing to old CUPS servers (Issue #5211)
152 - The `cupsCopyDest` function now correctly copies the `is_default` value
153 (Issue #5208)
154 - The scheduler did not work with older versions of uClibc (Issue #5188)
155 - The scheduler now substitutes default values for invalid job attributes when
156 running in "relaxed conformance" mode (Issue #5186)
157 - Fixed PAM module detection and added support for the common PAM definitions
158 (Issue #5185)
159 - Fixed a journald support bug in the scheduler (Issue #5181)
160 - The cups-driverd program incorrectly stopped scanning PPDs as soon as a loop
161 was seen (Issue #5170)
162 - Fixed group validation on OpenBSD (Issue #5166)
163 - Fixed the `ippserver` sample code when threading is disabled or unavailable
164 (Issue #5154)
165 - The `cupsEnumDests` function did not include options from the lpoptions files
166 (Issue #5144)
167 - The `SSLOptions` directive now supports `MinTLS` and `MaxTLS` options to
168 control the minimum and maximum TLS versions that will be allowed,
169 respectively (Issue #5119)
170 - The scheduler did not write out dirty configuration and state files if there
171 were open client connections (Issue #5118)
172 - The `lpadmin` command now provides a better error message when an unsupported
173 System V interface script is used (Issue #5111)
174 - The `lp` and `lpr` commands now provide better error messages when the default
175 printer cannot be found (Issue #5096)
176 - No longer support backslash, question mark, or quotes in printer names
177 (Issue #4966)
178 - The CUPS library now supports the latest HTTP Digest authentication
179 specification including support for SHA-256 (Issue #4862)
180 - The `lpstat` command now reports when new jobs are being held (Issue #4761)
181 - The `lpoptions` command incorrectly saved default options (Issue #4717)
182 - The `ppdLocalizeIPPReason` function incorrectly returned a localized version
183 of "none" (rdar://36566269)
184 - TLS connections now properly timeout (rdar://34938533)
185 - The IPP backend did not properly detect failed PDF prints (rdar://34055474)
186 - Temporary files are now placed in the correct directory for sandboxed
187 applications on macOS (rdar://problem/37789645)
188
189
190 Changes in CUPS v2.2.6
191 ----------------------
192
193 - DBUS notifications could crash the scheduler (Issue #5143)
194 - Added USB quirks rules for Canon MP540 and Samsung ML-2160 (Issue #5148)
195 - Fixed TLS cipher suite selection with GNU TLS (Issue #5145, Issue #5150)
196 - Localization updates (Issue #5152)
197
198
199 Changes in CUPS v2.2.5
200 ----------------------
201
202 - The scheduler's `-t` option did not force all errors to the standard error
203 file, making debugging of configuration problems hard (Issue #5041)
204 - Fixed a typo in the CUPS Programming Manual (Issue #5042)
205 - Fixed RPM packaging issue (Issue #5043, Issue #5044)
206 - The `cupsGetDests` function incorrectly returned an empty list of printers if
207 there was no default printer (Issue #5046)
208 - The `cupsGetDests` function waited too long for network printers (Issue #5049)
209 - Libtool support was completely broken with current libtool versions that use
210 an incompatible command-line syntax (Issue #5050)
211 - Fixed a build issue with `--enable-mallinfo` (Issue #5051)
212 - The ippserver test program contained a deadlock issue (Issue #5054)
213 - The `cupsLocalizeDest*` functions did not provide base localizations for
214 all registered IPP attributes and values (Issue #5056)
215 - The --enable-libtool configure option requires a path to the libtool program,
216 but doesn't document or check for it (Issue #5062)
217 - Fixed the `SSLOptions DenyCBC` option when using GNU TLS (Issue #5065)
218 - Fixed the `ServerTokens None` option (Issue #5065)
219 - Fixed the default `ServerAlias` value from `ServerName` (Issue #5072)
220 - Fixed the adminurl field in the TXT record for fully-qualified `ServerName`
221 values (Issue #5074)
222 - The scheduler now creates a PID file when not running on demand with a modern
223 service launcher (Issue #5080)
224 - The web interface did not support newer language identifiers used by Microsoft
225 web browsers (Issue #5803)
226 - Updated the cups-files.conf and cupsd.conf file documentation for missing
227 directives (Issue #5084)
228 - Fixed an Avahi-related crash bug in the scheduler (Issue #5085, Issue #5086)
229 - Fixed the interactions between the "print-quality" and "cupsPrintQuality"
230 options (Issue #5090)
231 - The IPP Everywhere PPD generator now sorts the supported resolutions before
232 choosing them for draft, normal, and best quality modes (Issue #5091)
233 - Fixed the localization unit test on Linux (Issue #5097)
234 - The CUPS library did not reuse domain sockets (Issue #5098)
235 - Fixed the "make check" target for some environments (Issue #5099)
236 - The scheduler woke up once per second to remove old temporary queues
237 (Issue #5100)
238 - Added USB quirk rule for Kyocera printer (Issue #5102, Issue #5103)
239 - Re-documented the limits of `file:///...` device URIs and moved the FileDevice
240 directive in `cups-files.conf` to the list of deprecated configuration
241 directives (Issue #5117)
242 - Added USB quirk rule for HP LaserJet 1160 printer (Issue #5121)
243 - Fixed the script interpreter detection in the configure script (Issue #5122)
244 - The network backends now retry on more error conditions (Issue #5123)
245 - Added a French translation of the web interface (Issue #5134)
246 - `cupsGetDests2` was not using the supplied HTTP connection (Issue #5135)
247 - `httpAddrConnect` leaked sockets in certain circumstances, causing some
248 printers to hang (rdar://31965686)
249 - Fixed an issue with Chinese localizations on macOS (rdar://32419311)
250 - The IPP backend now always sends the "finishings" attribute for printers that
251 support it because otherwise the client cannot override printer defaults
252 (rdar://33169732)
253 - The `cupsGetNamedDest` function did not use the local default printer
254 (rdar://33228500)
255 - The IPP backend incorrectly sent the "job-pages-per-set" attribute to PDF
256 printers (rdar://33250434)
257 - Fixed the `cups.strings` file that is used on macOS (rdar://33287650)
258 - CUPS now sends the `Date` HTTP header in IPP requests (rdar://33302034)
259 - The `ippCopyAttribute` function did not copy out-of-band values correctly
260 (rdar://33688003)
261 - Fixed the localization fallback code on macOS (rdar://33583699)
262 - The scheduler did not run with a high enough priority, causing problems on
263 busy systems (rdar://33789342)
264 - Added support for Japanese Kaku 1 envelope size (rdar://34774110)
265 - The `ipptool` program's `-P` option did not work correctly.
266 - The `ipptool` program did not compare URI scheme or hostname components
267 correctly for the WITH-ALL-HOSTNAMES, WITH-ALL-SCHEMES, WITH-HOSTNAME, or
268 WITH-SCHEME predicates.
269
270
271 Changes in CUPS v2.2.4
272 ----------------------
273
274 - The scheduler did not remove old job files (Issue #4987)
275 - cupsEnumDests did not return early when all printers had been discovered
276 (Issue #4989)
277 - The CUPS build system now supports cross-compilation (Issue #4897)
278 - Added a new CUPS Programming Manual to replace the aging API documentation.
279 - Added the `cupsAddIntegerOption` and `cupsGetIntegerOption` functions
280 (Issue #4992)
281 - The `cupsGetDests` and `cupsCreateJob` functions now support Bonjour printers
282 (Issue #4993)
283 - Added a USB quirk rule for Lexmark E260dn printers (Issue #4994)
284 - Fixed a potential buffer overflow in the `cupstestppd` utility (Issue #4996)
285 - IPP Everywhere improvements (Issue #4998)
286 - Fixed the "cancel all jobs" function in the web interface for several
287 languages (Issue #4999)
288 - Fixed issues with local queues (Issue #5003, Issue #5008, Issue #5009)
289 - The `lpstat` command now supports a `-e` option to enumerate local printers
290 (either previously added or on the network) that can be accessed
291 (Issue #5005)
292 - The `lp` and `lpr` commands now support printing to network printers that
293 haven't yet been added (Issue #5006)
294 - Fixed a typo in the mime.types file.
295 - Fixed a bug in the Spanish web interface template (Issue #5016)
296 - The `cupsEnumDests*` and `cupsGetDest*` functions now report the value of the
297 "printer-is-temporary" Printer Status attribute (Issue #5028)
298 - Added Chinese localization (Issue #5029)
299 - The `cupsCheckDestSupported` function did not support `NULL` values
300 (Issue #5031)
301 - Fixed some issues in the RPM spec file (Issue #5032)
302 - The `cupsConnectDest` function now supports the `CUPS_DEST_FLAGS_DEVICE` flag
303 for explicitly connecting to the device (printer) associated with the
304 destination.
305 - The `SSLOptions` directive in "client.conf" and "cupsd.conf" now supports
306 `DenyCBC` and `DenyTLS1.0` options (Issue #5037)
307
308
309 Changes in CUPS v2.2.3
310 ----------------------
311
312 - The IPP backend could get into an infinite loop for certain errors, causing a
313 hung queue (<rdar://problem/28008717>)
314 - The scheduler could pause responding to client requests in order to save state
315 changes to disk (<rdar://problem/28690656>)
316 - Added support for PPD finishing keywords (Issue #4960, Issue #4961,
317 Issue #4962)
318 - The IPP backend did not send a media-col attribute for just the source or type
319 (Issue #4963)
320 - IPP Everywhere print queues did not always support all print qualities
321 supported by the printer (Issue #4953)
322 - IPP Everywhere print queues did not always support all media types supported
323 by the printer (Issue #4953)
324 - The IPP Everywhere PPD generator did not return useful error messages
325 (Issue #4954)
326 - The IPP Everywhere finishings support did not work correctly with common UI or
327 command-line options (Issue #4976)
328 - Fixed an error handling issue for the network backends (Issue #4979)
329 - The default cupsd.conf file did not work on systems compiled without Kerberos
330 support (Issue #4947)
331 - The "reprint job" option was not available for some canceled jobs
332 (Issue #4915)
333 - Updated the job listing in the web interface (Issue #4978)
334 - Fixed some localization issues on macOS (<rdar://problem/27245567>)
335
336
337 Changes in CUPS v2.2.2
338 ----------------------
339
340 - Fixed some issues with the Zebra ZPL printer driver (Issue #4898)
341 - Fixed some issues with IPP Everywhere printer support (Issue #4893,
342 Issue #4909, Issue #4916, Issue #4921, Issue #4923, Issue #4932, Issue #4933,
343 Issue #4938)
344 - The rastertopwg filter could crash with certain input (Issue #4942)
345 - Optimized connection usage in the IPP backend (<rdar://problem/29547323>)
346 - The scheduler did not detect when an encrypted connection was closed by the
347 client on Linux (Issue #4901)
348 - The cups-lpd program did not catch all legacy usage of ISO-8859-1
349 (Issue #4899)
350 - Fixed builds on systems without a working poll() implementation (Issue #4905)
351 - Added a USB quirk rule for the Kyocera Ecosys P6026cdn (Issue #4900)
352 - The scheduler no longer creates log files on startup
353 (<rdar://problem/28332470>)
354 - The ippContainsString function now uses case-insensitive comparisons for
355 mimeMediaType, name, and text values in conformance with RFC 2911.
356 - The network backends now log the addresses that were found for a printer
357 (<rdar://problem/29268474>)
358 - Let's Encrypt certificates did not work when the hostname contained uppercase
359 letters (Issue #4919)
360 - Fixed reporting of printed pages in the web interface (Issue #4924)
361 - Updated systemd config files (Issue #4935)
362 - Updated documentation (PR #4896)
363 - Updated localizations (PR #4894, PR #4895, PR #4904, PR #4908, Issue #4946)
364 - Updated packaging files (Issue #4940)
365
366
367 Changes in CUPS v2.2.1
368 ----------------------
369
370 - Added "CreateSelfSignedCerts" directive for cups-files.conf to control whether
371 the scheduler automatically creates its own self-signed X.509 certificates for
372 TLS connections (Issue #4876)
373 - http*Connect did not handle partial failures (Issue #4870)
374 - Addressed some build warnings on Linux (Issue #4881)
375 - cupsHashData did not use the correct hashing algorithm
376 (<rdar://problem/28209220>)
377 - Updated man pages (PR #4885)
378 - Updated localizations (PR #4877, PR #4886)
379
380
381 Changes in CUPS v2.2.0
382 ----------------------
383
384 - Normalized the TLS certificate validation code and added additional error
385 messages to aid troubleshooting.
386 - The httpConnect functions did not work on Linux when cupsd was not running
387 (Issue #4870)
388 - The --no-remote-any option of cupsctl had no effect (Issue #4866)
389 - http*Connect did not return early when all addresses failed (Issue #4870)
390
391
392 Changes in CUPS v2.2rc1
393 -----------------------
394
395 - Updated the list of supported IPP Everywhere media types.
396 - The IPP backend did not validate TLS credentials properly.
397 - The printer-state-message attribute was not cleared after a print job with no
398 errors (Issue #4851)
399 - The CUPS-Add-Modify-Class and CUPS-Add-Modify-Printer operations did not
400 always return an error for failed adds (Issue #4854)
401 - PPD files with names longer than 127 bytes did not work (Issue #4860)
402 - Updated localizations (Issue #4846, PR #4858)
403
404
405 Changes in CUPS v2.2b2
406 ----------------------
407
408 - Added Upstart support (PR #4825)
409 - CUPS now supports Let's Encrypt certificates on Linux.
410
411
412 Changes in CUPS v2.2b1
413 ----------------------
414
415 - All CUPS commands now support POSIX options (Issue #4813)
416 - The scheduler now restarts faster (Issue #4760)
417 - Improved performance of web interface with large numbers of jobs (Issue #3819)
418 - Encrypted printing can now be limited to only trusted printers and servers
419 (<rdar://problem/25711658>)
420 - The scheduler now advertises PWG Raster attributes for IPP Everywhere clients
421 (Issue #4428)
422 - The scheduler now logs informational messages for jobs at LogLevel "info"
423 (Issue #4815)
424 - The scheduler now uses the getgrouplist function when available (Issue #4611)
425 - The IPP backend no longer enables compression by default except for certain
426 raster formats that generally benefit from it (<rdar://problem/25166952>)
427 - The scheduler did not handle out-of-disk situations gracefully (Issue #4742)
428 - The LPD mini-daemon now detects invalid UTF-8 sequences in job, document, and
429 user names (Issue #4748)
430 - The IPP backend now continues on to the next job when the remote server/
431 printer puts the job on hold (<rdar://problem/24858548>)
432 - The scheduler did not cancel multi-document jobs immediately
433 (<rdar://problem/24854834>)
434 - The scheduler did not return non-shared printers to local clients unless they
435 connected to the domain socket (<rdar://problem/24566996>)
436 - The scheduler now reads the spool directory if one or more job cache entries
437 point to deleted jobs (<rdar://problem/24048846>)
438 - Added support for disc media sizes (<rdar://problem/20219536>)
439 - The httpAddrConnect and httpConnect* APIs now try connecting to multiple
440 addresses in parallel (<rdar://problem/20643153>)
441 - The cupsd domain socket is no longer world-accessible on macOS
442 (<rdar://problem/7542560>)
443 - Interface scripts are no longer supported for security reasons
444 (<rdar://problem/23135640>)
445 - Added a new cupsHashData API and support for hashed job passwords
446 (<rdar://problem/20221502>)
447 - Localization fixes (<rdar://problem/25292403>, <rdar://problem/25461517>,
448 Issue #4041, Issue #4796)
449 - Documentation changes (Issue #4624, Issue #4781)
450 - Packaging fixes (PR #4832)