* Semi-broken vCard replacement implementation in place.
[citadel.git] / citadel / ChangeLog
1 $Log$
2 Revision 1.380  1999/10/07 02:58:46  ajc
3 * Semi-broken vCard replacement implementation in place.
4 * Added "Z" (Zap, supersede) field to message format
5
6 Revision 1.377  1999/10/04 03:19:52  ajc
7 * We now have a housekeeping thread and a housekeeping queue.
8
9 Revision 1.376  1999/10/03 21:48:21  ajc
10 * Added serv_upgrade.h to automagically convert pre-5.55 format user records
11   to 5.55 format user records and generate vCards.
12
13 Revision 1.375  1999/09/29 21:13:17  ajc
14 * CtdlWriteObject() can now store objects in personal rooms for any specified
15   user -- rather than only the current user or non-personal rooms.
16
17 Revision 1.374  1999/09/29 17:26:56  ajc
18 * serv_vcard.c: fixed crashola bug in cmd_greg()
19 * tools.c: simplified and improved the string tokenizer.  Now it runs in a
20            single pass with no intermediate buffer.
21
22 Revision 1.373  1999/09/28 03:27:37  ajc
23 * Fully migrated cmd_greg() and cmd_regi() into serv_vcard (still has bugs)
24
25 Revision 1.372  1999/09/27 03:33:40  ajc
26 * cmd_regi() is now in serv_vcard and writes to the vcard instead of to the
27   usersupp file.  Still needs tweaking.
28
29 Revision 1.371  1999/09/24 03:32:19  ajc
30 * "read my vCard" and "write my vCard" are written and tested.
31
32 Revision 1.370  1999/09/24 02:54:17  ajc
33 * Worked a little more on the vCard stuff.  The serv_vcard module is now in
34   place, and a "read my vcard" function is there; "write my" is next...
35
36 Revision 1.369  1999/09/23 03:07:56  ajc
37 * The vCard 'class' is now linked into the server, though it's not really
38   functional yet.  Its constructors/destructors are debugged, though.
39
40 Revision 1.368  1999/09/19 21:28:33  ajc
41 * Finished off the message architecture stuff with a new class of hooks to
42   enable future server-side handlers.
43
44 Revision 1.367  1999/09/19 15:57:06  ajc
45 * migrated cmd_ent3() to CtdlSaveMessage()
46
47 Revision 1.366  1999/09/19 05:13:57  ajc
48 * Debugged the new version of CtdlWriteObject()
49
50 Revision 1.365  1999/09/16 03:23:23  ajc
51 * Did most of the migration from save_message() to CtdlSaveMsg().  The
52   latter builds a "struct CtdlMessage" (so we can run server-side handlers
53   against it later on), then serializes it and stores to disk.
54 * BROKEN BUILD ALERT!!  cmd_ent3() and CtdlWriteObject() are still not
55   migrated.  They are stubbed out and will MALFUNCTION if used right now!!
56
57 Revision 1.364  1999/09/07 01:42:42  ajc
58 * cmd_msg3() now uses serialize_message() for its output.  All message
59   commands will eventually exist as a "struct CtdlMessage" at some point
60   so that we can install server-side handler hooks.
61
62 Revision 1.363  1999/09/07 00:04:13  ajc
63 * netproc.c: put outgoing messages into the use table, too -- this prevents
64   locally originated messages from showing up again if a remote system is
65   misconfigured and spools them back to us.
66
67 Revision 1.362  1999/09/06 03:39:15  ajc
68 * citadel.c: run strproc() on new passwords
69
70 Revision 1.361  1999/09/03 17:50:26  playcow
71 For URL view, don't prompt user to select url if there is only one.  Display
72 <U>RL View prompt if message contains url(s). -Ben
73
74 Revision 1.360  1999/09/02 02:09:59  ajc
75 * msgbase.c: new function serialize_message() for future use
76
77 Revision 1.359  1999/09/01 21:09:25  ajc
78 * database.c: display the GDBM version string on startup
79
80 Revision 1.358  1999/09/01 02:36:34  ajc
81 * Actually _enforce_ the max msg len limit
82
83 Revision 1.357  1999/09/01 01:51:48  ajc
84 * Added the ability to handle embedded URL's from the text client
85
86 Revision 1.356  1999/09/01 01:02:47  ajc
87 * Implemented "maximum message length" in global system config
88
89 Revision 1.355  1999/08/31 00:57:17  ajc
90 * Handle multipart/alternative properly during legacy message outputs.
91   Basically it just prints the first alternative and skips the rest.
92
93 Revision 1.354  1999/08/29 21:12:24  ajc
94 * Made some changes to the output of MIME (especially multipart) messages.
95
96 Revision 1.353  1999/08/29 19:56:43  ajc
97 * HTML updates
98
99 Revision 1.352  1999/08/24 02:01:03  ajc
100 * html.c: added.  This is an overly simplistic HTML-to-text converter.
101
102 Revision 1.351  1999/08/21 18:37:29  ajc
103 * Minor cosmetic cleanup.  No code changes.
104
105 Revision 1.350  1999/08/21 05:15:34  ajc
106 * mailinglist.c, netmailer.c: fixed to allow list submissions from all posters
107   on a Citadel network rather than only on the local system.
108
109 Revision 1.349  1999/08/08 00:25:45  ajc
110 * Made one more byte available in locate_host() and in all the structs which
111   its output gets written to (client can display 24 positions but we were only
112   saving 23).
113
114 Revision 1.348  1999/08/07 16:34:38  nbryant
115 * serv_icq.c: warning fixes
116
117 Revision 1.347  1999/08/06 02:57:26  ajc
118 * locate_host.c: use strdoop() and phree() instead of strdup() and free()
119 * serv_icq.c: run learned IP's through Citadel's locate_host() & put in Wholist
120
121 Revision 1.346  1999/08/05 17:58:59  ajc
122 * RWHO command now returns express message code in postion 3
123
124 Revision 1.345  1999/08/04 02:21:45  ajc
125 * Fixed some bugs in the ICQ metaclient, and documented the new protocol cmds
126
127 Revision 1.344  1999/08/03 11:34:35  ajc
128 * Added client_icq.c and client_icq.h
129
130 Revision 1.343  1999/08/03 03:14:51  ajc
131 * Wrote the client side of the ICQ gateway.  Now on to other projects.  :)
132
133 Revision 1.342  1999/08/03 01:52:06  ajc
134 * Redesigned the client protocol commands for dealing with ICQ
135 * Implemented page function priority ordering to prevent pages from being
136   simultaneously delivered over multiple IM systems
137 * Migrated serv_icq.* into the Makefile
138
139 Revision 1.341  1999/08/01 21:36:30  ajc
140 * EXTREME coolness.  The server side of the ICQ metaclient is now working.
141   It is set up using ICQL and ICQA commands, it automatically logs the user
142   onto ICQ along with Citadel, and displays all non-offline ICQ contacts
143   in the Wholist.
144
145 Revision 1.340  1999/07/31 07:18:01  ajc
146 * Restructured the express message infrastructure, adding a class of function
147   hooks for the addition of multiple paging modules with message routing
148
149 Revision 1.339  1999/07/30 22:20:19  ajc
150 * Applied bugfix patches contributed by Vaggelis Tsirkas:
151   * rooms.c: buffer overrun fix
152   * room_ops.c: cmd_rdir() now behaves better when directory doesn't exist
153
154 Revision 1.338  1999/07/30 03:32:24  ajc
155 * Added strdoop(), a leak-checked version of strdup()
156 * Small fixes to new API functions in msgbase.c
157 * ICQ metaclient stores/reads config using the message base API functions
158
159 Revision 1.337  1999/07/29 03:36:37  ajc
160 * msgbase.c: reorganized.  output_message() now uses CtdlFetchMessage(),
161   cmd_msg3() now fetches directly from disk and spews to the client.
162
163 Revision 1.336  1999/07/28 04:02:37  ajc
164 * Server modules are now labelled with their RCS ID instead of a complex and
165   manually-updated data structure.
166
167 Revision 1.335  1999/07/28 03:50:24  ajc
168 * serv_expire.c: expire-by-age now calls CtdlFetchMessage() instead of
169   calling output_message() in MT_DATE mode.
170 * msgbase.c: removed MT_DATE mode ('twas a sleazy hack)
171
172 Revision 1.334  1999/07/27 22:47:26  ajc
173 * Implemented new data type "CtdlMessage" which will eventually be used as
174   widely as possible to represent a message in memory.
175 * Implemented CtdlFetchMessage() which is intended to become the back-end to
176   output_message() as well as a bunch of other things.
177
178 Revision 1.333  1999/07/27 20:00:24  ajc
179 Removed all references to CC->msglist and CC->num_msgs, and all utility
180 functions which relied upon them.  Citadel Is Now Better.
181
182 Revision 1.332  1999/07/27 19:32:22  ajc
183 Removed serv_upgrade.c and all references to it in Makefile.in
184 Reworked new-mail-count to not use MessageFromList() etc.
185
186 Revision 1.331  1999/07/25 02:59:37  ajc
187 Fixed reference count problem in cmd_move()
188
189 Revision 1.330  1999/07/24 22:50:38  ajc
190 Continued replacing references to [get|put]_msglist() with better code.
191 For some reason, cmd_msgs() still doesn't always work right.
192
193 Revision 1.329  1999/07/24 22:16:41  ajc
194 Experimenting with automatic updating of ChangeLog by CVS.  Simply twiddle
195 ChangeLog a bit (i.e. by adding or removing a newline from the end of the
196 file) before issusing "cvs commit", and the comments recorded by CVS will
197 automatically appear at the beginning of ChangeLog.
198
199 Revision 1.328  1999/07/24 22:14:21  ajc
200 cmd_move() now uses CtdlDeleteMessages().
201 WARNING: build is temporarily broken.  Currently removing all references
202 to the "msglist" kept in CitContext.  It's ugly and must die.
203
204 Thu Jul 22 22:26:50 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
205         * Moved message deletion into new API function CtdlDeleteMessages()
206         * Added CtdlWriteObject() to store generic data in the msgbase
207         * Fixed really dumb error that prevented network msgs from posting
208
209 Tue Jul 20 22:14:54 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
210         * Moved the actual work done in cmd_msgs() into a new API function
211           called CtdlForEachMessage() which is supplied a callback function.
212
213 Mon Jul 19 23:24:18 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
214         * Keep the (unqualified) content-type in the SuppMsgInfo record.  We'll
215           be using this shortly to search rooms for specific object types.
216
217 Sun Jul 18 14:53:16 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us> 
218         * Changes to dynloader et al to handle ICQ module being written
219         * serv_icq.c, serv_icq.mk: added (separate makefile is temporary)
220
221 1999-07-17 Nathan Bryant <bryant@cs.usm.maine.edu>
222         * chkpwd.c: DELETED CVS REVISION 1.3 (backed out Art's last change)
223           use 'cvs update -r 1.2 chkpwd.c; cvs update -A chkpwd.c' NOW to
224           avoid problems with working directories.
225         * Makefile.in: don't install chkpwd setuid if make install isn't
226           being run as root.
227         * citadel.spec: chmod u+s chkpwd during %install stage
228
229 Fri Jul 16 18:39:04 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
230         * PEXP and GEXP no longer trip the idle time display
231         * Fixed bug which duplicated incoming private mail to Trashcan
232         * Improved auto-reconnect by NOT using SIGPIPE and longjmp(); also
233           implemented a 15 second delay to wait for a crashed server to restart
234         * Relaxed the security check in chkpwd.c a bit; it was just flat-out
235           preventing logins on my system otherwise
236
237 Thu Jul 15 22:57:32 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
238         * eliminate redundant "name" parameter in [l]putuser(), now uses
239           usbuf->fullname to guarantee the correct name for the index
240
241 1999-07-12 Nathan Bryant <bryant@cs.usm.maine.edu>
242         * Makefile.in, configure.in: link netproc with gdbm
243         * netproc.c: only include gdbm.h if HAVE_GDBM_H
244         * user_ops.c: warning fix
245
246 Mon Jul 12 19:51:30 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
247         * Mail is now saved in both sender and recipient mailboxes.  This is
248           structured in a way that will allow a separate "outbox" room and/or
249           multiple recipients in the future.
250
251 Sun Jul 11 18:46:48 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
252         * netproc.c: msgfind() no longer uses the timestamp as a message-ID
253           when no other message-ID is available (it screws up the loopzapper)
254         * room_ops.c: eliminate room name parameter in putroom() and its ilk;
255           get data from quickroom.QRname instead; prevents incorrect indexes
256         * Tentative implementation of "personal rooms" (user-private namespace)
257         * Added supplementary message info records for info that may change
258           at some time later than when the message is saved (i.e. ref counts)
259         * Implemented msg reference count increment/decrement; delete messages
260           whose reference count reaches zero
261
262 Wed Jul  7 23:25:09 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
263         * control.c: create citadel.control if it doesn't exist (yikes!)
264         * serv_expire.c: purge mailbox rooms belonging to non-existent users
265         * user_ops.c: don't delete user's mailbox at user-delete time
266
267 Mon Jul  5 17:01:29 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
268         * utilsmenu: removed menu items for defunct utilities
269
270 Mon Jun 28 16:24:10 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
271         * Changed any remaining references to UUCP, to "Internet" instead.
272
273 Thu Jun 24 11:13:23 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
274         * added server command line option "-f" to defrag databases on startup
275         * control.c: better performance and reliability in [get|put]_control()
276         * netproc.c: Finished the loopzapper
277
278 Mon Jun 21 00:04:15 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
279         * netproc.c: started writing a vortex checker.  Not finished.
280
281 Wed Jun  9 23:34:25 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
282         * Replaced all code that generated temporary filenames with calls to
283           tmpnam().  Rewrote using tmpfile() where possible.
284
285 Thu Jun  3 11:35:18 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
286         * base64.c: mapped fi and fo to stdin and stdout using
287           actual code rather than assignment at declaration time
288           (several users of Red Hat Linux 6.0 reported problems)
289
290 Fri May 21 20:05:00 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
291         * Added function CtdlGetDynamicSymbol() for dynamic symbol allocation
292         * server.h: Changed discrete #define's to enum's where appropriate
293         * sysdep.c: Changed the startup message to give credit to the whole
294           development team :)  Also made the message more GNU-ish.
295
296 Thu May 20 20:01:30 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
297         * database.c: print log messages for file defragmentations
298         * citserver.c: implemented CtdlAllocUserData() and CtdlGetUserData()
299           for arbitrary per-session data storage (by modules etc.) without
300           having to add fields to struct CitContext
301         * msgbase.c: removed "desired_section" from struct CitContext and
302           implemented it using CtdlGetUserData() as a test.
303
304 Wed May 19 19:30:28 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
305         * commands.c, commands.h, routines.c: began color scheme changes
306
307 1999-05-15 Nathan Bryant <bryant@cs.usm.maine.edu>
308         * configure.in: Added untested support for BSDI 4.x.
309
310 1999-05-13 Nathan Bryant <bryant@cs.usm.maine.edu>
311         * acconfig.h, configure.in, routines.c: fix for certain SYSV variants
312           which lack utmp.ut_host
313         * citadel.h, file_ops.c, msgbase.c, netproc.c, serv_chat.c: fix
314           namespace collision with <sys/stream.h> on aforementioned SYSV
315           variant
316         * configure.in, getutline.c: check for paths.h
317         * configure.in, Makefile.in: check for -lsocket and -lnsl
318
319 1999-05-11 Nathan Bryant <bryant@cs.usm.maine.edu>
320         * chkpwd.c: fixed excessive paranoia; it used to refuse to run when
321           invoked by root and BBSUID != 0
322         * Makefile.in: ignore errors while installing /etc/pam.d/citadel
323
324 1999-04-27 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
325         * file_ops.c: fixed NDOP to not crash the server if it has trouble
326           with a download file
327         * netpoll.c: upped default packet size
328
329 Mon Apr 26 22:06:57 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
330         * Repaired IGnorant security hole blunder re. citmail
331
332 Sun Apr 25 12:44:08 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
333         * serv_chat.c: notify user of number of participants upon entering chat
334         * Built the 5.53 distribution
335
336 Wed Apr 21 22:23:13 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
337         * aidepost.c: add -r flag to allow posting to rooms other than Aide>
338         * serv_expire.c: now posts transcripts of all auto-purged rooms/users
339
340 Tue Apr 20 12:45:55 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
341         * messages.c: downloading more than MAX_MSGS messages now truncates
342           (off the beginning of the list) rather than crashing.
343
344 Mon Apr 19 12:11:48 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
345         * whobbs.c: auto-detect when being called from a webserver, and act
346           as a CGI (print HTTP headers and HTML output)
347
348 1999-04-18 Nathan Bryant <bryant@cs.usm.maine.edu>
349         * serv_chat.c: fixed some potential buffer overruns (thanks dme)
350
351 Wed Apr 14 21:32:28 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
352         * Makefile.in: chmod 4755 citmail to prevent citmail from aborting
353           when called from sendmail due to citadel.config security check
354
355 1999-04-13 Nathan Bryant <bryant@cs.usm.maine.edu>
356         * dynloader.c: OpenBSD places underscores in front of symbol names
357         * Makefile.in: fixed a few sillies
358         * aidepost.c, citmail.c, file_ops.c, logging.c, msgbase.c, netmailer.c,
359           netproc.c, rcit.c, routines.c, serv_upgrade.c: fixed time_t handling
360           (have to cast it to long for printf/scanf)
361
362 Mon Apr 12 22:13:26 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
363         * aidepost.c: rewrote to unlink temp file before writing to it so that
364           it will automatically go away if interrupted. Also ran indent -kr -i8
365
366 1999-04-12 Nathan Bryant <bryant@cs.usm.maine.edu>
367         * configure.in, Makefile.in: taught it how to generate OpenBSD shared
368           libraries
369         * config.c, sysdep.c: fix -h option not setting proper modules dir
370         * configure.in, citadel.spec: make --enable-chkpwd the default
371         * setup.c: don't chown chkpwd
372
373 1999-04-11 Nathan Bryant <bryant@cs.usm.maine.edu>
374         * configure.in: another OpenBSD fix, but we're still not quite there yet
375         * serv_chat.c: warning fix
376
377 Thu Apr  8 22:51:28 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
378         * config.c: now requires a setup run for *any* rev level difference
379         * Updated docs & confs for 5.53b1 release
380         * setup.c: sets the 0600 permission bits on citadel.config that
381           is checked for in config.c
382
383 1999-04-08 Nathan Bryant <bryant@cs.usm.maine.edu>
384         * citserver.c: improved is_public_client(), also if a public_client
385           only supplies a numeric address, attempt to resolve it
386         * locate_host.c: verify that the forward DNS matches the reverse
387         * locate_host.c, locate_host.h: more general interface
388         * configure.in, acconfig.h: fixes for Digital UNIX
389
390 Wed Apr  7 21:36:16 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
391         * Implemented "access level required to create rooms" (client & server)
392
393 1999-04-07 Nathan Bryant <bryant@cs.usm.maine.edu>
394         * configure.in: updated help messages, OpenBSD support
395         * setup.c: if /etc/inittab doesn't exist, don't ask to create an
396           entry in it
397         * server.h, sysdep.c: fix a potential deadlock/data corruption bug
398         * room_ops.c: fixed the 'gdbm error: Illegal data' message when
399           deleting a room which had never been posted to
400         * user_ops.c: include errno.h
401         * dynloader.c: fix for OpenBSD
402
403 1999-04-06 Nathan Bryant <bryant@cs.usm.maine.edu>
404         * Makefile.in, configure.in, getutline.c, sysdep.c:
405           fixes/bug workarounds for FreeBSD
406
407 1999-04-03 Nathan Bryant <bryant@cs.usm.maine.edu>
408         * Makefile.in, configure.in, chkpwd.c, acconfig.h: support for
409           `chkpwd', a setuid helper program for machines which use shadow
410           passwords (configure --enable-chkpwd)
411         * Makefile.in, configure.in, auth.c, citadel.pam, user_ops.c: support
412           for PAM or shadow passwords (configure --with-pam)
413         * Makefile.in: made some messages simpler
414         * citadel.spec: updated for 5.53; correct name of tarball; build with
415           --enable-chkpwd and --with-pam; add defattr tags so rpm's can be
416           built by non-root user
417         * commands.c: cosmetic cleanup
418         * config.c: (security/paranoia) check permissions on citadel.config
419         * configure.in: check for ncurses if we can't find curses
420         * dynloader.c: warning fix
421         * sysdep.c: don't complain if initgroups() fails
422         * citadel.c: fix systems with SYSV-style signal handling (e.g. libc5)
423         * Makefile.in: New! Improved! Cleaner! Shinier!
424
425 Sun Mar 21 14:21:47 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
426         * messages.c: cosmetic cleanups to message reading loop
427
428 Sat Mar 13 21:33:19 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
429         * commands.c: use bright colors by default in color mode
430         * citserver.c: initialize wholist fields with (not logged in) etc.
431
432 1999-03-08 Nathan Bryant <bryant@cs.usm.maine.edu>
433         * sysdep.c: call DLoader_Init() with an absolute path so that gdb can
434           find module symbols
435         * database.c: bail out if opening databases fails
436
437 Sat Mar  6 01:55:55 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
438         * serv_chat.c: use memfmout(), *not* cprintf() to transmit express
439           messages.  Calling cprintf() on strings >256 bytes crashes the server
440         * msgbase.c: minor logging fix in save_message()
441
442 1999-03-05 Nathan Bryant <bryant@cs.usm.maine.edu>
443         * sysdep.c: add undocumented -r flag to citserver to prevent it from
444           dropping root permissions.
445         * sysdep.c: also drop supplementary groups
446
447 1999-03-04 Nathan Bryant <bryant@cs.usm.maine.edu>
448         * config.c: error checking in put_config()
449         * setup.c: chgrp files to the login group associated with BBSUID
450         * sysdep.c: copyright 1987-1999; drop root perms; load modules and call
451           master_startup() after dropping perms
452
453 Wed Mar  3 00:00:55 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
454         * Prevent buffer overruns in lowercase_name in [get|put]user()
455         * client_chat.c: use citedit() for page composition
456
457 Sat Feb 27 07:47:36 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
458         * rooms.c: download_to_local_disk() prompts for a filename if a blank
459           filename was supplied to it (for attachments without names)
460         * mime_parser.c: strip leading whitespace in content_type & disposition
461
462 1999-02-24 Nathan Bryant <bryant@cs.usm.maine.edu>
463         * configure.in: improved check for pthreads
464         * configure.in, routines.c, acconfig.h: check for ut_type in struct utmp
465         * configure.in, Makefile.in: support for building server modules as
466           relocatable objects for BSDI (which still uses a.out *gag* *choke*)
467         * configure.in: compiler choice & flags for BSDI; check for libtermcap
468         * database.c: don't use a critical section in open_databases()
469         * housekeeping.c: use getfloor()/putfloor() instead of
470           lgetfloor()/lputfloor() in check_ref_counts()
471         * mime_parser.c: include <errno.h>
472         * msgbase.c: include <limits.h>
473         * sysdep.c: hacks for BSDI. use signals to fake thread cancellation;
474           don't call master_cleanup() directly from signal handler.
475         * routines.c: prototype getutline() if necessary
476         * getutline.c: stupid bugfix
477         * acconfig.h, configure.in, locate_host.c, server.h: work around
478           nonreentrant gethostbyaddr() on BSDI
479
480 Mon Feb 15 22:59:00 EST 1999 Vaggelis Tsirkas
481         * citadel.c: increased hostname buffer size to handle very big names
482
483 1999-02-15 Nathan Bryant <bryant@cs.usm.maine.edu>
484         * sysdep.c(main): initialize alen before call to accept()
485
486 1999-02-04 Nathan Bryant <bryant@cs.usm.maine.edu>
487         * configure.in: improved check for cygwin
488         * configure.in, routines.c: access utmp directly instead of calling
489           `who' if getutline() is available.
490         * configure.in, Makefile.in, getutline.c: replace getutline() on
491           systems which don't have it
492         * routines.c: now always access utmp directly unless we can't find
493           utmp.h
494
495 1999-02-02 Nathan Bryant <bryant@cs.usm.maine.edu>
496         * Fixes for Cygwin:
497           - ifdef out file download methods that require named pipes (client)
498           - include pthread.h and gdbm.h only if they are present (fixes
499             auto dependency generation)
500           - include snprintf.h where needed
501           - handle .exe suffixes for "make install"
502
503 Tue Feb  2 22:15:08 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
504         * Overhauled the express messaging system (again)
505
506 Mon Feb  1 19:48:04 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
507         * messages.c: implemented client download of MIME attachments
508
509 Sun Jan 31 18:29:18 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
510         * Added qpdecode.c to the distribution (decodes quoted-printable)
511         * Finished the MIME parser
512         * Gave MSG0 a reasonable behaviour for MIME messages
513         * Added the OPNA command for downloading attachments
514
515 Sat Jan 30 18:39:53 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
516         * Look for citadel.rc in current directory if not found elsewhere
517         * More work on the MIME parser
518         * Added base64.c to the distribution
519
520 1999-01-29 Nathan Bryant <bryant@cs.usm.maine.edu>
521         * fixes for IRIX (thanks to wr and family for use of the Indy):
522           - use memset()/memcpy() instead of bzero()/bcopy() in all cases
523           - configure updates
524           - handle `long' pid's
525           - a few other little bits
526
527 Mon Jan 25 21:23:07 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
528         * Fixed bug in save_message() which crashed the server on mail to sysop
529         * Rewrote pop_march() to be smarter about <G>oto heuristics
530
531 Sat Jan 23 14:32:19 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
532         * Changed internal storage of express messages from a linked list to
533           a single, resizable buffer.
534         * Added a "room order" key to the room record, to allow some control
535           over room listing order.
536         * Made the room list commands aware of the room order key.
537         * Overhauled <G>oto heuristics to pay attention to floor & room order
538
539 Wed Jan 20 19:21:51 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
540         * Added some more code to the unfinished MIME parser
541         * Changed module loading path to simply "modules" because after calling
542           get_config(), the cwd is guaranteed to be the correct BBS directory.
543
544 Tue Jan 19 21:28:29 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
545         * Fixed a bug in the user editing command (client side)
546         * Started a rewrite of the MIME parser
547
548 Thu Jan 14 21:21:15 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
549         * Brought over the mime_parser from WebCit and began preliminary work
550           on supporting MIME format messages.
551
552 Tue Jan 12 22:30:00 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
553         * Various changes to begin work on support for MIME messages
554                 - Defined format type 4 for MIME
555                 - msgbase.c: *temporary* hacks in output_message() for Type 4
556                 - citmail.c: added more robust header parsing, and support
557                              for Type 4.  Also eliminated the crappy built-in
558                              SMTP server.
559                 - Updated some of the technical documentation
560
561 Sun Jan 10 13:34:36 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
562         * Fixed access to page log room
563
564 Fri Jan  8 12:35:09 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
565         * control.c: include <limits.h> to fix PATH_MAX undefined
566         * serv_chat.c: made the following changes to cmd_sexp() --
567                 * Send zero-length message to check only, don't send
568                 * Send "-" message on the command line to invoke
569                   the SEND_LISTING transfer mode for a multi-line message
570         * Added facilities to log all pages to a room (site configurable)
571
572 Tue Jan  5 23:24:52 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
573         * Replaced all occurances of malloc(), realloc(), and free() in the
574           server and server-modules with mallok(), reallok(), and phree().
575           Wrote macros and a set of leak-tracking functions.
576
577 Sun Jan  3 20:38:45 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
578         * Documentation changes
579
580 Fri Jan  1 01:01:45 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
581         * Fixed security problem relating to private rooms
582
583 Wed Dec 30 20:10:52 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
584         * sysdep.c: put a bigger string buffer into lprintf() to avoid overruns
585
586 Sat Dec 26 16:56:46 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
587         * internetmail.config: commented this file more clearly
588
589 Wed Dec 23 20:42:49 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
590         * citadel.c: added some experimental code to automatically reconnect
591           to the server if the connection is broken.  For some reason, it only
592           works once.
593
594 Wed Dec 23 18:47:12 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
595         * sysdep.c: ignore SIGPIPE.  This keeps broken connections from
596           crashing the whole server.
597         * Tagged everything for the official 5.50 release.
598
599 Mon Dec 21 07:54:20 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
600         * housekeeping.c: call kill_session() with session_to_kill,
601           not ccptr->cs_pid (was crashing the server)
602
603 Sat Dec 19 13:57:48 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
604         * Added "-i" flag to netproc to make it skip the export phase.
605           Updated other programs to call netproc in this way when appropriate.
606         * Updated network.txt to reflect the usage for netproc (which has
607           been wrong for several releases)
608
609 Thu Dec 17 00:17:04 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
610         * Started removing the word "beta" from the docs and code.
611           Preparing for an actual release.
612         * msgbase.c: generate an 'I' field when requested (i.e. on locally
613           originating messages.  this was breaking parts of the network)
614
615 1998-12-15 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
616         * msgbase.c: remove extra call to alias() which was causing
617           Citadel-to-Citadel mail to fall into the bit bucket.
618         * msgbase.c: fixed tempfile naming problem that could cause a new
619           outgoing netmail message to overwrite another if netproc had not been
620           run in between
621
622 1998-12-14 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
623         * More session table stability nonsense
624
625 Sun Dec 13 17:40:08 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
626         * sysdep.c, citserver.c: (hopefully) fixed a session table concurrency
627           bug which was causing the server to occasionally crash.
628         * removed serv_test.so from the default build
629
630 Fri Dec 11 18:50:00 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
631         * setup.c: default value for maxsessions is now 0 (no limit)
632         * room_ops.c: don't allow users to create a room called "Mail"
633         * serv_expire.c: fixed "number of messages purged" display
634         * commands.c: when using color, default to low-intensity colors
635
636 Tue Dec  8 07:58:16 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
637         * Beta 2
638
639 Sat Dec  5 01:24:03 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
640         * Added a new type of module hook for adding logging functions
641         * Removed whitespace to left and right of '@' in netmail recipients
642         * sysdep.c: read citadel.config _before_ initializing loadable modules
643         * stats.c: fixed segfault resulting from extracting log lines
644         * Ripped most of the "attachments" stuff out of both the client and
645           server.  (Thought of a better way to handle it ... LATER.)
646
647 1998-12-03 Nathan Bryant <bryant@cs.usm.maine.edu>
648         * setup.c: create citadel.config with mode 0600
649         * Makefile.in: don't chmod sendcommand
650         * serv_upgrade.c: don't create citadel.config if it doesn't already
651           exist (paranoia)
652         * setup.c: saner defaults for nodename and fqdn
653
654 Wed Dec  2 20:37:05 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
655         * msgbase.c: modified AddMessageToRoom() and all functions that call it
656           to use a more reliable/accurate method to set quickroom.QRhighest
657         * weekly.in: don't sort/purge filedir where filedir doesn't exist
658
659 1998-12-02 Nathan Bryant <bryant@cs.usm.maine.edu>
660         * weekly is now generated by configure
661
662 Mon Nov 30 19:48:52 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
663         * room_ops.c: added sort_msglist() to move and save operations
664         * sendcommand.c: added (also updated utils.txt, weekly, Makefile.in)
665         * BETA 1
666
667 Sun Nov 29 23:57:39 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
668         * Fixed cmd_regi() to not display a second result code after xfer
669         * Makefile.in: Removed "chmod 4755 citmail netmailer"
670
671 1998-11-23 Nathan Bryant <bryant@cs.usm.maine.edu>
672         * citadel.spec: added
673
674 1998-11-22 Nathan Bryant <bryant@cs.usm.maine.edu>
675         * Makefile.in: split install target into install-exec, install-data,
676           and install-doc subtargets
677
678 Sat Nov 21 16:53:30 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
679         * Added a fourth color mode in the client: "user" which turns color
680           on or off according to a per-user flag stored on the server.  Added
681           server-side support for this too, of course.
682         * import.c: removed
683         * serv_expire.c: finished the code to purge stale visits
684         * sysdep.c: strip trailing nonprintables in client_gets()
685         * routines2.c: fixed <.AS> command; all configs now work properly
686         * Moved num_parms() and all the extract() type functions into tools.c
687           and removed them from all other files.  Linked in tools.[o|ro] there.
688         * netproc.c: handled incoming file transfers to correct room directory
689         * room_ops.c: fixed incorrect naming of files in info and images dirs
690
691 Fri Nov 20 20:29:07 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
692         * setup.c: removed all prompts that can be configured from within the
693           client in order to simplify the setup procedure
694
695 Thu Nov 19 23:28:33 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
696         * Fixed serv_upgrade.c and export5.c (found elsewhere) to use a new
697           export format which treats visits as a separate section
698         * serv_expire.c: began writing functions to purge rooms and visits
699           (neither work yet), and added a way to call defrag_databases()
700
701 Wed Nov 18 23:51:17 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
702         * Reimplemented 'visit' structs stored globally instead of as
703           lists-per-user
704
705 Tue Nov 17 22:37:48 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
706         * Started implementing global room numbers.
707
708 Sun Nov 15 20:32:34 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
709         * room_ops.c: mailbox rooms always appear on the main floor
710         * made QR_MAILBOX rooms non-editable
711         * cmd_setr() delete old room record when room name changes
712           (This causes a big mess that exposes a flaw in the whole design.)
713         * room_ops.c: users can delete messages from their mailboxes
714
715 Thu Nov 12 23:59:13 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
716         * Rewrote cmd_rchg() and also increased the size of the "fakename"
717           buffer.  Overruns are probably what was causing the crashes.
718         * Changed the way cmd_ent3() handles mail messages; the previous code
719           rerouted all private mail to the trash.
720
721 Wed Nov 11 17:57:39 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
722         * citserver.c: slight changes to cmd_rchg() and cmd_hchg() [crashes]
723         * citserver.c, msgbase.c, user_ops.c: hide the owner-prefix of mail
724           rooms in a couple more places: set_wtmpsupp() and make_message()
725         * sysdep.c: added an fflush() to lprintf() for "tail -f"-able logs
726         * serv_expire.c: purge ops are now a command instead of a cleanup
727           function.  This is probably temporary as well.
728         * citadel.c: fixed the way <.WL> parses the returned data from a
729           TIME command.
730
731 1998-11-11 Nathan Bryant <bryant@cs.usm.maine.edu>
732         * serv_upgrade.c: fix uninitialized variable
733
734 Wed Nov 11 00:47:32 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
735         * msgbase.c: fixed a bug that was misrouting incoming network msgs
736         * server.h, database.c: wrapped all GDBM calls in critical sections
737           to avoid making those calls re-entrantly (gdbm fatal: lseek error)
738
739 1998-11-10 Nathan Bryant <bryant@cs.usm.maine.edu>
740         * Makefile.in: link in snprintf.o where needed
741
742 1998-11-09 Nathan Bryant <bryant@cs.usm.maine.edu>
743         * client_chat.c: eliminate calls to sprintf()
744         * commands.h, routines.c, routines2.c: warning fix
745         * commands.c, control.c, cux2ascii.c, file_ops.c, import.c,
746           ipc_c_tcp.c: eliminate sprintf() calls
747
748 Mon Nov  9 19:15:31 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
749         * serv_upgrade.c: added all missing fields to export/import
750         * serv_expire.c: support per-user purge time when purging users
751         * user_ops.c: added per-user purge time to AGUP and ASUP commands
752         * routines.c: added more stuff to <.A>ide <E>dit user
753
754 Sun Nov  8 22:56:53 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
755         * serv_expire.c: created; moved message expiry from serv_test.c,
756           moved user purge from userpurge.c
757         * userpurge.c: deleted
758         * routines2.c: finished <.AS> command
759         * room_ops.c: fixed Aide room access (for some reason, the Aide
760           room had the QR_MAILBOX flag set)
761
762 1998-11-08 Nathan Bryant <bryant@cs.usm.maine.edu>
763         * useradmin.c: really removed (cvs remove)
764         * aidepost.c, citadel.c: convert all sprintf() calls to snprintf()
765         * sysdep.c: fix overrun in lprintf() described by dme/Dead Monkey
766         * citmail.c, citserver.c: convert all sprintf() call to snprintf()
767
768 Sun Nov  8 13:19:36 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
769         * useradmin.c: removed
770         * utils.doc: removed references to useradmin and sysoputil
771
772 Fri Nov  6 20:22:20 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
773         * citadel.h (and related files): removed defunct parameters,
774           c_defent and c_msgbase (erase your test bbs)
775         * Implemented CONF server command for site-global configs
776         * Shuffled yesno() and yesno_d() from routines.c to commands.c
777         * commands.c: implemented boolprompt()
778         * routines2.c: started adding CONF questions to <.AS> command
779         * room_ops.c: began a fix for the mysterious disappearing Aide room
780
781 1998-11-05 Nathan Bryant <bryant@cs.usm.maine.edu>
782         * snprintf.c: warning fix propagated over from gcit
783
784 1998-11-04 Nathan Bryant <bryant@cs.usm.maine.edu>
785         * added RCS Id keyword strings to sources
786         * citmail.c: reverted to version 1.10
787
788 Wed Nov  4 10:53:13 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
789         * messages.c: temporarily set screenwidth to a fixed value of 80
790           during <P>rint operations.
791
792 Mon Nov  2 12:59:03 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
793         * setup.c: looks for 'citadel', 'bbs', or 'guest' in /etc/passwd to
794           try to get a default for bbsuid if it's currently set to 0
795         * citmail.c: changed usersupp.eternal to usersupp.usernum (why didn't
796           it complain about this before?)
797         * serv_upgrade.c: began writing an "export" command to do sidegrades
798
799 Sun Nov  1 18:47:42 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
800         * serv_upgrade.c: cosmetic changes
801         * Implemented message expiry by date (this really needs to be moved
802           out of serv_test.c, but where does it belong?)
803
804 1998-11-01 Nathan Bryant <bryant@cs.usm.maine.edu>
805         * serv_upgrade.c: warning fixes
806         * acconfig.h: remove ANSI_COLOR
807         * Configure, Makefile.tmpl: removed
808
809 Sat Oct 31 20:48:44 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
810         * More stoopid ANSI colour additions here and there.
811         * ANSI colour selection is now in citadel.rc instead of an option in
812           the configure script.  "on" "off" and "auto" are available.
813         * added "build.txt" to the techdoc directory, with LS's build notes
814
815 1998-10-31 Nathan Bryant <bryant@cs.usm.maine.edu>
816         * citadel.c, commands.c, commands.h: set background color to black
817           before clearing screen, so that we can actually see text on
818           black-on-white xterms.
819
820 1998-10-29 Nathan Bryant <bryant@cs.usm.maine.edu>
821         * rooms.c: fix color of Mail>
822         * citadel.c: send ANSI detect sequence after attach_to_server() so the
823           terminal doesn't send the answerback sequence to the shell if we
824           can't connect.
825
826 Wed Oct 28 20:20:14 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us
827         * citadel.c: Added a splash of colour to the Wholist
828
829 1998-10-28 Nathan Bryant <bryant@cs.usm.maine.edu>
830         * configure.in: added comments
831         * mkinstalldirs: new file to be used for `make install'
832         * aclocal.m4, missing: new files, also swiped from automake
833         * citadel.c: don't mung the terminal if we can't find citadel.rc
834         * Makefile.in: added `install' target, `clean' removes
835           *.mo, rebuild configure when configure.in changes.
836         * configure.in: check for install and autoconf
837         * configure.in, Makefile.in: only pass -fPIC to gcc
838         * policy.c: warning fix for OSF/1 (use memset() instead of bzero())
839
840 Tue Oct 27 22:25:42 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
841         * Unified the "unpacked database" format for both upgrades and
842           sidegrades (also see export5.c elsewhere)
843         * citserver.c: clear out cmdbuf before reading a command; some server
844           commands were accidentally extracting parameters from previous cmds
845         * rooms.c: removed the warning about the ineffectiveness of kicking
846           users out of public rooms, because the new server can do lockouts
847
848 1998-10-27 Nathan Bryant <bryant@cs.usm.maine.edu>
849         * sysdep.c (client_gets), ipc_c_tcp.c (serv_gets): improved handling
850           of long lines. 
851         * Makefile.in: partial support for VPATH builds, autodependency fix
852
853 Tue Oct 27 00:08:16 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
854         * minor documentation changes
855
856 Sun Oct 25 14:57:40 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
857         * messages.c: fixed an oversight that was allowing attachments even
858           when disabled in citadel.rc
859
860 1998-10-25 Nathan Bryant <bryant@cs.usm.maine.edu>
861         * routines2.c: warning fix
862
863 Sat Oct 24 22:07:56 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
864         * Client: added message expiration policy questions to room edit
865         * Client: added <.A>ide <S>ystem configuration command
866
867 1998-10-24 Nathan Bryant <bryant@cs.usm.maine.edu>
868         * Makefile.in: Auto dependency generation (may require GNU make, but
869           does at least function without this feature on OSF/1 make);
870           Makefile is regenerated when Makefile.in changes (ditto);
871           `realclean' is now known as `distclean';
872           portability fixes for older Unix make utilities
873         * citadel.c, citadel.h, commands.c: make client suspendable
874
875 Fri Oct 23 19:34:38 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
876         * setup.c: default node name is now obtained from uname()
877         * config.c: added put_config()
878         * policy.c: added, moved GetExpirePolicy() from room_ops.c
879         * policy.c: implemented cmd_gpex() and cmd_spex()
880
881 Wed Oct 21 22:24:48 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
882         * Mail rooms now hide their owner-prefix from the client.
883         * proxy.c: added configurability and primitive message expiry
884
885 1998-10-20 Nathan Bryant <bryant@cs.usm.maine.edu>
886         * Makefile.tmpl: fix to build client with old Configure script
887         * configure.in: autologin defaults to enabled if crypt() is available
888         * room_ops.c: fix improper null-termination bug I introduced
889
890 Mon Oct 19 20:52:55 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
891         * Client ability to force display of prompts in Mail rooms, even when
892           the user has prompting turned off (citadel.rc option)
893
894 1998-10-16 Nathan Bryant <bryant@cs.usm.maine.edu>
895         * sysdep.c (cprintf): generate a newline on truncated buffer
896         * room_ops.c: exploitable overrun fixes
897
898 Thu Oct 15 19:27:32 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
899         * msgbase.c: reimplemented cmd_move()
900           room_ops.c: wrote AddMessageToRoom() which is used for both entering
901           and moving messages.
902         * setup.c: system-default message expire policy of "number of
903           messages, 150" is now a default configuration instead of a temp hack
904         * proxy.c: cache dir create now dies on any error except EEXIST
905
906 Wed Oct 14 22:41:16 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
907         * Misc code cleanup
908
909 1998-10-13 Nathan Bryant <bryant@cs.usm.maine.edu>
910         * configure.in: don't check for -lcrypt unless autologin is enabled
911         * file_ops.c: fix another overrun
912
913 Mon Oct 12 15:27:21 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
914         * Killed the "rooms" subdirectory (it isn't used anymore)
915         * dynloader.c: Made dynamically added server commands case-insensitive
916         * import.c is now serv_upgrade.c, a module
917         * Removed most of the "level 9" trace messages no longer needed
918
919 1998-10-12 Nathan Bryant <bryant@cs.usm.maine.edu>
920         * Makefile.in: simplified to use pattern rules; files compiled with
921           -D_REENTRANT go to *.ro to allow the same files to be used with both
922           client and server
923         * tools.c, tools.h: new files; misc routines used by both client and
924           server go here. contains safestrncpy() at the moment.
925         * rooms.c: fix several exploitable buffer overruns
926         * sysdep.c: fix infinite loop when long lines are received from the
927           client; fix exploitable buffer overrun in cprintf()
928         * ipc_c_tcp.c: fix infinite loop on long line from server
929         * serv_upgrade.sh: remove uncnsrd-dependent absolute path
930         * .cvsignore: add *.ro
931
932 Sun Oct 11 23:17:48 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
933         * Built some more of the message expiry infrastructure
934
935 1998-10-11 Nathan Bryant <bryant@cs.usm.maine.edu>
936         * citserver.c: fix two more overruns, one of which was preventing
937           the "From Host" from showing up in the <W>ho listing.
938
939 Sun Oct 11 02:51:55 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
940         * Moved "struct visit" and its associated defs from citadel.h to
941           server.h where they belong
942         * Set up data structures for room policies (expiry, etc.)
943
944 1998-10-10 Nathan Bryant <bryant@cs.usm.maine.edu>
945         * citserver.c: fix overrun which caused segv's on servers with long
946           hostnames.
947
948 Fri Oct  9 18:34:06 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
949         * user_ops.c: added PurgeStaleRelationships() to do processing at
950           session logout time to remove visits for rooms which no longer exist
951         * user_ops.c: implemented NewMailCount()
952
953 1998-10-09 Nathan Bryant <bryant@cs.usm.maine.edu>
954         * serv_chat.c: fix buffer overrun that was resulting in segv's
955         * serv_chat.c: fix another overrun that could cause sessions to hang,
956           and cleaned up some other strncpy()-related stuff. DON'T FORGET TO
957           NULL-TERMINATE DESTINATION BUFFERS AFTER STRNCPY CALLS.
958
959 Fri Oct  9 13:22:37 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
960         * Implemented "lazy mode" traversal - pressing the space bar will do
961           <N>ext messsage, <G>oto next room, or read <N>ew as appropriate.
962         * room_ops.c: modify CtdlRoomAccess() to allow access to mailbox rooms
963           only to their owners.
964
965 Thu Oct  8 17:13:27 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
966         * messages.c, citadel.rc: added the ability to display message numbers
967           in the header when reading messages.  I think this is butt ugly, but
968           some of the DaveCode afficionados seem to like it...
969
970 Thu Oct  8 15:34:45 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
971         * room_ops.c: Added is_noneditable() function to replace all of the
972           duplicated code present in all functions which edit room parameters.
973
974 1998-10-08 Nathan Bryant <bryant@cs.usm.maine.edu>
975         * lots of warning fixes; builds with -std1 on dec unix
976         * aidepost.c, citadel.h, citmail.c, file_ops.c, msgbase.c, netmailer.c,
977           netproc.c, rcit.c, server.h, stats.c, userlist.c: use time_t where
978           needed
979         * control.c, room_ops.c, serv_chat.c, sysdep.c: use memset() instead of
980           bzero()
981         * dynloader.c, dynloader.h, messages.c, server.h, sysdep.c,
982           sysdep_decls.h: function pointer/prototyping fixes
983         * rooms.c: use mkfifo(3) instead of system("mkfifo")
984
985 1998-10-07 Nathan Bryant <bryant@cs.usm.maine.edu>
986         * snprintf.c, snprintf.h: new files
987         * Makefile.in, configure.in, dynloader.c, sysdep.c: support for the
988           above; citserver now builds and runs on Digital Unix 4.0d with the
989           GNU-style configure script. there is a bug with the hostname display
990           in the wholist.
991         * netproc.c: sillyness fix
992         * room_ops.h: prototype delete_room()
993         * client_chat.c, commands.c, serv_chat.c, sysdep.c:
994           use HAVE_SYS_SELECT_H macro
995
996 Mon Oct  5 17:01:32 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
997         * Began fixing the stuff I broke
998
999 Sun Oct  4 23:35:18 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1000         * Did the big migration to the new data structures.  Lots of stuff is
1001           now broken.  Basic moving from room to room works, but Mail is
1002           broken, and some of the administrative commands are unimplemented.
1003
1004 1998-10-02 Nathan Bryant <bryant@cs.usm.maine.edu>
1005         * configure.in: autologin now defaults to disabled
1006
1007 Fri Oct  2 00:04:31 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1008         * Finally removed all three usersupp.foo[MAXROOMS] elements, and
1009           migrated all the code that used them to use "struct visit" instead.
1010
1011 Thu Oct  1 23:02:20 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1012         * Rewrote [l][get|put]room() functions to use room names rather than
1013           room index numbers.  Temporarily prepended a "n" to these four
1014           function names until they are put to use.
1015
1016 Thu Oct  1 16:27:13 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1017         * Removed a few more references to usersupp.lastseen[]
1018
1019 1998-10-01 Nathan Bryant <bryant@cs.usm.maine.edu>
1020         * .cvsignore: add so_locations (generated by osf1 ld with shared libs)
1021         * Makefile.in: restructured variables for greater consistency, use
1022           @echo to print out notices during the make process, add so_locations
1023           to `cleaner'
1024         * configure.in, Makefile.in: configure checks for -rdynamic
1025         * ipc_c_tcp.c: fix DEC compiler warning wrt unsigned char
1026         * stats.c: add semicolon to placate DREC compiler
1027         * user_ops.c: define _POSIX_C_SOURCE, include <limits.h>
1028         * configure.in: pass -pthread to DEC compiler, don't check for
1029           libpthread[s] on DEC Unix
1030
1031 1998-09-30 Nathan Bryant <bryant@cs.usm.maine.edu>
1032         * Makefile.in: new variable PTHREAD_DEFS for portability
1033         * aidepost.c, citadel.c, citmail.c, mailinglist.c, msgform.c,
1034           netmailer.c, netpoll.c, netproc.c, rcit.c, readlog.c, setup.c,
1035           stats.c, userlist.c, whobbs.c: return type of main() is int
1036         * citadel.c, commands.c, messages.c: use time_t properly
1037         * citserver.c: include <limits.h>
1038         * config.guess, config.sub, install-sh: new files
1039         * configure.in: don't use gcc on Digital Unix
1040
1041 Tue Sep 29 23:17:34 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1042         * room_ops.c: modified usergoto() to look at the new data structures
1043           for counting new messages and such.
1044
1045 1998-09-29 Nathan Bryant <bryant@cs.usm.maine.edu>
1046         * user_ops.c: fix compiler warning and potential memory leak,
1047           include sysdep.h
1048         * configure.in, Makefile.in: only build the server if we find pthreads
1049         * Makefile.in: realclean removes config.{cache,log,status}
1050
1051 Tue Sep 29 13:20:14 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1052         * Removed code from some of the utilities which was still attempting
1053           to access the old non-gdbm data store.
1054         * housekeeping.c: rewrote check_ref_counts() to do a ForEachRoom()
1055           traversal instead of a MAXROOMS loop.
1056         * sysdep.c: set up a dummy CitContext record to be used during server
1057           startup, during which time there is no real context.
1058
1059 Mon Sep 28 23:51:51 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1060         * Implemented the function ForEachRoom() to handle all-rooms traversal
1061           (this will work with both the old and new paradigms, because both
1062           use a GDBM database with one room per record).  Migrated all room
1063           list commands to use it.
1064
1065 Mon Sep 28 22:05:35 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1066         * Implemented the function CtdlRoomAccess() to handle *all* of the
1067           user-access-to-rooms functionality.  Migrated all room list commands
1068           to use it.  Still need to migrate gotos.
1069
1070 1998-09-28 Nathan Bryant <bryant@cs.usm.maine.edu>
1071         * configure.in, acconfig.h: new files; partially functional GNU
1072           autoconf configure script. Run autoheader; autoconf; ./configure
1073           --prefix=`pwd` to test.
1074         * Makefile.tmpl: new file; this is what Makefile.in used to be. Used by
1075           Configure.
1076         * Makefile.in: modified to work with autoconf-style configure script
1077         * Configure: modified to use Makefile.tmpl and generate autoconf-style
1078           macros. Removed procfs detection. Pass -O2 to gcc, -O to other
1079           compilers. Removed mknod/mkfifo detection; code should use mkfifo(3).
1080         * citmail.c, msgform.c, netproc.c, routines.c, support.c, userlist.c,
1081           whobbs.c: use HAVE_STRERROR macro rather than NO_STRERROR
1082         * commands.c: use HAVE_TERMIOS_H macro rather than POSIX_TERMIO
1083         * netproc.c: remove procfs stuff. simply attempt to kill the target
1084           process with signal zero instead; this checks whether the process
1085           exists.
1086         * setup.c, useradmin.c: use HAVE_CURSES_H macro
1087
1088 Sun Sep 27 23:41:29 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1089         * BOTH the old and new generation systems are being written to at
1090           this point.  Code that reads stuff is still using the old system.
1091
1092 Sun Sep 27 16:10:49 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1093         * Changed all "generation" variables from char to long, in preparation
1094           for removing MAXROOMS.  Generations for new rooms are now timestamps.
1095         * Defined "struct visit" to hold user/room relationships.
1096         * Removed some #define's from citadel.h that are no longer used.
1097
1098 Wed Sep 23 13:41:49 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1099         * More changes to support attachments.  They mostly work, but only
1100           in fixed-format messages.
1101
1102 Mon Sep 21 21:19:17 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1103         * msgbase.c: began laying the groundwork to support attachments.
1104           Purchased Rogaine(tm) in preparation for expected hair loss.
1105
1106 1998-09-21 Nathan Bryant <bryant@cs.usm.maine.edu>
1107         * msgbase.c: include dynloader.h
1108         * citadelapi.h: removed
1109         * dynloader.h: prototype CtdlRegisterUserHook()
1110
1111 Sun Sep 20 18:56:37 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1112         * Added a UserFunctionHook category to implement hooks which perform
1113           operations on various users or usernames
1114
1115 Fri Sep 18 21:14:41 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1116         * citserver.c: removed cmd_extn() and related code
1117
1118 1998-09-18 Nathan Bryant <bryant@cs.usm.maine.edu>
1119         * user_ops.c: include dynloader.h
1120         * roomstats.{c,mk}: removed
1121         * Configure, Makefile.in: autodependency-related fixes
1122
1123 Thu Sep 17 22:55:29 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1124         * Various changes to allow "new messages" to work correctly with Mail
1125
1126 Thu Sep 17 22:21:45 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1127         * server.h, dynloader.c, citserver.c, user_ops.c: reduced the number
1128           of hook types by inventing an EventType field to the Session hook.
1129         * proxy.c: added pre-fetching
1130
1131 1998-09-17 Nathan Bryant <bryant@cs.usm.maine.edu>
1132         * Makefile.in: add SERV_MODULES and PROXY_TARGETS to `cleaner'
1133         * dynloader.[ch], serv_{chat,test}.[ch], sysdep.c: cleaned
1134           up the dynamic loader interface as follows:
1135           - all the symbol table stuff is gone.
1136           - modules are loaded once at server startup and never unloaded.
1137           - Added a new function CtdlRegisterProtoHook() to handle the stuff
1138             that was being done with the symbol tables.
1139           - Dynamic_Module_Init() now returns a pointer to a static struct
1140             DLModule_Info; this structure itself has been modified to use char*
1141             fields instead of fixed char arrays.
1142         * roomstats.c: include <stdarg.h> not <stdargs.h> (is this file still
1143           in use?)
1144         * Configure, Makefile.in: added autodependency support
1145
1146 Wed Sep 16 22:25:13 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1147         * Implemented separate structs, lists, and functions for each type
1148           of server-side hook available.
1149
1150 1998-09-16 Nathan Bryant <bryant@cs.usm.maine.edu>
1151         * ipc_c_tcp.c: Fixed up some #include/prototyping stuff, call memcpy()
1152           instead of bcopy()
1153         * hooks.h: removed
1154         * sysdep.c, user_ops.c: removed reference to hooks.h
1155
1156 Wed Sep 16 11:42:42 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1157         * ipc_c_tcp.c: Reversed any changes that have been made to this file,
1158           because something was causing abominally slow response time.
1159         * proxy.c: added.  This will eventually become a caching, pre-fetching
1160           multiuser proxy server for the Citadel protocol.
1161
1162 1998-09-15 Nathan Bryant <bryant@cs.usm.maine.edu>
1163         * Makefile.in: remove support.o from serv_chat.so, add -fPIC to compile
1164           flags for serv_chat.o
1165         * dynloader.c: include "sysdep_decls.h", use RTLD_NOW not RTLD_LAZY
1166         * dynloader.h: prototype CtdlRegisterHook()
1167         * .cvsignore: added data
1168
1169 Mon Sep 14 20:49:08 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1170         * Tried my hand at adding the ability for server extensions to
1171           register various types of "hooks" in addition to just adding
1172           server commands.  This is probably not final.
1173
1174 Tue Sep  8 12:11:56 EDT 1998 Brian Costello <btx@calyx.net>
1175         * Added support for dynamic server modules.  Reworked serv_chat.c
1176           to be such a module.
1177
1178 Tue Sep  1 23:09:50 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1179         * userpurge.c: rewrote using functions from the server core, rather
1180           than the now-defunct external API.  This'll be ready once the module
1181           loading code is done.  (I just had to commit _something_ tonight.)
1182
1183 Mon Aug 31 22:47:58 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1184         * Yanked the citadelapi.c module.  This wasn't working out well.
1185         * techdocs/citadelapi.txt - began documenting the new API to be used
1186           by modules which will be dynamic linked into the server - most of
1187           this API is existing server functions.
1188         * Added a ForEachUser() function with callback mechanism, and reworked
1189           cmd_list() to use it.
1190
1191 Sun Aug 30 21:52:43 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1192         * Moved all of the gdbm databases to a separate "data" directory.
1193
1194 1998-08-26 Nathan Bryant <bryant@cs.usm.maine.edu>
1195         * Makefile.in: realclean removes Makefile, fixed `touch citadel.h'
1196           problem
1197
1198 1998-08-25 Nathan Bryant <bryant@cs.usm.maine.edu>
1199         * room_ops.c: include time.h
1200         * userlist.c, whobbs.c, serv_chat.c, user_ops.c, sysdep.c, stats.c,
1201           citadel_decls.h, commands.c, messages.h, routines.h, routines2.h:
1202           remove duplicated declarations
1203
1204 Mon Aug 24 23:45:01 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1205         * setup.c: Removed yesno_s()
1206         * citadel.h, room_ops.c: added QRmtime field to struct quickroom,
1207           modified whenever a room is modified or posted in.
1208         * citadelapi.c: Added CtdlForEachRoom() function
1209
1210 Mon Aug 24 20:04:04 EDT 1998 Nathan Bryant <bryant@cs.usm.maine.edu>
1211         * Makefile.in: new target `cleaner' does the same as `realclean' 
1212           without removing sysdep.h
1213         * proto.h: is bad. eliminate. I've moved the prototypes into several
1214           header files, one per .c file
1215
1216 Mon Aug 24 00:45:55 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1217         * Added a CtdlGotoRoom() function to the CitadelAPI.
1218  
1219 Sun Aug 23 21:47:00 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1220         * sysoputil is finally dead!  Removed it from the build.
1221         * Added userpurge.c server extension (initial implementation)
1222
1223 Tue Aug 18 00:42:33 EDT 1998 Nathan Bryant <bryant@cs.usm.maine.edu>
1224         * Makefile.in: `clean' target no longer rm's sysdep.h; new target
1225           `realclean' removes everything clean does, plus sysdep.h, plus
1226           target binaries.
1227         * Configure: add -Wstrict-prototypes to CFLAGS for gcc systems
1228         * *.[ch]: protoized. Added several new header files containing
1229           prototypes and other external declarations; many duplicated
1230           declarations still should be moved to header files. proto.h must die
1231           as well, IMHO.
1232
1233 Mon Aug 17 23:52:13 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1234         * Implemented a bunch of user account related functions in the
1235           CitadelAPI library.
1236
1237 Mon Aug 17 20:01:18 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1238         * Fixed the crash problem.  It wasn't AGUP/ASUP, but rather a buffer
1239           overrun in getuser() (thanks, Nathan).  Implemented overrun checks
1240           in getuser(), getroom(), and getfloor() to prevent future problems.
1241
1242 Mon Aug 17 00:06:52 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1243         * Updated citmail.c with the latest stuff from the production system.
1244         * Implemented AGUP and ASUP commands, but AGUP crashes the server
1245           after its first successful use (user-not-found's don't affect it).
1246
1247 Thu Aug  6 19:25:01 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1248         * Got the CitadelAPI library to the point where the server can start
1249           up an extension, and the extension will connect to the server, do
1250           some initialization, call a user-supplied CtdlMain(), and exit.  Also
1251           hacked together a _temporary_ form of the new EXTN server command.
1252  
1253 Wed Aug  5 23:02:22 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1254         * Second attempt at getting the server API started.  Now it runs
1255           outside of the server and builds a connection.
1256
1257 Tue Aug  4 18:33:06 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1258         * Modified the appearance of Internet addresses when they arrive on
1259           a Citadel system.
1260         * Removed the <E> field from the message format writeup in hack.txt.
1261         * Fixed-up citmail.c so that it doesn't try to do database lookups.
1262
1263 Mon Aug  3 23:01:37 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1264         * Started developing the server-side API.  This is in its very
1265           initial stages.  See serverapi.c and techdoc/api.txt
1266
1267 1998-08-02  Nathan Bryant  <bryant@cs.usm.maine.edu>
1268         * Makefile.in: added config_decls.h to dependencies
1269
1270 Sun Aug  2 21:09:09 EDT 1998 Nathan Bryant <bryant@cs.usm.maine.edu>
1271         * config_defs.h: renamed to config_decls.h
1272         * config.c, sysoputil.c: updated to reflect the above
1273
1274 Sun Aug  2 18:52:05 EDT 1998 Nathan Bryant <bryant@cs.usm.maine.edu>
1275         * config_defs.h: new file, contains external declarations from config.c
1276         * config.c: moved defs to config_defs.h, use PATH_MAX from <limits.h>
1277           for bbs_home_directory
1278         * mailinglist.c, support.c: include <string.h>
1279         * sysoputil.c: include <string.h>, <limits.h>, "config_defs.h", remove
1280           duplicated defs, replace gets() call with fgets()
1281         * user_ops.c: define _XOPEN_SOURCE_EXTENDED
1282
1283 Sat Aug  1 18:32:52 EDT 1998 Nathan Bryant <bryant@cs.usm.maine.edu>
1284         * ipc_c_tcp.c: fixed order of memcpy parameters after gethostbyname
1285
1286 Sun Jul 19 17:26:12 EDT 1998 Nathan Bryant <bryant@cs.usm.maine.edu>
1287         * ChangeLog: reordered; the GNU standard is to add new entries to the
1288           top.
1289         * .cvsignore: added userlist
1290
1291 Sun Jul 12 20:58:59 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1292         * Finished migrating everything to the new data store.
1293         * Replaced the binary "calllog" with the ASCII "citadel.log"
1294         * Began converting broken utilities that depend on the old data store
1295
1296 Sat Jul 11 00:20:48 EDT 1998 Nathan Bryant <bryant@cs.usm.maine.edu>
1297         * Makefile.in: removed msgstats
1298
1299 Fri Jul 10 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1300         * Initial CVS import