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