/*
 * Copyright notice from original mutt:
 * Copyright (C) 2004 g10 Code GmbH
 *
 * This file is part of mutt-ng, see http://www.muttng.org/.
 * It's licensed under the GNU General Public License,
 * please see the file GPL in the top level source directory.
 */

/* 
    This is a crytpo module wrapping the gpgme based pgp code.
 */

#if HAVE_CONFIG_H
# include "config.h"
#endif

#ifdef CRYPT_BACKEND_GPGME

#include "crypt-mod.h"
#include "crypt-gpgme.h"

static void crypt_mod_pgp_init (void)
{
  pgp_gpgme_init ();
}

static void crypt_mod_pgp_void_passphrase (void)
{
  /* Handled by gpg-agent.  */
}

static int crypt_mod_pgp_valid_passphrase (void)
{
  /* Handled by gpg-agent.  */
  return 1;
}

static int crypt_mod_pgp_decrypt_mime (FILE * a, FILE ** b, BODY * c,
                                       BODY ** d)
{
  return pgp_gpgme_decrypt_mime (a, b, c, d);
}

static int crypt_mod_pgp_application_handler (BODY * m, STATE * s)
{
  return pgp_gpgme_application_handler (m, s);
}

static int crypt_mod_pgp_encrypted_handler (BODY * m, STATE * s)
{
  return pgp_gpgme_encrypted_handler (m, s);
}

static int crypt_mod_pgp_check_traditional (FILE * fp, BODY * b,
                                            int tagged_only)
{
  return pgp_gpgme_check_traditional (fp, b, tagged_only);
}

static char *crypt_mod_pgp_findkeys (ADDRESS * to, ADDRESS * cc,
                                     ADDRESS * bcc)
{
  return pgp_gpgme_findkeys (to, cc, bcc);
}

static BODY *crypt_mod_pgp_sign_message (BODY * a)
{
  return pgp_gpgme_sign_message (a);
}

static int crypt_mod_pgp_verify_one (BODY * sigbdy, STATE * s,
                                     const char *tempf)
{
  return pgp_gpgme_verify_one (sigbdy, s, tempf);
}

static int crypt_mod_pgp_send_menu (HEADER * msg, int *redraw)
{
  return pgp_gpgme_send_menu (msg, redraw);
}

static BODY *crypt_mod_pgp_encrypt_message (BODY * a, char *keylist, int sign)
{
  return pgp_gpgme_encrypt_message (a, keylist, sign);
}

struct crypt_module_specs crypt_mod_pgp_gpgme = { APPLICATION_PGP,
  {
   /* Common.  */
   crypt_mod_pgp_init,
   crypt_mod_pgp_void_passphrase,
   crypt_mod_pgp_valid_passphrase,
   crypt_mod_pgp_decrypt_mime,
   crypt_mod_pgp_application_handler,
   crypt_mod_pgp_encrypted_handler,
   crypt_mod_pgp_findkeys,
   crypt_mod_pgp_sign_message,
   crypt_mod_pgp_verify_one,
   crypt_mod_pgp_send_menu,

   /* PGP specific.  */
   crypt_mod_pgp_encrypt_message,
   NULL,                        /* pgp_make_key_attachment, */
   crypt_mod_pgp_check_traditional,
   NULL,                        /* pgp_traditional_encryptsign  */
   NULL,                        /* pgp_invoke_getkeys  */
   NULL,                        /* pgp_invoke_import  */
   NULL,                        /* pgp_extract_keys_from_attachment_list  */

   NULL,                        /* smime_getkeys */
   NULL,                        /* smime_verify_sender */
   NULL,                        /* smime_build_smime_entity */
   NULL,                        /* smime_invoke_import */
   }
};

#endif


syntax highlighted by Code2HTML, v. 0.9.1