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