* Create the Calendar> and Tasks> rooms at login time, and set their default
[citadel.git] / citadel / ChangeLog
1  $Log$
2  Revision 601.7  2002/09/17 03:18:15  ajc
3  * Create the Calendar> and Tasks> rooms at login time, and set their default
4    views to calendar and tasklist views.  Renamed "My Calendar>" to "Calendar>"
5    to be in sync with the KDE groupware project.
6
7  Revision 601.6  2002/09/15 03:24:28  ajc
8  * Renamed decode_base64() to CtdlDecodeBase64()
9  * Renamed decode_quoted_printable() to CtdlDecodeQuotedPrintable()
10  * These changes are to avoid namespace conflict with libical
11
12  Revision 601.5  2002/09/13 15:41:39  ajc
13  * serv_calendar.c: #include "serv_calendar.h", not "serv_ical.h"
14
15  Revision 601.4  2002/09/11 03:17:18  ajc
16  * [EXPERIMENTAL] Link in the "libical" calendar library if present
17  * Rename serv_ical to serv_calendar (because the resulting module would be
18    named "libical" which conflicts with the external library by that name)
19
20  Revision 601.3  2002/09/10 08:07:38  error
21  * update citadel.spec for 6.00* update citadel.spec for 6.00* update citadel.spec for 6.00* update citadel.spec for 6.00* update citadel.spec for 6.00* update citadel.spec for 6.00* update citadel.spec for 6.00* update citadel.spec for 6.00
22
23  Revision 601.2  2002/09/09 03:03:18  ajc
24  * When a user logs in, create the Mail> room if it doesn't exist.  (Should
25    never happen, but one site had a situation where this patch came in handy.)
26
27  Revision 601.1  2002/09/08 04:15:28  ajc
28  * Also fixed a bug in <.T>erminate <S>tay which caused the terminal to
29    become wacky on second and subsequent sessions.
30
31  Revision 601.0  2002/09/08 03:51:30  ajc
32  * Let's call this 6.01, shall we?
33
34  Revision 600.2  2002/09/08 03:48:48  ajc
35  * Fixed a crashy crashy bug in the AGUP protocol function in the client
36
37  Revision 600.1  2002/09/07 03:24:23  ajc
38  * When displaying messages using MSG4, enumerate the attachments on the
39    client side, because the server won't add their descriptions to the
40    message text.
41
42  Revision 600.0  2002/09/04 03:06:58  ajc
43  * Committing the current code base as version 6.00
44
45  Revision 591.109  2002/09/03 14:09:04  ajc
46  * setup.c: automatically stop/start services
47
48  Revision 591.108  2002/09/03 04:42:15  ajc
49  * Added MSG4 support to client-side IPC
50  * Moved HTML-to-text conversion to the client side
51
52  Revision 591.107  2002/09/02 20:40:34  ajc
53  * Automation work for setup
54
55  Revision 591.106  2002/08/31 04:36:26  ajc
56  * IMAP APPEND no longer forces messages to appear as from the logged-in user
57    when appending to a mailbox room.  (Allows migration to Citadel from some
58    other type of server without losing all the sender names.)
59
60  Revision 591.105  2002/08/31 04:12:39  ajc
61  * Set version number to 6.00 in documentation and header files.
62  * Convert RFC822 newlines (CRLF) to Unix/Citadel newlines (LF) when
63    performing an IMAP APPEND command.
64
65  Revision 591.104  2002/08/28 03:18:06  ajc
66  * Make reply_to and reply_subject global (otherwise they don't work!)
67
68  Revision 591.103  2002/08/27 04:01:03  ajc
69  * Added the ability to run an external command from the client when new mail
70    arrives.  (Ok, I admit it: I just discovered http://www.dailywav.com and I
71    just *had* to have Bear in the Big Blue House tell me I've got mail)
72
73  Revision 591.102  2002/08/26 02:55:09  ajc
74  * Small bugfix for memory bounds checking in the MIME parser
75
76  Revision 591.101  2002/08/25 21:23:49  ajc
77  * Hide the SMTP queue and the sysconfig rooms.
78
79  Revision 591.100  2002/08/24 05:58:53  ajc
80  * Bugfixes and cosmetic changes to listsub system
81
82  Revision 591.99  2002/08/23 03:36:52  ajc
83  * Finished all of the subscribe/unsubscribe/confirm stuff!
84
85  Revision 591.98  2002/08/23 02:30:02  ajc
86  * Delete unconfirmed pending subscribe/unsubscribe requests after three days
87  * Don't allow multiple subscriptions of the same address to a list
88
89  Revision 591.97  2002/08/22 03:55:11  ajc
90  * Fixed bug in above
91
92  Revision 591.96  2002/08/22 03:40:00  ajc
93  * Add "unsubscribe" command (but not yet "confirm unsubscribe")
94
95  Revision 591.95  2002/08/21 21:58:00  ajc
96  * Completed self-service list subscription via web.
97    (Still need to implement unsubscribe.)
98
99  Revision 591.94  2002/08/16 21:04:56  ajc
100  * Add LPRM command
101
102  Revision 591.93  2002/08/14 20:21:52  ajc
103  * Extend GETR/SETR to allow twiddling of bits in the QRflags2 bucket
104  * New flag and config options to allow/disallow self-service list subscription
105    and unsubscription to a room
106
107  Revision 591.92  2002/08/14 02:36:05  ajc
108  * WebCit list subscription integration
109
110  Revision 591.91  2002/08/13 18:48:46  ajc
111  * Generate and send subscription confirmation requests.
112    (Still need to finalize the URL format)
113
114  Revision 591.90  2002/08/13 17:19:11  ajc
115  * Added email capability to quickie_message()
116
117  Revision 591.89  2002/08/13 04:02:06  ajc
118  * <R>eplace string is now case sensitive
119
120  Revision 591.88  2002/08/13 03:46:31  ajc
121  * More work on the self-service subscribe/unsubscribe infrastructure
122
123  Revision 591.87  2002/08/12 03:00:20  ajc
124  * Fixed bug in <R>eplacestring which caused it to lock up in certain conditions
125
126  Revision 591.86  2002/08/12 00:09:05  ajc
127  * Compress VISIT records using zlib if available.  This reduces the object
128    size from over 4k to about 70 bytes.  Experimental.
129  * Automatically uncompress database records found to be compressed (duh)
130
131  Revision 591.85  2002/08/08 22:01:35  ajc
132  * autoconf to look for zlib (for an upcoming experiment)
133
134  Revision 591.84  2002/08/08 03:25:56  ajc
135  * Bugfix for above
136  * Started writing some infrastructure for sub/unsub
137
138  Revision 591.83  2002/08/08 02:49:12  ajc
139  * serv_network.c: retain unknown commands in netconfigs and write them back
140  * techdoc/netconfigs.txt: specify commands for subscribe/unsubscribe pending
141  * serv_listsub.c: added (currently a stub)
142
143  Revision 591.82  2002/08/06 03:12:14  ajc
144  * Fixed and clarified "new mail has arrived" messages.
145
146  Revision 591.81  2002/08/06 03:02:29  ajc
147  * ;AE command -- Make it clearer which floor the user is editing
148
149  Revision 591.80  2002/08/06 02:58:01  ajc
150  * Cleaned up the output of digest mode.  It's usable now, but the self-service
151    subscribe/unsubscribe functions are not there yet.
152
153  Revision 591.79  2002/08/05 14:38:11  ajc
154  * rooms.c: corrected a typo reported by Campagnolo (Mike Poulin)
155
156  Revision 591.78  2002/08/03 19:48:40  ajc
157  * NULLify 'roomrec' before attempting partial match in <G>oto
158    (fixes heap corruption when this command is executed)
159
160  Revision 591.77  2002/08/03 04:13:46  ajc
161  * citadel_ipc.c: Attempted to clean up memory allocation
162
163  Revision 591.76  2002/08/01 05:41:53  ajc
164  * Completion of (most of) digest mode.  Still needs some polish.
165
166  Revision 591.75  2002/07/31 04:01:57  ajc
167  * Began implementing "digest mode" for listserving.  (Not complete)
168
169  Revision 591.74  2002/07/28 20:33:13  ajc
170  * Augmented the "headers only" functionality of the message reading API (as
171    well as the options of the server commands which expose it) to allow
172    headers+body, headers only, or body only.
173  * Adjusted message output of IMAP command FETCH BODY[1] when message is in
174    legacy Citadel format.  This fixes a bug exposed by SquirrelMail.
175
176  Revision 591.73  2002/07/23 04:00:06  ajc
177  * Completed the MSGP and MSG4 commands to set the client's preferred MIME
178    content types, and fetch messages with MIME content types.
179
180  Revision 591.72  2002/07/21 22:29:46  ajc
181  * Added in some infrastructure to switch the client's message reading from
182    conventional MSG0 to a MIME-download type thing, like WebCit does.
183
184  Revision 591.71  2002/07/21 15:45:07  error
185  * Remove duplicate call for server time in who_is_online(); IPC does this now
186
187  Revision 591.70  2002/07/21 15:43:57  error
188  * citadel_ipc.c: Fix for segfault on empty messages
189
190  Revision 591.69  2002/07/20 04:05:10  ajc
191  * Updated hack.txt with some fresh new information
192
193  Revision 591.68  2002/07/19 02:28:11  ajc
194  * citadel_ipc.c: changed various buffer lengths from 256 to SIZ in order to
195    accomodate long lines which often spew out (usually from spam unfortunately)
196
197  Revision 591.67  2002/07/18 21:29:37  nbryant
198  added a note about GNU make to the configure script output
199
200  Revision 591.66  2002/07/18 20:21:18  ajc
201  * Eliminated the 512-message limit in the client for reading messages.
202
203  Revision 591.65  2002/07/13 04:12:40  ajc
204  * Don't lie about format types in MSG0 anymore.  We no longer need to.
205
206  Revision 591.64  2002/07/13 03:24:32  ajc
207  * CtdlOutputMsg() caches the most recently fetched message in memory.  This
208    eliminates the need to do multiple database fetches when we go back for
209    additional MIME parts, etc.
210
211  Revision 591.63  2002/07/11 03:40:51  ajc
212  * When outputting a multipart MIME message, supply the client with "pref="
213    and "suff=" lines in addition to the "part=" lines.
214
215  Revision 591.62  2002/07/02 16:27:06  error
216  * prototypes in citadel_ipc.h updated
217
218  Revision 591.61  2002/06/29 23:26:55  error
219  * fixed some memory leaks
220
221  Revision 591.60  2002/06/29 18:36:31  error
222  * tools.c: Massively faster versions of extract_token() and remove_token().
223    These functions can now handle multi-kilobyte sized strings with hundreds
224    of tokens (or more?).
225
226  Revision 591.59  2002/06/29 15:55:07  error
227  * Convert whobbs, serv_info, misc. functions to new IPC code
228
229  Revision 591.58  2002/06/27 03:10:04  error
230  * rooms.c: converted most functions to new IPC code
231
232  Revision 591.57  2002/06/25 15:38:52  error
233  * fixed bug in dotgoto() causing free() to segfault
234
235  Revision 591.56  2002/06/25 15:13:27  error
236  * gotonext() now uses new IPC code to retrieve room listing
237
238  Revision 591.55  2002/06/25 14:21:35  error
239  * remove a debugging trap I accidentally left in the code
240
241  Revision 591.54  2002/06/24 20:17:43  error
242  * Fixed code for client segfault at login
243
244  Revision 591.53  2002/06/24 20:11:00  error
245  * Buffer overflow fixes and minor cleanup in IPC code
246
247  Revision 591.52  2002/06/24 16:07:42  error
248  * Message reading and other functions which use the fmout() screen
249    formatter now use the new IPC code.
250
251  Revision 591.51  2002/06/22 20:09:16  error
252  * Use a new IPC API (in citadel_ipc.c).  Partially converted citadel.c to
253    use the new API.
254
255  Revision 591.50  2002/06/21 12:32:48  ajc
256  * Minor documentation update
257
258  Revision 591.49  2002/06/19 21:52:13  ajc
259  * Support a transient room create as well
260
261  Revision 591.48  2002/06/19 21:42:57  ajc
262  * Added support for "transient goto" which allows entry into a private and/or
263    zapped room without putting the room [back] on your known rooms list.  This
264    is useful for the new administrative functions in WebCit (updating a user's
265    vCard without the Aide suddenly having that user's config room on their
266    list).
267
268  Revision 591.47  2002/06/18 16:34:06  error
269  * room_ops.c: Fix for old room record not being deleted when renaming
270    baseroom or aideroom
271
272  Revision 591.46  2002/06/16 21:01:11  ajc
273  * Allow Aides to create rooms in other users' namespaces (if global access
274    controls allow)
275
276  Revision 591.45  2002/06/15 20:48:50  ajc
277  * Fixed small bug in the e<X>pert mode toggle
278
279  Revision 591.44  2002/06/15 20:14:55  ajc
280  * Fixed a memory allocation bug in the vCard parser
281
282  Revision 591.43  2002/06/15 17:53:59  error
283  * citserver.c: MESG command can now send a different system message based
284    on the developer and client ID of the connected client
285
286  Revision 591.42  2002/06/15 04:52:26  ajc
287  * SpamAssassin connector is now configurable in <.A>ide <S>ysconfig <I>nternet.
288  * Allow more than one SA server (it'll try 'em all)
289  * Don't run SA for logged in users
290
291  Revision 591.41  2002/06/14 20:42:56  ajc
292  * Discovered that spamd works even without the Content-length: command, so I
293    was able to redo the spam checker to work without a temp file.
294
295  Revision 591.40  2002/06/14 20:37:03  ajc
296  * Disabled the spam strings checker I wrote a few days ago.
297  * When receiving SMTP, check to see if spamd (the SpamAssassin daemon) is
298    running on the local machine.  If yes, run the message through it and
299    reject if spam.
300
301  Revision 591.39  2002/06/12 03:42:21  ajc
302  * "Suppress message prompts" has been changed to "Prompt after each message"
303    and of course the effect has been reversed.
304  * "Be unlisted in userlog" has been moved to the end of the list of
305    configuration prompts, so it doesn't interrupt the flow of thought regarding
306    the prompting questions.
307
308  Revision 591.38  2002/06/10 22:25:25  ajc
309  * Configuration for spam filter
310
311  Revision 591.37  2002/06/09 23:59:38  ajc
312  * Started working on the spam filter
313
314  Revision 591.36  2002/06/07 22:10:51  ajc
315  * Added a new message function hook type EVT_SMTPSCAN which permits modules to
316    register hooks that can scan incoming SMTP messages and elect to reject them
317    (due to virus or spam content, for example).
318
319  Revision 591.35  2002/06/07 03:22:13  ajc
320  * Added a module "serv_mrtg" which allows activity reporting to MRTG
321    (http://www.mrtg.org) -- this will replace our stats program.
322
323  Revision 591.34  2002/06/02 16:42:17  error
324  * Support for Ctrl-W to erase a word when editing or at a prompt
325
326  Revision 591.33  2002/05/31 18:34:04  nbryant
327  better curses compatibility, and a couple makefile/configure tweaks
328
329  Revision 591.32  2002/05/28 13:59:02  ajc
330  * Removed the 'netsetup' and 'dnetsetup' utilities (obsolete)
331
332  Revision 591.31  2002/05/24 19:58:13  ajc
333  * Fixed the "idle timeout during paginator prompt" bug by reintroducting the
334    concept of a "half keepalive" and sending them during paginator prompts.
335
336  Revision 591.30  2002/05/23 03:33:21  ajc
337  * Added a GTSN (GeT list of SeeN messages) command
338
339  Revision 591.29  2002/05/20 14:29:59  ajc
340  * commands.c: fixed bug in the scan for idle_threshold= which didn't include
341    the = sign and ended up always setting this value to 0
342
343  Revision 591.28  2002/05/17 03:57:30  ajc
344  * When doing fixed_output() of converted HTML, output the whole block of
345    data at once instead of one character at a time
346
347  Revision 591.27  2002/05/16 04:44:58  ajc
348  * Reduce the number of socket writes when doing fixed_output() to avoid
349    getting killed by overhead.  (Thanks to IO for the insight)
350
351  Revision 591.26  2002/05/14 15:25:34  error
352  * room_ops.c: clarified aide message when room aide is removed
353
354  Revision 591.25  2002/05/14 15:18:43  error
355  * rooms.c: Print name of room aide if any when doing <i>nfo
356
357  Revision 591.24  2002/05/14 01:33:18  error
358  * Fixed some incredibly silly typos
359
360  Revision 591.23  2002/05/14 01:27:18  error
361  * Minor cosmetic changes, extraneous double spaces etc.
362
363  Revision 591.22  2002/05/14 01:15:54  error
364  * Idle threshold on the who list is now customizable in the citadel.rc
365
366  Revision 591.21  2002/05/14 01:09:57  error
367  * citadel.c: spacebar won't read New if there are no new messages
368
369  Revision 591.20  2002/05/12 23:00:11  ajc
370  * Removed an unused variable
371
372  Revision 591.19  2002/05/12 22:57:04  ajc
373  * Removed the unfinished moderation system.
374  * CtdlForEachMessage() - only fetch metadata when hunting for messages with
375    a specified Content-type.  Serious performance boost.
376
377  Revision 591.18  2002/05/05 17:33:09  error
378  * screen.c: fix lack of beeps in curses mode
379
380  Revision 591.17  2002/05/04 02:58:16  ajc
381  * Documented a small protocol change for the STEL command
382
383  Revision 591.16  2002/04/30 03:13:59  ajc
384  * When sending a page that results in the receiver's Sent/Received Pages>
385    room to be created, don't automatically grant the sender access to that room.
386  * Added a parameter to create_room() to implement the above
387
388  Revision 591.15  2002/04/23 13:38:08  ajc
389  * Minor docs update
390
391  Revision 591.14  2002/04/21 21:28:06  ajc
392  * Create the My Citadel Config> room along with the user account
393
394  Revision 591.13  2002/04/20 03:00:01  ajc
395  * One more fix for the RENAME command wrt namespaces.
396
397  Revision 591.12  2002/04/18 18:44:36  nbryant
398  don't use libtool -avoid-version for libcitserver - this might help for
399  OpenBSD
400
401  Revision 591.11  2002/04/17 04:35:06  ajc
402  * Finished the IMAP RENAME command.  (I ended up using nested functions
403    because it made the task much, much easier.  We can fix it later or convert
404    it to C++ if we find this becomes a problem.)
405
406  Revision 591.10  2002/04/15 13:25:47  ajc
407  * Add error responses to imap_rename() and set up subfolder framework
408
409  Revision 591.9  2002/04/14 22:42:49  ajc
410  * Began implementing RENAME command in IMAP.
411
412  Revision 591.8  2002/04/14 22:27:05  ajc
413  * Added access control checking to CtdlRenameRoom()
414
415  Revision 591.7  2002/04/14 22:11:22  ajc
416  * New back end function CtdlRenameRoom() which is used to rename a room and/or
417    move it to a different floor.
418  * cmd_setr() now uses CtdlRenameRoom() to do part of its work
419
420  Revision 591.6  2002/04/10 03:58:40  ajc
421  * Began work on IMAP RENAME
422
423  Revision 591.5  2002/04/09 14:26:43  ajc
424  * Allow INBOX to have subfolders.  There's no longer any reason not to.
425
426  Revision 591.4  2002/04/05 22:31:59  error
427  * Send time-of-day with pages sent via IMAP
428
429  Revision 591.3  2002/04/05 14:34:02  ajc
430  * Minor tweak to nested folder algorithm to handle nesting in mail root
431
432  Revision 591.2  2002/04/05 04:25:56  ajc
433  * Support nested folders in IMAP.  We might want to change the delimiter.
434
435  Revision 591.1  2002/04/04 23:25:30  ajc
436  * Experimental hacking to handle subfolderization in IMAP.  Seems to work ok
437    but it makes Mozilla mail hang.  Will investigate more later...
438
439  Revision 591.0  2002/04/01 05:13:20  ajc
440  * Tagged everything for 5.91 release
441
442  Revision 590.168  2002/04/01 05:12:57  ajc
443  * Prep for 5.91 release
444
445  Revision 590.167  2002/03/29 04:43:15  ajc
446  * Removed the BMBX command.  Mailbox security update now runs automatically when the
447    server starts and it sees data files version <5.91.
448
449  Revision 590.166  2002/03/26 05:58:35  nbryant
450  don't check for a database driver until after the openssl check is
451  complete. if the ld paths aren't set up for the db installation this
452  can interfere with the openssl check because it tries to run a program
453  linked against the libraries we've been finding.
454
455  Revision 590.165  2002/03/26 05:20:46  nbryant
456  removed last vestiges of "#ifdef CIT_CLIENT" conditional compilation,
457  which has been rendered unusable by the build system simplifications
458
459  Revision 590.164  2002/03/26 05:13:32  nbryant
460  fix monstrous shell script syntax in configure.ac
461
462  Revision 590.163  2002/03/26 04:38:31  nbryant
463   * support autoconf 2.53
464   * make a note that people should be using libtool 1.4d
465   * cut some of the more pointless bells and whistles out of the configure
466     script in an effort to make it more maintainable
467   * modularized ipc_c_tcp.c and client_crypto.o so that they're not tied
468     to the curses stuff.
469   * timezone/daylight and other FreeBSD fixes
470   * more effort in the configure script to detect the common
471     bastardizations (ahem, ports) of Berkeley DB without falling down
472
473  Revision 590.162  2002/03/25 03:09:39  nbryant
474  fix warning on platforms where pthread_t may be a pointer
475
476  Revision 590.161  2002/03/25 00:01:50  nbryant
477   * compatibility with Berkeley DB < 3.3
478   * squished symbol clashes with the OK symbol from curses in certain *n[iu]x
479  distributions. this is kind of a pain in the ass, but I had to rename our
480  OK to CIT_OK :-(
481
482  Revision 590.160  2002/03/22 04:35:38  ajc
483  * Handle vCard registration updates for users other than the one currently
484    logged in.  (Allows administrative editing of contact information.)
485
486  Revision 590.159  2002/03/20 19:03:27  ajc
487  * Don't re-declare timezone variables ('cuz FreeBSD chokes on that)
488
489  Revision 590.158  2002/03/19 04:34:42  ajc
490  * mime_parser.c: minor changes for easier porting between Citadel and WebCit
491
492  Revision 590.157  2002/03/19 04:19:33  ajc
493  * Saw what IO did with strchr() and did the same in a few more places
494
495  Revision 590.156  2002/03/17 00:08:02  error
496  * mime_parser.c: more robust parsing of Content-Type header
497
498  Revision 590.155  2002/03/16 05:22:59  ajc
499  * Post an error message to Aide> when unlink() is unable to delete old
500    database log files.
501
502  Revision 590.154  2002/03/14 04:35:26  nbryant
503  avoid symbol clash with curses' "timeout" function (which may be a macro
504  in some versions)
505
506  Revision 590.153  2002/03/14 04:24:20  nbryant
507  support window resizing in curses mode
508
509  Revision 590.152  2002/03/13 04:11:11  nbryant
510  fix up minor gotcha introduced by fgets change
511
512  Revision 590.151  2002/03/13 03:58:29  ajc
513  * Site-configurable option "Allow system Aides to gain access to mailboxes"
514
515  Revision 590.150  2002/03/13 03:34:38  nbryant
516  /* when running in curses mode, the scroll bar in most
517     xterm-style programs becomes useless, so it makes sense to
518     pause after a screenful of pages if the user has been idle
519     for a while. However, this is annoying to some of the users
520     who aren't in curses mode and tend to leave their clients
521     idle. keepalives become disabled, resulting in getting booted
522     when coming back to the idle session. but they probably have
523     a working scrollback in their terminal, so disable it in this
524     case:
525   */
526  if (!is_curses_enabled())
527         lines_printed = 0;
528
529  Revision 590.149  2002/03/12 23:34:37  nbryant
530  use ncurses in preference to curses if it's installed; it handles
531  background colors properly on dtterm, has a larger color pair palette,
532  and has a bigger terminal database than solaris curses
533
534  Revision 590.148  2002/03/12 22:47:17  nbryant
535  curses fix: map our normal color pairs into the 0-7 range instead of 1-8,
536  in order to make our pairs fit on terminals such as dtterm where COLOR_PAIRS=8.
537  map the white/blue color pair onto 8 instead of 9, but only if that slot
538  is available; fall back on white/black otherwise.
539
540  it seems there may be an off-by-one error in the color pair manpages for
541  the various curses packages (?) if not, our 0 entry is unusable, but that's
542  the DIM_BLACK color and we don't use it anyway.
543
544  Revision 590.147  2002/03/12 22:17:20  ajc
545  * Give mailbox owners access to "who knows room" command
546
547  Revision 590.146  2002/03/12 21:08:03  nbryant
548  support color under Solaris curses
549
550  Revision 590.145  2002/03/12 19:59:40  ajc
551  * Access control change: do not treat mailboxes as guessname rooms for Aides.
552    Open up INVT/KICK commands to non-Aides for their mailboxes.
553
554  Revision 590.144  2002/03/12 04:30:52  nbryant
555  if a filesystem node exists at /var/run/egd-pool, try to connect to it as
556  the EGD (Entropy Gathering Daemon) or PRNGD (pseudorandom number
557  generator daemon) socket and seed OpenSSL's RNG.
558
559  this is necessary on solaris and other systems which lack /dev/urandom.
560
561  Revision 590.143  2002/03/12 03:43:26  nbryant
562  squished the last remaining calls to sprintf
563
564  Revision 590.142  2002/03/12 03:36:55  nbryant
565  replace calls to gets with fgets
566
567  Revision 590.141  2002/03/12 03:19:09  nbryant
568  more sprintf bashing. now the only ones left are in mime_parser
569
570  Revision 590.140  2002/03/12 01:33:42  nbryant
571   - pass -Wcast-qual to gcc
572   - more sprintf bashing
573
574  Revision 590.139  2002/03/12 00:03:43  nbryant
575  more sprintf removals
576
577  Revision 590.138  2002/03/11 06:00:21  nbryant
578  use <db.h> before <db3/db.h> or <db4/db.h>
579  this is the only way i can think of to make it work everywhere; people on
580  systems like FreeBSD where the ports work the other way around will have to
581  specify an extra -I flag in their CPPFLAGS variable.
582
583  Revision 590.137  2002/03/11 05:42:46  nbryant
584  removed all references to sprintf from several files (not all files yet)
585  and replace with snprintf
586
587  Revision 590.136  2002/03/11 04:16:20  nbryant
588  warning fixes on sparc-sun-solaris2.8 with gcc 3.0.4, mostly for *printf
589  format strings
590
591  Revision 590.135  2002/03/11 03:55:24  nbryant
592   - fixes for building without OpenSSL
593   - setenv doesn't exist on all systems, use putenv instead
594   - support Solaris' curses implementation
595
596  Revision 590.134  2002/03/09 22:52:04  ajc
597  * Applied a patch submitted by <xperc@hotmail.com> to fix a potential buffer
598    overflow problem in lprintf().  I also did the same fix to cprintf().
599
600  Revision 590.133  2002/03/09 16:47:57  ajc
601  * Added BMBX to fix a problem
602
603  Revision 590.132  2002/03/09 06:18:37  ajc
604  * one more tweak
605
606  Revision 590.131  2002/03/09 05:22:29  ajc
607  * this should do it.
608
609  Revision 590.130  2002/03/09 05:02:20  ajc
610  * Attempts to fix the access control crap
611
612  Revision 590.129  2002/03/08 05:42:02  ajc
613  * Patch to allow invitations and admin access to mailbox rooms.  NEEDS TESTING!
614
615  Revision 590.128  2002/03/07 04:30:37  ajc
616  * Force recipient only in Mail>, not in all mailbox rooms
617
618  Revision 590.127  2002/03/05 22:45:40  error
619  * Autoconf fixes for DB4 support
620
621  Revision 590.126  2002/03/05 04:47:49  ajc
622  * vcard.c: another API update
623
624  Revision 590.125  2002/03/04 05:29:39  ajc
625  * Made a small API change to vcard.c for WebCit, brought the change over here too
626    in order to keep vcard.c identical everywhere.
627
628  Revision 590.124  2002/03/03 06:48:25  ajc
629  * Client and server options to disable self-service user account creation
630
631  Revision 590.123  2002/03/03 06:31:58  ajc
632  * Added password starred-out entry to newprompt() and strprompt()
633  * Applied the above setting to password set/change in <.A>ide <U>seredit
634
635  Revision 590.122  2002/03/03 06:18:45  ajc
636  * Implemented the CREU server command to administratively create user accounts
637  * Added the ability to create new user accounts to <.A>ide <U>seredit
638
639  Revision 590.121  2002/03/03 06:05:16  ajc
640  * Split up some of the code in order to prepare for user accounts to be
641    administratively created without logging in to them.
642
643  Revision 590.120  2002/03/02 05:56:48  ajc
644  * Properly implemented the network filter list.  Finished the server module and
645    did a client-side <.A>ide <S>ysconfig <F>ilterlist command.
646
647  Revision 590.119  2002/03/01 04:24:20  ajc
648  * Cosmetic change to Received: line
649
650  Revision 590.118  2002/03/01 04:16:22  ajc
651  * CtdlReadMessageBody() -- fixed bug that caused the prepend buffer to be
652    discarded instead of prepended.  "Received:" lines now work.
653
654  Revision 590.117  2002/02/23 19:20:51  ajc
655  * Do the use table purge in two phases to avoid crashy crashy
656
657  Revision 590.116  2002/02/20 22:42:19  ajc
658  * Started adding better management of source IP addressses in SMTP service
659
660  Revision 590.115  2002/02/15 04:28:57  ajc
661  * Wrote the expire/purge routine for the new use table
662
663  Revision 590.114  2002/02/15 04:05:08  ajc
664  * Began implementation of a networker use table that doesn't chew up oodles
665    of CPU time.  (It uses a cdb instead.)
666
667  Revision 590.113  2002/02/15 03:40:06  ajc
668  * Stu's changes (which he checked in without making any ChangeLog comments,
669    bad Stu!) didn't build properly without curses.  Added #ifdef's.
670
671  Revision 590.112  2002/02/13 22:15:10  ajc
672  * That was stupid.
673
674  Revision 590.111  2002/02/13 22:04:11  ajc
675  * added vcard_to_html() function
676
677  Revision 590.110  2002/02/13 15:48:55  ajc
678  * Allow the READ command to return packets bigger than 1 byte.  (ooops!)
679
680  Revision 590.109  2002/02/12 20:15:25  ajc
681  * Threw in a few more #ifdef's so the client build doesn't barf on
682    non-curses systems
683  * Added rc_prompt_control (<N>ext/<S>top active at paginator: on/off/user)
684
685  Revision 590.108  2002/02/11 15:52:10  ajc
686  * Don't crash when deleting "purge this vCard" messages
687
688  Revision 590.107  2002/02/10 22:36:41  nbryant
689   - replace cdb_trunc with a complete version of the code i had been
690     working on; fallback code for db < 3.3.x needed
691   - change 'can't connect to host.port' to 'can't connect to host:port'
692
693  Revision 590.106  2002/02/08 22:39:08  ajc
694  * If there's already a Subject line in memory, display it below the usual
695    headers when the user hits <E>
696
697  Revision 590.105  2002/02/08 22:36:23  ajc
698  * Changed the logic for printing RFC822 addresses (again)
699  * Implemented cdb_trunc() in database_sleepycat.c, using db_truncate()
700    (We need to either provide an alternative implementation or require DB >=3.3)
701  * Automatically Re: subject line in the client where appropriate
702
703  Revision 590.104  2002/02/08 19:02:25  ajc
704  * Added client and server side support for entering Subject lines in
705    messages when not using RFC822.
706
707  Revision 590.103  2002/02/08 18:10:07  ajc
708  * When outputting a message in non-RFC822 format, don't display an Internet
709    address if the user is local.
710
711  Revision 590.102  2002/02/07 04:42:49  ajc
712  * Silently refuse to add directory entries for Internet addresses already
713    belonging to other users.
714  * cdb_trunc() for CtdlDirectoryInit: implemented for GDBM, stubbed for DB
715
716  Revision 590.101  2002/02/05 05:05:53  ajc
717  * Don't crash when posting if the user doesn't have an Internet directory address
718
719  Revision 590.100  2002/02/03 15:29:03  error
720  * fixed a silly oversight in serv_crypto.c when removing the ETLS command
721
722  Revision 590.99  2002/02/03 15:21:48  error
723  * Remove the ETLS command, it is no longer needed
724
725  Revision 590.98  2002/02/02 21:44:04  ajc
726  * If a user has at least one valid Internet directory address, stamp it onto
727    any outgoing messages.
728
729  Revision 590.97  2002/02/01 05:11:26  ajc
730  * Added a QDIR protocol command to do quick-and-dirty queries of the directory
731  * In the client, check the directory for conflicts when selecting email addr.
732
733  Revision 590.96  2002/01/31 05:13:44  ajc
734  * When deleting a vCard from the Global Address Book room, remove the
735    corresponding address in the directory.  (Not tested.)
736
737  Revision 590.95  2002/01/30 19:03:41  ajc
738  * Added a new DeleteFunctionHook type of thing.  These get called when a
739    message is being deleted from a room.
740  * When deleting messages from a room, do the AdjRefCount() calls (and now,
741    the PerformDeleteHooks() calls) in a second pass.  This keeps that stuff
742    outside of the S_QUICKROOM critical section.
743
744  Revision 590.94  2002/01/27 06:39:45  error
745  * file_ops.c: fixed bug in cmd_read() which could cause server to report
746    the wrong number of bytes for the client to download
747
748  Revision 590.93  2002/01/26 21:33:38  ajc
749  * More internet addressing and global directory stuff.  I think it's all working now
750    except for the purging of old entries.
751
752  Revision 590.92  2002/01/26 11:02:37  error
753  * citadel.spec cleaned up
754
755  Revision 590.91  2002/01/26 09:23:40  error
756  * setup now has a silent running mode (-q option) where it silently sets
757    defaults for everything.  This is intended for use in scripts such as
758    the RPM packages, eliminating a step from the installation process.
759
760  Revision 590.90  2002/01/26 09:19:16  error
761  * citadel.spec has been completely overhauled, we can make RPMs now!
762
763  Revision 590.89  2002/01/26 04:59:57  ajc
764  * smtp FROM command now validates sender using the validate_recipients() loop
765    (yeah, it's good for that too) making it directory-aware
766
767  Revision 590.88  2002/01/26 04:01:10  error
768  * Formatter now uses more of the available screen width
769
770  Revision 590.87  2002/01/26 03:57:30  error
771  * Revised status_line() display, it's much more compact now
772
773  Revision 590.86  2002/01/26 03:50:26  error
774  * Better error reporting in connection_died(), kills curses before printing
775    error message, prints last errno.
776
777  Revision 590.85  2002/01/25 05:19:03  ajc
778  * Greatly simplified the logic for validating recipient addresses for incoming
779    SMTP.  This logic destroys the whitespace mangling for local names; I will
780    fix this tomorrow.
781
782  Revision 590.84  2002/01/25 04:36:35  ajc
783  * fixz to allow incoming vCards in the address book to actually get processed
784
785  Revision 590.83  2002/01/24 06:52:54  error
786  * citadel_decls.h: fix unresolved extern errors
787
788  Revision 590.82  2002/01/23 05:04:05  ajc
789  * Add vCards from incoming network messages in the GAB to the directory.
790
791  Revision 590.81  2002/01/23 03:39:32  ajc
792  * Added a new hook type for handling incoming network messages
793  * Wrote a skeleton module for net filtering
794
795  Revision 590.80  2002/01/22 10:46:25  error
796  * read_message() and fmout() now accept a FILE to which to send their
797    output; this fixes quoting in the fullscreen client
798
799  Revision 590.79  2002/01/20 08:03:43  error
800  * curses client: use the status line as "input" line in chat mode
801
802  Revision 590.78  2002/01/20 07:43:07  error
803  * serv_chat.c: Server no longer crashes when CHATLOG can't be opened
804
805  Revision 590.77  2002/01/20 05:22:07  error
806  * curses client:  allow goodbye message to be seen on some terminals
807
808  Revision 590.76  2002/01/19 16:56:31  error
809  * Fixed color support, now works when rc_ansi_color is on or auto
810
811  Revision 590.75  2002/01/19 15:10:25  error
812  * Cosmetics for the client status line
813
814  Revision 590.74  2002/01/19 11:59:33  error
815  * A real status line for the text client
816
817  Revision 590.73  2002/01/19 10:08:43  error
818  * fix link for libcitserver.so to tools.o which I broke (oops!)
819
820  Revision 590.72  2002/01/19 09:59:08  error
821  * Full-screen curses support for Citadel text client
822
823  Revision 590.71  2002/01/17 20:11:05  nbryant
824  remove lock.c/lock.h; don't need them for what i was planning after all
825
826  Revision 590.70  2002/01/17 10:48:36  error
827  * cosmetic fixes in the new trace file functionality
828
829  Revision 590.69  2002/01/17 10:32:14  error
830  * lprintf() now logs the session ID for each log entry within a session.
831    Also SMTP, IMAP, POP3 and Citadel protocol commands are differentiated.
832
833  Revision 590.68  2002/01/17 10:16:09  error
834  * migratenet.c: cygwin fix: include limits.h
835
836  Revision 590.67  2002/01/17 10:13:31  error
837  * serv_ical.c: set expire policy for My Calendar> to manual
838
839  Revision 590.66  2002/01/17 07:18:11  ajc
840  * Changed all "free software" references to "open source" in order
841    to piss off Richard Stallman
842
843  Revision 590.65  2002/01/17 00:22:35  nbryant
844  added lock.[ch]: recursive read/write locking support. (not actually used yet)
845
846  Revision 590.64  2002/01/15 12:41:53  error
847  * Implement alternate_semantics (see comments in citadel.rc file)
848
849  Revision 590.63  2002/01/15 11:07:51  ajc
850  * vcard.c: updated vCard "object methods" to handle multiple instances of
851    the same key name when necessary.
852
853  Revision 590.62  2002/01/15 06:38:39  error
854  * Update citadelapi.txt with CtdlUnregister* calls, LogHook calls
855
856  Revision 590.61  2002/01/15 06:20:18  error
857  * Modules can now unregister any of their hooks (though none yet take
858    advantage of this).
859
860  Revision 590.60  2002/01/14 08:49:13  error
861  * Fixed bug in cmd_cre8() causing protocol to get out of sync when creating
862    a new room
863
864  Revision 590.59  2002/01/13 04:46:31  ajc
865  * Allow incoming SMTP to relay to other Citadel nodes for whom we are
866    providing directory service.
867
868  Revision 590.58  2002/01/13 04:06:33  ajc
869  * Repaired the problems I created when moving the_mime_parser()'s variables
870    from the stack to the heap.  (Hint: sizeof(char *) is 4, not 4096)
871
872  Revision 590.57  2002/01/11 15:46:57  error
873  * Allow users to move/copy messages between personal rooms
874
875  Revision 590.56  2002/01/11 04:59:00  ajc
876  * Finished most of the work for the Global Address Book.
877
878  Revision 590.55  2002/01/11 04:37:03  ajc
879  * More code for the Global Address Book
880
881  Revision 590.54  2002/01/11 02:57:35  error
882  * Don't print **** when sending a page or mail from an anonymous-only room
883
884  Revision 590.53  2002/01/10 21:22:37  ajc
885  * Minor changes for global directory service
886
887  Revision 590.52  2002/01/10 04:29:28  ajc
888  * Minor updates for directory service
889
890  Revision 590.51  2002/01/09 23:12:40  ajc
891  * Allow users to zap mailbox rooms
892
893  Revision 590.50  2002/01/09 04:37:32  ajc
894  * Finished the callback stuff for vCard address extraction
895
896  Revision 590.49  2002/01/09 04:05:53  ajc
897  * Began writing code to harvest Internet e-mail addresses from vCards, and
898    hacked together a temporary version (and writeup) of the IGAB command.
899
900  Revision 590.48  2002/01/08 16:34:22  ajc
901  * serv_vcard.c: cosmetic cleanup
902
903  Revision 590.47  2002/01/06 22:44:21  error
904  * Enable/disable encryption in client from command line and/or citadel.rc
905
906  Revision 590.46  2002/01/06 21:25:26  ajc
907  * sysdep.c: in client_write(), handle redirect_fp and redirect_sock *before*
908    handling redirect_ssl, because these need to be done the same way regardless
909    of client session crypto
910  * serv_crypto.c: pasted a bunch of Nathan's #ifdef blocks from sysdep.c in
911    order to gain greater portability (or even to get it to compile on splorph)
912
913  Revision 590.45  2002/01/06 11:13:33  error
914  * Enable SSL/TLS support in the client (again)
915
916  Revision 590.44  2002/01/06 11:11:31  error
917  * Enable SSL/TLS in the client
918
919  Revision 590.43  2002/01/06 10:49:55  error
920  * Add some #includes I apparently somehow missed
921
922  Revision 590.42  2002/01/06 10:33:10  error
923  * SSL/TLS support for the Citadel/UX wire protocol
924
925  Revision 590.41  2002/01/06 08:54:58  error
926  * user_ops.c: fixed become_session() when calling EVT_LOGOUT session hooks
927
928  Revision 590.40  2002/01/05 22:31:22  ajc
929  * Removed some protocol commands and writeups that are no longer necessary
930  * Began some of the framework for the Global Address Book
931
932  Revision 590.39  2002/01/05 12:44:43  error
933  * serv_chat.c: allow a session to be killed while in chat
934
935  Revision 590.38  2002/01/05 12:31:04  error
936  * user_ops.c: become_session() when calling EVT_LOGOUT session hooks
937
938  Revision 590.37  2002/01/05 04:51:36  error
939  * stats now sorts its top 20 lists properly
940
941  Revision 590.36  2002/01/04 20:57:36  nbryant
942  cygwin fix
943
944  Revision 590.35  2002/01/04 20:46:26  nbryant
945  Makefile fix for cygwin (fix migratenet linkage)
946
947  Revision 590.34  2002/01/04 20:43:26  nbryant
948  configure/genstamp: check for struct tm.tm_gmtoff
949
950  Revision 590.33  2002/01/03 22:01:17  ajc
951  * Fixed mail to "sysop"
952
953  Revision 590.32  2002/01/03 21:35:07  ajc
954  * I think this is the last of the fixes for the new submit queue.
955
956  Revision 590.31  2002/01/03 12:27:35  error
957  * Fixed my name in docs/copyright.txt, why didn't I notice that before?
958
959  Revision 590.30  2002/01/03 12:21:02  error
960  * Autoconf support for recognizing OpenSSL
961
962  Revision 590.29  2002/01/03 04:52:28  ajc
963  * serv_network.c: migrated deliveries and bounces to the new message
964    submission subsystem.  NOT TESTED.
965
966  Revision 590.28  2002/01/01 21:32:10  ajc
967  * Finished the updates to serv_smtp.c, although I think there may be a
968    problem with one-too-many reference counts when a message is submitted
969    via SMTP.
970
971  Revision 590.27  2001/12/31 20:15:13  ajc
972  * Almost finished converting serv_smtp.c to the new message submission
973    framework.  Still not done yet; don't use this.
974
975  Revision 590.26  2001/12/30 06:20:46  error
976  * More keys while reading messages:  Q or S same as Ctrl-C, N same as Ctrl-O.
977
978  Revision 590.25  2001/12/30 05:50:46  error
979  * Security:  Citadel now drops privileges when called from telnetd, also
980    checks to make sure you didn't set the setuid/setgid bits.  No more
981    loginwrapper.sh!
982
983  Revision 590.24  2001/12/29 05:19:32  ajc
984  * Minor cosmetic hack
985
986  Revision 590.23  2001/12/29 04:21:22  nixo
987  stupid me. I didn't realize that asking for the header did what I wanted
988  so I changed my little 'y' hack to not bother reading the text of the
989  message. a little saving on the bandwidth.
990
991  Revision 590.22  2001/12/28 22:32:38  nixo
992  Added a "read m<y> next" function in read mode. It will skip to the next
993  message by the user in the current message list (whatever mode you're in
994  be it read forward, last 50, whatever.)
995
996  Revision 590.21  2001/12/28 11:06:53  error
997  * More server support for hostnames up to 63 characters (oops I missed a spot)
998
999  Revision 590.20  2001/12/28 09:39:10  error
1000  * Client support for hostnames up to 63 characters: truncated at 24 in
1001    short who list, full display in long who list.
1002
1003  Revision 590.19  2001/12/28 09:28:04  error
1004  * Server support for hostnames up to 63 characters
1005
1006  Revision 590.18  2001/12/26 05:01:30  ajc
1007  * Added a new developer ID for Anticlimactic Teleservices
1008
1009  Revision 590.17  2001/12/23 10:00:43  error
1010  * Pages are once again formatted to the caller's screen width.
1011
1012  Revision 590.16  2001/12/23 09:57:47  error
1013  * tools.c: added parameter to fmt_date() to allow for printing the seconds
1014    along with the time, e.g. 12:34 pm or 12:34:56 pm
1015
1016  Revision 590.15  2001/12/20 04:54:26  ajc
1017  * If you paid for this software, someone is ripping you off.
1018
1019  Revision 590.14  2001/12/18 08:24:56  nbryant
1020  more lovely configure tweaks (include paths for db)
1021
1022  Revision 590.13  2001/12/18 06:04:08  ajc
1023  * Moved the buffers in the_mime_parser() from the stack to the heap, because
1024    it was crashing boxen with small stack sizes.
1025
1026  Revision 590.12  2001/12/18 05:54:16  ajc
1027  * Added more load_floorlist() commands to the beginning and end of functions
1028    in the client that manipulate the floor list.  This fixes a bug in which
1029    new floors don't show up right away after being created.
1030
1031  Revision 590.11  2001/12/17 08:14:26  nbryant
1032  restored the checks for /usr/include/db3 and /usr/local/include/db3
1033  in configure.  there are too many variations on db installation; this is
1034  getting messy :-(
1035
1036  Revision 590.10  2001/12/17 08:00:45  nbryant
1037  set the pthreads stack size to 128K because FreeBSD's default of 64K
1038  seems too small. fixes crashes under FreeBSD.
1039
1040  Revision 590.9  2001/12/16 00:50:14  error
1041  * Added usersupp.lastcall to the parameters returned from the PASS/PAS2
1042    commands in logged_in_response().
1043
1044  Revision 590.8  2001/12/14 21:33:18  nbryant
1045  finally changed configure to complain if there's no database driver ;)
1046
1047  Revision 590.7  2001/12/14 08:29:30  error
1048  * Security: trace file is now only readable by owner, since it contains
1049    plain text passwords.
1050
1051  Revision 590.6  2001/12/14 07:04:24  ajc
1052  * Now you can send mail to yourself.  Hi from Stu.
1053
1054  Revision 590.5  2001/12/14 06:58:12  ajc
1055  * Hi from Stu
1056
1057  Revision 590.4  2001/12/13 22:36:30  nbryant
1058  make configure search for /usr/local/BerkeleyDB.4.0
1059
1060  Revision 590.3  2001/12/13 22:29:57  nbryant
1061  make it compile with Berkeley DB 4.0.x
1062
1063  Revision 590.2  2001/12/11 21:31:07  nbryant
1064   - test for -ldb3 before -ldb
1065
1066  Revision 590.1  2001/12/11 20:04:41  nbryant
1067   - fix library flags, includes for portability
1068   - malloc.h is deprecated
1069   - fix genstamp, hopefully
1070   - fix size_t *printf handling for portability
1071
1072  Revision 590.0  2001/12/08 03:31:41  ajc
1073  * THIS IS 5.90
1074
1075  Revision 580.95  2001/12/08 03:30:37  ajc
1076  * Final changes to networking docs for 5.90
1077
1078  Revision 580.94  2001/12/06 05:13:34  ajc
1079  * Added the documentation for room sharing and listserv
1080
1081  Revision 580.93  2001/12/04 05:24:15  ajc
1082  * Added two more bytes to the possible length of shared secrets in networking
1083    due to some legacy support requirements.
1084
1085  Revision 580.92  2001/12/04 05:16:19  ajc
1086  * mime_parser.c: change to memory allocation algorithm ... some badly done
1087    messages were crashing the server
1088
1089  Revision 580.91  2001/12/03 22:48:16  ajc
1090  * ooops.  Look for the QR2_SYSTEM flag in QRflags2, not QRflags.
1091
1092  Revision 580.90  2001/12/03 17:02:50  ajc
1093  * dynloader.c: fixed improperly done declaration and mallok()
1094
1095  Revision 580.89  2001/12/03 04:28:02  ajc
1096  * mime_parser.c: now uses built-in functions to decode base64 and
1097    quoted-printable attachments, instead of piping data to outboard programs.
1098
1099  Revision 580.88  2001/12/03 02:45:46  ajc
1100  * Began implementing some code to handle multiple recipients (but #define'd
1101    it all out because we're approaching a release)
1102
1103  Revision 580.87  2001/12/03 01:50:17  ajc
1104  * When sending mail, copy to the sender's "Sent Items>" room instead of to
1105    the sender's "Mail>" room.
1106
1107  Revision 580.86  2001/12/02 23:36:24  ajc
1108  * On a new system, set the default new user level to 4 instead of 1.
1109
1110  Revision 580.85  2001/12/02 23:27:01  ajc
1111  * Removed references to the old networker from the documentation.  Did not
1112    write any new documentation, so what's there now is kind of sparse.
1113
1114  Revision 580.84  2001/12/02 02:42:55  ajc
1115  * Implemented new room flag QR2_SYSTEM which supresses the room from all
1116    room listings, even for Aides (but it's still gotoable).  This will be used
1117    for rooms which hold system configuration and message queues.
1118
1119  Revision 580.83  2001/12/01 19:23:26  ajc
1120  * clientsocket.c: implement socket timeouts for read operations
1121
1122  Revision 580.82  2001/12/01 17:00:23  ajc
1123  * serv_smtp.c: when multiple MX's are the same preference, randomize them
1124
1125  Revision 580.81  2001/12/01 07:18:28  ajc
1126  * Fixed an SMTP delivery problem that was causing certain classes of
1127    transient errors to cause a message to never be delivered.
1128
1129  Revision 580.80  2001/12/01 05:26:01  ajc
1130  * Added a command "SMTP" to the Citadel protocol, to do some unimportant
1131    utility/diagnostic functions.
1132
1133  Revision 580.79  2001/11/27 17:08:29  ajc
1134  * When calling an external editor, set the environment variable
1135    WINDOW_TITLE to an appropriate value.
1136
1137  Revision 580.78  2001/11/26 03:27:08  ajc
1138  * new algorithm to load the use table
1139
1140  Revision 580.77  2001/11/17 19:55:08  ajc
1141  * Updated some of the documentation
1142
1143  Revision 580.76  2001/11/16 04:43:12  ajc
1144  * Eliminated the sock_puts_crlf() function and ensured that all SMTP client
1145    commands are sent out using a single sock_write() call.  There are broken
1146    SMTP server implementations that can't handle SMTP commands split across
1147    multiple writes.  (Thanks to Andru Luvisi and Ben Mehlman for the idea.)
1148
1149  Revision 580.75  2001/11/15 04:11:30  ajc
1150  * hack.doc: updated to reflect Cit86Net compatibility fields removed from the
1151    file format (since we dumbed down the gateway software)
1152  * ipc_c_tcp.c: removed SOCKS4 support.  Nobody uses it anymore.
1153  * ipc_c_tcp.c: fixed a bug which caused the client to fall back to defaultPort
1154    if a numeric port number was specified instead of a service name
1155
1156  Revision 580.74  2001/11/14 02:59:01  ajc
1157  * Network run frequency is now a site-definable setting
1158
1159  Revision 580.73  2001/11/13 22:05:23  ajc
1160  * Re-introduced the ability to enter IGnet mail into the system.
1161
1162  Revision 580.72  2001/10/29 22:59:22  ajc
1163  * Renamed "SuppMsgInfo" to "MetaData" because that's what it is
1164
1165  Revision 580.71  2001/10/29 16:39:54  ajc
1166  * Finished the migratenet utility (finally).
1167
1168  Revision 580.70  2001/10/28 05:18:51  ajc
1169  * migratenet almost finished
1170
1171  Revision 580.69  2001/10/26 04:26:45  ajc
1172  * more work on the net migrator
1173
1174  Revision 580.68  2001/10/23 03:37:33  ajc
1175  * Threw a few more lines of code into migratenet.c
1176
1177  Revision 580.67  2001/10/20 18:10:50  ajc
1178  * migratenet.c: added (not even close to being finished)
1179
1180  Revision 580.66  2001/10/17 21:07:20  nbryant
1181  further format string cleanups (for i686-linux type sizes)
1182
1183  Revision 580.65  2001/10/17 20:41:07  nbryant
1184   - declare *printf format specifiers if gcc detected
1185   - format string fixes (compiles w/o warnings on alpha osf/1)
1186
1187  Revision 580.64  2001/10/17 19:40:38  nbryant
1188  warning fixes and cleanups for 64-bit machines
1189
1190  Revision 580.63  2001/10/16 20:47:37  nbryant
1191  - backed out -export-dynamic, it doesn't do anything and i've found the real
1192  problem
1193  - remove declaration for make_message
1194
1195  Revision 580.62  2001/10/16 19:18:49  nbryant
1196  backed out that compiler detection change for Tru64. it's not incredibly
1197  important and results in broken autoconf macro expansions.
1198
1199  Revision 580.61  2001/10/16 18:36:33  nbryant
1200  reinstate -export-dynamic for citserver in case libtool decides to build
1201  static libraries (why?)
1202
1203  Revision 580.60  2001/10/16 18:21:53  nbryant
1204  add some explanatory text to bootstrap
1205
1206  Revision 580.59  2001/10/16 17:43:53  nbryant
1207   - further configure tweaks for FreeBSD and Tru64 Unix
1208   - updated to latest libtool configure fragment
1209   - there are two functions named make_message. (?) so declare them both
1210     static.
1211
1212  Revision 580.58  2001/10/16 01:48:55  nbryant
1213  - configury tweaks for a /usr/include/db3 goof and Digital/Tru64 Unix
1214  - #ifdef out inline on non-GCC compilers
1215
1216  Revision 580.57  2001/10/15 19:50:50  ajc
1217  * Fixed a bug in the loopzapper that was corrupting the use table saved copy.
1218  * Post notification in Aide> when the loopzapper catches a message.
1219
1220  Revision 580.56  2001/10/12 22:41:11  ajc
1221  * Wrote the rest of the use table code.  Finished except for a bug.
1222
1223  Revision 580.55  2001/10/10 18:35:12  ajc
1224  * Comments & cosmetics for previous update
1225
1226  Revision 580.54  2001/10/10 17:12:54  ajc
1227  * Bugfix for MSG0 command to properly handle multipart/alternative
1228
1229  Revision 580.53  2001/10/06 21:32:29  ajc
1230  * Finished the concurrency check for network polling.  (Now works both for
1231    polling and being polled.  Severe UUCP deja vu.)
1232
1233  Revision 580.52  2001/10/06 20:28:06  ajc
1234  * Began implementing some concurrency stuff for the networker
1235
1236  Revision 580.51  2001/10/06 19:51:47  ajc
1237  * Stripped the build of obsolete parts of the old networker no longer in use.
1238
1239  Revision 580.50  2001/10/03 20:05:50  ajc
1240  * serv_smtp.c: implement RFC2920 ESMTP "pipelining" extension on the server
1241    side.  (No changes required other than advertising the extension.)
1242
1243  Revision 580.49  2001/10/03 03:15:16  ajc
1244  * Implemented BOUNCE BOUNCE BOUNCE
1245
1246  Revision 580.48  2001/10/02 03:04:30  ajc
1247  * Allow non-Aides to terminate sessions belonging to them
1248
1249  Revision 580.47  2001/09/24 18:55:13  ajc
1250  * Completed migrating the "netpoll" utility into the serv_network module.
1251    Removed this utility.
1252
1253  Revision 580.46  2001/09/21 20:58:25  nbryant
1254  support different log_archive prototype in DB versions prior to 3.3
1255
1256  Revision 580.45  2001/09/20 04:17:10  ajc
1257  * Inbound network authentication working.  Fixed a bug in the split-horizon
1258    algorithm.  Still need to move the 'netpoll' command into the server.
1259
1260  Revision 580.44  2001/09/18 04:05:04  ajc
1261  * Added host/IP and port to node config (client side only)
1262
1263  Revision 580.43  2001/09/17 23:55:45  ajc
1264  * Support for IGnet routing (not tested)
1265
1266  Revision 580.42  2001/09/16 05:44:51  ajc
1267  * serv_smtp.c: instead of doubling delivery retry times unbounded, set a
1268    maximum retry time of SMTP_RETRY_MAX (currently set to 12 hours)
1269
1270  Revision 580.41  2001/09/09 16:19:29  error
1271  * Updated PAM configuration file citadel.pam for Red Hat 7.x.
1272
1273  Revision 580.40  2001/09/09 03:19:38  ajc
1274  * cdb_cull_logs() now removes log files as soon as the log_archive() function
1275    says it's ok to do so.
1276
1277  Revision 580.39  2001/09/08 18:58:38  ajc
1278  * More changes to the new networker.  Added client command for room sharing.
1279
1280  Revision 580.38  2001/09/07 04:05:27  ajc
1281  * You guessed it: still more code for the new networker.
1282
1283  Revision 580.37  2001/09/06 05:47:29  nbryant
1284  check for /usr/include/db3 (for RedHat 6.2; others?)
1285
1286  Revision 580.36  2001/09/06 05:23:14  nbryant
1287  #include fix for glibc 2.1.3
1288
1289  Revision 580.35  2001/09/06 04:02:34  ajc
1290  * A few more updates to the networker
1291
1292  Revision 580.34  2001/09/06 03:32:41  nbryant
1293  build fix for sparc-sun-solaris2.8; i think the dependencies should be
1294  set up properly for all platforms now.
1295
1296  Revision 580.33  2001/09/06 02:55:27  nbryant
1297  build fix for Linux
1298
1299  Revision 580.32  2001/09/06 02:49:22  ajc
1300  * Fixed paste-post mode (<.E>nter <A>scii) to append instead of replace when
1301    the user hits <C>ontinue (bug reported by Stu Mark)
1302
1303  Revision 580.31  2001/09/06 01:26:39  nbryant
1304   - port to Cygwin (DLL support, etc.)
1305   - don't build SMTP module if there's no resolver library (eg on Windows)
1306
1307  Revision 580.30  2001/09/06 00:54:01  nbryant
1308  updated to libtool 1.4.1 and automake 1.5
1309
1310  Revision 580.29  2001/08/29 02:51:25  ajc
1311  * More work on the new networker.
1312
1313  Revision 580.28  2001/08/25 05:04:57  ajc
1314  * Worked a little more on the in-server replacement for netproc
1315
1316  Revision 580.27  2001/08/22 04:18:17  ajc
1317  * Realized that there was lots of similarly broken code in
1318    process_rfc822_addr().  Wrote two new utility functions in tools.c
1319    stripout() and stripallbut() and used them where appropriate.  This should
1320    take care of all possible infinite loops.
1321
1322  Revision 580.26  2001/08/22 03:43:11  ajc
1323  * internet_addressing.c: fixed a bug in process_rfc822_addr() that caused the
1324    server to jump into an endless loop when an e-mail address contained
1325    unbalanced angle brackets.
1326
1327  Revision 580.25  2001/08/15 04:26:02  ajc
1328  * Added split horizon and delete-after-spool to the new networker
1329
1330  Revision 580.24  2001/08/14 02:41:57  ajc
1331  * Began the migration of netproc into part of the serv_network.c module instead
1332    of a standalone program.
1333
1334  Revision 580.23  2001/08/11 22:35:40  nbryant
1335  updated citadel-with-berkeley-db.txt.
1336   - updated build instructions
1337   - improved backup procedures to be safer and more space-efficient.
1338
1339  Revision 580.22  2001/08/11 19:18:41  ajc
1340  * Realized that I am stupid and started implementing server commands to load
1341    and save network configurations, when I had already lovingly implemented the
1342    CONF GETSYS and CONF PUTSYS commands to store arbitrary configuration sets
1343    in the Local System Configuration> room.  Ripped the newer crap out.
1344  * Implemented a skeleton of <.A>ide <S>ysconfig <N>etwork on the client side.
1345
1346  Revision 580.21  2001/08/11 03:51:56  ajc
1347  * Removed the idle timer from the client.  Dialup is dead.
1348
1349  Revision 580.20  2001/08/06 21:33:29  nbryant
1350  made the client fall back on port 504 if there's no /etc/services entry
1351
1352  Revision 580.19  2001/08/05 23:54:14  ajc
1353  * prep for new network node infrastructure
1354
1355  Revision 580.18  2001/08/03 16:53:21  ajc
1356  * Added some more "break" statements to the main switch..case loop in
1357    citadel.c where they were needed.
1358
1359  Revision 580.17  2001/08/03 16:43:53  ajc
1360  * database_sleepycat.c: when running txn_checkpoint(), handle DB_INCOMPLETE
1361    return code as a warning instead of an error worthy of aborting the server.
1362    See http://www.sleepycat.com/docs/api_c/txn_checkpoint.html for explanation.
1363
1364  Revision 580.16  2001/07/30 03:46:14  nbryant
1365  made ForEachUser use a read-only cursor, too. there is now only one piece of
1366  code in Citadel proper (not the database driver) that needs transactions.
1367  that's check_ref_counts; in other words it's the only thing standing in the way
1368  of a clean implementation of retryable transactions.
1369
1370  Revision 580.15  2001/07/29 22:24:04  nbryant
1371   - added a new function to the database interface, cdb_close_cursor().  always
1372  call this when you're finished with a traversal but didn't bother reading all
1373  the way to the end.
1374
1375   - removed several cdb_begin_transaction()/cdb_end_transaction() calls that are
1376  no longer needed because of the read-only cursor support.
1377
1378  Revision 580.14  2001/07/29 20:56:09  nbryant
1379  change ForEachRoom to use read-only cursors by default. it can be overridden to
1380  still use read/write cursors by doing:
1381
1382   cdb_begin_transaction();
1383   ForEachRoom(...);
1384   cdb_end_transaction();
1385
1386  the only place I found where it appears necessary to do so is check_ref_counts,
1387  so this checkin affects that function too.
1388
1389  Revision 580.13  2001/07/29 20:06:33  nbryant
1390  generate symlinks to .libs in modules directory
1391
1392  Revision 580.12  2001/07/28 00:02:50  nbryant
1393  implemented read-only cursors. one of the advantages to these is that
1394  transactions can be avoided; a cursor operation that occurs within a
1395  transaction will often acquire a read lock on every single database page.  in
1396  general, the Sleepycat documentation recommends avoiding transaction-protected
1397  read-only operations where practical. read/modify/write operations can still
1398  be transaction protected, of course.
1399
1400  to use a read-only cursor, call cdb_rewind without a previous call to
1401  cdb_begin_transaction. the DB driver will notice this and prevent the current
1402  thread from modifying data or starting a transaction until the cursor is
1403  closed.
1404
1405  Revision 580.11  2001/07/27 20:45:44  nbryant
1406  libtool has matured a lot since the last time i looked at it (years ago)
1407  so we now use it to handle the details of building shared libraries and
1408  the linker flags for the main executable.
1409
1410  in theory this should bring a lot more portability to the dynloader
1411  subsystem and enable us to do things like transparently detect GNU vs Sun
1412  linkers on solaris, for example
1413
1414  Revision 580.10  2001/07/27 03:29:04  nbryant
1415  missed one thing in the autoconf move
1416
1417  Revision 580.9  2001/07/27 02:57:43  nbryant
1418  support one cursor per database rather than one global cursor
1419
1420  Revision 580.8  2001/07/27 01:32:07  nbryant
1421  remove the automatic transaction demarcation on singleton read operations
1422
1423  Revision 580.7  2001/07/26 21:43:46  nbryant
1424   - move to autoconf 2.52
1425   - random warning fix
1426   - check for db 3.3
1427
1428  Revision 580.6  2001/07/24 13:17:54  ajc
1429  * New UI for mailing list setup
1430  * rooms.c: code cleanup
1431  * docs update
1432
1433  Revision 580.5  2001/07/20 23:48:23  nbryant
1434  fix build on solaris, check default install location for db 3.2, and silence
1435  gcc 3.0
1436
1437  Revision 580.4  2001/07/16 14:24:30  ajc
1438  * Silly cosmetic change to keep the wholist ordered by ascending session number
1439
1440  Revision 580.3  2001/07/13 00:01:36  ajc
1441  * Shuffled around some of the housekeeping loop code
1442
1443  Revision 580.2  2001/07/11 17:01:10  ajc
1444  * database_sleepycat.c: small changes to log messages
1445
1446  Revision 580.1  2001/07/11 04:35:40  nbryant
1447  moved dret initialization in cdb_fetch, just in case
1448
1449  Revision 580.0  2001/07/03 03:07:06  ajc
1450  * THIS IS 5.80
1451
1452  Revision 573.143  2001/07/03 03:06:50  ajc
1453  * Last minute doco update for 5.80
1454
1455  Revision 573.142  2001/07/01 15:44:32  nbryant
1456  configure.in: check for Berkeley DB first.
1457
1458  Revision 573.141  2001/06/27 23:34:30  ajc
1459  * Added some verbage to messages/roomaccess to placate a user who keeps
1460    bitching about privacy policy.
1461
1462  Revision 573.140  2001/06/19 03:41:04  ajc
1463  * Ooops... last_cull needs to be declared static
1464
1465  Revision 573.139  2001/06/19 03:33:19  ajc
1466  * imap_fetch.c: download MIME parts without decoding first.  We like that.
1467  * database_sleepycat.c: added automatic culling of log files which have not
1468    been written to in five days.
1469
1470  Revision 573.138  2001/06/17 19:42:23  nbryant
1471  fix all the <time.h> vs. <sys/time.h> issues, hopefully
1472
1473  Revision 573.137  2001/06/07 03:28:37  ajc
1474  * More tweaks to the MIME parser
1475
1476  Revision 573.136  2001/06/06 15:44:37  ajc
1477  * msgbase.c: output extra newline at end of RFC822 message if necessary to
1478    ensure that 000 termination string appears on a line by itself.
1479
1480  Revision 573.135  2001/06/06 04:22:25  ajc
1481  * Moved memreadline() to tools.c
1482  * internet_addressing.c: fixed conversion of fields to (hopefully) never get
1483    into an active loop when encountering badly formed headers
1484
1485  Revision 573.134  2001/05/27 05:23:03  ajc
1486  * Added a "no new messages" response in the client, displayed when a read
1487    command turns up a zero message count.
1488
1489  Revision 573.133  2001/05/18 20:12:09  ajc
1490  * Fixed bug in mime_parser.c that caused parts to be dropped when the last
1491    boundary was the very last line of the message.
1492  * serv_smtp.c: toned down some of the command response verbage.
1493
1494  Revision 573.132  2001/04/28 04:42:55  ajc
1495  * Updated some of the docs.  Bumped version number to 5.80 in anticipation
1496    of going into a release cycle soon.
1497
1498  Revision 573.130  2001/04/26 03:31:00  ajc
1499  * Finished the implementation of per-message seen/unseen logic, both in the
1500    server proper and in IMAP.  Citadel protocol uses new "seen" command.
1501
1502  Revision 573.129  2001/04/21 04:55:51  ajc
1503  * Began implementation of per-message seen/unseen attribute
1504
1505  Revision 573.128  2001/04/20 03:39:54  ajc
1506  * IMAP LIST/LSUB: made it case insensitive.  Also minor IMAP code cleanup.
1507
1508  Revision 573.127  2001/04/17 00:35:19  cough
1509  * Modified rooms.c in the client so that it would allow inviting into
1510    public rooms.  This is important since there is now a V_LOCKOUT
1511    flag which prevents users who have been kicked from rejoining
1512    a room unless/until you invite them back in.
1513
1514  Revision 573.126  2001/04/16 19:21:14  cough
1515  * Fixed bug in room_ops.c that wasn't allowing aides to goto passworded
1516    rooms without knowing the password.
1517
1518  Revision 573.125  2001/04/14 04:26:44  ajc
1519  * Fixed an unterminated string bug in IMAP APPEND.  Storing messages should
1520    work now.
1521
1522  Revision 573.124  2001/04/10 01:04:10  ajc
1523  * Finished coding IMAP APPEND.  It works, but there's a bug in it somewhere
1524    that is corrupting the memory.
1525
1526  Revision 573.123  2001/04/03 00:47:23  ajc
1527  * Began implementing IMAP APPEND
1528
1529  Revision 573.122  2001/04/01 22:05:44  cough
1530  * *Actually* fixed a botched ChangeLog entry.
1531
1532  Revision 573.121  2001/04/01 22:04:28  cough
1533  * Fixed a botched ChangeLog entry.
1534
1535  Revision 573.120  2001/04/01 22:03:10  cough
1536  * Changed two fclose()s to pclose()s.
1537
1538  Revision 573.119  2001/03/25 11:52:36  error
1539  * serv_pop3.c: Fixed APOP. Now logs in properly. Also cleaned up some non-
1540    RFC-compliant error messages.
1541
1542  Revision 573.118  2001/03/21 05:47:49  ajc
1543  * Added the new IMAP mailbox string compare submitted by Daniel Malament.
1544
1545  Revision 573.117  2001/03/20 01:33:55  ajc
1546  * Added the (\NoInferiors) tag to all rooms listed in IMAP.  This made Mozilla
1547    behave very nicely.
1548
1549  Revision 573.116  2001/03/13 17:19:33  ajc
1550  * support (BODY[HEADER.FIELDS(BLAH BLAH BLAH)]) and HEADER.FIELDS.NOT
1551
1552  Revision 573.115  2001/03/12 01:27:42  ajc
1553  * Implemented SUBSCRIBE and UNSUBSCRIBE commands
1554
1555  Revision 573.114  2001/03/11 23:00:29  ajc
1556  * Mega sexy hack to deliver express messages THROUGH IMAP!  uber coolness!!
1557
1558  Revision 573.113  2001/03/11 22:09:20  ajc
1559  * Replaced the "citlogin" binary wrapper with the "loginwrapper.sh" script.
1560
1561  Revision 573.112  2001/03/11 20:06:53  ajc
1562  * Fixed bug that created incorrect roomnames when sending pages
1563
1564  Revision 573.111  2001/03/11 19:23:32  ajc
1565  * IMAP DELETE command ... also split up access control for room delete cmds
1566
1567  Revision 573.110  2001/03/10 17:29:07  ajc
1568  * Implement proper access control for deleting messages from IMAP
1569
1570  Revision 573.109  2001/03/07 04:02:27  ajc
1571  * Fixed some small IMAP bugs
1572
1573  Revision 573.108  2001/03/06 04:44:00  ajc
1574  * Probable completion of STATUS, COPY, STORE, and EXPUNGE commands in IMAP
1575
1576  Revision 573.107  2001/03/06 03:31:58  nbryant
1577  database-related cleanups and paranoia tests;
1578  fixed a transaction-leak/deadlock problem in cdb_delete;
1579  solved the SIGPIPE mystery (GDB stops on SIGPIPE is all it was)
1580
1581  Revision 573.106  2001/03/05 04:59:31  ajc
1582  * IMAP COPY
1583
1584  Revision 573.105  2001/03/04 23:49:41  ajc
1585  * IMAP EXPUNGE responses -should- be correct now
1586
1587  Revision 573.94  2001/02/20 00:02:56  ajc
1588  * IMAP: implemented the STATUS command (sort of).
1589
1590  Revision 573.93  2001/02/19 22:24:41  ajc
1591  * IMAP server: added untagged, unsolicited server messages for newly arrived
1592    messages, and messages expunged by another session.
1593
1594  Revision 573.92  2001/02/17 05:53:35  ajc
1595  * Repaired the creation of page log rooms in the wrong namespace when the
1596    recipient does not yet have his/her log room created.
1597  * Rewrite "EXPI messages" to run in two passes: one to gather messages to
1598    purge and the next to delete them.  Works better in transactionland.
1599
1600  Revision 573.91  2001/02/14 08:11:27  error
1601  * citadel.rc: added $Id$ (it's about time!)
1602
1603  Revision 573.90  2001/02/14 04:23:54  ajc
1604  * Fixed POP3 server responses ending in \n instead of \r\n as they should be.
1605    This was causing some clients (such as Pine) to lock up.
1606
1607  Revision 573.89  2001/02/13 04:06:14  ajc
1608  * Worked out the remaining bugs in IMAP FETCH for the BODYSTRUCTURE and
1609    BODY[n] data items.  I think.  So much protocol crud, so little time...
1610
1611  Revision 573.88  2001/02/13 01:18:44  ajc
1612  * imap fetch
1613
1614  Revision 573.87  2001/02/12 04:31:34  ajc
1615  * sysdep.c ig_tcp_server() - use IPPROTO_TCP instead of getprotobyname()
1616
1617  Revision 573.86  2001/02/08 04:45:58  ajc
1618  * Fixed namespace problems resulting from the automatic namespece prefixing
1619    added to create_room().  Also added the ability to specify "create a mailbox
1620    but I've already supplied the namespace prefix" for situations where the
1621    namespace isn't that of the logged in user.
1622  * Made the POP3 server response messages slightly less humorous
1623
1624  Revision 573.85  2001/02/06 04:44:12  ajc
1625  * Added a floor listing (complete with \NoSelect flag) to LIST and LSUB
1626
1627  Revision 573.84  2001/02/06 02:09:38  ajc
1628  * citadel.rc: changed the default for local_screen_dimensions to 1, since
1629    Internet users now outnumber dialup users 100 to 0.
1630  * room_ops.c: added a really_create option to create_room().  Also moved the
1631    generation of personal namespace into that function.  MODULE OWNERS PLEASE
1632    CHECK YOUR CALLS TO AVOID MULTIPLE NAMESPACING!!
1633  * room_ops.c: fixed a bug in cgetfloor() that left bad pointers around
1634  * serv_imap.c: finished the CREATE command (finally)
1635
1636  Revision 573.83  2001/02/05 05:20:22  ajc
1637  * Made some changes to functions which translate between Citadel room names
1638    and IMAP folder names.  They're still buggy.
1639
1640  Revision 573.82  2001/02/04 23:17:28  ajc
1641  * Implemented the IMAP CREATE command
1642
1643  Revision 573.81  2001/02/04 02:40:07  ajc
1644  * more imap.  imap sucks.  die crispin die.
1645
1646  Revision 573.80  2001/02/03 10:02:12  error
1647  * serv_ical.c: Verify that objects posted to My Calendar> are of type
1648    text/x-calendar or text/calendar; abort saving if not
1649
1650  Revision 573.79  2001/02/03 09:30:46  error
1651  * serv_ical.c: now creates a My Calendar> personal room, sets attributes
1652
1653  Revision 573.78  2001/02/03 08:21:00  error
1654  * serv_ical.c and serv_ical.h added; skeleton code for now
1655
1656  Revision 573.77  2001/02/02 20:18:18  ajc
1657  * Changed the error message in cdb_delete() to actually *say* cdb_delete
1658    instead of cdb_store.  Useful to know which function failed...
1659
1660  Revision 573.76  2001/02/01 04:08:03  ajc
1661  * IMAP minor change to mailbox name output
1662  * Increased size of buffer in lprintf()
1663
1664  Revision 573.75  2001/01/28 09:50:02  error
1665  * sysdep.c: lprintf() now generates timestamps
1666
1667  Revision 573.74  2001/01/28 07:35:04  error
1668   * serv_bio.c: RBIO now also returns stats about a user, see session.txt
1669
1670  Revision 573.73  2001/01/16 04:03:13  ajc
1671  * yeesh ... more on the IMAP BODYSTRUCTURE
1672
1673  Revision 573.72  2001/01/16 01:51:12  ajc
1674  * imap bodystructure
1675
1676  Revision 573.71  2001/01/16 00:46:40  ajc
1677  * Changed the MIME parser API *again* because we now need the ability to
1678    supply callback functions to be executed before and/or after parsing a
1679    multipart.  (Need this for IMAP BODYSTRUCTURE output.  Crispin sucks.)
1680
1681  Revision 573.70  2001/01/15 23:59:26  ajc
1682  * user_ops.c: reject NULL password in CtdlTryPassword() instead of crashing
1683
1684  Revision 573.68  2001/01/15 20:34:04  ajc
1685  * "Path:" removed for now because it confuses brain-dead Microsoft shitware
1686    into thinking that mail messages are newsgroup messages instead.  When we
1687    add NNTP support back into Citadel we'll have to add code to only output
1688    this field when appropriate.
1689
1690  Revision 573.67  2001/01/15 16:30:31  ajc
1691  * temporary implementation of 901 asynchronous express messages
1692
1693  Revision 573.66  2001/01/14 14:55:39  ajc
1694  * Changed the format of <.W>holist <L>ong
1695
1696  Revision 573.65  2001/01/13 06:40:26  nbryant
1697  merged remaining changes from TRANSACTIONS (using cvs update -j TRANSACTIONS)
1698  which should now be considered closed.
1699
1700  Revision 573.64  2001/01/13 06:12:15  ajc
1701  * Added the ASYN command
1702
1703  Revision 573.63  2001/01/12 22:05:46  ajc
1704  * Fixed a bug that caused bogus wholist lines to be displayed when a non-aide
1705    reads a list containing stealth mode sessions.
1706
1707  Revision 573.62  2001/01/09 05:39:45  ajc
1708  * Merged in code from the TRANSACTIONS branch for testing.
1709
1710  Revision 573.61  2000/12/30 06:17:17  ajc
1711  * Still more work on IMAP.  Damn this is tedious.
1712
1713  Revision 573.60  2000/12/30 04:55:05  ajc
1714  * more buffer size stuff
1715
1716  Revision 573.59  2000/12/27 20:19:51  ajc
1717  * The size constant "256" which shows up everywhere as a buffer size has now
1718    been changed to SIZ.  And, SIZ has been defined now as 1024, not 256, because
1719    we need 1024 byte buffers for most Internet protocols.
1720
1721  Revision 573.58  2000/12/27 05:09:58  ajc
1722  * Added a skeleton IMAP "SEARCH" command (based on the FETCH logic)
1723
1724  Revision 573.57  2000/12/26 03:46:50  ajc
1725  * More IMAP tweaks
1726
1727  Revision 573.56  2000/12/25 22:50:43  ajc
1728  * Added an API function to extract and unfold specific RFC822 fields.
1729  * imap-->fetch-->envelope-->in-reply-to now works
1730  * More robust checking and reporting of temp file errors in the client
1731
1732  Revision 573.55  2000/12/25 20:43:24  ajc
1733  * imap_fetch.c: added support for fetch-->envelope-->from
1734
1735  Revision 573.54  2000/12/20 04:09:24  ajc
1736  * A few memory handling fixes to netproc.
1737
1738  Revision 573.53  2000/12/20 01:57:37  ajc
1739  * netproc.c: added bounds check to fpgetfield()
1740
1741  Revision 573.52  2000/12/19 20:41:55  ajc
1742  * Fixed generation of unique file names for network uploads etc.
1743
1744  Revision 573.51.2.11  2000/12/26 05:30:55  nbryant
1745  remove extraneous transaction around dynamic module initializations. this will
1746  fix the crash on database creation.
1747
1748  Revision 573.51.2.10  2000/12/24 23:00:58  nbryant
1749  clean: also remove parsedate.c
1750
1751  Revision 573.51.2.9  2000/12/20 01:38:42  nbryant
1752  require transactional cursors
1753
1754  Revision 573.51.2.8  2000/12/20 00:30:01  nbryant
1755  release any stale db handles at the end of a server command
1756  (unfinished transactions will be aborted to annoy lazy programmers)
1757
1758  Revision 573.51.2.7  2000/12/19 06:18:27  nbryant
1759  set sched_yield as sleepycat's yield function. this should improve locking
1760  performance.
1761
1762  Revision 573.51.2.6  2000/12/19 02:22:29  nbryant
1763  added automatic transaction start/end on cdb_fetch, cdb_delete, and cdb_store
1764
1765  Revision 573.51.2.5  2000/12/18 03:51:13  nbryant
1766  ditto S_USER_TRANS, S_CALLLOG, and S_HOUSEKEEPING, which are no longer used at
1767  all
1768
1769  Revision 573.51.2.4  2000/12/18 02:49:17  nbryant
1770  removed all references to S_MSGMAIN critical section; it wasn't really needed.
1771  this should make things significantly more scaleable.
1772
1773  Revision 573.51.2.3  2000/12/17 22:12:48  nbryant
1774  reworked shutdown sequence to wait for worker threads to terminate before
1775  checkpointing and closing databases. it is no longer safe to call
1776  master_cleanup() directly to force a shutdown; instead, just set
1777  time_to_die to a nonzero value
1778
1779  Revision 573.51.2.2  2000/12/17 05:06:09  nbryant
1780  added deadlock detection and cleaned up messages
1781
1782  Revision 573.51.2.1  2000/12/16 21:06:59  nbryant
1783  created TRANSACTIONS branch
1784  track cursor and transaction id's in thread-specific data
1785
1786  Revision 573.51  2000/12/14 18:36:34  ajc
1787  * Fixed the "users not in chat" wholist display
1788
1789  Revision 573.50  2000/12/12 18:06:46  ajc
1790  * Removed the transaction stuff (but left the log in).  It wasn't working.
1791
1792  Revision 573.49  2000/12/12 06:19:55  ajc
1793  * Stabilize, dammit!!
1794
1795  Revision 573.48  2000/12/12 04:20:03  ajc
1796  * Made the transaction open/close a global thing, in a frantic attempt to get
1797    Uncensored to stop crashing.  More fixes on the way...
1798
1799  Revision 573.47  2000/12/11 06:08:41  ajc
1800  * Removed the housekeeper thread, moved terminate_idle_sessions() out to a
1801    timer event, and check_sched_shutdown() to the end of the worker thread
1802    loop.  Seems to have improved reliability (but why?)
1803
1804  Revision 573.46  2000/12/11 03:22:11  ajc
1805  * Added server-side REQT command to issue client termination requests
1806
1807  Revision 573.45  2000/12/11 02:19:26  ajc
1808  * Client now honors EM_GO_AWAY flag, used by the server to request that a
1809    client log off.  (The server doesn't support sending that flag yet, though)
1810
1811  Revision 573.44  2000/12/09 06:20:06  ajc
1812  * A few final touches to the Sleepycat DB back-end
1813
1814  Revision 573.43  2000/12/08 17:06:33  ajc
1815  * Wrap txn_begin and txn_end in S_DATABASE mutex
1816
1817  Revision 573.42  2000/12/07 20:21:39  ajc
1818  * begin/end transaction in master_startup()
1819
1820  Revision 573.41  2000/12/07 16:59:02  nbryant
1821  added --with-db and --with-gdbm options to configure
1822
1823  Revision 573.40  2000/12/07 04:50:33  ajc
1824  * Wrap housekeeper and timer events in transaction open/close functions
1825  * Checkpoint the DB as an EVT_TIMER event instead of after each session
1826    (runs each minute, but actually limited by the parameters of the function)
1827
1828  Revision 573.39  2000/12/06 04:44:36  ajc
1829  * Changed netproc to keep the use table in a flat file instead of a database
1830
1831  Revision 573.38  2000/12/05 05:32:58  ajc
1832  * Added support for non-USA country identities in vCard and registration
1833  * User edit now asks whether it should prompt to change the password
1834
1835  Revision 573.37  2000/12/03 04:12:21  ajc
1836  * Finished (mostly) the Sleepycat DB backend ... added transaction logging
1837
1838  Revision 573.36  2000/11/30 03:23:17  ajc
1839  * Got the Sleepycat DB back end working, by opening the databases in a non
1840    shared, non threaded mode, and using Citadel's locking to serialize access.
1841
1842  Revision 573.35  2000/11/29 05:00:02  ajc
1843  * I think the db stuff is ok, but my db library is fux0red...
1844
1845  Revision 573.34  2000/11/27 14:12:09  error
1846  * commands.c: fixups to print_express() to make external command not print
1847    extraneous stuff to the terminal and make the displayed message consistent
1848
1849  Revision 573.33  2000/11/27 10:41:14  error
1850  * print_express(): now uses GEXP instead of old PEXP; displays timestamps
1851
1852  Revision 573.32  2000/11/27 10:29:59  error
1853  * serv_chat.c: fix send_express_message() to include timestamps
1854
1855  Revision 573.31  2000/11/27 03:44:27  ajc
1856  * Initial checkin of database_sleepycat.c (doesn't work yet)
1857
1858  Revision 573.30  2000/11/26 05:24:22  ajc
1859  * msgbase.c: Added new API function CtdlOutputPreLoadedMsg(), and
1860    re-implemented the existing CtdlOutputMsg() as a wrapper around it.
1861  * imap_fetch.c: used the above function to do all output pre-loaded
1862
1863  Revision 573.29  2000/11/25 09:36:18  error
1864  * Added a bit of detail to syslog entries; now shows session id attached to
1865    client, hostname, and username, and time the session ended.
1866
1867  Revision 573.28  2000/11/25 06:17:06  ajc
1868  * Minor IMAP tweaks.  It still doesn't work.  :(
1869
1870  Revision 573.27  2000/11/23 07:22:21  error
1871  * citadel.spec: update version number
1872
1873  Revision 573.26  2000/11/21 11:12:56  error
1874   * domain.h: changed the HP/UX compatibility code to use defines from
1875     typesize.h for integers of specific bit widths (needed for Solaris, etc)
1876
1877  Revision 573.25  2000/11/12 04:20:49  ajc
1878  * Optimized server side input of message text
1879
1880  Revision 573.24  2000/11/10 03:55:06  ajc
1881  * Ford's Fix for Faster Functionality (save position during reply)
1882
1883  Revision 573.23  2000/11/09 04:48:50  ajc
1884  * tools.c: striplt() strips all whitespace, not just spaces
1885
1886  Revision 573.22  2000/11/07 20:47:21  ajc
1887  * imap_fetch.c: added a skeleton "ENVELOPE" fetch.  Currently sends NIL's.
1888
1889  Revision 573.21  2000/11/07 15:54:53  ajc
1890  * xx FETCH n:n BODY[pn.MIME] now works
1891
1892  Revision 573.20  2000/11/06 05:10:01  ajc
1893  * Changed the mime_parser() API (again) to allow "don't decode" mode
1894
1895  Revision 573.19  2000/10/29 18:11:07  ajc
1896  * Start numbering top-level MIME parts as 1, 2... not 1.1, 1.2...
1897
1898  Revision 573.18  2000/10/28 14:14:19  error
1899  * msgbase.c: eliminated most gotos; a single goto in alias() remains because
1900    it actually makes sense to do it that way...
1901
1902  Revision 573.17  2000/10/25 21:37:09  ajc
1903  * Implemented the AUTHENTICATE LOGIN command in IMAP
1904
1905  Revision 573.16  2000/10/25 19:20:37  ajc
1906  * FETCH now works for ranges *and* sets, and with sequence numbers *and* UID's
1907
1908  Revision 573.15  2000/10/24 20:39:59  ajc
1909  * Added RFC822, RFC822.HEADER, RFC822.SIZE, RFC822.TEXT fetch keys to IMAP
1910
1911  Revision 573.14  2000/10/23 20:26:51  error
1912  * War on goto:  rewrote a few easy functions to eliminate unnecessary gotos
1913
1914  Revision 573.13  2000/10/11 23:03:44  error
1915  * utilsmenu: obey $PAGER environment var, if any.  Default to more if neither
1916    $PAGER nor less is available.
1917
1918  Revision 573.12  2000/10/11 22:55:25  error
1919  * citadel.c: when ansi_color=user, enable color at login, so Lobby> posts
1920    displayed at login are in color
1921
1922  Revision 573.11  2000/10/11 22:47:51  error
1923  * domain.c: getmx() returns hostname as MX if no MX records found a la RFC 974
1924
1925  Revision 573.10  2000/10/10 19:18:12  ajc
1926  * Added support of macros ALL, BODY, FAST, and FULL to the IMAP FETCH command
1927
1928  Revision 573.9  2000/10/06 03:31:55  ajc
1929  * Mark Crispin is a fscking idiot.  IMAP is a convoluted mess.
1930
1931  Revision 573.8  2000/10/05 22:23:16  ajc
1932  * Slowly and painfully writing IMAP support
1933
1934  Revision 573.7  2000/10/04 22:39:06  ajc
1935  * Added skeleton versions of the LIST and LSUB commands to the imap server
1936
1937  Revision 573.6  2000/10/04 17:48:21  ajc
1938  * Allow Aides to zap rooms (site configurable setting)
1939
1940  Revision 573.5  2000/10/03 01:45:00  ajc
1941  * Changed the <.A>ide <S>ysconfig <G>eneral command to explicitly allow the
1942    global page log room to be disabled (answer "no" to set the log room to a
1943    null string)
1944
1945  Revision 573.4  2000/09/28 10:27:38  error
1946  * commands.c: changed sttybbs() to support HP/UX termios VMIN and VTIME
1947
1948  Revision 573.3  2000/09/24 22:01:45  ajc
1949  * ipc_c_tcp.c: don't hardcode BBSDIR path for unix domain sockets
1950
1951  Revision 573.2  2000/09/21 04:16:44  ajc
1952  * Fixed logged_in_response() so it only displays responses during Citadel
1953    protocol sessions.  (This was affecting POP etc.)
1954
1955  Revision 573.1  2000/09/11 22:05:04  ajc
1956  * citadel.c: accept -h <host> and -p arguments, so citadel can be called
1957    directly by telnetd, bypassing /bin/login.  It works, but not recommended at
1958    this time because it has to run as root.
1959
1960  Revision 573.0  2000/09/05 18:35:22  ajc
1961  * Tagged everything for version 5.73 release
1962
1963  Revision 572.39  2000/09/04 03:59:15  ajc
1964  IO's changes:
1965  ----------------------------
1966  revision 572.4
1967  date: 2000/09/03 06:36:01;  author: error;  state: Exp;  lines: +5 -1
1968  Added HP/UX linker flag for dynamic modules to work
1969  ----------------------------
1970  revision 572.3
1971  date: 2000/09/01 06:50:00;  author: error;  state: Exp;  lines: +8 -1
1972  Changed to use integer macros from typesize.h for specific bit widths
1973  ----------------------------
1974
1975  Revision 572.38  2000/09/01 20:17:08  ajc
1976  * msgbase.c: cmd_opna() - increase desired_section buffer from 64 to 256 bytes
1977
1978  Revision 572.37  2000/09/01 17:31:47  ajc
1979  * Fixed oopseth in control.c that might call fileno(NULL)
1980
1981  Revision 572.36  2000/09/01 13:37:16  ajc
1982  * control.c: chown citadel.control to bbsuid when opening/creating as root
1983
1984  Revision 572.35  2000/09/01 03:55:44  ajc
1985  * Fixed a few more references to the deprecated uncnsrd.mt-kisco.ny.us name
1986
1987  Revision 572.34  2000/09/01 03:43:09  ajc
1988  * Added 'author' command-line arg to aidepost.  Closes enhancement request
1989    #71 on bugzilla.
1990  * Put the default SMTP and POP3 ports back to 25 and 110.  Now that the
1991    unix domain socket bug is fixed, it's ok if these binds fail.
1992
1993  Revision 572.33  2000/08/31 23:02:15  ajc
1994  * ig_tcp_server() and ig_uds_server()  -  check to make sure queue length is
1995    always at least 5.  Zero-length queues can cause connection lockups.
1996
1997  Revision 572.32  2000/08/31 21:32:44  ajc
1998  * Still trying to fix a socket connect bug
1999
2000  Revision 572.31  2000/08/31 16:37:08  ajc
2001  * docs/import-export.txt: added.
2002
2003  Revision 572.30  2000/08/28 19:51:51  ajc
2004  * messages.c: cosmetic cleanup (coding convention and comments)
2005
2006  Revision 572.29  2000/08/26 20:23:18  ajc
2007  * Finished up the back end code for mailing list sends.  Sends now work!
2008
2009  Revision 572.28  2000/08/24 02:48:18  ajc
2010  * Merged in IO ERROR's diffs to make Citadel work with HP/UX
2011
2012  Revision 572.27  2000/08/22 02:31:47  ajc
2013  * nonce (for APOP-style auth) is now generated when a context is created
2014    instead of during protocol greeting functions.
2015  * Moved Citadel protocol nonce output from greeting to INFO
2016
2017  Revision 572.26  2000/08/18 21:09:36  ajc
2018  * Added a little more mailing list code to serv_network.c
2019
2020  Revision 572.25  2000/08/10 04:36:25  ajc
2021  * Fixed a bug in keyboard polling (in commands.c) which was causing the
2022    client protocol to get out of sync in certain conditions.
2023
2024  Revision 572.24  2000/08/10 02:42:13  ajc
2025  * Changed all the "200 ok" responses to more descriptive strings
2026  * Added a *temporary* protocol sync check.  Remove this!
2027
2028  Revision 572.23  2000/08/09 17:14:34  ajc
2029  msgbase.c: fixed a bug in
2030             remove_any_whitespace_to_the_left_or_right_of_at_symbol() that was
2031             causing the <R>eply function to fail on names with whitespace in
2032             certain parts of the string.  This closes Bug #56.
2033
2034  Revision 572.22  2000/08/05 04:24:00  ajc
2035  * Added [idle] to client wholist display for sessions idle >15 minutes
2036  * Added a generic "void *userdata" field to CtdlForEachMessage()
2037  * More prep for mailing list handling in the server
2038
2039  Revision 572.21  2000/07/30 04:36:12  ajc
2040  * Set up the SNET (Send NETwork config) and GNET (Get NETwork config) commands
2041    for the network overhaul.
2042
2043  Revision 572.20  2000/07/29 05:29:19  ajc
2044  * Changed the format of RWHO output to provide non-masqueraded user/room/host
2045    names (to Aides only) as additional fields rather than an extra line of
2046    output.
2047  * Changed the client to display new RWHO fields, in the "long" wholist only.
2048  * Default SMTP and POP ports are now -1, not 25/110.  These services must now
2049    be activated manually.
2050
2051  Revision 572.19  2000/07/24 00:39:13  ajc
2052  * Fixed a path problem when calling netmailer from mailinglist.c
2053
2054  Revision 572.18  2000/07/22 03:44:17  ajc
2055  * Prepared infrastructure for the networker rewrite
2056
2057  Revision 572.17  2000/07/17 02:38:08  ajc
2058  * Completed serv_vandelay.c (importer/exporter module)
2059  * sendcommand.c: fix behavior of SEND_LISTING mode
2060  * sysdep.c: client_gets() fill buffer with "000" terminator when returning -1
2061
2062  Revision 572.16  2000/07/14 03:06:55  ajc
2063  * Added .ATN (DOWN) and .ATS (SCDN 1) commands to the client
2064
2065  Revision 572.15  2000/07/10 23:36:08  ajc
2066  * Another attempt to fix the crashy crashy bug in serv_vcard
2067  * Did more work on the Art Vandelay module
2068  * Replaced all instances of sprintf(tempfile, tmpnam(NULL)) with strcpy()
2069
2070  Revision 572.14  2000/07/10 04:01:12  ajc
2071  * added an unfinished serv_vandelay.c (Art Vandelay module - importer/exporter)
2072
2073  Revision 572.13  2000/07/09 02:47:40  ajc
2074  * Overhauled the keepalive logic in the chat client.  Closes bug #20.
2075
2076  Revision 572.12  2000/07/09 02:27:02  ajc
2077  * Eliminated the whole SIGINT/SIGQUIT based handling of Ctrl-O and Ctrl-C
2078    keyboard interrupts.  Replaced with a non-blocking check for keyboard input
2079    which sets the global variable 'sigcaught' if either key was pressed.
2080    fmout() and pprintf() switch to 'drain mode' if sigcaught is set.
2081    This closes Bug #18.
2082
2083  Revision 572.11  2000/07/06 20:26:36  ajc
2084  * updated .Help SUMMARY
2085
2086  Revision 572.10  2000/07/04 20:02:46  ajc
2087  * Fixed potential crashy crashy bug in serv_vcard.c
2088
2089  Revision 572.9  2000/06/28 03:42:56  ajc
2090  * Changed the comments at the beginning of each file to a consistent format
2091  * Improved the parameterization of commands in the IMAP module
2092
2093  Revision 572.8  2000/06/27 01:27:13  ajc
2094  * Coupla very small changes to get on the road to IMAP support
2095
2096  Revision 572.7  2000/06/22 21:41:48  ajc
2097  * Made the ICQ stuff far more reliable ... by removing it!
2098
2099  Revision 572.6  2000/06/21 03:46:20  ajc
2100  * IMAP is now legal but useless, supporting NOOP, LOGIN, and LOGOUT.
2101
2102  Revision 572.5  2000/06/15 20:15:52  ajc
2103  * Inserted a skeleton IMAP module into the build.  IT DOES NOT WORK AT ALL.
2104
2105  Revision 572.4  2000/06/04 02:30:56  ajc
2106  * CtdlForEachMessage() now returns the number of messages processed.  It also
2107    accepts the MSGS_EQ mode, for targeting a specific message number (useful
2108    for determining whether the specified message actually exists in a room).
2109  * Completed the server side of the moderation system (serv_moderate.c module
2110    which implements the MMOD command)
2111
2112  Revision 572.3  2000/06/03 05:47:57  ajc
2113  * Replaced most of the very repetitive and very redundant access level checks
2114    in most commands with a single API call:  CtdlAccessCheck()
2115  * serv_moderate.c: added (not finished)
2116
2117  Revision 572.2  2000/06/02 03:38:50  ajc
2118  * Bind unix socket prior to TCP socket for citadel protocol
2119  * Fixed bug in sendcommand.c which was causing it to crash on attach
2120
2121  Revision 572.1  2000/05/26 19:27:51  ajc
2122  * Changed some of the rev-level sensitive stuff to look at the actual version
2123    of Citadel running, not the last version with which we ran setup
2124  * Added a moderation system.  Default filter level for new users is in the
2125    config file.  Per-user setting is in usersupp.  Moderation level of each
2126    message is in SuppMsgInfo.  Tweaked CONF, GETU, and SETU.  Read filter is
2127    working.  Moderate message up/down commands are not here yet.  See
2128    techdoc/moderation.txt for more info.
2129
2130  Revision 572.0  2000/05/23 02:09:30  ajc
2131  * Updated docs and tagged everything for the 5.72 release
2132
2133  Revision 571.7  2000/05/20 23:28:20  ajc
2134  * Fixed bug in client API that was causing netproc to crash
2135
2136  Revision 571.6  2000/05/15 00:05:19  ajc
2137  * Double the retry interval for SMTP deliveries after each failed attempt.
2138
2139  Revision 571.5  2000/05/11 03:08:47  ajc
2140  * serv_smtp.c: clear the relevant state buffers after an SMTP DATA command
2141    completes, allowing multiple messages in one session.  Closes bug #58.
2142
2143  Revision 571.4  2000/04/24 03:36:43  ajc
2144  * Removed references to strucmp() and struncmp(), replaced them with
2145    strcasecmp() and strncasecmp() as we did in the server a while ago, and
2146    set up the config script to figure out whether they need to be compiled
2147    in.  Also moved them to tools.h
2148  * Wrote a password manager for the client
2149
2150  Revision 571.3  2000/04/19 03:17:10  ajc
2151  * Don't ever expire the Local System Configuration> room
2152
2153  Revision 571.2  2000/04/16 19:03:47  ajc
2154  * Minor changes to avoid host lookup for local clients
2155
2156  Revision 571.1  2000/04/15 19:55:52  ajc
2157  * Fixed "Unvalidated users appear even with registration disabled" bug #36
2158
2159  Revision 571.0  2000/04/13 02:43:24  ajc
2160  * Fixed a problem that crashed the client during <G>oto commands if a room
2161    existed with a name more than 32 characters (thanks to Magus for reporting
2162    this one).
2163  * Tagged everything and updated docs for the 5.71 release
2164
2165  Revision 570.18  2000/04/10 01:47:22  ajc
2166  * More paginator changes.  Shuffled code around, added pagination to a bunch
2167    of other functions, and replaced the old, cumbersome pagination with the
2168    new, easy, API-based one in everything except message output.
2169
2170  Revision 570.17  2000/04/09 17:51:18  ajc
2171  * Added pprintf() (paginated version of printf) to the client-side API.  Now
2172    any client side function can be paginated simply by changing all of the
2173    printf's to pprintf's.  I've already done this for the user list and wholist
2174    (removing the old style pagination) and for "read directory."
2175
2176  Revision 570.16  2000/04/08 04:52:48  ajc
2177  * Another minor stoopid little time display fix
2178
2179  Revision 570.15  2000/04/08 03:58:12  nbryant
2180   * backed out the previous changes since they didn't look good on some
2181     xterms with a blue bold mode. just set the background color to black
2182     instead. this makes black-on-white terminals actually readable, if not
2183     particularly good looking.
2184
2185  Revision 570.14  2000/04/08 01:36:30  nbryant
2186   * citadel.c, commands.c: comment out cls() as this wasn't called if
2187     ansi_color=user anyway, and we have no way of knowing whether the user's
2188     terminal does background color erase, which was the reason for adding this
2189     in the first place. with the recent changes to color(), the display will get
2190     screwed up if they *do* have background color erase. perhaps this is a job
2191     for terminfo.
2192
2193  Revision 570.13  2000/04/08 00:37:42  nbryant
2194   * commands.c: fix color support for black-on-white color terminals such as
2195     CDE's dtterm. this just avoids white-on-white text; some color combinations
2196     such as yellow-on-white still aren't very legible due to contrast. There's
2197     not much I can think to do about that without affecting the look on the
2198     white-on-black terminals which probably account for most users.
2199
2200  Revision 570.12  2000/04/07 20:22:34  ajc
2201  * Fixed am/pm bug in time display
2202
2203  Revision 570.11  2000/04/07 19:22:45  ajc
2204  * For services disabled by setting port number to -1, administratively skip
2205    the bind instead of just allowing it to fail.
2206
2207  Revision 570.10  2000/03/31 04:31:02  ajc
2208  * Quick fix to 'stats' utility to purge records with bogus timestamps
2209
2210  Revision 570.9  2000/03/31 02:10:52  ajc
2211  * Caved in to pressure and enabled <R>eply in public rooms.
2212
2213  Revision 570.8  2000/03/28 03:55:53  ajc
2214  * Modified <.RU> to allow search for partial match
2215
2216  Revision 570.7  2000/03/27 03:08:19  ajc
2217  * Third parameter of CtdlDeleteMessages() now takes "" instead of NULL to
2218    specify 'any MIME type'.
2219
2220  Revision 570.6  2000/03/27 01:14:08  nbryant
2221   * Makefile.in: generate parsedate.c automatically
2222   * configure.in: check for bison/byacc/yacc. bison seems to build cleaner
2223     code.
2224   * parsedate.c: removed from CVS
2225   * parsedate.y: added #include <stdlib.h> so it builds with bison
2226
2227  Revision 570.5  2000/03/27 00:46:10  nbryant
2228   * First cut at Solaris fixes. There may still be some *printf("%s", NULL)
2229     type of issues lurking in the shadows.
2230
2231  Revision 570.4  2000/03/25 18:29:58  nbryant
2232  changed my email address
2233
2234  Revision 570.3  2000/03/23 02:41:50  ajc
2235  *** empty log message ***
2236
2237  Revision 570.2  2000/03/21 03:23:24  ajc
2238  * Experimental new linebreak mode
2239
2240  Revision 570.1  2000/03/20 14:43:19  ajc
2241  * "Brown paper bag" fix for SMTP bug (incoming long fields crash logger)
2242
2243  Revision 570.0  2000/03/19 23:42:34  ajc
2244  * This is the official 5.70 release.
2245
2246  Revision 1.494  2000/03/19 23:04:08  ajc
2247  * Small cosmetic change to date/time output
2248
2249  Revision 1.493  2000/03/19 05:02:39  ajc
2250  * SMTP hacks to deal with AOL braindamage
2251
2252  Revision 1.492  2000/03/18 18:18:04  ajc
2253  * Support multiline responses from SMTP servers when sending mail
2254
2255  Revision 1.491  2000/03/17 16:26:57  ajc
2256  * Set up a private "Sent/Received Pages" room for each user
2257
2258  Revision 1.490  2000/03/17 04:11:24  ajc
2259  * Moved bio-related commands out to a loadable module
2260
2261  Revision 1.489  2000/03/16 17:58:54  smw
2262  Created a docs directory.
2263  Moved install.txt to docs.
2264  Added inetmailsetup.txt (BBS server side e-mail)
2265  Added inetmailsetupmx.txt (local mail AND bbs e-mail
2266  Added inetsiteconfig.txt (describes the .asi command)
2267  Added siteconfig.txt (describes .asg)
2268  Added chat.txt (describes changes and new chat functionality)
2269  Made a couple of changes to install.txt (references to new documentation)
2270  Added Steve Williams to copyright.txt as the document writer.
2271
2272 Revision 1.488  2000/03/15 03:04:51  ajc
2273 * Added DEXP server command to disable incoming express messages.
2274 * <Q>uiet mode client side command to set/clear DEXP mode.
2275 * <K>nown rooms list displays through the paginator.
2276
2277 Revision 1.487  2000/03/12 00:21:35  ajc
2278 * Removed the semi-broken "chat room" functionality in the chat system, and
2279   replaced it with direct mapping to the actual Citadel room the user is in.
2280 * Display masqueraded roomname in chat, if applicable.  Fixes bug #19.
2281
2282 Revision 1.486  2000/03/11 21:29:37  ajc
2283 * SM_ flags for CtdlSaveMsgPointerInRoom() need to be a bit bucket, not an
2284   enum, since more than one can be passed.  Changed SM_DONT_BUMP_REF_COUNT
2285   from 3 to 4.  This also fixes bug #33.
2286
2287 Revision 1.485  2000/03/11 20:26:03  ajc
2288 * Reworked the <R>eply logic in messages.c - fixes bug #34
2289
2290 Revision 1.484  2000/03/11 19:22:19  nbryant
2291  * commands.c: improved timing of background keepalives if connection is
2292                lagged
2293
2294 Revision 1.483  2000/03/11 05:08:48  nbryant
2295  * commands.c: oops, that mutex stuff wasn't necessary
2296
2297 Revision 1.482  2000/03/11 04:09:03  nbryant
2298  * new threaded client code for background keepalives
2299
2300 Revision 1.481  2000/03/10 21:40:04  ajc
2301 * Changes to message base and networker to support Internet-style message
2302   ID's instead of the conventional Citadel style.
2303
2304 Revision 1.480  2000/03/08 03:36:37  ajc
2305 * Shut off hostname resolution when dealing with Unix domain sockets
2306 * Cleaned up the 'citmail' MDA tool
2307 * Added POP3 and SMTP port numbers to global system configuration
2308
2309 Revision 1.479  2000/03/07 21:54:58  ajc
2310 * Fixed the naming conventions and permissions for unix domain sockets.
2311
2312 Revision 1.478  2000/03/05 07:33:23  ajc
2313 * Added support for protocols over Unix domain sockets.
2314
2315 Revision 1.477  2000/03/04 22:36:23  ajc
2316 * Remove nulls appended to editor files during replace, edit, and print
2317   operations.  Truncate temp files during same operations.
2318   Closes bugs #6 and #7.
2319
2320 Revision 1.476  2000/03/04 05:29:18  ajc
2321 * Relax restrictions on editing of base rooms.  Renaming is not allowed but
2322   all other attributes can be edited.  Closes feature request #21.
2323 * Sending pages from the client now uses the same message editing functions
2324   as entering messages, allowing edit/abort.  Closes feature request #25.
2325
2326 Revision 1.475  2000/03/03 04:50:14  ajc
2327 * Moved all of the wholist masquerading commands into the serv_rwho module
2328
2329 Revision 1.474  2000/03/03 04:12:37  ajc
2330 * Finished the inbound side of gateway domain service
2331
2332 Revision 1.473  2000/02/27 04:55:51  ajc
2333 * Added "keymenu()" generic menu-maker to commands.c
2334 * Blocked non-numeric input to intprompt()  (fixes bug #16)
2335
2336 Revision 1.472  2000/02/27 03:57:35  ajc
2337 * Completed 'fsck'-like reference count verifier (server and client)
2338
2339 Revision 1.471  2000/02/26 18:30:40  ajc
2340 * Properly handle all aliases specified in network/mail.aliases for incoming
2341   SMTP mail (uses the alias() function, so if we replace that function with
2342   something that uses the same calling convention, it'll still work)
2343
2344 Revision 1.470  2000/02/26 05:15:38  ajc
2345 * Fortified the message base and SMTP code so that misdirected bounce messages
2346   end up in the Aide> room instead of getting dereferenced
2347 * Started writing a message reference count verifier ('fsck' for message base)
2348
2349 Revision 1.469  2000/02/25 06:14:05  ajc
2350 * Modularized the RWHO (Read WHO is online) command, basically as a pilot
2351   for modularizing all "non-API" functionality.
2352
2353 Revision 1.468  2000/02/24 03:44:00  ajc
2354 * Implemented holdoff time (15 minutes) for SMTP send retry.
2355 * Implemented "try for 3 days and then give up" on SMTP send.
2356
2357 Revision 1.467  2000/02/24 00:51:48  ajc
2358 * Client protocol synchronization check during exit from chat.
2359   This closes Bug #15.
2360
2361 Revision 1.466  2000/02/22 16:37:28  ajc
2362 * Minor tweaks to RFC822 output to keep brain-damanged MS Outlook from dying
2363
2364 Revision 1.465  2000/02/22 04:17:56  ajc
2365 * Got bounce messages working (mostly ... testers, please beat this up!)
2366 * Changed 'FIX' comments to 'FIXME' (less conflict, plus vim highlights it!)
2367
2368 Revision 1.464  2000/02/18 22:29:18  ajc
2369 * Coded up the "bounce" functions.  Still a coupla bugs.
2370
2371 Revision 1.463  2000/02/18 05:10:50  ajc
2372 * Made the <.ASI> command a bit friendlier.
2373 * SMTP sender now pays attention to "smarthost" entries in the system's
2374   Internet configuration, using them if one or more is present.
2375
2376 Revision 1.462  2000/02/17 05:27:39  ajc
2377 * Got the "MAIL From:" command sending the correct data.  (unnnhhhhnnhhhh...)
2378
2379 Revision 1.461  2000/02/16 22:06:26  ajc
2380 * Altered the display and conversion of RFC822 messages
2381
2382 Revision 1.460  2000/02/16 03:43:28  ajc
2383 * Added the resolver library to the configure script
2384
2385 Revision 1.459  2000/02/16 01:19:39  ajc
2386 * Vanquished the evil dn_expand() beast.  getmx() now seems to be working.
2387
2388 Revision 1.458  2000/02/14 04:36:14  ajc
2389 * sysdep.c: added new event hook type EVT_TIMER.  Timer event hooks are called
2390   once per minute by any worker thread.
2391 * msgbase.c: removed dependence on nested functions in CtdlOutputMsg() by
2392   replacing them with an API call CtdlRedirectOutput() in sysdep.c, which
2393   can temporarily redirect a session's output to an arbitrary file or socket.
2394 * serv_smtp.c: implemented the purging of messages in the queue for which all
2395   deliveries have been completed.
2396 * serv_smtp.c: removed temporary 'QQQQ' server command and replaced it with
2397   a timer event hook that runs the queue once per minute (this needs to be
2398   made more robust)
2399
2400 Revision 1.457  2000/02/08 21:00:47  ajc
2401 * Implemented the deprecated "LAST" command in POP3.  Some clients need it.
2402 * POP3 sessions now set the last-read pointer in Mail>.
2403
2404 Revision 1.456  2000/02/07 05:15:00  ajc
2405 * Renamed CtdlLocalHost() to CtdlHostAlias() and worked it a little deeper into
2406   the message routing logic.  Still needs some work on the gateway-domain
2407   stuff.
2408 * Twiddled CtdlOutputMsg() a bit for 'all Internet' situations.  Still needs
2409   some work to avoid printing dual headers when both Cit and RFC822 exist.
2410
2411 Revision 1.455  2000/02/03 03:57:35  ajc
2412 * Formalized the 'Internet Configuration' logistics.  Added new API call
2413   CtdlLocalHost() to detect aliases for the local host.  Used in SMTP listener.
2414
2415 Revision 1.454  2000/01/31 02:13:05  ajc
2416 * <.A>ide <S>ystem configuration <I>nternet  in the client (unfinished)
2417
2418 Revision 1.453  2000/01/26 02:41:27  ajc
2419 * SMTP delivery is working but still *very* rough.
2420
2421 Revision 1.452  2000/01/25 04:45:50  ajc
2422 * Wrote enough of the SMTP sender to get Patriot drooling over it, but not
2423   enough to complete the transmission of mail.
2424
2425 Revision 1.451  2000/01/23 21:25:45  ajc
2426 * Temporary hack to ig_tcp_server() to listen on an arbitrary port if the
2427   one specified is not bindable (for development only)
2428 * Added SM_DONT_BUMP_REF flag to CtdlSaveMsgPointerInRoom() to be used only
2429   in very specific and special situations
2430 * Generate delivery instructions when outbound SMTP mail is created from
2431   within Citadel (as opposed to being from the SMTP module)
2432
2433 Revision 1.450  2000/01/23 05:22:41  ajc
2434 * Coded up some more of the SMTP-sender (still not done)
2435
2436 Revision 1.449  2000/01/22 05:13:56  ajc
2437 * Added some more functionality to the string tokenizer
2438
2439 Revision 1.448  2000/01/17 20:57:43  ajc
2440 * CR to CRLF hacks (lose, lose, lose)
2441
2442 Revision 1.447  2000/01/17 18:30:27  ajc
2443 * Completed POP3 server.  All RFC1939 commands except APOP are implemented.
2444
2445 Revision 1.446  2000/01/17 17:09:23  ajc
2446 * Implemented LIST and STAT commands in the pop3 server
2447
2448 Revision 1.445  2000/01/17 05:38:14  ajc
2449 * citserver.c: cleanup hook functions are now run under the proper context,
2450                even when initiated by the housekeeper thread
2451 * serv_pop3.c: establish a place to hold the message list
2452
2453 Revision 1.444  2000/01/17 04:26:39  ajc
2454 * Modified CtdlOutputMsg() to handle output to arbitrary sockets or files.
2455   This uses nested functions and may not be portable beyond GCC...
2456
2457 Revision 1.443  2000/01/15 18:29:15  ajc
2458 * Added a generic (void *) parameter to the ForEachUser() and ForEachRoom()
2459   callback mechanisms, to allow callers and callbacks to pass arbitrary data
2460   between each other without requiring TSD variables.
2461 * room_ops.c: eliminated the need for 'FloorBeingSearched' TSD variable
2462 * internet_addressing.c: eliminated 'buffer1' and 'buffer2' TSD variables
2463
2464 Revision 1.442  2000/01/15 04:31:44  ajc
2465 * Removed UI_DIALOG mode in setup.  Can't count on 'dialog' to be consistent.
2466
2467 Revision 1.441  2000/01/15 04:07:17  ajc
2468 * Fixed the access rights on auto-created rooms (the same changes that were
2469   made to version 5.62 in the stable tree)
2470
2471 Revision 1.440  2000/01/13 03:32:36  ajc
2472 * techdoc/delivery-list.txt: added (syntax for delivery lists)
2473 * domain.*: added (will contain MX lookup code)
2474 * internet_addressing.c, logging.c: fixed some buffer overflow bugs
2475
2476 Revision 1.439  2000/01/12 03:56:27  ajc
2477 * sysdep.c: start the housekeeping thread *after* dropping root perms.
2478
2479 Revision 1.438  2000/01/09 19:03:16  ajc
2480 * Removed the fifo-based protocol downloads and replaced it with a less
2481   elegant "download temporary file to client, then sx/sb/sz" because
2482   downloading through a fifo was confusing some software.
2483
2484 Revision 1.437  2000/01/08 22:19:44  ajc
2485 * Completed spool to outbound delivery queue (still no queue sender implemented)
2486
2487 Revision 1.436  2000/01/08 05:00:09  ajc
2488 * Reworked some of the data structures to handle multiple recipients
2489 * Began implementation of the delivery queue
2490 * Added CtdlReallocUserData()
2491 * CtdlSaveMsg() now returns the local message ID in the database
2492
2493 Revision 1.435  2000/01/06 03:50:34  ajc
2494 * Replaced citmail.c with a new one that simply SMTP-forwards to Citadel
2495 * Started outbound SMTP queue work
2496
2497 Revision 1.434  1999/12/30 04:56:29  ajc
2498 * Got initial SMTP delivery working in a very specific situation (delivery
2499   to a single, local user)
2500
2501 Revision 1.433  1999/12/29 04:44:00  ajc
2502 * client_chat.c: display "No message sent" if a send page is aborted.
2503   Closes bug #2 in bugzilla.
2504
2505 Revision 1.432  1999/12/26 21:50:07  ajc
2506 * serv_vcard: don't run hooks when not logged in (such as in SMTP sessions)
2507 * serv_pop3: added.  This is the skeleton for a module implementing POP3.
2508
2509 Revision 1.431  1999/12/23 04:46:23  ajc
2510 * "Finished" initial hack of RFC822 import
2511
2512 Revision 1.430  1999/12/22 04:46:34  ajc
2513 * Fixed up the "Date:" headers to be RFC822-compliant
2514
2515 Revision 1.429  1999/12/13 05:30:57  ajc
2516 * Removed our naive 'conv_date()' RFC822-to-unixtime conversion function
2517   and replaced it with the public domain 'parsedate()' function from UseNet
2518
2519 Revision 1.428  1999/12/10 23:58:25  ajc
2520 * internet_addressing.c: added.  (Internet address to Citadel mapping)
2521
2522 Revision 1.427  1999/12/10 21:34:19  ajc
2523 * serv_smtp: implemented RFC821 "VRFY" and "EXPN" commands
2524
2525 Revision 1.426  1999/12/09 05:01:14  ajc
2526 * Split cmd_user() and cmd_pass() into frontend/backend functions
2527 * serv_smtp: implemented AUTH LOGIN for client authentication
2528
2529 Revision 1.425  1999/12/09 00:22:58  ajc
2530 * Finished the "arbitrary service" registration.
2531 * Eliminated "special" master socket for Citadel protocol - just register it
2532   like any other protocol.
2533 * Began initial implementation of native SMTP service.
2534
2535 Revision 1.424  1999/12/08 18:09:10  ajc
2536 * Added CtdlRegisterServiceHook() and its data type, for implementing arbitrary
2537   TCP-based services directly in the Citadel server.  Not finished yet.
2538
2539 Revision 1.423  1999/11/29 17:39:07  nbryant
2540 * citserver.c: Solaris lacks inet_aton; use inet_addr instead
2541
2542 Revision 1.422  1999/11/29 17:26:15  nbryant
2543 * citserver.c: include <sys/types.h>; may help portability to Solaris
2544
2545 Revision 1.421  1999/11/22 00:27:42  ajc
2546 * Added some temporary variables to OpenCmdResult().  Hopefully fixes
2547   bug #14 when running on FreeBSD.
2548
2549 Revision 1.420  1999/11/21 18:30:16  ajc
2550 * Protected cmd_move() from buffer overrun (no longer crashes the server)
2551 * cmd_chat() -- truncate input at 100 characters to prevent buffer overruns.
2552   Also handle broken client sockets properly.  (Thanks to DME for bug report)
2553
2554 Revision 1.419  1999/11/19 01:57:40  ajc
2555 * Fixed a *serious* memory leak in the database function wrappers.
2556 * Updated version number to 5.60 -- run setup when installing this version.
2557
2558 Revision 1.418  1999/11/18 03:29:20  ajc
2559 * Changed the order of parameters in <.A>ide <S>ystem config into a more
2560   logical grouping.
2561
2562 Revision 1.417  1999/11/18 02:31:50  ajc
2563 * Updated some of the documentation
2564 * Brought the internal version number up to 5.60
2565
2566 Revision 1.416  1999/11/17 04:15:05  ajc
2567 * Removed the session_count() function.  Instead, keep a reference count
2568   updated when sessions begin and end.
2569 * Replaced fixed number of worker threads with lower and upper limits; current
2570   code now tries to make thread count == session count, within these limits
2571
2572 Revision 1.415  1999/11/15 03:17:39  ajc
2573 * Put lockfile in /tmp instead of in /var/lock.   The latter is not guaranteed
2574   to exist, nor is it guaranteed to be writable by BBSUID
2575   (Resolves bug #11 from the Bugzilla repository)
2576
2577 Revision 1.414  1999/11/15 03:07:24  ajc
2578 * Fixed the network-wide vCard purge logic so that it (1) actually works,
2579   and (2) forces a netproc run immediately when a purge is entered
2580
2581 Revision 1.413  1999/11/09 21:20:44  nbryant
2582 * configure.in: include <sys/types.h> when doing checks which require <utmp.h>
2583   (should fix Bug #10 on FreeBSD)
2584
2585 Revision 1.412  1999/11/05 03:53:47  ajc
2586 * Issue 'cancel' messages for vCard when a user is deleted.
2587 * Try to delete 'cancel' messages locally after they've been distributed.
2588
2589 Revision 1.411  1999/11/03 04:01:20  ajc
2590 * Fixed buffer overrun problems in cmd_rchg(), cmd_hchg(), and cmd_uchg()
2591 * Removed my email address as the feedback content from the docs; replaced
2592   it with a reference to the Citadel/UX web site.
2593
2594 Revision 1.410  1999/11/02 19:51:23  ajc
2595 * Fixed timeout problem for remote client sessions (all timeouts were set to
2596   1 second ... probably a temporary hack that was missed in the cleanup)
2597
2598 Revision 1.409  1999/11/02 03:03:27  ajc
2599 * Several fixes to msgbase.c and netproc.c to prevent corrupted incoming
2600   network traffic from crashing the server.  Reject bad messages.
2601
2602 Revision 1.408  1999/11/01 04:21:34  ajc
2603 * Fixed a concurrency bug which crashed the server when multiple sessions
2604   terminated simultaneously.
2605
2606 Revision 1.407  1999/11/01 00:54:02  ajc
2607 * CtdlFetchMessage() - generate a "<no text>" message body if there's none
2608   on disk.  Too much stuff goes haywire if there's no M field.
2609
2610 Revision 1.406  1999/10/31 18:17:17  ajc
2611 * Fixed buffer overrun in cmd_rchg()
2612 * Call master_cleanup() when time_to_die==1 for proper shutdown
2613
2614 Revision 1.405  1999/10/31 16:26:55  ajc
2615 * Fixed incorrect assignment of new session ID's
2616
2617 Revision 1.404  1999/10/31 04:17:17  ajc
2618 * Fixed a bug which was crashing the server during very long message entry.
2619
2620 Revision 1.403  1999/10/29 01:48:45  ajc
2621 * database.c: Removed arbitrary limit on maximum number of sessions
2622
2623 Revision 1.402  1999/10/29 01:03:03  ajc
2624 * Debugged all possible ways for a session to terminate; do them cleanly.
2625 * Assign session numbers in a more portable and less arbitrary way.
2626
2627 Revision 1.401  1999/10/28 19:50:55  ajc
2628 * Fixed a problem where the client protocol would spit out two responses
2629   and therefore get out of sync if ASUP command set the access level to
2630   0 and therefore deleted the user (thanks to Eric McDonald)
2631
2632 Revision 1.400  1999/10/28 05:08:49  ajc
2633 * Removed all of the thread cancellation cruft that is no longer necessary
2634 * Moved the now non-system-dependent RemoveContext() out of sysdep.c (now
2635   it's part of cleanup() in citserver.c)
2636 * Removed all references to pthread_* from all modules except sysdep.c
2637
2638 Revision 1.399  1999/10/28 03:20:17  ajc
2639 * Fixed the problem of worker threads waking up prematurely.
2640 * 'QUIT'-terminated sessions now exit properly.
2641
2642 Revision 1.398  1999/10/27 04:26:58  ajc
2643 * Initial hack of worker-thread rearchitecture.  Right now it is successfully
2644   dispatching worker threads to active client sockets (and to the master
2645   socket too, of course).  Removing sessions is currently broken.
2646
2647 Revision 1.397  1999/10/26 20:20:29  ajc
2648 * Removed the auto-reconnect stuff... it was locking the client in an active
2649   loop more often than it was reconnecting.
2650
2651 Revision 1.396  1999/10/26 13:59:11  ajc
2652 damn bugs
2653
2654 Revision 1.395  1999/10/26 03:48:39  ajc
2655 * Shuffled around the order of events when a thread is terminating.  All
2656   mutex operations now happen prior to the freeing of the CitContext structure,
2657   otherwise begin_critical_section() and end_critical_section() try to
2658   manipulate the context's mutex count when there isn't any context.
2659
2660 Revision 1.394  1999/10/26 03:21:16  ajc
2661 * Changed a lot of strncpy() calls to safestrncpy() and replaced most of their
2662   hardcoded size arguments with 'sizeof' based arguments.
2663
2664 Revision 1.393  1999/10/24 19:22:51  nbryant
2665         * Makefile.in, configure.in: added --enable-icq flag; made checks for
2666           authentication libraries more intelligent.
2667
2668 Revision 1.392  1999/10/23 03:39:12  ajc
2669 * Finished moving vCard functionality to the new message base functions.
2670
2671 Revision 1.391  1999/10/21 00:50:14  ajc
2672 * Finished up the flags and replication checks in CtdlSaveMsgPointerInRoom().
2673
2674 Revision 1.390  1999/10/20 16:46:27  ajc
2675 * More code shuffle.  Added some flags to CtdlSaveMessagePointerInRoom() and
2676   enabled the MOVE command to also do a "copy" operation (actually just
2677   creates a second link and bumps the ref count).  Implemented "<C>opy" in
2678   the client.
2679
2680 Revision 1.389  1999/10/20 16:07:48  ajc
2681 * Wholist fixes for users who are in chat mode
2682
2683 Revision 1.388  1999/10/20 03:42:29  ajc
2684 * In the wholist, only show <private room> if the user viewing the list
2685   doesn't know that room.  Otherwise show the name.
2686
2687 Revision 1.387  1999/10/20 02:59:22  ajc
2688 * Code reorganization.  Making it easier to move/copy messages without
2689   duplicating existing code.
2690
2691 Revision 1.386  1999/10/17 02:25:18  ajc
2692 * Discovered a huge design flaw in the replication algorithm.  Ripped it
2693   out and replaced it with something a bit more robust.
2694
2695 Revision 1.385  1999/10/16 05:30:17  ajc
2696 * Changes to message replication code.  Don't do server-side hooks during
2697   an ENT3 command.  Also fixed a bug in cmd_whok() that caused crashes
2698   after a file format change.
2699
2700 Revision 1.384  1999/10/14 03:04:16  ajc
2701 * Finished the netproc side of Z (zap/supersede) processing for replication
2702
2703 Revision 1.383  1999/10/13 04:24:18  ajc
2704 * Added search-by-header-fields to CtdlForEachMessage(), and then to the
2705   server MSGS command.  This will have lots of uses.
2706
2707 Revision 1.382  1999/10/13 01:36:39  ajc
2708 * Starting some work on network zap (supersede) mode for replication
2709
2710 Revision 1.381  1999/10/08 02:55:57  ajc
2711 * More vCard-related debugging
2712
2713 Revision 1.380  1999/10/07 02:58:46  ajc
2714 * Semi-broken vCard replacement implementation in place.
2715 * Added "Z" (Zap, supersede) field to message format
2716
2717 Revision 1.377  1999/10/04 03:19:52  ajc
2718 * We now have a housekeeping thread and a housekeeping queue.
2719
2720 Revision 1.376  1999/10/03 21:48:21  ajc
2721 * Added serv_upgrade.h to automagically convert pre-5.55 format user records
2722   to 5.55 format user records and generate vCards.
2723
2724 Revision 1.375  1999/09/29 21:13:17  ajc
2725 * CtdlWriteObject() can now store objects in personal rooms for any specified
2726   user -- rather than only the current user or non-personal rooms.
2727
2728 Revision 1.374  1999/09/29 17:26:56  ajc
2729 * serv_vcard.c: fixed crashola bug in cmd_greg()
2730 * tools.c: simplified and improved the string tokenizer.  Now it runs in a
2731            single pass with no intermediate buffer.
2732
2733 Revision 1.373  1999/09/28 03:27:37  ajc
2734 * Fully migrated cmd_greg() and cmd_regi() into serv_vcard (still has bugs)
2735
2736 Revision 1.372  1999/09/27 03:33:40  ajc
2737 * cmd_regi() is now in serv_vcard and writes to the vcard instead of to the
2738   usersupp file.  Still needs tweaking.
2739
2740 Revision 1.371  1999/09/24 03:32:19  ajc
2741 * "read my vCard" and "write my vCard" are written and tested.
2742
2743 Revision 1.370  1999/09/24 02:54:17  ajc
2744 * Worked a little more on the vCard stuff.  The serv_vcard module is now in
2745   place, and a "read my vcard" function is there; "write my" is next...
2746
2747 Revision 1.369  1999/09/23 03:07:56  ajc
2748 * The vCard 'class' is now linked into the server, though it's not really
2749   functional yet.  Its constructors/destructors are debugged, though.
2750
2751 Revision 1.368  1999/09/19 21:28:33  ajc
2752 * Finished off the message architecture stuff with a new class of hooks to
2753   enable future server-side handlers.
2754
2755 Revision 1.367  1999/09/19 15:57:06  ajc
2756 * migrated cmd_ent3() to CtdlSaveMessage()
2757
2758 Revision 1.366  1999/09/19 05:13:57  ajc
2759 * Debugged the new version of CtdlWriteObject()
2760
2761 Revision 1.365  1999/09/16 03:23:23  ajc
2762 * Did most of the migration from save_message() to CtdlSaveMsg().  The
2763   latter builds a "struct CtdlMessage" (so we can run server-side handlers
2764   against it later on), then serializes it and stores to disk.
2765 * BROKEN BUILD ALERT!!  cmd_ent3() and CtdlWriteObject() are still not
2766   migrated.  They are stubbed out and will MALFUNCTION if used right now!!
2767
2768 Revision 1.364  1999/09/07 01:42:42  ajc
2769 * cmd_msg3() now uses serialize_message() for its output.  All message
2770   commands will eventually exist as a "struct CtdlMessage" at some point
2771   so that we can install server-side handler hooks.
2772
2773 Revision 1.363  1999/09/07 00:04:13  ajc
2774 * netproc.c: put outgoing messages into the use table, too -- this prevents
2775   locally originated messages from showing up again if a remote system is
2776   misconfigured and spools them back to us.
2777
2778 Revision 1.362  1999/09/06 03:39:15  ajc
2779 * citadel.c: run strproc() on new passwords
2780
2781 Revision 1.361  1999/09/03 17:50:26  playcow
2782 For URL view, don't prompt user to select url if there is only one.  Display
2783 <U>RL View prompt if message contains url(s). -Ben
2784
2785 Revision 1.360  1999/09/02 02:09:59  ajc
2786 * msgbase.c: new function serialize_message() for future use
2787
2788 Revision 1.359  1999/09/01 21:09:25  ajc
2789 * database.c: display the GDBM version string on startup
2790
2791 Revision 1.358  1999/09/01 02:36:34  ajc
2792 * Actually _enforce_ the max msg len limit
2793
2794 Revision 1.357  1999/09/01 01:51:48  ajc
2795 * Added the ability to handle embedded URL's from the text client
2796
2797 Revision 1.356  1999/09/01 01:02:47  ajc
2798 * Implemented "maximum message length" in global system config
2799
2800 Revision 1.355  1999/08/31 00:57:17  ajc
2801 * Handle multipart/alternative properly during legacy message outputs.
2802   Basically it just prints the first alternative and skips the rest.
2803
2804 Revision 1.354  1999/08/29 21:12:24  ajc
2805 * Made some changes to the output of MIME (especially multipart) messages.
2806
2807 Revision 1.353  1999/08/29 19:56:43  ajc
2808 * HTML updates
2809
2810 Revision 1.352  1999/08/24 02:01:03  ajc
2811 * html.c: added.  This is an overly simplistic HTML-to-text converter.
2812
2813 Revision 1.351  1999/08/21 18:37:29  ajc
2814 * Minor cosmetic cleanup.  No code changes.
2815
2816 Revision 1.350  1999/08/21 05:15:34  ajc
2817 * mailinglist.c, netmailer.c: fixed to allow list submissions from all posters
2818   on a Citadel network rather than only on the local system.
2819
2820 Revision 1.349  1999/08/08 00:25:45  ajc
2821 * Made one more byte available in locate_host() and in all the structs which
2822   its output gets written to (client can display 24 positions but we were only
2823   saving 23).
2824
2825 Revision 1.348  1999/08/07 16:34:38  nbryant
2826 * serv_icq.c: warning fixes
2827
2828 Revision 1.347  1999/08/06 02:57:26  ajc
2829 * locate_host.c: use strdoop() and phree() instead of strdup() and free()
2830 * serv_icq.c: run learned IP's through Citadel's locate_host() & put in Wholist
2831
2832 Revision 1.346  1999/08/05 17:58:59  ajc
2833 * RWHO command now returns express message code in postion 3
2834
2835 Revision 1.345  1999/08/04 02:21:45  ajc
2836 * Fixed some bugs in the ICQ metaclient, and documented the new protocol cmds
2837
2838 Revision 1.344  1999/08/03 11:34:35  ajc
2839 * Added client_icq.c and client_icq.h
2840
2841 Revision 1.343  1999/08/03 03:14:51  ajc
2842 * Wrote the client side of the ICQ gateway.  Now on to other projects.  :)
2843
2844 Revision 1.342  1999/08/03 01:52:06  ajc
2845 * Redesigned the client protocol commands for dealing with ICQ
2846 * Implemented page function priority ordering to prevent pages from being
2847   simultaneously delivered over multiple IM systems
2848 * Migrated serv_icq.* into the Makefile
2849
2850 Revision 1.341  1999/08/01 21:36:30  ajc
2851 * EXTREME coolness.  The server side of the ICQ metaclient is now working.
2852   It is set up using ICQL and ICQA commands, it automatically logs the user
2853   onto ICQ along with Citadel, and displays all non-offline ICQ contacts
2854   in the Wholist.
2855
2856 Revision 1.340  1999/07/31 07:18:01  ajc
2857 * Restructured the express message infrastructure, adding a class of function
2858   hooks for the addition of multiple paging modules with message routing
2859
2860 Revision 1.339  1999/07/30 22:20:19  ajc
2861 * Applied bugfix patches contributed by Vaggelis Tsirkas:
2862   * rooms.c: buffer overrun fix
2863   * room_ops.c: cmd_rdir() now behaves better when directory doesn't exist
2864
2865 Revision 1.338  1999/07/30 03:32:24  ajc
2866 * Added strdoop(), a leak-checked version of strdup()
2867 * Small fixes to new API functions in msgbase.c
2868 * ICQ metaclient stores/reads config using the message base API functions
2869
2870 Revision 1.337  1999/07/29 03:36:37  ajc
2871 * msgbase.c: reorganized.  output_message() now uses CtdlFetchMessage(),
2872   cmd_msg3() now fetches directly from disk and spews to the client.
2873
2874 Revision 1.336  1999/07/28 04:02:37  ajc
2875 * Server modules are now labelled with their RCS ID instead of a complex and
2876   manually-updated data structure.
2877
2878 Revision 1.335  1999/07/28 03:50:24  ajc
2879 * serv_expire.c: expire-by-age now calls CtdlFetchMessage() instead of
2880   calling output_message() in MT_DATE mode.
2881 * msgbase.c: removed MT_DATE mode ('twas a sleazy hack)
2882
2883 Revision 1.334  1999/07/27 22:47:26  ajc
2884 * Implemented new data type "CtdlMessage" which will eventually be used as
2885   widely as possible to represent a message in memory.
2886 * Implemented CtdlFetchMessage() which is intended to become the back-end to
2887   output_message() as well as a bunch of other things.
2888
2889 Revision 1.333  1999/07/27 20:00:24  ajc
2890 Removed all references to CC->msglist and CC->num_msgs, and all utility
2891 functions which relied upon them.  Citadel Is Now Better.
2892
2893 Revision 1.332  1999/07/27 19:32:22  ajc
2894 Removed serv_upgrade.c and all references to it in Makefile.in
2895 Reworked new-mail-count to not use MessageFromList() etc.
2896
2897 Revision 1.331  1999/07/25 02:59:37  ajc
2898 Fixed reference count problem in cmd_move()
2899
2900 Revision 1.330  1999/07/24 22:50:38  ajc
2901 Continued replacing references to [get|put]_msglist() with better code.
2902 For some reason, cmd_msgs() still doesn't always work right.
2903
2904 Revision 1.329  1999/07/24 22:16:41  ajc
2905 Experimenting with automatic updating of ChangeLog by CVS.  Simply twiddle
2906 ChangeLog a bit (i.e. by adding or removing a newline from the end of the
2907 file) before issusing "cvs commit", and the comments recorded by CVS will
2908 automatically appear at the beginning of ChangeLog.
2909
2910 Revision 1.328  1999/07/24 22:14:21  ajc
2911 cmd_move() now uses CtdlDeleteMessages().
2912 WARNING: build is temporarily broken.  Currently removing all references
2913 to the "msglist" kept in CitContext.  It's ugly and must die.
2914
2915 Thu Jul 22 22:26:50 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
2916         * Moved message deletion into new API function CtdlDeleteMessages()
2917         * Added CtdlWriteObject() to store generic data in the msgbase
2918         * Fixed really dumb error that prevented network msgs from posting
2919
2920 Tue Jul 20 22:14:54 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
2921         * Moved the actual work done in cmd_msgs() into a new API function
2922           called CtdlForEachMessage() which is supplied a callback function.
2923
2924 Mon Jul 19 23:24:18 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
2925         * Keep the (unqualified) content-type in the SuppMsgInfo record.  We'll
2926           be using this shortly to search rooms for specific object types.
2927
2928 Sun Jul 18 14:53:16 EDT 1999 Art Cancro <ajc@uncensored.citadel.org> 
2929         * Changes to dynloader et al to handle ICQ module being written
2930         * serv_icq.c, serv_icq.mk: added (separate makefile is temporary)
2931
2932 1999-07-17 Nathan Bryant <bryant@cs.usm.maine.edu>
2933         * chkpwd.c: DELETED CVS REVISION 1.3 (backed out Art's last change)
2934           use 'cvs update -r 1.2 chkpwd.c; cvs update -A chkpwd.c' NOW to
2935           avoid problems with working directories.
2936         * Makefile.in: don't install chkpwd setuid if make install isn't
2937           being run as root.
2938         * citadel.spec: chmod u+s chkpwd during %install stage
2939
2940 Fri Jul 16 18:39:04 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
2941         * PEXP and GEXP no longer trip the idle time display
2942         * Fixed bug which duplicated incoming private mail to Trashcan
2943         * Improved auto-reconnect by NOT using SIGPIPE and longjmp(); also
2944           implemented a 15 second delay to wait for a crashed server to restart
2945         * Relaxed the security check in chkpwd.c a bit; it was just flat-out
2946           preventing logins on my system otherwise
2947
2948 Thu Jul 15 22:57:32 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
2949         * eliminate redundant "name" parameter in [l]putuser(), now uses
2950           usbuf->fullname to guarantee the correct name for the index
2951
2952 1999-07-12 Nathan Bryant <bryant@cs.usm.maine.edu>
2953         * Makefile.in, configure.in: link netproc with gdbm
2954         * netproc.c: only include gdbm.h if HAVE_GDBM_H
2955         * user_ops.c: warning fix
2956
2957 Mon Jul 12 19:51:30 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
2958         * Mail is now saved in both sender and recipient mailboxes.  This is
2959           structured in a way that will allow a separate "outbox" room and/or
2960           multiple recipients in the future.
2961
2962 Sun Jul 11 18:46:48 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
2963         * netproc.c: msgfind() no longer uses the timestamp as a message-ID
2964           when no other message-ID is available (it screws up the loopzapper)
2965         * room_ops.c: eliminate room name parameter in putroom() and its ilk;
2966           get data from quickroom.QRname instead; prevents incorrect indexes
2967         * Tentative implementation of "personal rooms" (user-private namespace)
2968         * Added supplementary message info records for info that may change
2969           at some time later than when the message is saved (i.e. ref counts)
2970         * Implemented msg reference count increment/decrement; delete messages
2971           whose reference count reaches zero
2972
2973 Wed Jul  7 23:25:09 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
2974         * control.c: create citadel.control if it doesn't exist (yikes!)
2975         * serv_expire.c: purge mailbox rooms belonging to non-existent users
2976         * user_ops.c: don't delete user's mailbox at user-delete time
2977
2978 Mon Jul  5 17:01:29 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
2979         * utilsmenu: removed menu items for defunct utilities
2980
2981 Mon Jun 28 16:24:10 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
2982         * Changed any remaining references to UUCP, to "Internet" instead.
2983
2984 Thu Jun 24 11:13:23 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
2985         * added server command line option "-f" to defrag databases on startup
2986         * control.c: better performance and reliability in [get|put]_control()
2987         * netproc.c: Finished the loopzapper
2988
2989 Mon Jun 21 00:04:15 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
2990         * netproc.c: started writing a vortex checker.  Not finished.
2991
2992 Wed Jun  9 23:34:25 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
2993         * Replaced all code that generated temporary filenames with calls to
2994           tmpnam().  Rewrote using tmpfile() where possible.
2995
2996 Thu Jun  3 11:35:18 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
2997         * base64.c: mapped fi and fo to stdin and stdout using
2998           actual code rather than assignment at declaration time
2999           (several users of Red Hat Linux 6.0 reported problems)
3000
3001 Fri May 21 20:05:00 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
3002         * Added function CtdlGetDynamicSymbol() for dynamic symbol allocation
3003         * server.h: Changed discrete #define's to enum's where appropriate
3004         * sysdep.c: Changed the startup message to give credit to the whole
3005           development team :)  Also made the message more GNU-ish.
3006
3007 Thu May 20 20:01:30 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
3008         * database.c: print log messages for file defragmentations
3009         * citserver.c: implemented CtdlAllocUserData() and CtdlGetUserData()
3010           for arbitrary per-session data storage (by modules etc.) without
3011           having to add fields to struct CitContext
3012         * msgbase.c: removed "desired_section" from struct CitContext and
3013           implemented it using CtdlGetUserData() as a test.
3014
3015 Wed May 19 19:30:28 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
3016         * commands.c, commands.h, routines.c: began color scheme changes
3017
3018 1999-05-15 Nathan Bryant <bryant@cs.usm.maine.edu>
3019         * configure.in: Added untested support for BSDI 4.x.
3020
3021 1999-05-13 Nathan Bryant <bryant@cs.usm.maine.edu>
3022         * acconfig.h, configure.in, routines.c: fix for certain SYSV variants
3023           which lack utmp.ut_host
3024         * citadel.h, file_ops.c, msgbase.c, netproc.c, serv_chat.c: fix
3025           namespace collision with <sys/stream.h> on aforementioned SYSV
3026           variant
3027         * configure.in, getutline.c: check for paths.h
3028         * configure.in, Makefile.in: check for -lsocket and -lnsl
3029
3030 1999-05-11 Nathan Bryant <bryant@cs.usm.maine.edu>
3031         * chkpwd.c: fixed excessive paranoia; it used to refuse to run when
3032           invoked by root and BBSUID != 0
3033         * Makefile.in: ignore errors while installing /etc/pam.d/citadel
3034
3035 1999-04-27 Art Cancro <ajc@uncensored.citadel.org>
3036         * file_ops.c: fixed NDOP to not crash the server if it has trouble
3037           with a download file
3038         * netpoll.c: upped default packet size
3039
3040 Mon Apr 26 22:06:57 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
3041         * Repaired IGnorant security hole blunder re. citmail
3042
3043 Sun Apr 25 12:44:08 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
3044         * serv_chat.c: notify user of number of participants upon entering chat
3045         * Built the 5.53 distribution
3046
3047 Wed Apr 21 22:23:13 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
3048         * aidepost.c: add -r flag to allow posting to rooms other than Aide>
3049         * serv_expire.c: now posts transcripts of all auto-purged rooms/users
3050
3051 Tue Apr 20 12:45:55 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
3052         * messages.c: downloading more than MAX_MSGS messages now truncates
3053           (off the beginning of the list) rather than crashing.
3054
3055 Mon Apr 19 12:11:48 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
3056         * whobbs.c: auto-detect when being called from a webserver, and act
3057           as a CGI (print HTTP headers and HTML output)
3058
3059 1999-04-18 Nathan Bryant <bryant@cs.usm.maine.edu>
3060         * serv_chat.c: fixed some potential buffer overruns (thanks dme)
3061
3062 Wed Apr 14 21:32:28 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
3063         * Makefile.in: chmod 4755 citmail to prevent citmail from aborting
3064           when called from sendmail due to citadel.config security check
3065
3066 1999-04-13 Nathan Bryant <bryant@cs.usm.maine.edu>
3067         * dynloader.c: OpenBSD places underscores in front of symbol names
3068         * Makefile.in: fixed a few sillies
3069         * aidepost.c, citmail.c, file_ops.c, logging.c, msgbase.c, netmailer.c,
3070           netproc.c, rcit.c, routines.c, serv_upgrade.c: fixed time_t handling
3071           (have to cast it to long for printf/scanf)
3072
3073 Mon Apr 12 22:13:26 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
3074         * aidepost.c: rewrote to unlink temp file before writing to it so that
3075           it will automatically go away if interrupted. Also ran indent -kr -i8
3076
3077 1999-04-12 Nathan Bryant <bryant@cs.usm.maine.edu>
3078         * configure.in, Makefile.in: taught it how to generate OpenBSD shared
3079           libraries
3080         * config.c, sysdep.c: fix -h option not setting proper modules dir
3081         * configure.in, citadel.spec: make --enable-chkpwd the default
3082         * setup.c: don't chown chkpwd
3083
3084 1999-04-11 Nathan Bryant <bryant@cs.usm.maine.edu>
3085         * configure.in: another OpenBSD fix, but we're still not quite there yet
3086         * serv_chat.c: warning fix
3087
3088 Thu Apr  8 22:51:28 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
3089         * config.c: now requires a setup run for *any* rev level difference
3090         * Updated docs & confs for 5.53b1 release
3091         * setup.c: sets the 0600 permission bits on citadel.config that
3092           is checked for in config.c
3093
3094 1999-04-08 Nathan Bryant <bryant@cs.usm.maine.edu>
3095         * citserver.c: improved is_public_client(), also if a public_client
3096           only supplies a numeric address, attempt to resolve it
3097         * locate_host.c: verify that the forward DNS matches the reverse
3098         * locate_host.c, locate_host.h: more general interface
3099         * configure.in, acconfig.h: fixes for Digital UNIX
3100
3101 Wed Apr  7 21:36:16 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
3102         * Implemented "access level required to create rooms" (client & server)
3103
3104 1999-04-07 Nathan Bryant <bryant@cs.usm.maine.edu>
3105         * configure.in: updated help messages, OpenBSD support
3106         * setup.c: if /etc/inittab doesn't exist, don't ask to create an
3107           entry in it
3108         * server.h, sysdep.c: fix a potential deadlock/data corruption bug
3109         * room_ops.c: fixed the 'gdbm error: Illegal data' message when
3110           deleting a room which had never been posted to
3111         * user_ops.c: include errno.h
3112         * dynloader.c: fix for OpenBSD
3113
3114 1999-04-06 Nathan Bryant <bryant@cs.usm.maine.edu>
3115         * Makefile.in, configure.in, getutline.c, sysdep.c:
3116           fixes/bug workarounds for FreeBSD
3117
3118 1999-04-03 Nathan Bryant <bryant@cs.usm.maine.edu>
3119         * Makefile.in, configure.in, chkpwd.c, acconfig.h: support for
3120           `chkpwd', a setuid helper program for machines which use shadow
3121           passwords (configure --enable-chkpwd)
3122         * Makefile.in, configure.in, auth.c, citadel.pam, user_ops.c: support
3123           for PAM or shadow passwords (configure --with-pam)
3124         * Makefile.in: made some messages simpler
3125         * citadel.spec: updated for 5.53; correct name of tarball; build with
3126           --enable-chkpwd and --with-pam; add defattr tags so rpm's can be
3127           built by non-root user
3128         * commands.c: cosmetic cleanup
3129         * config.c: (security/paranoia) check permissions on citadel.config
3130         * configure.in: check for ncurses if we can't find curses
3131         * dynloader.c: warning fix
3132         * sysdep.c: don't complain if initgroups() fails
3133         * citadel.c: fix systems with SYSV-style signal handling (e.g. libc5)
3134         * Makefile.in: New! Improved! Cleaner! Shinier!
3135
3136 Sun Mar 21 14:21:47 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
3137         * messages.c: cosmetic cleanups to message reading loop
3138
3139 Sat Mar 13 21:33:19 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
3140         * commands.c: use bright colors by default in color mode
3141         * citserver.c: initialize wholist fields with (not logged in) etc.
3142
3143 1999-03-08 Nathan Bryant <bryant@cs.usm.maine.edu>
3144         * sysdep.c: call DLoader_Init() with an absolute path so that gdb can
3145           find module symbols
3146         * database.c: bail out if opening databases fails
3147
3148 Sat Mar  6 01:55:55 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
3149         * serv_chat.c: use memfmout(), *not* cprintf() to transmit express
3150           messages.  Calling cprintf() on strings >256 bytes crashes the server
3151         * msgbase.c: minor logging fix in save_message()
3152
3153 1999-03-05 Nathan Bryant <bryant@cs.usm.maine.edu>
3154         * sysdep.c: add undocumented -r flag to citserver to prevent it from
3155           dropping root permissions.
3156         * sysdep.c: also drop supplementary groups
3157
3158 1999-03-04 Nathan Bryant <bryant@cs.usm.maine.edu>
3159         * config.c: error checking in put_config()
3160         * setup.c: chgrp files to the login group associated with BBSUID
3161         * sysdep.c: copyright 1987-1999; drop root perms; load modules and call
3162           master_startup() after dropping perms
3163
3164 Wed Mar  3 00:00:55 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
3165         * Prevent buffer overruns in lowercase_name in [get|put]user()
3166         * client_chat.c: use citedit() for page composition
3167
3168 Sat Feb 27 07:47:36 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
3169         * rooms.c: download_to_local_disk() prompts for a filename if a blank
3170           filename was supplied to it (for attachments without names)
3171         * mime_parser.c: strip leading whitespace in content_type & disposition
3172
3173 1999-02-24 Nathan Bryant <bryant@cs.usm.maine.edu>
3174         * configure.in: improved check for pthreads
3175         * configure.in, routines.c, acconfig.h: check for ut_type in struct utmp
3176         * configure.in, Makefile.in: support for building server modules as
3177           relocatable objects for BSDI (which still uses a.out *gag* *choke*)
3178         * configure.in: compiler choice & flags for BSDI; check for libtermcap
3179         * database.c: don't use a critical section in open_databases()
3180         * housekeeping.c: use getfloor()/putfloor() instead of
3181           lgetfloor()/lputfloor() in check_ref_counts()
3182         * mime_parser.c: include <errno.h>
3183         * msgbase.c: include <limits.h>
3184         * sysdep.c: hacks for BSDI. use signals to fake thread cancellation;
3185           don't call master_cleanup() directly from signal handler.
3186         * routines.c: prototype getutline() if necessary
3187         * getutline.c: stupid bugfix
3188         * acconfig.h, configure.in, locate_host.c, server.h: work around
3189           nonreentrant gethostbyaddr() on BSDI
3190
3191 Mon Feb 15 22:59:00 EST 1999 Vaggelis Tsirkas
3192         * citadel.c: increased hostname buffer size to handle very big names
3193
3194 1999-02-15 Nathan Bryant <bryant@cs.usm.maine.edu>
3195         * sysdep.c(main): initialize alen before call to accept()
3196
3197 1999-02-04 Nathan Bryant <bryant@cs.usm.maine.edu>
3198         * configure.in: improved check for cygwin
3199         * configure.in, routines.c: access utmp directly instead of calling
3200           `who' if getutline() is available.
3201         * configure.in, Makefile.in, getutline.c: replace getutline() on
3202           systems which don't have it
3203         * routines.c: now always access utmp directly unless we can't find
3204           utmp.h
3205
3206 1999-02-02 Nathan Bryant <bryant@cs.usm.maine.edu>
3207         * Fixes for Cygwin:
3208           - ifdef out file download methods that require named pipes (client)
3209           - include pthread.h and gdbm.h only if they are present (fixes
3210             auto dependency generation)
3211           - include snprintf.h where needed
3212           - handle .exe suffixes for "make install"
3213
3214 Tue Feb  2 22:15:08 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
3215         * Overhauled the express messaging system (again)
3216
3217 Mon Feb  1 19:48:04 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
3218         * messages.c: implemented client download of MIME attachments
3219
3220 Sun Jan 31 18:29:18 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
3221         * Added qpdecode.c to the distribution (decodes quoted-printable)
3222         * Finished the MIME parser
3223         * Gave MSG0 a reasonable behaviour for MIME messages
3224         * Added the OPNA command for downloading attachments
3225
3226 Sat Jan 30 18:39:53 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
3227         * Look for citadel.rc in current directory if not found elsewhere
3228         * More work on the MIME parser
3229         * Added base64.c to the distribution
3230
3231 1999-01-29 Nathan Bryant <bryant@cs.usm.maine.edu>
3232         * fixes for IRIX (thanks to wr and family for use of the Indy):
3233           - use memset()/memcpy() instead of bzero()/bcopy() in all cases
3234           - configure updates
3235           - handle `long' pid's
3236           - a few other little bits
3237
3238 Mon Jan 25 21:23:07 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
3239         * Fixed bug in save_message() which crashed the server on mail to sysop
3240         * Rewrote pop_march() to be smarter about <G>oto heuristics
3241
3242 Sat Jan 23 14:32:19 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
3243         * Changed internal storage of express messages from a linked list to
3244           a single, resizable buffer.
3245         * Added a "room order" key to the room record, to allow some control
3246           over room listing order.
3247         * Made the room list commands aware of the room order key.
3248         * Overhauled <G>oto heuristics to pay attention to floor & room order
3249
3250 Wed Jan 20 19:21:51 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
3251         * Added some more code to the unfinished MIME parser
3252         * Changed module loading path to simply "modules" because after calling
3253           get_config(), the cwd is guaranteed to be the correct BBS directory.
3254
3255 Tue Jan 19 21:28:29 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
3256         * Fixed a bug in the user editing command (client side)
3257         * Started a rewrite of the MIME parser
3258
3259 Thu Jan 14 21:21:15 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
3260         * Brought over the mime_parser from WebCit and began preliminary work
3261           on supporting MIME format messages.
3262
3263 Tue Jan 12 22:30:00 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
3264         * Various changes to begin work on support for MIME messages
3265                 - Defined format type 4 for MIME
3266                 - msgbase.c: *temporary* hacks in output_message() for Type 4
3267                 - citmail.c: added more robust header parsing, and support
3268                              for Type 4.  Also eliminated the crappy built-in
3269                              SMTP server.
3270                 - Updated some of the technical documentation
3271
3272 Sun Jan 10 13:34:36 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
3273         * Fixed access to page log room
3274
3275 Fri Jan  8 12:35:09 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
3276         * control.c: include <limits.h> to fix PATH_MAX undefined
3277         * serv_chat.c: made the following changes to cmd_sexp() --
3278                 * Send zero-length message to check only, don't send
3279                 * Send "-" message on the command line to invoke
3280                   the SEND_LISTING transfer mode for a multi-line message
3281         * Added facilities to log all pages to a room (site configurable)
3282
3283 Tue Jan  5 23:24:52 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
3284         * Replaced all occurances of malloc(), realloc(), and free() in the
3285           server and server-modules with mallok(), reallok(), and phree().
3286           Wrote macros and a set of leak-tracking functions.
3287
3288 Sun Jan  3 20:38:45 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
3289         * Documentation changes
3290
3291 Fri Jan  1 01:01:45 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
3292         * Fixed security problem relating to private rooms
3293
3294 Wed Dec 30 20:10:52 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
3295         * sysdep.c: put a bigger string buffer into lprintf() to avoid overruns
3296
3297 Sat Dec 26 16:56:46 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
3298         * internetmail.config: commented this file more clearly
3299
3300 Wed Dec 23 20:42:49 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
3301         * citadel.c: added some experimental code to automatically reconnect
3302           to the server if the connection is broken.  For some reason, it only
3303           works once.
3304
3305 Wed Dec 23 18:47:12 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
3306         * sysdep.c: ignore SIGPIPE.  This keeps broken connections from
3307           crashing the whole server.
3308         * Tagged everything for the official 5.50 release.
3309
3310 Mon Dec 21 07:54:20 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
3311         * housekeeping.c: call kill_session() with session_to_kill,
3312           not ccptr->cs_pid (was crashing the server)
3313
3314 Sat Dec 19 13:57:48 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
3315         * Added "-i" flag to netproc to make it skip the export phase.
3316           Updated other programs to call netproc in this way when appropriate.
3317         * Updated network.txt to reflect the usage for netproc (which has
3318           been wrong for several releases)
3319
3320 Thu Dec 17 00:17:04 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
3321         * Started removing the word "beta" from the docs and code.
3322           Preparing for an actual release.
3323         * msgbase.c: generate an 'I' field when requested (i.e. on locally
3324           originating messages.  this was breaking parts of the network)
3325
3326 1998-12-15 Art Cancro <ajc@uncensored.citadel.org>
3327         * msgbase.c: remove extra call to alias() which was causing
3328           Citadel-to-Citadel mail to fall into the bit bucket.
3329         * msgbase.c: fixed tempfile naming problem that could cause a new
3330           outgoing netmail message to overwrite another if netproc had not been
3331           run in between
3332
3333 1998-12-14 Art Cancro <ajc@uncensored.citadel.org>
3334         * More session table stability nonsense
3335
3336 Sun Dec 13 17:40:08 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
3337         * sysdep.c, citserver.c: (hopefully) fixed a session table concurrency
3338           bug which was causing the server to occasionally crash.
3339         * removed serv_test.so from the default build
3340
3341 Fri Dec 11 18:50:00 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
3342         * setup.c: default value for maxsessions is now 0 (no limit)
3343         * room_ops.c: don't allow users to create a room called "Mail"
3344         * serv_expire.c: fixed "number of messages purged" display
3345         * commands.c: when using color, default to low-intensity colors
3346
3347 Tue Dec  8 07:58:16 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
3348         * Beta 2
3349
3350 Sat Dec  5 01:24:03 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
3351         * Added a new type of module hook for adding logging functions
3352         * Removed whitespace to left and right of '@' in netmail recipients
3353         * sysdep.c: read citadel.config _before_ initializing loadable modules
3354         * stats.c: fixed segfault resulting from extracting log lines
3355         * Ripped most of the "attachments" stuff out of both the client and
3356           server.  (Thought of a better way to handle it ... LATER.)
3357
3358 1998-12-03 Nathan Bryant <bryant@cs.usm.maine.edu>
3359         * setup.c: create citadel.config with mode 0600
3360         * Makefile.in: don't chmod sendcommand
3361         * serv_upgrade.c: don't create citadel.config if it doesn't already
3362           exist (paranoia)
3363         * setup.c: saner defaults for nodename and fqdn
3364
3365 Wed Dec  2 20:37:05 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
3366         * msgbase.c: modified AddMessageToRoom() and all functions that call it
3367           to use a more reliable/accurate method to set quickroom.QRhighest
3368         * weekly.in: don't sort/purge filedir where filedir doesn't exist
3369
3370 1998-12-02 Nathan Bryant <bryant@cs.usm.maine.edu>
3371         * weekly is now generated by configure
3372
3373 Mon Nov 30 19:48:52 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
3374         * room_ops.c: added sort_msglist() to move and save operations
3375         * sendcommand.c: added (also updated utils.txt, weekly, Makefile.in)
3376         * BETA 1
3377
3378 Sun Nov 29 23:57:39 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
3379         * Fixed cmd_regi() to not display a second result code after xfer
3380         * Makefile.in: Removed "chmod 4755 citmail netmailer"
3381
3382 1998-11-23 Nathan Bryant <bryant@cs.usm.maine.edu>
3383         * citadel.spec: added
3384
3385 1998-11-22 Nathan Bryant <bryant@cs.usm.maine.edu>
3386         * Makefile.in: split install target into install-exec, install-data,
3387           and install-doc subtargets
3388
3389 Sat Nov 21 16:53:30 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
3390         * Added a fourth color mode in the client: "user" which turns color
3391           on or off according to a per-user flag stored on the server.  Added
3392           server-side support for this too, of course.
3393         * import.c: removed
3394         * serv_expire.c: finished the code to purge stale visits
3395         * sysdep.c: strip trailing nonprintables in client_gets()
3396         * routines2.c: fixed <.AS> command; all configs now work properly
3397         * Moved num_parms() and all the extract() type functions into tools.c
3398           and removed them from all other files.  Linked in tools.[o|ro] there.
3399         * netproc.c: handled incoming file transfers to correct room directory
3400         * room_ops.c: fixed incorrect naming of files in info and images dirs
3401
3402 Fri Nov 20 20:29:07 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
3403         * setup.c: removed all prompts that can be configured from within the
3404           client in order to simplify the setup procedure
3405
3406 Thu Nov 19 23:28:33 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
3407         * Fixed serv_upgrade.c and export5.c (found elsewhere) to use a new
3408           export format which treats visits as a separate section
3409         * serv_expire.c: began writing functions to purge rooms and visits
3410           (neither work yet), and added a way to call defrag_databases()
3411
3412 Wed Nov 18 23:51:17 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
3413         * Reimplemented 'visit' structs stored globally instead of as
3414           lists-per-user
3415
3416 Tue Nov 17 22:37:48 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
3417         * Started implementing global room numbers.
3418
3419 Sun Nov 15 20:32:34 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
3420         * room_ops.c: mailbox rooms always appear on the main floor
3421         * made QR_MAILBOX rooms non-editable
3422         * cmd_setr() delete old room record when room name changes
3423           (This causes a big mess that exposes a flaw in the whole design.)
3424         * room_ops.c: users can delete messages from their mailboxes
3425
3426 Thu Nov 12 23:59:13 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
3427         * Rewrote cmd_rchg() and also increased the size of the "fakename"
3428           buffer.  Overruns are probably what was causing the crashes.
3429         * Changed the way cmd_ent3() handles mail messages; the previous code
3430           rerouted all private mail to the trash.
3431
3432 Wed Nov 11 17:57:39 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
3433         * citserver.c: slight changes to cmd_rchg() and cmd_hchg() [crashes]
3434         * citserver.c, msgbase.c, user_ops.c: hide the owner-prefix of mail
3435           rooms in a couple more places: set_wtmpsupp() and make_message()
3436         * sysdep.c: added an fflush() to lprintf() for "tail -f"-able logs
3437         * serv_expire.c: purge ops are now a command instead of a cleanup
3438           function.  This is probably temporary as well.
3439         * citadel.c: fixed the way <.WL> parses the returned data from a
3440           TIME command.
3441
3442 1998-11-11 Nathan Bryant <bryant@cs.usm.maine.edu>
3443         * serv_upgrade.c: fix uninitialized variable
3444
3445 Wed Nov 11 00:47:32 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
3446         * msgbase.c: fixed a bug that was misrouting incoming network msgs
3447         * server.h, database.c: wrapped all GDBM calls in critical sections
3448           to avoid making those calls re-entrantly (gdbm fatal: lseek error)
3449
3450 1998-11-10 Nathan Bryant <bryant@cs.usm.maine.edu>
3451         * Makefile.in: link in snprintf.o where needed
3452
3453 1998-11-09 Nathan Bryant <bryant@cs.usm.maine.edu>
3454         * client_chat.c: eliminate calls to sprintf()
3455         * commands.h, routines.c, routines2.c: warning fix
3456         * commands.c, control.c, cux2ascii.c, file_ops.c, import.c,
3457           ipc_c_tcp.c: eliminate sprintf() calls
3458
3459 Mon Nov  9 19:15:31 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
3460         * serv_upgrade.c: added all missing fields to export/import
3461         * serv_expire.c: support per-user purge time when purging users
3462         * user_ops.c: added per-user purge time to AGUP and ASUP commands
3463         * routines.c: added more stuff to <.A>ide <E>dit user
3464
3465 Sun Nov  8 22:56:53 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
3466         * serv_expire.c: created; moved message expiry from serv_test.c,
3467           moved user purge from userpurge.c
3468         * userpurge.c: deleted
3469         * routines2.c: finished <.AS> command
3470         * room_ops.c: fixed Aide room access (for some reason, the Aide
3471           room had the QR_MAILBOX flag set)
3472
3473 1998-11-08 Nathan Bryant <bryant@cs.usm.maine.edu>
3474         * useradmin.c: really removed (cvs remove)
3475         * aidepost.c, citadel.c: convert all sprintf() calls to snprintf()
3476         * sysdep.c: fix overrun in lprintf() described by dme/Dead Monkey
3477         * citmail.c, citserver.c: convert all sprintf() call to snprintf()
3478
3479 Sun Nov  8 13:19:36 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
3480         * useradmin.c: removed
3481         * utils.doc: removed references to useradmin and sysoputil
3482
3483 Fri Nov  6 20:22:20 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
3484         * citadel.h (and related files): removed defunct parameters,
3485           c_defent and c_msgbase (erase your test bbs)
3486         * Implemented CONF server command for site-global configs
3487         * Shuffled yesno() and yesno_d() from routines.c to commands.c
3488         * commands.c: implemented boolprompt()
3489         * routines2.c: started adding CONF questions to <.AS> command
3490         * room_ops.c: began a fix for the mysterious disappearing Aide room
3491
3492 1998-11-05 Nathan Bryant <bryant@cs.usm.maine.edu>
3493         * snprintf.c: warning fix propagated over from gcit
3494
3495 1998-11-04 Nathan Bryant <bryant@cs.usm.maine.edu>
3496         * added RCS Id keyword strings to sources
3497         * citmail.c: reverted to version 1.10
3498
3499 Wed Nov  4 10:53:13 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
3500         * messages.c: temporarily set screenwidth to a fixed value of 80
3501           during <P>rint operations.
3502
3503 Mon Nov  2 12:59:03 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
3504         * setup.c: looks for 'citadel', 'bbs', or 'guest' in /etc/passwd to
3505           try to get a default for bbsuid if it's currently set to 0
3506         * citmail.c: changed usersupp.eternal to usersupp.usernum (why didn't
3507           it complain about this before?)
3508         * serv_upgrade.c: began writing an "export" command to do sidegrades
3509
3510 Sun Nov  1 18:47:42 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
3511         * serv_upgrade.c: cosmetic changes
3512         * Implemented message expiry by date (this really needs to be moved
3513           out of serv_test.c, but where does it belong?)
3514
3515 1998-11-01 Nathan Bryant <bryant@cs.usm.maine.edu>
3516         * serv_upgrade.c: warning fixes
3517         * acconfig.h: remove ANSI_COLOR
3518         * Configure, Makefile.tmpl: removed
3519
3520 Sat Oct 31 20:48:44 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
3521         * More stoopid ANSI colour additions here and there.
3522         * ANSI colour selection is now in citadel.rc instead of an option in
3523           the configure script.  "on" "off" and "auto" are available.
3524         * added "build.txt" to the techdoc directory, with LS's build notes
3525
3526 1998-10-31 Nathan Bryant <bryant@cs.usm.maine.edu>
3527         * citadel.c, commands.c, commands.h: set background color to black
3528           before clearing screen, so that we can actually see text on
3529           black-on-white xterms.
3530
3531 1998-10-29 Nathan Bryant <bryant@cs.usm.maine.edu>
3532         * rooms.c: fix color of Mail>
3533         * citadel.c: send ANSI detect sequence after attach_to_server() so the
3534           terminal doesn't send the answerback sequence to the shell if we
3535           can't connect.
3536
3537 Wed Oct 28 20:20:14 EST 1998 Art Cancro <ajc@uncensored.citadel.org
3538         * citadel.c: Added a splash of colour to the Wholist
3539
3540 1998-10-28 Nathan Bryant <bryant@cs.usm.maine.edu>
3541         * configure.in: added comments
3542         * mkinstalldirs: new file to be used for `make install'
3543         * aclocal.m4, missing: new files, also swiped from automake
3544         * citadel.c: don't mung the terminal if we can't find citadel.rc
3545         * Makefile.in: added `install' target, `clean' removes
3546           *.mo, rebuild configure when configure.in changes.
3547         * configure.in: check for install and autoconf
3548         * configure.in, Makefile.in: only pass -fPIC to gcc
3549         * policy.c: warning fix for OSF/1 (use memset() instead of bzero())
3550
3551 Tue Oct 27 22:25:42 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
3552         * Unified the "unpacked database" format for both upgrades and
3553           sidegrades (also see export5.c elsewhere)
3554         * citserver.c: clear out cmdbuf before reading a command; some server
3555           commands were accidentally extracting parameters from previous cmds
3556         * rooms.c: removed the warning about the ineffectiveness of kicking
3557           users out of public rooms, because the new server can do lockouts
3558
3559 1998-10-27 Nathan Bryant <bryant@cs.usm.maine.edu>
3560         * sysdep.c (client_gets), ipc_c_tcp.c (serv_gets): improved handling
3561           of long lines. 
3562         * Makefile.in: partial support for VPATH builds, autodependency fix
3563
3564 Tue Oct 27 00:08:16 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
3565         * minor documentation changes
3566
3567 Sun Oct 25 14:57:40 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
3568         * messages.c: fixed an oversight that was allowing attachments even
3569           when disabled in citadel.rc
3570
3571 1998-10-25 Nathan Bryant <bryant@cs.usm.maine.edu>
3572         * routines2.c: warning fix
3573
3574 Sat Oct 24 22:07:56 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
3575         * Client: added message expiration policy questions to room edit
3576         * Client: added <.A>ide <S>ystem configuration command
3577
3578 1998-10-24 Nathan Bryant <bryant@cs.usm.maine.edu>
3579         * Makefile.in: Auto dependency generation (may require GNU make, but
3580           does at least function without this feature on OSF/1 make);
3581           Makefile is regenerated when Makefile.in changes (ditto);
3582           `realclean' is now known as `distclean';
3583           portability fixes for older Unix make utilities
3584         * citadel.c, citadel.h, commands.c: make client suspendable
3585
3586 Fri Oct 23 19:34:38 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
3587         * setup.c: default node name is now obtained from uname()
3588         * config.c: added put_config()
3589         * policy.c: added, moved GetExpirePolicy() from room_ops.c
3590         * policy.c: implemented cmd_gpex() and cmd_spex()
3591
3592 Wed Oct 21 22:24:48 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
3593         * Mail rooms now hide their owner-prefix from the client.
3594         * proxy.c: added configurability and primitive message expiry
3595
3596 1998-10-20 Nathan Bryant <bryant@cs.usm.maine.edu>
3597         * Makefile.tmpl: fix to build client with old Configure script
3598         * configure.in: autologin defaults to enabled if crypt() is available
3599         * room_ops.c: fix improper null-termination bug I introduced
3600
3601 Mon Oct 19 20:52:55 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
3602         * Client ability to force display of prompts in Mail rooms, even when
3603           the user has prompting turned off (citadel.rc option)
3604
3605 1998-10-16 Nathan Bryant <bryant@cs.usm.maine.edu>
3606         * sysdep.c (cprintf): generate a newline on truncated buffer
3607         * room_ops.c: exploitable overrun fixes
3608
3609 Thu Oct 15 19:27:32 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
3610         * msgbase.c: reimplemented cmd_move()
3611           room_ops.c: wrote AddMessageToRoom() which is used for both entering
3612           and moving messages.
3613         * setup.c: system-default message expire policy of "number of
3614           messages, 150" is now a default configuration instead of a temp hack
3615         * proxy.c: cache dir create now dies on any error except EEXIST
3616
3617 Wed Oct 14 22:41:16 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
3618         * Misc code cleanup
3619
3620 1998-10-13 Nathan Bryant <bryant@cs.usm.maine.edu>
3621         * configure.in: don't check for -lcrypt unless autologin is enabled
3622         * file_ops.c: fix another overrun
3623
3624 Mon Oct 12 15:27:21 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
3625         * Killed the "rooms" subdirectory (it isn't used anymore)
3626         * dynloader.c: Made dynamically added server commands case-insensitive
3627         * import.c is now serv_upgrade.c, a module
3628         * Removed most of the "level 9" trace messages no longer needed
3629
3630 1998-10-12 Nathan Bryant <bryant@cs.usm.maine.edu>
3631         * Makefile.in: simplified to use pattern rules; files compiled with
3632           -D_REENTRANT go to *.ro to allow the same files to be used with both
3633           client and server
3634         * tools.c, tools.h: new files; misc routines used by both client and
3635           server go here. contains safestrncpy() at the moment.
3636         * rooms.c: fix several exploitable buffer overruns
3637         * sysdep.c: fix infinite loop when long lines are received from the
3638           client; fix exploitable buffer overrun in cprintf()
3639         * ipc_c_tcp.c: fix infinite loop on long line from server
3640         * serv_upgrade.sh: remove uncnsrd-dependent absolute path
3641         * .cvsignore: add *.ro
3642
3643 Sun Oct 11 23:17:48 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
3644         * Built some more of the message expiry infrastructure
3645
3646 1998-10-11 Nathan Bryant <bryant@cs.usm.maine.edu>
3647         * citserver.c: fix two more overruns, one of which was preventing
3648           the "From Host" from showing up in the <W>ho listing.
3649
3650 Sun Oct 11 02:51:55 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
3651         * Moved "struct visit" and its associated defs from citadel.h to
3652           server.h where they belong
3653         * Set up data structures for room policies (expiry, etc.)
3654
3655 1998-10-10 Nathan Bryant <bryant@cs.usm.maine.edu>
3656         * citserver.c: fix overrun which caused segv's on servers with long
3657           hostnames.
3658
3659 Fri Oct  9 18:34:06 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
3660         * user_ops.c: added PurgeStaleRelationships() to do processing at
3661           session logout time to remove visits for rooms which no longer exist
3662         * user_ops.c: implemented NewMailCount()
3663
3664 1998-10-09 Nathan Bryant <bryant@cs.usm.maine.edu>
3665         * serv_chat.c: fix buffer overrun that was resulting in segv's
3666         * serv_chat.c: fix another overrun that could cause sessions to hang,
3667           and cleaned up some other strncpy()-related stuff. DON'T FORGET TO
3668           NULL-TERMINATE DESTINATION BUFFERS AFTER STRNCPY CALLS.
3669
3670 Fri Oct  9 13:22:37 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
3671         * Implemented "lazy mode" traversal - pressing the space bar will do
3672           <N>ext messsage, <G>oto next room, or read <N>ew as appropriate.
3673         * room_ops.c: modify CtdlRoomAccess() to allow access to mailbox rooms
3674           only to their owners.
3675
3676 Thu Oct  8 17:13:27 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
3677         * messages.c, citadel.rc: added the ability to display message numbers
3678           in the header when reading messages.  I think this is butt ugly, but
3679           some of the DaveCode afficionados seem to like it...
3680
3681 Thu Oct  8 15:34:45 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
3682         * room_ops.c: Added is_noneditable() function to replace all of the
3683           duplicated code present in all functions which edit room parameters.
3684
3685 1998-10-08 Nathan Bryant <bryant@cs.usm.maine.edu>
3686         * lots of warning fixes; builds with -std1 on dec unix
3687         * aidepost.c, citadel.h, citmail.c, file_ops.c, msgbase.c, netmailer.c,
3688           netproc.c, rcit.c, server.h, stats.c, userlist.c: use time_t where
3689           needed
3690         * control.c, room_ops.c, serv_chat.c, sysdep.c: use memset() instead of
3691           bzero()
3692         * dynloader.c, dynloader.h, messages.c, server.h, sysdep.c,
3693           sysdep_decls.h: function pointer/prototyping fixes
3694         * rooms.c: use mkfifo(3) instead of system("mkfifo")
3695
3696 1998-10-07 Nathan Bryant <bryant@cs.usm.maine.edu>
3697         * snprintf.c, snprintf.h: new files
3698         * Makefile.in, configure.in, dynloader.c, sysdep.c: support for the
3699           above; citserver now builds and runs on Digital Unix 4.0d with the
3700           GNU-style configure script. there is a bug with the hostname display
3701           in the wholist.
3702         * netproc.c: sillyness fix
3703         * room_ops.h: prototype delete_room()
3704         * client_chat.c, commands.c, serv_chat.c, sysdep.c:
3705           use HAVE_SYS_SELECT_H macro
3706
3707 Mon Oct  5 17:01:32 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
3708         * Began fixing the stuff I broke
3709
3710 Sun Oct  4 23:35:18 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
3711         * Did the big migration to the new data structures.  Lots of stuff is
3712           now broken.  Basic moving from room to room works, but Mail is
3713           broken, and some of the administrative commands are unimplemented.
3714
3715 1998-10-02 Nathan Bryant <bryant@cs.usm.maine.edu>
3716         * configure.in: autologin now defaults to disabled
3717
3718 Fri Oct  2 00:04:31 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
3719         * Finally removed all three usersupp.foo[MAXROOMS] elements, and
3720           migrated all the code that used them to use "struct visit" instead.
3721
3722 Thu Oct  1 23:02:20 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
3723         * Rewrote [l][get|put]room() functions to use room names rather than
3724           room index numbers.  Temporarily prepended a "n" to these four
3725           function names until they are put to use.
3726
3727 Thu Oct  1 16:27:13 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
3728         * Removed a few more references to usersupp.lastseen[]
3729
3730 1998-10-01 Nathan Bryant <bryant@cs.usm.maine.edu>
3731         * .cvsignore: add so_locations (generated by osf1 ld with shared libs)
3732         * Makefile.in: restructured variables for greater consistency, use
3733           @echo to print out notices during the make process, add so_locations
3734           to `cleaner'
3735         * configure.in, Makefile.in: configure checks for -rdynamic
3736         * ipc_c_tcp.c: fix DEC compiler warning wrt unsigned char
3737         * stats.c: add semicolon to placate DREC compiler
3738         * user_ops.c: define _POSIX_C_SOURCE, include <limits.h>
3739         * configure.in: pass -pthread to DEC compiler, don't check for
3740           libpthread[s] on DEC Unix
3741
3742 1998-09-30 Nathan Bryant <bryant@cs.usm.maine.edu>
3743         * Makefile.in: new variable PTHREAD_DEFS for portability
3744         * aidepost.c, citadel.c, citmail.c, mailinglist.c, msgform.c,
3745           netmailer.c, netpoll.c, netproc.c, rcit.c, readlog.c, setup.c,
3746           stats.c, userlist.c, whobbs.c: return type of main() is int
3747         * citadel.c, commands.c, messages.c: use time_t properly
3748         * citserver.c: include <limits.h>
3749         * config.guess, config.sub, install-sh: new files
3750         * configure.in: don't use gcc on Digital Unix
3751
3752 Tue Sep 29 23:17:34 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
3753         * room_ops.c: modified usergoto() to look at the new data structures
3754           for counting new messages and such.
3755
3756 1998-09-29 Nathan Bryant <bryant@cs.usm.maine.edu>
3757         * user_ops.c: fix compiler warning and potential memory leak,
3758           include sysdep.h
3759         * configure.in, Makefile.in: only build the server if we find pthreads
3760         * Makefile.in: realclean removes config.{cache,log,status}
3761
3762 Tue Sep 29 13:20:14 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
3763         * Removed code from some of the utilities which was still attempting
3764           to access the old non-gdbm data store.
3765         * housekeeping.c: rewrote check_ref_counts() to do a ForEachRoom()
3766           traversal instead of a MAXROOMS loop.
3767         * sysdep.c: set up a dummy CitContext record to be used during server
3768           startup, during which time there is no real context.
3769
3770 Mon Sep 28 23:51:51 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
3771         * Implemented the function ForEachRoom() to handle all-rooms traversal
3772           (this will work with both the old and new paradigms, because both
3773           use a GDBM database with one room per record).  Migrated all room
3774           list commands to use it.
3775
3776 Mon Sep 28 22:05:35 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
3777         * Implemented the function CtdlRoomAccess() to handle *all* of the
3778           user-access-to-rooms functionality.  Migrated all room list commands
3779           to use it.  Still need to migrate gotos.
3780
3781 1998-09-28 Nathan Bryant <bryant@cs.usm.maine.edu>
3782         * configure.in, acconfig.h: new files; partially functional GNU
3783           autoconf configure script. Run autoheader; autoconf; ./configure
3784           --prefix=`pwd` to test.
3785         * Makefile.tmpl: new file; this is what Makefile.in used to be. Used by
3786           Configure.
3787         * Makefile.in: modified to work with autoconf-style configure script
3788         * Configure: modified to use Makefile.tmpl and generate autoconf-style
3789           macros. Removed procfs detection. Pass -O2 to gcc, -O to other
3790           compilers. Removed mknod/mkfifo detection; code should use mkfifo(3).
3791         * citmail.c, msgform.c, netproc.c, routines.c, support.c, userlist.c,
3792           whobbs.c: use HAVE_STRERROR macro rather than NO_STRERROR
3793         * commands.c: use HAVE_TERMIOS_H macro rather than POSIX_TERMIO
3794         * netproc.c: remove procfs stuff. simply attempt to kill the target
3795           process with signal zero instead; this checks whether the process
3796           exists.
3797         * setup.c, useradmin.c: use HAVE_CURSES_H macro
3798
3799 Sun Sep 27 23:41:29 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
3800         * BOTH the old and new generation systems are being written to at
3801           this point.  Code that reads stuff is still using the old system.
3802
3803 Sun Sep 27 16:10:49 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
3804         * Changed all "generation" variables from char to long, in preparation
3805           for removing MAXROOMS.  Generations for new rooms are now timestamps.
3806         * Defined "struct visit" to hold user/room relationships.
3807         * Removed some #define's from citadel.h that are no longer used.
3808
3809 Wed Sep 23 13:41:49 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
3810         * More changes to support attachments.  They mostly work, but only
3811           in fixed-format messages.
3812
3813 Mon Sep 21 21:19:17 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
3814         * msgbase.c: began laying the groundwork to support attachments.
3815           Purchased Rogaine(tm) in preparation for expected hair loss.
3816
3817 1998-09-21 Nathan Bryant <bryant@cs.usm.maine.edu>
3818         * msgbase.c: include dynloader.h
3819         * citadelapi.h: removed
3820         * dynloader.h: prototype CtdlRegisterUserHook()
3821
3822 Sun Sep 20 18:56:37 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
3823         * Added a UserFunctionHook category to implement hooks which perform
3824           operations on various users or usernames
3825
3826 Fri Sep 18 21:14:41 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
3827         * citserver.c: removed cmd_extn() and related code
3828
3829 1998-09-18 Nathan Bryant <bryant@cs.usm.maine.edu>
3830         * user_ops.c: include dynloader.h
3831         * roomstats.{c,mk}: removed
3832         * Configure, Makefile.in: autodependency-related fixes
3833
3834 Thu Sep 17 22:55:29 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
3835         * Various changes to allow "new messages" to work correctly with Mail
3836
3837 Thu Sep 17 22:21:45 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
3838         * server.h, dynloader.c, citserver.c, user_ops.c: reduced the number
3839           of hook types by inventing an EventType field to the Session hook.
3840         * proxy.c: added pre-fetching
3841
3842 1998-09-17 Nathan Bryant <bryant@cs.usm.maine.edu>
3843         * Makefile.in: add SERV_MODULES and PROXY_TARGETS to `cleaner'
3844         * dynloader.[ch], serv_{chat,test}.[ch], sysdep.c: cleaned
3845           up the dynamic loader interface as follows:
3846           - all the symbol table stuff is gone.
3847           - modules are loaded once at server startup and never unloaded.
3848           - Added a new function CtdlRegisterProtoHook() to handle the stuff
3849             that was being done with the symbol tables.
3850           - Dynamic_Module_Init() now returns a pointer to a static struct
3851             DLModule_Info; this structure itself has been modified to use char*
3852             fields instead of fixed char arrays.
3853         * roomstats.c: include <stdarg.h> not <stdargs.h> (is this file still
3854           in use?)
3855         * Configure, Makefile.in: added autodependency support
3856
3857 Wed Sep 16 22:25:13 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
3858         * Implemented separate structs, lists, and functions for each type
3859           of server-side hook available.
3860
3861 1998-09-16 Nathan Bryant <bryant@cs.usm.maine.edu>
3862         * ipc_c_tcp.c: Fixed up some #include/prototyping stuff, call memcpy()
3863           instead of bcopy()
3864         * hooks.h: removed
3865         * sysdep.c, user_ops.c: removed reference to hooks.h
3866
3867 Wed Sep 16 11:42:42 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
3868         * ipc_c_tcp.c: Reversed any changes that have been made to this file,
3869           because something was causing abominally slow response time.
3870         * proxy.c: added.  This will eventually become a caching, pre-fetching
3871           multiuser proxy server for the Citadel protocol.
3872
3873 1998-09-15 Nathan Bryant <bryant@cs.usm.maine.edu>
3874         * Makefile.in: remove support.o from serv_chat.so, add -fPIC to compile
3875           flags for serv_chat.o
3876         * dynloader.c: include "sysdep_decls.h", use RTLD_NOW not RTLD_LAZY
3877         * dynloader.h: prototype CtdlRegisterHook()
3878         * .cvsignore: added data
3879
3880 Mon Sep 14 20:49:08 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
3881         * Tried my hand at adding the ability for server extensions to
3882           register various types of "hooks" in addition to just adding
3883           server commands.  This is probably not final.
3884
3885 Tue Sep  8 12:11:56 EDT 1998 Brian Costello <btx@calyx.net>
3886         * Added support for dynamic server modules.  Reworked serv_chat.c
3887           to be such a module.
3888
3889 Tue Sep  1 23:09:50 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
3890         * userpurge.c: rewrote using functions from the server core, rather
3891           than the now-defunct external API.  This'll be ready once the module
3892           loading code is done.  (I just had to commit _something_ tonight.)
3893
3894 Mon Aug 31 22:47:58 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
3895         * Yanked the citadelapi.c module.  This wasn't working out well.
3896         * techdocs/citadelapi.txt - began documenting the new API to be used
3897           by modules which will be dynamic linked into the server - most of
3898           this API is existing server functions.
3899         * Added a ForEachUser() function with callback mechanism, and reworked
3900           cmd_list() to use it.
3901
3902 Sun Aug 30 21:52:43 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
3903         * Moved all of the gdbm databases to a separate "data" directory.
3904
3905 1998-08-26 Nathan Bryant <bryant@cs.usm.maine.edu>
3906         * Makefile.in: realclean removes Makefile, fixed `touch citadel.h'
3907           problem
3908
3909 1998-08-25 Nathan Bryant <bryant@cs.usm.maine.edu>
3910         * room_ops.c: include time.h
3911         * userlist.c, whobbs.c, serv_chat.c, user_ops.c, sysdep.c, stats.c,
3912           citadel_decls.h, commands.c, messages.h, routines.h, routines2.h:
3913           remove duplicated declarations
3914
3915 Mon Aug 24 23:45:01 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
3916         * setup.c: Removed yesno_s()
3917         * citadel.h, room_ops.c: added QRmtime field to struct quickroom,
3918           modified whenever a room is modified or posted in.
3919         * citadelapi.c: Added CtdlForEachRoom() function
3920
3921 Mon Aug 24 20:04:04 EDT 1998 Nathan Bryant <bryant@cs.usm.maine.edu>
3922         * Makefile.in: new target `cleaner' does the same as `realclean' 
3923           without removing sysdep.h
3924         * proto.h: is bad. eliminate. I've moved the prototypes into several
3925           header files, one per .c file
3926
3927 Mon Aug 24 00:45:55 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
3928         * Added a CtdlGotoRoom() function to the CitadelAPI.
3929  
3930 Sun Aug 23 21:47:00 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
3931         * sysoputil is finally dead!  Removed it from the build.
3932         * Added userpurge.c server extension (initial implementation)
3933
3934 Tue Aug 18 00:42:33 EDT 1998 Nathan Bryant <bryant@cs.usm.maine.edu>
3935         * Makefile.in: `clean' target no longer rm's sysdep.h; new target
3936           `realclean' removes everything clean does, plus sysdep.h, plus
3937           target binaries.
3938         * Configure: add -Wstrict-prototypes to CFLAGS for gcc systems
3939         * *.[ch]: protoized. Added several new header files containing
3940           prototypes and other external declarations; many duplicated
3941           declarations still should be moved to header files. proto.h must die
3942           as well, IMHO.
3943
3944 Mon Aug 17 23:52:13 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
3945         * Implemented a bunch of user account related functions in the
3946           CitadelAPI library.
3947
3948 Mon Aug 17 20:01:18 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
3949         * Fixed the crash problem.  It wasn't AGUP/ASUP, but rather a buffer
3950           overrun in getuser() (thanks, Nathan).  Implemented overrun checks
3951           in getuser(), getroom(), and getfloor() to prevent future problems.
3952
3953 Mon Aug 17 00:06:52 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
3954         * Updated citmail.c with the latest stuff from the production system.
3955         * Implemented AGUP and ASUP commands, but AGUP crashes the server
3956           after its first successful use (user-not-found's don't affect it).
3957
3958 Thu Aug  6 19:25:01 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
3959         * Got the CitadelAPI library to the point where the server can start
3960           up an extension, and the extension will connect to the server, do
3961           some initialization, call a user-supplied CtdlMain(), and exit.  Also
3962           hacked together a _temporary_ form of the new EXTN server command.
3963  
3964 Wed Aug  5 23:02:22 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
3965         * Second attempt at getting the server API started.  Now it runs
3966           outside of the server and builds a connection.
3967
3968 Tue Aug  4 18:33:06 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
3969         * Modified the appearance of Internet addresses when they arrive on
3970           a Citadel system.
3971         * Removed the <E> field from the message format writeup in hack.txt.
3972         * Fixed-up citmail.c so that it doesn't try to do database lookups.
3973
3974 Mon Aug  3 23:01:37 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
3975         * Started developing the server-side API.  This is in its very
3976           initial stages.  See serverapi.c and techdoc/api.txt
3977
3978 1998-08-02  Nathan Bryant  <bryant@cs.usm.maine.edu>
3979         * Makefile.in: added config_decls.h to dependencies
3980
3981 Sun Aug  2 21:09:09 EDT 1998 Nathan Bryant <bryant@cs.usm.maine.edu>
3982         * config_defs.h: renamed to config_decls.h
3983         * config.c, sysoputil.c: updated to reflect the above
3984
3985 Sun Aug  2 18:52:05 EDT 1998 Nathan Bryant <bryant@cs.usm.maine.edu>
3986         * config_defs.h: new file, contains external declarations from config.c
3987         * config.c: moved defs to config_defs.h, use PATH_MAX from <limits.h>
3988           for bbs_home_directory
3989         * mailinglist.c, support.c: include <string.h>
3990         * sysoputil.c: include <string.h>, <limits.h>, "config_defs.h", remove
3991           duplicated defs, replace gets() call with fgets()
3992         * user_ops.c: define _XOPEN_SOURCE_EXTENDED
3993
3994 Sat Aug  1 18:32:52 EDT 1998 Nathan Bryant <bryant@cs.usm.maine.edu>
3995         * ipc_c_tcp.c: fixed order of memcpy parameters after gethostbyname
3996
3997 Sun Jul 19 17:26:12 EDT 1998 Nathan Bryant <bryant@cs.usm.maine.edu>
3998         * ChangeLog: reordered; the GNU standard is to add new entries to the
3999           top.
4000         * .cvsignore: added userlist
4001
4002 Sun Jul 12 20:58:59 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
4003         * Finished migrating everything to the new data store.
4004         * Replaced the binary "calllog" with the ASCII "citadel.log"
4005         * Began converting broken utilities that depend on the old data store
4006
4007 Sat Jul 11 00:20:48 EDT 1998 Nathan Bryant <bryant@cs.usm.maine.edu>
4008         * Makefile.in: removed msgstats
4009
4010 Fri Jul 10 1998 Art Cancro <ajc@uncensored.citadel.org>
4011         * Initial CVS import
4012