From: Christian Garbs Date: Wed, 30 Sep 2015 20:49:29 +0000 (+0200) Subject: fix quoting in AsyncWgetFileGetter X-Git-Url: https://git.camperquake.de/gitweb.cgi?p=videosite.git;a=commitdiff_plain;h=8a8df14f31f9a11ad01415febd0cb95e393de204 fix quoting in AsyncWgetFileGetter 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 --- diff --git a/videosite/AsyncWgetFileGetter.pm b/videosite/AsyncWgetFileGetter.pm index 7a3642a..0cc6856 100644 --- a/videosite/AsyncWgetFileGetter.pm +++ b/videosite/AsyncWgetFileGetter.pm @@ -31,30 +31,8 @@ sub new { 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'})) { @@ -66,11 +44,9 @@ sub get { $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) { @@ -80,3 +56,26 @@ sub get { 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; +}