X-Git-Url: http://git.shiar.nl/sc2-widget/blobdiff_plain/300140a14ec496df0368af411e02c34551ee1aef..v0.1-7-g1d18af433a:/getsc2clan diff --git a/getsc2clan b/getsc2clan index 6c02c0b..4f6bcc3 100755 --- a/getsc2clan +++ b/getsc2clan @@ -30,21 +30,36 @@ sub blizget { # find largest group consisting entirely of clan members # prefer deprecated interface to prevent costly ladder search -my $ladders = blizget(legacy => profile => 2 => 1 => $profileid => 'ladders'); -my ($ladder) = ( - sort { $b->{characters}->@* <=> $a->{characters}->@* } # population desc +my $ladderdata = blizget(legacy => profile => 2 => 1 => $profileid => 'ladders'); +my @ladders = ( + sort { + $b->{ladder}->[0]->{wins}+$b->{ladder}->[0]->{losses} <=> + $a->{ladder}->[0]->{wins}+$a->{ladder}->[0]->{losses} + } # activity desc grep { !$clanmatch or all { fc $_->{clanName} eq fc $clanmatch } $_->{characters}->@* } # members - $ladders->{currentSeason}->@* + grep { $_->{ladder}->[0]->{division} } + $ladderdata->{currentSeason}->@* ) or die "No matching groups found\n"; +my (@members, %memberidx); +$memberidx{ $_->{id} } //= push(@members, $_) && $#members + for map { $_->{characters}->@* } @ladders; say JSON->new->canonical->pretty->encode({ - league => ucfirst lc $ladder->{ladder}->[0]->{league}, - division => $ladder->{ladder}->[0]->{ladderName}, - rank => $ladder->{ladder}->[0]->{rank}, - tag => $ladder->{characters}->[0]->{clanTag}, - members => [map { blizget(metadata => profile => 2 => 1 => $_->{id}) } $ladder->{characters}->@*], - # lacks mmr, fav race (available in new api) + name => $members[0]->{clanName}, + tag => $members[0]->{clanTag}, + ladders => [map {{ + league => lc $_->{ladder}->[0]->{league}, + division => $_->{ladder}->[0]->{ladderName}, + rank => $_->{ladder}->[0]->{rank}, + members => [map { $memberidx{$_->{id}} } $_->{characters}->@*], + wins => $_->{ladder}->[0]->{wins}, + losses => $_->{ladder}->[0]->{losses}, + }} @ladders], + members => [map { + blizget(metadata => profile => 2 => 1 => $_->{id}) + # lacks mmr, fav race (available in new api) + } @members], });