summaryrefslogtreecommitdiffstats
path: root/frikanalen/bin
diff options
context:
space:
mode:
authorPetter Reinholdtsen <pere@hungry.com>2013-02-19 08:58:09 +0000
committerPetter Reinholdtsen <pere@hungry.com>2013-02-19 08:58:09 +0000
commit89104c34e9e6381c229fb36e8b371ff6fb61d614 (patch)
tree55382d84a732af3af2853cb71cc1b1eb80347a45 /frikanalen/bin
parent50764daefca510ad83ab3d9659a8ee045e93756f (diff)
Update to use new API.
Diffstat (limited to 'frikanalen/bin')
-rwxr-xr-xfrikanalen/bin/frikanalen-tonostats58
1 files changed, 27 insertions, 31 deletions
diff --git a/frikanalen/bin/frikanalen-tonostats b/frikanalen/bin/frikanalen-tonostats
index fb3a8e1..31ac0b0 100755
--- a/frikanalen/bin/frikanalen-tonostats
+++ b/frikanalen/bin/frikanalen-tonostats
@@ -7,50 +7,45 @@ use Data::Dumper;
use Getopt::Std;
-# SOAP:Lite må modifiseres til å gjøre ting på MS måten :-/
-use SOAP::Lite on_action => sub {sprintf '%s/%s', @_}, ;
+use JSON;
+use LWP::Simple;
-sub get_tono_stats {
- my $soap = new SOAP::Lite
- -> uri('http://localhost/CommunitySiteService')
- -> proxy('http://communitysite1.frikanalen.tv/CommunitySiteFacade/CommunitySiteService.asmx');
-
- my $obj = $soap->SearchVideos(
- SOAP::Data->name('searcher' => {
- 'PredefinedSearchType' => 'Default',
- 'Take' => 10000,
- }
- )
- );
- if ($obj->fault) {
- print join ', ',
- $obj->faultcode,
- $obj->faultstring;
- return;
- }
-
- my $res = $obj->result;
-# print Dumper($res);
- unless ($res->{'Data'}) {
+sub get_tono_stats_page {
+ my $url = shift;
+ my $jsonstr = get($url);
+ my $json = decode_json( $jsonstr );
+ print Dumper($json);
+ unless ($json->{'results'}) {
return;
}
my $tono = 0;
my $notono = 0;
- foreach my $video (@{$res->{'Data'}->{'Video'}}) {
- if ("true" eq $video->{'HasTonoRecords'}) {
+ foreach my $video (@{$json->{'results'}}) {
+ if (exists $video->{'has_tono_records'}
+ && $video->{'has_tono_records'}) {
$tono++;
- $orgs{$video->{'Organization'}}{tono}++;
- push(@{$orgs{$video->{'Organization'}}{tonoids}},
- $video->{MetaDataVideoId});
+ $orgs{$video->{'organization'}}{tono}++;
+ push(@{$orgs{$video->{'organization'}}{tonoids}},
+ $video->{id});
# print Dumper($video);
# exit 0;
} else {
$notono++;
- $orgs{$video->{'Organization'} || ""}{notono}++;
+ $orgs{$video->{'organization'} || ""}{notono}++;
}
}
+ if (defined $json->{'next'}) {
+ my ($newtono, $newnotono) = get_tono_stats_page($json->{'next'});
+ $tono += $newtono;
+ $notono += $newnotono;
+ }
return ($tono, $notono);
}
+
+sub get_tono_stats {
+ my $url = 'http://beta.frikanalen.tv/ws/videos/';
+ return get_tono_stats_page($url);
+}
sub print_tono_stats {
my ($with, $without) = get_tono_stats();
printf("Innslag med tono-musikk: %d (%.1f%%)\n", $with, 100 * $with / ($with+$without));
@@ -60,7 +55,8 @@ sub print_tono_stats {
for my $org (sort tonoorder keys %orgs) {
my $tono = $orgs{$org}{tono} || 0;
my $notono = $orgs{$org}{notono} || 0;
- my $frac = 100 * $tono / $with;
+ my $frac = 0;
+ $frac = 100 * $tono / $with if $with;
printf "%4.1f\t%d\t%d\t%s\n", $frac, $tono, $notono, $org;
print join(" ", " ", @{$orgs{$org}{tonoids}}), "\n"
if $opts{'i'} && exists $orgs{$org}{tonoids};