Mercurial > pidgin
changeset 4805:a7e99eb2c0f2
[gaim-migrate @ 5125]
Note to self:
cvs add THEN cvs commit
committer: Tailor Script <tailor@pidgin.im>
author | Mark Doliner <mark@kingant.net> |
---|---|
date | Mon, 17 Mar 2003 04:03:01 +0000 |
parents | 9810ce8e7a96 |
children | 315ef59a5031 |
files | src/protocols/oscar/icon.c |
diffstat | 1 files changed, 103 insertions(+), 0 deletions(-) [+] |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/protocols/oscar/icon.c Mon Mar 17 04:03:01 2003 +0000 @@ -0,0 +1,103 @@ +/* + * Family 0x0010 - Server stored buddy icons + * + * Used for storing and retrieving your cute little buddy icon + * from the AIM servers. + * + */ + +#define FAIM_INTERNAL +#include <aim.h> + +/** + * Subtype 0x0004 - Request someone's icon. + * + * @param sess The oscar session. + * @param conn The icon connection for this session. + * @return Return 0 if no errors, otherwise return the error number. + */ +faim_export int aim_icon_requesticon(aim_session_t *sess, const char *sn, const fu8_t *iconstr, fu16_t iconstrlen) +{ + aim_conn_t *conn; + aim_frame_t *fr; + aim_snacid_t snacid; + + if (!sess || !(conn = aim_conn_findbygroup(sess, 0x0010)) || !sn || !strlen(sn) || !iconstr || !iconstrlen) + return -EINVAL; + + if (!(fr = aim_tx_new(sess, conn, AIM_FRAMETYPE_FLAP, 0x02, 10 + 1+strlen(sn) + 1 + iconstrlen))) + return -ENOMEM; + snacid = aim_cachesnac(sess, 0x0010, 0x0004, 0x0000, NULL, 0); + aim_putsnac(&fr->data, 0x0010, 0x0004, 0x0000, snacid); + + /* Screen name */ + aimbs_put8(&fr->data, strlen(sn)); + aimbs_putraw(&fr->data, sn, strlen(sn)); + + /* The number "1" */ + aimbs_put8(&fr->data, 0x01); + + /* Icon string */ + aimbs_putraw(&fr->data, iconstr, iconstrlen); + + aim_tx_enqueue(sess, fr); + + return 0; +} + + +/** + * Subtype 0x0005 - Receive a buddy icon. + * + * This is sent in response to a buddy icon request. + */ +static int parseicon(aim_session_t *sess, aim_module_t *mod, aim_frame_t *rx, aim_modsnac_t *snac, aim_bstream_t *bs) +{ + aim_rxcallback_t userfunc; + int i; + char *sn; + fu16_t iconstrlen, iconlen; + fu8_t iconstr[30], *icon; + + sn = aimbs_getstr(bs, aimbs_get8(bs)); + iconstr[0] = aimbs_get8(bs); + iconstr[1] = aimbs_get8(bs); + iconstr[2] = aimbs_get8(bs); + iconstr[3] = aimbs_get8(bs); + iconstrlen = iconstr[3] + 4; + for (i = 4; i < iconstrlen; i++) + iconstr[i] = aimbs_get8(bs); + iconlen = aimbs_get16(bs); + icon = aimbs_getraw(bs, iconlen); + + if ((userfunc = aim_callhandler(sess, rx->conn, snac->family, snac->subtype))) + return userfunc(sess, rx, sn, iconstr, iconstrlen, icon, iconlen); + + free(iconstr); + free(icon); + + return 0; +} + +static int snachandler(aim_session_t *sess, aim_module_t *mod, aim_frame_t *rx, aim_modsnac_t *snac, aim_bstream_t *bs) +{ + + if (snac->subtype == 0x0005) + return parseicon(sess, mod, rx, snac, bs); + + return 0; +} + +faim_internal int icon_modfirst(aim_session_t *sess, aim_module_t *mod) +{ + + mod->family = 0x0010; + mod->version = 0x0001; + mod->toolid = 0x0010; + mod->toolversion = 0x0629; + mod->flags = 0; + strncpy(mod->name, "icon", sizeof(mod->name)); + mod->snachandler = snachandler; + + return 0; +}