X-Git-Url: https://git.camperquake.de/gitweb.cgi?a=blobdiff_plain;f=videosite%2FMyVideoGrabber.pm;h=be83de2e59db837f0e47ffd367f20ca510df7801;hb=542ba5f881a3de86e9d6b01c64dbdbcff172fbaf;hp=bd0282bc906325484df9ddad0d14cc83d44a42fe;hpb=015c03c982f7ed0d56bdf81c833323e9e4de5494;p=videosite.git diff --git a/videosite/MyVideoGrabber.pm b/videosite/MyVideoGrabber.pm index bd0282b..be83de2 100644 --- a/videosite/MyVideoGrabber.pm +++ b/videosite/MyVideoGrabber.pm @@ -3,10 +3,10 @@ # # Grabber for myvideo.de -package MyVideoGrabber; +package videosite::MyVideoGrabber; -use GrabberBase; -@ISA = qw(GrabberBase); +use videosite::GrabberBase; +@ISA = qw(videosite::GrabberBase); use LWP::Simple qw(!get); use HTML::Parser; @@ -54,8 +54,7 @@ sub _parse { } $p->handler(start => \@accum, "tagname, attr"); - $p->handler(text => \@text, "text"); - $p->report_tags(qw(meta script)); + $p->report_tags(qw(meta link)); $p->utf8_mode(1); $p->parse($content); @@ -64,15 +63,23 @@ sub _parse { if ('meta' eq $e->[0]) { if ('title' eq $e->[1]->{'name'}) { $metadata->{'TITLE'} = $e->[1]->{'content'}; - $metadata->{'TITLE'} =~ s/\s*-\s*MyVideo$//; + $metadata->{'TITLE'} =~ s/\s+Video\s+-\s+\S+\s+-\s+MyVideo$//; + $self->debug("Found title: %s", $metadata->{'TITLE'}); + last; } } } # Look for the download URL - foreach $e (@text) { - if ($e->[0] =~ m|SWFObject\(.*?\.swf\?([^\&]+)\&|) { - $metadata->{'DLURL'} = $1; + foreach $e (@accum) { + if ('link' eq $e->[0]) { + if (exists($e->[1]->{'rel'}) and ('image_src' eq $e->[1]->{'rel'})) { + $metadata->{'DLURL'} = $e->[1]->{'href'}; + $metadata->{'DLURL'} =~ s,thumbs/[^/]*$,,; + $metadata->{'DLURL'} .= $metadata->{'ID'} . ".flv"; + $self->debug("Found URL: %s", $metadata->{'DLURL'}); + last; + } } }