Replies: 11 comments 1 reply
-
The key management and all hasn't changed in rpm itself, this is rpm-sequoia being far, far stricter about what is accepted than the rpm internal pgp parser ever was. To go with rpm-sequoia, you'll need to keep your keys in shape, like not have keys expired 12 years ago. The alternative is using the "traditional" PGP parser, it's still available only now split into separate repo (see INSTALL) |
Beta Was this translation helpful? Give feedback.
-
Well the key is updated on media (=repos in urpmi).
I guess I'm a special case 😅 |
Beta Was this translation helpful? Give feedback.
-
Looks like even when adding new media, we don't re-import the key: Still @pmatilai, since urpmi checks pkgs first, should it set RPMPROB_FILTER_VERIFY when calling rpmtsRun() for real since at that point the user said yes to force ? |
Beta Was this translation helpful? Give feedback.
-
Yeah rpm doesn't have a meaningful way to update keys because back when I added the "is primary key id present", we didn't know anything about expiry, revokes, subkeys .. nothing. I don't know what urpmi --no-verify does, exactly. The story on rpm side is complicated as there are multiple related and partially overlapping mechanisms: the verify step during transactions is not a "signature check" per se, it's more of a payload validation step. Signatures can be used in there, but aren't by default. If urpmi's --no-verify is supposed to be a direct --nosignature counterpart then see 5ed632a. |
Beta Was this translation helpful? Give feedback.
-
So there's two issues, so I'll use 2 parts : Updating/reimporting a pubkey: Currently the URPM C binding uses rpmtsImportPubkey() https://gitweb.mageia.org/software/rpm/perl-URPM/tree/URPM.xs#n3363 ➡️ I guess I'll have to run a small transaction removing the offending key before importing. Urpmi --no-verify The actual installation basically means we run a series of transactions here http://gitweb.mageia.org/software/rpm/urpmi/tree/urpm/install.pm#n352 But before installing, as said above, unless using --no-verify, we'll do some tests : http://gitweb.mageia.org/software/rpm/urpmi/tree/urpm/main_loop.pm#n129 So at this point we already checked the pkgs for signatures. So I think that in urpmi context, we want to prevent rpmlib to check again the pkgs since we already did it. |
Beta Was this translation helpful? Give feedback.
-
Yes, there's nothing better at the moment.
Maybe, but again that verify step is NOT about signature verification as such, it could be package whose (header) signature is perfectly valid but truncated payload, or such. For "frak the signatures", IIRC you want to set rpmtsSetVfyFlags() to same as rpmtsSetVSFlags(). Note that letting verify do its job has more subtle side-effects too: installations only show as verified in the auditing log if rpm itself verified it. |
Beta Was this translation helpful? Give feedback.
-
I've a working patch for that. BTW other packagers are throwing stones at mea, saying there's a difference between an expired key and a revoked
That would only be set up if the urpmi verify pass failed and the user said "go on anyway" or if he sets up the no-verify option in /etc/urpmi/urpmi.cfg ot used the --no-verify option, so in regular cases that won't be an issue |
Beta Was this translation helpful? Give feedback.
-
It gets all a bit filosophical. If it doesn't come invalid at that point, then when does it? And if it doesn't, what's the point of expiry in the first place? It shouldn't be possible to create new signatures with an expired key for one, but I guess expiry should be considered wrt the time of signing instead of "now" I suppose. I kinda thought that's how Sequoia does it, but not sure (tagging @nwalfield for possible comments). To evaluate what actually happens one needs to look at both the key and the signature, which we don't have linked here AFAICS. |
Beta Was this translation helpful? Give feedback.
-
Yeah but aborting on expired key when we don't have an API to refresh the key yet is an issue. |
Beta Was this translation helpful? Give feedback.
-
Oh, no disagreement there. This is a case where basically everybody got caught with their pants down: in the first 20+ years of rpm's existence nobody gave much thought to expiry and all that, but then in recent years (even before sequoia) people started running into their ancient SHA1 based keys suddenly stopping to work, first due to FIPS and then more generally distros tried to push for disabling obsoleted crypto but disabling SHA1 got postponed and postponed and postponed for things like google-chrome, and then rpm-sequoia was introduced and pushing those people more strongly to update their signing systems. And when those parties finally updated their keys we realize there's no mechanism for them to update those keys at all. 🙈 |
Beta Was this translation helpful? Give feedback.
-
@soig, I just found this threa as I was looking for an error in updating my mageia cauldron docker container image :-( After doing urpmi.update -a [... download phase ....] installing lib64rpmbuild10-4.20.0-1.mga10.x86_64.rpm lib64python3.12-stdlib-3.12.8-1.mga10.x86_64.rpm perl-XML-LibXML-2.21.0-8.mga10.x86_64.rpm python3-httplib2-0.22.0-1.mga10.noarch.rpm libgomp1-14.2.0-2.mga10.x86_64.rpm rpm-4.20.0-1.mga10.x86_64.rpm python3-packaging-24.0-1.mga10.noarch.rpm python3-tzdata-2023.3-2.mga10.noarch.rpm python3-pytz-2024.1-1.mga10.noarch.rpm pyproject-srpm-macros-1.16.3-1.mga10.noarch.rpm lib64xcrypt-devel-4.4.37-1.mga10.x86_64.rpm python3-dateutil-2.9.0.post0-1.mga10.noarch.rpm pcre2-tools-10.44-1.mga10.x86_64.rpm rpm-mageia-setup-build-2.82-1.mga10.x86_64.rpm python3-wheel-0.43.0-1.mga10.noarch.rpm mgarepo-1.14.6-2.mga10.noarch.rpm lib64rpmsign10-4.20.0-1.mga10.x86_64.rpm lib64rpm10-4.20.0-1.mga10.x86_64.rpm perl-base-5.40.0-3.mga10.x86_64.rpm lib64dw1-0.192-4.mga10.x86_64.rpm libgomp-devel-14.2.0-2.mga10.x86_64.rpm gcc-14.2.0-2.mga10.x86_64.rpm lib64debuginfod1-0.192-4.mga10.x86_64.rpm cmake-rpm-macros-9-9.mga9.noarch.rpm openssl-3.3.2-2.mga10.x86_64.rpm libgfortran5-14.2.0-2.mga10.x86_64.rpm python3-pandas-2.2.2-2.mga10.x86_64.rpm glibc-devel-2.40-1.mga10.x86_64.rpm binutils-2.43.1-2.mga10.x86_64.rpm python3-tqdm-4.67.1-2.mga10.noarch.rpm rust-srpm-macros-26.3-2.mga10.noarch.rpm python3-pygments-2.17.2-1.mga10.noarch.rpm lib64openssl3-3.3.2-2.mga10.x86_64.rpm perl-URPM-5.225-4.mga10.x86_64.rpm gcc-c++-14.2.0-2.mga10.x86_64.rpm perl-List-MoreUtils-XS-0.430-12.mga10.x86_64.rpm pyproject-rpm-macros-1.16.3-1.mga10.noarch.rpm perl-Filesys-Df-0.920.0-40.mga10.x86_64.rpm lib64mpdec4-4.0.0-1.mga10.x86_64.rpm elfutils-0.192-4.mga10.x86_64.rpm rpm-mageia-setup-2.82-1.mga10.x86_64.rpm python3-six-1.16.0-6.mga10.noarch.rpm bm-3.9-1.mga10.noarch.rpm lib64xcrypt1-4.4.37-1.mga10.x86_64.rpm glibc-2.40-1.mga10.x86_64.rpm python3-rpm-4.20.0-1.mga10.x86_64.rpm python3-numpy-2.1.3-3.mga10.x86_64.rpm openblas-0.3.28-1.mga10.x86_64.rpm python3-pip-24.3.1-1.mga10.noarch.rpm rpm-build-4.20.0-1.mga10.x86_64.rpm lib64pcre2posix3-10.44-1.mga10.x86_64.rpm perl-5.40.0-3.mga10.x86_64.rpm python3-pyparsing-3.1.2-1.mga10.noarch.rpm lib64python3.12-3.12.8-1.mga10.x86_64.rpm python3-setuptools-75.6.0-1.mga10.noarch.rpm perl-Locale-gettext-1.70.0-22.mga10.x86_64.rpm python3-3.12.8-1.mga10.x86_64.rpm perl-File-Sync-0.110.0-39.mga10.x86_64.rpm rpm-sequoia-1.7.0-1.mga10.x86_64.rpm gdb-minimal-15.2-1.mga10.x86_64.rpm libquadmath0-14.2.0-2.mga10.x86_64.rpm lib64asm1-0.192-4.mga10.x86_64.rpm lib64nsl3-2.0.1-1.mga10.x86_64.rpm lib64openblas-serial0-0.3.28-1.mga10.x86_64.rpm gcc-cpp-14.2.0-2.mga10.x86_64.rpm libstdc++6-14.2.0-2.mga10.x86_64.rpm gobject-introspection-1.82.0-1.mga10.x86_64.rpm lib64elf1-0.192-4.mga10.x86_64.rpm libstdc++-devel-14.2.0-2.mga10.x86_64.rpm gdb-headless-15.2-1.mga10.x86_64.rpm from /var/cache/urpmi/rpms [ ... removal phase ...] You should restart your computer for glibc
going on for all the remaining packages. Have you found a workaround for this ? |
Beta Was this translation helpful? Give feedback.
-
We are hitting issues on Mageia with 4.20.x.
The first issue is that signatures being refused
This one seems to be on Mageia :
However this break "urpmi --no-verify" which used to behave like rpm --noverify
But now only rpm --nosignature can bypass this check, whereas rpm --no-verify used to do the same, which looks like regression ?
Previously, we used to check pkgs in urpmi but it looks like rpm does it on its own now too:
http://gitweb.mageia.org/software/rpm/urpmi/tree/urpm/main_loop.pm#n527
Which calls:
http://gitweb.mageia.org/software/rpm/urpmi/tree/urpm/main_loop.pm#n129
Which calls:
http://gitweb.mageia.org/software/rpm/urpmi/tree/urpm/signature.pm#n40
Which calls:
http://gitweb.mageia.org/software/rpm/perl-URPM/tree/URPM.xs#n3306
Which calls rpmReadPackageFile()
See attached logs showing urpmi output with both rpm-4.19 & 4.20
For me, there's 2 issues :
Do we've to set RPMPROB_FILTER_VERIFY when calling rpmtsRun() ?
Would it impact urpmi running on older rpm versions (aka no more checks there) ?
Or should we kill that check (but then no more informative error in GUI?
Note that we all those upstream patches have been backported:
0001-Ensure-noarch-packages-don-t-get-debuginfo.patch
0001-Fix-noprep-regression-from-introducing-mkbuilddir.patch
0002-Drop-an-accidentally-added-duplicated-test.patch
0003-Make-build-in-place-much-less-of-a-hack-and-also-wor.patch
0001-Fix-incomplete-header-on-plain-src.rpm-build-modes-r.patch
0001-Hammer-in-no-debuginfo-for-noarch-packages-damn-it-r.patch
0001-Fix-regression-on-subpackage-debuginfo-RPMTAG_SOURCE.patch
0001-Fix-a-buildroot-regression-on-an-early-__spec_instal.patch
See you
LOG.urpmi-rpm-4.19.txt
LOG.urpmi-rpm-4.20.txt
Beta Was this translation helpful? Give feedback.
All reactions