]> code.citadel.org Git - citadel.git/blob - citadel/ChangeLog
* migratenet almost finished
[citadel.git] / citadel / ChangeLog
1  $Log$
2  Revision 580.70  2001/10/28 05:18:51  ajc
3  * migratenet almost finished
4
5  Revision 580.69  2001/10/26 04:26:45  ajc
6  * more work on the net migrator
7
8  Revision 580.68  2001/10/23 03:37:33  ajc
9  * Threw a few more lines of code into migratenet.c
10
11  Revision 580.67  2001/10/20 18:10:50  ajc
12  * migratenet.c: added (not even close to being finished)
13
14  Revision 580.66  2001/10/17 21:07:20  nbryant
15  further format string cleanups (for i686-linux type sizes)
16
17  Revision 580.65  2001/10/17 20:41:07  nbryant
18   - declare *printf format specifiers if gcc detected
19   - format string fixes (compiles w/o warnings on alpha osf/1)
20
21  Revision 580.64  2001/10/17 19:40:38  nbryant
22  warning fixes and cleanups for 64-bit machines
23
24  Revision 580.63  2001/10/16 20:47:37  nbryant
25  - backed out -export-dynamic, it doesn't do anything and i've found the real
26  problem
27  - remove declaration for make_message
28
29  Revision 580.62  2001/10/16 19:18:49  nbryant
30  backed out that compiler detection change for Tru64. it's not incredibly
31  important and results in broken autoconf macro expansions.
32
33  Revision 580.61  2001/10/16 18:36:33  nbryant
34  reinstate -export-dynamic for citserver in case libtool decides to build
35  static libraries (why?)
36
37  Revision 580.60  2001/10/16 18:21:53  nbryant
38  add some explanatory text to bootstrap
39
40  Revision 580.59  2001/10/16 17:43:53  nbryant
41   - further configure tweaks for FreeBSD and Tru64 Unix
42   - updated to latest libtool configure fragment
43   - there are two functions named make_message. (?) so declare them both
44     static.
45
46  Revision 580.58  2001/10/16 01:48:55  nbryant
47  - configury tweaks for a /usr/include/db3 goof and Digital/Tru64 Unix
48  - #ifdef out inline on non-GCC compilers
49
50  Revision 580.57  2001/10/15 19:50:50  ajc
51  * Fixed a bug in the loopzapper that was corrupting the use table saved copy.
52  * Post notification in Aide> when the loopzapper catches a message.
53
54  Revision 580.56  2001/10/12 22:41:11  ajc
55  * Wrote the rest of the use table code.  Finished except for a bug.
56
57  Revision 580.55  2001/10/10 18:35:12  ajc
58  * Comments & cosmetics for previous update
59
60  Revision 580.54  2001/10/10 17:12:54  ajc
61  * Bugfix for MSG0 command to properly handle multipart/alternative
62
63  Revision 580.53  2001/10/06 21:32:29  ajc
64  * Finished the concurrency check for network polling.  (Now works both for
65    polling and being polled.  Severe UUCP deja vu.)
66
67  Revision 580.52  2001/10/06 20:28:06  ajc
68  * Began implementing some concurrency stuff for the networker
69
70  Revision 580.51  2001/10/06 19:51:47  ajc
71  * Stripped the build of obsolete parts of the old networker no longer in use.
72
73  Revision 580.50  2001/10/03 20:05:50  ajc
74  * serv_smtp.c: implement RFC2920 ESMTP "pipelining" extension on the server
75    side.  (No changes required other than advertising the extension.)
76
77  Revision 580.49  2001/10/03 03:15:16  ajc
78  * Implemented BOUNCE BOUNCE BOUNCE
79
80  Revision 580.48  2001/10/02 03:04:30  ajc
81  * Allow non-Aides to terminate sessions belonging to them
82
83  Revision 580.47  2001/09/24 18:55:13  ajc
84  * Completed migrating the "netpoll" utility into the serv_network module.
85    Removed this utility.
86
87  Revision 580.46  2001/09/21 20:58:25  nbryant
88  support different log_archive prototype in DB versions prior to 3.3
89
90  Revision 580.45  2001/09/20 04:17:10  ajc
91  * Inbound network authentication working.  Fixed a bug in the split-horizon
92    algorithm.  Still need to move the 'netpoll' command into the server.
93
94  Revision 580.44  2001/09/18 04:05:04  ajc
95  * Added host/IP and port to node config (client side only)
96
97  Revision 580.43  2001/09/17 23:55:45  ajc
98  * Support for IGnet routing (not tested)
99
100  Revision 580.42  2001/09/16 05:44:51  ajc
101  * serv_smtp.c: instead of doubling delivery retry times unbounded, set a
102    maximum retry time of SMTP_RETRY_MAX (currently set to 12 hours)
103
104  Revision 580.41  2001/09/09 16:19:29  error
105  * Updated PAM configuration file citadel.pam for Red Hat 7.x.
106
107  Revision 580.40  2001/09/09 03:19:38  ajc
108  * cdb_cull_logs() now removes log files as soon as the log_archive() function
109    says it's ok to do so.
110
111  Revision 580.39  2001/09/08 18:58:38  ajc
112  * More changes to the new networker.  Added client command for room sharing.
113
114  Revision 580.38  2001/09/07 04:05:27  ajc
115  * You guessed it: still more code for the new networker.
116
117  Revision 580.37  2001/09/06 05:47:29  nbryant
118  check for /usr/include/db3 (for RedHat 6.2; others?)
119
120  Revision 580.36  2001/09/06 05:23:14  nbryant
121  #include fix for glibc 2.1.3
122
123  Revision 580.35  2001/09/06 04:02:34  ajc
124  * A few more updates to the networker
125
126  Revision 580.34  2001/09/06 03:32:41  nbryant
127  build fix for sparc-sun-solaris2.8; i think the dependencies should be
128  set up properly for all platforms now.
129
130  Revision 580.33  2001/09/06 02:55:27  nbryant
131  build fix for Linux
132
133  Revision 580.32  2001/09/06 02:49:22  ajc
134  * Fixed paste-post mode (<.E>nter <A>scii) to append instead of replace when
135    the user hits <C>ontinue (bug reported by Stu Mark)
136
137  Revision 580.31  2001/09/06 01:26:39  nbryant
138   - port to Cygwin (DLL support, etc.)
139   - don't build SMTP module if there's no resolver library (eg on Windows)
140
141  Revision 580.30  2001/09/06 00:54:01  nbryant
142  updated to libtool 1.4.1 and automake 1.5
143
144  Revision 580.29  2001/08/29 02:51:25  ajc
145  * More work on the new networker.
146
147  Revision 580.28  2001/08/25 05:04:57  ajc
148  * Worked a little more on the in-server replacement for netproc
149
150  Revision 580.27  2001/08/22 04:18:17  ajc
151  * Realized that there was lots of similarly broken code in
152    process_rfc822_addr().  Wrote two new utility functions in tools.c
153    stripout() and stripallbut() and used them where appropriate.  This should
154    take care of all possible infinite loops.
155
156  Revision 580.26  2001/08/22 03:43:11  ajc
157  * internet_addressing.c: fixed a bug in process_rfc822_addr() that caused the
158    server to jump into an endless loop when an e-mail address contained
159    unbalanced angle brackets.
160
161  Revision 580.25  2001/08/15 04:26:02  ajc
162  * Added split horizon and delete-after-spool to the new networker
163
164  Revision 580.24  2001/08/14 02:41:57  ajc
165  * Began the migration of netproc into part of the serv_network.c module instead
166    of a standalone program.
167
168  Revision 580.23  2001/08/11 22:35:40  nbryant
169  updated citadel-with-berkeley-db.txt.
170   - updated build instructions
171   - improved backup procedures to be safer and more space-efficient.
172
173  Revision 580.22  2001/08/11 19:18:41  ajc
174  * Realized that I am stupid and started implementing server commands to load
175    and save network configurations, when I had already lovingly implemented the
176    CONF GETSYS and CONF PUTSYS commands to store arbitrary configuration sets
177    in the Local System Configuration> room.  Ripped the newer crap out.
178  * Implemented a skeleton of <.A>ide <S>ysconfig <N>etwork on the client side.
179
180  Revision 580.21  2001/08/11 03:51:56  ajc
181  * Removed the idle timer from the client.  Dialup is dead.
182
183  Revision 580.20  2001/08/06 21:33:29  nbryant
184  made the client fall back on port 504 if there's no /etc/services entry
185
186  Revision 580.19  2001/08/05 23:54:14  ajc
187  * prep for new network node infrastructure
188
189  Revision 580.18  2001/08/03 16:53:21  ajc
190  * Added some more "break" statements to the main switch..case loop in
191    citadel.c where they were needed.
192
193  Revision 580.17  2001/08/03 16:43:53  ajc
194  * database_sleepycat.c: when running txn_checkpoint(), handle DB_INCOMPLETE
195    return code as a warning instead of an error worthy of aborting the server.
196    See http://www.sleepycat.com/docs/api_c/txn_checkpoint.html for explanation.
197
198  Revision 580.16  2001/07/30 03:46:14  nbryant
199  made ForEachUser use a read-only cursor, too. there is now only one piece of
200  code in Citadel proper (not the database driver) that needs transactions.
201  that's check_ref_counts; in other words it's the only thing standing in the way
202  of a clean implementation of retryable transactions.
203
204  Revision 580.15  2001/07/29 22:24:04  nbryant
205   - added a new function to the database interface, cdb_close_cursor().  always
206  call this when you're finished with a traversal but didn't bother reading all
207  the way to the end.
208
209   - removed several cdb_begin_transaction()/cdb_end_transaction() calls that are
210  no longer needed because of the read-only cursor support.
211
212  Revision 580.14  2001/07/29 20:56:09  nbryant
213  change ForEachRoom to use read-only cursors by default. it can be overridden to
214  still use read/write cursors by doing:
215
216   cdb_begin_transaction();
217   ForEachRoom(...);
218   cdb_end_transaction();
219
220  the only place I found where it appears necessary to do so is check_ref_counts,
221  so this checkin affects that function too.
222
223  Revision 580.13  2001/07/29 20:06:33  nbryant
224  generate symlinks to .libs in modules directory
225
226  Revision 580.12  2001/07/28 00:02:50  nbryant
227  implemented read-only cursors. one of the advantages to these is that
228  transactions can be avoided; a cursor operation that occurs within a
229  transaction will often acquire a read lock on every single database page.  in
230  general, the Sleepycat documentation recommends avoiding transaction-protected
231  read-only operations where practical. read/modify/write operations can still
232  be transaction protected, of course.
233
234  to use a read-only cursor, call cdb_rewind without a previous call to
235  cdb_begin_transaction. the DB driver will notice this and prevent the current
236  thread from modifying data or starting a transaction until the cursor is
237  closed.
238
239  Revision 580.11  2001/07/27 20:45:44  nbryant
240  libtool has matured a lot since the last time i looked at it (years ago)
241  so we now use it to handle the details of building shared libraries and
242  the linker flags for the main executable.
243
244  in theory this should bring a lot more portability to the dynloader
245  subsystem and enable us to do things like transparently detect GNU vs Sun
246  linkers on solaris, for example
247
248  Revision 580.10  2001/07/27 03:29:04  nbryant
249  missed one thing in the autoconf move
250
251  Revision 580.9  2001/07/27 02:57:43  nbryant
252  support one cursor per database rather than one global cursor
253
254  Revision 580.8  2001/07/27 01:32:07  nbryant
255  remove the automatic transaction demarcation on singleton read operations
256
257  Revision 580.7  2001/07/26 21:43:46  nbryant
258   - move to autoconf 2.52
259   - random warning fix
260   - check for db 3.3
261
262  Revision 580.6  2001/07/24 13:17:54  ajc
263  * New UI for mailing list setup
264  * rooms.c: code cleanup
265  * docs update
266
267  Revision 580.5  2001/07/20 23:48:23  nbryant
268  fix build on solaris, check default install location for db 3.2, and silence
269  gcc 3.0
270
271  Revision 580.4  2001/07/16 14:24:30  ajc
272  * Silly cosmetic change to keep the wholist ordered by ascending session number
273
274  Revision 580.3  2001/07/13 00:01:36  ajc
275  * Shuffled around some of the housekeeping loop code
276
277  Revision 580.2  2001/07/11 17:01:10  ajc
278  * database_sleepycat.c: small changes to log messages
279
280  Revision 580.1  2001/07/11 04:35:40  nbryant
281  moved dret initialization in cdb_fetch, just in case
282
283  Revision 580.0  2001/07/03 03:07:06  ajc
284  * THIS IS 5.80
285
286  Revision 573.143  2001/07/03 03:06:50  ajc
287  * Last minute doco update for 5.80
288
289  Revision 573.142  2001/07/01 15:44:32  nbryant
290  configure.in: check for Berkeley DB first.
291
292  Revision 573.141  2001/06/27 23:34:30  ajc
293  * Added some verbage to messages/roomaccess to placate a user who keeps
294    bitching about privacy policy.
295
296  Revision 573.140  2001/06/19 03:41:04  ajc
297  * Ooops... last_cull needs to be declared static
298
299  Revision 573.139  2001/06/19 03:33:19  ajc
300  * imap_fetch.c: download MIME parts without decoding first.  We like that.
301  * database_sleepycat.c: added automatic culling of log files which have not
302    been written to in five days.
303
304  Revision 573.138  2001/06/17 19:42:23  nbryant
305  fix all the <time.h> vs. <sys/time.h> issues, hopefully
306
307  Revision 573.137  2001/06/07 03:28:37  ajc
308  * More tweaks to the MIME parser
309
310  Revision 573.136  2001/06/06 15:44:37  ajc
311  * msgbase.c: output extra newline at end of RFC822 message if necessary to
312    ensure that 000 termination string appears on a line by itself.
313
314  Revision 573.135  2001/06/06 04:22:25  ajc
315  * Moved memreadline() to tools.c
316  * internet_addressing.c: fixed conversion of fields to (hopefully) never get
317    into an active loop when encountering badly formed headers
318
319  Revision 573.134  2001/05/27 05:23:03  ajc
320  * Added a "no new messages" response in the client, displayed when a read
321    command turns up a zero message count.
322
323  Revision 573.133  2001/05/18 20:12:09  ajc
324  * Fixed bug in mime_parser.c that caused parts to be dropped when the last
325    boundary was the very last line of the message.
326  * serv_smtp.c: toned down some of the command response verbage.
327
328  Revision 573.132  2001/04/28 04:42:55  ajc
329  * Updated some of the docs.  Bumped version number to 5.80 in anticipation
330    of going into a release cycle soon.
331
332  Revision 573.130  2001/04/26 03:31:00  ajc
333  * Finished the implementation of per-message seen/unseen logic, both in the
334    server proper and in IMAP.  Citadel protocol uses new "seen" command.
335
336  Revision 573.129  2001/04/21 04:55:51  ajc
337  * Began implementation of per-message seen/unseen attribute
338
339  Revision 573.128  2001/04/20 03:39:54  ajc
340  * IMAP LIST/LSUB: made it case insensitive.  Also minor IMAP code cleanup.
341
342  Revision 573.127  2001/04/17 00:35:19  cough
343  * Modified rooms.c in the client so that it would allow inviting into
344    public rooms.  This is important since there is now a V_LOCKOUT
345    flag which prevents users who have been kicked from rejoining
346    a room unless/until you invite them back in.
347
348  Revision 573.126  2001/04/16 19:21:14  cough
349  * Fixed bug in room_ops.c that wasn't allowing aides to goto passworded
350    rooms without knowing the password.
351
352  Revision 573.125  2001/04/14 04:26:44  ajc
353  * Fixed an unterminated string bug in IMAP APPEND.  Storing messages should
354    work now.
355
356  Revision 573.124  2001/04/10 01:04:10  ajc
357  * Finished coding IMAP APPEND.  It works, but there's a bug in it somewhere
358    that is corrupting the memory.
359
360  Revision 573.123  2001/04/03 00:47:23  ajc
361  * Began implementing IMAP APPEND
362
363  Revision 573.122  2001/04/01 22:05:44  cough
364  * *Actually* fixed a botched ChangeLog entry.
365
366  Revision 573.121  2001/04/01 22:04:28  cough
367  * Fixed a botched ChangeLog entry.
368
369  Revision 573.120  2001/04/01 22:03:10  cough
370  * Changed two fclose()s to pclose()s.
371
372  Revision 573.119  2001/03/25 11:52:36  error
373  * serv_pop3.c: Fixed APOP. Now logs in properly. Also cleaned up some non-
374    RFC-compliant error messages.
375
376  Revision 573.118  2001/03/21 05:47:49  ajc
377  * Added the new IMAP mailbox string compare submitted by Daniel Malament.
378
379  Revision 573.117  2001/03/20 01:33:55  ajc
380  * Added the (\NoInferiors) tag to all rooms listed in IMAP.  This made Mozilla
381    behave very nicely.
382
383  Revision 573.116  2001/03/13 17:19:33  ajc
384  * support (BODY[HEADER.FIELDS(BLAH BLAH BLAH)]) and HEADER.FIELDS.NOT
385
386  Revision 573.115  2001/03/12 01:27:42  ajc
387  * Implemented SUBSCRIBE and UNSUBSCRIBE commands
388
389  Revision 573.114  2001/03/11 23:00:29  ajc
390  * Mega sexy hack to deliver express messages THROUGH IMAP!  uber coolness!!
391
392  Revision 573.113  2001/03/11 22:09:20  ajc
393  * Replaced the "citlogin" binary wrapper with the "loginwrapper.sh" script.
394
395  Revision 573.112  2001/03/11 20:06:53  ajc
396  * Fixed bug that created incorrect roomnames when sending pages
397
398  Revision 573.111  2001/03/11 19:23:32  ajc
399  * IMAP DELETE command ... also split up access control for room delete cmds
400
401  Revision 573.110  2001/03/10 17:29:07  ajc
402  * Implement proper access control for deleting messages from IMAP
403
404  Revision 573.109  2001/03/07 04:02:27  ajc
405  * Fixed some small IMAP bugs
406
407  Revision 573.108  2001/03/06 04:44:00  ajc
408  * Probable completion of STATUS, COPY, STORE, and EXPUNGE commands in IMAP
409
410  Revision 573.107  2001/03/06 03:31:58  nbryant
411  database-related cleanups and paranoia tests;
412  fixed a transaction-leak/deadlock problem in cdb_delete;
413  solved the SIGPIPE mystery (GDB stops on SIGPIPE is all it was)
414
415  Revision 573.106  2001/03/05 04:59:31  ajc
416  * IMAP COPY
417
418  Revision 573.105  2001/03/04 23:49:41  ajc
419  * IMAP EXPUNGE responses -should- be correct now
420
421  Revision 573.94  2001/02/20 00:02:56  ajc
422  * IMAP: implemented the STATUS command (sort of).
423
424  Revision 573.93  2001/02/19 22:24:41  ajc
425  * IMAP server: added untagged, unsolicited server messages for newly arrived
426    messages, and messages expunged by another session.
427
428  Revision 573.92  2001/02/17 05:53:35  ajc
429  * Repaired the creation of page log rooms in the wrong namespace when the
430    recipient does not yet have his/her log room created.
431  * Rewrite "EXPI messages" to run in two passes: one to gather messages to
432    purge and the next to delete them.  Works better in transactionland.
433
434  Revision 573.91  2001/02/14 08:11:27  error
435  * citadel.rc: added $Id$ (it's about time!)
436
437  Revision 573.90  2001/02/14 04:23:54  ajc
438  * Fixed POP3 server responses ending in \n instead of \r\n as they should be.
439    This was causing some clients (such as Pine) to lock up.
440
441  Revision 573.89  2001/02/13 04:06:14  ajc
442  * Worked out the remaining bugs in IMAP FETCH for the BODYSTRUCTURE and
443    BODY[n] data items.  I think.  So much protocol crud, so little time...
444
445  Revision 573.88  2001/02/13 01:18:44  ajc
446  * imap fetch
447
448  Revision 573.87  2001/02/12 04:31:34  ajc
449  * sysdep.c ig_tcp_server() - use IPPROTO_TCP instead of getprotobyname()
450
451  Revision 573.86  2001/02/08 04:45:58  ajc
452  * Fixed namespace problems resulting from the automatic namespece prefixing
453    added to create_room().  Also added the ability to specify "create a mailbox
454    but I've already supplied the namespace prefix" for situations where the
455    namespace isn't that of the logged in user.
456  * Made the POP3 server response messages slightly less humorous
457
458  Revision 573.85  2001/02/06 04:44:12  ajc
459  * Added a floor listing (complete with \NoSelect flag) to LIST and LSUB
460
461  Revision 573.84  2001/02/06 02:09:38  ajc
462  * citadel.rc: changed the default for local_screen_dimensions to 1, since
463    Internet users now outnumber dialup users 100 to 0.
464  * room_ops.c: added a really_create option to create_room().  Also moved the
465    generation of personal namespace into that function.  MODULE OWNERS PLEASE
466    CHECK YOUR CALLS TO AVOID MULTIPLE NAMESPACING!!
467  * room_ops.c: fixed a bug in cgetfloor() that left bad pointers around
468  * serv_imap.c: finished the CREATE command (finally)
469
470  Revision 573.83  2001/02/05 05:20:22  ajc
471  * Made some changes to functions which translate between Citadel room names
472    and IMAP folder names.  They're still buggy.
473
474  Revision 573.82  2001/02/04 23:17:28  ajc
475  * Implemented the IMAP CREATE command
476
477  Revision 573.81  2001/02/04 02:40:07  ajc
478  * more imap.  imap sucks.  die crispin die.
479
480  Revision 573.80  2001/02/03 10:02:12  error
481  * serv_ical.c: Verify that objects posted to My Calendar> are of type
482    text/x-calendar or text/calendar; abort saving if not
483
484  Revision 573.79  2001/02/03 09:30:46  error
485  * serv_ical.c: now creates a My Calendar> personal room, sets attributes
486
487  Revision 573.78  2001/02/03 08:21:00  error
488  * serv_ical.c and serv_ical.h added; skeleton code for now
489
490  Revision 573.77  2001/02/02 20:18:18  ajc
491  * Changed the error message in cdb_delete() to actually *say* cdb_delete
492    instead of cdb_store.  Useful to know which function failed...
493
494  Revision 573.76  2001/02/01 04:08:03  ajc
495  * IMAP minor change to mailbox name output
496  * Increased size of buffer in lprintf()
497
498  Revision 573.75  2001/01/28 09:50:02  error
499  * sysdep.c: lprintf() now generates timestamps
500
501  Revision 573.74  2001/01/28 07:35:04  error
502   * serv_bio.c: RBIO now also returns stats about a user, see session.txt
503
504  Revision 573.73  2001/01/16 04:03:13  ajc
505  * yeesh ... more on the IMAP BODYSTRUCTURE
506
507  Revision 573.72  2001/01/16 01:51:12  ajc
508  * imap bodystructure
509
510  Revision 573.71  2001/01/16 00:46:40  ajc
511  * Changed the MIME parser API *again* because we now need the ability to
512    supply callback functions to be executed before and/or after parsing a
513    multipart.  (Need this for IMAP BODYSTRUCTURE output.  Crispin sucks.)
514
515  Revision 573.70  2001/01/15 23:59:26  ajc
516  * user_ops.c: reject NULL password in CtdlTryPassword() instead of crashing
517
518  Revision 573.68  2001/01/15 20:34:04  ajc
519  * "Path:" removed for now because it confuses brain-dead Microsoft shitware
520    into thinking that mail messages are newsgroup messages instead.  When we
521    add NNTP support back into Citadel we'll have to add code to only output
522    this field when appropriate.
523
524  Revision 573.67  2001/01/15 16:30:31  ajc
525  * temporary implementation of 901 asynchronous express messages
526
527  Revision 573.66  2001/01/14 14:55:39  ajc
528  * Changed the format of <.W>holist <L>ong
529
530  Revision 573.65  2001/01/13 06:40:26  nbryant
531  merged remaining changes from TRANSACTIONS (using cvs update -j TRANSACTIONS)
532  which should now be considered closed.
533
534  Revision 573.64  2001/01/13 06:12:15  ajc
535  * Added the ASYN command
536
537  Revision 573.63  2001/01/12 22:05:46  ajc
538  * Fixed a bug that caused bogus wholist lines to be displayed when a non-aide
539    reads a list containing stealth mode sessions.
540
541  Revision 573.62  2001/01/09 05:39:45  ajc
542  * Merged in code from the TRANSACTIONS branch for testing.
543
544  Revision 573.61  2000/12/30 06:17:17  ajc
545  * Still more work on IMAP.  Damn this is tedious.
546
547  Revision 573.60  2000/12/30 04:55:05  ajc
548  * more buffer size stuff
549
550  Revision 573.59  2000/12/27 20:19:51  ajc
551  * The size constant "256" which shows up everywhere as a buffer size has now
552    been changed to SIZ.  And, SIZ has been defined now as 1024, not 256, because
553    we need 1024 byte buffers for most Internet protocols.
554
555  Revision 573.58  2000/12/27 05:09:58  ajc
556  * Added a skeleton IMAP "SEARCH" command (based on the FETCH logic)
557
558  Revision 573.57  2000/12/26 03:46:50  ajc
559  * More IMAP tweaks
560
561  Revision 573.56  2000/12/25 22:50:43  ajc
562  * Added an API function to extract and unfold specific RFC822 fields.
563  * imap-->fetch-->envelope-->in-reply-to now works
564  * More robust checking and reporting of temp file errors in the client
565
566  Revision 573.55  2000/12/25 20:43:24  ajc
567  * imap_fetch.c: added support for fetch-->envelope-->from
568
569  Revision 573.54  2000/12/20 04:09:24  ajc
570  * A few memory handling fixes to netproc.
571
572  Revision 573.53  2000/12/20 01:57:37  ajc
573  * netproc.c: added bounds check to fpgetfield()
574
575  Revision 573.52  2000/12/19 20:41:55  ajc
576  * Fixed generation of unique file names for network uploads etc.
577
578  Revision 573.51.2.11  2000/12/26 05:30:55  nbryant
579  remove extraneous transaction around dynamic module initializations. this will
580  fix the crash on database creation.
581
582  Revision 573.51.2.10  2000/12/24 23:00:58  nbryant
583  clean: also remove parsedate.c
584
585  Revision 573.51.2.9  2000/12/20 01:38:42  nbryant
586  require transactional cursors
587
588  Revision 573.51.2.8  2000/12/20 00:30:01  nbryant
589  release any stale db handles at the end of a server command
590  (unfinished transactions will be aborted to annoy lazy programmers)
591
592  Revision 573.51.2.7  2000/12/19 06:18:27  nbryant
593  set sched_yield as sleepycat's yield function. this should improve locking
594  performance.
595
596  Revision 573.51.2.6  2000/12/19 02:22:29  nbryant
597  added automatic transaction start/end on cdb_fetch, cdb_delete, and cdb_store
598
599  Revision 573.51.2.5  2000/12/18 03:51:13  nbryant
600  ditto S_USER_TRANS, S_CALLLOG, and S_HOUSEKEEPING, which are no longer used at
601  all
602
603  Revision 573.51.2.4  2000/12/18 02:49:17  nbryant
604  removed all references to S_MSGMAIN critical section; it wasn't really needed.
605  this should make things significantly more scaleable.
606
607  Revision 573.51.2.3  2000/12/17 22:12:48  nbryant
608  reworked shutdown sequence to wait for worker threads to terminate before
609  checkpointing and closing databases. it is no longer safe to call
610  master_cleanup() directly to force a shutdown; instead, just set
611  time_to_die to a nonzero value
612
613  Revision 573.51.2.2  2000/12/17 05:06:09  nbryant
614  added deadlock detection and cleaned up messages
615
616  Revision 573.51.2.1  2000/12/16 21:06:59  nbryant
617  created TRANSACTIONS branch
618  track cursor and transaction id's in thread-specific data
619
620  Revision 573.51  2000/12/14 18:36:34  ajc
621  * Fixed the "users not in chat" wholist display
622
623  Revision 573.50  2000/12/12 18:06:46  ajc
624  * Removed the transaction stuff (but left the log in).  It wasn't working.
625
626  Revision 573.49  2000/12/12 06:19:55  ajc
627  * Stabilize, dammit!!
628
629  Revision 573.48  2000/12/12 04:20:03  ajc
630  * Made the transaction open/close a global thing, in a frantic attempt to get
631    Uncensored to stop crashing.  More fixes on the way...
632
633  Revision 573.47  2000/12/11 06:08:41  ajc
634  * Removed the housekeeper thread, moved terminate_idle_sessions() out to a
635    timer event, and check_sched_shutdown() to the end of the worker thread
636    loop.  Seems to have improved reliability (but why?)
637
638  Revision 573.46  2000/12/11 03:22:11  ajc
639  * Added server-side REQT command to issue client termination requests
640
641  Revision 573.45  2000/12/11 02:19:26  ajc
642  * Client now honors EM_GO_AWAY flag, used by the server to request that a
643    client log off.  (The server doesn't support sending that flag yet, though)
644
645  Revision 573.44  2000/12/09 06:20:06  ajc
646  * A few final touches to the Sleepycat DB back-end
647
648  Revision 573.43  2000/12/08 17:06:33  ajc
649  * Wrap txn_begin and txn_end in S_DATABASE mutex
650
651  Revision 573.42  2000/12/07 20:21:39  ajc
652  * begin/end transaction in master_startup()
653
654  Revision 573.41  2000/12/07 16:59:02  nbryant
655  added --with-db and --with-gdbm options to configure
656
657  Revision 573.40  2000/12/07 04:50:33  ajc
658  * Wrap housekeeper and timer events in transaction open/close functions
659  * Checkpoint the DB as an EVT_TIMER event instead of after each session
660    (runs each minute, but actually limited by the parameters of the function)
661
662  Revision 573.39  2000/12/06 04:44:36  ajc
663  * Changed netproc to keep the use table in a flat file instead of a database
664
665  Revision 573.38  2000/12/05 05:32:58  ajc
666  * Added support for non-USA country identities in vCard and registration
667  * User edit now asks whether it should prompt to change the password
668
669  Revision 573.37  2000/12/03 04:12:21  ajc
670  * Finished (mostly) the Sleepycat DB backend ... added transaction logging
671
672  Revision 573.36  2000/11/30 03:23:17  ajc
673  * Got the Sleepycat DB back end working, by opening the databases in a non
674    shared, non threaded mode, and using Citadel's locking to serialize access.
675
676  Revision 573.35  2000/11/29 05:00:02  ajc
677  * I think the db stuff is ok, but my db library is fux0red...
678
679  Revision 573.34  2000/11/27 14:12:09  error
680  * commands.c: fixups to print_express() to make external command not print
681    extraneous stuff to the terminal and make the displayed message consistent
682
683  Revision 573.33  2000/11/27 10:41:14  error
684  * print_express(): now uses GEXP instead of old PEXP; displays timestamps
685
686  Revision 573.32  2000/11/27 10:29:59  error
687  * serv_chat.c: fix send_express_message() to include timestamps
688
689  Revision 573.31  2000/11/27 03:44:27  ajc
690  * Initial checkin of database_sleepycat.c (doesn't work yet)
691
692  Revision 573.30  2000/11/26 05:24:22  ajc
693  * msgbase.c: Added new API function CtdlOutputPreLoadedMsg(), and
694    re-implemented the existing CtdlOutputMsg() as a wrapper around it.
695  * imap_fetch.c: used the above function to do all output pre-loaded
696
697  Revision 573.29  2000/11/25 09:36:18  error
698  * Added a bit of detail to syslog entries; now shows session id attached to
699    client, hostname, and username, and time the session ended.
700
701  Revision 573.28  2000/11/25 06:17:06  ajc
702  * Minor IMAP tweaks.  It still doesn't work.  :(
703
704  Revision 573.27  2000/11/23 07:22:21  error
705  * citadel.spec: update version number
706
707  Revision 573.26  2000/11/21 11:12:56  error
708   * domain.h: changed the HP/UX compatibility code to use defines from
709     typesize.h for integers of specific bit widths (needed for Solaris, etc)
710
711  Revision 573.25  2000/11/12 04:20:49  ajc
712  * Optimized server side input of message text
713
714  Revision 573.24  2000/11/10 03:55:06  ajc
715  * Ford's Fix for Faster Functionality (save position during reply)
716
717  Revision 573.23  2000/11/09 04:48:50  ajc
718  * tools.c: striplt() strips all whitespace, not just spaces
719
720  Revision 573.22  2000/11/07 20:47:21  ajc
721  * imap_fetch.c: added a skeleton "ENVELOPE" fetch.  Currently sends NIL's.
722
723  Revision 573.21  2000/11/07 15:54:53  ajc
724  * xx FETCH n:n BODY[pn.MIME] now works
725
726  Revision 573.20  2000/11/06 05:10:01  ajc
727  * Changed the mime_parser() API (again) to allow "don't decode" mode
728
729  Revision 573.19  2000/10/29 18:11:07  ajc
730  * Start numbering top-level MIME parts as 1, 2... not 1.1, 1.2...
731
732  Revision 573.18  2000/10/28 14:14:19  error
733  * msgbase.c: eliminated most gotos; a single goto in alias() remains because
734    it actually makes sense to do it that way...
735
736  Revision 573.17  2000/10/25 21:37:09  ajc
737  * Implemented the AUTHENTICATE LOGIN command in IMAP
738
739  Revision 573.16  2000/10/25 19:20:37  ajc
740  * FETCH now works for ranges *and* sets, and with sequence numbers *and* UID's
741
742  Revision 573.15  2000/10/24 20:39:59  ajc
743  * Added RFC822, RFC822.HEADER, RFC822.SIZE, RFC822.TEXT fetch keys to IMAP
744
745  Revision 573.14  2000/10/23 20:26:51  error
746  * War on goto:  rewrote a few easy functions to eliminate unnecessary gotos
747
748  Revision 573.13  2000/10/11 23:03:44  error
749  * utilsmenu: obey $PAGER environment var, if any.  Default to more if neither
750    $PAGER nor less is available.
751
752  Revision 573.12  2000/10/11 22:55:25  error
753  * citadel.c: when ansi_color=user, enable color at login, so Lobby> posts
754    displayed at login are in color
755
756  Revision 573.11  2000/10/11 22:47:51  error
757  * domain.c: getmx() returns hostname as MX if no MX records found a la RFC 974
758
759  Revision 573.10  2000/10/10 19:18:12  ajc
760  * Added support of macros ALL, BODY, FAST, and FULL to the IMAP FETCH command
761
762  Revision 573.9  2000/10/06 03:31:55  ajc
763  * Mark Crispin is a fscking idiot.  IMAP is a convoluted mess.
764
765  Revision 573.8  2000/10/05 22:23:16  ajc
766  * Slowly and painfully writing IMAP support
767
768  Revision 573.7  2000/10/04 22:39:06  ajc
769  * Added skeleton versions of the LIST and LSUB commands to the imap server
770
771  Revision 573.6  2000/10/04 17:48:21  ajc
772  * Allow Aides to zap rooms (site configurable setting)
773
774  Revision 573.5  2000/10/03 01:45:00  ajc
775  * Changed the <.A>ide <S>ysconfig <G>eneral command to explicitly allow the
776    global page log room to be disabled (answer "no" to set the log room to a
777    null string)
778
779  Revision 573.4  2000/09/28 10:27:38  error
780  * commands.c: changed sttybbs() to support HP/UX termios VMIN and VTIME
781
782  Revision 573.3  2000/09/24 22:01:45  ajc
783  * ipc_c_tcp.c: don't hardcode BBSDIR path for unix domain sockets
784
785  Revision 573.2  2000/09/21 04:16:44  ajc
786  * Fixed logged_in_response() so it only displays responses during Citadel
787    protocol sessions.  (This was affecting POP etc.)
788
789  Revision 573.1  2000/09/11 22:05:04  ajc
790  * citadel.c: accept -h <host> and -p arguments, so citadel can be called
791    directly by telnetd, bypassing /bin/login.  It works, but not recommended at
792    this time because it has to run as root.
793
794  Revision 573.0  2000/09/05 18:35:22  ajc
795  * Tagged everything for version 5.73 release
796
797  Revision 572.39  2000/09/04 03:59:15  ajc
798  IO's changes:
799  ----------------------------
800  revision 572.4
801  date: 2000/09/03 06:36:01;  author: error;  state: Exp;  lines: +5 -1
802  Added HP/UX linker flag for dynamic modules to work
803  ----------------------------
804  revision 572.3
805  date: 2000/09/01 06:50:00;  author: error;  state: Exp;  lines: +8 -1
806  Changed to use integer macros from typesize.h for specific bit widths
807  ----------------------------
808
809  Revision 572.38  2000/09/01 20:17:08  ajc
810  * msgbase.c: cmd_opna() - increase desired_section buffer from 64 to 256 bytes
811
812  Revision 572.37  2000/09/01 17:31:47  ajc
813  * Fixed oopseth in control.c that might call fileno(NULL)
814
815  Revision 572.36  2000/09/01 13:37:16  ajc
816  * control.c: chown citadel.control to bbsuid when opening/creating as root
817
818  Revision 572.35  2000/09/01 03:55:44  ajc
819  * Fixed a few more references to the deprecated uncnsrd.mt-kisco.ny.us name
820
821  Revision 572.34  2000/09/01 03:43:09  ajc
822  * Added 'author' command-line arg to aidepost.  Closes enhancement request
823    #71 on bugzilla.
824  * Put the default SMTP and POP3 ports back to 25 and 110.  Now that the
825    unix domain socket bug is fixed, it's ok if these binds fail.
826
827  Revision 572.33  2000/08/31 23:02:15  ajc
828  * ig_tcp_server() and ig_uds_server()  -  check to make sure queue length is
829    always at least 5.  Zero-length queues can cause connection lockups.
830
831  Revision 572.32  2000/08/31 21:32:44  ajc
832  * Still trying to fix a socket connect bug
833
834  Revision 572.31  2000/08/31 16:37:08  ajc
835  * docs/import-export.txt: added.
836
837  Revision 572.30  2000/08/28 19:51:51  ajc
838  * messages.c: cosmetic cleanup (coding convention and comments)
839
840  Revision 572.29  2000/08/26 20:23:18  ajc
841  * Finished up the back end code for mailing list sends.  Sends now work!
842
843  Revision 572.28  2000/08/24 02:48:18  ajc
844  * Merged in IO ERROR's diffs to make Citadel work with HP/UX
845
846  Revision 572.27  2000/08/22 02:31:47  ajc
847  * nonce (for APOP-style auth) is now generated when a context is created
848    instead of during protocol greeting functions.
849  * Moved Citadel protocol nonce output from greeting to INFO
850
851  Revision 572.26  2000/08/18 21:09:36  ajc
852  * Added a little more mailing list code to serv_network.c
853
854  Revision 572.25  2000/08/10 04:36:25  ajc
855  * Fixed a bug in keyboard polling (in commands.c) which was causing the
856    client protocol to get out of sync in certain conditions.
857
858  Revision 572.24  2000/08/10 02:42:13  ajc
859  * Changed all the "200 ok" responses to more descriptive strings
860  * Added a *temporary* protocol sync check.  Remove this!
861
862  Revision 572.23  2000/08/09 17:14:34  ajc
863  msgbase.c: fixed a bug in
864             remove_any_whitespace_to_the_left_or_right_of_at_symbol() that was
865             causing the <R>eply function to fail on names with whitespace in
866             certain parts of the string.  This closes Bug #56.
867
868  Revision 572.22  2000/08/05 04:24:00  ajc
869  * Added [idle] to client wholist display for sessions idle >15 minutes
870  * Added a generic "void *userdata" field to CtdlForEachMessage()
871  * More prep for mailing list handling in the server
872
873  Revision 572.21  2000/07/30 04:36:12  ajc
874  * Set up the SNET (Send NETwork config) and GNET (Get NETwork config) commands
875    for the network overhaul.
876
877  Revision 572.20  2000/07/29 05:29:19  ajc
878  * Changed the format of RWHO output to provide non-masqueraded user/room/host
879    names (to Aides only) as additional fields rather than an extra line of
880    output.
881  * Changed the client to display new RWHO fields, in the "long" wholist only.
882  * Default SMTP and POP ports are now -1, not 25/110.  These services must now
883    be activated manually.
884
885  Revision 572.19  2000/07/24 00:39:13  ajc
886  * Fixed a path problem when calling netmailer from mailinglist.c
887
888  Revision 572.18  2000/07/22 03:44:17  ajc
889  * Prepared infrastructure for the networker rewrite
890
891  Revision 572.17  2000/07/17 02:38:08  ajc
892  * Completed serv_vandelay.c (importer/exporter module)
893  * sendcommand.c: fix behavior of SEND_LISTING mode
894  * sysdep.c: client_gets() fill buffer with "000" terminator when returning -1
895
896  Revision 572.16  2000/07/14 03:06:55  ajc
897  * Added .ATN (DOWN) and .ATS (SCDN 1) commands to the client
898
899  Revision 572.15  2000/07/10 23:36:08  ajc
900  * Another attempt to fix the crashy crashy bug in serv_vcard
901  * Did more work on the Art Vandelay module
902  * Replaced all instances of sprintf(tempfile, tmpnam(NULL)) with strcpy()
903
904  Revision 572.14  2000/07/10 04:01:12  ajc
905  * added an unfinished serv_vandelay.c (Art Vandelay module - importer/exporter)
906
907  Revision 572.13  2000/07/09 02:47:40  ajc
908  * Overhauled the keepalive logic in the chat client.  Closes bug #20.
909
910  Revision 572.12  2000/07/09 02:27:02  ajc
911  * Eliminated the whole SIGINT/SIGQUIT based handling of Ctrl-O and Ctrl-C
912    keyboard interrupts.  Replaced with a non-blocking check for keyboard input
913    which sets the global variable 'sigcaught' if either key was pressed.
914    fmout() and pprintf() switch to 'drain mode' if sigcaught is set.
915    This closes Bug #18.
916
917  Revision 572.11  2000/07/06 20:26:36  ajc
918  * updated .Help SUMMARY
919
920  Revision 572.10  2000/07/04 20:02:46  ajc
921  * Fixed potential crashy crashy bug in serv_vcard.c
922
923  Revision 572.9  2000/06/28 03:42:56  ajc
924  * Changed the comments at the beginning of each file to a consistent format
925  * Improved the parameterization of commands in the IMAP module
926
927  Revision 572.8  2000/06/27 01:27:13  ajc
928  * Coupla very small changes to get on the road to IMAP support
929
930  Revision 572.7  2000/06/22 21:41:48  ajc
931  * Made the ICQ stuff far more reliable ... by removing it!
932
933  Revision 572.6  2000/06/21 03:46:20  ajc
934  * IMAP is now legal but useless, supporting NOOP, LOGIN, and LOGOUT.
935
936  Revision 572.5  2000/06/15 20:15:52  ajc
937  * Inserted a skeleton IMAP module into the build.  IT DOES NOT WORK AT ALL.
938
939  Revision 572.4  2000/06/04 02:30:56  ajc
940  * CtdlForEachMessage() now returns the number of messages processed.  It also
941    accepts the MSGS_EQ mode, for targeting a specific message number (useful
942    for determining whether the specified message actually exists in a room).
943  * Completed the server side of the moderation system (serv_moderate.c module
944    which implements the MMOD command)
945
946  Revision 572.3  2000/06/03 05:47:57  ajc
947  * Replaced most of the very repetitive and very redundant access level checks
948    in most commands with a single API call:  CtdlAccessCheck()
949  * serv_moderate.c: added (not finished)
950
951  Revision 572.2  2000/06/02 03:38:50  ajc
952  * Bind unix socket prior to TCP socket for citadel protocol
953  * Fixed bug in sendcommand.c which was causing it to crash on attach
954
955  Revision 572.1  2000/05/26 19:27:51  ajc
956  * Changed some of the rev-level sensitive stuff to look at the actual version
957    of Citadel running, not the last version with which we ran setup
958  * Added a moderation system.  Default filter level for new users is in the
959    config file.  Per-user setting is in usersupp.  Moderation level of each
960    message is in SuppMsgInfo.  Tweaked CONF, GETU, and SETU.  Read filter is
961    working.  Moderate message up/down commands are not here yet.  See
962    techdoc/moderation.txt for more info.
963
964  Revision 572.0  2000/05/23 02:09:30  ajc
965  * Updated docs and tagged everything for the 5.72 release
966
967  Revision 571.7  2000/05/20 23:28:20  ajc
968  * Fixed bug in client API that was causing netproc to crash
969
970  Revision 571.6  2000/05/15 00:05:19  ajc
971  * Double the retry interval for SMTP deliveries after each failed attempt.
972
973  Revision 571.5  2000/05/11 03:08:47  ajc
974  * serv_smtp.c: clear the relevant state buffers after an SMTP DATA command
975    completes, allowing multiple messages in one session.  Closes bug #58.
976
977  Revision 571.4  2000/04/24 03:36:43  ajc
978  * Removed references to strucmp() and struncmp(), replaced them with
979    strcasecmp() and strncasecmp() as we did in the server a while ago, and
980    set up the config script to figure out whether they need to be compiled
981    in.  Also moved them to tools.h
982  * Wrote a password manager for the client
983
984  Revision 571.3  2000/04/19 03:17:10  ajc
985  * Don't ever expire the Local System Configuration> room
986
987  Revision 571.2  2000/04/16 19:03:47  ajc
988  * Minor changes to avoid host lookup for local clients
989
990  Revision 571.1  2000/04/15 19:55:52  ajc
991  * Fixed "Unvalidated users appear even with registration disabled" bug #36
992
993  Revision 571.0  2000/04/13 02:43:24  ajc
994  * Fixed a problem that crashed the client during <G>oto commands if a room
995    existed with a name more than 32 characters (thanks to Magus for reporting
996    this one).
997  * Tagged everything and updated docs for the 5.71 release
998
999  Revision 570.18  2000/04/10 01:47:22  ajc
1000  * More paginator changes.  Shuffled code around, added pagination to a bunch
1001    of other functions, and replaced the old, cumbersome pagination with the
1002    new, easy, API-based one in everything except message output.
1003
1004  Revision 570.17  2000/04/09 17:51:18  ajc
1005  * Added pprintf() (paginated version of printf) to the client-side API.  Now
1006    any client side function can be paginated simply by changing all of the
1007    printf's to pprintf's.  I've already done this for the user list and wholist
1008    (removing the old style pagination) and for "read directory."
1009
1010  Revision 570.16  2000/04/08 04:52:48  ajc
1011  * Another minor stoopid little time display fix
1012
1013  Revision 570.15  2000/04/08 03:58:12  nbryant
1014   * backed out the previous changes since they didn't look good on some
1015     xterms with a blue bold mode. just set the background color to black
1016     instead. this makes black-on-white terminals actually readable, if not
1017     particularly good looking.
1018
1019  Revision 570.14  2000/04/08 01:36:30  nbryant
1020   * citadel.c, commands.c: comment out cls() as this wasn't called if
1021     ansi_color=user anyway, and we have no way of knowing whether the user's
1022     terminal does background color erase, which was the reason for adding this
1023     in the first place. with the recent changes to color(), the display will get
1024     screwed up if they *do* have background color erase. perhaps this is a job
1025     for terminfo.
1026
1027  Revision 570.13  2000/04/08 00:37:42  nbryant
1028   * commands.c: fix color support for black-on-white color terminals such as
1029     CDE's dtterm. this just avoids white-on-white text; some color combinations
1030     such as yellow-on-white still aren't very legible due to contrast. There's
1031     not much I can think to do about that without affecting the look on the
1032     white-on-black terminals which probably account for most users.
1033
1034  Revision 570.12  2000/04/07 20:22:34  ajc
1035  * Fixed am/pm bug in time display
1036
1037  Revision 570.11  2000/04/07 19:22:45  ajc
1038  * For services disabled by setting port number to -1, administratively skip
1039    the bind instead of just allowing it to fail.
1040
1041  Revision 570.10  2000/03/31 04:31:02  ajc
1042  * Quick fix to 'stats' utility to purge records with bogus timestamps
1043
1044  Revision 570.9  2000/03/31 02:10:52  ajc
1045  * Caved in to pressure and enabled <R>eply in public rooms.
1046
1047  Revision 570.8  2000/03/28 03:55:53  ajc
1048  * Modified <.RU> to allow search for partial match
1049
1050  Revision 570.7  2000/03/27 03:08:19  ajc
1051  * Third parameter of CtdlDeleteMessages() now takes "" instead of NULL to
1052    specify 'any MIME type'.
1053
1054  Revision 570.6  2000/03/27 01:14:08  nbryant
1055   * Makefile.in: generate parsedate.c automatically
1056   * configure.in: check for bison/byacc/yacc. bison seems to build cleaner
1057     code.
1058   * parsedate.c: removed from CVS
1059   * parsedate.y: added #include <stdlib.h> so it builds with bison
1060
1061  Revision 570.5  2000/03/27 00:46:10  nbryant
1062   * First cut at Solaris fixes. There may still be some *printf("%s", NULL)
1063     type of issues lurking in the shadows.
1064
1065  Revision 570.4  2000/03/25 18:29:58  nbryant
1066  changed my email address
1067
1068  Revision 570.3  2000/03/23 02:41:50  ajc
1069  *** empty log message ***
1070
1071  Revision 570.2  2000/03/21 03:23:24  ajc
1072  * Experimental new linebreak mode
1073
1074  Revision 570.1  2000/03/20 14:43:19  ajc
1075  * "Brown paper bag" fix for SMTP bug (incoming long fields crash logger)
1076
1077  Revision 570.0  2000/03/19 23:42:34  ajc
1078  * This is the official 5.70 release.
1079
1080  Revision 1.494  2000/03/19 23:04:08  ajc
1081  * Small cosmetic change to date/time output
1082
1083  Revision 1.493  2000/03/19 05:02:39  ajc
1084  * SMTP hacks to deal with AOL braindamage
1085
1086  Revision 1.492  2000/03/18 18:18:04  ajc
1087  * Support multiline responses from SMTP servers when sending mail
1088
1089  Revision 1.491  2000/03/17 16:26:57  ajc
1090  * Set up a private "Sent/Received Pages" room for each user
1091
1092  Revision 1.490  2000/03/17 04:11:24  ajc
1093  * Moved bio-related commands out to a loadable module
1094
1095  Revision 1.489  2000/03/16 17:58:54  smw
1096  Created a docs directory.
1097  Moved install.txt to docs.
1098  Added inetmailsetup.txt (BBS server side e-mail)
1099  Added inetmailsetupmx.txt (local mail AND bbs e-mail
1100  Added inetsiteconfig.txt (describes the .asi command)
1101  Added siteconfig.txt (describes .asg)
1102  Added chat.txt (describes changes and new chat functionality)
1103  Made a couple of changes to install.txt (references to new documentation)
1104  Added Steve Williams to copyright.txt as the document writer.
1105
1106 Revision 1.488  2000/03/15 03:04:51  ajc
1107 * Added DEXP server command to disable incoming express messages.
1108 * <Q>uiet mode client side command to set/clear DEXP mode.
1109 * <K>nown rooms list displays through the paginator.
1110
1111 Revision 1.487  2000/03/12 00:21:35  ajc
1112 * Removed the semi-broken "chat room" functionality in the chat system, and
1113   replaced it with direct mapping to the actual Citadel room the user is in.
1114 * Display masqueraded roomname in chat, if applicable.  Fixes bug #19.
1115
1116 Revision 1.486  2000/03/11 21:29:37  ajc
1117 * SM_ flags for CtdlSaveMsgPointerInRoom() need to be a bit bucket, not an
1118   enum, since more than one can be passed.  Changed SM_DONT_BUMP_REF_COUNT
1119   from 3 to 4.  This also fixes bug #33.
1120
1121 Revision 1.485  2000/03/11 20:26:03  ajc
1122 * Reworked the <R>eply logic in messages.c - fixes bug #34
1123
1124 Revision 1.484  2000/03/11 19:22:19  nbryant
1125  * commands.c: improved timing of background keepalives if connection is
1126                lagged
1127
1128 Revision 1.483  2000/03/11 05:08:48  nbryant
1129  * commands.c: oops, that mutex stuff wasn't necessary
1130
1131 Revision 1.482  2000/03/11 04:09:03  nbryant
1132  * new threaded client code for background keepalives
1133
1134 Revision 1.481  2000/03/10 21:40:04  ajc
1135 * Changes to message base and networker to support Internet-style message
1136   ID's instead of the conventional Citadel style.
1137
1138 Revision 1.480  2000/03/08 03:36:37  ajc
1139 * Shut off hostname resolution when dealing with Unix domain sockets
1140 * Cleaned up the 'citmail' MDA tool
1141 * Added POP3 and SMTP port numbers to global system configuration
1142
1143 Revision 1.479  2000/03/07 21:54:58  ajc
1144 * Fixed the naming conventions and permissions for unix domain sockets.
1145
1146 Revision 1.478  2000/03/05 07:33:23  ajc
1147 * Added support for protocols over Unix domain sockets.
1148
1149 Revision 1.477  2000/03/04 22:36:23  ajc
1150 * Remove nulls appended to editor files during replace, edit, and print
1151   operations.  Truncate temp files during same operations.
1152   Closes bugs #6 and #7.
1153
1154 Revision 1.476  2000/03/04 05:29:18  ajc
1155 * Relax restrictions on editing of base rooms.  Renaming is not allowed but
1156   all other attributes can be edited.  Closes feature request #21.
1157 * Sending pages from the client now uses the same message editing functions
1158   as entering messages, allowing edit/abort.  Closes feature request #25.
1159
1160 Revision 1.475  2000/03/03 04:50:14  ajc
1161 * Moved all of the wholist masquerading commands into the serv_rwho module
1162
1163 Revision 1.474  2000/03/03 04:12:37  ajc
1164 * Finished the inbound side of gateway domain service
1165
1166 Revision 1.473  2000/02/27 04:55:51  ajc
1167 * Added "keymenu()" generic menu-maker to commands.c
1168 * Blocked non-numeric input to intprompt()  (fixes bug #16)
1169
1170 Revision 1.472  2000/02/27 03:57:35  ajc
1171 * Completed 'fsck'-like reference count verifier (server and client)
1172
1173 Revision 1.471  2000/02/26 18:30:40  ajc
1174 * Properly handle all aliases specified in network/mail.aliases for incoming
1175   SMTP mail (uses the alias() function, so if we replace that function with
1176   something that uses the same calling convention, it'll still work)
1177
1178 Revision 1.470  2000/02/26 05:15:38  ajc
1179 * Fortified the message base and SMTP code so that misdirected bounce messages
1180   end up in the Aide> room instead of getting dereferenced
1181 * Started writing a message reference count verifier ('fsck' for message base)
1182
1183 Revision 1.469  2000/02/25 06:14:05  ajc
1184 * Modularized the RWHO (Read WHO is online) command, basically as a pilot
1185   for modularizing all "non-API" functionality.
1186
1187 Revision 1.468  2000/02/24 03:44:00  ajc
1188 * Implemented holdoff time (15 minutes) for SMTP send retry.
1189 * Implemented "try for 3 days and then give up" on SMTP send.
1190
1191 Revision 1.467  2000/02/24 00:51:48  ajc
1192 * Client protocol synchronization check during exit from chat.
1193   This closes Bug #15.
1194
1195 Revision 1.466  2000/02/22 16:37:28  ajc
1196 * Minor tweaks to RFC822 output to keep brain-damanged MS Outlook from dying
1197
1198 Revision 1.465  2000/02/22 04:17:56  ajc
1199 * Got bounce messages working (mostly ... testers, please beat this up!)
1200 * Changed 'FIX' comments to 'FIXME' (less conflict, plus vim highlights it!)
1201
1202 Revision 1.464  2000/02/18 22:29:18  ajc
1203 * Coded up the "bounce" functions.  Still a coupla bugs.
1204
1205 Revision 1.463  2000/02/18 05:10:50  ajc
1206 * Made the <.ASI> command a bit friendlier.
1207 * SMTP sender now pays attention to "smarthost" entries in the system's
1208   Internet configuration, using them if one or more is present.
1209
1210 Revision 1.462  2000/02/17 05:27:39  ajc
1211 * Got the "MAIL From:" command sending the correct data.  (unnnhhhhnnhhhh...)
1212
1213 Revision 1.461  2000/02/16 22:06:26  ajc
1214 * Altered the display and conversion of RFC822 messages
1215
1216 Revision 1.460  2000/02/16 03:43:28  ajc
1217 * Added the resolver library to the configure script
1218
1219 Revision 1.459  2000/02/16 01:19:39  ajc
1220 * Vanquished the evil dn_expand() beast.  getmx() now seems to be working.
1221
1222 Revision 1.458  2000/02/14 04:36:14  ajc
1223 * sysdep.c: added new event hook type EVT_TIMER.  Timer event hooks are called
1224   once per minute by any worker thread.
1225 * msgbase.c: removed dependence on nested functions in CtdlOutputMsg() by
1226   replacing them with an API call CtdlRedirectOutput() in sysdep.c, which
1227   can temporarily redirect a session's output to an arbitrary file or socket.
1228 * serv_smtp.c: implemented the purging of messages in the queue for which all
1229   deliveries have been completed.
1230 * serv_smtp.c: removed temporary 'QQQQ' server command and replaced it with
1231   a timer event hook that runs the queue once per minute (this needs to be
1232   made more robust)
1233
1234 Revision 1.457  2000/02/08 21:00:47  ajc
1235 * Implemented the deprecated "LAST" command in POP3.  Some clients need it.
1236 * POP3 sessions now set the last-read pointer in Mail>.
1237
1238 Revision 1.456  2000/02/07 05:15:00  ajc
1239 * Renamed CtdlLocalHost() to CtdlHostAlias() and worked it a little deeper into
1240   the message routing logic.  Still needs some work on the gateway-domain
1241   stuff.
1242 * Twiddled CtdlOutputMsg() a bit for 'all Internet' situations.  Still needs
1243   some work to avoid printing dual headers when both Cit and RFC822 exist.
1244
1245 Revision 1.455  2000/02/03 03:57:35  ajc
1246 * Formalized the 'Internet Configuration' logistics.  Added new API call
1247   CtdlLocalHost() to detect aliases for the local host.  Used in SMTP listener.
1248
1249 Revision 1.454  2000/01/31 02:13:05  ajc
1250 * <.A>ide <S>ystem configuration <I>nternet  in the client (unfinished)
1251
1252 Revision 1.453  2000/01/26 02:41:27  ajc
1253 * SMTP delivery is working but still *very* rough.
1254
1255 Revision 1.452  2000/01/25 04:45:50  ajc
1256 * Wrote enough of the SMTP sender to get Patriot drooling over it, but not
1257   enough to complete the transmission of mail.
1258
1259 Revision 1.451  2000/01/23 21:25:45  ajc
1260 * Temporary hack to ig_tcp_server() to listen on an arbitrary port if the
1261   one specified is not bindable (for development only)
1262 * Added SM_DONT_BUMP_REF flag to CtdlSaveMsgPointerInRoom() to be used only
1263   in very specific and special situations
1264 * Generate delivery instructions when outbound SMTP mail is created from
1265   within Citadel (as opposed to being from the SMTP module)
1266
1267 Revision 1.450  2000/01/23 05:22:41  ajc
1268 * Coded up some more of the SMTP-sender (still not done)
1269
1270 Revision 1.449  2000/01/22 05:13:56  ajc
1271 * Added some more functionality to the string tokenizer
1272
1273 Revision 1.448  2000/01/17 20:57:43  ajc
1274 * CR to CRLF hacks (lose, lose, lose)
1275
1276 Revision 1.447  2000/01/17 18:30:27  ajc
1277 * Completed POP3 server.  All RFC1939 commands except APOP are implemented.
1278
1279 Revision 1.446  2000/01/17 17:09:23  ajc
1280 * Implemented LIST and STAT commands in the pop3 server
1281
1282 Revision 1.445  2000/01/17 05:38:14  ajc
1283 * citserver.c: cleanup hook functions are now run under the proper context,
1284                even when initiated by the housekeeper thread
1285 * serv_pop3.c: establish a place to hold the message list
1286
1287 Revision 1.444  2000/01/17 04:26:39  ajc
1288 * Modified CtdlOutputMsg() to handle output to arbitrary sockets or files.
1289   This uses nested functions and may not be portable beyond GCC...
1290
1291 Revision 1.443  2000/01/15 18:29:15  ajc
1292 * Added a generic (void *) parameter to the ForEachUser() and ForEachRoom()
1293   callback mechanisms, to allow callers and callbacks to pass arbitrary data
1294   between each other without requiring TSD variables.
1295 * room_ops.c: eliminated the need for 'FloorBeingSearched' TSD variable
1296 * internet_addressing.c: eliminated 'buffer1' and 'buffer2' TSD variables
1297
1298 Revision 1.442  2000/01/15 04:31:44  ajc
1299 * Removed UI_DIALOG mode in setup.  Can't count on 'dialog' to be consistent.
1300
1301 Revision 1.441  2000/01/15 04:07:17  ajc
1302 * Fixed the access rights on auto-created rooms (the same changes that were
1303   made to version 5.62 in the stable tree)
1304
1305 Revision 1.440  2000/01/13 03:32:36  ajc
1306 * techdoc/delivery-list.txt: added (syntax for delivery lists)
1307 * domain.*: added (will contain MX lookup code)
1308 * internet_addressing.c, logging.c: fixed some buffer overflow bugs
1309
1310 Revision 1.439  2000/01/12 03:56:27  ajc
1311 * sysdep.c: start the housekeeping thread *after* dropping root perms.
1312
1313 Revision 1.438  2000/01/09 19:03:16  ajc
1314 * Removed the fifo-based protocol downloads and replaced it with a less
1315   elegant "download temporary file to client, then sx/sb/sz" because
1316   downloading through a fifo was confusing some software.
1317
1318 Revision 1.437  2000/01/08 22:19:44  ajc
1319 * Completed spool to outbound delivery queue (still no queue sender implemented)
1320
1321 Revision 1.436  2000/01/08 05:00:09  ajc
1322 * Reworked some of the data structures to handle multiple recipients
1323 * Began implementation of the delivery queue
1324 * Added CtdlReallocUserData()
1325 * CtdlSaveMsg() now returns the local message ID in the database
1326
1327 Revision 1.435  2000/01/06 03:50:34  ajc
1328 * Replaced citmail.c with a new one that simply SMTP-forwards to Citadel
1329 * Started outbound SMTP queue work
1330
1331 Revision 1.434  1999/12/30 04:56:29  ajc
1332 * Got initial SMTP delivery working in a very specific situation (delivery
1333   to a single, local user)
1334
1335 Revision 1.433  1999/12/29 04:44:00  ajc
1336 * client_chat.c: display "No message sent" if a send page is aborted.
1337   Closes bug #2 in bugzilla.
1338
1339 Revision 1.432  1999/12/26 21:50:07  ajc
1340 * serv_vcard: don't run hooks when not logged in (such as in SMTP sessions)
1341 * serv_pop3: added.  This is the skeleton for a module implementing POP3.
1342
1343 Revision 1.431  1999/12/23 04:46:23  ajc
1344 * "Finished" initial hack of RFC822 import
1345
1346 Revision 1.430  1999/12/22 04:46:34  ajc
1347 * Fixed up the "Date:" headers to be RFC822-compliant
1348
1349 Revision 1.429  1999/12/13 05:30:57  ajc
1350 * Removed our naive 'conv_date()' RFC822-to-unixtime conversion function
1351   and replaced it with the public domain 'parsedate()' function from UseNet
1352
1353 Revision 1.428  1999/12/10 23:58:25  ajc
1354 * internet_addressing.c: added.  (Internet address to Citadel mapping)
1355
1356 Revision 1.427  1999/12/10 21:34:19  ajc
1357 * serv_smtp: implemented RFC821 "VRFY" and "EXPN" commands
1358
1359 Revision 1.426  1999/12/09 05:01:14  ajc
1360 * Split cmd_user() and cmd_pass() into frontend/backend functions
1361 * serv_smtp: implemented AUTH LOGIN for client authentication
1362
1363 Revision 1.425  1999/12/09 00:22:58  ajc
1364 * Finished the "arbitrary service" registration.
1365 * Eliminated "special" master socket for Citadel protocol - just register it
1366   like any other protocol.
1367 * Began initial implementation of native SMTP service.
1368
1369 Revision 1.424  1999/12/08 18:09:10  ajc
1370 * Added CtdlRegisterServiceHook() and its data type, for implementing arbitrary
1371   TCP-based services directly in the Citadel server.  Not finished yet.
1372
1373 Revision 1.423  1999/11/29 17:39:07  nbryant
1374 * citserver.c: Solaris lacks inet_aton; use inet_addr instead
1375
1376 Revision 1.422  1999/11/29 17:26:15  nbryant
1377 * citserver.c: include <sys/types.h>; may help portability to Solaris
1378
1379 Revision 1.421  1999/11/22 00:27:42  ajc
1380 * Added some temporary variables to OpenCmdResult().  Hopefully fixes
1381   bug #14 when running on FreeBSD.
1382
1383 Revision 1.420  1999/11/21 18:30:16  ajc
1384 * Protected cmd_move() from buffer overrun (no longer crashes the server)
1385 * cmd_chat() -- truncate input at 100 characters to prevent buffer overruns.
1386   Also handle broken client sockets properly.  (Thanks to DME for bug report)
1387
1388 Revision 1.419  1999/11/19 01:57:40  ajc
1389 * Fixed a *serious* memory leak in the database function wrappers.
1390 * Updated version number to 5.60 -- run setup when installing this version.
1391
1392 Revision 1.418  1999/11/18 03:29:20  ajc
1393 * Changed the order of parameters in <.A>ide <S>ystem config into a more
1394   logical grouping.
1395
1396 Revision 1.417  1999/11/18 02:31:50  ajc
1397 * Updated some of the documentation
1398 * Brought the internal version number up to 5.60
1399
1400 Revision 1.416  1999/11/17 04:15:05  ajc
1401 * Removed the session_count() function.  Instead, keep a reference count
1402   updated when sessions begin and end.
1403 * Replaced fixed number of worker threads with lower and upper limits; current
1404   code now tries to make thread count == session count, within these limits
1405
1406 Revision 1.415  1999/11/15 03:17:39  ajc
1407 * Put lockfile in /tmp instead of in /var/lock.   The latter is not guaranteed
1408   to exist, nor is it guaranteed to be writable by BBSUID
1409   (Resolves bug #11 from the Bugzilla repository)
1410
1411 Revision 1.414  1999/11/15 03:07:24  ajc
1412 * Fixed the network-wide vCard purge logic so that it (1) actually works,
1413   and (2) forces a netproc run immediately when a purge is entered
1414
1415 Revision 1.413  1999/11/09 21:20:44  nbryant
1416 * configure.in: include <sys/types.h> when doing checks which require <utmp.h>
1417   (should fix Bug #10 on FreeBSD)
1418
1419 Revision 1.412  1999/11/05 03:53:47  ajc
1420 * Issue 'cancel' messages for vCard when a user is deleted.
1421 * Try to delete 'cancel' messages locally after they've been distributed.
1422
1423 Revision 1.411  1999/11/03 04:01:20  ajc
1424 * Fixed buffer overrun problems in cmd_rchg(), cmd_hchg(), and cmd_uchg()
1425 * Removed my email address as the feedback content from the docs; replaced
1426   it with a reference to the Citadel/UX web site.
1427
1428 Revision 1.410  1999/11/02 19:51:23  ajc
1429 * Fixed timeout problem for remote client sessions (all timeouts were set to
1430   1 second ... probably a temporary hack that was missed in the cleanup)
1431
1432 Revision 1.409  1999/11/02 03:03:27  ajc
1433 * Several fixes to msgbase.c and netproc.c to prevent corrupted incoming
1434   network traffic from crashing the server.  Reject bad messages.
1435
1436 Revision 1.408  1999/11/01 04:21:34  ajc
1437 * Fixed a concurrency bug which crashed the server when multiple sessions
1438   terminated simultaneously.
1439
1440 Revision 1.407  1999/11/01 00:54:02  ajc
1441 * CtdlFetchMessage() - generate a "<no text>" message body if there's none
1442   on disk.  Too much stuff goes haywire if there's no M field.
1443
1444 Revision 1.406  1999/10/31 18:17:17  ajc
1445 * Fixed buffer overrun in cmd_rchg()
1446 * Call master_cleanup() when time_to_die==1 for proper shutdown
1447
1448 Revision 1.405  1999/10/31 16:26:55  ajc
1449 * Fixed incorrect assignment of new session ID's
1450
1451 Revision 1.404  1999/10/31 04:17:17  ajc
1452 * Fixed a bug which was crashing the server during very long message entry.
1453
1454 Revision 1.403  1999/10/29 01:48:45  ajc
1455 * database.c: Removed arbitrary limit on maximum number of sessions
1456
1457 Revision 1.402  1999/10/29 01:03:03  ajc
1458 * Debugged all possible ways for a session to terminate; do them cleanly.
1459 * Assign session numbers in a more portable and less arbitrary way.
1460
1461 Revision 1.401  1999/10/28 19:50:55  ajc
1462 * Fixed a problem where the client protocol would spit out two responses
1463   and therefore get out of sync if ASUP command set the access level to
1464   0 and therefore deleted the user (thanks to Eric McDonald)
1465
1466 Revision 1.400  1999/10/28 05:08:49  ajc
1467 * Removed all of the thread cancellation cruft that is no longer necessary
1468 * Moved the now non-system-dependent RemoveContext() out of sysdep.c (now
1469   it's part of cleanup() in citserver.c)
1470 * Removed all references to pthread_* from all modules except sysdep.c
1471
1472 Revision 1.399  1999/10/28 03:20:17  ajc
1473 * Fixed the problem of worker threads waking up prematurely.
1474 * 'QUIT'-terminated sessions now exit properly.
1475
1476 Revision 1.398  1999/10/27 04:26:58  ajc
1477 * Initial hack of worker-thread rearchitecture.  Right now it is successfully
1478   dispatching worker threads to active client sockets (and to the master
1479   socket too, of course).  Removing sessions is currently broken.
1480
1481 Revision 1.397  1999/10/26 20:20:29  ajc
1482 * Removed the auto-reconnect stuff... it was locking the client in an active
1483   loop more often than it was reconnecting.
1484
1485 Revision 1.396  1999/10/26 13:59:11  ajc
1486 damn bugs
1487
1488 Revision 1.395  1999/10/26 03:48:39  ajc
1489 * Shuffled around the order of events when a thread is terminating.  All
1490   mutex operations now happen prior to the freeing of the CitContext structure,
1491   otherwise begin_critical_section() and end_critical_section() try to
1492   manipulate the context's mutex count when there isn't any context.
1493
1494 Revision 1.394  1999/10/26 03:21:16  ajc
1495 * Changed a lot of strncpy() calls to safestrncpy() and replaced most of their
1496   hardcoded size arguments with 'sizeof' based arguments.
1497
1498 Revision 1.393  1999/10/24 19:22:51  nbryant
1499         * Makefile.in, configure.in: added --enable-icq flag; made checks for
1500           authentication libraries more intelligent.
1501
1502 Revision 1.392  1999/10/23 03:39:12  ajc
1503 * Finished moving vCard functionality to the new message base functions.
1504
1505 Revision 1.391  1999/10/21 00:50:14  ajc
1506 * Finished up the flags and replication checks in CtdlSaveMsgPointerInRoom().
1507
1508 Revision 1.390  1999/10/20 16:46:27  ajc
1509 * More code shuffle.  Added some flags to CtdlSaveMessagePointerInRoom() and
1510   enabled the MOVE command to also do a "copy" operation (actually just
1511   creates a second link and bumps the ref count).  Implemented "<C>opy" in
1512   the client.
1513
1514 Revision 1.389  1999/10/20 16:07:48  ajc
1515 * Wholist fixes for users who are in chat mode
1516
1517 Revision 1.388  1999/10/20 03:42:29  ajc
1518 * In the wholist, only show <private room> if the user viewing the list
1519   doesn't know that room.  Otherwise show the name.
1520
1521 Revision 1.387  1999/10/20 02:59:22  ajc
1522 * Code reorganization.  Making it easier to move/copy messages without
1523   duplicating existing code.
1524
1525 Revision 1.386  1999/10/17 02:25:18  ajc
1526 * Discovered a huge design flaw in the replication algorithm.  Ripped it
1527   out and replaced it with something a bit more robust.
1528
1529 Revision 1.385  1999/10/16 05:30:17  ajc
1530 * Changes to message replication code.  Don't do server-side hooks during
1531   an ENT3 command.  Also fixed a bug in cmd_whok() that caused crashes
1532   after a file format change.
1533
1534 Revision 1.384  1999/10/14 03:04:16  ajc
1535 * Finished the netproc side of Z (zap/supersede) processing for replication
1536
1537 Revision 1.383  1999/10/13 04:24:18  ajc
1538 * Added search-by-header-fields to CtdlForEachMessage(), and then to the
1539   server MSGS command.  This will have lots of uses.
1540
1541 Revision 1.382  1999/10/13 01:36:39  ajc
1542 * Starting some work on network zap (supersede) mode for replication
1543
1544 Revision 1.381  1999/10/08 02:55:57  ajc
1545 * More vCard-related debugging
1546
1547 Revision 1.380  1999/10/07 02:58:46  ajc
1548 * Semi-broken vCard replacement implementation in place.
1549 * Added "Z" (Zap, supersede) field to message format
1550
1551 Revision 1.377  1999/10/04 03:19:52  ajc
1552 * We now have a housekeeping thread and a housekeeping queue.
1553
1554 Revision 1.376  1999/10/03 21:48:21  ajc
1555 * Added serv_upgrade.h to automagically convert pre-5.55 format user records
1556   to 5.55 format user records and generate vCards.
1557
1558 Revision 1.375  1999/09/29 21:13:17  ajc
1559 * CtdlWriteObject() can now store objects in personal rooms for any specified
1560   user -- rather than only the current user or non-personal rooms.
1561
1562 Revision 1.374  1999/09/29 17:26:56  ajc
1563 * serv_vcard.c: fixed crashola bug in cmd_greg()
1564 * tools.c: simplified and improved the string tokenizer.  Now it runs in a
1565            single pass with no intermediate buffer.
1566
1567 Revision 1.373  1999/09/28 03:27:37  ajc
1568 * Fully migrated cmd_greg() and cmd_regi() into serv_vcard (still has bugs)
1569
1570 Revision 1.372  1999/09/27 03:33:40  ajc
1571 * cmd_regi() is now in serv_vcard and writes to the vcard instead of to the
1572   usersupp file.  Still needs tweaking.
1573
1574 Revision 1.371  1999/09/24 03:32:19  ajc
1575 * "read my vCard" and "write my vCard" are written and tested.
1576
1577 Revision 1.370  1999/09/24 02:54:17  ajc
1578 * Worked a little more on the vCard stuff.  The serv_vcard module is now in
1579   place, and a "read my vcard" function is there; "write my" is next...
1580
1581 Revision 1.369  1999/09/23 03:07:56  ajc
1582 * The vCard 'class' is now linked into the server, though it's not really
1583   functional yet.  Its constructors/destructors are debugged, though.
1584
1585 Revision 1.368  1999/09/19 21:28:33  ajc
1586 * Finished off the message architecture stuff with a new class of hooks to
1587   enable future server-side handlers.
1588
1589 Revision 1.367  1999/09/19 15:57:06  ajc
1590 * migrated cmd_ent3() to CtdlSaveMessage()
1591
1592 Revision 1.366  1999/09/19 05:13:57  ajc
1593 * Debugged the new version of CtdlWriteObject()
1594
1595 Revision 1.365  1999/09/16 03:23:23  ajc
1596 * Did most of the migration from save_message() to CtdlSaveMsg().  The
1597   latter builds a "struct CtdlMessage" (so we can run server-side handlers
1598   against it later on), then serializes it and stores to disk.
1599 * BROKEN BUILD ALERT!!  cmd_ent3() and CtdlWriteObject() are still not
1600   migrated.  They are stubbed out and will MALFUNCTION if used right now!!
1601
1602 Revision 1.364  1999/09/07 01:42:42  ajc
1603 * cmd_msg3() now uses serialize_message() for its output.  All message
1604   commands will eventually exist as a "struct CtdlMessage" at some point
1605   so that we can install server-side handler hooks.
1606
1607 Revision 1.363  1999/09/07 00:04:13  ajc
1608 * netproc.c: put outgoing messages into the use table, too -- this prevents
1609   locally originated messages from showing up again if a remote system is
1610   misconfigured and spools them back to us.
1611
1612 Revision 1.362  1999/09/06 03:39:15  ajc
1613 * citadel.c: run strproc() on new passwords
1614
1615 Revision 1.361  1999/09/03 17:50:26  playcow
1616 For URL view, don't prompt user to select url if there is only one.  Display
1617 <U>RL View prompt if message contains url(s). -Ben
1618
1619 Revision 1.360  1999/09/02 02:09:59  ajc
1620 * msgbase.c: new function serialize_message() for future use
1621
1622 Revision 1.359  1999/09/01 21:09:25  ajc
1623 * database.c: display the GDBM version string on startup
1624
1625 Revision 1.358  1999/09/01 02:36:34  ajc
1626 * Actually _enforce_ the max msg len limit
1627
1628 Revision 1.357  1999/09/01 01:51:48  ajc
1629 * Added the ability to handle embedded URL's from the text client
1630
1631 Revision 1.356  1999/09/01 01:02:47  ajc
1632 * Implemented "maximum message length" in global system config
1633
1634 Revision 1.355  1999/08/31 00:57:17  ajc
1635 * Handle multipart/alternative properly during legacy message outputs.
1636   Basically it just prints the first alternative and skips the rest.
1637
1638 Revision 1.354  1999/08/29 21:12:24  ajc
1639 * Made some changes to the output of MIME (especially multipart) messages.
1640
1641 Revision 1.353  1999/08/29 19:56:43  ajc
1642 * HTML updates
1643
1644 Revision 1.352  1999/08/24 02:01:03  ajc
1645 * html.c: added.  This is an overly simplistic HTML-to-text converter.
1646
1647 Revision 1.351  1999/08/21 18:37:29  ajc
1648 * Minor cosmetic cleanup.  No code changes.
1649
1650 Revision 1.350  1999/08/21 05:15:34  ajc
1651 * mailinglist.c, netmailer.c: fixed to allow list submissions from all posters
1652   on a Citadel network rather than only on the local system.
1653
1654 Revision 1.349  1999/08/08 00:25:45  ajc
1655 * Made one more byte available in locate_host() and in all the structs which
1656   its output gets written to (client can display 24 positions but we were only
1657   saving 23).
1658
1659 Revision 1.348  1999/08/07 16:34:38  nbryant
1660 * serv_icq.c: warning fixes
1661
1662 Revision 1.347  1999/08/06 02:57:26  ajc
1663 * locate_host.c: use strdoop() and phree() instead of strdup() and free()
1664 * serv_icq.c: run learned IP's through Citadel's locate_host() & put in Wholist
1665
1666 Revision 1.346  1999/08/05 17:58:59  ajc
1667 * RWHO command now returns express message code in postion 3
1668
1669 Revision 1.345  1999/08/04 02:21:45  ajc
1670 * Fixed some bugs in the ICQ metaclient, and documented the new protocol cmds
1671
1672 Revision 1.344  1999/08/03 11:34:35  ajc
1673 * Added client_icq.c and client_icq.h
1674
1675 Revision 1.343  1999/08/03 03:14:51  ajc
1676 * Wrote the client side of the ICQ gateway.  Now on to other projects.  :)
1677
1678 Revision 1.342  1999/08/03 01:52:06  ajc
1679 * Redesigned the client protocol commands for dealing with ICQ
1680 * Implemented page function priority ordering to prevent pages from being
1681   simultaneously delivered over multiple IM systems
1682 * Migrated serv_icq.* into the Makefile
1683
1684 Revision 1.341  1999/08/01 21:36:30  ajc
1685 * EXTREME coolness.  The server side of the ICQ metaclient is now working.
1686   It is set up using ICQL and ICQA commands, it automatically logs the user
1687   onto ICQ along with Citadel, and displays all non-offline ICQ contacts
1688   in the Wholist.
1689
1690 Revision 1.340  1999/07/31 07:18:01  ajc
1691 * Restructured the express message infrastructure, adding a class of function
1692   hooks for the addition of multiple paging modules with message routing
1693
1694 Revision 1.339  1999/07/30 22:20:19  ajc
1695 * Applied bugfix patches contributed by Vaggelis Tsirkas:
1696   * rooms.c: buffer overrun fix
1697   * room_ops.c: cmd_rdir() now behaves better when directory doesn't exist
1698
1699 Revision 1.338  1999/07/30 03:32:24  ajc
1700 * Added strdoop(), a leak-checked version of strdup()
1701 * Small fixes to new API functions in msgbase.c
1702 * ICQ metaclient stores/reads config using the message base API functions
1703
1704 Revision 1.337  1999/07/29 03:36:37  ajc
1705 * msgbase.c: reorganized.  output_message() now uses CtdlFetchMessage(),
1706   cmd_msg3() now fetches directly from disk and spews to the client.
1707
1708 Revision 1.336  1999/07/28 04:02:37  ajc
1709 * Server modules are now labelled with their RCS ID instead of a complex and
1710   manually-updated data structure.
1711
1712 Revision 1.335  1999/07/28 03:50:24  ajc
1713 * serv_expire.c: expire-by-age now calls CtdlFetchMessage() instead of
1714   calling output_message() in MT_DATE mode.
1715 * msgbase.c: removed MT_DATE mode ('twas a sleazy hack)
1716
1717 Revision 1.334  1999/07/27 22:47:26  ajc
1718 * Implemented new data type "CtdlMessage" which will eventually be used as
1719   widely as possible to represent a message in memory.
1720 * Implemented CtdlFetchMessage() which is intended to become the back-end to
1721   output_message() as well as a bunch of other things.
1722
1723 Revision 1.333  1999/07/27 20:00:24  ajc
1724 Removed all references to CC->msglist and CC->num_msgs, and all utility
1725 functions which relied upon them.  Citadel Is Now Better.
1726
1727 Revision 1.332  1999/07/27 19:32:22  ajc
1728 Removed serv_upgrade.c and all references to it in Makefile.in
1729 Reworked new-mail-count to not use MessageFromList() etc.
1730
1731 Revision 1.331  1999/07/25 02:59:37  ajc
1732 Fixed reference count problem in cmd_move()
1733
1734 Revision 1.330  1999/07/24 22:50:38  ajc
1735 Continued replacing references to [get|put]_msglist() with better code.
1736 For some reason, cmd_msgs() still doesn't always work right.
1737
1738 Revision 1.329  1999/07/24 22:16:41  ajc
1739 Experimenting with automatic updating of ChangeLog by CVS.  Simply twiddle
1740 ChangeLog a bit (i.e. by adding or removing a newline from the end of the
1741 file) before issusing "cvs commit", and the comments recorded by CVS will
1742 automatically appear at the beginning of ChangeLog.
1743
1744 Revision 1.328  1999/07/24 22:14:21  ajc
1745 cmd_move() now uses CtdlDeleteMessages().
1746 WARNING: build is temporarily broken.  Currently removing all references
1747 to the "msglist" kept in CitContext.  It's ugly and must die.
1748
1749 Thu Jul 22 22:26:50 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
1750         * Moved message deletion into new API function CtdlDeleteMessages()
1751         * Added CtdlWriteObject() to store generic data in the msgbase
1752         * Fixed really dumb error that prevented network msgs from posting
1753
1754 Tue Jul 20 22:14:54 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
1755         * Moved the actual work done in cmd_msgs() into a new API function
1756           called CtdlForEachMessage() which is supplied a callback function.
1757
1758 Mon Jul 19 23:24:18 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
1759         * Keep the (unqualified) content-type in the SuppMsgInfo record.  We'll
1760           be using this shortly to search rooms for specific object types.
1761
1762 Sun Jul 18 14:53:16 EDT 1999 Art Cancro <ajc@uncensored.citadel.org> 
1763         * Changes to dynloader et al to handle ICQ module being written
1764         * serv_icq.c, serv_icq.mk: added (separate makefile is temporary)
1765
1766 1999-07-17 Nathan Bryant <bryant@cs.usm.maine.edu>
1767         * chkpwd.c: DELETED CVS REVISION 1.3 (backed out Art's last change)
1768           use 'cvs update -r 1.2 chkpwd.c; cvs update -A chkpwd.c' NOW to
1769           avoid problems with working directories.
1770         * Makefile.in: don't install chkpwd setuid if make install isn't
1771           being run as root.
1772         * citadel.spec: chmod u+s chkpwd during %install stage
1773
1774 Fri Jul 16 18:39:04 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
1775         * PEXP and GEXP no longer trip the idle time display
1776         * Fixed bug which duplicated incoming private mail to Trashcan
1777         * Improved auto-reconnect by NOT using SIGPIPE and longjmp(); also
1778           implemented a 15 second delay to wait for a crashed server to restart
1779         * Relaxed the security check in chkpwd.c a bit; it was just flat-out
1780           preventing logins on my system otherwise
1781
1782 Thu Jul 15 22:57:32 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
1783         * eliminate redundant "name" parameter in [l]putuser(), now uses
1784           usbuf->fullname to guarantee the correct name for the index
1785
1786 1999-07-12 Nathan Bryant <bryant@cs.usm.maine.edu>
1787         * Makefile.in, configure.in: link netproc with gdbm
1788         * netproc.c: only include gdbm.h if HAVE_GDBM_H
1789         * user_ops.c: warning fix
1790
1791 Mon Jul 12 19:51:30 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
1792         * Mail is now saved in both sender and recipient mailboxes.  This is
1793           structured in a way that will allow a separate "outbox" room and/or
1794           multiple recipients in the future.
1795
1796 Sun Jul 11 18:46:48 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
1797         * netproc.c: msgfind() no longer uses the timestamp as a message-ID
1798           when no other message-ID is available (it screws up the loopzapper)
1799         * room_ops.c: eliminate room name parameter in putroom() and its ilk;
1800           get data from quickroom.QRname instead; prevents incorrect indexes
1801         * Tentative implementation of "personal rooms" (user-private namespace)
1802         * Added supplementary message info records for info that may change
1803           at some time later than when the message is saved (i.e. ref counts)
1804         * Implemented msg reference count increment/decrement; delete messages
1805           whose reference count reaches zero
1806
1807 Wed Jul  7 23:25:09 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
1808         * control.c: create citadel.control if it doesn't exist (yikes!)
1809         * serv_expire.c: purge mailbox rooms belonging to non-existent users
1810         * user_ops.c: don't delete user's mailbox at user-delete time
1811
1812 Mon Jul  5 17:01:29 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
1813         * utilsmenu: removed menu items for defunct utilities
1814
1815 Mon Jun 28 16:24:10 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
1816         * Changed any remaining references to UUCP, to "Internet" instead.
1817
1818 Thu Jun 24 11:13:23 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
1819         * added server command line option "-f" to defrag databases on startup
1820         * control.c: better performance and reliability in [get|put]_control()
1821         * netproc.c: Finished the loopzapper
1822
1823 Mon Jun 21 00:04:15 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
1824         * netproc.c: started writing a vortex checker.  Not finished.
1825
1826 Wed Jun  9 23:34:25 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
1827         * Replaced all code that generated temporary filenames with calls to
1828           tmpnam().  Rewrote using tmpfile() where possible.
1829
1830 Thu Jun  3 11:35:18 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
1831         * base64.c: mapped fi and fo to stdin and stdout using
1832           actual code rather than assignment at declaration time
1833           (several users of Red Hat Linux 6.0 reported problems)
1834
1835 Fri May 21 20:05:00 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
1836         * Added function CtdlGetDynamicSymbol() for dynamic symbol allocation
1837         * server.h: Changed discrete #define's to enum's where appropriate
1838         * sysdep.c: Changed the startup message to give credit to the whole
1839           development team :)  Also made the message more GNU-ish.
1840
1841 Thu May 20 20:01:30 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
1842         * database.c: print log messages for file defragmentations
1843         * citserver.c: implemented CtdlAllocUserData() and CtdlGetUserData()
1844           for arbitrary per-session data storage (by modules etc.) without
1845           having to add fields to struct CitContext
1846         * msgbase.c: removed "desired_section" from struct CitContext and
1847           implemented it using CtdlGetUserData() as a test.
1848
1849 Wed May 19 19:30:28 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
1850         * commands.c, commands.h, routines.c: began color scheme changes
1851
1852 1999-05-15 Nathan Bryant <bryant@cs.usm.maine.edu>
1853         * configure.in: Added untested support for BSDI 4.x.
1854
1855 1999-05-13 Nathan Bryant <bryant@cs.usm.maine.edu>
1856         * acconfig.h, configure.in, routines.c: fix for certain SYSV variants
1857           which lack utmp.ut_host
1858         * citadel.h, file_ops.c, msgbase.c, netproc.c, serv_chat.c: fix
1859           namespace collision with <sys/stream.h> on aforementioned SYSV
1860           variant
1861         * configure.in, getutline.c: check for paths.h
1862         * configure.in, Makefile.in: check for -lsocket and -lnsl
1863
1864 1999-05-11 Nathan Bryant <bryant@cs.usm.maine.edu>
1865         * chkpwd.c: fixed excessive paranoia; it used to refuse to run when
1866           invoked by root and BBSUID != 0
1867         * Makefile.in: ignore errors while installing /etc/pam.d/citadel
1868
1869 1999-04-27 Art Cancro <ajc@uncensored.citadel.org>
1870         * file_ops.c: fixed NDOP to not crash the server if it has trouble
1871           with a download file
1872         * netpoll.c: upped default packet size
1873
1874 Mon Apr 26 22:06:57 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
1875         * Repaired IGnorant security hole blunder re. citmail
1876
1877 Sun Apr 25 12:44:08 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
1878         * serv_chat.c: notify user of number of participants upon entering chat
1879         * Built the 5.53 distribution
1880
1881 Wed Apr 21 22:23:13 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
1882         * aidepost.c: add -r flag to allow posting to rooms other than Aide>
1883         * serv_expire.c: now posts transcripts of all auto-purged rooms/users
1884
1885 Tue Apr 20 12:45:55 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
1886         * messages.c: downloading more than MAX_MSGS messages now truncates
1887           (off the beginning of the list) rather than crashing.
1888
1889 Mon Apr 19 12:11:48 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
1890         * whobbs.c: auto-detect when being called from a webserver, and act
1891           as a CGI (print HTTP headers and HTML output)
1892
1893 1999-04-18 Nathan Bryant <bryant@cs.usm.maine.edu>
1894         * serv_chat.c: fixed some potential buffer overruns (thanks dme)
1895
1896 Wed Apr 14 21:32:28 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
1897         * Makefile.in: chmod 4755 citmail to prevent citmail from aborting
1898           when called from sendmail due to citadel.config security check
1899
1900 1999-04-13 Nathan Bryant <bryant@cs.usm.maine.edu>
1901         * dynloader.c: OpenBSD places underscores in front of symbol names
1902         * Makefile.in: fixed a few sillies
1903         * aidepost.c, citmail.c, file_ops.c, logging.c, msgbase.c, netmailer.c,
1904           netproc.c, rcit.c, routines.c, serv_upgrade.c: fixed time_t handling
1905           (have to cast it to long for printf/scanf)
1906
1907 Mon Apr 12 22:13:26 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
1908         * aidepost.c: rewrote to unlink temp file before writing to it so that
1909           it will automatically go away if interrupted. Also ran indent -kr -i8
1910
1911 1999-04-12 Nathan Bryant <bryant@cs.usm.maine.edu>
1912         * configure.in, Makefile.in: taught it how to generate OpenBSD shared
1913           libraries
1914         * config.c, sysdep.c: fix -h option not setting proper modules dir
1915         * configure.in, citadel.spec: make --enable-chkpwd the default
1916         * setup.c: don't chown chkpwd
1917
1918 1999-04-11 Nathan Bryant <bryant@cs.usm.maine.edu>
1919         * configure.in: another OpenBSD fix, but we're still not quite there yet
1920         * serv_chat.c: warning fix
1921
1922 Thu Apr  8 22:51:28 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
1923         * config.c: now requires a setup run for *any* rev level difference
1924         * Updated docs & confs for 5.53b1 release
1925         * setup.c: sets the 0600 permission bits on citadel.config that
1926           is checked for in config.c
1927
1928 1999-04-08 Nathan Bryant <bryant@cs.usm.maine.edu>
1929         * citserver.c: improved is_public_client(), also if a public_client
1930           only supplies a numeric address, attempt to resolve it
1931         * locate_host.c: verify that the forward DNS matches the reverse
1932         * locate_host.c, locate_host.h: more general interface
1933         * configure.in, acconfig.h: fixes for Digital UNIX
1934
1935 Wed Apr  7 21:36:16 EDT 1999 Art Cancro <ajc@uncensored.citadel.org>
1936         * Implemented "access level required to create rooms" (client & server)
1937
1938 1999-04-07 Nathan Bryant <bryant@cs.usm.maine.edu>
1939         * configure.in: updated help messages, OpenBSD support
1940         * setup.c: if /etc/inittab doesn't exist, don't ask to create an
1941           entry in it
1942         * server.h, sysdep.c: fix a potential deadlock/data corruption bug
1943         * room_ops.c: fixed the 'gdbm error: Illegal data' message when
1944           deleting a room which had never been posted to
1945         * user_ops.c: include errno.h
1946         * dynloader.c: fix for OpenBSD
1947
1948 1999-04-06 Nathan Bryant <bryant@cs.usm.maine.edu>
1949         * Makefile.in, configure.in, getutline.c, sysdep.c:
1950           fixes/bug workarounds for FreeBSD
1951
1952 1999-04-03 Nathan Bryant <bryant@cs.usm.maine.edu>
1953         * Makefile.in, configure.in, chkpwd.c, acconfig.h: support for
1954           `chkpwd', a setuid helper program for machines which use shadow
1955           passwords (configure --enable-chkpwd)
1956         * Makefile.in, configure.in, auth.c, citadel.pam, user_ops.c: support
1957           for PAM or shadow passwords (configure --with-pam)
1958         * Makefile.in: made some messages simpler
1959         * citadel.spec: updated for 5.53; correct name of tarball; build with
1960           --enable-chkpwd and --with-pam; add defattr tags so rpm's can be
1961           built by non-root user
1962         * commands.c: cosmetic cleanup
1963         * config.c: (security/paranoia) check permissions on citadel.config
1964         * configure.in: check for ncurses if we can't find curses
1965         * dynloader.c: warning fix
1966         * sysdep.c: don't complain if initgroups() fails
1967         * citadel.c: fix systems with SYSV-style signal handling (e.g. libc5)
1968         * Makefile.in: New! Improved! Cleaner! Shinier!
1969
1970 Sun Mar 21 14:21:47 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
1971         * messages.c: cosmetic cleanups to message reading loop
1972
1973 Sat Mar 13 21:33:19 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
1974         * commands.c: use bright colors by default in color mode
1975         * citserver.c: initialize wholist fields with (not logged in) etc.
1976
1977 1999-03-08 Nathan Bryant <bryant@cs.usm.maine.edu>
1978         * sysdep.c: call DLoader_Init() with an absolute path so that gdb can
1979           find module symbols
1980         * database.c: bail out if opening databases fails
1981
1982 Sat Mar  6 01:55:55 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
1983         * serv_chat.c: use memfmout(), *not* cprintf() to transmit express
1984           messages.  Calling cprintf() on strings >256 bytes crashes the server
1985         * msgbase.c: minor logging fix in save_message()
1986
1987 1999-03-05 Nathan Bryant <bryant@cs.usm.maine.edu>
1988         * sysdep.c: add undocumented -r flag to citserver to prevent it from
1989           dropping root permissions.
1990         * sysdep.c: also drop supplementary groups
1991
1992 1999-03-04 Nathan Bryant <bryant@cs.usm.maine.edu>
1993         * config.c: error checking in put_config()
1994         * setup.c: chgrp files to the login group associated with BBSUID
1995         * sysdep.c: copyright 1987-1999; drop root perms; load modules and call
1996           master_startup() after dropping perms
1997
1998 Wed Mar  3 00:00:55 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
1999         * Prevent buffer overruns in lowercase_name in [get|put]user()
2000         * client_chat.c: use citedit() for page composition
2001
2002 Sat Feb 27 07:47:36 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
2003         * rooms.c: download_to_local_disk() prompts for a filename if a blank
2004           filename was supplied to it (for attachments without names)
2005         * mime_parser.c: strip leading whitespace in content_type & disposition
2006
2007 1999-02-24 Nathan Bryant <bryant@cs.usm.maine.edu>
2008         * configure.in: improved check for pthreads
2009         * configure.in, routines.c, acconfig.h: check for ut_type in struct utmp
2010         * configure.in, Makefile.in: support for building server modules as
2011           relocatable objects for BSDI (which still uses a.out *gag* *choke*)
2012         * configure.in: compiler choice & flags for BSDI; check for libtermcap
2013         * database.c: don't use a critical section in open_databases()
2014         * housekeeping.c: use getfloor()/putfloor() instead of
2015           lgetfloor()/lputfloor() in check_ref_counts()
2016         * mime_parser.c: include <errno.h>
2017         * msgbase.c: include <limits.h>
2018         * sysdep.c: hacks for BSDI. use signals to fake thread cancellation;
2019           don't call master_cleanup() directly from signal handler.
2020         * routines.c: prototype getutline() if necessary
2021         * getutline.c: stupid bugfix
2022         * acconfig.h, configure.in, locate_host.c, server.h: work around
2023           nonreentrant gethostbyaddr() on BSDI
2024
2025 Mon Feb 15 22:59:00 EST 1999 Vaggelis Tsirkas
2026         * citadel.c: increased hostname buffer size to handle very big names
2027
2028 1999-02-15 Nathan Bryant <bryant@cs.usm.maine.edu>
2029         * sysdep.c(main): initialize alen before call to accept()
2030
2031 1999-02-04 Nathan Bryant <bryant@cs.usm.maine.edu>
2032         * configure.in: improved check for cygwin
2033         * configure.in, routines.c: access utmp directly instead of calling
2034           `who' if getutline() is available.
2035         * configure.in, Makefile.in, getutline.c: replace getutline() on
2036           systems which don't have it
2037         * routines.c: now always access utmp directly unless we can't find
2038           utmp.h
2039
2040 1999-02-02 Nathan Bryant <bryant@cs.usm.maine.edu>
2041         * Fixes for Cygwin:
2042           - ifdef out file download methods that require named pipes (client)
2043           - include pthread.h and gdbm.h only if they are present (fixes
2044             auto dependency generation)
2045           - include snprintf.h where needed
2046           - handle .exe suffixes for "make install"
2047
2048 Tue Feb  2 22:15:08 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
2049         * Overhauled the express messaging system (again)
2050
2051 Mon Feb  1 19:48:04 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
2052         * messages.c: implemented client download of MIME attachments
2053
2054 Sun Jan 31 18:29:18 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
2055         * Added qpdecode.c to the distribution (decodes quoted-printable)
2056         * Finished the MIME parser
2057         * Gave MSG0 a reasonable behaviour for MIME messages
2058         * Added the OPNA command for downloading attachments
2059
2060 Sat Jan 30 18:39:53 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
2061         * Look for citadel.rc in current directory if not found elsewhere
2062         * More work on the MIME parser
2063         * Added base64.c to the distribution
2064
2065 1999-01-29 Nathan Bryant <bryant@cs.usm.maine.edu>
2066         * fixes for IRIX (thanks to wr and family for use of the Indy):
2067           - use memset()/memcpy() instead of bzero()/bcopy() in all cases
2068           - configure updates
2069           - handle `long' pid's
2070           - a few other little bits
2071
2072 Mon Jan 25 21:23:07 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
2073         * Fixed bug in save_message() which crashed the server on mail to sysop
2074         * Rewrote pop_march() to be smarter about <G>oto heuristics
2075
2076 Sat Jan 23 14:32:19 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
2077         * Changed internal storage of express messages from a linked list to
2078           a single, resizable buffer.
2079         * Added a "room order" key to the room record, to allow some control
2080           over room listing order.
2081         * Made the room list commands aware of the room order key.
2082         * Overhauled <G>oto heuristics to pay attention to floor & room order
2083
2084 Wed Jan 20 19:21:51 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
2085         * Added some more code to the unfinished MIME parser
2086         * Changed module loading path to simply "modules" because after calling
2087           get_config(), the cwd is guaranteed to be the correct BBS directory.
2088
2089 Tue Jan 19 21:28:29 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
2090         * Fixed a bug in the user editing command (client side)
2091         * Started a rewrite of the MIME parser
2092
2093 Thu Jan 14 21:21:15 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
2094         * Brought over the mime_parser from WebCit and began preliminary work
2095           on supporting MIME format messages.
2096
2097 Tue Jan 12 22:30:00 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
2098         * Various changes to begin work on support for MIME messages
2099                 - Defined format type 4 for MIME
2100                 - msgbase.c: *temporary* hacks in output_message() for Type 4
2101                 - citmail.c: added more robust header parsing, and support
2102                              for Type 4.  Also eliminated the crappy built-in
2103                              SMTP server.
2104                 - Updated some of the technical documentation
2105
2106 Sun Jan 10 13:34:36 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
2107         * Fixed access to page log room
2108
2109 Fri Jan  8 12:35:09 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
2110         * control.c: include <limits.h> to fix PATH_MAX undefined
2111         * serv_chat.c: made the following changes to cmd_sexp() --
2112                 * Send zero-length message to check only, don't send
2113                 * Send "-" message on the command line to invoke
2114                   the SEND_LISTING transfer mode for a multi-line message
2115         * Added facilities to log all pages to a room (site configurable)
2116
2117 Tue Jan  5 23:24:52 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
2118         * Replaced all occurances of malloc(), realloc(), and free() in the
2119           server and server-modules with mallok(), reallok(), and phree().
2120           Wrote macros and a set of leak-tracking functions.
2121
2122 Sun Jan  3 20:38:45 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
2123         * Documentation changes
2124
2125 Fri Jan  1 01:01:45 EST 1999 Art Cancro <ajc@uncensored.citadel.org>
2126         * Fixed security problem relating to private rooms
2127
2128 Wed Dec 30 20:10:52 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
2129         * sysdep.c: put a bigger string buffer into lprintf() to avoid overruns
2130
2131 Sat Dec 26 16:56:46 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
2132         * internetmail.config: commented this file more clearly
2133
2134 Wed Dec 23 20:42:49 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
2135         * citadel.c: added some experimental code to automatically reconnect
2136           to the server if the connection is broken.  For some reason, it only
2137           works once.
2138
2139 Wed Dec 23 18:47:12 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
2140         * sysdep.c: ignore SIGPIPE.  This keeps broken connections from
2141           crashing the whole server.
2142         * Tagged everything for the official 5.50 release.
2143
2144 Mon Dec 21 07:54:20 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
2145         * housekeeping.c: call kill_session() with session_to_kill,
2146           not ccptr->cs_pid (was crashing the server)
2147
2148 Sat Dec 19 13:57:48 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
2149         * Added "-i" flag to netproc to make it skip the export phase.
2150           Updated other programs to call netproc in this way when appropriate.
2151         * Updated network.txt to reflect the usage for netproc (which has
2152           been wrong for several releases)
2153
2154 Thu Dec 17 00:17:04 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
2155         * Started removing the word "beta" from the docs and code.
2156           Preparing for an actual release.
2157         * msgbase.c: generate an 'I' field when requested (i.e. on locally
2158           originating messages.  this was breaking parts of the network)
2159
2160 1998-12-15 Art Cancro <ajc@uncensored.citadel.org>
2161         * msgbase.c: remove extra call to alias() which was causing
2162           Citadel-to-Citadel mail to fall into the bit bucket.
2163         * msgbase.c: fixed tempfile naming problem that could cause a new
2164           outgoing netmail message to overwrite another if netproc had not been
2165           run in between
2166
2167 1998-12-14 Art Cancro <ajc@uncensored.citadel.org>
2168         * More session table stability nonsense
2169
2170 Sun Dec 13 17:40:08 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
2171         * sysdep.c, citserver.c: (hopefully) fixed a session table concurrency
2172           bug which was causing the server to occasionally crash.
2173         * removed serv_test.so from the default build
2174
2175 Fri Dec 11 18:50:00 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
2176         * setup.c: default value for maxsessions is now 0 (no limit)
2177         * room_ops.c: don't allow users to create a room called "Mail"
2178         * serv_expire.c: fixed "number of messages purged" display
2179         * commands.c: when using color, default to low-intensity colors
2180
2181 Tue Dec  8 07:58:16 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
2182         * Beta 2
2183
2184 Sat Dec  5 01:24:03 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
2185         * Added a new type of module hook for adding logging functions
2186         * Removed whitespace to left and right of '@' in netmail recipients
2187         * sysdep.c: read citadel.config _before_ initializing loadable modules
2188         * stats.c: fixed segfault resulting from extracting log lines
2189         * Ripped most of the "attachments" stuff out of both the client and
2190           server.  (Thought of a better way to handle it ... LATER.)
2191
2192 1998-12-03 Nathan Bryant <bryant@cs.usm.maine.edu>
2193         * setup.c: create citadel.config with mode 0600
2194         * Makefile.in: don't chmod sendcommand
2195         * serv_upgrade.c: don't create citadel.config if it doesn't already
2196           exist (paranoia)
2197         * setup.c: saner defaults for nodename and fqdn
2198
2199 Wed Dec  2 20:37:05 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
2200         * msgbase.c: modified AddMessageToRoom() and all functions that call it
2201           to use a more reliable/accurate method to set quickroom.QRhighest
2202         * weekly.in: don't sort/purge filedir where filedir doesn't exist
2203
2204 1998-12-02 Nathan Bryant <bryant@cs.usm.maine.edu>
2205         * weekly is now generated by configure
2206
2207 Mon Nov 30 19:48:52 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
2208         * room_ops.c: added sort_msglist() to move and save operations
2209         * sendcommand.c: added (also updated utils.txt, weekly, Makefile.in)
2210         * BETA 1
2211
2212 Sun Nov 29 23:57:39 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
2213         * Fixed cmd_regi() to not display a second result code after xfer
2214         * Makefile.in: Removed "chmod 4755 citmail netmailer"
2215
2216 1998-11-23 Nathan Bryant <bryant@cs.usm.maine.edu>
2217         * citadel.spec: added
2218
2219 1998-11-22 Nathan Bryant <bryant@cs.usm.maine.edu>
2220         * Makefile.in: split install target into install-exec, install-data,
2221           and install-doc subtargets
2222
2223 Sat Nov 21 16:53:30 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
2224         * Added a fourth color mode in the client: "user" which turns color
2225           on or off according to a per-user flag stored on the server.  Added
2226           server-side support for this too, of course.
2227         * import.c: removed
2228         * serv_expire.c: finished the code to purge stale visits
2229         * sysdep.c: strip trailing nonprintables in client_gets()
2230         * routines2.c: fixed <.AS> command; all configs now work properly
2231         * Moved num_parms() and all the extract() type functions into tools.c
2232           and removed them from all other files.  Linked in tools.[o|ro] there.
2233         * netproc.c: handled incoming file transfers to correct room directory
2234         * room_ops.c: fixed incorrect naming of files in info and images dirs
2235
2236 Fri Nov 20 20:29:07 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
2237         * setup.c: removed all prompts that can be configured from within the
2238           client in order to simplify the setup procedure
2239
2240 Thu Nov 19 23:28:33 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
2241         * Fixed serv_upgrade.c and export5.c (found elsewhere) to use a new
2242           export format which treats visits as a separate section
2243         * serv_expire.c: began writing functions to purge rooms and visits
2244           (neither work yet), and added a way to call defrag_databases()
2245
2246 Wed Nov 18 23:51:17 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
2247         * Reimplemented 'visit' structs stored globally instead of as
2248           lists-per-user
2249
2250 Tue Nov 17 22:37:48 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
2251         * Started implementing global room numbers.
2252
2253 Sun Nov 15 20:32:34 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
2254         * room_ops.c: mailbox rooms always appear on the main floor
2255         * made QR_MAILBOX rooms non-editable
2256         * cmd_setr() delete old room record when room name changes
2257           (This causes a big mess that exposes a flaw in the whole design.)
2258         * room_ops.c: users can delete messages from their mailboxes
2259
2260 Thu Nov 12 23:59:13 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
2261         * Rewrote cmd_rchg() and also increased the size of the "fakename"
2262           buffer.  Overruns are probably what was causing the crashes.
2263         * Changed the way cmd_ent3() handles mail messages; the previous code
2264           rerouted all private mail to the trash.
2265
2266 Wed Nov 11 17:57:39 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
2267         * citserver.c: slight changes to cmd_rchg() and cmd_hchg() [crashes]
2268         * citserver.c, msgbase.c, user_ops.c: hide the owner-prefix of mail
2269           rooms in a couple more places: set_wtmpsupp() and make_message()
2270         * sysdep.c: added an fflush() to lprintf() for "tail -f"-able logs
2271         * serv_expire.c: purge ops are now a command instead of a cleanup
2272           function.  This is probably temporary as well.
2273         * citadel.c: fixed the way <.WL> parses the returned data from a
2274           TIME command.
2275
2276 1998-11-11 Nathan Bryant <bryant@cs.usm.maine.edu>
2277         * serv_upgrade.c: fix uninitialized variable
2278
2279 Wed Nov 11 00:47:32 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
2280         * msgbase.c: fixed a bug that was misrouting incoming network msgs
2281         * server.h, database.c: wrapped all GDBM calls in critical sections
2282           to avoid making those calls re-entrantly (gdbm fatal: lseek error)
2283
2284 1998-11-10 Nathan Bryant <bryant@cs.usm.maine.edu>
2285         * Makefile.in: link in snprintf.o where needed
2286
2287 1998-11-09 Nathan Bryant <bryant@cs.usm.maine.edu>
2288         * client_chat.c: eliminate calls to sprintf()
2289         * commands.h, routines.c, routines2.c: warning fix
2290         * commands.c, control.c, cux2ascii.c, file_ops.c, import.c,
2291           ipc_c_tcp.c: eliminate sprintf() calls
2292
2293 Mon Nov  9 19:15:31 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
2294         * serv_upgrade.c: added all missing fields to export/import
2295         * serv_expire.c: support per-user purge time when purging users
2296         * user_ops.c: added per-user purge time to AGUP and ASUP commands
2297         * routines.c: added more stuff to <.A>ide <E>dit user
2298
2299 Sun Nov  8 22:56:53 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
2300         * serv_expire.c: created; moved message expiry from serv_test.c,
2301           moved user purge from userpurge.c
2302         * userpurge.c: deleted
2303         * routines2.c: finished <.AS> command
2304         * room_ops.c: fixed Aide room access (for some reason, the Aide
2305           room had the QR_MAILBOX flag set)
2306
2307 1998-11-08 Nathan Bryant <bryant@cs.usm.maine.edu>
2308         * useradmin.c: really removed (cvs remove)
2309         * aidepost.c, citadel.c: convert all sprintf() calls to snprintf()
2310         * sysdep.c: fix overrun in lprintf() described by dme/Dead Monkey
2311         * citmail.c, citserver.c: convert all sprintf() call to snprintf()
2312
2313 Sun Nov  8 13:19:36 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
2314         * useradmin.c: removed
2315         * utils.doc: removed references to useradmin and sysoputil
2316
2317 Fri Nov  6 20:22:20 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
2318         * citadel.h (and related files): removed defunct parameters,
2319           c_defent and c_msgbase (erase your test bbs)
2320         * Implemented CONF server command for site-global configs
2321         * Shuffled yesno() and yesno_d() from routines.c to commands.c
2322         * commands.c: implemented boolprompt()
2323         * routines2.c: started adding CONF questions to <.AS> command
2324         * room_ops.c: began a fix for the mysterious disappearing Aide room
2325
2326 1998-11-05 Nathan Bryant <bryant@cs.usm.maine.edu>
2327         * snprintf.c: warning fix propagated over from gcit
2328
2329 1998-11-04 Nathan Bryant <bryant@cs.usm.maine.edu>
2330         * added RCS Id keyword strings to sources
2331         * citmail.c: reverted to version 1.10
2332
2333 Wed Nov  4 10:53:13 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
2334         * messages.c: temporarily set screenwidth to a fixed value of 80
2335           during <P>rint operations.
2336
2337 Mon Nov  2 12:59:03 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
2338         * setup.c: looks for 'citadel', 'bbs', or 'guest' in /etc/passwd to
2339           try to get a default for bbsuid if it's currently set to 0
2340         * citmail.c: changed usersupp.eternal to usersupp.usernum (why didn't
2341           it complain about this before?)
2342         * serv_upgrade.c: began writing an "export" command to do sidegrades
2343
2344 Sun Nov  1 18:47:42 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
2345         * serv_upgrade.c: cosmetic changes
2346         * Implemented message expiry by date (this really needs to be moved
2347           out of serv_test.c, but where does it belong?)
2348
2349 1998-11-01 Nathan Bryant <bryant@cs.usm.maine.edu>
2350         * serv_upgrade.c: warning fixes
2351         * acconfig.h: remove ANSI_COLOR
2352         * Configure, Makefile.tmpl: removed
2353
2354 Sat Oct 31 20:48:44 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
2355         * More stoopid ANSI colour additions here and there.
2356         * ANSI colour selection is now in citadel.rc instead of an option in
2357           the configure script.  "on" "off" and "auto" are available.
2358         * added "build.txt" to the techdoc directory, with LS's build notes
2359
2360 1998-10-31 Nathan Bryant <bryant@cs.usm.maine.edu>
2361         * citadel.c, commands.c, commands.h: set background color to black
2362           before clearing screen, so that we can actually see text on
2363           black-on-white xterms.
2364
2365 1998-10-29 Nathan Bryant <bryant@cs.usm.maine.edu>
2366         * rooms.c: fix color of Mail>
2367         * citadel.c: send ANSI detect sequence after attach_to_server() so the
2368           terminal doesn't send the answerback sequence to the shell if we
2369           can't connect.
2370
2371 Wed Oct 28 20:20:14 EST 1998 Art Cancro <ajc@uncensored.citadel.org
2372         * citadel.c: Added a splash of colour to the Wholist
2373
2374 1998-10-28 Nathan Bryant <bryant@cs.usm.maine.edu>
2375         * configure.in: added comments
2376         * mkinstalldirs: new file to be used for `make install'
2377         * aclocal.m4, missing: new files, also swiped from automake
2378         * citadel.c: don't mung the terminal if we can't find citadel.rc
2379         * Makefile.in: added `install' target, `clean' removes
2380           *.mo, rebuild configure when configure.in changes.
2381         * configure.in: check for install and autoconf
2382         * configure.in, Makefile.in: only pass -fPIC to gcc
2383         * policy.c: warning fix for OSF/1 (use memset() instead of bzero())
2384
2385 Tue Oct 27 22:25:42 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
2386         * Unified the "unpacked database" format for both upgrades and
2387           sidegrades (also see export5.c elsewhere)
2388         * citserver.c: clear out cmdbuf before reading a command; some server
2389           commands were accidentally extracting parameters from previous cmds
2390         * rooms.c: removed the warning about the ineffectiveness of kicking
2391           users out of public rooms, because the new server can do lockouts
2392
2393 1998-10-27 Nathan Bryant <bryant@cs.usm.maine.edu>
2394         * sysdep.c (client_gets), ipc_c_tcp.c (serv_gets): improved handling
2395           of long lines. 
2396         * Makefile.in: partial support for VPATH builds, autodependency fix
2397
2398 Tue Oct 27 00:08:16 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
2399         * minor documentation changes
2400
2401 Sun Oct 25 14:57:40 EST 1998 Art Cancro <ajc@uncensored.citadel.org>
2402         * messages.c: fixed an oversight that was allowing attachments even
2403           when disabled in citadel.rc
2404
2405 1998-10-25 Nathan Bryant <bryant@cs.usm.maine.edu>
2406         * routines2.c: warning fix
2407
2408 Sat Oct 24 22:07:56 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
2409         * Client: added message expiration policy questions to room edit
2410         * Client: added <.A>ide <S>ystem configuration command
2411
2412 1998-10-24 Nathan Bryant <bryant@cs.usm.maine.edu>
2413         * Makefile.in: Auto dependency generation (may require GNU make, but
2414           does at least function without this feature on OSF/1 make);
2415           Makefile is regenerated when Makefile.in changes (ditto);
2416           `realclean' is now known as `distclean';
2417           portability fixes for older Unix make utilities
2418         * citadel.c, citadel.h, commands.c: make client suspendable
2419
2420 Fri Oct 23 19:34:38 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
2421         * setup.c: default node name is now obtained from uname()
2422         * config.c: added put_config()
2423         * policy.c: added, moved GetExpirePolicy() from room_ops.c
2424         * policy.c: implemented cmd_gpex() and cmd_spex()
2425
2426 Wed Oct 21 22:24:48 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
2427         * Mail rooms now hide their owner-prefix from the client.
2428         * proxy.c: added configurability and primitive message expiry
2429
2430 1998-10-20 Nathan Bryant <bryant@cs.usm.maine.edu>
2431         * Makefile.tmpl: fix to build client with old Configure script
2432         * configure.in: autologin defaults to enabled if crypt() is available
2433         * room_ops.c: fix improper null-termination bug I introduced
2434
2435 Mon Oct 19 20:52:55 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
2436         * Client ability to force display of prompts in Mail rooms, even when
2437           the user has prompting turned off (citadel.rc option)
2438
2439 1998-10-16 Nathan Bryant <bryant@cs.usm.maine.edu>
2440         * sysdep.c (cprintf): generate a newline on truncated buffer
2441         * room_ops.c: exploitable overrun fixes
2442
2443 Thu Oct 15 19:27:32 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
2444         * msgbase.c: reimplemented cmd_move()
2445           room_ops.c: wrote AddMessageToRoom() which is used for both entering
2446           and moving messages.
2447         * setup.c: system-default message expire policy of "number of
2448           messages, 150" is now a default configuration instead of a temp hack
2449         * proxy.c: cache dir create now dies on any error except EEXIST
2450
2451 Wed Oct 14 22:41:16 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
2452         * Misc code cleanup
2453
2454 1998-10-13 Nathan Bryant <bryant@cs.usm.maine.edu>
2455         * configure.in: don't check for -lcrypt unless autologin is enabled
2456         * file_ops.c: fix another overrun
2457
2458 Mon Oct 12 15:27:21 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
2459         * Killed the "rooms" subdirectory (it isn't used anymore)
2460         * dynloader.c: Made dynamically added server commands case-insensitive
2461         * import.c is now serv_upgrade.c, a module
2462         * Removed most of the "level 9" trace messages no longer needed
2463
2464 1998-10-12 Nathan Bryant <bryant@cs.usm.maine.edu>
2465         * Makefile.in: simplified to use pattern rules; files compiled with
2466           -D_REENTRANT go to *.ro to allow the same files to be used with both
2467           client and server
2468         * tools.c, tools.h: new files; misc routines used by both client and
2469           server go here. contains safestrncpy() at the moment.
2470         * rooms.c: fix several exploitable buffer overruns
2471         * sysdep.c: fix infinite loop when long lines are received from the
2472           client; fix exploitable buffer overrun in cprintf()
2473         * ipc_c_tcp.c: fix infinite loop on long line from server
2474         * serv_upgrade.sh: remove uncnsrd-dependent absolute path
2475         * .cvsignore: add *.ro
2476
2477 Sun Oct 11 23:17:48 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
2478         * Built some more of the message expiry infrastructure
2479
2480 1998-10-11 Nathan Bryant <bryant@cs.usm.maine.edu>
2481         * citserver.c: fix two more overruns, one of which was preventing
2482           the "From Host" from showing up in the <W>ho listing.
2483
2484 Sun Oct 11 02:51:55 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
2485         * Moved "struct visit" and its associated defs from citadel.h to
2486           server.h where they belong
2487         * Set up data structures for room policies (expiry, etc.)
2488
2489 1998-10-10 Nathan Bryant <bryant@cs.usm.maine.edu>
2490         * citserver.c: fix overrun which caused segv's on servers with long
2491           hostnames.
2492
2493 Fri Oct  9 18:34:06 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
2494         * user_ops.c: added PurgeStaleRelationships() to do processing at
2495           session logout time to remove visits for rooms which no longer exist
2496         * user_ops.c: implemented NewMailCount()
2497
2498 1998-10-09 Nathan Bryant <bryant@cs.usm.maine.edu>
2499         * serv_chat.c: fix buffer overrun that was resulting in segv's
2500         * serv_chat.c: fix another overrun that could cause sessions to hang,
2501           and cleaned up some other strncpy()-related stuff. DON'T FORGET TO
2502           NULL-TERMINATE DESTINATION BUFFERS AFTER STRNCPY CALLS.
2503
2504 Fri Oct  9 13:22:37 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
2505         * Implemented "lazy mode" traversal - pressing the space bar will do
2506           <N>ext messsage, <G>oto next room, or read <N>ew as appropriate.
2507         * room_ops.c: modify CtdlRoomAccess() to allow access to mailbox rooms
2508           only to their owners.
2509
2510 Thu Oct  8 17:13:27 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
2511         * messages.c, citadel.rc: added the ability to display message numbers
2512           in the header when reading messages.  I think this is butt ugly, but
2513           some of the DaveCode afficionados seem to like it...
2514
2515 Thu Oct  8 15:34:45 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
2516         * room_ops.c: Added is_noneditable() function to replace all of the
2517           duplicated code present in all functions which edit room parameters.
2518
2519 1998-10-08 Nathan Bryant <bryant@cs.usm.maine.edu>
2520         * lots of warning fixes; builds with -std1 on dec unix
2521         * aidepost.c, citadel.h, citmail.c, file_ops.c, msgbase.c, netmailer.c,
2522           netproc.c, rcit.c, server.h, stats.c, userlist.c: use time_t where
2523           needed
2524         * control.c, room_ops.c, serv_chat.c, sysdep.c: use memset() instead of
2525           bzero()
2526         * dynloader.c, dynloader.h, messages.c, server.h, sysdep.c,
2527           sysdep_decls.h: function pointer/prototyping fixes
2528         * rooms.c: use mkfifo(3) instead of system("mkfifo")
2529
2530 1998-10-07 Nathan Bryant <bryant@cs.usm.maine.edu>
2531         * snprintf.c, snprintf.h: new files
2532         * Makefile.in, configure.in, dynloader.c, sysdep.c: support for the
2533           above; citserver now builds and runs on Digital Unix 4.0d with the
2534           GNU-style configure script. there is a bug with the hostname display
2535           in the wholist.
2536         * netproc.c: sillyness fix
2537         * room_ops.h: prototype delete_room()
2538         * client_chat.c, commands.c, serv_chat.c, sysdep.c:
2539           use HAVE_SYS_SELECT_H macro
2540
2541 Mon Oct  5 17:01:32 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
2542         * Began fixing the stuff I broke
2543
2544 Sun Oct  4 23:35:18 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
2545         * Did the big migration to the new data structures.  Lots of stuff is
2546           now broken.  Basic moving from room to room works, but Mail is
2547           broken, and some of the administrative commands are unimplemented.
2548
2549 1998-10-02 Nathan Bryant <bryant@cs.usm.maine.edu>
2550         * configure.in: autologin now defaults to disabled
2551
2552 Fri Oct  2 00:04:31 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
2553         * Finally removed all three usersupp.foo[MAXROOMS] elements, and
2554           migrated all the code that used them to use "struct visit" instead.
2555
2556 Thu Oct  1 23:02:20 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
2557         * Rewrote [l][get|put]room() functions to use room names rather than
2558           room index numbers.  Temporarily prepended a "n" to these four
2559           function names until they are put to use.
2560
2561 Thu Oct  1 16:27:13 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
2562         * Removed a few more references to usersupp.lastseen[]
2563
2564 1998-10-01 Nathan Bryant <bryant@cs.usm.maine.edu>
2565         * .cvsignore: add so_locations (generated by osf1 ld with shared libs)
2566         * Makefile.in: restructured variables for greater consistency, use
2567           @echo to print out notices during the make process, add so_locations
2568           to `cleaner'
2569         * configure.in, Makefile.in: configure checks for -rdynamic
2570         * ipc_c_tcp.c: fix DEC compiler warning wrt unsigned char
2571         * stats.c: add semicolon to placate DREC compiler
2572         * user_ops.c: define _POSIX_C_SOURCE, include <limits.h>
2573         * configure.in: pass -pthread to DEC compiler, don't check for
2574           libpthread[s] on DEC Unix
2575
2576 1998-09-30 Nathan Bryant <bryant@cs.usm.maine.edu>
2577         * Makefile.in: new variable PTHREAD_DEFS for portability
2578         * aidepost.c, citadel.c, citmail.c, mailinglist.c, msgform.c,
2579           netmailer.c, netpoll.c, netproc.c, rcit.c, readlog.c, setup.c,
2580           stats.c, userlist.c, whobbs.c: return type of main() is int
2581         * citadel.c, commands.c, messages.c: use time_t properly
2582         * citserver.c: include <limits.h>
2583         * config.guess, config.sub, install-sh: new files
2584         * configure.in: don't use gcc on Digital Unix
2585
2586 Tue Sep 29 23:17:34 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
2587         * room_ops.c: modified usergoto() to look at the new data structures
2588           for counting new messages and such.
2589
2590 1998-09-29 Nathan Bryant <bryant@cs.usm.maine.edu>
2591         * user_ops.c: fix compiler warning and potential memory leak,
2592           include sysdep.h
2593         * configure.in, Makefile.in: only build the server if we find pthreads
2594         * Makefile.in: realclean removes config.{cache,log,status}
2595
2596 Tue Sep 29 13:20:14 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
2597         * Removed code from some of the utilities which was still attempting
2598           to access the old non-gdbm data store.
2599         * housekeeping.c: rewrote check_ref_counts() to do a ForEachRoom()
2600           traversal instead of a MAXROOMS loop.
2601         * sysdep.c: set up a dummy CitContext record to be used during server
2602           startup, during which time there is no real context.
2603
2604 Mon Sep 28 23:51:51 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
2605         * Implemented the function ForEachRoom() to handle all-rooms traversal
2606           (this will work with both the old and new paradigms, because both
2607           use a GDBM database with one room per record).  Migrated all room
2608           list commands to use it.
2609
2610 Mon Sep 28 22:05:35 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
2611         * Implemented the function CtdlRoomAccess() to handle *all* of the
2612           user-access-to-rooms functionality.  Migrated all room list commands
2613           to use it.  Still need to migrate gotos.
2614
2615 1998-09-28 Nathan Bryant <bryant@cs.usm.maine.edu>
2616         * configure.in, acconfig.h: new files; partially functional GNU
2617           autoconf configure script. Run autoheader; autoconf; ./configure
2618           --prefix=`pwd` to test.
2619         * Makefile.tmpl: new file; this is what Makefile.in used to be. Used by
2620           Configure.
2621         * Makefile.in: modified to work with autoconf-style configure script
2622         * Configure: modified to use Makefile.tmpl and generate autoconf-style
2623           macros. Removed procfs detection. Pass -O2 to gcc, -O to other
2624           compilers. Removed mknod/mkfifo detection; code should use mkfifo(3).
2625         * citmail.c, msgform.c, netproc.c, routines.c, support.c, userlist.c,
2626           whobbs.c: use HAVE_STRERROR macro rather than NO_STRERROR
2627         * commands.c: use HAVE_TERMIOS_H macro rather than POSIX_TERMIO
2628         * netproc.c: remove procfs stuff. simply attempt to kill the target
2629           process with signal zero instead; this checks whether the process
2630           exists.
2631         * setup.c, useradmin.c: use HAVE_CURSES_H macro
2632
2633 Sun Sep 27 23:41:29 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
2634         * BOTH the old and new generation systems are being written to at
2635           this point.  Code that reads stuff is still using the old system.
2636
2637 Sun Sep 27 16:10:49 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
2638         * Changed all "generation" variables from char to long, in preparation
2639           for removing MAXROOMS.  Generations for new rooms are now timestamps.
2640         * Defined "struct visit" to hold user/room relationships.
2641         * Removed some #define's from citadel.h that are no longer used.
2642
2643 Wed Sep 23 13:41:49 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
2644         * More changes to support attachments.  They mostly work, but only
2645           in fixed-format messages.
2646
2647 Mon Sep 21 21:19:17 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
2648         * msgbase.c: began laying the groundwork to support attachments.
2649           Purchased Rogaine(tm) in preparation for expected hair loss.
2650
2651 1998-09-21 Nathan Bryant <bryant@cs.usm.maine.edu>
2652         * msgbase.c: include dynloader.h
2653         * citadelapi.h: removed
2654         * dynloader.h: prototype CtdlRegisterUserHook()
2655
2656 Sun Sep 20 18:56:37 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
2657         * Added a UserFunctionHook category to implement hooks which perform
2658           operations on various users or usernames
2659
2660 Fri Sep 18 21:14:41 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
2661         * citserver.c: removed cmd_extn() and related code
2662
2663 1998-09-18 Nathan Bryant <bryant@cs.usm.maine.edu>
2664         * user_ops.c: include dynloader.h
2665         * roomstats.{c,mk}: removed
2666         * Configure, Makefile.in: autodependency-related fixes
2667
2668 Thu Sep 17 22:55:29 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
2669         * Various changes to allow "new messages" to work correctly with Mail
2670
2671 Thu Sep 17 22:21:45 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
2672         * server.h, dynloader.c, citserver.c, user_ops.c: reduced the number
2673           of hook types by inventing an EventType field to the Session hook.
2674         * proxy.c: added pre-fetching
2675
2676 1998-09-17 Nathan Bryant <bryant@cs.usm.maine.edu>
2677         * Makefile.in: add SERV_MODULES and PROXY_TARGETS to `cleaner'
2678         * dynloader.[ch], serv_{chat,test}.[ch], sysdep.c: cleaned
2679           up the dynamic loader interface as follows:
2680           - all the symbol table stuff is gone.
2681           - modules are loaded once at server startup and never unloaded.
2682           - Added a new function CtdlRegisterProtoHook() to handle the stuff
2683             that was being done with the symbol tables.
2684           - Dynamic_Module_Init() now returns a pointer to a static struct
2685             DLModule_Info; this structure itself has been modified to use char*
2686             fields instead of fixed char arrays.
2687         * roomstats.c: include <stdarg.h> not <stdargs.h> (is this file still
2688           in use?)
2689         * Configure, Makefile.in: added autodependency support
2690
2691 Wed Sep 16 22:25:13 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
2692         * Implemented separate structs, lists, and functions for each type
2693           of server-side hook available.
2694
2695 1998-09-16 Nathan Bryant <bryant@cs.usm.maine.edu>
2696         * ipc_c_tcp.c: Fixed up some #include/prototyping stuff, call memcpy()
2697           instead of bcopy()
2698         * hooks.h: removed
2699         * sysdep.c, user_ops.c: removed reference to hooks.h
2700
2701 Wed Sep 16 11:42:42 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
2702         * ipc_c_tcp.c: Reversed any changes that have been made to this file,
2703           because something was causing abominally slow response time.
2704         * proxy.c: added.  This will eventually become a caching, pre-fetching
2705           multiuser proxy server for the Citadel protocol.
2706
2707 1998-09-15 Nathan Bryant <bryant@cs.usm.maine.edu>
2708         * Makefile.in: remove support.o from serv_chat.so, add -fPIC to compile
2709           flags for serv_chat.o
2710         * dynloader.c: include "sysdep_decls.h", use RTLD_NOW not RTLD_LAZY
2711         * dynloader.h: prototype CtdlRegisterHook()
2712         * .cvsignore: added data
2713
2714 Mon Sep 14 20:49:08 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
2715         * Tried my hand at adding the ability for server extensions to
2716           register various types of "hooks" in addition to just adding
2717           server commands.  This is probably not final.
2718
2719 Tue Sep  8 12:11:56 EDT 1998 Brian Costello <btx@calyx.net>
2720         * Added support for dynamic server modules.  Reworked serv_chat.c
2721           to be such a module.
2722
2723 Tue Sep  1 23:09:50 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
2724         * userpurge.c: rewrote using functions from the server core, rather
2725           than the now-defunct external API.  This'll be ready once the module
2726           loading code is done.  (I just had to commit _something_ tonight.)
2727
2728 Mon Aug 31 22:47:58 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
2729         * Yanked the citadelapi.c module.  This wasn't working out well.
2730         * techdocs/citadelapi.txt - began documenting the new API to be used
2731           by modules which will be dynamic linked into the server - most of
2732           this API is existing server functions.
2733         * Added a ForEachUser() function with callback mechanism, and reworked
2734           cmd_list() to use it.
2735
2736 Sun Aug 30 21:52:43 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
2737         * Moved all of the gdbm databases to a separate "data" directory.
2738
2739 1998-08-26 Nathan Bryant <bryant@cs.usm.maine.edu>
2740         * Makefile.in: realclean removes Makefile, fixed `touch citadel.h'
2741           problem
2742
2743 1998-08-25 Nathan Bryant <bryant@cs.usm.maine.edu>
2744         * room_ops.c: include time.h
2745         * userlist.c, whobbs.c, serv_chat.c, user_ops.c, sysdep.c, stats.c,
2746           citadel_decls.h, commands.c, messages.h, routines.h, routines2.h:
2747           remove duplicated declarations
2748
2749 Mon Aug 24 23:45:01 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
2750         * setup.c: Removed yesno_s()
2751         * citadel.h, room_ops.c: added QRmtime field to struct quickroom,
2752           modified whenever a room is modified or posted in.
2753         * citadelapi.c: Added CtdlForEachRoom() function
2754
2755 Mon Aug 24 20:04:04 EDT 1998 Nathan Bryant <bryant@cs.usm.maine.edu>
2756         * Makefile.in: new target `cleaner' does the same as `realclean' 
2757           without removing sysdep.h
2758         * proto.h: is bad. eliminate. I've moved the prototypes into several
2759           header files, one per .c file
2760
2761 Mon Aug 24 00:45:55 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
2762         * Added a CtdlGotoRoom() function to the CitadelAPI.
2763  
2764 Sun Aug 23 21:47:00 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
2765         * sysoputil is finally dead!  Removed it from the build.
2766         * Added userpurge.c server extension (initial implementation)
2767
2768 Tue Aug 18 00:42:33 EDT 1998 Nathan Bryant <bryant@cs.usm.maine.edu>
2769         * Makefile.in: `clean' target no longer rm's sysdep.h; new target
2770           `realclean' removes everything clean does, plus sysdep.h, plus
2771           target binaries.
2772         * Configure: add -Wstrict-prototypes to CFLAGS for gcc systems
2773         * *.[ch]: protoized. Added several new header files containing
2774           prototypes and other external declarations; many duplicated
2775           declarations still should be moved to header files. proto.h must die
2776           as well, IMHO.
2777
2778 Mon Aug 17 23:52:13 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
2779         * Implemented a bunch of user account related functions in the
2780           CitadelAPI library.
2781
2782 Mon Aug 17 20:01:18 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
2783         * Fixed the crash problem.  It wasn't AGUP/ASUP, but rather a buffer
2784           overrun in getuser() (thanks, Nathan).  Implemented overrun checks
2785           in getuser(), getroom(), and getfloor() to prevent future problems.
2786
2787 Mon Aug 17 00:06:52 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
2788         * Updated citmail.c with the latest stuff from the production system.
2789         * Implemented AGUP and ASUP commands, but AGUP crashes the server
2790           after its first successful use (user-not-found's don't affect it).
2791
2792 Thu Aug  6 19:25:01 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
2793         * Got the CitadelAPI library to the point where the server can start
2794           up an extension, and the extension will connect to the server, do
2795           some initialization, call a user-supplied CtdlMain(), and exit.  Also
2796           hacked together a _temporary_ form of the new EXTN server command.
2797  
2798 Wed Aug  5 23:02:22 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
2799         * Second attempt at getting the server API started.  Now it runs
2800           outside of the server and builds a connection.
2801
2802 Tue Aug  4 18:33:06 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
2803         * Modified the appearance of Internet addresses when they arrive on
2804           a Citadel system.
2805         * Removed the <E> field from the message format writeup in hack.txt.
2806         * Fixed-up citmail.c so that it doesn't try to do database lookups.
2807
2808 Mon Aug  3 23:01:37 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
2809         * Started developing the server-side API.  This is in its very
2810           initial stages.  See serverapi.c and techdoc/api.txt
2811
2812 1998-08-02  Nathan Bryant  <bryant@cs.usm.maine.edu>
2813         * Makefile.in: added config_decls.h to dependencies
2814
2815 Sun Aug  2 21:09:09 EDT 1998 Nathan Bryant <bryant@cs.usm.maine.edu>
2816         * config_defs.h: renamed to config_decls.h
2817         * config.c, sysoputil.c: updated to reflect the above
2818
2819 Sun Aug  2 18:52:05 EDT 1998 Nathan Bryant <bryant@cs.usm.maine.edu>
2820         * config_defs.h: new file, contains external declarations from config.c
2821         * config.c: moved defs to config_defs.h, use PATH_MAX from <limits.h>
2822           for bbs_home_directory
2823         * mailinglist.c, support.c: include <string.h>
2824         * sysoputil.c: include <string.h>, <limits.h>, "config_defs.h", remove
2825           duplicated defs, replace gets() call with fgets()
2826         * user_ops.c: define _XOPEN_SOURCE_EXTENDED
2827
2828 Sat Aug  1 18:32:52 EDT 1998 Nathan Bryant <bryant@cs.usm.maine.edu>
2829         * ipc_c_tcp.c: fixed order of memcpy parameters after gethostbyname
2830
2831 Sun Jul 19 17:26:12 EDT 1998 Nathan Bryant <bryant@cs.usm.maine.edu>
2832         * ChangeLog: reordered; the GNU standard is to add new entries to the
2833           top.
2834         * .cvsignore: added userlist
2835
2836 Sun Jul 12 20:58:59 EDT 1998 Art Cancro <ajc@uncensored.citadel.org>
2837         * Finished migrating everything to the new data store.
2838         * Replaced the binary "calllog" with the ASCII "citadel.log"
2839         * Began converting broken utilities that depend on the old data store
2840
2841 Sat Jul 11 00:20:48 EDT 1998 Nathan Bryant <bryant@cs.usm.maine.edu>
2842         * Makefile.in: removed msgstats
2843
2844 Fri Jul 10 1998 Art Cancro <ajc@uncensored.citadel.org>
2845         * Initial CVS import 
2846