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