]> arthur.barton.de Git - netatalk.git/blob - NEWS
3aed94ffe9280f8fc99f51461b5bc2bfe8c7a5f7
[netatalk.git] / NEWS
1 Changes in 3.0 alpha2
2 =====================
3
4 * UPD: afpd: Store '.' as is and '/' as ':' on the server, don't
5        CAP hexencode as "2e" and "2f" respectively
6 * UPD: afdp: Automatic name conversion, renaming files and directories
7        containing CAP sequences to their not enscaped forms
8 * UPD: dbd: -C option removes CAP encoding
9 * UPD: Add graceful option to RedHat init script
10 * UPD: Add --disable-bundled-libevent configure options When set to yes,
11        we rely on a properly installed version on libevent CPPFLAGS and LDFLAGS
12        should be set properly to pick that up
13 * UPD: Run ldconfig on Linux at the end of make install
14 * REM: Volumes options "use dots" and "hex encoding"
15
16 Changes in 3.0 alpha1
17 =====================
18
19 * NEW: Central configuration file afp.conf which replaces all previous files
20 * NEW: netatalk: service controller starting and restarting afpd and cnid_metad
21        as necessary
22 * NEW: afpd: Extended Attributes AppleDouble backend (default)
23 * UPD: CNID databases are stored in $localstatedir/netatalk/CNID
24        (default: /var/netatalk/CNID), databases found in AFP volumes are
25        automatically moved
26 * UPD: Start scripts and service manifests have been changed to only start
27        the new netatalk service controller process
28 * UPD: afpd: UNIX privileges and use dots enabled by default
29 * UPD: afpd: Support for arbitrary AFP volumes using variable expansion has been
30        removed
31 * UPD: afpd: afp_voluuid.conf and afp_signature.conf location has been
32        changed to $localstatedir/netatalk/ (default: /var/netatalk/)
33 * UPD: afpd: default server messages dir changed to $localstatedir/netatalk/msg/
34 * UPD: dbd: new option -C for conversion from AppleDouble v2 to ea
35 * REM: AppleTalk support has been removed
36 * REM: afpd: SLP and AFP proxy support have been removed
37 * REM: afpd: legacy file extension to type/creator mapping has been removed
38 * REM: afpd: AppleDouble backends v1, osx and sfm have been removed
39
40 Changes in 2.2.3
41 ================
42
43 * NEW: afpd: support for mdnsresponder
44 * NEW: afpd: new LDAP config option ldap_uuid_string
45 * UPD: based on Unicode 6.1.0
46 * UPD: experimental systemd service files: always run both afpd and cnid_metad
47 * UPD: afpd: Ensure our umask is not altered by eg pam_umask
48 * UPD: afpd: Use GSS_C_NO_NAME as server principal when Kerberos options -fqdn
49        and -krb5service are not set, from Jamie Gilbertson
50 * FIX: afpd: sendfile() on FreeBSD was broken, courtesy of Denis Ahrens
51 * FIX: afpd: Dont use searchdb when doing partial name search
52 * FIX: afpd: Fix a possible bug handling disconnected sessions,
53        NetAFP Bug ID #16
54 * FIX: dbd: Don't remove BerkeleyDB if it's still in use by eg cnid_dbd, fixes
55        bug introduced in 2.2.2
56 * FIX: debian initscript: start avahi-daemon (if available) before atalkd
57
58 Changes in 2.2.2
59 ================
60
61 * NEW: afpd: New option "adminauthuser". Specifying eg "-adminauthuser root"
62        whenever a normal user login fails, afpd tries to authenticate as
63        the specified adminauthuser. If this succeeds, a normal session is
64        created for the original connecting user. Said differently: if you
65        know the password of adminauthuser, you can authenticate as any other
66        user.
67 * NEW: configure option "--enable-suse-systemd" for openSUSE12.1 and later.
68        "--enable-redhat-systemd" and "--enable-suse-systemd" are same as
69        "--enable-systemd".
70        "--enable-suse" is renamed "--enable-suse-sysv".
71 * NEW: experimental systemd service files in distrib/systemd/
72 * UPD: afpd: Enhanced POSIX ACL mapping semantics, from Laura Mueller
73 * UPD: afpd: Reset options every time a :DEFAULT: line is found in a
74        AppleVolumes file
75 * UPD: afpd: Convert passwords from legacy encoding (wire format) to host
76        encoding, NetAFP Bug ID #14
77 * UPD: afpd: Don't set ATTRBIT_SHARED flag for directories
78 * UPD: afpd: Use sendfile() on Solaris and FreeBSD for sending data
79 * UPD: afpd: Faster volume used size calculation for "volsizelimit" option,
80        cf man AppleVolume.default for details
81 * FIX: afpd: ACL access checking
82 * FIX: afpd: Fix an error when duplicating files that lacked an AppleDouble
83        file which lead to a possible Finder crash
84 * FIX: afpd: Read-only filesystems lead to afpd processes running as root
85 * FIX: afpd: Fix for filesystem without NFSv4 ACL support on Solaris
86 * FIX: afpd: Fix catsearch bug, NetAFP Bug ID #12
87 * FIX: afpd: Fix dircache bug, NetAFP Bug ID #13
88 * FIX: dbd: Better checking for duplicated or bogus CNIDs from AppleDouble
89        files
90 * FIX: dbd: Remove BerkeleyDB database environment after running `dbd`. This
91        is crucial for the automatic BerkeleyDB database upgrade feature which
92        is built into cnid_dbd and dbd.
93 * FIX: Fix compilation error when AppleTalk support is disabled
94 * FIX: Portability fixes
95 * FIX: search of surrogate pair
96
97 Changes in 2.2.1
98 ================
99
100 * NEW: afpd: disable continous service feature by default, new option
101        -keepsessions to enable it
102 * NEW: configure option "--enable-redhat-systemd" for Fedora15 and later.
103        "--enable-redhat" is renamed "--enable-redhat-sysv".
104 * UPD: afpd: Enhance ACL support detection for volumes: enable them per volume
105        if
106        1) ACL support compiled in, 2) the volume supports ACLs, 3) the new
107        volume option "noacls" is not set for the volume.
108        The previous behaviour was to enable ACL support for a volume if
109        1) it was compiled in and 2) the volume supported ACLs. There was no way
110        to disable ACLs for a volume.
111 * UPD: afpd: add a configurable hold time option to FCE file modification event
112        generation, default is 60 s, new option "fceholdfmod" to change it
113 * UPD: afpd: add support for new NetBSD quota subsystem, Bug ID 3249879
114 * FIX: afpd: increase BerkeleyDB locks and lockobjs
115 * FIX: afpd: create special folder as root
116 * FIX: afpd: fix compilation error if --enable-ddp is used
117 * FIX: afpd: More robust IPC reconnect error handling
118 * FIX: afpd: ACL access checking
119 * FIX: afpd: fix a possible race condition between SIGCHLD handler and
120        new connection attempts
121 * FIX: afpd: fix undefined behaviour when more then ~510 connetions where
122        established
123 * FIX: afpd: fix a crash when searching for a UUID that is not a special
124        local UUID and LDAP support is not compiled in
125 * FIX: afpd: .volinfo file not created on first volume access if user in rolist
126 * FIX: afpd: possible crash at startup when registering with Avahi
127        when Avahi is not running
128 * FIX: afpd: return correct user/group type when mapping UUIDs to names
129 * FIX: afpd: for directories add DARWIN_ACE_DELETE ACE
130        if DARWIN_ACE_ADD_SUBDIRECTORY is set
131 * FIX: afpd: afpd crashed when it failed to register with Avahi because eg
132        user service registration is disabled in the Avahi config
133 * FIX: dbd: function checking and removing malformed ad:ea header files failed
134        to chdir back to the original working directory
135 * FIX: cnid_dbd: increase BerkeleyDB locks and lockobjs
136 * FIX: cnid_dbd: implement -d option, deletes CNID db
137 * FIX: dbd: better detection of local (or SMB/NFS) modifications on AFP volumes
138 * FIX: suse: initscript return better status
139 * FIX: Sourcecode distribution: add missing headers
140 * FIX: Solaris 10: missing dirfd replacement function
141 * FIX: case-conversion of surrogate pair
142 * FIX: Compilation error on GNU/kFreeBSD, fixes Bug ID 3392794 and
143        Debian #630349
144 * FIX: Fix Debian Bug#637025
145 * FIX: Multiple *BSD compilation compatibility fixes, Bug ID 3380785
146 * FIX: precompose_w() failed if tail character is decomposed surrogate pair
147
148 Changes in 2.2.0
149 ==============
150
151 * NEW: afpd: new volume option "nonetids"
152 * NEW: afpd: ACL access check caching
153 * NEW: afpd: FCE event notifications
154 * NEW: afpd: new option "-mimicmodel" for specifying Bonjour model registration
155 * UPD: Support for Berkeley DB 5.1
156 * UPD: case-conversion is based on Unicode 6.0.0
157 * UPD: cnid_metad: allow up to 4096 volumes
158 * UPD: afpd: only forward SIGTERM and SIGUSR1 from parent to childs
159 * UPD: afpd: use internal function instead of popening du -sh in order to
160        calculate the used size of a volume for option "volsizelimit"
161 * UPD: afpd: Add negative UUID caching, enhance local UUID handling
162 * FIX: afpd: configuration reload with SIGHUP
163 * FIX: afpd: crashes in the dircache
164 * FIX: afpd: Correct afp logout vs dsi eof behaviour
165 * FIX: afpd: new catsearch was broken
166 * FIX: afpd: only use volume UUIDs in master afpd
167 * FIX: dbd: Multiple fixes, reliable locking
168 * FIX: ad file suite: fix an error that resulted in CNID database
169        inconsistencies
170
171 Changes in 2.2beta4
172 ===================
173
174 * NEW: afpd: new afpd.conf options "tcprcvbuf" and "tcpsndbuf" to customize
175        the corresponding TCP socket options.
176 * NEW: afpd: new afpd.conf option "nozeroconf" which disabled automatic
177        Zeroconf service registration.
178 * FIX: afpd: generate mersenne primes for DHX2 UAM once at startup,
179        not for every login
180 * FIX: afpd: DSI streaming deadlock
181 * FIX: afpd: extended sleep
182 * FIX: afpd: directory cache
183 * FIX: Support for platforms that do not have the *at functions
184 * UPD: afpd: put POSIX write lock on volume files while reading them
185
186 Changes in 2.2beta3
187 ===================
188
189 * FIX: afpd: fix option volsizelimit to return a usefull value for the
190        volume free space using `du -sh` with popen
191 * FIX: afpd: fix idle connection disconnects
192 * FIX: afpd: don't disconnect sessions for clients if boottimes don't match
193 * FIX: afpd: better handling of very long filenames that contain many
194        multibyte UTF-8 glyphs
195
196 Changes in 2.2beta2
197 ====================
198
199 * NEW: afpd: AFP 3.3
200 * UPD: afpd: AFP 3.x can't be disabled
201
202 Changes in 2.2beta1
203 ====================
204
205 * FIX: composition of Surrogate Pair
206 * UPD: gentoo,suse,cobalt,tru64: inistscript name is "netatalk", not "atalk"
207 * UPD: gentoo: rc-update install don't hook in the Makefile
208
209 Changes in 2.2alpha5
210 ====================
211
212 * UPD: afpd: new option "searchdb" which enables fast catalog searches
213        using the CNID db.
214 * UPD: Case-insensitive fast search with the CNID db
215 * UPD: cnid_dbd: afpd now passes the volume path, not the db path when
216        connecting for a volume. cnid_dbd will read the
217        ".AppleDesktop/.volinfo" file of the volume in order to figure
218        out the CNID db path and the volume charset encoding.
219
220 Changes in 2.2alpha4
221 ====================
222
223 * NEW: Enhanced CNID "dbd" database for fast name search support.
224        Important: this makes cnidscheme "cdb" incompatible with "dbd".
225 * NEW: afpd: support for fast catalog searches
226 * NEW: ad utility: ad find
227 * UPD: afpd: CNID database versioning check for "cdb" scheme
228 * UPD: cnid_dbd: CNID database versioning and upgrading. Additional
229        CNID database index for fast name searches.
230
231 Changes in 2.2alpha3
232 ====================
233
234 * FIX: afpd: various fixes
235 * FIX: Any daemon did not run if atalkd doesn't exist (redhat/debian)
236
237 Changes in 2.2alpha2
238 ====================
239
240 * FIX: afpd: fix compilation error when ACL support is not available
241 * FIX: Ensure Appletalk manpages and config files are distributed
242
243 Changes in 2.2alpha1
244 ====================
245
246 * NEW: ad utility: ad cp
247 * NEW: ad utility: ad rm
248 * NEW: ad utility: ad mv
249 * NEW: afpd: dynamic directoy and CNID cache (new config option -dircachesize)
250 * NEW: afpd: POSIX 1e ACL support
251 * NEW: afpd: automagic Zeroconf registration with avahi, registering both
252        the service _afpovertcp._tcp and TimeMachine volumes with _adisk._tcp.
253 * UPD: afpd: ACLs usable (though not visible on the client side) without common
254        directory service, by mapping ACLs to UARight
255 * UPD: afpd: performance improvements for ACL access calculations
256 * UPD: AppleTalk is disabled by default at configuration time. If needed
257        use configure switch --enable-ddp.
258 * FIX: afpd: Solaris 10 compatibilty fix: don't use SO_SNDTIMEO/SO_RCVTIMEO,
259        use non-blocking IO and select instead.
260 * FIX: cnid_dbd: Solaris 10 compatibilty fix: don't use SO_SNDTIMEO/SO_RCVTIMEO,
261        use non-blocking IO and select instead.
262 * REM: afile/achfile/apple_cp/apple_mv/apple_rm: use ad
263
264 Changes in 2.1.6
265 ================
266
267 * FIX: afpd: Fix for LDAP user cache corruption
268 * FIX: afpd: Fix for not shown ACLs for when filesyem uid or gid
269        couldn't be resolved because (eg deleted users/groups)
270 * FIX: gentoo: cannot set $CNID_CONFIG
271 * FIX: ubuntu: servername was empty
272 * FIX: Solaris: configure script failed to enable DDP module
273 * FIX: AppleDouble buffer overrun by extremely long filename
274 * UPD: afpd: return version info with machine type in DSIGetStatus
275 * UPD: dbd: use on-disk temporary rebuild db instead of in-memory db
276 * UPD: suse: initscript update
277
278 Changes in 2.1.5
279 ================
280
281 * UPD: afpd: support newlines in -loginmesg with \n escaping syntax
282 * UPD: afpd: support for changed chmod semantics on ZFS with ACLs
283        in onnv145+
284 * FIX: afpd: fix leaking ressource when moving objects on the server
285 * FIX: afpd: backport Solaris 10 compatibilty fix from 2.2: don't use
286        SO_SNDTIMEO/SO_RCVTIMEO, use non-blocking IO and select instead.
287 * FIX: afpd: misaligned memory access on Sparc in ad_setattr, fixes
288        bug 3110004.
289 * FIX: cnid_dbd: backport Solaris 10 compatibilty fix from 2.2: don't
290        use SO_SNDTIMEO/SO_RCVTIMEO, use non-blocking IO and select instead.
291
292 Changes in 2.1.4
293 ================
294
295 * FIX: afpd: Downstream fix for FreeBSD PR 148022
296 * FIX: afpd: Fixes for bugs 3074077 and 3074078
297 * FIX: afpd: Better handling of symlinks in combination with ACLs and EAs.
298        Fixes bug 3074076.
299 * FIX: dbd: Adding a file with the CNID from it's adouble file did
300        not work in case that CNID was already occupied in the database
301 * FIX: macusers: add support for Solaris
302 * NEW: cnid_metad: use a PID lockfile
303 * NEW: afpd: prevent log flooding
304 * UPD: dbd: ignore ".zfs" snapshot directories
305 * UPD: dbd: support interrupting -re mode
306
307 Changes in 2.1.3
308 ================
309
310 * FIX: afpd: fix a serious error in networking IO code
311 * FIX: afpd: Solaris 10 compatibilty fix: don't use SO_SNDTIMEO, use
312        non-blocking IO and select instead for writing/sending data.
313 * UPD: Support for BerkeleyDB 5.0.
314
315 Changes in 2.1.2
316 ================
317
318 * FIX: afpd: fix for possible crash in case more then one server is
319        configured in afpd.conf.
320 * FIX: afpd: ExtendedAttributes in FreeBSD
321 * FIX: afpd: sharing home folders corrupted the per volume umask.
322 * UPD: afpd: umask for home folders is no longer taken from startup umask.
323 * UPD: afpd: dont and permissions with parent folder when creating new
324        directories on "upriv" volumes.
325 * UPD: afpd: use 'afpserver@fqdn' instead of 'afpserver/fqdn@realm'.
326        Prevents a crash in older GNU GSSAPI libs on eg. CentOS 5.x.
327  
328 Changes in 2.1.1
329 ================
330
331 * UPD: fallback to a temporary in memory tdb CNID database if the volume
332        database can't be opened now works with the default backend "dbd" too.
333 * FIX: afpd: afp_ldap.conf was missing from tarball. This only effected
334        [Open]Solaris.
335 * FIX: afpd: Check if options->server is set in set_signature, preventing
336        SIGSEGV.
337 * FIX: afpd: server signature wasn't initialized in some cases
338 * FIX: DESTDIR support: DESTDIR was expanded twice
339 * FIX: Fix for compilation error if header files of an older Netatalk
340        version are installed.
341
342 Changes in 2.1-release
343 ======================
344
345 * NEW: afpd: new volume option "volsizelimit" for limitting reported volume
346        size. Useful for limitting TM backup size.
347 * UPD: dbd: -c option for rebuilding volumes which prevents the creation
348        of .AppleDouble stuff, only removes orphaned files.
349
350 Changes in 2.1-beta2
351 ====================
352
353 * NEW: afpd: static generated AFP signature stored in afp_signature.conf,
354        cf man 5 afp_signature.conf
355 * NEW: afpd: clustering support: new per volume option "cnidserver".
356 * UPD: afpd: set volume defaults options "upriv" and "usedots" in the
357        volume config file AppleVolumes.default. This will only affect
358        new installations, but not upgrades.
359 * FIX: afpd: prevent security attack guessing valid server accounts. afpd
360        now returns error -5023 for unknown users, as does AppleFileServer.
361
362 Changes in 2.1-beta1
363 ====================
364
365 * NEW: afpd: AFP 3.2 support
366 * NEW: afpd: Extended Attributes support using native attributes or
367        using files inside .AppleDouble directories.
368 * NEW: afpd: ACL support with ZFS
369 * NEW: cnid_metad: options -l and -f to configure logging
370 * NEW: IPv6 support
371 * NEW: AppleDouble compatible UNIX files utility suite `ad ...`.
372        With 2.1 only `ad ls`.
373 * NEW: CNID database maintanance utility dbd
374 * NEW: support BerkeleyDB upgrade. Starting with the next release
375        after 2.1 in case of BerkeleyDB library updates, Netatalk
376        will be able to upgrade the CNID databases.
377 * NEW: afpd: store and read CNIDs to/from AppleDouble files by default.
378        This is used as a cache and as a backup in case the database
379        is deleted or corrupted. It can be disabled with a new volume
380        option "nocnidcache".
381 * NEW: afpd: sending SIGINT to a child afpd process enables debug logging
382        to /tmp/afpd.PID.XXXXXX.
383 * NEW: configure args to download and install a "private" Webmin instance
384        including only basic Webmin modules plus our netatalk.wbm.
385 * NEW: fallback to a temporary in memory tdb CNID database if the volume
386        database can't be opened.
387 * NEW: support for Unicode characters in the range above U+010000 using
388        internal surrogate pairs
389 * NEW: apple_dump: utility to dump AppleSingle and AppleDouble files
390 * NEW: afpldaptest: utility to check afp_ldap.conf.
391 * UPD: atalkd and papd are now disabled by default. AppleTalk is legacy.
392 * UPD: slp advertisement is now disabled by default. server option -slp
393        SRVLOC is legacy.
394 * UPD: cdb/dbd CNID backend requires BerkeleyDB >= 4.6
395 * UPD: afpd: default CNID backend is "dbd"
396 * UPD: afpd: try to install PAM config that pulls in system|common auth
397 * UPD: afpd: symlink handling: never followed server side, client resolves
398        them, so it's safe to use them now.
399 * UPD: afpd: Comment out all extension->type/creator mappings in
400        AppleVolumes.system. They're unmaintained, possibly wrong and
401        do not fit for OS X.
402 * FIX: rewritten logger
403 * FIX: afpd: UNIX permissions handling
404 * FIX: cnid_dbd: always use BerkeleyDB transactions
405 * FIX: initscripts installation now correctly uses autoconf paths,
406        ie they're installed to --sysconfdir.
407 * FIX: UTF-8 volume name length
408 * FIX: atalkd: workaround for broken Linux 2.6 AT kernel module:
409        Linux 2.6 sends broadcast queries to the first available socket
410        which is in our case the last configured one. atalkd now tries to
411        find the right one.
412        Note: now a misconfigured or plugged router can broadcast a wrong route !
413 * REM: afpd: removed CNID backends "db3", "hash" and "mtab"
414 * REM: cnid_maint: use dbd
415 * REM: cleanappledouble.pl: use dbd
416 * REM: nu: use `macusers` instead
417
418 Changes in 2.0.5
419 ================
420
421 * NEW: afpd: Time Machine support with new volume option "tm".
422 * FIX: papd: Remove variable expansion for BSD printers. Fixes CVE-2008-5718.
423 * FIX: afpd: .AppleDxxx folders were user accessible if option 'usedots'
424        was set 
425 * FIX: afpd: vetoed files/dirs where still accessible
426 * FIX: afpd: cnid_resolve: don't return '..' as a valid name.
427 * FIX: uniconv: -d option wasn't working
428
429 Changes in 2.0.4
430 ================
431
432 * REM: remove timeout 
433 * NEW: afpd: DHX2 uams using GNU libgcrypt.
434 * NEW: afpd: volume options 'illegalseq', 'perm' and 'invisibledots'
435        'ilegalseq'  encode illegal sequence in filename asis, ex "\217-", which is not 
436        a valid SHIFT-JIS char, is encoded  as U\217 -.
437        'perm' value OR with the client requested permissions. (help with OSX 10.5
438        strange permissions).
439        Make dot files visible by default with 'usedots', use 'invisibledots' 
440        for keeping the old behavior, ie for OS9 (OSX hide dot files on its
441        own).
442 * NEW: afpd: volume options allow_hosts/denied hosts
443 * NEW: afpd: volume options dperm/fperm default directory and file
444        permissions or with server requests.
445 * NEW: afpd: afpd.conf, allow line continuation with \ 
446 * NEW: afpd: AppleVolumes.default allow line continuation with \
447 * NEW: afpd: Mac greek encoding.
448 * NEW: afpd: CJK encoding.
449 * UPD: afpd: Default UAMs: DHX + DHX2
450 * FIX: afpd: return the right error in createfile and copyfile if the disk
451        is full.
452 * FIX: afpd: resolveid return the same error code than OSX if it's a directory
453 * FIX: afpd: server name check, test for the whole loopback subnet 
454        not only 127.0.0.1.
455 * UPD: afpd: limit comments size to 128 bytes, (workaround for Adobe CS2 bug).
456 * UPD: afpd: no more daemon icon.
457 * UPD: usedots, return an invalide name only for .Applexxx files used by netatalk not
458        all files starting with .apple.
459 * UPD: cnid: increase the number of cnid_dbd slots to 512.
460 * FIX: cnid: dbd detach the daemon from the control terminal.
461 * UPD: cnid: never ending Berkeley API changes...
462 * UPD: cnid: dbd add a timeout when reading data from afpd client.
463 * UPD: cnid: Don't wait five second after the first error when speaking to the dbd
464        backend.
465 * FIX: papd: vars use % not $
466 * FIX: papd: quote chars in popen variables expansion. security fix.
467 * FIX: papd: papd -d didn't write to stderr.
468 * FIX: papd: ps comments don't always use ()
469 * FIX: many compilation errors (solaris, AFS, Tru64, xfs quota...).
470
471 Changes in 2.0.3
472 ================
473
474 * NEW: afpd: add a cachecnid option that controls if afpd should 
475        use the IDs stored in the AD2 files as cache. Defaults
476        to off.
477 * UPD: afpd: deal with more than 32 groups.
478 * FIX: afpd: several catsearch fixes, based on patch from
479        TSUBAKIMOTO Hiroya.
480 * FIX: afpd: fix a race when a client very quickly reconnects and 
481        tries to kill its old session.
482 * FIX: afpd: OSX style symlink caused problems with Panther clients.
483 * FIX: afpd: old files with default type didn't show the right icon
484        in finder, from Shlomi Yaakobovich, slightly modified.
485 * FIX: cnid_check: disable cnid_check if CNID db was configured with
486        transactions and really bail out after the first error.
487 * FIX: admin-group configure option was broken.
488 * FIX: several problems with IDs cached in AD2 files.
489 * FIX: Ignore BIDI in UTF8 hints from OSX.
490 * FIX: Lots of gcc warning fixes.
491 * FIX: small configure script changes.
492
493
494 Changes in 2.0.2
495 ================
496
497 * NEW: cnid: Add an indexes check and rebuild, optional for dbd 
498        (parameter check default no), standalone program cnid_index for
499        cdb.
500 * UPD: Enhanced afpd's -v command line switch and added -V for more 
501        verbose information
502 * UPD: uams_gss: build the principal used by uams_gss.so from afpd's
503        configuration, don't use GSS_C_NT_HOSTBASED_SERVICE
504 * UPD: cnid_dbd: add process id in syslog and small clean up
505 * REM: remove netatalkshorternamelinks.pl cf. SF bug [ 1061396 ]
506        netatalkshorternamelinks.pl broken
507 * FIX: afpd: check for DenyRead on FPCopyFile
508 * FIX: afpd: add missing flush for AD2 Metadata on FPCopyFile, SF bug 
509        [ 1055691 ] Word 98 OS 9 Saving an existing file
510 * FIX: afpd: Deal with AFP3 connection and type 2 (non-UTF8) names.
511        reported by Gair Heaton, HI RESOLUTION SYSTEMS
512 * FIX: afpd: Broken 'crlf' option
513 * FIX: afpd: fix SF bug [ 1079622 ] afpd/dhx memory bug, 
514        by Ralf Schuchardt
515 * FIX: afpd: Return an error if we cannot get the db stamp in 
516        afp_openvol.
517 * FIX: afpd: Fix slp registration with Solaris9 slpd, from
518        hat at fa2.so-net.ne.jp
519         
520
521 Changes in 2.0.1
522 ================
523
524 * NEW: --enable-debian configure option. Will install /etc/init.d/atalk
525        to get not in conflict with standard debian /etc/init.d/netatalk.
526        Reads netatalk.conf from $ETCDIR and not from /etc/default/
527 * UPD: Disable logger code by default. Log to syslog instead
528 * UPD: changed netatalk.conf default settings to prevent problems with
529        AppleTalk zone names containing spaces
530 * FIX: insecure tempfile handling bug in etc2ps.sh,
531        found by Trustix, CAN-2004-0974.
532 * REM: remove add_netatalk_printer and netatalk.template from stable 
533        branch until fixed. (possible symlink vulnerabilities)
534 * FIX: afpd: set hasBeenInited in default finder info. This bug caused 
535        endless finder refreshes with OS9 finder if the noadouble option 
536        was used. From TSUBAKIMOTO Hiroya.
537 * FIX: afpd: fix a bug in default CREATOR/TYPE handling. Due to this bug 
538        the type/creator mappings in AppleVolumes.system were ignored, 
539        causing problems i.e. with OS9 clients.
540 * FIX: AppleVolumes.system: By default don't define a CREATOR/TYPE for a
541        file of unknown type.
542 * FIX: fix two Tru64 UNIX compilation errors, 
543        from Burkhard Schmidt bs AT cpfs.mpg.de
544 * FIX: afpd: FPMapId wasn't using UTF8 for groups if requested by client.       
545
546 Changes in 2.0.0
547 ================
548
549 * UPD: afpd: add an error message if -ipaddr parameter cannot be parsed
550 * UPD: updated documentation
551 * FIX: afpd: fix a file descriptor and memory leak with OSX ._ resource fork
552 * FIX: afpd: Prevent overwriting a file by renaming a file in the same 
553        directory to the same name. Won't work with OSX, the dest file gets 
554        deleted by OSX first.
555 * FIX: sometimes '0' was used instead of 0 for creator/type
556 * FIX: removed setpgrp check from configure, we don't use it anymore and
557        it doesn't work with cross compile.
558 * FIX: fix for Solaris "make maintainer-clean", from Alexander Barton
559 * FIX: fix username matching bug in afppasswd. from kanai at nadmin dot org
560 * FIX: reworked username check a little. Depending on the UAM, the wrong
561        username _could_ have been selected.
562
563 Changes in 2.0-rc2
564 ==================
565
566 * UPD: use 0 0 for default creator/type rather than UNIX TEXT, from
567        Shlomi Yaakobovich.
568 * UPD: updated documentation
569 * UPD: change machine type from Macintosh to Netatalk in status reply
570 * FIX: afpd: CopyFile only create a resource fork for destination if source
571        has one.
572 * FIX: afpd: mangling: for utf8 --> max filename length is 255 bytes, else 31.
573 * FIX: cnid_dbd: fix a signed/unsigned, 16/32 bits mismatch. from Burkhard
574        Schmidt, bs at cpfs.mpg.de.
575 * FIX: afpd: After ad_setid don't flush resource fork if it has not been
576        modified.
577 * FIX: NEWS: Fixed ancient NEWS entries. Removed umlauts
578 * FIX: fix macname cache, SF bug 1021642
579 * FIX: revert Makefile change from 2.0-rc1. We have to include BDB_CFLAGS
580        after CFLAGS
581
582 Changes in 2.0-rc1
583 ==================
584
585 * NEW: new manual page for asip-status.pl
586 * UPD: updated documentation
587 * UPD: uams: link uam_dhx_passwd.so to lcrypt before lcrypto. might help with
588        MD5 passwords
589 * UPD: Improved BerkeleyDB detection
590 * UPD: sys/solaris/Makefile.in: enable 'make check', from Alexander Barton
591 * UPD: tcp wrappers detection should work on OpenBSD as well now
592 * UPD: macbin: increase the maximum size of macbinary forks, as suggested by 
593        Sourceforge bug ID 829221
594 * UPD: ASP: rework getstatus. use several ASP packets if the client allows
595        it, otherwise just send as much as we can
596 * FIX: FreeBSD 5 build, from Alex Barton (alex at barton.de)
597 * FIX: OSX 10.3 build
598 * FIX: papd: workaround a problem with PJL before Postscript
599 * FIX: afpd: make sure we only disconnect on old session if the users match
600 * FIX: apfd: Quark6 mangled long filenames should work better now
601 * FIX: enhance ADv1 to ADv2 conversion. Fixed a SIGSEGV reported by Mark Baker
602 * FIX: better detection of invalid resource forks
603 * FIX: fix some linking problems on OpenBSD
604 * FIX: afpd: catsearch.c, filedir.c: fix bogus casts, from Olaf Hering 
605        (olh at suse.de)
606 * FIX: afpd: don't try to create special folders and .volinfo on read-only
607        volumes
608 * FIX: iconv/unicode enhancements. fixed a sigsegv on conversion error
609 * FIX: configure.in: fix a typo, reported by Joerg Rossdeutscher
610 * FIX: uniconv: enhanced uniconv behaviour
611 * FIX: fixed some Solaris compilation problems
612 * FIX: papd/Makefile.am: add a missing $DESTDIR, from Vlad Agranovsky
613 * FIX: afpd: quota.c: remove a c99 declaration, from Yann Rouillard
614 * FIX: configure.in: Solaris/gcc 3.0 fix, from Yann Rouillard
615 * FIX: afpd: fix a SIGSEGV when sharing home dirs without any options in 
616        AppleVolumes.
617 * FIX: numerous small bugfixes
618
619 Changes in 2.0-beta2
620 ====================
621
622 * NEW: atalkd, papd and npb tools now support nbpnames with extended
623        characters
624 * NEW: integrated CUPS support for papd
625 * NEW: optionally advertise SSH tunneling capabilties
626 * NEW: automatic logfile removal for cnid_metad
627 * NEW: asip-status.pl has been added to netatalk
628 * UPD: updated documentation
629 * UPD: we now require Berkeley DB >= 4.1
630 * UPD: 64bit Linux fixes from Stew Benedict, Mandrakesoft
631 * UPD: remove --enable-sendfile
632 * UPD: more verbose error messages
633 * FIX: better handling for resource forks without read access
634 * FIX: Tru64 build, by Burkhard Schmidt
635 * FIX: MIT Kerberos detection
636 * FIX: varios *BSD compile problems
637 * FIX: compile problem with libiconv, reported by Joe Marcus Clarke
638 * FIX: adv1tov2: make it work with the new structure
639 * FIX: afpd: filenames longer than 127 bytes were not enumerated correctly,
640        reported by Thies C. Arntzen
641 * FIX: afpd: return IP before FQDN in status reply.
642 * FIX: afpd: Mac chooser could crash on a codepage conversion error
643 * FIX: afpd: KerberosV auth with Panther clients, make long AD tickets work,
644        reported by Andrew Smith
645 * FIX: atalkd: could send invalid NBPLKUP replies, e.g with more than 15
646        printers. Reported by Almacha
647 * FIX: papd: fix papd.conf parsing problems with consecutive ':' and missing 
648        newline. Reported by Craig White.
649 * FIX: megatron: make megatron work with UTF-8 volumes
650 * FIX: timeout: running timeout with commands which accept arguments, 
651        from Yuval Yeret.
652 * FIX: uniconv: fix a SEGFAULT, reported by Matthew Geier
653 * FIX: pam detection: PAM_C/LDFLAGS were always empty, from Alexander Barton
654 * FIX: numerous small bugfixes.
655
656 Changes in 2.0-beta1
657 ====================
658
659 * NEW: OSX style adouble scheme
660 * NEW: japanese SHIFT_JIS codepage (iconv supplied)
661 * NEW: Solaris kernel module build integrated with configure
662 * NEW: Gentoo start scripts
663 * NEW: cnid_dbd doesn't use transactions by default
664 * FIX: afpd: the volume casefold option was broken
665 * FIX: afpd: update AD2 headers and keep owner on file exchange
666 * FIX: Solaris 9 and FreeBSD 4.9/5.2 compilation
667 * FIX: free space reported with groups quotas on Linux
668 * FIX: OS9/OS X didn't update free space
669 * FIX: finder crash if folder opened got deleted by another process
670 * FIX: randnum UAM wasn't AFP3 ready
671 * FIX: numerous small bugfixes.
672
673 Changes in 2.0-alpha2
674 =====================
675
676 * NEW: uniconv tool for converting volume encoding.
677 * NEW: afpd: Make sure getstatus doesn't return loopback address as server IP.
678 * NEW: afpd: Specify USEDOTS with MSWINDOWS implicitely.
679 * NEW: afpd: SRVLOC register with IP address instead of hostname by default,
680        if -fqdn is specified register with FQDN.  Added extended character 
681        support for SLP, non ASCII characters are escaped Added ZONE to registration.
682 * NEW: atalkd: Make atalkd set interfaces to ALLMULTI on linux by default.
683 * NEW: cnid_metad: Use DB_PRIVATE attribute for dbd backend without transaction.
684 * FIX: afpd: Partial workaround for an OSX client deadlock.
685 * FIX: afpd: Reenumerate folder if db is out of sync in resolveID.
686 * FIX: afpd: Don't modify modification date in copyfile.
687 * FIX: afpd: Variable $v substitution: always use name defined in config files.
688 * FIX: libatalk: Speed optimisation for byte locking was broken on resource fork.
689 * FIX: Solaris 9 compilation.
690 * FIX: Tru64 compilation fixes.
691 * FIX: AFS compilation fixes.
692 * FIX: strncpy bugfix.
693 * FIX: configure, man pages update and small bugfixes.
694
695 Changes in 2.0-alpha1
696 =====================
697
698 * NEW: afpd: We now support AFP 3.x, which features long filenames and 
699        large file support
700 * NEW: CNID handling completely reworked. We now use per Volume configurable
701        CNID backends.
702 * NEW: Two new daemons, cnid_metad and cnid_dbd to implement the dbd CNID backend.
703        Using Berkeley DB transactions with the CNID database should be safe now.
704 * NEW: The on disk format of the CNID database has changed. We now support 8 byte
705        device and inode numbers and an additinal type field that should make 
706        detection of file/directory changes outside of afpd more robust. 
707        Changed from HASH to BTREE access which speeds things up in certain cases 
708        and reduces database file size.
709 * NEW: Long file name mangling is now implemented using the CNID ID, so no database is 
710        required to map names to mangled names. This is the same method Mac OS X uses. 
711 * NEW: New format (version 2) for Metadata in AppleDouble files. We record device and  
712        inode of the underlying file as well as the CNID. This can be used for recovery
713        and speeds up access to the CNID.
714 * NEW: The old NLS codepage system has been removed. It was replaced by an iconv 
715        based conversion system, which provides much more flexibility.
716 * NEW: You can safely use extended characters in volume names and for SIGUSR2 messaging.
717 * NEW: The default volume encoding is UTF-8.
718 * NEW: All documentation is now generated using DocBook. New or completely reworked 
719        sections about installing, setting up and upgrading Netatalk replace various 
720        README files in the doc directory.
721 * FIX: Protect afpd better against unexpected signals during updates of the CNID
722        database with the cdb backend. This makes database corruption less likely.   
723 * FIX: All manpages have been reviewed and should now be up to date.
724 * FIX: Tons of bug fixes since 1.6.4. Please consults the CVS change log for details.
725
726 Changes in 1.6.4
727 ================
728
729 * NEW: afpd: Using the mswindows option now implicitly specifies usedots.
730   [Sam Noble]
731 * UPD: afpd.8: Updated the option documentation.
732   [Thomas Kaiser, Sebastian Rittau]
733 * FIX: configure: Removed broken --with-flock-locks option. [Bjoern Fernhomberg]
734 * FIX: libatalk: Do not log network probe (OSX 10.3). [Didier Gautheron]
735 * FIX: libatalk: Deadlock in signal handlers. [Didier]
736 * FIX: libatalk: Compilation with Linux kernel 2.6 fixed. [Sebastian, Bjoern]
737 * FIX: afpd: Solaris compile issues. [Bjoern]
738 * FIX: afpd: If connection broke in dsi_tickle the child did never die. [Bjoern]
739 * FIX: afpd: Catsearch, fixes a possible segmentation fault. [Bjoern]
740 * FIX: afpd: Compilation issues. [Olaf Hering, Sebastian]
741 * FIX: cnid: Fix compile problems on Tru64. [Burkhard Schmidt]
742 * FIX: megatron: Fixed an uninitialized variable. [Olaf]
743 * FIX: installation: Don't overwrite PAM file if --enable-overwrite configure
744        option is not set. [Sam, Ryan Cleary]
745 * FIX: installation: Fixed BSD installation. [Toru TAKAMIZU]
746 * FIX: docs: Removed ssl-dir/ssl-dirs confusion from doc/INSTALL. [Bjoern]
747
748 Changes in 1.6.3
749 ================
750
751 * UPD: afpd: Infrastructural support for an upcoming Kerberos 5 UAM.
752        [Sam Noble]
753 * UPD: uams_dhx_passwd: Better random seed in Tru64. [Burkhard Schmidt]
754 * FIX: afpd: Bug in AFP connection negotiation stage. [Sam]
755 * FIX: afpd: Catsearch, when Mac and unix name differ, search on attributes.
756 * FIX: afpd: Files could be opened for writing on read-only filesystems.
757 * FIX: afpd: Debugging using SIGUSR1 was broken. [Stefan Muenkner]
758 * FIX: afpd: Segfault after login. [Robby Griffin, Sean Bolton]
759 * FIX: psf: Correct path to etc2ps.sh.
760 * FIX: shell_utils: Don't distribute generated files.
761 * FIX: aecho: -A option didn't work. [Chris Shiels]
762 * FIX: configure: Berkeley DB path detection could be wrong. [Stefan]
763 * FIX: Automake build fixes.
764
765 Changes in 1.6.2
766 ================
767
768 * FIX: atalkd: Fixes for reading long configuration file lines. [Dan Wilga]
769 * FIX: afpd: CNID id allocation in a multiuser environment.
770 * FIX: papd: Fix PSSP support when PAM is enabled.
771 * FIX: macusers: Can now cope with IP addresses as well as host names.
772 * FIX: etc2ps.sh: Install correctly.
773
774 Changes in 1.6.1
775 ================
776
777 * UPD: Improve --enable-fhs. [Olaf Hering]
778 * UPD: Add BDB 4.1.x support.
779 * UPD: Add more documentation on CNID, as well as list which versions
780        of Berkeley DB are supported.
781 * FIX: Codepage file maccode.koi8-r is now correctly cleaned.
782 * FIX: Fix init script location on SuSE. [Olaf]
783 * FIX: Build fixes. [Olaf, Steven N. Hirsch]
784 * FIX: Various bugs when a user doesn't have access permission to a folder.
785        (Fixes an OSX kernel panic.)
786 * FIX: CNID, folders' DID handling with concurrent access or symlinks.
787        (Fixes an endless loop in afpd.)
788
789 Changes in 1.6.0
790 ================
791
792 * FIX: pap looks at the STDOUT file descriptor to see if it's connected to
793        a tty, instead of STDIN.
794
795 Changes in 1.6pre2
796 ==================
797
798 * UPD: Removed --with-catsearch option from configure and enable FPCatSearch
799        by default.
800 * UPD: The dbpath argument does now support variable substitution.
801 * FIX: Build fix for non-GNU-C compilers in libatalk/util/logger.c.
802 * FIX: Two directories with the same name but different case confused the
803        Mac Finder.
804 * FIX: The ROOT_PARENT directory could get invalidated.
805
806 Changes in 1.6pre1
807 ====================
808
809 * NEW: Long file name mangling support.
810 * NEW: Improved log file support.
811 * NEW: Server-side find capability ("FPCatSearch")
812 * NEW: Concurrent datastore (CDB) is now the default CNID datastore.  This
813        should be heavily tested in a multiuser environment.
814 * NEW: Variable substitution support has been added for the dbpath AppleVolume
815        option.
816 * UPD: CNID DID handling is now enabled by default.
817 * FIX: Various bug and build fixes as well as code cleanups.
818
819 Changes in 1.5.5
820 ================
821
822 * NEW: Allow afpd debugging to be enabled by sending the afpd process
823        a SIGUSR1.
824 * NEW: Allow SLP to be disabled per afpd process by adding a new -noslp flag
825        to afpd.conf.
826 * FIX: Use server name (if not NULL) for the SLP URL.
827 * FIX: papd: buffer overflow during config file read (Olaf Hering)
828
829 Changes in 1.5.4
830 ================
831
832 * FIX: File open read only and then read write (aka pb with Illustrator).
833 * FIX: Problems with unexpected EOF when reading files on a ddp connection
834        Photoshop, old finder.
835 * FIX: --with-nls-dir option does now work
836
837 Changes in 1.5.3
838 ================
839
840 * UPD: Extend the --disable-shell-check functionality to ignore users
841        with _no_ shell.  Also, send a log message if a user is refused login
842        based on the fact that they have no shell.
843 * UPD: Autoconf updates.
844 * UPD: Tru64 afpd authentication updates.
845 * UPD: As always: lots of minor code cleanups.
846 * FIX: Problems with Photoshop trying to open image files has been
847        corrected.
848 * FIX: Preserve special permission bits when creating or modifying
849        directories.
850 * FIX: afp_deleteid() now deletes the specified file and not the parent
851        directory.
852 * FIX: papd does now announce that it supports binary data to its clients.
853 * FIX: NetBSD ELF support.
854 * FIX: acleandir.rc is now installed in the bin directory.
855 * FIX: megatron does now compile even if compiled with -DDEBUG.
856 * FIX: Clean up some syslog messages.
857
858 Changes in 1.5.2
859 ================
860
861 * NEW: NetBSD support contributed by David Rankin and NetBSD contributors.
862        This includes a new configure option --enable-netbsd.
863 * NEW: Add the -client_polling afpd.conf flag to allow for clients to poll
864        the server every 10 seconds for open window updates.  Currently
865        this is the only way to get asynchronous directory updates.
866 * UPD: Use separate macro for AFS configure check.
867 * UPD: Some Perl scripts are now (partially) auto-generated. This improves
868        out-of-the-box usage of Netatalk.
869 * UPD: Solaris Kernel Makefile is now auto-generated. This fixes some path
870        issues, but isn't perfect, yet. Added some Solaris compatibility
871        fixes to the Kernel sources, too.
872 * UPD: CNID DB code sync'd with the current CVS version.  NOTE: Using this
873        code requires you to delete _all_ existing .AppleDB directories in
874        order to avoid database corruption!
875 * FIX: The file AppleVolumes.system contained wrong line breaks so that
876        not all file types were properly recognized.
877 * FIX: AFS compilation would fail due to a misnamed variable.
878 * FIX: SLP configure check was wrong so SLP did not compile.
879 * FIX: Fix the way quotas are handled under certain situations.
880 * FIX: Do not enable debugging code if debugging option is not set.
881 * FIX: Some problems with wrongly assigned DIDs were fixed.
882 * FIX: Various bug fixes and code cleanups.
883
884 Changes in 1.5.1
885 ================
886
887 * NEW: Added a program called cnid_didname_verify that can be used to
888        verify the consistency of the CNID database.
889 * NEW: New afpd option: -timeout. Warning: This still doesn't do what it's
890        supposed to!
891 * UPD: Code cleanups and compatibility fixes to macusers.
892 * UPD: AppleVolumes.system was cleaned up.
893 * FIX: Really fix Tru64 compilation (see last entry).
894 * FIX: Hand correct error value back to AFP client when deleting files or
895        directories fails.
896 * FIX: Leading or trailing spaces are now forbidden on volumes that have
897        the AFPVOL_MSWINDOWS flag set.
898 * FIX: Minor code cleanups and warning fixes.
899 * FIX: Make quota support work on FreeBSD.
900
901 Changes in 1.5.0
902 ================
903
904 * FIX: Compilation on Tru64 systems was broken, since libtool's acinclude.m4
905        file on the packagers system did not contain the necessary patch.
906 * FIX: On some systems, atalkd refuses to start, since it couldn't detect
907        any interfaces. This was caused by an overzealous validity check.
908
909 Changes in 1.5rc2
910 =================
911
912 * FIX: contrib/shell_utils/lp2pap.sh was erased when "make clean" was called.
913        Now we distribute lp2pap.sh.tmpl instead, and lp2pap.sh is automatically
914        generated during package build.
915 * FIX: Some platforms (notably Tru64) don't have the snprintf() call, which
916        was used in etc/afp/afp_config.c. This call was replaced by sprintf()
917        and prior bounds checking.
918
919 Changes from the 1.4b1 release:
920 ===============================
921
922 *   Fixed the maximum free/total volume size in afpd.
923
924 *   Made ~ the default volume in afpd.
925
926 *   Fixed pid file handling and changed setpgrp() to setpgid() in afpd,
927     papd, and atalkd.
928
929 *   Added code to afpd to set the Unix file time stamps with utime().
930
931 *   Fixed a bug in papd's printcap code which limited it to 15 or so
932     printers.
933
934 *   Fixed papd's handling of piped printers.
935
936 *   Fixed papd's handling of bad job names.
937
938 *   Fixed atalkd to send NBP LKUP packets from NBP port.
939
940 *   Added "sync;sync;sync" to Solaris kinstall to help with streams
941     file corruption.
942
943 *   Added nlocalrts to streams ddp.conf.  Thanks Thomas Tornblom.
944
945 *   Fixed signed extension infinite loop in Solaris module.
946
947 *   Moved all the config files to .../config.
948
949 Changes from the 1.3.3 release:
950 ===============================
951
952 *   Added code from Sun Microsystems, Inc (OPCOM) for Solaris support.
953     See COPYRIGHT.
954
955 *   Added support for FreeBSD, mostly changes by Mark Dawson and Julian
956     Elischer.
957
958 *   All sorts of other stuff.
959
960 Changes from the 1.3.1 release:
961 ===============================
962
963 *   Added options to psf's filter names to support accounting on HPs.
964     !!! NOTE:  The location of the filters has changed, see the man
965     page for where.
966
967 *   Added code from Alan Cox to support Linux.
968
969 *   Rewrote papd.  Now handles dropped connections better.
970     Configuration has been modernized.  !!! NOTE: The format of the
971     configuration file has changed, but NOT THE NAME.
972
973 *   Added Kerberos support to papd.
974
975 *   atalkd now removes routes on a SIGTERM.  Still can't just restart
976     it, but it's closer.
977
978 *   Changed atalkd and the kernel driver to remove a hack added to
979     support sending to 0.255.  Now the kernel will allow multiple open
980     sockets with the same port, so long as the addess associated with
981     the port is different.  atalkd now opens a socket for each port on
982     each interface.
983
984 *   atalkd now rewrites its configuration file.  If no configuration
985     file is given, one will be generated.  Permissions on the new
986     configuration file will be inherited from the old one.  If there is
987     no old one, permissions default to 644.  Won't rewrite the file if
988     the owner doesn't have write permission.
989
990 *   Removed support for the "AFS Kerberos UAM", in favor of the
991     "AuthMan UAM".  Kerberos support should now be much more
992     straight-forward.
993
994 *   Fixed a bug in afpd which would cause incorrect group calculations
995     on ultrix machines.
996
997 *   Fixed a bug in afpd which causes SimpleText and some other
998     applications to silently fail to write.  There's also a bug in
999     MacOS, but we can't fix that.
1000
1001 *   Fixed a bad interaction with afpd and AFS which would cause file
1002     writes to not propogate between AFS clients.
1003
1004 *   !!! CHANGED the name(s) of afpd's config files.  The new files are
1005     AppleVolumes.system and AppleVolumes.default.  If AppleVolumes.system
1006     exists, it is always read, AppleVolumes.default is only read if the
1007     user has no AppleVolumes file.  Included a flag "-u" to indicate
1008     which file has precedence.  "-u" user wins, otherwise ".system"
1009     wins.
1010
1011 *   Rewrote the AppleVolumes parsing code.  Now works.
1012
1013 *   Added a filename extension mapping to afpd.  User always takes
1014     precedence, regardless of the "-u" flag.  Code to change the type
1015     of all Unix files contributed by Kee Hinckley <nazgul@utopia.com>.
1016
1017 *   afpd now supports both UFS and AFS volumes simultaneously.  It also
1018     uses access() to attempt to calculate reasonable Mac permissions
1019     for AFS directories.
1020
1021 *   Changed reporting of file times.  Files that are written from Unix
1022     now update the Mac's idea of the files modification time.  Unix
1023     mtime is now reported instead of ctime.
1024
1025 *   Added support for a new UAM to afpd.  This requires that client
1026     Macs have MacTCP and AuthMan installed.  Should make running afpd
1027     for AFS easier.
1028
1029 *   Removed code so that otherwise valid volumes for which the mounting
1030     user has no permission will appear in the volume selection dialog
1031     on the Mac gray-ed out.
1032
1033 *   Added code from Chris Metcalf of MIT to the AppleDouble library
1034     which improves permission inheritance.
1035
1036 *   Added code from G. Paul Ziemba of Alantec, Inc to better report
1037     errors in psf.  Also changed psf to use syslog for errors that
1038     users aren't interested in.
1039
1040 *   Added information to psf's man page to better explain the
1041     interaction between psf, pap, and lpd.
1042
1043 *   Make psf/pap/psa do accounting when it's turnes on in
1044     /etc/printcap.
1045
1046 *   Changed pap's error message when there is no printer specified on
1047     the command line and no .paprc is found.  Also heavily modified
1048     pap's man page to reflect changes in the "new" version of pap,
1049     including moving it from section 8 to section 1.
1050
1051 *   Fixed a byte-order bug in pap's sequence numbers.  Doubt if pap has
1052     ever worked right on little endian machines!
1053
1054 *   Added a flag to pap to optionally close before receiving EOF from
1055     the printer.  Off by default.  psf calls pap with this option on.
1056
1057 *   Added timeouts to the nbp library calls.  This means that processes
1058     won't hang when atalkd dies during boot, thus hanging your
1059     machine.
1060
1061 Changes from the 1.3 release:
1062 =============================
1063
1064 *   Fixed a bug in afpd which would cause APPL mappings to contain both
1065     mac and unix path names.  The fixed code will handle the old
1066     (corrupted) database.
1067
1068 *   Fixed a *very* serious bug which would cause files to be corrupted
1069     when copying to afpd.
1070
1071 *   Fixed a bug in afpd which would cause replies to icon writes to
1072     contain the written icon.
1073
1074 *   Filled in the function code switch in afpd.  Previously, a hacker
1075     could probably have used afpd to get unauthorized access to a
1076     machine running afpd.
1077
1078 *   Fixed a bug in the asp portion of libatalk.a which could cause the
1079     malloc()/free() database to be corrupted.
1080
1081 *   Fixed a bug in atalkd's zip query code.  With this bug, only the
1082     first N % 255 nets get queried.  However, since nets bigger than
1083     255 are usually pretty unstable, the unqueried for nets will
1084     eventually get done, when N drops by one.
1085
1086 *   Suppressed a spurious error ("route: No such process") in atalkd.
1087
1088 Changes from the 1.2.1 release:
1089 ===============================
1090
1091 *   atalkd is completely rewritten for phase 2 support.  atalkd.conf
1092     from previous version will not work!
1093
1094 *   afpd now has better AFS support.  In particular, the configuration
1095     for AFS was made much easier; a number of Kerberos-related
1096     byte-ordering and time problems were found; clear-text passwords
1097     were added (thanks to geeb@umich.edu).
1098
1099 *   afpd now handles Unix permissions much better (thanks to
1100     metcalf@mit.edu).
1101
1102 *   There are many, many more changes, but most are small bug fixes.
1103
1104 Changes from the 1.2 release:
1105 =============================
1106
1107 *   The Sun support now uses loadable kernel modules (a la VDDRV)
1108     instead of binary patches. As such, it should work on any sunos
1109     greater than 4.1, and is confirmed to work under 4.1.1 and 4.1.2.
1110
1111 *   The DEC support no longer requires source. It also runs under
1112     ultrix 4.1 and 4.2. It still requires patching your kernel, but the
1113     patches are limited to those files available to binary-only sites
1114     -- primarily hooks for things like netatalk.
1115
1116 *   The etc.rc script now uses changes made to nbprgstr (see below).
1117
1118 *   aecho now takes machine names on the command line.
1119
1120 *   nbplkup now takes a command line argument specifying the number of
1121     responses to accept. It also takes its defaults from the NBPLKUP
1122     environment variable.
1123
1124 *   nbprgstr may be used to register a name at any requested port.
1125
1126 *   afpd now logs if an illegal shell is used during login, instead of
1127     silently denying service.
1128
1129 *   A bug in afpd which caused position information for the directory
1130     children of the root of a volume to be ignored has been fixed.
1131
1132 *   Several typos in afpd which would cause include files necessary to
1133     ultrix to be skipped have been fixed.
1134
1135 *   atalkd will no long propagate routes to networks whose zone
1136     it doesn't know.
1137
1138 *   atalkd no longer dumps core if it receives a ZIP GetMyZone request
1139     from a network whose zone it doesn't know. (Since this currently
1140     can only happen from off net, it's not precisely a legal request.)
1141
1142 *   pap and papd (optionally) no longer check the connection id in PAP
1143     DATA responses. Both also maintain the function code in non-first-packet
1144     PAP DATA responses.  These changes are work-arounds to deal with
1145     certain AppleTalk printer cards, notably the BridgePort LocalTalk
1146     card for HP LJIIISIs.
1147
1148 *   pap no longer sends an EOF response to each PAP SENDDATA request,
1149     only the first.
1150
1151 *   A bug in papd which would cause it to return a random value when
1152     printing the procset to a piped printer has been fixed.
1153
1154 *   A bug relating to NBP on reverse-endian machines has been fixed.
1155
1156 *   atp_rsel() from libatalk now returns a correct value even if it
1157     hasn't recieved anything yet.
1158
1159 *   atalk_addr() from libatalk no longer accepts addresses in octal
1160     format, since AppleTalk addresses can have leading zeros. Also it
1161     checks that the separator character is a '.'.
1162
1163 *   Pseudo man pages for nbplkup, nbprgstr, and nbpunrgstr, have been
1164     added.
1165
1166 *   The example in the psf(8) man page is now correct.
1167
1168 *   The man pages for changed commands have been updated.
1169
1170 *   The README files for various machine have been updated
1171     appropriately.