xref: /minix3/crypto/external/bsd/netpgp/dist/src/lib/create.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 #ifndef CREATE_H_
53*ebfedea0SLionel Sambuc #define CREATE_H_
54*ebfedea0SLionel Sambuc 
55*ebfedea0SLionel Sambuc #include "types.h"
56*ebfedea0SLionel Sambuc #include "packet.h"
57*ebfedea0SLionel Sambuc #include "crypto.h"
58*ebfedea0SLionel Sambuc #include "errors.h"
59*ebfedea0SLionel Sambuc #include "keyring.h"
60*ebfedea0SLionel Sambuc #include "writer.h"
61*ebfedea0SLionel Sambuc #include "memory.h"
62*ebfedea0SLionel Sambuc 
63*ebfedea0SLionel Sambuc /**
64*ebfedea0SLionel Sambuc  * \ingroup Create
65*ebfedea0SLionel Sambuc  * This struct contains the required information about how to write this stream
66*ebfedea0SLionel Sambuc  */
67*ebfedea0SLionel Sambuc struct pgp_output_t {
68*ebfedea0SLionel Sambuc 	pgp_writer_t	 writer;
69*ebfedea0SLionel Sambuc 	pgp_error_t	*errors;	/* error stack */
70*ebfedea0SLionel Sambuc };
71*ebfedea0SLionel Sambuc 
72*ebfedea0SLionel Sambuc pgp_output_t *pgp_output_new(void);
73*ebfedea0SLionel Sambuc void pgp_output_delete(pgp_output_t *);
74*ebfedea0SLionel Sambuc 
75*ebfedea0SLionel Sambuc int pgp_filewrite(const char *, const char *, const size_t, const unsigned);
76*ebfedea0SLionel Sambuc 
77*ebfedea0SLionel Sambuc void pgp_build_pubkey(pgp_memory_t *, const pgp_pubkey_t *, unsigned);
78*ebfedea0SLionel Sambuc 
79*ebfedea0SLionel Sambuc unsigned pgp_calc_sesskey_checksum(pgp_pk_sesskey_t *, uint8_t *);
80*ebfedea0SLionel Sambuc unsigned pgp_write_struct_userid(pgp_output_t *, const uint8_t *);
81*ebfedea0SLionel Sambuc unsigned pgp_write_ss_header(pgp_output_t *, unsigned, pgp_content_enum);
82*ebfedea0SLionel Sambuc unsigned pgp_write_struct_seckey(const pgp_seckey_t *,
83*ebfedea0SLionel Sambuc 			    const uint8_t *,
84*ebfedea0SLionel Sambuc 			    const size_t,
85*ebfedea0SLionel Sambuc 			    pgp_output_t *);
86*ebfedea0SLionel Sambuc unsigned pgp_write_one_pass_sig(pgp_output_t *,
87*ebfedea0SLionel Sambuc 				const pgp_seckey_t *,
88*ebfedea0SLionel Sambuc 				const pgp_hash_alg_t,
89*ebfedea0SLionel Sambuc 				const pgp_sig_type_t);
90*ebfedea0SLionel Sambuc unsigned pgp_write_litdata(pgp_output_t *,
91*ebfedea0SLionel Sambuc 				const uint8_t *,
92*ebfedea0SLionel Sambuc 				const int,
93*ebfedea0SLionel Sambuc 				const pgp_litdata_enum);
94*ebfedea0SLionel Sambuc pgp_pk_sesskey_t *pgp_create_pk_sesskey(const pgp_key_t *, const char *);
95*ebfedea0SLionel Sambuc unsigned pgp_write_pk_sesskey(pgp_output_t *, pgp_pk_sesskey_t *);
96*ebfedea0SLionel Sambuc unsigned pgp_write_xfer_pubkey(pgp_output_t *,
97*ebfedea0SLionel Sambuc 				const pgp_key_t *, const unsigned);
98*ebfedea0SLionel Sambuc unsigned   pgp_write_xfer_seckey(pgp_output_t *,
99*ebfedea0SLionel Sambuc 				const pgp_key_t *,
100*ebfedea0SLionel Sambuc 				const uint8_t *,
101*ebfedea0SLionel Sambuc 				const size_t,
102*ebfedea0SLionel Sambuc 				const unsigned);
103*ebfedea0SLionel Sambuc 
104*ebfedea0SLionel Sambuc void pgp_fast_create_userid(uint8_t **, uint8_t *);
105*ebfedea0SLionel Sambuc unsigned pgp_write_userid(const uint8_t *, pgp_output_t *);
106*ebfedea0SLionel Sambuc void pgp_fast_create_rsa_pubkey(pgp_pubkey_t *, time_t, BIGNUM *, BIGNUM *);
107*ebfedea0SLionel Sambuc unsigned pgp_write_rsa_pubkey(time_t, const BIGNUM *, const BIGNUM *,
108*ebfedea0SLionel Sambuc 				pgp_output_t *);
109*ebfedea0SLionel Sambuc void pgp_fast_create_rsa_seckey(pgp_seckey_t *, time_t, BIGNUM *,
110*ebfedea0SLionel Sambuc 				BIGNUM *, BIGNUM *, BIGNUM *,
111*ebfedea0SLionel Sambuc 				BIGNUM *, BIGNUM *);
112*ebfedea0SLionel Sambuc unsigned encode_m_buf(const uint8_t *, size_t, const pgp_pubkey_t *,
113*ebfedea0SLionel Sambuc 				uint8_t *);
114*ebfedea0SLionel Sambuc unsigned pgp_fileread_litdata(const char *, const pgp_litdata_enum,
115*ebfedea0SLionel Sambuc 				pgp_output_t *);
116*ebfedea0SLionel Sambuc unsigned pgp_write_symm_enc_data(const uint8_t *, const int,
117*ebfedea0SLionel Sambuc 				pgp_output_t *);
118*ebfedea0SLionel Sambuc 
119*ebfedea0SLionel Sambuc #endif /* CREATE_H_ */
120