[pacman-dev] [PATCH 4/5 v2] be_package: lookup missing keys in the WKD using the packager email
Jonas Witschel
diabonas at gmx.de
Mon Aug 5 15:32:36 UTC 2019
In contrast to the preceeding commit we do not have a database with the
required packager information to work with, so we need to extract the
package temporarily to obtain this information.
Signed-off-by: Jonas Witschel <diabonas at gmx.de>
---
lib/libalpm/be_package.c | 12 +++++++++++-
1 file changed, 11 insertions(+), 1 deletion(-)
diff --git a/lib/libalpm/be_package.c b/lib/libalpm/be_package.c
index fbb0d43e..ee148831 100644
--- a/lib/libalpm/be_package.c
+++ b/lib/libalpm/be_package.c
@@ -731,6 +731,8 @@ int SYMEXPORT alpm_pkg_load(alpm_handle_t *handle, const char *filename, int ful
{
int validation = 0;
char *sigpath;
+ alpm_pkg_t *pkg_temp;
+ char *email;
CHECK_HANDLE(handle, return -1);
ASSERT(pkg != NULL, RET_ERR(handle, ALPM_ERR_WRONG_ARGS, -1));
@@ -755,9 +757,17 @@ int SYMEXPORT alpm_pkg_load(alpm_handle_t *handle, const char *filename, int ful
for(k = keys; k; k = k->next) {
char *key = k->data;
if(_alpm_key_in_keychain(handle, key) == 0) {
- if(_alpm_key_import(handle, NULL, key) == -1) {
+ pkg_temp = _alpm_pkg_load_internal(handle, filename, full);
+ if(pkg_temp) {
+ _alpm_email_from_packager(pkg_temp->packager, &email);
+ _alpm_pkg_free(pkg_temp);
+ } else {
+ email = NULL;
+ }
+ if(_alpm_key_import(handle, email, key) == -1) {
fail = 1;
}
+ free(email);
}
}
FREELIST(keys);
--
2.22.0
More information about the pacman-dev
mailing list