diff options
author | Birte Kristina Friesel <derf@finalrewind.org> | 2024-01-04 11:44:59 +0100 |
---|---|---|
committer | Birte Kristina Friesel <derf@finalrewind.org> | 2024-01-04 11:44:59 +0100 |
commit | 68004b7dbdc1b334551752e5d4d88dd9635d9488 (patch) | |
tree | a53820922546248c629e17cf9bd471da0ca86966 /share/enhance | |
parent | 3b81412f19620a610fdd764dd6570f10deef2c29 (diff) |
share/enhance: switch from transport.rest to Travel::Status::DE::HAFAS
Diffstat (limited to 'share/enhance')
-rwxr-xr-x | share/enhance | 28 |
1 files changed, 11 insertions, 17 deletions
diff --git a/share/enhance b/share/enhance index 42eb38f..25533c6 100755 --- a/share/enhance +++ b/share/enhance @@ -5,8 +5,7 @@ use warnings; use 5.010; use File::Slurp qw(read_file write_file); -use JSON; -use LWP::UserAgent; +use Travel::Status::DE::HAFAS; my $json_str = read_file('stations.json'); my $stations = JSON->new->utf8->decode($json_str); @@ -18,24 +17,19 @@ $ua->env_proxy; for my $station ( @{$stations} ) { if ( not $station->{latlong} ) { say "Requesting location for $station->{name} ..."; - my $res = $ua->get( - sprintf( 'https://v6.db.transport.rest/stops/%07d', - $station->{eva} ) + my $hafas = Travel::Status::DE::HAFAS->new( + locationSearch => $station->{name}, ); - if ( $res->is_error ) { - say ' transport.rest returned error ' . $res->status_line; + if (not scalar $hafas->results) { + say ' not found'; + next; } - else { - my $content = $res->decoded_content; - my $json = JSON->new->utf8->decode($content); - if ( $json and $json->{location} and $json->{location}{latitude} ) { - $station->{latlong} = [ $json->{location}{latitude}, - $json->{location}{longitude} ]; - } - else { - say ' transport.rest has no location'; - } + my $result = ($hafas->results)[0]; + if ($result->name ne $station->{name}) { + say ' name mismatch: got ' . $result->name; + next; } + $station->{latlong} = [ $result->lat, $result->lon ]; } } |