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