prefer european blizzard api endpoint
[sc2-widget] / getsc2clan
index 6c02c0bd2cec780ece29040d4625665337db277e..60cbc1a50d7521153bc662bec71ed1cad89544dd 100755 (executable)
@@ -12,17 +12,16 @@ my ($profileid, $clanmatch) = @ARGV;  # clan host and name
 $profileid and $profileid =~ /\A\d+\z/
        or die "Usage: $0 <profile id> [<clan name>]\n";
 
-my $bliz = LWP::Authen::OAuth2->new(
-       client_id               => '7f0f95ac9529474f854ee8d68a12c3e0',
-       client_secret           => 'Kfa8n98UAaDo4brOeqxe9C2kJE9pqpSd',
-       token_endpoint          => 'https://us.battle.net/oauth/token',
+my %auth = do './.blizzard.passwd.pl' or die "no auth setup: $!\n";
+my $bliz = LWP::Authen::OAuth2->new(%auth,
+       token_endpoint          => 'https://eu.battle.net/oauth/token',
        request_required_params => [qw( client_id client_secret grant_type )],
 );
 $bliz->request_tokens(grant_type => 'client_credentials');
 
 sub blizget {
        my $args = join('/', @_);
-       my $res = $bliz->get("https://us.api.blizzard.com/sc2/$args");
+       my $res = $bliz->get("https://eu.api.blizzard.com/sc2/$args");
        $res->is_success or die $res->status_line;
        my $json = $res->decoded_content;
        return decode_json($json);
@@ -30,21 +29,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],
+}) =~ s/(?: \G \d,? | \[ ) \K \s+ (?=\d|\])/ /grx; # concat arrays of single digits