* The full text indexer now runs in its own dedicated thread instead of
[citadel.git] / citadel / ChangeLog
1  Revision 647.20  2005/05/23 19:26:04  ajc
2  * Move the location of the "enable full text index" configuration item to
3    a new location.  Reusing an old location was a stupid idea because old
4    clients can inadvertently switch it on.
5
6  Revision 647.19  2005/05/23 14:07:39  ajc
7  * serv_imap.c: improve SELECT time by fetching the msglist directly out of
8    the database instead of doing a CtdlForEachMessage() loop.
9
10  Revision 647.18  2005/05/22 16:12:25  ajc
11  * Full text indexer is now switchable on/off
12
13  Revision 647.17  2005/05/20 20:02:50  ajc
14  * The IGnet map is now rewritten to disk only when it changes.
15  * When processing inbound network spool, ignore "." and ".." instead of
16    failing on them.
17
18  Revision 647.16  2005/05/20 16:22:33  ajc
19  Fixed some errors in the ChangeLog
20
21  Revision 647.15  2005/05/20 16:14:43  ajc
22  * Dramatically improved the time it takes to goto (or select) a room which
23    contains a very long and complex seen/unseen list.  Our test folder,
24    containing 359 new of 3162 messages, formerly took 22 seconds to select;
25    now it takes 1 to 2 seconds.
26
27  Revision 647.14  2005/05/20 02:37:17  ajc
28  * Performance-optimized the full text indexer.
29
30  Revision 647.13  2005/05/20 01:20:24  ajc
31  * Cull logs immediately after a successful db checkpoint instead of only
32    once every 24 hours.  During big db write operations (such as building
33    the full text index) they were just piling up too much.
34
35  Revision 647.12  2005/05/19 21:10:03  ajc
36  * Altered the full text indexer to output messages as text before running
37    through the wordbreaker.  This prevents the inclusion of encoded base64
38    strings in the index, and also allows legitimate text encoded inside
39    base64 to be decoded and then indexed.
40
41  Revision 647.11  2005/05/19 03:42:29  ajc
42  * Bound the full text index to IMAP search
43
44  Revision 647.10  2005/05/18 22:09:01  ajc
45  * Finished the indexer *and* deindexer!  The search API is now working
46    flawlessly too.  Now all we have to do is glue it to IMAP and other
47    user-facing functionality.  (The SRCH command is for testing only.)
48
49  Revision 647.9  2005/05/18 04:02:54  ajc
50  * Completed the "search for all of these words" functionality.  All we need
51    to do now is generalize its calling syntax so it can be called from the
52    IMAP service.
53
54  Revision 647.8  2005/05/18 03:22:27  ajc
55  * Finished the indexer and the first part of the search function...
56
57  Revision 647.7  2005/05/17 20:36:48  ajc
58  * Indexer is completed; also began work on the search function itself.
59    Still need to add de-indexing so deleted messages are removed from index.
60
61  Revision 647.6  2005/05/17 16:25:23  ajc
62  * Completed the wordbreaker for the full text indexer.
63
64  Revision 647.5  2005/05/17 04:04:46  ajc
65  * Began some glue code for the full text indexer.
66
67  Revision 647.4  2005/05/16 20:03:33  ajc
68  * definition of struct CitControl moved from citadel.h to server.h
69
70  Revision 647.3  2005/05/16 18:48:45  ajc
71  * Don't prompt the user for screen dimensions anymore.  Nobody is using
72    dialup terminals with arbitrary screen sizes anymore; nearly everyone (or
73    more likely, *absolutely* everyone) is now using networked displays which
74    can be automatically queried for their screen dimensions.  For now, we'll
75    keep the screen size properties in the database and in the protocol, but
76    the prompts have been commented out.
77
78  Revision 647.2  2005/05/16 18:25:56  ajc
79  * Avoid re-creating the default-named baseroom (Lobby) upon subsequent
80    startups after it's been renamed to something else.
81
82  Revision 647.1  2005/05/16 16:59:39  ajc
83  * Default expire policy is now 'manual' (no automatic expiry of messages
84    under any circumstances).  Implemented as per David Given's suggestion
85    that we should operate using the element of least surprise.
86
87  Revision 647.0  2005/05/12 16:54:10  ajc
88  * THIS IS 6.47
89
90  Revision 646.1  2005/05/12 16:53:18  ajc
91  * Fixed a minor bug discovered in SMTP at one site
92
93  Revision 646.0  2005/05/11 17:06:04  ajc
94  * THIS IS 6.46
95
96  Revision 645.20  2005/05/09 22:17:30  ajc
97  * Interactive room deletions are now deferred.  The server reconfigures the
98    room to be a mailbox owned by a nonexistent user and immediately returns
99    control back to the client.  Later, THE DREADED AUTO-PURGER will see the
100    dangling room and erase its contents.
101
102  Revision 645.19  2005/05/08 03:43:22  ajc
103  * Set the internal version number to 6.46 in preparation for a release
104
105  Revision 645.18  2005/05/02 20:52:42  ajc
106  * More IMAP optimizations, including the application of our latest "don't
107    fetch the message body" trick to ENVELOPE and INTERNALDATE fetches, to
108    make MS-Outbreak spread email viruses faster.
109
110  Revision 645.17  2005/05/02 16:09:52  ajc
111  * serv_imap.c: implemented the RFC 3501 suggestion that the initial
112    greeting, and the response to the LOGIN command, include an output
113    of the server's CAPABILITY string.  I find this to be gratuitous but
114    the UW IMAP server does it, so we are also doing it in order to better
115    interoperate with clients which make assumptions...
116
117  Revision 645.16  2005/04/29 22:02:20  ajc
118  * More IMAP tuning
119
120  Revision 645.15  2005/04/29 20:47:45  ajc
121  * More complex cache handling for IMAP fetch operations -- now we can
122    fetch/cache "just the headers" and remember whether we did so, so we can
123    burn the cache if the client then comes around and requests something
124    that requires the body.  Still needs some testing and tuning.
125
126  Revision 645.14  2005/04/29 16:50:03  ajc
127  * Significantly reduced the memory footprint of struct CitContext.
128
129  Revision 645.13  2005/04/29 16:26:00  ajc
130  * Removed the CtdlRedirectOutput() API, as we are no longer using it.
131    (Oh happy day; no more temp files!)
132
133  Revision 645.12  2005/04/27 19:22:57  ajc
134  * .ASG command: made better use of memory to avoid crashes
135
136  Revision 645.11  2005/04/23 04:38:26  ajc
137  * Substantially improved the appearance of mailing list digests.
138    Superfluous RFC822 headers no longer appear, and all messages are
139    converted to plain text using the preferred_formats framework.
140  * CtdlOutputPreLoadedMsg() -- fixed bug that caused Citadel protocol
141    headers to appear for MIME prefix, suffix, etc. even when do_proto is 0.
142
143  Revision 645.10  2005/04/23 02:04:11  ajc
144  * serv_imap.c: don't respond "OK DELETE completed" until after the room
145    delete operation actually completes.
146
147  Revision 645.9  2005/04/23 01:59:58  ajc
148  * Big performance optimization on CtdlSetSeen()
149
150  Revision 645.8  2005/04/22 04:26:34  ajc
151  * is_msg_is_mset() has been renamed to is_msg_in_sequence_set() because
152    "sequence set" is now the official terminology as of RFC3501.
153  * imap_set_seen_flags() no longer calls is_msg_in_sequence_set() for each
154    message and for each flag.  It's just too expensive.  We now parse each
155    flag's sequence set manually, marking the relevant messages as we go.
156
157  Revision 645.7  2005/04/22 00:52:03  ajc
158  * small fix to previous commit
159
160  Revision 645.6  2005/04/21 17:28:51  ajc
161  * msgbase.c: when committing a new message to the store, save its RFC822
162    length to the metadata record immediately.  This will eliminate the need
163    to calculate it later during a fetch operation.
164
165  Revision 645.5  2005/04/14 15:53:55  ajc
166  * Variable names, comments, documentation, etc...  removed the acronym 'BBS'
167    in places where functionality is not specific to the use of Citadel as
168    a BBS platform.
169
170  Revision 645.4  2005/04/13 20:42:44  ajc
171  * citmail.c: changes to citmail to make it usable as a /usr/sbin/sendmail
172    replacement; i.e. /bin/mail calls /usr/sbin/sendmail which sends mail
173    through Citadel.
174
175  Revision 645.3  2005/04/13 17:03:07  ajc
176  * Reverted database changes because the cull_logs function wasn't working
177    with the separate log directory.
178  * citmail.c: started some fixes to make it able to work from
179
180  Revision 645.2  2005/04/12 21:19:52  ajc
181  * 'make install' now installs citadel-openldap.schema
182
183  Revision 645.1  2005/04/11 16:31:57  ajc
184  * Database logs are now kept in the "data_logs" directory instead of in
185    the "data" directory.  If no "data_logs" directory is found, a symlink
186    to "data" will be created, in order to preserve access to any existing
187    log files -- a savvy sysadmin (or a storage management wizard script)
188    will know what to do if a different location is desirable.
189
190  Revision 645.0  2005/04/01 03:02:44  ajc
191  * THIS IS 6.45
192
193  Revision 641.34  2005/03/31 04:31:42  ajc
194  * Bumped the internal version number to 6.45 in preparation for
195    an upcoming release.
196
197  Revision 641.33  2005/03/24 22:52:40  ajc
198  * More extermination of the dreaded SIZ moby-buffers.
199
200  Revision 641.32  2005/03/24 22:13:56  ajc
201  * extract_token() now expects to be supplied with the size of the
202    destination string buffer.  This, along with the elimination of other
203    unbounded functions like strcpy(), will allow the removal of the
204    "all string buffers are of size SIZ" assumption (a process which I have
205    already begun), which will hopefully reduce stack consumption.
206
207  Revision 641.31  2005/03/22 21:53:48  ajc
208  * Oops, forgot to initialize some data structures...
209
210  Revision 641.30  2005/03/22 16:49:29  ajc
211  * Fixed a couple of memory allocation bugs
212
213  Revision 641.29  2005/03/20 22:55:58  ajc
214  * Logging to stderr no longer uses syslog()
215  * Reworked the way dead sessions are purged.  More efficient and more
216    reliable now.
217
218  Revision 641.28  2005/03/18 21:40:36  ajc
219  * Minor bugfix to previous checkin
220
221  Revision 641.27  2005/03/18 21:25:06  ajc
222  * Finished removing all the "dynamic session data" stuff in order to
223    boost reliability, improve performance, and reduce complexity.
224
225  Revision 641.26  2005/03/12 05:42:35  ajc
226  * Trying to fix a memory bug somewhere.
227  * While working on the above, noticed that the way we did the per-session
228    dynamic symbols loses badly in terms of performance.  Began moving to
229    a less modular but better performing way of doing the same.
230
231  Revision 641.25  2005/03/10 03:36:25  ajc
232  * Silenced a compiler warning
233  * Our graceful cleanup handler no longer gracefully cleans up after
234    receiving SIGSEGV or its friends.  Unfortunately we need the core dump.
235
236  Revision 641.24  2005/03/10 03:11:07  ajc
237  * Altered the algorithm by which the doubly-linked session list is
238    amended and culled.  Decided that performance is better than cute
239    session numbers (which we don't display to the users anymore anyway)
240    and we now assign a session number (CC->cs_pid) starting with 1 when the
241    server starts and incrementing indefinitely.  Need to test this more.
242
243  Revision 641.23  2005/03/07 04:08:07  ajc
244  * vcard.c: realloc fix
245
246  Revision 641.22  2005/03/05 22:31:01  ajc
247  * Allow the use of chained certificates for crypto
248
249  Revision 641.21  2005/03/04 20:04:00  ajc
250  * IMAP FETCH RFC822.SIZE now honors the cached rfc822 size in each
251    message's metadata, using it if present and storing it for next time
252    otherwise.
253  * Fixed bug in POP3 server that was causing it to fail to store the
254    correct RFC822 size in metadata.  Fortunately it was failing in a way
255    that merely affected performance rather than corrupting the data on
256    existing installations.
257
258  Revision 641.20  2005/03/04 02:24:31  ajc
259  * SMTP: only offer TLS on the MSA port (587), not on the MTA port (25).
260    There seem to be some other MTA's out there that make things go haywire
261    when TLS is offered.
262
263  Revision 641.19  2005/03/04 02:18:46  ajc
264  * config.c: default setting for "maxmsglen" is now 10 megabytes, not INT_MAX
265
266  Revision 641.18  2005/03/03 18:10:27  ajc
267  * sysdep.c: change the algorithm for dynamically expanding the redirect
268    buffer's size.  Large writes were overflowing it.
269
270  Revision 641.17  2005/03/03 17:56:53  ajc
271  * Finished removing the use of temp files in IMAP.
272    WARNING: DON'T USE THIS ON A PRODUCTION SYSTEM, IT HAS NOT BEEN
273    FULLY TESTED WITH VARIOUS IMAP CLIENTS YET!
274
275  Revision 641.16  2005/03/03 05:14:06  ajc
276  * Realized that memreadline() does NOT return a NULL pointer when it hits
277    a null character, and adjusted all the code I wrote yesterday under that
278    assumption.
279  * Removed the use of a temp file for IMAP FETCH BODYSTRUCTURE on a
280    non-RFC822 message.
281
282  Revision 641.15  2005/03/02 17:33:03  ajc
283  * msgbase.c: fixed a buffer overflow error
284  * imap_fetch.c, serv_imap.c, serv_imap.h: migrated imap_fetch_rfc822() to
285    use the new in-memory message buffering.  BODY comes next...
286
287  Revision 641.14  2005/03/02 03:35:18  ajc
288  * serv_smtp.c: removed use of temporary file for SMTP transmission
289
290  Revision 641.13  2005/03/02 03:01:18  ajc
291  * serv_spam.c: use redirect_buffer instead of redirect_sock
292  * Removed redirect_sock from the API.  redirect_fp is next!
293
294  Revision 641.12  2005/03/02 02:42:06  ajc
295  * Finished moving the POP3 server to the new redirect_buffer semantics
296
297  Revision 641.11  2005/03/02 02:16:10  ajc
298  * Toned down some of the hostility in the code's comments :)
299
300  Revision 641.10  2005/03/01 22:03:35  ajc
301  * Began implementation of a third RedirectOutput mode -- one which writes
302    to a memory buffer.  This will replace the other two.
303  * serv_pop3.c: began migration to the new redirect mode.
304
305  Revision 641.9  2005/03/01 04:24:52  ajc
306  * When saving an RFC822 message, use a less expensive algorithm to
307    search for the Content Type
308
309  Revision 641.8  2005/02/28 20:32:50  ajc
310  * IMAP APPEND command now accepts the message text using one big
311    client_read() call instead of a bunch of smaller ones.
312
313  Revision 641.7  2005/02/28 02:25:29  ajc
314  * added pid file writing
315
316  Revision 641.6  2005/02/27 15:36:28  ajc
317  * database_cleanup.sh: look for /usr/local/ctdlsupport/bin/db_dump and
318    prepend that directory to the PATH if found.
319  * database_cleanup.sh: add more warnings about how dangerous this tool is
320
321  Revision 641.5  2005/02/26 16:27:54  ajc
322  * setup.c: added "hula" to the list of non-Citadel MTA's which can be
323    disabled during setup.
324
325  Revision 641.4  2005/02/25 17:59:12  ajc
326  * Ok, now we accept *all* the flags transmitted during an IMAP APPEND, not
327    just the first one.
328
329  Revision 641.3  2005/02/25 05:51:52  ajc
330  * Started working on a fix for the IMAP APPEND "flags" thing.  It works
331    but only for the first flag sent.  Will finish tomorrow.
332
333  Revision 641.2  2005/02/24 18:14:24  ajc
334  * Removed excessive trace messages that were slowing the server down
335  * Prepared for handling of setting flags in IMAP APPEND
336
337  Revision 641.1  2005/02/23 04:24:57  ajc
338  * When auto-creating Mail>, Sent Items>, etc... set view to VIEW_MAILBOX
339
340  Revision 641.0  2005/02/21 21:59:33  ajc
341  * THIS IS 6.41
342
343  Revision 640.14  2005/02/21 21:40:28  ajc
344  * Updated internal version number to 6.41
345
346  Revision 640.13  2005/02/20 21:10:59  ajc
347  * Repaired access control problem in IMAP SUBSCRIBE
348
349  Revision 640.12  2005/02/17 16:13:59  ajc
350  * Removed "Log Hooks."  This enabled the removal of a buf[SIZ] in lprintf,
351    where it can potentially blow lots of stacks.
352
353  Revision 640.11  2005/02/17 03:52:16  ajc
354  * setup.c: clarify some of the messages
355
356  Revision 640.10  2005/02/16 19:03:38  ajc
357  * master_cleanup() now passes along an exit code from its caller to the OS.
358
359  Revision 640.9  2005/02/16 18:48:39  ajc
360  * Try to reach our cleanup routine when SIGSEGV is caught.  Hopefully
361    we'll get there and we can close the databases cleanly.
362
363  Revision 640.8  2005/02/16 17:37:16  ajc
364  * Be more aggressive about shutting down when told to.  Getting the
365    databases closed is the highest priority.
366
367  Revision 640.7  2005/02/16 04:08:42  ajc
368  * newinstall.sh: put the checksum files server-side to avoid
369    unnecessary downloads
370
371  Revision 640.6  2005/02/16 03:02:28  ajc
372  * Applied patches submitted by Kevin Kilbride for TCP_CORK and for
373    turning CitContext into a doubly-linked list.
374
375  Revision 640.5  2005/02/13 04:55:18  ajc
376  * Did the server port hooks etc. for SSL listeners.  For some reason it
377    doesn't work.  :(
378
379  Revision 640.4  2005/02/13 04:23:59  ajc
380  * Added server and client configuration settings to specify port
381    numbers for IMAPS, POP3S, and SMTPS (SSL-encrypted services that start
382    SSL upon connect instead of using a STARTTLS command).  These services
383    are not yet implemented, only the port number settings are.
384
385  Revision 640.3  2005/02/13 03:39:21  ajc
386  * IMAP flag twiddling with STORE was broken because of the \Flag leading
387    backslash getting stripped out.  Located problem and worked around.  Said
388    many nasty things about IMAP's gratuitous complexity, particularly the
389    moronic idea to put backslashes in a place where they were completely
390    unnecessary.
391
392  Revision 640.2  2005/02/12 16:58:36  ajc
393  * Changes to lprintf() and start_daemon() submitted by Kevin Kilbride
394    for more "true unix" approaches to each.
395
396  Revision 640.1  2005/02/11 03:51:51  ajc
397  * <.A>ide <U>ser-edit is now <.A>ide <U>ser <E>dit
398  * Added a new <.A>ide <U>ser <D>elete command, because it is unintuitive
399    to tell people "delete a user by setting their access level to 0"
400
401  Revision 640.0  2005/02/10 16:52:18  ajc
402  * THIS IS 6.40
403
404  Revision 630.16  2005/02/10 16:52:03  ajc
405  * Updated documentation etc. for 6.40 release (and for 2005 copyright)
406
407  Revision 630.15  2005/02/08 03:33:49  ajc
408  * client_gets(char *buf) has been replaced by
409    client_getln(char *buf, int maxbytes)
410
411  Revision 630.14  2005/02/05 22:56:31  ajc
412  * More reliable handling of conversion of vCard UID to Citadel Extended ID
413    (necessary for GroupDAV URL's to be generated properly in WebCit)
414
415  Revision 630.13  2005/02/05 04:13:34  ajc
416  * msgbase.c: replication checks for Exclusive-ID no longer cause a save
417    operation to fail when the existing message is newer.  This was causing
418    groupware clients to go haywire because of datestamps being set to
419    event start times, etc.
420
421  Revision 630.12  2005/02/03 04:36:56  ajc
422  * serv_calendar.c: beforesave hook now looks for the UID inside nested
423    VTODO components, in addition to VCALENDAR components.
424
425  Revision 630.11  2005/02/01 23:11:46  ajc
426  * new ENT0 syntax now also outputs EUID
427
428  Revision 630.10  2005/02/01 19:46:12  ajc
429  * Added an SMTP-like calling syntax to ENT0 to allow a confirmation message
430    to be sent back to the client after a message is transmitted.
431
432  Revision 630.9  2005/02/01 03:33:22  ajc
433  * Changed CtdlRoomAccess() calling syntax in order to return both
434    the access bits and the current view
435  * All "list rooms" commands now return the view for each room.
436
437  Revision 630.8  2005/01/27 22:05:21  ajc
438  * Renamed the "Extended message ID" field to "Exclusive message ID"
439    (nothing changes except documentation and internal variable names)
440
441  Revision 630.7  2005/01/27 21:59:22  ajc
442  * serv_vcard.c: changed the logic a bit.  When saving a vCard to a user's
443    "My Citadel Config" room, force-feed the vCard a site-compliant UID and
444    FBURL.  When saving a vCard to *any* address book room, set the Citadel
445    EUID to the vCard UID.
446
447  Revision 630.6  2005/01/27 17:33:52  ajc
448  * The before-save hook in serv_calendar.c now runs for any room with a
449    view of VIEW_CALENDAR or VIEW_TASKS, not just Calendar> and Tasks>.
450
451  Revision 630.5  2005/01/26 23:04:22  ajc
452  * When saving calendar items, if the vCalendar object does not contain
453    a UUID, generate one on the fly.  In order to support GroupDAV we need
454    persistent URL's, and I plan to base those on the UUID.
455
456  Revision 630.4  2005/01/25 20:58:07  ajc
457  * serv_pop3.c: minor change to logging output
458
459  Revision 630.3  2005/01/25 15:02:12  error
460  * Updated SSL/TLS code to actually use the TLS cipher suites
461
462  Revision 630.2  2005/01/22 04:15:32  ajc
463  * Increased per-thread stack size again, this time to 1MB
464
465  Revision 630.1  2005/01/22 03:14:20  ajc
466  * Each message's metadata now has the ability to cache the length of
467    the message when output in RFC822 format.  The POP3 service populates
468    this field the first time it sees each message, and fetches the length
469    from cache on subsequent visits.
470  * Because of this optimization, we no longer need to keep the entire POP3
471    mailbox stored in open temp files during a session.  Each message is
472    opened again when it is fetched.
473
474  Revision 630.0  2005/01/21 20:25:08  ajc
475  * THIS IS 6.30
476
477  Revision 629.10  2005/01/21 20:24:34  ajc
478  * Internal version number is now 6.30
479
480  Revision 629.9  2005/01/21 20:20:06  ajc
481  * Increase per-thread stack size from 128k to 256k.  This fixes the
482    crashing IMAP service on 64-bit Linux.
483
484  Revision 629.8  2005/01/19 20:49:46  ajc
485  * Minor fixenbugs after running with Valgrind
486
487  Revision 629.7  2005/01/19 03:03:36  ajc
488  * Minor and/or cosmetic changes made during x64 troubleshooting
489
490  Revision 629.6  2005/01/18 17:58:38  ajc
491  * Trying to fix IMAP brokenness on Linux-x64.  Committing changes even
492    though there are a lot of annoying trace messages in this tree, because
493    I did clean up a bunch of stuff here and there.
494
495  Revision 629.5  2005/01/14 17:08:30  ajc
496  * Applied a configure script fix sent in by David Given for more reliable
497    detection of the installed libical version.
498
499  Revision 629.4  2005/01/13 05:43:16  ajc
500  * Initial support for having a room participate in a remote mailing list
501
502  Revision 629.3  2005/01/09 03:20:41  ajc
503  * Applied a patch sent in by David Given for handling of the "&" character
504    plus Unicode characters in IMAP folder names.
505
506  Revision 629.2  2005/01/07 15:56:14  ajc
507  * msgbase.c: fixed an incorrect variable name in the bigmsg-handler
508
509  Revision 629.1  2005/01/07 03:05:04  ajc
510  * serv_imap.c: fail with a "BAD" error response if the LOGIN command is
511    called with the wrong number of parameters (otherwise it goes boom)
512  * user_ops.c: CtdlLoginExistingUser() was calling strproc() on the supplied
513    name, which killed the ability to log in with your email address (because
514    it stripped the @ symbol).  Changed it to striplt() instead.
515
516  Revision 629.0  2005/01/04 03:57:32  ajc
517  * THIS IS 6.29
518
519  Revision 628.2  2005/01/04 03:57:21  ajc
520  * newinstall.sh: save tarball checksums after successful install of each
521    component; skip subsequent installs for components which have not changed
522  * Bumped internal version number to 6.29
523
524  Revision 628.1  2005/01/04 02:06:28  ajc
525  * sysdep.c: if we have enough information to do so, adjust maximum file
526    descriptors to avoid exceeding FD_SETSIZE.  This is done to circumvent
527    a rare but specific vulnerability.
528
529  Revision 628.0  2004/12/14 03:16:19  ajc
530  * THIS IS 6.28
531
532  Revision 627.12  2004/12/12 17:33:24  error
533  * sysdep.c: lprintf(): Bug 124: Fix remote format string vulnerability
534    (thanks to coki@nosystem.com.ar)
535
536  Revision 627.11  2004/12/01 16:28:58  ajc
537  * tools.c: don't crash when striplt() is called with z zero length string
538
539  Revision 627.10  2004/11/26 22:44:08  ajc
540  * Added a sooper-seekrit way to spool network messages to a remote node
541    where the room has a different name
542  * Internal version number is now 6.28, so that WebCit doesn't b0rk the
543    netconfigs of older Citadel servers
544
545  Revision 627.9  2004/11/19 02:31:56  ajc
546  * Added developer ID # 177
547
548  Revision 627.8  2004/11/16 23:04:18  ajc
549  * setup.c: added "dovecot" to the list of "other email services" which
550    the setup program can helpfully disable for you.  :)
551
552  Revision 627.7  2004/11/12 03:51:42  ajc
553  * serv_expire.c: auto-purge any user whose user number is less than 1.
554
555  Revision 627.6  2004/11/11 16:21:12  nbryant
556  * database_sleepycat.c: make cdb_rewind enforce that cursors must be
557    closed before they can be opened again. (prevents cursors being held
558    open for longer than they should be and holding database locks.)
559
560  Revision 627.5  2004/11/11 14:56:16  ajc
561  * Further adjustments to ldap setup
562
563  Revision 627.4  2004/11/11 04:38:36  ajc
564  * setup.c: fix bug that kept creating new inittab entries for slapd
565
566  Revision 627.3  2004/11/10 21:33:47  ajc
567  * Go to Berkeley DB 4.3.21 in Easy Install
568
569  Revision 627.2  2004/11/10 19:59:23  nbryant
570   * configure.ac: detect /usr/local/BerkeleyDB.4.3
571
572  Revision 627.1  2004/11/10 03:03:14  ajc
573  * Added a few wonderful linebreaks to >80 column lines
574
575  Revision 627.0  2004/11/03 20:18:58  ajc
576  * THIS IS 6.27
577
578  Revision 626.18  2004/11/03 20:18:46  ajc
579  * Internal version number is now 6.27
580
581  Revision 626.17  2004/11/02 22:59:20  ajc
582  * setup.c: fixed an incorrect variable name that was causing inittab
583    twiddling to malfunction.
584
585  Revision 626.16  2004/11/02 02:47:10  ajc
586  * Easy Install: put the log directly in /tmp instead of in the build
587    directory so it doesn't get deleted on a failed install.
588
589  Revision 626.15  2004/10/23 14:33:44  ajc
590  * serv_notes.c: finished.  When saving a message in a room whose view
591    is set to "notes," look for an X-KOrg-Note-Id: header, and if one is
592    present, set both the Extended ID and the Subject to that.  This is for
593    Aethera compatibility.
594
595  Revision 626.14  2004/10/22 14:49:25  ajc
596  * newinstall.sh: Be more careful about locating make/gmake on the host
597    system.  Also now tries to use curl if wget is not available.
598
599  Revision 626.13  2004/10/22 02:53:25  ajc
600  * serv_notes.c: added skeleton module
601  * serv_newuser.c: corrected internal comment
602  * techdoc: renamed session.txt to protocol.txt because it really isn't
603    a session layer protocol, it's more of an application layer protocol.
604
605  Revision 626.12  2004/10/13 02:11:00  ajc
606  * Repaired a completely broken <;Z>ap floor command.
607
608  Revision 626.11  2004/10/12 11:24:42  ajc
609  * Tracing a problem with ;Z command
610
611  Revision 626.10  2004/10/12 02:48:11  ajc
612  * Reworked shutdown sequence to avoid thread deadlock
613
614  Revision 626.9  2004/10/12 02:17:49  ajc
615  * Cleaned up some things that generated compiler warnings
616  * crypto keys directory is now relative to the server's working directory,
617    not to the compiled-in CTDLDIR
618  * Re-ordered the security checks in CtdlAccessCheck()
619
620  Revision 626.8  2004/10/06 21:23:21  error
621  * Fixup a few more compiler warnings from icc
622
623  Revision 626.7  2004/10/05 01:44:20  ajc
624  * Changed a bunch of localtime() calls to localtime_r(), for great justice.
625
626  Revision 626.6  2004/10/04 21:40:29  error
627  * configure.ac: Add CFLAGS for icc Intel Compiler
628
629  Revision 626.5  2004/10/04 21:39:35  error
630  * Fix a couple of minor compiler warnings
631
632  Revision 626.4  2004/10/03 04:25:23  ajc
633  * Removed some vestiges
634
635  Revision 626.3  2004/10/03 04:11:48  ajc
636  * sysdep.c: in the main server loop, when time_to_die is detected, return
637    immediately instead of falling through to the end of the function.
638
639  Revision 626.2  2004/10/03 03:57:32  ajc
640  * Added pthread_attr_destroy() in the appropriate location (thanks fleeb!)
641
642  Revision 626.1  2004/10/01 15:58:08  ajc
643  * Configure "notes" view and auto-create Notes> room
644
645  Revision 626.0  2004/09/28 16:11:16  ajc
646  * THIS IS 6.26
647
648  Revision 625.33  2004/09/28 16:09:58  ajc
649  * Update documentation and config files for 6.26 release
650
651  Revision 625.32  2004/09/28 02:18:12  ajc
652  * Improve output of RECENT flag in IMAP
653
654  Revision 625.31  2004/09/23 03:02:31  ajc
655  * MyContext() no longer declared INLINE
656
657  Revision 625.30  2004/09/23 02:54:46  ajc
658  * in MyContext(), reduced the number of calls to pthread_getspecific()
659    from two to one
660
661  Revision 625.29  2004/09/23 00:22:18  error
662  * rooms.c: create_floor(): Fix the check for whether a floor name was given
663
664  Revision 625.28  2004/09/21 02:09:30  ajc
665  * Tweaks to above
666
667  Revision 625.27  2004/09/21 01:43:23  ajc
668  * imap_search.c: when search criteria permit, do not fetch messages.
669
670  Revision 625.26  2004/09/17 16:54:13  ajc
671  * Updated documentation to include information about setting up MSA 587 port.
672
673  Revision 625.25  2004/09/17 04:14:18  ajc
674  * serv_network.c: added a missing \n in log output
675
676  Revision 625.24  2004/09/17 03:54:47  ajc
677  * citadel-openldap.schema: replaced.  Dunno why it was missing.
678  * serv_calendar.c: fixed a return with no value for a function returning
679    int; this was causing a before-save hook to abandon messages
680
681  Revision 625.23  2004/09/16 01:46:40  ajc
682  * CRE8 command: allow setting default view during room creation
683
684  Revision 625.22  2004/09/15 03:02:47  ajc
685  * Add an SMTP MSA listener (separate port, requires auth)
686
687  Revision 625.21  2004/09/13 15:51:59  ajc
688  * newinstall.sh: updated from the working version at easyinstall.citadel.org
689
690  Revision 625.20  2004/09/11 03:13:04  error
691  * Remove calls to the broken flush_output() while I try to figure out what's
692    wrong with it.  Replaced with unbuffer_output() which does work.
693
694  Revision 625.19  2004/09/10 02:54:26  ajc
695  * Added flush_output() calls to IMAP modules.  (Do we need them?  Are we
696    buffering IMAP output?  Should we?)
697
698  Revision 625.18  2004/09/09 02:26:45  ajc
699  * Completed (I think) the 'dialog' mode in setup
700
701  Revision 625.17  2004/09/08 04:16:07  ajc
702  * setup.c: initial changes to use a 'dialog' based setup (yes, it's back,
703    because the b0rken version is now long gone and it appears to be more
704    portable than newt)
705
706  Revision 625.16  2004/09/07 04:15:35  error
707  * msgbase.c: cmd_msgs(): Call unbuffer_output() when a message list is
708    requested using a search template.
709
710  Revision 625.15  2004/09/06 01:11:35  error
711  * msgbase.c: cmd_ent0(): Fix another unbuffer_output()
712
713  Revision 625.14  2004/09/06 00:59:01  error
714  * file_ops.c: cmd_writ(): Add an unbuffer_output() that I forgot.
715
716  Revision 625.13  2004/09/05 17:39:09  error
717  * Buffered output needs to be flushed in several places.  Added calls to
718    flush_output().  (basically anywhere where we send a response and then
719    wait for the client, except chat, where we turned it off entirely)
720
721  Revision 625.12  2004/09/05 15:41:45  error
722  * Network optimizations - buffer output server-side for better network
723    utilization; one client-side optimization
724
725  Revision 625.11  2004/09/05 15:20:41  error
726  * sysdep.c: unbuffer_output(): Split the writing part to a new function
727    flush_output() for more precise control
728
729  Revision 625.10  2004/09/03 04:34:30  ajc
730  * setup.c: when creating an inittab entry for slapd, use "-d 0" instead
731    of "-d 1" to avoid spewing messages to the console, while still remaining
732    in the foreground.
733
734  Revision 625.9  2004/09/03 04:19:17  ajc
735  * setup.c: Changes to inittab-twiddling to make it a bit more reliable
736  * ipc_c_tcp.c: don't send SIGHUP to children; it makes them very angry
737
738  Revision 625.8  2004/09/01 15:34:52  ajc
739  * serv_smtp.c: fix build error on hosts with no SSL support
740
741  Revision 625.7  2004/08/31 17:31:55  ajc
742  * Calendar: store UUID+comment instead of comment as Subject (this was done
743    at the request of Eugen Constantinescu for Aethera optimizations)
744
745  Revision 625.6  2004/08/30 02:45:33  ajc
746  * setup.c: when running in Newt mode, make the size of the dialogs dynamic
747    to the size of the text in them.
748
749  Revision 625.5  2004/08/29 15:18:41  error
750  * newinstall.sh: fix detection of gmake/make
751
752  Revision 625.4  2004/08/28 14:21:25  error
753  * Change the logging level of some messages and add a couple of new ones to
754    show when a network node is connecting.
755
756  Revision 625.3  2004/08/28 02:42:44  ajc
757  * setup.c: when run from the Easy Install script, auto-configure slapd
758    and put it into /etc/inittab
759
760  Revision 625.2  2004/08/28 01:56:38  ajc
761  * Generalize some of the inittab-tweaking stuff so that we can use it
762    for slapd, too.
763
764  Revision 625.1  2004/08/27 21:39:33  ajc
765  * Fleshed out contemplate_ldap() a bit
766
767  Revision 625.0  2004/08/27 21:06:30  ajc
768  * THIS IS 6.25
769
770  Revision 624.8  2004/08/27 20:16:51  ajc
771  * Update internal version number to 6.25
772
773  Revision 624.7  2004/08/26 04:13:55  ajc
774  * newinstall.sh: updated with some new goodies
775  * setup.c: when run from Easy Install, offer to set up LDAP.  (Not finished.)
776
777  Revision 624.6  2004/08/23 21:41:26  error
778  * html.c: Try to something sane with lists
779
780  Revision 624.5  2004/08/23 21:40:04  error
781  * No longer accept MD5 as a hash when encrypting
782
783  Revision 624.4  2004/08/23 21:34:28  error
784  * serv_network.c: Suppress Invalid node name for "." and ".."
785
786  Revision 624.3  2004/08/16 04:19:14  ajc
787  * newinstall.sh: more intelligent auto-run of setup programs
788  * setup.c: change inittab question to be more newbie-friendly
789
790  Revision 624.2  2004/08/15 05:04:36  ajc
791  * newinstall.sh: various tweaks to make it more reliable
792
793  Revision 624.1  2004/08/14 03:59:43  ajc
794  * newinstall.sh: shuffled around the environment variables to prevent
795    "C compiler cannot generate executables" error.
796
797  Revision 624.0  2004/08/12 13:47:47  ajc
798  * THIS IS 6.24
799
800  Revision 623.16  2004/08/11 04:09:14  ajc
801  * Replaced all "Citadel/UX" references with "Citadel"
802
803  Revision 623.15  2004/08/05 03:19:48  ajc
804  * html.c: handle the <BLOCKQUOTE> tag properly
805
806  Revision 623.14  2004/08/05 02:02:33  ajc
807  * CtdlHostAlias() now accepts "localhost" as a localhost address.
808  * working_ignetcfg is now loaded during incoming NETP commands, which
809  should theoretically take care of the missing config problem.
810
811  Revision 623.13  2004/08/02 02:51:03  ajc
812  * utilsmenu: removed.  Because most of the admin functions have been moved
813    into Citadel proper, what's left of this menu is now pathetic.
814  * techdoc/build.txt: removed verbage that referred to the old build system.
815
816  Revision 623.12  2004/07/30 03:18:21  ajc
817  * user_ops.c: limit the length of the name which can be supplied
818    to CtdlLoginExistingUser() to avoid crashing it.
819
820  Revision 623.11  2004/07/28 04:09:58  ajc
821  * serv_network.c: we had ignetcfg and working_ignetcfg, but it turns out we
822    no longer use the former anywhere, so it has been removed (along with the
823    aftersave hook that detected changes)
824
825  Revision 623.10  2004/07/25 16:20:04  error
826  * msgbase.c: CtdlCheckInternetMailPermission(): Do not allow twits to send
827    Internet mail (they shouldn't be sending ANYTHING at all)
828
829  Revision 623.9  2004/07/25 16:18:43  error
830  * citadel.spec: update version number
831
832  Revision 623.8  2004/07/25 16:17:37  error
833  * stress.c:  Slightly more verbose output
834
835  Revision 623.7  2004/07/25 16:16:19  error
836  * citadel_decls.h: fixed the new logoff() macro
837
838  Revision 623.6  2004/07/24 05:11:52  ajc
839  * citadel.c: temporarily commented out the signal() call for SIGHUP because
840    it is causing the client not to work at all on Linux 2.6 (or at least on
841    Fedora Core 2) when citadel is called as the login shell -- a SIGHUP is
842    mysteriously received at the username prompt and the program exits.
843
844  Revision 623.5  2004/07/15 02:54:49  ajc
845  * serv_network.c: grab and use a networker-local copy of the network
846    configuration, ensuring that it doesn't accidentally get clobbered while
847    the network is running.
848
849  Revision 623.4  2004/07/11 18:41:39  ajc
850  * Updated roadmap document slightly
851
852  Revision 623.3  2004/07/11 03:59:02  ajc
853  serv_network.c: small fix to above
854
855  Revision 623.2  2004/07/11 03:50:31  ajc
856  * serv_network.c: removed a stray end_critical_section()
857  * serv_network.c: purge invalid ignet_push_share entries during
858    netconfig load instead of during rewrite
859
860  Revision 623.1  2004/07/10 02:51:01  ajc
861  * Changed "policy set" message to "policy has been updated" to make it
862    clearer.
863
864  Revision 623.0  2004/07/06 18:15:04  ajc
865  * THIS IS 6.23
866
867  Revision 622.7  2004/07/06 18:09:13  ajc
868  * When writing a message body to the CDB_BIGMSGS table instead of the main
869    message base, increase data length by one byte in order to include the
870    NULL terminator.  (Doh!)
871
872  Revision 622.6  2004/07/03 04:09:37  ajc
873  * Check the "Permission to send Internet mail" access controls when
874    messages are submitted via Authenticated SMTP.
875
876  Revision 622.5  2004/06/28 17:09:20  ajc
877  * Properly re-terminate messages posted via IMAP APPEND.  The newline
878    conversion process was shortening the text but not adjusting string
879    termination, causing extra message snippets to appear.
880
881  Revision 622.4  2004/06/24 20:38:06  ajc
882  * updated serv_vandelay.c to include new "c_ip_addr" config
883
884  Revision 622.3  2004/06/24 20:33:37  ajc
885  * Bumped internal version number to 6.23
886  * Added "Server IP address" to config (server, client, docs)
887
888  Revision 622.2  2004/06/24 15:26:33  ajc
889  * Updated the ig_tcp_server() function to allow binding to a single IP
890    address.  This is not yet used by anything.
891
892  Revision 622.1  2004/06/24 02:34:39  ajc
893  * serv_imap.c: when an IMAP socket breaks while a folder is selected,
894    auto-expunge the folder before closing it.  Fixes the "mysteriously
895    reappearing deleted messages" for clients that just drop the session
896    without issuing a CLOSE when the user closes the window.
897
898  Revision 622.0  2004/06/19 03:20:22  ajc
899  * THIS IS 6.22
900
901  Revision 621.19  2004/06/19 03:13:26  ajc
902  * Updated internal version number to 6.22
903
904  Revision 621.18  2004/06/19 02:35:16  ajc
905  *** empty log message ***
906
907  Revision 621.17  2004/06/19 02:33:54  ajc
908  * Removed the configuration option "Allow Aides access to all mailboxes."
909    This functionality *must* always be enabled for administrative create/edit
910    of vCards, which live in the user's My Citadel Config> room.
911
912  Revision 621.16  2004/06/16 04:17:43  ajc
913  * More scheduler changes.  Removed the rescan pipe again, and also
914    removed the mutex wrapper around select().  In my initial testing I am
915    getting reliable, fast service, but further testing is needed.
916
917  Revision 621.15  2004/06/16 03:13:02  ajc
918  * Scheduler fix ... added the rescan pipe back in
919
920  Revision 621.14  2004/06/15 20:42:42  ajc
921  * Store the body of any large (>1K) message in a separate database.  This
922    will allow fast headers-only retrieval later.
923
924  Revision 621.13  2004/06/15 03:05:01  ajc
925  * Bumped internal version number to 6.22
926  * Added a new faster headers-only mode that excludes enumeration of
927    MIME parts.
928
929  Revision 621.12  2004/06/14 19:09:26  ajc
930  * serv_vandelay.c: re-inserted a missing line of code for setting tempfile
931    names, which was causing exports to crash.
932
933  Revision 621.11  2004/06/11 01:26:02  ajc
934  * Optimized the scheduler some more.  The S_I_WANNA_SELECT mutex now
935    wraps only the select() call itself.
936
937  Revision 621.10  2004/06/09 03:54:07  ajc
938  * The scheduler can now "wake up" a session to deliver async messages.
939  * Renumbered the "instant msgs waiting" message and changed its usage
940
941  Revision 621.9  2004/06/07 22:12:19  ajc
942  * Removed network/filterlist network/mailinglists network/rnews.xref
943    because none of these are used anymore.
944
945  Revision 621.8  2004/06/07 16:41:28  ajc
946  * Changed "express message" to "instant message" everywhere in the code
947    and documentation, to reflect the now industry-standard terminology for
948    this function.  (Obviously, the server command names have not changed,
949    because that would break everything.)
950
951  Revision 621.7  2004/06/06 22:30:10  ajc
952  * New session scheduler.  All sessions which select() marks for activity
953    are now handled before select() is called again.
954
955  Revision 621.6  2004/06/03 02:49:14  ajc
956  * html.c: allow parsing of tags even when they're qualified
957            (i.e. <TAG foo=bar> instead of just <TAG> )
958  * html.c: handle escaped decimal characters (such as &#39; for an apostrophe)
959
960  Revision 621.5  2004/06/03 02:28:16  ajc
961  * citadel_ipc.c: SETR command was missing defaultview and flags2.  Added.
962
963  Revision 621.4  2004/05/31 15:19:14  ajc
964  * Reworked the security checks for move/copy commands.  Theoretically it's
965    performing all the same checks, but the code is far more readable.
966
967  Revision 621.3  2004/05/26 18:13:15  nbryant
968  * stress.c: silence warning
969
970  Revision 621.2  2004/05/26 16:53:31  nbryant
971  * configure.ac: check for /usr/local/BerkeleyDB.4.2
972
973  Revision 621.1  2004/05/24 01:59:16  ajc
974  * serv_network.c: when processing incoming IGnet spool, give the <C> field
975    priority over the <R> field.  This allows messages emailed to a network
976    room to be shared properly instead of attempting to deliver via email a
977    second time.
978
979  Revision 621.0  2004/05/21 01:58:16  ajc
980  * THIS IS 6.21
981
982  Revision 620.35  2004/05/20 16:14:08  ajc
983  * Changed internal version number to 6.21
984  * Added missing VIEW_* defines in citadel.h (they're used only by WebCit
985    for now, which is why Citadel didn't need them, but they should be there
986    anyway for completeness)
987  * Removed the last vestiges of the built-in spam filter.  It had been
988    commented out, but it's definitely never coming back now, so away it goes.
989  * Updated some of the docs
990
991  Revision 620.34  2004/05/15 14:19:52  error
992  * Scheduler: when next_session is to be deleted, make it point to some
993    other session which isn't being deleted (or NULL if there aren't any).
994
995  Revision 620.33  2004/05/14 03:09:54  ajc
996  * When a session kills itself (for example, due to a broken socket),
997    force the dead_session_purge() to run immediately.  This avoids
998    thousands of error messages for up to the next five seconds while it
999    waits for the next purge.
1000  * For the main select() loop, we can now recover from EBADF by jumping
1001    back to the code that scans for valid descriptors.  (Yeah, I used a
1002    goto.  It's more readable that way, so STFU if you have a problem with
1003    it.)
1004
1005  Revision 620.32  2004/05/11 15:21:45  nbryant
1006  * configure.ac: check for <sys/prctl.h>
1007  * server_main.c: call prctl(PR_SET_DUMPABLE, 1) if we are dropping root
1008    permissions.
1009  * sysdep.c: no longer call setrlimit(RLIMIT_CORE, ...); this can be handled
1010    from a shell script.
1011
1012  Revision 620.31  2004/05/10 01:47:11  error
1013  * messages.c: Fix crash when trying to use m<Y> next
1014
1015  Revision 620.30  2004/05/07 20:27:46  ajc
1016  # citadel-openldap.schema: updated to include RFC2739 objects & attributes
1017
1018  Revision 620.29  2004/05/07 19:31:40  ajc
1019  * More RFC2739 compliance: when converting vCard to LDAP, include
1020    the calFBURL attribute.
1021
1022  Revision 620.28  2004/05/07 19:09:07  ajc
1023  * Implemented partial RFC2739 compliance (calendar free/busy URL in vCard).
1024    Still need to add it to LDAP.
1025
1026  Revision 620.27  2004/05/07 18:17:26  ajc
1027  * Scrawled some notes in roadmap.txt
1028
1029  Revision 620.26  2004/05/06 03:38:26  ajc
1030  * Never reduce the size of the thread pool, only increase it (still
1031    observing the max ceiling, of course)
1032  * Don't explicitly call RemoveContext() when a session exits.  The
1033    subsequent call to dead_session_purge() will handle it.
1034
1035  Revision 620.25  2004/05/03 00:12:27  ajc
1036  * Found and removed a bug that caused network rooms to be un-shared with
1037    all nodes instead of only with nodes that no longer exist.
1038  * New target "make upgrade" (to be consistent with other projects)
1039
1040  Revision 620.24  2004/04/29 02:37:58  ajc
1041  * Updated the roadmap
1042
1043  Revision 620.23  2004/04/26 15:11:17  ajc
1044  * Enable core dumps regardless of system ulimit setting
1045    (maybe temporary until we fix BOOM)
1046
1047  Revision 620.22  2004/04/23 17:27:50  ajc
1048  * user_ops.c: do not attempt to save the loaded user record into the
1049    supplied buffer, when the supplied buffer is NULL.  (This calling
1050    syntax is used to check for the existence of a user without storing it.)
1051
1052  Revision 620.21  2004/04/21 03:44:50  ajc
1053  * serv_crypto.c: small fix to make self-signed certs no longer invalid
1054
1055  Revision 620.20  2004/04/21 03:00:06  ajc
1056  * Replace ctdl_install_certificate() with convenience functions found
1057    in the OpenSSL library.
1058
1059  Revision 620.19  2004/04/20 02:42:54  ajc
1060  * techdoc/binaries.txt : updated, now includes WebCit instructions
1061  * setup.c: detect when setup is run from within the Citadel Ridiculously
1062    Easy Installer and skip the directory prompt; the installer sets it.
1063
1064  Revision 620.18  2004/04/14 18:43:51  nbryant
1065  * citadel.spec: BuildRequire redhat-rpm-config
1066
1067  Revision 620.17  2004/04/14 16:16:47  nbryant
1068  * citadel.spec: don't BuildRequire newt-devel
1069
1070  Revision 620.16  2004/04/14 03:42:01  ajc
1071  * ICAL FREEBUSY output now includes ORGANIZER, DTSTART, and DTEND fields.
1072    (Required for Kolab compatibility.)
1073
1074  Revision 620.15  2004/04/13 23:53:00  nbryant
1075  * citadel.spec: BuildRequire bison
1076
1077  Revision 620.14  2004/04/13 22:44:35  nbryant
1078   * citadel.spec: commented out Icon line and the openldap-servers dependency.
1079   * citadel.spec: added several BuildRequires. Some of these are, strictly
1080     speaking, compile time options, but the goal is to document the runtime
1081     dependencies and make sure our RPM's are always built consistently.
1082
1083  Revision 620.13  2004/04/13 21:09:20  error
1084  * citadel.spec: Updated for 6.20p1
1085
1086  Revision 620.12  2004/04/13 18:31:40  ajc
1087  * serv_calendar.c: ICAL FREEBUSY command now tries the supplied name not
1088    only as a screen name, but as an email address, and then as an
1089    unqualified email address in every hosted domain.  (For Kolab compat)
1090
1091  Revision 620.11  2004/04/13 02:45:07  ajc
1092  * Don't display the "Ending SSL/TLS" log message unless TLS is actually present
1093
1094  Revision 620.10  2004/04/12 20:51:40  error
1095  * citadel.lsm: Update LSM for 6.20p1; uploaded to ibiblio.org
1096
1097  Revision 620.9  2004/04/09 23:11:01  error
1098  * serv_chat.c: Differentiate when a user does not exist when paging users.
1099
1100  Revision 620.8  2004/04/09 23:05:52  error
1101  * user_ops.c: fix unused variable compiler warnings
1102
1103  Revision 620.7  2004/04/03 15:42:35  ajc
1104  * stress.c: include <stdlib.h> in order to get RAND_MAX
1105    (Submitted by Thomas.Lotterer@cw.com, Cable & Wireless / OpenPKG)
1106
1107  Revision 620.6  2004/04/01 04:41:55  ajc
1108  * Put some blankety-blank values in the default generated vCard so it's
1109    more acceptable to LDAP conversion
1110
1111  Revision 620.5  2004/03/31 02:19:09  ajc
1112  * Change the IMAP folder delimiter from "|" to "/" because more than a few
1113    client programs don't follow RFC2060 strictly enough to work with
1114    non-"/" delimiters.  Actual slashes in room names appear as "|" in IMAP.
1115
1116  Revision 620.4  2004/03/30 03:11:07  ajc
1117  * control.c: when config.c_maxsessions is unset or negative, set it to 0
1118    instead of setting it to 1 when it is 0 or negative.  The default should
1119    be unlimited sessions.
1120
1121  Revision 620.3  2004/03/29 16:05:02  ajc
1122  * begin_critical_section() -- bypass transaction checking for S_FLOORCACHE
1123    sections, to avoid crashing the db layer
1124
1125  Revision 620.2  2004/03/29 02:33:19  error
1126  * citadel.spec: major modifications for 6.xx (hasn't been updated since 5.xx)
1127
1128  Revision 620.1  2004/03/27 23:04:59  error
1129  * citadel.lsm: update version number, sending to ibiblio
1130
1131  Revision 620.0  2004/03/27 02:33:26  ajc
1132  * THIS IS 6.20
1133
1134  Revision 614.105  2004/03/27 02:33:10  ajc
1135  * Bumped the version number to 6.20
1136  * Corrected session.txt writeup for CONF command (three of the five LDAP
1137    related fields were missing)
1138  * Updated the roadmap documentation slightly
1139
1140  Revision 614.104  2004/03/27 02:21:30  ajc
1141  * Completed documenting the LDAP Connector
1142
1143  Revision 614.103  2004/03/26 05:41:25  ajc
1144  * Began writing up the LDAP Connector for Citadel in the documentation
1145
1146  Revision 614.102  2004/03/26 05:40:47  ajc
1147  *** empty log message ***
1148
1149  Revision 614.101  2004/03/26 05:13:15  ajc
1150  * citadel-slapd.conf: comment out the reference to the Citadel schema
1151    and add "schemacheck off" to make it easier to get started with the
1152    Citadel LDAP connector.  Also made the backend in the sample conf
1153    ldbm instead of bdb, because that's what RH9 ships with.
1154
1155  Revision 614.100  2004/03/24 21:23:50  ajc
1156  * msgbase.c: repaired a memory leak
1157
1158  Revision 614.99  2004/03/24 17:07:11  ajc
1159  * Put a new memory leak checker into the server because it turns out that
1160    the third-party ones all suck.  :)  This one doesn't involve renaming
1161    all of the malloc() related functions, though.
1162
1163  Revision 614.98  2004/03/24 15:04:06  ajc
1164  * stress.c: fix "wrong password" race condition by giving the very
1165    first worker thread time to finish creating the user account before the
1166    other threads start using it.  (Ok, I fixed it by creating a different
1167    race condition, but if your Citadel takes more than three seconds to
1168    create an account, your problems can't be fixed with the stress tester.)
1169
1170  Revision 614.97  2004/03/24 03:46:40  ajc
1171  * Reorg header stuff to make it more compatible with leak checkers
1172
1173  Revision 614.96  2004/03/24 03:25:19  ajc
1174  * Removed the built-in memory leak checker.  It wasn't threadsafe and
1175    there now exist third-party utilities that do this job better.
1176
1177  Revision 614.95  2004/03/24 02:59:19  ajc
1178  * After initializing the database, chown and chmod all files in the data/
1179    directory correctly to avoid EPERM errors later on when we drop root privs
1180
1181  Revision 614.94  2004/03/22 19:37:28  error
1182  * sysdep.c: worker_thread(): Make scheduling a little more fair to higher
1183    sessions
1184  * sysdep.c: lprintf(): Enable microsecond display in trace file
1185  * stress.c: worker(): Sleep for random amount of time as per specification
1186
1187  Revision 614.93  2004/03/21 22:51:54  error
1188  * Fix a few remaining lprintf(9, ...) to lprintf(CTDL_DEBUG, ...)
1189
1190  Revision 614.92  2004/03/21 22:35:20  error
1191  * stress.c: Wait before posting instead of after posting.
1192
1193  Revision 614.91  2004/03/21 22:34:41  error
1194  * database_sleepycat.c: emit a panic message when Berkeley DB wants us to
1195    run recovery; should provide a little more detail on the actual error
1196
1197  Revision 614.90  2004/03/21 22:32:24  ajc
1198  * room_ops.c: increased the thread safety of cgetfloor()
1199  * housekeeping.c: check floor reference counts in two passes instead of
1200    trying to manipulate multiple tables in O^2
1201
1202  Revision 614.89  2004/03/21 17:14:46  error
1203  * stress.c: Fixed.  Now properly spawns threads and stresses out your
1204    favorite Citadel server by simulating large numbers of really active
1205    users.  (It's configurable on the command line, too, to vary the stress
1206    level.)  Don't use it against a production system!  You've been warned!
1207
1208  Revision 614.88  2004/03/21 17:13:15  error
1209  * configure.ac: Fix for defines for pthreads not being included properly
1210
1211  Revision 614.87  2004/03/21 06:15:06  ajc
1212  * docs/citadel.html: documented TLS support and administration procedures
1213
1214  Revision 614.86  2004/03/20 22:32:06  ajc
1215  * citadel.rc: changed the comments around local_screen_dimensions= to
1216    reflect its legacy type of situation
1217
1218  Revision 614.85  2004/03/16 22:44:15  ajc
1219  * Better conversion of friendly name to fully qualified vcard name
1220
1221  Revision 614.84  2004/03/16 21:09:37  ajc
1222  * Eliminate EVT_OUTPUTMSG server extensions (don't need them anymore)
1223  * Add EVT_NEWUSER server extensions
1224  * EVT_NEWUSER and EVT_PURGEUSER server extensions now specify a
1225    struct ctdluser * instead of a username and usernum
1226  * serv_vcard.c: automatically create and submit a skeleton vCard when
1227    a new user is created.
1228
1229  Revision 614.83  2004/03/16 19:05:50  error
1230  * Further changes to stress.c, Makefile.in to build it, .cvsignore
1231    (but it's still broken)
1232
1233  Revision 614.82  2004/03/15 18:11:34  error
1234  * stress.c: various fixed/improvements (but it still isn't working)
1235
1236  Revision 614.81  2004/03/15 17:22:14  error
1237  * First draft of the stress tester.  Isn't quite ready (it needs to be
1238    tested itself!).
1239
1240  Revision 614.80  2004/03/15 16:48:22  error
1241  * Documentation update: update citadel.html for new syslog logging
1242
1243  Revision 614.79  2004/03/15 16:47:04  error
1244  * msgbase.c: cmd_move(): Fix the security logic for non-aides trying to
1245    move or copy messages.  The logic should do the following:
1246    * Allow move/copy for Aides
1247    * Allow regular users to:
1248      * Move a message between two personal rooms
1249      * Copy a message from a Personal room to a room the user is subscribed to
1250      * Copy a message from a room the user is subscribed to, to a personal room
1251    * Prohibit other moves/copies
1252
1253  Revision 614.78  2004/03/15 16:39:27  error
1254  * Multiple files: Set permissions on existing Citadel directories to prevent
1255    access to the database by local unix users to prevent direct database reads.
1256
1257  Revision 614.77  2004/03/15 16:36:50  error
1258  * Multiple files:  Convert most remaining client code to use new Citadel IPC
1259    functions.  A few bits remain and will be converted when the chat system
1260    is rewritten.
1261
1262  Revision 614.76  2004/03/14 06:35:46  ajc
1263  * Cache IMAP "BODY" fetches in an already-converted format.  This speeds
1264    up clients like Mozilla and Thunderbird that request big messages in
1265    chunks -- we don't have to load and convert the message every time
1266    another chunk is requested.
1267  * Fixed a potential memory leak in fetch
1268
1269  Revision 614.75  2004/03/13 23:26:10  ajc
1270  * imap_fetch.c: don't fetch the message from disk at all for UID and FLAGS
1271    fetch items.  (It's rare, but sometimes IMAP optimizations are actually
1272    possible, despite IMAP's brain-dead design!)
1273
1274  Revision 614.74  2004/03/13 22:52:05  ajc
1275  * Documented the GNET and SNET commands  :)
1276
1277  Revision 614.73  2004/03/12 19:35:13  error
1278  * routines2.c: Fix two typos
1279
1280  Revision 614.72  2004/03/12 19:32:09  error
1281  * routines2.c: Convert multiple functions to use new IPC code (almost done!)
1282
1283  Revision 614.71  2004/03/12 19:30:06  error
1284  * citadel.c: main(): Fix error response for RCHG, HCHG and UCHG commands.
1285
1286  Revision 614.70  2004/03/12 19:28:04  error
1287  * Implement GNET/SNET commands in IPC code; provide a CtdlIPC_delete();
1288    emit warnings when client code uses CtdlIPC_getline() or CtdlIPC_putline()
1289    (These are reserved and should not be used by client code.)
1290
1291  Revision 614.69  2004/03/10 04:50:04  ajc
1292  * serv_expire.c: auto-purge any Citadel account that is associated with
1293    a Unix account that no longer exists.
1294
1295  Revision 614.68  2004/03/09 20:46:33  error
1296  * Add a Linux Software Map file
1297
1298  Revision 614.67  2004/03/08 05:26:49  ajc
1299  * When the last argument of an IMAP APPEND command is a binary literal
1300    (i.e. all the time), the client will still be sending a CRLF after the
1301    literal.  Added an extra client_read() after the message input to absorb
1302    that extra CRLF, to keep client and server from getting out of sync.
1303
1304  Revision 614.66  2004/03/06 05:09:04  ajc
1305  * serv_smtp.c: don't offer the STARTTLS extension if TLS is already
1306    active.  Done for to-the-letter compliance with RFC2487.
1307
1308  Revision 614.65  2004/03/06 02:03:39  ajc
1309  * serv_smtp.c: do not offer the PIPELINING extension when TLS is
1310    running.  Doing so causes sessions to hang unexpectedly.
1311
1312  Revision 614.64  2004/03/05 23:21:25  ajc
1313  * Added some more debugging to serv_smtp.c to try to figure out the
1314    problem with Postfix TLS hanging during send
1315
1316  Revision 614.63  2004/03/05 03:36:03  ajc
1317  * Remove the automatic population of A and N fields we recently added
1318    when found to be NULL.  It was confusing the output functions into
1319    thinking that Internet messages were local.
1320
1321  Revision 614.62  2004/03/03 05:43:29  ajc
1322  * Generate better output when a user is kicked out of chat
1323
1324  Revision 614.61  2004/03/01 22:36:14  ajc
1325  * Implement the NAMESPACE extension of IMAP (RFC 2342)
1326
1327  Revision 614.60  2004/03/01 17:47:28  error
1328  * Fix missing arg in m<Y> next rewrite.
1329
1330  Revision 614.59  2004/03/01 17:33:30  error
1331  * Rewrite m<Y> next function; now uses CtdlIPC code.
1332
1333  Revision 614.58  2004/03/01 04:08:34  ajc
1334  * Revoke access to room when /kicked
1335
1336  Revision 614.57  2004/02/29 23:26:48  ajc
1337  * Added /kick command to chat.  /ban coming soon.
1338
1339  Revision 614.56  2004/02/28 16:37:41  ajc
1340  * setup.c: removed an unused temp file name variable
1341
1342  Revision 614.55  2004/02/27 17:23:21  error
1343  * Use syslog-compatible logging levels in lprintf(); the loglevel chosen
1344    is passed directly to syslog().  The available levels are docuemnted in
1345    sysdep_decls.h.
1346
1347  Revision 614.54  2004/02/27 04:29:00  ajc
1348  * Fixed a bug in PLAIN authentication
1349
1350  Revision 614.53  2004/02/26 22:03:24  error
1351  * ;Goto floor now goes to first KNOWN room, or first room only if no known
1352    rooms on the floor
1353
1354  Revision 614.52  2004/02/26 20:30:36  error
1355  * Populate IPC into a few more places to avoid a nasty crash at MORE prompt
1356
1357  Revision 614.51  2004/02/26 20:17:29  error
1358  * Client stability and enhancements:
1359    * CtdlServInfo structure moved inside CtdlIPC; eliminates unnecessary
1360      global and makes IPC more self-contained
1361    * Removed redundant serv_ from variable names in CtdlServInfo struct
1362    * Send SIGHUP to process group when connection_died().  Kills self and
1363      children (e.g. external editor).
1364
1365  Revision 614.50  2004/02/25 01:35:34  error
1366  Missing parameter to a printf() function.  No idea where it went, but I
1367  put it back.
1368
1369  Revision 614.49  2004/02/24 05:09:06  ajc
1370  * Better validation of incoming network messages.
1371
1372  Revision 614.48  2004/02/23 16:10:47  nbryant
1373  --disable-pie by default.
1374
1375  Revision 614.47  2004/02/22 04:55:15  ajc
1376  * CSR code more or less in its final form for now.
1377
1378  Revision 614.46  2004/02/22 04:42:05  ajc
1379  * Initial version of function to automatically generate a Certificate
1380    Signing Request if one is not present
1381
1382  Revision 614.45  2004/02/20 19:29:05  error
1383  * Fix bug 112: .Goto allowed partial room match on forgotten rooms
1384
1385  Revision 614.44  2004/02/20 02:55:18  ajc
1386  * Fixed one of the prompts (bugzilla #118)
1387
1388  Revision 614.43  2004/02/19 04:12:56  ajc
1389  * Instead of doing the silly "Kolab reserved folder names" thing, instead
1390    implemented the Cyrus-compatible style of forcing all personal mailbox
1391    folders to be subfolders of INBOX.  But only for IMAP.
1392
1393  Revision 614.42  2004/02/18 14:46:05  ajc
1394  * smtp: EHLO response now includes both "AUTH " and "AUTH=" output, due to
1395    the requirement to interoperate with brain-dead Microsoft shitware that
1396    doesn't follow the RFC.
1397
1398  Revision 614.41  2004/02/17 16:56:51  ajc
1399  * During SSL initialization, create the "keys" directory if it does not
1400    exist ... generate a private key if that does not exist ... more code
1401    coming soon to generate CSR and self-signed cert.  Hard-coded pathnames
1402    have been moved to sysconfig.h.
1403
1404  Revision 614.40  2004/02/17 04:47:22  ajc
1405  * Support PLAIN auth method in SMTP
1406
1407  Revision 614.39  2004/02/17 03:53:11  ajc
1408  * New ICAL subcommand "sgi" to enable or disable automatic server
1409    generated invitations.  (WebCit wants sgi's but Kontaqt doesn't.)
1410
1411  Revision 614.38  2004/02/16 21:54:22  ajc
1412  * Support POP3 over TLS
1413
1414  Revision 614.37  2004/02/16 21:45:43  ajc
1415  * Implement RFC 2487 - SMTP Service Extension for Secure SMTP over TLS
1416
1417  Revision 614.36  2004/02/16 21:02:28  ajc
1418  * IMAP and Citadel protocols now use the same code path for TLS negotiation
1419
1420  Revision 614.35  2004/02/16 20:55:47  ajc
1421  * Genericized the Citadel API for TLS-enabling protocols
1422
1423  Revision 614.34  2004/02/16 18:16:39  error
1424  * Remove some unnecessary and possibly hazardous debugging code leftover
1425    from debugging IMAP STARTTLS
1426
1427  Revision 614.33  2004/02/16 18:14:00  error
1428  * Fixed IMAP STARTTLS; trouble was in client_read_ssl the whole time.
1429    It should now be possible to implement SSL/TLS for any protocol.
1430
1431  Revision 614.32  2004/02/16 18:13:10  error
1432  * Log session IDs in syslog as well as stderr
1433
1434  Revision 614.31  2004/02/16 15:06:44  error
1435  * Add specific error codes for every command on the wire protocol, so that
1436    clients can more easily determine what went wrong.  Partially updated
1437    session.txt (will finish it later).  This lets clients more easily
1438    determine what, if anything, went wrong with a particular command.
1439
1440  Revision 614.30  2004/02/15 06:06:49  ajc
1441  * More work on IMAP TLS.  Still not working correctly.  :(  Added in
1442    support for server-side certificates.  Now instead of failing it hangs.
1443
1444  Revision 614.29  2004/02/14 04:41:55  ajc
1445  * STARTTLS attempt #2.  Still disabled because it's broken.
1446
1447  Revision 614.28  2004/02/13 20:51:13  error
1448  * Reset screen attributes before fork() so that external programs do the
1449    right thing
1450
1451  Revision 614.27  2004/02/12 04:16:38  ajc
1452  * Support for PLAIN logins in IMAP (need to test!)
1453
1454  Revision 614.26  2004/02/11 03:50:49  ajc
1455  * The groupware folders "Calendar", "Contacts", "Notes", and "Tasks" are
1456    now presented as subfolders of INBOX when using IMAP.  This is for the
1457    purpose of Kolab compatibility.
1458
1459  Revision 614.25  2004/02/09 22:40:57  error
1460  * oops...also close the client on EOF/error on tty OUTPUT
1461
1462  Revision 614.24  2004/02/09 22:26:17  error
1463  * Exit the citadel client when EOF reached on input - should prevent
1464    a process from hanging around when a telnet connection dies unexpectedly
1465
1466  Revision 614.23  2004/02/08 05:29:34  ajc
1467  * Corrected various small syntax conversion problems that were keeping
1468    some vCards out of the LDAP directory.
1469
1470  Revision 614.22  2004/02/07 05:28:10  ajc
1471  * Automatically purge files from ./network/spoolout which were intended
1472    for nodes which no longer exist
1473
1474  Revision 614.21  2004/02/07 04:59:21  ajc
1475  * Cache the IGnet config in memory, avoiding a db fetch for every single
1476    operation which references it.  Invalidate the cache when a new config
1477    is uploaded.
1478  * When doing network spool for a room, automatically remove shares for
1479    Citadel nodes which no longer exist.
1480
1481  Revision 614.20  2004/02/07 04:22:12  ajc
1482  * serv_network.c: fixed a problem with an uninitialized data structure
1483
1484  Revision 614.19  2004/02/06 04:40:50  ajc
1485  * Suppress posting of messages to Aide> when the loopzapper catches dupes.
1486  * New command NSYN to sync the entire contents of a room to a specified
1487    network node.  This will be used to bring new nodes in sync with existing
1488    nodes.
1489
1490  Revision 614.18  2004/02/06 03:58:10  ajc
1491  * Added some comments to the sample citadel-slapd.conf
1492
1493  Revision 614.17  2004/02/06 03:52:46  ajc
1494  * Changed the domain name and password in the sample slapd.conf
1495
1496  Revision 614.16  2004/02/05 05:20:20  ajc
1497  * Delete a user's LDAP entry when deleting the vCard.  NOT TESTED.
1498
1499  Revision 614.15  2004/02/05 03:54:14  ajc
1500  * Completed the per-user initialization of LDAP entries.
1501
1502  Revision 614.14  2004/02/04 18:27:25  error
1503  * Don't delete temp file when composing message until after server writes
1504    it successfully (or an error occurs in the client itself).
1505
1506  Revision 614.13  2004/02/04 04:07:56  ajc
1507  * More work on LDAP connector
1508
1509  Revision 614.12  2004/02/01 06:19:22  ajc
1510  * policy.c: fix bug in GetExpirePolicy() that was causing the default
1511    mailbox purge policy to be misinterpreted if it was set to "use
1512    system default"
1513  * serv_vcard.c: always set the Global Address Book room's expire policy
1514    to "never expire" and its default view to "address book"
1515
1516  Revision 614.11  2004/01/31 05:44:29  ajc
1517  *** empty log message ***
1518
1519  Revision 614.10  2004/01/27 19:56:29  ajc
1520  * serv_smtp.c: HELO and EHLO responses now reply with the detected
1521    IP address and reverse DNS lookup of the connecting host
1522
1523  Revision 614.9  2004/01/24 05:47:50  ajc
1524  * Got Citadel talking to LDAP.  Still requires manual creation of schema
1525    and container entries, which I don't like; we'll have to fix that.  It
1526    also does not yet populate all fields.
1527
1528  Revision 614.8  2004/01/19 21:01:15  error
1529  * Clear out the autom4te.cache when bootstrapping to avoid autoheader problems
1530
1531  Revision 614.7  2004/01/19 04:44:11  ajc
1532  * Further work on creating LDAP entries.
1533
1534  Revision 614.6  2004/01/18 21:04:40  ajc
1535  * Reworked vCard etc. functions for addition of new vCard data to LDAP
1536
1537  Revision 614.5  2004/01/17 22:57:54  ajc
1538  * Added "Base DN" "Bind DN" and "Bind DN password" config options
1539  * serv_ldap.c: added.  (New module implementing the LDAP Connector)
1540  * Upon startup, connect to LDAP directory and bind to it.  Unbind at exit.
1541
1542  Revision 614.4  2004/01/17 04:23:28  ajc
1543  * Sysconfig commands for specifying where the LDAP server lives
1544
1545  Revision 614.3  2004/01/17 03:26:17  ajc
1546  * Changed a diagnostic in msgbase.c to a higher logging level so it doesn't
1547    make as much noise.
1548  * Setup now adds "-x3 -llocal4" to the default inittab line.
1549
1550  Revision 614.2  2004/01/17 03:17:34  ajc
1551  * New server command-line option "-l" to send log output to the host
1552    computer's syslog facility instead of to a trace file.
1553
1554  Revision 614.1  2004/01/02 22:13:59  ajc
1555  * Link to OpenLDAP client library (-lldap) and set HAVE_LDAP if present.
1556
1557  Revision 614.0  2003/12/30 04:13:40  ajc
1558  * THIS IS 6.14
1559
1560  Revision 613.12  2003/12/30 04:13:31  ajc
1561  * Commented out one of the supplied .RU commands in citadel.rc
1562
1563  Revision 613.11  2003/12/24 05:02:49  ajc
1564  * Allow a separate default message expire policy for mailbox rooms.  The
1565    floor default setting is now ignored for mailboxes.  Updated client and
1566    documentation to match.
1567
1568  Revision 613.10  2003/12/23 03:53:49  ajc
1569  * Expanded the size of all string fields in "struct CtdlIPCMessage" to
1570    the standard SIZ length, in order to accomodate "weird" messages
1571    without crashing.  Also converted many strcpy()'s to safestrncpy()'s
1572    while populating this data structure, to avoid overruns.
1573
1574  Revision 613.9  2003/12/22 16:49:36  error
1575  * Add Preview for Mac OS X as an image viewer option in citadel.rc
1576
1577  Revision 613.8  2003/12/22 15:30:53  error
1578  * Fork image viewer process in background (works now); suppress
1579    stdout/stderr from the image viewer
1580
1581  Revision 613.7  2003/12/21 20:02:28  error
1582  * When viewing images, append the image filename to the temp filename so
1583    that less-intelligent viewers can deal with the images
1584
1585  Revision 613.6  2003/12/21 19:07:28  error
1586  * Start a new thread and fork() for image viewer (broken/disabled; for
1587    refernce only)
1588
1589  Revision 613.5  2003/12/21 01:23:12  nbryant
1590  added some additional comments to citadel.rc concerning possible image viewers
1591
1592  Revision 613.4  2003/12/21 00:44:19  error
1593  * Fix for idle_threshold being ignored when reading citadel.rc
1594
1595  Revision 613.3  2003/12/21 00:37:54  error
1596  * Fix for crash when downloading multiple attachments
1597
1598  Revision 613.2  2003/12/21 00:19:41  error
1599  * Image viewer code for the text client.  Hit 'I' to view an image
1600    attached to a file.  Hey aahz, this code actually works!
1601
1602  Revision 613.1  2003/12/19 04:33:52  ajc
1603  * Changes to auto-expunge algorithm to support correct behavior in
1604    some IMAP clients while moving messages.
1605
1606  Revision 613.0  2003/12/15 16:37:01  ajc
1607  * THIS IS 6.13
1608
1609  Revision 612.14  2003/12/15 16:33:47  ajc
1610  * Added support for "Cc" and "Bcc" IMAP SEARCHes
1611  * Bumped the version number to 6.13
1612
1613  Revision 612.13  2003/12/11 04:21:23  ajc
1614  * Removed a "FIXME this needs blah blah" comment because blah blah has
1615    since been completed
1616
1617  Revision 612.12  2003/12/11 04:06:55  nbryant
1618  configure.ac: add support for position-independent executables. can be disabled
1619  with --disable-pie
1620
1621  Revision 612.11  2003/12/11 03:44:18  nbryant
1622  domain.c: include <arpa/nameser_compat.h> if present
1623  configure.ac: check for <arpa/nameser_compat.h>
1624
1625  Revision 612.10  2003/12/10 03:58:26  ajc
1626  * Completed a more accurate implementation of the ENVELOPE fetch in IMAP.
1627
1628  Revision 612.9  2003/12/09 06:39:19  nbryant
1629  did a minimal amount of ANSIfication without changing anything that would
1630  affect the compiler output in any way. I was just trying to get enough warnings
1631  enabled to be able to tell if there are any nested functions lurking about...
1632
1633  If we get rid of nested functions we can get some big security gains under
1634  Fedora.
1635
1636  Revision 612.8  2003/12/09 05:12:49  ajc
1637  * Don't give away anonymous poster information in IMAP or RFC822
1638
1639  Revision 612.7  2003/12/09 04:50:16  ajc
1640  * Painstakingly combed through IMAP headers and responses for two hours in
1641    an attempt to figure out why the horrendous pile of crap called Microsoft
1642    Outlook counts the correct number of messages but wasn't displaying any
1643    of them.  Eventually determined that it was ONE EXTRA SPACE after the
1644    closing paren of the ENVELOPE output that caused Outlook to totally ignore
1645    all the messages.  This only reinforces my belief that anything designed
1646    in the state of Washington is utter and complete CRAP.
1647  * Corrected the above glitch.  Outbreak works properly now.
1648
1649  Revision 612.6  2003/12/09 03:56:29  ajc
1650  * user_ops.c: missing string declaration or something?
1651
1652  Revision 612.5  2003/12/08 17:41:01  ajc
1653  * serv_smtp.c: validated and documented compliance with a big pile of RFC's
1654    which are in one way or another related to SMTP.
1655
1656  Revision 612.4  2003/12/07 19:59:13  error
1657  * Minor enhancements to a few of the trace file entries
1658
1659  Revision 612.3  2003/12/07 19:57:48  error
1660  * Added some useless comments to some of the techdocs/ files
1661
1662  Revision 612.2  2003/12/07 19:56:24  error
1663  * CREU command now allows specification of an initial password
1664
1665  Revision 612.1  2003/12/04 04:20:08  ajc
1666  * Incoming RFC822 messages get the To: field translated directly to
1667    a Citadel <R> field.
1668
1669  Revision 612.0  2003/12/01 04:11:48  ajc
1670  * THIS IS 6.12
1671
1672  Revision 611.10  2003/11/30 03:43:34  ajc
1673  * Support IMAP \Answered flag
1674
1675  Revision 611.9  2003/11/22 03:30:14  ajc
1676  * Commented out the call to the 'high speed download' function and
1677    uncommented the call to the original 'chatty' download function.  Some
1678    users were reporting lockups.
1679
1680  Revision 611.8  2003/11/14 20:15:44  ajc
1681  * Reversed the previous change because it made things b0rken
1682
1683  Revision 611.7  2003/11/14 20:04:28  ajc
1684  * IMAP FETCH ENVELOPE now outputs more fields correctly.
1685
1686  Revision 611.6  2003/11/14 03:49:54  ajc
1687  * MUCH faster implementation of rfc822_fetch_field()
1688
1689  Revision 611.5  2003/11/13 04:25:38  ajc
1690  * mime_parser.c: handle multipart *much* more efficiently now.  Instead
1691    of scanning line by line, we snag the boundaries using the Boyer-Moore
1692    algorithm.
1693
1694  Revision 611.4  2003/11/12 04:28:22  ajc
1695  * Replaced bmstrcasestr() with a more generic function, bmstrstr(), which
1696    can be supplied with *any* strncmp()-compatible compare function.
1697
1698  Revision 611.3  2003/11/08 06:46:08  ajc
1699  * IMAP FETCH BODY<xxx.yyy> was outputting the offset and length in the
1700    wrong order.  Fixed.
1701
1702  Revision 611.2  2003/11/08 06:29:47  ajc
1703  * IMAP FETCH FLAGS ... removed extra trailing space after last flag
1704
1705  Revision 611.1  2003/11/06 04:25:30  ajc
1706  * For certain IMAP outputs (such as BODYSTRUCTURE), buffer all output until
1707    we've got the whole thing, then spew it all at once to avoid lots of
1708    tiny TCP packets.
1709  * New API calls buffer_output() (to start buffering) and unbuffer_output()
1710    (to dump the buffer and stop buffering) are available to do this.
1711
1712  Revision 611.0  2003/10/21 04:20:41  ajc
1713  * THIS IS 6.11
1714
1715  Revision 610.22  2003/10/17 02:18:40  ajc
1716  * Replaced the DEFAULT_ENTRY definition in sysconfig.h with a new option
1717    "reply_with_external_editor" in citadel.rc.
1718
1719  Revision 610.21  2003/10/14 03:09:47  ajc
1720  * routines2.c: fixed an off-by-one error in filename sanitization for
1721    client file uploads
1722
1723  Revision 610.20  2003/10/10 05:43:57  ajc
1724  * citadel.c:  Reworded one of the prompts
1725
1726  Revision 610.19  2003/10/07 15:56:17  ajc
1727  * Better handling of incoming Internet addresses consisting of an address
1728    in angle brackets with no name outside the brackets.
1729
1730  Revision 610.18  2003/09/21 04:10:56  ajc
1731  * messages.c: don't crash when a message contains more than MAXURLS of
1732    embedded URL's.  Omit them instead.
1733  * citadel.rc: updated the sample browser remoting command for Macintosh
1734    based on a Mr.T suggestion
1735  * techdoc/session.txt: redid the writeup for the MOVE command (fixed a
1736    mistake and made the writeup clearer)
1737
1738  Revision 610.17  2003/09/17 21:40:13  ajc
1739  * html.c: don't truncate messages when wacky characters are
1740    encountered.  Substitute '?' characters instead.  Now the Citadel
1741    community can complain about b0rken MS ASCII.
1742
1743  Revision 610.16  2003/09/13 02:53:04  ajc
1744  * More intelligent selection of directory to save attachments
1745
1746  Revision 610.15  2003/09/12 15:48:55  ajc
1747  * serv_smtp.c: remember whether we're SMTP or LMTP across a RSET command.
1748
1749  Revision 610.14  2003/09/09 02:42:28  ajc
1750  * Documentation update for LMTP
1751
1752  Revision 610.13  2003/09/09 01:47:02  ajc
1753  * Suppress domain forgery check when using LMTP
1754
1755  Revision 610.12  2003/09/08 18:48:14  ajc
1756  * The unix domain socket used for citmail to talk to citserver now
1757    implements LMTP (RFC2033).  Other LMTP client implementations (such as
1758    Postfix) can also use the socket, eliminating the need for citmail.
1759
1760  Revision 610.11  2003/09/07 03:29:25  ajc
1761  * serv_network.c: aggressively poll any node for which we have data
1762
1763  Revision 610.10  2003/09/06 02:04:54  ajc
1764  * Don't reset "last poll" time when not doing the "full" net processing
1765
1766  Revision 610.9  2003/09/03 03:29:01  ajc
1767  * syslog messages now say session started/ended instead of ended/ended
1768
1769  Revision 610.8  2003/09/03 03:24:40  ajc
1770  * client: remove rooms from the march list when zapping them (or the floors
1771    they're on)
1772
1773  Revision 610.7  2003/09/02 15:05:34  ajc
1774  * Repaired an incorrect adjustment of floor reference counts when a room was
1775    moved to a different floor.  (Thanks to Winzlo for reporting this.)
1776
1777  Revision 610.6  2003/09/02 14:49:05  ajc
1778  * Improve client chat mode reliability and performance by assuming that all
1779    server output will be in complete lines.  (This is a safe assumption.)
1780
1781  Revision 610.5  2003/09/02 04:04:39  ajc
1782  * Don't try to directly spool to non-neighbor nodes
1783
1784  Revision 610.4  2003/08/29 08:21:57  ajc
1785  * Do network runs more proactively.  The inbound queue is now scanned
1786    every minute instead of every poll frequency.
1787
1788  Revision 610.3  2003/08/21 23:26:06  ajc
1789  * setup.c: offer to disable "exim" if found
1790
1791  Revision 610.2  2003/08/20 03:51:08  ajc
1792  * Bumped the internal version number to 6.11
1793
1794  Revision 610.1  2003/08/20 03:36:13  ajc
1795  * Create a "Contacts" room for personal address book use
1796
1797  Revision 610.0  2003/08/17 03:00:37  ajc
1798  * THIS IS 6.10
1799
1800  Revision 609.2  2003/08/17 02:58:46  ajc
1801  * Changed internal version number to 6.10
1802
1803  Revision 609.1  2003/08/17 02:46:37  ajc
1804  * Don't fail on "data files too old to be upgraded" for NEW installations
1805
1806  Revision 609.0  2003/08/14 03:40:55  ajc
1807  * THIS IS 6.09
1808
1809  Revision 608.21  2003/08/13 18:08:24  ajc
1810  * Removed the last vestiges of the now-obsolete global networking password
1811
1812  Revision 608.20  2003/08/13 14:36:04  ajc
1813  * "make install" now installs the contents of docs/ as well as README.txt
1814
1815  Revision 608.19  2003/08/13 14:30:47  ajc
1816  * Temporarily disabled IMAP TLS support due to the discovery of some
1817    compatibility problems.  It will be re-enabled when they are fixed.
1818
1819  Revision 608.18  2003/08/12 00:39:35  ajc
1820  * setup now knows about lots of other mail programs it can disable (various
1821    flavors of Cyrus and Courier, for example)
1822  * setup now ensures that it really did startup/shutdown the Citadel service,
1823    and displays an error message when that fails.
1824  * "make install" now instructs the user run "setup"
1825  * Removed an old GDBM reference from the documentation
1826
1827  Revision 608.17  2003/08/05 03:06:58  ajc
1828  * Added a README.txt file because some Joker kept bugging me about it
1829  * Reloaded the code that extracts embedded URL's to a place where it'll
1830    get picked up on *every* message, not just the old variformat stuff
1831
1832  Revision 608.16  2003/08/03 17:51:52  ajc
1833  * Clear out all masqueraded wholist fields when logging out, in case another
1834    user logs in without reconnecting.
1835
1836  Revision 608.15  2003/07/30 20:36:18  ajc
1837  * Allow users to authenticate with either their display name or any valid
1838    e-mail address which belongs to them.  Applies to all protocols.
1839
1840  Revision 608.14  2003/07/30 03:54:34  ajc
1841  * Fixed a small client bug in the purge hour setting
1842
1843  Revision 608.13  2003/07/30 03:47:53  ajc
1844  * Eliminated the EXPI command
1845  * Completed the configuration item of "purge hour"
1846  * Auto-purger now runs as a scheduled job
1847
1848  Revision 608.12  2003/07/30 00:26:50  ajc
1849  * Removed the "weekly" script and began installing a facility to allow
1850    database maintenance to happen automatically.  (One Step Install can't
1851    require the sysadmin to know cron)
1852
1853  Revision 608.11  2003/07/28 04:17:24  ajc
1854  * migratenet.c: removed.  Adjusted Makefile.in accordingly.
1855
1856  Revision 608.10  2003/07/27 21:15:23  ajc
1857  * Implemented all IMAP date-based search criteria.  Note that Citadel does
1858    not record an "internal date" of a message, so the "sent date" and "internal
1859    date" searches perform identically.
1860  * Date search comparisons available: "before," "on," or "on or after."  Yet
1861    another example of IMAP's gratuitous complexity.
1862
1863  Revision 608.9  2003/07/26 04:49:40  ajc
1864  * Implemented a bunch of the IMAP SEARCH keywords
1865
1866  Revision 608.8  2003/07/26 04:28:44  ajc
1867  * tools.c: added bmstrcasestr(), a Boyer-Moore, case-insensitive string search
1868  * imap_search.c: implement BODY criterion in search command
1869
1870  Revision 608.7  2003/07/24 04:57:53  ajc
1871  * Began implementation of the IMAP SEARCH command.  Basically just got the
1872    parser working and stubbed all the search criteria.  Next step is to
1873    implement the functionality of each criterion keyword.
1874  * Implemented the functionality for the ALL (wow!) and UID criteria.
1875
1876  Revision 608.6  2003/07/23 03:57:05  ajc
1877  * Optimized the updating of visit records in several places by checking to
1878    see if they've changed and aborting the db update if they haven't.
1879  * Functions which read/write user records are now slightly faster due to
1880    an improvement of the algorithm used to generate the database keys.
1881
1882  Revision 608.5  2003/07/22 03:07:50  nbryant
1883  fix build for Solaris
1884
1885  Revision 608.4  2003/07/20 20:46:06  ajc
1886  * build system: link Berkeley DB only to the server, not to the client & utils
1887
1888  Revision 608.3  2003/07/20 03:51:46  ajc
1889  * setup.c: offer to disable sendmail, postfix, and qmail if found (only if
1890    using the /etc/init.d type of startup scripts)
1891
1892  Revision 608.2  2003/07/20 03:08:22  ajc
1893  * setup.c: offer to hack /etc/xinetd.d/telnet
1894
1895  Revision 608.1  2003/07/15 14:54:09  ajc
1896  * Killed off CtdlGetDynamicSymbol() and just put all the symbols in server.h
1897
1898  Revision 608.0  2003/07/15 04:12:52  ajc
1899  * THIS IS 6.08
1900
1901  Revision 607.23  2003/07/14 17:26:42  ajc
1902  * strcpy() --> safestrncpy() in a few other random places
1903
1904  Revision 607.22  2003/07/14 17:12:28  ajc
1905  * Replaced strcpy() with safestrcpy() in cmd_setp()
1906
1907  Revision 607.21  2003/07/14 03:07:05  ajc
1908  * ipgm_secret is no longer set during setup.  Now it is set at server startup
1909    and automatically changes whenever an IPGM command is executed.
1910  * Upon an IPGM authentication failure, wait 5 seconds before displaying an
1911    error, then disconnect the session.
1912
1913  Revision 607.20  2003/07/13 04:58:35  ajc
1914  * Allow connect on unix domain sockets to Citadels in other directories
1915  * sendcommand now uses unix domain sockets instead of the network
1916  * Do not allow IPGM command to run on the network -- unix domain sockets only
1917
1918  Revision 607.19  2003/07/11 22:33:02  ajc
1919  * Ignore comments in public_clients file
1920
1921  Revision 607.18  2003/07/11 22:30:19  ajc
1922  * Automatically add 127.0.0.1 and config.c_fqdn to public_clients
1923
1924  Revision 607.17  2003/07/11 22:19:49  ajc
1925  * is_public_client() now caches the IP addresses of all hosts in
1926    the public_clients file, at server startup and whenever the file is
1927    modified.  This eliminates the need to make lots of calls to the
1928    resolver library every time.
1929
1930  Revision 607.16  2003/07/10 05:51:46  ajc
1931  * Added cs_addr field to struct CitContext -- holds a dotted quad string
1932    of the user's source IP (if applicable).  It's big enough to hold other
1933    types of address strings in the future (such as IPv6).
1934  * locate_host() populates cs_addr when on a network connection.
1935  * serv_smtp.c now saves the IP address in the proper place in
1936    the Received: header.
1937  * is_public_client() no longer accepts a hostname.  It just looks at
1938    CC->cs_host instead.
1939
1940  Revision 607.15  2003/06/29 19:54:39  ajc
1941  * Renamed "struct user" to "struct ctdluser"
1942  * Renamed "struct room" to "struct ctdlroom"
1943
1944  Revision 607.14  2003/06/29 04:13:32  ajc
1945  * Renamed:
1946    S_QUICKROOM to S_ROOMS
1947    S_USERSUPP to S_USERS
1948    CDB_QUICKROOM to CDB_ROOMS
1949    CDB_USERSUPP to CDB_USERS
1950
1951  Revision 607.13  2003/06/29 04:07:11  ajc
1952  * Globally renamed "struct quickroom" and "struct usersupp" to
1953    "struct room" and "struct user".
1954
1955  Revision 607.12  2003/06/29 04:06:41  ajc
1956  *** empty log message ***
1957
1958  Revision 607.11  2003/06/29 03:58:41  ajc
1959  * Renamed fields in 'struct config' which are no longer relevant (but kept
1960    them in place to avoid corrupting everyone's data files).  Removed them
1961    entirely from serv_vandelay.c.
1962
1963  Revision 607.10  2003/06/28 05:12:56  ajc
1964  * Bump internal version number to 6.08
1965  * Use (-1) instead of CTDLUID as the uid of user records which exist only
1966    in Citadel and not in the system password database.  serv_upgrade also
1967    changes this setting for ALL such users, the first time the server is run
1968    after upgrading to 6.08
1969
1970  Revision 607.9  2003/06/27 22:19:31  error
1971  * routines2.c: Quick and dirty fix for Mail> becoming new after entering a
1972    mail message
1973
1974  Revision 607.8  2003/06/26 01:50:14  ajc
1975  * Compiler warning fix for building setup without newt
1976
1977  Revision 607.7  2003/06/25 15:40:57  ajc
1978  * setup now uses "newt" instead of "curses" to draw its pretty screens.
1979    Changes were made to setup.c as well as all the autoconf stuff.
1980
1981  Revision 607.6  2003/06/25 02:40:05  ajc
1982  * Per-user and global flags calling for validation need to be set in the
1983    vCard upload thingie, not in the wrapper function that emulates the
1984    deprecated REGI server command.  Moved it to the correct place.
1985
1986  Revision 607.5  2003/06/22 20:49:31  error
1987  * citadel.c: display idle times in wholist up to 999 days
1988
1989  Revision 607.4  2003/06/19 04:12:30  ajc
1990  * domain.c: use qsort() to sort MX records by preference.  Why have a
1991    custom function when the operating system provides one for free?
1992  * serv_smtp.c: accept mail from "<>" (empty sender).  RFC1123 5.2.9 demands it.
1993
1994  Revision 607.3  2003/06/19 03:55:22  ajc
1995  * Fixed a subtle but ugly bug in the SMTP sender that was causing it to
1996    ignore all successful connections except the last one.  Now when it gets
1997    a connection it uses it.
1998
1999  Revision 607.2  2003/06/17 22:05:11  ajc
2000  * New format for wholist.
2001
2002  Revision 607.1  2003/06/16 04:39:45  ajc
2003  * support.c: removed an unused variable
2004  * citadel.c: sort wholist by idle time (most recently active users first)
2005
2006  Revision 607.0  2003/06/10 04:15:39  ajc
2007  * THIS IS 6.07
2008
2009  Revision 606.10  2003/06/04 21:46:13  error
2010  * citadel.c: Added a missing #ifdef __CYGWIN__
2011
2012  Revision 606.9  2003/06/04 21:39:27  error
2013  * Numerous fixups needed for Windows port:
2014    * cmd_mesg() rewritten to use the stat() syscall to find files
2015    * really_do_keepalive() does not try to send if we are not connected
2016    * Misc. fixups; added Windows readme file
2017
2018  Revision 606.8  2003/06/04 21:30:39  error
2019  * messages.c: When file attachment has no name, use message subject as name
2020
2021  Revision 606.7  2003/06/02 23:11:00  error
2022  * Checkin installer script citadel.nsi for NSIS Windows installer
2023
2024  Revision 606.6  2003/06/02 03:01:22  ajc
2025  * citserver.c: added another trace message to is_public_client().  Uncensored
2026    has crashed twice in this function, for no apparent reason.
2027  * internet_addressing.c: don't attempt to look up the specified Internet
2028    address in a Citadel directory, if the supplied address has no hostname
2029    portion.  (Fixes a crash in the calendar service when alias() attempts to
2030    look up potentially nonexistent attendees during event validation)
2031
2032  Revision 606.5  2003/05/28 03:08:38  ajc
2033  * msgbase.c: validate_recipients() now rejects Internet addresses in
2034    domains belonging to the local system or an attached Citadel network,
2035    when it fails to translate to a Citadel address.
2036
2037  Revision 606.4  2003/05/26 05:36:25  ajc
2038  * citadel.h: changed internal version number to 6.07
2039  * file_ops.c: #include <ctype.h>
2040  * migratenet.c: #include <ctype.h>
2041
2042  Revision 606.3  2003/05/26 05:30:18  ajc
2043  * serv_calendar.c: fixed a bug in the "ICAL freebusy" subcommand which
2044    caused it to always fetch the logged in user's freebusy times instead
2045    of the user specified.
2046
2047  Revision 606.2  2003/05/22 13:34:30  ajc
2048  * database_sleepycat.c: added a couple of diagnostic messages to help
2049    troubleshoot problems with db-4.1.25 on Red Hat Linux 9
2050  * room_ops.c: call mkdir() instead of system() to create a directory
2051
2052  Revision 606.1  2003/05/20 01:28:50  error
2053  * citadel.c: don't truncate roomname when user is idle, in long who list;
2054    display idle time in short who list
2055
2056  Revision 606.0  2003/05/16 15:17:11  ajc
2057  * THIS IS 6.06
2058
2059  Revision 605.50  2003/05/16 14:59:08  ajc
2060  * Removed the old rec_log() facility because the utilities which read its
2061    data are crufty, disused, and produce incorrect output.
2062  * Updated the documentation for the forthcoming 6.06 release.
2063  * public_clients: removed hostnames which crept in from development servers
2064
2065  Revision 605.49  2003/05/16 04:07:37  nbryant
2066  make configure.ac automagically do the right thing on redhat 9
2067  remove crappy tolower() hack that was breaking the build on redhat 9
2068  (because the kerberized openssl includes ctype.h)
2069
2070  before anyone yells at me, i did a little cvs archaeology on the tolower
2071  thing, and it appears to have been in the Citadel source base since,
2072  roughly, the Epoch. I doubt that the hack is needed any longer, and using
2073  the OS's tolower() will handle extended charsets.
2074
2075  Anyone who is stupid enough to be using an OS with such a horribly broken
2076  tolower() can just scratch their head and figure things out for
2077  themselves. Citadel needs higher barriers to entry, there are too many
2078  weirdos on the IGnet lately. :-)
2079
2080  Revision 605.48  2003/05/13 03:22:04  ajc
2081  * Implemented the IMAP STARTTLS command as specified in RFC 2595.
2082
2083  Revision 605.47  2003/05/06 03:38:59  ajc
2084  * IMAP folder create and rename commands -- don't allow backslashes in
2085    folder names.
2086
2087  Revision 605.46  2003/05/03 16:50:52  ajc
2088  * Change folder delimiter in room names from / to \
2089
2090  Revision 605.45  2003/05/02 04:02:47  ajc
2091  * setup.c: allow specification of the Citadel system account by either
2092             username or uid
2093  * setup.c: tell init to re-read /etc/inittab by sending a SIGHUP to pid 1
2094             instead of hunting around for the correct init or telinit command
2095  * docs/citadel.html: documented the above change, and also rewrote some
2096                       other stuff to be less BBS-specific
2097
2098  Revision 605.44  2003/04/30 16:16:13  ajc
2099  * Minor fix to ESMTP greeting (missing '-' screwed up pipelining)
2100
2101  Revision 605.43  2003/04/30 15:46:27  ajc
2102  * Added the ENHANCEDSTATUSCODES extention to ESMTP.
2103
2104  Revision 605.42  2003/04/29 04:41:22  ajc
2105  * Fix an off-by-one error in the mime parser
2106
2107  Revision 605.41  2003/04/29 04:13:58  ajc
2108  * mime parser: look for the "name=" subfield tacked onto either
2109    Content-type or Content-disposition, wherever it finds it.
2110
2111  Revision 605.40  2003/04/28 16:56:51  ajc
2112  * Added a site-configurable setting to suppress the automatic correction of
2113    forged From: lines from authenticated SMTP users, for those who prefer
2114    strict RFC compliance instead of common sense.
2115
2116  Revision 605.39  2003/04/26 21:55:15  ajc
2117  * Anytime a socket connect() fails, CLOSE THE SOCKET before erroring out.
2118    Not doing so causes a file descriptor leak.
2119
2120  Revision 605.38  2003/04/26 04:22:51  ajc
2121  * Removal of individual "remote" lines from message delivery instruction sets
2122    was corrupting the end of the set, rendering the "bounceto" line unusable
2123    and preventing bounces from being delivered.  Fixed this by explicitly
2124    adding a trailing newline when remove_token() strips it.
2125
2126  Revision 605.37  2003/04/25 18:28:47  ajc
2127  * When rejecting spam, use SMTP error code 550, not 552
2128
2129  Revision 605.36  2003/04/23 03:18:44  ajc
2130  * Allow IMAP STORE of more than one flag at a time (Mail.app from MacOS
2131    does this).
2132
2133  Revision 605.35  2003/04/15 02:44:02  ajc
2134  * Do not allow incoming network polls while an outbound network processing
2135    session is in progress.
2136  * tools.c: removed collapsed_strcmp() as it is no longer used anywhere
2137
2138  Revision 605.34  2003/04/08 04:03:37  ajc
2139  * Implemented the ".SILENT" protocol option in IMAP STORE.  Certain apps seem
2140    to want to use it.
2141  * Optimized the IMAP operations which scan for expunged and added messages.
2142    These loops no longer make multiple traversals through the message list.
2143
2144  Revision 605.33  2003/04/07 05:02:23  ajc
2145  * Reworked all the "list rooms" operations so that they only require one
2146    pass through the database.
2147  * Repaired the "create floor" operation which was broken by the switch
2148    to the new IPC libray
2149
2150  Revision 605.32  2003/04/02 13:33:28  ajc
2151  * Fixed output of "-0500" vs. "+0500" type of timezone stamps in RFC822.
2152    (I think they were reversed.)
2153
2154  Revision 605.31  2003/04/01 05:01:08  ajc
2155  * sysdep.c: optimized MyContext() a bit, and inlined it.  A little profiling
2156    revealed that this function was getting used super heavily.
2157  * tools.c: removed the older, slower string tokenizer functions that
2158    weren't getting used anymore.
2159
2160  Revision 605.30  2003/03/31 04:55:58  ajc
2161  * Repaired the formatting of text/plain messages with blank lines.
2162
2163  Revision 605.29  2003/03/30 06:16:52  ajc
2164  * Optimized CtdlReadMessageBody() and also gave it an option to store
2165    messages with CRLF newlines instead of LF.  This option is used when
2166    reading SMTP in order to keep Pine from barfing on LF-terminated newlines
2167    while decoding quoted-printable.  *sigh*
2168
2169  Revision 605.28  2003/03/26 05:17:12  ajc
2170  * Downloading of attachments was completely broken by the change to the new
2171    protocol library.  Located and fixed bugs.
2172  * html.c: increased the conversion buffer size
2173
2174  Revision 605.27  2003/03/24 03:42:14  ajc
2175  * Add the ability to quit out while validating users.  Also added a help
2176    option listing available access levels.  This closes Bugzilla #37.
2177
2178  Revision 605.26  2003/03/22 05:38:23  ajc
2179  * During startup, display the version string from the Berkeley DB library.
2180  * When deleting a mailbox, don't reveal the namespace prefix to the user.
2181
2182  Revision 605.25  2003/03/20 08:37:04  error
2183  * connection_died(): Don't crash before printing message, crash afterward.
2184    (Bugzilla id 111)
2185
2186  Revision 605.24  2003/03/19 11:48:06  error
2187  * entmsg(): Don't corrupt the msg_arr[] when replying to a message in a room
2188
2189  Revision 605.23  2003/03/19 04:04:56  ajc
2190  * Dropped support for GDBM and for versions of Berkeley DB prior to 4.1
2191
2192  Revision 605.22  2003/03/18 05:15:05  ajc
2193  * Applied a patch sent in by Clint Adams <schizo@debian.org> to handle
2194    building on Debian's unstable with Berkeley DB 4.1, compiled with
2195    the --with-db-uniquename when errno is a macro (as in glibc 2.3.1).
2196
2197  Revision 605.21  2003/03/17 11:56:35  error
2198  * Fix <G>oto in alternate_semantics - it actually marks messages read now.
2199
2200  Revision 605.20  2003/03/17 04:03:14  ajc
2201  * Supply a NULL argument as the second argument to accept() instead of an
2202    empty buffer whose contents we never even look at.
2203
2204  Revision 605.19  2003/03/16 05:07:12  ajc
2205  * Fixed the bug that caused freebusy publishes to crash.
2206
2207  Revision 605.18  2003/03/15 23:05:08  ajc
2208  * Rewrite of calendar-to-freebusy conversion functions.  This one creates
2209    freebusy in the correct format, instead of what I mistakenly assumed it
2210    was supposed to look like.  :(
2211
2212  Revision 605.17  2003/03/15 22:31:06  ajc
2213  * When scanning a user's Calendar> room for calendar events, search for
2214    MIME parts of type text/calendar instead of assuming that the event will
2215    always appear as part "1"
2216
2217  Revision 605.16  2003/03/14 05:08:25  ajc
2218  * Clone calendar subcomponents before encapsulating in case they already
2219    happen to have a parent.
2220
2221  Revision 605.15  2003/03/13 05:48:33  ajc
2222  * Move towards storing calendar objects as fully encapsulated VCALENDAR
2223    components instead of just VEVENT subcomponents.
2224
2225  Revision 605.14  2003/03/12 03:33:54  ajc
2226  * More changes to the handling of RFC822 headers with regard to
2227    splitting up the headers and body.  (Blank lines and such.)
2228
2229  Revision 605.13  2003/03/11 06:23:50  ajc
2230  * More accurate handling of IMAP FETCH xx BODYSTRUCTURE command.  This should
2231    make Pine happier with multipart messages.
2232
2233  Revision 605.12  2003/03/10 05:38:21  ajc
2234  * Tweaks to msgbase.c and imap_fetch.c to fix slightly incorrect byte counts
2235    reported in the numerous variations of IMAP FETCH.  This silences a number of
2236    error messages reported by Pine.
2237
2238  Revision 605.11  2003/03/10 03:40:08  ajc
2239  * Fixed bug that caused segv when <R>eplying to certain messages
2240
2241  Revision 605.10  2003/03/07 17:39:45  ajc
2242  * Remove the "modules" directory
2243
2244  Revision 605.9  2003/03/06 04:58:11  ajc
2245  * When entering a message into Citadel with authenticated SMTP, stamp the
2246    room name as MAILROOM (Mail>) so it doesn't end up with an ugly moniker
2247    like "0000058008.Sent Items"
2248
2249  Revision 605.8  2003/03/05 04:55:32  ajc
2250  * serv_smtp.c: when authenticated, do not log out when a RSET command is
2251    issued.  This breaks clients which carelessly issue RSET before each
2252    message, such as Pine.
2253  * serv_smtp.c: when authenticated, ignore envelope FROM:<xxx> sender name
2254    and replace with address of user who authenticated.  Also fixes Pine.
2255  * serv_smtp.c: when authenticated, not only do we continue our glorious
2256    RFC-violating condition of replacing the From: header with the user who
2257    is logged in, but we also stamp it with their preferred Internet address
2258    for outbound mail (which is kept in CC->cs_inet_email).
2259
2260  Revision 605.7  2003/03/03 04:09:21  ajc
2261  * When creating a user, hide the "My Citadel Config>" room of the user being
2262    created, not the user currently logged in.
2263
2264  Revision 605.6  2003/03/01 18:18:03  ajc
2265  * commands.c: alternate_semantics might have been getting set where it
2266    should not.  Fixed.
2267
2268  Revision 605.5  2003/03/01 17:25:33  ajc
2269  * citadel.rc default for alternate_semantics = no
2270
2271  Revision 605.4  2003/02/23 05:34:45  ajc
2272  * When the <N>ew command is used to read new messages, the next "lazy"
2273    command (space bar) now always does <G>oto, regardless of the last one.
2274
2275  Revision 605.3  2003/02/21 04:24:51  ajc
2276  * Completed the "ICAL freebusy" subcommand, which fetches free/busy times
2277    for any requested user (output in stripped-down VCALENDAR format)
2278
2279  Revision 605.2  2003/02/20 04:51:17  ajc
2280  * Began framing up a command to view other users' free/busy times
2281
2282  Revision 605.1  2003/02/19 22:38:43  ajc
2283  * Changed socklen_t to int (to allow compile on Macintosh)
2284
2285  Revision 605.0  2003/02/19 03:46:01  ajc
2286  * THIS IS 6.05
2287
2288  Revision 601.134  2003/02/17 05:23:20  ajc
2289  * Fixed a small bug in the GDBM backend (deprecated, but the bug was very
2290    obvious and a kind user pointed it out)
2291  * Removed vestiges of setjmp/longjmp from the client
2292  * When doing .TS, don't get caught in a constant-logout loop
2293
2294  Revision 601.133  2003/02/14 16:12:04  ajc
2295  * Added support for any standard RBL
2296
2297  Revision 601.132  2003/02/13 22:33:41  ajc
2298  * Fixed algorithm for reporting "last login"
2299
2300  Revision 601.131  2003/02/13 21:52:13  ajc
2301  * IMAP service: fixed bug that was causing the wrong messages (usually *all*
2302    messages) to be flagged when a STORE or COPY operation was performed.
2303
2304  Revision 601.130  2003/02/13 20:13:51  ajc
2305  * Applied "multi editor" patch supplied by georbit
2306
2307  Revision 601.129  2003/02/12 04:51:44  ajc
2308  * More docs update
2309
2310  Revision 601.128  2003/02/10 04:50:33  ajc
2311  * More documentation updates
2312
2313  Revision 601.127  2003/02/09 03:38:28  ajc
2314  * Updated the documentation some more
2315
2316  Revision 601.126  2003/01/25 07:37:15  error
2317  * whobbs.c: Print error message if we can't connect to server
2318
2319  Revision 601.125  2003/01/23 05:50:59  ajc
2320  * citadel.c: hitting enter without entering a room name in the <.G>oto and
2321    <.S>kip commands now does nothing instead of exhibiting undefined behavior
2322
2323  Revision 601.124  2003/01/23 04:42:33  ajc
2324  * Began reviewing, updating, and HTML-izing the documentation
2325
2326  Revision 601.123  2003/01/22 03:53:24  ajc
2327  * More reliablility hacks for autologin mode, and better quarantine of
2328    autologin code when it's disabled.
2329
2330  Revision 601.122  2003/01/21 04:42:12  ajc
2331  * Moved login-to-screenname code ... no longer part of CtdlTryExistingUser(),
2332    it's now part of getuser() so it always gets called, even when looking up
2333    addresses for mail and stuff.
2334
2335  Revision 601.121  2003/01/19 08:59:02  error
2336  * Remove irrelevant file hpsux.h (was part of dynloader)
2337
2338  Revision 601.120  2003/01/19 05:55:59  ajc
2339  * serv_calendar.c: allocate dynamic symbol at module startup, not during
2340    each session startup.  This error was causing crashes (of course).
2341
2342  Revision 601.119  2003/01/18 06:18:20  ajc
2343  * whobbs.c: line up the columns better
2344  * routines2.c: when doing <.ASI> command, entering a blank hostname causes
2345    it to abort instead of adding a new host.  Also strip l/t whitespace.
2346
2347  Revision 601.118  2003/01/17 22:36:56  ajc
2348  * This commit is a figment of your imagination.
2349
2350  Revision 601.117  2003/01/17 21:50:27  ajc
2351  * Began making some build changes for Cygwin compatibility
2352
2353  Revision 601.116  2003/01/17 10:06:54  error
2354  * fmout():  Ignore \r (carriage return) characters in messages
2355
2356  Revision 601.115  2003/01/17 04:36:04  ajc
2357  * whobbs.c: fix bad call to CtdlGetServInfo() so we can get our session ID
2358    and the name of the Citadel site
2359
2360  Revision 601.114  2003/01/16 21:16:23  error
2361  * CtdlIPCGetMessages(): Fix message read failing on first attempt to read
2362    messages
2363
2364  Revision 601.113  2003/01/16 10:04:03  error
2365  * ENT0 command: changed post-as username from arg 4 to arg 5; 4 was already
2366    used as the message subject
2367  * Convert message entry and reading to new IPC code
2368  * Minor bugfixes throughout IPC code
2369
2370  Revision 601.112  2003/01/16 04:17:02  ajc
2371  * citadel_ipc.c: when issuing a SPEX command, send the string value for
2372    room/floor/site instead of the number.  citserver wants a string.
2373  * ipc_c_tcp.c: don't call SSL_shutdown() from connection_died().  This just
2374    causes it to segfault because there's no valid socket.
2375
2376  Revision 601.111  2003/01/16 03:41:45  ajc
2377  * Renamed "dynloader" to "serv_extensions" globally.  We don't want people
2378    to think we have a dynamic loader, do we?  :)
2379  * serv_*_init() is now declared in serv_extensions.h.  This is definitely the
2380    wrong place for it.  It's there temporarily until we decide on a new
2381    convention for server extensions.
2382  * bootstrap: more reliable detection of Red Hat Linux 7.3 -- more specifically,
2383    fewer fireworks when the host system is *not* Red Hat Linux.
2384
2385  Revision 601.110  2003/01/15 16:34:53  ajc
2386  * bootstrap: don't check /etc/redhat-release if it doesn't exist (which is
2387    the case on all non Red Hat Linux systems)
2388
2389  Revision 601.109  2003/01/15 05:57:09  ajc
2390  * First cut at static-linking the citserver.  Ripped out libtool and
2391    replaced the dynloader paradigm with "server extensions" paradigm (static
2392    linked, but still very loosely coupled by way of using the API's to
2393    register callbacks and commands etc.)   Needs more testing.
2394
2395  Revision 601.108  2003/01/14 04:12:26  ajc
2396  * Set default view for new user Calendar> rooms to 3 (calendar)
2397  * Set default view for new user Tasks> rooms to 4 (tasks)
2398
2399  Revision 601.107  2003/01/13 17:04:19  ajc
2400  * Add a sample URL view command for Macintosh in the included citadel.rc
2401
2402  Revision 601.106  2003/01/13 02:55:07  ajc
2403  * Do calendar support only if libical header *and* library are present
2404
2405  Revision 601.105  2003/01/12 23:07:40  ajc
2406  * configure.ac: Attempt to check for libical 0.24 or newer
2407
2408  Revision 601.104  2003/01/12 05:01:58  ajc
2409  * Start marking things for 6.05 release
2410
2411  Revision 601.103  2003/01/12 04:48:23  ajc
2412  * Display message subjects in magenta instead of white
2413
2414  Revision 601.102  2003/01/06 09:17:10  error
2415  * Remove non (yet) existent sstring.c dependency from Makefile.in
2416
2417  Revision 601.101  2003/01/05 07:35:03  error
2418  * Add an AllFloors parameter to the citadel IPC API
2419
2420  Revision 601.100  2003/01/01 08:07:46  error
2421  * commands.c: bugfix for reading from FILE pointers; affected quote, print
2422    and external editor.
2423
2424  Revision 601.99  2002/12/28 05:33:29  ajc
2425  * ical_dezonify: set is_utc=1 even if we didn't convert from some arbitrary
2426    timezone.  Presumably this means the time was already UTC, and we really
2427    need that "Z" to get slapped on it.
2428
2429  Revision 601.98  2002/12/28 05:12:06  ajc
2430  * Yet another attempt at making ical_dezonify() send outgoing calendar items
2431    in UTC format.  (This one will probably work -- the timestamps have the
2432    "Z" after them which signifies UTC instead of local time.)
2433
2434  Revision 601.97  2002/12/27 04:40:40  ajc
2435  * Another attempt at fixing timezones :(
2436
2437  Revision 601.96  2002/12/25 23:17:07  ajc
2438  * ical_dezonify.c: shuffle around #includes and #ifdef's
2439
2440  Revision 601.95  2002/12/25 21:46:19  ajc
2441  * Another shot at timezone handling (ugggghh)
2442
2443  Revision 601.94  2002/12/25 07:05:26  ajc
2444  * set up ical_dezonify() to be called at appropriate times
2445    (but it doesn't seem to work correctly yet)
2446
2447  Revision 601.93  2002/12/25 06:41:44  ajc
2448  * ical_dezonify.c: added (function to strip localized timestamps out of
2449    a component and replace them with UTC timestamps)
2450
2451  Revision 601.92  2002/12/19 04:51:49  ajc
2452  * database_cleanup.sh: added
2453
2454  Revision 601.91  2002/12/18 04:08:16  ajc
2455  * Don't attempt to send out invitations when there are no attendees.
2456
2457  Revision 601.90  2002/12/15 10:53:51  error
2458  * Final touches on the new message formatter.
2459
2460  Revision 601.89  2002/12/15 09:42:37  error
2461  * Converted more routines to new IPC code.
2462
2463  Revision 601.88  2002/12/14 23:21:29  ajc
2464  * When saving a calendar event, set the message Subject to the event
2465    summary string, and the message Date/time to the event start time.
2466
2467  Revision 601.87  2002/12/10 23:36:20  ajc
2468  * Fixed a bug in the allocation of per-session dynamic data for calendar module
2469
2470  Revision 601.86  2002/12/09 06:07:29  ajc
2471  * Finished the code to accept incoming calendar REPLY messages and
2472    merge/save the updated event in the user's calendar.
2473
2474  Revision 601.85  2002/12/08 06:01:48  ajc
2475  * More work on the reply handler.  Wrote functions to locate the message
2476    containing the invitation being replied to.  Just need to write the
2477    merge and resave functions now.
2478
2479  Revision 601.84  2002/12/08 00:23:08  ajc
2480  * Began adding a calendaring subcommand to accept a reply to a meeting
2481    invitation and update the event in the user's calendar.  (Not finished.)
2482
2483  Revision 601.83  2002/12/04 05:01:18  ajc
2484  * When sending out invitations, encapsulate the VEVENT component inside a
2485    VCALENDAR component, along with proper metadata such as product ID and
2486    vcalendar version.  Move the METHOD:REQUEST property to the encapsulating
2487    component rather than the event itself.  (Still need to add a VTIMEZONE).
2488
2489  Revision 601.82  2002/12/03 04:49:15  ajc
2490  * Send out meeting requests!  (Need to test with various clients.)
2491
2492  Revision 601.81  2002/12/02 08:09:00  error
2493  * Improvements to the new message formatter, including URL support and
2494    doing the Right Thing for text/plain messages.
2495
2496  Revision 601.80  2002/12/01 11:02:57  error
2497  * New experimental message formatter - try it, you'll like it!
2498
2499  Revision 601.79  2002/12/01 04:48:24  ajc
2500  * The code to check for sending invitations needs to happen *after* save
2501
2502  Revision 601.78  2002/12/01 00:59:54  ajc
2503  * Reliably detect when the user saving an event is listed as the meeting
2504    organizer.  (Currently calls a stub function.  Still need to write the
2505    function to generate and send invitations.)
2506
2507  Revision 601.77  2002/11/30 21:35:30  ajc
2508  * just some trace messages
2509
2510  Revision 601.76  2002/11/30 05:39:28  ajc
2511  * Started banging out some code to determine when a saved vEvent needs to
2512    send out meeting invites.
2513
2514  Revision 601.75  2002/11/29 16:24:59  ajc
2515  * When calling ical*_remove_*() routines, the caller then owns the object
2516    which is removed.  Added ical*_free() calls to free the memory.
2517
2518  Revision 601.74  2002/11/29 15:44:41  ajc
2519  * CC->cs_inet_email is now a string buffer, not a pointer
2520  * Initialize CC->cs_inet_email with a default address, so it always
2521    contains something even when the directory doesn't
2522  * Augment CHEK command to return the user's preferred Internet e-mail addr.
2523
2524  Revision 601.73  2002/11/27 21:05:31  nixo
2525  added dot ungoto functionality.
2526  It allows you to enter a room to ungoto, it will look
2527  through the ungoto list and goto there at the room position
2528  you last goto-ed it from.
2529  Don't blame me, this was Gary's idea.
2530
2531  Revision 601.72  2002/11/25 05:10:07  ajc
2532  * Post a notification to Aide> when a user is manually deleted
2533    (resolves Bugzilla enhancement request #73)
2534
2535  Revision 601.71  2002/11/25 04:57:43  ajc
2536  * Allow set/clear of per-user Internet mail privilege
2537  * Honor that flag
2538
2539  Revision 601.70  2002/11/23 13:35:47  error
2540  * Makefile.in: Alphabetized all the source files
2541
2542  Revision 601.69  2002/11/21 05:38:13  ajc
2543  * Added support for a "New User Greetings" room.  See docs/install.txt
2544
2545  Revision 601.68  2002/11/15 11:24:40  error
2546  * serv_rwho.c: cmd_rwho(): move logged_in from param 8 to param 11
2547    (see RWHO in techdoc/session.txt)
2548
2549  Revision 601.67  2002/11/13 17:20:57  ajc
2550  * When in curses mode, call beep() instead of putc(7, stdout) to make it beep.
2551
2552  Revision 601.66  2002/11/12 04:30:16  ajc
2553  * Completed the invitation accept/decline code.  It now sends back a
2554    correctly formated reply!  (Tested with Evolution)
2555
2556  Revision 601.65  2002/11/11 06:21:55  error
2557  * Fixed minor bugs with color handling; added explicit support for handling
2558    the background color e.g. for transparent terminals
2559
2560  Revision 601.64  2002/11/11 04:17:24  ajc
2561  * More work on reply to meeting invitation
2562
2563  Revision 601.63  2002/11/10 09:21:57  error
2564  * messages.c: fixed <H>eader command
2565
2566  Revision 601.62  2002/11/10 09:19:38  error
2567  * Convert some more routines to new IPC code
2568
2569  Revision 601.61  2002/11/10 09:14:16  error
2570  * citadel.spec: updated for post-6.01
2571
2572  Revision 601.60  2002/11/10 09:12:06  error
2573  * citadel.c: When terminating, don't mark messages new when using new
2574    message semantics
2575
2576  Revision 601.59  2002/11/08 05:28:54  ajc
2577  * Reply to VEVENT invitations: generate reply by cloning the request,
2578    stripping out non-me attendees, setting the partstat to accept/decline,
2579    and extracting the address of the organizer.   (Still not finished: right
2580    now it does everything except actually sending the reply.)
2581
2582  Revision 601.58  2002/11/07 04:40:07  ajc
2583  * Repaired the "remember username/password" functionality of the client
2584    (it was broken during the transition to the new client protocol library)
2585
2586  Revision 601.57  2002/11/06 05:03:01  ajc
2587  * No changes; just testing CVS permissions
2588
2589  Revision 601.56  2002/11/04 21:49:53  ajc
2590  * Don't run the wait indicator when in an external editor
2591
2592  Revision 601.55  2002/11/01 04:57:56  ajc
2593  * Fixed .AM and .AE commands
2594
2595  Revision 601.54  2002/10/29 20:14:56  error
2596  * rooms.c: don't allow a blank floor name when creating a floor (in client)
2597
2598  Revision 601.53  2002/10/26 06:15:09  ajc
2599  * cmd_cflr() - don't allow zero length floor names
2600
2601  Revision 601.52  2002/10/26 06:01:19  ajc
2602  * Increase size of temp file name buffer in struct CitContext
2603
2604  Revision 601.51  2002/10/25 09:38:38  error
2605  * Fixed broken .Goto by partial match
2606
2607  Revision 601.50  2002/10/25 09:26:26  error
2608  * Fix the status line not updating with the new wait indicator; rearrange
2609    the code so network_status_cb is a member function of ipc.
2610
2611  Revision 601.49  2002/10/25 04:39:38  ajc
2612  * When in fullscreen mode, display an "X" icon in the lower right corner of
2613    the screen while waiting for the server.
2614
2615  Revision 601.48  2002/10/24 09:04:53  error
2616  * acconfig.h: add DISABLE_CURSES template
2617
2618  Revision 601.47  2002/10/23 04:06:41  ajc
2619  * "conflicts" check now also tells the client whether a conflicting event
2620    is really just an older version of the same object.
2621
2622  Revision 601.46  2002/10/23 03:55:21  ajc
2623  * Finished: when saving an object of type text/calendar to the Calendar> room,
2624    set the Citadel "extended message ID" to the UID of the VEVENT object.  This
2625    causes the message base to automatically delete any existing instance(s) of
2626    that object: automatic replacement.
2627
2628  Revision 601.45  2002/10/23 03:07:43  ajc
2629  * First hack at UID-to-EMSGID mapping (for auto replacement)
2630
2631  Revision 601.44  2002/10/21 20:00:41  ajc
2632  * List UID and SUMMARY properties of conflicting events
2633
2634  Revision 601.43  2002/10/21 17:14:42  ajc
2635  * More work on conflict detects
2636
2637  Revision 601.42  2002/10/20 21:42:54  ajc
2638  * More conflict checking stuff
2639
2640  Revision 601.41  2002/10/20 20:21:27  ajc
2641  * Put in a skeleton "hunt for conflicts" code
2642
2643  Revision 601.40  2002/10/20 08:01:03  error
2644  * docs/install.txt: add Mac OS X build instructions
2645
2646  Revision 601.39  2002/10/19 21:35:34  ajc
2647  * Moved some of the calendar logic over from WebCit
2648
2649  Revision 601.38  2002/10/19 08:30:03  error
2650  * dynloader.c:  Darwin places underscores in front of symbol names, just
2651    like OpenBSD.
2652
2653  Revision 601.37  2002/10/19 08:18:06  error
2654  * Disable any use of curses on Darwin (this is temporary until I beat
2655    Apple's bizarre linker into submission)
2656
2657  Revision 601.36  2002/10/18 10:33:09  error
2658  * More signed/unsigned fixes (for the new progress gauge)
2659
2660  Revision 601.35  2002/10/18 07:56:30  error
2661  * fix self-service account creation at login prompt (accidentally called
2662    CREU instead of NEWU).
2663
2664  Revision 601.34  2002/10/18 03:44:13  ajc
2665  * Fixed a bug in CtdlRenameRoom() that caused the old room record not to be
2666    deleted when there was a mailbox namespace attached.
2667  * Reworked imap_rename() and imap_rename_backend() to not use nested functions
2668
2669  Revision 601.33  2002/10/17 12:56:44  error
2670  * Bug fixes:  Fix numerous char array size mismatches, signed/unsigned
2671    mismatches, and const correctness problems (though not nearly all)
2672
2673  Revision 601.32  2002/10/17 11:13:27  error
2674  * Convert room listings and some aide functions to new IPC code
2675
2676  Revision 601.31  2002/10/16 13:46:19  ajc
2677  * Remove some trace messages
2678
2679  Revision 601.30  2002/10/16 08:59:41  error
2680  * Don't assume pointer to time_t is compatible with pointer to
2681    struct timeval.tv_sec (it isn't on darwin)
2682
2683  Revision 601.29  2002/10/16 02:49:55  ajc
2684  * CtdlWriteObject() encode in memory instead of on disk (not tested)
2685
2686  Revision 601.28  2002/10/15 17:41:20  ajc
2687  * Numerous warning fixes and cleanups for compile on Linux for IBM S/390
2688  * Name temp files with source code location of who created them
2689
2690  Revision 601.27  2002/10/15 06:47:11  error
2691  * IPC support for resumable downloads
2692
2693  Revision 601.26  2002/10/15 06:44:55  error
2694  * configure.ac check for malloc.h header file (Mac OS X needs this)
2695
2696  Revision 601.25  2002/10/15 03:56:33  ajc
2697  * Run without crashing on Berkeley DB 4.1  :)
2698
2699  Revision 601.24  2002/10/15 03:30:52  ajc
2700  * Build ok on Berkeley DB 4.1
2701
2702  Revision 601.23  2002/10/14 08:27:40  error
2703  * Mac OS X build fixes (everything but serv_imap now builds)
2704
2705  Revision 601.22  2002/10/08 09:44:52  error
2706  * Build environment:  cvs ignore .diff/.patch files
2707
2708  Revision 601.21  2002/10/07 18:59:37  ajc
2709  * Build fixes for Solaris box without OpenSSL installed
2710
2711  Revision 601.20  2002/10/07 09:40:49  error
2712  * Don't try to compile non-existent client_crypto.c (oops!)
2713
2714  Revision 601.19  2002/10/06 18:46:30  error
2715  * Move (nearly) all IPC-related code to citadel_ipc.[ch].
2716
2717  Revision 601.18  2002/10/05 04:48:29  ajc
2718  * Change MAXSETUP from 4 to 3 (bug reported by mavherzog, fix suggested by IO)
2719
2720  Revision 601.17  2002/10/04 07:11:56  error
2721  * Fix bootstrap for Red Hat 7.3
2722
2723  Revision 601.16  2002/10/02 04:07:27  error
2724  * status_line() now shows "new mail" only when there is new mail
2725
2726  Revision 601.15  2002/10/01 04:00:13  ajc
2727  * html.c: speed improvement in html-to-ascii converter
2728  * messages.c: MASSIVE speed improvement in message output
2729
2730  Revision 601.14  2002/09/30 08:07:11  error
2731  * ipcdef.h: add extern "C" for linking to C++ programs
2732
2733  Revision 601.13  2002/09/30 07:32:09  error
2734  * ipcdef.h: remove prototype for connection_died(), it doesn't belong there
2735
2736  Revision 601.12  2002/09/30 07:20:35  error
2737  * Fix configure mis-detecting libical and zlib and a missing semicolon in
2738    tools.h
2739
2740  Revision 601.11  2002/09/29 04:55:13  error
2741  * File and attachment downloads now use the new IPC code.
2742  * Implemented high-speed pipelined file download in IPC code.
2743
2744  Revision 601.10  2002/09/29 04:41:43  error
2745  * file_ops.c: cmd_read() now returns a short read at end-of-file instead of
2746    4096, this prevents trailing garbage on the downloaded file; also it now
2747    succeeds if the requested number of bytes is > 4096; it simply returns
2748    only 4096 bytes.
2749
2750  Revision 601.9  2002/09/27 06:53:20  error
2751  * Allow multiple simultaneous IPC connections.  All changes necessary for
2752    the client to use the new code are necessarily included.
2753
2754  Revision 601.8  2002/09/22 02:48:04  ajc
2755  * axdefs.h: add "Notes" view
2756
2757  Revision 601.7  2002/09/17 03:18:15  ajc
2758  * Create the Calendar> and Tasks> rooms at login time, and set their default
2759    views to calendar and tasklist views.  Renamed "My Calendar>" to "Calendar>"
2760    to be in sync with the KDE groupware project.
2761
2762  Revision 601.6  2002/09/15 03:24:28  ajc
2763  * Renamed decode_base64() to CtdlDecodeBase64()
2764  * Renamed decode_quoted_printable() to CtdlDecodeQuotedPrintable()
2765  * These changes are to avoid namespace conflict with libical
2766
2767  Revision 601.5  2002/09/13 15:41:39  ajc
2768  * serv_calendar.c: #include "serv_calendar.h", not "serv_ical.h"
2769
2770  Revision 601.4  2002/09/11 03:17:18  ajc
2771  * [EXPERIMENTAL] Link in the "libical" calendar library if present
2772  * Rename serv_ical to serv_calendar (because the resulting module would be
2773    named "libical" which conflicts with the external library by that name)
2774
2775  Revision 601.3  2002/09/10 08:07:38  error
2776  * 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
2777
2778  Revision 601.2  2002/09/09 03:03:18  ajc
2779  * When a user logs in, create the Mail> room if it doesn't exist.  (Should
2780    never happen, but one site had a situation where this patch came in handy.)
2781
2782  Revision 601.1  2002/09/08 04:15:28  ajc
2783  * Also fixed a bug in <.T>erminate <S>tay which caused the terminal to
2784    become wacky on second and subsequent sessions.
2785
2786  Revision 601.0  2002/09/08 03:51:30  ajc
2787  * Let's call this 6.01, shall we?
2788
2789  Revision 600.2  2002/09/08 03:48:48  ajc
2790  * Fixed a crashy crashy bug in the AGUP protocol function in the client
2791
2792  Revision 600.1  2002/09/07 03:24:23  ajc
2793  * When displaying messages using MSG4, enumerate the attachments on the
2794    client side, because the server won't add their descriptions to the
2795    message text.
2796
2797  Revision 600.0  2002/09/04 03:06:58  ajc
2798  * Committing the current code base as version 6.00
2799
2800  Revision 591.109  2002/09/03 14:09:04  ajc
2801  * setup.c: automatically stop/start services
2802
2803  Revision 591.108  2002/09/03 04:42:15  ajc
2804  * Added MSG4 support to client-side IPC
2805  * Moved HTML-to-text conversion to the client side
2806
2807  Revision 591.107  2002/09/02 20:40:34  ajc
2808  * Automation work for setup
2809
2810  Revision 591.106  2002/08/31 04:36:26  ajc
2811  * IMAP APPEND no longer forces messages to appear as from the logged-in user
2812    when appending to a mailbox room.  (Allows migration to Citadel from some
2813    other type of server without losing all the sender names.)
2814
2815  Revision 591.105  2002/08/31 04:12:39  ajc
2816  * Set version number to 6.00 in documentation and header files.
2817  * Convert RFC822 newlines (CRLF) to Unix/Citadel newlines (LF) when
2818    performing an IMAP APPEND command.
2819
2820  Revision 591.104  2002/08/28 03:18:06  ajc
2821  * Make reply_to and reply_subject global (otherwise they don't work!)
2822
2823  Revision 591.103  2002/08/27 04:01:03  ajc
2824  * Added the ability to run an external command from the client when new mail
2825    arrives.  (Ok, I admit it: I just discovered http://www.dailywav.com and I
2826    just *had* to have Bear in the Big Blue House tell me I've got mail)
2827
2828  Revision 591.102  2002/08/26 02:55:09  ajc
2829  * Small bugfix for memory bounds checking in the MIME parser
2830
2831  Revision 591.101  2002/08/25 21:23:49  ajc
2832  * Hide the SMTP queue and the sysconfig rooms.
2833
2834  Revision 591.100  2002/08/24 05:58:53  ajc
2835  * Bugfixes and cosmetic changes to listsub system
2836
2837  Revision 591.99  2002/08/23 03:36:52  ajc
2838  * Finished all of the subscribe/unsubscribe/confirm stuff!
2839
2840  Revision 591.98  2002/08/23 02:30:02  ajc
2841  * Delete unconfirmed pending subscribe/unsubscribe requests after three days
2842  * Don't allow multiple subscriptions of the same address to a list
2843
2844  Revision 591.97  2002/08/22 03:55:11  ajc
2845  * Fixed bug in above
2846
2847  Revision 591.96  2002/08/22 03:40:00  ajc
2848  * Add "unsubscribe" command (but not yet "confirm unsubscribe")
2849
2850  Revision 591.95  2002/08/21 21:58:00  ajc
2851  * Completed self-service list subscription via web.
2852    (Still need to implement unsubscribe.)
2853
2854  Revision 591.94  2002/08/16 21:04:56  ajc
2855  * Add LPRM command
2856
2857  Revision 591.93  2002/08/14 20:21:52  ajc
2858  * Extend GETR/SETR to allow twiddling of bits in the QRflags2 bucket
2859  * New flag and config options to allow/disallow self-service list subscription
2860    and unsubscription to a room
2861
2862  Revision 591.92  2002/08/14 02:36:05  ajc
2863  * WebCit list subscription integration
2864
2865  Revision 591.91  2002/08/13 18:48:46  ajc
2866  * Generate and send subscription confirmation requests.
2867    (Still need to finalize the URL format)
2868
2869  Revision 591.90  2002/08/13 17:19:11  ajc
2870  * Added email capability to quickie_message()
2871
2872  Revision 591.89  2002/08/13 04:02:06  ajc
2873  * <R>eplace string is now case sensitive
2874
2875  Revision 591.88  2002/08/13 03:46:31  ajc
2876  * More work on the self-service subscribe/unsubscribe infrastructure
2877
2878  Revision 591.87  2002/08/12 03:00:20  ajc
2879  * Fixed bug in <R>eplacestring which caused it to lock up in certain conditions
2880
2881  Revision 591.86  2002/08/12 00:09:05  ajc
2882  * Compress VISIT records using zlib if available.  This reduces the object
2883    size from over 4k to about 70 bytes.  Experimental.
2884  * Automatically uncompress database records found to be compressed (duh)
2885
2886  Revision 591.85  2002/08/08 22:01:35  ajc
2887  * autoconf to look for zlib (for an upcoming experiment)
2888
2889  Revision 591.84  2002/08/08 03:25:56  ajc
2890  * Bugfix for above
2891  * Started writing some infrastructure for sub/unsub
2892
2893  Revision 591.83  2002/08/08 02:49:12  ajc
2894  * serv_network.c: retain unknown commands in netconfigs and write them back
2895  * techdoc/netconfigs.txt: specify commands for subscribe/unsubscribe pending
2896  * serv_listsub.c: added (currently a stub)
2897
2898  Revision 591.82  2002/08/06 03:12:14  ajc
2899  * Fixed and clarified "new mail has arrived" messages.
2900
2901  Revision 591.81  2002/08/06 03:02:29  ajc
2902  * ;AE command -- Make it clearer which floor the user is editing
2903
2904  Revision 591.80  2002/08/06 02:58:01  ajc
2905  * Cleaned up the output of digest mode.  It's usable now, but the self-service
2906    subscribe/unsubscribe functions are not there yet.
2907
2908  Revision 591.79  2002/08/05 14:38:11  ajc
2909  * rooms.c: corrected a typo reported by Campagnolo (Mike Poulin)
2910
2911  Revision 591.78  2002/08/03 19:48:40  ajc
2912  * NULLify 'roomrec' before attempting partial match in <G>oto
2913    (fixes heap corruption when this command is executed)
2914
2915  Revision 591.77  2002/08/03 04:13:46  ajc
2916  * citadel_ipc.c: Attempted to clean up memory allocation
2917
2918  Revision 591.76  2002/08/01 05:41:53  ajc
2919  * Completion of (most of) digest mode.  Still needs some polish.
2920
2921  Revision 591.75  2002/07/31 04:01:57  ajc
2922  * Began implementing "digest mode" for listserving.  (Not complete)
2923
2924  Revision 591.74  2002/07/28 20:33:13  ajc
2925  * Augmented the "headers only" functionality of the message reading API (as
2926    well as the options of the server commands which expose it) to allow
2927    headers+body, headers only, or body only.
2928  * Adjusted message output of IMAP command FETCH BODY[1] when message is in
2929    legacy Citadel format.  This fixes a bug exposed by SquirrelMail.
2930
2931  Revision 591.73  2002/07/23 04:00:06  ajc
2932  * Completed the MSGP and MSG4 commands to set the client's preferred MIME
2933    content types, and fetch messages with MIME content types.
2934
2935  Revision 591.72  2002/07/21 22:29:46  ajc
2936  * Added in some infrastructure to switch the client's message reading from
2937    conventional MSG0 to a MIME-download type thing, like WebCit does.
2938
2939  Revision 591.71  2002/07/21 15:45:07  error
2940  * Remove duplicate call for server time in who_is_online(); IPC does this now
2941
2942  Revision 591.70  2002/07/21 15:43:57  error
2943  * citadel_ipc.c: Fix for segfault on empty messages
2944
2945  Revision 591.69  2002/07/20 04:05:10  ajc
2946  * Updated hack.txt with some fresh new information
2947
2948  Revision 591.68  2002/07/19 02:28:11  ajc
2949  * citadel_ipc.c: changed various buffer lengths from 256 to SIZ in order to
2950    accomodate long lines which often spew out (usually from spam unfortunately)
2951
2952  Revision 591.67  2002/07/18 21:29:37  nbryant
2953  added a note about GNU make to the configure script output
2954
2955  Revision 591.66  2002/07/18 20:21:18  ajc
2956  * Eliminated the 512-message limit in the client for reading messages.
2957
2958  Revision 591.65  2002/07/13 04:12:40  ajc
2959  * Don't lie about format types in MSG0 anymore.  We no longer need to.
2960
2961  Revision 591.64  2002/07/13 03:24:32  ajc
2962  * CtdlOutputMsg() caches the most recently fetched message in memory.  This
2963    eliminates the need to do multiple database fetches when we go back for
2964    additional MIME parts, etc.
2965
2966  Revision 591.63  2002/07/11 03:40:51  ajc
2967  * When outputting a multipart MIME message, supply the client with "pref="
2968    and "suff=" lines in addition to the "part=" lines.
2969
2970  Revision 591.62  2002/07/02 16:27:06  error
2971  * prototypes in citadel_ipc.h updated
2972
2973  Revision 591.61  2002/06/29 23:26:55  error
2974  * fixed some memory leaks
2975
2976  Revision 591.60  2002/06/29 18:36:31  error
2977  * tools.c: Massively faster versions of extract_token() and remove_token().
2978    These functions can now handle multi-kilobyte sized strings with hundreds
2979    of tokens (or more?).
2980
2981  Revision 591.59  2002/06/29 15:55:07  error
2982  * Convert whobbs, serv_info, misc. functions to new IPC code
2983
2984  Revision 591.58  2002/06/27 03:10:04  error
2985  * rooms.c: converted most functions to new IPC code
2986
2987  Revision 591.57  2002/06/25 15:38:52  error
2988  * fixed bug in dotgoto() causing free() to segfault
2989
2990  Revision 591.56  2002/06/25 15:13:27  error
2991  * gotonext() now uses new IPC code to retrieve room listing
2992
2993  Revision 591.55  2002/06/25 14:21:35  error
2994  * remove a debugging trap I accidentally left in the code
2995
2996  Revision 591.54  2002/06/24 20:17:43  error
2997  * Fixed code for client segfault at login
2998
2999  Revision 591.53  2002/06/24 20:11:00  error
3000  * Buffer overflow fixes and minor cleanup in IPC code
3001
3002  Revision 591.52  2002/06/24 16:07:42  error
3003  * Message reading and other functions which use the fmout() screen
3004    formatter now use the new IPC code.
3005
3006  Revision 591.51  2002/06/22 20:09:16  error
3007  * Use a new IPC API (in citadel_ipc.c).  Partially converted citadel.c to
3008    use the new API.
3009
3010  Revision 591.50  2002/06/21 12:32:48  ajc
3011  * Minor documentation update
3012
3013  Revision 591.49  2002/06/19 21:52:13  ajc
3014  * Support a transient room create as well
3015
3016  Revision 591.48  2002/06/19 21:42:57  ajc
3017  * Added support for "transient goto" which allows entry into a private and/or
3018    zapped room without putting the room [back] on your known rooms list.  This
3019    is useful for the new administrative functions in WebCit (updating a user's
3020    vCard without the Aide suddenly having that user's config room on their
3021    list).
3022
3023  Revision 591.47  2002/06/18 16:34:06  error
3024  * room_ops.c: Fix for old room record not being deleted when renaming
3025    baseroom or aideroom
3026
3027  Revision 591.46  2002/06/16 21:01:11  ajc
3028  * Allow Aides to create rooms in other users' namespaces (if global access
3029    controls allow)
3030
3031  Revision 591.45  2002/06/15 20:48:50  ajc
3032  * Fixed small bug in the e<X>pert mode toggle
3033
3034  Revision 591.44  2002/06/15 20:14:55  ajc
3035  * Fixed a memory allocation bug in the vCard parser
3036
3037  Revision 591.43  2002/06/15 17:53:59  error
3038  * citserver.c: MESG command can now send a different system message based
3039    on the developer and client ID of the connected client
3040
3041  Revision 591.42  2002/06/15 04:52:26  ajc
3042  * SpamAssassin connector is now configurable in <.A>ide <S>ysconfig <I>nternet.
3043  * Allow more than one SA server (it'll try 'em all)
3044  * Don't run SA for logged in users
3045
3046  Revision 591.41  2002/06/14 20:42:56  ajc
3047  * Discovered that spamd works even without the Content-length: command, so I
3048    was able to redo the spam checker to work without a temp file.
3049
3050  Revision 591.40  2002/06/14 20:37:03  ajc
3051  * Disabled the spam strings checker I wrote a few days ago.
3052  * When receiving SMTP, check to see if spamd (the SpamAssassin daemon) is
3053    running on the local machine.  If yes, run the message through it and
3054    reject if spam.
3055
3056  Revision 591.39  2002/06/12 03:42:21  ajc
3057  * "Suppress message prompts" has been changed to "Prompt after each message"
3058    and of course the effect has been reversed.
3059  * "Be unlisted in userlog" has been moved to the end of the list of
3060    configuration prompts, so it doesn't interrupt the flow of thought regarding
3061    the prompting questions.
3062
3063  Revision 591.38  2002/06/10 22:25:25  ajc
3064  * Configuration for spam filter
3065
3066  Revision 591.37  2002/06/09 23:59:38  ajc
3067  * Started working on the spam filter
3068
3069  Revision 591.36  2002/06/07 22:10:51  ajc
3070  * Added a new message function hook type EVT_SMTPSCAN which permits modules to
3071    register hooks that can scan incoming SMTP messages and elect to reject them
3072    (due to virus or spam content, for example).
3073
3074  Revision 591.35  2002/06/07 03:22:13  ajc
3075  * Added a module "serv_mrtg" which allows activity reporting to MRTG
3076    (http://www.mrtg.org) -- this will replace our stats program.
3077
3078  Revision 591.34  2002/06/02 16:42:17  error
3079  * Support for Ctrl-W to erase a word when editing or at a prompt
3080
3081  Revision 591.33  2002/05/31 18:34:04  nbryant
3082  better curses compatibility, and a couple makefile/configure tweaks
3083
3084  Revision 591.32  2002/05/28 13:59:02  ajc
3085  * Removed the 'netsetup' and 'dnetsetup' utilities (obsolete)
3086
3087  Revision 591.31  2002/05/24 19:58:13  ajc
3088  * Fixed the "idle timeout during paginator prompt" bug by reintroducting the
3089    concept of a "half keepalive" and sending them during paginator prompts.
3090
3091  Revision 591.30  2002/05/23 03:33:21  ajc
3092  * Added a GTSN (GeT list of SeeN messages) command
3093
3094  Revision 591.29  2002/05/20 14:29:59  ajc
3095  * commands.c: fixed bug in the scan for idle_threshold= which didn't include
3096    the = sign and ended up always setting this value to 0
3097
3098  Revision 591.28  2002/05/17 03:57:30  ajc
3099  * When doing fixed_output() of converted HTML, output the whole block of
3100    data at once instead of one character at a time
3101
3102  Revision 591.27  2002/05/16 04:44:58  ajc
3103  * Reduce the number of socket writes when doing fixed_output() to avoid
3104    getting killed by overhead.  (Thanks to IO for the insight)
3105
3106  Revision 591.26  2002/05/14 15:25:34  error
3107  * room_ops.c: clarified aide message when room aide is removed
3108
3109  Revision 591.25  2002/05/14 15:18:43  error
3110  * rooms.c: Print name of room aide if any when doing <i>nfo
3111
3112  Revision 591.24  2002/05/14 01:33:18  error
3113  * Fixed some incredibly silly typos
3114
3115  Revision 591.23  2002/05/14 01:27:18  error
3116  * Minor cosmetic changes, extraneous double spaces etc.
3117
3118  Revision 591.22  2002/05/14 01:15:54  error
3119  * Idle threshold on the who list is now customizable in the citadel.rc
3120
3121  Revision 591.21  2002/05/14 01:09:57  error
3122  * citadel.c: spacebar won't read New if there are no new messages
3123
3124  Revision 591.20  2002/05/12 23:00:11  ajc
3125  * Removed an unused variable
3126
3127  Revision 591.19  2002/05/12 22:57:04  ajc
3128  * Removed the unfinished moderation system.
3129  * CtdlForEachMessage() - only fetch metadata when hunting for messages with
3130    a specified Content-type.  Serious performance boost.
3131
3132  Revision 591.18  2002/05/05 17:33:09  error
3133  * screen.c: fix lack of beeps in curses mode
3134
3135  Revision 591.17  2002/05/04 02:58:16  ajc
3136  * Documented a small protocol change for the STEL command
3137
3138  Revision 591.16  2002/04/30 03:13:59  ajc
3139  * When sending a page that results in the receiver's Sent/Received Pages>
3140    room to be created, don't automatically grant the sender access to that room.
3141  * Added a parameter to create_room() to implement the above
3142
3143  Revision 591.15  2002/04/23 13:38:08  ajc
3144  * Minor docs update
3145
3146  Revision 591.14  2002/04/21 21:28:06  ajc
3147  * Create the My Citadel Config> room along with the user account
3148
3149  Revision 591.13  2002/04/20 03:00:01  ajc
3150  * One more fix for the RENAME command wrt namespaces.
3151
3152  Revision 591.12  2002/04/18 18:44:36  nbryant
3153  don't use libtool -avoid-version for libcitserver - this might help for
3154  OpenBSD
3155
3156  Revision 591.11  2002/04/17 04:35:06  ajc
3157  * Finished the IMAP RENAME command.  (I ended up using nested functions
3158    because it made the task much, much easier.  We can fix it later or convert
3159    it to C++ if we find this becomes a problem.)
3160
3161  Revision 591.10  2002/04/15 13:25:47  ajc
3162  * Add error responses to imap_rename() and set up subfolder framework
3163
3164  Revision 591.9  2002/04/14 22:42:49  ajc
3165  * Began implementing RENAME command in IMAP.
3166
3167  Revision 591.8  2002/04/14 22:27:05  ajc
3168  * Added access control checking to CtdlRenameRoom()
3169
3170  Revision 591.7  2002/04/14 22:11:22  ajc
3171  * New back end function CtdlRenameRoom() which is used to rename a room and/or
3172    move it to a different floor.
3173  * cmd_setr() now uses CtdlRenameRoom() to do part of its work
3174
3175  Revision 591.6  2002/04/10 03:58:40  ajc
3176  * Began work on IMAP RENAME
3177
3178  Revision 591.5  2002/04/09 14:26:43  ajc
3179  * Allow INBOX to have subfolders.  There's no longer any reason not to.
3180
3181  Revision 591.4  2002/04/05 22:31:59  error
3182  * Send time-of-day with pages sent via IMAP
3183
3184  Revision 591.3  2002/04/05 14:34:02  ajc
3185  * Minor tweak to nested folder algorithm to handle nesting in mail root
3186
3187  Revision 591.2  2002/04/05 04:25:56  ajc
3188  * Support nested folders in IMAP.  We might want to change the delimiter.
3189
3190  Revision 591.1  2002/04/04 23:25:30  ajc
3191  * Experimental hacking to handle subfolderization in IMAP.  Seems to work ok
3192    but it makes Mozilla mail hang.  Will investigate more later...
3193
3194  Revision 591.0  2002/04/01 05:13:20  ajc
3195  * Tagged everything for 5.91 release
3196
3197  Revision 590.168  2002/04/01 05:12:57  ajc
3198  * Prep for 5.91 release
3199
3200  Revision 590.167  2002/03/29 04:43:15  ajc
3201  * Removed the BMBX command.  Mailbox security update now runs automatically when the
3202    server starts and it sees data files version <5.91.
3203
3204  Revision 590.166  2002/03/26 05:58:35  nbryant
3205  don't check for a database driver until after the openssl check is
3206  complete. if the ld paths aren't set up for the db installation this
3207  can interfere with the openssl check because it tries to run a program
3208  linked against the libraries we've been finding.
3209
3210  Revision 590.165  2002/03/26 05:20:46  nbryant
3211  removed last vestiges of "#ifdef CIT_CLIENT" conditional compilation,
3212  which has been rendered unusable by the build system simplifications
3213
3214  Revision 590.164  2002/03/26 05:13:32  nbryant
3215  fix monstrous shell script syntax in configure.ac
3216
3217  Revision 590.163  2002/03/26 04:38:31  nbryant
3218   * support autoconf 2.53
3219   * make a note that people should be using libtool 1.4d
3220   * cut some of the more pointless bells and whistles out of the configure
3221     script in an effort to make it more maintainable
3222   * modularized ipc_c_tcp.c and client_crypto.o so that they're not tied
3223     to the curses stuff.
3224   * timezone/daylight and other FreeBSD fixes
3225   * more effort in the configure script to detect the common
3226     bastardizations (ahem, ports) of Berkeley DB without falling down
3227
3228  Revision 590.162  2002/03/25 03:09:39  nbryant
3229  fix warning on platforms where pthread_t may be a pointer
3230
3231  Revision 590.161  2002/03/25 00:01:50  nbryant
3232   * compatibility with Berkeley DB < 3.3
3233   * squished symbol clashes with the OK symbol from curses in certain *n[iu]x
3234  distributions. this is kind of a pain in the ass, but I had to rename our
3235  OK to CIT_OK :-(
3236
3237  Revision 590.160  2002/03/22 04:35:38  ajc
3238  * Handle vCard registration updates for users other than the one currently
3239    logged in.  (Allows administrative editing of contact information.)
3240
3241  Revision 590.159  2002/03/20 19:03:27  ajc
3242  * Don't re-declare timezone variables ('cuz FreeBSD chokes on that)
3243
3244  Revision 590.158  2002/03/19 04:34:42  ajc
3245  * mime_parser.c: minor changes for easier porting between Citadel and WebCit
3246
3247  Revision 590.157  2002/03/19 04:19:33  ajc
3248  * Saw what IO did with strchr() and did the same in a few more places
3249
3250  Revision 590.156  2002/03/17 00:08:02  error
3251  * mime_parser.c: more robust parsing of Content-Type header
3252
3253  Revision 590.155  2002/03/16 05:22:59  ajc
3254  * Post an error message to Aide> when unlink() is unable to delete old
3255    database log files.
3256
3257  Revision 590.154  2002/03/14 04:35:26  nbryant
3258  avoid symbol clash with curses' "timeout" function (which may be a macro
3259  in some versions)
3260
3261  Revision 590.153  2002/03/14 04:24:20  nbryant
3262  support window resizing in curses mode
3263
3264  Revision 590.152  2002/03/13 04:11:11  nbryant
3265  fix up minor gotcha introduced by fgets change
3266
3267  Revision 590.151  2002/03/13 03:58:29  ajc
3268  * Site-configurable option "Allow system Aides to gain access to mailboxes"
3269
3270  Revision 590.150  2002/03/13 03:34:38  nbryant
3271  /* when running in curses mode, the scroll bar in most
3272     xterm-style programs becomes useless, so it makes sense to
3273     pause after a screenful of pages if the user has been idle
3274     for a while. However, this is annoying to some of the users
3275     who aren't in curses mode and tend to leave their clients
3276     idle. keepalives become disabled, resulting in getting booted
3277     when coming back to the idle session. but they probably have
3278     a working scrollback in their terminal, so disable it in this
3279     case:
3280   */
3281  if (!is_curses_enabled())
3282         lines_printed = 0;
3283
3284  Revision 590.149  2002/03/12 23:34:37  nbryant
3285  use ncurses in preference to curses if it's installed; it handles
3286  background colors properly on dtterm, has a larger color pair palette,
3287  and has a bigger terminal database than solaris curses
3288
3289  Revision 590.148  2002/03/12 22:47:17  nbryant
3290  curses fix: map our normal color pairs into the 0-7 range instead of 1-8,
3291  in order to make our pairs fit on terminals such as dtterm where COLOR_PAIRS=8.
3292  map the white/blue color pair onto 8 instead of 9, but only if that slot
3293  is available; fall back on white/black otherwise.
3294
3295  it seems there may be an off-by-one error in the color pair manpages for
3296  the various curses packages (?) if not, our 0 entry is unusable, but that's
3297  the DIM_BLACK color and we don't use it anyway.
3298
3299  Revision 590.147  2002/03/12 22:17:20  ajc
3300  * Give mailbox owners access to "who knows room" command
3301
3302  Revision 590.146  2002/03/12 21:08:03  nbryant
3303  support color under Solaris curses
3304
3305  Revision 590.145  2002/03/12 19:59:40  ajc
3306  * Access control change: do not treat mailboxes as guessname rooms for Aides.
3307    Open up INVT/KICK commands to non-Aides for their mailboxes.
3308
3309  Revision 590.144  2002/03/12 04:30:52  nbryant
3310  if a filesystem node exists at /var/run/egd-pool, try to connect to it as
3311  the EGD (Entropy Gathering Daemon) or PRNGD (pseudorandom number
3312  generator daemon) socket and seed OpenSSL's RNG.
3313
3314  this is necessary on solaris and other systems which lack /dev/urandom.
3315
3316  Revision 590.143  2002/03/12 03:43:26  nbryant
3317  squished the last remaining calls to sprintf
3318
3319  Revision 590.142  2002/03/12 03:36:55  nbryant
3320  replace calls to gets with fgets
3321
3322  Revision 590.141  2002/03/12 03:19:09  nbryant
3323  more sprintf bashing. now the only ones left are in mime_parser
3324
3325  Revision 590.140  2002/03/12 01:33:42  nbryant
3326   - pass -Wcast-qual to gcc
3327   - more sprintf bashing
3328
3329  Revision 590.139  2002/03/12 00:03:43  nbryant
3330  more sprintf removals
3331
3332  Revision 590.138  2002/03/11 06:00:21  nbryant
3333  use <db.h> before <db3/db.h> or <db4/db.h>
3334  this is the only way i can think of to make it work everywhere; people on
3335  systems like FreeBSD where the ports work the other way around will have to
3336  specify an extra -I flag in their CPPFLAGS variable.
3337
3338  Revision 590.137  2002/03/11 05:42:46  nbryant
3339  removed all references to sprintf from several files (not all files yet)
3340  and replace with snprintf
3341
3342  Revision 590.136  2002/03/11 04:16:20  nbryant
3343  warning fixes on sparc-sun-solaris2.8 with gcc 3.0.4, mostly for *printf
3344  format strings
3345
3346  Revision 590.135  2002/03/11 03:55:24  nbryant
3347   - fixes for building without OpenSSL
3348   - setenv doesn't exist on all systems, use putenv instead
3349   - support Solaris' curses implementation
3350
3351  Revision 590.134  2002/03/09 22:52:04  ajc
3352  * Applied a patch submitted by <xperc@hotmail.com> to fix a potential buffer
3353    overflow problem in lprintf().  I also did the same fix to cprintf().
3354
3355  Revision 590.133  2002/03/09 16:47:57  ajc
3356  * Added BMBX to fix a problem
3357
3358  Revision 590.132  2002/03/09 06:18:37  ajc
3359  * one more tweak
3360
3361  Revision 590.131  2002/03/09 05:22:29  ajc
3362  * this should do it.
3363
3364  Revision 590.130  2002/03/09 05:02:20  ajc
3365  * Attempts to fix the access control crap
3366
3367  Revision 590.129  2002/03/08 05:42:02  ajc
3368  * Patch to allow invitations and admin access to mailbox rooms.  NEEDS TESTING!
3369
3370  Revision 590.128  2002/03/07 04:30:37  ajc
3371  * Force recipient only in Mail>, not in all mailbox rooms
3372
3373  Revision 590.127  2002/03/05 22:45:40  error
3374  * Autoconf fixes for DB4 support
3375
3376  Revision 590.126  2002/03/05 04:47:49  ajc
3377  * vcard.c: another API update
3378
3379  Revision 590.125  2002/03/04 05:29:39  ajc
3380  * Made a small API change to vcard.c for WebCit, brought the change over here too
3381    in order to keep vcard.c identical everywhere.
3382
3383  Revision 590.124  2002/03/03 06:48:25  ajc
3384  * Client and server options to disable self-service user account creation
3385
3386  Revision 590.123  2002/03/03 06:31:58  ajc
3387  * Added password starred-out entry to newprompt() and strprompt()
3388  * Applied the above setting to password set/change in <.A>ide <U>seredit
3389
3390  Revision 590.122  2002/03/03 06:18:45  ajc
3391  * Implemented the CREU server command to administratively create user accounts
3392  * Added the ability to create new user accounts to <.A>ide <U>seredit
3393
3394  Revision 590.121  2002/03/03 06:05:16  ajc
3395  * Split up some of the code in order to prepare for user accounts to be
3396    administratively created without logging in to them.
3397
3398  Revision 590.120  2002/03/02 05:56:48  ajc
3399  * Properly implemented the network filter list.  Finished the server module and
3400    did a client-side <.A>ide <S>ysconfig <F>ilterlist command.
3401
3402  Revision 590.119  2002/03/01 04:24:20  ajc
3403  * Cosmetic change to Received: line
3404
3405  Revision 590.118  2002/03/01 04:16:22  ajc
3406  * CtdlReadMessageBody() -- fixed bug that caused the prepend buffer to be
3407    discarded instead of prepended.  "Received:" lines now work.
3408
3409  Revision 590.117  2002/02/23 19:20:51  ajc
3410  * Do the use table purge in two phases to avoid crashy crashy
3411
3412  Revision 590.116  2002/02/20 22:42:19  ajc
3413  * Started adding better management of source IP addressses in SMTP service
3414
3415  Revision 590.115  2002/02/15 04:28:57  ajc
3416  * Wrote the expire/purge routine for the new use table
3417
3418  Revision 590.114  2002/02/15 04:05:08  ajc
3419  * Began implementation of a networker use table that doesn't chew up oodles
3420    of CPU time.  (It uses a cdb instead.)
3421
3422  Revision 590.113  2002/02/15 03:40:06  ajc
3423  * Stu's changes (which he checked in without making any ChangeLog comments,
3424    bad Stu!) didn't build properly without curses.  Added #ifdef's.
3425
3426  Revision 590.112  2002/02/13 22:15:10  ajc
3427  * That was stupid.
3428
3429  Revision 590.111  2002/02/13 22:04:11  ajc
3430  * added vcard_to_html() function
3431
3432  Revision 590.110  2002/02/13 15:48:55  ajc
3433  * Allow the READ command to return packets bigger than 1 byte.  (ooops!)
3434
3435  Revision 590.109  2002/02/12 20:15:25  ajc
3436  * Threw in a few more #ifdef's so the client build doesn't barf on
3437    non-curses systems
3438  * Added rc_prompt_control (<N>ext/<S>top active at paginator: on/off/user)
3439
3440  Revision 590.108  2002/02/11 15:52:10  ajc
3441  * Don't crash when deleting "purge this vCard" messages
3442
3443  Revision 590.107  2002/02/10 22:36:41  nbryant
3444   - replace cdb_trunc with a complete version of the code i had been
3445     working on; fallback code for db < 3.3.x needed
3446   - change 'can't connect to host.port' to 'can't connect to host:port'
3447
3448  Revision 590.106  2002/02/08 22:39:08  ajc
3449  * If there's already a Subject line in memory, display it below the usual
3450    headers when the user hits <E>
3451
3452  Revision 590.105  2002/02/08 22:36:23  ajc
3453  * Changed the logic for printing RFC822 addresses (again)
3454  * Implemented cdb_trunc() in database_sleepycat.c, using db_truncate()
3455    (We need to either provide an alternative implementation or require DB >=3.3)
3456  * Automatically Re: subject line in the client where appropriate
3457
3458  Revision 590.104  2002/02/08 19:02:25  ajc
3459  * Added client and server side support for entering Subject lines in
3460    messages when not using RFC822.
3461
3462  Revision 590.103  2002/02/08 18:10:07  ajc
3463  * When outputting a message in non-RFC822 format, don't display an Internet
3464    address if the user is local.
3465
3466  Revision 590.102  2002/02/07 04:42:49  ajc
3467  * Silently refuse to add directory entries for Internet addresses already
3468    belonging to other users.
3469  * cdb_trunc() for CtdlDirectoryInit: implemented for GDBM, stubbed for DB
3470
3471  Revision 590.101  2002/02/05 05:05:53  ajc
3472  * Don't crash when posting if the user doesn't have an Internet directory address
3473
3474  Revision 590.100  2002/02/03 15:29:03  error
3475  * fixed a silly oversight in serv_crypto.c when removing the ETLS command
3476
3477  Revision 590.99  2002/02/03 15:21:48  error
3478  * Remove the ETLS command, it is no longer needed
3479
3480  Revision 590.98  2002/02/02 21:44:04  ajc
3481  * If a user has at least one valid Internet directory address, stamp it onto
3482    any outgoing messages.
3483
3484  Revision 590.97  2002/02/01 05:11:26  ajc
3485  * Added a QDIR protocol command to do quick-and-dirty queries of the directory
3486  * In the client, check the directory for conflicts when selecting email addr.
3487
3488  Revision 590.96  2002/01/31 05:13:44  ajc
3489  * When deleting a vCard from the Global Address Book room, remove the
3490    corresponding address in the directory.  (Not tested.)
3491
3492  Revision 590.95  2002/01/30 19:03:41  ajc
3493  * Added a new DeleteFunctionHook type of thing.  These get called when a
3494    message is being deleted from a room.
3495  * When deleting messages from a room, do the AdjRefCount() calls (and now,
3496    the PerformDeleteHooks() calls) in a second pass.  This keeps that stuff
3497    outside of the S_QUICKROOM critical section.
3498
3499  Revision 590.94  2002/01/27 06:39:45  error
3500  * file_ops.c: fixed bug in cmd_read() which could cause server to report
3501    the wrong number of bytes for the client to download
3502
3503  Revision 590.93  2002/01/26 21:33:38  ajc
3504  * More internet addressing and global directory stuff.  I think it's all working now
3505    except for the purging of old entries.
3506
3507  Revision 590.92  2002/01/26 11:02:37  error
3508  * citadel.spec cleaned up
3509
3510  Revision 590.91  2002/01/26 09:23:40  error
3511  * setup now has a silent running mode (-q option) where it silently sets
3512    defaults for everything.  This is intended for use in scripts such as
3513    the RPM packages, eliminating a step from the installation process.
3514
3515  Revision 590.90  2002/01/26 09:19:16  error
3516  * citadel.spec has been completely overhauled, we can make RPMs now!
3517
3518  Revision 590.89  2002/01/26 04:59:57  ajc
3519  * smtp FROM command now validates sender using the validate_recipients() loop
3520    (yeah, it's good for that too) making it directory-aware
3521
3522  Revision 590.88  2002/01/26 04:01:10  error
3523  * Formatter now uses more of the available screen width
3524
3525  Revision 590.87  2002/01/26 03:57:30  error
3526  * Revised status_line() display, it's much more compact now
3527
3528  Revision 590.86  2002/01/26 03:50:26  error
3529  * Better error reporting in connection_died(), kills curses before printing
3530    error message, prints last errno.
3531
3532  Revision 590.85  2002/01/25 05:19:03  ajc
3533  * Greatly simplified the logic for validating recipient addresses for incoming
3534    SMTP.  This logic destroys the whitespace mangling for local names; I will
3535    fix this tomorrow.
3536
3537  Revision 590.84  2002/01/25 04:36:35  ajc
3538  * fixz to allow incoming vCards in the address book to actually get processed
3539
3540  Revision 590.83  2002/01/24 06:52:54  error
3541  * citadel_decls.h: fix unresolved extern errors
3542
3543  Revision 590.82  2002/01/23 05:04:05  ajc
3544  * Add vCards from incoming network messages in the GAB to the directory.
3545
3546  Revision 590.81  2002/01/23 03:39:32  ajc
3547  * Added a new hook type for handling incoming network messages
3548  * Wrote a skeleton module for net filtering
3549
3550  Revision 590.80  2002/01/22 10:46:25  error
3551  * read_message() and fmout() now accept a FILE to which to send their
3552    output; this fixes quoting in the fullscreen client
3553
3554  Revision 590.79  2002/01/20 08:03:43  error
3555  * curses client: use the status line as "input" line in chat mode
3556
3557  Revision 590.78  2002/01/20 07:43:07  error
3558  * serv_chat.c: Server no longer crashes when CHATLOG can't be opened
3559
3560  Revision 590.77  2002/01/20 05:22:07  error
3561  * curses client:  allow goodbye message to be seen on some terminals
3562
3563  Revision 590.76  2002/01/19 16:56:31  error
3564  * Fixed color support, now works when rc_ansi_color is on or auto
3565
3566  Revision 590.75  2002/01/19 15:10:25  error
3567  * Cosmetics for the client status line
3568
3569  Revision 590.74  2002/01/19 11:59:33  error
3570  * A real status line for the text client
3571
3572  Revision 590.73  2002/01/19 10:08:43  error
3573  * fix link for libcitserver.so to tools.o which I broke (oops!)
3574
3575  Revision 590.72  2002/01/19 09:59:08  error
3576  * Full-screen curses support for Citadel text client
3577
3578  Revision 590.71  2002/01/17 20:11:05  nbryant
3579  remove lock.c/lock.h; don't need them for what i was planning after all
3580
3581  Revision 590.70  2002/01/17 10:48:36  error
3582  * cosmetic fixes in the new trace file functionality
3583
3584  Revision 590.69  2002/01/17 10:32:14  error
3585  * lprintf() now logs the session ID for each log entry within a session.
3586    Also SMTP, IMAP, POP3 and Citadel protocol commands are differentiated.
3587
3588  Revision 590.68  2002/01/17 10:16:09  error
3589  * migratenet.c: cygwin fix: include limits.h
3590
3591  Revision 590.67  2002/01/17 10:13:31  error
3592  * serv_ical.c: set expire policy for My Calendar> to manual
3593
3594  Revision 590.66  2002/01/17 07:18:11  ajc
3595  * Changed all "free software" references to "open source" in order
3596    to piss off Richard Stallman
3597
3598  Revision 590.65  2002/01/17 00:22:35  nbryant
3599  added lock.[ch]: recursive read/write locking support. (not actually used yet)
3600
3601  Revision 590.64  2002/01/15 12:41:53  error
3602  * Implement alternate_semantics (see comments in citadel.rc file)
3603
3604  Revision 590.63  2002/01/15 11:07:51  ajc
3605  * vcard.c: updated vCard "object methods" to handle multiple instances of
3606    the same key name when necessary.
3607
3608  Revision 590.62  2002/01/15 06:38:39  error
3609  * Update citadelapi.txt with CtdlUnregister* calls, LogHook calls
3610
3611  Revision 590.61  2002/01/15 06:20:18  error
3612  * Modules can now unregister any of their hooks (though none yet take
3613    advantage of this).
3614
3615  Revision 590.60  2002/01/14 08:49:13  error
3616  * Fixed bug in cmd_cre8() causing protocol to get out of sync when creating
3617    a new room
3618
3619  Revision 590.59  2002/01/13 04:46:31  ajc
3620  * Allow incoming SMTP to relay to other Citadel nodes for whom we are
3621    providing directory service.
3622
3623  Revision 590.58  2002/01/13 04:06:33  ajc
3624  * Repaired the problems I created when moving the_mime_parser()'s variables
3625    from the stack to the heap.  (Hint: sizeof(char *) is 4, not 4096)
3626
3627  Revision 590.57  2002/01/11 15:46:57  error
3628  * Allow users to move/copy messages between personal rooms
3629
3630  Revision 590.56  2002/01/11 04:59:00  ajc
3631  * Finished most of the work for the Global Address Book.
3632
3633  Revision 590.55  2002/01/11 04:37:03  ajc
3634  * More code for the Global Address Book
3635
3636  Revision 590.54  2002/01/11 02:57:35  error
3637  * Don't print **** when sending a page or mail from an anonymous-only room
3638
3639  Revision 590.53  2002/01/10 21:22:37  ajc
3640  * Minor changes for global directory service
3641
3642  Revision 590.52  2002/01/10 04:29:28  ajc
3643  * Minor updates for directory service
3644
3645  Revision 590.51  2002/01/09 23:12:40  ajc
3646  * Allow users to zap mailbox rooms
3647
3648  Revision 590.50  2002/01/09 04:37:32  ajc
3649  * Finished the callback stuff for vCard address extraction
3650
3651  Revision 590.49  2002/01/09 04:05:53  ajc
3652  * Began writing code to harvest Internet e-mail addresses from vCards, and
3653    hacked together a temporary version (and writeup) of the IGAB command.
3654
3655  Revision 590.48  2002/01/08 16:34:22  ajc
3656  * serv_vcard.c: cosmetic cleanup
3657
3658  Revision 590.47  2002/01/06 22:44:21  error
3659  * Enable/disable encryption in client from command line and/or citadel.rc
3660
3661  Revision 590.46  2002/01/06 21:25:26  ajc
3662  * sysdep.c: in client_write(), handle redirect_fp and redirect_sock *before*
3663    handling redirect_ssl, because these need to be done the same way regardless
3664    of client session crypto
3665  * serv_crypto.c: pasted a bunch of Nathan's #ifdef blocks from sysdep.c in
3666    order to gain greater portability (or even to get it to compile on splorph)
3667
3668  Revision 590.45  2002/01/06 11:13:33  error
3669  * Enable SSL/TLS support in the client (again)
3670
3671  Revision 590.44  2002/01/06 11:11:31  error
3672  * Enable SSL/TLS in the client
3673
3674  Revision 590.43  2002/01/06 10:49:55  error
3675  * Add some #includes I apparently somehow missed
3676
3677  Revision 590.42  2002/01/06 10:33:10  error
3678  * SSL/TLS support for the Citadel wire protocol
3679
3680  Revision 590.41  2002/01/06 08:54:58  error
3681  * user_ops.c: fixed become_session() when calling EVT_LOGOUT session hooks
3682
3683  Revision 590.40  2002/01/05 22:31:22  ajc
3684  * Removed some protocol commands and writeups that are no longer necessary
3685  * Began some of the framework for the Global Address Book
3686
3687  Revision 590.39  2002/01/05 12:44:43  error
3688  * serv_chat.c: allow a session to be killed while in chat
3689
3690  Revision 590.38  2002/01/05 12:31:04  error
3691  * user_ops.c: become_session() when calling EVT_LOGOUT session hooks
3692
3693  Revision 590.37  2002/01/05 04:51:36  error
3694  * stats now sorts its top 20 lists properly
3695
3696  Revision 590.36  2002/01/04 20:57:36  nbryant
3697  cygwin fix
3698
3699  Revision 590.35  2002/01/04 20:46:26  nbryant
3700  Makefile fix for cygwin (fix migratenet linkage)
3701
3702  Revision 590.34  2002/01/04 20:43:26  nbryant
3703  configure/genstamp: check for struct tm.tm_gmtoff
3704
3705  Revision 590.33  2002/01/03 22:01:17  ajc
3706  * Fixed mail to "sysop"
3707
3708  Revision 590.32  2002/01/03 21:35:07  ajc
3709  * I think this is the last of the fixes for the new submit queue.
3710
3711  Revision 590.31  2002/01/03 12:27:35  error
3712  * Fixed my name in docs/copyright.txt, why didn't I notice that before?
3713
3714  Revision 590.30  2002/01/03 12:21:02  error
3715  * Autoconf support for recognizing OpenSSL
3716
3717  Revision 590.29  2002/01/03 04:52:28  ajc
3718  * serv_network.c: migrated deliveries and bounces to the new message
3719    submission subsystem.  NOT TESTED.
3720
3721  Revision 590.28  2002/01/01 21:32:10  ajc
3722  * Finished the updates to serv_smtp.c, although I think there may be a
3723    problem with one-too-many reference counts when a message is submitted
3724    via SMTP.
3725
3726  Revision 590.27  2001/12/31 20:15:13  ajc
3727  * Almost finished converting serv_smtp.c to the new message submission
3728    framework.  Still not done yet; don't use this.
3729
3730  Revision 590.26  2001/12/30 06:20:46  error
3731  * More keys while reading messages:  Q or S same as Ctrl-C, N same as Ctrl-O.
3732
3733  Revision 590.25  2001/12/30 05:50:46  error
3734  * Security:  Citadel now drops privileges when called from telnetd, also
3735    checks to make sure you didn't set the setuid/setgid bits.  No more
3736    loginwrapper.sh!
3737
3738  Revision 590.24  2001/12/29 05:19:32  ajc
3739  * Minor cosmetic hack
3740
3741  Revision 590.23  2001/12/29 04:21:22  nixo
3742  stupid me. I didn't realize that asking for the header did what I wanted
3743  so I changed my little 'y' hack to not bother reading the text of the
3744  message. a little saving on the bandwidth.
3745
3746  Revision 590.22  2001/12/28 22:32:38  nixo
3747  Added a "read m<y> next" function in read mode. It will skip to the next
3748  message by the user in the current message list (whatever mode you're in
3749  be it read forward, last 50, whatever.)
3750
3751  Revision 590.21  2001/12/28 11:06:53  error
3752  * More server support for hostnames up to 63 characters (oops I missed a spot)
3753
3754  Revision 590.20  2001/12/28 09:39:10  error
3755  * Client support for hostnames up to 63 characters: truncated at 24 in
3756    short who list, full display in long who list.
3757
3758  Revision 590.19  2001/12/28 09:28:04  error
3759  * Server support for hostnames up to 63 characters
3760
3761  Revision 590.18  2001/12/26 05:01:30  ajc
3762  * Added a new developer ID for Anticlimactic Teleservices
3763
3764  Revision 590.17  2001/12/23 10:00:43  error
3765  * Pages are once again formatted to the caller's screen width.
3766
3767  Revision 590.16  2001/12/23 09:57:47  error
3768  * tools.c: added parameter to fmt_date() to allow for printing the seconds
3769    along with the time, e.g. 12:34 pm or 12:34:56 pm
3770
3771  Revision 590.15  2001/12/20 04:54:26  ajc
3772  * If you paid for this software, someone is ripping you off.
3773
3774  Revision 590.14  2001/12/18 08:24:56  nbryant
3775  more lovely configure tweaks (include paths for db)
3776
3777  Revision 590.13  2001/12/18 06:04:08  ajc
3778  * Moved the buffers in the_mime_parser() from the stack to the heap, because
3779    it was crashing boxen with small stack sizes.
3780
3781  Revision 590.12  2001/12/18 05:54:16  ajc
3782  * Added more load_floorlist() commands to the beginning and end of functions
3783    in the client that manipulate the floor list.  This fixes a bug in which
3784    new floors don't show up right away after being created.
3785
3786  Revision 590.11  2001/12/17 08:14:26  nbryant
3787  restored the checks for /usr/include/db3 and /usr/local/include/db3
3788  in configure.  there are too many variations on db installation; this is
3789  getting messy :-(
3790
3791  Revision 590.10  2001/12/17 08:00:45  nbryant
3792  set the pthreads stack size to 128K because FreeBSD's default of 64K
3793  seems too small. fixes crashes under FreeBSD.
3794
3795  Revision 590.9  2001/12/16 00:50:14  error
3796  * Added usersupp.lastcall to the parameters returned from the PASS/PAS2
3797    commands in logged_in_response().
3798
3799  Revision 590.8  2001/12/14 21:33:18  nbryant
3800  finally changed configure to complain if there's no database driver ;)
3801
3802  Revision 590.7  2001/12/14 08:29:30  error
3803  * Security: trace file is now only readable by owner, since it contains
3804    plain text passwords.
3805
3806  Revision 590.6  2001/12/14 07:04:24  ajc
3807  * Now you can send mail to yourself.  Hi from Stu.
3808
3809  Revision 590.5  2001/12/14 06:58:12  ajc
3810  * Hi from Stu
3811
3812  Revision 590.4  2001/12/13 22:36:30  nbryant
3813  make configure search for /usr/local/BerkeleyDB.4.0
3814
3815  Revision 590.3  2001/12/13 22:29:57  nbryant
3816  make it compile with Berkeley DB 4.0.x
3817
3818  Revision 590.2  2001/12/11 21:31:07  nbryant
3819   - test for -ldb3 before -ldb
3820
3821  Revision 590.1  2001/12/11 20:04:41  nbryant
3822   - fix library flags, includes for portability
3823   - malloc.h is deprecated
3824   - fix genstamp, hopefully
3825   - fix size_t *printf handling for portability
3826
3827  Revision 590.0  2001/12/08 03:31:41  ajc
3828  * THIS IS 5.90
3829
3830  Revision 580.95  2001/12/08 03:30:37  ajc
3831  * Final changes to networking docs for 5.90
3832
3833  Revision 580.94  2001/12/06 05:13:34  ajc
3834  * Added the documentation for room sharing and listserv
3835
3836  Revision 580.93  2001/12/04 05:24:15  ajc
3837  * Added two more bytes to the possible length of shared secrets in networking
3838    due to some legacy support requirements.
3839
3840  Revision 580.92  2001/12/04 05:16:19  ajc
3841  * mime_parser.c: change to memory allocation algorithm ... some badly done
3842    messages were crashing the server
3843
3844  Revision 580.91  2001/12/03 22:48:16  ajc
3845  * ooops.  Look for the QR2_SYSTEM flag in QRflags2, not QRflags.
3846
3847  Revision 580.90  2001/12/03 17:02:50  ajc
3848  * dynloader.c: fixed improperly done declaration and mallok()
3849
3850  Revision 580.89  2001/12/03 04:28:02  ajc
3851  * mime_parser.c: now uses built-in functions to decode base64 and
3852    quoted-printable attachments, instead of piping data to outboard programs.
3853
3854  Revision 580.88  2001/12/03 02:45:46  ajc
3855  * Began implementing some code to handle multiple recipients (but #define'd
3856    it all out because we're approaching a release)
3857
3858  Revision 580.87  2001/12/03 01:50:17  ajc
3859  * When sending mail, copy to the sender's "Sent Items>" room instead of to
3860    the sender's "Mail>" room.
3861
3862  Revision 580.86  2001/12/02 23:36:24  ajc
3863  * On a new system, set the default new user level to 4 instead of 1.
3864
3865  Revision 580.85  2001/12/02 23:27:01  ajc
3866  * Removed references to the old networker from the documentation.  Did not
3867    write any new documentation, so what's there now is kind of sparse.
3868
3869  Revision 580.84  2001/12/02 02:42:55  ajc
3870  * Implemented new room flag QR2_SYSTEM which supresses the room from all
3871    room listings, even for Aides (but it's still gotoable).  This will be used
3872    for rooms which hold system configuration and message queues.
3873
3874  Revision 580.83  2001/12/01 19:23:26  ajc
3875  * clientsocket.c: implement socket timeouts for read operations
3876
3877  Revision 580.82  2001/12/01 17:00:23  ajc
3878  * serv_smtp.c: when multiple MX's are the same preference, randomize them
3879
3880  Revision 580.81  2001/12/01 07:18:28  ajc
3881  * Fixed an SMTP delivery problem that was causing certain classes of
3882    transient errors to cause a message to never be delivered.
3883
3884  Revision 580.80  2001/12/01 05:26:01  ajc
3885  * Added a command "SMTP" to the Citadel protocol, to do some unimportant
3886    utility/diagnostic functions.
3887
3888  Revision 580.79  2001/11/27 17:08:29  ajc
3889  * When calling an external editor, set the environment variable
3890    WINDOW_TITLE to an appropriate value.
3891
3892  Revision 580.78  2001/11/26 03:27:08  ajc
3893  * new algorithm to load the use table
3894
3895  Revision 580.77  2001/11/17 19:55:08  ajc
3896  * Updated some of the documentation
3897
3898  Revision 580.76  2001/11/16 04:43:12  ajc
3899  * Eliminated the sock_puts_crlf() function and ensured that all SMTP client
3900    commands are sent out using a single sock_write() call.  There are broken
3901    SMTP server implementations that can't handle SMTP commands split across
3902    multiple writes.  (Thanks to Andru Luvisi and Ben Mehlman for the idea.)
3903
3904  Revision 580.75  2001/11/15 04:11:30  ajc
3905  * hack.doc: updated to reflect Cit86Net compatibility fields removed from the
3906    file format (since we dumbed down the gateway software)
3907  * ipc_c_tcp.c: removed SOCKS4 support.  Nobody uses it anymore.
3908  * ipc_c_tcp.c: fixed a bug which caused the client to fall back to defaultPort
3909    if a numeric port number was specified instead of a service name
3910
3911  Revision 580.74  2001/11/14 02:59:01  ajc
3912  * Network run frequency is now a site-definable setting
3913
3914  Revision 580.73  2001/11/13 22:05:23  ajc
3915  * Re-introduced the ability to enter IGnet mail into the system.
3916
3917  Revision 580.72  2001/10/29 22:59:22  ajc
3918  * Renamed "SuppMsgInfo" to "MetaData" because that's what it is
3919
3920  Revision 580.71  2001/10/29 16:39:54  ajc
3921  * Finished the migratenet utility (finally).
3922
3923  Revision 580.70  2001/10/28 05:18:51  ajc
3924  * migratenet almost finished
3925
3926  Revision 580.69  2001/10/26 04:26:45  ajc
3927  * more work on the net migrator
3928
3929  Revision 580.68  2001/10/23 03:37:33  ajc
3930  * Threw a few more lines of code into migratenet.c
3931
3932  Revision 580.67  2001/10/20 18:10:50  ajc
3933  * migratenet.c: added (not even close to being finished)
3934
3935  Revision 580.66  2001/10/17 21:07:20  nbryant
3936  further format string cleanups (for i686-linux type sizes)
3937
3938  Revision 580.65  2001/10/17 20:41:07  nbryant
3939   - declare *printf format specifiers if gcc detected
3940   - format string fixes (compiles w/o warnings on alpha osf/1)
3941
3942  Revision 580.64  2001/10/17 19:40:38  nbryant
3943  warning fixes and cleanups for 64-bit machines
3944
3945  Revision 580.63  2001/10/16 20:47:37  nbryant
3946  - backed out -export-dynamic, it doesn't do anything and i've found the real
3947  problem
3948  - remove declaration for make_message
3949
3950  Revision 580.62  2001/10/16 19:18:49  nbryant
3951  backed out that compiler detection change for Tru64. it's not incredibly
3952  important and results in broken autoconf macro expansions.
3953
3954  Revision 580.61  2001/10/16 18:36:33  nbryant
3955  reinstate -export-dynamic for citserver in case libtool decides to build
3956  static libraries (why?)
3957
3958  Revision 580.60  2001/10/16 18:21:53  nbryant
3959  add some explanatory text to bootstrap
3960
3961  Revision 580.59  2001/10/16 17:43:53  nbryant
3962   - further configure tweaks for FreeBSD and Tru64 Unix
3963   - updated to latest libtool configure fragment
3964   - there are two functions named make_message. (?) so declare them both
3965     static.
3966
3967  Revision 580.58  2001/10/16 01:48:55  nbryant
3968  - configury tweaks for a /usr/include/db3 goof and Digital/Tru64 Unix
3969  - #ifdef out inline on non-GCC compilers
3970
3971  Revision 580.57  2001/10/15 19:50:50  ajc
3972  * Fixed a bug in the loopzapper that was corrupting the use table saved copy.
3973  * Post notification in Aide> when the loopzapper catches a message.
3974
3975  Revision 580.56  2001/10/12 22:41:11  ajc
3976  * Wrote the rest of the use table code.  Finished except for a bug.
3977
3978  Revision 580.55  2001/10/10 18:35:12  ajc
3979  * Comments & cosmetics for previous update
3980
3981  Revision 580.54  2001/10/10 17:12:54  ajc
3982  * Bugfix for MSG0 command to properly handle multipart/alternative
3983
3984  Revision 580.53  2001/10/06 21:32:29  ajc
3985  * Finished the concurrency check for network polling.  (Now works both for
3986    polling and being polled.  Severe UUCP deja vu.)
3987
3988  Revision 580.52  2001/10/06 20:28:06  ajc
3989  * Began implementing some concurrency stuff for the networker
3990
3991  Revision 580.51  2001/10/06 19:51:47  ajc
3992  * Stripped the build of obsolete parts of the old networker no longer in use.
3993
3994  Revision 580.50  2001/10/03 20:05:50  ajc
3995  * serv_smtp.c: implement RFC2920 ESMTP "pipelining" extension on the server
3996    side.  (No changes required other than advertising the extension.)
3997
3998  Revision 580.49  2001/10/03 03:15:16  ajc
3999  * Implemented BOUNCE BOUNCE BOUNCE
4000
4001  Revision 580.48  2001/10/02 03:04:30  ajc
4002  * Allow non-Aides to terminate sessions belonging to them
4003
4004  Revision 580.47  2001/09/24 18:55:13  ajc
4005  * Completed migrating the "netpoll" utility into the serv_network module.
4006    Removed this utility.
4007
4008  Revision 580.46  2001/09/21 20:58:25  nbryant
4009  support different log_archive prototype in DB versions prior to 3.3
4010
4011  Revision 580.45  2001/09/20 04:17:10  ajc
4012  * Inbound network authentication working.  Fixed a bug in the split-horizon
4013    algorithm.  Still need to move the 'netpoll' command into the server.
4014
4015  Revision 580.44  2001/09/18 04:05:04  ajc
4016  * Added host/IP and port to node config (client side only)
4017
4018  Revision 580.43  2001/09/17 23:55:45  ajc
4019  * Support for IGnet routing (not tested)
4020
4021  Revision 580.42  2001/09/16 05:44:51  ajc
4022  * serv_smtp.c: instead of doubling delivery retry times unbounded, set a
4023    maximum retry time of SMTP_RETRY_MAX (currently set to 12 hours)
4024
4025  Revision 580.41  2001/09/09 16:19:29  error
4026  * Updated PAM configuration file citadel.pam for Red Hat 7.x.
4027
4028  Revision 580.40  2001/09/09 03:19:38  ajc
4029  * cdb_cull_logs() now removes log files as soon as the log_archive() function
4030    says it's ok to do so.
4031
4032  Revision 580.39  2001/09/08 18:58:38  ajc
4033  * More changes to the new networker.  Added client command for room sharing.
4034
4035  Revision 580.38  2001/09/07 04:05:27  ajc
4036  * You guessed it: still more code for the new networker.
4037
4038  Revision 580.37  2001/09/06 05:47:29  nbryant
4039  check for /usr/include/db3 (for RedHat 6.2; others?)
4040
4041  Revision 580.36  2001/09/06 05:23:14  nbryant
4042  #include fix for glibc 2.1.3
4043
4044  Revision 580.35  2001/09/06 04:02:34  ajc
4045  * A few more updates to the networker
4046
4047  Revision 580.34  2001/09/06 03:32:41  nbryant
4048  build fix for sparc-sun-solaris2.8; i think the dependencies should be
4049  set up properly for all platforms now.
4050
4051  Revision 580.33  2001/09/06 02:55:27  nbryant
4052  build fix for Linux
4053
4054  Revision 580.32  2001/09/06 02:49:22  ajc
4055  * Fixed paste-post mode (<.E>nter <A>scii) to append instead of replace when
4056    the user hits <C>ontinue (bug reported by Stu Mark)
4057
4058  Revision 580.31  2001/09/06 01:26:39  nbryant
4059   - port to Cygwin (DLL support, etc.)
4060   - don't build SMTP module if there's no resolver library (eg on Windows)
4061
4062  Revision 580.30  2001/09/06 00:54:01  nbryant
4063  updated to libtool 1.4.1 and automake 1.5
4064
4065  Revision 580.29  2001/08/29 02:51:25  ajc
4066  * More work on the new networker.
4067
4068  Revision 580.28  2001/08/25 05:04:57  ajc
4069  * Worked a little more on the in-server replacement for netproc
4070
4071  Revision 580.27  2001/08/22 04:18:17  ajc
4072  * Realized that there was lots of similarly broken code in
4073    process_rfc822_addr().  Wrote two new utility functions in tools.c
4074    stripout() and stripallbut() and used them where appropriate.  This should
4075    take care of all possible infinite loops.
4076
4077  Revision 580.26  2001/08/22 03:43:11  ajc
4078  * internet_addressing.c: fixed a bug in process_rfc822_addr() that caused the
4079    server to jump into an endless loop when an e-mail address contained
4080    unbalanced angle brackets.
4081
4082  Revision 580.25  2001/08/15 04:26:02  ajc
4083  * Added split horizon and delete-after-spool to the new networker
4084
4085  Revision 580.24  2001/08/14 02:41:57  ajc
4086  * Began the migration of netproc into part of the serv_network.c module instead
4087    of a standalone program.
4088
4089  Revision 580.23  2001/08/11 22:35:40  nbryant
4090  updated citadel-with-berkeley-db.txt.
4091   - updated build instructions
4092   - improved backup procedures to be safer and more space-efficient.
4093
4094  Revision 580.22  2001/08/11 19:18:41  ajc
4095  * Realized that I am stupid and started implementing server commands to load
4096    and save network configurations, when I had already lovingly implemented the
4097    CONF GETSYS and CONF PUTSYS commands to store arbitrary configuration sets
4098    in the Local System Configuration> room.  Ripped the newer crap out.
4099  * Implemented a skeleton of <.A>ide <S>ysconfig <N>etwork on the client side.
4100
4101  Revision 580.21  2001/08/11 03:51:56  ajc
4102  * Removed the idle timer from the client.  Dialup is dead.
4103
4104  Revision 580.20  2001/08/06 21:33:29  nbryant
4105  made the client fall back on port 504 if there's no /etc/services entry
4106
4107  Revision 580.19  2001/08/05 23:54:14  ajc
4108  * prep for new network node infrastructure
4109
4110  Revision 580.18  2001/08/03 16:53:21  ajc
4111  * Added some more "break" statements to the main switch..case loop in
4112    citadel.c where they were needed.
4113
4114  Revision 580.17  2001/08/03 16:43:53  ajc
4115  * database_sleepycat.c: when running txn_checkpoint(), handle DB_INCOMPLETE
4116    return code as a warning instead of an error worthy of aborting the server.
4117    See http://www.sleepycat.com/docs/api_c/txn_checkpoint.html for explanation.
4118
4119  Revision 580.16  2001/07/30 03:46:14  nbryant
4120  made ForEachUser use a read-only cursor, too. there is now only one piece of
4121  code in Citadel proper (not the database driver) that needs transactions.
4122  that's check_ref_counts; in other words it's the only thing standing in the way
4123  of a clean implementation of retryable transactions.
4124
4125  Revision 580.15  2001/07/29 22:24:04  nbryant
4126   - added a new function to the database interface, cdb_close_cursor().  always
4127  call this when you're finished with a traversal but didn't bother reading all
4128  the way to the end.
4129
4130   - removed several cdb_begin_transaction()/cdb_end_transaction() calls that are
4131  no longer needed because of the read-only cursor support.
4132
4133  Revision 580.14  2001/07/29 20:56:09  nbryant
4134  change ForEachRoom to use read-only cursors by default. it can be overridden to
4135  still use read/write cursors by doing:
4136
4137   cdb_begin_transaction();
4138   ForEachRoom(...);
4139   cdb_end_transaction();
4140
4141  the only place I found where it appears necessary to do so is check_ref_counts,
4142  so this checkin affects that function too.
4143
4144  Revision 580.13  2001/07/29 20:06:33  nbryant
4145  generate symlinks to .libs in modules directory
4146
4147  Revision 580.12  2001/07/28 00:02:50  nbryant
4148  implemented read-only cursors. one of the advantages to these is that
4149  transactions can be avoided; a cursor operation that occurs within a
4150  transaction will often acquire a read lock on every single database page.  in
4151  general, the Sleepycat documentation recommends avoiding transaction-protected
4152  read-only operations where practical. read/modify/write operations can still
4153  be transaction protected, of course.
4154
4155  to use a read-only cursor, call cdb_rewind without a previous call to
4156  cdb_begin_transaction. the DB driver will notice this and prevent the current
4157  thread from modifying data or starting a transaction until the cursor is
4158  closed.
4159
4160  Revision 580.11  2001/07/27 20:45:44  nbryant
4161  libtool has matured a lot since the last time i looked at it (years ago)
4162  so we now use it to handle the details of building shared libraries and
4163  the linker flags for the main executable.
4164
4165  in theory this should bring a lot more portability to the dynloader
4166  subsystem and enable us to do things like transparently detect GNU vs Sun
4167  linkers on solaris, for example
4168
4169  Revision 580.10  2001/07/27 03:29:04  nbryant
4170  missed one thing in the autoconf move
4171
4172  Revision 580.9  2001/07/27 02:57:43  nbryant
4173  support one cursor per database rather than one global cursor
4174
4175  Revision 580.8  2001/07/27 01:32:07  nbryant
4176  remove the automatic transaction demarcation on singleton read operations
4177
4178  Revision 580.7  2001/07/26 21:43:46  nbryant
4179   - move to autoconf 2.52
4180   - random warning fix
4181   - check for db 3.3
4182
4183  Revision 580.6  2001/07/24 13:17:54  ajc
4184  * New UI for mailing list setup
4185  * rooms.c: code cleanup
4186  * docs update
4187
4188  Revision 580.5  2001/07/20 23:48:23  nbryant
4189  fix build on solaris, check default install location for db 3.2, and silence
4190  gcc 3.0
4191
4192  Revision 580.4  2001/07/16 14:24:30  ajc
4193  * Silly cosmetic change to keep the wholist ordered by ascending session number
4194
4195  Revision 580.3  2001/07/13 00:01:36  ajc
4196  * Shuffled around some of the housekeeping loop code
4197
4198  Revision 580.2  2001/07/11 17:01:10  ajc
4199  * database_sleepycat.c: small changes to log messages
4200
4201  Revision 580.1  2001/07/11 04:35:40  nbryant
4202  moved dret initialization in cdb_fetch, just in case
4203
4204  Revision 580.0  2001/07/03 03:07:06  ajc
4205  * THIS IS 5.80
4206
4207  Revision 573.143  2001/07/03 03:06:50  ajc
4208  * Last minute doco update for 5.80
4209
4210  Revision 573.142  2001/07/01 15:44:32  nbryant
4211  configure.in: check for Berkeley DB first.
4212
4213  Revision 573.141  2001/06/27 23:34:30  ajc
4214  * Added some verbage to messages/roomaccess to placate a user who keeps
4215    bitching about privacy policy.
4216
4217  Revision 573.140  2001/06/19 03:41:04  ajc
4218  * Ooops... last_cull needs to be declared static
4219
4220  Revision 573.139  2001/06/19 03:33:19  ajc
4221  * imap_fetch.c: download MIME parts without decoding first.  We like that.
4222  * database_sleepycat.c: added automatic culling of log files which have not
4223    been written to in five days.
4224
4225  Revision 573.138  2001/06/17 19:42:23  nbryant
4226  fix all the <time.h> vs. <sys/time.h> issues, hopefully
4227
4228  Revision 573.137  2001/06/07 03:28:37  ajc
4229  * More tweaks to the MIME parser
4230
4231  Revision 573.136  2001/06/06 15:44:37  ajc
4232  * msgbase.c: output extra newline at end of RFC822 message if necessary to
4233    ensure that 000 termination string appears on a line by itself.
4234
4235  Revision 573.135  2001/06/06 04:22:25  ajc
4236  * Moved memreadline() to tools.c
4237  * internet_addressing.c: fixed conversion of fields to (hopefully) never get
4238    into an active loop when encountering badly formed headers
4239
4240  Revision 573.134  2001/05/27 05:23:03  ajc
4241  * Added a "no new messages" response in the client, displayed when a read
4242    command turns up a zero message count.
4243
4244  Revision 573.133  2001/05/18 20:12:09  ajc
4245  * Fixed bug in mime_parser.c that caused parts to be dropped when the last
4246    boundary was the very last line of the message.
4247  * serv_smtp.c: toned down some of the command response verbage.
4248
4249  Revision 573.132  2001/04/28 04:42:55  ajc
4250  * Updated some of the docs.  Bumped version number to 5.80 in anticipation
4251    of going into a release cycle soon.
4252
4253  Revision 573.130  2001/04/26 03:31:00  ajc
4254  * Finished the implementation of per-message seen/unseen logic, both in the
4255    server proper and in IMAP.  Citadel protocol uses new "seen" command.
4256
4257  Revision 573.129  2001/04/21 04:55:51  ajc
4258  * Began implementation of per-message seen/unseen attribute
4259
4260  Revision 573.128  2001/04/20 03:39:54  ajc
4261  * IMAP LIST/LSUB: made it case insensitive.  Also minor IMAP code cleanup.
4262
4263  Revision 573.127  2001/04/17 00:35:19  cough
4264  * Modified rooms.c in the client so that it would allow inviting into
4265    public rooms.  This is important since there is now a V_LOCKOUT
4266    flag which prevents users who have been kicked from rejoining
4267    a room unless/until you invite them back in.
4268
4269  Revision 573.126  2001/04/16 19:21:14  cough
4270  * Fixed bug in room_ops.c that wasn't allowing aides to goto passworded
4271    rooms without knowing the password.
4272
4273  Revision 573.125  2001/04/14 04:26:44  ajc
4274  * Fixed an unterminated string bug in IMAP APPEND.  Storing messages should
4275    work now.
4276
4277  Revision 573.124  2001/04/10 01:04:10  ajc
4278  * Finished coding IMAP APPEND.  It works, but there's a bug in it somewhere
4279    that is corrupting the memory.
4280
4281  Revision 573.123  2001/04/03 00:47:23  ajc
4282  * Began implementing IMAP APPEND
4283
4284  Revision 573.122  2001/04/01 22:05:44  cough
4285  * *Actually* fixed a botched ChangeLog entry.
4286
4287  Revision 573.121  2001/04/01 22:04:28  cough
4288  * Fixed a botched ChangeLog entry.
4289
4290  Revision 573.120  2001/04/01 22:03:10  cough
4291  * Changed two fclose()s to pclose()s.
4292
4293  Revision 573.119  2001/03/25 11:52:36  error
4294  * serv_pop3.c: Fixed APOP. Now logs in properly. Also cleaned up some non-
4295    RFC-compliant error messages.
4296
4297  Revision 573.118  2001/03/21 05:47:49  ajc
4298  * Added the new IMAP mailbox string compare submitted by Daniel Malament.
4299
4300  Revision 573.117  2001/03/20 01:33:55  ajc
4301  * Added the (\NoInferiors) tag to all rooms listed in IMAP.  This made Mozilla
4302    behave very nicely.
4303
4304  Revision 573.116  2001/03/13 17:19:33  ajc
4305  * support (BODY[HEADER.FIELDS(BLAH BLAH BLAH)]) and HEADER.FIELDS.NOT
4306
4307  Revision 573.115  2001/03/12 01:27:42  ajc
4308  * Implemented SUBSCRIBE and UNSUBSCRIBE commands
4309
4310  Revision 573.114  2001/03/11 23:00:29  ajc
4311  * Mega sexy hack to deliver express messages THROUGH IMAP!  uber coolness!!
4312
4313  Revision 573.113  2001/03/11 22:09:20  ajc
4314  * Replaced the "citlogin" binary wrapper with the "loginwrapper.sh" script.
4315
4316  Revision 573.112  2001/03/11 20:06:53  ajc
4317  * Fixed bug that created incorrect roomnames when sending pages
4318
4319  Revision 573.111  2001/03/11 19:23:32  ajc
4320  * IMAP DELETE command ... also split up access control for room delete cmds
4321
4322  Revision 573.110  2001/03/10 17:29:07  ajc
4323  * Implement proper access control for deleting messages from IMAP
4324
4325  Revision 573.109  2001/03/07 04:02:27  ajc
4326  * Fixed some small IMAP bugs
4327
4328  Revision 573.108  2001/03/06 04:44:00  ajc
4329  * Probable completion of STATUS, COPY, STORE, and EXPUNGE commands in IMAP
4330
4331  Revision 573.107  2001/03/06 03:31:58  nbryant
4332  database-related cleanups and paranoia tests;
4333  fixed a transaction-leak/deadlock problem in cdb_delete;
4334  solved the SIGPIPE mystery (GDB stops on SIGPIPE is all it was)
4335
4336  Revision 573.106  2001/03/05 04:59:31  ajc
4337  * IMAP COPY
4338
4339  Revision 573.105  2001/03/04 23:49:41  ajc
4340  * IMAP EXPUNGE responses -should- be correct now
4341
4342  Revision 573.94  2001/02/20 00:02:56  ajc
4343  * IMAP: implemented the STATUS command (sort of).
4344
4345  Revision 573.93  2001/02/19 22:24:41  ajc
4346  * IMAP server: added untagged, unsolicited server messages for newly arrived
4347    messages, and messages expunged by another session.
4348
4349  Revision 573.92  2001/02/17 05:53:35  ajc
4350  * Repaired the creation of page log rooms in the wrong namespace when the
4351    recipient does not yet have his/her log room created.
4352  * Rewrite "EXPI messages" to run in two passes: one to gather messages to
4353    purge and the next to delete them.  Works better in transactionland.
4354
4355  Revision 573.91  2001/02/14 08:11:27  error
4356  * citadel.rc: added RCS ID (it's about time!)
4357
4358  Revision 573.90  2001/02/14 04:23:54  ajc
4359  * Fixed POP3 server responses ending in \n instead of \r\n as they should be.
4360    This was causing some clients (such as Pine) to lock up.
4361
4362  Revision 573.89  2001/02/13 04:06:14  ajc
4363  * Worked out the remaining bugs in IMAP FETCH for the BODYSTRUCTURE and
4364    BODY[n] data items.  I think.  So much protocol crud, so little time...
4365
4366  Revision 573.88  2001/02/13 01:18:44  ajc
4367  * imap fetch
4368
4369  Revision 573.87  2001/02/12 04:31:34  ajc
4370  * sysdep.c ig_tcp_server() - use IPPROTO_TCP instead of getprotobyname()
4371
4372  Revision 573.86  2001/02/08 04:45:58  ajc
4373  * Fixed namespace problems resulting from the automatic namespece prefixing
4374    added to create_room().  Also added the ability to specify "create a mailbox
4375    but I've already supplied the namespace prefix" for situations where the
4376    namespace isn't that of the logged in user.
4377  * Made the POP3 server response messages slightly less humorous
4378
4379  Revision 573.85  2001/02/06 04:44:12  ajc
4380  * Added a floor listing (complete with \NoSelect flag) to LIST and LSUB
4381
4382  Revision 573.84  2001/02/06 02:09:38  ajc
4383  * citadel.rc: changed the default for local_screen_dimensions to 1, since
4384    Internet users now outnumber dialup users 100 to 0.
4385  * room_ops.c: added a really_create option to create_room().  Also moved the
4386    generation of personal namespace into that function.  MODULE OWNERS PLEASE
4387    CHECK YOUR CALLS TO AVOID MULTIPLE NAMESPACING!!
4388  * room_ops.c: fixed a bug in cgetfloor() that left bad pointers around
4389  * serv_imap.c: finished the CREATE command (finally)
4390
4391  Revision 573.83  2001/02/05 05:20:22  ajc
4392  * Made some changes to functions which translate between Citadel room names
4393    and IMAP folder names.  They're still buggy.
4394
4395  Revision 573.82  2001/02/04 23:17:28  ajc
4396  * Implemented the IMAP CREATE command
4397
4398  Revision 573.81  2001/02/04 02:40:07  ajc
4399  * more imap.  imap sucks.  die crispin die.
4400
4401  Revision 573.80  2001/02/03 10:02:12  error
4402  * serv_ical.c: Verify that objects posted to My Calendar> are of type
4403    text/x-calendar or text/calendar; abort saving if not
4404
4405  Revision 573.79  2001/02/03 09:30:46  error
4406  * serv_ical.c: now creates a My Calendar> personal room, sets attributes
4407
4408  Revision 573.78  2001/02/03 08:21:00  error
4409  * serv_ical.c and serv_ical.h added; skeleton code for now
4410
4411  Revision 573.77  2001/02/02 20:18:18  ajc
4412  * Changed the error message in cdb_delete() to actually *say* cdb_delete
4413    instead of cdb_store.  Useful to know which function failed...
4414
4415  Revision 573.76  2001/02/01 04:08:03  ajc
4416  * IMAP minor change to mailbox name output
4417  * Increased size of buffer in lprintf()
4418
4419  Revision 573.75  2001/01/28 09:50:02  error
4420  * sysdep.c: lprintf() now generates timestamps
4421
4422  Revision 573.74  2001/01/28 07:35:04  error
4423   * serv_bio.c: RBIO now also returns stats about a user, see session.txt
4424
4425  Revision 573.73  2001/01/16 04:03:13  ajc
4426  * yeesh ... more on the IMAP BODYSTRUCTURE
4427
4428  Revision 573.72  2001/01/16 01:51:12  ajc
4429  * imap bodystructure
4430
4431  Revision 573.71  2001/01/16 00:46:40  ajc
4432  * Changed the MIME parser API *again* because we now need the ability to
4433    supply callback functions to be executed before and/or after parsing a
4434    multipart.  (Need this for IMAP BODYSTRUCTURE output.)
4435
4436  Revision 573.70  2001/01/15 23:59:26  ajc
4437  * user_ops.c: reject NULL password in CtdlTryPassword() instead of crashing
4438
4439  Revision 573.68  2001/01/15 20:34:04  ajc
4440  * "Path:" removed for now because it confuses brain-dead Microsoft shitware
4441    into thinking that mail messages are newsgroup messages instead.  When we
4442    add NNTP support back into Citadel we'll have to add code to only output
4443    this field when appropriate.
4444
4445  Revision 573.67  2001/01/15 16:30:31  ajc
4446  * temporary implementation of 901 asynchronous express messages
4447
4448  Revision 573.66  2001/01/14 14:55:39  ajc
4449  * Changed the format of <.W>holist <L>ong
4450
4451  Revision 573.65  2001/01/13 06:40:26  nbryant
4452  merged remaining changes from TRANSACTIONS (using cvs update -j TRANSACTIONS)
4453  which should now be considered closed.
4454
4455  Revision 573.64  2001/01/13 06:12:15  ajc
4456  * Added the ASYN command
4457
4458  Revision 573.63  2001/01/12 22:05:46  ajc
4459  * Fixed a bug that caused bogus wholist lines to be displayed when a non-aide
4460    reads a list containing stealth mode sessions.
4461
4462  Revision 573.62  2001/01/09 05:39:45  ajc
4463  * Merged in code from the TRANSACTIONS branch for testing.
4464
4465  Revision 573.61  2000/12/30 06:17:17  ajc
4466  * Still more work on IMAP.  Damn this is tedious.
4467
4468  Revision 573.60  2000/12/30 04:55:05  ajc
4469  * more buffer size stuff
4470
4471  Revision 573.59  2000/12/27 20:19:51  ajc
4472  * The size constant "256" which shows up everywhere as a buffer size has now
4473    been changed to SIZ.  And, SIZ has been defined now as 1024, not 256, because
4474    we need 1024 byte buffers for most Internet protocols.
4475
4476  Revision 573.58  2000/12/27 05:09:58  ajc
4477  * Added a skeleton IMAP "SEARCH" command (based on the FETCH logic)
4478
4479  Revision 573.57  2000/12/26 03:46:50  ajc
4480  * More IMAP tweaks
4481
4482  Revision 573.56  2000/12/25 22:50:43  ajc
4483  * Added an API function to extract and unfold specific RFC822 fields.
4484  * imap-->fetch-->envelope-->in-reply-to now works
4485  * More robust checking and reporting of temp file errors in the client
4486
4487  Revision 573.55  2000/12/25 20:43:24  ajc
4488  * imap_fetch.c: added support for fetch-->envelope-->from
4489
4490  Revision 573.54  2000/12/20 04:09:24  ajc
4491  * A few memory handling fixes to netproc.
4492
4493  Revision 573.53  2000/12/20 01:57:37  ajc
4494  * netproc.c: added bounds check to fpgetfield()
4495
4496  Revision 573.52  2000/12/19 20:41:55  ajc
4497  * Fixed generation of unique file names for network uploads etc.
4498
4499  Revision 573.51.2.11  2000/12/26 05:30:55  nbryant
4500  remove extraneous transaction around dynamic module initializations. this will
4501  fix the crash on database creation.
4502
4503  Revision 573.51.2.10  2000/12/24 23:00:58  nbryant
4504  clean: also remove parsedate.c
4505
4506  Revision 573.51.2.9  2000/12/20 01:38:42  nbryant
4507  require transactional cursors
4508
4509  Revision 573.51.2.8  2000/12/20 00:30:01  nbryant
4510  release any stale db handles at the end of a server command
4511  (unfinished transactions will be aborted to annoy lazy programmers)
4512
4513  Revision 573.51.2.7  2000/12/19 06:18:27  nbryant
4514  set sched_yield as sleepycat's yield function. this should improve locking
4515  performance.
4516
4517  Revision 573.51.2.6  2000/12/19 02:22:29  nbryant
4518  added automatic transaction start/end on cdb_fetch, cdb_delete, and cdb_store
4519
4520  Revision 573.51.2.5  2000/12/18 03:51:13  nbryant
4521  ditto S_USER_TRANS, S_CALLLOG, and S_HOUSEKEEPING, which are no longer used at
4522  all
4523
4524  Revision 573.51.2.4  2000/12/18 02:49:17  nbryant
4525  removed all references to S_MSGMAIN critical section; it wasn't really needed.
4526  this should make things significantly more scaleable.
4527
4528  Revision 573.51.2.3  2000/12/17 22:12:48  nbryant
4529  reworked shutdown sequence to wait for worker threads to terminate before
4530  checkpointing and closing databases. it is no longer safe to call
4531  master_cleanup() directly to force a shutdown; instead, just set
4532  time_to_die to a nonzero value
4533
4534  Revision 573.51.2.2  2000/12/17 05:06:09  nbryant
4535  added deadlock detection and cleaned up messages
4536
4537  Revision 573.51.2.1  2000/12/16 21:06:59  nbryant
4538  created TRANSACTIONS branch
4539  track cursor and transaction id's in thread-specific data
4540
4541  Revision 573.51  2000/12/14 18:36:34  ajc
4542  * Fixed the "users not in chat" wholist display
4543
4544  Revision 573.50  2000/12/12 18:06:46  ajc
4545  * Removed the transaction stuff (but left the log in).  It wasn't working.
4546
4547  Revision 573.49  2000/12/12 06:19:55  ajc
4548  * Stabilize, dammit!!
4549
4550  Revision 573.48  2000/12/12 04:20:03  ajc
4551  * Made the transaction open/close a global thing, in a frantic attempt to get
4552    Uncensored to stop crashing.  More fixes on the way...
4553
4554  Revision 573.47  2000/12/11 06:08:41  ajc
4555  * Removed the housekeeper thread, moved terminate_idle_sessions() out to a
4556    timer event, and check_sched_shutdown() to the end of the worker thread
4557    loop.  Seems to have improved reliability (but why?)
4558
4559  Revision 573.46  2000/12/11 03:22:11  ajc
4560  * Added server-side REQT command to issue client termination requests
4561
4562  Revision 573.45  2000/12/11 02:19:26  ajc
4563  * Client now honors EM_GO_AWAY flag, used by the server to request that a
4564    client log off.  (The server doesn't support sending that flag yet, though)
4565
4566  Revision 573.44  2000/12/09 06:20:06  ajc
4567  * A few final touches to the Sleepycat DB back-end
4568
4569  Revision 573.43  2000/12/08 17:06:33  ajc
4570  * Wrap txn_begin and txn_end in S_DATABASE mutex
4571
4572  Revision 573.42  2000/12/07 20:21:39  ajc
4573  * begin/end transaction in master_startup()
4574
4575  Revision 573.41  2000/12/07 16:59:02  nbryant
4576  added --with-db and --with-gdbm options to configure
4577
4578  Revision 573.40  2000/12/07 04:50:33  ajc
4579  * Wrap housekeeper and timer events in transaction open/close functions
4580  * Checkpoint the DB as an EVT_TIMER event instead of after each session
4581    (runs each minute, but actually limited by the parameters of the function)
4582
4583  Revision 573.39  2000/12/06 04:44:36  ajc
4584  * Changed netproc to keep the use table in a flat file instead of a database
4585
4586  Revision 573.38  2000/12/05 05:32:58  ajc
4587  * Added support for non-USA country identities in vCard and registration
4588  * User edit now asks whether it should prompt to change the password
4589
4590  Revision 573.37  2000/12/03 04:12:21  ajc
4591  * Finished (mostly) the Sleepycat DB backend ... added transaction logging
4592
4593  Revision 573.36  2000/11/30 03:23:17  ajc
4594  * Got the Sleepycat DB back end working, by opening the databases in a non
4595    shared, non threaded mode, and using Citadel's locking to serialize access.
4596
4597  Revision 573.35  2000/11/29 05:00:02  ajc
4598  * I think the db stuff is ok, but my db library is fux0red...
4599
4600  Revision 573.34  2000/11/27 14:12:09  error
4601  * commands.c: fixups to print_express() to make external command not print
4602    extraneous stuff to the terminal and make the displayed message consistent
4603
4604  Revision 573.33  2000/11/27 10:41:14  error
4605  * print_express(): now uses GEXP instead of old PEXP; displays timestamps
4606
4607  Revision 573.32  2000/11/27 10:29:59  error
4608  * serv_chat.c: fix send_express_message() to include timestamps
4609
4610  Revision 573.31  2000/11/27 03:44:27  ajc
4611  * Initial checkin of database_sleepycat.c (doesn't work yet)
4612
4613  Revision 573.30  2000/11/26 05:24:22  ajc
4614  * msgbase.c: Added new API function CtdlOutputPreLoadedMsg(), and
4615    re-implemented the existing CtdlOutputMsg() as a wrapper around it.
4616  * imap_fetch.c: used the above function to do all output pre-loaded
4617
4618  Revision 573.29  2000/11/25 09:36:18  error
4619  * Added a bit of detail to syslog entries; now shows session id attached to
4620    client, hostname, and username, and time the session ended.
4621
4622  Revision 573.28  2000/11/25 06:17:06  ajc
4623  * Minor IMAP tweaks.  It still doesn't work.  :(
4624
4625  Revision 573.27  2000/11/23 07:22:21  error
4626  * citadel.spec: update version number
4627
4628  Revision 573.26  2000/11/21 11:12:56  error
4629   * domain.h: changed the HP/UX compatibility code to use defines from
4630     typesize.h for integers of specific bit widths (needed for Solaris, etc)
4631
4632  Revision 573.25  2000/11/12 04:20:49  ajc
4633  * Optimized server side input of message text
4634
4635  Revision 573.24  2000/11/10 03:55:06  ajc
4636  * Ford's Fix for Faster Functionality (save position during reply)
4637
4638  Revision 573.23  2000/11/09 04:48:50  ajc
4639  * tools.c: striplt() strips all whitespace, not just spaces
4640
4641  Revision 573.22  2000/11/07 20:47:21  ajc
4642  * imap_fetch.c: added a skeleton "ENVELOPE" fetch.  Currently sends NIL's.
4643
4644  Revision 573.21  2000/11/07 15:54:53  ajc
4645  * xx FETCH n:n BODY[pn.MIME] now works
4646
4647  Revision 573.20  2000/11/06 05:10:01  ajc
4648  * Changed the mime_parser() API (again) to allow "don't decode" mode
4649
4650  Revision 573.19  2000/10/29 18:11:07  ajc
4651  * Start numbering top-level MIME parts as 1, 2... not 1.1, 1.2...
4652
4653  Revision 573.18  2000/10/28 14:14:19  error
4654  * msgbase.c: eliminated most gotos; a single goto in alias() remains because
4655    it actually makes sense to do it that way...
4656
4657  Revision 573.17  2000/10/25 21:37:09  ajc
4658  * Implemented the AUTHENTICATE LOGIN command in IMAP
4659
4660  Revision 573.16  2000/10/25 19:20:37  ajc
4661  * FETCH now works for ranges *and* sets, and with sequence numbers *and* UID's
4662
4663  Revision 573.15  2000/10/24 20:39:59  ajc
4664  * Added RFC822, RFC822.HEADER, RFC822.SIZE, RFC822.TEXT fetch keys to IMAP
4665
4666  Revision 573.14  2000/10/23 20:26:51  error
4667  * War on goto:  rewrote a few easy functions to eliminate unnecessary gotos
4668
4669  Revision 573.13  2000/10/11 23:03:44  error
4670  * utilsmenu: obey $PAGER environment var, if any.  Default to more if neither
4671    $PAGER nor less is available.
4672
4673  Revision 573.12  2000/10/11 22:55:25  error
4674  * citadel.c: when ansi_color=user, enable color at login, so Lobby> posts
4675    displayed at login are in color
4676
4677  Revision 573.11  2000/10/11 22:47:51  error
4678  * domain.c: getmx() returns hostname as MX if no MX records found a la RFC 974
4679
4680  Revision 573.10  2000/10/10 19:18:12  ajc
4681  * Added support of macros ALL, BODY, FAST, and FULL to the IMAP FETCH command
4682
4683  Revision 573.9  2000/10/06 03:31:55  ajc
4684  * IMAP is a convoluted mess.
4685
4686  Revision 573.8  2000/10/05 22:23:16  ajc
4687  * Slowly and painfully writing IMAP support
4688
4689  Revision 573.7  2000/10/04 22:39:06  ajc
4690  * Added skeleton versions of the LIST and LSUB commands to the imap server
4691
4692  Revision 573.6  2000/10/04 17:48:21  ajc
4693  * Allow Aides to zap rooms (site configurable setting)
4694
4695  Revision 573.5  2000/10/03 01:45:00  ajc
4696  * Changed the <.A>ide <S>ysconfig <G>eneral command to explicitly allow the
4697    global page log room to be disabled (answer "no" to set the log room to a
4698    null string)
4699
4700  Revision 573.4  2000/09/28 10:27:38  error
4701  * commands.c: changed stty_ctdl() to support HP/UX termios VMIN and VTIME
4702
4703  Revision 573.3  2000/09/24 22:01:45  ajc
4704  * ipc_c_tcp.c: don't hardcode CTDLDIR path for unix domain sockets
4705
4706  Revision 573.2  2000/09/21 04:16:44  ajc
4707  * Fixed logged_in_response() so it only displays responses during Citadel
4708    protocol sessions.  (This was affecting POP etc.)
4709
4710  Revision 573.1  2000/09/11 22:05:04  ajc
4711  * citadel.c: accept -h <host> and -p arguments, so citadel can be called
4712    directly by telnetd, bypassing /bin/login.  It works, but not recommended at
4713    this time because it has to run as root.
4714
4715  Revision 573.0  2000/09/05 18:35:22  ajc
4716  * Tagged everything for version 5.73 release
4717
4718  Revision 572.39  2000/09/04 03:59:15  ajc
4719  IO's changes:
4720  ----------------------------
4721  revision 572.4
4722  date: 2000/09/03 06:36:01;  author: error;  state: Exp;  lines: +5 -1
4723  Added HP/UX linker flag for dynamic modules to work
4724  ----------------------------
4725  revision 572.3
4726  date: 2000/09/01 06:50:00;  author: error;  state: Exp;  lines: +8 -1
4727  Changed to use integer macros from typesize.h for specific bit widths
4728  ----------------------------
4729
4730  Revision 572.38  2000/09/01 20:17:08  ajc
4731  * msgbase.c: cmd_opna() - increase desired_section buffer from 64 to 256 bytes
4732
4733  Revision 572.37  2000/09/01 17:31:47  ajc
4734  * Fixed oopseth in control.c that might call fileno(NULL)
4735
4736  Revision 572.36  2000/09/01 13:37:16  ajc
4737  * control.c: chown citadel.control to ctdluid when opening/creating as root
4738
4739  Revision 572.35  2000/09/01 03:55:44  ajc
4740  * Fixed a few more references to the deprecated uncnsrd.mt-kisco.ny.us name
4741
4742  Revision 572.34  2000/09/01 03:43:09  ajc
4743  * Added 'author' command-line arg to aidepost.  Closes enhancement request
4744    #71 on bugzilla.
4745  * Put the default SMTP and POP3 ports back to 25 and 110.  Now that the
4746    unix domain socket bug is fixed, it's ok if these binds fail.
4747
4748  Revision 572.33  2000/08/31 23:02:15  ajc
4749  * ig_tcp_server() and ig_uds_server()  -  check to make sure queue length is
4750    always at least 5.  Zero-length queues can cause connection lockups.
4751
4752  Revision 572.32  2000/08/31 21:32:44  ajc
4753  * Still trying to fix a socket connect bug
4754
4755  Revision 572.31  2000/08/31 16:37:08  ajc
4756  * docs/import-export.txt: added.
4757
4758  Revision 572.30  2000/08/28 19:51:51  ajc
4759  * messages.c: cosmetic cleanup (coding convention and comments)
4760
4761  Revision 572.29  2000/08/26 20:23:18  ajc
4762  * Finished up the back end code for mailing list sends.  Sends now work!
4763
4764  Revision 572.28  2000/08/24 02:48:18  ajc
4765  * Merged in IO ERROR's diffs to make Citadel work with HP/UX
4766
4767  Revision 572.27  2000/08/22 02:31:47  ajc
4768  * nonce (for APOP-style auth) is now generated when a context is created
4769    instead of during protocol greeting functions.
4770  * Moved Citadel protocol nonce output from greeting to INFO
4771
4772  Revision 572.26  2000/08/18 21:09:36  ajc
4773  * Added a little more mailing list code to serv_network.c
4774
4775  Revision 572.25  2000/08/10 04:36:25  ajc
4776  * Fixed a bug in keyboard polling (in commands.c) which was causing the
4777    client protocol to get out of sync in certain conditions.
4778
4779  Revision 572.24  2000/08/10 02:42:13  ajc
4780  * Changed all the "200 ok" responses to more descriptive strings
4781  * Added a *temporary* protocol sync check.  Remove this!
4782
4783  Revision 572.23  2000/08/09 17:14:34  ajc
4784  msgbase.c: fixed a bug in
4785             remove_any_whitespace_to_the_left_or_right_of_at_symbol() that was
4786             causing the <R>eply function to fail on names with whitespace in
4787             certain parts of the string.  This closes Bug #56.
4788
4789  Revision 572.22  2000/08/05 04:24:00  ajc
4790  * Added [idle] to client wholist display for sessions idle >15 minutes
4791  * Added a generic "void *userdata" field to CtdlForEachMessage()
4792  * More prep for mailing list handling in the server
4793
4794  Revision 572.21  2000/07/30 04:36:12  ajc
4795  * Set up the SNET (Send NETwork config) and GNET (Get NETwork config) commands
4796    for the network overhaul.
4797
4798  Revision 572.20  2000/07/29 05:29:19  ajc
4799  * Changed the format of RWHO output to provide non-masqueraded user/room/host
4800    names (to Aides only) as additional fields rather than an extra line of
4801    output.
4802  * Changed the client to display new RWHO fields, in the "long" wholist only.
4803  * Default SMTP and POP ports are now -1, not 25/110.  These services must now
4804    be activated manually.
4805
4806  Revision 572.19  2000/07/24 00:39:13  ajc
4807  * Fixed a path problem when calling netmailer from mailinglist.c
4808
4809  Revision 572.18  2000/07/22 03:44:17  ajc
4810  * Prepared infrastructure for the networker rewrite
4811
4812  Revision 572.17  2000/07/17 02:38:08  ajc
4813  * Completed serv_vandelay.c (importer/exporter module)
4814  * sendcommand.c: fix behavior of SEND_LISTING mode
4815  * sysdep.c: client_gets() fill buffer with "000" terminator when returning -1
4816
4817  Revision 572.16  2000/07/14 03:06:55  ajc
4818  * Added .ATN (DOWN) and .ATS (SCDN 1) commands to the client
4819
4820  Revision 572.15  2000/07/10 23:36:08  ajc
4821  * Another attempt to fix the crashy crashy bug in serv_vcard
4822  * Did more work on the Art Vandelay module
4823  * Replaced all instances of sprintf(tempfile, tmpnam(NULL)) with strcpy()
4824
4825  Revision 572.14  2000/07/10 04:01:12  ajc
4826  * added an unfinished serv_vandelay.c (Art Vandelay module - importer/exporter)
4827
4828  Revision 572.13  2000/07/09 02:47:40  ajc
4829  * Overhauled the keepalive logic in the chat client.  Closes bug #20.
4830
4831  Revision 572.12  2000/07/09 02:27:02  ajc
4832  * Eliminated the whole SIGINT/SIGQUIT based handling of Ctrl-O and Ctrl-C
4833    keyboard interrupts.  Replaced with a non-blocking check for keyboard input
4834    which sets the global variable 'sigcaught' if either key was pressed.
4835    fmout() and pprintf() switch to 'drain mode' if sigcaught is set.
4836    This closes Bug #18.
4837
4838  Revision 572.11  2000/07/06 20:26:36  ajc
4839  * updated .Help SUMMARY
4840
4841  Revision 572.10  2000/07/04 20:02:46  ajc
4842  * Fixed potential crashy crashy bug in serv_vcard.c
4843
4844  Revision 572.9  2000/06/28 03:42:56  ajc
4845  * Changed the comments at the beginning of each file to a consistent format
4846  * Improved the parameterization of commands in the IMAP module
4847
4848  Revision 572.8  2000/06/27 01:27:13  ajc
4849  * Coupla very small changes to get on the road to IMAP support
4850
4851  Revision 572.7  2000/06/22 21:41:48  ajc
4852  * Made the ICQ stuff far more reliable ... by removing it!
4853
4854  Revision 572.6  2000/06/21 03:46:20  ajc
4855  * IMAP is now legal but useless, supporting NOOP, LOGIN, and LOGOUT.
4856
4857  Revision 572.5  2000/06/15 20:15:52  ajc
4858  * Inserted a skeleton IMAP module into the build.  IT DOES NOT WORK AT ALL.
4859
4860  Revision 572.4  2000/06/04 02:30:56  ajc
4861  * CtdlForEachMessage() now returns the number of messages processed.  It also
4862    accepts the MSGS_EQ mode, for targeting a specific message number (useful
4863    for determining whether the specified message actually exists in a room).
4864  * Completed the server side of the moderation system (serv_moderate.c module
4865    which implements the MMOD command)
4866
4867  Revision 572.3  2000/06/03 05:47:57  ajc
4868  * Replaced most of the very repetitive and very redundant access level checks
4869    in most commands with a single API call:  CtdlAccessCheck()
4870  * serv_moderate.c: added (not finished)
4871
4872  Revision 572.2  2000/06/02 03:38:50  ajc
4873  * Bind unix socket prior to TCP socket for citadel protocol
4874  * Fixed bug in sendcommand.c which was causing it to crash on attach
4875
4876  Revision 572.1  2000/05/26 19:27:51  ajc
4877  * Changed some of the rev-level sensitive stuff to look at the actual version
4878    of Citadel running, not the last version with which we ran setup
4879  * Added a moderation system.  Default filter level for new users is in the
4880    config file.  Per-user setting is in usersupp.  Moderation level of each
4881    message is in SuppMsgInfo.  Tweaked CONF, GETU, and SETU.  Read filter is
4882    working.  Moderate message up/down commands are not here yet.  See
4883    techdoc/moderation.txt for more info.
4884
4885  Revision 572.0  2000/05/23 02:09:30  ajc
4886  * Updated docs and tagged everything for the 5.72 release
4887
4888  Revision 571.7  2000/05/20 23:28:20  ajc
4889  * Fixed bug in client API that was causing netproc to crash
4890
4891  Revision 571.6  2000/05/15 00:05:19  ajc
4892  * Double the retry interval for SMTP deliveries after each failed attempt.
4893
4894  Revision 571.5  2000/05/11 03:08:47  ajc
4895  * serv_smtp.c: clear the relevant state buffers after an SMTP DATA command
4896    completes, allowing multiple messages in one session.  Closes bug #58.
4897
4898  Revision 571.4  2000/04/24 03:36:43  ajc
4899  * Removed references to strucmp() and struncmp(), replaced them with
4900    strcasecmp() and strncasecmp() as we did in the server a while ago, and
4901    set up the config script to figure out whether they need to be compiled
4902    in.  Also moved them to tools.h
4903  * Wrote a password manager for the client
4904
4905  Revision 571.3  2000/04/19 03:17:10  ajc
4906  * Don't ever expire the Local System Configuration> room
4907
4908  Revision 571.2  2000/04/16 19:03:47  ajc
4909  * Minor changes to avoid host lookup for local clients
4910
4911  Revision 571.1  2000/04/15 19:55:52  ajc
4912  * Fixed "Unvalidated users appear even with registration disabled" bug #36
4913
4914  Revision 571.0  2000/04/13 02:43:24  ajc
4915  * Fixed a problem that crashed the client during <G>oto commands if a room
4916    existed with a name more than 32 characters (thanks to Magus for reporting
4917    this one).
4918  * Tagged everything and updated docs for the 5.71 release
4919
4920  Revision 570.18  2000/04/10 01:47:22  ajc
4921  * More paginator changes.  Shuffled code around, added pagination to a bunch
4922    of other functions, and replaced the old, cumbersome pagination with the
4923    new, easy, API-based one in everything except message output.
4924
4925  Revision 570.17  2000/04/09 17:51:18  ajc
4926  * Added pprintf() (paginated version of printf) to the client-side API.  Now
4927    any client side function can be paginated simply by changing all of the
4928    printf's to pprintf's.  I've already done this for the user list and wholist
4929    (removing the old style pagination) and for "read directory."
4930
4931  Revision 570.16  2000/04/08 04:52:48  ajc
4932  * Another minor stoopid little time display fix
4933
4934  Revision 570.15  2000/04/08 03:58:12  nbryant
4935   * backed out the previous changes since they didn't look good on some
4936     xterms with a blue bold mode. just set the background color to black
4937     instead. this makes black-on-white terminals actually readable, if not
4938     particularly good looking.
4939
4940  Revision 570.14  2000/04/08 01:36:30  nbryant
4941   * citadel.c, commands.c: comment out cls() as this wasn't called if
4942     ansi_color=user anyway, and we have no way of knowing whether the user's
4943     terminal does background color erase, which was the reason for adding this
4944     in the first place. with the recent changes to color(), the display will get
4945     screwed up if they *do* have background color erase. perhaps this is a job
4946     for terminfo.
4947
4948  Revision 570.13  2000/04/08 00:37:42  nbryant
4949   * commands.c: fix color support for black-on-white color terminals such as
4950     CDE's dtterm. this just avoids white-on-white text; some color combinations
4951     such as yellow-on-white still aren't very legible due to contrast. There's
4952     not much I can think to do about that without affecting the look on the
4953     white-on-black terminals which probably account for most users.
4954
4955  Revision 570.12  2000/04/07 20:22:34  ajc
4956  * Fixed am/pm bug in time display
4957
4958  Revision 570.11  2000/04/07 19:22:45  ajc
4959  * For services disabled by setting port number to -1, administratively skip
4960    the bind instead of just allowing it to fail.
4961
4962  Revision 570.10  2000/03/31 04:31:02  ajc
4963  * Quick fix to 'stats' utility to purge records with bogus timestamps
4964
4965  Revision 570.9  2000/03/31 02:10:52  ajc
4966  * Caved in to pressure and enabled <R>eply in public rooms.
4967
4968  Revision 570.8  2000/03/28 03:55:53  ajc
4969  * Modified <.RU> to allow search for partial match
4970
4971  Revision 570.7  2000/03/27 03:08:19  ajc
4972  * Third parameter of CtdlDeleteMessages() now takes "" instead of NULL to
4973    specify 'any MIME type'.
4974
4975  Revision 570.6  2000/03/27 01:14:08  nbryant
4976   * Makefile.in: generate parsedate.c automatically
4977   * configure.in: check for bison/byacc/yacc. bison seems to build cleaner
4978     code.
4979   * parsedate.c: removed from CVS
4980   * parsedate.y: added #include <stdlib.h> so it builds with bison
4981
4982  Revision 570.5  2000/03/27 00:46:10  nbryant
4983   * First cut at Solaris fixes. There may still be some *printf("%s", NULL)
4984     type of issues lurking in the shadows.
4985
4986  Revision 570.4  2000/03/25 18:29:58  nbryant
4987  changed my email address
4988
4989  Revision 570.3  2000/03/23 02:41:50  ajc
4990  *** empty log message ***
4991
4992  Revision 570.2  2000/03/21 03:23:24  ajc
4993  * Experimental new linebreak mode
4994
4995  Revision 570.1  2000/03/20 14:43:19  ajc
4996  * "Brown paper bag" fix for SMTP bug (incoming long fields crash logger)
4997
4998  Revision 570.0  2000/03/19 23:42:34  ajc
4999  * This is the official 5.70 release.
5000
5001  Revision 1.494  2000/03/19 23:04:08  ajc
5002  * Small cosmetic change to date/time output
5003
5004  Revision 1.493  2000/03/19 05:02:39  ajc
5005  * SMTP hacks to deal with AOL braindamage
5006
5007  Revision 1.492  2000/03/18 18:18:04  ajc
5008  * Support multiline responses from SMTP servers when sending mail
5009
5010  Revision 1.491  2000/03/17 16:26:57  ajc
5011  * Set up a private "Sent/Received Pages" room for each user
5012
5013  Revision 1.490  2000/03/17 04:11:24  ajc
5014  * Moved bio-related commands out to a loadable module
5015
5016  Revision 1.489  2000/03/16 17:58:54  smw
5017  Created a docs directory.
5018  Moved install.txt to docs.
5019  Added inetmailsetup.txt (Citadel server side e-mail)
5020  Added inetmailsetupmx.txt (local mail AND Citadel e-mail
5021  Added inetsiteconfig.txt (describes the .asi command)
5022  Added siteconfig.txt (describes .asg)
5023  Added chat.txt (describes changes and new chat functionality)
5024  Made a couple of changes to install.txt (references to new documentation)
5025  Added Steve Williams to copyright.txt as the document writer.
5026
5027 Revision 1.488  2000/03/15 03:04:51  ajc
5028 * Added DEXP server command to disable incoming express messages.
5029 * <Q>uiet mode client side command to set/clear DEXP mode.
5030 * <K>nown rooms list displays through the paginator.
5031
5032 Revision 1.487  2000/03/12 00:21:35  ajc
5033 * Removed the semi-broken "chat room" functionality in the chat system, and
5034   replaced it with direct mapping to the actual Citadel room the user is in.
5035 * Display masqueraded roomname in chat, if applicable.  Fixes bug #19.
5036
5037 Revision 1.486  2000/03/11 21:29:37  ajc
5038 * SM_ flags for CtdlSaveMsgPointerInRoom() need to be a bit bucket, not an
5039   enum, since more than one can be passed.  Changed SM_DONT_BUMP_REF_COUNT
5040   from 3 to 4.  This also fixes bug #33.
5041
5042 Revision 1.485  2000/03/11 20:26:03  ajc
5043 * Reworked the <R>eply logic in messages.c - fixes bug #34
5044
5045 Revision 1.484  2000/03/11 19:22:19  nbryant
5046  * commands.c: improved timing of background keepalives if connection is
5047                lagged
5048
5049 Revision 1.483  2000/03/11 05:08:48  nbryant
5050  * commands.c: oops, that mutex stuff wasn't necessary
5051
5052 Revision 1.482  2000/03/11 04:09:03  nbryant
5053  * new threaded client code for background keepalives
5054
5055 Revision 1.481  2000/03/10 21:40:04  ajc
5056 * Changes to message base and networker to support Internet-style message
5057   ID's instead of the conventional Citadel style.
5058
5059 Revision 1.480  2000/03/08 03:36:37  ajc
5060 * Shut off hostname resolution when dealing with Unix domain sockets
5061 * Cleaned up the 'citmail' MDA tool
5062 * Added POP3 and SMTP port numbers to global system configuration
5063
5064 Revision 1.479  2000/03/07 21:54:58  ajc
5065 * Fixed the naming conventions and permissions for unix domain sockets.
5066
5067 Revision 1.478  2000/03/05 07:33:23  ajc
5068 * Added support for protocols over Unix domain sockets.
5069
5070 Revision 1.477  2000/03/04 22:36:23  ajc
5071 * Remove nulls appended to editor files during replace, edit, and print
5072   operations.  Truncate temp files during same operations.
5073   Closes bugs #6 and #7.
5074
5075 Revision 1.476  2000/03/04 05:29:18  ajc
5076 * Relax restrictions on editing of base rooms.  Renaming is not allowed but
5077   all other attributes can be edited.  Closes feature request #21.
5078 * Sending pages from the client now uses the same message editing functions
5079   as entering messages, allowing edit/abort.  Closes feature request #25.
5080
5081 Revision 1.475  2000/03/03 04:50:14  ajc
5082 * Moved all of the wholist masquerading commands into the serv_rwho module
5083
5084 Revision 1.474  2000/03/03 04:12:37  ajc
5085 * Finished the inbound side of gateway domain service
5086
5087 Revision 1.473  2000/02/27 04:55:51  ajc
5088 * Added "keymenu()" generic menu-maker to commands.c
5089 * Blocked non-numeric input to intprompt()  (fixes bug #16)
5090
5091 Revision 1.472  2000/02/27 03:57:35  ajc
5092 * Completed 'fsck'-like reference count verifier (server and client)
5093
5094 Revision 1.471  2000/02/26 18:30:40  ajc
5095 * Properly handle all aliases specified in network/mail.aliases for incoming
5096   SMTP mail (uses the alias() function, so if we replace that function with
5097   something that uses the same calling convention, it'll still work)
5098
5099 Revision 1.470  2000/02/26 05:15:38  ajc
5100 * Fortified the message base and SMTP code so that misdirected bounce messages
5101   end up in the Aide> room instead of getting dereferenced
5102 * Started writing a message reference count verifier ('fsck' for message base)
5103
5104 Revision 1.469  2000/02/25 06:14:05  ajc
5105 * Modularized the RWHO (Read WHO is online) command, basically as a pilot
5106   for modularizing all "non-API" functionality.
5107
5108 Revision 1.468  2000/02/24 03:44:00  ajc
5109 * Implemented holdoff time (15 minutes) for SMTP send retry.
5110 * Implemented "try for 3 days and then give up" on SMTP send.
5111
5112 Revision 1.467  2000/02/24 00:51:48  ajc
5113 * Client protocol synchronization check during exit from chat.
5114   This closes Bug #15.
5115
5116 Revision 1.466  2000/02/22 16:37:28  ajc
5117 * Minor tweaks to RFC822 output to keep brain-damanged MS Outlook from dying
5118
5119 Revision 1.465  2000/02/22 04:17:56  ajc
5120 * Got bounce messages working (mostly ... testers, please beat this up!)
5121 * Changed 'FIX' comments to 'FIXME' (less conflict, plus vim highlights it!)
5122
5123 Revision 1.464  2000/02/18 22:29:18  ajc
5124 * Coded up the "bounce" functions.  Still a coupla bugs.
5125
5126 Revision 1.463  2000/02/18 05:10:50  ajc
5127 * Made the <.ASI> command a bit friendlier.
5128 * SMTP sender now pays attention to "smarthost" entries in the system's
5129   Internet configuration, using them if one or more is present.
5130
5131 Revision 1.462  2000/02/17 05:27:39  ajc
5132 * Got the "MAIL From:" command sending the correct data.  (unnnhhhhnnhhhh...)
5133
5134 Revision 1.461  2000/02/16 22:06:26  ajc
5135 * Altered the display and conversion of RFC822 messages
5136
5137 Revision 1.460  2000/02/16 03:43:28  ajc
5138 * Added the resolver library to the configure script
5139
5140 Revision 1.459  2000/02/16 01:19:39  ajc
5141 * Vanquished the evil dn_expand() beast.  getmx() now seems to be working.
5142
5143 Revision 1.458  2000/02/14 04:36:14  ajc
5144 * sysdep.c: added new event hook type EVT_TIMER.  Timer event hooks are called
5145   once per minute by any worker thread.
5146 * msgbase.c: removed dependence on nested functions in CtdlOutputMsg() by
5147   replacing them with an API call CtdlRedirectOutput() in sysdep.c, which
5148   can temporarily redirect a session's output to an arbitrary file or socket.
5149 * serv_smtp.c: implemented the purging of messages in the queue for which all
5150   deliveries have been completed.
5151 * serv_smtp.c: removed temporary 'QQQQ' server command and replaced it with
5152   a timer event hook that runs the queue once per minute (this needs to be
5153   made more robust)
5154
5155 Revision 1.457  2000/02/08 21:00:47  ajc
5156 * Implemented the deprecated "LAST" command in POP3.  Some clients need it.
5157 * POP3 sessions now set the last-read pointer in Mail>.
5158
5159 Revision 1.456  2000/02/07 05:15:00  ajc
5160 * Renamed CtdlLocalHost() to CtdlHostAlias() and worked it a little deeper into
5161   the message routing logic.  Still needs some work on the gateway-domain
5162   stuff.
5163 * Twiddled CtdlOutputMsg() a bit for 'all Internet' situations.  Still needs
5164   some work to avoid printing dual headers when both Cit and RFC822 exist.
5165
5166 Revision 1.455  2000/02/03 03:57:35  ajc
5167 * Formalized the 'Internet Configuration' logistics.  Added new API call
5168   CtdlLocalHost() to detect aliases for the local host.  Used in SMTP listener.
5169
5170 Revision 1.454  2000/01/31 02:13:05  ajc
5171 * <.A>ide <S>ystem configuration <I>nternet  in the client (unfinished)
5172
5173 Revision 1.453  2000/01/26 02:41:27  ajc
5174 * SMTP delivery is working but still *very* rough.
5175
5176 Revision 1.452  2000/01/25 04:45:50  ajc
5177 * Wrote enough of the SMTP sender to get Patriot drooling over it, but not
5178   enough to complete the transmission of mail.
5179
5180 Revision 1.451  2000/01/23 21:25:45  ajc
5181 * Temporary hack to ig_tcp_server() to listen on an arbitrary port if the
5182   one specified is not bindable (for development only)
5183 * Added SM_DONT_BUMP_REF flag to CtdlSaveMsgPointerInRoom() to be used only
5184   in very specific and special situations
5185 * Generate delivery instructions when outbound SMTP mail is created from
5186   within Citadel (as opposed to being from the SMTP module)
5187
5188 Revision 1.450  2000/01/23 05:22:41  ajc
5189 * Coded up some more of the SMTP-sender (still not done)
5190
5191 Revision 1.449  2000/01/22 05:13:56  ajc
5192 * Added some more functionality to the string tokenizer
5193
5194 Revision 1.448  2000/01/17 20:57:43  ajc
5195 * CR to CRLF hacks (lose, lose, lose)
5196
5197 Revision 1.447  2000/01/17 18:30:27  ajc
5198 * Completed POP3 server.  All RFC1939 commands except APOP are implemented.
5199
5200 Revision 1.446  2000/01/17 17:09:23  ajc
5201 * Implemented LIST and STAT commands in the pop3 server
5202
5203 Revision 1.445  2000/01/17 05:38:14  ajc
5204 * citserver.c: cleanup hook functions are now run under the proper context,
5205                even when initiated by the housekeeper thread
5206 * serv_pop3.c: establish a place to hold the message list
5207
5208 Revision 1.444  2000/01/17 04:26:39  ajc
5209 * Modified CtdlOutputMsg() to handle output to arbitrary sockets or files.
5210   This uses nested functions and may not be portable beyond GCC...
5211
5212 Revision 1.443  2000/01/15 18:29:15  ajc
5213 * Added a generic (void *) parameter to the ForEachUser() and ForEachRoom()
5214   callback mechanisms, to allow callers and callbacks to pass arbitrary data
5215   between each other without requiring TSD variables.
5216 * room_ops.c: eliminated the need for 'FloorBeingSearched' TSD variable
5217 * internet_addressing.c: eliminated 'buffer1' and 'buffer2' TSD variables
5218
5219 Revision 1.442  2000/01/15 04:31:44  ajc
5220 * Removed UI_DIALOG mode in setup.  Can't count on 'dialog' to be consistent.
5221
5222 Revision 1.441  2000/01/15 04:07:17  ajc
5223 * Fixed the access rights on auto-created rooms (the same changes that were
5224   made to version 5.62 in the stable tree)
5225
5226 Revision 1.440  2000/01/13 03:32:36  ajc
5227 * techdoc/delivery-list.txt: added (syntax for delivery lists)
5228 * domain.*: added (will contain MX lookup code)
5229 * internet_addressing.c, logging.c: fixed some buffer overflow bugs
5230
5231 Revision 1.439  2000/01/12 03:56:27  ajc
5232 * sysdep.c: start the housekeeping thread *after* dropping root perms.
5233
5234 Revision 1.438  2000/01/09 19:03:16  ajc
5235 * Removed the fifo-based protocol downloads and replaced it with a less
5236   elegant "download temporary file to client, then sx/sb/sz" because
5237   downloading through a fifo was confusing some software.
5238
5239 Revision 1.437  2000/01/08 22:19:44  ajc
5240 * Completed spool to outbound delivery queue (still no queue sender implemented)
5241
5242 Revision 1.436  2000/01/08 05:00:09  ajc
5243 * Reworked some of the data structures to handle multiple recipients
5244 * Began implementation of the delivery queue
5245 * Added CtdlReallocUserData()
5246 * CtdlSaveMsg() now returns the local message ID in the database
5247
5248 Revision 1.435  2000/01/06 03:50:34  ajc
5249 * Replaced citmail.c with a new one that simply SMTP-forwards to Citadel
5250 * Started outbound SMTP queue work
5251
5252 Revision 1.434  1999/12/30 04:56:29  ajc
5253 * Got initial SMTP delivery working in a very specific situation (delivery
5254   to a single, local user)
5255
5256 Revision 1.433  1999/12/29 04:44:00  ajc
5257 * client_chat.c: display "No message sent" if a send page is aborted.
5258   Closes bug #2 in bugzilla.
5259
5260 Revision 1.432  1999/12/26 21:50:07  ajc
5261 * serv_vcard: don't run hooks when not logged in (such as in SMTP sessions)
5262 * serv_pop3: added.  This is the skeleton for a module implementing POP3.
5263
5264 Revision 1.431  1999/12/23 04:46:23  ajc
5265 * "Finished" initial hack of RFC822 import
5266
5267 Revision 1.430  1999/12/22 04:46:34  ajc
5268 * Fixed up the "Date:" headers to be RFC822-compliant
5269
5270 Revision 1.429  1999/12/13 05:30:57  ajc
5271 * Removed our naive 'conv_date()' RFC822-to-unixtime conversion function
5272   and replaced it with the public domain 'parsedate()' function from UseNet
5273
5274 Revision 1.428  1999/12/10 23:58:25  ajc
5275 * internet_addressing.c: added.  (Internet address to Citadel mapping)
5276
5277 Revision 1.427  1999/12/10 21:34:19  ajc
5278 * serv_smtp: implemented RFC821 "VRFY" and "EXPN" commands
5279
5280 Revision 1.426  1999/12/09 05:01:14  ajc
5281 * Split cmd_user() and cmd_pass() into frontend/backend functions
5282 * serv_smtp: implemented AUTH LOGIN for client authentication
5283
5284 Revision 1.425  1999/12/09 00:22:58  ajc
5285 * Finished the "arbitrary service" registration.
5286 * Eliminated "special" master socket for Citadel protocol - just register it
5287   like any other protocol.
5288 * Began initial implementation of native SMTP service.
5289
5290 Revision 1.424  1999/12/08 18:09:10  ajc
5291 * Added CtdlRegisterServiceHook() and its data type, for implementing arbitrary
5292   TCP-based services directly in the Citadel server.  Not finished yet.
5293
5294 Revision 1.423  1999/11/29 17:39:07  nbryant
5295 * citserver.c: Solaris lacks inet_aton; use inet_addr instead
5296
5297 Revision 1.422  1999/11/29 17:26:15  nbryant
5298 * citserver.c: include <sys/types.h>; may help portability to Solaris
5299
5300 Revision 1.421  1999/11/22 00:27:42  ajc
5301 * Added some temporary variables to OpenCmdResult().  Hopefully fixes
5302   bug #14 when running on FreeBSD.
5303
5304 Revision 1.420  1999/11/21 18:30:16  ajc
5305 * Protected cmd_move() from buffer overrun (no longer crashes the server)
5306 * cmd_chat() -- truncate input at 100 characters to prevent buffer overruns.
5307   Also handle broken client sockets properly.  (Thanks to DME for bug report)
5308
5309 Revision 1.419  1999/11/19 01:57:40  ajc
5310 * Fixed a *serious* memory leak in the database function wrappers.
5311 * Updated version number to 5.60 -- run setup when installing this version.
5312
5313 Revision 1.418  1999/11/18 03:29:20  ajc
5314 * Changed the order of parameters in <.A>ide <S>ystem config into a more
5315   logical grouping.
5316
5317 Revision 1.417  1999/11/18 02:31:50  ajc
5318 * Updated some of the documentation
5319 * Brought the internal version number up to 5.60
5320
5321 Revision 1.416  1999/11/17 04:15:05  ajc
5322 * Removed the session_count() function.  Instead, keep a reference count
5323   updated when sessions begin and end.
5324 * Replaced fixed number of worker threads with lower and upper limits; current
5325   code now tries to make thread count == session count, within these limits
5326
5327 Revision 1.415  1999/11/15 03:17:39  ajc
5328 * Put lockfile in /tmp instead of in /var/lock.   The latter is not guaranteed
5329   to exist, nor is it guaranteed to be writable by CTDLUID
5330   (Resolves bug #11 from the Bugzilla repository)
5331
5332 Revision 1.414  1999/11/15 03:07:24  ajc
5333 * Fixed the network-wide vCard purge logic so that it (1) actually works,
5334   and (2) forces a netproc run immediately when a purge is entered
5335
5336 Revision 1.413  1999/11/09 21:20:44  nbryant
5337 * configure.in: include <sys/types.h> when doing checks which require <utmp.h>
5338   (should fix Bug #10 on FreeBSD)
5339
5340 Revision 1.412  1999/11/05 03:53:47  ajc
5341 * Issue 'cancel' messages for vCard when a user is deleted.
5342 * Try to delete 'cancel' messages locally after they've been distributed.
5343
5344 Revision 1.411  1999/11/03 04:01:20  ajc
5345 * Fixed buffer overrun problems in cmd_rchg(), cmd_hchg(), and cmd_uchg()
5346 * Removed my email address as the feedback content from the docs; replaced
5347   it with a reference to the Citadel web site.
5348
5349 Revision 1.410  1999/11/02 19:51:23  ajc
5350 * Fixed timeout problem for remote client sessions (all timeouts were set to
5351   1 second ... probably a temporary hack that was missed in the cleanup)
5352
5353 Revision 1.409  1999/11/02 03:03:27  ajc
5354 * Several fixes to msgbase.c and netproc.c to prevent corrupted incoming
5355   network traffic from crashing the server.  Reject bad messages.
5356
5357 Revision 1.408  1999/11/01 04:21:34  ajc
5358 * Fixed a concurrency bug which crashed the server when multiple sessions
5359   terminated simultaneously.
5360
5361 Revision 1.407  1999/11/01 00:54:02  ajc
5362 * CtdlFetchMessage() - generate a "<no text>" message body if there's none
5363   on disk.  Too much stuff goes haywire if there's no M field.
5364
5365 Revision 1.406  1999/10/31 18:17:17  ajc
5366 * Fixed buffer overrun in cmd_rchg()
5367 * Call master_cleanup() when time_to_die==1 for proper shutdown
5368
5369 Revision 1.405  1999/10/31 16:26:55  ajc
5370 * Fixed incorrect assignment of new session ID's
5371
5372 Revision 1.404  1999/10/31 04:17:17  ajc
5373 * Fixed a bug which was crashing the server during very long message entry.
5374
5375 Revision 1.403  1999/10/29 01:48:45  ajc
5376 * database.c: Removed arbitrary limit on maximum number of sessions
5377
5378 Revision 1.402  1999/10/29 01:03:03  ajc
5379 * Debugged all possible ways for a session to terminate; do them cleanly.
5380 * Assign session numbers in a more portable and less arbitrary way.
5381
5382 Revision 1.401  1999/10/28 19:50:55  ajc
5383 * Fixed a problem where the client protocol would spit out two responses
5384   and therefore get out of sync if ASUP command set the access level to
5385   0 and therefore deleted the user (thanks to Eric McDonald)
5386
5387 Revision 1.400  1999/10/28 05:08:49  ajc
5388 * Removed all of the thread cancellation cruft that is no longer necessary
5389 * Moved the now non-system-dependent RemoveContext() out of sysdep.c (now
5390   it's part of cleanup() in citserver.c)
5391 * Removed all references to pthread_* from all modules except sysdep.c
5392
5393 Revision 1.399  1999/10/28 03:20:17  ajc
5394 * Fixed the problem of worker threads waking up prematurely.
5395 * 'QUIT'-terminated sessions now exit properly.
5396
5397 Revision 1.398  1999/10/27 04:26:58  ajc
5398 * Initial hack of worker-thread rearchitecture.  Right now it is successfully
5399   dispatching worker threads to active client sockets (and to the master
5400   socket too, of course).  Removing sessions is currently broken.
5401
5402 Revision 1.397  1999/10/26 20:20:29  ajc
5403 * Removed the auto-reconnect stuff... it was locking the client in an active
5404   loop more often than it was reconnecting.
5405
5406 Revision 1.396  1999/10/26 13:59:11  ajc
5407 damn bugs
5408
5409 Revision 1.395  1999/10/26 03:48:39  ajc
5410 * Shuffled around the order of events when a thread is terminating.  All
5411   mutex operations now happen prior to the freeing of the CitContext structure,
5412   otherwise begin_critical_section() and end_critical_section() try to
5413   manipulate the context's mutex count when there isn't any context.
5414
5415 Revision 1.394  1999/10/26 03:21:16  ajc
5416 * Changed a lot of strncpy() calls to safestrncpy() and replaced most of their
5417   hardcoded size arguments with 'sizeof' based arguments.
5418
5419 Revision 1.393  1999/10/24 19:22:51  nbryant
5420         * Makefile.in, configure.in: added --enable-icq flag; made checks for
5421           authentication libraries more intelligent.
5422
5423 Revision 1.392  1999/10/23 03:39:12  ajc
5424 * Finished moving vCard functionality to the new message base functions.
5425
5426 Revision 1.391  1999/10/21 00:50:14  ajc
5427 * Finished up the flags and replication checks in CtdlSaveMsgPointerInRoom().
5428
5429 Revision 1.390  1999/10/20 16:46:27  ajc
5430 * More code shuffle.  Added some flags to CtdlSaveMessagePointerInRoom() and
5431   enabled the MOVE command to also do a "copy" operation (actually just
5432   creates a second link and bumps the ref count).  Implemented "<C>opy" in
5433   the client.
5434
5435 Revision 1.389  1999/10/20 16:07:48  ajc
5436 * Wholist fixes for users who are in chat mode
5437
5438 Revision 1.388  1999/10/20 03:42:29  ajc
5439 * In the wholist, only show <private room> if the user viewing the list
5440   doesn't know that room.  Otherwise show the name.
5441
5442 Revision 1.387  1999/10/20 02:59:22  ajc
5443 * Code reorganization.  Making it easier to move/copy messages without
5444   duplicating existing code.
5445
5446 Revision 1.386  1999/10/17 02:25:18  ajc
5447 * Discovered a huge design flaw in the replication algorithm.  Ripped it
5448   out and replaced it with something a bit more robust.
5449
5450 Revision 1.385  1999/10/16 05:30:17  ajc
5451 * Changes to message replication code.  Don't do server-side hooks during
5452   an ENT3 command.  Also fixed a bug in cmd_whok() that caused crashes
5453   after a file format change.
5454
5455 Revision 1.384  1999/10/14 03:04:16  ajc
5456 * Finished the netproc side of Z (zap/supersede) processing for replication
5457
5458 Revision 1.383  1999/10/13 04:24:18  ajc
5459 * Added search-by-header-fields to CtdlForEachMessage(), and then to the
5460   server MSGS command.  This will have lots of uses.
5461
5462 Revision 1.382  1999/10/13 01:36:39  ajc
5463 * Starting some work on network zap (supersede) mode for replication
5464
5465 Revision 1.381  1999/10/08 02:55:57  ajc
5466 * More vCard-related debugging
5467
5468 Revision 1.380  1999/10/07 02:58:46  ajc
5469 * Semi-broken vCard replacement implementation in place.
5470 * Added "Z" (Zap, supersede) field to message format
5471
5472 Revision 1.377  1999/10/04 03:19:52  ajc
5473 * We now have a housekeeping thread and a housekeeping queue.
5474
5475 Revision 1.376  1999/10/03 21:48:21  ajc
5476 * Added serv_upgrade.h to automagically convert pre-5.55 format user records
5477   to 5.55 format user records and generate vCards.
5478
5479 Revision 1.375  1999/09/29 21:13:17  ajc
5480 * CtdlWriteObject() can now store objects in personal rooms for any specified
5481   user -- rather than only the current user or non-personal rooms.
5482
5483 Revision 1.374  1999/09/29 17:26:56  ajc
5484 * serv_vcard.c: fixed crashola bug in cmd_greg()
5485 * tools.c: simplified and improved the string tokenizer.  Now it runs in a
5486            single pass with no intermediate buffer.
5487
5488 Revision 1.373  1999/09/28 03:27:37  ajc
5489 * Fully migrated cmd_greg() and cmd_regi() into serv_vcard (still has bugs)
5490
5491 Revision 1.372  1999/09/27 03:33:40  ajc
5492 * cmd_regi() is now in serv_vcard and writes to the vcard instead of to the
5493   usersupp file.  Still needs tweaking.
5494
5495 Revision 1.371  1999/09/24 03:32:19  ajc
5496 * "read my vCard" and "write my vCard" are written and tested.
5497
5498 Revision 1.370  1999/09/24 02:54:17  ajc
5499 * Worked a little more on the vCard stuff.  The serv_vcard module is now in
5500   place, and a "read my vcard" function is there; "write my" is next...
5501
5502 Revision 1.369  1999/09/23 03:07:56  ajc
5503 * The vCard 'class' is now linked into the server, though it's not really
5504   functional yet.  Its constructors/destructors are debugged, though.
5505
5506 Revision 1.368  1999/09/19 21:28:33  ajc
5507 * Finished off the message architecture stuff with a new class of hooks to
5508   enable future server-side handlers.
5509
5510 Revision 1.367  1999/09/19 15:57:06  ajc
5511 * migrated cmd_ent3() to CtdlSaveMessage()
5512
5513 Revision 1.366  1999/09/19 05:13:57  ajc
5514 * Debugged the new version of CtdlWriteObject()
5515
5516 Revision 1.365  1999/09/16 03:23:23  ajc
5517 * Did most of the migration from save_message() to CtdlSaveMsg().  The
5518   latter builds a "struct CtdlMessage" (so we can run server-side handlers
5519   against it later on), then serializes it and stores to disk.
5520 * BROKEN BUILD ALERT!!  cmd_ent3() and CtdlWriteObject() are still not
5521   migrated.  They are stubbed out and will MALFUNCTION if used right now!!
5522
5523 Revision 1.364  1999/09/07 01:42:42  ajc
5524 * cmd_msg3() now uses serialize_message() for its output.  All message
5525   commands will eventually exist as a "struct CtdlMessage" at some point
5526   so that we can install server-side handler hooks.
5527
5528 Revision 1.363  1999/09/07 00:04:13  ajc
5529 * netproc.c: put outgoing messages into the use table, too -- this prevents
5530   locally originated messages from showing up again if a remote system is
5531   misconfigured and spools them back to us.
5532
5533 Revision 1.362  1999/09/06 03:39:15  ajc
5534 * citadel.c: run strproc() on new passwords
5535
5536 Revision 1.361  1999/09/03 17:50:26  playcow
5537 For URL view, don't prompt user to select url if there is only one.  Display
5538 <U>RL View prompt if message contains url(s). -Ben
5539
5540 Revision 1.360  1999/09/02 02:09:59  ajc
5541 * msgbase.c: new function serialize_message() for future use
5542
5543 Revision 1.359  1999/09/01 21:09:25  ajc
5544 * database.c: display the GDBM version string on startup
5545
5546 Revision 1.358  1999/09/01 02:36:34  ajc
5547 * Actually _enforce_ the max msg len limit
5548
5549 Revision 1.357  1999/09/01 01:51:48  ajc
5550 * Added the ability to handle embedded URL's from the text client
5551
5552 Revision 1.356  1999/09/01 01:02:47  ajc
5553 * Implemented "maximum message length" in global system config
5554
5555 Revision 1.355  1999/08/31 00:57:17  ajc
5556 * Handle multipart/alternative properly during legacy message outputs.
5557   Basically it just prints the first alternative and skips the rest.
5558
5559 Revision 1.354  1999/08/29 21:12:24  ajc
5560 * Made some changes to the output of MIME (especially multipart) messages.
5561
5562 Revision 1.353  1999/08/29 19:56:43  ajc
5563 * HTML updates
5564
5565 Revision 1.352  1999/08/24 02:01:03  ajc
5566 * html.c: added.  This is an overly simplistic HTML-to-text converter.
5567
5568 Revision 1.351  1999/08/21 18:37:29  ajc
5569 * Minor cosmetic cleanup.  No code changes.
5570
5571 Revision 1.350  1999/08/21 05:15:34  ajc
5572 * mailinglist.c, netmailer.c: fixed to allow list submissions from all posters
5573   on a Citadel network rather than only on the local system.
5574
5575 Revision 1.349  1999/08/08 00:25:45  ajc
5576 * Made one more byte available in locate_host() and in all the structs which
5577   its output gets written to (client can display 24 positions but we were only
5578   saving 23).
5579
5580 Revision 1.348  1999/08/07 16:34:38  nbryant
5581 * serv_icq.c: warning fixes
5582
5583 Revision 1.347  1999/08/06 02:57:26  ajc
5584 * locate_host.c: use strdoop() and phree() instead of strdup() and free()
5585 * serv_icq.c: run learned IP's through Citadel's locate_host() & put in Wholist
5586
5587 Revision 1.346  1999/08/05 17:58:59  ajc
5588 * RWHO command now returns express message code in postion 3
5589
5590 Revision 1.345  1999/08/04 02:21:45  ajc
5591 * Fixed some bugs in the ICQ metaclient, and documented the new protocol cmds
5592
5593 Revision 1.344  1999/08/03 11:34:35  ajc
5594 * Added client_icq.c and client_icq.h
5595
5596 Revision 1.343  1999/08/03 03:14:51  ajc
5597 * Wrote the client side of the ICQ gateway.  Now on to other projects.  :)
5598
5599 Revision 1.342  1999/08/03 01:52:06  ajc
5600 * Redesigned the client protocol commands for dealing with ICQ
5601 * Implemented page function priority ordering to prevent pages from being
5602   simultaneously delivered over multiple IM systems
5603 * Migrated serv_icq.* into the Makefile
5604
5605 Revision 1.341  1999/08/01 21:36:30  ajc
5606 * EXTREME coolness.  The server side of the ICQ metaclient is now working.
5607   It is set up using ICQL and ICQA commands, it automatically logs the user
5608   onto ICQ along with Citadel, and displays all non-offline ICQ contacts
5609   in the Wholist.
5610
5611 Revision 1.340  1999/07/31 07:18:01  ajc
5612 * Restructured the express message infrastructure, adding a class of function
5613   hooks for the addition of multiple paging modules with message routing
5614
5615 Revision 1.339  1999/07/30 22:20:19  ajc
5616 * Applied bugfix patches contributed by Vaggelis Tsirkas:
5617   * rooms.c: buffer overrun fix
5618   * room_ops.c: cmd_rdir() now behaves better when directory doesn't exist
5619
5620 Revision 1.338  1999/07/30 03:32:24  ajc
5621 * Added strdoop(), a leak-checked version of strdup()
5622 * Small fixes to new API functions in msgbase.c
5623 * ICQ metaclient stores/reads config using the message base API functions
5624
5625 Revision 1.337  1999/07/29 03:36:37  ajc
5626 * msgbase.c: reorganized.  output_message() now uses CtdlFetchMessage(),
5627   cmd_msg3() now fetches directly from disk and spews to the client.
5628
5629 Revision 1.336  1999/07/28 04:02:37  ajc
5630 * Server modules are now labelled with their RCS ID instead of a complex and
5631   manually-updated data structure.
5632
5633 Revision 1.335  1999/07/28 03:50:24  ajc
5634 * serv_expire.c: expire-by-age now calls CtdlFetchMessage() instead of
5635   calling output_message() in MT_DATE mode.
5636 * msgbase.c: removed MT_DATE mode ('twas a sleazy hack)
5637
5638 Revision 1.334  1999/07/27 22:47:26  ajc
5639 * Implemented new data type "CtdlMessage" which will eventually be used as
5640   widely as possible to represent a message in memory.
5641 * Implemented CtdlFetchMessage() which is intended to become the back-end to
5642   output_message() as well as a bunch of other things.
5643
5644 Revision 1.333  1999/07/27 20:00:24  ajc
5645 Removed all references to CC->msglist and CC->num_msgs, and all utility
5646 functions which relied upon them.  Citadel Is Now Better.
5647
5648 Revision 1.332  1999/07/27 19:32:22  ajc
5649 Removed serv_upgrade.c and all references to it in Makefile.in
5650 Reworked new-mail-count to not use MessageFromList() etc.
5651
5652 Revision 1.331  1999/07/25 02:59:37  ajc
5653 Fixed reference count problem in cmd_move()
5654
5655 Revision 1.330  1999/07/24 22:50:38  ajc
5656 Continued replacing references to [get|put]_msglist() with better code.
5657 For some reason, cmd_msgs() still doesn't always work right.
5658
5659 Revision 1.329  1999/07/24 22:16:41  ajc
5660 Experimenting with automatic updating of ChangeLog by CVS.  Simply twiddle
5661 ChangeLog a bit (i.e. by adding or removing a newline from the end of the
5662 file) before issusing "cvs commit", and the comments recorded by CVS will
5663 automatically appear at the beginning of ChangeLog.
5664
5665 Revision 1.328  1999/07/24 22:14:21  ajc
5666 cmd_move() now uses CtdlDeleteMessages().
5667 WARNING: build is temporarily broken.  Currently removing all references
5668 to the "msglist" kept in CitContext.  It's ugly and must die.
5669
5670 Thu Jul 22 22:26:50 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
5671         * Moved message deletion into new API function CtdlDeleteMessages()
5672         * Added CtdlWriteObject() to store generic data in the msgbase
5673         * Fixed really dumb error that prevented network msgs from posting
5674
5675 Tue Jul 20 22:14:54 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
5676         * Moved the actual work done in cmd_msgs() into a new API function
5677           called CtdlForEachMessage() which is supplied a callback function.
5678
5679 Mon Jul 19 23:24:18 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
5680         * Keep the (unqualified) content-type in the SuppMsgInfo record.  We'll
5681           be using this shortly to search rooms for specific object types.
5682
5683 Sun Jul 18 14:53:16 EDT 1999 Art Cancro <ajc@uncensored.citadel.org> 
5684         * Changes to dynloader et al to handle ICQ module being written
5685         * serv_icq.c, serv_icq.mk: added (separate makefile is temporary)
5686
5687 1999-07-17 Nathan Bryant <bryant@cs.usm.maine.edu>
5688         * chkpwd.c: DELETED CVS REVISION 1.3 (backed out Art's last change)
5689           use 'cvs update -r 1.2 chkpwd.c; cvs update -A chkpwd.c' NOW to
5690           avoid problems with working directories.
5691         * Makefile.in: don't install chkpwd setuid if make install isn't
5692           being run as root.
5693         * citadel.spec: chmod u+s chkpwd during %install stage
5694
5695 Fri Jul 16 18:39:04 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
5696         * PEXP and GEXP no longer trip the idle time display
5697         * Fixed bug which duplicated incoming private mail to Trashcan
5698         * Improved auto-reconnect by NOT using SIGPIPE and longjmp(); also
5699           implemented a 15 second delay to wait for a crashed server to restart
5700         * Relaxed the security check in chkpwd.c a bit; it was just flat-out
5701           preventing logins on my system otherwise
5702
5703 Thu Jul 15 22:57:32 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
5704         * eliminate redundant "name" parameter in [l]putuser(), now uses
5705           usbuf->fullname to guarantee the correct name for the index
5706
5707 1999-07-12 Nathan Bryant <bryant@cs.usm.maine.edu>
5708         * Makefile.in, configure.in: link netproc with gdbm
5709         * netproc.c: only include gdbm.h if HAVE_GDBM_H
5710         * user_ops.c: warning fix
5711
5712 Mon Jul 12 19:51:30 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
5713         * Mail is now saved in both sender and recipient mailboxes.  This is
5714           structured in a way that will allow a separate "outbox" room and/or
5715           multiple recipients in the future.
5716
5717 Sun Jul 11 18:46:48 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
5718         * netproc.c: msgfind() no longer uses the timestamp as a message-ID
5719           when no other message-ID is available (it screws up the loopzapper)
5720         * room_ops.c: eliminate room name parameter in putroom() and its ilk;
5721           get data from quickroom.QRname instead; prevents incorrect indexes
5722         * Tentative implementation of "personal rooms" (user-private namespace)
5723         * Added supplementary message info records for info that may change
5724           at some time later than when the message is saved (i.e. ref counts)
5725         * Implemented msg reference count increment/decrement; delete messages
5726           whose reference count reaches zero
5727
5728 Wed Jul  7 23:25:09 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
5729         * control.c: create citadel.control if it doesn't exist (yikes!)
5730         * serv_expire.c: purge mailbox rooms belonging to non-existent users
5731         * user_ops.c: don't delete user's mailbox at user-delete time
5732
5733 Mon Jul  5 17:01:29 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
5734         * utilsmenu: removed menu items for defunct utilities
5735
5736 Mon Jun 28 16:24:10 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
5737         * Changed any remaining references to UUCP, to "Internet" instead.
5738
5739 Thu Jun 24 11:13:23 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
5740         * added server command line option "-f" to defrag databases on startup
5741         * control.c: better performance and reliability in [get|put]_control()
5742         * netproc.c: Finished the loopzapper
5743
5744 Mon Jun 21 00:04:15 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
5745         * netproc.c: started writing a vortex checker.  Not finished.
5746
5747 Wed Jun  9 23:34:25 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
5748         * Replaced all code that generated temporary filenames with calls to
5749           tmpnam().  Rewrote using tmpfile() where possible.
5750
5751 Thu Jun  3 11:35:18 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
5752         * base64.c: mapped fi and fo to stdin and stdout using
5753           actual code rather than assignment at declaration time
5754           (several users of Red Hat Linux 6.0 reported problems)
5755
5756 Fri May 21 20:05:00 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
5757         * Added function CtdlGetDynamicSymbol() for dynamic symbol allocation
5758         * server.h: Changed discrete #define's to enum's where appropriate
5759         * sysdep.c: Changed the startup message to give credit to the whole
5760           development team :)  Also made the message more GNU-ish.
5761
5762 Thu May 20 20:01:30 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
5763         * database.c: print log messages for file defragmentations
5764         * citserver.c: implemented CtdlAllocUserData() and CtdlGetUserData()
5765           for arbitrary per-session data storage (by modules etc.) without
5766           having to add fields to struct CitContext
5767         * msgbase.c: removed "desired_section" from struct CitContext and
5768           implemented it using CtdlGetUserData() as a test.
5769
5770 Wed May 19 19:30:28 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
5771         * commands.c, commands.h, routines.c: began color scheme changes
5772
5773 1999-05-15 Nathan Bryant <bryant@cs.usm.maine.edu>
5774         * configure.in: Added untested support for BSDI 4.x.
5775
5776 1999-05-13 Nathan Bryant <bryant@cs.usm.maine.edu>
5777         * acconfig.h, configure.in, routines.c: fix for certain SYSV variants
5778           which lack utmp.ut_host
5779         * citadel.h, file_ops.c, msgbase.c, netproc.c, serv_chat.c: fix
5780           namespace collision with <sys/stream.h> on aforementioned SYSV
5781           variant
5782         * configure.in, getutline.c: check for paths.h
5783         * configure.in, Makefile.in: check for -lsocket and -lnsl
5784
5785 1999-05-11 Nathan Bryant <bryant@cs.usm.maine.edu>
5786         * chkpwd.c: fixed excessive paranoia; it used to refuse to run when
5787           invoked by root and CTDLUID != 0
5788         * Makefile.in: ignore errors while installing /etc/pam.d/citadel
5789
5790 1999-04-27 Art Cancro <ajc@uncensored.citadel.org>
5791         * file_ops.c: fixed NDOP to not crash the server if it has trouble
5792           with a download file
5793         * netpoll.c: upped default packet size
5794
5795 Mon Apr 26 22:06:57 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
5796         * Repaired IGnorant security hole blunder re. citmail
5797
5798 Sun Apr 25 12:44:08 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
5799         * serv_chat.c: notify user of number of participants upon entering chat
5800         * Built the 5.53 distribution
5801
5802 Wed Apr 21 22:23:13 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
5803         * aidepost.c: add -r flag to allow posting to rooms other than Aide>
5804         * serv_expire.c: now posts transcripts of all auto-purged rooms/users
5805
5806 Tue Apr 20 12:45:55 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
5807         * messages.c: downloading more than MAX_MSGS messages now truncates
5808           (off the beginning of the list) rather than crashing.
5809
5810 Mon Apr 19 12:11:48 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
5811         * whobbs.c: auto-detect when being called from a webserver, and act
5812           as a CGI (print HTTP headers and HTML output)
5813
5814 1999-04-18 Nathan Bryant <bryant@cs.usm.maine.edu>
5815         * serv_chat.c: fixed some potential buffer overruns (thanks dme)
5816
5817 Wed Apr 14 21:32:28 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
5818         * Makefile.in: chmod 4755 citmail to prevent citmail from aborting
5819           when called from sendmail due to citadel.config security check
5820
5821 1999-04-13 Nathan Bryant <bryant@cs.usm.maine.edu>
5822         * dynloader.c: OpenBSD places underscores in front of symbol names
5823         * Makefile.in: fixed a few sillies
5824         * aidepost.c, citmail.c, file_ops.c, logging.c, msgbase.c, netmailer.c,
5825           netproc.c, rcit.c, routines.c, serv_upgrade.c: fixed time_t handling
5826           (have to cast it to long for printf/scanf)
5827
5828 Mon Apr 12 22:13:26 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
5829         * aidepost.c: rewrote to unlink temp file before writing to it so that
5830           it will automatically go away if interrupted. Also ran indent -kr -i8
5831
5832 1999-04-12 Nathan Bryant <bryant@cs.usm.maine.edu>
5833         * configure.in, Makefile.in: taught it how to generate OpenBSD shared
5834           libraries
5835         * config.c, sysdep.c: fix -h option not setting proper modules dir
5836         * configure.in, citadel.spec: make --enable-chkpwd the default
5837         * setup.c: don't chown chkpwd
5838
5839 1999-04-11 Nathan Bryant <bryant@cs.usm.maine.edu>
5840         * configure.in: another OpenBSD fix, but we're still not quite there yet
5841         * serv_chat.c: warning fix
5842
5843 Thu Apr  8 22:51:28 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
5844         * config.c: now requires a setup run for *any* rev level difference
5845         * Updated docs & confs for 5.53b1 release
5846         * setup.c: sets the 0600 permission bits on citadel.config that
5847           is checked for in config.c
5848
5849 1999-04-08 Nathan Bryant <bryant@cs.usm.maine.edu>
5850         * citserver.c: improved is_public_client(), also if a public_client
5851           only supplies a numeric address, attempt to resolve it
5852         * locate_host.c: verify that the forward DNS matches the reverse
5853         * locate_host.c, locate_host.h: more general interface
5854         * configure.in, acconfig.h: fixes for Digital UNIX
5855
5856 Wed Apr  7 21:36:16 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
5857         * Implemented "access level required to create rooms" (client & server)
5858
5859 1999-04-07 Nathan Bryant <bryant@cs.usm.maine.edu>
5860         * configure.in: updated help messages, OpenBSD support
5861         * setup.c: if /etc/inittab doesn't exist, don't ask to create an
5862           entry in it
5863         * server.h, sysdep.c: fix a potential deadlock/data corruption bug
5864         * room_ops.c: fixed the 'gdbm error: Illegal data' message when
5865           deleting a room which had never been posted to
5866         * user_ops.c: include errno.h
5867         * dynloader.c: fix for OpenBSD
5868
5869 1999-04-06 Nathan Bryant <bryant@cs.usm.maine.edu>
5870         * Makefile.in, configure.in, getutline.c, sysdep.c:
5871           fixes/bug workarounds for FreeBSD
5872
5873 1999-04-03 Nathan Bryant <bryant@cs.usm.maine.edu>
5874         * Makefile.in, configure.in, chkpwd.c, acconfig.h: support for
5875           `chkpwd', a setuid helper program for machines which use shadow
5876           passwords (configure --enable-chkpwd)
5877         * Makefile.in, configure.in, auth.c, citadel.pam, user_ops.c: support
5878           for PAM or shadow passwords (configure --with-pam)
5879         * Makefile.in: made some messages simpler
5880         * citadel.spec: updated for 5.53; correct name of tarball; build with
5881           --enable-chkpwd and --with-pam; add defattr tags so rpm's can be
5882           built by non-root user
5883         * commands.c: cosmetic cleanup
5884         * config.c: (security/paranoia) check permissions on citadel.config
5885         * configure.in: check for ncurses if we can't find curses
5886         * dynloader.c: warning fix
5887         * sysdep.c: don't complain if initgroups() fails
5888         * citadel.c: fix systems with SYSV-style signal handling (e.g. libc5)
5889         * Makefile.in: New! Improved! Cleaner! Shinier!
5890
5891 Sun Mar 21 14:21:47 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
5892         * messages.c: cosmetic cleanups to message reading loop
5893
5894 Sat Mar 13 21:33:19 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
5895         * commands.c: use bright colors by default in color mode
5896         * citserver.c: initialize wholist fields with (not logged in) etc.
5897
5898 1999-03-08 Nathan Bryant <bryant@cs.usm.maine.edu>
5899         * sysdep.c: call DLoader_Init() with an absolute path so that gdb can
5900           find module symbols
5901         * database.c: bail out if opening databases fails
5902
5903 Sat Mar  6 01:55:55 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
5904         * serv_chat.c: use memfmout(), *not* cprintf() to transmit express
5905           messages.  Calling cprintf() on strings >256 bytes crashes the server
5906         * msgbase.c: minor logging fix in save_message()
5907
5908 1999-03-05 Nathan Bryant <bryant@cs.usm.maine.edu>
5909         * sysdep.c: add undocumented -r flag to citserver to prevent it from
5910           dropping root permissions.
5911         * sysdep.c: also drop supplementary groups
5912
5913 1999-03-04 Nathan Bryant <bryant@cs.usm.maine.edu>
5914         * config.c: error checking in put_config()
5915         * setup.c: chgrp files to the login group associated with CTDLUID
5916         * sysdep.c: copyright 1987-1999; drop root perms; load modules and call
5917           master_startup() after dropping perms
5918
5919 Wed Mar  3 00:00:55 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
5920         * Prevent buffer overruns in lowercase_name in [get|put]user()
5921         * client_chat.c: use citedit() for page composition
5922
5923 Sat Feb 27 07:47:36 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
5924         * rooms.c: download_to_local_disk() prompts for a filename if a blank
5925           filename was supplied to it (for attachments without names)
5926         * mime_parser.c: strip leading whitespace in content_type & disposition
5927
5928 1999-02-24 Nathan Bryant <bryant@cs.usm.maine.edu>
5929         * configure.in: improved check for pthreads
5930         * configure.in, routines.c, acconfig.h: check for ut_type in struct utmp
5931         * configure.in, Makefile.in: support for building server modules as
5932           relocatable objects for BSDI (which still uses a.out *gag* *choke*)
5933         * configure.in: compiler choice & flags for BSDI; check for libtermcap
5934         * database.c: don't use a critical section in open_databases()
5935         * housekeeping.c: use getfloor()/putfloor() instead of
5936           lgetfloor()/lputfloor() in check_ref_counts()
5937         * mime_parser.c: include <errno.h>
5938         * msgbase.c: include <limits.h>
5939         * sysdep.c: hacks for BSDI. use signals to fake thread cancellation;
5940           don't call master_cleanup() directly from signal handler.
5941         * routines.c: prototype getutline() if necessary
5942         * getutline.c: stupid bugfix
5943         * acconfig.h, configure.in, locate_host.c, server.h: work around
5944           nonreentrant gethostbyaddr() on BSDI
5945
5946 Mon Feb 15 22:59:00 EST 1999 Vaggelis Tsirkas
5947         * citadel.c: increased hostname buffer size to handle very big names
5948
5949 1999-02-15 Nathan Bryant <bryant@cs.usm.maine.edu>
5950         * sysdep.c(main): initialize alen before call to accept()
5951
5952 1999-02-04 Nathan Bryant <bryant@cs.usm.maine.edu>
5953         * configure.in: improved check for cygwin
5954         * configure.in, routines.c: access utmp directly instead of calling
5955           `who' if getutline() is available.
5956         * configure.in, Makefile.in, getutline.c: replace getutline() on
5957           systems which don't have it
5958         * routines.c: now always access utmp directly unless we can't find
5959           utmp.h
5960
5961 1999-02-02 Nathan Bryant <bryant@cs.usm.maine.edu>
5962         * Fixes for Cygwin:
5963           - ifdef out file download methods that require named pipes (client)
5964           - include pthread.h and gdbm.h only if they are present (fixes
5965             auto dependency generation)
5966           - include snprintf.h where needed
5967           - handle .exe suffixes for "make install"
5968
5969 Tue Feb  2 22:15:08 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
5970         * Overhauled the express messaging system (again)
5971
5972 Mon Feb  1 19:48:04 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
5973         * messages.c: implemented client download of MIME attachments
5974
5975 Sun Jan 31 18:29:18 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
5976         * Added qpdecode.c to the distribution (decodes quoted-printable)
5977         * Finished the MIME parser
5978         * Gave MSG0 a reasonable behaviour for MIME messages
5979         * Added the OPNA command for downloading attachments
5980
5981 Sat Jan 30 18:39:53 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
5982         * Look for citadel.rc in current directory if not found elsewhere
5983         * More work on the MIME parser
5984         * Added base64.c to the distribution
5985
5986 1999-01-29 Nathan Bryant <bryant@cs.usm.maine.edu>
5987         * fixes for IRIX (thanks to wr and family for use of the Indy):
5988           - use memset()/memcpy() instead of bzero()/bcopy() in all cases
5989           - configure updates
5990           - handle `long' pid's
5991           - a few other little bits
5992
5993 Mon Jan 25 21:23:07 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
5994         * Fixed bug in save_message() which crashed the server on mail to sysop
5995         * Rewrote pop_march() to be smarter about <G>oto heuristics
5996
5997 Sat Jan 23 14:32:19 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
5998         * Changed internal storage of express messages from a linked list to
5999           a single, resizable buffer.
6000         * Added a "room order" key to the room record, to allow some control
6001           over room listing order.
6002         * Made the room list commands aware of the room order key.
6003         * Overhauled <G>oto heuristics to pay attention to floor & room order
6004
6005 Wed Jan 20 19:21:51 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
6006         * Added some more code to the unfinished MIME parser
6007         * Changed module loading path to simply "modules" because after calling
6008           get_config(), the cwd is guaranteed to be the correct Citadel directory.
6009
6010 Tue Jan 19 21:28:29 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
6011         * Fixed a bug in the user editing command (client side)
6012         * Started a rewrite of the MIME parser
6013
6014 Thu Jan 14 21:21:15 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
6015         * Brought over the mime_parser from WebCit and began preliminary work
6016           on supporting MIME format messages.
6017
6018 Tue Jan 12 22:30:00 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
6019         * Various changes to begin work on support for MIME messages
6020                 - Defined format type 4 for MIME
6021                 - msgbase.c: *temporary* hacks in output_message() for Type 4
6022                 - citmail.c: added more robust header parsing, and support
6023                              for Type 4.  Also eliminated the crappy built-in
6024                              SMTP server.
6025                 - Updated some of the technical documentation
6026
6027 Sun Jan 10 13:34:36 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
6028         * Fixed access to page log room
6029
6030 Fri Jan  8 12:35:09 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
6031         * control.c: include <limits.h> to fix PATH_MAX undefined
6032         * serv_chat.c: made the following changes to cmd_sexp() --
6033                 * Send zero-length message to check only, don't send
6034                 * Send "-" message on the command line to invoke
6035                   the SEND_LISTING transfer mode for a multi-line message
6036         * Added facilities to log all pages to a room (site configurable)
6037
6038 Tue Jan  5 23:24:52 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
6039         * Replaced all occurances of malloc(), realloc(), and free() in the
6040           server and server-modules with mallok(), reallok(), and phree().
6041           Wrote macros and a set of leak-tracking functions.
6042
6043 Sun Jan  3 20:38:45 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
6044         * Documentation changes
6045
6046 Fri Jan  1 01:01:45 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
6047         * Fixed security problem relating to private rooms
6048
6049 Wed Dec 30 20:10:52 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
6050         * sysdep.c: put a bigger string buffer into lprintf() to avoid overruns
6051
6052 Sat Dec 26 16:56:46 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
6053         * internetmail.config: commented this file more clearly
6054
6055 Wed Dec 23 20:42:49 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
6056         * citadel.c: added some experimental code to automatically reconnect
6057           to the server if the connection is broken.  For some reason, it only
6058           works once.
6059
6060 Wed Dec 23 18:47:12 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
6061         * sysdep.c: ignore SIGPIPE.  This keeps broken connections from
6062           crashing the whole server.
6063         * Tagged everything for the official 5.50 release.
6064
6065 Mon Dec 21 07:54:20 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
6066         * housekeeping.c: call kill_session() with session_to_kill,
6067           not ccptr->cs_pid (was crashing the server)
6068
6069 Sat Dec 19 13:57:48 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
6070         * Added "-i" flag to netproc to make it skip the export phase.
6071           Updated other programs to call netproc in this way when appropriate.
6072         * Updated network.txt to reflect the usage for netproc (which has
6073           been wrong for several releases)
6074
6075 Thu Dec 17 00:17:04 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
6076         * Started removing the word "beta" from the docs and code.
6077           Preparing for an actual release.
6078         * msgbase.c: generate an 'I' field when requested (i.e. on locally
6079           originating messages.  this was breaking parts of the network)
6080
6081 1998-12-15 Art Cancro <ajc@uncensored.citadel.org>
6082         * msgbase.c: remove extra call to alias() which was causing
6083           Citadel-to-Citadel mail to fall into the bit bucket.
6084         * msgbase.c: fixed tempfile naming problem that could cause a new
6085           outgoing netmail message to overwrite another if netproc had not been
6086           run in between
6087
6088 1998-12-14 Art Cancro <ajc@uncensored.citadel.org>
6089         * More session table stability nonsense
6090
6091 Sun Dec 13 17:40:08 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
6092         * sysdep.c, citserver.c: (hopefully) fixed a session table concurrency
6093           bug which was causing the server to occasionally crash.
6094         * removed serv_test.so from the default build
6095
6096 Fri Dec 11 18:50:00 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
6097         * setup.c: default value for maxsessions is now 0 (no limit)
6098         * room_ops.c: don't allow users to create a room called "Mail"
6099         * serv_expire.c: fixed "number of messages purged" display
6100         * commands.c: when using color, default to low-intensity colors
6101
6102 Tue Dec  8 07:58:16 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
6103         * Beta 2
6104
6105 Sat Dec  5 01:24:03 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
6106         * Added a new type of module hook for adding logging functions
6107         * Removed whitespace to left and right of '@' in netmail recipients
6108         * sysdep.c: read citadel.config _before_ initializing loadable modules
6109         * stats.c: fixed segfault resulting from extracting log lines
6110         * Ripped most of the "attachments" stuff out of both the client and
6111           server.  (Thought of a better way to handle it ... LATER.)
6112
6113 1998-12-03 Nathan Bryant <bryant@cs.usm.maine.edu>
6114         * setup.c: create citadel.config with mode 0600
6115         * Makefile.in: don't chmod sendcommand
6116         * serv_upgrade.c: don't create citadel.config if it doesn't already
6117           exist (paranoia)
6118         * setup.c: saner defaults for nodename and fqdn
6119
6120 Wed Dec  2 20:37:05 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
6121         * msgbase.c: modified AddMessageToRoom() and all functions that call it
6122           to use a more reliable/accurate method to set quickroom.QRhighest
6123         * weekly.in: don't sort/purge filedir where filedir doesn't exist
6124
6125 1998-12-02 Nathan Bryant <bryant@cs.usm.maine.edu>
6126         * weekly is now generated by configure
6127
6128 Mon Nov 30 19:48:52 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
6129         * room_ops.c: added sort_msglist() to move and save operations
6130         * sendcommand.c: added (also updated utils.txt, weekly, Makefile.in)
6131         * BETA 1
6132
6133 Sun Nov 29 23:57:39 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
6134         * Fixed cmd_regi() to not display a second result code after xfer
6135         * Makefile.in: Removed "chmod 4755 citmail netmailer"
6136
6137 1998-11-23 Nathan Bryant <bryant@cs.usm.maine.edu>
6138         * citadel.spec: added
6139
6140 1998-11-22 Nathan Bryant <bryant@cs.usm.maine.edu>
6141         * Makefile.in: split install target into install-exec, install-data,
6142           and install-doc subtargets
6143
6144 Sat Nov 21 16:53:30 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
6145         * Added a fourth color mode in the client: "user" which turns color
6146           on or off according to a per-user flag stored on the server.  Added
6147           server-side support for this too, of course.
6148         * import.c: removed
6149         * serv_expire.c: finished the code to purge stale visits
6150         * sysdep.c: strip trailing nonprintables in client_gets()
6151         * routines2.c: fixed <.AS> command; all configs now work properly
6152         * Moved num_parms() and all the extract() type functions into tools.c
6153           and removed them from all other files.  Linked in tools.[o|ro] there.
6154         * netproc.c: handled incoming file transfers to correct room directory
6155         * room_ops.c: fixed incorrect naming of files in info and images dirs
6156
6157 Fri Nov 20 20:29:07 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
6158         * setup.c: removed all prompts that can be configured from within the
6159           client in order to simplify the setup procedure
6160
6161 Thu Nov 19 23:28:33 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
6162         * Fixed serv_upgrade.c and export5.c (found elsewhere) to use a new
6163           export format which treats visits as a separate section
6164         * serv_expire.c: began writing functions to purge rooms and visits
6165           (neither work yet), and added a way to call defrag_databases()
6166
6167 Wed Nov 18 23:51:17 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
6168         * Reimplemented 'visit' structs stored globally instead of as
6169           lists-per-user
6170
6171 Tue Nov 17 22:37:48 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
6172         * Started implementing global room numbers.
6173
6174 Sun Nov 15 20:32:34 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
6175         * room_ops.c: mailbox rooms always appear on the main floor
6176         * made QR_MAILBOX rooms non-editable
6177         * cmd_setr() delete old room record when room name changes
6178           (This causes a big mess that exposes a flaw in the whole design.)
6179         * room_ops.c: users can delete messages from their mailboxes
6180
6181 Thu Nov 12 23:59:13 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
6182         * Rewrote cmd_rchg() and also increased the size of the "fakename"
6183           buffer.  Overruns are probably what was causing the crashes.
6184         * Changed the way cmd_ent3() handles mail messages; the previous code
6185           rerouted all private mail to the trash.
6186
6187 Wed Nov 11 17:57:39 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
6188         * citserver.c: slight changes to cmd_rchg() and cmd_hchg() [crashes]
6189         * citserver.c, msgbase.c, user_ops.c: hide the owner-prefix of mail
6190           rooms in a couple more places: set_wtmpsupp() and make_message()
6191         * sysdep.c: added an fflush() to lprintf() for "tail -f"-able logs
6192         * serv_expire.c: purge ops are now a command instead of a cleanup
6193           function.  This is probably temporary as well.
6194         * citadel.c: fixed the way <.WL> parses the returned data from a
6195           TIME command.
6196
6197 1998-11-11 Nathan Bryant <bryant@cs.usm.maine.edu>
6198         * serv_upgrade.c: fix uninitialized variable
6199
6200 Wed Nov 11 00:47:32 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
6201         * msgbase.c: fixed a bug that was misrouting incoming network msgs
6202         * server.h, database.c: wrapped all GDBM calls in critical sections
6203           to avoid making those calls re-entrantly (gdbm fatal: lseek error)
6204
6205 1998-11-10 Nathan Bryant <bryant@cs.usm.maine.edu>
6206         * Makefile.in: link in snprintf.o where needed
6207
6208 1998-11-09 Nathan Bryant <bryant@cs.usm.maine.edu>
6209         * client_chat.c: eliminate calls to sprintf()
6210         * commands.h, routines.c, routines2.c: warning fix
6211         * commands.c, control.c, cux2ascii.c, file_ops.c, import.c,
6212           ipc_c_tcp.c: eliminate sprintf() calls
6213
6214 Mon Nov  9 19:15:31 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
6215         * serv_upgrade.c: added all missing fields to export/import
6216         * serv_expire.c: support per-user purge time when purging users
6217         * user_ops.c: added per-user purge time to AGUP and ASUP commands
6218         * routines.c: added more stuff to <.A>ide <E>dit user
6219
6220 Sun Nov  8 22:56:53 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
6221         * serv_expire.c: created; moved message expiry from serv_test.c,
6222           moved user purge from userpurge.c
6223         * userpurge.c: deleted
6224         * routines2.c: finished <.AS> command
6225         * room_ops.c: fixed Aide room access (for some reason, the Aide
6226           room had the QR_MAILBOX flag set)
6227
6228 1998-11-08 Nathan Bryant <bryant@cs.usm.maine.edu>
6229         * useradmin.c: really removed (cvs remove)
6230         * aidepost.c, citadel.c: convert all sprintf() calls to snprintf()
6231         * sysdep.c: fix overrun in lprintf() described by dme/Dead Monkey
6232         * citmail.c, citserver.c: convert all sprintf() call to snprintf()
6233
6234 Sun Nov  8 13:19:36 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
6235         * useradmin.c: removed
6236         * utils.doc: removed references to useradmin and sysoputil
6237
6238 Fri Nov  6 20:22:20 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
6239         * citadel.h (and related files): removed defunct parameters,
6240           c_defent and c_msgbase (erase your test system)
6241         * Implemented CONF server command for site-global configs
6242         * Shuffled yesno() and yesno_d() from routines.c to commands.c
6243         * commands.c: implemented boolprompt()
6244         * routines2.c: started adding CONF questions to <.AS> command
6245         * room_ops.c: began a fix for the mysterious disappearing Aide room
6246
6247 1998-11-05 Nathan Bryant <bryant@cs.usm.maine.edu>
6248         * snprintf.c: warning fix propagated over from gcit
6249
6250 1998-11-04 Nathan Bryant <bryant@cs.usm.maine.edu>
6251         * added RCS Id keyword strings to sources
6252         * citmail.c: reverted to version 1.10
6253
6254 Wed Nov  4 10:53:13 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
6255         * messages.c: temporarily set screenwidth to a fixed value of 80
6256           during <P>rint operations.
6257
6258 Mon Nov  2 12:59:03 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
6259         * setup.c: looks for 'citadel', 'bbs', or 'guest' in /etc/passwd to
6260           try to get a default for ctdluid if it's currently set to 0
6261         * citmail.c: changed usersupp.eternal to usersupp.usernum (why didn't
6262           it complain about this before?)
6263         * serv_upgrade.c: began writing an "export" command to do sidegrades
6264
6265 Sun Nov  1 18:47:42 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
6266         * serv_upgrade.c: cosmetic changes
6267         * Implemented message expiry by date (this really needs to be moved
6268           out of serv_test.c, but where does it belong?)
6269
6270 1998-11-01 Nathan Bryant <bryant@cs.usm.maine.edu>
6271         * serv_upgrade.c: warning fixes
6272         * acconfig.h: remove ANSI_COLOR
6273         * Configure, Makefile.tmpl: removed
6274
6275 Sat Oct 31 20:48:44 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
6276         * More stoopid ANSI colour additions here and there.
6277         * ANSI colour selection is now in citadel.rc instead of an option in
6278           the configure script.  "on" "off" and "auto" are available.
6279         * added "build.txt" to the techdoc directory, with LS's build notes
6280
6281 1998-10-31 Nathan Bryant <bryant@cs.usm.maine.edu>
6282         * citadel.c, commands.c, commands.h: set background color to black
6283           before clearing screen, so that we can actually see text on
6284           black-on-white xterms.
6285
6286 1998-10-29 Nathan Bryant <bryant@cs.usm.maine.edu>
6287         * rooms.c: fix color of Mail>
6288         * citadel.c: send ANSI detect sequence after attach_to_server() so the
6289           terminal doesn't send the answerback sequence to the shell if we
6290           can't connect.
6291
6292 Wed Oct 28 20:20:14 EST 1998 Art Cancro <ajc@uncensored.citadel.org
6293         * citadel.c: Added a splash of colour to the Wholist
6294
6295 1998-10-28 Nathan Bryant <bryant@cs.usm.maine.edu>
6296         * configure.in: added comments
6297         * mkinstalldirs: new file to be used for `make install'
6298         * aclocal.m4, missing: new files, also swiped from automake
6299         * citadel.c: don't mung the terminal if we can't find citadel.rc
6300         * Makefile.in: added `install' target, `clean' removes
6301           *.mo, rebuild configure when configure.in changes.
6302         * configure.in: check for install and autoconf
6303         * configure.in, Makefile.in: only pass -fPIC to gcc
6304         * policy.c: warning fix for OSF/1 (use memset() instead of bzero())
6305
6306 Tue Oct 27 22:25:42 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
6307         * Unified the "unpacked database" format for both upgrades and
6308           sidegrades (also see export5.c elsewhere)
6309         * citserver.c: clear out cmdbuf before reading a command; some server
6310           commands were accidentally extracting parameters from previous cmds
6311         * rooms.c: removed the warning about the ineffectiveness of kicking
6312           users out of public rooms, because the new server can do lockouts
6313
6314 1998-10-27 Nathan Bryant <bryant@cs.usm.maine.edu>
6315         * sysdep.c (client_gets), ipc_c_tcp.c (serv_gets): improved handling
6316           of long lines. 
6317         * Makefile.in: partial support for VPATH builds, autodependency fix
6318
6319 Tue Oct 27 00:08:16 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
6320         * minor documentation changes
6321
6322 Sun Oct 25 14:57:40 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
6323         * messages.c: fixed an oversight that was allowing attachments even
6324           when disabled in citadel.rc
6325
6326 1998-10-25 Nathan Bryant <bryant@cs.usm.maine.edu>
6327         * routines2.c: warning fix
6328
6329 Sat Oct 24 22:07:56 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
6330         * Client: added message expiration policy questions to room edit
6331         * Client: added <.A>ide <S>ystem configuration command
6332
6333 1998-10-24 Nathan Bryant <bryant@cs.usm.maine.edu>
6334         * Makefile.in: Auto dependency generation (may require GNU make, but
6335           does at least function without this feature on OSF/1 make);
6336           Makefile is regenerated when Makefile.in changes (ditto);
6337           `realclean' is now known as `distclean';
6338           portability fixes for older Unix make utilities
6339         * citadel.c, citadel.h, commands.c: make client suspendable
6340
6341 Fri Oct 23 19:34:38 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
6342         * setup.c: default node name is now obtained from uname()
6343         * config.c: added put_config()
6344         * policy.c: added, moved GetExpirePolicy() from room_ops.c
6345         * policy.c: implemented cmd_gpex() and cmd_spex()
6346
6347 Wed Oct 21 22:24:48 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
6348         * Mail rooms now hide their owner-prefix from the client.
6349         * proxy.c: added configurability and primitive message expiry
6350
6351 1998-10-20 Nathan Bryant <bryant@cs.usm.maine.edu>
6352         * Makefile.tmpl: fix to build client with old Configure script
6353         * configure.in: autologin defaults to enabled if crypt() is available
6354         * room_ops.c: fix improper null-termination bug I introduced
6355
6356 Mon Oct 19 20:52:55 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
6357         * Client ability to force display of prompts in Mail rooms, even when
6358           the user has prompting turned off (citadel.rc option)
6359
6360 1998-10-16 Nathan Bryant <bryant@cs.usm.maine.edu>
6361         * sysdep.c (cprintf): generate a newline on truncated buffer
6362         * room_ops.c: exploitable overrun fixes
6363
6364 Thu Oct 15 19:27:32 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
6365         * msgbase.c: reimplemented cmd_move()
6366           room_ops.c: wrote AddMessageToRoom() which is used for both entering
6367           and moving messages.
6368         * setup.c: system-default message expire policy of "number of
6369           messages, 150" is now a default configuration instead of a temp hack
6370         * proxy.c: cache dir create now dies on any error except EEXIST
6371
6372 Wed Oct 14 22:41:16 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
6373         * Misc code cleanup
6374
6375 1998-10-13 Nathan Bryant <bryant@cs.usm.maine.edu>
6376         * configure.in: don't check for -lcrypt unless autologin is enabled
6377         * file_ops.c: fix another overrun
6378
6379 Mon Oct 12 15:27:21 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
6380         * Killed the "rooms" subdirectory (it isn't used anymore)
6381         * dynloader.c: Made dynamically added server commands case-insensitive
6382         * import.c is now serv_upgrade.c, a module
6383         * Removed most of the "level 9" trace messages no longer needed
6384
6385 1998-10-12 Nathan Bryant <bryant@cs.usm.maine.edu>
6386         * Makefile.in: simplified to use pattern rules; files compiled with
6387           -D_REENTRANT go to *.ro to allow the same files to be used with both
6388           client and server
6389         * tools.c, tools.h: new files; misc routines used by both client and
6390           server go here. contains safestrncpy() at the moment.
6391         * rooms.c: fix several exploitable buffer overruns
6392         * sysdep.c: fix infinite loop when long lines are received from the
6393           client; fix exploitable buffer overrun in cprintf()
6394         * ipc_c_tcp.c: fix infinite loop on long line from server
6395         * serv_upgrade.sh: remove uncnsrd-dependent absolute path
6396         * .cvsignore: add *.ro
6397
6398 Sun Oct 11 23:17:48 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
6399         * Built some more of the message expiry infrastructure
6400
6401 1998-10-11 Nathan Bryant <bryant@cs.usm.maine.edu>
6402         * citserver.c: fix two more overruns, one of which was preventing
6403           the "From Host" from showing up in the <W>ho listing.
6404
6405 Sun Oct 11 02:51:55 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
6406         * Moved "struct visit" and its associated defs from citadel.h to
6407           server.h where they belong
6408         * Set up data structures for room policies (expiry, etc.)
6409
6410 1998-10-10 Nathan Bryant <bryant@cs.usm.maine.edu>
6411         * citserver.c: fix overrun which caused segv's on servers with long
6412           hostnames.
6413
6414 Fri Oct  9 18:34:06 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
6415         * user_ops.c: added PurgeStaleRelationships() to do processing at
6416           session logout time to remove visits for rooms which no longer exist
6417         * user_ops.c: implemented NewMailCount()
6418
6419 1998-10-09 Nathan Bryant <bryant@cs.usm.maine.edu>
6420         * serv_chat.c: fix buffer overrun that was resulting in segv's
6421         * serv_chat.c: fix another overrun that could cause sessions to hang,
6422           and cleaned up some other strncpy()-related stuff. DON'T FORGET TO
6423           NULL-TERMINATE DESTINATION BUFFERS AFTER STRNCPY CALLS.
6424
6425 Fri Oct  9 13:22:37 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
6426         * Implemented "lazy mode" traversal - pressing the space bar will do
6427           <N>ext messsage, <G>oto next room, or read <N>ew as appropriate.
6428         * room_ops.c: modify CtdlRoomAccess() to allow access to mailbox rooms
6429           only to their owners.
6430
6431 Thu Oct  8 17:13:27 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
6432         * messages.c, citadel.rc: added the ability to display message numbers
6433           in the header when reading messages.  I think this is butt ugly, but
6434           some of the DaveCode afficionados seem to like it...
6435
6436 Thu Oct  8 15:34:45 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
6437         * room_ops.c: Added is_noneditable() function to replace all of the
6438           duplicated code present in all functions which edit room parameters.
6439
6440 1998-10-08 Nathan Bryant <bryant@cs.usm.maine.edu>
6441         * lots of warning fixes; builds with -std1 on dec unix
6442         * aidepost.c, citadel.h, citmail.c, file_ops.c, msgbase.c, netmailer.c,
6443           netproc.c, rcit.c, server.h, stats.c, userlist.c: use time_t where
6444           needed
6445         * control.c, room_ops.c, serv_chat.c, sysdep.c: use memset() instead of
6446           bzero()
6447         * dynloader.c, dynloader.h, messages.c, server.h, sysdep.c,
6448           sysdep_decls.h: function pointer/prototyping fixes
6449         * rooms.c: use mkfifo(3) instead of system("mkfifo")
6450
6451 1998-10-07 Nathan Bryant <bryant@cs.usm.maine.edu>
6452         * snprintf.c, snprintf.h: new files
6453         * Makefile.in, configure.in, dynloader.c, sysdep.c: support for the
6454           above; citserver now builds and runs on Digital Unix 4.0d with the
6455           GNU-style configure script. there is a bug with the hostname display
6456           in the wholist.
6457         * netproc.c: sillyness fix
6458         * room_ops.h: prototype delete_room()
6459         * client_chat.c, commands.c, serv_chat.c, sysdep.c:
6460           use HAVE_SYS_SELECT_H macro
6461
6462 Mon Oct  5 17:01:32 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
6463         * Began fixing the stuff I broke
6464
6465 Sun Oct  4 23:35:18 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
6466         * Did the big migration to the new data structures.  Lots of stuff is
6467           now broken.  Basic moving from room to room works, but Mail is
6468           broken, and some of the administrative commands are unimplemented.
6469
6470 1998-10-02 Nathan Bryant <bryant@cs.usm.maine.edu>
6471         * configure.in: autologin now defaults to disabled
6472
6473 Fri Oct  2 00:04:31 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
6474         * Finally removed all three usersupp.foo[MAXROOMS] elements, and
6475           migrated all the code that used them to use "struct visit" instead.
6476
6477 Thu Oct  1 23:02:20 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
6478         * Rewrote [l][get|put]room() functions to use room names rather than
6479           room index numbers.  Temporarily prepended a "n" to these four
6480           function names until they are put to use.
6481
6482 Thu Oct  1 16:27:13 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
6483         * Removed a few more references to usersupp.lastseen[]
6484
6485 1998-10-01 Nathan Bryant <bryant@cs.usm.maine.edu>
6486         * .cvsignore: add so_locations (generated by osf1 ld with shared libs)
6487         * Makefile.in: restructured variables for greater consistency, use
6488           @echo to print out notices during the make process, add so_locations
6489           to `cleaner'
6490         * configure.in, Makefile.in: configure checks for -rdynamic
6491         * ipc_c_tcp.c: fix DEC compiler warning wrt unsigned char
6492         * stats.c: add semicolon to placate DREC compiler
6493         * user_ops.c: define _POSIX_C_SOURCE, include <limits.h>
6494         * configure.in: pass -pthread to DEC compiler, don't check for
6495           libpthread[s] on DEC Unix
6496
6497 1998-09-30 Nathan Bryant <bryant@cs.usm.maine.edu>
6498         * Makefile.in: new variable PTHREAD_DEFS for portability
6499         * aidepost.c, citadel.c, citmail.c, mailinglist.c, msgform.c,
6500           netmailer.c, netpoll.c, netproc.c, rcit.c, readlog.c, setup.c,
6501           stats.c, userlist.c, whobbs.c: return type of main() is int
6502         * citadel.c, commands.c, messages.c: use time_t properly
6503         * citserver.c: include <limits.h>
6504         * config.guess, config.sub, install-sh: new files
6505         * configure.in: don't use gcc on Digital Unix
6506
6507 Tue Sep 29 23:17:34 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
6508         * room_ops.c: modified usergoto() to look at the new data structures
6509           for counting new messages and such.
6510
6511 1998-09-29 Nathan Bryant <bryant@cs.usm.maine.edu>
6512         * user_ops.c: fix compiler warning and potential memory leak,
6513           include sysdep.h
6514         * configure.in, Makefile.in: only build the server if we find pthreads
6515         * Makefile.in: realclean removes config.{cache,log,status}
6516
6517 Tue Sep 29 13:20:14 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
6518         * Removed code from some of the utilities which was still attempting
6519           to access the old non-gdbm data store.
6520         * housekeeping.c: rewrote check_ref_counts() to do a ForEachRoom()
6521           traversal instead of a MAXROOMS loop.
6522         * sysdep.c: set up a dummy CitContext record to be used during server
6523           startup, during which time there is no real context.
6524
6525 Mon Sep 28 23:51:51 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
6526         * Implemented the function ForEachRoom() to handle all-rooms traversal
6527           (this will work with both the old and new paradigms, because both
6528           use a GDBM database with one room per record).  Migrated all room
6529           list commands to use it.
6530
6531 Mon Sep 28 22:05:35 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
6532         * Implemented the function CtdlRoomAccess() to handle *all* of the
6533           user-access-to-rooms functionality.  Migrated all room list commands
6534           to use it.  Still need to migrate gotos.
6535
6536 1998-09-28 Nathan Bryant <bryant@cs.usm.maine.edu>
6537         * configure.in, acconfig.h: new files; partially functional GNU
6538           autoconf configure script. Run autoheader; autoconf; ./configure
6539           --prefix=`pwd` to test.
6540         * Makefile.tmpl: new file; this is what Makefile.in used to be. Used by
6541           Configure.
6542         * Makefile.in: modified to work with autoconf-style configure script
6543         * Configure: modified to use Makefile.tmpl and generate autoconf-style
6544           macros. Removed procfs detection. Pass -O2 to gcc, -O to other
6545           compilers. Removed mknod/mkfifo detection; code should use mkfifo(3).
6546         * citmail.c, msgform.c, netproc.c, routines.c, support.c, userlist.c,
6547           whobbs.c: use HAVE_STRERROR macro rather than NO_STRERROR
6548         * commands.c: use HAVE_TERMIOS_H macro rather than POSIX_TERMIO
6549         * netproc.c: remove procfs stuff. simply attempt to kill the target
6550           process with signal zero instead; this checks whether the process
6551           exists.
6552         * setup.c, useradmin.c: use HAVE_CURSES_H macro
6553
6554 Sun Sep 27 23:41:29 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
6555         * BOTH the old and new generation systems are being written to at
6556           this point.  Code that reads stuff is still using the old system.
6557
6558 Sun Sep 27 16:10:49 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
6559         * Changed all "generation" variables from char to long, in preparation
6560           for removing MAXROOMS.  Generations for new rooms are now timestamps.
6561         * Defined "struct visit" to hold user/room relationships.
6562         * Removed some #define's from citadel.h that are no longer used.
6563
6564 Wed Sep 23 13:41:49 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
6565         * More changes to support attachments.  They mostly work, but only
6566           in fixed-format messages.
6567
6568 Mon Sep 21 21:19:17 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
6569         * msgbase.c: began laying the groundwork to support attachments.
6570           Purchased Rogaine(tm) in preparation for expected hair loss.
6571
6572 1998-09-21 Nathan Bryant <bryant@cs.usm.maine.edu>
6573         * msgbase.c: include dynloader.h
6574         * citadelapi.h: removed
6575         * dynloader.h: prototype CtdlRegisterUserHook()
6576
6577 Sun Sep 20 18:56:37 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
6578         * Added a UserFunctionHook category to implement hooks which perform
6579           operations on various users or usernames
6580
6581 Fri Sep 18 21:14:41 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
6582         * citserver.c: removed cmd_extn() and related code
6583
6584 1998-09-18 Nathan Bryant <bryant@cs.usm.maine.edu>
6585         * user_ops.c: include dynloader.h
6586         * roomstats.{c,mk}: removed
6587         * Configure, Makefile.in: autodependency-related fixes
6588
6589 Thu Sep 17 22:55:29 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
6590         * Various changes to allow "new messages" to work correctly with Mail
6591
6592 Thu Sep 17 22:21:45 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
6593         * server.h, dynloader.c, citserver.c, user_ops.c: reduced the number
6594           of hook types by inventing an EventType field to the Session hook.
6595         * proxy.c: added pre-fetching
6596
6597 1998-09-17 Nathan Bryant <bryant@cs.usm.maine.edu>
6598         * Makefile.in: add SERV_MODULES and PROXY_TARGETS to `cleaner'
6599         * dynloader.[ch], serv_{chat,test}.[ch], sysdep.c: cleaned
6600           up the dynamic loader interface as follows:
6601           - all the symbol table stuff is gone.
6602           - modules are loaded once at server startup and never unloaded.
6603           - Added a new function CtdlRegisterProtoHook() to handle the stuff
6604             that was being done with the symbol tables.
6605           - Dynamic_Module_Init() now returns a pointer to a static struct
6606             DLModule_Info; this structure itself has been modified to use char*
6607             fields instead of fixed char arrays.
6608         * roomstats.c: include <stdarg.h> not <stdargs.h> (is this file still
6609           in use?)
6610         * Configure, Makefile.in: added autodependency support
6611
6612 Wed Sep 16 22:25:13 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
6613         * Implemented separate structs, lists, and functions for each type
6614           of server-side hook available.
6615
6616 1998-09-16 Nathan Bryant <bryant@cs.usm.maine.edu>
6617         * ipc_c_tcp.c: Fixed up some #include/prototyping stuff, call memcpy()
6618           instead of bcopy()
6619         * hooks.h: removed
6620         * sysdep.c, user_ops.c: removed reference to hooks.h
6621
6622 Wed Sep 16 11:42:42 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
6623         * ipc_c_tcp.c: Reversed any changes that have been made to this file,
6624           because something was causing abominally slow response time.
6625         * proxy.c: added.  This will eventually become a caching, pre-fetching
6626           multiuser proxy server for the Citadel protocol.
6627
6628 1998-09-15 Nathan Bryant <bryant@cs.usm.maine.edu>
6629         * Makefile.in: remove support.o from serv_chat.so, add -fPIC to compile
6630           flags for serv_chat.o
6631         * dynloader.c: include "sysdep_decls.h", use RTLD_NOW not RTLD_LAZY
6632         * dynloader.h: prototype CtdlRegisterHook()
6633         * .cvsignore: added data
6634
6635 Mon Sep 14 20:49:08 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
6636         * Tried my hand at adding the ability for server extensions to
6637           register various types of "hooks" in addition to just adding
6638           server commands.  This is probably not final.
6639
6640 Tue Sep  8 12:11:56 EDT 1998 Brian Costello <btx@calyx.net>
6641         * Added support for dynamic server modules.  Reworked serv_chat.c
6642           to be such a module.
6643
6644 Tue Sep  1 23:09:50 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
6645         * userpurge.c: rewrote using functions from the server core, rather
6646           than the now-defunct external API.  This'll be ready once the module
6647           loading code is done.  (I just had to commit _something_ tonight.)
6648
6649 Mon Aug 31 22:47:58 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
6650         * Yanked the citadelapi.c module.  This wasn't working out well.
6651         * techdocs/citadelapi.txt - began documenting the new API to be used
6652           by modules which will be dynamic linked into the server - most of
6653           this API is existing server functions.
6654         * Added a ForEachUser() function with callback mechanism, and reworked
6655           cmd_list() to use it.
6656
6657 Sun Aug 30 21:52:43 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
6658         * Moved all of the gdbm databases to a separate "data" directory.
6659
6660 1998-08-26 Nathan Bryant <bryant@cs.usm.maine.edu>
6661         * Makefile.in: realclean removes Makefile, fixed `touch citadel.h'
6662           problem
6663
6664 1998-08-25 Nathan Bryant <bryant@cs.usm.maine.edu>
6665         * room_ops.c: include time.h
6666         * userlist.c, whobbs.c, serv_chat.c, user_ops.c, sysdep.c, stats.c,
6667           citadel_decls.h, commands.c, messages.h, routines.h, routines2.h:
6668           remove duplicated declarations
6669
6670 Mon Aug 24 23:45:01 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
6671         * setup.c: Removed yesno_s()
6672         * citadel.h, room_ops.c: added QRmtime field to struct quickroom,
6673           modified whenever a room is modified or posted in.
6674         * citadelapi.c: Added CtdlForEachRoom() function
6675
6676 Mon Aug 24 20:04:04 EDT 1998 Nathan Bryant <bryant@cs.usm.maine.edu>
6677         * Makefile.in: new target `cleaner' does the same as `realclean' 
6678           without removing sysdep.h
6679         * proto.h: is bad. eliminate. I've moved the prototypes into several
6680           header files, one per .c file
6681
6682 Mon Aug 24 00:45:55 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
6683         * Added a CtdlGotoRoom() function to the CitadelAPI.
6684  
6685 Sun Aug 23 21:47:00 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
6686         * sysoputil is finally dead!  Removed it from the build.
6687         * Added userpurge.c server extension (initial implementation)
6688
6689 Tue Aug 18 00:42:33 EDT 1998 Nathan Bryant <bryant@cs.usm.maine.edu>
6690         * Makefile.in: `clean' target no longer rm's sysdep.h; new target
6691           `realclean' removes everything clean does, plus sysdep.h, plus
6692           target binaries.
6693         * Configure: add -Wstrict-prototypes to CFLAGS for gcc systems
6694         * *.[ch]: protoized. Added several new header files containing
6695           prototypes and other external declarations; many duplicated
6696           declarations still should be moved to header files. proto.h must die
6697           as well, IMHO.
6698
6699 Mon Aug 17 23:52:13 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
6700         * Implemented a bunch of user account related functions in the
6701           CitadelAPI library.
6702
6703 Mon Aug 17 20:01:18 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
6704         * Fixed the crash problem.  It wasn't AGUP/ASUP, but rather a buffer
6705           overrun in getuser() (thanks, Nathan).  Implemented overrun checks
6706           in getuser(), getroom(), and getfloor() to prevent future problems.
6707
6708 Mon Aug 17 00:06:52 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
6709         * Updated citmail.c with the latest stuff from the production system.
6710         * Implemented AGUP and ASUP commands, but AGUP crashes the server
6711           after its first successful use (user-not-found's don't affect it).
6712
6713 Thu Aug  6 19:25:01 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
6714         * Got the CitadelAPI library to the point where the server can start
6715           up an extension, and the extension will connect to the server, do
6716           some initialization, call a user-supplied CtdlMain(), and exit.  Also
6717           hacked together a _temporary_ form of the new EXTN server command.
6718  
6719 Wed Aug  5 23:02:22 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
6720         * Second attempt at getting the server API started.  Now it runs
6721           outside of the server and builds a connection.
6722
6723 Tue Aug  4 18:33:06 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
6724         * Modified the appearance of Internet addresses when they arrive on
6725           a Citadel system.
6726         * Removed the <E> field from the message format writeup in hack.txt.
6727         * Fixed-up citmail.c so that it doesn't try to do database lookups.
6728
6729 Mon Aug  3 23:01:37 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
6730         * Started developing the server-side API.  This is in its very
6731           initial stages.  See serverapi.c and techdoc/api.txt
6732
6733 1998-08-02  Nathan Bryant  <bryant@cs.usm.maine.edu>
6734         * Makefile.in: added config_decls.h to dependencies
6735
6736 Sun Aug  2 21:09:09 EDT 1998 Nathan Bryant <bryant@cs.usm.maine.edu>
6737         * config_defs.h: renamed to config_decls.h
6738         * config.c, sysoputil.c: updated to reflect the above
6739
6740 Sun Aug  2 18:52:05 EDT 1998 Nathan Bryant <bryant@cs.usm.maine.edu>
6741         * config_defs.h: new file, contains external declarations from config.c
6742         * config.c: moved defs to config_defs.h, use PATH_MAX from <limits.h>
6743           for ctdl_home_directory
6744         * mailinglist.c, support.c: include <string.h>
6745         * sysoputil.c: include <string.h>, <limits.h>, "config_defs.h", remove
6746           duplicated defs, replace gets() call with fgets()
6747         * user_ops.c: define _XOPEN_SOURCE_EXTENDED
6748
6749 Sat Aug  1 18:32:52 EDT 1998 Nathan Bryant <bryant@cs.usm.maine.edu>
6750         * ipc_c_tcp.c: fixed order of memcpy parameters after gethostbyname
6751
6752 Sun Jul 19 17:26:12 EDT 1998 Nathan Bryant <bryant@cs.usm.maine.edu>
6753         * ChangeLog: reordered; the GNU standard is to add new entries to the
6754           top.
6755         * .cvsignore: added userlist
6756
6757 Sun Jul 12 20:58:59 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
6758         * Finished migrating everything to the new data store.
6759         * Replaced the binary "calllog" with the ASCII "citadel.log"
6760         * Began converting broken utilities that depend on the old data store
6761
6762 Sat Jul 11 00:20:48 EDT 1998 Nathan Bryant <bryant@cs.usm.maine.edu>
6763         * Makefile.in: removed msgstats
6764
6765 Fri Jul 10 1998 Art Cancro <ajc@uncensored.citadel.org>
6766         * Initial CVS import
6767