Merge branch 'devel'
[videosite.git] / videosite / LiveLeakGrabber.pm
index 27f4c7f..1e6bd74 100644 (file)
@@ -15,15 +15,15 @@ use strict;
 
 sub new {
     my $class = shift;
-    my $self = $class->SUPER::new();
-
-    $self->{'NAME'} = 'liveleak';
-    $self->{'PATTERNS'} = ['(http://(?:[-a-zA-Z0-9_.]+\.)*liveleak.com/view\?i=([^\&]+))'];
-
-    bless($self, $class);
-    $self->_prepare_parameters();
-
-    return $self;
+    my $self = $class->SUPER::new(
+        NAME => 'liveleak',
+        _SELFTESTURL => 'http://www.liveleak.com/view?i=688_1259911803',
+        _SELFTESTTITLE => 'Girl Wins Street Fight By Choking Her Opponent Out Cold',
+        PATTERNS => ['(http://(?:[-a-zA-Z0-9_.]+\.)*liveleak.com/view\?i=([^\&]+))'],
+        @_,
+    );
+
+    return bless($self, $class);
 }
 
 sub _parse {
@@ -33,6 +33,7 @@ sub _parse {
     my $content;
     my $metadata = {};
     my $p;
+    my $tag;
     my $ua = $self->ua();
 
     $url =~ m|$pattern|;
@@ -54,23 +55,21 @@ sub _parse {
     $p = HTML::TokeParser->new(\$content);
 
     # Look for the title
-    if ($p->get_tag('title')) {
-        $metadata->{'TITLE'} = $p->get_text();
-        $metadata->{'TITLE'} =~ s/^LiveLeak\.com\s+-\s+(.+)$/$1/im;
-    }
-
-    # Get the file containing the video metadata
-    unless(defined($content = $self->simple_get(sprintf('http://www.liveleak.com/mi?token=%s', $2), $ua))) {
-        $self->error('Could not download metadata');
-        return undef;
-    }
-
-    unless ($content =~ m/file_location=([^\&]+)\&/) {
-        $self->error('Could not find download URL');
-        return undef;
+    while ($tag = $p->get_tag('script', 'meta')) {
+        if ('meta' eq $tag->[0]) {
+            if (exists($tag->[1]->{property}) and ('og:title' eq $tag->[1]->{property})) {
+                $metadata->{'TITLE'} = $tag->[1]->{content};
+                $metadata->{'TITLE'} =~ s/^LiveLeak\.com - //;
+            }
+        } elsif ('script' eq $tag->[0]) {
+            my $e = $p->get_text();
+
+            if ($e =~ /file: "([^"]+)"/) {
+                $self->debug("Found file: %s", $1);
+                $metadata->{'DLURL'} = $1;
+            }
+        }
     }
-    $metadata->{'DLURL'} = $1;
-    $metadata->{'DLURL'} =~ s/%(..)/chr(hex($1))/ge;
 
     unless(defined($metadata->{'DLURL'}) && defined($metadata->{'TITLE'})) {
         $self->error('Could not extract download URL and title');