fix quoting in AsyncWgetFileGetter
authorChristian Garbs <mitch@cgarbs.de>
Wed, 30 Sep 2015 20:49:29 +0000 (22:49 +0200)
committerChristian Garbs <mitch@cgarbs.de>
Tue, 6 Oct 2015 18:48:23 +0000 (20:48 +0200)
make youtube file wfAnJt-j4Gs work, it has a funny title with lots of special characters:
►Heinrichs & Hirtenfellner @ Licht & Liebe Berlin Opening ♬♫ ..•❤* ★¨`•♫.•´.¸.•´❤♫♬♩

- use ' instead of " to escape shell arguments
- use qq{} instead of "" for more readable perl code
- overwrite FileGetter::_download() instead of duplicating all of FileGetter::get()

Conflicts:
videosite/AsyncWgetFileGetter.pm

videosite/AsyncWgetFileGetter.pm

index 7a3642a..0cc6856 100644 (file)
@@ -31,30 +31,8 @@ sub new {
 sub get {
     my $self = shift;
     my $video = shift;
 sub get {
     my $self = shift;
     my $video = shift;
-    my $dlfile;
-    my $dirname;
-    my $cookie = "";
-    my $useragent = "--user-agent=Mozilla/5.0";
-
-    $dlfile = sprintf($self->_getval('FILEPATTERN'),
-        $self->_encode($video->{'SOURCE'}),
-        $self->_encode($video->{'ID'}),
-        $self->_encode($video->{'TITLE'}),
-        $self->_encode($video->{'DLURL'}),
-        $self->_encode($video)->{'URL'});
-
-    $dlfile =~ s/([\\"])/\\$1/g;
-
-    $dirname = dirname($dlfile);
-    if ($self->_diskfree($dirname) < $self->_getval('MINFREE')) {
-        $self->error("Not enough free space to download");
-        return 0;
-    }
-
-    $self->debug('Going to download %s to %s', $video->{'DLURL'}, $dlfile);
-
-    my (undef, $tmpfile) = tempfile('videosite.tmp.XXXXXXXXXXXX', DIR => $dirname);
 
 
+    # saving the environment has nice race conditions... :(
     my %saved_env;
     
     if (exists($video->{'CONNECTOR'})) {
     my %saved_env;
     
     if (exists($video->{'CONNECTOR'})) {
@@ -66,11 +44,9 @@ sub get {
             $ENV{ $envkey } = $schemas->{$schemakey};
         }
     }
             $ENV{ $envkey } = $schemas->{$schemakey};
         }
     }
-    
-    $cookie = "--header=\"Cookie: $video->{'COOKIE'}\"" if (defined $video->{'COOKIE'});
-    my $cmdline = "( wget -q -O\"$tmpfile\" $useragent $cookie \"$video->{'DLURL'}\" && mv \"$tmpfile\" \"$dlfile\" && chmod =rw \"$dlfile\" && touch \"$dlfile\" || rm -f \"$tmpfile\" ) &";
-    $self->debug("Going to execute: %s", $cmdline);
-    system($cmdline);
+
+    # dispatch to super class method
+    $self->SUPER::get($video);
 
     # restore environment
     foreach my $envkey (keys %saved_env) {
 
     # restore environment
     foreach my $envkey (keys %saved_env) {
@@ -80,3 +56,26 @@ sub get {
 
     return 1;
 }
 
     return 1;
 }
+
+sub _download {
+    my $self = shift;
+    my $dlurl = shift;
+    my $dlfile = shift;
+    my $video = shift;
+    my $res;
+    my $cookie = '';
+    my $useragent = qq{ --user-agent='Mozilla/4.0 (compatible; MSIE 5.0; Linux) Opera 5.0  [en]' };
+
+    $dlfile =~ s/([\\'])/\\$1/g; # ???
+
+    my (undef, $tmpfile) = tempfile('videosite.tmp.XXXXXXXXXXXX', DIR => dirname($dlfile));
+
+    $self->debug('Going to download %s to %s (%s)', $dlurl, $dlfile, $tmpfile);
+
+    $cookie = qq{ --header='Cookie: $video->{'COOKIE'}'} if (defined $video->{'COOKIE'});
+    my $cmdline = qq{ ( wget -q -O'$tmpfile' $useragent $cookie '$video->{'DLURL'}' && mv '$tmpfile' '$dlfile' && chmod =rw '$dlfile' && touch '$dlfile' || rm -f '$tmpfile' ) & };
+    $self->debug("Going to execute: %s", $cmdline);
+    system($cmdline);
+
+    return 1;
+}