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