netpgp.h revision 1.2 1 /*-
2 * Copyright (c) 2009 The NetBSD Foundation, Inc.
3 * All rights reserved.
4 *
5 * This code is derived from software contributed to The NetBSD Foundation
6 * by Alistair Crooks (agc (at) netbsd.org)
7 *
8 * Redistribution and use in source and binary forms, with or without
9 * modification, are permitted provided that the following conditions
10 * are met:
11 * 1. Redistributions of source code must retain the above copyright
12 * notice, this list of conditions and the following disclaimer.
13 * 2. Redistributions in binary form must reproduce the above copyright
14 * notice, this list of conditions and the following disclaimer in the
15 * documentation and/or other materials provided with the distribution.
16 *
17 * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
18 * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
19 * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
20 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
21 * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
22 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
23 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
24 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
25 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
26 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
27 * POSSIBILITY OF SUCH DAMAGE.
28 */
29 #ifndef NETPGP_H_
30 #define NETPGP_H_
31
32 #ifndef __BEGIN_DECLS
33 # if defined(__cplusplus)
34 # define __BEGIN_DECLS extern "C" {
35 # define __END_DECLS }
36 # else
37 # define __BEGIN_DECLS
38 # define __END_DECLS
39 # endif
40 #endif
41
42 __BEGIN_DECLS
43
44 /* structure used to hold (key,value) pair information */
45 typedef struct netpgp_t {
46 unsigned c; /* # of elements used */
47 unsigned size; /* size of array */
48 char **name; /* key names */
49 char **value; /* value information */
50 void *pubring; /* public key ring */
51 void *secring; /* s3kr1t key ring */
52 void *io; /* the io struct for results/errs */
53 void *passfp; /* file pointer for password input */
54 } netpgp_t;
55
56 /* begin and end */
57 int netpgp_init(netpgp_t *);
58 int netpgp_end(netpgp_t *);
59
60 /* debugging, reflection and information */
61 int netpgp_set_debug(const char *);
62 int netpgp_get_debug(const char *);
63 const char *netpgp_get_info(const char *);
64 int netpgp_list_packets(netpgp_t *, char *, int, char *);
65
66 /* variables */
67 int netpgp_setvar(netpgp_t *, const char *, const char *);
68 char *netpgp_getvar(netpgp_t *, const char *);
69 int netpgp_incvar(netpgp_t *, const char *, const int);
70 int netpgp_unsetvar(netpgp_t *, const char *);
71
72 /* set home directory information */
73 int netpgp_set_homedir(netpgp_t *, char *, const char *, const int);
74
75 /* key management */
76 int netpgp_list_keys(netpgp_t *, const int);
77 int netpgp_find_key(netpgp_t *, char *);
78 char *netpgp_get_key(netpgp_t *, const char *, const char *);
79 char *netpgp_export_key(netpgp_t *, char *);
80 int netpgp_import_key(netpgp_t *, char *);
81 int netpgp_generate_key(netpgp_t *, char *, int);
82
83 /* file management */
84 int netpgp_encrypt_file(netpgp_t *, const char *, const char *, char *, int);
85 int netpgp_decrypt_file(netpgp_t *, const char *, char *, int);
86 int netpgp_sign_file(netpgp_t *, const char *, const char *, char *, int, int, int);
87 int netpgp_verify_file(netpgp_t *, const char *, const char *, int);
88
89 /* memory signing and encryption */
90 int netpgp_sign_memory(netpgp_t *, const char *, char *, size_t, char *, size_t, const unsigned, const unsigned);
91 int netpgp_verify_memory(netpgp_t *, const void *, const size_t, void *, size_t, const int);
92 int netpgp_encrypt_memory(netpgp_t *, const char *, void *, const size_t, char *, size_t, int);
93 int netpgp_decrypt_memory(netpgp_t *, const void *, const size_t, char *, size_t, const int);
94
95 /* match and hkp-related functions */
96 int netpgp_match_keys(netpgp_t *, char *, const char *, void *, const int);
97 int netpgp_match_pubkeys(netpgp_t *, char *, void *);
98
99 int netpgp_validate_sigs(netpgp_t *);
100
101 __END_DECLS
102
103 #endif /* !NETPGP_H_ */
104