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