13234
|
1 /*
|
|
2 * Gaim'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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
19 */
|
|
20
|
|
21 /*
|
|
22 * Family 0x0018 - Email notification
|
|
23 *
|
|
24 * Used for being alerted when the email address(es) associated with
|
|
25 * your screen name get new electronic-m. For normal AIM accounts, you
|
|
26 * get the email address screenname@netscape.net. AOL accounts have
|
|
27 * screenname@aol.com, and can also activate a netscape.net account.
|
|
28 *
|
|
29 */
|
|
30
|
|
31 #include "oscar.h"
|
|
32
|
|
33 /**
|
|
34 * Subtype 0x0006 - Request information about your email account
|
|
35 *
|
|
36 * @param sess 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 */
|
13239
|
40 faim_export int aim_email_sendcookies(OscarSession *sess)
|
13234
|
41 {
|
13239
|
42 OscarConnection *conn;
|
|
43 FlapFrame *fr;
|
13234
|
44 aim_snacid_t snacid;
|
|
45
|
|
46 if (!sess || !(conn = aim_conn_findbygroup(sess, OSCAR_FAMILY_ALERT)))
|
|
47 return -EINVAL;
|
|
48
|
|
49 if (!(fr = aim_tx_new(sess, conn, AIM_FRAMETYPE_FLAP, 0x02, 10+2+16+16)))
|
|
50 return -ENOMEM;
|
|
51 snacid = aim_cachesnac(sess, 0x0018, 0x0006, 0x0000, NULL, 0);
|
|
52 aim_putsnac(&fr->data, 0x0018, 0x0006, 0x0000, snacid);
|
|
53
|
|
54 /* Number of cookies to follow */
|
|
55 aimbs_put16(&fr->data, 0x0002);
|
|
56
|
|
57 /* Cookie */
|
|
58 aimbs_put16(&fr->data, 0x5d5e);
|
|
59 aimbs_put16(&fr->data, 0x1708);
|
|
60 aimbs_put16(&fr->data, 0x55aa);
|
|
61 aimbs_put16(&fr->data, 0x11d3);
|
|
62 aimbs_put16(&fr->data, 0xb143);
|
|
63 aimbs_put16(&fr->data, 0x0060);
|
|
64 aimbs_put16(&fr->data, 0xb0fb);
|
|
65 aimbs_put16(&fr->data, 0x1ecb);
|
|
66
|
|
67 /* Cookie */
|
|
68 aimbs_put16(&fr->data, 0xb380);
|
|
69 aimbs_put16(&fr->data, 0x9ad8);
|
|
70 aimbs_put16(&fr->data, 0x0dba);
|
|
71 aimbs_put16(&fr->data, 0x11d5);
|
|
72 aimbs_put16(&fr->data, 0x9f8a);
|
|
73 aimbs_put16(&fr->data, 0x0060);
|
|
74 aimbs_put16(&fr->data, 0xb0ee);
|
|
75 aimbs_put16(&fr->data, 0x0631);
|
|
76
|
|
77 aim_tx_enqueue(sess, fr);
|
|
78
|
|
79 return 0;
|
|
80 }
|
|
81
|
|
82
|
|
83 /**
|
|
84 * Subtype 0x0007 - Receive information about your email account
|
|
85 *
|
|
86 * So I don't even know if you can have multiple 16 byte keys,
|
|
87 * but this is coded so it will handle that, and handle it well.
|
|
88 * This tells you if you have unread mail or not, the URL you
|
|
89 * should use to access that mail, and the domain name for the
|
|
90 * email account (screenname@domainname.com). If this is the
|
|
91 * first 0x0007 SNAC you've received since you signed on, or if
|
|
92 * this is just a periodic status update, this will also contain
|
|
93 * the number of unread emails that you have.
|
|
94 */
|
13239
|
95 static int parseinfo(OscarSession *sess, aim_module_t *mod, FlapFrame *rx, aim_modsnac_t *snac, ByteStream *bs)
|
13234
|
96 {
|
|
97 int ret = 0;
|
|
98 aim_rxcallback_t userfunc;
|
|
99 struct aim_emailinfo *new;
|
|
100 aim_tlvlist_t *tlvlist;
|
|
101 guint8 *cookie8, *cookie16;
|
|
102 int tmp, havenewmail = 0; /* Used to tell the client we have _new_ mail */
|
|
103
|
|
104 char *alertitle = NULL, *alerturl = NULL;
|
|
105
|
|
106 cookie8 = aimbs_getraw(bs, 8); /* Possibly the code used to log you in to mail? */
|
|
107 cookie16 = aimbs_getraw(bs, 16); /* Mail cookie sent above */
|
|
108
|
|
109 /* See if we already have some info associated with this cookie */
|
|
110 for (new = sess->emailinfo; (new && memcmp(cookie16, new->cookie16, 16)); new = new->next);
|
|
111 if (new) {
|
|
112 /* Free some of the old info, if it exists */
|
|
113 free(new->cookie8);
|
|
114 free(new->cookie16);
|
|
115 free(new->url);
|
|
116 free(new->domain);
|
|
117 } else {
|
|
118 /* We don't already have info, so create a new struct for it */
|
|
119 if (!(new = malloc(sizeof(struct aim_emailinfo))))
|
|
120 return -ENOMEM;
|
|
121 memset(new, 0, sizeof(struct aim_emailinfo));
|
|
122 new->next = sess->emailinfo;
|
|
123 sess->emailinfo = new;
|
|
124 }
|
|
125
|
|
126 new->cookie8 = cookie8;
|
|
127 new->cookie16 = cookie16;
|
|
128
|
|
129 tlvlist = aim_tlvlist_readnum(bs, aimbs_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(sess, rx->conn, snac->family, snac->subtype)))
|
|
154 ret = userfunc(sess, rx, new, havenewmail, alertitle, (alerturl ? alerturl + 2 : NULL));
|
|
155
|
|
156 aim_tlvlist_free(&tlvlist);
|
|
157
|
|
158 free(alertitle);
|
|
159 free(alerturl);
|
|
160
|
|
161 return ret;
|
|
162 }
|
|
163
|
|
164 /**
|
|
165 * Subtype 0x0016 - Send something or other
|
|
166 *
|
|
167 * @param sess 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 */
|
13239
|
171 faim_export int aim_email_activate(OscarSession *sess)
|
13234
|
172 {
|
13239
|
173 OscarConnection *conn;
|
|
174 FlapFrame *fr;
|
13234
|
175 aim_snacid_t snacid;
|
|
176
|
|
177 if (!sess || !(conn = aim_conn_findbygroup(sess, OSCAR_FAMILY_ALERT)))
|
|
178 return -EINVAL;
|
|
179
|
|
180 if (!(fr = aim_tx_new(sess, conn, AIM_FRAMETYPE_FLAP, 0x02, 10+1+16)))
|
|
181 return -ENOMEM;
|
|
182 snacid = aim_cachesnac(sess, 0x0018, 0x0016, 0x0000, NULL, 0);
|
|
183 aim_putsnac(&fr->data, 0x0018, 0x0016, 0x0000, snacid);
|
|
184
|
|
185 /* I would guess this tells AIM that you want updates for your mail accounts */
|
|
186 /* ...but I really have no idea */
|
|
187 aimbs_put8(&fr->data, 0x02);
|
|
188 aimbs_put32(&fr->data, 0x04000000);
|
|
189 aimbs_put32(&fr->data, 0x04000000);
|
|
190 aimbs_put32(&fr->data, 0x04000000);
|
|
191 aimbs_put32(&fr->data, 0x00000000);
|
|
192
|
|
193 aim_tx_enqueue(sess, fr);
|
|
194
|
|
195 return 0;
|
|
196 }
|
|
197
|
13239
|
198 static int snachandler(OscarSession *sess, aim_module_t *mod, FlapFrame *rx, aim_modsnac_t *snac, ByteStream *bs)
|
13234
|
199 {
|
|
200
|
|
201 if (snac->subtype == 0x0007)
|
|
202 return parseinfo(sess, mod, rx, snac, bs);
|
|
203
|
|
204 return 0;
|
|
205 }
|
|
206
|
13239
|
207 static void email_shutdown(OscarSession *sess, aim_module_t *mod)
|
13234
|
208 {
|
|
209 while (sess->emailinfo) {
|
|
210 struct aim_emailinfo *tmp = sess->emailinfo;
|
|
211 sess->emailinfo = sess->emailinfo->next;
|
|
212 free(tmp->cookie16);
|
|
213 free(tmp->cookie8);
|
|
214 free(tmp->url);
|
|
215 free(tmp->domain);
|
|
216 free(tmp);
|
|
217 }
|
|
218
|
|
219 return;
|
|
220 }
|
|
221
|
13239
|
222 faim_internal int email_modfirst(OscarSession *sess, aim_module_t *mod)
|
13234
|
223 {
|
|
224
|
|
225 mod->family = 0x0018;
|
|
226 mod->version = 0x0001;
|
|
227 mod->toolid = 0x0010;
|
|
228 mod->toolversion = 0x0629;
|
|
229 mod->flags = 0;
|
|
230 strncpy(mod->name, "alert", sizeof(mod->name));
|
|
231 mod->snachandler = snachandler;
|
|
232 mod->shutdown = email_shutdown;
|
|
233
|
|
234 return 0;
|
|
235 }
|