/* * 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