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