use /usr/share/distro-info/debian.csv to figure out the security mirror for bullseye and beyond

This commit is contained in:
Johannes 'josch' Schauer 2020-11-15 10:14:03 +01:00
parent 9d32dee3f5
commit 12b26a8817
Signed by: josch
GPG key ID: F2CBA5C78FBD83E1

View file

@ -3931,15 +3931,60 @@ sub get_sourceslist_by_suite {
} elsif (any { $_ eq $suite } @debstable } elsif (any { $_ eq $suite } @debstable
and none { $_ eq $suite } ('testing', 'unstable', 'sid')) { and none { $_ eq $suite } ('testing', 'unstable', 'sid')) {
$sourceslist .= "deb$signedby $mirror $suite-updates $compstr\n"; $sourceslist .= "deb$signedby $mirror $suite-updates $compstr\n";
if (any { $_ eq $suite } ('bullseye')) { # the security mirror changes, starting with bullseye
# starting from bullseye use
# https://lists.debian.org/87r26wqr2a.fsf@43-1.org # https://lists.debian.org/87r26wqr2a.fsf@43-1.org
my $distro_info = '/usr/share/distro-info/debian.csv';
if (-f $distro_info) {
open my $fh, '<', $distro_info
or error "cannot open $distro_info: $!";
my $i = 0;
my $matching_version;
while (my $line = <$fh>) {
chomp($line);
$i++;
my @cells = split /,/, $line;
if (scalar @cells < 4) {
error "cannot parse line $i of $distro_info";
}
if (
$i == 1
and ( scalar @cells < 6
or $cells[0] ne 'version'
or $cells[1] ne 'codename'
or $cells[2] ne 'series'
or $cells[3] ne 'created'
or $cells[4] ne 'release'
or $cells[5] ne 'eol')
) {
error "cannot find correct header in $distro_info";
}
if ($i == 1) {
next;
}
if (lc $cells[1] eq $suite or lc $cells[2] eq $suite) {
$matching_version = $cells[0];
last;
}
}
close $fh;
if ($matching_version >= 11) {
# starting from bullseye use
$sourceslist $sourceslist
.= "deb$signedby $secmirror $suite-security" . " $compstr\n"; .= "deb$signedby $secmirror $suite-security" . " $compstr\n";
} else { } else {
$sourceslist $sourceslist
.= "deb$signedby $secmirror $suite/updates" . " $compstr\n"; .= "deb$signedby $secmirror $suite/updates" . " $compstr\n";
} }
} else {
if (any { $_ eq $suite } ('bullseye', 'bookworm')) {
# starting from bullseye use
$sourceslist
.= "deb$signedby $secmirror $suite-security" . " $compstr\n";
} else {
$sourceslist
.= "deb$signedby $secmirror $suite/updates" . " $compstr\n";
}
}
} }
return $sourceslist; return $sourceslist;
} }