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