2 * Copyright (C) 2004 g10 Code GmbH
4 * This program is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License as published by
6 * the Free Software Foundation; either version 2 of the License, or
7 * (at your option) any later version.
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU General Public License for more details.
14 * You should have received a copy of the GNU General Public License
15 * along with this program; if not, write to the Free Software
16 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
20 This is a crytpo module wrapping the classic pgp code.
27 #include "crypt-mod.h"
30 static void crypt_mod_pgp_void_passphrase (void)
32 pgp_void_passphrase ();
35 static int crypt_mod_pgp_valid_passphrase (void)
37 return pgp_valid_passphrase ();
40 static int crypt_mod_pgp_decrypt_mime (FILE *a, FILE **b, BODY *c, BODY **d)
42 return pgp_decrypt_mime (a, b, c, d);
44 static int crypt_mod_pgp_application_handler (BODY *m, STATE *s)
46 return pgp_application_pgp_handler (m, s);
49 static char *crypt_mod_pgp_findkeys (ADDRESS *to, ADDRESS *cc, ADDRESS *bcc)
51 return pgp_findKeys (to, cc, bcc);
54 static BODY *crypt_mod_pgp_sign_message (BODY *a)
56 return pgp_sign_message (a);
59 static int crypt_mod_pgp_verify_one (BODY *sigbdy, STATE *s, const char *tempf)
61 return pgp_verify_one (sigbdy, s, tempf);
64 static int crypt_mod_pgp_send_menu (HEADER *msg, int *redraw)
66 return pgp_send_menu (msg, redraw);
69 static BODY *crypt_mod_pgp_encrypt_message (BODY *a, char *keylist, int sign)
71 return pgp_encrypt_message (a, keylist, sign);
74 static BODY *crypt_mod_pgp_make_key_attachment (char *tempf)
76 return pgp_make_key_attachment (tempf);
79 static int crypt_mod_pgp_check_traditional (FILE *fp, BODY *b, int tagged_only)
81 return pgp_check_traditional (fp, b, tagged_only);
84 static BODY *crypt_mod_pgp_traditional_encryptsign (BODY *a, int flags, char *keylist)
86 return pgp_traditional_encryptsign (a, flags, keylist);
89 static int crypt_mod_pgp_encrypted_handler (BODY *m, STATE *s)
91 return pgp_encrypted_handler (m, s);
94 static void crypt_mod_pgp_invoke_getkeys (ADDRESS *addr)
96 pgp_invoke_getkeys (addr);
99 static void crypt_mod_pgp_invoke_import (const char *fname)
101 pgp_invoke_import (fname);
104 static void crypt_mod_pgp_extract_keys_from_attachment_list (FILE *fp, int tag, BODY *top)
106 pgp_extract_keys_from_attachment_list (fp, tag, top);
109 struct crypt_module_specs crypt_mod_pgp_classic =
113 crypt_mod_pgp_void_passphrase,
114 crypt_mod_pgp_valid_passphrase,
115 crypt_mod_pgp_decrypt_mime,
116 crypt_mod_pgp_application_handler,
117 crypt_mod_pgp_encrypted_handler,
118 crypt_mod_pgp_findkeys,
119 crypt_mod_pgp_sign_message,
120 crypt_mod_pgp_verify_one,
121 crypt_mod_pgp_send_menu,
124 crypt_mod_pgp_encrypt_message,
125 crypt_mod_pgp_make_key_attachment,
126 crypt_mod_pgp_check_traditional,
127 crypt_mod_pgp_traditional_encryptsign,
128 crypt_mod_pgp_invoke_getkeys,
129 crypt_mod_pgp_invoke_import,
130 crypt_mod_pgp_extract_keys_from_attachment_list,
132 NULL, /* smime_getkeys */
133 NULL, /* smime_verify_sender */
134 NULL, /* smime_build_smime_entity */
135 NULL, /* smime_invoke_import */