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