1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
|
#!/usr/bin/perl -w
################################################################
#
# Copyright (c) 1995-2014 SUSE Linux Products GmbH
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License version 2 or 3 as
# published by the Free Software Foundation.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program (see the file COPYING); if not, write to the
# Free Software Foundation, Inc.,
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
#
################################################################
BEGIN {
unshift @INC, ($::ENV{'BUILD_DIR'} || '/usr/lib/build');
}
use LWP::UserAgent;
use URI;
use File::Path;
use File::Basename;
use strict;
sub hide_passwd {
my $url = shift;
$url =~ s|://[^@]*@|://|;
return $url
}
die "USAGE: $0 DIR URLS..." unless $#ARGV >= 1;
my $dir = shift @ARGV;
my $ua = LWP::UserAgent->new(
agent => "openSUSE build script",
timeout => 42,
ssl_opts => {
verify_hostname => 1
});
for my $url (@ARGV) {
my $original = $url;
if ($url =~ /^zypp:\/\/([^\/]*)\/?/) {
use Build::Zypp;
my $repo = Build::Zypp::parserepo($1);
die "can't parse $1\n" unless $repo;
die "missing url in repo ".$repo->{'name'}."\n" unless exists $repo->{'baseurl'};
my $u = $repo->{'baseurl'};
$u .= '/' unless $u =~ /\/$/;
$url =~ s/^zypp:\/\/[^\/]*\/*//;
$url = URI->new($u.$url);
if ($url->scheme eq 'dir') {
my $dest = "$dir/".basename($url->path);
unlink($dest); # just in case
system('cp', $url->path, $dest) && die("cp $url->path $dest failed\n");
last;
}
} else {
my $found = 0;
if ( defined $ENV{BUILD_ROOT} && -e $ENV{BUILD_ROOT} . "/.repo.config" ) {
open FILE, "<", $ENV{BUILD_ROOT} . "/.repo.config" or die $!;
while (<FILE>) {
next if ($_ !~ /^http[s]?:\/\/([^\/]*)\/?/);
chomp($_);
my $hidden = URI->new($_);
my $ui = $hidden->userinfo;
$hidden->userinfo(undef);
if ( $url =~ m/^$hidden/ ) {
$url = URI->new($url);
$url->userinfo($ui);
$found = 1;
last;
}
}
close FILE;
}
if ($found == 0 ) {
$url = URI->new($url);
}
}
$ua->env_proxy if $url->scheme ne 'https';
my $dest = "$dir/".basename($url->path).".tmp";
unlink($dest); # just in case
my $retry = 3;
while ($retry--) {
my $res = $ua->mirror($url, $dest);
last if $res->is_success;
# if it's a redirect we probably got a bad mirror and should just retry
die "reqesting " . hide_passwd($original) . " failed: ".$res->status_line."\n" unless $retry && $res->previous;
warn "retrying " . hide_passwd($original) . "\n";
}
rename($dest, "$dir/".basename($url->path));
}
# vim:sw=2
|