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