xref: /minix3/crypto/external/bsd/netpgp/dist/src/lib/keyring.h (revision ebfedea0ce5bbe81e252ddf32d732e40fb633fae)
1*ebfedea0SLionel Sambuc /*-
2*ebfedea0SLionel Sambuc  * Copyright (c) 2009 The NetBSD Foundation, Inc.
3*ebfedea0SLionel Sambuc  * All rights reserved.
4*ebfedea0SLionel Sambuc  *
5*ebfedea0SLionel Sambuc  * This code is derived from software contributed to The NetBSD Foundation
6*ebfedea0SLionel Sambuc  * by Alistair Crooks (agc@NetBSD.org)
7*ebfedea0SLionel Sambuc  *
8*ebfedea0SLionel Sambuc  * Redistribution and use in source and binary forms, with or without
9*ebfedea0SLionel Sambuc  * modification, are permitted provided that the following conditions
10*ebfedea0SLionel Sambuc  * are met:
11*ebfedea0SLionel Sambuc  * 1. Redistributions of source code must retain the above copyright
12*ebfedea0SLionel Sambuc  *    notice, this list of conditions and the following disclaimer.
13*ebfedea0SLionel Sambuc  * 2. Redistributions in binary form must reproduce the above copyright
14*ebfedea0SLionel Sambuc  *    notice, this list of conditions and the following disclaimer in the
15*ebfedea0SLionel Sambuc  *    documentation and/or other materials provided with the distribution.
16*ebfedea0SLionel Sambuc  *
17*ebfedea0SLionel Sambuc  * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
18*ebfedea0SLionel Sambuc  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
19*ebfedea0SLionel Sambuc  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
20*ebfedea0SLionel Sambuc  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
21*ebfedea0SLionel Sambuc  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
22*ebfedea0SLionel Sambuc  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
23*ebfedea0SLionel Sambuc  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
24*ebfedea0SLionel Sambuc  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
25*ebfedea0SLionel Sambuc  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
26*ebfedea0SLionel Sambuc  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
27*ebfedea0SLionel Sambuc  * POSSIBILITY OF SUCH DAMAGE.
28*ebfedea0SLionel Sambuc  */
29*ebfedea0SLionel Sambuc /*
30*ebfedea0SLionel Sambuc  * Copyright (c) 2005-2008 Nominet UK (www.nic.uk)
31*ebfedea0SLionel Sambuc  * All rights reserved.
32*ebfedea0SLionel Sambuc  * Contributors: Ben Laurie, Rachel Willmer. The Contributors have asserted
33*ebfedea0SLionel Sambuc  * their moral rights under the UK Copyright Design and Patents Act 1988 to
34*ebfedea0SLionel Sambuc  * be recorded as the authors of this copyright work.
35*ebfedea0SLionel Sambuc  *
36*ebfedea0SLionel Sambuc  * Licensed under the Apache License, Version 2.0 (the "License"); you may not
37*ebfedea0SLionel Sambuc  * use this file except in compliance with the License.
38*ebfedea0SLionel Sambuc  *
39*ebfedea0SLionel Sambuc  * You may obtain a copy of the License at
40*ebfedea0SLionel Sambuc  *     http://www.apache.org/licenses/LICENSE-2.0
41*ebfedea0SLionel Sambuc  *
42*ebfedea0SLionel Sambuc  * Unless required by applicable law or agreed to in writing, software
43*ebfedea0SLionel Sambuc  * distributed under the License is distributed on an "AS IS" BASIS,
44*ebfedea0SLionel Sambuc  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
45*ebfedea0SLionel Sambuc  *
46*ebfedea0SLionel Sambuc  * See the License for the specific language governing permissions and
47*ebfedea0SLionel Sambuc  * limitations under the License.
48*ebfedea0SLionel Sambuc  */
49*ebfedea0SLionel Sambuc 
50*ebfedea0SLionel Sambuc /** \file
51*ebfedea0SLionel Sambuc  */
52*ebfedea0SLionel Sambuc 
53*ebfedea0SLionel Sambuc #ifndef KEYRING_H_
54*ebfedea0SLionel Sambuc #define KEYRING_H_
55*ebfedea0SLionel Sambuc 
56*ebfedea0SLionel Sambuc #include "packet.h"
57*ebfedea0SLionel Sambuc #include "packet-parse.h"
58*ebfedea0SLionel Sambuc #include "mj.h"
59*ebfedea0SLionel Sambuc 
60*ebfedea0SLionel Sambuc enum {
61*ebfedea0SLionel Sambuc 	MAX_ID_LENGTH		= 128,
62*ebfedea0SLionel Sambuc 	MAX_PASSPHRASE_LENGTH	= 256
63*ebfedea0SLionel Sambuc };
64*ebfedea0SLionel Sambuc 
65*ebfedea0SLionel Sambuc typedef struct pgp_key_t	pgp_key_t;
66*ebfedea0SLionel Sambuc 
67*ebfedea0SLionel Sambuc /** \struct pgp_keyring_t
68*ebfedea0SLionel Sambuc  * A keyring
69*ebfedea0SLionel Sambuc  */
70*ebfedea0SLionel Sambuc typedef struct pgp_keyring_t {
71*ebfedea0SLionel Sambuc 	DYNARRAY(pgp_key_t,	key);
72*ebfedea0SLionel Sambuc 	pgp_hash_alg_t	hashtype;
73*ebfedea0SLionel Sambuc } pgp_keyring_t;
74*ebfedea0SLionel Sambuc 
75*ebfedea0SLionel Sambuc const pgp_key_t *pgp_getkeybyid(pgp_io_t *,
76*ebfedea0SLionel Sambuc 					const pgp_keyring_t *,
77*ebfedea0SLionel Sambuc 					const uint8_t *,
78*ebfedea0SLionel Sambuc 					unsigned *,
79*ebfedea0SLionel Sambuc 					pgp_pubkey_t **);
80*ebfedea0SLionel Sambuc const pgp_key_t *pgp_getkeybyname(pgp_io_t *,
81*ebfedea0SLionel Sambuc 					const pgp_keyring_t *,
82*ebfedea0SLionel Sambuc 					const char *);
83*ebfedea0SLionel Sambuc const pgp_key_t *pgp_getnextkeybyname(pgp_io_t *,
84*ebfedea0SLionel Sambuc 					const pgp_keyring_t *,
85*ebfedea0SLionel Sambuc 					const char *,
86*ebfedea0SLionel Sambuc 					unsigned *);
87*ebfedea0SLionel Sambuc void pgp_keydata_free(pgp_key_t *);
88*ebfedea0SLionel Sambuc void pgp_keyring_free(pgp_keyring_t *);
89*ebfedea0SLionel Sambuc void pgp_dump_keyring(const pgp_keyring_t *);
90*ebfedea0SLionel Sambuc const pgp_pubkey_t *pgp_get_pubkey(const pgp_key_t *);
91*ebfedea0SLionel Sambuc unsigned   pgp_is_key_secret(const pgp_key_t *);
92*ebfedea0SLionel Sambuc const pgp_seckey_t *pgp_get_seckey(const pgp_key_t *);
93*ebfedea0SLionel Sambuc pgp_seckey_t *pgp_get_writable_seckey(pgp_key_t *);
94*ebfedea0SLionel Sambuc pgp_seckey_t *pgp_decrypt_seckey(const pgp_key_t *, void *);
95*ebfedea0SLionel Sambuc 
96*ebfedea0SLionel Sambuc unsigned   pgp_keyring_fileread(pgp_keyring_t *, const unsigned,
97*ebfedea0SLionel Sambuc 					const char *);
98*ebfedea0SLionel Sambuc 
99*ebfedea0SLionel Sambuc int pgp_keyring_list(pgp_io_t *, const pgp_keyring_t *, const int);
100*ebfedea0SLionel Sambuc int pgp_keyring_json(pgp_io_t *, const pgp_keyring_t *, mj_t *, const int);
101*ebfedea0SLionel Sambuc 
102*ebfedea0SLionel Sambuc void pgp_set_seckey(pgp_contents_t *, const pgp_key_t *);
103*ebfedea0SLionel Sambuc void pgp_forget(void *, unsigned);
104*ebfedea0SLionel Sambuc 
105*ebfedea0SLionel Sambuc const uint8_t *pgp_get_key_id(const pgp_key_t *);
106*ebfedea0SLionel Sambuc unsigned pgp_get_userid_count(const pgp_key_t *);
107*ebfedea0SLionel Sambuc const uint8_t *pgp_get_userid(const pgp_key_t *, unsigned);
108*ebfedea0SLionel Sambuc unsigned pgp_is_key_supported(const pgp_key_t *);
109*ebfedea0SLionel Sambuc 
110*ebfedea0SLionel Sambuc uint8_t *pgp_add_userid(pgp_key_t *, const uint8_t *);
111*ebfedea0SLionel Sambuc pgp_subpacket_t *pgp_add_subpacket(pgp_key_t *,
112*ebfedea0SLionel Sambuc 						const pgp_subpacket_t *);
113*ebfedea0SLionel Sambuc 
114*ebfedea0SLionel Sambuc unsigned pgp_add_selfsigned_userid(pgp_key_t *, uint8_t *);
115*ebfedea0SLionel Sambuc 
116*ebfedea0SLionel Sambuc pgp_key_t  *pgp_keydata_new(void);
117*ebfedea0SLionel Sambuc void pgp_keydata_init(pgp_key_t *, const pgp_content_enum);
118*ebfedea0SLionel Sambuc 
119*ebfedea0SLionel Sambuc int pgp_parse_and_accumulate(pgp_keyring_t *, pgp_stream_t *);
120*ebfedea0SLionel Sambuc 
121*ebfedea0SLionel Sambuc int pgp_sprint_keydata(pgp_io_t *, const pgp_keyring_t *,
122*ebfedea0SLionel Sambuc 			const pgp_key_t *, char **, const char *,
123*ebfedea0SLionel Sambuc 			const pgp_pubkey_t *, const int);
124*ebfedea0SLionel Sambuc int pgp_sprint_mj(pgp_io_t *, const pgp_keyring_t *,
125*ebfedea0SLionel Sambuc 			const pgp_key_t *, mj_t *, const char *,
126*ebfedea0SLionel Sambuc 			const pgp_pubkey_t *, const int);
127*ebfedea0SLionel Sambuc int pgp_hkp_sprint_keydata(pgp_io_t *, const pgp_keyring_t *,
128*ebfedea0SLionel Sambuc 			const pgp_key_t *, char **,
129*ebfedea0SLionel Sambuc 			const pgp_pubkey_t *, const int);
130*ebfedea0SLionel Sambuc void pgp_print_keydata(pgp_io_t *, const pgp_keyring_t *, const pgp_key_t *,
131*ebfedea0SLionel Sambuc 			const char *, const pgp_pubkey_t *, const int);
132*ebfedea0SLionel Sambuc void pgp_print_sig(pgp_io_t *, const pgp_key_t *, const char *,
133*ebfedea0SLionel Sambuc 			const pgp_pubkey_t *);
134*ebfedea0SLionel Sambuc void pgp_print_pubkey(const pgp_pubkey_t *);
135*ebfedea0SLionel Sambuc int pgp_sprint_pubkey(const pgp_key_t *, char *, size_t);
136*ebfedea0SLionel Sambuc 
137*ebfedea0SLionel Sambuc int pgp_list_packets(pgp_io_t *,
138*ebfedea0SLionel Sambuc 			char *,
139*ebfedea0SLionel Sambuc 			unsigned,
140*ebfedea0SLionel Sambuc 			pgp_keyring_t *,
141*ebfedea0SLionel Sambuc 			pgp_keyring_t *,
142*ebfedea0SLionel Sambuc 			void *,
143*ebfedea0SLionel Sambuc 			pgp_cbfunc_t *);
144*ebfedea0SLionel Sambuc 
145*ebfedea0SLionel Sambuc char *pgp_export_key(pgp_io_t *, const pgp_key_t *, uint8_t *);
146*ebfedea0SLionel Sambuc 
147*ebfedea0SLionel Sambuc int pgp_add_to_pubring(pgp_keyring_t *, const pgp_pubkey_t *, pgp_content_enum tag);
148*ebfedea0SLionel Sambuc int pgp_add_to_secring(pgp_keyring_t *, const pgp_seckey_t *);
149*ebfedea0SLionel Sambuc 
150*ebfedea0SLionel Sambuc int pgp_append_keyring(pgp_keyring_t *, pgp_keyring_t *);
151*ebfedea0SLionel Sambuc 
152*ebfedea0SLionel Sambuc #endif /* KEYRING_H_ */
153