Mercurial > pidgin.yaz
view libfaim/aim_buddylist.c @ 1030:38452403563b
[gaim-migrate @ 1040]
updating the buddy list to work better with multiple connections. there are still a bunch of things fucked up with this but i wanted more people to start working on it than just me, especially since i won't be here this weekend.
committer: Tailor Script <tailor@pidgin.im>
author | Eric Warmenhoven <eric@warmenhoven.org> |
---|---|
date | Fri, 27 Oct 2000 07:53:32 +0000 |
parents | 595ac7759563 |
children | 920c86b753d7 |
line wrap: on
line source
#include <faim/aim.h> /* * aim_add_buddy() * * Adds a single buddy to your buddy list after login. * */ faim_export unsigned long aim_add_buddy(struct aim_session_t *sess, struct aim_conn_t *conn, char *sn ) { struct command_tx_struct *newpacket; int i; if(!sn) return -1; if (!(newpacket = aim_tx_new(AIM_FRAMETYPE_OSCAR, 0x0002, conn, 10+1+strlen(sn)))) return -1; newpacket->lock = 1; i = aim_putsnac(newpacket->data, 0x0003, 0x0004, 0x0000, sess->snac_nextid); i += aimutil_put8(newpacket->data+i, strlen(sn)); i += aimutil_putstr(newpacket->data+i, sn, strlen(sn)); aim_tx_enqueue(sess, newpacket ); #if 0 /* do we really need this code? */ { struct aim_snac_t snac; snac.id = sess->snac_nextid; snac.family = 0x0003; snac.type = 0x0004; snac.flags = 0x0000; snac.data = malloc( strlen( sn ) + 1 ); memcpy( snac.data, sn, strlen( sn ) + 1 ); aim_newsnac(sess, &snac); } #endif return( sess->snac_nextid++ ); } faim_export unsigned long aim_remove_buddy(struct aim_session_t *sess, struct aim_conn_t *conn, char *sn ) { struct command_tx_struct *newpacket; int i; if(!sn) return -1; if (!(newpacket = aim_tx_new(AIM_FRAMETYPE_OSCAR, 0x0002, conn, 10+1+strlen(sn)))) return -1; newpacket->lock = 1; i = aim_putsnac(newpacket->data, 0x0003, 0x0005, 0x0000, sess->snac_nextid); i += aimutil_put8(newpacket->data+i, strlen(sn)); i += aimutil_putstr(newpacket->data+i, sn, strlen(sn)); aim_tx_enqueue(sess, newpacket); { struct aim_snac_t snac; snac.id = sess->snac_nextid; snac.family = 0x0003; snac.type = 0x0005; snac.flags = 0x0000; snac.data = malloc( strlen( sn ) + 1 ); memcpy( snac.data, sn, strlen( sn ) + 1 ); aim_newsnac(sess, &snac ); } return( sess->snac_nextid++ ); } faim_internal int aim_parse_buddyrights(struct aim_session_t *sess, struct command_rx_struct *command, ...) { rxcallback_t userfunc = NULL; int ret=1; struct aim_tlvlist_t *tlvlist; struct aim_tlv_t *tlv; unsigned short maxbuddies = 0, maxwatchers = 0; /* * TLVs follow */ if (!(tlvlist = aim_readtlvchain(command->data+10, command->commandlen-10))) return ret; /* * TLV type 0x0001: Maximum number of buddies. */ if ((tlv = aim_gettlv(tlvlist, 0x0001, 1))) { maxbuddies = aimutil_get16(tlv->value); } /* * TLV type 0x0002: Maximum number of watchers. * * XXX: what the hell is a watcher? * */ if ((tlv = aim_gettlv(tlvlist, 0x0002, 1))) { maxwatchers = aimutil_get16(tlv->value); } userfunc = aim_callhandler(command->conn, 0x0003, 0x0003); if (userfunc) ret = userfunc(sess, command, maxbuddies, maxwatchers); aim_freetlvchain(&tlvlist); return ret; }