Mercurial > pidgin
annotate libfaim/aim_misc.c @ 519:926ba0807a2d
[gaim-migrate @ 529]
hm de hm hm
committer: Tailor Script <tailor@pidgin.im>
author | Eric Warmenhoven <eric@warmenhoven.org> |
---|---|
date | Fri, 21 Jul 2000 20:03:12 +0000 |
parents | e4c34ca88d9b |
children | 72e556f6b99d |
rev | line source |
---|---|
2 | 1 |
2 /* | |
3 * aim_misc.c | |
4 * | |
5 * TODO: Seperate a lot of this into an aim_bos.c. | |
6 * | |
7 * Other things... | |
8 * | |
9 * - Idle setting | |
10 * | |
11 * | |
12 */ | |
13 | |
283
0f14e6d8a51b
[gaim-migrate @ 293]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
279
diff
changeset
|
14 #include <faim/aim.h> |
2 | 15 |
16 /* | |
17 * aim_bos_setidle() | |
18 * | |
19 * Should set your current idle time in seconds. Idealy, OSCAR should | |
20 * do this for us. But, it doesn't. The client must call this to set idle | |
21 * time. | |
22 * | |
23 */ | |
237 | 24 u_long aim_bos_setidle(struct aim_session_t *sess, |
25 struct aim_conn_t *conn, | |
26 u_long idletime) | |
2 | 27 { |
237 | 28 return aim_genericreq_l(sess, conn, 0x0001, 0x0011, &idletime); |
2 | 29 } |
30 | |
31 | |
32 /* | |
33 * aim_bos_changevisibility(conn, changtype, namelist) | |
34 * | |
35 * Changes your visibility depending on changetype: | |
36 * | |
37 * AIM_VISIBILITYCHANGE_PERMITADD: Lets provided list of names see you | |
38 * AIM_VISIBILITYCHANGE_PERMIDREMOVE: Removes listed names from permit list | |
39 * AIM_VISIBILITYCHANGE_DENYADD: Hides you from provided list of names | |
40 * AIM_VISIBILITYCHANGE_DENYREMOVE: Lets list see you again | |
41 * | |
42 * list should be a list of | |
43 * screen names in the form "Screen Name One&ScreenNameTwo&" etc. | |
44 * | |
45 * Equivelents to options in WinAIM: | |
46 * - Allow all users to contact me: Send an AIM_VISIBILITYCHANGE_DENYADD | |
47 * with only your name on it. | |
48 * - Allow only users on my Buddy List: Send an | |
49 * AIM_VISIBILITYCHANGE_PERMITADD with the list the same as your | |
50 * buddy list | |
51 * - Allow only the uesrs below: Send an AIM_VISIBILITYCHANGE_PERMITADD | |
52 * with everyone listed that you want to see you. | |
53 * - Block all users: Send an AIM_VISIBILITYCHANGE_PERMITADD with only | |
54 * yourself in the list | |
55 * - Block the users below: Send an AIM_VISIBILITYCHANGE_DENYADD with | |
56 * the list of users to be blocked | |
57 * | |
58 * | |
59 */ | |
237 | 60 u_long aim_bos_changevisibility(struct aim_session_t *sess, |
61 struct aim_conn_t *conn, | |
62 int changetype, char *denylist) | |
2 | 63 { |
237 | 64 struct command_tx_struct *newpacket; |
65 int packlen = 0; | |
66 u_short subtype; | |
2 | 67 |
68 char *localcpy = NULL; | |
69 char *tmpptr = NULL; | |
70 int i,j; | |
237 | 71 int listcount; |
2 | 72 |
73 if (!denylist) | |
74 return 0; | |
75 | |
76 localcpy = (char *) malloc(strlen(denylist)+1); | |
77 memcpy(localcpy, denylist, strlen(denylist)+1); | |
237 | 78 |
79 listcount = aimutil_itemcnt(localcpy, '&'); | |
80 packlen = aimutil_tokslen(localcpy, 99, '&') + listcount + 9; | |
2 | 81 |
445
e4c34ca88d9b
[gaim-migrate @ 455]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
283
diff
changeset
|
82 if (!(newpacket = aim_tx_new(AIM_FRAMETYPE_OSCAR, 0x0002, conn, packlen))) |
237 | 83 return -1; |
2 | 84 |
237 | 85 newpacket->lock = 1; |
2 | 86 |
87 switch(changetype) | |
88 { | |
237 | 89 case AIM_VISIBILITYCHANGE_PERMITADD: subtype = 0x05; break; |
90 case AIM_VISIBILITYCHANGE_PERMITREMOVE: subtype = 0x06; break; | |
91 case AIM_VISIBILITYCHANGE_DENYADD: subtype = 0x07; break; | |
92 case AIM_VISIBILITYCHANGE_DENYREMOVE: subtype = 0x08; break; | |
2 | 93 default: |
237 | 94 free(newpacket->data); |
95 free(newpacket); | |
2 | 96 return 0; |
97 } | |
237 | 98 |
99 /* We actually DO NOT send a SNAC ID with this one! */ | |
100 aim_putsnac(newpacket->data, 0x0009, subtype, 0x00, 0); | |
2 | 101 |
102 j = 10; /* the next byte */ | |
237 | 103 |
104 for (i=0; (i < (listcount - 1)) && (i < 99); i++) | |
2 | 105 { |
237 | 106 tmpptr = aimutil_itemidx(localcpy, i, '&'); |
107 | |
108 newpacket->data[j] = strlen(tmpptr); | |
109 memcpy(&(newpacket->data[j+1]), tmpptr, strlen(tmpptr)); | |
2 | 110 j += strlen(tmpptr)+1; |
237 | 111 free(tmpptr); |
2 | 112 } |
237 | 113 free(localcpy); |
2 | 114 |
237 | 115 newpacket->lock = 0; |
2 | 116 |
237 | 117 aim_tx_enqueue(sess, newpacket); |
2 | 118 |
237 | 119 return (sess->snac_nextid); /* dont increment */ |
2 | 120 |
121 } | |
122 | |
123 | |
124 | |
125 /* | |
126 * aim_bos_setbuddylist(buddylist) | |
127 * | |
128 * This just builds the "set buddy list" command then queues it. | |
129 * | |
130 * buddy_list = "Screen Name One&ScreenNameTwo&"; | |
131 * | |
237 | 132 * TODO: Clean this up. |
133 * | |
134 * XXX: I can't stress the TODO enough. | |
2 | 135 * |
136 */ | |
237 | 137 u_long aim_bos_setbuddylist(struct aim_session_t *sess, |
138 struct aim_conn_t *conn, | |
139 char *buddy_list) | |
2 | 140 { |
141 int i, j; | |
142 | |
237 | 143 struct command_tx_struct *newpacket; |
2 | 144 |
145 int packet_login_phase3c_hi_b_len = 0; | |
146 | |
147 char *localcpy = NULL; | |
148 char *tmpptr = NULL; | |
149 | |
150 packet_login_phase3c_hi_b_len = 16; /* 16b for FLAP and SNAC headers */ | |
151 | |
152 /* bail out if we can't make the packet */ | |
237 | 153 if (!buddy_list) { |
154 return -1; | |
155 } | |
2 | 156 |
157 localcpy = (char *) malloc(strlen(buddy_list)+1); | |
158 memcpy(localcpy, buddy_list, strlen(buddy_list)+1); | |
159 | |
160 i = 0; | |
161 tmpptr = strtok(localcpy, "&"); | |
162 while ((tmpptr != NULL) && (i < 100)) | |
163 { | |
164 #if debug > 0 | |
165 printf("---adding %s (%d)\n", tmpptr, strlen(tmpptr)); | |
166 #endif | |
167 packet_login_phase3c_hi_b_len += strlen(tmpptr)+1; | |
168 i++; | |
169 tmpptr = strtok(NULL, "&"); | |
170 } | |
171 #if debug > 0 | |
172 printf("*** send buddy list len: %d (%x)\n", packet_login_phase3c_hi_b_len, packet_login_phase3c_hi_b_len); | |
173 #endif | |
174 free(localcpy); | |
175 | |
445
e4c34ca88d9b
[gaim-migrate @ 455]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
283
diff
changeset
|
176 if (!(newpacket = aim_tx_new(AIM_FRAMETYPE_OSCAR, 0x0002, conn, packet_login_phase3c_hi_b_len - 6))) |
237 | 177 return -1; |
2 | 178 |
237 | 179 newpacket->lock = 1; |
180 | |
181 aim_putsnac(newpacket->data, 0x0003, 0x0004, 0x0000, sess->snac_nextid); | |
2 | 182 |
183 j = 10; /* the next byte */ | |
184 | |
185 i = 0; | |
186 tmpptr = strtok(buddy_list, "&"); | |
187 while ((tmpptr != NULL) & (i < 100)) | |
188 { | |
189 #if debug > 0 | |
190 printf("---adding %s (%d)\n", tmpptr, strlen(tmpptr)); | |
191 #endif | |
237 | 192 newpacket->data[j] = strlen(tmpptr); |
193 memcpy(&(newpacket->data[j+1]), tmpptr, strlen(tmpptr)); | |
2 | 194 j += strlen(tmpptr)+1; |
195 i++; | |
196 tmpptr = strtok(NULL, "&"); | |
197 } | |
198 | |
237 | 199 newpacket->lock = 0; |
2 | 200 |
237 | 201 aim_tx_enqueue(sess, newpacket); |
2 | 202 |
237 | 203 return (sess->snac_nextid++); |
2 | 204 } |
205 | |
206 /* | |
207 * aim_bos_setprofile(profile) | |
208 * | |
209 * Gives BOS your profile. | |
210 * | |
237 | 211 * |
2 | 212 */ |
237 | 213 u_long aim_bos_setprofile(struct aim_session_t *sess, |
214 struct aim_conn_t *conn, | |
215 char *profile, | |
216 char *awaymsg, | |
217 unsigned int caps) | |
2 | 218 { |
237 | 219 struct command_tx_struct *newpacket; |
445
e4c34ca88d9b
[gaim-migrate @ 455]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
283
diff
changeset
|
220 int i = 0, tmp, caplen; |
2 | 221 |
445
e4c34ca88d9b
[gaim-migrate @ 455]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
283
diff
changeset
|
222 if (!(newpacket = aim_tx_new(AIM_FRAMETYPE_OSCAR, 0x0002, conn, 1152+strlen(profile)+1+(awaymsg?strlen(awaymsg):0)))) |
237 | 223 return -1; |
2 | 224 |
237 | 225 i += aim_putsnac(newpacket->data, 0x0002, 0x004, 0x0000, sess->snac_nextid); |
226 i += aim_puttlv_str(newpacket->data+i, 0x0001, strlen("text/x-aolrtf; charset=\"us-ascii\""), "text/x-aolrtf; charset=\"us-ascii\""); | |
227 i += aim_puttlv_str(newpacket->data+i, 0x0002, strlen(profile), profile); | |
228 /* why do we send this twice? */ | |
229 i += aim_puttlv_str(newpacket->data+i, 0x0003, strlen("text/x-aolrtf; charset=\"us-ascii\""), "text/x-aolrtf; charset=\"us-ascii\""); | |
230 | |
231 /* Away message -- we send this no matter what, even if its blank */ | |
232 if (awaymsg) | |
233 i += aim_puttlv_str(newpacket->data+i, 0x0004, strlen(awaymsg), awaymsg); | |
2 | 234 else |
237 | 235 i += aim_puttlv_str(newpacket->data+i, 0x0004, 0x0000, NULL); |
2 | 236 |
237 | 237 /* Capability information. */ |
445
e4c34ca88d9b
[gaim-migrate @ 455]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
283
diff
changeset
|
238 |
e4c34ca88d9b
[gaim-migrate @ 455]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
283
diff
changeset
|
239 tmp = (i += aimutil_put16(newpacket->data+i, 0x0005)); |
e4c34ca88d9b
[gaim-migrate @ 455]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
283
diff
changeset
|
240 i += aimutil_put16(newpacket->data+i, 0x0000); /* rewritten later */ |
e4c34ca88d9b
[gaim-migrate @ 455]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
283
diff
changeset
|
241 i += (caplen = aim_putcap(newpacket->data+i, 512, caps)); |
e4c34ca88d9b
[gaim-migrate @ 455]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
283
diff
changeset
|
242 aimutil_put16(newpacket->data+tmp, caplen); /* rewrite TLV size */ |
e4c34ca88d9b
[gaim-migrate @ 455]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
283
diff
changeset
|
243 |
237 | 244 newpacket->commandlen = i; |
245 aim_tx_enqueue(sess, newpacket); | |
2 | 246 |
237 | 247 return (sess->snac_nextid++); |
2 | 248 } |
249 | |
250 /* | |
251 * aim_bos_setgroupperm(mask) | |
252 * | |
253 * Set group permisson mask. Normally 0x1f. | |
254 * | |
255 */ | |
237 | 256 u_long aim_bos_setgroupperm(struct aim_session_t *sess, |
257 struct aim_conn_t *conn, | |
258 u_long mask) | |
2 | 259 { |
237 | 260 return aim_genericreq_l(sess, conn, 0x0009, 0x0004, &mask); |
2 | 261 } |
262 | |
263 /* | |
264 * aim_bos_clientready() | |
265 * | |
266 * Send Client Ready. | |
267 * | |
268 * TODO: Dynamisize. | |
269 * | |
270 */ | |
237 | 271 u_long aim_bos_clientready(struct aim_session_t *sess, |
272 struct aim_conn_t *conn) | |
2 | 273 { |
237 | 274 u_char command_2[] = { |
275 /* placeholders for dynamic data */ | |
276 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, | |
277 0xff, 0xff, | |
278 /* real data */ | |
279 0x00, 0x01, | |
280 0x00, 0x03, | |
281 0x00, 0x04, | |
282 0x06, 0x86, | |
283 0x00, 0x02, | |
284 0x00, 0x01, | |
285 0x00, 0x04, | |
286 0x00, 0x01, | |
287 | |
288 0x00, 0x03, | |
289 0x00, 0x01, | |
290 0x00, 0x04, | |
291 0x00, 0x01, | |
292 0x00, 0x04, | |
293 0x00, 0x01, | |
294 0x00, 0x04, | |
295 0x00, 0x01, | |
296 | |
297 0x00, 0x06, | |
298 0x00, 0x01, | |
299 0x00, 0x04, | |
300 0x00, 0x01, | |
301 0x00, 0x08, | |
302 0x00, 0x01, | |
303 0x00, 0x04, | |
304 0x00, 0x01, | |
305 | |
306 0x00, 0x09, | |
307 0x00, 0x01, | |
308 0x00, 0x04, | |
309 0x00, 0x01, | |
310 0x00, 0x0a, | |
311 0x00, 0x01, | |
312 0x00, 0x04, | |
313 0x00, 0x01, | |
314 | |
315 0x00, 0x0b, | |
316 0x00, 0x01, | |
317 0x00, 0x04, | |
2 | 318 0x00, 0x01 |
319 }; | |
320 int command_2_len = 0x52; | |
237 | 321 struct command_tx_struct *newpacket; |
2 | 322 |
445
e4c34ca88d9b
[gaim-migrate @ 455]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
283
diff
changeset
|
323 if (!(newpacket = aim_tx_new(AIM_FRAMETYPE_OSCAR, 0x0002, conn, command_2_len))) |
237 | 324 return -1; |
325 | |
326 newpacket->lock = 1; | |
327 | |
328 memcpy(newpacket->data, command_2, command_2_len); | |
2 | 329 |
237 | 330 /* This write over the dynamic parts of the byte block */ |
331 aim_putsnac(newpacket->data, 0x0001, 0x0002, 0x0000, sess->snac_nextid); | |
2 | 332 |
237 | 333 aim_tx_enqueue(sess, newpacket); |
2 | 334 |
237 | 335 return (sess->snac_nextid++); |
2 | 336 } |
337 | |
338 /* | |
339 * send_login_phase3(int socket) | |
340 * | |
341 * Request Rate Information. | |
342 * | |
343 * TODO: Move to aim_conn. | |
344 * TODO: Move to SNAC interface. | |
345 */ | |
237 | 346 u_long aim_bos_reqrate(struct aim_session_t *sess, |
347 struct aim_conn_t *conn) | |
2 | 348 { |
237 | 349 return aim_genericreq_n(sess, conn, 0x0001, 0x0006); |
2 | 350 } |
351 | |
352 /* | |
353 * send_login_phase3b(int socket) | |
354 * | |
355 * Rate Information Response Acknowledge. | |
356 * | |
357 */ | |
237 | 358 u_long aim_bos_ackrateresp(struct aim_session_t *sess, |
359 struct aim_conn_t *conn) | |
2 | 360 { |
237 | 361 struct command_tx_struct *newpacket; |
362 int packlen = 18, i=0; | |
2 | 363 |
237 | 364 if (conn->type != AIM_CONN_TYPE_BOS) |
365 packlen += 2; | |
366 | |
445
e4c34ca88d9b
[gaim-migrate @ 455]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
283
diff
changeset
|
367 if(!(newpacket = aim_tx_new(AIM_FRAMETYPE_OSCAR, 0x0002, conn, packlen))); |
237 | 368 |
369 newpacket->lock = 1; | |
2 | 370 |
237 | 371 i = aim_putsnac(newpacket->data, 0x0001, 0x0008, 0x0000, sess->snac_nextid); |
372 i += aimutil_put16(newpacket->data+i, 0x0001); | |
373 i += aimutil_put16(newpacket->data+i, 0x0002); | |
374 i += aimutil_put16(newpacket->data+i, 0x0003); | |
375 i += aimutil_put16(newpacket->data+i, 0x0004); | |
376 | |
377 if (conn->type != AIM_CONN_TYPE_BOS) { | |
378 i += aimutil_put16(newpacket->data+i, 0x0005); | |
379 } | |
2 | 380 |
237 | 381 aim_tx_enqueue(sess, newpacket); |
2 | 382 |
237 | 383 return (sess->snac_nextid++); |
2 | 384 } |
385 | |
386 /* | |
387 * aim_bos_setprivacyflags() | |
388 * | |
389 * Sets privacy flags. Normally 0x03. | |
390 * | |
391 * Bit 1: Allows other AIM users to see how long you've been idle. | |
392 * | |
393 * | |
394 */ | |
237 | 395 u_long aim_bos_setprivacyflags(struct aim_session_t *sess, |
396 struct aim_conn_t *conn, | |
397 u_long flags) | |
2 | 398 { |
237 | 399 return aim_genericreq_l(sess, conn, 0x0001, 0x0014, &flags); |
2 | 400 } |
401 | |
402 /* | |
403 * aim_bos_reqpersonalinfo() | |
404 * | |
405 * Requests the current user's information. Can't go generic on this one | |
406 * because aparently it uses SNAC flags. | |
407 * | |
408 */ | |
237 | 409 u_long aim_bos_reqpersonalinfo(struct aim_session_t *sess, |
410 struct aim_conn_t *conn) | |
2 | 411 { |
237 | 412 struct command_tx_struct *newpacket; |
2 | 413 |
445
e4c34ca88d9b
[gaim-migrate @ 455]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
283
diff
changeset
|
414 if (!(newpacket = aim_tx_new(AIM_FRAMETYPE_OSCAR, 0x0002, conn, 12))) |
237 | 415 return -1; |
2 | 416 |
237 | 417 newpacket->lock = 1; |
418 | |
419 aim_putsnac(newpacket->data, 0x000a, 0x0001, 0x000e /* huh? */, sess->snac_nextid); | |
2 | 420 |
237 | 421 newpacket->data[10] = 0x0d; |
422 newpacket->data[11] = 0xda; | |
423 | |
424 newpacket->lock = 0; | |
425 aim_tx_enqueue(sess, newpacket); | |
426 | |
427 return (sess->snac_nextid++); | |
428 } | |
429 | |
430 u_long aim_setversions(struct aim_session_t *sess, | |
431 struct aim_conn_t *conn) | |
432 { | |
433 struct command_tx_struct *newpacket; | |
434 int i; | |
435 | |
445
e4c34ca88d9b
[gaim-migrate @ 455]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
283
diff
changeset
|
436 if (!(newpacket = aim_tx_new(AIM_FRAMETYPE_OSCAR, 0x0002, conn, 10 + (4*11)))) |
237 | 437 return -1; |
438 | |
439 newpacket->lock = 1; | |
440 | |
441 i = aim_putsnac(newpacket->data, 0x0001, 0x0017, 0x0000, sess->snac_nextid); | |
442 | |
443 i += aimutil_put16(newpacket->data+i, 0x0001); | |
444 i += aimutil_put16(newpacket->data+i, 0x0003); | |
445 | |
446 i += aimutil_put16(newpacket->data+i, 0x0002); | |
447 i += aimutil_put16(newpacket->data+i, 0x0001); | |
448 | |
449 i += aimutil_put16(newpacket->data+i, 0x0003); | |
450 i += aimutil_put16(newpacket->data+i, 0x0001); | |
451 | |
452 i += aimutil_put16(newpacket->data+i, 0x0004); | |
453 i += aimutil_put16(newpacket->data+i, 0x0001); | |
2 | 454 |
237 | 455 i += aimutil_put16(newpacket->data+i, 0x0006); |
456 i += aimutil_put16(newpacket->data+i, 0x0001); | |
457 | |
458 i += aimutil_put16(newpacket->data+i, 0x0008); | |
459 i += aimutil_put16(newpacket->data+i, 0x0001); | |
460 | |
461 i += aimutil_put16(newpacket->data+i, 0x0009); | |
462 i += aimutil_put16(newpacket->data+i, 0x0001); | |
463 | |
464 i += aimutil_put16(newpacket->data+i, 0x000a); | |
465 i += aimutil_put16(newpacket->data+i, 0x0001); | |
466 | |
467 i += aimutil_put16(newpacket->data+i, 0x000b); | |
468 i += aimutil_put16(newpacket->data+i, 0x0002); | |
2 | 469 |
237 | 470 i += aimutil_put16(newpacket->data+i, 0x000c); |
471 i += aimutil_put16(newpacket->data+i, 0x0001); | |
472 | |
473 i += aimutil_put16(newpacket->data+i, 0x0015); | |
474 i += aimutil_put16(newpacket->data+i, 0x0001); | |
2 | 475 |
237 | 476 #if 0 |
477 for (j = 0; j < 0x10; j++) { | |
478 i += aimutil_put16(newpacket->data+i, j); /* family */ | |
479 i += aimutil_put16(newpacket->data+i, 0x0003); /* version */ | |
480 } | |
481 #endif | |
482 newpacket->lock = 0; | |
483 aim_tx_enqueue(sess, newpacket); | |
2 | 484 |
237 | 485 return (sess->snac_nextid++); |
2 | 486 } |
487 | |
237 | 488 |
2 | 489 /* |
490 * aim_bos_reqservice(serviceid) | |
491 * | |
492 * Service request. | |
493 * | |
494 */ | |
237 | 495 u_long aim_bos_reqservice(struct aim_session_t *sess, |
496 struct aim_conn_t *conn, | |
497 u_short serviceid) | |
2 | 498 { |
237 | 499 return aim_genericreq_s(sess, conn, 0x0001, 0x0004, &serviceid); |
2 | 500 } |
501 | |
502 /* | |
445
e4c34ca88d9b
[gaim-migrate @ 455]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
283
diff
changeset
|
503 * aim_bos_nop() |
e4c34ca88d9b
[gaim-migrate @ 455]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
283
diff
changeset
|
504 * |
e4c34ca88d9b
[gaim-migrate @ 455]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
283
diff
changeset
|
505 * No-op. WinAIM sends these every 4min or so to keep |
e4c34ca88d9b
[gaim-migrate @ 455]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
283
diff
changeset
|
506 * the connection alive. With the recent changes |
e4c34ca88d9b
[gaim-migrate @ 455]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
283
diff
changeset
|
507 * in the OSCAR servers, it looks like we must do the |
e4c34ca88d9b
[gaim-migrate @ 455]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
283
diff
changeset
|
508 * same or be disconnected with a mysterious 'you logged |
e4c34ca88d9b
[gaim-migrate @ 455]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
283
diff
changeset
|
509 * on from another client' message. |
e4c34ca88d9b
[gaim-migrate @ 455]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
283
diff
changeset
|
510 * |
e4c34ca88d9b
[gaim-migrate @ 455]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
283
diff
changeset
|
511 */ |
e4c34ca88d9b
[gaim-migrate @ 455]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
283
diff
changeset
|
512 u_long aim_bos_nop(struct aim_session_t *sess, |
e4c34ca88d9b
[gaim-migrate @ 455]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
283
diff
changeset
|
513 struct aim_conn_t *conn) |
e4c34ca88d9b
[gaim-migrate @ 455]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
283
diff
changeset
|
514 { |
e4c34ca88d9b
[gaim-migrate @ 455]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
283
diff
changeset
|
515 return aim_genericreq_n(sess, conn, 0x0001, 0x0016); |
e4c34ca88d9b
[gaim-migrate @ 455]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
283
diff
changeset
|
516 } |
e4c34ca88d9b
[gaim-migrate @ 455]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
283
diff
changeset
|
517 |
e4c34ca88d9b
[gaim-migrate @ 455]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
283
diff
changeset
|
518 /* |
2 | 519 * aim_bos_reqrights() |
520 * | |
521 * Request BOS rights. | |
522 * | |
523 */ | |
237 | 524 u_long aim_bos_reqrights(struct aim_session_t *sess, |
525 struct aim_conn_t *conn) | |
2 | 526 { |
237 | 527 return aim_genericreq_n(sess, conn, 0x0009, 0x0002); |
2 | 528 } |
529 | |
530 /* | |
531 * aim_bos_reqbuddyrights() | |
532 * | |
533 * Request Buddy List rights. | |
534 * | |
535 */ | |
237 | 536 u_long aim_bos_reqbuddyrights(struct aim_session_t *sess, |
537 struct aim_conn_t *conn) | |
2 | 538 { |
237 | 539 return aim_genericreq_n(sess, conn, 0x0003, 0x0002); |
2 | 540 } |
541 | |
542 /* | |
445
e4c34ca88d9b
[gaim-migrate @ 455]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
283
diff
changeset
|
543 * aim_debugconn_sendconnect() |
e4c34ca88d9b
[gaim-migrate @ 455]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
283
diff
changeset
|
544 * |
e4c34ca88d9b
[gaim-migrate @ 455]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
283
diff
changeset
|
545 * For aimdebugd. If you don't know what it is, you don't want to. |
e4c34ca88d9b
[gaim-migrate @ 455]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
283
diff
changeset
|
546 */ |
e4c34ca88d9b
[gaim-migrate @ 455]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
283
diff
changeset
|
547 u_long aim_debugconn_sendconnect(struct aim_session_t *sess, |
e4c34ca88d9b
[gaim-migrate @ 455]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
283
diff
changeset
|
548 struct aim_conn_t *conn) |
e4c34ca88d9b
[gaim-migrate @ 455]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
283
diff
changeset
|
549 { |
e4c34ca88d9b
[gaim-migrate @ 455]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
283
diff
changeset
|
550 return aim_genericreq_n(sess, conn, AIM_CB_FAM_SPECIAL, AIM_CB_SPECIAL_DEBUGCONN_CONNECT); |
e4c34ca88d9b
[gaim-migrate @ 455]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
283
diff
changeset
|
551 } |
e4c34ca88d9b
[gaim-migrate @ 455]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
283
diff
changeset
|
552 |
e4c34ca88d9b
[gaim-migrate @ 455]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
283
diff
changeset
|
553 /* |
2 | 554 * Generic routine for sending commands. |
555 * | |
556 * | |
557 * I know I can do this in a smarter way...but I'm not thinking straight | |
558 * right now... | |
559 * | |
560 * I had one big function that handled all three cases, but then it broke | |
561 * and I split it up into three. But then I fixed it. I just never went | |
562 * back to the single. I don't see any advantage to doing it either way. | |
563 * | |
564 */ | |
237 | 565 u_long aim_genericreq_n(struct aim_session_t *sess, |
566 struct aim_conn_t *conn, | |
567 u_short family, u_short subtype) | |
2 | 568 { |
237 | 569 struct command_tx_struct *newpacket; |
2 | 570 |
445
e4c34ca88d9b
[gaim-migrate @ 455]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
283
diff
changeset
|
571 if (!(newpacket = aim_tx_new(AIM_FRAMETYPE_OSCAR, 0x0002, conn, 10))) |
237 | 572 return 0; |
573 | |
574 newpacket->lock = 1; | |
2 | 575 |
237 | 576 aim_putsnac(newpacket->data, family, subtype, 0x0000, sess->snac_nextid); |
577 | |
578 aim_tx_enqueue(sess, newpacket); | |
579 return (sess->snac_nextid++); | |
2 | 580 } |
581 | |
582 /* | |
583 * | |
584 * | |
585 */ | |
237 | 586 u_long aim_genericreq_l(struct aim_session_t *sess, |
587 struct aim_conn_t *conn, | |
588 u_short family, u_short subtype, u_long *longdata) | |
2 | 589 { |
237 | 590 struct command_tx_struct *newpacket; |
2 | 591 u_long newlong; |
592 | |
593 /* If we don't have data, there's no reason to use this function */ | |
594 if (!longdata) | |
237 | 595 return aim_genericreq_n(sess, conn, family, subtype); |
2 | 596 |
445
e4c34ca88d9b
[gaim-migrate @ 455]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
283
diff
changeset
|
597 if (!(newpacket = aim_tx_new(AIM_FRAMETYPE_OSCAR, 0x0002, conn, 10+sizeof(u_long)))) |
237 | 598 return -1; |
2 | 599 |
237 | 600 newpacket->lock = 1; |
601 | |
602 aim_putsnac(newpacket->data, family, subtype, 0x0000, sess->snac_nextid); | |
2 | 603 |
604 /* copy in data */ | |
605 newlong = htonl(*longdata); | |
237 | 606 memcpy(&(newpacket->data[10]), &newlong, sizeof(u_long)); |
2 | 607 |
237 | 608 aim_tx_enqueue(sess, newpacket); |
609 return (sess->snac_nextid++); | |
2 | 610 } |
611 | |
237 | 612 u_long aim_genericreq_s(struct aim_session_t *sess, |
613 struct aim_conn_t *conn, | |
614 u_short family, u_short subtype, u_short *shortdata) | |
2 | 615 { |
237 | 616 struct command_tx_struct *newpacket; |
2 | 617 u_short newshort; |
618 | |
619 /* If we don't have data, there's no reason to use this function */ | |
620 if (!shortdata) | |
237 | 621 return aim_genericreq_n(sess, conn, family, subtype); |
2 | 622 |
445
e4c34ca88d9b
[gaim-migrate @ 455]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
283
diff
changeset
|
623 if (!(newpacket = aim_tx_new(AIM_FRAMETYPE_OSCAR, 0x0002, conn, 10+sizeof(u_short)))) |
237 | 624 return -1; |
2 | 625 |
237 | 626 newpacket->lock = 1; |
627 | |
628 aim_putsnac(newpacket->data, family, subtype, 0x0000, sess->snac_nextid); | |
2 | 629 |
630 /* copy in data */ | |
631 newshort = htons(*shortdata); | |
237 | 632 memcpy(&(newpacket->data[10]), &newshort, sizeof(u_short)); |
2 | 633 |
237 | 634 aim_tx_enqueue(sess, newpacket); |
635 return (sess->snac_nextid++); | |
2 | 636 } |
637 | |
638 /* | |
639 * aim_bos_reqlocaterights() | |
640 * | |
641 * Request Location services rights. | |
642 * | |
643 */ | |
237 | 644 u_long aim_bos_reqlocaterights(struct aim_session_t *sess, |
645 struct aim_conn_t *conn) | |
2 | 646 { |
237 | 647 return aim_genericreq_n(sess, conn, 0x0002, 0x0002); |
2 | 648 } |
649 | |
650 /* | |
279
501e09c51cbc
[gaim-migrate @ 289]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
237
diff
changeset
|
651 * aim_bos_reqicbmparaminfo() |
2 | 652 * |
653 * Request ICBM parameter information. | |
654 * | |
655 */ | |
237 | 656 u_long aim_bos_reqicbmparaminfo(struct aim_session_t *sess, |
657 struct aim_conn_t *conn) | |
2 | 658 { |
237 | 659 return aim_genericreq_n(sess, conn, 0x0004, 0x0004); |
2 | 660 } |
279
501e09c51cbc
[gaim-migrate @ 289]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
237
diff
changeset
|
661 |