*** empty log message ***
[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 "mpi.h"
25 #include "cipher.h"
26 #include "keydb.h"
27
28 #define DEFAULT_CIPHER_ALGO  CIPHER_ALGO_BLOWFISH
29 #define DEFAULT_PUBKEY_ALGO  PUBKEY_ALGO_ELGAMAL
30 #define DEFAULT_DIGEST_ALGO  DIGEST_ALGO_RMD160
31
32
33 typedef struct {
34     int header_okay;
35     PKC_LIST pkc_list;
36     cipher_filter_context_t cfx;
37 } encrypt_filter_context_t;
38
39
40 /*-- g10.c --*/
41 #if __GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ >= 5 )
42   void g10_exit(int rc) __attribute__ ((noreturn));
43 #else
44   void g10_exit(int rc);
45 #endif
46
47 /*-- misc.c --*/
48 void trap_unaligned(void);
49 u16 checksum_u16( unsigned n );
50 u16 checksum( byte *p, unsigned n );
51 u16 checksum_mpi( MPI a );
52
53 /*-- encode.c --*/
54 int encode_symmetric( const char *filename );
55 int encode_store( const char *filename );
56 int encode_crypt( const char *filename, STRLIST remusr );
57 int encrypt_filter( void *opaque, int control,
58                     IOBUF a, byte *buf, size_t *ret_len);
59
60
61 /*-- sign.c --*/
62 int complete_sig( PKT_signature *sig, PKT_secret_cert *skc, MD_HANDLE md );
63 int sign_file( STRLIST filenames, int detached, STRLIST locusr,
64                int encrypt, STRLIST remusr, const char *outfile );
65 int clearsign_file( const char *fname, STRLIST locusr, const char *outfile );
66
67 /*-- sig-check.c --*/
68 int check_key_signature( KBNODE root, KBNODE node, int *is_selfsig );
69
70 /*-- keyedit.c --*/
71 int sign_key( const char *username, STRLIST locusr );
72 int edit_keysigs( const char *username );
73 int delete_key( const char *username, int secure );
74 int change_passphrase( const char *username );
75
76 /*-- keygen.c --*/
77 void generate_keypair(void);
78 void generate_subkeypair(const char *userid);
79
80 /*-- openfile.c --*/
81 int overwrite_filep( const char *fname );
82 IOBUF open_outfile( const char *fname, int mode );
83 IOBUF open_sigfile( const char *iname );
84
85 /*-- seskey.c --*/
86 void make_session_key( DEK *dek );
87 MPI encode_session_key( DEK *dek, unsigned nbits );
88 MPI encode_md_value( MD_HANDLE md, int hash_algo, unsigned nbits );
89
90 /*-- comment.c --*/
91 KBNODE make_comment_node( const char *s );
92 KBNODE make_mpi_comment_node( const char *s, MPI a );
93
94 /*-- elg.c --*/
95 void g10_elg_encrypt( PKT_public_cert *pkc, PKT_pubkey_enc *enc, DEK *dek );
96 void g10_elg_sign( PKT_secret_cert *skc, PKT_signature *sig,
97                                          MD_HANDLE md, int digest_algo );
98
99 /*-- dsa.c --*/
100 void g10_dsa_sign( PKT_secret_cert *skc, PKT_signature *sig,
101                                          MD_HANDLE md, int digest_algo );
102
103 /*-- rsa.c --*/
104 void g10_rsa_encrypt( PKT_public_cert *pkc, PKT_pubkey_enc *enc, DEK *dek );
105 void g10_rsa_sign( PKT_secret_cert *skc, PKT_signature *sig,
106                                          MD_HANDLE md, int digest_algo );
107
108 /*-- import.c --*/
109 int import_pubkeys( const char *filename );
110 /*-- export.c --*/
111 int export_pubkeys( STRLIST users );
112 /* dearmor.c --*/
113 int dearmor_file( const char *fname );
114 int enarmor_file( const char *fname );
115
116 /*-- revoke.c --*/
117 int gen_revoke( const char *uname );
118
119 /*-- keylist.c --*/
120 void public_key_list( int nnames, char **names );
121 void secret_key_list( int nnames, char **names );
122
123 /*-- verify.c --*/
124 int verify_signatures( int nfiles, char **files );
125
126 /*-- decrypt.c --*/
127 int decrypt_message( const char *filename );
128
129 /*-- plaintext.c --*/
130 int hash_datafiles( MD_HANDLE md, STRLIST files, int textmode );
131
132 /*-- signal.c --*/
133 void init_signals(void);
134
135 #endif /*G10_MAIN_H*/