]> arthur.barton.de Git - netatalk.git/blob - NEWS
backport SLPreg fix for Solaris for dev branch.
[netatalk.git] / NEWS
1 Changes in 2.0.1
2 ================
3
4 * NEW: --enable-debian configure option. Will install /etc/init.d/atalk
5        to get not in conflict with standard debian /etc/init.d/netatalk.
6        Reads netatalk.conf from $ETCDIR and not from /etc/default/
7 * UPD: Disable logger code by default. Log to syslog instead
8 * UPD: changed netatalk.conf default settings to prevent problems with
9        AppleTalk zone names containing spaces
10 * FIX: insecure tempfile handling bug in etc2ps.sh,
11        found by Trustix, CAN-2004-0974.
12 * REM: remove add_netatalk_printer and netatalk.template from stable 
13        branch until fixed. (possible symlink vulnerabilities)
14 * FIX: afpd: set hasBeenInited in default finder info. This bug caused 
15        endless finder refreshes with OS9 finder if the noadouble option 
16        was used. From TSUBAKIMOTO Hiroya.
17 * FIX: afpd: fix a bug in default CREATOR/TYPE handling. Due to this bug 
18        the type/creator mappings in AppleVolumes.system were ignored, 
19        causing problems i.e. with OS9 clients.
20 * FIX: AppleVolumes.system: By default don't define a CREATOR/TYPE for a
21        file of unknown type.
22 * FIX: fix two Tru64 UNIX compilation errors, 
23        from Burkhard Schmidt bs AT cpfs.mpg.de
24 * FIX: afpd: FPMapId wasn't using UTF8 for groups if requested by client.
25
26 Changes in 2.0.0
27 ================
28
29 * UPD: afpd: add an error message if -ipaddr parameter cannot be parsed
30 * UPD: updated documentation
31 * FIX: afpd: fix a file descriptor and memory leak with OSX ._ resource fork
32 * FIX: afpd: Prevent overwriting a file by renaming a file in the same 
33        directory to the same name. Won't work with OSX, the dest file gets 
34        deleted by OSX first.
35 * FIX: sometimes '0' was used instead of 0 for creator/type
36 * FIX: removed setpgrp check from configure, we don't use it anymore and
37        it doesn't work with cross compile.
38 * FIX: fix for Solaris "make maintainer-clean", from Alexander Barton
39 * FIX: fix username matching bug in afppasswd. from kanai at nadmin dot org
40 * FIX: reworked username check a little. Depending on the UAM, the wrong
41        username _could_ have been selected.
42
43 Changes in 2.0-rc2
44 ==================
45
46 * UPD: use 0 0 for default creator/type rather than UNIX TEXT, from
47        Shlomi Yaakobovich.
48 * UPD: updated documentation
49 * UPD: change machine type from Macintosh to Netatalk in status reply
50 * FIX: afpd: CopyFile only create a resource fork for destination if source
51        has one.
52 * FIX: afpd: mangling: for utf8 --> max filename length is 255 bytes, else 31.
53 * FIX: cnid_dbd: fix a signed/unsigned, 16/32 bits mismatch. from Burkhard
54        Schmidt, bs at cpfs.mpg.de.
55 * FIX: afpd: After ad_setid don't flush resource fork if it has not been
56        modified.
57 * FIX: NEWS: Fixed ancient NEWS entries. Removed umlauts
58 * FIX: fix macname cache, SF bug 1021642
59 * FIX: revert Makefile change from 2.0-rc1. We have to include BDB_CFLAGS
60        after CFLAGS
61
62 Changes in 2.0-rc1
63 ==================
64
65 * NEW: new manual page for asip-status.pl
66 * UPD: updated documentation
67 * UPD: uams: link uam_dhx_passwd.so to lcrypt before lcrypto. might help with
68        MD5 passwords
69 * UPD: Improved BerkeleyDB detection
70 * UPD: sys/solaris/Makefile.in: enable 'make check', from Alexander Barton
71 * UPD: tcp wrappers detection should work on OpenBSD as well now
72 * UPD: macbin: increase the maximum size of macbinary forks, as suggested by 
73        Sourceforge bug ID 829221
74 * UPD: ASP: rework getstatus. use several ASP packets if the client allows
75        it, otherwise just send as much as we can
76 * FIX: FreeBSD 5 build, from Alex Barton (alex at barton.de)
77 * FIX: OSX 10.3 build
78 * FIX: papd: workaround a problem with PJL before Postscript
79 * FIX: afpd: make sure we only disconnect on old session if the users match
80 * FIX: apfd: Quark6 mangled long filenames should work better now
81 * FIX: enhance ADv1 to ADv2 conversion. Fixed a SIGSEGV reported by Mark Baker
82 * FIX: better detection of invalid resource forks
83 * FIX: fix some linking problems on OpenBSD
84 * FIX: afpd: catsearch.c, filedir.c: fix bogus casts, from Olaf Hering 
85        (olh at suse.de)
86 * FIX: afpd: don't try to create special folders and .volinfo on read-only
87        volumes
88 * FIX: iconv/unicode enhancements. fixed a sigsegv on conversion error
89 * FIX: configure.in: fix a typo, reported by Joerg Rossdeutscher
90 * FIX: uniconv: enhanced uniconv behaviour
91 * FIX: fixed some Solaris compilation problems
92 * FIX: papd/Makefile.am: add a missing $DESTDIR, from Vlad Agranovsky
93 * FIX: afpd: quota.c: remove a c99 declaration, from Yann Rouillard
94 * FIX: configure.in: Solaris/gcc 3.0 fix, from Yann Rouillard
95 * FIX: afpd: fix a SIGSEGV when sharing home dirs without any options in 
96        AppleVolumes.
97 * FIX: numerous small bugfixes
98
99 Changes in 2.0-beta2
100 ====================
101
102 * NEW: atalkd, papd and npb tools now support nbpnames with extended
103        characters
104 * NEW: integrated CUPS support for papd
105 * NEW: optionally advertise SSH tunneling capabilties
106 * NEW: automatic logfile removal for cnid_metad
107 * NEW: asip-status.pl has been added to netatalk
108 * UPD: updated documentation
109 * UPD: we now require Berkeley DB >= 4.1
110 * UPD: 64bit Linux fixes from Stew Benedict, Mandrakesoft
111 * UPD: remove --enable-sendfile
112 * UPD: more verbose error messages
113 * FIX: better handling for resource forks without read access
114 * FIX: Tru64 build, by Burkhard Schmidt
115 * FIX: MIT Kerberos detection
116 * FIX: varios *BSD compile problems
117 * FIX: compile problem with libiconv, reported by Joe Marcus Clarke
118 * FIX: adv1tov2: make it work with the new structure
119 * FIX: afpd: filenames longer than 127 bytes were not enumerated correctly,
120        reported by Thies C. Arntzen
121 * FIX: afpd: return IP before FQDN in status reply.
122 * FIX: afpd: Mac chooser could crash on a codepage conversion error
123 * FIX: afpd: KerberosV auth with Panther clients, make long AD tickets work,
124        reported by Andrew Smith
125 * FIX: atalkd: could send invalid NBPLKUP replies, e.g with more than 15
126        printers. Reported by Almacha
127 * FIX: papd: fix papd.conf parsing problems with consecutive ':' and missing 
128        newline. Reported by Craig White.
129 * FIX: megatron: make megatron work with UTF-8 volumes
130 * FIX: timeout: running timeout with commands which accept arguments, 
131        from Yuval Yeret.
132 * FIX: uniconv: fix a SEGFAULT, reported by Matthew Geier
133 * FIX: pam detection: PAM_C/LDFLAGS were always empty, from Alexander Barton
134 * FIX: numerous small bugfixes.
135
136 Changes in 2.0-beta1
137 =====================
138
139 * NEW: OSX style adouble scheme
140 * NEW: japanese SHIFT_JIS codepage (iconv supplied)
141 * NEW: Solaris kernel module build integrated with configure
142 * NEW: Gentoo start scripts
143 * NEW: cnid_dbd doesn't use transactions by default
144 * FIX: afpd: the volume casefold option was broken
145 * FIX: afpd: update AD2 headers and keep owner on file exchange
146 * FIX: Solaris 9 and FreeBSD 4.9/5.2 compilation
147 * FIX: free space reported with groups quotas on Linux
148 * FIX: OS9/OS X didn't update free space
149 * FIX: finder crash if folder opened got deleted by another process
150 * FIX: randnum UAM wasn't AFP3 ready
151 * FIX: numerous small bugfixes.
152
153 Changes in 2.0-alpha2
154 =====================
155
156 * NEW: uniconv tool for converting volume encoding.
157 * NEW: afpd: Make sure getstatus doesn't return loopback address as server IP.
158 * NEW: afpd: Specify USEDOTS with MSWINDOWS implicitely.
159 * NEW: afpd: SRVLOC register with IP address instead of hostname by default,
160        if -fqdn is specified register with FQDN.  Added extended character 
161        support for SLP, non ASCII characters are escaped Added ZONE to registration.
162 * NEW: atalkd: Make atalkd set interfaces to ALLMULTI on linux by default.
163 * NEW: cnid_metad: Use DB_PRIVATE attribute for dbd backend without transaction.
164 * FIX: afpd: Partial workaround for an OSX client deadlock.
165 * FIX: afpd: Reenumerate folder if db is out of sync in resolveID.
166 * FIX: afpd: Don't modify modification date in copyfile.
167 * FIX: afpd: Variable $v substitution: always use name defined in config files.
168 * FIX: libatalk: Speed optimisation for byte locking was broken on resource fork.
169 * FIX: Solaris 9 compilation.
170 * FIX: Tru64 compilation fixes.
171 * FIX: AFS compilation fixes.
172 * FIX: strncpy bugfix.
173 * FIX: configure, man pages update and small bugfixes.
174
175 Changes in 2.0-alpha1
176 =====================
177
178 * NEW: afpd: We now support AFP 3.x, which features long filenames and 
179        large file support
180 * NEW: CNID handling completely reworked. We now use per Volume configurable
181        CNID backends.
182 * NEW: Two new daemons, cnid_metad and cnid_dbd to implement the dbd CNID backend.
183        Using Berkeley DB transactions with the CNID database should be safe now.
184 * NEW: The on disk format of the CNID database has changed. We now support 8 byte
185        device and inode numbers and an additinal type field that should make 
186        detection of file/directory changes outside of afpd more robust. 
187        Changed from HASH to BTREE access which speeds things up in certain cases 
188        and reduces database file size.
189 * NEW: Long file name mangling is now implemented using the CNID ID, so no database is 
190        required to map names to mangled names. This is the same method Mac OS X uses. 
191 * NEW: New format (version 2) for Metadata in AppleDouble files. We record device and  
192        inode of the underlying file as well as the CNID. This can be used for recovery
193        and speeds up access to the CNID.
194 * NEW: The old NLS codepage system has been removed. It was replaced by an iconv 
195        based conversion system, which provides much more flexibility.
196 * NEW: You can safely use extended characters in volume names and for SIGUSR2 messaging.
197 * NEW: The default volume encoding is UTF-8.
198 * NEW: All documentation is now generated using DocBook. New or completely reworked 
199        sections about installing, setting up and upgrading Netatalk replace various 
200        README files in the doc directory.
201 * FIX: Protect afpd better against unexpected signals during updates of the CNID
202        database with the cdb backend. This makes database corruption less likely.   
203 * FIX: All manpages have been reviewed and should now be up to date.
204 * FIX: Tons of bug fixes since 1.6.4. Please consults the CVS change log for details.
205
206 Changes in 1.6.4
207 ================
208
209 * NEW: afpd: Using the mswindows option now implicitly specifies usedots.
210   [Sam Noble]
211 * UPD: afpd.8: Updated the option documentation.
212   [Thomas Kaiser, Sebastian Rittau]
213 * FIX: configure: Removed broken --with-flock-locks option. [Bjoern Fernhomberg]
214 * FIX: libatalk: Do not log network probe (OSX 10.3). [Didier Gautheron]
215 * FIX: libatalk: Deadlock in signal handlers. [Didier]
216 * FIX: libatalk: Compilation with Linux kernel 2.6 fixed. [Sebastian, Bjoern]
217 * FIX: afpd: Solaris compile issues. [Bjoern]
218 * FIX: afpd: If connection broke in dsi_tickle the child did never die. [Bjoern]
219 * FIX: afpd: Catsearch, fixes a possible segmentation fault. [Bjoern]
220 * FIX: afpd: Compilation issues. [Olaf Hering, Sebastian]
221 * FIX: cnid: Fix compile problems on Tru64. [Burkhard Schmidt]
222 * FIX: megatron: Fixed an uninitialized variable. [Olaf]
223 * FIX: installation: Don't overwrite PAM file if --enable-overwrite configure
224        option is not set. [Sam, Ryan Cleary]
225 * FIX: installation: Fixed BSD installation. [Toru TAKAMIZU]
226 * FIX: docs: Removed ssl-dir/ssl-dirs confusion from doc/INSTALL. [Bjoern]
227
228 Changes in 1.6.3
229 ================
230
231 * UPD: afpd: Infrastructural support for an upcoming Kerberos 5 UAM.
232        [Sam Noble]
233 * UPD: uams_dhx_passwd: Better random seed in Tru64. [Burkhard Schmidt]
234 * FIX: afpd: Bug in AFP connection negotiation stage. [Sam]
235 * FIX: afpd: Catsearch, when Mac and unix name differ, search on attributes.
236 * FIX: afpd: Files could be opened for writing on read-only filesystems.
237 * FIX: afpd: Debugging using SIGUSR1 was broken. [Stefan Muenkner]
238 * FIX: afpd: Segfault after login. [Robby Griffin, Sean Bolton]
239 * FIX: psf: Correct path to etc2ps.sh.
240 * FIX: shell_utils: Don't distribute generated files.
241 * FIX: aecho: -A option didn't work. [Chris Shiels]
242 * FIX: configure: Berkeley DB path detection could be wrong. [Stefan]
243 * FIX: Automake build fixes.
244
245 Changes in 1.6.2
246 ================
247
248 * FIX: atalkd: Fixes for reading long configuration file lines. [Dan Wilga]
249 * FIX: afpd: CNID id allocation in a multiuser environment.
250 * FIX: papd: Fix PSSP support when PAM is enabled.
251 * FIX: macusers: Can now cope with IP addresses as well as host names.
252 * FIX: etc2ps.sh: Install correctly.
253
254 Changes in 1.6.1
255 ================
256
257 * UPD: Improve --enable-fhs. [Olaf Hering]
258 * UPD: Add BDB 4.1.x support.
259 * UPD: Add more documentation on CNID, as well as list which versions
260        of Berkeley DB are supported.
261 * FIX: Codepage file maccode.koi8-r is now correctly cleaned.
262 * FIX: Fix init script location on SuSE. [Olaf]
263 * FIX: Build fixes. [Olaf, Steven N. Hirsch]
264 * FIX: Various bugs when a user doesn't have access permission to a folder.
265        (Fixes an OSX kernel panic.)
266 * FIX: CNID, folders' DID handling with concurrent access or symlinks.
267        (Fixes an endless loop in afpd.)
268
269 Changes in 1.6.0
270 ================
271
272 * FIX: pap looks at the STDOUT file descriptor to see if it's connected to
273        a tty, instead of STDIN.
274
275 Changes in 1.6pre2
276 ==================
277
278 * UPD: Removed --with-catsearch option from configure and enable FPCatSearch
279        by default.
280 * UPD: The dbpath argument does now support variable substitution.
281 * FIX: Build fix for non-GNU-C compilers in libatalk/util/logger.c.
282 * FIX: Two directories with the same name but different case confused the
283        Mac Finder.
284 * FIX: The ROOT_PARENT directory could get invalidated.
285
286 Changes in 1.6pre1
287 ====================
288
289 * NEW: Long file name mangling support.
290 * NEW: Improved log file support.
291 * NEW: Server-side find capability ("FPCatSearch")
292 * NEW: Concurrent datastore (CDB) is now the default CNID datastore.  This
293        should be heavily tested in a multiuser environment.
294 * NEW: Variable substitution support has been added for the dbpath AppleVolume
295        option.
296 * UPD: CNID DID handling is now enabled by default.
297 * FIX: Various bug and build fixes as well as code cleanups.
298
299 Changes in 1.5.5
300 ================
301
302 * NEW: Allow afpd debugging to be enabled by sending the afpd process
303        a SIGUSR1.
304 * NEW: Allow SLP to be disabled per afpd process by adding a new -noslp flag
305        to afpd.conf.
306 * FIX: Use server name (if not NULL) for the SLP URL.
307 * FIX: papd: buffer overflow during config file read (Olaf Hering)
308
309 Changes in 1.5.4
310 ================
311
312 * FIX: File open read only and then read write (aka pb with Illustrator).
313 * FIX: Problems with unexpected EOF when reading files on a ddp connection
314        Photoshop, old finder.
315 * FIX: --with-nls-dir option does now work
316
317 Changes in 1.5.3
318 ================
319
320 * UPD: Extend the --disable-shell-check functionality to ignore users
321        with _no_ shell.  Also, send a log message if a user is refused login
322        based on the fact that they have no shell.
323 * UPD: Autoconf updates.
324 * UPD: Tru64 afpd authentication updates.
325 * UPD: As always: lots of minor code cleanups.
326 * FIX: Problems with Photoshop trying to open image files has been
327        corrected.
328 * FIX: Preserve special permission bits when creating or modifying
329        directories.
330 * FIX: afp_deleteid() now deletes the specified file and not the parent
331        directory.
332 * FIX: papd does now announce that it supports binary data to its clients.
333 * FIX: NetBSD ELF support.
334 * FIX: acleandir.rc is now installed in the bin directory.
335 * FIX: megatron does now compile even if compiled with -DDEBUG.
336 * FIX: Clean up some syslog messages.
337
338 Changes in 1.5.2
339 ================
340
341 * NEW: NetBSD support contributed by David Rankin and NetBSD contributors.
342        This includes a new configure option --enable-netbsd.
343 * NEW: Add the -client_polling afpd.conf flag to allow for clients to poll
344        the server every 10 seconds for open window updates.  Currently
345        this is the only way to get asynchronous directory updates.
346 * UPD: Use separate macro for AFS configure check.
347 * UPD: Some Perl scripts are now (partially) auto-generated. This improves
348        out-of-the-box usage of Netatalk.
349 * UPD: Solaris Kernel Makefile is now auto-generated. This fixes some path
350        issues, but isn't perfect, yet. Added some Solaris compatibility
351        fixes to the Kernel sources, too.
352 * UPD: CNID DB code sync'd with the current CVS version.  NOTE: Using this
353        code requires you to delete _all_ existing .AppleDB directories in
354        order to avoid database corruption!
355 * FIX: The file AppleVolumes.system contained wrong line breaks so that
356        not all file types were properly recognized.
357 * FIX: AFS compilation would fail due to a misnamed variable.
358 * FIX: SLP configure check was wrong so SLP did not compile.
359 * FIX: Fix the way quotas are handled under certain situations.
360 * FIX: Do not enable debugging code if debugging option is not set.
361 * FIX: Some problems with wrongly assigned DIDs were fixed.
362 * FIX: Various bug fixes and code cleanups.
363
364 Changes in 1.5.1
365 ================
366
367 * NEW: Added a program called cnid_didname_verify that can be used to
368        verify the consistency of the CNID database.
369 * NEW: New afpd option: -timeout. Warning: This still doesn't do what it's
370        supposed to!
371 * UPD: Code cleanups and compatibility fixes to macusers.
372 * UPD: AppleVolumes.system was cleaned up.
373 * FIX: Really fix Tru64 compilation (see last entry).
374 * FIX: Hand correct error value back to AFP client when deleting files or
375        directories fails.
376 * FIX: Leading or trailing spaces are now forbidden on volumes that have
377        the AFPVOL_MSWINDOWS flag set.
378 * FIX: Minor code cleanups and warning fixes.
379 * FIX: Make quota support work on FreeBSD.
380
381 Changes in 1.5.0
382 ================
383
384 * FIX: Compilation on Tru64 systems was broken, since libtool's acinclude.m4
385        file on the packagers system did not contain the necessary patch.
386 * FIX: On some systems, atalkd refuses to start, since it couldn't detect
387        any interfaces. This was caused by an overzealous validity check.
388
389 Changes in 1.5rc2
390 =================
391
392 * FIX: contrib/shell_utils/lp2pap.sh was erased when "make clean" was called.
393        Now we distribute lp2pap.sh.tmpl instead, and lp2pap.sh is automatically
394        generated during package build.
395 * FIX: Some platforms (notably Tru64) don't have the snprintf() call, which
396        was used in etc/afp/afp_config.c. This call was replaced by sprintf()
397        and prior bounds checking.
398
399 Changes from the 1.4b1 release:
400 ===============================
401
402 *   Fixed the maximum free/total volume size in afpd.
403
404 *   Made ~ the default volume in afpd.
405
406 *   Fixed pid file handling and changed setpgrp() to setpgid() in afpd,
407     papd, and atalkd.
408
409 *   Added code to afpd to set the Unix file time stamps with utime().
410
411 *   Fixed a bug in papd's printcap code which limited it to 15 or so
412     printers.
413
414 *   Fixed papd's handling of piped printers.
415
416 *   Fixed papd's handling of bad job names.
417
418 *   Fixed atalkd to send NBP LKUP packets from NBP port.
419
420 *   Added "sync;sync;sync" to Solaris kinstall to help with streams
421     file corruption.
422
423 *   Added nlocalrts to streams ddp.conf.  Thanks Thomas Tornblom.
424
425 *   Fixed signed extension infinite loop in Solaris module.
426
427 *   Moved all the config files to .../config.
428
429 Changes from the 1.3.3 release:
430 ===============================
431
432 *   Added code from Sun Microsystems, Inc (OPCOM) for Solaris support.
433     See COPYRIGHT.
434
435 *   Added support for FreeBSD, mostly changes by Mark Dawson and Julian
436     Elischer.
437
438 *   All sorts of other stuff.
439
440 Changes from the 1.3.1 release:
441 ===============================
442
443 *   Added options to psf's filter names to support accounting on HPs.
444     !!! NOTE:  The location of the filters has changed, see the man
445     page for where.
446
447 *   Added code from Alan Cox to support Linux.
448
449 *   Rewrote papd.  Now handles dropped connections better.
450     Configuration has been modernized.  !!! NOTE: The format of the
451     configuration file has changed, but NOT THE NAME.
452
453 *   Added Kerberos support to papd.
454
455 *   atalkd now removes routes on a SIGTERM.  Still can't just restart
456     it, but it's closer.
457
458 *   Changed atalkd and the kernel driver to remove a hack added to
459     support sending to 0.255.  Now the kernel will allow multiple open
460     sockets with the same port, so long as the addess associated with
461     the port is different.  atalkd now opens a socket for each port on
462     each interface.
463
464 *   atalkd now rewrites its configuration file.  If no configuration
465     file is given, one will be generated.  Permissions on the new
466     configuration file will be inherited from the old one.  If there is
467     no old one, permissions default to 644.  Won't rewrite the file if
468     the owner doesn't have write permission.
469
470 *   Removed support for the "AFS Kerberos UAM", in favor of the
471     "AuthMan UAM".  Kerberos support should now be much more
472     straight-forward.
473
474 *   Fixed a bug in afpd which would cause incorrect group calculations
475     on ultrix machines.
476
477 *   Fixed a bug in afpd which causes SimpleText and some other
478     applications to silently fail to write.  There's also a bug in
479     MacOS, but we can't fix that.
480
481 *   Fixed a bad interaction with afpd and AFS which would cause file
482     writes to not propogate between AFS clients.
483
484 *   !!! CHANGED the name(s) of afpd's config files.  The new files are
485     AppleVolumes.system and AppleVolumes.default.  If AppleVolumes.system
486     exists, it is always read, AppleVolumes.default is only read if the
487     user has no AppleVolumes file.  Included a flag "-u" to indicate
488     which file has precedence.  "-u" user wins, otherwise ".system"
489     wins.
490
491 *   Rewrote the AppleVolumes parsing code.  Now works.
492
493 *   Added a filename extension mapping to afpd.  User always takes
494     precedence, regardless of the "-u" flag.  Code to change the type
495     of all Unix files contributed by Kee Hinckley <nazgul@utopia.com>.
496
497 *   afpd now supports both UFS and AFS volumes simultaneously.  It also
498     uses access() to attempt to calculate reasonable Mac permissions
499     for AFS directories.
500
501 *   Changed reporting of file times.  Files that are written from Unix
502     now update the Mac's idea of the files modification time.  Unix
503     mtime is now reported instead of ctime.
504
505 *   Added support for a new UAM to afpd.  This requires that client
506     Macs have MacTCP and AuthMan installed.  Should make running afpd
507     for AFS easier.
508
509 *   Removed code so that otherwise valid volumes for which the mounting
510     user has no permission will appear in the volume selection dialog
511     on the Mac gray-ed out.
512
513 *   Added code from Chris Metcalf of MIT to the AppleDouble library
514     which improves permission inheritance.
515
516 *   Added code from G. Paul Ziemba of Alantec, Inc to better report
517     errors in psf.  Also changed psf to use syslog for errors that
518     users aren't interested in.
519
520 *   Added information to psf's man page to better explain the
521     interaction between psf, pap, and lpd.
522
523 *   Make psf/pap/psa do accounting when it's turnes on in
524     /etc/printcap.
525
526 *   Changed pap's error message when there is no printer specified on
527     the command line and no .paprc is found.  Also heavily modified
528     pap's man page to reflect changes in the "new" version of pap,
529     including moving it from section 8 to section 1.
530
531 *   Fixed a byte-order bug in pap's sequence numbers.  Doubt if pap has
532     ever worked right on little endian machines!
533
534 *   Added a flag to pap to optionally close before receiving EOF from
535     the printer.  Off by default.  psf calls pap with this option on.
536
537 *   Added timeouts to the nbp library calls.  This means that processes
538     won't hang when atalkd dies during boot, thus hanging your
539     machine.
540
541 Changes from the 1.3 release:
542 =============================
543
544 *   Fixed a bug in afpd which would cause APPL mappings to contain both
545     mac and unix path names.  The fixed code will handle the old
546     (corrupted) database.
547
548 *   Fixed a *very* serious bug which would cause files to be corrupted
549     when copying to afpd.
550
551 *   Fixed a bug in afpd which would cause replies to icon writes to
552     contain the written icon.
553
554 *   Filled in the function code switch in afpd.  Previously, a hacker
555     could probably have used afpd to get unauthorized access to a
556     machine running afpd.
557
558 *   Fixed a bug in the asp portion of libatalk.a which could cause the
559     malloc()/free() database to be corrupted.
560
561 *   Fixed a bug in atalkd's zip query code.  With this bug, only the
562     first N % 255 nets get queried.  However, since nets bigger than
563     255 are usually pretty unstable, the unqueried for nets will
564     eventually get done, when N drops by one.
565
566 *   Suppressed a spurious error ("route: No such process") in atalkd.
567
568 Changes from the 1.2.1 release:
569 ===============================
570
571 *   atalkd is completely rewritten for phase 2 support.  atalkd.conf
572     from previous version will not work!
573
574 *   afpd now has better AFS support.  In particular, the configuration
575     for AFS was made much easier; a number of Kerberos-related
576     byte-ordering and time problems were found; clear-text passwords
577     were added (thanks to geeb@umich.edu).
578
579 *   afpd now handles Unix permissions much better (thanks to
580     metcalf@mit.edu).
581
582 *   There are many, many more changes, but most are small bug fixes.
583
584 Changes from the 1.2 release:
585 =============================
586
587 *   The Sun support now uses loadable kernel modules (a la VDDRV)
588     instead of binary patches. As such, it should work on any sunos
589     greater than 4.1, and is confirmed to work under 4.1.1 and 4.1.2.
590
591 *   The DEC support no longer requires source. It also runs under
592     ultrix 4.1 and 4.2. It still requires patching your kernel, but the
593     patches are limited to those files available to binary-only sites
594     -- primarily hooks for things like netatalk.
595
596 *   The etc.rc script now uses changes made to nbprgstr (see below).
597
598 *   aecho now takes machine names on the command line.
599
600 *   nbplkup now takes a command line argument specifying the number of
601     responses to accept. It also takes its defaults from the NBPLKUP
602     environment variable.
603
604 *   nbprgstr may be used to register a name at any requested port.
605
606 *   afpd now logs if an illegal shell is used during login, instead of
607     silently denying service.
608
609 *   A bug in afpd which caused position information for the directory
610     children of the root of a volume to be ignored has been fixed.
611
612 *   Several typos in afpd which would cause include files necessary to
613     ultrix to be skipped have been fixed.
614
615 *   atalkd will no long propagate routes to networks whose zone
616     it doesn't know.
617
618 *   atalkd no longer dumps core if it receives a ZIP GetMyZone request
619     from a network whose zone it doesn't know. (Since this currently
620     can only happen from off net, it's not precisely a legal request.)
621
622 *   pap and papd (optionally) no longer check the connection id in PAP
623     DATA responses. Both also maintain the function code in non-first-packet
624     PAP DATA responses.  These changes are work-arounds to deal with
625     certain AppleTalk printer cards, notably the BridgePort LocalTalk
626     card for HP LJIIISIs.
627
628 *   pap no longer sends an EOF response to each PAP SENDDATA request,
629     only the first.
630
631 *   A bug in papd which would cause it to return a random value when
632     printing the procset to a piped printer has been fixed.
633
634 *   A bug relating to NBP on reverse-endian machines has been fixed.
635
636 *   atp_rsel() from libatalk now returns a correct value even if it
637     hasn't recieved anything yet.
638
639 *   atalk_addr() from libatalk no longer accepts addresses in octal
640     format, since AppleTalk addresses can have leading zeros. Also it
641     checks that the separator character is a '.'.
642
643 *   Pseudo man pages for nbplkup, nbprgstr, and nbpunrgstr, have been
644     added.
645
646 *   The example in the psf(8) man page is now correct.
647
648 *   The man pages for changed commands have been updated.
649
650 *   The README files for various machine have been updated
651     appropriately.