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