Fix occasionally incorrect TripIDs (and thus incorrect polylines)
Until now, tripIDs were cached based on station and departure timestamp. These are identical for any two trains departing at the same time at the same station, leading to one of those getting being assigned a wrong tripID. From now on, only the JSON reported by transport.rest is cached -- tripIDs are always recomputed based on it.
This commit is contained in:
parent
d66cf00d9d
commit
ac2a23c3fa
1 changed files with 32 additions and 14 deletions
|
@ -2135,27 +2135,15 @@ sub startup {
|
||||||
= "https://2.db.transport.rest/stations/${eva}/arrivals?duration=5&when=$dep_ts";
|
= "https://2.db.transport.rest/stations/${eva}/arrivals?duration=5&when=$dep_ts";
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( my $content = $cache->get($url) ) {
|
$self->get_hafas_rest_p($url)->then(
|
||||||
$promise->resolve($content);
|
|
||||||
return $promise;
|
|
||||||
}
|
|
||||||
|
|
||||||
$self->ua->request_timeout(5)->get_p(
|
|
||||||
$url => {
|
|
||||||
'User-Agent' => 'travelynx/' . $self->app->config->{version}
|
|
||||||
}
|
|
||||||
)->then(
|
|
||||||
sub {
|
sub {
|
||||||
my ($tx) = @_;
|
my ($json) = @_;
|
||||||
my $body = decode( 'utf-8', $tx->res->body );
|
|
||||||
my $json = JSON->new->decode($body);
|
|
||||||
|
|
||||||
for my $result ( @{$json} ) {
|
for my $result ( @{$json} ) {
|
||||||
if ( $result->{line}
|
if ( $result->{line}
|
||||||
and $result->{line}{fahrtNr} == $train->train_no )
|
and $result->{line}{fahrtNr} == $train->train_no )
|
||||||
{
|
{
|
||||||
my $trip_id = $result->{tripId};
|
my $trip_id = $result->{tripId};
|
||||||
$cache->set( $url, $trip_id );
|
|
||||||
$promise->resolve($trip_id);
|
$promise->resolve($trip_id);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -2173,6 +2161,36 @@ sub startup {
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
|
||||||
|
$self->helper(
|
||||||
|
'get_hafas_rest_p' => sub {
|
||||||
|
my ( $self, $url ) = @_;
|
||||||
|
|
||||||
|
my $cache = $self->app->cache_iris_main;
|
||||||
|
my $promise = Mojo::Promise->new;
|
||||||
|
|
||||||
|
if ( my $content = $cache->thaw($url) ) {
|
||||||
|
$promise->resolve($content);
|
||||||
|
return $promise;
|
||||||
|
}
|
||||||
|
|
||||||
|
$self->ua->request_timeout(5)->get_p($url)->then(
|
||||||
|
sub {
|
||||||
|
my ($tx) = @_;
|
||||||
|
my $json = JSON->new->decode( $tx->res->body );
|
||||||
|
$cache->freeze( $url, $json );
|
||||||
|
$promise->resolve($json);
|
||||||
|
}
|
||||||
|
)->catch(
|
||||||
|
sub {
|
||||||
|
my ($err) = @_;
|
||||||
|
$self->app->log->warn("get($url): $err");
|
||||||
|
$promise->reject($err);
|
||||||
|
}
|
||||||
|
)->wait;
|
||||||
|
return $promise;
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
$self->helper(
|
$self->helper(
|
||||||
'get_hafas_json_p' => sub {
|
'get_hafas_json_p' => sub {
|
||||||
my ( $self, $url ) = @_;
|
my ( $self, $url ) = @_;
|
||||||
|
|
Loading…
Reference in a new issue