Mercurial > pidgin.yaz
diff libfaim/aim_misc.c @ 829:9a123b171f46
[gaim-migrate @ 839]
yay. i have a secret. but basically this should fix most outstanding libfaim issues in gaim.
committer: Tailor Script <tailor@pidgin.im>
author | Eric Warmenhoven <eric@warmenhoven.org> |
---|---|
date | Sat, 02 Sep 2000 02:41:57 +0000 |
parents | 72e556f6b99d |
children | 88f8f98de02d |
line wrap: on
line diff
--- a/libfaim/aim_misc.c Fri Sep 01 23:45:43 2000 +0000 +++ b/libfaim/aim_misc.c Sat Sep 02 02:41:57 2000 +0000 @@ -142,65 +142,61 @@ struct command_tx_struct *newpacket; - int packet_login_phase3c_hi_b_len = 0; + int len = 0; char *localcpy = NULL; char *tmpptr = NULL; - packet_login_phase3c_hi_b_len = 16; /* 16b for FLAP and SNAC headers */ + len = 10; /* 10B SNAC headers */ - /* bail out if we can't make the packet */ - if (!buddy_list) { + if (!buddy_list || !(localcpy = (char *) malloc(strlen(buddy_list)+1))) return -1; - } - - localcpy = (char *) malloc(strlen(buddy_list)+1); - memcpy(localcpy, buddy_list, strlen(buddy_list)+1); + strncpy(localcpy, buddy_list, strlen(buddy_list)+1); i = 0; tmpptr = strtok(localcpy, "&"); - while ((tmpptr != NULL) && (i < 100)) - { + while ((tmpptr != NULL) && (i < 150)) { #if debug > 0 - printf("---adding %s (%d)\n", tmpptr, strlen(tmpptr)); + printf("---adding %d: %s (%d)\n", i, tmpptr, strlen(tmpptr)); #endif - packet_login_phase3c_hi_b_len += strlen(tmpptr)+1; - i++; - tmpptr = strtok(NULL, "&"); - } + len += 1+strlen(tmpptr); + i++; + tmpptr = strtok(NULL, "&"); + } #if debug > 0 - printf("*** send buddy list len: %d (%x)\n", packet_login_phase3c_hi_b_len, packet_login_phase3c_hi_b_len); + printf("*** send buddy list len: %d (%x)\n", len, len); #endif - free(localcpy); - if (!(newpacket = aim_tx_new(AIM_FRAMETYPE_OSCAR, 0x0002, conn, packet_login_phase3c_hi_b_len - 6))) + if (!(newpacket = aim_tx_new(AIM_FRAMETYPE_OSCAR, 0x0002, conn, len))) return -1; newpacket->lock = 1; - aim_putsnac(newpacket->data, 0x0003, 0x0004, 0x0000, sess->snac_nextid); + aim_putsnac(newpacket->data, 0x0003, 0x0004, 0x0000, 0); j = 10; /* the next byte */ + strncpy(localcpy, buddy_list, strlen(buddy_list)+1); i = 0; - tmpptr = strtok(buddy_list, "&"); - while ((tmpptr != NULL) & (i < 100)) - { + tmpptr = strtok(localcpy, "&"); + while ((tmpptr != NULL) & (i < 150)) { #if debug > 0 - printf("---adding %s (%d)\n", tmpptr, strlen(tmpptr)); + printf("---adding %d: %s (%d)\n", i, tmpptr, strlen(tmpptr)); #endif - newpacket->data[j] = strlen(tmpptr); - memcpy(&(newpacket->data[j+1]), tmpptr, strlen(tmpptr)); - j += strlen(tmpptr)+1; - i++; - tmpptr = strtok(NULL, "&"); - } + newpacket->data[j] = strlen(tmpptr); + memcpy(&(newpacket->data[j+1]), tmpptr, strlen(tmpptr)); + j += 1+strlen(tmpptr); + i++; + tmpptr = strtok(NULL, "&"); + } newpacket->lock = 0; aim_tx_enqueue(sess, newpacket); - return (sess->snac_nextid++); + free(localcpy); + + return (sess->snac_nextid); } /* @@ -283,7 +279,8 @@ 0x00, 0x01, 0x00, 0x03, 0x00, 0x04, - 0x06, 0x86, + 0x07, 0xda, + 0x00, 0x02, 0x00, 0x01, 0x00, 0x04, @@ -292,7 +289,8 @@ 0x00, 0x03, 0x00, 0x01, 0x00, 0x04, - 0x00, 0x01, + 0x00, 0x01, + 0x00, 0x04, 0x00, 0x01, 0x00, 0x04, @@ -357,28 +355,23 @@ struct aim_conn_t *conn) { struct command_tx_struct *newpacket; - int packlen = 18, i=0; + int packlen = 20, i=0; - if (conn->type != AIM_CONN_TYPE_BOS) - packlen += 2; - - if(!(newpacket = aim_tx_new(AIM_FRAMETYPE_OSCAR, 0x0002, conn, packlen))); + if(!(newpacket = aim_tx_new(AIM_FRAMETYPE_OSCAR, 0x0002, conn, packlen))) + return (sess->snac_nextid); newpacket->lock = 1; - i = aim_putsnac(newpacket->data, 0x0001, 0x0008, 0x0000, sess->snac_nextid); + i = aim_putsnac(newpacket->data, 0x0001, 0x0008, 0x0000, 0); i += aimutil_put16(newpacket->data+i, 0x0001); i += aimutil_put16(newpacket->data+i, 0x0002); i += aimutil_put16(newpacket->data+i, 0x0003); i += aimutil_put16(newpacket->data+i, 0x0004); + i += aimutil_put16(newpacket->data+i, 0x0005); - if (conn->type != AIM_CONN_TYPE_BOS) { - i += aimutil_put16(newpacket->data+i, 0x0005); - } - aim_tx_enqueue(sess, newpacket); - return (sess->snac_nextid++); + return (sess->snac_nextid); } /* @@ -407,22 +400,7 @@ u_long aim_bos_reqpersonalinfo(struct aim_session_t *sess, struct aim_conn_t *conn) { - struct command_tx_struct *newpacket; - - if (!(newpacket = aim_tx_new(AIM_FRAMETYPE_OSCAR, 0x0002, conn, 12))) - return -1; - - newpacket->lock = 1; - - aim_putsnac(newpacket->data, 0x000a, 0x0001, 0x000e /* huh? */, sess->snac_nextid); - - newpacket->data[10] = 0x0d; - newpacket->data[11] = 0xda; - - newpacket->lock = 0; - aim_tx_enqueue(sess, newpacket); - - return (sess->snac_nextid++); + return aim_genericreq_n(sess, conn, 0x0001, 0x000e); } u_long aim_setversions(struct aim_session_t *sess, @@ -431,7 +409,7 @@ struct command_tx_struct *newpacket; int i; - if (!(newpacket = aim_tx_new(AIM_FRAMETYPE_OSCAR, 0x0002, conn, 10 + (4*11)))) + if (!(newpacket = aim_tx_new(AIM_FRAMETYPE_OSCAR, 0x0002, conn, 10 + (4*12)))) return -1; newpacket->lock = 1; @@ -468,6 +446,9 @@ i += aimutil_put16(newpacket->data+i, 0x000c); i += aimutil_put16(newpacket->data+i, 0x0001); + i += aimutil_put16(newpacket->data+i, 0x0013); + i += aimutil_put16(newpacket->data+i, 0x0001); + i += aimutil_put16(newpacket->data+i, 0x0015); i += aimutil_put16(newpacket->data+i, 0x0001); @@ -694,3 +675,31 @@ return aim_genericreq_n(sess, conn, 0x0004, 0x0004); } +/* + * Add ICBM parameter? Huh? + */ +unsigned long aim_addicbmparam(struct aim_session_t *sess, + struct aim_conn_t *conn) +{ + struct command_tx_struct *newpacket; + int packlen = 10+16, i=0; + + if(!(newpacket = aim_tx_new(AIM_FRAMETYPE_OSCAR, 0x0002, conn, packlen))) + return (sess->snac_nextid); + + newpacket->lock = 1; + + i = aim_putsnac(newpacket->data, 0x0004, 0x0002, 0x0000, sess->snac_nextid); + i += aimutil_put16(newpacket->data+i, 0x0000); + i += aimutil_put16(newpacket->data+i, 0x0000); + i += aimutil_put16(newpacket->data+i, 0x0003); + i += aimutil_put16(newpacket->data+i, 0x1f40); + i += aimutil_put16(newpacket->data+i, 0x03e7); + i += aimutil_put16(newpacket->data+i, 0x03e7); + i += aimutil_put16(newpacket->data+i, 0x0000); + i += aimutil_put16(newpacket->data+i, 0x0000); + + aim_tx_enqueue(sess, newpacket); + + return (sess->snac_nextid); +}