Blame src/decrypt-verify.c

Packit d7e8d0
/* decrypt-verify.c - Decrypt and verify function.
Packit Service 30b792
 * Copyright (C) 2000 Werner Koch (dd9jn)
Packit Service 30b792
 * Copyright (C) 2001, 2002, 2003, 2004 g10 Code GmbH
Packit Service 30b792
 *
Packit Service 30b792
 * This file is part of GPGME.
Packit Service 30b792
 *
Packit Service 30b792
 * GPGME is free software; you can redistribute it and/or modify it
Packit Service 30b792
 * under the terms of the GNU Lesser General Public License as
Packit Service 30b792
 * published by the Free Software Foundation; either version 2.1 of
Packit Service 30b792
 * the License, or (at your option) any later version.
Packit Service 30b792
 *
Packit Service 30b792
 * GPGME is distributed in the hope that it will be useful, but
Packit Service 30b792
 * WITHOUT ANY WARRANTY; without even the implied warranty of
Packit Service 30b792
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit Service 30b792
 * Lesser General Public License for more details.
Packit Service 30b792
 *
Packit Service 30b792
 * You should have received a copy of the GNU Lesser General Public
Packit Service 30b792
 * License along with this program; if not, see <https://gnu.org/licenses/>.
Packit Service 30b792
 * SPDX-License-Identifier: LGPL-2.1-or-later
Packit Service 30b792
 */
Packit d7e8d0
Packit d7e8d0
#if HAVE_CONFIG_H
Packit d7e8d0
#include <config.h>
Packit d7e8d0
#endif
Packit d7e8d0
Packit d7e8d0
#include <assert.h>
Packit d7e8d0
Packit d7e8d0
#include "debug.h"
Packit d7e8d0
#include "gpgme.h"
Packit d7e8d0
#include "ops.h"
Packit d7e8d0
Packit d7e8d0

Packit d7e8d0
static gpgme_error_t
Packit d7e8d0
decrypt_verify_status_handler (void *priv, gpgme_status_code_t code,
Packit d7e8d0
			       char *args)
Packit d7e8d0
{
Packit d7e8d0
  gpgme_error_t err;
Packit d7e8d0
Packit d7e8d0
  err = _gpgme_progress_status_handler (priv, code, args);
Packit d7e8d0
  if (!err)
Packit d7e8d0
    err = _gpgme_decrypt_status_handler (priv, code, args);
Packit d7e8d0
  if (!err)
Packit d7e8d0
      err = _gpgme_verify_status_handler (priv, code, args);
Packit d7e8d0
  return err;
Packit d7e8d0
}
Packit d7e8d0
Packit d7e8d0
Packit d7e8d0
static gpgme_error_t
Packit d7e8d0
decrypt_verify_start (gpgme_ctx_t ctx, int synchronous,
Packit d7e8d0
                      gpgme_decrypt_flags_t flags,
Packit d7e8d0
		      gpgme_data_t cipher, gpgme_data_t plain)
Packit d7e8d0
{
Packit d7e8d0
  gpgme_error_t err;
Packit d7e8d0
Packit d7e8d0
  assert ((flags & GPGME_DECRYPT_VERIFY));
Packit d7e8d0
Packit d7e8d0
  err = _gpgme_op_reset (ctx, synchronous);
Packit d7e8d0
  if (err)
Packit d7e8d0
    return err;
Packit d7e8d0
Packit Service 30b792
  err = _gpgme_op_decrypt_init_result (ctx, plain);
Packit d7e8d0
  if (err)
Packit d7e8d0
    return err;
Packit d7e8d0
Packit d7e8d0
  err = _gpgme_op_verify_init_result (ctx);
Packit d7e8d0
  if (err)
Packit d7e8d0
    return err;
Packit d7e8d0
Packit d7e8d0
  if (!cipher)
Packit d7e8d0
    return gpg_error (GPG_ERR_NO_DATA);
Packit d7e8d0
  if (!plain)
Packit d7e8d0
    return gpg_error (GPG_ERR_INV_VALUE);
Packit d7e8d0
Packit d7e8d0
  if (ctx->passphrase_cb)
Packit d7e8d0
    {
Packit d7e8d0
      err = _gpgme_engine_set_command_handler
Packit Service 30b792
	(ctx->engine, _gpgme_passphrase_command_handler, ctx);
Packit d7e8d0
      if (err)
Packit d7e8d0
	return err;
Packit d7e8d0
    }
Packit d7e8d0
Packit d7e8d0
  _gpgme_engine_set_status_handler (ctx->engine,
Packit d7e8d0
				    decrypt_verify_status_handler, ctx);
Packit d7e8d0
Packit d7e8d0
  return _gpgme_engine_op_decrypt (ctx->engine,
Packit d7e8d0
                                   flags,
Packit d7e8d0
                                   cipher, plain,
Packit d7e8d0
                                   ctx->export_session_keys,
Packit d7e8d0
                                   ctx->override_session_key,
Packit d7e8d0
                                   ctx->auto_key_retrieve);
Packit d7e8d0
}
Packit d7e8d0
Packit d7e8d0
Packit d7e8d0
/* Decrypt ciphertext CIPHER and make a signature verification within
Packit d7e8d0
   CTX and store the resulting plaintext in PLAIN.  */
Packit d7e8d0
gpgme_error_t
Packit d7e8d0
gpgme_op_decrypt_verify_start (gpgme_ctx_t ctx, gpgme_data_t cipher,
Packit d7e8d0
			       gpgme_data_t plain)
