Annotation of ChivanetAimPidgin/oscarprpl/src/c/family_alert.c, revision 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>