Ignore:
Timestamp:
2010-03-14T23:15:05Z (14 years ago)
Author:
Wilmer van der Gaast <wilmer@…>
Branches:
master
Children:
81ee561
Parents:
7c5affca (diff), 7e2b593 (diff)
Note: this is a merge changeset, the changes displayed below correspond to the merge itself.
Use the (diff) links above to see all the changes relative to each parent.
Message:

Merging in head.

File:
1 edited

Legend:

Unmodified
Added
Removed
  • protocols/yahoo/libyahoo2.c

    r7c5affca r3330468  
    855855}
    856856
    857 static YList * bud_str2list(char *rawlist)
    858 {
    859         YList * l = NULL;
    860 
    861         char **lines;
    862         char **split;
    863         char **buddies;
    864         char **tmp, **bud;
    865 
    866         lines = y_strsplit(rawlist, "\n", -1);
    867         for (tmp = lines; *tmp; tmp++) {
    868                 struct yahoo_buddy *newbud;
    869 
    870                 split = y_strsplit(*tmp, ":", 2);
    871                 if (!split)
    872                         continue;
    873                 if (!split[0] || !split[1]) {
    874                         y_strfreev(split);
    875                         continue;
    876                 }
    877                 buddies = y_strsplit(split[1], ",", -1);
    878 
    879                 for (bud = buddies; bud && *bud; bud++) {
    880                         newbud = y_new0(struct yahoo_buddy, 1);
    881                         newbud->id = strdup(*bud);
    882                         newbud->group = strdup(split[0]);
    883 
    884                         if(y_list_find_custom(l, newbud, is_same_bud)) {
    885                                 FREE(newbud->id);
    886                                 FREE(newbud->group);
    887                                 FREE(newbud);
    888                                 continue;
    889                         }
    890 
    891                         newbud->real_name = NULL;
    892 
    893                         l = y_list_append(l, newbud);
    894 
    895                         NOTICE(("Added buddy %s to group %s", newbud->id, newbud->group));
    896                 }
    897 
    898                 y_strfreev(buddies);
    899                 y_strfreev(split);
    900         }
    901         y_strfreev(lines);
    902 
    903         return l;
    904 }
    905 
    906857static char * getcookie(char *rawcookie)
    907858{
     
    13601311}
    13611312
    1362 
    1363 static void yahoo_process_status(struct yahoo_input_data *yid, struct yahoo_packet *pkt)
     1313static void yahoo_process_status(struct yahoo_input_data *yid,
     1314        struct yahoo_packet *pkt)
    13641315{
    13651316        YList *l;
    13661317        struct yahoo_data *yd = yid->yd;
    13671318
    1368         struct user
    1369         {
    1370                 char *name;     /* 7    name */
    1371                 int   state;    /* 10   state */
    1372                 int   flags;    /* 13   flags, bit 0 = pager, bit 1 = chat, bit 2 = game */
    1373                 int   mobile;   /* 60   mobile */
    1374                 char *msg;      /* 19   custom status message */
    1375                 int   away;     /* 47   away (or invisible)*/
    1376                 int   buddy_session;    /* 11   state */
    1377                 int   f17;      /* 17   in chat? then what about flags? */
    1378                 int   idle;     /* 137  seconds idle */
    1379                 int   f138;     /* 138  state */
    1380                 char *f184;     /* 184  state */
    1381                 int   f192;     /* 192  state */
    1382                 int   f10001;   /* 10001        state */
    1383                 int   f10002;   /* 10002        state */
    1384                 int   f198;     /* 198  state */
    1385                 char *f197;     /* 197  state */
    1386                 char *f205;     /* 205  state */
    1387                 int   f213;     /* 213  state */
    1388         } *u;
     1319        struct yahoo_process_status_entry *u;
    13891320
    13901321        YList *users = 0;
    1391        
     1322
    13921323        if (pkt->service == YAHOO_SERVICE_LOGOFF && pkt->status == -1) {
    1393                 YAHOO_CALLBACK(ext_yahoo_login_response)(yd->client_id, YAHOO_LOGIN_DUPL, NULL);
    1394                 return;
    1395         }
     1324                YAHOO_CALLBACK(ext_yahoo_login_response) (yd->client_id,
     1325                        YAHOO_LOGIN_DUPL, NULL);
     1326                return;
     1327        }
     1328
     1329        /* Status updates may be spread accross multiple packets and not
     1330           even on buddy boundaries, so keeping some state is important.
     1331           So, continue where we left off, and only add a user entry to
     1332           the list once it's complete (301-315 End buddy). */
     1333        u = yd->half_user;
    13961334
    13971335        for (l = pkt->hash; l; l = l->next) {
     
    13991337
    14001338                switch (pair->key) {
    1401                 case 0: /* we won't actually do anything with this */
     1339                case 300:       /* Begin buddy */
     1340                        if (!strcmp(pair->value, "315") && !u) {
     1341                                u = yd->half_user = y_new0(struct yahoo_process_status_entry, 1);
     1342                        }
     1343                        break;
     1344                case 301:       /* End buddy */
     1345                        if (!strcmp(pair->value, "315") && u) {
     1346                                users = y_list_prepend(users, u);
     1347                                u = yd->half_user = NULL;
     1348                        }
     1349                        break;
     1350                case 0: /* we won't actually do anything with this */
    14021351                        NOTICE(("key %d:%s", pair->key, pair->value));
    14031352                        break;
    1404                 case 1: /* we don't get the full buddy list here. */
     1353                case 1: /* we don't get the full buddy list here. */
    14051354                        if (!yd->logged_in) {
    1406                                 yd->logged_in = TRUE;
    1407                                 if(yd->current_status < 0)
     1355                                yd->logged_in = 1;
     1356                                if (yd->current_status < 0)
    14081357                                        yd->current_status = yd->initial_status;
    1409                                 YAHOO_CALLBACK(ext_yahoo_login_response)(yd->client_id, YAHOO_LOGIN_OK, NULL);
     1358                                YAHOO_CALLBACK(ext_yahoo_login_response) (yd->
     1359                                        client_id, YAHOO_LOGIN_OK, NULL);
    14101360                        }
    14111361                        break;
    1412                 case 8: /* how many online buddies we have */
     1362                case 8: /* how many online buddies we have */
    14131363                        NOTICE(("key %d:%s", pair->key, pair->value));
    14141364                        break;
    1415                 case 7: /* the current buddy */
    1416                         u = y_new0(struct user, 1);
     1365                case 7: /* the current buddy */
     1366                        if (!u) {
     1367                                /* This will only happen in case of a single level message */
     1368                                u = y_new0(struct yahoo_process_status_entry, 1);
     1369                                users = y_list_prepend(users, u);
     1370                        }
    14171371                        u->name = pair->value;
    1418                         users = y_list_prepend(users, u);
    1419                         break;
    1420                 case 10: /* state */
    1421                         ((struct user*)users->data)->state = strtol(pair->value, NULL, 10);
    1422                         break;
    1423                 case 19: /* custom status message */
    1424                         ((struct user*)users->data)->msg = pair->value;
    1425                         break;
    1426                 case 47: /* is it an away message or not */
    1427                         ((struct user*)users->data)->away = atoi(pair->value);
    1428                         break;
    1429                 case 137: /* seconds idle */
    1430                         ((struct user*)users->data)->idle = atoi(pair->value);
    1431                         break;
    1432                 case 11: /* this is the buddy's session id */
    1433                         ((struct user*)users->data)->buddy_session = atoi(pair->value);
    1434                         break;
    1435                 case 17: /* in chat? */
    1436                         ((struct user*)users->data)->f17 = atoi(pair->value);
    1437                         break;
    1438                 case 13: /* bitmask, bit 0 = pager, bit 1 = chat, bit 2 = game */
    1439                         ((struct user*)users->data)->flags = atoi(pair->value);
    1440                         break;
    1441                 case 60: /* SMS -> 1 MOBILE USER */
     1372                        break;
     1373                case 10:        /* state */
     1374                        u->state = strtol(pair->value, NULL, 10);
     1375                        break;
     1376                case 19:        /* custom status message */
     1377                        u->msg = pair->value;
     1378                        break;
     1379                case 47:        /* is it an away message or not. Not applicable for YMSG16 anymore */
     1380                        u->away = atoi(pair->value);
     1381                        break;
     1382                case 137:       /* seconds idle */
     1383                        u->idle = atoi(pair->value);
     1384                        break;
     1385                case 11:        /* this is the buddy's session id */
     1386                        u->buddy_session = atoi(pair->value);
     1387                        break;
     1388                case 17:        /* in chat? */
     1389                        u->f17 = atoi(pair->value);
     1390                        break;
     1391                case 13:        /* bitmask, bit 0 = pager, bit 1 = chat, bit 2 = game */
     1392                        u->flags = atoi(pair->value);
     1393                        break;
     1394                case 60:        /* SMS -> 1 MOBILE USER */
    14421395                        /* sometimes going offline makes this 2, but invisible never sends it */
    1443                         ((struct user*)users->data)->mobile = atoi(pair->value);
     1396                        u->mobile = atoi(pair->value);
    14441397                        break;
    14451398                case 138:
    1446                         ((struct user*)users->data)->f138 = atoi(pair->value);
     1399                        u->f138 = atoi(pair->value);
    14471400                        break;
    14481401                case 184:
    1449                         ((struct user*)users->data)->f184 = pair->value;
     1402                        u->f184 = pair->value;
    14501403                        break;
    14511404                case 192:
    1452                         ((struct user*)users->data)->f192 = atoi(pair->value);
     1405                        u->f192 = atoi(pair->value);
    14531406                        break;
    14541407                case 10001:
    1455                         ((struct user*)users->data)->f10001 = atoi(pair->value);
     1408                        u->f10001 = atoi(pair->value);
    14561409                        break;
    14571410                case 10002:
    1458                         ((struct user*)users->data)->f10002 = atoi(pair->value);
     1411                        u->f10002 = atoi(pair->value);
    14591412                        break;
    14601413                case 198:
    1461                         ((struct user*)users->data)->f198 = atoi(pair->value);
     1414                        u->f198 = atoi(pair->value);
    14621415                        break;
    14631416                case 197:
    1464                         ((struct user*)users->data)->f197 = pair->value;
     1417                        u->f197 = pair->value;
    14651418                        break;
    14661419                case 205:
    1467                         ((struct user*)users->data)->f205 = pair->value;
     1420                        u->f205 = pair->value;
    14681421                        break;
    14691422                case 213:
    1470                         ((struct user*)users->data)->f213 = atoi(pair->value);
    1471                         break;
    1472                 case 16: /* Custom error message */
    1473                         YAHOO_CALLBACK(ext_yahoo_error)(yd->client_id, pair->value, 0, E_CUSTOM);
     1423                        u->f213 = atoi(pair->value);
     1424                        break;
     1425                case 16:        /* Custom error message */
     1426                        YAHOO_CALLBACK(ext_yahoo_error) (yd->client_id,
     1427                                pair->value, 0, E_CUSTOM);
    14741428                        break;
    14751429                default:
    1476                         WARNING(("unknown status key %d:%s", pair->key, pair->value));
    1477                         break;
    1478                 }
    1479         }
    1480        
     1430                        WARNING(("unknown status key %d:%s", pair->key,
     1431                                        pair->value));
     1432                        break;
     1433                }
     1434        }
     1435
    14811436        while (users) {
    14821437                YList *t = users;
    1483                 struct user *u = users->data;
     1438                struct yahoo_process_status_entry *u = users->data;
    14841439
    14851440                if (u->name != NULL) {
    1486                         if (pkt->service == YAHOO_SERVICE_LOGOFF) { /* || u->flags == 0) { Not in YMSG16 */
    1487                                 YAHOO_CALLBACK(ext_yahoo_status_changed)(yd->client_id, u->name, YAHOO_STATUS_OFFLINE, NULL, 1, 0, 0);
     1441                        if (pkt->service ==
     1442                                YAHOO_SERVICE_LOGOFF
     1443                                /*|| u->flags == 0 No flags for YMSG16 */ ) {
     1444                                YAHOO_CALLBACK(ext_yahoo_status_changed) (yd->
     1445                                        client_id, u->name,
     1446                                        YAHOO_STATUS_OFFLINE, NULL, 1, 0, 0);
    14881447                        } else {
    14891448                                /* Key 47 always seems to be 1 for YMSG16 */
    1490                                 if(!u->state)
     1449                                if (!u->state)
    14911450                                        u->away = 0;
    14921451                                else
    14931452                                        u->away = 1;
    14941453
    1495                                 YAHOO_CALLBACK(ext_yahoo_status_changed)(yd->client_id, u->name, u->state, u->msg, u->away, u->idle, u->mobile);
     1454                                YAHOO_CALLBACK(ext_yahoo_status_changed) (yd->
     1455                                        client_id, u->name, u->state, u->msg,
     1456                                        u->away, u->idle, u->mobile);
    14961457                        }
    14971458                }
     
    15031464}
    15041465
    1505 static void yahoo_process_buddy_list(struct yahoo_input_data *yid, struct yahoo_packet *pkt)
     1466static void yahoo_process_buddy_list(struct yahoo_input_data *yid,
     1467        struct yahoo_packet *pkt)
    15061468{
    15071469        struct yahoo_data *yd = yid->yd;
     
    15151477                struct yahoo_pair *pair = l->data;
    15161478
    1517                 switch(pair->key) {
     1479                switch (pair->key) {
    15181480                case 300:
    15191481                case 301:
    15201482                case 302:
     1483                        break;  /* Separators. Our logic does not need them */
    15211484                case 303:
    1522                         if ( 315 == atoi(pair->value) )
     1485                        if (318 == atoi(pair->value))
    15231486                                last_packet = 1;
    15241487                        break;
    15251488                case 65:
    1526                         g_free(cur_group);
    15271489                        cur_group = strdup(pair->value);
    15281490                        break;
     
    15301492                        newbud = y_new0(struct yahoo_buddy, 1);
    15311493                        newbud->id = strdup(pair->value);
    1532                         if (cur_group) {
     1494                        if (cur_group)
    15331495                                newbud->group = strdup(cur_group);
    1534                         } else {
    1535                                 YList *last;
    1536                                 struct yahoo_buddy *lastbud;
    1537                                
    1538                                 for (last = yd->buddies; last && last->next; last = last->next);
    1539                                 if (last) {
    1540                                         lastbud = last->data;
    1541                                         newbud->group = strdup(lastbud->group);
    1542                                 } else {
    1543                                         newbud->group = strdup("Buddies");
    1544                                 }
    1545                         }
     1496                        else if (yd->buddies) {
     1497                                struct yahoo_buddy *lastbud =
     1498                                        (struct yahoo_buddy *)y_list_nth(yd->
     1499                                        buddies,
     1500                                        y_list_length(yd->buddies) - 1)->data;
     1501                                newbud->group = strdup(lastbud->group);
     1502                        } else
     1503                                newbud->group = strdup("Buddies");
    15461504
    15471505                        yd->buddies = y_list_append(yd->buddies, newbud);
     
    15501508                }
    15511509        }
    1552        
    1553         g_free(cur_group);
    15541510
    15551511        /* we could be getting multiple packets here */
    1556         if (last_packet)
    1557                 return;
    1558 
    1559         YAHOO_CALLBACK(ext_yahoo_got_buddies)(yd->client_id, yd->buddies);
    1560 
    1561         /*** We login at the very end of the packet communication */
     1512        if (pkt->hash && !last_packet)
     1513                return;
     1514
     1515        YAHOO_CALLBACK(ext_yahoo_got_buddies) (yd->client_id, yd->buddies);
     1516
     1517        /* Logged in */
    15621518        if (!yd->logged_in) {
    1563                 yd->logged_in = TRUE;
    1564                 if(yd->current_status < 0)
     1519                yd->logged_in = 1;
     1520                if (yd->current_status < 0)
    15651521                        yd->current_status = yd->initial_status;
    1566                 YAHOO_CALLBACK(ext_yahoo_login_response)(yd->client_id, YAHOO_LOGIN_OK, NULL);
    1567         }
    1568 }
    1569 
    1570 static void yahoo_process_list(struct yahoo_input_data *yid, struct yahoo_packet *pkt)
     1522                YAHOO_CALLBACK(ext_yahoo_login_response) (yd->client_id,
     1523                        YAHOO_LOGIN_OK, NULL);
     1524
     1525                /*
     1526                yahoo_set_away(yd->client_id, yd->initial_status, NULL,
     1527                        (yd->initial_status == YAHOO_STATUS_AVAILABLE) ? 0 : 1);
     1528
     1529                yahoo_get_yab(yd->client_id);
     1530                */
     1531        }
     1532
     1533}
     1534
     1535static void yahoo_process_list(struct yahoo_input_data *yid,
     1536        struct yahoo_packet *pkt)
    15711537{
    15721538        struct yahoo_data *yd = yid->yd;
    15731539        YList *l;
    15741540
    1575         if (!yd->logged_in) {
    1576                 yd->logged_in = TRUE;
    1577                 if(yd->current_status < 0)
    1578                         yd->current_status = yd->initial_status;
    1579                 YAHOO_CALLBACK(ext_yahoo_login_response)(yd->client_id, YAHOO_LOGIN_OK, NULL);
    1580         }
    1581 
     1541        /* we could be getting multiple packets here */
    15821542        for (l = pkt->hash; l; l = l->next) {
    15831543                struct yahoo_pair *pair = l->data;
    15841544
    1585                 switch(pair->key) {
    1586                 case 87: /* buddies */
    1587                         if(!yd->rawbuddylist)
    1588                                 yd->rawbuddylist = strdup(pair->value);
    1589                         else {
    1590                                 yd->rawbuddylist = y_string_append(yd->rawbuddylist, pair->value);
     1545                switch (pair->key) {
     1546                case 89:        /* identities */
     1547                        {
     1548                                char **identities =
     1549                                        y_strsplit(pair->value, ",", -1);
     1550                                int i;
     1551                                for (i = 0; identities[i]; i++)
     1552                                        yd->identities =
     1553                                                y_list_append(yd->identities,
     1554                                                strdup(identities[i]));
     1555                                y_strfreev(identities);
    15911556                        }
    1592                         break;
    1593 
    1594                 case 88: /* ignore list */
    1595                         if(!yd->ignorelist)
    1596                                 yd->ignorelist = strdup("Ignore:");
    1597                         yd->ignorelist = y_string_append(yd->ignorelist, pair->value);
    1598                         break;
    1599 
    1600                 case 89: /* identities */
    1601                         {
    1602                         char **identities = y_strsplit(pair->value, ",", -1);
    1603                         int i;
    1604                         for(i=0; identities[i]; i++)
    1605                                 yd->identities = y_list_append(yd->identities,
    1606                                                 strdup(identities[i]));
    1607                         y_strfreev(identities);
    1608                         }
    1609                         YAHOO_CALLBACK(ext_yahoo_got_identities)(yd->client_id, yd->identities);
    1610                         break;
    1611                 case 59: /* cookies */
    1612                         if(yd->ignorelist) {
    1613                                 yd->ignore = bud_str2list(yd->ignorelist);
    1614                                 FREE(yd->ignorelist);
    1615                                 YAHOO_CALLBACK(ext_yahoo_got_ignore)(yd->client_id, yd->ignore);
    1616                         }
    1617                         if(yd->rawbuddylist) {
    1618                                 yd->buddies = bud_str2list(yd->rawbuddylist);
    1619                                 FREE(yd->rawbuddylist);
    1620                                 YAHOO_CALLBACK(ext_yahoo_got_buddies)(yd->client_id, yd->buddies);
    1621                         }
    1622 
    1623                         if(pair->value[0]=='Y') {
     1557                        YAHOO_CALLBACK(ext_yahoo_got_identities) (yd->client_id,
     1558                                yd->identities);
     1559                        break;
     1560                case 59:        /* cookies */
     1561                        if (pair->value[0] == 'Y') {
    16241562                                FREE(yd->cookie_y);
    16251563                                FREE(yd->login_cookie);
     
    16281566                                yd->login_cookie = getlcookie(yd->cookie_y);
    16291567
    1630                         } else if(pair->value[0]=='T') {
     1568                        } else if (pair->value[0] == 'T') {
    16311569                                FREE(yd->cookie_t);
    16321570                                yd->cookie_t = getcookie(pair->value);
    16331571
    1634                         } else if(pair->value[0]=='C') {
     1572                        } else if (pair->value[0] == 'C') {
    16351573                                FREE(yd->cookie_c);
    16361574                                yd->cookie_c = getcookie(pair->value);
    1637                         } 
    1638 
    1639                         if(yd->cookie_y && yd->cookie_t)
    1640                                 YAHOO_CALLBACK(ext_yahoo_got_cookies)(yd->client_id);
    1641 
    1642                         break;
    1643                 case 3: /* my id */
    1644                 case 90: /* 1 */
    1645                 case 100: /* 0 */
    1646                 case 101: /* NULL */
    1647                 case 102: /* NULL */
    1648                 case 93: /* 86400/1440 */
    1649                         break;
    1650                 }
    1651         }
     1575                        }
     1576
     1577                        break;
     1578                case 3: /* my id */
     1579                case 90:        /* 1 */
     1580                case 100:       /* 0 */
     1581                case 101:       /* NULL */
     1582                case 102:       /* NULL */
     1583                case 93:        /* 86400/1440 */
     1584                        break;
     1585                }
     1586        }
     1587
     1588        if (yd->cookie_y && yd->cookie_t)       /* We don't get cookie_c anymore */
     1589                YAHOO_CALLBACK(ext_yahoo_got_cookies) (yd->client_id);
    16521590}
    16531591
Note: See TracChangeset for help on using the changeset viewer.