2004-06-23 Marcus Brinkmann <marcus@g10code.de>
[gpgme.git] / gpgme / decrypt-verify.c
index 940b53c..ef7f79b 100644 (file)
-/* decrypt-verify.c -  decrypt and verify functions
- *     Copyright (C) 2000 Werner Koch (dd9jn)
- *      Copyright (C) 2001 g10 Code GmbH
- *
- * This file is part of GPGME.
- *
- * GPGME is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * GPGME is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
- */
+/* decrypt-verify.c - Decrypt and verify function.
+   Copyright (C) 2000 Werner Koch (dd9jn)
+   Copyright (C) 2001, 2002, 2003 g10 Code GmbH
 
+   This file is part of GPGME.
+   GPGME is free software; you can redistribute it and/or modify it
+   under the terms of the GNU General Public License as published by
+   the Free Software Foundation; either version 2 of the License, or
+   (at your option) any later version.
+   GPGME is distributed in the hope that it will be useful, but
+   WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+   General Public License for more details.
+   You should have received a copy of the GNU General Public License
+   along with GPGME; if not, write to the Free Software Foundation,
+   Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.  */
+
+#if HAVE_CONFIG_H
 #include <config.h>
-#include <stdio.h>
-#include <stdlib.h>
-#include <string.h>
-#include <assert.h>
+#endif
 
-#include "util.h"
-#include "context.h"
+#include "gpgme.h"
 #include "ops.h"
 
-
-static void
-decrypt_verify_status_handler (GpgmeCtx ctx, GpgStatusCode code, char *args)
+\f
+static gpgme_error_t
+decrypt_verify_status_handler (void *priv, gpgme_status_code_t code,
+                              char *args)
 {
-  _gpgme_decrypt_status_handler (ctx, code, args);
-  _gpgme_verify_status_handler (ctx, code, args);
+  gpgme_error_t err;
+
+  err = _gpgme_progress_status_handler (priv, code, args);
+  if (!err)
+    err = _gpgme_decrypt_status_handler (priv, code, args);
+  if (!err)
+      err = _gpgme_verify_status_handler (priv, code, args);
+  return err;
 }
 
 
-GpgmeError
-gpgme_op_decrypt_verify_start (GpgmeCtx ctx, GpgmeData ciph, GpgmeData plain)
+static gpgme_error_t
+decrypt_verify_start (gpgme_ctx_t ctx, int synchronous,
+                     gpgme_data_t cipher, gpgme_data_t plain)
 {
-  return _gpgme_decrypt_start (ctx, ciph, plain,
-                              decrypt_verify_status_handler);
+  gpgme_error_t err;
+
+  err = _gpgme_op_reset (ctx, synchronous);
+  if (err)
+    return err;
+
+  err = _gpgme_op_decrypt_init_result (ctx);
+  if (err)
+    return err;
+
+  err = _gpgme_op_verify_init_result (ctx);
+  if (err)
+    return err;
+
+  if (!cipher)
+    return gpg_error (GPG_ERR_NO_DATA);
+  if (!plain)
+    return gpg_error (GPG_ERR_INV_VALUE);
+
+  if (ctx->passphrase_cb)
+    {
+      err = _gpgme_engine_set_command_handler
+       (ctx->engine, _gpgme_passphrase_command_handler, ctx, NULL);
+      if (err)
+       return err;
+    }
+
+  _gpgme_engine_set_status_handler (ctx->engine,
+                                   decrypt_verify_status_handler, ctx);
+  
+  return _gpgme_engine_op_decrypt (ctx->engine, cipher, plain);
 }
 
 
-/**
- * gpgme_op_decrypt_verify:
- * @ctx: The context
- * @in: ciphertext input
- * @out: plaintext output
- * 
- * This function decrypts @in to @out and performs a signature check.
- * Other parameters are take from the context @c.
- * The function does wait for the result.
- * 
- * Return value:  0 on success or an errorcode. 
- **/
-GpgmeError
-gpgme_op_decrypt_verify (GpgmeCtx ctx,
-                        GpgmeData in, GpgmeData out,
-                        GpgmeSigStat *r_stat)
+/* Decrypt ciphertext CIPHER and make a signature verification within
+   CTX and store the resulting plaintext in PLAIN.  */
+gpgme_error_t
+gpgme_op_decrypt_verify_start (gpgme_ctx_t ctx, gpgme_data_t cipher,
+                              gpgme_data_t plain)
 {
-  GpgmeError err;
+  return decrypt_verify_start (ctx, 0, cipher, plain);
+}
 
-  gpgme_data_release (ctx->notation);
-  ctx->notation = NULL;
-    
-  *r_stat = GPGME_SIG_STAT_NONE;
-  err = gpgme_op_decrypt_verify_start (ctx, in, out);
+
+/* Decrypt ciphertext CIPHER and make a signature verification within
+   CTX and store the resulting plaintext in PLAIN.  */
+gpgme_error_t
+gpgme_op_decrypt_verify (gpgme_ctx_t ctx, gpgme_data_t cipher,
+                        gpgme_data_t plain)
+{
+  gpgme_error_t err = decrypt_verify_start (ctx, 1, cipher, plain);
   if (!err)
-    {
-      gpgme_wait (ctx, &err, 1);
-      if (!err)
-       *r_stat = _gpgme_intersect_stati (ctx->result.verify);
-    }
+    err = _gpgme_wait_one (ctx);
   return err;
 }