4 - Tue Sep 19 03:10:07 UTC 2000
5 - Add aim_setuserinterests() and aim_setdirectoryinfo()
8 - Thu Sep 14 00:54:48 UTC 2000
9 - Added create room callback
11 - Wed Sep 13 22:01:35 UTC 2000
12 - Remove references to "new" and "class" for dumb C++ compilers
13 - Renamed userinfo->class to userinfo->flags both for clarity and C++
14 - Remove some extraneous variables
16 - Tue Sep 12 20:16:51 UTC 2000
17 - Add aim_flap_nop() from my work tree
19 - Tue Sep 12 05:06:53 UTC 2000
20 - Revert the two-byte change in aim_misc, clientready
22 - Tue Sep 5 04:41:45 GMT 2000
23 - Few more minor things
24 - Added the changes needed for faimtest.
25 - Removed aimdebugd from default build
27 - Tue Sep 5 03:47:26 GMT 2000
28 - More ANSIfication for win32
29 - Forgot aim_misc last time.
31 - Mon Sep 4 22:08:35 GMT 2000
32 - Forgot aim_snac and aim_search
34 - Mon Sep 4 21:38:09 GMT 2000
35 - A mild step towards ANSI compliance
36 - Compiles cleanly with -pedantic (except for the libc issue in socket.h)
37 - Fixes various sign mismatch things. There may be more, we'll see
38 what MSVC has to say about it.
39 - Add faim_internal and faim_export macros so Win32 DLL is easier
41 - Sun Sep 3 23:58:17 UTC 2000
42 - Portability fixes (for solaris, set the SOLARIS env var first)
44 - Sat Sep 2 23:42:37 UTC 2000
45 - Hopefully fix aim_snac.c bugs
46 - Add Buddy List Rights parser (max buddies and max watchers)
47 - Fix rather major problem in rxhandlers caused by missing breaks
48 - Add reason code for msgerr (0004/0001) callback
49 - Add BOS Rights parser (max permit / max deny)
50 - Add locate error (0002/0001) parser
51 - Add parser for missed calls (0004/000a)
53 - Fri Sep 1 23:34:28 UTC 2000
54 - Switched the read()s in rxqueue to use recv()
55 - Should fix the big message problem and the big buddy list problem
56 - Changed some values around in aim_misc to match winaim4.1
57 - Added aim_addicbmparm. dunno what it does
58 - Cleanup the login process in faimtest (can now login in less than 2sec)
60 - Fri Sep 1 00:13:04 UTC 2000
61 - Avoid zero-length mallocs in aim_tlv
63 - Thu Aug 31 23:40:23 UTC 2000
64 - Threw in aim_select modification from nicolas
65 - Remove stray debugging printf in aim_tlv
67 - Mon Aug 28 03:11:15 GMT 2000
68 - Adds lots of comments
69 - Add AIM_CLASS_ALLUSERS constant for setgrouppermmask()
70 - Add warnings support (jbm)
72 - Mon Aug 21 22:00:18 UTC 2000
73 - Implement SNAC login MD5 (thanks to Sonuvbob for that one)
74 - Clear out all that old login cruft. Much cleaner now.
75 - REQUIRES CLIENT CHANGES (see faimtest)
77 - Fri Aug 18 19:52:54 UTC 2000
78 - Fix the non-pthread bug
80 - Thu Aug 17 23:19:40 UTC 2000
81 - A few more leak fixes (only a few left to go...)
83 - Thu Aug 17 23:08:08 UTC 2000
84 - More leak fixes (eric, eric, eric...)
86 - Thu Aug 17 22:53:03 UTC 2000
87 - Change the SNAC cache to a hash instead of list
88 - Fixed a few leaks relating to aim_gettlv_str()
90 - Thu Aug 17 14:04:18 UTC 2000
91 - Fix the fd closing bug introduced last week
93 - Tue Aug 8 04:25:35 UTC 2000
94 - Preserve subtype and priv after aim_conn_close
96 - Tue Aug 8 04:15:47 UTC 2000
97 - Fixed double-calling of faim_mutex_init
98 - conn->type preserved after aim_conn_close
100 - Mon Jul 17 01:56:31 UTC 2000
101 - Added 0004/000c callback (for message acknowledgments)
102 - This goes with the AIM_IMFLAGS_ACK option that has been there
103 for ages now. When you send a message with that option, you'll
104 get a message back containing the screenname, telling you it was sent.
105 - Moved the aim_conn_kill's out of aim_get_command() and into
106 the client. They're only closed in there now. This is so that you
107 can detect what type of connection died. You'll want to handle
108 BOS and chat connections in special ways most likely. You'll also
109 need to call aim_conn_kill when you're done with it.
110 - Added/fixed the Rate Change handlers. Now passes up a long that
111 should contain a number. I'm currently in pattern-searching mode.
113 - Sun Jul 16 22:59:39 GMT 2000
114 - Fixed the locking in the rendezvous code. Hopefully is safe now.
116 - Sun Jul 16 11:03:28 GMT 2000
117 - Fixed 0001/000a chat printf. (Actually a one liner a few days ago.)
118 - Started integrating josh's 3k rendezvous patch. Currently only
119 directim is working. And its got bugs. But he's not online
120 right now, so I can't bitch. I'd love to bitch here, but I'm
122 - Can definitly accept directim connections and send/recieve.
123 - See faimtest for the new callbacks. (Urg.)
124 - Here weeee gooooo. (Not sure if this will break everyone or not.)
126 - Fri Jun 30 00:04:47 UTC 2000
127 - Removed the forceful ICQ-related warnings, just in case they're wrong
128 - Added three new fields to the client info.
129 - **REQUIRES CLIENT CHANGES -- see faimtest for new initializer
130 - Cleaned up aim_send_login()
131 - Put in a nice hidious fix for AOL's latest bit of the drama. See
132 aim_readtlvchain() for the details.
134 - Mon Jun 26 07:53:02 UTC 2000
135 - Added utils/aimdebugd for playing with things -- see the README
136 - Added aim_im.c::aim_parse_outgoing_im(). Probably not useful
137 unless you're writing a server or something (or hacking aimdebugd).
138 - aim_send_im() now sends the same data as AIM4 does (three more bytes)
139 - Added aim_debugconn_sendconnect() for aimdebugd-enablement.
141 - Sat Jun 24 02:14:07 UTC 2000
142 - Added fakelocks for platforms without pthreads or that have no
144 - Added workaround for MSG_WAITALL for people with the very broken
145 libc that comes with earlier Red Hat's.
147 - Sat Jun 24 00:44:24 UTC 2000
148 - Support zero-type TLVs in aim_extractinfo()
149 - AOL now ocassionally throws extra zeros in so in order to break
150 clients. Aparently zero-type TLVs are a special case -- if the
151 type is zero, then _there is no length_ field. AOL are geniuses.
152 - Note that you only get these if you send a bad client string, such
153 as the top one in faimtest. If you #if 0 that one out and use the
154 second one, you'll be fine. (Unless you just want to see the message
155 for yourself. Its nifty. (FREE!))
156 - ICBM parser now uses aim_extractuserinfo() so that it can benefit
157 from the above changes, as well as clean up the whole "is it the
158 first or the second one of this type?" issue
159 - This also fixes the changes AOL made in away messages.
160 = Fixed a possible buffer overflow when AOL changes the max sn length
161 - Increased MAXSNLEN to 32 (they appear to be valid)
162 - If you start getting messages from someone called "AOL Instant
163 Messenger", see comment one, paragraph two.
164 - aim_select() now returns a -1 if there are no connections open
165 - Connections are now killed completely if there is a major error on them
166 - faimtest now calls aim_logoff() on connection error
168 - Fri Jun 23 22:38:47 UTC 2000
169 - Adds start of adverts support
170 - Adds aim_bos_nop(). You may want to send this occassionally
171 - Fixes aim_rxhandlers.c to work for people with three-letter
174 - The week prior to Fri Jun 16 19:37:09 UTC 2000
175 - Rethought the rendezvous stuff. DEFINIT WORK IN PROGRESS
176 - Do not bother trying to use this. This will probably break
177 your clients. You may or may not want to fix them, since
178 I may change it again soon.
179 - I REPEAT: This really is a developer-only version. It barely
180 compiles. I'm just committing it so I don't have so many
181 trees floating around.
182 - Added stuff to support OFT as well as OSCAR protocols
183 - Added aim_send_im_direct() for directim ("IM Image")
184 - Added caps getting/putting routines
185 - Added more aim_login fixes to avoid more AOL stupidity
186 - This is the same as went to libfaim-devel yesterday, so don't upgrade
187 just to get these changes.
188 - Removed aimicq_encode_password -- now use the same table
192 - Tue Jun 6 01:36:48 UTC 2000
193 - Inverted gethostbyname2() check. Not sure how that ended up
195 - Added some of the initial framework to support file transfers
196 - Added in a few checks for that
197 - Can currently parse and send a denial message.
198 - Added cookie caching. (Sorry, I just like saying that.)
199 - Rearranged channel 2 ICBM parsing (detects the different
200 rendezvous types better and hopefully accuratly).
201 - Killed the connection array. Now a list. (Suits the
202 upcoming features better.) --- REQUIRES CLIENT CHANGES...
203 - In most cases, you need to change aim_conn_close() calls
204 to aim_conn_kill(). This will free them as well as
205 close them. If you don't do this, you'll pollute the
206 connection list and leak memory.
207 - Possibly a few other minor things (some cleanups to faimtest for one)
209 - Fri Jun 2 23:27:28 UTC 2000
210 - Cleaned up aim_send_login slightly
211 - Added aimicq_encode_password to support the new hash
212 values required for logging in with ICQ
213 - Removed crash when email and/or reg status aren't
214 in the auth response (they're not in ICQ responses)
215 - So now as long as you specify a client version of
216 4.30.3141 in the client info, and your ICQ number
217 as your screen name, you can login to ICQ via libfaim
218 and use it just like an AIM account.
219 - Added AIM_CB_SPECIAL_CONNERR callback for recieving
220 messages such as disconnect reasonses ("you logged
221 on from a different machine", etc).
222 - Added faimtest's userinfo handler to support away messages
224 - Fri Jun 2 15:57:27 UTC 2000
225 - Add creation time, maxmsglen, and various unknowns to chat info
227 - Remove 'nothing works yet' comment from top of aim_chat.c (it works!)
229 - Wed May 31 01:17:24 UTC 2000
230 - Added constants for message sizes (MAXMSGLEN, MAXCHATMSGLEN)
231 - Note that the new max message size is defined as 7988bytes,
232 drastically larger than WinAIM lets you put out. This is a
233 libfaim-exclusive feature :)
234 - Reduced base buffer size on aim_send_im()
236 - Tue May 30 22:32:31 UTC 2000
237 - Added lock around tx seqnum to prevent that race when transmitting
238 from diverse threads. (actually committed earlier today)
239 - Added aim_meta.c and a few constants and things to keep
241 - Added mkbuildinfo.sh to automatically update build string
242 "constants" on every invocation of 'make all'.
244 - Mon May 29 12:08:28 GMT 2000
245 - Rearranged aim_tx_flushqueue(); moved write operation
246 to aim_tx_sendframe()
247 - Turned aim_tx_enqueue() into a macro that calls sess->tx_enqueue,
248 a function pointer to whatever you want to use to enqueue
249 things for transmition (or not)
250 - Old aim_tx_enqueue becomes aim_tx_enqueue__queuebased. Added
251 aim_tx_enqueue__immediate for doing immediate writes. Default
252 is to use queue-based procedure.
253 - Cleaned up parts of aim_conn.c
254 - Added locking around the sockets themselves. Should allow
255 for full cross-thread usage.
256 - Unfortunatly, only pthreads are supported at this time.
257 If you don't have pthreads on your arch, implement the
258 macros your arch needs and send me a patch. (A SysV
259 semaphore implementation would be trivial, as would a
260 simple integer-based lock.)
262 - Sun May 21 14:59:20 GMT 2000
263 - Added infotype parameter to aim_getinfo() for requesting
264 different types of messages. AIM_GETINFO_GENERALINFO
265 will get you the normal stuff, AIM_GETINFO_AWAYMESSAGE
266 will get the normal stuff, with the profile replaced with
267 the user's away message. Also, the callback adds an
268 unsigned short to the end to give you the value that
269 was originally passed to the request.
270 - There were a few server-pertinent changes that didn't get
271 documented from last month. I have no idea what they were.
273 - Sun Apr 2 07:29:11 UTC 2000
274 - Redid much of the tx path to remove the superfluous copy. But
275 it touches every function that transmits. Its been a long
277 - Added caps parameter to aim_bos_setprofile(). You can now
278 control what capabilties you show up as others to
279 - Added ->capabilities to userinfo. It should be nonzero when
280 its coming off buddy oncoming information, but NOT requested
283 - Sun Apr 2 01:45:15 UTC 2000
284 - Increased AIM_CONN_MAX from 5 to 7. Precausionary only
285 - Removed deprecated TIS_TELNET_PROXY from faim/faimconfig.h
286 - Added macros for the simple integer functions in aim_util.c
287 - Removed usage of aim_failsaferead()
288 - Still not sure why I had it to begin with. I think it
289 was a remament from when we used non-blocking sockets
290 (which I don't know why I did either)
291 - Removed some of the oddities in aim_get_command()
292 - gprof showed this taking 20kns on my k6-300. Should be faster now.
293 - Added conn parameter. This should prevent aim_select() from
294 getting called too many times in a row.
296 - Thu Mar 23 08:45:40 UTC 2000
297 - Removed aim_countconn() > 0 check in aim_select(), its logically redundent
298 - Added aim_putuserinfo() (inverse of aim_extractuserinfo())
299 - Added aim_sendbuddyoncoming/offgoing()
300 - Rearranged loop in rxdispatch()
301 - Remove aim_conn_close() if connections dead in aim_get_command()
303 - Thu Mar 23 00:44:32 UTC 2000
304 - Added a check to purge_rxqueue to skip handled commands
306 - Mon Mar 20 05:30:59 UTC 2000
307 - Added some server-only functions for login
308 - Added aim_counttlvchain()
309 - Added aim_sncmp() and aim_snlen()
311 - Sun Mar 19 06:07:52 UTC 2000
312 - Added a parameter to aim_select to return event type
313 - REQUIRES CLIENT CHANGES.
314 - For the most part rewrote the tx and rx queuing code
315 - Should fix many, many outstanding problems in and related
316 to that code, including one that keeps memory from freeing
317 - Fixed several bugs in various places
318 - Reformated a lot of code, and did general cleanups
319 - Should have a generally more robust lib now.
321 - Sun Mar 12 00:07:40 UTC 2000
322 - Fixed a robustness problem in aim_handleredirect_middle()
323 - Added TLV chain creation routines (yes, aimd is progressing)
325 - Mon Jan 3 04:07:55 UTC 2000
326 - Fixed bug in aim_snac.c
327 - Fixed condition where commands read from connections that have
328 been closed were still left in the queue. Now cancelled.
329 - Added some printfs to aim_info to get more informative crahes
330 - Fixed a bug in aim_rxqueue::purge
332 - Sun Jan 2 10:31:19 UTC 2000
333 - Cleanups in aim_info.c
334 - Can compile with -Ddebug=100 again
335 - Implemented chat: Joining/Leaving, info parsing, IM parsing/sending
336 - Implemented some chatnav: rights req/parsing, room creation
338 - Thu Dec 30 10:08:42 UTC 1999
339 - Fixed bug in aim_im.c when (encoding == NULL) || (lang == NULL)
340 - Added detection of voice chat requests
341 - Added AIM_CLASS_* defines, including new Away flag
342 - Added awaymsg parameter to bos_setprofile.
343 - If awaymsg is nonnull, you will be advertised as being away (your
344 class will be ORed with AIM_CLASS_AWAY), otherwise you'll show
347 - Wed Dec 29 10:06:35 UTC 1999
348 - Fixed small bug in IM parser
349 - Added stubs for the capability TLVs in userinfo.
351 - Wed Dec 29 09:14:45 UTC 1999
352 - Added a capability block to aim_bos_setprofile. Can now get chat
354 - Extended ICBM parser to support channel 2 messages (chat invites)
355 - A channel parameter has been prepended to the varargs -- REQUIRES
357 - Extended faimtest to support chat invites.
358 - Changed faimtest to get sn/password from environment
360 - Wed Dec 29 04:17:03 UTC 1999
362 - Added aim_sendconnack() to aim_login.c (needed for newer login)
363 - Added code for the new SNAC-based login/auth procedure. (see SNACLOGIN
364 in faim/faimconfig.h for why its not enabled)
365 - Reimplemented aim_authparse(), aim_handleredirect() using TLVlists
366 - The old auth_failed callback is now integrated into the
367 success one. If there was an error, logininfo->errorcode is nonzero
368 - Fiddled with version information. Added aim_setversions()
369 - Added table of SNAC names for showing unknown snacs (jbm)
370 - Added a middle handler for MOTD
371 - Added new authorization SNACs to faim/aim_cbtypes.h
373 - Sun Dec 26 22:59:10 UTC 1999
374 - Renamed login_phase1_struct to aim_login_struct
375 - Changed cookie and sn to be static arrays in aim_login_struct
376 - Integrated the Jabber-faim changes. (temas) [BIG CLIENT CHANGES]
377 - Added aim_session_t, removed all global variables
378 - Changed all functions to accept a session pointer
379 - Removed aim_global.c
380 - Updated faimtest to use an aim_session_t.
381 - Removed all cases where logininfo was passed as vararg to client
382 - Fixed small bug in aim_newconn's 'fixing' of host:port addresses
383 - Added an install rule to the makefile (installs headers+so only!)
384 - Enabled USE_SNAC_FOR_IMS by default, assuming it got fixed
385 by n's new aim_snac.c from ages ago
386 - Implemented a middle handler for 0004/0001 message errors, added
387 snacid lookup to get illfated destination SN and pass to client
388 - Implemented a short middle handler for offgoing buddy.
390 - Fri Dec 24 21:30:06 UTC 1999
391 - Added an error-counting Read() that has been sitting in my inbox
392 - Cleaned up header files, created aim_cbtypes.h.
393 - Added void * to aim_conn_t for private client use if they want. (Orb)
394 - Removed all stderr output. All output is important, and goes to stdout.
395 - Renamed isautoresponse in IM parser to icbmflags.
396 - Added Orb's fix for the new login code, deleted old (see Orb, I do read
397 your mail....eventually).
398 - Added mailing lists to README.
400 - Fri Dec 24 11:12:34 UTC 1999
401 - Cleaned up both outgoing and incoming ICBM handling. Anything
402 that crashes around there is no longer libfaims fault!
403 - The encoding flags are now passed up to the client.
404 - Added several TLV routines to parse large blocks of continuous
405 TLV triplets. Not terribly effecient, but quite elegent in usage.
406 - Added icbm_setparams() back in from way-back-long-ago. It hasn't
407 been implemented in a long time, but I think we should still send it.
409 - Fri Dec 24 01:23:06 UTC 1999
410 - Fixed a very minor bug in aim_newconn().
411 - Added aimutil_get{16,32}()
412 - Added aim_extractuserinfo() for extracting user data
413 blocks and putting them into struct aim_userinfo_s's.
414 - Added a loop to print out info on extraneous TLVs.
415 - Put in lots of comments.
416 - Added parse_oncoming_middle() to parse the user data
417 block of that packet. Now passes struct aim_userinfo_s
419 - Rearranged parse_userinfo_middle(). Now passes an entire
420 userinfo struct to client instead of individual variables.
421 - Convered the version of parse_im_middle() thats actually getting
422 used to pass up a userinfo struct.
423 - Updated faimtest to accept new structs.
425 - Tue Dec 21 06:18:50 UTC 1999
426 - Fixed a Win32 header problem
427 - Tue Dec 21 03:44:13 UTC 1999
428 - Latency timers now update on rx as well as tx. Gets rid of even more
429 of the rate problems that most clients are having.
430 - Renamed lasttx and settxlatency to lastactivity and setlatency, respec.
431 - Integrated fixes needed for Win32 -- should compile cleanly now (DMP)
432 - Cleaned up some places, use aim_putsnac everywhere now.
434 - Sun Sep 26 20:04:20 MST 1999
435 - Reduced the IM parsing to look for 3 zeros instead of 4 -- NEEDS WORK
436 - This was needed to work with MacAIM3 and some WinAIM3s.
437 - Added aim_conn_settxlatency() for throttling outgoing frames -- NEEDS WORK
438 - Added an int to the userinfo and incoming IM user callbacks for new
439 TLV that AOL put it in -- its the number of seconds elapsed since
441 - Worked more on the callbacks (more internal rearrangements)
442 - Fixed bug in aim_select() (returning negative fds)
443 - Clear out logininfo struct before putting more data into it
444 - Other bugfixes that I can't particularly remember.
446 - Tue Aug 24 03:13:12 UTC 1999 --- TRANSITION RELEASE!!
447 - Added jbm's new aim_rxqueue.c, which should crash less
448 - Started the overhaul on the callback system. No where near complete yet.
450 - Sun Aug 1 03:02:17 UTC 1999
451 - Added aimutil_*()s in aim_util.c for raw byte placement
452 - Cleaned up aim_im.c, aim_auth.c, and aim_login.c using aimutil_*
453 - Added AIM_IMFLAGS, flags option to aim_send_im(), removed
455 - Added client_info parameter to aim_send_login()
456 - Tweaked aim_send_im() (AOL changed a few things, there's some more
458 - Some Chat stuff changed, still no where near functional
459 - Finally remembered to switch the license to LGPL (from GPL)
460 - Permit/Deny (blocking) list support added
461 - Released a snapshot
463 - Sat Jul 31 05:28:38 UTC 1999
464 - Changed aim_bos_setdeny() to aim_bos_changevisibility() and actually
465 did the implementation.
467 - Fri Jul 23 17:45:22 UTC 1999
468 - Work around for the AOL change in IP syntax (thanks to Eric Peyton)
471 - Sun Apr 25 23:31:44 UTC 1999
472 - Fixed stupid off-by-one bug in aim_logoff()
474 - Sun Apr 25 22:43:31 UTC 1999
475 - Renamed/reclassified missed IM errors (now all callbacks -- no backend handling)
476 - Killed aim_login() -- all connections now opened in frontend
477 - aim_conn_close() will not close fd's < 3
480 - Sat Apr 10 22:44:07 UTC 1999
481 - Changed how rx_command->handled works; now uses return value from callback
482 - Changed the if's in the dispatcher (aim_rxhandlers.c) to switch()es
484 - Sat Apr 10 03:51:21 UTC 1999
486 - Put in n's aim_snac.c.
487 - Updated aim_{add,remove}_buddy() to use aim_conn
488 - Updated aim_usersearch_address() to use aim_conn
489 - Cleaned up aim.h a bit (removed old *phase* protos)
490 - Changed gethostbyname() to gethostbyname2() (for MacOS X)
491 - Changed aim_newconn() to pass connection errors in connstruct->status
492 - Updated faimtest.c to detect connection errors
493 - Fixed a small typo in aim_im::aim_parse_incoming_im_middle()
494 - Added free()s in that function and to userinfo counterpart (fewer leaks)
497 - Sat Apr 3 06:43:14 UTC 1999
500 - Wed Dec 30 01:20:59 MST 1998
503 - Mon Dec 7 16:57:57 MST 1998
506 - Sat Dec 5 00:01:53 MST 1998
509 - Thu Nov 26 17:50:02 MST 1998