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