summaryrefslogtreecommitdiff
path: root/share
diff options
context:
space:
mode:
authorBirte Kristina Friesel <derf@finalrewind.org>2024-01-04 11:44:59 +0100
committerBirte Kristina Friesel <derf@finalrewind.org>2024-01-04 11:44:59 +0100
commit68004b7dbdc1b334551752e5d4d88dd9635d9488 (patch)
treea53820922546248c629e17cf9bd471da0ca86966 /share
parent3b81412f19620a610fdd764dd6570f10deef2c29 (diff)
share/enhance: switch from transport.rest to Travel::Status::DE::HAFAS
Diffstat (limited to 'share')
-rwxr-xr-xshare/enhance28
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 ];
}
}