Blame src/decrypt-verify.c

Packit d7e8d0
/* decrypt-verify.c - Decrypt and verify function.
Packit d7e8d0
   Copyright (C) 2000 Werner Koch (dd9jn)
Packit d7e8d0
   Copyright (C) 2001, 2002, 2003, 2004 g10 Code GmbH
Packit d7e8d0
Packit d7e8d0
   This file is part of GPGME.
Packit d7e8d0
Packit d7e8d0
   GPGME is free software; you can redistribute it and/or modify it
Packit d7e8d0
   under the terms of the GNU Lesser General Public License as
Packit d7e8d0
   published by the Free Software Foundation; either version 2.1 of
Packit d7e8d0
   the License, or (at your option) any later version.
Packit d7e8d0
Packit d7e8d0
   GPGME is distributed in the hope that it will be useful, but
Packit d7e8d0
   WITHOUT ANY WARRANTY; without even the implied warranty of
Packit d7e8d0
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit d7e8d0
   Lesser General Public License for more details.
Packit d7e8d0
Packit d7e8d0
   You should have received a copy of the GNU Lesser General Public
Packit d7e8d0
   License along with this program; if not, write to the Free Software
Packit d7e8d0
   Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
Packit d7e8d0
   02111-1307, USA.  */
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 d7e8d0
  err = _gpgme_op_decrypt_init_result (ctx);
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 d7e8d0
	(ctx->engine, _gpgme_passphrase_command_handler, ctx, NULL);
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 d7e8d0
  TRACE_BEG2 (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 d7e8d0
  TRACE_BEG2 (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 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 d7e8d0
  TRACE_BEG2 (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 d7e8d0
  TRACE_BEG2 (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 d7e8d0
  return TRACE_ERR (err);
Packit d7e8d0
}