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 #ifndef VALIDATE_H_ 50*ebfedea0SLionel Sambuc #define VALIDATE_H_ 1 51*ebfedea0SLionel Sambuc 52*ebfedea0SLionel Sambuc typedef struct { 53*ebfedea0SLionel Sambuc const pgp_key_t *key; 54*ebfedea0SLionel Sambuc unsigned packet; 55*ebfedea0SLionel Sambuc unsigned offset; 56*ebfedea0SLionel Sambuc } validate_reader_t; 57*ebfedea0SLionel Sambuc 58*ebfedea0SLionel Sambuc /** Struct used with the validate_key_cb callback */ 59*ebfedea0SLionel Sambuc typedef struct { 60*ebfedea0SLionel Sambuc pgp_pubkey_t pubkey; 61*ebfedea0SLionel Sambuc pgp_pubkey_t subkey; 62*ebfedea0SLionel Sambuc pgp_seckey_t seckey; 63*ebfedea0SLionel Sambuc enum { 64*ebfedea0SLionel Sambuc ATTRIBUTE = 1, 65*ebfedea0SLionel Sambuc ID 66*ebfedea0SLionel Sambuc } last_seen; 67*ebfedea0SLionel Sambuc uint8_t *userid; 68*ebfedea0SLionel Sambuc pgp_data_t userattr; 69*ebfedea0SLionel Sambuc uint8_t hash[PGP_MAX_HASH_SIZE]; 70*ebfedea0SLionel Sambuc const pgp_keyring_t *keyring; 71*ebfedea0SLionel Sambuc validate_reader_t *reader; 72*ebfedea0SLionel Sambuc pgp_validation_t *result; 73*ebfedea0SLionel Sambuc pgp_cb_ret_t(*getpassphrase) (const pgp_packet_t *, 74*ebfedea0SLionel Sambuc pgp_cbdata_t *); 75*ebfedea0SLionel Sambuc } validate_key_cb_t; 76*ebfedea0SLionel Sambuc 77*ebfedea0SLionel Sambuc /** Struct use with the validate_data_cb callback */ 78*ebfedea0SLionel Sambuc typedef struct { 79*ebfedea0SLionel Sambuc enum { 80*ebfedea0SLionel Sambuc LITDATA, 81*ebfedea0SLionel Sambuc SIGNED_CLEARTEXT 82*ebfedea0SLionel Sambuc } type; 83*ebfedea0SLionel Sambuc union { 84*ebfedea0SLionel Sambuc pgp_litdata_body_t litdata_body; 85*ebfedea0SLionel Sambuc pgp_fixed_body_t cleartext_body; 86*ebfedea0SLionel Sambuc } data; 87*ebfedea0SLionel Sambuc uint8_t hash[PGP_MAX_HASH_SIZE]; 88*ebfedea0SLionel Sambuc pgp_memory_t *mem; 89*ebfedea0SLionel Sambuc const pgp_keyring_t *keyring; 90*ebfedea0SLionel Sambuc validate_reader_t *reader;/* reader-specific arg */ 91*ebfedea0SLionel Sambuc pgp_validation_t *result; 92*ebfedea0SLionel Sambuc char *detachname; 93*ebfedea0SLionel Sambuc } validate_data_cb_t; 94*ebfedea0SLionel Sambuc 95*ebfedea0SLionel Sambuc void pgp_keydata_reader_set(pgp_stream_t *, const pgp_key_t *); 96*ebfedea0SLionel Sambuc 97*ebfedea0SLionel Sambuc pgp_cb_ret_t pgp_validate_key_cb(const pgp_packet_t *, pgp_cbdata_t *); 98*ebfedea0SLionel Sambuc 99*ebfedea0SLionel Sambuc unsigned check_binary_sig(const uint8_t *, 100*ebfedea0SLionel Sambuc const unsigned, 101*ebfedea0SLionel Sambuc const pgp_sig_t *, 102*ebfedea0SLionel Sambuc const pgp_pubkey_t *); 103*ebfedea0SLionel Sambuc 104*ebfedea0SLionel Sambuc unsigned pgp_validate_file(pgp_io_t *, 105*ebfedea0SLionel Sambuc pgp_validation_t *, 106*ebfedea0SLionel Sambuc const char *, 107*ebfedea0SLionel Sambuc const char *, 108*ebfedea0SLionel Sambuc const int, 109*ebfedea0SLionel Sambuc const pgp_keyring_t *); 110*ebfedea0SLionel Sambuc 111*ebfedea0SLionel Sambuc unsigned pgp_validate_mem(pgp_io_t *, 112*ebfedea0SLionel Sambuc pgp_validation_t *, 113*ebfedea0SLionel Sambuc pgp_memory_t *, 114*ebfedea0SLionel Sambuc pgp_memory_t **, 115*ebfedea0SLionel Sambuc const int, 116*ebfedea0SLionel Sambuc const pgp_keyring_t *); 117*ebfedea0SLionel Sambuc 118*ebfedea0SLionel Sambuc pgp_cb_ret_t validate_data_cb(const pgp_packet_t *, pgp_cbdata_t *); 119*ebfedea0SLionel Sambuc 120*ebfedea0SLionel Sambuc #endif /* !VALIDATE_H_ */ 121