From c33f2943fe01fd629a0beda4efcf2a3b60b1c7f0 Mon Sep 17 00:00:00 2001 From: Florian Festi Date: Wed, 21 Feb 2024 08:25:27 +0100 Subject: [PATCH] Add --list and --delete to rpmkeys This is a bit of a hack as it manipulates the parsed cli parameters to to the "right thing" and then calls rpmcliQuery and rpmErase. --- docs/man/rpmkeys.8.md | 18 +++++++++++++++--- tests/rpmdb.at | 35 ++++++++++++++++++++++++++++++++++- tools/rpmkeys.c | 40 ++++++++++++++++++++++++++++++++++------ 3 files changed, 83 insertions(+), 10 deletions(-) diff --git a/docs/man/rpmkeys.8.md b/docs/man/rpmkeys.8.md index 9d4105939f..79b0f9b029 100644 --- a/docs/man/rpmkeys.8.md +++ b/docs/man/rpmkeys.8.md @@ -12,15 +12,19 @@ rpmkeys - RPM Keyring SYNOPSIS ======== -**rpmkeys** {**\--import\|\--checksig**} +**rpmkeys** {**\--list\|\--import\|\--delete\|\--checksig**} DESCRIPTION =========== The general forms of rpm digital signature commands are +**rpmkeys** **\--list** \[*KEYHASH \...*\] + **rpmkeys** **\--import** *PUBKEY \...* +**rpmkeys** **\--delete** *KEYHASH \...* + **rpmkeys** {**-K\|\--checksig**} *PACKAGE\_FILE \...* The **\--checksig** option checks all the digests and signatures @@ -37,13 +41,21 @@ example, all currently imported public keys can be displayed by: **rpm -q gpg-pubkey** -Details about a specific public key, when imported, can be displayed by +A more convenient way to display them is + +**rpmkeys** **\--list** + +More details about a specific public key, when imported, can be displayed by querying. Here\'s information about the Red Hat GPG/DSA key: **rpm -qi gpg-pubkey-db42a60e** Finally, public keys can be erased after importing just like packages. -Here\'s how to remove the Red Hat GPG/DSA key +Here\'s how to remove the Red Hat GPG/DSA key: + +**rpmkeys** **\--delete db42a60e** + +Or alternatively: **rpm -e gpg-pubkey-db42a60e** diff --git a/tests/rpmdb.at b/tests/rpmdb.at index 1ff60e9088..536069e003 100644 --- a/tests/rpmdb.at +++ b/tests/rpmdb.at @@ -56,7 +56,7 @@ runroot rpm \ [ignore]) RPMTEST_CLEANUP -AT_SETUP([rpm -qa 3]) +AT_SETUP([rpm -qa and rpmkeys]) AT_KEYWORDS([rpmdb query]) RPMDB_INIT @@ -82,6 +82,39 @@ gpg-pubkey-1964c5fc-58e63918 hello-2.0-1.x86_64 ], []) + +RPMTEST_CHECK([ +runroot rpmkeys --list +], +[0], +[1964c5fc-58e63918: rpm.org RSA testkey public key +], +[]) + +RPMTEST_CHECK([ +runroot rpmkeys --list 1964c5fc +], +[0], +[1964c5fc-58e63918: rpm.org RSA testkey public key +], +[]) + +RPMTEST_CHECK([ +runroot rpmkeys --list XXX +], +[1], +[package gpg-pubkey-XXX is not installed +], +[]) + +RPMTEST_CHECK([ +runroot rpmkeys --delete 1964c5fc +runroot rpmkeys --list +], +[1], +[package gpg-pubkey is not installed +], +[]) RPMTEST_CLEANUP # ------------------------------ diff --git a/tools/rpmkeys.c b/tools/rpmkeys.c index afaffe5013..adb65735c6 100644 --- a/tools/rpmkeys.c +++ b/tools/rpmkeys.c @@ -2,6 +2,7 @@ #include #include +#include #include "cliutils.h" #include "debug.h" @@ -22,12 +23,10 @@ static struct poptOption keyOptsTable[] = { N_("import an armored public key"), NULL }, { "test", '\0', POPT_ARG_NONE, &test, 0, N_("don't import, but tell if it would work or not"), NULL }, -#if 0 - { "delete-key", '\0', (POPT_ARG_VAL|POPT_ARGFLAG_OR), &mode, MODE_DELKEY, + { "delete", '\0', (POPT_ARG_VAL|POPT_ARGFLAG_OR), &mode, MODE_DELKEY, + N_("delete keys from RPM keyring"), NULL }, + { "list", '\0', (POPT_ARG_VAL|POPT_ARGFLAG_OR), &mode, MODE_LISTKEY, N_("list keys from RPM keyring"), NULL }, - { "list-keys", '\0', (POPT_ARG_VAL|POPT_ARGFLAG_OR), &mode, MODE_LISTKEY, - N_("list keys from RPM keyring"), NULL }, -#endif POPT_TABLEEND }; @@ -42,6 +41,21 @@ static struct poptOption optionsTable[] = { POPT_TABLEEND }; +static ARGV_t gpgkeyargs(ARGV_const_t args) { + ARGV_t gpgargs = NULL; + for (char * const * arg = args; *arg; arg++) { + if (strncmp(*arg, "gpg-pubkey-", 11)) { + char * gpgarg = NULL; + rstrscat(&gpgarg, "gpg-pubkey-", *arg, NULL); + argvAdd(&gpgargs, gpgarg); + free(gpgarg); + } else { + argvAdd(&gpgargs, *arg); + } + } + return gpgargs; +} + int main(int argc, char *argv[]) { int ec = EXIT_FAILURE; @@ -73,9 +87,23 @@ int main(int argc, char *argv[]) rpmtsSetFlags(ts, (rpmtsFlags(ts)|RPMTRANS_FLAG_TEST)); ec = rpmcliImportPubkeys(ts, args); break; - /* XXX TODO: actually implement these... */ case MODE_DELKEY: + struct rpmInstallArguments_s * ia = &rpmIArgs; + ARGV_t gpgargs = gpgkeyargs(args); + ec = rpmErase(ts, ia, gpgargs); + argvFree(gpgargs); + break; case MODE_LISTKEY: + ARGV_t query = NULL; + if (args != NULL) { + query = gpgkeyargs(args); + } else { + argvAdd(&query, "gpg-pubkey"); + } + QVA_t qva = &rpmQVKArgs; + rstrcat(&qva->qva_queryFormat, "%{version}-%{release}: %{summary}\n"); + ec = rpmcliQuery(ts, &rpmQVKArgs, (ARGV_const_t) query); + query = argvFree(query); break; default: argerror(_("only one major mode may be specified"));