]>
Commit | Line | Data |
---|---|---|
9de3ca7e | 1 | |
37ee990e | 2 | #define FAIM_INTERNAL |
dd60ff8b | 3 | #include <aim.h> |
9de3ca7e | 4 | |
5 | /* | |
6 | * aim_add_buddy() | |
7 | * | |
8 | * Adds a single buddy to your buddy list after login. | |
9 | * | |
37ee990e | 10 | * XXX this should just be an extension of setbuddylist() |
11 | * | |
9de3ca7e | 12 | */ |
78b3fb13 | 13 | faim_export unsigned long aim_add_buddy(struct aim_session_t *sess, |
14 | struct aim_conn_t *conn, | |
15 | char *sn ) | |
9de3ca7e | 16 | { |
5b79dc93 | 17 | struct command_tx_struct *newpacket; |
18 | int i; | |
9de3ca7e | 19 | |
5b79dc93 | 20 | if(!sn) |
21 | return -1; | |
9de3ca7e | 22 | |
646c6b52 | 23 | if (!(newpacket = aim_tx_new(sess, conn, AIM_FRAMETYPE_OSCAR, 0x0002, 10+1+strlen(sn)))) |
5b79dc93 | 24 | return -1; |
9de3ca7e | 25 | |
5b79dc93 | 26 | newpacket->lock = 1; |
9de3ca7e | 27 | |
5b79dc93 | 28 | i = aim_putsnac(newpacket->data, 0x0003, 0x0004, 0x0000, sess->snac_nextid); |
29 | i += aimutil_put8(newpacket->data+i, strlen(sn)); | |
30 | i += aimutil_putstr(newpacket->data+i, sn, strlen(sn)); | |
9de3ca7e | 31 | |
5b79dc93 | 32 | aim_tx_enqueue(sess, newpacket ); |
9de3ca7e | 33 | |
1ea867e3 | 34 | aim_cachesnac(sess, 0x0003, 0x0004, 0x0000, sn, strlen(sn)+1); |
35 | ||
36 | return sess->snac_nextid; | |
9de3ca7e | 37 | } |
38 | ||
37ee990e | 39 | /* |
40 | * XXX generalise to support removing multiple buddies (basically, its | |
41 | * the same as setbuddylist() but with a different snac subtype). | |
42 | * | |
43 | */ | |
78b3fb13 | 44 | faim_export unsigned long aim_remove_buddy(struct aim_session_t *sess, |
45 | struct aim_conn_t *conn, | |
46 | char *sn ) | |
9de3ca7e | 47 | { |
5b79dc93 | 48 | struct command_tx_struct *newpacket; |
49 | int i; | |
9de3ca7e | 50 | |
5b79dc93 | 51 | if(!sn) |
52 | return -1; | |
9de3ca7e | 53 | |
646c6b52 | 54 | if (!(newpacket = aim_tx_new(sess, conn, AIM_FRAMETYPE_OSCAR, 0x0002, 10+1+strlen(sn)))) |
5b79dc93 | 55 | return -1; |
9de3ca7e | 56 | |
5b79dc93 | 57 | newpacket->lock = 1; |
9de3ca7e | 58 | |
5b79dc93 | 59 | i = aim_putsnac(newpacket->data, 0x0003, 0x0005, 0x0000, sess->snac_nextid); |
9de3ca7e | 60 | |
5b79dc93 | 61 | i += aimutil_put8(newpacket->data+i, strlen(sn)); |
62 | i += aimutil_putstr(newpacket->data+i, sn, strlen(sn)); | |
9de3ca7e | 63 | |
5b79dc93 | 64 | aim_tx_enqueue(sess, newpacket); |
9de3ca7e | 65 | |
1ea867e3 | 66 | aim_cachesnac(sess, 0x0003, 0x0005, 0x0000, sn, strlen(sn)+1); |
9de3ca7e | 67 | |
1ea867e3 | 68 | return sess->snac_nextid; |
9de3ca7e | 69 | } |
70 | ||
78b3fb13 | 71 | faim_internal int aim_parse_buddyrights(struct aim_session_t *sess, |
72 | struct command_rx_struct *command, ...) | |
96f8b1ed | 73 | { |
74 | rxcallback_t userfunc = NULL; | |
75 | int ret=1; | |
76 | struct aim_tlvlist_t *tlvlist; | |
96f8b1ed | 77 | unsigned short maxbuddies = 0, maxwatchers = 0; |
78 | ||
79 | /* | |
80 | * TLVs follow | |
81 | */ | |
82 | if (!(tlvlist = aim_readtlvchain(command->data+10, command->commandlen-10))) | |
83 | return ret; | |
84 | ||
85 | /* | |
86 | * TLV type 0x0001: Maximum number of buddies. | |
87 | */ | |
1ea867e3 | 88 | if (aim_gettlv(tlvlist, 0x0001, 1)) |
89 | maxbuddies = aim_gettlv16(tlvlist, 0x0001, 1); | |
96f8b1ed | 90 | |
91 | /* | |
92 | * TLV type 0x0002: Maximum number of watchers. | |
93 | * | |
94 | * XXX: what the hell is a watcher? | |
95 | * | |
96 | */ | |
1ea867e3 | 97 | if (aim_gettlv(tlvlist, 0x0002, 1)) |
98 | maxwatchers = aim_gettlv16(tlvlist, 0x0002, 1); | |
96f8b1ed | 99 | |
646c6b52 | 100 | if ((userfunc = aim_callhandler(sess, command->conn, 0x0003, 0x0003))) |
96f8b1ed | 101 | ret = userfunc(sess, command, maxbuddies, maxwatchers); |
102 | ||
103 | aim_freetlvchain(&tlvlist); | |
104 | ||
105 | return ret; | |
106 | } |