Packit d7e8d0
{
Packit d7e8d0
  gpgme_error_t err;
Packit d7e8d0
Packit Service 30b792
  TRACE_BEG  (DEBUG_CTX, "gpgme_op_decrypt_verify_start", ctx,
Packit d7e8d0
	      "cipher=%p, plain=%p", cipher, plain);
Packit d7e8d0
Packit d7e8d0
  if (!ctx)
Packit d7e8d0
    return TRACE_ERR (gpg_error (GPG_ERR_INV_VALUE));
Packit d7e8d0
Packit d7e8d0
  err = decrypt_verify_start (ctx, 0, GPGME_DECRYPT_VERIFY, cipher, plain);
Packit d7e8d0
  return TRACE_ERR (err);
Packit d7e8d0
}
Packit d7e8d0
Packit d7e8d0
Packit d7e8d0
/* Decrypt ciphertext CIPHER and make a signature verification within
Packit d7e8d0
   CTX and store the resulting plaintext in PLAIN.  */
Packit d7e8d0
gpgme_error_t
Packit d7e8d0
gpgme_op_decrypt_verify (gpgme_ctx_t ctx, gpgme_data_t cipher,
Packit d7e8d0
			 gpgme_data_t plain)
Packit d7e8d0
{
Packit d7e8d0
  gpgme_error_t err;
Packit d7e8d0
Packit Service 30b792
  TRACE_BEG  (DEBUG_CTX, "gpgme_op_decrypt_verify", ctx,
Packit d7e8d0
	      "cipher=%p, plain=%p", cipher, plain);
Packit d7e8d0
Packit d7e8d0
  if (!ctx)
Packit d7e8d0
    return TRACE_ERR (gpg_error (GPG_ERR_INV_VALUE));
Packit d7e8d0
Packit d7e8d0
  err = decrypt_verify_start (ctx, 1, GPGME_DECRYPT_VERIFY, cipher, plain);
Packit d7e8d0
  if (!err)
Packit d7e8d0
    err = _gpgme_wait_one (ctx);
Packit Service 30b792
  ctx->ignore_mdc_error = 0;  /* Always reset.  */
Packit d7e8d0
  return TRACE_ERR (err);
Packit d7e8d0
}
Packit d7e8d0
Packit d7e8d0
Packit d7e8d0
/* Decrypt ciphertext CIPHER within CTX and store the resulting
Packit d7e8d0
   plaintext in PLAIN.  */
Packit d7e8d0
gpgme_error_t
Packit d7e8d0
gpgme_op_decrypt_ext_start (gpgme_ctx_t ctx,
Packit d7e8d0
                            gpgme_decrypt_flags_t flags,
Packit d7e8d0
                            gpgme_data_t cipher,
Packit d7e8d0
                            gpgme_data_t plain)
Packit d7e8d0
{
Packit d7e8d0
  gpgme_error_t err;
Packit d7e8d0
Packit Service 30b792
  TRACE_BEG  (DEBUG_CTX, "gpgme_op_decrypt_ext_start", ctx,
Packit d7e8d0
	      "cipher=%p, plain=%p", cipher, plain);
Packit d7e8d0
Packit d7e8d0
  if (!ctx)
Packit d7e8d0
    return TRACE_ERR (gpg_error (GPG_ERR_INV_VALUE));
Packit d7e8d0
Packit d7e8d0
  if ((flags & GPGME_DECRYPT_VERIFY))
Packit d7e8d0
    err = decrypt_verify_start (ctx, 0, flags, cipher, plain);
Packit d7e8d0
  else
Packit d7e8d0
    err = _gpgme_decrypt_start (ctx, 0, flags, cipher, plain);
Packit d7e8d0
  return TRACE_ERR (err);
Packit d7e8d0
}
Packit d7e8d0
Packit d7e8d0
Packit d7e8d0
/* Decrypt ciphertext CIPHER within CTX and store the resulting
Packit d7e8d0
   plaintext in PLAIN.  */
Packit d7e8d0
gpgme_error_t
Packit d7e8d0
gpgme_op_decrypt_ext (gpgme_ctx_t ctx,
Packit d7e8d0
                      gpgme_decrypt_flags_t flags,
Packit d7e8d0
                      gpgme_data_t cipher,
Packit d7e8d0
                      gpgme_data_t plain)
Packit d7e8d0
{
Packit d7e8d0
  gpgme_error_t err;
Packit d7e8d0
Packit Service 30b792
  TRACE_BEG  (DEBUG_CTX, "gpgme_op_decrypt_ext", ctx,
Packit d7e8d0
	      "cipher=%p, plain=%p", cipher, plain);
Packit d7e8d0
Packit d7e8d0
  if (!ctx)
Packit d7e8d0
    return TRACE_ERR (gpg_error (GPG_ERR_INV_VALUE));
Packit d7e8d0
Packit d7e8d0
  if ((flags & GPGME_DECRYPT_VERIFY))
Packit d7e8d0
    err = decrypt_verify_start (ctx, 1, flags, cipher, plain);
Packit d7e8d0
  else
Packit d7e8d0
    err = _gpgme_decrypt_start (ctx, 1, flags, cipher, plain);
Packit d7e8d0
  if (!err)
Packit d7e8d0
    err = _gpgme_wait_one (ctx);
Packit Service 30b792
  ctx->ignore_mdc_error = 0;  /* Always reset.  */
Packit d7e8d0
  return TRACE_ERR (err);
Packit d7e8d0
}