Mercurial > pidgin
annotate libfaim/aim_misc.c @ 760:d2eef8a40a77
[gaim-migrate @ 770]
oscar has no dir info
committer: Tailor Script <tailor@pidgin.im>
| author | Eric Warmenhoven <eric@warmenhoven.org> |
|---|---|
| date | Thu, 24 Aug 2000 23:55:37 +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 |
