add DBDB helper for wagonorder and stationinfo
This commit is contained in:
parent
a3149adddd
commit
4171fe22ca
3 changed files with 158 additions and 120 deletions
141
lib/Travelynx.pm
141
lib/Travelynx.pm
|
@ -16,6 +16,7 @@ use List::UtilsBy qw(uniq_by);
|
||||||
use List::MoreUtils qw(first_index);
|
use List::MoreUtils qw(first_index);
|
||||||
use Travel::Status::DE::DBWagenreihung;
|
use Travel::Status::DE::DBWagenreihung;
|
||||||
use Travel::Status::DE::IRIS::Stations;
|
use Travel::Status::DE::IRIS::Stations;
|
||||||
|
use Travelynx::Helper::DBDB;
|
||||||
use Travelynx::Helper::HAFAS;
|
use Travelynx::Helper::HAFAS;
|
||||||
use Travelynx::Helper::IRIS;
|
use Travelynx::Helper::IRIS;
|
||||||
use Travelynx::Helper::Sendmail;
|
use Travelynx::Helper::Sendmail;
|
||||||
|
@ -271,6 +272,7 @@ sub startup {
|
||||||
log => $self->app->log,
|
log => $self->app->log,
|
||||||
main_cache => $self->app->cache_iris_main,
|
main_cache => $self->app->cache_iris_main,
|
||||||
realtime_cache => $self->app->cache_iris_rt,
|
realtime_cache => $self->app->cache_iris_rt,
|
||||||
|
root_url => $self->url_for('/')->to_abs,
|
||||||
user_agent => $self->ua,
|
user_agent => $self->ua,
|
||||||
version => $self->app->config->{version},
|
version => $self->app->config->{version},
|
||||||
);
|
);
|
||||||
|
@ -280,10 +282,11 @@ sub startup {
|
||||||
$self->helper(
|
$self->helper(
|
||||||
iris => sub {
|
iris => sub {
|
||||||
my ($self) = @_;
|
my ($self) = @_;
|
||||||
state $hafas = Travelynx::Helper::IRIS->new(
|
state $iris = Travelynx::Helper::IRIS->new(
|
||||||
log => $self->app->log,
|
log => $self->app->log,
|
||||||
main_cache => $self->app->cache_iris_main,
|
main_cache => $self->app->cache_iris_main,
|
||||||
realtime_cache => $self->app->cache_iris_rt,
|
realtime_cache => $self->app->cache_iris_rt,
|
||||||
|
root_url => $self->url_for('/')->to_abs,
|
||||||
version => $self->app->config->{version},
|
version => $self->app->config->{version},
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
@ -334,6 +337,19 @@ sub startup {
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
|
||||||
|
$self->helper(
|
||||||
|
dbdb => sub {
|
||||||
|
my ($self) = @_;
|
||||||
|
state $dbdb = Travelynx::Helper::DBDB->new(
|
||||||
|
log => $self->app->log,
|
||||||
|
cache => $self->app->cache_iris_main,
|
||||||
|
root_url => $self->url_for('/')->to_abs,
|
||||||
|
user_agent => $self->ua,
|
||||||
|
version => $self->app->config->{version},
|
||||||
|
);
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
$self->helper(
|
$self->helper(
|
||||||
'now' => sub {
|
'now' => sub {
|
||||||
return DateTime->now( time_zone => 'Europe/Berlin' );
|
return DateTime->now( time_zone => 'Europe/Berlin' );
|
||||||
|
@ -1149,119 +1165,6 @@ sub startup {
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
|
||||||
$self->helper(
|
|
||||||
'get_dbdb_station_p' => sub {
|
|
||||||
my ( $self, $eva ) = @_;
|
|
||||||
|
|
||||||
my $url = "https://lib.finalrewind.org/dbdb/s/${eva}.json";
|
|
||||||
|
|
||||||
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) = @_;
|
|
||||||
|
|
||||||
if ( my $err = $tx->error ) {
|
|
||||||
return $promise->reject(
|
|
||||||
"HTTP $err->{code} $err->{message}");
|
|
||||||
}
|
|
||||||
|
|
||||||
my $json = $tx->result->json;
|
|
||||||
$cache->freeze( $url, $json );
|
|
||||||
return $promise->resolve($json);
|
|
||||||
}
|
|
||||||
)->catch(
|
|
||||||
sub {
|
|
||||||
my ($err) = @_;
|
|
||||||
return $promise->reject($err);
|
|
||||||
}
|
|
||||||
)->wait;
|
|
||||||
return $promise;
|
|
||||||
}
|
|
||||||
);
|
|
||||||
|
|
||||||
$self->helper(
|
|
||||||
'has_wagonorder_p' => sub {
|
|
||||||
my ( $self, $ts, $train_no ) = @_;
|
|
||||||
my $api_ts = $ts->strftime('%Y%m%d%H%M');
|
|
||||||
my $url
|
|
||||||
= "https://lib.finalrewind.org/dbdb/has_wagonorder/${train_no}/${api_ts}";
|
|
||||||
my $cache = $self->app->cache_iris_main;
|
|
||||||
my $promise = Mojo::Promise->new;
|
|
||||||
|
|
||||||
if ( my $content = $cache->get($url) ) {
|
|
||||||
if ( $content eq 'y' ) {
|
|
||||||
$promise->resolve;
|
|
||||||
return $promise;
|
|
||||||
}
|
|
||||||
elsif ( $content eq 'n' ) {
|
|
||||||
$promise->reject;
|
|
||||||
return $promise;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
$self->ua->request_timeout(5)->head_p($url)->then(
|
|
||||||
sub {
|
|
||||||
my ($tx) = @_;
|
|
||||||
if ( $tx->result->is_success ) {
|
|
||||||
$cache->set( $url, 'y' );
|
|
||||||
$promise->resolve;
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
$cache->set( $url, 'n' );
|
|
||||||
$promise->reject;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
)->catch(
|
|
||||||
sub {
|
|
||||||
$cache->set( $url, 'n' );
|
|
||||||
$promise->reject;
|
|
||||||
}
|
|
||||||
)->wait;
|
|
||||||
return $promise;
|
|
||||||
}
|
|
||||||
);
|
|
||||||
|
|
||||||
$self->helper(
|
|
||||||
'get_wagonorder_p' => sub {
|
|
||||||
my ( $self, $ts, $train_no ) = @_;
|
|
||||||
my $api_ts = $ts->strftime('%Y%m%d%H%M');
|
|
||||||
my $url
|
|
||||||
= "https://www.apps-bahn.de/wr/wagenreihung/1.0/${train_no}/${api_ts}";
|
|
||||||
|
|
||||||
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 $body = decode( 'utf-8', $tx->res->body );
|
|
||||||
|
|
||||||
my $json = JSON->new->decode($body);
|
|
||||||
$cache->freeze( $url, $json );
|
|
||||||
$promise->resolve($json);
|
|
||||||
}
|
|
||||||
)->catch(
|
|
||||||
sub {
|
|
||||||
my ($err) = @_;
|
|
||||||
$promise->reject($err);
|
|
||||||
}
|
|
||||||
)->wait;
|
|
||||||
return $promise;
|
|
||||||
}
|
|
||||||
);
|
|
||||||
|
|
||||||
$self->helper(
|
$self->helper(
|
||||||
'add_route_timestamps' => sub {
|
'add_route_timestamps' => sub {
|
||||||
my ( $self, $uid, $train, $is_departure ) = @_;
|
my ( $self, $uid, $train, $is_departure ) = @_;
|
||||||
|
@ -1494,11 +1397,11 @@ sub startup {
|
||||||
)->wait;
|
)->wait;
|
||||||
|
|
||||||
if ( $train->sched_departure ) {
|
if ( $train->sched_departure ) {
|
||||||
$self->has_wagonorder_p( $train->sched_departure,
|
$self->dbdb->has_wagonorder_p( $train->sched_departure,
|
||||||
$train->train_no )->then(
|
$train->train_no )->then(
|
||||||
sub {
|
sub {
|
||||||
return $self->get_wagonorder_p( $train->sched_departure,
|
return $self->dbdb->get_wagonorder_p(
|
||||||
$train->train_no );
|
$train->sched_departure, $train->train_no );
|
||||||
}
|
}
|
||||||
)->then(
|
)->then(
|
||||||
sub {
|
sub {
|
||||||
|
@ -1577,7 +1480,7 @@ sub startup {
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($is_departure) {
|
if ($is_departure) {
|
||||||
$self->get_dbdb_station_p( $journey->{dep_eva} )->then(
|
$self->dbdb->get_stationinfo_p( $journey->{dep_eva} )->then(
|
||||||
sub {
|
sub {
|
||||||
my ($station_info) = @_;
|
my ($station_info) = @_;
|
||||||
|
|
||||||
|
@ -1598,7 +1501,7 @@ sub startup {
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( $journey->{arr_eva} and not $is_departure ) {
|
if ( $journey->{arr_eva} and not $is_departure ) {
|
||||||
$self->get_dbdb_station_p( $journey->{arr_eva} )->then(
|
$self->dbdb->get_stationinfo_p( $journey->{arr_eva} )->then(
|
||||||
sub {
|
sub {
|
||||||
my ($station_info) = @_;
|
my ($station_info) = @_;
|
||||||
|
|
||||||
|
|
134
lib/Travelynx/Helper/DBDB.pm
Normal file
134
lib/Travelynx/Helper/DBDB.pm
Normal file
|
@ -0,0 +1,134 @@
|
||||||
|
package Travelynx::Helper::DBDB;
|
||||||
|
|
||||||
|
use strict;
|
||||||
|
use warnings;
|
||||||
|
use 5.020;
|
||||||
|
|
||||||
|
use Encode qw(decode);
|
||||||
|
use Mojo::Promise;
|
||||||
|
use JSON;
|
||||||
|
|
||||||
|
sub new {
|
||||||
|
my ( $class, %opt ) = @_;
|
||||||
|
|
||||||
|
my $version = $opt{version};
|
||||||
|
|
||||||
|
$opt{header}
|
||||||
|
= { 'User-Agent' =>
|
||||||
|
"travelynx/${version} on $opt{root_url} +https://finalrewind.org/projects/travelynx"
|
||||||
|
};
|
||||||
|
|
||||||
|
return bless( \%opt, $class );
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
sub has_wagonorder_p {
|
||||||
|
my ( $self, $ts, $train_no ) = @_;
|
||||||
|
my $api_ts = $ts->strftime('%Y%m%d%H%M');
|
||||||
|
my $url
|
||||||
|
= "https://lib.finalrewind.org/dbdb/has_wagonorder/${train_no}/${api_ts}";
|
||||||
|
my $cache = $self->{cache};
|
||||||
|
my $promise = Mojo::Promise->new;
|
||||||
|
|
||||||
|
if ( my $content = $cache->get($url) ) {
|
||||||
|
if ( $content eq 'y' ) {
|
||||||
|
$promise->resolve;
|
||||||
|
return $promise;
|
||||||
|
}
|
||||||
|
elsif ( $content eq 'n' ) {
|
||||||
|
$promise->reject;
|
||||||
|
return $promise;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$self->{user_agent}->request_timeout(5)->head_p( $url => $self->{header} )
|
||||||
|
->then(
|
||||||
|
sub {
|
||||||
|
my ($tx) = @_;
|
||||||
|
if ( $tx->result->is_success ) {
|
||||||
|
$cache->set( $url, 'y' );
|
||||||
|
$promise->resolve;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
$cache->set( $url, 'n' );
|
||||||
|
$promise->reject;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
)->catch(
|
||||||
|
sub {
|
||||||
|
$cache->set( $url, 'n' );
|
||||||
|
$promise->reject;
|
||||||
|
}
|
||||||
|
)->wait;
|
||||||
|
return $promise;
|
||||||
|
}
|
||||||
|
|
||||||
|
sub get_wagonorder_p {
|
||||||
|
my ( $self, $ts, $train_no ) = @_;
|
||||||
|
my $api_ts = $ts->strftime('%Y%m%d%H%M');
|
||||||
|
my $url
|
||||||
|
= "https://www.apps-bahn.de/wr/wagenreihung/1.0/${train_no}/${api_ts}";
|
||||||
|
|
||||||
|
my $cache = $self->{cache};
|
||||||
|
my $promise = Mojo::Promise->new;
|
||||||
|
|
||||||
|
if ( my $content = $cache->thaw($url) ) {
|
||||||
|
$promise->resolve($content);
|
||||||
|
return $promise;
|
||||||
|
}
|
||||||
|
|
||||||
|
$self->{user_agent}->request_timeout(5)->get_p( $url => $self->{header} )
|
||||||
|
->then(
|
||||||
|
sub {
|
||||||
|
my ($tx) = @_;
|
||||||
|
my $body = decode( 'utf-8', $tx->res->body );
|
||||||
|
|
||||||
|
my $json = JSON->new->decode($body);
|
||||||
|
$cache->freeze( $url, $json );
|
||||||
|
$promise->resolve($json);
|
||||||
|
}
|
||||||
|
)->catch(
|
||||||
|
sub {
|
||||||
|
my ($err) = @_;
|
||||||
|
$promise->reject($err);
|
||||||
|
}
|
||||||
|
)->wait;
|
||||||
|
return $promise;
|
||||||
|
}
|
||||||
|
|
||||||
|
sub get_stationinfo_p {
|
||||||
|
my ( $self, $eva ) = @_;
|
||||||
|
|
||||||
|
my $url = "https://lib.finalrewind.org/dbdb/s/${eva}.json";
|
||||||
|
|
||||||
|
my $cache = $self->{cache};
|
||||||
|
my $promise = Mojo::Promise->new;
|
||||||
|
|
||||||
|
if ( my $content = $cache->thaw($url) ) {
|
||||||
|
$promise->resolve($content);
|
||||||
|
return $promise;
|
||||||
|
}
|
||||||
|
|
||||||
|
$self->{user_agent}->request_timeout(5)->get_p( $url => $self->{header} )
|
||||||
|
->then(
|
||||||
|
sub {
|
||||||
|
my ($tx) = @_;
|
||||||
|
|
||||||
|
if ( my $err = $tx->error ) {
|
||||||
|
return $promise->reject("HTTP $err->{code} $err->{message}");
|
||||||
|
}
|
||||||
|
|
||||||
|
my $json = $tx->result->json;
|
||||||
|
$cache->freeze( $url, $json );
|
||||||
|
return $promise->resolve($json);
|
||||||
|
}
|
||||||
|
)->catch(
|
||||||
|
sub {
|
||||||
|
my ($err) = @_;
|
||||||
|
return $promise->reject($err);
|
||||||
|
}
|
||||||
|
)->wait;
|
||||||
|
return $promise;
|
||||||
|
}
|
||||||
|
|
||||||
|
1;
|
|
@ -17,7 +17,8 @@ sub new {
|
||||||
|
|
||||||
$opt{header}
|
$opt{header}
|
||||||
= { 'User-Agent' =>
|
= { 'User-Agent' =>
|
||||||
"travelynx/${version} +https://finalrewind.org/projects/travelynx" };
|
"travelynx/${version} on $opt{root_url} +https://finalrewind.org/projects/travelynx"
|
||||||
|
};
|
||||||
|
|
||||||
return bless( \%opt, $class );
|
return bless( \%opt, $class );
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue