diff options
| author | Daniel Friesel <derf@finalrewind.org> | 2021-08-13 14:52:32 +0200 | 
|---|---|---|
| committer | Daniel Friesel <derf@finalrewind.org> | 2021-08-13 14:52:32 +0200 | 
| commit | ca372be9811a183d11a00abd539442a9e2e53cae (patch) | |
| tree | 1017345c15999c675fcd5e177a65e10b9f1b9ecd /lib | |
| parent | 7eb656dd0a461f2782e601753ee96736b7ef0d3c (diff) | |
Wagonorder: send request to www.apps-bahn.de when availability is unknown
www.apps-bahn.de/wr no longer serves "tryThese" suggestions. So, unless we
know from lib.finalrewind.org/dbdb/has_wagonorder (via ist-wr.noncd.db.de)
that the trais definitely has a wagon order, we send a wagon order request to
www.apps-bahn.de/wr to determine whether it has one or not.
We do cache the result though, so if a user clicks on the wagon order link, we
don't need to request it again.
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/DBInfoscreen/Helper/Wagonorder.pm | 67 | 
1 files changed, 46 insertions, 21 deletions
| diff --git a/lib/DBInfoscreen/Helper/Wagonorder.pm b/lib/DBInfoscreen/Helper/Wagonorder.pm index dbae538..469eda6 100644 --- a/lib/DBInfoscreen/Helper/Wagonorder.pm +++ b/lib/DBInfoscreen/Helper/Wagonorder.pm @@ -108,6 +108,7 @@ sub head_dbdb_p {  	my $cache = $self->{main_cache};  	if ( my $content = $cache->get($url) ) { +		$self->{log}->debug("wagonorder->head_dbdb_p($url): cached ($content)");  		if ( $content eq 'y' ) {  			return $promise->resolve;  		} @@ -121,10 +122,12 @@ sub head_dbdb_p {  		sub {  			my ($tx) = @_;  			if ( $tx->result->is_success ) { +				$self->{log}->debug("wagonorder->head_dbdb_p($url): y");  				$cache->set( $url, 'y' );  				$promise->resolve;  			}  			else { +				$self->{log}->debug("wagonorder->head_dbdb_p($url): n");  				$cache->set( $url, 'n' );  				$promise->reject;  			} @@ -132,6 +135,7 @@ sub head_dbdb_p {  		}  	)->catch(  		sub { +			$self->{log}->debug("wagonorder->head_dbdb_p($url): n");  			$cache->set( $url, 'n' );  			$promise->reject;  			return; @@ -150,35 +154,50 @@ sub has_cycle_p {  sub check_wagonorder_p {  	my ( $self, $train_no, $wr_link ) = @_; -	return $self->get_dbdb_p( +	my $promise = Mojo::Promise->new; + +	$self->head_dbdb_p(  		"https://lib.finalrewind.org/dbdb/has_wagonorder/${train_no}/${wr_link}" -	); +	)->then( +		sub { +			$promise->resolve; +			return; +		} +	)->catch( +		sub { +			$self->get_p( $train_no, $wr_link )->then( +				sub { +					$promise->resolve; +					return; +				} +			)->catch( +				sub { +					$promise->reject; +					return; +				} +			)->wait; +			return; +		} +	)->wait; + +	return $promise;  }  sub get_p {  	my ( $self, $train_no, $api_ts ) = @_;  	my $url -	  = "https://ist-wr.noncd.db.de/wagenreihung/1.0/${train_no}/${api_ts}"; - -	if ( -		my $content = $self->{main_cache}->get( -"https://lib.finalrewind.org/dbdb/has_wagonorder/${train_no}/${api_ts}" -		) -	  ) -	{ -		if ( $content !~ m{i} and $content =~ m{a} ) { -			$url -			  = "https://www.apps-bahn.de/wr/wagenreihung/1.0/${train_no}/${api_ts}"; -		} -	} +	  = "https://www.apps-bahn.de/wr/wagenreihung/1.0/${train_no}/${api_ts}";  	my $cache = $self->{realtime_cache};  	my $promise = Mojo::Promise->new;  	if ( my $content = $cache->thaw($url) ) { -		$self->{log}->debug("GET $url (cached)"); +		$self->{log}->debug("wagonorder->get_p($url): cached"); +		if ( $content->{error} ) { +			return $promise->reject($content); +		}  		return $promise->resolve($content);  	} @@ -188,15 +207,21 @@ sub get_p {  			my ($tx) = @_;  			if ( my $err = $tx->error ) { -				$self->{log}->warn( +				my $json = { +					error => { +						id  => $err->{code}, +						msg => $err->{message} +					} +				}; +				$self->{log}->debug(  					"wagonorder->get_p($url): HTTP $err->{code} $err->{message}"  				); -				$promise->reject( -					"GET $url returned HTTP $err->{code} $err->{message}"); +				$cache->freeze( $url, $json ); +				$promise->reject($json);  				return;  			} -			$self->{log}->debug("GET $url (OK)"); +			$self->{log}->debug("wagonorder->get_p($url): OK");  			my $json = $tx->res->json;  			$cache->freeze( $url, $json ); @@ -206,7 +231,7 @@ sub get_p {  	)->catch(  		sub {  			my ($err) = @_; -			$self->{log}->warn("GET $url: $err"); +			$self->{log}->warn("wagonorder->get_p($url): $err");  			$promise->reject("GET $url: $err");  			return;  		} | 
