* Adds a single buddy to your buddy list after login.
*
*/
-u_long aim_add_buddy(struct aim_session_t *sess,
- struct aim_conn_t *conn,
- char *sn )
+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(0x0002, conn, 10+1+strlen(sn))))
+ if (!(newpacket = aim_tx_new(AIM_FRAMETYPE_OSCAR, 0x0002, conn, 10+1+strlen(sn))))
return -1;
newpacket->lock = 1;
aim_tx_enqueue(sess, newpacket );
+#if 0 /* do we really need this code? */
{
struct aim_snac_t snac;
aim_newsnac(sess, &snac);
}
+#endif
return( sess->snac_nextid++ );
}
-u_long aim_remove_buddy(struct aim_session_t *sess,
- struct aim_conn_t *conn,
- char *sn )
+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(0x0002, conn, 10+1+strlen(sn))))
+ if (!(newpacket = aim_tx_new(AIM_FRAMETYPE_OSCAR, 0x0002, conn, 10+1+strlen(sn))))
return -1;
newpacket->lock = 1;
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;
+}