diff options
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/Travelynx/Command/maintenance.pm | 44 | 
1 files changed, 44 insertions, 0 deletions
| diff --git a/lib/Travelynx/Command/maintenance.pm b/lib/Travelynx/Command/maintenance.pm index 5cbf982..a70d42a 100644 --- a/lib/Travelynx/Command/maintenance.pm +++ b/lib/Travelynx/Command/maintenance.pm @@ -128,6 +128,50 @@ sub run {  	}  	$tx->commit; + +	# Add estimated polylines to journeys logged before 2020-01-28 + +	$tx = $db->begin; + +	say 'Adding polylines to journeys logged before 2020-01-28'; +	my $no_polyline +	  = $db->select( 'journeys', 'count(*) as count', { polyline_id => undef } ) +	  ->hash; +	say "Checking $no_polyline->{count} journeys ..."; + +	for my $journey ( +		$db->select( 'journeys', [ 'id', 'route' ], { polyline_id => undef } ) +		->hashes->each ) +	{ +		my $ref = $db->select( +			'journeys', +			[ 'id', 'polyline_id' ], +			{ +				route       => $journey->{route}, +				polyline_id => { '!=', undef } +			}, +			{ limit => 1 } +		)->hash; +		if ($ref) { +			my $rows = $db->update( +				'journeys', +				{ polyline_id => $ref->{polyline_id} }, +				{ id          => $journey->{id} } +			)->rows; +			if ( $rows != 1 ) { +				say STDERR +"Database update returned $rows rows, expected 1. Rollback and abort."; +				exit(1); +			} +		} +	} + +	my $remaining +	  = $db->select( 'journeys', 'count(*) as count', { polyline_id => undef } ) +	  ->hash; +	say "Done! Remaining journeys without polyline: " . $remaining->{count}; + +	$tx->commit;  }  1; | 
