Annotation of ChivanetAimPidgin/oscarprpl/src/c/family_alert.c, revision 1.1.1.1
1.1       snw         1: /*
                      2:  * Purple's oscar protocol plugin
                      3:  * This file is the legal property of its developers.
                      4:  * Please see the AUTHORS file distributed alongside this file.
                      5:  *
                      6:  * This library is free software; you can redistribute it and/or
                      7:  * modify it under the terms of the GNU Lesser General Public
                      8:  * License as published by the Free Software Foundation; either
                      9:  * version 2 of the License, or (at your option) any later version.
                     10:  *
                     11:  * This library is distributed in the hope that it will be useful,
                     12:  * but WITHOUT ANY WARRANTY; without even the implied warranty of
                     13:  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
                     14:  * Lesser General Public License for more details.
                     15:  *
                     16:  * You should have received a copy of the GNU Lesser General Public
                     17:  * License along with this library; if not, write to the Free Software
                     18:  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02111-1301  USA
                     19: */
                     20: 
                     21: /*
                     22:  * Family 0x0018 - Email notification
                     23:  *
                     24:  * Used for being alerted when the email address(es) associated with
                     25:  * your username get new electronic-m.  For normal AIM accounts, you
                     26:  * get the email address username@netscape.net.  AOL accounts have
                     27:  * username@aol.com, and can also activate a netscape.net account.
                     28:  * Note: This information might be out of date.
                     29:  */
                     30: 
                     31: #include "oscar.h"
                     32: 
                     33: /**
                     34:  * Subtype 0x0006 - Request information about your email account
                     35:  *
                     36:  * @param od The oscar session.
                     37:  * @param conn The email connection for this session.
                     38:  * @return Return 0 if no errors, otherwise return the error number.
                     39:  */
                     40: int
                     41: aim_email_sendcookies(OscarData *od)
                     42: {
                     43:        FlapConnection *conn;
                     44:        ByteStream bs;
                     45:        aim_snacid_t snacid;
                     46: 
                     47:        if (!od || !(conn = flap_connection_findbygroup(od, SNAC_FAMILY_ALERT)))
                     48:                return -EINVAL;
                     49: 
                     50:        byte_stream_new(&bs, 2+16+16);
                     51: 
                     52:        /* Number of cookies to follow */
                     53:        byte_stream_put16(&bs, 0x0002);
                     54: 
                     55:        /* Cookie */
                     56:        byte_stream_put16(&bs, 0x5d5e);
                     57:        byte_stream_put16(&bs, 0x1708);
                     58:        byte_stream_put16(&bs, 0x55aa);
                     59:        byte_stream_put16(&bs, 0x11d3);
                     60:        byte_stream_put16(&bs, 0xb143);
                     61:        byte_stream_put16(&bs, 0x0060);
                     62:        byte_stream_put16(&bs, 0xb0fb);
                     63:        byte_stream_put16(&bs, 0x1ecb);
                     64: 
                     65:        /* Cookie */
                     66:        byte_stream_put16(&bs, 0xb380);
                     67:        byte_stream_put16(&bs, 0x9ad8);
                     68:        byte_stream_put16(&bs, 0x0dba);
                     69:        byte_stream_put16(&bs, 0x11d5);
                     70:        byte_stream_put16(&bs, 0x9f8a);
                     71:        byte_stream_put16(&bs, 0x0060);
                     72:        byte_stream_put16(&bs, 0xb0ee);
                     73:        byte_stream_put16(&bs, 0x0631);
                     74: 
                     75:        snacid = aim_cachesnac(od, SNAC_FAMILY_ALERT, 0x0006, 0x0000, NULL, 0);
                     76:        flap_connection_send_snac(od, conn, SNAC_FAMILY_ALERT, 0x0006, snacid, &bs);
                     77: 
                     78:        byte_stream_destroy(&bs);
                     79: 
                     80:        return 0;
                     81: }
                     82: 
                     83: 
                     84: /**
                     85:  * Subtype 0x0007 - Receive information about your email account
                     86:  *
                     87:  * So I don't even know if you can have multiple 16 byte keys,
                     88:  * but this is coded so it will handle that, and handle it well.
                     89:  * This tells you if you have unread mail or not, the URL you
                     90:  * should use to access that mail, and the domain name for the
                     91:  * email account (username@domainname.com).  If this is the
                     92:  * first 0x0007 SNAC you've received since you signed on, or if
                     93:  * this is just a periodic status update, this will also contain
                     94:  * the number of unread emails that you have.
                     95:  */
                     96: static int
                     97: parseinfo(OscarData *od, FlapConnection *conn, aim_module_t *mod, FlapFrame *frame, aim_modsnac_t *snac, ByteStream *bs)
                     98: {
                     99:        int ret = 0;
                    100:        aim_rxcallback_t userfunc;
                    101:        struct aim_emailinfo *new;
                    102:        GSList *tlvlist;
                    103:        guint8 *cookie8, *cookie16;
                    104:        int tmp, havenewmail = 0; /* Used to tell the client we have _new_ mail */
                    105: 
                    106:        char *alertitle = NULL, *alerturl = NULL;
                    107: 
                    108:        cookie8 = byte_stream_getraw(bs, 8); /* Possibly the code used to log you in to mail? */
                    109:        cookie16 = byte_stream_getraw(bs, 16); /* Mail cookie sent above */
                    110: 
                    111:        /* See if we already have some info associated with this cookie */
                    112:        for (new = od->emailinfo; (new && memcmp(cookie16, new->cookie16, 16)); new = new->next);
                    113:        if (new) {
                    114:                /* Free some of the old info, if it exists */
                    115:                g_free(new->cookie8);
                    116:                g_free(new->cookie16);
                    117:                g_free(new->url);
                    118:                g_free(new->domain);
                    119:        } else {
                    120:                /* We don't already have info, so create a new struct for it */
                    121:                new = g_new0(struct aim_emailinfo, 1);
                    122:                new->next = od->emailinfo;
                    123:                od->emailinfo = new;
                    124:        }
                    125: 
                    126:        new->cookie8 = cookie8;
                    127:        new->cookie16 = cookie16;
                    128: 
                    129:        tlvlist = aim_tlvlist_readnum(bs, byte_stream_get16(bs));
                    130: 
                    131:        tmp = aim_tlv_get16(tlvlist, 0x0080, 1);
                    132:        if (tmp) {
                    133:                if (new->nummsgs < tmp)
                    134:                        havenewmail = 1;
                    135:                new->nummsgs = tmp;
                    136:        } else {
                    137:                /* If they don't send a 0x0080 TLV, it means we definitely have new mail */
                    138:                /* (ie. this is not just another status update) */
                    139:                havenewmail = 1;
                    140:                new->nummsgs++; /* We know we have at least 1 new email */
                    141:        }
                    142:        new->url = aim_tlv_getstr(tlvlist, 0x0007, 1);
                    143:        if (!(new->unread = aim_tlv_get8(tlvlist, 0x0081, 1))) {
                    144:                havenewmail = 0;
                    145:                new->nummsgs = 0;
                    146:        }
                    147:        new->domain = aim_tlv_getstr(tlvlist, 0x0082, 1);
                    148:        new->flag = aim_tlv_get16(tlvlist, 0x0084, 1);
                    149: 
                    150:        alertitle = aim_tlv_getstr(tlvlist, 0x0005, 1);
                    151:        alerturl  = aim_tlv_getstr(tlvlist, 0x000d, 1);
                    152: 
                    153:        if ((userfunc = aim_callhandler(od, snac->family, snac->subtype)))
                    154:                ret = userfunc(od, conn, frame, new, havenewmail, alertitle, (alerturl ? alerturl + 2 : NULL));
                    155: 
                    156:        aim_tlvlist_free(tlvlist);
                    157: 
                    158:        g_free(alertitle);
                    159:        g_free(alerturl);
                    160: 
                    161:        return ret;
                    162: }
                    163: 
                    164: /**
                    165:  * Subtype 0x0016 - Send something or other
                    166:  *
                    167:  * @param od The oscar session.
                    168:  * @param conn The email connection for this session.
                    169:  * @return Return 0 if no errors, otherwise return the error number.
                    170:  */
                    171: int
                    172: aim_email_activate(OscarData *od)
                    173: {
                    174:        FlapConnection *conn;
                    175:        ByteStream bs;
                    176:        aim_snacid_t snacid;
                    177: 
                    178:        if (!od || !(conn = flap_connection_findbygroup(od, SNAC_FAMILY_ALERT)))
                    179:                return -EINVAL;
                    180: 
                    181:        byte_stream_new(&bs, 1+16);
                    182: 
                    183:        /* I would guess this tells AIM that you want updates for your mail accounts */
                    184:        /* ...but I really have no idea */
                    185:        byte_stream_put8(&bs, 0x02);
                    186:        byte_stream_put32(&bs, 0x04000000);
                    187:        byte_stream_put32(&bs, 0x04000000);
                    188:        byte_stream_put32(&bs, 0x04000000);
                    189:        byte_stream_put32(&bs, 0x00000000);
                    190: 
                    191:        snacid = aim_cachesnac(od, SNAC_FAMILY_ALERT, 0x0016, 0x0000, NULL, 0);
                    192:        flap_connection_send_snac(od, conn, SNAC_FAMILY_ALERT, 0x0006, snacid, &bs);
                    193: 
                    194:        byte_stream_destroy(&bs);
                    195: 
                    196:        return 0;
                    197: }
                    198: 
                    199: static int
                    200: snachandler(OscarData *od, FlapConnection *conn, aim_module_t *mod, FlapFrame *frame, aim_modsnac_t *snac, ByteStream *bs)
                    201: {
                    202:        if (snac->subtype == 0x0007)
                    203:                return parseinfo(od, conn, mod, frame, snac, bs);
                    204: 
                    205:        return 0;
                    206: }
                    207: 
                    208: static void
                    209: email_shutdown(OscarData *od, aim_module_t *mod)
                    210: {
                    211:        while (od->emailinfo)
                    212:        {
                    213:                struct aim_emailinfo *tmp = od->emailinfo;
                    214:                od->emailinfo = od->emailinfo->next;
                    215:                g_free(tmp->cookie16);
                    216:                g_free(tmp->cookie8);
                    217:                g_free(tmp->url);
                    218:                g_free(tmp->domain);
                    219:                g_free(tmp);
                    220:        }
                    221: 
                    222:        return;
                    223: }
                    224: 
                    225: int
                    226: email_modfirst(OscarData *od, aim_module_t *mod)
                    227: {
                    228:        mod->family = SNAC_FAMILY_ALERT;
                    229:        mod->version = 0x0001;
                    230:        mod->toolid = 0x0010;
                    231:        mod->toolversion = 0x0629;
                    232:        mod->flags = 0;
                    233:        strncpy(mod->name, "alert", sizeof(mod->name));
                    234:        mod->snachandler = snachandler;
                    235:        mod->shutdown = email_shutdown;
                    236: 
                    237:        return 0;
                    238: }
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>