diff options
Diffstat (limited to 'lib/Net/Travel')
| -rw-r--r-- | lib/Net/Travel/DE/VRR.pm | 83 | 
1 files changed, 44 insertions, 39 deletions
| diff --git a/lib/Net/Travel/DE/VRR.pm b/lib/Net/Travel/DE/VRR.pm index cb4b5ec..fd3edc4 100644 --- a/lib/Net/Travel/DE/VRR.pm +++ b/lib/Net/Travel/DE/VRR.pm @@ -12,16 +12,16 @@ use XML::LibXML;  our $VERSION = '1.3';  sub post_time { -	my ( $post, $conf ) = @_; +	my ( $self, $conf ) = @_;  	my $time;  	if ( $conf->{departure_time} ) { -		$post->{itdTripDateTimeDepArr} = 'dep'; +		$self->{post}->{itdTripDateTimeDepArr} = 'dep';  		$time = $conf->{departure_time} || $conf->{time};  	}  	else { -		$post->{itdTripDateTimeDepArr} = 'arr'; +		$self->{post}->{itdTripDateTimeDepArr} = 'arr';  		$time = $conf->{arrival_time};  	} @@ -29,13 +29,13 @@ sub post_time {  		confess("time: must match HH:MM - '${time}'");  	} -	@{$post}{ 'itdTimeHour', 'itdTimeMinute' } = split( /:/, $time ); +	@{ $self->{post} }{ 'itdTimeHour', 'itdTimeMinute' } = split( /:/, $time );  	return;  }  sub post_date { -	my ( $post, $date ) = @_; +	my ( $self, $date ) = @_;  	my ( $day, $month, $year ) = split( /[.]/, $date ); @@ -51,14 +51,14 @@ sub post_date {  		$year = ( localtime(time) )[5] + 1900;  	} -	@{$post}{ 'itdDateDay', 'itdDateMonth', 'itdDateYear' } +	@{ $self->{post} }{ 'itdDateDay', 'itdDateMonth', 'itdDateYear' }  	  = ( $day, $month, $year );  	return;  }  sub post_exclude { -	my ( $post, @exclude ) = @_; +	my ( $self, @exclude ) = @_;  	my @mapping = qw{  	  zug s-bahn u-bahn stadtbahn tram stadtbus regionalbus @@ -69,7 +69,7 @@ sub post_exclude {  		my $ok = 0;  		for my $map_id ( 0 .. $#mapping ) {  			if ( $exclude_type eq $mapping[$map_id] ) { -				$post->{"inclMOT_${map_id}"} = undef; +				$self->{post}->{"inclMOT_${map_id}"} = undef;  				$ok = 1;  			}  		} @@ -82,12 +82,12 @@ sub post_exclude {  }  sub post_prefer { -	my ( $post, $prefer ) = @_; +	my ( $self, $prefer ) = @_;  	given ($prefer) { -		when ('speed')    { $post->{routeType} = 'LEASTTIME' } -		when ('waittime') { $post->{routeType} = 'LEASTINTERCHANGE' } -		when ('distance') { $post->{routeType} = 'LEASTWALKING' } +		when ('speed')    { $self->{post}->{routeType} = 'LEASTTIME' } +		when ('waittime') { $self->{post}->{routeType} = 'LEASTINTERCHANGE' } +		when ('distance') { $self->{post}->{routeType} = 'LEASTWALKING' }  		default {  			confess(  "select_interchange_by: Must be speed/waittime/distance: '${prefer}'" @@ -99,12 +99,12 @@ sub post_prefer {  }  sub post_include { -	my ( $post, $include ) = @_; +	my ( $self, $include ) = @_;  	given ($include) { -		when ('local') { $post->{lineRestriction} = 403 } -		when ('ic')    { $post->{lineRestriction} = 401 } -		when ('ice')   { $post->{lineRestriction} = 400 } +		when ('local') { $self->{post}->{lineRestriction} = 403 } +		when ('ic')    { $self->{post}->{lineRestriction} = 401 } +		when ('ice')   { $self->{post}->{lineRestriction} = 400 }  		default {  			confess("train_type: Must be local/ic/ice: '${include}'");  		} @@ -114,10 +114,10 @@ sub post_include {  }  sub post_walk_speed { -	my ( $post, $walk_speed ) = @_; +	my ( $self, $walk_speed ) = @_;  	if ( $walk_speed ~~ [ 'normal', 'fast', 'slow' ] ) { -		$post->{changeSpeed} = $walk_speed; +		$self->{post}->{changeSpeed} = $walk_speed;  	}  	else {  		confess("walk_speed: Must be normal/fast/slow: '${walk_speed}'"); @@ -127,7 +127,7 @@ sub post_walk_speed {  }  sub post_place { -	my ( $post, $which, $place, $stop, $type ) = @_; +	my ( $self, $which, $place, $stop, $type ) = @_;  	if ( not( $place and $stop ) ) {  		confess('place: Need two elements'); @@ -135,19 +135,22 @@ sub post_place {  	$type //= 'stop'; -	@{$post}{ "place_${which}", "name_${which}" } = ( $place, $stop ); +	@{ $self->{post} }{ "place_${which}", "name_${which}" } = ( $place, $stop );  	if ( $type ~~ [qw[address poi stop]] ) { -		$post->{"type_${which}"} = $type; +		$self->{post}->{"type_${which}"} = $type;  	}  	return;  }  sub create_post { -	my ($conf) = @_; -	my @now    = localtime( time() ); -	my $post   = { +	my ($self) = @_; + +	my $conf = $self->{config}; +	my @now  = localtime( time() ); + +	$self->{post} = {  		changeSpeed                                        => 'normal',  		command                                            => q{},  		execInst                                           => q{}, @@ -235,41 +238,41 @@ sub create_post {  		useRealtime                                        => 1  	}; -	post_place( $post, 'origin',      @{ $conf->{origin} } ); -	post_place( $post, 'destination', @{ $conf->{destination} } ); +	$self->post_place( 'origin',      @{ $conf->{origin} } ); +	$self->post_place( 'destination', @{ $conf->{destination} } );  	if ( $conf->{via} ) { -		post_place( $post, 'via', @{ $conf->{via} } ); +		$self->post_place( 'via', @{ $conf->{via} } );  	}  	if ( $conf->{arrival_time} || $conf->{departure_time} ) { -		post_time( $post, $conf ); +		$self->post_time($conf);  	}  	if ( $conf->{date} ) { -		post_date( $post, $conf->{date} ); +		$self->post_date( $conf->{date} );  	}  	if ( $conf->{exclude} ) { -		post_exclude( $post, @{ $conf->{exclude} } ); +		$self->post_exclude( @{ $conf->{exclude} } );  	}  	if ( $conf->{max_interchanges} ) { -		$post->{maxChanges} = $conf->{max_interchanges}; +		$self->{post}->{maxChanges} = $conf->{max_interchanges};  	}  	if ( $conf->{select_interchange_by} ) { -		post_prefer( $post, $conf->{select_interchange_by} ); +		$self->post_prefer( $conf->{select_interchange_by} );  	}  	if ( $conf->{use_near_stops} ) { -		$post->{useProxFootSearch} = 1; +		$self->{post}->{useProxFootSearch} = 1;  	}  	if ( $conf->{train_type} ) { -		post_include( $post, $conf->{train_type} ); +		$self->post_include( $conf->{train_type} );  	}  	if ( $conf->{walk_speed} ) { -		post_walk_speed( $post, $conf->{walk_speed} ); +		$self->post_walk_speed( $conf->{walk_speed} );  	}  	if ( $conf->{with_bike} ) { -		$post->{bikeTakeAlong} = 1; +		$self->{post}->{bikeTakeAlong} = 1;  	} -	return $post; +	return;  }  sub parse_initial { @@ -386,9 +389,11 @@ sub new {  	$ref->{config} = \%conf; -	$ref->{post} = create_post( \%conf ); +	bless( $ref, $obj ); + +	$ref->create_post(); -	return bless( $ref, $obj ); +	return $ref;  }  sub submit { | 
