4 - Wed Oct 3 11:07:22 PDT 2001
5 - Fix awful bug in ft listenestablish.
6 - struct aim_userinfo_s becomes aim_userinfo_t.
7 - I haven't decided what to do with this. I like it in its current
8 form to an extent, but it is also not flexible enough. But it would
9 become too complex and cumbersome if I were to do it more flexibly.
10 - Also added a few accessor functions that should be used instead of
11 directly accessing the struct, particularly for the capabilities.
13 - Wed Sep 19 18:50:34 PDT 2001
14 - Remove non-standard default features from aim_send_im_ext.
15 - Sadly, AOL 5.0 ignores messages with non-standard features. Once
16 AOL releases AOL 6 for the Macintosh, there will no longer be any
17 reason for anyone to use AOL 5, and this will be a non-issue.
18 - Check for 0x2711 TLV in buddy icons. This is weird.
19 - Add AIM_IMFLAG_ACTIVEBUDDY.
20 - Fix ICQ login. (Oops.)
22 - Tue Sep 11 16:41:11 PDT 2001
24 - Keep faimtest from passing va_list's. That scares me.
26 - Tue Sep 11 04:42:28 PDT 2001
27 - Fix faim_internal/export confusion for the TLV functions
28 - Add aim_addtlvtochain_userinfo() (used by AP)
29 - Clean up ICBM Channel 1 parsing ever so slightly
30 - Add multipart message support in both directions, and some
31 fun examples of it in faimtest.
34 - Mon Sep 10 06:15:43 PDT 2001
35 - Remove $Id line from md5.h. I really really hate those things.
36 - Remove all that locking crap. It never worked right anyway.
37 - Add conn->inside for things that should never ever be seen by clients
38 - Store supported groups list for each connection
40 - faimtest now theoretically supports doing this. It happens so rarely
41 that it makes it difficult to test. For more complicated clients, a
42 flag will have to be kept so that some things that happen during login
43 don't get triggered the second time around. But faimtest doesn't have
45 - Added some random commentary.
47 - Sun Sep 9 03:01:28 PDT 2001
48 - Three fixes in directim for gaim. It works now. Yay.
50 - Sat Sep 8 21:26:27 PDT 2001
51 - Minor bug directim_connect
53 - Sat Sep 8 20:18:34 PDT 2001
54 - Split up the ICBM Channel 2 handlers a bit more
55 - Add a stub parser for recieving buddy lists. It will stay that way until
56 someone decides on a good API for passing lists like this to the client.
57 In case someone does, the same standard will be used for setbuddylist and
58 the as yet nonexistant support for server-side buddy lists.
59 - Make infochange work again. I still don't like it, but I don't want to
62 - Sat Sep 8 19:05:05 PDT 2001
64 - Fix search by email (oops).
66 - Sat Sep 8 17:07:09 PDT 2001
67 - Fix directim so you can do it more than once without crashing.
68 - This removes the connect/disconnect callbacks. They were pointless, as
69 you can get the same information at a better spot by looking for when
70 aim_getcommand returns -1, just like is done for FLAP connections.
71 - (This was causing aim_conn_kill to be called twice for the same connect,
72 once in the client callback, and once more when aim_getcommand returned
74 - Add aim_conn_(close|kill)_rend(). This is for destroying the cookie and
75 the internal data sections in one spot.
76 - Fix a bug in aim_connrst (and hence aim_logout()) that caused intdata/priv
77 to not be freed in those cases. Evil.
79 - Sat Sep 8 07:32:27 PDT 2001
80 - Clean up ft.c slightly. Direct IM now works. In both directions.
81 - This could still use a lot more help. It should use bstreams more.
83 - Sat Sep 8 00:55:46 PDT 2001
84 - Chatnav loop fix. (Err. I shouldn't code when I'm that tired.)
85 - Remove some things from BUGS
86 - Remove USE_MACROS from faimconfig.h. Not used, and frivelous when it was.
88 - Fri Sep 7 21:18:51 PDT 2001
89 - Make icon field names uniform
90 - Add AIM_IMFLAGS_CUSTOMFEATURES. This allows the client to send/recieve
91 the field in IMs that show client information.
92 - This can be used to identify other open source OSCAR clients, if any
94 - Increase the size of args->icbmflags to 32bits
95 - Make sure that extended-only flags are not set for aim_send_im()
97 - Fri Sep 7 19:59:43 PDT 2001
98 - Fix buddyicons. Yay! (checksums are 32bits all the time. duh.)
100 - Mon Sep 3 18:48:26 PDT 2001
101 - Reformat everything to use real tabs (and to my latest coding style)
102 - Abstract out the numerical data types to fu8/16/32_t for portability.
103 - AIM_FRAMETYPE_OSCAR -> AIM_FRAMETYPE_FLAP. This makes more sense.
104 - aim_conn_t's FLAP sequence number was a signed int. Oops.
105 - Get rid of the 'struct' on all types suffixed with _t. That's been
106 annoying me for a while. They're all real typedefs now.
107 - Yes, client people are going to be rather annoyed by this. But it
108 doesn't stop there. Keep reading.
109 - Make the 'struct aim_rxcblist_t' type local to rxhandlers.c.
110 - Combine the command_tx_struct and command_rx_struct into aim_frame_t.
111 - Mostly aim_frame_t is command_rx_struct. For command_tx_struct, the
112 same structure is used, except where ->sent was, ->handled is now
114 - This makes things a lot easier, everywhere.
115 - Get rid of ->lock. Pointless. If libfaim is ever preemptible, it
116 has much more important problems than that.
117 - Welcome to aim_bstream_t. No more direct buffer accesses. Anywhere.
118 - In fact I plan on getting rid of the aimutil macros completly.
119 - This isn't complete yet. It will be better later. Believe me. Maybe
120 even make more sense.
121 - More advanced and configurable boundschecking is coming, too.
122 - Clean up lots of stuff, everywhere.
123 - Rearrange the implementation of the TLV functions, saving lots of code.
124 - I'm rather pleased with the way some things got implemented with this,
125 particularly in places where TLVs contain TLVs.
126 - Get rid of aim_puttlv_() functions. Those were gross. Use tlvchains.
127 - XOR login is temporarily broken. I'll fix it someday. ("Someone" needs it.)
128 - Fix the return values of most everything -- OSCAR functions should all
129 return 0 on sucess, negative errno on failure.
130 - There are several things braced with #ifdef MID_REWROTE_ALL_THE_CRAP.
131 Consider that code broken and nonfunctional for now.
132 - I think I may have broken buddy icons. Remind me to fix that.
133 - Renovate faimtest substantially. Reformat, split up, update to new types.
135 - Wed Aug 29 16:59:24 PDT 2001
136 - Pass up entire icon triplet (checksum/length/timestamp) in all cases
138 - Eric was paying more attention than I am.
140 - Sat Aug 25 19:46:38 PDT 2001
141 - Pass "Maximum visible message length" to client in chat info update
142 - This is the real maximum message length now. There is still a
143 "complexity" limit that will prevent you from sending messages
144 even if they are less than this limit (102 right now), but I don't
145 know how that is calculated.
147 - Sat Aug 25 19:19:16 PDT 2001
148 - Keep parsing missed calls for entire packet
149 - This is really easy to test now. Just talk to someone with
150 their minmsginterval set high (like 10seconds or something)
152 - Sat Aug 25 18:35:13 PDT 2001
153 - aim_sendconnack -> aim_sendflapver
154 - Remove addicbmparam. This was identical to aim_seticbmparam
155 - aim_seticbmparam now takes a struct with the parameters in it. See
156 faimtest. !!! REQUIRES CLIENT CHANGES if you use aim_seticbmparam, which
157 you really really should -- the defaults are insanely limited
158 - Fix rendezvous IM parsing that I broke last time.
159 - ICBM parameter info callback gives same struct as above. !!! REQUIRES
161 - Reformat login.c and part of faimtest.c
162 - !!! NOTE: don't do anything in your motd handler. If you do, it will
163 get run twice, sine for some reason AOL is sending two MOTDs now.
165 - Wed Aug 22 22:11:18 PDT 2001
166 - Reformat the rest of im.c
167 - Fix a few returns, particularly in error cases
169 - Thu Aug 16 06:17:57 PDT 2001
170 - Reformat a bit of im.c and aim.h
171 - Rearrange encoding/subencoding checks in IM parsing
173 - Fri Aug 3 14:19:37 EDT 2001
174 - Naje aun_sebd_un retyrn sabe vakyes
176 - Thu Aug 2 13:28:37 EDT 2001
177 - Uhm. Why does arcanejill think its in EDT?
178 - Cache the username on warnings so errors work right.
179 - Someday, I'm going to convert all of libfaim to that formatting style, too.
181 - Wed Jun 27 00:13:20 EDT 2001
182 - Some comments about UNICODE in faimtest.
184 - Fri Jun 15 17:51:27 EDT 2001
185 - Make faimtest compile on RH7.1 (new gcc).
186 - Add aim_conn_getsess()
187 - Add aim_getconn_type_all() and aim_getconn_fd().
188 - Make aim_connrst() and aim_conn_getnext() static to conn.c.
189 - Why does arcanejill think she is in EDT? Oh well.
191 - Thu Jun 14 17:37:47 PDT 2001
192 - Rearrange aim_setprofile(). It will now let you _not_ send a profile,
193 if you really want to (pass NULL). Note that this is quite different
194 than sending a _blank_ profile. Also fixes the "asci" bug.
196 - Mon Jun 4 12:57:46 PDT 2001
197 - Fix chatnav. Whoops.
199 - Mon Jun 4 12:45:18 PDT 2001
200 - Don't use snacid's for generic requests (gets around recent blocks)
201 - If they start doing snacid-based blocks again, an audit will have
202 to be done to see what WinAIM requests uses snacids for and what
203 it leaves it blank for. That will be tedious and I'm not going to
206 - Thu May 31 23:00:50 PDT 2001
207 - Store two hardcoded hashes in login.c. Sigh.
208 - Add prototype for aim_callhandler_noparam in aim_internal.h
210 - Sat May 26 03:58:27 PDT 2001
211 - Aha! This is why I could never get icons to work before.
212 - Luckily the checksum is painfully simple.
214 - Sat May 26 01:37:39 PDT 2001
215 - So this is my big merge with the ActiveBuddy version...
216 - Remove use of tlvchains from IM parsing for better performance
217 - Add in buddy icon support
218 - Add support for sending UNICODE messages.
219 - Split up the more complicated options to aim_send_im into a structure
220 that is passed to aim_send_im_ext(). This makes it easier to send
221 simple messages, and only slightly harder to send complex ones.
222 - aim_send_im_ext() must be used if you're using buddy icons and/or you
223 are sending UNICODE messages.
224 - UNICODE is fully explained in commentary above aim_send_im_ext() in im.c.
225 - The ISO-8859-1 option is also added. Use when necessary, to avoid making
227 - This removes the msglen parameter to aim_send_im because that was only
228 needed to do UNICODE, which can now only be done by aim_send_im_ext.
230 - Wed May 23 18:05:46 PDT 2001
231 - I upgraded libtool. Which broke the faimtest makefile.
232 - Parse locate rights
233 - You shouldn't ask so many questions, Eric.
235 - Wed May 16 12:48:13 PDT 2001
236 - Thanks Rob and Eric
238 - Thu May 10 17:37:23 PDT 2001
239 - I haven't had lunch yet. What should I have?
241 - Wed May 9 15:21:51 PDT 2001
242 - I had pizza for lunch.
244 - Mon May 7 15:19:55 PDT 2001
245 - Rename rxhandler_t to aim_rxhandler_t. This has been
246 bugging me for a while.
248 - Thu May 3 15:47:23 PDT 2001
249 - Clean up getcap/putcaps
250 - Add GAMES2 and SENDBUDDYLIST caps (the latter is new in winaim 4.7beta)
251 - Update hash to latest value
253 - Wed Apr 25 11:51:39 PDT 2001
254 - I think this was a bug.
256 - Tue Apr 24 17:36:03 PDT 2001
257 - Let Eric generate the hash if he wants.
259 - Mon Apr 23 15:58:11 PDT 2001
260 - On a clear day, you can see forever.
262 - Thu Mar 29 13:05:50 PST 2001
265 - Thu Mar 29 14:45:22 CST 2001 (jbm)
266 - Add module capability to the 0001/001f stuff (jbm)
268 - Wed Mar 28 21:20:08 PST 2001
269 - Add flags arg to aim_chat_send_im()
270 - Add msglen arg to aim_send_im and aim_chat_send_im
271 - This will make more sense when I make the UNICODE commit (tomorrow?)
273 - Wed Mar 28 16:51:25 PST 2001
274 - I decided it was a good day while I was figuring out that it was a bad day.
275 - See faimtest and login.c::memrequest().
276 - Hopefully I'm done for a while.
278 - Tue Mar 27 19:15:10 PST 2001
279 - I haven't decided yet whether today is a good day or a bad day.
283 - Mon Mar 26 16:08:45 PST 2001
284 - Why didn't anyone tell me buddy-offgoing wasn't working?
285 - *** REQUIRES CLIENT CHANGES... buddy-offgoing now passes a userinfo
286 struct (its now identical to buddy-oncoming)
288 - Mon Mar 26 15:57:41 PST 2001
290 - Debuglevel wasn't getting set properly by aim_session_init
292 - Sat Mar 24 03:16:32 UTC 2001
293 - vaargs to msgerror and locateerror swapped
294 - ** CLIENT CHANGE: Reason code comes before SN now. This is so that
295 the backend code for all three error handlers is identical.
296 - aim_getinfo() returns -1 on failure (hah! I don't think anyone checks
297 return codes from libfaim anyway...they're known for their
298 inconsistency and lack of sensicality)
299 - Remove _DEFAULT handlers in faimtest...
300 - They were not consistent.
301 - They did not make sense.
302 - They did not work anyway.
303 - Most of them were #if 0'd.
304 - Add ICBM Parameter Info callback... you can catch this if you want.
305 - aim_getbuildstring() now takes a buffer instead of returning static (ew!)
306 - Clean up, "factorize", etc
307 - More stuff... (Only one "middle handler" left in rxhandlers.c!)
309 - Fri Mar 23 05:42:11 UTC 2001
310 - Export aim_encode_password_md5()
311 - Add middle handler for 000b/0002 (min report interval)
312 - Add aim_session_kill()
313 - CLIENTS MUST CALL THIS either in addition to or instead of
314 aim_logoff(), particularly if you keep lots of sessions open.
315 (Sessions now contain dynamically allocated memory which must be freed.)
316 - Oh, and some other stuff...
318 - Fri Mar 23 01:45:28 UTC 2001
319 - Add AIM_CLIENTINFO_KNOWNGOOD
320 - Fix a few details in aim_send_login (thanks temas)
321 - Prevent aim_rxhandlers from being called recursively
322 - This is something that has been in my PENDING_AIM mailbox for over
323 a year now. I figured it was trivial enough to throw in. EveryBuddy
324 wanted it, but I don't remember why. It should never happen anyway.
325 - Use AIM_CLIENTINFO_KNOWNGOOD
326 - This lets faimtest log in after today's round of AOL being mean.
328 - Fri Mar 16 23:12:58 UTC 2001
329 - Remove one level from aim_rxdispatch()
331 - Wed Mar 14 20:21:49 UTC 2001
332 - Clean up declarations of TLV functions (ie, const)
333 - Add -o and -O to faimtest (I didn't use your patch, josh)
335 - Wed Mar 14 03:11:03 UTC 2001
336 - Err...I'll commit before I go home. More faimtest crap.
338 - Tue Mar 13 20:23:04 UTC 2001
339 - Fiddle with faimtest a bit.
341 - Sun Mar 11 06:02:19 UTC 2001
344 - Sun Mar 11 05:51:45 UTC 2001 (jbm)
345 - Split off aim_internal.h
346 - Add aim_tx_cleanqueue()
347 - Remove sn from directim callback (use priv)
349 - Mon Mar 5 01:19:48 UTC 2001
350 - Fix typo in last CHANGES entry.
351 - Add fix from Eric to keep efence from complaining about malloc(0)
352 - Add .cvsignore files (also from Eric)
353 - Throw in josh's latest OFT/ODC kludges
354 - Completly remove all calls to printf and (unbounded) sprintf
355 - Add aim_setdebuggingcb()
356 - Remove preprocessor-based debug semantics (faimconfig.h)
357 - faimdprintf() now calls a user-specified callback to do printing
358 - Rearrange aim_tx_new() parameters to be more sensical, add sess
359 - Do some sanity checking in aim_tx_new()
360 - Add #defines to keep printf from compiling inside libfaim
361 - Who knows what else. (in total, this patch is nearly 5k lines)
363 - Fri Mar 2 02:17:22 UTC 2001
364 - Add aim_fingerprintclient(). (AB will trust this, but you shouldn't.)
365 - Add some EXTRA_DIST to Makefile.am
367 - Mon Feb 26 01:46:34 UTC 2001
368 - Fix swapped bytes in aim_caps[]. Thanks to
369 Bruce Miller <bmiller@ics.uci.edu> for pointing this out.
371 - Sun Feb 11 01:07:36 UTC 2001
372 - Make secondary connections to the authorizer work again
373 - Make aim_auth_changepasswd() work again.
374 - Add aim_auth_setversions(), aim_auth_getinfo(), aim_auth_setemail(),
375 aim_auth_reqconfirm()
376 - Add middle handlers for responses to all of above.
377 - Add examples of above to faimtest (start with 'reqauth')
379 - Fri Feb 9 22:31:22 UTC 2001
380 - Add aim_tx_setenqueue().
382 - Thu Feb 8 20:12:39 UTC 2001
383 - Let TLV functions out of aim.h if FAIM_NEED_TLV is defined.
385 - Thu Feb 8 02:31:25 UTC 2001
386 - Remove aim_purgecookies() -- never used anyway
387 - Clean up a few bits of aim_msgcookie.c
388 - Remove AIM_CONN_MAX constant (hasn't been relevent in ages)
389 - Change commentary on synchro in aim.h
390 - Add NOPLOCKS and make them default
391 - Make faim/aim.h more of a mess; try to keep interfaces hiddenish.
392 - Add #define FAIM_INTERNAL to top of every file
393 - Remove aim_countconn (no one uses it anyway)
394 - Add aim_cloneconn() (cringe.)
395 - Throw in josh's getfile patch (and then munge it enough to break it)
396 - Add getopt() to faimtest.
397 - Remove aim_buildcode.h/mkbuildinfo.sh crap.
398 - Clean up aim_cleansnacs()
399 - There may have been other stuff too. As always, the diff is the
400 most accurate changelog there is.
401 - *** FT is currently more broken than it was before. Also, this patch
402 introduces even more memory leaks. You've been warned.
404 - Sun Dec 17 07:19:04 UTC 2000
405 - Update the capability block list
407 - Sat Dec 16 01:34:19 UTC 2000
408 - Rename paramid to rateclass
409 - Add a long comment about the rate system
410 - Add a few other comments
411 - Clean up aim_bos_clientready().
413 - Fri Dec 15 23:35:01 UTC 2000
414 - Add genericerr callback/middle.
415 - This is for catching the errors that come back, for instance, from
416 sending a SNAC that isn't supported by the host (such as the
417 Watcher Request SNAC).
419 - Fri Dec 15 21:51:32 UTC 2000
420 - Add more info to evilnotify callback
421 - Add a few values to aim_cbtypes.h
423 - Fri Dec 15 20:41:15 UTC 2000
425 - Make aimdebugd compile
428 - Fri Dec 15 02:04:12 UTC 2000
429 - Parse rate changes *properly*
430 - Add sample code to faimtest demonstrating my approximations
431 on how to fiddle with aim_conn_setlatency() in relation
432 to the rate changes (properly wildly conservative). [I also
433 copied this stuff into mfaim.]
435 - Thu Dec 14 03:39:34 UTC 2000
436 - Change the 0x01 to a 0x00 in auth request to make buddy lists work again
437 - Rearrange bytes in setversions() to match winaim
438 - Add several cachesnac() calls
439 - Add hostonline and hostversions parsers (superfluous)
441 - Wed Dec 13 02:26:39 UTC 2000
442 - Create aim_cachesnac()
443 - Some long overdue cleanups
445 - Wed Dec 13 00:38:56 UTC 2000
446 - Added the client update/version info to the authresp callback
447 - Added the prototype for aim_getfile_send_chunk to aim.h
449 - Tue Dec 12 23:02:41 UTC 2000
450 - Got pissed off at sess->logininfo. Got rid of it.
451 - Now pass all that stuff in as varargs, like it should be.
452 - *** Look at the changes to faimtest. You'll also need to
453 change anything in your code that references sess->logininfo
454 to reference sess->sn instead. The rest of the other info
455 is now unavailable (it was before, too, it just didnt look like it).
456 - A few other minor cleanups.
457 - Added aim_gettlv8/16/32, aim_puttlv_8, and aim_addtlvtochain_noval.
458 - Added that short 0x004a TLV to the auth request, like WinAIM 4.3.
460 - Mon Dec 4 23:46:35 UTC 2000
461 - Add exchange to the create response callback (doh!)
463 - Sat Dec 2 02:14:45 UTC 2000
464 - Dumb bug in aim_clearhandlers()
466 - Fri Dec 1 23:48:38 UTC 2000
467 - Store exchange along with room name in the great chat hack
469 - Fri Dec 1 22:25:56 UTC 2000
470 - Fix numerous tiny (but sometimes catastrophic) bugs dealing
471 with connection death (particularly with chat connections)
472 - *** Any connection with a -1 fd will get returned by aim_select
473 immediatly now... your code probably already handles this implicitly.
475 - Wed Nov 29 17:31:23 UTC 2000
476 - Rewrote some of the msgcookie stuff
477 - Changed cachecookies to uncachecookies where it makes sense (arg!)
480 - Fri Nov 10 08:24:34 UTC 2000
481 - Add sess->flags (replaces sess->snaclogin)
482 - Remove odd setstatus call in chat parser
483 - Remove aim_tx_enqueue macro, replace with a smarter one
484 - If a connection is in progress, enqueue instead of calling
485 the client-specified queuer
486 - Add support for nonblocking connects through the
487 AIM_SESS_FLAG_NONBLOCKCONNECT flag to aim_session_init()
488 - Add AIM_CB_SPECIAL_CONNCOMPLETE callback. Not real useful.
489 - Add AIM_CB_SPECIAL_FLAPVER callback. Can be used as an alternate
490 way of starting the login process, or just to look like you
491 know what you're doing. Fixed associated inconsistencies
492 in aim_rxhandlers too.
493 - Fix some connection status stupidities in faimtest.
495 - Wed Nov 8 13:11:18 UTC 2000
496 - Reenable/reimplement older login, but only use for ICQ UINs
497 - This is a fairly ugly hack. But...eh. It works.
498 - You'll need to remove the aim_sendconnack() before the
499 call to aim_request_login. It will now do it automatically
500 if its needed. (hint: ***CLIENT CHANGE***)
502 - Wed Nov 8 02:23:25 UTC 2000
503 - I'm trying out using a modified version of the kernel-doc scripts
504 to help document the libfaim code a bit. See aim_conn.c and
505 aim_tlv.c, as well as the scripts in utils/docs.
507 - Wed Oct 25 17:52:20 UTC 2000
508 - Cleanup warnings from newer gcc's (RH7.0)
509 - Aparently newer gcc's don't let you do as strong of integer types
510 on va_arg as older ones... So, let me know if this breaks on your
513 - Tue Oct 17 02:10:13 UTC 2000
514 - Rearrange a few things
516 - Mon Oct 16 20:56:59 UTC 2000
517 - Remove some warnings
519 - Mon Oct 9 04:24:56 CDT 2000 (jbm)
520 - took care of the XXXs in aim_putuserinfo()
521 - now use dynamic TLV count to send ("look ma, no magic!")
522 - now send cap blocks
523 - now send icq info if a numeric SN
525 - Wed Oct 4 21:29:47 CDT 2000 (jbm)
526 - Fix borked disconnect callbacks
527 - Add aim_conn_in_sess()
528 - A little housekeeping in faimtest ("fixing" order of printf,
531 - Mon Sep 25 00:21:31 CDT 2000 (jbm)
532 - Add a couple of ICQ userinfo parses
534 - Fri Sep 22 22:47:49 UTC 2000
535 - Add aim_icq_setstatus() (jbm)
537 - Fri Sep 22 22:35:51 UTC 2000
538 - Apply jbm's patch below
539 - Minor cleanup in cb handler stuff
541 - Thu Sep 21 20:28:20 CDT 2000 (jbm)
542 - DirectIM shouldn't kill us any more.
543 - Eliminated a potential segfault in aim_send_im_direct().
545 - Added an aim_tx_destroy(); need to move the lib over to using it.
546 - Got rid of some #if 0 BS code in a couple of places
547 (aim_ft::establish() and aim_im::aim_parse_incoming_im_middle()).
548 - Added some file transfer stuff (so experimental, i haven't
549 had a chance to see if it causes cancer in lab animals).
550 - Added to faimtest for all of the above.
551 - Added myself to AUTHORS with Real Info.
553 - Thu Sep 21 00:24:36 UTC 2000
554 - Add socks5 proxy support (not tested real well, worked the
556 - Added proxy support to faimtest.
558 - Tue Sep 19 03:10:07 UTC 2000
559 - Add aim_setuserinterests() and aim_setdirectoryinfo()
560 - Add ICQ away status
562 - Thu Sep 14 00:54:48 UTC 2000
563 - Added create room callback
565 - Wed Sep 13 22:01:35 UTC 2000
566 - Remove references to "new" and "class" for dumb C++ compilers
567 - Renamed userinfo->class to userinfo->flags both for clarity and C++
568 - Remove some extraneous variables
570 - Tue Sep 12 20:16:51 UTC 2000
571 - Add aim_flap_nop() from my work tree
573 - Tue Sep 12 05:06:53 UTC 2000
574 - Revert the two-byte change in aim_misc, clientready
576 - Tue Sep 5 04:41:45 GMT 2000
577 - Few more minor things
578 - Added the changes needed for faimtest.
579 - Removed aimdebugd from default build
581 - Tue Sep 5 03:47:26 GMT 2000
582 - More ANSIfication for win32
583 - Forgot aim_misc last time.
585 - Mon Sep 4 22:08:35 GMT 2000
586 - Forgot aim_snac and aim_search
588 - Mon Sep 4 21:38:09 GMT 2000
589 - A mild step towards ANSI compliance
590 - Compiles cleanly with -pedantic (except for the libc issue in socket.h)
591 - Fixes various sign mismatch things. There may be more, we'll see
592 what MSVC has to say about it.
593 - Add faim_internal and faim_export macros so Win32 DLL is easier
595 - Sun Sep 3 23:58:17 UTC 2000
596 - Portability fixes (for solaris, set the SOLARIS env var first)
598 - Sat Sep 2 23:42:37 UTC 2000
599 - Hopefully fix aim_snac.c bugs
600 - Add Buddy List Rights parser (max buddies and max watchers)
601 - Fix rather major problem in rxhandlers caused by missing breaks
602 - Add reason code for msgerr (0004/0001) callback
603 - Add BOS Rights parser (max permit / max deny)
604 - Add locate error (0002/0001) parser
605 - Add parser for missed calls (0004/000a)
607 - Fri Sep 1 23:34:28 UTC 2000
608 - Switched the read()s in rxqueue to use recv()
609 - Should fix the big message problem and the big buddy list problem
610 - Changed some values around in aim_misc to match winaim4.1
611 - Added aim_addicbmparm. dunno what it does
612 - Cleanup the login process in faimtest (can now login in less than 2sec)
614 - Fri Sep 1 00:13:04 UTC 2000
615 - Avoid zero-length mallocs in aim_tlv
617 - Thu Aug 31 23:40:23 UTC 2000
618 - Threw in aim_select modification from nicolas
619 - Remove stray debugging printf in aim_tlv
621 - Mon Aug 28 03:11:15 GMT 2000
622 - Adds lots of comments
623 - Add AIM_CLASS_ALLUSERS constant for setgrouppermmask()
624 - Add warnings support (jbm)
626 - Mon Aug 21 22:00:18 UTC 2000
627 - Implement SNAC login MD5 (thanks to Sonuvbob for that one)
628 - Clear out all that old login cruft. Much cleaner now.
629 - REQUIRES CLIENT CHANGES (see faimtest)
631 - Fri Aug 18 19:52:54 UTC 2000
632 - Fix the non-pthread bug
634 - Thu Aug 17 23:19:40 UTC 2000
635 - A few more leak fixes (only a few left to go...)
637 - Thu Aug 17 23:08:08 UTC 2000
638 - More leak fixes (eric, eric, eric...)
640 - Thu Aug 17 22:53:03 UTC 2000
641 - Change the SNAC cache to a hash instead of list
642 - Fixed a few leaks relating to aim_gettlv_str()
644 - Thu Aug 17 14:04:18 UTC 2000
645 - Fix the fd closing bug introduced last week
647 - Tue Aug 8 04:25:35 UTC 2000
648 - Preserve subtype and priv after aim_conn_close
650 - Tue Aug 8 04:15:47 UTC 2000
651 - Fixed double-calling of faim_mutex_init
652 - conn->type preserved after aim_conn_close
654 - Mon Jul 17 01:56:31 UTC 2000
655 - Added 0004/000c callback (for message acknowledgments)
656 - This goes with the AIM_IMFLAGS_ACK option that has been there
657 for ages now. When you send a message with that option, you'll
658 get a message back containing the screenname, telling you it was sent.
659 - Moved the aim_conn_kill's out of aim_get_command() and into
660 the client. They're only closed in there now. This is so that you
661 can detect what type of connection died. You'll want to handle
662 BOS and chat connections in special ways most likely. You'll also
663 need to call aim_conn_kill when you're done with it.
664 - Added/fixed the Rate Change handlers. Now passes up a long that
665 should contain a number. I'm currently in pattern-searching mode.
667 - Sun Jul 16 22:59:39 GMT 2000
668 - Fixed the locking in the rendezvous code. Hopefully is safe now.
670 - Sun Jul 16 11:03:28 GMT 2000
671 - Fixed 0001/000a chat printf. (Actually a one liner a few days ago.)
672 - Started integrating josh's 3k rendezvous patch. Currently only
673 directim is working. And its got bugs. But he's not online
674 right now, so I can't bitch. I'd love to bitch here, but I'm
676 - Can definitly accept directim connections and send/recieve.
677 - See faimtest for the new callbacks. (Urg.)
678 - Here weeee gooooo. (Not sure if this will break everyone or not.)
680 - Fri Jun 30 00:04:47 UTC 2000
681 - Removed the forceful ICQ-related warnings, just in case they're wrong
682 - Added three new fields to the client info.
683 - **REQUIRES CLIENT CHANGES -- see faimtest for new initializer
684 - Cleaned up aim_send_login()
685 - Put in a nice hidious fix for AOL's latest bit of the drama. See
686 aim_readtlvchain() for the details.
688 - Mon Jun 26 07:53:02 UTC 2000
689 - Added utils/aimdebugd for playing with things -- see the README
690 - Added aim_im.c::aim_parse_outgoing_im(). Probably not useful
691 unless you're writing a server or something (or hacking aimdebugd).
692 - aim_send_im() now sends the same data as AIM4 does (three more bytes)
693 - Added aim_debugconn_sendconnect() for aimdebugd-enablement.
695 - Sat Jun 24 02:14:07 UTC 2000
696 - Added fakelocks for platforms without pthreads or that have no
698 - Added workaround for MSG_WAITALL for people with the very broken
699 libc that comes with earlier Red Hat's.
701 - Sat Jun 24 00:44:24 UTC 2000
702 - Support zero-type TLVs in aim_extractinfo()
703 - AOL now ocassionally throws extra zeros in so in order to break
704 clients. Aparently zero-type TLVs are a special case -- if the
705 type is zero, then _there is no length_ field. AOL are geniuses.
706 - Note that you only get these if you send a bad client string, such
707 as the top one in faimtest. If you #if 0 that one out and use the
708 second one, you'll be fine. (Unless you just want to see the message
709 for yourself. Its nifty. (FREE!))
710 - ICBM parser now uses aim_extractuserinfo() so that it can benefit
711 from the above changes, as well as clean up the whole "is it the
712 first or the second one of this type?" issue
713 - This also fixes the changes AOL made in away messages.
714 = Fixed a possible buffer overflow when AOL changes the max sn length
715 - Increased MAXSNLEN to 32 (they appear to be valid)
716 - If you start getting messages from someone called "AOL Instant
717 Messenger", see comment one, paragraph two.
718 - aim_select() now returns a -1 if there are no connections open
719 - Connections are now killed completely if there is a major error on them
720 - faimtest now calls aim_logoff() on connection error
722 - Fri Jun 23 22:38:47 UTC 2000
723 - Adds start of adverts support
724 - Adds aim_bos_nop(). You may want to send this occassionally
725 - Fixes aim_rxhandlers.c to work for people with three-letter
728 - The week prior to Fri Jun 16 19:37:09 UTC 2000
729 - Rethought the rendezvous stuff. DEFINIT WORK IN PROGRESS
730 - Do not bother trying to use this. This will probably break
731 your clients. You may or may not want to fix them, since
732 I may change it again soon.
733 - I REPEAT: This really is a developer-only version. It barely
734 compiles. I'm just committing it so I don't have so many
735 trees floating around.
736 - Added stuff to support OFT as well as OSCAR protocols
737 - Added aim_send_im_direct() for directim ("IM Image")
738 - Added caps getting/putting routines
739 - Added more aim_login fixes to avoid more AOL stupidity
740 - This is the same as went to libfaim-devel yesterday, so don't upgrade
741 just to get these changes.
742 - Removed aimicq_encode_password -- now use the same table
746 - Tue Jun 6 01:36:48 UTC 2000
747 - Inverted gethostbyname2() check. Not sure how that ended up
749 - Added some of the initial framework to support file transfers
750 - Added in a few checks for that
751 - Can currently parse and send a denial message.
752 - Added cookie caching. (Sorry, I just like saying that.)
753 - Rearranged channel 2 ICBM parsing (detects the different
754 rendezvous types better and hopefully accuratly).
755 - Killed the connection array. Now a list. (Suits the
756 upcoming features better.) --- REQUIRES CLIENT CHANGES...
757 - In most cases, you need to change aim_conn_close() calls
758 to aim_conn_kill(). This will free them as well as
759 close them. If you don't do this, you'll pollute the
760 connection list and leak memory.
761 - Possibly a few other minor things (some cleanups to faimtest for one)
763 - Fri Jun 2 23:27:28 UTC 2000
764 - Cleaned up aim_send_login slightly
765 - Added aimicq_encode_password to support the new hash
766 values required for logging in with ICQ
767 - Removed crash when email and/or reg status aren't
768 in the auth response (they're not in ICQ responses)
769 - So now as long as you specify a client version of
770 4.30.3141 in the client info, and your ICQ number
771 as your screen name, you can login to ICQ via libfaim
772 and use it just like an AIM account.
773 - Added AIM_CB_SPECIAL_CONNERR callback for recieving
774 messages such as disconnect reasonses ("you logged
775 on from a different machine", etc).
776 - Added faimtest's userinfo handler to support away messages
778 - Fri Jun 2 15:57:27 UTC 2000
779 - Add creation time, maxmsglen, and various unknowns to chat info
781 - Remove 'nothing works yet' comment from top of aim_chat.c (it works!)
783 - Wed May 31 01:17:24 UTC 2000
784 - Added constants for message sizes (MAXMSGLEN, MAXCHATMSGLEN)
785 - Note that the new max message size is defined as 7988bytes,
786 drastically larger than WinAIM lets you put out. This is a
787 libfaim-exclusive feature :)
788 - Reduced base buffer size on aim_send_im()
790 - Tue May 30 22:32:31 UTC 2000
791 - Added lock around tx seqnum to prevent that race when transmitting
792 from diverse threads. (actually committed earlier today)
793 - Added aim_meta.c and a few constants and things to keep
795 - Added mkbuildinfo.sh to automatically update build string
796 "constants" on every invocation of 'make all'.
798 - Mon May 29 12:08:28 GMT 2000
799 - Rearranged aim_tx_flushqueue(); moved write operation
800 to aim_tx_sendframe()
801 - Turned aim_tx_enqueue() into a macro that calls sess->tx_enqueue,
802 a function pointer to whatever you want to use to enqueue
803 things for transmition (or not)
804 - Old aim_tx_enqueue becomes aim_tx_enqueue__queuebased. Added
805 aim_tx_enqueue__immediate for doing immediate writes. Default
806 is to use queue-based procedure.
807 - Cleaned up parts of aim_conn.c
808 - Added locking around the sockets themselves. Should allow
809 for full cross-thread usage.
810 - Unfortunatly, only pthreads are supported at this time.
811 If you don't have pthreads on your arch, implement the
812 macros your arch needs and send me a patch. (A SysV
813 semaphore implementation would be trivial, as would a
814 simple integer-based lock.)
816 - Sun May 21 14:59:20 GMT 2000
817 - Added infotype parameter to aim_getinfo() for requesting
818 different types of messages. AIM_GETINFO_GENERALINFO
819 will get you the normal stuff, AIM_GETINFO_AWAYMESSAGE
820 will get the normal stuff, with the profile replaced with
821 the user's away message. Also, the callback adds an
822 unsigned short to the end to give you the value that
823 was originally passed to the request.
824 - There were a few server-pertinent changes that didn't get
825 documented from last month. I have no idea what they were.
827 - Sun Apr 2 07:29:11 UTC 2000
828 - Redid much of the tx path to remove the superfluous copy. But
829 it touches every function that transmits. Its been a long
831 - Added caps parameter to aim_bos_setprofile(). You can now
832 control what capabilties you show up as others to
833 - Added ->capabilities to userinfo. It should be nonzero when
834 its coming off buddy oncoming information, but NOT requested
837 - Sun Apr 2 01:45:15 UTC 2000
838 - Increased AIM_CONN_MAX from 5 to 7. Precausionary only
839 - Removed deprecated TIS_TELNET_PROXY from faim/faimconfig.h
840 - Added macros for the simple integer functions in aim_util.c
841 - Removed usage of aim_failsaferead()
842 - Still not sure why I had it to begin with. I think it
843 was a remament from when we used non-blocking sockets
844 (which I don't know why I did either)
845 - Removed some of the oddities in aim_get_command()
846 - gprof showed this taking 20kns on my k6-300. Should be faster now.
847 - Added conn parameter. This should prevent aim_select() from
848 getting called too many times in a row.
850 - Thu Mar 23 08:45:40 UTC 2000
851 - Removed aim_countconn() > 0 check in aim_select(), its logically redundent
852 - Added aim_putuserinfo() (inverse of aim_extractuserinfo())
853 - Added aim_sendbuddyoncoming/offgoing()
854 - Rearranged loop in rxdispatch()
855 - Remove aim_conn_close() if connections dead in aim_get_command()
857 - Thu Mar 23 00:44:32 UTC 2000
858 - Added a check to purge_rxqueue to skip handled commands
860 - Mon Mar 20 05:30:59 UTC 2000
861 - Added some server-only functions for login
862 - Added aim_counttlvchain()
863 - Added aim_sncmp() and aim_snlen()
865 - Sun Mar 19 06:07:52 UTC 2000
866 - Added a parameter to aim_select to return event type
867 - REQUIRES CLIENT CHANGES.
868 - For the most part rewrote the tx and rx queuing code
869 - Should fix many, many outstanding problems in and related
870 to that code, including one that keeps memory from freeing
871 - Fixed several bugs in various places
872 - Reformated a lot of code, and did general cleanups
873 - Should have a generally more robust lib now.
875 - Sun Mar 12 00:07:40 UTC 2000
876 - Fixed a robustness problem in aim_handleredirect_middle()
877 - Added TLV chain creation routines (yes, aimd is progressing)
879 - Mon Jan 3 04:07:55 UTC 2000
880 - Fixed bug in aim_snac.c
881 - Fixed condition where commands read from connections that have
882 been closed were still left in the queue. Now cancelled.
883 - Added some printfs to aim_info to get more informative crahes
884 - Fixed a bug in aim_rxqueue::purge
886 - Sun Jan 2 10:31:19 UTC 2000
887 - Cleanups in aim_info.c
888 - Can compile with -Ddebug=100 again
889 - Implemented chat: Joining/Leaving, info parsing, IM parsing/sending
890 - Implemented some chatnav: rights req/parsing, room creation
892 - Thu Dec 30 10:08:42 UTC 1999
893 - Fixed bug in aim_im.c when (encoding == NULL) || (lang == NULL)
894 - Added detection of voice chat requests
895 - Added AIM_CLASS_* defines, including new Away flag
896 - Added awaymsg parameter to bos_setprofile.
897 - If awaymsg is nonnull, you will be advertised as being away (your
898 class will be ORed with AIM_CLASS_AWAY), otherwise you'll show
901 - Wed Dec 29 10:06:35 UTC 1999
902 - Fixed small bug in IM parser
903 - Added stubs for the capability TLVs in userinfo.
905 - Wed Dec 29 09:14:45 UTC 1999
906 - Added a capability block to aim_bos_setprofile. Can now get chat
908 - Extended ICBM parser to support channel 2 messages (chat invites)
909 - A channel parameter has been prepended to the varargs -- REQUIRES
911 - Extended faimtest to support chat invites.
912 - Changed faimtest to get sn/password from environment
914 - Wed Dec 29 04:17:03 UTC 1999
916 - Added aim_sendconnack() to aim_login.c (needed for newer login)
917 - Added code for the new SNAC-based login/auth procedure. (see SNACLOGIN
918 in faim/faimconfig.h for why its not enabled)
919 - Reimplemented aim_authparse(), aim_handleredirect() using TLVlists
920 - The old auth_failed callback is now integrated into the
921 success one. If there was an error, logininfo->errorcode is nonzero
922 - Fiddled with version information. Added aim_setversions()
923 - Added table of SNAC names for showing unknown snacs (jbm)
924 - Added a middle handler for MOTD
925 - Added new authorization SNACs to faim/aim_cbtypes.h
927 - Sun Dec 26 22:59:10 UTC 1999
928 - Renamed login_phase1_struct to aim_login_struct
929 - Changed cookie and sn to be static arrays in aim_login_struct
930 - Integrated the Jabber-faim changes. (temas) [BIG CLIENT CHANGES]
931 - Added aim_session_t, removed all global variables
932 - Changed all functions to accept a session pointer
933 - Removed aim_global.c
934 - Updated faimtest to use an aim_session_t.
935 - Removed all cases where logininfo was passed as vararg to client
936 - Fixed small bug in aim_newconn's 'fixing' of host:port addresses
937 - Added an install rule to the makefile (installs headers+so only!)
938 - Enabled USE_SNAC_FOR_IMS by default, assuming it got fixed
939 by n's new aim_snac.c from ages ago
940 - Implemented a middle handler for 0004/0001 message errors, added
941 snacid lookup to get illfated destination SN and pass to client
942 - Implemented a short middle handler for offgoing buddy.
944 - Fri Dec 24 21:30:06 UTC 1999
945 - Added an error-counting Read() that has been sitting in my inbox
946 - Cleaned up header files, created aim_cbtypes.h.
947 - Added void * to aim_conn_t for private client use if they want. (Orb)
948 - Removed all stderr output. All output is important, and goes to stdout.
949 - Renamed isautoresponse in IM parser to icbmflags.
950 - Added Orb's fix for the new login code, deleted old (see Orb, I do read
951 your mail....eventually).
952 - Added mailing lists to README.
954 - Fri Dec 24 11:12:34 UTC 1999
955 - Cleaned up both outgoing and incoming ICBM handling. Anything
956 that crashes around there is no longer libfaims fault!
957 - The encoding flags are now passed up to the client.
958 - Added several TLV routines to parse large blocks of continuous
959 TLV triplets. Not terribly effecient, but quite elegent in usage.
960 - Added icbm_setparams() back in from way-back-long-ago. It hasn't
961 been implemented in a long time, but I think we should still send it.
963 - Fri Dec 24 01:23:06 UTC 1999
964 - Fixed a very minor bug in aim_newconn().
965 - Added aimutil_get{16,32}()
966 - Added aim_extractuserinfo() for extracting user data
967 blocks and putting them into struct aim_userinfo_s's.
968 - Added a loop to print out info on extraneous TLVs.
969 - Put in lots of comments.
970 - Added parse_oncoming_middle() to parse the user data
971 block of that packet. Now passes struct aim_userinfo_s
973 - Rearranged parse_userinfo_middle(). Now passes an entire
974 userinfo struct to client instead of individual variables.
975 - Convered the version of parse_im_middle() thats actually getting
976 used to pass up a userinfo struct.
977 - Updated faimtest to accept new structs.
979 - Tue Dec 21 06:18:50 UTC 1999
980 - Fixed a Win32 header problem
981 - Tue Dec 21 03:44:13 UTC 1999
982 - Latency timers now update on rx as well as tx. Gets rid of even more
983 of the rate problems that most clients are having.
984 - Renamed lasttx and settxlatency to lastactivity and setlatency, respec.
985 - Integrated fixes needed for Win32 -- should compile cleanly now (DMP)
986 - Cleaned up some places, use aim_putsnac everywhere now.
988 - Sun Sep 26 20:04:20 MST 1999
989 - Reduced the IM parsing to look for 3 zeros instead of 4 -- NEEDS WORK
990 - This was needed to work with MacAIM3 and some WinAIM3s.
991 - Added aim_conn_settxlatency() for throttling outgoing frames -- NEEDS WORK
992 - Added an int to the userinfo and incoming IM user callbacks for new
993 TLV that AOL put it in -- its the number of seconds elapsed since
995 - Worked more on the callbacks (more internal rearrangements)
996 - Fixed bug in aim_select() (returning negative fds)
997 - Clear out logininfo struct before putting more data into it
998 - Other bugfixes that I can't particularly remember.
1000 - Tue Aug 24 03:13:12 UTC 1999 --- TRANSITION RELEASE!!
1001 - Added jbm's new aim_rxqueue.c, which should crash less
1002 - Started the overhaul on the callback system. No where near complete yet.
1004 - Sun Aug 1 03:02:17 UTC 1999
1005 - Added aimutil_*()s in aim_util.c for raw byte placement
1006 - Cleaned up aim_im.c, aim_auth.c, and aim_login.c using aimutil_*
1007 - Added AIM_IMFLAGS, flags option to aim_send_im(), removed
1009 - Added client_info parameter to aim_send_login()
1010 - Tweaked aim_send_im() (AOL changed a few things, there's some more
1012 - Some Chat stuff changed, still no where near functional
1013 - Finally remembered to switch the license to LGPL (from GPL)
1014 - Permit/Deny (blocking) list support added
1015 - Released a snapshot
1017 - Sat Jul 31 05:28:38 UTC 1999
1018 - Changed aim_bos_setdeny() to aim_bos_changevisibility() and actually
1019 did the implementation.
1021 - Fri Jul 23 17:45:22 UTC 1999
1022 - Work around for the AOL change in IP syntax (thanks to Eric Peyton)
1025 - Sun Apr 25 23:31:44 UTC 1999
1026 - Fixed stupid off-by-one bug in aim_logoff()
1028 - Sun Apr 25 22:43:31 UTC 1999
1029 - Renamed/reclassified missed IM errors (now all callbacks -- no backend handling)
1030 - Killed aim_login() -- all connections now opened in frontend
1031 - aim_conn_close() will not close fd's < 3
1032 - Released snapshot.
1034 - Sat Apr 10 22:44:07 UTC 1999
1035 - Changed how rx_command->handled works; now uses return value from callback
1036 - Changed the if's in the dispatcher (aim_rxhandlers.c) to switch()es
1038 - Sat Apr 10 03:51:21 UTC 1999
1040 - Put in n's aim_snac.c.
1041 - Updated aim_{add,remove}_buddy() to use aim_conn
1042 - Updated aim_usersearch_address() to use aim_conn
1043 - Cleaned up aim.h a bit (removed old *phase* protos)
1044 - Changed gethostbyname() to gethostbyname2() (for MacOS X)
1045 - Changed aim_newconn() to pass connection errors in connstruct->status
1046 - Updated faimtest.c to detect connection errors
1047 - Fixed a small typo in aim_im::aim_parse_incoming_im_middle()
1048 - Added free()s in that function and to userinfo counterpart (fewer leaks)
1051 - Sat Apr 3 06:43:14 UTC 1999
1054 - Wed Dec 30 01:20:59 MST 1998
1057 - Mon Dec 7 16:57:57 MST 1998
1060 - Sat Dec 5 00:01:53 MST 1998
1063 - Thu Nov 26 17:50:02 MST 1998