Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

rpm --import does not update our release pubkey #953

Open
3 tasks done
rocodes opened this issue Feb 21, 2024 · 2 comments
Open
3 tasks done

rpm --import does not update our release pubkey #953

rocodes opened this issue Feb 21, 2024 · 2 comments
Labels

Comments

@rocodes
Copy link
Contributor

rocodes commented Feb 21, 2024

Summary

dom0 updates recently started failing for longstanding SDW installs, with the behaviour that the SDW updater and GUI updater would fail, and on inspection of the updatevm console, the following message appeared:

1. Certificiate [sic] 188EDD3B7B22E6A3 invalid: certificate is not alive
    because: The primary key is not live
    because: Expired on 2023-07-04T10:52:20Z
2. Key 188EDD3B7B22E6A3 invalid: key is not alive
    because: The primary key is not live
    because: Expired on 2023-07-04T10:52:20Z
[...]
Error: GPG check FAILED

This is caused by this issue in RPM, where a key different subkeys but the same master key fingerprint (our use case) is not replaced in the rpm database when rpm --import is run. When we bumped our release key last summer, the updated key was put in place at /etc/pki/rpm-gpg/RPM-GPG-KEY-securedrop-workstation, but the rpm import command meant it wasn't imported into the rpm pubkey database. (Visible by querying pubkeys via rpm -qi and comparing).

Why now?

Hard to say why this didn't bite us sooner, but my best guess is that this upstream commit changed the behaviour of which rpm db material was 'winning' and being used in the updatevm. It came a few weeks after our key bump, so this would be the first time we would have released a new dom0 rpm since then.

Manual resolution

The good news is, the appropriate key is already on users' machines in dom0, in /etc/pki/rpm-gpg.

sudo rpm -q gpg-pubkey --qf '%{NAME}-%{VERSION}-%{RELEASE}\t%{SUMMARY}\n' | grep SecureDrop
# expected: gpg-pubkey-xxxxx-xxxxx        SecureDrop Release Signing Key <[email protected]  public key
sudo rpm -e gpg-pubkey-xxxxxx-xxxxxx 
sudo rpm --import /etc/pki/rpm-GPG/RPM-GPG-KEY-securedrop-workstation

Next steps

@rocodes
Copy link
Contributor Author

rocodes commented Jun 26, 2024

Commenting that in the upstream ticket above, there's been some progress towards resolving this issue, so the combination of that plus our longer release key expiry (#1046) means hopefully we won't encounter this again in SDW, although we should keep it open until we're sure.

(A 4.1 workaround has been linked above)

@rocodes rocodes moved this to Ready For Review in SecureDrop dev cycle Jun 26, 2024
@rocodes rocodes removed the status in SecureDrop dev cycle Jun 26, 2024
@rocodes rocodes removed the qubes-4.1 label Jun 26, 2024
@rocodes
Copy link
Contributor Author

rocodes commented Jul 3, 2024

Don't want to close this til it's fully resolved upstream, but the current status is: fixed in 4.1 (workaround); not relevant for our release signing key for 3 more years in 4.2 (longer signing key expiry).

@rocodes rocodes moved this to In Progress in SecureDrop dev cycle Dec 20, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
Status: In Progress
Development

No branches or pull requests

2 participants