diff options
author | Daniel Friesel <derf@finalrewind.org> | 2011-06-22 19:57:16 +0200 |
---|---|---|
committer | Daniel Friesel <derf@finalrewind.org> | 2011-06-22 19:57:16 +0200 |
commit | 50ac58e8ebae424bc66c593afac14954c1475e19 (patch) | |
tree | a52de5472ccb392a77f42304e6f866236f2b5803 /lib | |
parent | 12b8919088d7f4b03c14f7981296de463ab0d105 (diff) |
Travel::Status::DE::DeutscheBahn
Diffstat (limited to 'lib')
-rw-r--r-- | lib/Travel/Status/DE/DeutscheBahn.pm | 170 | ||||
-rw-r--r-- | lib/Travel/Status/DE/DeutscheBahn/Departure.pm | 69 | ||||
-rw-r--r-- | lib/Travel/Status/DeutscheBahn.pm | 65 |
3 files changed, 239 insertions, 65 deletions
diff --git a/lib/Travel/Status/DE/DeutscheBahn.pm b/lib/Travel/Status/DE/DeutscheBahn.pm new file mode 100644 index 0000000..499f540 --- /dev/null +++ b/lib/Travel/Status/DE/DeutscheBahn.pm @@ -0,0 +1,170 @@ +package Travel::Status::DE::DeutscheBahn; + +use strict; +use warnings; +use 5.010; + +use Carp qw(confess); +use LWP::UserAgent; +use POSIX qw(strftime); +use Travel::Status::DE::DeutscheBahn::Departure; +use XML::LibXML; + +our $VERSION = '0.0'; + +sub new { + my ( $obj, %conf ) = @_; + my $date = strftime( '%d.%m.%Y', localtime(time) ); + my $time = strftime( '%H:%M', localtime(time) ); + + my $ua = LWP::UserAgent->new(); + + if ( not $conf{station} ) { + confess('You need to specify a station'); + } + + my $ref = { + post => { + input => $conf{station}, + inputRef => q{#}, + date => $conf{date} || $date, + time => $conf{time} || $time, + productsFilter => '1111101000000000', + REQTrain_name => q{}, + maxJourneys => 20, + delayedJourney => undef, + start => 'Suchen', + boardType => 'Abfahrt', + ao => 'yes', + }, + }; + + $ref->{html} + = $ua->post( 'http://mobile.bahn.de/bin/mobil/bhftafel.exe/dn?rt=1', + $ref->{post} )->content(); + + $ref->{tree} = XML::LibXML->load_html( + string => $ref->{html}, + recover => 2, + suppress_errors => 1, + suppress_warnings => 1, + ); + + return bless( $ref, $obj ); +} + +sub departures { + my ($self) = @_; + + my $xp_element = XML::LibXML::XPathExpression->new( + '//table[@class="result stboard dep"]/tr'); + my $xp_time = XML::LibXML::XPathExpression->new('./td[@class="time"]'); + my $xp_train = XML::LibXML::XPathExpression->new('./td[@class="train"]'); + my $xp_route = XML::LibXML::XPathExpression->new('./td[@class="route"]'); + my $xp_dest = XML::LibXML::XPathExpression->new('./td[@class="route"]//a'); + my $xp_platform + = XML::LibXML::XPathExpression->new('./td[@class="platform"]'); + my $xp_info = XML::LibXML::XPathExpression->new('./td[@class="ris"]'); + + my $re_via = qr{ + ^ \s* (.+?) \s* \n + \d{1,2}:\d{1,2} + }mx; + + for my $tr ( @{ $self->{tree}->findnodes($xp_element) } ) { + + my ($n_time) = $tr->findnodes($xp_time); + my ( undef, $n_train ) = $tr->findnodes($xp_train); + my ($n_route) = $tr->findnodes($xp_route); + my ($n_dest) = $tr->findnodes($xp_dest); + my ($n_platform) = $tr->findnodes($xp_platform); + my ($n_info) = $tr->findnodes($xp_info); + my $first = 1; + + if ( not( $n_time and $n_dest ) ) { + next; + } + + my $time = $n_time->textContent(); + my $train = $n_train->textContent(); + my $route = $n_route->textContent(); + my $dest = $n_dest->textContent(); + my $platform = $n_platform->textContent(); + my $info = $n_info->textContent(); + my @via; + + for my $str ( $time, $train, $dest, $platform, $info ) { + $str =~ s/\n//mg; + $str =~ tr/ //s; + } + + $info =~ s/,Grund//; + + while ( $route =~ m{$re_via}g ) { + if ($first) { + $first = 0; + next; + } + my $stop = $1; + push( @via, $stop ); + } + + push( + @{ $self->{departures} }, + Travel::Status::DE::DeutscheBahn::Departure->new( + time => $time, + train => $train, + route_raw => $route, + route => \@via, + destination => $dest, + platform => $platform, + info => $info, + ) + ); + } + + return @{ $self->{departures} }; +} + +1; + +__END__ + +=head1 NAME + +Travel::Status::DE::DeutscheBahn - Interface to the DeutscheBahn online +departure monitor + +=head1 SYNOPSIS + +=head1 VERSION + +version 0.0 + +=head1 DESCRIPTION + +=head1 METHODS + +=over + +=back + +=head1 DIAGNOSTICS + +=head1 DEPENDENCIES + +=over + +=back + +=head1 BUGS AND LIMITATIONS + +=head1 SEE ALSO + +=head1 AUTHOR + +Copyright (C) 2011 by Daniel Friesel E<lt>derf@finalrewind.orgE<gt> + +=head1 LICENSE + +This module is licensed under the same terms as Perl itself. diff --git a/lib/Travel/Status/DE/DeutscheBahn/Departure.pm b/lib/Travel/Status/DE/DeutscheBahn/Departure.pm new file mode 100644 index 0000000..9ca1aa9 --- /dev/null +++ b/lib/Travel/Status/DE/DeutscheBahn/Departure.pm @@ -0,0 +1,69 @@ +package Travel::Status::DE::DeutscheBahn::Departure; + +use strict; +use warnings; +use 5.010; + +use parent 'Class::Accessor'; + +our $VERSION = '0.0'; + +Travel::Status::DE::DeutscheBahn::Departure->mk_ro_accessors( + qw(time train destination platform info)); + +sub new { + my ( $obj, %conf ) = @_; + + my $ref = \%conf; + + return bless( $ref, $obj ); +} + +sub route { + my ($self) = @_; + + return @{ $self->{route} }; +} + +1; + +__END__ + +=head1 NAME + +Travel::Status::DE::DeutscheBahn::Departure - Information about a single +departure received by Travel::Status::DE::DeutscheBahn + +=head1 SYNOPSIS + +=head1 VERSION + +version + +=head1 DESCRIPTION + +=head1 METHODS + +=over + +=back + +=head1 DIAGNOSTICS + +=head1 DEPENDENCIES + +=over + +=back + +=head1 BUGS AND LIMITATIONS + +=head1 SEE ALSO + +=head1 AUTHOR + +Copyright (C) 2011 by Daniel Friesel E<lt>derf@finalrewind.orgE<gt> + +=head1 LICENSE + +This module is licensed under the same terms as Perl itself. diff --git a/lib/Travel/Status/DeutscheBahn.pm b/lib/Travel/Status/DeutscheBahn.pm deleted file mode 100644 index dfa50d0..0000000 --- a/lib/Travel/Status/DeutscheBahn.pm +++ /dev/null @@ -1,65 +0,0 @@ -package Travel::Status::DeutscheBahn; - -use strict; -use warnings; -use 5.010; -use base 'Exporter'; - -use LWP::UserAgent; -use XML::LibXML; - -our @EXPORT_OK = (); -my $VERSION = '0.0'; - -sub new { - my ($obj, %conf) = @_; - my $ref = {}; - - my @now = localtime(time()); - - $ref->{post} = { - date => $conf{date} - // sprintf('%d.%d.%d', $now[3], $now[4] + 1, $now[5] + 1900), - time => $conf{time} - // sprintf('%d:%d', $now[2], $now[1]), - input => $conf{station}, - inputef => q{#}, - produtsFilter => '1111101000000000', - REQTrin_name => q{}, - maxJorneys => 20, - delayedJourney => undef, - start => 'Suchen', - boardType => 'Abfahrt', - ao => 'yes', - }; - - return bless($ref, $obj); -} - -sub get { - my ($self) = @_; - my $ua = LWP::UserAgent->new(); - my $reply = $ua->post( - 'http://mobile.bahn.de/bin/mobil/bhftafel.exe/dox', - $self->{post}, - )->content(); - my $tree = XML::LibXML->load_html( - string => $reply, - recover => 2, - suppress_errors => 1, - suppress_warnings => 1, - ); - - my $xp_element - = XML::LibXML::XPathExpression->new('//div[@class="sqdetailsDep trow"]'); - my $xp_line = XML::LibXML::XPathExpression->new('./a/span'); - my $xp_dep = XML::LibXML::XPathExpression->new('./span[1]'); - - for my $div (@{$tree->findnodes($xp_element)}) { - say $div->findnodes($xp_line)->[0]->textContent(); - say $div->findnodes($xp_dep)->[0]->textContent(); - say q{}; - } -} - -1; |