5078e80aa3c0386b6cfd1dce2e6c47dc89073193
[gnupg.git] / g10 / main.h
1 /* main.h
2  *      Copyright (C) 1998 Free Software Foundation, Inc.
3  *
4  * This file is part of GNUPG.
5  *
6  * GNUPG is free software; you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License as published by
8  * the Free Software Foundation; either version 2 of the License, or
9  * (at your option) any later version.
10  *
11  * GNUPG is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  * GNU General Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with this program; if not, write to the Free Software
18  * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
19  */
20 #ifndef G10_MAIN_H
21 #define G10_MAIN_H
22 #include "types.h"
23 #include "iobuf.h"
24 #include "cipher.h"
25 #include "keydb.h"
26
27
28 typedef struct {
29     int header_okay;
30     PKC_LIST pkc_list;
31     cipher_filter_context_t cfx;
32 } encrypt_filter_context_t;
33
34
35 /*-- g10.c --*/
36 #if __GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ >= 5 )
37   void g10_exit(int rc) __attribute__ ((noreturn));
38 #else
39   void g10_exit(int rc);
40 #endif
41
42 /*-- encode.c --*/
43 int encode_symmetric( const char *filename );
44 int encode_store( const char *filename );
45 int encode_crypt( const char *filename, STRLIST remusr );
46 int encrypt_filter( void *opaque, int control,
47                     IOBUF a, byte *buf, size_t *ret_len);
48
49
50 /*-- sign.c --*/
51 int sign_file( STRLIST filenames, int detached, STRLIST locusr,
52                int encrypt, STRLIST remusr, const char *outfile );
53 int clearsign_file( const char *fname, STRLIST locusr, const char *outfile );
54 int sign_key( const char *username, STRLIST locusr );
55 int edit_keysigs( const char *username );
56 int delete_key( const char *username, int secure );
57 int change_passphrase( const char *username );
58
59 /*-- sig-check.c --*/
60 int check_key_signature( KBNODE root, KBNODE node, int *is_selfsig );
61
62 /*-- keygen.c --*/
63 void generate_keypair(void);
64
65 /*-- openfile.c --*/
66 int overwrite_filep( const char *fname );
67 IOBUF open_outfile( const char *fname, int mode );
68 IOBUF open_sigfile( const char *iname );
69
70 /*-- seskey.c --*/
71 void make_session_key( DEK *dek );
72 MPI encode_session_key( DEK *dek, unsigned nbits );
73 MPI encode_md_value( MD_HANDLE md, unsigned nbits );
74
75 /*-- comment.c --*/
76 KBNODE make_comment_node( const char *s );
77 KBNODE make_mpi_comment_node( const char *s, MPI a );
78
79 /*-- elg.c --*/
80 void g10_elg_encrypt( PKT_public_cert *pkc, PKT_pubkey_enc *enc, DEK *dek );
81 void g10_elg_sign( PKT_secret_cert *skc, PKT_signature *sig,
82                                          MD_HANDLE md, int digest_algo );
83
84 /*-- dsa.c --*/
85 void g10_dsa_sign( PKT_secret_cert *skc, PKT_signature *sig,
86                                          MD_HANDLE md, int digest_algo );
87
88 /*-- rsa.c --*/
89 void g10_rsa_encrypt( PKT_public_cert *pkc, PKT_pubkey_enc *enc, DEK *dek );
90 void g10_rsa_sign( PKT_secret_cert *skc, PKT_signature *sig,
91                                          MD_HANDLE md, int digest_algo );
92
93 /*-- import.c --*/
94 int import_pubkeys( const char *filename );
95 /*-- export.c --*/
96 int export_pubkeys( STRLIST users );
97 /* dearmor.c --*/
98 int dearmor_file( const char *fname );
99 int enarmor_file( const char *fname );
100
101 /*-- revoke.c --*/
102 int gen_revoke( const char *uname );
103
104 /*-- keylist.c --*/
105 void std_key_list( int nnames, char **names );
106
107 /*-- verify.c --*/
108 int verify_signatures( int nfiles, char **files );
109
110 /*-- decrypt.c --*/
111 int decrypt_message( const char *filename );
112
113 /*-- plaintext.c --*/
114 int hash_datafiles( MD_HANDLE md, STRLIST files, int textmode );
115
116 #endif /*G10_MAIN_H*/