2020-09-06 10:41:36 +00:00
|
|
|
package Travelynx::Helper::DBDB;
|
2021-02-06 11:31:35 +00:00
|
|
|
|
2023-07-03 15:59:25 +00:00
|
|
|
# Copyright (C) 2020-2023 Birte Kristina Friesel
|
2020-11-27 21:12:56 +00:00
|
|
|
#
|
2021-01-29 17:32:13 +00:00
|
|
|
# SPDX-License-Identifier: AGPL-3.0-or-later
|
2020-09-06 10:41:36 +00:00
|
|
|
|
|
|
|
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
|
2023-02-13 17:27:26 +00:00
|
|
|
= "https://ist-wr.noncd.db.de/wagenreihung/1.0/${train_no}/${api_ts}";
|
2024-05-30 09:53:33 +00:00
|
|
|
my $cache = $self->{realtime_cache};
|
2020-09-06 10:41:36 +00:00
|
|
|
my $promise = Mojo::Promise->new;
|
|
|
|
|
2021-12-12 16:24:24 +00:00
|
|
|
if ( my $content = $cache->get("HEAD $url") ) {
|
2021-02-06 11:31:35 +00:00
|
|
|
if ( $content eq 'n' ) {
|
2024-05-30 09:54:02 +00:00
|
|
|
$self->{log}
|
|
|
|
->debug("has_wagonorder_p(${train_no}/${api_ts}): n (cached)");
|
2020-09-10 19:20:26 +00:00
|
|
|
return $promise->reject;
|
2020-09-06 10:41:36 +00:00
|
|
|
}
|
2021-02-06 11:31:35 +00:00
|
|
|
else {
|
2024-05-30 09:54:02 +00:00
|
|
|
$self->{log}
|
|
|
|
->debug("has_wagonorder_p(${train_no}/${api_ts}): y (cached)");
|
2021-02-06 11:31:35 +00:00
|
|
|
return $promise->resolve($content);
|
|
|
|
}
|
2020-09-06 10:41:36 +00:00
|
|
|
}
|
|
|
|
|
2021-12-12 15:38:26 +00:00
|
|
|
$self->{user_agent}->request_timeout(5)->head_p( $url => $self->{header} )
|
2020-09-06 10:41:36 +00:00
|
|
|
->then(
|
|
|
|
sub {
|
|
|
|
my ($tx) = @_;
|
|
|
|
if ( $tx->result->is_success ) {
|
2024-05-30 09:54:02 +00:00
|
|
|
$self->{log}
|
|
|
|
->debug("has_wagonorder_p(${train_no}/${api_ts}): a");
|
2021-12-12 16:24:24 +00:00
|
|
|
$cache->set( "HEAD $url", 'a' );
|
2021-12-12 15:38:26 +00:00
|
|
|
$promise->resolve('a');
|
2020-09-06 10:41:36 +00:00
|
|
|
}
|
|
|
|
else {
|
2024-05-30 09:54:02 +00:00
|
|
|
$self->{log}
|
|
|
|
->debug("has_wagonorder_p(${train_no}/${api_ts}): n");
|
2021-12-12 16:24:24 +00:00
|
|
|
$cache->set( "HEAD $url", 'n' );
|
2020-09-06 10:41:36 +00:00
|
|
|
$promise->reject;
|
|
|
|
}
|
2020-09-10 19:20:26 +00:00
|
|
|
return;
|
2020-09-06 10:41:36 +00:00
|
|
|
}
|
|
|
|
)->catch(
|
|
|
|
sub {
|
2024-05-30 09:54:02 +00:00
|
|
|
$self->{log}->debug("has_wagonorder_p(${train_no}/${api_ts}): n");
|
2021-12-12 16:24:24 +00:00
|
|
|
$cache->set( "HEAD $url", 'n' );
|
2020-09-06 10:41:36 +00:00
|
|
|
$promise->reject;
|
2020-09-10 19:20:26 +00:00
|
|
|
return;
|
2020-09-06 10:41:36 +00:00
|
|
|
}
|
|
|
|
)->wait;
|
|
|
|
return $promise;
|
|
|
|
}
|
|
|
|
|
|
|
|
sub get_wagonorder_p {
|
2021-02-06 11:31:35 +00:00
|
|
|
my ( $self, $api, $ts, $train_no ) = @_;
|
2020-09-06 10:41:36 +00:00
|
|
|
my $api_ts = $ts->strftime('%Y%m%d%H%M');
|
|
|
|
my $url
|
2021-02-02 17:17:45 +00:00
|
|
|
= "https://ist-wr.noncd.db.de/wagenreihung/1.0/${train_no}/${api_ts}";
|
2020-09-06 10:41:36 +00:00
|
|
|
|
2024-05-30 09:53:33 +00:00
|
|
|
my $cache = $self->{realtime_cache};
|
2020-09-06 10:41:36 +00:00
|
|
|
my $promise = Mojo::Promise->new;
|
|
|
|
|
|
|
|
if ( my $content = $cache->thaw($url) ) {
|
2024-05-30 09:54:02 +00:00
|
|
|
$self->{log}
|
|
|
|
->debug("get_wagonorder_p(${train_no}/${api_ts}): (cached)");
|
2020-09-06 10:41:36 +00:00
|
|
|
$promise->resolve($content);
|
|
|
|
return $promise;
|
|
|
|
}
|
|
|
|
|
|
|
|
$self->{user_agent}->request_timeout(5)->get_p( $url => $self->{header} )
|
|
|
|
->then(
|
|
|
|
sub {
|
|
|
|
my ($tx) = @_;
|
|
|
|
|
2021-12-12 16:24:24 +00:00
|
|
|
if ( $tx->result->is_success ) {
|
|
|
|
my $body = decode( 'utf-8', $tx->res->body );
|
|
|
|
my $json = JSON->new->decode($body);
|
2024-05-30 09:54:02 +00:00
|
|
|
$self->{log}
|
|
|
|
->debug("get_wagonorder_p(${train_no}/${api_ts}): success");
|
2021-12-12 16:24:24 +00:00
|
|
|
$cache->freeze( $url, $json );
|
|
|
|
$promise->resolve($json);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
my $code = $tx->code;
|
2024-05-30 09:54:02 +00:00
|
|
|
$self->{log}->debug(
|
|
|
|
"get_wagonorder_p(${train_no}/${api_ts}): HTTP ${code}");
|
2021-12-12 16:24:24 +00:00
|
|
|
$promise->reject("HTTP ${code}");
|
|
|
|
}
|
2020-09-10 19:20:26 +00:00
|
|
|
return;
|
2020-09-06 10:41:36 +00:00
|
|
|
}
|
|
|
|
)->catch(
|
|
|
|
sub {
|
|
|
|
my ($err) = @_;
|
2024-05-30 09:54:02 +00:00
|
|
|
$self->{log}
|
|
|
|
->debug("get_wagonorder_p(${train_no}/${api_ts}): error ${err}");
|
2020-09-06 10:41:36 +00:00
|
|
|
$promise->reject($err);
|
2020-09-10 19:20:26 +00:00
|
|
|
return;
|
2020-09-06 10:41:36 +00:00
|
|
|
}
|
|
|
|
)->wait;
|
|
|
|
return $promise;
|
|
|
|
}
|
|
|
|
|
|
|
|
sub get_stationinfo_p {
|
|
|
|
my ( $self, $eva ) = @_;
|
|
|
|
|
|
|
|
my $url = "https://lib.finalrewind.org/dbdb/s/${eva}.json";
|
|
|
|
|
2024-05-30 09:53:33 +00:00
|
|
|
my $cache = $self->{main_cache};
|
2020-09-06 10:41:36 +00:00
|
|
|
my $promise = Mojo::Promise->new;
|
|
|
|
|
|
|
|
if ( my $content = $cache->thaw($url) ) {
|
2024-05-30 09:54:02 +00:00
|
|
|
$self->{log}->debug("get_stationinfo_p(${eva}): (cached)");
|
2020-09-10 19:20:26 +00:00
|
|
|
return $promise->resolve($content);
|
2020-09-06 10:41:36 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
$self->{user_agent}->request_timeout(5)->get_p( $url => $self->{header} )
|
|
|
|
->then(
|
|
|
|
sub {
|
|
|
|
my ($tx) = @_;
|
|
|
|
|
|
|
|
if ( my $err = $tx->error ) {
|
2024-05-30 09:54:02 +00:00
|
|
|
$self->{log}->debug(
|
|
|
|
"get_stationinfo_p(${eva}): HTTP $err->{code} $err->{message}"
|
|
|
|
);
|
2020-09-20 07:55:28 +00:00
|
|
|
$cache->freeze( $url, {} );
|
2020-09-10 19:20:26 +00:00
|
|
|
$promise->reject("HTTP $err->{code} $err->{message}");
|
|
|
|
return;
|
2020-09-06 10:41:36 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
my $json = $tx->result->json;
|
2024-05-30 09:54:02 +00:00
|
|
|
$self->{log}->debug("get_stationinfo_p(${eva}): success");
|
2020-09-06 10:41:36 +00:00
|
|
|
$cache->freeze( $url, $json );
|
2020-09-10 19:20:26 +00:00
|
|
|
$promise->resolve($json);
|
|
|
|
return;
|
2020-09-06 10:41:36 +00:00
|
|
|
}
|
|
|
|
)->catch(
|
|
|
|
sub {
|
|
|
|
my ($err) = @_;
|
2024-05-30 09:54:02 +00:00
|
|
|
$self->{log}->debug("get_stationinfo_p(${eva}): Error ${err}");
|
2020-09-20 07:55:28 +00:00
|
|
|
$cache->freeze( $url, {} );
|
2020-09-10 19:20:26 +00:00
|
|
|
$promise->reject($err);
|
|
|
|
return;
|
2020-09-06 10:41:36 +00:00
|
|
|
}
|
|
|
|
)->wait;
|
|
|
|
return $promise;
|
|
|
|
}
|
|
|
|
|
|
|
|
1;
|