diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/context.h | 3 | ||||
| -rw-r--r-- | src/engine-gpg.c | 23 | ||||
| -rw-r--r-- | src/gpgme.c | 8 | 
3 files changed, 33 insertions, 1 deletions
| diff --git a/src/context.h b/src/context.h index 202cf168..c8e75ba0 100644 --- a/src/context.h +++ b/src/context.h @@ -121,6 +121,9 @@ struct gpgme_context    /* True if the option --auto-key-retrieve shall be passed to gpg.  */    unsigned int auto_key_retrieve : 1; +  /* Do not use the symmtric encryption passphrase cache.  */ +  unsigned int no_symkey_cache : 1; +    /* Flags for keylist mode.  */    gpgme_keylist_mode_t keylist_mode; diff --git a/src/engine-gpg.c b/src/engine-gpg.c index 3b9a6ff5..a37d1f7b 100644 --- a/src/engine-gpg.c +++ b/src/engine-gpg.c @@ -145,6 +145,10 @@ struct engine_gpg    gpgme_pinentry_mode_t pinentry_mode;    char request_origin[10]; +  struct { +    unsigned int no_symkey_cache : 1; +  } flags; +    /* NULL or the data object fed to --override_session_key-fd.  */    gpgme_data_t override_session_key;  }; @@ -642,6 +646,10 @@ gpg_set_engine_flags (void *engine, const gpgme_ctx_t ctx)        else          strcpy (gpg->request_origin, ctx->request_origin);      } +  else if (ctx->no_symkey_cache && have_gpg_version (gpg, "2.2.7")) +    { +      gpg->flags.no_symkey_cache = 1; +    }    else      *gpg->request_origin = 0;  } @@ -875,7 +883,7 @@ build_argv (engine_gpg_t gpg, const char *pgmname)      argc++;    if (!gpg->cmd.used)      argc++;	/* --batch */ -  argc += 2;	/* --no-sk-comments, --request-origin */ +  argc += 3;	/* --no-sk-comments, --request-origin, --no-symkey-cache */    argv = calloc (argc + 1, sizeof *argv);    if (!argv) @@ -937,6 +945,19 @@ build_argv (engine_gpg_t gpg, const char *pgmname)        argc++;      } +  if (gpg->flags.no_symkey_cache) +    { +      argv[argc] = strdup ("--no-symkey-cache"); +      if (!argv[argc]) +	{ +          int saved_err = gpg_error_from_syserror (); +	  free (fd_data_map); +	  free_argv (argv); +	  return saved_err; +        } +      argc++; +    } +    if (gpg->pinentry_mode && have_gpg_version (gpg, "2.1.0"))      {        const char *s = NULL; diff --git a/src/gpgme.c b/src/gpgme.c index 9e65c50a..82d67478 100644 --- a/src/gpgme.c +++ b/src/gpgme.c @@ -538,6 +538,10 @@ gpgme_set_ctx_flag (gpgme_ctx_t ctx, const char *name, const char *value)        if (!ctx->request_origin)          err = gpg_error_from_syserror ();      } +  else if (!strcmp (name, "no-symkey-cache")) +    { +      ctx->no_symkey_cache = abool; +    }    else      err = gpg_error (GPG_ERR_UNKNOWN_NAME); @@ -583,6 +587,10 @@ gpgme_get_ctx_flag (gpgme_ctx_t ctx, const char *name)      {        return ctx->request_origin? ctx->request_origin : "";      } +  else if (!strcmp (name, "no-symkey-cache")) +    { +      return ctx->no_symkey_cache? "1":""; +    }    else      return NULL;  } | 
