diff options
author | Ingo Klöcker <[email protected]> | 2021-12-14 14:44:37 +0000 |
---|---|---|
committer | Ingo Klöcker <[email protected]> | 2021-12-14 14:44:37 +0000 |
commit | d35d44efaf72f90ee4f92af8382c4bcb9982da3f (patch) | |
tree | 90e0e4e08394a6ac3d3a43f7e40c6d4ac39dcb8f /src/gpgme.c | |
parent | qt: Add pattern used for WKD lookup to result (diff) | |
download | gpgme-d35d44efaf72f90ee4f92af8382c4bcb9982da3f.tar.gz gpgme-d35d44efaf72f90ee4f92af8382c4bcb9982da3f.zip |
core: Allow setting import filters when importing keys
* src/context.h (struct gpgme_context): New field import_filter.
* src/engine-backend.h (struct engine_ops): Add arg import_filter to
field 'import'.
* src/engine-gpg.c (gpg_import): Add arg import_filter and pass option
--import-filter with argument value to gpg. Adjust all callers.
* src/engine-gpgsm.c (gpgsm_import): Add dummy arg import_filter.
* src/gpgme.c (gpgme_release): Free 'import_filter'.
(gpgme_set_ctx_flag, gpgme_get_ctx_flag): New flag "import-filter".
* tests/run-import.c (main): Add option --import-filter.
--
This makes the --import-filter option available in the GPGME API for
key imports.
GnuPG-bug-id: 5739
Diffstat (limited to 'src/gpgme.c')
-rw-r--r-- | src/gpgme.c | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/src/gpgme.c b/src/gpgme.c index 2703cd72..6a5232e1 100644 --- a/src/gpgme.c +++ b/src/gpgme.c @@ -255,6 +255,7 @@ gpgme_release (gpgme_ctx_t ctx) free (ctx->trust_model); free (ctx->cert_expire); free (ctx->key_origin); + free (ctx->import_filter); _gpgme_engine_info_release (ctx->engine_info); ctx->engine_info = NULL; DESTROY_LOCK (ctx->lock); @@ -594,6 +595,13 @@ gpgme_set_ctx_flag (gpgme_ctx_t ctx, const char *name, const char *value) if (!ctx->key_origin) err = gpg_error_from_syserror (); } + else if (!strcmp (name, "import-filter")) + { + free (ctx->import_filter); + ctx->import_filter = strdup (value); + if (!ctx->import_filter) + err = gpg_error_from_syserror (); + } else err = gpg_error (GPG_ERR_UNKNOWN_NAME); @@ -671,6 +679,10 @@ gpgme_get_ctx_flag (gpgme_ctx_t ctx, const char *name) { return ctx->key_origin? ctx->key_origin : ""; } + else if (!strcmp (name, "import-filter")) + { + return ctx->import_filter? ctx->import_filter : ""; + } else return NULL; } |