diff options
| author | Ingo Klöcker <[email protected]> | 2023-01-25 10:21:39 +0000 | 
|---|---|---|
| committer | Ingo Klöcker <[email protected]> | 2023-01-25 10:26:34 +0000 | 
| commit | 5b79b323971cb0794c45791851d85f8a66f0a441 (patch) | |
| tree | e3f4788ad6c8b581f776863b9011b305bd8a3ceb /src/engine-gpg.c | |
| parent | core: Support usage of gpgtar for decrypting an encrypted archive (diff) | |
| download | gpgme-5b79b323971cb0794c45791851d85f8a66f0a441.tar.gz gpgme-5b79b323971cb0794c45791851d85f8a66f0a441.zip | |
core: Support usage of gpgtar for verifying a signed archive
* src/gpgme.h.in (gpgme_verify_flags_t): New enum.
(GPGME_VERIFY_ARCHIVE): New const.
(gpgme_op_verify_ext_start): New func.
(gpgme_op_verify_ext): New func.
* src/gpgme.def, src/libgpgme.vers: Add new functions.
* src/verify.c (gpgme_op_verify_ext_start): New.
(gpgme_op_verify_ext): New.
(verify_start): Add arg FLAGS.  Pass the flags to
_gpgme_engine_op_verify.
(gpgme_op_verify_start): Call gpgme_op_verify_ext_start with 0 for
FLAGS.
(gpgme_op_verify): Call gpgme_op_verify_ext with 0 for FLAGS.
* src/engine.c, src/engine.h (_gpgme_engine_op_verify): Add arg FLAGS.
* src/engine-backend.h (struct engine_ops): Add FLAGS to 'verify'.
* src/engine-gpg.c (gpg_verify): Add arg FLAGS. Set use_gpgtar engine
flag if GPGME_VERIFY_ARCHIVE flag is set. Check for new enough gpg. Use
add_gpg_arg for gpg-only options without a value. Set extra options for
gpgtar and pass input data to stdin when using gpgtar.
* src/engine-gpgsm.c (gpgsm_verify): Add arg FLAGS. Return error if
GPGME_VERIFY_ARCHIVE flag is set.
* src/engine-uiserver.c (uiserver_verify): Ditto.
* tests/run-verify.c (show_usage): New options --archive, --directory,
and --diagnostics.
(main): Parse new options. Verify and extract with gpgtar if --archive
is given. Set file name of output data to value of --directory option.
Print stderr of gpg/gpgtar if --diagnostics is given.
--
GnuPG-bug-id: 6342
Diffstat (limited to '')
| -rw-r--r-- | src/engine-gpg.c | 31 | 
1 files changed, 27 insertions, 4 deletions
| diff --git a/src/engine-gpg.c b/src/engine-gpg.c index 86422112..2f63d6ff 100644 --- a/src/engine-gpg.c +++ b/src/engine-gpg.c @@ -3666,20 +3666,43 @@ gpg_sign (void *engine, gpgme_data_t in, gpgme_data_t out,  }  static gpgme_error_t -gpg_verify (void *engine, gpgme_data_t sig, gpgme_data_t signed_text, -	    gpgme_data_t plaintext, gpgme_ctx_t ctx) +gpg_verify (void *engine, gpgme_verify_flags_t flags, gpgme_data_t sig, +            gpgme_data_t signed_text, gpgme_data_t plaintext, gpgme_ctx_t ctx)  {    engine_gpg_t gpg = engine;    gpgme_error_t err; +  gpg->flags.use_gpgtar = !!(flags & GPGME_VERIFY_ARCHIVE); + +  if (gpg->flags.use_gpgtar && !have_gpg_version (gpg, "2.3.5")) +    return gpg_error (GPG_ERR_NOT_SUPPORTED); +    err = append_args_from_sender (gpg, ctx);    if (!err && gpg->flags.auto_key_import) -    err = add_arg (gpg, "--auto-key-import"); +    err = add_gpg_arg (gpg, "--auto-key-import");    if (!err && ctx->auto_key_retrieve) -    err = add_arg (gpg, "--auto-key-retrieve"); +    err = add_gpg_arg (gpg, "--auto-key-retrieve");    if (err)      ; +  else if (gpg->flags.use_gpgtar) +    { +      const char *file_name = gpgme_data_get_file_name (plaintext); +      if (!err && file_name) +        { +          err = add_arg (gpg, "--directory"); +          if (!err) +            err = add_arg (gpg, file_name); +        } +      /* gpgtar uses --decrypt also for signed-only archives */ +      err = add_arg (gpg, "--decrypt"); +      if (!err) +        err = add_input_size_hint (gpg, sig); +      if (!err) +        err = add_arg (gpg, "--"); +      if (!err) +        err = add_data (gpg, sig, 0, 0); +    }    else if (plaintext)      {        /* Normal or cleartext signature.  */ | 
