* Changes to message base and networker to support Internet-style message
[citadel.git] / citadel / ChangeLog
1 $Log$
2 Revision 1.481  2000/03/10 21:40:04  ajc
3 * Changes to message base and networker to support Internet-style message
4   ID's instead of the conventional Citadel style.
5
6 Revision 1.480  2000/03/08 03:36:37  ajc
7 * Shut off hostname resolution when dealing with Unix domain sockets
8 * Cleaned up the 'citmail' MDA tool
9 * Added POP3 and SMTP port numbers to global system configuration
10
11 Revision 1.479  2000/03/07 21:54:58  ajc
12 * Fixed the naming conventions and permissions for unix domain sockets.
13
14 Revision 1.478  2000/03/05 07:33:23  ajc
15 * Added support for protocols over Unix domain sockets.
16
17 Revision 1.477  2000/03/04 22:36:23  ajc
18 * Remove nulls appended to editor files during replace, edit, and print
19   operations.  Truncate temp files during same operations.
20   Closes bugs #6 and #7.
21
22 Revision 1.476  2000/03/04 05:29:18  ajc
23 * Relax restrictions on editing of base rooms.  Renaming is not allowed but
24   all other attributes can be edited.  Closes feature request #21.
25 * Sending pages from the client now uses the same message editing functions
26   as entering messages, allowing edit/abort.  Closes feature request #25.
27
28 Revision 1.475  2000/03/03 04:50:14  ajc
29 * Moved all of the wholist masquerading commands into the serv_rwho module
30
31 Revision 1.474  2000/03/03 04:12:37  ajc
32 * Finished the inbound side of gateway domain service
33
34 Revision 1.473  2000/02/27 04:55:51  ajc
35 * Added "keymenu()" generic menu-maker to commands.c
36 * Blocked non-numeric input to intprompt()  (fixes bug #16)
37
38 Revision 1.472  2000/02/27 03:57:35  ajc
39 * Completed 'fsck'-like reference count verifier (server and client)
40
41 Revision 1.471  2000/02/26 18:30:40  ajc
42 * Properly handle all aliases specified in network/mail.aliases for incoming
43   SMTP mail (uses the alias() function, so if we replace that function with
44   something that uses the same calling convention, it'll still work)
45
46 Revision 1.470  2000/02/26 05:15:38  ajc
47 * Fortified the message base and SMTP code so that misdirected bounce messages
48   end up in the Aide> room instead of getting dereferenced
49 * Started writing a message reference count verifier ('fsck' for message base)
50
51 Revision 1.469  2000/02/25 06:14:05  ajc
52 * Modularized the RWHO (Read WHO is online) command, basically as a pilot
53   for modularizing all "non-API" functionality.
54
55 Revision 1.468  2000/02/24 03:44:00  ajc
56 * Implemented holdoff time (15 minutes) for SMTP send retry.
57 * Implemented "try for 3 days and then give up" on SMTP send.
58
59 Revision 1.467  2000/02/24 00:51:48  ajc
60 * Client protocol synchronization check during exit from chat.
61   This closes Bug #15.
62
63 Revision 1.466  2000/02/22 16:37:28  ajc
64 * Minor tweaks to RFC822 output to keep brain-damanged MS Outlook from dying
65
66 Revision 1.465  2000/02/22 04:17:56  ajc
67 * Got bounce messages working (mostly ... testers, please beat this up!)
68 * Changed 'FIX' comments to 'FIXME' (less conflict, plus vim highlights it!)
69
70 Revision 1.464  2000/02/18 22:29:18  ajc
71 * Coded up the "bounce" functions.  Still a coupla bugs.
72
73 Revision 1.463  2000/02/18 05:10:50  ajc
74 * Made the <.ASI> command a bit friendlier.
75 * SMTP sender now pays attention to "smarthost" entries in the system's
76   Internet configuration, using them if one or more is present.
77
78 Revision 1.462  2000/02/17 05:27:39  ajc
79 * Got the "MAIL From:" command sending the correct data.  (unnnhhhhnnhhhh...)
80
81 Revision 1.461  2000/02/16 22:06:26  ajc
82 * Altered the display and conversion of RFC822 messages
83
84 Revision 1.460  2000/02/16 03:43:28  ajc
85 * Added the resolver library to the configure script
86
87 Revision 1.459  2000/02/16 01:19:39  ajc
88 * Vanquished the evil dn_expand() beast.  getmx() now seems to be working.
89
90 Revision 1.458  2000/02/14 04:36:14  ajc
91 * sysdep.c: added new event hook type EVT_TIMER.  Timer event hooks are called
92   once per minute by any worker thread.
93 * msgbase.c: removed dependence on nested functions in CtdlOutputMsg() by
94   replacing them with an API call CtdlRedirectOutput() in sysdep.c, which
95   can temporarily redirect a session's output to an arbitrary file or socket.
96 * serv_smtp.c: implemented the purging of messages in the queue for which all
97   deliveries have been completed.
98 * serv_smtp.c: removed temporary 'QQQQ' server command and replaced it with
99   a timer event hook that runs the queue once per minute (this needs to be
100   made more robust)
101
102 Revision 1.457  2000/02/08 21:00:47  ajc
103 * Implemented the deprecated "LAST" command in POP3.  Some clients need it.
104 * POP3 sessions now set the last-read pointer in Mail>.
105
106 Revision 1.456  2000/02/07 05:15:00  ajc
107 * Renamed CtdlLocalHost() to CtdlHostAlias() and worked it a little deeper into
108   the message routing logic.  Still needs some work on the gateway-domain
109   stuff.
110 * Twiddled CtdlOutputMsg() a bit for 'all Internet' situations.  Still needs
111   some work to avoid printing dual headers when both Cit and RFC822 exist.
112
113 Revision 1.455  2000/02/03 03:57:35  ajc
114 * Formalized the 'Internet Configuration' logistics.  Added new API call
115   CtdlLocalHost() to detect aliases for the local host.  Used in SMTP listener.
116
117 Revision 1.454  2000/01/31 02:13:05  ajc
118 * <.A>ide <S>ystem configuration <I>nternet  in the client (unfinished)
119
120 Revision 1.453  2000/01/26 02:41:27  ajc
121 * SMTP delivery is working but still *very* rough.
122
123 Revision 1.452  2000/01/25 04:45:50  ajc
124 * Wrote enough of the SMTP sender to get Patriot drooling over it, but not
125   enough to complete the transmission of mail.
126
127 Revision 1.451  2000/01/23 21:25:45  ajc
128 * Temporary hack to ig_tcp_server() to listen on an arbitrary port if the
129   one specified is not bindable (for development only)
130 * Added SM_DONT_BUMP_REF flag to CtdlSaveMsgPointerInRoom() to be used only
131   in very specific and special situations
132 * Generate delivery instructions when outbound SMTP mail is created from
133   within Citadel (as opposed to being from the SMTP module)
134
135 Revision 1.450  2000/01/23 05:22:41  ajc
136 * Coded up some more of the SMTP-sender (still not done)
137
138 Revision 1.449  2000/01/22 05:13:56  ajc
139 * Added some more functionality to the string tokenizer
140
141 Revision 1.448  2000/01/17 20:57:43  ajc
142 * CR to CRLF hacks (lose, lose, lose)
143
144 Revision 1.447  2000/01/17 18:30:27  ajc
145 * Completed POP3 server.  All RFC1939 commands except APOP are implemented.
146
147 Revision 1.446  2000/01/17 17:09:23  ajc
148 * Implemented LIST and STAT commands in the pop3 server
149
150 Revision 1.445  2000/01/17 05:38:14  ajc
151 * citserver.c: cleanup hook functions are now run under the proper context,
152                even when initiated by the housekeeper thread
153 * serv_pop3.c: establish a place to hold the message list
154
155 Revision 1.444  2000/01/17 04:26:39  ajc
156 * Modified CtdlOutputMsg() to handle output to arbitrary sockets or files.
157   This uses nested functions and may not be portable beyond GCC...
158
159 Revision 1.443  2000/01/15 18:29:15  ajc
160 * Added a generic (void *) parameter to the ForEachUser() and ForEachRoom()
161   callback mechanisms, to allow callers and callbacks to pass arbitrary data
162   between each other without requiring TSD variables.
163 * room_ops.c: eliminated the need for 'FloorBeingSearched' TSD variable
164 * internet_addressing.c: eliminated 'buffer1' and 'buffer2' TSD variables
165
166 Revision 1.442  2000/01/15 04:31:44  ajc
167 * Removed UI_DIALOG mode in setup.  Can't count on 'dialog' to be consistent.
168
169 Revision 1.441  2000/01/15 04:07:17  ajc
170 * Fixed the access rights on auto-created rooms (the same changes that were
171   made to version 5.62 in the stable tree)
172
173 Revision 1.440  2000/01/13 03:32:36  ajc
174 * techdoc/delivery-list.txt: added (syntax for delivery lists)
175 * domain.*: added (will contain MX lookup code)
176 * internet_addressing.c, logging.c: fixed some buffer overflow bugs
177
178 Revision 1.439  2000/01/12 03:56:27  ajc
179 * sysdep.c: start the housekeeping thread *after* dropping root perms.
180
181 Revision 1.438  2000/01/09 19:03:16  ajc
182 * Removed the fifo-based protocol downloads and replaced it with a less
183   elegant "download temporary file to client, then sx/sb/sz" because
184   downloading through a fifo was confusing some software.
185
186 Revision 1.437  2000/01/08 22:19:44  ajc
187 * Completed spool to outbound delivery queue (still no queue sender implemented)
188
189 Revision 1.436  2000/01/08 05:00:09  ajc
190 * Reworked some of the data structures to handle multiple recipients
191 * Began implementation of the delivery queue
192 * Added CtdlReallocUserData()
193 * CtdlSaveMsg() now returns the local message ID in the database
194
195 Revision 1.435  2000/01/06 03:50:34  ajc
196 * Replaced citmail.c with a new one that simply SMTP-forwards to Citadel
197 * Started outbound SMTP queue work
198
199 Revision 1.434  1999/12/30 04:56:29  ajc
200 * Got initial SMTP delivery working in a very specific situation (delivery
201   to a single, local user)
202
203 Revision 1.433  1999/12/29 04:44:00  ajc
204 * client_chat.c: display "No message sent" if a send page is aborted.
205   Closes bug #2 in bugzilla.
206
207 Revision 1.432  1999/12/26 21:50:07  ajc
208 * serv_vcard: don't run hooks when not logged in (such as in SMTP sessions)
209 * serv_pop3: added.  This is the skeleton for a module implementing POP3.
210
211 Revision 1.431  1999/12/23 04:46:23  ajc
212 * "Finished" initial hack of RFC822 import
213
214 Revision 1.430  1999/12/22 04:46:34  ajc
215 * Fixed up the "Date:" headers to be RFC822-compliant
216
217 Revision 1.429  1999/12/13 05:30:57  ajc
218 * Removed our naive 'conv_date()' RFC822-to-unixtime conversion function
219   and replaced it with the public domain 'parsedate()' function from UseNet
220
221 Revision 1.428  1999/12/10 23:58:25  ajc
222 * internet_addressing.c: added.  (Internet address to Citadel mapping)
223
224 Revision 1.427  1999/12/10 21:34:19  ajc
225 * serv_smtp: implemented RFC821 "VRFY" and "EXPN" commands
226
227 Revision 1.426  1999/12/09 05:01:14  ajc
228 * Split cmd_user() and cmd_pass() into frontend/backend functions
229 * serv_smtp: implemented AUTH LOGIN for client authentication
230
231 Revision 1.425  1999/12/09 00:22:58  ajc
232 * Finished the "arbitrary service" registration.
233 * Eliminated "special" master socket for Citadel protocol - just register it
234   like any other protocol.
235 * Began initial implementation of native SMTP service.
236
237 Revision 1.424  1999/12/08 18:09:10  ajc
238 * Added CtdlRegisterServiceHook() and its data type, for implementing arbitrary
239   TCP-based services directly in the Citadel server.  Not finished yet.
240
241 Revision 1.423  1999/11/29 17:39:07  nbryant
242 * citserver.c: Solaris lacks inet_aton; use inet_addr instead
243
244 Revision 1.422  1999/11/29 17:26:15  nbryant
245 * citserver.c: include <sys/types.h>; may help portability to Solaris
246
247 Revision 1.421  1999/11/22 00:27:42  ajc
248 * Added some temporary variables to OpenCmdResult().  Hopefully fixes
249   bug #14 when running on FreeBSD.
250
251 Revision 1.420  1999/11/21 18:30:16  ajc
252 * Protected cmd_move() from buffer overrun (no longer crashes the server)
253 * cmd_chat() -- truncate input at 100 characters to prevent buffer overruns.
254   Also handle broken client sockets properly.  (Thanks to DME for bug report)
255
256 Revision 1.419  1999/11/19 01:57:40  ajc
257 * Fixed a *serious* memory leak in the database function wrappers.
258 * Updated version number to 5.60 -- run setup when installing this version.
259
260 Revision 1.418  1999/11/18 03:29:20  ajc
261 * Changed the order of parameters in <.A>ide <S>ystem config into a more
262   logical grouping.
263
264 Revision 1.417  1999/11/18 02:31:50  ajc
265 * Updated some of the documentation
266 * Brought the internal version number up to 5.60
267
268 Revision 1.416  1999/11/17 04:15:05  ajc
269 * Removed the session_count() function.  Instead, keep a reference count
270   updated when sessions begin and end.
271 * Replaced fixed number of worker threads with lower and upper limits; current
272   code now tries to make thread count == session count, within these limits
273
274 Revision 1.415  1999/11/15 03:17:39  ajc
275 * Put lockfile in /tmp instead of in /var/lock.   The latter is not guaranteed
276   to exist, nor is it guaranteed to be writable by BBSUID
277   (Resolves bug #11 from the Bugzilla repository)
278
279 Revision 1.414  1999/11/15 03:07:24  ajc
280 * Fixed the network-wide vCard purge logic so that it (1) actually works,
281   and (2) forces a netproc run immediately when a purge is entered
282
283 Revision 1.413  1999/11/09 21:20:44  nbryant
284 * configure.in: include <sys/types.h> when doing checks which require <utmp.h>
285   (should fix Bug #10 on FreeBSD)
286
287 Revision 1.412  1999/11/05 03:53:47  ajc
288 * Issue 'cancel' messages for vCard when a user is deleted.
289 * Try to delete 'cancel' messages locally after they've been distributed.
290
291 Revision 1.411  1999/11/03 04:01:20  ajc
292 * Fixed buffer overrun problems in cmd_rchg(), cmd_hchg(), and cmd_uchg()
293 * Removed my email address as the feedback content from the docs; replaced
294   it with a reference to the Citadel/UX web site.
295
296 Revision 1.410  1999/11/02 19:51:23  ajc
297 * Fixed timeout problem for remote client sessions (all timeouts were set to
298   1 second ... probably a temporary hack that was missed in the cleanup)
299
300 Revision 1.409  1999/11/02 03:03:27  ajc
301 * Several fixes to msgbase.c and netproc.c to prevent corrupted incoming
302   network traffic from crashing the server.  Reject bad messages.
303
304 Revision 1.408  1999/11/01 04:21:34  ajc
305 * Fixed a concurrency bug which crashed the server when multiple sessions
306   terminated simultaneously.
307
308 Revision 1.407  1999/11/01 00:54:02  ajc
309 * CtdlFetchMessage() - generate a "<no text>" message body if there's none
310   on disk.  Too much stuff goes haywire if there's no M field.
311
312 Revision 1.406  1999/10/31 18:17:17  ajc
313 * Fixed buffer overrun in cmd_rchg()
314 * Call master_cleanup() when time_to_die==1 for proper shutdown
315
316 Revision 1.405  1999/10/31 16:26:55  ajc
317 * Fixed incorrect assignment of new session ID's
318
319 Revision 1.404  1999/10/31 04:17:17  ajc
320 * Fixed a bug which was crashing the server during very long message entry.
321
322 Revision 1.403  1999/10/29 01:48:45  ajc
323 * database.c: Removed arbitrary limit on maximum number of sessions
324
325 Revision 1.402  1999/10/29 01:03:03  ajc
326 * Debugged all possible ways for a session to terminate; do them cleanly.
327 * Assign session numbers in a more portable and less arbitrary way.
328
329 Revision 1.401  1999/10/28 19:50:55  ajc
330 * Fixed a problem where the client protocol would spit out two responses
331   and therefore get out of sync if ASUP command set the access level to
332   0 and therefore deleted the user (thanks to Eric McDonald)
333
334 Revision 1.400  1999/10/28 05:08:49  ajc
335 * Removed all of the thread cancellation cruft that is no longer necessary
336 * Moved the now non-system-dependent RemoveContext() out of sysdep.c (now
337   it's part of cleanup() in citserver.c)
338 * Removed all references to pthread_* from all modules except sysdep.c
339
340 Revision 1.399  1999/10/28 03:20:17  ajc
341 * Fixed the problem of worker threads waking up prematurely.
342 * 'QUIT'-terminated sessions now exit properly.
343
344 Revision 1.398  1999/10/27 04:26:58  ajc
345 * Initial hack of worker-thread rearchitecture.  Right now it is successfully
346   dispatching worker threads to active client sockets (and to the master
347   socket too, of course).  Removing sessions is currently broken.
348
349 Revision 1.397  1999/10/26 20:20:29  ajc
350 * Removed the auto-reconnect stuff... it was locking the client in an active
351   loop more often than it was reconnecting.
352
353 Revision 1.396  1999/10/26 13:59:11  ajc
354 damn bugs
355
356 Revision 1.395  1999/10/26 03:48:39  ajc
357 * Shuffled around the order of events when a thread is terminating.  All
358   mutex operations now happen prior to the freeing of the CitContext structure,
359   otherwise begin_critical_section() and end_critical_section() try to
360   manipulate the context's mutex count when there isn't any context.
361
362 Revision 1.394  1999/10/26 03:21:16  ajc
363 * Changed a lot of strncpy() calls to safestrncpy() and replaced most of their
364   hardcoded size arguments with 'sizeof' based arguments.
365
366 Revision 1.393  1999/10/24 19:22:51  nbryant
367         * Makefile.in, configure.in: added --enable-icq flag; made checks for
368           authentication libraries more intelligent.
369
370 Revision 1.392  1999/10/23 03:39:12  ajc
371 * Finished moving vCard functionality to the new message base functions.
372
373 Revision 1.391  1999/10/21 00:50:14  ajc
374 * Finished up the flags and replication checks in CtdlSaveMsgPointerInRoom().
375
376 Revision 1.390  1999/10/20 16:46:27  ajc
377 * More code shuffle.  Added some flags to CtdlSaveMessagePointerInRoom() and
378   enabled the MOVE command to also do a "copy" operation (actually just
379   creates a second link and bumps the ref count).  Implemented "<C>opy" in
380   the client.
381
382 Revision 1.389  1999/10/20 16:07:48  ajc
383 * Wholist fixes for users who are in chat mode
384
385 Revision 1.388  1999/10/20 03:42:29  ajc
386 * In the wholist, only show <private room> if the user viewing the list
387   doesn't know that room.  Otherwise show the name.
388
389 Revision 1.387  1999/10/20 02:59:22  ajc
390 * Code reorganization.  Making it easier to move/copy messages without
391   duplicating existing code.
392
393 Revision 1.386  1999/10/17 02:25:18  ajc
394 * Discovered a huge design flaw in the replication algorithm.  Ripped it
395   out and replaced it with something a bit more robust.
396
397 Revision 1.385  1999/10/16 05:30:17  ajc
398 * Changes to message replication code.  Don't do server-side hooks during
399   an ENT3 command.  Also fixed a bug in cmd_whok() that caused crashes
400   after a file format change.
401
402 Revision 1.384  1999/10/14 03:04:16  ajc
403 * Finished the netproc side of Z (zap/supersede) processing for replication
404
405 Revision 1.383  1999/10/13 04:24:18  ajc
406 * Added search-by-header-fields to CtdlForEachMessage(), and then to the
407   server MSGS command.  This will have lots of uses.
408
409 Revision 1.382  1999/10/13 01:36:39  ajc
410 * Starting some work on network zap (supersede) mode for replication
411
412 Revision 1.381  1999/10/08 02:55:57  ajc
413 * More vCard-related debugging
414
415 Revision 1.380  1999/10/07 02:58:46  ajc
416 * Semi-broken vCard replacement implementation in place.
417 * Added "Z" (Zap, supersede) field to message format
418
419 Revision 1.377  1999/10/04 03:19:52  ajc
420 * We now have a housekeeping thread and a housekeeping queue.
421
422 Revision 1.376  1999/10/03 21:48:21  ajc
423 * Added serv_upgrade.h to automagically convert pre-5.55 format user records
424   to 5.55 format user records and generate vCards.
425
426 Revision 1.375  1999/09/29 21:13:17  ajc
427 * CtdlWriteObject() can now store objects in personal rooms for any specified
428   user -- rather than only the current user or non-personal rooms.
429
430 Revision 1.374  1999/09/29 17:26:56  ajc
431 * serv_vcard.c: fixed crashola bug in cmd_greg()
432 * tools.c: simplified and improved the string tokenizer.  Now it runs in a
433            single pass with no intermediate buffer.
434
435 Revision 1.373  1999/09/28 03:27:37  ajc
436 * Fully migrated cmd_greg() and cmd_regi() into serv_vcard (still has bugs)
437
438 Revision 1.372  1999/09/27 03:33:40  ajc
439 * cmd_regi() is now in serv_vcard and writes to the vcard instead of to the
440   usersupp file.  Still needs tweaking.
441
442 Revision 1.371  1999/09/24 03:32:19  ajc
443 * "read my vCard" and "write my vCard" are written and tested.
444
445 Revision 1.370  1999/09/24 02:54:17  ajc
446 * Worked a little more on the vCard stuff.  The serv_vcard module is now in
447   place, and a "read my vcard" function is there; "write my" is next...
448
449 Revision 1.369  1999/09/23 03:07:56  ajc
450 * The vCard 'class' is now linked into the server, though it's not really
451   functional yet.  Its constructors/destructors are debugged, though.
452
453 Revision 1.368  1999/09/19 21:28:33  ajc
454 * Finished off the message architecture stuff with a new class of hooks to
455   enable future server-side handlers.
456
457 Revision 1.367  1999/09/19 15:57:06  ajc
458 * migrated cmd_ent3() to CtdlSaveMessage()
459
460 Revision 1.366  1999/09/19 05:13:57  ajc
461 * Debugged the new version of CtdlWriteObject()
462
463 Revision 1.365  1999/09/16 03:23:23  ajc
464 * Did most of the migration from save_message() to CtdlSaveMsg().  The
465   latter builds a "struct CtdlMessage" (so we can run server-side handlers
466   against it later on), then serializes it and stores to disk.
467 * BROKEN BUILD ALERT!!  cmd_ent3() and CtdlWriteObject() are still not
468   migrated.  They are stubbed out and will MALFUNCTION if used right now!!
469
470 Revision 1.364  1999/09/07 01:42:42  ajc
471 * cmd_msg3() now uses serialize_message() for its output.  All message
472   commands will eventually exist as a "struct CtdlMessage" at some point
473   so that we can install server-side handler hooks.
474
475 Revision 1.363  1999/09/07 00:04:13  ajc
476 * netproc.c: put outgoing messages into the use table, too -- this prevents
477   locally originated messages from showing up again if a remote system is
478   misconfigured and spools them back to us.
479
480 Revision 1.362  1999/09/06 03:39:15  ajc
481 * citadel.c: run strproc() on new passwords
482
483 Revision 1.361  1999/09/03 17:50:26  playcow
484 For URL view, don't prompt user to select url if there is only one.  Display
485 <U>RL View prompt if message contains url(s). -Ben
486
487 Revision 1.360  1999/09/02 02:09:59  ajc
488 * msgbase.c: new function serialize_message() for future use
489
490 Revision 1.359  1999/09/01 21:09:25  ajc
491 * database.c: display the GDBM version string on startup
492
493 Revision 1.358  1999/09/01 02:36:34  ajc
494 * Actually _enforce_ the max msg len limit
495
496 Revision 1.357  1999/09/01 01:51:48  ajc
497 * Added the ability to handle embedded URL's from the text client
498
499 Revision 1.356  1999/09/01 01:02:47  ajc
500 * Implemented "maximum message length" in global system config
501
502 Revision 1.355  1999/08/31 00:57:17  ajc
503 * Handle multipart/alternative properly during legacy message outputs.
504   Basically it just prints the first alternative and skips the rest.
505
506 Revision 1.354  1999/08/29 21:12:24  ajc
507 * Made some changes to the output of MIME (especially multipart) messages.
508
509 Revision 1.353  1999/08/29 19:56:43  ajc
510 * HTML updates
511
512 Revision 1.352  1999/08/24 02:01:03  ajc
513 * html.c: added.  This is an overly simplistic HTML-to-text converter.
514
515 Revision 1.351  1999/08/21 18:37:29  ajc
516 * Minor cosmetic cleanup.  No code changes.
517
518 Revision 1.350  1999/08/21 05:15:34  ajc
519 * mailinglist.c, netmailer.c: fixed to allow list submissions from all posters
520   on a Citadel network rather than only on the local system.
521
522 Revision 1.349  1999/08/08 00:25:45  ajc
523 * Made one more byte available in locate_host() and in all the structs which
524   its output gets written to (client can display 24 positions but we were only
525   saving 23).
526
527 Revision 1.348  1999/08/07 16:34:38  nbryant
528 * serv_icq.c: warning fixes
529
530 Revision 1.347  1999/08/06 02:57:26  ajc
531 * locate_host.c: use strdoop() and phree() instead of strdup() and free()
532 * serv_icq.c: run learned IP's through Citadel's locate_host() & put in Wholist
533
534 Revision 1.346  1999/08/05 17:58:59  ajc
535 * RWHO command now returns express message code in postion 3
536
537 Revision 1.345  1999/08/04 02:21:45  ajc
538 * Fixed some bugs in the ICQ metaclient, and documented the new protocol cmds
539
540 Revision 1.344  1999/08/03 11:34:35  ajc
541 * Added client_icq.c and client_icq.h
542
543 Revision 1.343  1999/08/03 03:14:51  ajc
544 * Wrote the client side of the ICQ gateway.  Now on to other projects.  :)
545
546 Revision 1.342  1999/08/03 01:52:06  ajc
547 * Redesigned the client protocol commands for dealing with ICQ
548 * Implemented page function priority ordering to prevent pages from being
549   simultaneously delivered over multiple IM systems
550 * Migrated serv_icq.* into the Makefile
551
552 Revision 1.341  1999/08/01 21:36:30  ajc
553 * EXTREME coolness.  The server side of the ICQ metaclient is now working.
554   It is set up using ICQL and ICQA commands, it automatically logs the user
555   onto ICQ along with Citadel, and displays all non-offline ICQ contacts
556   in the Wholist.
557
558 Revision 1.340  1999/07/31 07:18:01  ajc
559 * Restructured the express message infrastructure, adding a class of function
560   hooks for the addition of multiple paging modules with message routing
561
562 Revision 1.339  1999/07/30 22:20:19  ajc
563 * Applied bugfix patches contributed by Vaggelis Tsirkas:
564   * rooms.c: buffer overrun fix
565   * room_ops.c: cmd_rdir() now behaves better when directory doesn't exist
566
567 Revision 1.338  1999/07/30 03:32:24  ajc
568 * Added strdoop(), a leak-checked version of strdup()
569 * Small fixes to new API functions in msgbase.c
570 * ICQ metaclient stores/reads config using the message base API functions
571
572 Revision 1.337  1999/07/29 03:36:37  ajc
573 * msgbase.c: reorganized.  output_message() now uses CtdlFetchMessage(),
574   cmd_msg3() now fetches directly from disk and spews to the client.
575
576 Revision 1.336  1999/07/28 04:02:37  ajc
577 * Server modules are now labelled with their RCS ID instead of a complex and
578   manually-updated data structure.
579
580 Revision 1.335  1999/07/28 03:50:24  ajc
581 * serv_expire.c: expire-by-age now calls CtdlFetchMessage() instead of
582   calling output_message() in MT_DATE mode.
583 * msgbase.c: removed MT_DATE mode ('twas a sleazy hack)
584
585 Revision 1.334  1999/07/27 22:47:26  ajc
586 * Implemented new data type "CtdlMessage" which will eventually be used as
587   widely as possible to represent a message in memory.
588 * Implemented CtdlFetchMessage() which is intended to become the back-end to
589   output_message() as well as a bunch of other things.
590
591 Revision 1.333  1999/07/27 20:00:24  ajc
592 Removed all references to CC->msglist and CC->num_msgs, and all utility
593 functions which relied upon them.  Citadel Is Now Better.
594
595 Revision 1.332  1999/07/27 19:32:22  ajc
596 Removed serv_upgrade.c and all references to it in Makefile.in
597 Reworked new-mail-count to not use MessageFromList() etc.
598
599 Revision 1.331  1999/07/25 02:59:37  ajc
600 Fixed reference count problem in cmd_move()
601
602 Revision 1.330  1999/07/24 22:50:38  ajc
603 Continued replacing references to [get|put]_msglist() with better code.
604 For some reason, cmd_msgs() still doesn't always work right.
605
606 Revision 1.329  1999/07/24 22:16:41  ajc
607 Experimenting with automatic updating of ChangeLog by CVS.  Simply twiddle
608 ChangeLog a bit (i.e. by adding or removing a newline from the end of the
609 file) before issusing "cvs commit", and the comments recorded by CVS will
610 automatically appear at the beginning of ChangeLog.
611
612 Revision 1.328  1999/07/24 22:14:21  ajc
613 cmd_move() now uses CtdlDeleteMessages().
614 WARNING: build is temporarily broken.  Currently removing all references
615 to the "msglist" kept in CitContext.  It's ugly and must die.
616
617 Thu Jul 22 22:26:50 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
618         * Moved message deletion into new API function CtdlDeleteMessages()
619         * Added CtdlWriteObject() to store generic data in the msgbase
620         * Fixed really dumb error that prevented network msgs from posting
621
622 Tue Jul 20 22:14:54 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
623         * Moved the actual work done in cmd_msgs() into a new API function
624           called CtdlForEachMessage() which is supplied a callback function.
625
626 Mon Jul 19 23:24:18 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
627         * Keep the (unqualified) content-type in the SuppMsgInfo record.  We'll
628           be using this shortly to search rooms for specific object types.
629
630 Sun Jul 18 14:53:16 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us> 
631         * Changes to dynloader et al to handle ICQ module being written
632         * serv_icq.c, serv_icq.mk: added (separate makefile is temporary)
633
634 1999-07-17 Nathan Bryant <bryant@cs.usm.maine.edu>
635         * chkpwd.c: DELETED CVS REVISION 1.3 (backed out Art's last change)
636           use 'cvs update -r 1.2 chkpwd.c; cvs update -A chkpwd.c' NOW to
637           avoid problems with working directories.
638         * Makefile.in: don't install chkpwd setuid if make install isn't
639           being run as root.
640         * citadel.spec: chmod u+s chkpwd during %install stage
641
642 Fri Jul 16 18:39:04 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
643         * PEXP and GEXP no longer trip the idle time display
644         * Fixed bug which duplicated incoming private mail to Trashcan
645         * Improved auto-reconnect by NOT using SIGPIPE and longjmp(); also
646           implemented a 15 second delay to wait for a crashed server to restart
647         * Relaxed the security check in chkpwd.c a bit; it was just flat-out
648           preventing logins on my system otherwise
649
650 Thu Jul 15 22:57:32 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
651         * eliminate redundant "name" parameter in [l]putuser(), now uses
652           usbuf->fullname to guarantee the correct name for the index
653
654 1999-07-12 Nathan Bryant <bryant@cs.usm.maine.edu>
655         * Makefile.in, configure.in: link netproc with gdbm
656         * netproc.c: only include gdbm.h if HAVE_GDBM_H
657         * user_ops.c: warning fix
658
659 Mon Jul 12 19:51:30 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
660         * Mail is now saved in both sender and recipient mailboxes.  This is
661           structured in a way that will allow a separate "outbox" room and/or
662           multiple recipients in the future.
663
664 Sun Jul 11 18:46:48 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
665         * netproc.c: msgfind() no longer uses the timestamp as a message-ID
666           when no other message-ID is available (it screws up the loopzapper)
667         * room_ops.c: eliminate room name parameter in putroom() and its ilk;
668           get data from quickroom.QRname instead; prevents incorrect indexes
669         * Tentative implementation of "personal rooms" (user-private namespace)
670         * Added supplementary message info records for info that may change
671           at some time later than when the message is saved (i.e. ref counts)
672         * Implemented msg reference count increment/decrement; delete messages
673           whose reference count reaches zero
674
675 Wed Jul  7 23:25:09 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
676         * control.c: create citadel.control if it doesn't exist (yikes!)
677         * serv_expire.c: purge mailbox rooms belonging to non-existent users
678         * user_ops.c: don't delete user's mailbox at user-delete time
679
680 Mon Jul  5 17:01:29 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
681         * utilsmenu: removed menu items for defunct utilities
682
683 Mon Jun 28 16:24:10 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
684         * Changed any remaining references to UUCP, to "Internet" instead.
685
686 Thu Jun 24 11:13:23 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
687         * added server command line option "-f" to defrag databases on startup
688         * control.c: better performance and reliability in [get|put]_control()
689         * netproc.c: Finished the loopzapper
690
691 Mon Jun 21 00:04:15 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
692         * netproc.c: started writing a vortex checker.  Not finished.
693
694 Wed Jun  9 23:34:25 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
695         * Replaced all code that generated temporary filenames with calls to
696           tmpnam().  Rewrote using tmpfile() where possible.
697
698 Thu Jun  3 11:35:18 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
699         * base64.c: mapped fi and fo to stdin and stdout using
700           actual code rather than assignment at declaration time
701           (several users of Red Hat Linux 6.0 reported problems)
702
703 Fri May 21 20:05:00 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
704         * Added function CtdlGetDynamicSymbol() for dynamic symbol allocation
705         * server.h: Changed discrete #define's to enum's where appropriate
706         * sysdep.c: Changed the startup message to give credit to the whole
707           development team :)  Also made the message more GNU-ish.
708
709 Thu May 20 20:01:30 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
710         * database.c: print log messages for file defragmentations
711         * citserver.c: implemented CtdlAllocUserData() and CtdlGetUserData()
712           for arbitrary per-session data storage (by modules etc.) without
713           having to add fields to struct CitContext
714         * msgbase.c: removed "desired_section" from struct CitContext and
715           implemented it using CtdlGetUserData() as a test.
716
717 Wed May 19 19:30:28 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
718         * commands.c, commands.h, routines.c: began color scheme changes
719
720 1999-05-15 Nathan Bryant <bryant@cs.usm.maine.edu>
721         * configure.in: Added untested support for BSDI 4.x.
722
723 1999-05-13 Nathan Bryant <bryant@cs.usm.maine.edu>
724         * acconfig.h, configure.in, routines.c: fix for certain SYSV variants
725           which lack utmp.ut_host
726         * citadel.h, file_ops.c, msgbase.c, netproc.c, serv_chat.c: fix
727           namespace collision with <sys/stream.h> on aforementioned SYSV
728           variant
729         * configure.in, getutline.c: check for paths.h
730         * configure.in, Makefile.in: check for -lsocket and -lnsl
731
732 1999-05-11 Nathan Bryant <bryant@cs.usm.maine.edu>
733         * chkpwd.c: fixed excessive paranoia; it used to refuse to run when
734           invoked by root and BBSUID != 0
735         * Makefile.in: ignore errors while installing /etc/pam.d/citadel
736
737 1999-04-27 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
738         * file_ops.c: fixed NDOP to not crash the server if it has trouble
739           with a download file
740         * netpoll.c: upped default packet size
741
742 Mon Apr 26 22:06:57 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
743         * Repaired IGnorant security hole blunder re. citmail
744
745 Sun Apr 25 12:44:08 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
746         * serv_chat.c: notify user of number of participants upon entering chat
747         * Built the 5.53 distribution
748
749 Wed Apr 21 22:23:13 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
750         * aidepost.c: add -r flag to allow posting to rooms other than Aide>
751         * serv_expire.c: now posts transcripts of all auto-purged rooms/users
752
753 Tue Apr 20 12:45:55 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
754         * messages.c: downloading more than MAX_MSGS messages now truncates
755           (off the beginning of the list) rather than crashing.
756
757 Mon Apr 19 12:11:48 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
758         * whobbs.c: auto-detect when being called from a webserver, and act
759           as a CGI (print HTTP headers and HTML output)
760
761 1999-04-18 Nathan Bryant <bryant@cs.usm.maine.edu>
762         * serv_chat.c: fixed some potential buffer overruns (thanks dme)
763
764 Wed Apr 14 21:32:28 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
765         * Makefile.in: chmod 4755 citmail to prevent citmail from aborting
766           when called from sendmail due to citadel.config security check
767
768 1999-04-13 Nathan Bryant <bryant@cs.usm.maine.edu>
769         * dynloader.c: OpenBSD places underscores in front of symbol names
770         * Makefile.in: fixed a few sillies
771         * aidepost.c, citmail.c, file_ops.c, logging.c, msgbase.c, netmailer.c,
772           netproc.c, rcit.c, routines.c, serv_upgrade.c: fixed time_t handling
773           (have to cast it to long for printf/scanf)
774
775 Mon Apr 12 22:13:26 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
776         * aidepost.c: rewrote to unlink temp file before writing to it so that
777           it will automatically go away if interrupted. Also ran indent -kr -i8
778
779 1999-04-12 Nathan Bryant <bryant@cs.usm.maine.edu>
780         * configure.in, Makefile.in: taught it how to generate OpenBSD shared
781           libraries
782         * config.c, sysdep.c: fix -h option not setting proper modules dir
783         * configure.in, citadel.spec: make --enable-chkpwd the default
784         * setup.c: don't chown chkpwd
785
786 1999-04-11 Nathan Bryant <bryant@cs.usm.maine.edu>
787         * configure.in: another OpenBSD fix, but we're still not quite there yet
788         * serv_chat.c: warning fix
789
790 Thu Apr  8 22:51:28 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
791         * config.c: now requires a setup run for *any* rev level difference
792         * Updated docs & confs for 5.53b1 release
793         * setup.c: sets the 0600 permission bits on citadel.config that
794           is checked for in config.c
795
796 1999-04-08 Nathan Bryant <bryant@cs.usm.maine.edu>
797         * citserver.c: improved is_public_client(), also if a public_client
798           only supplies a numeric address, attempt to resolve it
799         * locate_host.c: verify that the forward DNS matches the reverse
800         * locate_host.c, locate_host.h: more general interface
801         * configure.in, acconfig.h: fixes for Digital UNIX
802
803 Wed Apr  7 21:36:16 EDT 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
804         * Implemented "access level required to create rooms" (client & server)
805
806 1999-04-07 Nathan Bryant <bryant@cs.usm.maine.edu>
807         * configure.in: updated help messages, OpenBSD support
808         * setup.c: if /etc/inittab doesn't exist, don't ask to create an
809           entry in it
810         * server.h, sysdep.c: fix a potential deadlock/data corruption bug
811         * room_ops.c: fixed the 'gdbm error: Illegal data' message when
812           deleting a room which had never been posted to
813         * user_ops.c: include errno.h
814         * dynloader.c: fix for OpenBSD
815
816 1999-04-06 Nathan Bryant <bryant@cs.usm.maine.edu>
817         * Makefile.in, configure.in, getutline.c, sysdep.c:
818           fixes/bug workarounds for FreeBSD
819
820 1999-04-03 Nathan Bryant <bryant@cs.usm.maine.edu>
821         * Makefile.in, configure.in, chkpwd.c, acconfig.h: support for
822           `chkpwd', a setuid helper program for machines which use shadow
823           passwords (configure --enable-chkpwd)
824         * Makefile.in, configure.in, auth.c, citadel.pam, user_ops.c: support
825           for PAM or shadow passwords (configure --with-pam)
826         * Makefile.in: made some messages simpler
827         * citadel.spec: updated for 5.53; correct name of tarball; build with
828           --enable-chkpwd and --with-pam; add defattr tags so rpm's can be
829           built by non-root user
830         * commands.c: cosmetic cleanup
831         * config.c: (security/paranoia) check permissions on citadel.config
832         * configure.in: check for ncurses if we can't find curses
833         * dynloader.c: warning fix
834         * sysdep.c: don't complain if initgroups() fails
835         * citadel.c: fix systems with SYSV-style signal handling (e.g. libc5)
836         * Makefile.in: New! Improved! Cleaner! Shinier!
837
838 Sun Mar 21 14:21:47 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
839         * messages.c: cosmetic cleanups to message reading loop
840
841 Sat Mar 13 21:33:19 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
842         * commands.c: use bright colors by default in color mode
843         * citserver.c: initialize wholist fields with (not logged in) etc.
844
845 1999-03-08 Nathan Bryant <bryant@cs.usm.maine.edu>
846         * sysdep.c: call DLoader_Init() with an absolute path so that gdb can
847           find module symbols
848         * database.c: bail out if opening databases fails
849
850 Sat Mar  6 01:55:55 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
851         * serv_chat.c: use memfmout(), *not* cprintf() to transmit express
852           messages.  Calling cprintf() on strings >256 bytes crashes the server
853         * msgbase.c: minor logging fix in save_message()
854
855 1999-03-05 Nathan Bryant <bryant@cs.usm.maine.edu>
856         * sysdep.c: add undocumented -r flag to citserver to prevent it from
857           dropping root permissions.
858         * sysdep.c: also drop supplementary groups
859
860 1999-03-04 Nathan Bryant <bryant@cs.usm.maine.edu>
861         * config.c: error checking in put_config()
862         * setup.c: chgrp files to the login group associated with BBSUID
863         * sysdep.c: copyright 1987-1999; drop root perms; load modules and call
864           master_startup() after dropping perms
865
866 Wed Mar  3 00:00:55 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
867         * Prevent buffer overruns in lowercase_name in [get|put]user()
868         * client_chat.c: use citedit() for page composition
869
870 Sat Feb 27 07:47:36 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
871         * rooms.c: download_to_local_disk() prompts for a filename if a blank
872           filename was supplied to it (for attachments without names)
873         * mime_parser.c: strip leading whitespace in content_type & disposition
874
875 1999-02-24 Nathan Bryant <bryant@cs.usm.maine.edu>
876         * configure.in: improved check for pthreads
877         * configure.in, routines.c, acconfig.h: check for ut_type in struct utmp
878         * configure.in, Makefile.in: support for building server modules as
879           relocatable objects for BSDI (which still uses a.out *gag* *choke*)
880         * configure.in: compiler choice & flags for BSDI; check for libtermcap
881         * database.c: don't use a critical section in open_databases()
882         * housekeeping.c: use getfloor()/putfloor() instead of
883           lgetfloor()/lputfloor() in check_ref_counts()
884         * mime_parser.c: include <errno.h>
885         * msgbase.c: include <limits.h>
886         * sysdep.c: hacks for BSDI. use signals to fake thread cancellation;
887           don't call master_cleanup() directly from signal handler.
888         * routines.c: prototype getutline() if necessary
889         * getutline.c: stupid bugfix
890         * acconfig.h, configure.in, locate_host.c, server.h: work around
891           nonreentrant gethostbyaddr() on BSDI
892
893 Mon Feb 15 22:59:00 EST 1999 Vaggelis Tsirkas
894         * citadel.c: increased hostname buffer size to handle very big names
895
896 1999-02-15 Nathan Bryant <bryant@cs.usm.maine.edu>
897         * sysdep.c(main): initialize alen before call to accept()
898
899 1999-02-04 Nathan Bryant <bryant@cs.usm.maine.edu>
900         * configure.in: improved check for cygwin
901         * configure.in, routines.c: access utmp directly instead of calling
902           `who' if getutline() is available.
903         * configure.in, Makefile.in, getutline.c: replace getutline() on
904           systems which don't have it
905         * routines.c: now always access utmp directly unless we can't find
906           utmp.h
907
908 1999-02-02 Nathan Bryant <bryant@cs.usm.maine.edu>
909         * Fixes for Cygwin:
910           - ifdef out file download methods that require named pipes (client)
911           - include pthread.h and gdbm.h only if they are present (fixes
912             auto dependency generation)
913           - include snprintf.h where needed
914           - handle .exe suffixes for "make install"
915
916 Tue Feb  2 22:15:08 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
917         * Overhauled the express messaging system (again)
918
919 Mon Feb  1 19:48:04 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
920         * messages.c: implemented client download of MIME attachments
921
922 Sun Jan 31 18:29:18 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
923         * Added qpdecode.c to the distribution (decodes quoted-printable)
924         * Finished the MIME parser
925         * Gave MSG0 a reasonable behaviour for MIME messages
926         * Added the OPNA command for downloading attachments
927
928 Sat Jan 30 18:39:53 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
929         * Look for citadel.rc in current directory if not found elsewhere
930         * More work on the MIME parser
931         * Added base64.c to the distribution
932
933 1999-01-29 Nathan Bryant <bryant@cs.usm.maine.edu>
934         * fixes for IRIX (thanks to wr and family for use of the Indy):
935           - use memset()/memcpy() instead of bzero()/bcopy() in all cases
936           - configure updates
937           - handle `long' pid's
938           - a few other little bits
939
940 Mon Jan 25 21:23:07 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
941         * Fixed bug in save_message() which crashed the server on mail to sysop
942         * Rewrote pop_march() to be smarter about <G>oto heuristics
943
944 Sat Jan 23 14:32:19 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
945         * Changed internal storage of express messages from a linked list to
946           a single, resizable buffer.
947         * Added a "room order" key to the room record, to allow some control
948           over room listing order.
949         * Made the room list commands aware of the room order key.
950         * Overhauled <G>oto heuristics to pay attention to floor & room order
951
952 Wed Jan 20 19:21:51 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
953         * Added some more code to the unfinished MIME parser
954         * Changed module loading path to simply "modules" because after calling
955           get_config(), the cwd is guaranteed to be the correct BBS directory.
956
957 Tue Jan 19 21:28:29 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
958         * Fixed a bug in the user editing command (client side)
959         * Started a rewrite of the MIME parser
960
961 Thu Jan 14 21:21:15 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
962         * Brought over the mime_parser from WebCit and began preliminary work
963           on supporting MIME format messages.
964
965 Tue Jan 12 22:30:00 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
966         * Various changes to begin work on support for MIME messages
967                 - Defined format type 4 for MIME
968                 - msgbase.c: *temporary* hacks in output_message() for Type 4
969                 - citmail.c: added more robust header parsing, and support
970                              for Type 4.  Also eliminated the crappy built-in
971                              SMTP server.
972                 - Updated some of the technical documentation
973
974 Sun Jan 10 13:34:36 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
975         * Fixed access to page log room
976
977 Fri Jan  8 12:35:09 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
978         * control.c: include <limits.h> to fix PATH_MAX undefined
979         * serv_chat.c: made the following changes to cmd_sexp() --
980                 * Send zero-length message to check only, don't send
981                 * Send "-" message on the command line to invoke
982                   the SEND_LISTING transfer mode for a multi-line message
983         * Added facilities to log all pages to a room (site configurable)
984
985 Tue Jan  5 23:24:52 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
986         * Replaced all occurances of malloc(), realloc(), and free() in the
987           server and server-modules with mallok(), reallok(), and phree().
988           Wrote macros and a set of leak-tracking functions.
989
990 Sun Jan  3 20:38:45 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
991         * Documentation changes
992
993 Fri Jan  1 01:01:45 EST 1999 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
994         * Fixed security problem relating to private rooms
995
996 Wed Dec 30 20:10:52 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
997         * sysdep.c: put a bigger string buffer into lprintf() to avoid overruns
998
999 Sat Dec 26 16:56:46 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1000         * internetmail.config: commented this file more clearly
1001
1002 Wed Dec 23 20:42:49 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1003         * citadel.c: added some experimental code to automatically reconnect
1004           to the server if the connection is broken.  For some reason, it only
1005           works once.
1006
1007 Wed Dec 23 18:47:12 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1008         * sysdep.c: ignore SIGPIPE.  This keeps broken connections from
1009           crashing the whole server.
1010         * Tagged everything for the official 5.50 release.
1011
1012 Mon Dec 21 07:54:20 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1013         * housekeeping.c: call kill_session() with session_to_kill,
1014           not ccptr->cs_pid (was crashing the server)
1015
1016 Sat Dec 19 13:57:48 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1017         * Added "-i" flag to netproc to make it skip the export phase.
1018           Updated other programs to call netproc in this way when appropriate.
1019         * Updated network.txt to reflect the usage for netproc (which has
1020           been wrong for several releases)
1021
1022 Thu Dec 17 00:17:04 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1023         * Started removing the word "beta" from the docs and code.
1024           Preparing for an actual release.
1025         * msgbase.c: generate an 'I' field when requested (i.e. on locally
1026           originating messages.  this was breaking parts of the network)
1027
1028 1998-12-15 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1029         * msgbase.c: remove extra call to alias() which was causing
1030           Citadel-to-Citadel mail to fall into the bit bucket.
1031         * msgbase.c: fixed tempfile naming problem that could cause a new
1032           outgoing netmail message to overwrite another if netproc had not been
1033           run in between
1034
1035 1998-12-14 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1036         * More session table stability nonsense
1037
1038 Sun Dec 13 17:40:08 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1039         * sysdep.c, citserver.c: (hopefully) fixed a session table concurrency
1040           bug which was causing the server to occasionally crash.
1041         * removed serv_test.so from the default build
1042
1043 Fri Dec 11 18:50:00 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1044         * setup.c: default value for maxsessions is now 0 (no limit)
1045         * room_ops.c: don't allow users to create a room called "Mail"
1046         * serv_expire.c: fixed "number of messages purged" display
1047         * commands.c: when using color, default to low-intensity colors
1048
1049 Tue Dec  8 07:58:16 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1050         * Beta 2
1051
1052 Sat Dec  5 01:24:03 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1053         * Added a new type of module hook for adding logging functions
1054         * Removed whitespace to left and right of '@' in netmail recipients
1055         * sysdep.c: read citadel.config _before_ initializing loadable modules
1056         * stats.c: fixed segfault resulting from extracting log lines
1057         * Ripped most of the "attachments" stuff out of both the client and
1058           server.  (Thought of a better way to handle it ... LATER.)
1059
1060 1998-12-03 Nathan Bryant <bryant@cs.usm.maine.edu>
1061         * setup.c: create citadel.config with mode 0600
1062         * Makefile.in: don't chmod sendcommand
1063         * serv_upgrade.c: don't create citadel.config if it doesn't already
1064           exist (paranoia)
1065         * setup.c: saner defaults for nodename and fqdn
1066
1067 Wed Dec  2 20:37:05 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1068         * msgbase.c: modified AddMessageToRoom() and all functions that call it
1069           to use a more reliable/accurate method to set quickroom.QRhighest
1070         * weekly.in: don't sort/purge filedir where filedir doesn't exist
1071
1072 1998-12-02 Nathan Bryant <bryant@cs.usm.maine.edu>
1073         * weekly is now generated by configure
1074
1075 Mon Nov 30 19:48:52 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1076         * room_ops.c: added sort_msglist() to move and save operations
1077         * sendcommand.c: added (also updated utils.txt, weekly, Makefile.in)
1078         * BETA 1
1079
1080 Sun Nov 29 23:57:39 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1081         * Fixed cmd_regi() to not display a second result code after xfer
1082         * Makefile.in: Removed "chmod 4755 citmail netmailer"
1083
1084 1998-11-23 Nathan Bryant <bryant@cs.usm.maine.edu>
1085         * citadel.spec: added
1086
1087 1998-11-22 Nathan Bryant <bryant@cs.usm.maine.edu>
1088         * Makefile.in: split install target into install-exec, install-data,
1089           and install-doc subtargets
1090
1091 Sat Nov 21 16:53:30 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1092         * Added a fourth color mode in the client: "user" which turns color
1093           on or off according to a per-user flag stored on the server.  Added
1094           server-side support for this too, of course.
1095         * import.c: removed
1096         * serv_expire.c: finished the code to purge stale visits
1097         * sysdep.c: strip trailing nonprintables in client_gets()
1098         * routines2.c: fixed <.AS> command; all configs now work properly
1099         * Moved num_parms() and all the extract() type functions into tools.c
1100           and removed them from all other files.  Linked in tools.[o|ro] there.
1101         * netproc.c: handled incoming file transfers to correct room directory
1102         * room_ops.c: fixed incorrect naming of files in info and images dirs
1103
1104 Fri Nov 20 20:29:07 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1105         * setup.c: removed all prompts that can be configured from within the
1106           client in order to simplify the setup procedure
1107
1108 Thu Nov 19 23:28:33 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1109         * Fixed serv_upgrade.c and export5.c (found elsewhere) to use a new
1110           export format which treats visits as a separate section
1111         * serv_expire.c: began writing functions to purge rooms and visits
1112           (neither work yet), and added a way to call defrag_databases()
1113
1114 Wed Nov 18 23:51:17 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1115         * Reimplemented 'visit' structs stored globally instead of as
1116           lists-per-user
1117
1118 Tue Nov 17 22:37:48 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1119         * Started implementing global room numbers.
1120
1121 Sun Nov 15 20:32:34 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1122         * room_ops.c: mailbox rooms always appear on the main floor
1123         * made QR_MAILBOX rooms non-editable
1124         * cmd_setr() delete old room record when room name changes
1125           (This causes a big mess that exposes a flaw in the whole design.)
1126         * room_ops.c: users can delete messages from their mailboxes
1127
1128 Thu Nov 12 23:59:13 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1129         * Rewrote cmd_rchg() and also increased the size of the "fakename"
1130           buffer.  Overruns are probably what was causing the crashes.
1131         * Changed the way cmd_ent3() handles mail messages; the previous code
1132           rerouted all private mail to the trash.
1133
1134 Wed Nov 11 17:57:39 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1135         * citserver.c: slight changes to cmd_rchg() and cmd_hchg() [crashes]
1136         * citserver.c, msgbase.c, user_ops.c: hide the owner-prefix of mail
1137           rooms in a couple more places: set_wtmpsupp() and make_message()
1138         * sysdep.c: added an fflush() to lprintf() for "tail -f"-able logs
1139         * serv_expire.c: purge ops are now a command instead of a cleanup
1140           function.  This is probably temporary as well.
1141         * citadel.c: fixed the way <.WL> parses the returned data from a
1142           TIME command.
1143
1144 1998-11-11 Nathan Bryant <bryant@cs.usm.maine.edu>
1145         * serv_upgrade.c: fix uninitialized variable
1146
1147 Wed Nov 11 00:47:32 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1148         * msgbase.c: fixed a bug that was misrouting incoming network msgs
1149         * server.h, database.c: wrapped all GDBM calls in critical sections
1150           to avoid making those calls re-entrantly (gdbm fatal: lseek error)
1151
1152 1998-11-10 Nathan Bryant <bryant@cs.usm.maine.edu>
1153         * Makefile.in: link in snprintf.o where needed
1154
1155 1998-11-09 Nathan Bryant <bryant@cs.usm.maine.edu>
1156         * client_chat.c: eliminate calls to sprintf()
1157         * commands.h, routines.c, routines2.c: warning fix
1158         * commands.c, control.c, cux2ascii.c, file_ops.c, import.c,
1159           ipc_c_tcp.c: eliminate sprintf() calls
1160
1161 Mon Nov  9 19:15:31 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1162         * serv_upgrade.c: added all missing fields to export/import
1163         * serv_expire.c: support per-user purge time when purging users
1164         * user_ops.c: added per-user purge time to AGUP and ASUP commands
1165         * routines.c: added more stuff to <.A>ide <E>dit user
1166
1167 Sun Nov  8 22:56:53 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1168         * serv_expire.c: created; moved message expiry from serv_test.c,
1169           moved user purge from userpurge.c
1170         * userpurge.c: deleted
1171         * routines2.c: finished <.AS> command
1172         * room_ops.c: fixed Aide room access (for some reason, the Aide
1173           room had the QR_MAILBOX flag set)
1174
1175 1998-11-08 Nathan Bryant <bryant@cs.usm.maine.edu>
1176         * useradmin.c: really removed (cvs remove)
1177         * aidepost.c, citadel.c: convert all sprintf() calls to snprintf()
1178         * sysdep.c: fix overrun in lprintf() described by dme/Dead Monkey
1179         * citmail.c, citserver.c: convert all sprintf() call to snprintf()
1180
1181 Sun Nov  8 13:19:36 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1182         * useradmin.c: removed
1183         * utils.doc: removed references to useradmin and sysoputil
1184
1185 Fri Nov  6 20:22:20 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1186         * citadel.h (and related files): removed defunct parameters,
1187           c_defent and c_msgbase (erase your test bbs)
1188         * Implemented CONF server command for site-global configs
1189         * Shuffled yesno() and yesno_d() from routines.c to commands.c
1190         * commands.c: implemented boolprompt()
1191         * routines2.c: started adding CONF questions to <.AS> command
1192         * room_ops.c: began a fix for the mysterious disappearing Aide room
1193
1194 1998-11-05 Nathan Bryant <bryant@cs.usm.maine.edu>
1195         * snprintf.c: warning fix propagated over from gcit
1196
1197 1998-11-04 Nathan Bryant <bryant@cs.usm.maine.edu>
1198         * added RCS Id keyword strings to sources
1199         * citmail.c: reverted to version 1.10
1200
1201 Wed Nov  4 10:53:13 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1202         * messages.c: temporarily set screenwidth to a fixed value of 80
1203           during <P>rint operations.
1204
1205 Mon Nov  2 12:59:03 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1206         * setup.c: looks for 'citadel', 'bbs', or 'guest' in /etc/passwd to
1207           try to get a default for bbsuid if it's currently set to 0
1208         * citmail.c: changed usersupp.eternal to usersupp.usernum (why didn't
1209           it complain about this before?)
1210         * serv_upgrade.c: began writing an "export" command to do sidegrades
1211
1212 Sun Nov  1 18:47:42 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1213         * serv_upgrade.c: cosmetic changes
1214         * Implemented message expiry by date (this really needs to be moved
1215           out of serv_test.c, but where does it belong?)
1216
1217 1998-11-01 Nathan Bryant <bryant@cs.usm.maine.edu>
1218         * serv_upgrade.c: warning fixes
1219         * acconfig.h: remove ANSI_COLOR
1220         * Configure, Makefile.tmpl: removed
1221
1222 Sat Oct 31 20:48:44 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1223         * More stoopid ANSI colour additions here and there.
1224         * ANSI colour selection is now in citadel.rc instead of an option in
1225           the configure script.  "on" "off" and "auto" are available.
1226         * added "build.txt" to the techdoc directory, with LS's build notes
1227
1228 1998-10-31 Nathan Bryant <bryant@cs.usm.maine.edu>
1229         * citadel.c, commands.c, commands.h: set background color to black
1230           before clearing screen, so that we can actually see text on
1231           black-on-white xterms.
1232
1233 1998-10-29 Nathan Bryant <bryant@cs.usm.maine.edu>
1234         * rooms.c: fix color of Mail>
1235         * citadel.c: send ANSI detect sequence after attach_to_server() so the
1236           terminal doesn't send the answerback sequence to the shell if we
1237           can't connect.
1238
1239 Wed Oct 28 20:20:14 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us
1240         * citadel.c: Added a splash of colour to the Wholist
1241
1242 1998-10-28 Nathan Bryant <bryant@cs.usm.maine.edu>
1243         * configure.in: added comments
1244         * mkinstalldirs: new file to be used for `make install'
1245         * aclocal.m4, missing: new files, also swiped from automake
1246         * citadel.c: don't mung the terminal if we can't find citadel.rc
1247         * Makefile.in: added `install' target, `clean' removes
1248           *.mo, rebuild configure when configure.in changes.
1249         * configure.in: check for install and autoconf
1250         * configure.in, Makefile.in: only pass -fPIC to gcc
1251         * policy.c: warning fix for OSF/1 (use memset() instead of bzero())
1252
1253 Tue Oct 27 22:25:42 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1254         * Unified the "unpacked database" format for both upgrades and
1255           sidegrades (also see export5.c elsewhere)
1256         * citserver.c: clear out cmdbuf before reading a command; some server
1257           commands were accidentally extracting parameters from previous cmds
1258         * rooms.c: removed the warning about the ineffectiveness of kicking
1259           users out of public rooms, because the new server can do lockouts
1260
1261 1998-10-27 Nathan Bryant <bryant@cs.usm.maine.edu>
1262         * sysdep.c (client_gets), ipc_c_tcp.c (serv_gets): improved handling
1263           of long lines. 
1264         * Makefile.in: partial support for VPATH builds, autodependency fix
1265
1266 Tue Oct 27 00:08:16 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1267         * minor documentation changes
1268
1269 Sun Oct 25 14:57:40 EST 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1270         * messages.c: fixed an oversight that was allowing attachments even
1271           when disabled in citadel.rc
1272
1273 1998-10-25 Nathan Bryant <bryant@cs.usm.maine.edu>
1274         * routines2.c: warning fix
1275
1276 Sat Oct 24 22:07:56 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1277         * Client: added message expiration policy questions to room edit
1278         * Client: added <.A>ide <S>ystem configuration command
1279
1280 1998-10-24 Nathan Bryant <bryant@cs.usm.maine.edu>
1281         * Makefile.in: Auto dependency generation (may require GNU make, but
1282           does at least function without this feature on OSF/1 make);
1283           Makefile is regenerated when Makefile.in changes (ditto);
1284           `realclean' is now known as `distclean';
1285           portability fixes for older Unix make utilities
1286         * citadel.c, citadel.h, commands.c: make client suspendable
1287
1288 Fri Oct 23 19:34:38 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1289         * setup.c: default node name is now obtained from uname()
1290         * config.c: added put_config()
1291         * policy.c: added, moved GetExpirePolicy() from room_ops.c
1292         * policy.c: implemented cmd_gpex() and cmd_spex()
1293
1294 Wed Oct 21 22:24:48 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1295         * Mail rooms now hide their owner-prefix from the client.
1296         * proxy.c: added configurability and primitive message expiry
1297
1298 1998-10-20 Nathan Bryant <bryant@cs.usm.maine.edu>
1299         * Makefile.tmpl: fix to build client with old Configure script
1300         * configure.in: autologin defaults to enabled if crypt() is available
1301         * room_ops.c: fix improper null-termination bug I introduced
1302
1303 Mon Oct 19 20:52:55 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1304         * Client ability to force display of prompts in Mail rooms, even when
1305           the user has prompting turned off (citadel.rc option)
1306
1307 1998-10-16 Nathan Bryant <bryant@cs.usm.maine.edu>
1308         * sysdep.c (cprintf): generate a newline on truncated buffer
1309         * room_ops.c: exploitable overrun fixes
1310
1311 Thu Oct 15 19:27:32 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1312         * msgbase.c: reimplemented cmd_move()
1313           room_ops.c: wrote AddMessageToRoom() which is used for both entering
1314           and moving messages.
1315         * setup.c: system-default message expire policy of "number of
1316           messages, 150" is now a default configuration instead of a temp hack
1317         * proxy.c: cache dir create now dies on any error except EEXIST
1318
1319 Wed Oct 14 22:41:16 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1320         * Misc code cleanup
1321
1322 1998-10-13 Nathan Bryant <bryant@cs.usm.maine.edu>
1323         * configure.in: don't check for -lcrypt unless autologin is enabled
1324         * file_ops.c: fix another overrun
1325
1326 Mon Oct 12 15:27:21 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1327         * Killed the "rooms" subdirectory (it isn't used anymore)
1328         * dynloader.c: Made dynamically added server commands case-insensitive
1329         * import.c is now serv_upgrade.c, a module
1330         * Removed most of the "level 9" trace messages no longer needed
1331
1332 1998-10-12 Nathan Bryant <bryant@cs.usm.maine.edu>
1333         * Makefile.in: simplified to use pattern rules; files compiled with
1334           -D_REENTRANT go to *.ro to allow the same files to be used with both
1335           client and server
1336         * tools.c, tools.h: new files; misc routines used by both client and
1337           server go here. contains safestrncpy() at the moment.
1338         * rooms.c: fix several exploitable buffer overruns
1339         * sysdep.c: fix infinite loop when long lines are received from the
1340           client; fix exploitable buffer overrun in cprintf()
1341         * ipc_c_tcp.c: fix infinite loop on long line from server
1342         * serv_upgrade.sh: remove uncnsrd-dependent absolute path
1343         * .cvsignore: add *.ro
1344
1345 Sun Oct 11 23:17:48 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1346         * Built some more of the message expiry infrastructure
1347
1348 1998-10-11 Nathan Bryant <bryant@cs.usm.maine.edu>
1349         * citserver.c: fix two more overruns, one of which was preventing
1350           the "From Host" from showing up in the <W>ho listing.
1351
1352 Sun Oct 11 02:51:55 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1353         * Moved "struct visit" and its associated defs from citadel.h to
1354           server.h where they belong
1355         * Set up data structures for room policies (expiry, etc.)
1356
1357 1998-10-10 Nathan Bryant <bryant@cs.usm.maine.edu>
1358         * citserver.c: fix overrun which caused segv's on servers with long
1359           hostnames.
1360
1361 Fri Oct  9 18:34:06 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1362         * user_ops.c: added PurgeStaleRelationships() to do processing at
1363           session logout time to remove visits for rooms which no longer exist
1364         * user_ops.c: implemented NewMailCount()
1365
1366 1998-10-09 Nathan Bryant <bryant@cs.usm.maine.edu>
1367         * serv_chat.c: fix buffer overrun that was resulting in segv's
1368         * serv_chat.c: fix another overrun that could cause sessions to hang,
1369           and cleaned up some other strncpy()-related stuff. DON'T FORGET TO
1370           NULL-TERMINATE DESTINATION BUFFERS AFTER STRNCPY CALLS.
1371
1372 Fri Oct  9 13:22:37 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1373         * Implemented "lazy mode" traversal - pressing the space bar will do
1374           <N>ext messsage, <G>oto next room, or read <N>ew as appropriate.
1375         * room_ops.c: modify CtdlRoomAccess() to allow access to mailbox rooms
1376           only to their owners.
1377
1378 Thu Oct  8 17:13:27 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1379         * messages.c, citadel.rc: added the ability to display message numbers
1380           in the header when reading messages.  I think this is butt ugly, but
1381           some of the DaveCode afficionados seem to like it...
1382
1383 Thu Oct  8 15:34:45 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1384         * room_ops.c: Added is_noneditable() function to replace all of the
1385           duplicated code present in all functions which edit room parameters.
1386
1387 1998-10-08 Nathan Bryant <bryant@cs.usm.maine.edu>
1388         * lots of warning fixes; builds with -std1 on dec unix
1389         * aidepost.c, citadel.h, citmail.c, file_ops.c, msgbase.c, netmailer.c,
1390           netproc.c, rcit.c, server.h, stats.c, userlist.c: use time_t where
1391           needed
1392         * control.c, room_ops.c, serv_chat.c, sysdep.c: use memset() instead of
1393           bzero()
1394         * dynloader.c, dynloader.h, messages.c, server.h, sysdep.c,
1395           sysdep_decls.h: function pointer/prototyping fixes
1396         * rooms.c: use mkfifo(3) instead of system("mkfifo")
1397
1398 1998-10-07 Nathan Bryant <bryant@cs.usm.maine.edu>
1399         * snprintf.c, snprintf.h: new files
1400         * Makefile.in, configure.in, dynloader.c, sysdep.c: support for the
1401           above; citserver now builds and runs on Digital Unix 4.0d with the
1402           GNU-style configure script. there is a bug with the hostname display
1403           in the wholist.
1404         * netproc.c: sillyness fix
1405         * room_ops.h: prototype delete_room()
1406         * client_chat.c, commands.c, serv_chat.c, sysdep.c:
1407           use HAVE_SYS_SELECT_H macro
1408
1409 Mon Oct  5 17:01:32 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1410         * Began fixing the stuff I broke
1411
1412 Sun Oct  4 23:35:18 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1413         * Did the big migration to the new data structures.  Lots of stuff is
1414           now broken.  Basic moving from room to room works, but Mail is
1415           broken, and some of the administrative commands are unimplemented.
1416
1417 1998-10-02 Nathan Bryant <bryant@cs.usm.maine.edu>
1418         * configure.in: autologin now defaults to disabled
1419
1420 Fri Oct  2 00:04:31 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1421         * Finally removed all three usersupp.foo[MAXROOMS] elements, and
1422           migrated all the code that used them to use "struct visit" instead.
1423
1424 Thu Oct  1 23:02:20 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1425         * Rewrote [l][get|put]room() functions to use room names rather than
1426           room index numbers.  Temporarily prepended a "n" to these four
1427           function names until they are put to use.
1428
1429 Thu Oct  1 16:27:13 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1430         * Removed a few more references to usersupp.lastseen[]
1431
1432 1998-10-01 Nathan Bryant <bryant@cs.usm.maine.edu>
1433         * .cvsignore: add so_locations (generated by osf1 ld with shared libs)
1434         * Makefile.in: restructured variables for greater consistency, use
1435           @echo to print out notices during the make process, add so_locations
1436           to `cleaner'
1437         * configure.in, Makefile.in: configure checks for -rdynamic
1438         * ipc_c_tcp.c: fix DEC compiler warning wrt unsigned char
1439         * stats.c: add semicolon to placate DREC compiler
1440         * user_ops.c: define _POSIX_C_SOURCE, include <limits.h>
1441         * configure.in: pass -pthread to DEC compiler, don't check for
1442           libpthread[s] on DEC Unix
1443
1444 1998-09-30 Nathan Bryant <bryant@cs.usm.maine.edu>
1445         * Makefile.in: new variable PTHREAD_DEFS for portability
1446         * aidepost.c, citadel.c, citmail.c, mailinglist.c, msgform.c,
1447           netmailer.c, netpoll.c, netproc.c, rcit.c, readlog.c, setup.c,
1448           stats.c, userlist.c, whobbs.c: return type of main() is int
1449         * citadel.c, commands.c, messages.c: use time_t properly
1450         * citserver.c: include <limits.h>
1451         * config.guess, config.sub, install-sh: new files
1452         * configure.in: don't use gcc on Digital Unix
1453
1454 Tue Sep 29 23:17:34 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1455         * room_ops.c: modified usergoto() to look at the new data structures
1456           for counting new messages and such.
1457
1458 1998-09-29 Nathan Bryant <bryant@cs.usm.maine.edu>
1459         * user_ops.c: fix compiler warning and potential memory leak,
1460           include sysdep.h
1461         * configure.in, Makefile.in: only build the server if we find pthreads
1462         * Makefile.in: realclean removes config.{cache,log,status}
1463
1464 Tue Sep 29 13:20:14 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1465         * Removed code from some of the utilities which was still attempting
1466           to access the old non-gdbm data store.
1467         * housekeeping.c: rewrote check_ref_counts() to do a ForEachRoom()
1468           traversal instead of a MAXROOMS loop.
1469         * sysdep.c: set up a dummy CitContext record to be used during server
1470           startup, during which time there is no real context.
1471
1472 Mon Sep 28 23:51:51 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1473         * Implemented the function ForEachRoom() to handle all-rooms traversal
1474           (this will work with both the old and new paradigms, because both
1475           use a GDBM database with one room per record).  Migrated all room
1476           list commands to use it.
1477
1478 Mon Sep 28 22:05:35 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1479         * Implemented the function CtdlRoomAccess() to handle *all* of the
1480           user-access-to-rooms functionality.  Migrated all room list commands
1481           to use it.  Still need to migrate gotos.
1482
1483 1998-09-28 Nathan Bryant <bryant@cs.usm.maine.edu>
1484         * configure.in, acconfig.h: new files; partially functional GNU
1485           autoconf configure script. Run autoheader; autoconf; ./configure
1486           --prefix=`pwd` to test.
1487         * Makefile.tmpl: new file; this is what Makefile.in used to be. Used by
1488           Configure.
1489         * Makefile.in: modified to work with autoconf-style configure script
1490         * Configure: modified to use Makefile.tmpl and generate autoconf-style
1491           macros. Removed procfs detection. Pass -O2 to gcc, -O to other
1492           compilers. Removed mknod/mkfifo detection; code should use mkfifo(3).
1493         * citmail.c, msgform.c, netproc.c, routines.c, support.c, userlist.c,
1494           whobbs.c: use HAVE_STRERROR macro rather than NO_STRERROR
1495         * commands.c: use HAVE_TERMIOS_H macro rather than POSIX_TERMIO
1496         * netproc.c: remove procfs stuff. simply attempt to kill the target
1497           process with signal zero instead; this checks whether the process
1498           exists.
1499         * setup.c, useradmin.c: use HAVE_CURSES_H macro
1500
1501 Sun Sep 27 23:41:29 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1502         * BOTH the old and new generation systems are being written to at
1503           this point.  Code that reads stuff is still using the old system.
1504
1505 Sun Sep 27 16:10:49 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1506         * Changed all "generation" variables from char to long, in preparation
1507           for removing MAXROOMS.  Generations for new rooms are now timestamps.
1508         * Defined "struct visit" to hold user/room relationships.
1509         * Removed some #define's from citadel.h that are no longer used.
1510
1511 Wed Sep 23 13:41:49 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1512         * More changes to support attachments.  They mostly work, but only
1513           in fixed-format messages.
1514
1515 Mon Sep 21 21:19:17 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1516         * msgbase.c: began laying the groundwork to support attachments.
1517           Purchased Rogaine(tm) in preparation for expected hair loss.
1518
1519 1998-09-21 Nathan Bryant <bryant@cs.usm.maine.edu>
1520         * msgbase.c: include dynloader.h
1521         * citadelapi.h: removed
1522         * dynloader.h: prototype CtdlRegisterUserHook()
1523
1524 Sun Sep 20 18:56:37 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1525         * Added a UserFunctionHook category to implement hooks which perform
1526           operations on various users or usernames
1527
1528 Fri Sep 18 21:14:41 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1529         * citserver.c: removed cmd_extn() and related code
1530
1531 1998-09-18 Nathan Bryant <bryant@cs.usm.maine.edu>
1532         * user_ops.c: include dynloader.h
1533         * roomstats.{c,mk}: removed
1534         * Configure, Makefile.in: autodependency-related fixes
1535
1536 Thu Sep 17 22:55:29 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1537         * Various changes to allow "new messages" to work correctly with Mail
1538
1539 Thu Sep 17 22:21:45 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1540         * server.h, dynloader.c, citserver.c, user_ops.c: reduced the number
1541           of hook types by inventing an EventType field to the Session hook.
1542         * proxy.c: added pre-fetching
1543
1544 1998-09-17 Nathan Bryant <bryant@cs.usm.maine.edu>
1545         * Makefile.in: add SERV_MODULES and PROXY_TARGETS to `cleaner'
1546         * dynloader.[ch], serv_{chat,test}.[ch], sysdep.c: cleaned
1547           up the dynamic loader interface as follows:
1548           - all the symbol table stuff is gone.
1549           - modules are loaded once at server startup and never unloaded.
1550           - Added a new function CtdlRegisterProtoHook() to handle the stuff
1551             that was being done with the symbol tables.
1552           - Dynamic_Module_Init() now returns a pointer to a static struct
1553             DLModule_Info; this structure itself has been modified to use char*
1554             fields instead of fixed char arrays.
1555         * roomstats.c: include <stdarg.h> not <stdargs.h> (is this file still
1556           in use?)
1557         * Configure, Makefile.in: added autodependency support
1558
1559 Wed Sep 16 22:25:13 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1560         * Implemented separate structs, lists, and functions for each type
1561           of server-side hook available.
1562
1563 1998-09-16 Nathan Bryant <bryant@cs.usm.maine.edu>
1564         * ipc_c_tcp.c: Fixed up some #include/prototyping stuff, call memcpy()
1565           instead of bcopy()
1566         * hooks.h: removed
1567         * sysdep.c, user_ops.c: removed reference to hooks.h
1568
1569 Wed Sep 16 11:42:42 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1570         * ipc_c_tcp.c: Reversed any changes that have been made to this file,
1571           because something was causing abominally slow response time.
1572         * proxy.c: added.  This will eventually become a caching, pre-fetching
1573           multiuser proxy server for the Citadel protocol.
1574
1575 1998-09-15 Nathan Bryant <bryant@cs.usm.maine.edu>
1576         * Makefile.in: remove support.o from serv_chat.so, add -fPIC to compile
1577           flags for serv_chat.o
1578         * dynloader.c: include "sysdep_decls.h", use RTLD_NOW not RTLD_LAZY
1579         * dynloader.h: prototype CtdlRegisterHook()
1580         * .cvsignore: added data
1581
1582 Mon Sep 14 20:49:08 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1583         * Tried my hand at adding the ability for server extensions to
1584           register various types of "hooks" in addition to just adding
1585           server commands.  This is probably not final.
1586
1587 Tue Sep  8 12:11:56 EDT 1998 Brian Costello <btx@calyx.net>
1588         * Added support for dynamic server modules.  Reworked serv_chat.c
1589           to be such a module.
1590
1591 Tue Sep  1 23:09:50 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1592         * userpurge.c: rewrote using functions from the server core, rather
1593           than the now-defunct external API.  This'll be ready once the module
1594           loading code is done.  (I just had to commit _something_ tonight.)
1595
1596 Mon Aug 31 22:47:58 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1597         * Yanked the citadelapi.c module.  This wasn't working out well.
1598         * techdocs/citadelapi.txt - began documenting the new API to be used
1599           by modules which will be dynamic linked into the server - most of
1600           this API is existing server functions.
1601         * Added a ForEachUser() function with callback mechanism, and reworked
1602           cmd_list() to use it.
1603
1604 Sun Aug 30 21:52:43 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1605         * Moved all of the gdbm databases to a separate "data" directory.
1606
1607 1998-08-26 Nathan Bryant <bryant@cs.usm.maine.edu>
1608         * Makefile.in: realclean removes Makefile, fixed `touch citadel.h'
1609           problem
1610
1611 1998-08-25 Nathan Bryant <bryant@cs.usm.maine.edu>
1612         * room_ops.c: include time.h
1613         * userlist.c, whobbs.c, serv_chat.c, user_ops.c, sysdep.c, stats.c,
1614           citadel_decls.h, commands.c, messages.h, routines.h, routines2.h:
1615           remove duplicated declarations
1616
1617 Mon Aug 24 23:45:01 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1618         * setup.c: Removed yesno_s()
1619         * citadel.h, room_ops.c: added QRmtime field to struct quickroom,
1620           modified whenever a room is modified or posted in.
1621         * citadelapi.c: Added CtdlForEachRoom() function
1622
1623 Mon Aug 24 20:04:04 EDT 1998 Nathan Bryant <bryant@cs.usm.maine.edu>
1624         * Makefile.in: new target `cleaner' does the same as `realclean' 
1625           without removing sysdep.h
1626         * proto.h: is bad. eliminate. I've moved the prototypes into several
1627           header files, one per .c file
1628
1629 Mon Aug 24 00:45:55 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1630         * Added a CtdlGotoRoom() function to the CitadelAPI.
1631  
1632 Sun Aug 23 21:47:00 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1633         * sysoputil is finally dead!  Removed it from the build.
1634         * Added userpurge.c server extension (initial implementation)
1635
1636 Tue Aug 18 00:42:33 EDT 1998 Nathan Bryant <bryant@cs.usm.maine.edu>
1637         * Makefile.in: `clean' target no longer rm's sysdep.h; new target
1638           `realclean' removes everything clean does, plus sysdep.h, plus
1639           target binaries.
1640         * Configure: add -Wstrict-prototypes to CFLAGS for gcc systems
1641         * *.[ch]: protoized. Added several new header files containing
1642           prototypes and other external declarations; many duplicated
1643           declarations still should be moved to header files. proto.h must die
1644           as well, IMHO.
1645
1646 Mon Aug 17 23:52:13 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1647         * Implemented a bunch of user account related functions in the
1648           CitadelAPI library.
1649
1650 Mon Aug 17 20:01:18 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1651         * Fixed the crash problem.  It wasn't AGUP/ASUP, but rather a buffer
1652           overrun in getuser() (thanks, Nathan).  Implemented overrun checks
1653           in getuser(), getroom(), and getfloor() to prevent future problems.
1654
1655 Mon Aug 17 00:06:52 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1656         * Updated citmail.c with the latest stuff from the production system.
1657         * Implemented AGUP and ASUP commands, but AGUP crashes the server
1658           after its first successful use (user-not-found's don't affect it).
1659
1660 Thu Aug  6 19:25:01 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1661         * Got the CitadelAPI library to the point where the server can start
1662           up an extension, and the extension will connect to the server, do
1663           some initialization, call a user-supplied CtdlMain(), and exit.  Also
1664           hacked together a _temporary_ form of the new EXTN server command.
1665  
1666 Wed Aug  5 23:02:22 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1667         * Second attempt at getting the server API started.  Now it runs
1668           outside of the server and builds a connection.
1669
1670 Tue Aug  4 18:33:06 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1671         * Modified the appearance of Internet addresses when they arrive on
1672           a Citadel system.
1673         * Removed the <E> field from the message format writeup in hack.txt.
1674         * Fixed-up citmail.c so that it doesn't try to do database lookups.
1675
1676 Mon Aug  3 23:01:37 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1677         * Started developing the server-side API.  This is in its very
1678           initial stages.  See serverapi.c and techdoc/api.txt
1679
1680 1998-08-02  Nathan Bryant  <bryant@cs.usm.maine.edu>
1681         * Makefile.in: added config_decls.h to dependencies
1682
1683 Sun Aug  2 21:09:09 EDT 1998 Nathan Bryant <bryant@cs.usm.maine.edu>
1684         * config_defs.h: renamed to config_decls.h
1685         * config.c, sysoputil.c: updated to reflect the above
1686
1687 Sun Aug  2 18:52:05 EDT 1998 Nathan Bryant <bryant@cs.usm.maine.edu>
1688         * config_defs.h: new file, contains external declarations from config.c
1689         * config.c: moved defs to config_defs.h, use PATH_MAX from <limits.h>
1690           for bbs_home_directory
1691         * mailinglist.c, support.c: include <string.h>
1692         * sysoputil.c: include <string.h>, <limits.h>, "config_defs.h", remove
1693           duplicated defs, replace gets() call with fgets()
1694         * user_ops.c: define _XOPEN_SOURCE_EXTENDED
1695
1696 Sat Aug  1 18:32:52 EDT 1998 Nathan Bryant <bryant@cs.usm.maine.edu>
1697         * ipc_c_tcp.c: fixed order of memcpy parameters after gethostbyname
1698
1699 Sun Jul 19 17:26:12 EDT 1998 Nathan Bryant <bryant@cs.usm.maine.edu>
1700         * ChangeLog: reordered; the GNU standard is to add new entries to the
1701           top.
1702         * .cvsignore: added userlist
1703
1704 Sun Jul 12 20:58:59 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1705         * Finished migrating everything to the new data store.
1706         * Replaced the binary "calllog" with the ASCII "citadel.log"
1707         * Began converting broken utilities that depend on the old data store
1708
1709 Sat Jul 11 00:20:48 EDT 1998 Nathan Bryant <bryant@cs.usm.maine.edu>
1710         * Makefile.in: removed msgstats
1711
1712 Fri Jul 10 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
1713         * Initial CVS import 
1714