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