]> code.citadel.org Git - citadel.git/blob - citadel/ChangeLog
* Completed serv_vandelay.c (importer/exporter module)
[citadel.git] / citadel / ChangeLog
1  $Log$
2  Revision 572.17  2000/07/17 02:38:08  ajc
3  * Completed serv_vandelay.c (importer/exporter module)
4  * sendcommand.c: fix behavior of SEND_LISTING mode
5  * sysdep.c: client_gets() fill buffer with "000" terminator when returning -1
6
7  Revision 572.16  2000/07/14 03:06:55  ajc
8  * Added .ATN (DOWN) and .ATS (SCDN 1) commands to the client
9
10  Revision 572.15  2000/07/10 23:36:08  ajc
11  * Another attempt to fix the crashy crashy bug in serv_vcard
12  * Did more work on the Art Vandelay module
13  * Replaced all instances of sprintf(tempfile, tmpnam(NULL)) with strcpy()
14
15  Revision 572.14  2000/07/10 04:01:12  ajc
16  * added an unfinished serv_vandelay.c (Art Vandelay module - importer/exporter)
17
18  Revision 572.13  2000/07/09 02:47:40  ajc
19  * Overhauled the keepalive logic in the chat client.  Closes bug #20.
20
21  Revision 572.12  2000/07/09 02:27:02  ajc
22  * Eliminated the whole SIGINT/SIGQUIT based handling of Ctrl-O and Ctrl-C
23    keyboard interrupts.  Replaced with a non-blocking check for keyboard input
24    which sets the global variable 'sigcaught' if either key was pressed.
25    fmout() and pprintf() switch to 'drain mode' if sigcaught is set.
26    This closes Bug #18.
27
28  Revision 572.11  2000/07/06 20:26:36  ajc
29  * updated .Help SUMMARY
30
31  Revision 572.10  2000/07/04 20:02:46  ajc
32  * Fixed potential crashy crashy bug in serv_vcard.c
33
34  Revision 572.9  2000/06/28 03:42:56  ajc
35  * Changed the comments at the beginning of each file to a consistent format
36  * Improved the parameterization of commands in the IMAP module
37
38  Revision 572.8  2000/06/27 01:27:13  ajc
39  * Coupla very small changes to get on the road to IMAP support
40
41  Revision 572.7  2000/06/22 21:41:48  ajc
42  * Made the ICQ stuff far more reliable ... by removing it!
43
44  Revision 572.6  2000/06/21 03:46:20  ajc
45  * IMAP is now legal but useless, supporting NOOP, LOGIN, and LOGOUT.
46
47  Revision 572.5  2000/06/15 20:15:52  ajc
48  * Inserted a skeleton IMAP module into the build.  IT DOES NOT WORK AT ALL.
49
50  Revision 572.4  2000/06/04 02:30:56  ajc
51  * CtdlForEachMessage() now returns the number of messages processed.  It also
52    accepts the MSGS_EQ mode, for targeting a specific message number (useful
53    for determining whether the specified message actually exists in a room).
54  * Completed the server side of the moderation system (serv_moderate.c module
55    which implements the MMOD command)
56
57  Revision 572.3  2000/06/03 05:47:57  ajc
58  * Replaced most of the very repetitive and very redundant access level checks
59    in most commands with a single API call:  CtdlAccessCheck()
60  * serv_moderate.c: added (not finished)
61
62  Revision 572.2  2000/06/02 03:38:50  ajc
63  * Bind unix socket prior to TCP socket for citadel protocol
64  * Fixed bug in sendcommand.c which was causing it to crash on attach
65
66  Revision 572.1  2000/05/26 19:27:51  ajc
67  * Changed some of the rev-level sensitive stuff to look at the actual version
68    of Citadel running, not the last version with which we ran setup
69  * Added a moderation system.  Default filter level for new users is in the
70    config file.  Per-user setting is in usersupp.  Moderation level of each
71    message is in SuppMsgInfo.  Tweaked CONF, GETU, and SETU.  Read filter is
72    working.  Moderate message up/down commands are not here yet.  See
73    techdoc/moderation.txt for more info.
74
75  Revision 572.0  2000/05/23 02:09:30  ajc
76  * Updated docs and tagged everything for the 5.72 release
77
78  Revision 571.7  2000/05/20 23:28:20  ajc
79  * Fixed bug in client API that was causing netproc to crash
80
81  Revision 571.6  2000/05/15 00:05:19  ajc
82  * Double the retry interval for SMTP deliveries after each failed attempt.
83
84  Revision 571.5  2000/05/11 03:08:47  ajc
85  * serv_smtp.c: clear the relevant state buffers after an SMTP DATA command
86    completes, allowing multiple messages in one session.  Closes bug #58.
87
88  Revision 571.4  2000/04/24 03:36:43  ajc
89  * Removed references to strucmp() and struncmp(), replaced them with
90    strcasecmp() and strncasecmp() as we did in the server a while ago, and
91    set up the config script to figure out whether they need to be compiled
92    in.  Also moved them to tools.h
93  * Wrote a password manager for the client
94
95  Revision 571.3  2000/04/19 03:17:10  ajc
96  * Don't ever expire the Local System Configuration> room
97
98  Revision 571.2  2000/04/16 19:03:47  ajc
99  * Minor changes to avoid host lookup for local clients
100
101  Revision 571.1  2000/04/15 19:55:52  ajc
102  * Fixed "Unvalidated users appear even with registration disabled" bug #36
103
104  Revision 571.0  2000/04/13 02:43:24  ajc
105  * Fixed a problem that crashed the client during <G>oto commands if a room
106    existed with a name more than 32 characters (thanks to Magus for reporting
107    this one).
108  * Tagged everything and updated docs for the 5.71 release
109
110  Revision 570.18  2000/04/10 01:47:22  ajc
111  * More paginator changes.  Shuffled code around, added pagination to a bunch
112    of other functions, and replaced the old, cumbersome pagination with the
113    new, easy, API-based one in everything except message output.
114
115  Revision 570.17  2000/04/09 17:51:18  ajc
116  * Added pprintf() (paginated version of printf) to the client-side API.  Now
117    any client side function can be paginated simply by changing all of the
118    printf's to pprintf's.  I've already done this for the user list and wholist
119    (removing the old style pagination) and for "read directory."
120
121  Revision 570.16  2000/04/08 04:52:48  ajc
122  * Another minor stoopid little time display fix
123
124  Revision 570.15  2000/04/08 03:58:12  nbryant
125   * backed out the previous changes since they didn't look good on some
126     xterms with a blue bold mode. just set the background color to black
127     instead. this makes black-on-white terminals actually readable, if not
128     particularly good looking.
129
130  Revision 570.14  2000/04/08 01:36:30  nbryant
131   * citadel.c, commands.c: comment out cls() as this wasn't called if
132     ansi_color=user anyway, and we have no way of knowing whether the user's
133     terminal does background color erase, which was the reason for adding this
134     in the first place. with the recent changes to color(), the display will get
135     screwed up if they *do* have background color erase. perhaps this is a job
136     for terminfo.
137
138  Revision 570.13  2000/04/08 00:37:42  nbryant
139   * commands.c: fix color support for black-on-white color terminals such as
140     CDE's dtterm. this just avoids white-on-white text; some color combinations
141     such as yellow-on-white still aren't very legible due to contrast. There's
142     not much I can think to do about that without affecting the look on the
143     white-on-black terminals which probably account for most users.
144
145  Revision 570.12  2000/04/07 20:22:34  ajc
146  * Fixed am/pm bug in time display
147
148  Revision 570.11  2000/04/07 19:22:45  ajc
149  * For services disabled by setting port number to -1, administratively skip
150    the bind instead of just allowing it to fail.
151
152  Revision 570.10  2000/03/31 04:31:02  ajc
153  * Quick fix to 'stats' utility to purge records with bogus timestamps
154
155  Revision 570.9  2000/03/31 02:10:52  ajc
156  * Caved in to pressure and enabled <R>eply in public rooms.
157
158  Revision 570.8  2000/03/28 03:55:53  ajc
159  * Modified <.RU> to allow search for partial match
160
161  Revision 570.7  2000/03/27 03:08:19  ajc
162  * Third parameter of CtdlDeleteMessages() now takes "" instead of NULL to
163    specify 'any MIME type'.
164
165  Revision 570.6  2000/03/27 01:14:08  nbryant
166   * Makefile.in: generate parsedate.c automatically
167   * configure.in: check for bison/byacc/yacc. bison seems to build cleaner
168     code.
169   * parsedate.c: removed from CVS
170   * parsedate.y: added #include <stdlib.h> so it builds with bison
171
172  Revision 570.5  2000/03/27 00:46:10  nbryant
173   * First cut at Solaris fixes. There may still be some *printf("%s", NULL)
174     type of issues lurking in the shadows.
175
176  Revision 570.4  2000/03/25 18:29:58  nbryant
177  changed my email address
178
179  Revision 570.3  2000/03/23 02:41:50  ajc
180  *** empty log message ***
181
182  Revision 570.2  2000/03/21 03:23:24  ajc
183  * Experimental new linebreak mode
184
185  Revision 570.1  2000/03/20 14:43:19  ajc
186  * "Brown paper bag" fix for SMTP bug (incoming long fields crash logger)
187
188  Revision 570.0  2000/03/19 23:42:34  ajc
189  * This is the official 5.70 release.
190
191  Revision 1.494  2000/03/19 23:04:08  ajc
192  * Small cosmetic change to date/time output
193
194  Revision 1.493  2000/03/19 05:02:39  ajc
195  * SMTP hacks to deal with AOL braindamage
196
197  Revision 1.492  2000/03/18 18:18:04  ajc
198  * Support multiline responses from SMTP servers when sending mail
199
200  Revision 1.491  2000/03/17 16:26:57  ajc
201  * Set up a private "Sent/Received Pages" room for each user
202
203  Revision 1.490  2000/03/17 04:11:24  ajc
204  * Moved bio-related commands out to a loadable module
205
206  Revision 1.489  2000/03/16 17:58:54  smw
207  Created a docs directory.
208  Moved install.txt to docs.
209  Added inetmailsetup.txt (BBS server side e-mail)
210  Added inetmailsetupmx.txt (local mail AND bbs e-mail
211  Added inetsiteconfig.txt (describes the .asi command)
212  Added siteconfig.txt (describes .asg)
213  Added chat.txt (describes changes and new chat functionality)
214  Made a couple of changes to install.txt (references to new documentation)
215  Added Steve Williams to copyright.txt as the document writer.
216
217 Revision 1.488  2000/03/15 03:04:51  ajc
218 * Added DEXP server command to disable incoming express messages.
219 * <Q>uiet mode client side command to set/clear DEXP mode.
220 * <K>nown rooms list displays through the paginator.
221
222 Revision 1.487  2000/03/12 00:21:35  ajc
223 * Removed the semi-broken "chat room" functionality in the chat system, and
224   replaced it with direct mapping to the actual Citadel room the user is in.
225 * Display masqueraded roomname in chat, if applicable.  Fixes bug #19.
226
227 Revision 1.486  2000/03/11 21:29:37  ajc
228 * SM_ flags for CtdlSaveMsgPointerInRoom() need to be a bit bucket, not an
229   enum, since more than one can be passed.  Changed SM_DONT_BUMP_REF_COUNT
230   from 3 to 4.  This also fixes bug #33.
231
232 Revision 1.485  2000/03/11 20:26:03  ajc
233 * Reworked the <R>eply logic in messages.c - fixes bug #34
234
235 Revision 1.484  2000/03/11 19:22:19  nbryant
236  * commands.c: improved timing of background keepalives if connection is
237                lagged
238
239 Revision 1.483  2000/03/11 05:08:48  nbryant
240  * commands.c: oops, that mutex stuff wasn't necessary
241
242 Revision 1.482  2000/03/11 04:09:03  nbryant
243  * new threaded client code for background keepalives
244
245 Revision 1.481  2000/03/10 21:40:04  ajc
246 * Changes to message base and networker to support Internet-style message
247   ID's instead of the conventional Citadel style.
248
249 Revision 1.480  2000/03/08 03:36:37  ajc
250 * Shut off hostname resolution when dealing with Unix domain sockets
251 * Cleaned up the 'citmail' MDA tool
252 * Added POP3 and SMTP port numbers to global system configuration
253
254 Revision 1.479  2000/03/07 21:54:58  ajc
255 * Fixed the naming conventions and permissions for unix domain sockets.
256
257 Revision 1.478  2000/03/05 07:33:23  ajc
258 * Added support for protocols over Unix domain sockets.
259
260 Revision 1.477  2000/03/04 22:36:23  ajc
261 * Remove nulls appended to editor files during replace, edit, and print
262   operations.  Truncate temp files during same operations.
263   Closes bugs #6 and #7.
264
265 Revision 1.476  2000/03/04 05:29:18  ajc
266 * Relax restrictions on editing of base rooms.  Renaming is not allowed but
267   all other attributes can be edited.  Closes feature request #21.
268 * Sending pages from the client now uses the same message editing functions
269   as entering messages, allowing edit/abort.  Closes feature request #25.
270
271 Revision 1.475  2000/03/03 04:50:14  ajc
272 * Moved all of the wholist masquerading commands into the serv_rwho module
273
274 Revision 1.474  2000/03/03 04:12:37  ajc
275 * Finished the inbound side of gateway domain service
276
277 Revision 1.473  2000/02/27 04:55:51  ajc
278 * Added "keymenu()" generic menu-maker to commands.c
279 * Blocked non-numeric input to intprompt()  (fixes bug #16)
280
281 Revision 1.472  2000/02/27 03:57:35  ajc
282 * Completed 'fsck'-like reference count verifier (server and client)
283
284 Revision 1.471  2000/02/26 18:30:40  ajc
285 * Properly handle all aliases specified in network/mail.aliases for incoming
286   SMTP mail (uses the alias() function, so if we replace that function with
287   something that uses the same calling convention, it'll still work)
288
289 Revision 1.470  2000/02/26 05:15:38  ajc
290 * Fortified the message base and SMTP code so that misdirected bounce messages
291   end up in the Aide> room instead of getting dereferenced
292 * Started writing a message reference count verifier ('fsck' for message base)
293
294 Revision 1.469  2000/02/25 06:14:05  ajc
295 * Modularized the RWHO (Read WHO is online) command, basically as a pilot
296   for modularizing all "non-API" functionality.
297
298 Revision 1.468  2000/02/24 03:44:00  ajc
299 * Implemented holdoff time (15 minutes) for SMTP send retry.
300 * Implemented "try for 3 days and then give up" on SMTP send.
301
302 Revision 1.467  2000/02/24 00:51:48  ajc
303 * Client protocol synchronization check during exit from chat.
304   This closes Bug #15.
305
306 Revision 1.466  2000/02/22 16:37:28  ajc
307 * Minor tweaks to RFC822 output to keep brain-damanged MS Outlook from dying
308
309 Revision 1.465  2000/02/22 04:17:56  ajc
310 * Got bounce messages working (mostly ... testers, please beat this up!)
311 * Changed 'FIX' comments to 'FIXME' (less conflict, plus vim highlights it!)
312
313 Revision 1.464  2000/02/18 22:29:18  ajc
314 * Coded up the "bounce" functions.  Still a coupla bugs.
315
316 Revision 1.463  2000/02/18 05:10:50  ajc
317 * Made the <.ASI> command a bit friendlier.
318 * SMTP sender now pays attention to "smarthost" entries in the system's
319   Internet configuration, using them if one or more is present.
320
321 Revision 1.462  2000/02/17 05:27:39  ajc
322 * Got the "MAIL From:" command sending the correct data.  (unnnhhhhnnhhhh...)
323
324 Revision 1.461  2000/02/16 22:06:26  ajc
325 * Altered the display and conversion of RFC822 messages
326
327 Revision 1.460  2000/02/16 03:43:28  ajc
328 * Added the resolver library to the configure script
329
330 Revision 1.459  2000/02/16 01:19:39  ajc
331 * Vanquished the evil dn_expand() beast.  getmx() now seems to be working.
332
333 Revision 1.458  2000/02/14 04:36:14  ajc
334 * sysdep.c: added new event hook type EVT_TIMER.  Timer event hooks are called
335   once per minute by any worker thread.
336 * msgbase.c: removed dependence on nested functions in CtdlOutputMsg() by
337   replacing them with an API call CtdlRedirectOutput() in sysdep.c, which
338   can temporarily redirect a session's output to an arbitrary file or socket.
339 * serv_smtp.c: implemented the purging of messages in the queue for which all
340   deliveries have been completed.
341 * serv_smtp.c: removed temporary 'QQQQ' server command and replaced it with
342   a timer event hook that runs the queue once per minute (this needs to be
343   made more robust)
344
345 Revision 1.457  2000/02/08 21:00:47  ajc
346 * Implemented the deprecated "LAST" command in POP3.  Some clients need it.
347 * POP3 sessions now set the last-read pointer in Mail>.
348
349 Revision 1.456  2000/02/07 05:15:00  ajc
350 * Renamed CtdlLocalHost() to CtdlHostAlias() and worked it a little deeper into
351   the message routing logic.  Still needs some work on the gateway-domain
352   stuff.
353 * Twiddled CtdlOutputMsg() a bit for 'all Internet' situations.  Still needs
354   some work to avoid printing dual headers when both Cit and RFC822 exist.
355
356 Revision 1.455  2000/02/03 03:57:35  ajc
357 * Formalized the 'Internet Configuration' logistics.  Added new API call
358   CtdlLocalHost() to detect aliases for the local host.  Used in SMTP listener.
359
360 Revision 1.454  2000/01/31 02:13:05  ajc
361 * <.A>ide <S>ystem configuration <I>nternet  in the client (unfinished)
362
363 Revision 1.453  2000/01/26 02:41:27  ajc
364 * SMTP delivery is working but still *very* rough.
365
366 Revision 1.452  2000/01/25 04:45:50  ajc
367 * Wrote enough of the SMTP sender to get Patriot drooling over it, but not
368   enough to complete the transmission of mail.
369
370 Revision 1.451  2000/01/23 21:25:45  ajc
371 * Temporary hack to ig_tcp_server() to listen on an arbitrary port if the
372   one specified is not bindable (for development only)
373 * Added SM_DONT_BUMP_REF flag to CtdlSaveMsgPointerInRoom() to be used only
374   in very specific and special situations
375 * Generate delivery instructions when outbound SMTP mail is created from
376   within Citadel (as opposed to being from the SMTP module)
377
378 Revision 1.450  2000/01/23 05:22:41  ajc
379 * Coded up some more of the SMTP-sender (still not done)
380
381 Revision 1.449  2000/01/22 05:13:56  ajc
382 * Added some more functionality to the string tokenizer
383
384 Revision 1.448  2000/01/17 20:57:43  ajc
385 * CR to CRLF hacks (lose, lose, lose)
386
387 Revision 1.447  2000/01/17 18:30:27  ajc
388 * Completed POP3 server.  All RFC1939 commands except APOP are implemented.
389
390 Revision 1.446  2000/01/17 17:09:23  ajc
391 * Implemented LIST and STAT commands in the pop3 server
392
393 Revision 1.445  2000/01/17 05:38:14  ajc
394 * citserver.c: cleanup hook functions are now run under the proper context,
395                even when initiated by the housekeeper thread
396 * serv_pop3.c: establish a place to hold the message list
397
398 Revision 1.444  2000/01/17 04:26:39  ajc
399 * Modified CtdlOutputMsg() to handle output to arbitrary sockets or files.
400   This uses nested functions and may not be portable beyond GCC...
401
402 Revision 1.443  2000/01/15 18:29:15  ajc
403 * Added a generic (void *) parameter to the ForEachUser() and ForEachRoom()
404   callback mechanisms, to allow callers and callbacks to pass arbitrary data
405   between each other without requiring TSD variables.
406 * room_ops.c: eliminated the need for 'FloorBeingSearched' TSD variable
407 * internet_addressing.c: eliminated 'buffer1' and 'buffer2' TSD variables
408
409 Revision 1.442  2000/01/15 04:31:44  ajc
410 * Removed UI_DIALOG mode in setup.  Can't count on 'dialog' to be consistent.
411
412 Revision 1.441  2000/01/15 04:07:17  ajc
413 * Fixed the access rights on auto-created rooms (the same changes that were
414   made to version 5.62 in the stable tree)
415
416 Revision 1.440  2000/01/13 03:32:36  ajc
417 * techdoc/delivery-list.txt: added (syntax for delivery lists)
418 * domain.*: added (will contain MX lookup code)
419 * internet_addressing.c, logging.c: fixed some buffer overflow bugs
420
421 Revision 1.439  2000/01/12 03:56:27  ajc
422 * sysdep.c: start the housekeeping thread *after* dropping root perms.
423
424 Revision 1.438  2000/01/09 19:03:16  ajc
425 * Removed the fifo-based protocol downloads and replaced it with a less
426   elegant "download temporary file to client, then sx/sb/sz" because
427   downloading through a fifo was confusing some software.
428
429 Revision 1.437  2000/01/08 22:19:44  ajc
430 * Completed spool to outbound delivery queue (still no queue sender implemented)
431
432 Revision 1.436  2000/01/08 05:00:09  ajc
433 * Reworked some of the data structures to handle multiple recipients
434 * Began implementation of the delivery queue
435 * Added CtdlReallocUserData()
436 * CtdlSaveMsg() now returns the local message ID in the database
437
438 Revision 1.435  2000/01/06 03:50:34  ajc
439 * Replaced citmail.c with a new one that simply SMTP-forwards to Citadel
440 * Started outbound SMTP queue work
441
442 Revision 1.434  1999/12/30 04:56:29  ajc
443 * Got initial SMTP delivery working in a very specific situation (delivery
444   to a single, local user)
445
446 Revision 1.433  1999/12/29 04:44:00  ajc
447 * client_chat.c: display "No message sent" if a send page is aborted.
448   Closes bug #2 in bugzilla.
449
450 Revision 1.432  1999/12/26 21:50:07  ajc
451 * serv_vcard: don't run hooks when not logged in (such as in SMTP sessions)
452 * serv_pop3: added.  This is the skeleton for a module implementing POP3.
453
454 Revision 1.431  1999/12/23 04:46:23  ajc
455 * "Finished" initial hack of RFC822 import
456
457 Revision 1.430  1999/12/22 04:46:34  ajc
458 * Fixed up the "Date:" headers to be RFC822-compliant
459
460 Revision 1.429  1999/12/13 05:30:57  ajc
461 * Removed our naive 'conv_date()' RFC822-to-unixtime conversion function
462   and replaced it with the public domain 'parsedate()' function from UseNet
463
464 Revision 1.428  1999/12/10 23:58:25  ajc
465 * internet_addressing.c: added.  (Internet address to Citadel mapping)
466
467 Revision 1.427  1999/12/10 21:34:19  ajc
468 * serv_smtp: implemented RFC821 "VRFY" and "EXPN" commands
469
470 Revision 1.426  1999/12/09 05:01:14  ajc
471 * Split cmd_user() and cmd_pass() into frontend/backend functions
472 * serv_smtp: implemented AUTH LOGIN for client authentication
473
474 Revision 1.425  1999/12/09 00:22:58  ajc
475 * Finished the "arbitrary service" registration.
476 * Eliminated "special" master socket for Citadel protocol - just register it
477   like any other protocol.
478 * Began initial implementation of native SMTP service.
479
480 Revision 1.424  1999/12/08 18:09:10  ajc
481 * Added CtdlRegisterServiceHook() and its data type, for implementing arbitrary
482   TCP-based services directly in the Citadel server.  Not finished yet.
483
484 Revision 1.423  1999/11/29 17:39:07  nbryant
485 * citserver.c: Solaris lacks inet_aton; use inet_addr instead
486
487 Revision 1.422  1999/11/29 17:26:15  nbryant
488 * citserver.c: include <sys/types.h>; may help portability to Solaris
489
490 Revision 1.421  1999/11/22 00:27:42  ajc
491 * Added some temporary variables to OpenCmdResult().  Hopefully fixes
492   bug #14 when running on FreeBSD.
493
494 Revision 1.420  1999/11/21 18:30:16  ajc
495 * Protected cmd_move() from buffer overrun (no longer crashes the server)
496 * cmd_chat() -- truncate input at 100 characters to prevent buffer overruns.
497   Also handle broken client sockets properly.  (Thanks to DME for bug report)
498
499 Revision 1.419  1999/11/19 01:57:40  ajc
500 * Fixed a *serious* memory leak in the database function wrappers.
501 * Updated version number to 5.60 -- run setup when installing this version.
502
503 Revision 1.418  1999/11/18 03:29:20  ajc
504 * Changed the order of parameters in <.A>ide <S>ystem config into a more
505   logical grouping.
506
507 Revision 1.417  1999/11/18 02:31:50  ajc
508 * Updated some of the documentation
509 * Brought the internal version number up to 5.60
510
511 Revision 1.416  1999/11/17 04:15:05  ajc
512 * Removed the session_count() function.  Instead, keep a reference count
513   updated when sessions begin and end.
514 * Replaced fixed number of worker threads with lower and upper limits; current
515   code now tries to make thread count == session count, within these limits
516
517 Revision 1.415  1999/11/15 03:17:39  ajc
518 * Put lockfile in /tmp instead of in /var/lock.   The latter is not guaranteed
519   to exist, nor is it guaranteed to be writable by BBSUID
520   (Resolves bug #11 from the Bugzilla repository)
521
522 Revision 1.414  1999/11/15 03:07:24  ajc
523 * Fixed the network-wide vCard purge logic so that it (1) actually works,
524   and (2) forces a netproc run immediately when a purge is entered
525
526 Revision 1.413  1999/11/09 21:20:44  nbryant
527 * configure.in: include <sys/types.h> when doing checks which require <utmp.h>
528   (should fix Bug #10 on FreeBSD)
529
530 Revision 1.412  1999/11/05 03:53:47  ajc
531 * Issue 'cancel' messages for vCard when a user is deleted.
532 * Try to delete 'cancel' messages locally after they've been distributed.
533
534 Revision 1.411  1999/11/03 04:01:20  ajc
535 * Fixed buffer overrun problems in cmd_rchg(), cmd_hchg(), and cmd_uchg()
536 * Removed my email address as the feedback content from the docs; replaced
537   it with a reference to the Citadel/UX web site.
538
539 Revision 1.410  1999/11/02 19:51:23  ajc
540 * Fixed timeout problem for remote client sessions (all timeouts were set to
541   1 second ... probably a temporary hack that was missed in the cleanup)
542
543 Revision 1.409  1999/11/02 03:03:27  ajc
544 * Several fixes to msgbase.c and netproc.c to prevent corrupted incoming
545   network traffic from crashing the server.  Reject bad messages.
546
547 Revision 1.408  1999/11/01 04:21:34  ajc
548 * Fixed a concurrency bug which crashed the server when multiple sessions
549   terminated simultaneously.
550
551 Revision 1.407  1999/11/01 00:54:02  ajc
552 * CtdlFetchMessage() - generate a "<no text>" message body if there's none
553   on disk.  Too much stuff goes haywire if there's no M field.
554
555 Revision 1.406  1999/10/31 18:17:17  ajc
556 * Fixed buffer overrun in cmd_rchg()
557 * Call master_cleanup() when time_to_die==1 for proper shutdown
558
559 Revision 1.405  1999/10/31 16:26:55  ajc
560 * Fixed incorrect assignment of new session ID's
561
562 Revision 1.404  1999/10/31 04:17:17  ajc
563 * Fixed a bug which was crashing the server during very long message entry.
564
565 Revision 1.403  1999/10/29 01:48:45  ajc
566 * database.c: Removed arbitrary limit on maximum number of sessions
567
568 Revision 1.402  1999/10/29 01:03:03  ajc
569 * Debugged all possible ways for a session to terminate; do them cleanly.
570 * Assign session numbers in a more portable and less arbitrary way.
571
572 Revision 1.401  1999/10/28 19:50:55  ajc
573 * Fixed a problem where the client protocol would spit out two responses
574   and therefore get out of sync if ASUP command set the access level to
575   0 and therefore deleted the user (thanks to Eric McDonald)
576
577 Revision 1.400  1999/10/28 05:08:49  ajc
578 * Removed all of the thread cancellation cruft that is no longer necessary
579 * Moved the now non-system-dependent RemoveContext() out of sysdep.c (now
580   it's part of cleanup() in citserver.c)
581 * Removed all references to pthread_* from all modules except sysdep.c
582
583 Revision 1.399  1999/10/28 03:20:17  ajc
584 * Fixed the problem of worker threads waking up prematurely.
585 * 'QUIT'-terminated sessions now exit properly.
586
587 Revision 1.398  1999/10/27 04:26:58  ajc
588 * Initial hack of worker-thread rearchitecture.  Right now it is successfully
589   dispatching worker threads to active client sockets (and to the master
590   socket too, of course).  Removing sessions is currently broken.
591
592 Revision 1.397  1999/10/26 20:20:29  ajc
593 * Removed the auto-reconnect stuff... it was locking the client in an active
594   loop more often than it was reconnecting.
595
596 Revision 1.396  1999/10/26 13:59:11  ajc
597 damn bugs
598
599 Revision 1.395  1999/10/26 03:48:39  ajc
600 * Shuffled around the order of events when a thread is terminating.  All
601   mutex operations now happen prior to the freeing of the CitContext structure,
602   otherwise begin_critical_section() and end_critical_section() try to
603   manipulate the context's mutex count when there isn't any context.
604
605 Revision 1.394  1999/10/26 03:21:16  ajc
606 * Changed a lot of strncpy() calls to safestrncpy() and replaced most of their
607   hardcoded size arguments with 'sizeof' based arguments.
608
609 Revision 1.393  1999/10/24 19:22:51  nbryant
610         * Makefile.in, configure.in: added --enable-icq flag; made checks for
611           authentication libraries more intelligent.
612
613 Revision 1.392  1999/10/23 03:39:12  ajc
614 * Finished moving vCard functionality to the new message base functions.
615
616 Revision 1.391  1999/10/21 00:50:14  ajc
617 * Finished up the flags and replication checks in CtdlSaveMsgPointerInRoom().
618
619 Revision 1.390  1999/10/20 16:46:27  ajc
620 * More code shuffle.  Added some flags to CtdlSaveMessagePointerInRoom() and
621   enabled the MOVE command to also do a "copy" operation (actually just
622   creates a second link and bumps the ref count).  Implemented "<C>opy" in
623   the client.
624
625 Revision 1.389  1999/10/20 16:07:48  ajc
626 * Wholist fixes for users who are in chat mode
627
628 Revision 1.388  1999/10/20 03:42:29  ajc
629 * In the wholist, only show <private room> if the user viewing the list
630   doesn't know that room.  Otherwise show the name.
631
632 Revision 1.387  1999/10/20 02:59:22  ajc
633 * Code reorganization.  Making it easier to move/copy messages without
634   duplicating existing code.
635
636 Revision 1.386  1999/10/17 02:25:18  ajc
637 * Discovered a huge design flaw in the replication algorithm.  Ripped it
638   out and replaced it with something a bit more robust.
639
640 Revision 1.385  1999/10/16 05:30:17  ajc
641 * Changes to message replication code.  Don't do server-side hooks during
642   an ENT3 command.  Also fixed a bug in cmd_whok() that caused crashes
643   after a file format change.
644
645 Revision 1.384  1999/10/14 03:04:16  ajc
646 * Finished the netproc side of Z (zap/supersede) processing for replication
647
648 Revision 1.383  1999/10/13 04:24:18  ajc
649 * Added search-by-header-fields to CtdlForEachMessage(), and then to the
650   server MSGS command.  This will have lots of uses.
651
652 Revision 1.382  1999/10/13 01:36:39  ajc
653 * Starting some work on network zap (supersede) mode for replication
654
655 Revision 1.381  1999/10/08 02:55:57  ajc
656 * More vCard-related debugging
657
658 Revision 1.380  1999/10/07 02:58:46  ajc
659 * Semi-broken vCard replacement implementation in place.
660 * Added "Z" (Zap, supersede) field to message format
661
662 Revision 1.377  1999/10/04 03:19:52  ajc
663 * We now have a housekeeping thread and a housekeeping queue.
664
665 Revision 1.376  1999/10/03 21:48:21  ajc
666 * Added serv_upgrade.h to automagically convert pre-5.55 format user records
667   to 5.55 format user records and generate vCards.
668
669 Revision 1.375  1999/09/29 21:13:17  ajc
670 * CtdlWriteObject() can now store objects in personal rooms for any specified
671   user -- rather than only the current user or non-personal rooms.
672
673 Revision 1.374  1999/09/29 17:26:56  ajc
674 * serv_vcard.c: fixed crashola bug in cmd_greg()
675 * tools.c: simplified and improved the string tokenizer.  Now it runs in a
676            single pass with no intermediate buffer.
677
678 Revision 1.373  1999/09/28 03:27:37  ajc
679 * Fully migrated cmd_greg() and cmd_regi() into serv_vcard (still has bugs)
680
681 Revision 1.372  1999/09/27 03:33:40  ajc
682 * cmd_regi() is now in serv_vcard and writes to the vcard instead of to the
683   usersupp file.  Still needs tweaking.
684
685 Revision 1.371  1999/09/24 03:32:19  ajc
686 * "read my vCard" and "write my vCard" are written and tested.
687
688 Revision 1.370  1999/09/24 02:54:17  ajc
689 * Worked a little more on the vCard stuff.  The serv_vcard module is now in
690   place, and a "read my vcard" function is there; "write my" is next...
691
692 Revision 1.369  1999/09/23 03:07:56  ajc
693 * The vCard 'class' is now linked into the server, though it's not really
694   functional yet.  Its constructors/destructors are debugged, though.
695
696 Revision 1.368  1999/09/19 21:28:33  ajc
697 * Finished off the message architecture stuff with a new class of hooks to
698   enable future server-side handlers.
699
700 Revision 1.367  1999/09/19 15:57:06  ajc
701 * migrated cmd_ent3() to CtdlSaveMessage()
702
703 Revision 1.366  1999/09/19 05:13:57  ajc
704 * Debugged the new version of CtdlWriteObject()
705
706 Revision 1.365  1999/09/16 03:23:23  ajc
707 * Did most of the migration from save_message() to CtdlSaveMsg().  The
708   latter builds a "struct CtdlMessage" (so we can run server-side handlers
709   against it later on), then serializes it and stores to disk.
710 * BROKEN BUILD ALERT!!  cmd_ent3() and CtdlWriteObject() are still not
711   migrated.  They are stubbed out and will MALFUNCTION if used right now!!
712
713 Revision 1.364  1999/09/07 01:42:42  ajc
714 * cmd_msg3() now uses serialize_message() for its output.  All message
715   commands will eventually exist as a "struct CtdlMessage" at some point
716   so that we can install server-side handler hooks.
717
718 Revision 1.363  1999/09/07 00:04:13  ajc
719 * netproc.c: put outgoing messages into the use table, too -- this prevents
720   locally originated messages from showing up again if a remote system is
721   misconfigured and spools them back to us.
722
723 Revision 1.362  1999/09/06 03:39:15  ajc
724 * citadel.c: run strproc() on new passwords
725
726 Revision 1.361  1999/09/03 17:50:26  playcow
727 For URL view, don't prompt user to select url if there is only one.  Display
728 <U>RL View prompt if message contains url(s). -Ben
729
730 Revision 1.360  1999/09/02 02:09:59  ajc
731 * msgbase.c: new function serialize_message() for future use
732
733 Revision 1.359  1999/09/01 21:09:25  ajc
734 * database.c: display the GDBM version string on startup
735
736 Revision 1.358  1999/09/01 02:36:34  ajc
737 * Actually _enforce_ the max msg len limit
738
739 Revision 1.357  1999/09/01 01:51:48  ajc
740 * Added the ability to handle embedded URL's from the text client
741
742 Revision 1.356  1999/09/01 01:02:47  ajc
743 * Implemented "maximum message length" in global system config
744
745 Revision 1.355  1999/08/31 00:57:17  ajc
746 * Handle multipart/alternative properly during legacy message outputs.
747   Basically it just prints the first alternative and skips the rest.
748
749 Revision 1.354  1999/08/29 21:12:24  ajc
750 * Made some changes to the output of MIME (especially multipart) messages.
751
752 Revision 1.353  1999/08/29 19:56:43  ajc
753 * HTML updates
754
755 Revision 1.352  1999/08/24 02:01:03  ajc
756 * html.c: added.  This is an overly simplistic HTML-to-text converter.
757
758 Revision 1.351  1999/08/21 18:37:29  ajc
759 * Minor cosmetic cleanup.  No code changes.
760
761 Revision 1.350  1999/08/21 05:15:34  ajc
762 * mailinglist.c, netmailer.c: fixed to allow list submissions from all posters
763   on a Citadel network rather than only on the local system.
764
765 Revision 1.349  1999/08/08 00:25:45  ajc
766 * Made one more byte available in locate_host() and in all the structs which
767   its output gets written to (client can display 24 positions but we were only
768   saving 23).
769
770 Revision 1.348  1999/08/07 16:34:38  nbryant
771 * serv_icq.c: warning fixes
772
773 Revision 1.347  1999/08/06 02:57:26  ajc
774 * locate_host.c: use strdoop() and phree() instead of strdup() and free()
775 * serv_icq.c: run learned IP's through Citadel's locate_host() & put in Wholist
776
777 Revision 1.346  1999/08/05 17:58:59  ajc
778 * RWHO command now returns express message code in postion 3
779
780 Revision 1.345  1999/08/04 02:21:45  ajc
781 * Fixed some bugs in the ICQ metaclient, and documented the new protocol cmds
782
783 Revision 1.344  1999/08/03 11:34:35  ajc
784 * Added client_icq.c and client_icq.h
785
786 Revision 1.343  1999/08/03 03:14:51  ajc
787 * Wrote the client side of the ICQ gateway.  Now on to other projects.  :)
788
789 Revision 1.342  1999/08/03 01:52:06  ajc
790 * Redesigned the client protocol commands for dealing with ICQ
791 * Implemented page function priority ordering to prevent pages from being
792   simultaneously delivered over multiple IM systems
793 * Migrated serv_icq.* into the Makefile
794
795 Revision 1.341  1999/08/01 21:36:30  ajc
796 * EXTREME coolness.  The server side of the ICQ metaclient is now working.
797   It is set up using ICQL and ICQA commands, it automatically logs the user
798   onto ICQ along with Citadel, and displays all non-offline ICQ contacts
799   in the Wholist.
800
801 Revision 1.340  1999/07/31 07:18:01  ajc
802 * Restructured the express message infrastructure, adding a class of function
803   hooks for the addition of multiple paging modules with message routing
804
805 Revision 1.339  1999/07/30 22:20:19  ajc
806 * Applied bugfix patches contributed by Vaggelis Tsirkas:
807   * rooms.c: buffer overrun fix
808   * room_ops.c: cmd_rdir() now behaves better when directory doesn't exist
809
810 Revision 1.338  1999/07/30 03:32:24  ajc
811 * Added strdoop(), a leak-checked version of strdup()
812 * Small fixes to new API functions in msgbase.c
813 * ICQ metaclient stores/reads config using the message base API functions
814
815 Revision 1.337  1999/07/29 03:36:37  ajc
816 * msgbase.c: reorganized.  output_message() now uses CtdlFetchMessage(),
817   cmd_msg3() now fetches directly from disk and spews to the client.
818
819 Revision 1.336  1999/07/28 04:02:37  ajc
820 * Server modules are now labelled with their RCS ID instead of a complex and
821   manually-updated data structure.
822
823 Revision 1.335  1999/07/28 03:50:24  ajc
824 * serv_expire.c: expire-by-age now calls CtdlFetchMessage() instead of
825   calling output_message() in MT_DATE mode.
826 * msgbase.c: removed MT_DATE mode ('twas a sleazy hack)
827
828 Revision 1.334  1999/07/27 22:47:26  ajc
829 * Implemented new data type "CtdlMessage" which will eventually be used as
830   widely as possible to represent a message in memory.
831 * Implemented CtdlFetchMessage() which is intended to become the back-end to
832   output_message() as well as a bunch of other things.
833
834 Revision 1.333  1999/07/27 20:00:24  ajc
835 Removed all references to CC->msglist and CC->num_msgs, and all utility
836 functions which relied upon them.  Citadel Is Now Better.
837
838 Revision 1.332  1999/07/27 19:32:22  ajc
839 Removed serv_upgrade.c and all references to it in Makefile.in
840 Reworked new-mail-count to not use MessageFromList() etc.
841
842 Revision 1.331  1999/07/25 02:59:37  ajc
843 Fixed reference count problem in cmd_move()
844
845 Revision 1.330  1999/07/24 22:50:38  ajc
846 Continued replacing references to [get|put]_msglist() with better code.
847 For some reason, cmd_msgs() still doesn't always work right.
848
849 Revision 1.329  1999/07/24 22:16:41  ajc
850 Experimenting with automatic updating of ChangeLog by CVS.  Simply twiddle
851 ChangeLog a bit (i.e. by adding or removing a newline from the end of the
852 file) before issusing "cvs commit", and the comments recorded by CVS will
853 automatically appear at the beginning of ChangeLog.
854
855 Revision 1.328  1999/07/24 22:14:21  ajc
856 cmd_move() now uses CtdlDeleteMessages().
857 WARNING: build is temporarily broken.  Currently removing all references
858 to the "msglist" kept in CitContext.  It's ugly and must die.
859
860 Thu Jul 22 22:26:50 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
861         * Moved message deletion into new API function CtdlDeleteMessages()
862         * Added CtdlWriteObject() to store generic data in the msgbase
863         * Fixed really dumb error that prevented network msgs from posting
864
865 Tue Jul 20 22:14:54 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
866         * Moved the actual work done in cmd_msgs() into a new API function
867           called CtdlForEachMessage() which is supplied a callback function.
868
869 Mon Jul 19 23:24:18 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
870         * Keep the (unqualified) content-type in the SuppMsgInfo record.  We'll
871           be using this shortly to search rooms for specific object types.
872
873 Sun Jul 18 14:53:16 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us> 
874         * Changes to dynloader et al to handle ICQ module being written
875         * serv_icq.c, serv_icq.mk: added (separate makefile is temporary)
876
877 1999-07-17 Nathan Bryant <bryant@cs.usm.maine.edu>
878         * chkpwd.c: DELETED CVS REVISION 1.3 (backed out Art's last change)
879           use 'cvs update -r 1.2 chkpwd.c; cvs update -A chkpwd.c' NOW to
880           avoid problems with working directories.
881         * Makefile.in: don't install chkpwd setuid if make install isn't
882           being run as root.
883         * citadel.spec: chmod u+s chkpwd during %install stage
884
885 Fri Jul 16 18:39:04 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
886         * PEXP and GEXP no longer trip the idle time display
887         * Fixed bug which duplicated incoming private mail to Trashcan
888         * Improved auto-reconnect by NOT using SIGPIPE and longjmp(); also
889           implemented a 15 second delay to wait for a crashed server to restart
890         * Relaxed the security check in chkpwd.c a bit; it was just flat-out
891           preventing logins on my system otherwise
892
893 Thu Jul 15 22:57:32 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
894         * eliminate redundant "name" parameter in [l]putuser(), now uses
895           usbuf->fullname to guarantee the correct name for the index
896
897 1999-07-12 Nathan Bryant <bryant@cs.usm.maine.edu>
898         * Makefile.in, configure.in: link netproc with gdbm
899         * netproc.c: only include gdbm.h if HAVE_GDBM_H
900         * user_ops.c: warning fix
901
902 Mon Jul 12 19:51:30 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
903         * Mail is now saved in both sender and recipient mailboxes.  This is
904           structured in a way that will allow a separate "outbox" room and/or
905           multiple recipients in the future.
906
907 Sun Jul 11 18:46:48 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
908         * netproc.c: msgfind() no longer uses the timestamp as a message-ID
909           when no other message-ID is available (it screws up the loopzapper)
910         * room_ops.c: eliminate room name parameter in putroom() and its ilk;
911           get data from quickroom.QRname instead; prevents incorrect indexes
912         * Tentative implementation of "personal rooms" (user-private namespace)
913         * Added supplementary message info records for info that may change
914           at some time later than when the message is saved (i.e. ref counts)
915         * Implemented msg reference count increment/decrement; delete messages
916           whose reference count reaches zero
917
918 Wed Jul  7 23:25:09 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
919         * control.c: create citadel.control if it doesn't exist (yikes!)
920         * serv_expire.c: purge mailbox rooms belonging to non-existent users
921         * user_ops.c: don't delete user's mailbox at user-delete time
922
923 Mon Jul  5 17:01:29 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
924         * utilsmenu: removed menu items for defunct utilities
925
926 Mon Jun 28 16:24:10 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
927         * Changed any remaining references to UUCP, to "Internet" instead.
928
929 Thu Jun 24 11:13:23 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
930         * added server command line option "-f" to defrag databases on startup
931         * control.c: better performance and reliability in [get|put]_control()
932         * netproc.c: Finished the loopzapper
933
934 Mon Jun 21 00:04:15 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
935         * netproc.c: started writing a vortex checker.  Not finished.
936
937 Wed Jun  9 23:34:25 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
938         * Replaced all code that generated temporary filenames with calls to
939           tmpnam().  Rewrote using tmpfile() where possible.
940
941 Thu Jun  3 11:35:18 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
942         * base64.c: mapped fi and fo to stdin and stdout using
943           actual code rather than assignment at declaration time
944           (several users of Red Hat Linux 6.0 reported problems)
945
946 Fri May 21 20:05:00 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
947         * Added function CtdlGetDynamicSymbol() for dynamic symbol allocation
948         * server.h: Changed discrete #define's to enum's where appropriate
949         * sysdep.c: Changed the startup message to give credit to the whole
950           development team :)  Also made the message more GNU-ish.
951
952 Thu May 20 20:01:30 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
953         * database.c: print log messages for file defragmentations
954         * citserver.c: implemented CtdlAllocUserData() and CtdlGetUserData()
955           for arbitrary per-session data storage (by modules etc.) without
956           having to add fields to struct CitContext
957         * msgbase.c: removed "desired_section" from struct CitContext and
958           implemented it using CtdlGetUserData() as a test.
959
960 Wed May 19 19:30:28 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
961         * commands.c, commands.h, routines.c: began color scheme changes
962
963 1999-05-15 Nathan Bryant <bryant@cs.usm.maine.edu>
964         * configure.in: Added untested support for BSDI 4.x.
965
966 1999-05-13 Nathan Bryant <bryant@cs.usm.maine.edu>
967         * acconfig.h, configure.in, routines.c: fix for certain SYSV variants
968           which lack utmp.ut_host
969         * citadel.h, file_ops.c, msgbase.c, netproc.c, serv_chat.c: fix
970           namespace collision with <sys/stream.h> on aforementioned SYSV
971           variant
972         * configure.in, getutline.c: check for paths.h
973         * configure.in, Makefile.in: check for -lsocket and -lnsl
974
975 1999-05-11 Nathan Bryant <bryant@cs.usm.maine.edu>
976         * chkpwd.c: fixed excessive paranoia; it used to refuse to run when
977           invoked by root and BBSUID != 0
978         * Makefile.in: ignore errors while installing /etc/pam.d/citadel
979
980 1999-04-27 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
981         * file_ops.c: fixed NDOP to not crash the server if it has trouble
982           with a download file
983         * netpoll.c: upped default packet size
984
985 Mon Apr 26 22:06:57 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
986         * Repaired IGnorant security hole blunder re. citmail
987
988 Sun Apr 25 12:44:08 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
989         * serv_chat.c: notify user of number of participants upon entering chat
990         * Built the 5.53 distribution
991
992 Wed Apr 21 22:23:13 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
993         * aidepost.c: add -r flag to allow posting to rooms other than Aide>
994         * serv_expire.c: now posts transcripts of all auto-purged rooms/users
995
996 Tue Apr 20 12:45:55 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
997         * messages.c: downloading more than MAX_MSGS messages now truncates
998           (off the beginning of the list) rather than crashing.
999
1000 Mon Apr 19 12:11:48 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1001         * whobbs.c: auto-detect when being called from a webserver, and act
1002           as a CGI (print HTTP headers and HTML output)
1003
1004 1999-04-18 Nathan Bryant <bryant@cs.usm.maine.edu>
1005         * serv_chat.c: fixed some potential buffer overruns (thanks dme)
1006
1007 Wed Apr 14 21:32:28 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1008         * Makefile.in: chmod 4755 citmail to prevent citmail from aborting
1009           when called from sendmail due to citadel.config security check
1010
1011 1999-04-13 Nathan Bryant <bryant@cs.usm.maine.edu>
1012         * dynloader.c: OpenBSD places underscores in front of symbol names
1013         * Makefile.in: fixed a few sillies
1014         * aidepost.c, citmail.c, file_ops.c, logging.c, msgbase.c, netmailer.c,
1015           netproc.c, rcit.c, routines.c, serv_upgrade.c: fixed time_t handling
1016           (have to cast it to long for printf/scanf)
1017
1018 Mon Apr 12 22:13:26 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1019         * aidepost.c: rewrote to unlink temp file before writing to it so that
1020           it will automatically go away if interrupted. Also ran indent -kr -i8
1021
1022 1999-04-12 Nathan Bryant <bryant@cs.usm.maine.edu>
1023         * configure.in, Makefile.in: taught it how to generate OpenBSD shared
1024           libraries
1025         * config.c, sysdep.c: fix -h option not setting proper modules dir
1026         * configure.in, citadel.spec: make --enable-chkpwd the default
1027         * setup.c: don't chown chkpwd
1028
1029 1999-04-11 Nathan Bryant <bryant@cs.usm.maine.edu>
1030         * configure.in: another OpenBSD fix, but we're still not quite there yet
1031         * serv_chat.c: warning fix
1032
1033 Thu Apr  8 22:51:28 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1034         * config.c: now requires a setup run for *any* rev level difference
1035         * Updated docs & confs for 5.53b1 release
1036         * setup.c: sets the 0600 permission bits on citadel.config that
1037           is checked for in config.c
1038
1039 1999-04-08 Nathan Bryant <bryant@cs.usm.maine.edu>
1040         * citserver.c: improved is_public_client(), also if a public_client
1041           only supplies a numeric address, attempt to resolve it
1042         * locate_host.c: verify that the forward DNS matches the reverse
1043         * locate_host.c, locate_host.h: more general interface
1044         * configure.in, acconfig.h: fixes for Digital UNIX
1045
1046 Wed Apr  7 21:36:16 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1047         * Implemented "access level required to create rooms" (client & server)
1048
1049 1999-04-07 Nathan Bryant <bryant@cs.usm.maine.edu>
1050         * configure.in: updated help messages, OpenBSD support
1051         * setup.c: if /etc/inittab doesn't exist, don't ask to create an
1052           entry in it
1053         * server.h, sysdep.c: fix a potential deadlock/data corruption bug
1054         * room_ops.c: fixed the 'gdbm error: Illegal data' message when
1055           deleting a room which had never been posted to
1056         * user_ops.c: include errno.h
1057         * dynloader.c: fix for OpenBSD
1058
1059 1999-04-06 Nathan Bryant <bryant@cs.usm.maine.edu>
1060         * Makefile.in, configure.in, getutline.c, sysdep.c:
1061           fixes/bug workarounds for FreeBSD
1062
1063 1999-04-03 Nathan Bryant <bryant@cs.usm.maine.edu>
1064         * Makefile.in, configure.in, chkpwd.c, acconfig.h: support for
1065           `chkpwd', a setuid helper program for machines which use shadow
1066           passwords (configure --enable-chkpwd)
1067         * Makefile.in, configure.in, auth.c, citadel.pam, user_ops.c: support
1068           for PAM or shadow passwords (configure --with-pam)
1069         * Makefile.in: made some messages simpler
1070         * citadel.spec: updated for 5.53; correct name of tarball; build with
1071           --enable-chkpwd and --with-pam; add defattr tags so rpm's can be
1072           built by non-root user
1073         * commands.c: cosmetic cleanup
1074         * config.c: (security/paranoia) check permissions on citadel.config
1075         * configure.in: check for ncurses if we can't find curses
1076         * dynloader.c: warning fix
1077         * sysdep.c: don't complain if initgroups() fails
1078         * citadel.c: fix systems with SYSV-style signal handling (e.g. libc5)
1079         * Makefile.in: New! Improved! Cleaner! Shinier!
1080
1081 Sun Mar 21 14:21:47 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1082         * messages.c: cosmetic cleanups to message reading loop
1083
1084 Sat Mar 13 21:33:19 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1085         * commands.c: use bright colors by default in color mode
1086         * citserver.c: initialize wholist fields with (not logged in) etc.
1087
1088 1999-03-08 Nathan Bryant <bryant@cs.usm.maine.edu>
1089         * sysdep.c: call DLoader_Init() with an absolute path so that gdb can
1090           find module symbols
1091         * database.c: bail out if opening databases fails
1092
1093 Sat Mar  6 01:55:55 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1094         * serv_chat.c: use memfmout(), *not* cprintf() to transmit express
1095           messages.  Calling cprintf() on strings >256 bytes crashes the server
1096         * msgbase.c: minor logging fix in save_message()
1097
1098 1999-03-05 Nathan Bryant <bryant@cs.usm.maine.edu>
1099         * sysdep.c: add undocumented -r flag to citserver to prevent it from
1100           dropping root permissions.
1101         * sysdep.c: also drop supplementary groups
1102
1103 1999-03-04 Nathan Bryant <bryant@cs.usm.maine.edu>
1104         * config.c: error checking in put_config()
1105         * setup.c: chgrp files to the login group associated with BBSUID
1106         * sysdep.c: copyright 1987-1999; drop root perms; load modules and call
1107           master_startup() after dropping perms
1108
1109 Wed Mar  3 00:00:55 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1110         * Prevent buffer overruns in lowercase_name in [get|put]user()
1111         * client_chat.c: use citedit() for page composition
1112
1113 Sat Feb 27 07:47:36 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1114         * rooms.c: download_to_local_disk() prompts for a filename if a blank
1115           filename was supplied to it (for attachments without names)
1116         * mime_parser.c: strip leading whitespace in content_type & disposition
1117
1118 1999-02-24 Nathan Bryant <bryant@cs.usm.maine.edu>
1119         * configure.in: improved check for pthreads
1120         * configure.in, routines.c, acconfig.h: check for ut_type in struct utmp
1121         * configure.in, Makefile.in: support for building server modules as
1122           relocatable objects for BSDI (which still uses a.out *gag* *choke*)
1123         * configure.in: compiler choice & flags for BSDI; check for libtermcap
1124         * database.c: don't use a critical section in open_databases()
1125         * housekeeping.c: use getfloor()/putfloor() instead of
1126           lgetfloor()/lputfloor() in check_ref_counts()
1127         * mime_parser.c: include <errno.h>
1128         * msgbase.c: include <limits.h>
1129         * sysdep.c: hacks for BSDI. use signals to fake thread cancellation;
1130           don't call master_cleanup() directly from signal handler.
1131         * routines.c: prototype getutline() if necessary
1132         * getutline.c: stupid bugfix
1133         * acconfig.h, configure.in, locate_host.c, server.h: work around
1134           nonreentrant gethostbyaddr() on BSDI
1135
1136 Mon Feb 15 22:59:00 EST 1999 Vaggelis Tsirkas
1137         * citadel.c: increased hostname buffer size to handle very big names
1138
1139 1999-02-15 Nathan Bryant <bryant@cs.usm.maine.edu>
1140         * sysdep.c(main): initialize alen before call to accept()
1141
1142 1999-02-04 Nathan Bryant <bryant@cs.usm.maine.edu>
1143         * configure.in: improved check for cygwin
1144         * configure.in, routines.c: access utmp directly instead of calling
1145           `who' if getutline() is available.
1146         * configure.in, Makefile.in, getutline.c: replace getutline() on
1147           systems which don't have it
1148         * routines.c: now always access utmp directly unless we can't find
1149           utmp.h
1150
1151 1999-02-02 Nathan Bryant <bryant@cs.usm.maine.edu>
1152         * Fixes for Cygwin:
1153           - ifdef out file download methods that require named pipes (client)
1154           - include pthread.h and gdbm.h only if they are present (fixes
1155             auto dependency generation)
1156           - include snprintf.h where needed
1157           - handle .exe suffixes for "make install"
1158
1159 Tue Feb  2 22:15:08 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1160         * Overhauled the express messaging system (again)
1161
1162 Mon Feb  1 19:48:04 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1163         * messages.c: implemented client download of MIME attachments
1164
1165 Sun Jan 31 18:29:18 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1166         * Added qpdecode.c to the distribution (decodes quoted-printable)
1167         * Finished the MIME parser
1168         * Gave MSG0 a reasonable behaviour for MIME messages
1169         * Added the OPNA command for downloading attachments
1170
1171 Sat Jan 30 18:39:53 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1172         * Look for citadel.rc in current directory if not found elsewhere
1173         * More work on the MIME parser
1174         * Added base64.c to the distribution
1175
1176 1999-01-29 Nathan Bryant <bryant@cs.usm.maine.edu>
1177         * fixes for IRIX (thanks to wr and family for use of the Indy):
1178           - use memset()/memcpy() instead of bzero()/bcopy() in all cases
1179           - configure updates
1180           - handle `long' pid's
1181           - a few other little bits
1182
1183 Mon Jan 25 21:23:07 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1184         * Fixed bug in save_message() which crashed the server on mail to sysop
1185         * Rewrote pop_march() to be smarter about <G>oto heuristics
1186
1187 Sat Jan 23 14:32:19 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1188         * Changed internal storage of express messages from a linked list to
1189           a single, resizable buffer.
1190         * Added a "room order" key to the room record, to allow some control
1191           over room listing order.
1192         * Made the room list commands aware of the room order key.
1193         * Overhauled <G>oto heuristics to pay attention to floor & room order
1194
1195 Wed Jan 20 19:21:51 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1196         * Added some more code to the unfinished MIME parser
1197         * Changed module loading path to simply "modules" because after calling
1198           get_config(), the cwd is guaranteed to be the correct BBS directory.
1199
1200 Tue Jan 19 21:28:29 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1201         * Fixed a bug in the user editing command (client side)
1202         * Started a rewrite of the MIME parser
1203
1204 Thu Jan 14 21:21:15 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1205         * Brought over the mime_parser from WebCit and began preliminary work
1206           on supporting MIME format messages.
1207
1208 Tue Jan 12 22:30:00 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1209         * Various changes to begin work on support for MIME messages
1210                 - Defined format type 4 for MIME
1211                 - msgbase.c: *temporary* hacks in output_message() for Type 4
1212                 - citmail.c: added more robust header parsing, and support
1213                              for Type 4.  Also eliminated the crappy built-in
1214                              SMTP server.
1215                 - Updated some of the technical documentation
1216
1217 Sun Jan 10 13:34:36 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1218         * Fixed access to page log room
1219
1220 Fri Jan  8 12:35:09 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1221         * control.c: include <limits.h> to fix PATH_MAX undefined
1222         * serv_chat.c: made the following changes to cmd_sexp() --
1223                 * Send zero-length message to check only, don't send
1224                 * Send "-" message on the command line to invoke
1225                   the SEND_LISTING transfer mode for a multi-line message
1226         * Added facilities to log all pages to a room (site configurable)
1227
1228 Tue Jan  5 23:24:52 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1229         * Replaced all occurances of malloc(), realloc(), and free() in the
1230           server and server-modules with mallok(), reallok(), and phree().
1231           Wrote macros and a set of leak-tracking functions.
1232
1233 Sun Jan  3 20:38:45 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1234         * Documentation changes
1235
1236 Fri Jan  1 01:01:45 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1237         * Fixed security problem relating to private rooms
1238
1239 Wed Dec 30 20:10:52 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1240         * sysdep.c: put a bigger string buffer into lprintf() to avoid overruns
1241
1242 Sat Dec 26 16:56:46 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1243         * internetmail.config: commented this file more clearly
1244
1245 Wed Dec 23 20:42:49 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1246         * citadel.c: added some experimental code to automatically reconnect
1247           to the server if the connection is broken.  For some reason, it only
1248           works once.
1249
1250 Wed Dec 23 18:47:12 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1251         * sysdep.c: ignore SIGPIPE.  This keeps broken connections from
1252           crashing the whole server.
1253         * Tagged everything for the official 5.50 release.
1254
1255 Mon Dec 21 07:54:20 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1256         * housekeeping.c: call kill_session() with session_to_kill,
1257           not ccptr->cs_pid (was crashing the server)
1258
1259 Sat Dec 19 13:57:48 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1260         * Added "-i" flag to netproc to make it skip the export phase.
1261           Updated other programs to call netproc in this way when appropriate.
1262         * Updated network.txt to reflect the usage for netproc (which has
1263           been wrong for several releases)
1264
1265 Thu Dec 17 00:17:04 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1266         * Started removing the word "beta" from the docs and code.
1267           Preparing for an actual release.
1268         * msgbase.c: generate an 'I' field when requested (i.e. on locally
1269           originating messages.  this was breaking parts of the network)
1270
1271 1998-12-15 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1272         * msgbase.c: remove extra call to alias() which was causing
1273           Citadel-to-Citadel mail to fall into the bit bucket.
1274         * msgbase.c: fixed tempfile naming problem that could cause a new
1275           outgoing netmail message to overwrite another if netproc had not been
1276           run in between
1277
1278 1998-12-14 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1279         * More session table stability nonsense
1280
1281 Sun Dec 13 17:40:08 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1282         * sysdep.c, citserver.c: (hopefully) fixed a session table concurrency
1283           bug which was causing the server to occasionally crash.
1284         * removed serv_test.so from the default build
1285
1286 Fri Dec 11 18:50:00 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1287         * setup.c: default value for maxsessions is now 0 (no limit)
1288         * room_ops.c: don't allow users to create a room called "Mail"
1289         * serv_expire.c: fixed "number of messages purged" display
1290         * commands.c: when using color, default to low-intensity colors
1291
1292 Tue Dec  8 07:58:16 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1293         * Beta 2
1294
1295 Sat Dec  5 01:24:03 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1296         * Added a new type of module hook for adding logging functions
1297         * Removed whitespace to left and right of '@' in netmail recipients
1298         * sysdep.c: read citadel.config _before_ initializing loadable modules
1299         * stats.c: fixed segfault resulting from extracting log lines
1300         * Ripped most of the "attachments" stuff out of both the client and
1301           server.  (Thought of a better way to handle it ... LATER.)
1302
1303 1998-12-03 Nathan Bryant <bryant@cs.usm.maine.edu>
1304         * setup.c: create citadel.config with mode 0600
1305         * Makefile.in: don't chmod sendcommand
1306         * serv_upgrade.c: don't create citadel.config if it doesn't already
1307           exist (paranoia)
1308         * setup.c: saner defaults for nodename and fqdn
1309
1310 Wed Dec  2 20:37:05 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1311         * msgbase.c: modified AddMessageToRoom() and all functions that call it
1312           to use a more reliable/accurate method to set quickroom.QRhighest
1313         * weekly.in: don't sort/purge filedir where filedir doesn't exist
1314
1315 1998-12-02 Nathan Bryant <bryant@cs.usm.maine.edu>
1316         * weekly is now generated by configure
1317
1318 Mon Nov 30 19:48:52 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1319         * room_ops.c: added sort_msglist() to move and save operations
1320         * sendcommand.c: added (also updated utils.txt, weekly, Makefile.in)
1321         * BETA 1
1322
1323 Sun Nov 29 23:57:39 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1324         * Fixed cmd_regi() to not display a second result code after xfer
1325         * Makefile.in: Removed "chmod 4755 citmail netmailer"
1326
1327 1998-11-23 Nathan Bryant <bryant@cs.usm.maine.edu>
1328         * citadel.spec: added
1329
1330 1998-11-22 Nathan Bryant <bryant@cs.usm.maine.edu>
1331         * Makefile.in: split install target into install-exec, install-data,
1332           and install-doc subtargets
1333
1334 Sat Nov 21 16:53:30 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1335         * Added a fourth color mode in the client: "user" which turns color
1336           on or off according to a per-user flag stored on the server.  Added
1337           server-side support for this too, of course.
1338         * import.c: removed
1339         * serv_expire.c: finished the code to purge stale visits
1340         * sysdep.c: strip trailing nonprintables in client_gets()
1341         * routines2.c: fixed <.AS> command; all configs now work properly
1342         * Moved num_parms() and all the extract() type functions into tools.c
1343           and removed them from all other files.  Linked in tools.[o|ro] there.
1344         * netproc.c: handled incoming file transfers to correct room directory
1345         * room_ops.c: fixed incorrect naming of files in info and images dirs
1346
1347 Fri Nov 20 20:29:07 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1348         * setup.c: removed all prompts that can be configured from within the
1349           client in order to simplify the setup procedure
1350
1351 Thu Nov 19 23:28:33 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1352         * Fixed serv_upgrade.c and export5.c (found elsewhere) to use a new
1353           export format which treats visits as a separate section
1354         * serv_expire.c: began writing functions to purge rooms and visits
1355           (neither work yet), and added a way to call defrag_databases()
1356
1357 Wed Nov 18 23:51:17 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1358         * Reimplemented 'visit' structs stored globally instead of as
1359           lists-per-user
1360
1361 Tue Nov 17 22:37:48 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1362         * Started implementing global room numbers.
1363
1364 Sun Nov 15 20:32:34 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1365         * room_ops.c: mailbox rooms always appear on the main floor
1366         * made QR_MAILBOX rooms non-editable
1367         * cmd_setr() delete old room record when room name changes
1368           (This causes a big mess that exposes a flaw in the whole design.)
1369         * room_ops.c: users can delete messages from their mailboxes
1370
1371 Thu Nov 12 23:59:13 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1372         * Rewrote cmd_rchg() and also increased the size of the "fakename"
1373           buffer.  Overruns are probably what was causing the crashes.
1374         * Changed the way cmd_ent3() handles mail messages; the previous code
1375           rerouted all private mail to the trash.
1376
1377 Wed Nov 11 17:57:39 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1378         * citserver.c: slight changes to cmd_rchg() and cmd_hchg() [crashes]
1379         * citserver.c, msgbase.c, user_ops.c: hide the owner-prefix of mail
1380           rooms in a couple more places: set_wtmpsupp() and make_message()
1381         * sysdep.c: added an fflush() to lprintf() for "tail -f"-able logs
1382         * serv_expire.c: purge ops are now a command instead of a cleanup
1383           function.  This is probably temporary as well.
1384         * citadel.c: fixed the way <.WL> parses the returned data from a
1385           TIME command.
1386
1387 1998-11-11 Nathan Bryant <bryant@cs.usm.maine.edu>
1388         * serv_upgrade.c: fix uninitialized variable
1389
1390 Wed Nov 11 00:47:32 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1391         * msgbase.c: fixed a bug that was misrouting incoming network msgs
1392         * server.h, database.c: wrapped all GDBM calls in critical sections
1393           to avoid making those calls re-entrantly (gdbm fatal: lseek error)
1394
1395 1998-11-10 Nathan Bryant <bryant@cs.usm.maine.edu>
1396         * Makefile.in: link in snprintf.o where needed
1397
1398 1998-11-09 Nathan Bryant <bryant@cs.usm.maine.edu>
1399         * client_chat.c: eliminate calls to sprintf()
1400         * commands.h, routines.c, routines2.c: warning fix
1401         * commands.c, control.c, cux2ascii.c, file_ops.c, import.c,
1402           ipc_c_tcp.c: eliminate sprintf() calls
1403
1404 Mon Nov  9 19:15:31 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1405         * serv_upgrade.c: added all missing fields to export/import
1406         * serv_expire.c: support per-user purge time when purging users
1407         * user_ops.c: added per-user purge time to AGUP and ASUP commands
1408         * routines.c: added more stuff to <.A>ide <E>dit user
1409
1410 Sun Nov  8 22:56:53 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1411         * serv_expire.c: created; moved message expiry from serv_test.c,
1412           moved user purge from userpurge.c
1413         * userpurge.c: deleted
1414         * routines2.c: finished <.AS> command
1415         * room_ops.c: fixed Aide room access (for some reason, the Aide
1416           room had the QR_MAILBOX flag set)
1417
1418 1998-11-08 Nathan Bryant <bryant@cs.usm.maine.edu>
1419         * useradmin.c: really removed (cvs remove)
1420         * aidepost.c, citadel.c: convert all sprintf() calls to snprintf()
1421         * sysdep.c: fix overrun in lprintf() described by dme/Dead Monkey
1422         * citmail.c, citserver.c: convert all sprintf() call to snprintf()
1423
1424 Sun Nov  8 13:19:36 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1425         * useradmin.c: removed
1426         * utils.doc: removed references to useradmin and sysoputil
1427
1428 Fri Nov  6 20:22:20 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1429         * citadel.h (and related files): removed defunct parameters,
1430           c_defent and c_msgbase (erase your test bbs)
1431         * Implemented CONF server command for site-global configs
1432         * Shuffled yesno() and yesno_d() from routines.c to commands.c
1433         * commands.c: implemented boolprompt()
1434         * routines2.c: started adding CONF questions to <.AS> command
1435         * room_ops.c: began a fix for the mysterious disappearing Aide room
1436
1437 1998-11-05 Nathan Bryant <bryant@cs.usm.maine.edu>
1438         * snprintf.c: warning fix propagated over from gcit
1439
1440 1998-11-04 Nathan Bryant <bryant@cs.usm.maine.edu>
1441         * added RCS Id keyword strings to sources
1442         * citmail.c: reverted to version 1.10
1443
1444 Wed Nov  4 10:53:13 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1445         * messages.c: temporarily set screenwidth to a fixed value of 80
1446           during <P>rint operations.
1447
1448 Mon Nov  2 12:59:03 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1449         * setup.c: looks for 'citadel', 'bbs', or 'guest' in /etc/passwd to
1450           try to get a default for bbsuid if it's currently set to 0
1451         * citmail.c: changed usersupp.eternal to usersupp.usernum (why didn't
1452           it complain about this before?)
1453         * serv_upgrade.c: began writing an "export" command to do sidegrades
1454
1455 Sun Nov  1 18:47:42 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1456         * serv_upgrade.c: cosmetic changes
1457         * Implemented message expiry by date (this really needs to be moved
1458           out of serv_test.c, but where does it belong?)
1459
1460 1998-11-01 Nathan Bryant <bryant@cs.usm.maine.edu>
1461         * serv_upgrade.c: warning fixes
1462         * acconfig.h: remove ANSI_COLOR
1463         * Configure, Makefile.tmpl: removed
1464
1465 Sat Oct 31 20:48:44 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1466         * More stoopid ANSI colour additions here and there.
1467         * ANSI colour selection is now in citadel.rc instead of an option in
1468           the configure script.  "on" "off" and "auto" are available.
1469         * added "build.txt" to the techdoc directory, with LS's build notes
1470
1471 1998-10-31 Nathan Bryant <bryant@cs.usm.maine.edu>
1472         * citadel.c, commands.c, commands.h: set background color to black
1473           before clearing screen, so that we can actually see text on
1474           black-on-white xterms.
1475
1476 1998-10-29 Nathan Bryant <bryant@cs.usm.maine.edu>
1477         * rooms.c: fix color of Mail>
1478         * citadel.c: send ANSI detect sequence after attach_to_server() so the
1479           terminal doesn't send the answerback sequence to the shell if we
1480           can't connect.
1481
1482 Wed Oct 28 20:20:14 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us
1483         * citadel.c: Added a splash of colour to the Wholist
1484
1485 1998-10-28 Nathan Bryant <bryant@cs.usm.maine.edu>
1486         * configure.in: added comments
1487         * mkinstalldirs: new file to be used for `make install'
1488         * aclocal.m4, missing: new files, also swiped from automake
1489         * citadel.c: don't mung the terminal if we can't find citadel.rc
1490         * Makefile.in: added `install' target, `clean' removes
1491           *.mo, rebuild configure when configure.in changes.
1492         * configure.in: check for install and autoconf
1493         * configure.in, Makefile.in: only pass -fPIC to gcc
1494         * policy.c: warning fix for OSF/1 (use memset() instead of bzero())
1495
1496 Tue Oct 27 22:25:42 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1497         * Unified the "unpacked database" format for both upgrades and
1498           sidegrades (also see export5.c elsewhere)
1499         * citserver.c: clear out cmdbuf before reading a command; some server
1500           commands were accidentally extracting parameters from previous cmds
1501         * rooms.c: removed the warning about the ineffectiveness of kicking
1502           users out of public rooms, because the new server can do lockouts
1503
1504 1998-10-27 Nathan Bryant <bryant@cs.usm.maine.edu>
1505         * sysdep.c (client_gets), ipc_c_tcp.c (serv_gets): improved handling
1506           of long lines. 
1507         * Makefile.in: partial support for VPATH builds, autodependency fix
1508
1509 Tue Oct 27 00:08:16 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1510         * minor documentation changes
1511
1512 Sun Oct 25 14:57:40 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1513         * messages.c: fixed an oversight that was allowing attachments even
1514           when disabled in citadel.rc
1515
1516 1998-10-25 Nathan Bryant <bryant@cs.usm.maine.edu>
1517         * routines2.c: warning fix
1518
1519 Sat Oct 24 22:07:56 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1520         * Client: added message expiration policy questions to room edit
1521         * Client: added <.A>ide <S>ystem configuration command
1522
1523 1998-10-24 Nathan Bryant <bryant@cs.usm.maine.edu>
1524         * Makefile.in: Auto dependency generation (may require GNU make, but
1525           does at least function without this feature on OSF/1 make);
1526           Makefile is regenerated when Makefile.in changes (ditto);
1527           `realclean' is now known as `distclean';
1528           portability fixes for older Unix make utilities
1529         * citadel.c, citadel.h, commands.c: make client suspendable
1530
1531 Fri Oct 23 19:34:38 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1532         * setup.c: default node name is now obtained from uname()
1533         * config.c: added put_config()
1534         * policy.c: added, moved GetExpirePolicy() from room_ops.c
1535         * policy.c: implemented cmd_gpex() and cmd_spex()
1536
1537 Wed Oct 21 22:24:48 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1538         * Mail rooms now hide their owner-prefix from the client.
1539         * proxy.c: added configurability and primitive message expiry
1540
1541 1998-10-20 Nathan Bryant <bryant@cs.usm.maine.edu>
1542         * Makefile.tmpl: fix to build client with old Configure script
1543         * configure.in: autologin defaults to enabled if crypt() is available
1544         * room_ops.c: fix improper null-termination bug I introduced
1545
1546 Mon Oct 19 20:52:55 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1547         * Client ability to force display of prompts in Mail rooms, even when
1548           the user has prompting turned off (citadel.rc option)
1549
1550 1998-10-16 Nathan Bryant <bryant@cs.usm.maine.edu>
1551         * sysdep.c (cprintf): generate a newline on truncated buffer
1552         * room_ops.c: exploitable overrun fixes
1553
1554 Thu Oct 15 19:27:32 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1555         * msgbase.c: reimplemented cmd_move()
1556           room_ops.c: wrote AddMessageToRoom() which is used for both entering
1557           and moving messages.
1558         * setup.c: system-default message expire policy of "number of
1559           messages, 150" is now a default configuration instead of a temp hack
1560         * proxy.c: cache dir create now dies on any error except EEXIST
1561
1562 Wed Oct 14 22:41:16 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1563         * Misc code cleanup
1564
1565 1998-10-13 Nathan Bryant <bryant@cs.usm.maine.edu>
1566         * configure.in: don't check for -lcrypt unless autologin is enabled
1567         * file_ops.c: fix another overrun
1568
1569 Mon Oct 12 15:27:21 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1570         * Killed the "rooms" subdirectory (it isn't used anymore)
1571         * dynloader.c: Made dynamically added server commands case-insensitive
1572         * import.c is now serv_upgrade.c, a module
1573         * Removed most of the "level 9" trace messages no longer needed
1574
1575 1998-10-12 Nathan Bryant <bryant@cs.usm.maine.edu>
1576         * Makefile.in: simplified to use pattern rules; files compiled with
1577           -D_REENTRANT go to *.ro to allow the same files to be used with both
1578           client and server
1579         * tools.c, tools.h: new files; misc routines used by both client and
1580           server go here. contains safestrncpy() at the moment.
1581         * rooms.c: fix several exploitable buffer overruns
1582         * sysdep.c: fix infinite loop when long lines are received from the
1583           client; fix exploitable buffer overrun in cprintf()
1584         * ipc_c_tcp.c: fix infinite loop on long line from server
1585         * serv_upgrade.sh: remove uncnsrd-dependent absolute path
1586         * .cvsignore: add *.ro
1587
1588 Sun Oct 11 23:17:48 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1589         * Built some more of the message expiry infrastructure
1590
1591 1998-10-11 Nathan Bryant <bryant@cs.usm.maine.edu>
1592         * citserver.c: fix two more overruns, one of which was preventing
1593           the "From Host" from showing up in the <W>ho listing.
1594
1595 Sun Oct 11 02:51:55 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1596         * Moved "struct visit" and its associated defs from citadel.h to
1597           server.h where they belong
1598         * Set up data structures for room policies (expiry, etc.)
1599
1600 1998-10-10 Nathan Bryant <bryant@cs.usm.maine.edu>
1601         * citserver.c: fix overrun which caused segv's on servers with long
1602           hostnames.
1603
1604 Fri Oct  9 18:34:06 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1605         * user_ops.c: added PurgeStaleRelationships() to do processing at
1606           session logout time to remove visits for rooms which no longer exist
1607         * user_ops.c: implemented NewMailCount()
1608
1609 1998-10-09 Nathan Bryant <bryant@cs.usm.maine.edu>
1610         * serv_chat.c: fix buffer overrun that was resulting in segv's
1611         * serv_chat.c: fix another overrun that could cause sessions to hang,
1612           and cleaned up some other strncpy()-related stuff. DON'T FORGET TO
1613           NULL-TERMINATE DESTINATION BUFFERS AFTER STRNCPY CALLS.
1614
1615 Fri Oct  9 13:22:37 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1616         * Implemented "lazy mode" traversal - pressing the space bar will do
1617           <N>ext messsage, <G>oto next room, or read <N>ew as appropriate.
1618         * room_ops.c: modify CtdlRoomAccess() to allow access to mailbox rooms
1619           only to their owners.
1620
1621 Thu Oct  8 17:13:27 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1622         * messages.c, citadel.rc: added the ability to display message numbers
1623           in the header when reading messages.  I think this is butt ugly, but
1624           some of the DaveCode afficionados seem to like it...
1625
1626 Thu Oct  8 15:34:45 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1627         * room_ops.c: Added is_noneditable() function to replace all of the
1628           duplicated code present in all functions which edit room parameters.
1629
1630 1998-10-08 Nathan Bryant <bryant@cs.usm.maine.edu>
1631         * lots of warning fixes; builds with -std1 on dec unix
1632         * aidepost.c, citadel.h, citmail.c, file_ops.c, msgbase.c, netmailer.c,
1633           netproc.c, rcit.c, server.h, stats.c, userlist.c: use time_t where
1634           needed
1635         * control.c, room_ops.c, serv_chat.c, sysdep.c: use memset() instead of
1636           bzero()
1637         * dynloader.c, dynloader.h, messages.c, server.h, sysdep.c,
1638           sysdep_decls.h: function pointer/prototyping fixes
1639         * rooms.c: use mkfifo(3) instead of system("mkfifo")
1640
1641 1998-10-07 Nathan Bryant <bryant@cs.usm.maine.edu>
1642         * snprintf.c, snprintf.h: new files
1643         * Makefile.in, configure.in, dynloader.c, sysdep.c: support for the
1644           above; citserver now builds and runs on Digital Unix 4.0d with the
1645           GNU-style configure script. there is a bug with the hostname display
1646           in the wholist.
1647         * netproc.c: sillyness fix
1648         * room_ops.h: prototype delete_room()
1649         * client_chat.c, commands.c, serv_chat.c, sysdep.c:
1650           use HAVE_SYS_SELECT_H macro
1651
1652 Mon Oct  5 17:01:32 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1653         * Began fixing the stuff I broke
1654
1655 Sun Oct  4 23:35:18 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1656         * Did the big migration to the new data structures.  Lots of stuff is
1657           now broken.  Basic moving from room to room works, but Mail is
1658           broken, and some of the administrative commands are unimplemented.
1659
1660 1998-10-02 Nathan Bryant <bryant@cs.usm.maine.edu>
1661         * configure.in: autologin now defaults to disabled
1662
1663 Fri Oct  2 00:04:31 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1664         * Finally removed all three usersupp.foo[MAXROOMS] elements, and
1665           migrated all the code that used them to use "struct visit" instead.
1666
1667 Thu Oct  1 23:02:20 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1668         * Rewrote [l][get|put]room() functions to use room names rather than
1669           room index numbers.  Temporarily prepended a "n" to these four
1670           function names until they are put to use.
1671
1672 Thu Oct  1 16:27:13 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1673         * Removed a few more references to usersupp.lastseen[]
1674
1675 1998-10-01 Nathan Bryant <bryant@cs.usm.maine.edu>
1676         * .cvsignore: add so_locations (generated by osf1 ld with shared libs)
1677         * Makefile.in: restructured variables for greater consistency, use
1678           @echo to print out notices during the make process, add so_locations
1679           to `cleaner'
1680         * configure.in, Makefile.in: configure checks for -rdynamic
1681         * ipc_c_tcp.c: fix DEC compiler warning wrt unsigned char
1682         * stats.c: add semicolon to placate DREC compiler
1683         * user_ops.c: define _POSIX_C_SOURCE, include <limits.h>
1684         * configure.in: pass -pthread to DEC compiler, don't check for
1685           libpthread[s] on DEC Unix
1686
1687 1998-09-30 Nathan Bryant <bryant@cs.usm.maine.edu>
1688         * Makefile.in: new variable PTHREAD_DEFS for portability
1689         * aidepost.c, citadel.c, citmail.c, mailinglist.c, msgform.c,
1690           netmailer.c, netpoll.c, netproc.c, rcit.c, readlog.c, setup.c,
1691           stats.c, userlist.c, whobbs.c: return type of main() is int
1692         * citadel.c, commands.c, messages.c: use time_t properly
1693         * citserver.c: include <limits.h>
1694         * config.guess, config.sub, install-sh: new files
1695         * configure.in: don't use gcc on Digital Unix
1696
1697 Tue Sep 29 23:17:34 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1698         * room_ops.c: modified usergoto() to look at the new data structures
1699           for counting new messages and such.
1700
1701 1998-09-29 Nathan Bryant <bryant@cs.usm.maine.edu>
1702         * user_ops.c: fix compiler warning and potential memory leak,
1703           include sysdep.h
1704         * configure.in, Makefile.in: only build the server if we find pthreads
1705         * Makefile.in: realclean removes config.{cache,log,status}
1706
1707 Tue Sep 29 13:20:14 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1708         * Removed code from some of the utilities which was still attempting
1709           to access the old non-gdbm data store.
1710         * housekeeping.c: rewrote check_ref_counts() to do a ForEachRoom()
1711           traversal instead of a MAXROOMS loop.
1712         * sysdep.c: set up a dummy CitContext record to be used during server
1713           startup, during which time there is no real context.
1714
1715 Mon Sep 28 23:51:51 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1716         * Implemented the function ForEachRoom() to handle all-rooms traversal
1717           (this will work with both the old and new paradigms, because both
1718           use a GDBM database with one room per record).  Migrated all room
1719           list commands to use it.
1720
1721 Mon Sep 28 22:05:35 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1722         * Implemented the function CtdlRoomAccess() to handle *all* of the
1723           user-access-to-rooms functionality.  Migrated all room list commands
1724           to use it.  Still need to migrate gotos.
1725
1726 1998-09-28 Nathan Bryant <bryant@cs.usm.maine.edu>
1727         * configure.in, acconfig.h: new files; partially functional GNU
1728           autoconf configure script. Run autoheader; autoconf; ./configure
1729           --prefix=`pwd` to test.
1730         * Makefile.tmpl: new file; this is what Makefile.in used to be. Used by
1731           Configure.
1732         * Makefile.in: modified to work with autoconf-style configure script
1733         * Configure: modified to use Makefile.tmpl and generate autoconf-style
1734           macros. Removed procfs detection. Pass -O2 to gcc, -O to other
1735           compilers. Removed mknod/mkfifo detection; code should use mkfifo(3).
1736         * citmail.c, msgform.c, netproc.c, routines.c, support.c, userlist.c,
1737           whobbs.c: use HAVE_STRERROR macro rather than NO_STRERROR
1738         * commands.c: use HAVE_TERMIOS_H macro rather than POSIX_TERMIO
1739         * netproc.c: remove procfs stuff. simply attempt to kill the target
1740           process with signal zero instead; this checks whether the process
1741           exists.
1742         * setup.c, useradmin.c: use HAVE_CURSES_H macro
1743
1744 Sun Sep 27 23:41:29 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1745         * BOTH the old and new generation systems are being written to at
1746           this point.  Code that reads stuff is still using the old system.
1747
1748 Sun Sep 27 16:10:49 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1749         * Changed all "generation" variables from char to long, in preparation
1750           for removing MAXROOMS.  Generations for new rooms are now timestamps.
1751         * Defined "struct visit" to hold user/room relationships.
1752         * Removed some #define's from citadel.h that are no longer used.
1753
1754 Wed Sep 23 13:41:49 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1755         * More changes to support attachments.  They mostly work, but only
1756           in fixed-format messages.
1757
1758 Mon Sep 21 21:19:17 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1759         * msgbase.c: began laying the groundwork to support attachments.
1760           Purchased Rogaine(tm) in preparation for expected hair loss.
1761
1762 1998-09-21 Nathan Bryant <bryant@cs.usm.maine.edu>
1763         * msgbase.c: include dynloader.h
1764         * citadelapi.h: removed
1765         * dynloader.h: prototype CtdlRegisterUserHook()
1766
1767 Sun Sep 20 18:56:37 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1768         * Added a UserFunctionHook category to implement hooks which perform
1769           operations on various users or usernames
1770
1771 Fri Sep 18 21:14:41 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1772         * citserver.c: removed cmd_extn() and related code
1773
1774 1998-09-18 Nathan Bryant <bryant@cs.usm.maine.edu>
1775         * user_ops.c: include dynloader.h
1776         * roomstats.{c,mk}: removed
1777         * Configure, Makefile.in: autodependency-related fixes
1778
1779 Thu Sep 17 22:55:29 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1780         * Various changes to allow "new messages" to work correctly with Mail
1781
1782 Thu Sep 17 22:21:45 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1783         * server.h, dynloader.c, citserver.c, user_ops.c: reduced the number
1784           of hook types by inventing an EventType field to the Session hook.
1785         * proxy.c: added pre-fetching
1786
1787 1998-09-17 Nathan Bryant <bryant@cs.usm.maine.edu>
1788         * Makefile.in: add SERV_MODULES and PROXY_TARGETS to `cleaner'
1789         * dynloader.[ch], serv_{chat,test}.[ch], sysdep.c: cleaned
1790           up the dynamic loader interface as follows:
1791           - all the symbol table stuff is gone.
1792           - modules are loaded once at server startup and never unloaded.
1793           - Added a new function CtdlRegisterProtoHook() to handle the stuff
1794             that was being done with the symbol tables.
1795           - Dynamic_Module_Init() now returns a pointer to a static struct
1796             DLModule_Info; this structure itself has been modified to use char*
1797             fields instead of fixed char arrays.
1798         * roomstats.c: include <stdarg.h> not <stdargs.h> (is this file still
1799           in use?)
1800         * Configure, Makefile.in: added autodependency support
1801
1802 Wed Sep 16 22:25:13 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1803         * Implemented separate structs, lists, and functions for each type
1804           of server-side hook available.
1805
1806 1998-09-16 Nathan Bryant <bryant@cs.usm.maine.edu>
1807         * ipc_c_tcp.c: Fixed up some #include/prototyping stuff, call memcpy()
1808           instead of bcopy()
1809         * hooks.h: removed
1810         * sysdep.c, user_ops.c: removed reference to hooks.h
1811
1812 Wed Sep 16 11:42:42 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1813         * ipc_c_tcp.c: Reversed any changes that have been made to this file,
1814           because something was causing abominally slow response time.
1815         * proxy.c: added.  This will eventually become a caching, pre-fetching
1816           multiuser proxy server for the Citadel protocol.
1817
1818 1998-09-15 Nathan Bryant <bryant@cs.usm.maine.edu>
1819         * Makefile.in: remove support.o from serv_chat.so, add -fPIC to compile
1820           flags for serv_chat.o
1821         * dynloader.c: include "sysdep_decls.h", use RTLD_NOW not RTLD_LAZY
1822         * dynloader.h: prototype CtdlRegisterHook()
1823         * .cvsignore: added data
1824
1825 Mon Sep 14 20:49:08 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1826         * Tried my hand at adding the ability for server extensions to
1827           register various types of "hooks" in addition to just adding
1828           server commands.  This is probably not final.
1829
1830 Tue Sep  8 12:11:56 EDT 1998 Brian Costello <btx@calyx.net>
1831         * Added support for dynamic server modules.  Reworked serv_chat.c
1832           to be such a module.
1833
1834 Tue Sep  1 23:09:50 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1835         * userpurge.c: rewrote using functions from the server core, rather
1836           than the now-defunct external API.  This'll be ready once the module
1837           loading code is done.  (I just had to commit _something_ tonight.)
1838
1839 Mon Aug 31 22:47:58 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1840         * Yanked the citadelapi.c module.  This wasn't working out well.
1841         * techdocs/citadelapi.txt - began documenting the new API to be used
1842           by modules which will be dynamic linked into the server - most of
1843           this API is existing server functions.
1844         * Added a ForEachUser() function with callback mechanism, and reworked
1845           cmd_list() to use it.
1846
1847 Sun Aug 30 21:52:43 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1848         * Moved all of the gdbm databases to a separate "data" directory.
1849
1850 1998-08-26 Nathan Bryant <bryant@cs.usm.maine.edu>
1851         * Makefile.in: realclean removes Makefile, fixed `touch citadel.h'
1852           problem
1853
1854 1998-08-25 Nathan Bryant <bryant@cs.usm.maine.edu>
1855         * room_ops.c: include time.h
1856         * userlist.c, whobbs.c, serv_chat.c, user_ops.c, sysdep.c, stats.c,
1857           citadel_decls.h, commands.c, messages.h, routines.h, routines2.h:
1858           remove duplicated declarations
1859
1860 Mon Aug 24 23:45:01 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1861         * setup.c: Removed yesno_s()
1862         * citadel.h, room_ops.c: added QRmtime field to struct quickroom,
1863           modified whenever a room is modified or posted in.
1864         * citadelapi.c: Added CtdlForEachRoom() function
1865
1866 Mon Aug 24 20:04:04 EDT 1998 Nathan Bryant <bryant@cs.usm.maine.edu>
1867         * Makefile.in: new target `cleaner' does the same as `realclean' 
1868           without removing sysdep.h
1869         * proto.h: is bad. eliminate. I've moved the prototypes into several
1870           header files, one per .c file
1871
1872 Mon Aug 24 00:45:55 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1873         * Added a CtdlGotoRoom() function to the CitadelAPI.
1874  
1875 Sun Aug 23 21:47:00 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1876         * sysoputil is finally dead!  Removed it from the build.
1877         * Added userpurge.c server extension (initial implementation)
1878
1879 Tue Aug 18 00:42:33 EDT 1998 Nathan Bryant <bryant@cs.usm.maine.edu>
1880         * Makefile.in: `clean' target no longer rm's sysdep.h; new target
1881           `realclean' removes everything clean does, plus sysdep.h, plus
1882           target binaries.
1883         * Configure: add -Wstrict-prototypes to CFLAGS for gcc systems
1884         * *.[ch]: protoized. Added several new header files containing
1885           prototypes and other external declarations; many duplicated
1886           declarations still should be moved to header files. proto.h must die
1887           as well, IMHO.
1888
1889 Mon Aug 17 23:52:13 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1890         * Implemented a bunch of user account related functions in the
1891           CitadelAPI library.
1892
1893 Mon Aug 17 20:01:18 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1894         * Fixed the crash problem.  It wasn't AGUP/ASUP, but rather a buffer
1895           overrun in getuser() (thanks, Nathan).  Implemented overrun checks
1896           in getuser(), getroom(), and getfloor() to prevent future problems.
1897
1898 Mon Aug 17 00:06:52 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1899         * Updated citmail.c with the latest stuff from the production system.
1900         * Implemented AGUP and ASUP commands, but AGUP crashes the server
1901           after its first successful use (user-not-found's don't affect it).
1902
1903 Thu Aug  6 19:25:01 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1904         * Got the CitadelAPI library to the point where the server can start
1905           up an extension, and the extension will connect to the server, do
1906           some initialization, call a user-supplied CtdlMain(), and exit.  Also
1907           hacked together a _temporary_ form of the new EXTN server command.
1908  
1909 Wed Aug  5 23:02:22 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1910         * Second attempt at getting the server API started.  Now it runs
1911           outside of the server and builds a connection.
1912
1913 Tue Aug  4 18:33:06 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1914         * Modified the appearance of Internet addresses when they arrive on
1915           a Citadel system.
1916         * Removed the <E> field from the message format writeup in hack.txt.
1917         * Fixed-up citmail.c so that it doesn't try to do database lookups.
1918
1919 Mon Aug  3 23:01:37 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1920         * Started developing the server-side API.  This is in its very
1921           initial stages.  See serverapi.c and techdoc/api.txt
1922
1923 1998-08-02  Nathan Bryant  <bryant@cs.usm.maine.edu>
1924         * Makefile.in: added config_decls.h to dependencies
1925
1926 Sun Aug  2 21:09:09 EDT 1998 Nathan Bryant <bryant@cs.usm.maine.edu>
1927         * config_defs.h: renamed to config_decls.h
1928         * config.c, sysoputil.c: updated to reflect the above
1929
1930 Sun Aug  2 18:52:05 EDT 1998 Nathan Bryant <bryant@cs.usm.maine.edu>
1931         * config_defs.h: new file, contains external declarations from config.c
1932         * config.c: moved defs to config_defs.h, use PATH_MAX from <limits.h>
1933           for bbs_home_directory
1934         * mailinglist.c, support.c: include <string.h>
1935         * sysoputil.c: include <string.h>, <limits.h>, "config_defs.h", remove
1936           duplicated defs, replace gets() call with fgets()
1937         * user_ops.c: define _XOPEN_SOURCE_EXTENDED
1938
1939 Sat Aug  1 18:32:52 EDT 1998 Nathan Bryant <bryant@cs.usm.maine.edu>
1940         * ipc_c_tcp.c: fixed order of memcpy parameters after gethostbyname
1941
1942 Sun Jul 19 17:26:12 EDT 1998 Nathan Bryant <bryant@cs.usm.maine.edu>
1943         * ChangeLog: reordered; the GNU standard is to add new entries to the
1944           top.
1945         * .cvsignore: added userlist
1946
1947 Sun Jul 12 20:58:59 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1948         * Finished migrating everything to the new data store.
1949         * Replaced the binary "calllog" with the ASCII "citadel.log"
1950         * Began converting broken utilities that depend on the old data store
1951
1952 Sat Jul 11 00:20:48 EDT 1998 Nathan Bryant <bryant@cs.usm.maine.edu>
1953         * Makefile.in: removed msgstats
1954
1955 Fri Jul 10 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1956         * Initial CVS import