yifengyou / rpms / yum

Forked from rpms/yum 4 years ago
Clone

Blame SOURCES/BZ-1451817-docs-improve-payload-gpgcheck-opt.patch

5e9bef
diff -up yum-3.4.3/docs/yum.conf.5.orig yum-3.4.3/docs/yum.conf.5
5e9bef
--- yum-3.4.3/docs/yum.conf.5.orig	2017-10-26 11:13:52.013324456 +0200
5e9bef
+++ yum-3.4.3/docs/yum.conf.5	2017-10-26 11:15:37.733858789 +0200
5e9bef
@@ -106,28 +106,34 @@ default for all repositories. The defaul
5e9bef
 
5e9bef
 .IP
5e9bef
 \fBpayload_gpgcheck\fR
5e9bef
-Either `1' or `0'. This tells yum whether or not it should also perform a GPG
5e9bef
-signature check on the payload (part of a package holding the actual files that
5e9bef
-comprise the package).
5e9bef
-
5e9bef
-By default, yum only performs GPG signature checks on package headers.
5e9bef
-Thus, if the payload data has been tampered with or corrupted, yum will fail in
5e9bef
-the middle of the transaction due to an RPM unpacking error, after some
5e9bef
-unverified scriptlets might have already run, and possibly leave the package in
5e9bef
-question partly installed.
5e9bef
-
5e9bef
-To prevent all of that, you can enable this option to extend the signature
5e9bef
-check to also include the payload, so that yum can avoid running the
5e9bef
-transaction in case of payload corruption.
5e9bef
-This slightly improves security, however at the expense of significantly
5e9bef
-increased transaction time, so you may want to only use this option when
5e9bef
-package corruption is a concern.
5e9bef
+Either `1' or `0'. This tells yum whether or not it should perform a v3
5e9bef
+signature check on packages when \fBgpgcheck\fR (or \fBlocalpkg_gpgcheck\fR for
5e9bef
+local packages) is enabled.
5e9bef
+
5e9bef
+There are two types of GPG signatures generated by rpm: v3 (on header+payload)
5e9bef
+and v4 (on header only).  When rpm signs a package, it creates both types.  Yum
5e9bef
+can verify any of them before the transaction, depending on which options are
5e9bef
+set.  When \fBgpgcheck\fR is enabled and this option is disabled, yum will
5e9bef
+verify v4 signatures only.  When both \fBgpgcheck\fR and this option are
5e9bef
+enabled, yum will verify both v4 and v3 signatures (equivalent to running "rpm
5e9bef
+\-\-checksig").  The same rules apply to local packages and the
5e9bef
+\fBlocalpkg_gpgcheck\fR option accordingly.
5e9bef
+
5e9bef
+Since the header contains sha256 digests of individual files in the payload (a
5e9bef
+gzip-compressed cpio archive of files used in the package), verifying the
5e9bef
+header signature (v4) is sufficient to ensure authenticity and integrity of the
5e9bef
+whole package.  After rpm unpacks the payload, it moves the files to their
5e9bef
+destination paths one by one after they pass the digest check.  If a file
5e9bef
+doesn't pass, it won't be moved and the transaction will abort.  However,
5e9bef
+because no rollback is done in such a case, the package may end up in the
5e9bef
+partially installed state.
5e9bef
+
5e9bef
+By verifying v3 signatures, yum will detect payload tamper before the
5e9bef
+transaction.  While this will slightly increase processing time for big
5e9bef
+transactions and/or packages, it will prevent such broken installs and enhance
5e9bef
+security.
5e9bef
 
5e9bef
-For this option to have effect, make sure to also enable gpgcheck (or
5e9bef
-localpkg_gpgcheck for local packages).
5e9bef
-
5e9bef
-When this option is set in the [main] section it sets the default for all
5e9bef
-repositories. The default is `0'.
5e9bef
+The default is `0'.
5e9bef
 
5e9bef
 .IP
5e9bef
 \fBskip_broken\fR
5e9bef
diff -up yum-3.4.3/rpmUtils/miscutils.py.orig yum-3.4.3/rpmUtils/miscutils.py
5e9bef
--- yum-3.4.3/rpmUtils/miscutils.py.orig	2017-10-26 11:13:49.637334921 +0200
5e9bef
+++ yum-3.4.3/rpmUtils/miscutils.py	2017-10-26 11:15:43.141834969 +0200
5e9bef
@@ -61,8 +61,8 @@ def compareVerOnly(v1, v2):
5e9bef
 def checkSig(ts, package, payload=False):
5e9bef
     """Takes a transaction set and a package, check it's sigs.
5e9bef
 
5e9bef
-    By default, only RPMv4 sigs (header-only) will be verified (faster).  By
5e9bef
-    setting payload to True, RPMv3 sigs (header+payload) will also be verified
5e9bef
+    By default, only v4 sigs (header-only) will be verified (faster).  By
5e9bef
+    setting payload to True, v3 sigs (header+payload) will also be verified
5e9bef
     (slower).
5e9bef
 
5e9bef
     return 0 if they are all fine