From: Christian Garbs Date: Tue, 18 Oct 2011 18:46:00 +0000 (+0200) Subject: go green X-Git-Url: https://git.camperquake.de/gitweb.cgi?p=videosite.git;a=commitdiff_plain;h=c2a9f7038145a7fd62f452a0a77dc09fac5403f6 go green restore the environment after polluting it with _proxy variables --- diff --git a/videosite/AsyncFileGetter.pm b/videosite/AsyncFileGetter.pm index 70fa613..e9af7e4 100644 --- a/videosite/AsyncFileGetter.pm +++ b/videosite/AsyncFileGetter.pm @@ -1,5 +1,5 @@ # (c) 2007 by Ralf Ertzinger -# 2008-2009 by Christian Garbs +# 2008-2009,2011 by Christian Garbs # # licensed under GNU GPL v2 # @@ -54,18 +54,28 @@ sub get { my (undef, $tmpfile) = tempfile('videosite.tmp.XXXXXXXXXXXX', DIR => $dirname); + my %saved_env; + if (exists($video->{'CONNECTOR'})) { - my $schemas = $video->{'CONNECTOR'}->{'schemas'}; - foreach (keys(%{$schemas})) { - $self->debug("Setting %s_proxy to %s", $_, $schemas->{$_}); - $ENV{ $_.'_proxy'} = $schemas->{$_}; - } + my $schemas = $video->{'CONNECTOR'}->{'schemas'}; + foreach my $schemakey(keys(%{$schemas})) { + $self->debug("Setting %s_proxy to %s", $schemakey, $schemas->{$schemakey}); + my $envkey = $schemakey.'_proxy'; + $saved_env{ $envkey } = $ENV{ $envkey }; + $ENV{ $envkey } = $schemas->{$schemakey}; + } } - + $cookie = "-H \"Cookie: $video->{'COOKIE'}\"" if (defined $video->{'COOKIE'}); my $cmdline = "( GET $cookie \"$video->{'DLURL'}\" > \"$tmpfile\" && mv \"$tmpfile\" \"$dlfile\" && chmod =rw \"$dlfile\" || rm -f \"$tmpfile\" ) &"; $self->debug(encode_base64($cmdline)); system($cmdline); + # restore environment + foreach my $envkey (keys %saved_env) { + $self->debug("Restoring environment: %s=%s", $envkey, $saved_env{ $envkey} ); + $ENV{ $envkey } = $saved_env{ $envkey }; + } + return 1; } diff --git a/videosite/AsyncWgetFileGetter.pm b/videosite/AsyncWgetFileGetter.pm index 8f04656..43366a3 100644 --- a/videosite/AsyncWgetFileGetter.pm +++ b/videosite/AsyncWgetFileGetter.pm @@ -1,5 +1,5 @@ # (c) 2007 by Ralf Ertzinger -# 2008-2009 by Christian Garbs +# 2008-2009,2011 by Christian Garbs # 2010 by Maximilian Rehkopf # licensed under GNU GPL v2 # @@ -53,18 +53,28 @@ sub get { my (undef, $tmpfile) = tempfile('videosite.tmp.XXXXXXXXXXXX', DIR => $dirname); + my %saved_env; + if (exists($video->{'CONNECTOR'})) { - my $schemas = $video->{'CONNECTOR'}->{'schemas'}; - foreach (keys(%{$schemas})) { - $self->debug("Setting %s_proxy to %s", $_, $schemas->{$_}); - $ENV{ $_.'_proxy'} = $schemas->{$_}; - } + my $schemas = $video->{'CONNECTOR'}->{'schemas'}; + foreach my $schemakey(keys(%{$schemas})) { + $self->debug("Setting %s_proxy to %s", $schemakey, $schemas->{$schemakey}); + my $envkey = $schemakey.'_proxy'; + $saved_env{ $envkey } = $ENV{ $envkey }; + $ENV{ $envkey } = $schemas->{$schemakey}; + } } - + $cookie = "--header=\"Cookie: $video->{'COOKIE'}\"" if (defined $video->{'COOKIE'}); my $cmdline = "( wget -q -O\"$tmpfile\" $cookie \"$video->{'DLURL'}\" && mv \"$tmpfile\" \"$dlfile\" && chmod =rw \"$dlfile\" && touch \"$dlfile\" || rm -f \"$tmpfile\" ) &"; $self->debug("Going to execute: %s", $cmdline); system($cmdline); + # restore environment + foreach my $envkey (keys %saved_env) { + $self->debug("Restoring environment: %s=%s", $envkey, $saved_env{ $envkey} ); + $ENV{ $envkey } = $saved_env{ $envkey }; + } + return 1; }