Home | History | Annotate | Line # | Download | only in validator
val_secalgo.c revision 1.1.1.2
      1 /*
      2  * validator/val_secalgo.c - validator security algorithm functions.
      3  *
      4  * Copyright (c) 2012, NLnet Labs. All rights reserved.
      5  *
      6  * This software is open source.
      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  *
     12  * Redistributions of source code must retain the above copyright notice,
     13  * this list of conditions and the following disclaimer.
     14  *
     15  * Redistributions in binary form must reproduce the above copyright notice,
     16  * this list of conditions and the following disclaimer in the documentation
     17  * and/or other materials provided with the distribution.
     18  *
     19  * Neither the name of the NLNET LABS nor the names of its contributors may
     20  * be used to endorse or promote products derived from this software without
     21  * specific prior written permission.
     22  *
     23  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
     24  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
     25  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
     26  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
     27  * HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
     28  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED
     29  * TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
     30  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
     31  * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
     32  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
     33  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
     34  */
     35 
     36 /**
     37  * \file
     38  *
     39  * This file contains helper functions for the validator module.
     40  * These functions take raw data buffers, formatted for crypto verification,
     41  * and do the library calls (for the crypto library in use).
     42  */
     43 #include "config.h"
     44 /* packed_rrset on top to define enum types (forced by c99 standard) */
     45 #include "util/data/packed_rrset.h"
     46 #include "validator/val_secalgo.h"
     47 #include "validator/val_nsec3.h"
     48 #include "util/log.h"
     49 #include "sldns/rrdef.h"
     50 #include "sldns/keyraw.h"
     51 #include "sldns/sbuffer.h"
     52 
     53 #if !defined(HAVE_SSL) && !defined(HAVE_NSS) && !defined(HAVE_NETTLE)
     54 #error "Need crypto library to do digital signature cryptography"
     55 #endif
     56 
     57 /* OpenSSL implementation */
     58 #ifdef HAVE_SSL
     59 #ifdef HAVE_OPENSSL_ERR_H
     60 #include <openssl/err.h>
     61 #endif
     62 
     63 #ifdef HAVE_OPENSSL_RAND_H
     64 #include <openssl/rand.h>
     65 #endif
     66 
     67 #ifdef HAVE_OPENSSL_CONF_H
     68 #include <openssl/conf.h>
     69 #endif
     70 
     71 #ifdef HAVE_OPENSSL_ENGINE_H
     72 #include <openssl/engine.h>
     73 #endif
     74 
     75 /** fake DSA support for unit tests */
     76 int fake_dsa = 0;
     77 /** fake SHA1 support for unit tests */
     78 int fake_sha1 = 0;
     79 
     80 /* return size of digest if supported, or 0 otherwise */
     81 size_t
     82 nsec3_hash_algo_size_supported(int id)
     83 {
     84 	switch(id) {
     85 	case NSEC3_HASH_SHA1:
     86 		return SHA_DIGEST_LENGTH;
     87 	default:
     88 		return 0;
     89 	}
     90 }
     91 
     92 /* perform nsec3 hash. return false on failure */
     93 int
     94 secalgo_nsec3_hash(int algo, unsigned char* buf, size_t len,
     95         unsigned char* res)
     96 {
     97 	switch(algo) {
     98 	case NSEC3_HASH_SHA1:
     99 		(void)SHA1(buf, len, res);
    100 		return 1;
    101 	default:
    102 		return 0;
    103 	}
    104 }
    105 
    106 void
    107 secalgo_hash_sha256(unsigned char* buf, size_t len, unsigned char* res)
    108 {
    109 	(void)SHA256(buf, len, res);
    110 }
    111 
    112 /**
    113  * Return size of DS digest according to its hash algorithm.
    114  * @param algo: DS digest algo.
    115  * @return size in bytes of digest, or 0 if not supported.
    116  */
    117 size_t
    118 ds_digest_size_supported(int algo)
    119 {
    120 	switch(algo) {
    121 		case LDNS_SHA1:
    122 #if defined(HAVE_EVP_SHA1) && defined(USE_SHA1)
    123 			return SHA_DIGEST_LENGTH;
    124 #else
    125 			if(fake_sha1) return 20;
    126 			return 0;
    127 #endif
    128 #ifdef HAVE_EVP_SHA256
    129 		case LDNS_SHA256:
    130 			return SHA256_DIGEST_LENGTH;
    131 #endif
    132 #ifdef USE_GOST
    133 		case LDNS_HASH_GOST:
    134 			/* we support GOST if it can be loaded */
    135 			(void)sldns_key_EVP_load_gost_id();
    136 			if(EVP_get_digestbyname("md_gost94"))
    137 				return 32;
    138 			else	return 0;
    139 #endif
    140 #ifdef USE_ECDSA
    141 		case LDNS_SHA384:
    142 			return SHA384_DIGEST_LENGTH;
    143 #endif
    144 		default: break;
    145 	}
    146 	return 0;
    147 }
    148 
    149 #ifdef USE_GOST
    150 /** Perform GOST hash */
    151 static int
    152 do_gost94(unsigned char* data, size_t len, unsigned char* dest)
    153 {
    154 	const EVP_MD* md = EVP_get_digestbyname("md_gost94");
    155 	if(!md)
    156 		return 0;
    157 	return sldns_digest_evp(data, (unsigned int)len, dest, md);
    158 }
    159 #endif
    160 
    161 int
    162 secalgo_ds_digest(int algo, unsigned char* buf, size_t len,
    163 	unsigned char* res)
    164 {
    165 	switch(algo) {
    166 #if defined(HAVE_EVP_SHA1) && defined(USE_SHA1)
    167 		case LDNS_SHA1:
    168 			(void)SHA1(buf, len, res);
    169 			return 1;
    170 #endif
    171 #ifdef HAVE_EVP_SHA256
    172 		case LDNS_SHA256:
    173 			(void)SHA256(buf, len, res);
    174 			return 1;
    175 #endif
    176 #ifdef USE_GOST
    177 		case LDNS_HASH_GOST:
    178 			if(do_gost94(buf, len, res))
    179 				return 1;
    180 			break;
    181 #endif
    182 #ifdef USE_ECDSA
    183 		case LDNS_SHA384:
    184 			(void)SHA384(buf, len, res);
    185 			return 1;
    186 #endif
    187 		default:
    188 			verbose(VERB_QUERY, "unknown DS digest algorithm %d",
    189 				algo);
    190 			break;
    191 	}
    192 	return 0;
    193 }
    194 
    195 /** return true if DNSKEY algorithm id is supported */
    196 int
    197 dnskey_algo_id_is_supported(int id)
    198 {
    199 	switch(id) {
    200 	case LDNS_RSAMD5:
    201 		/* RFC 6725 deprecates RSAMD5 */
    202 		return 0;
    203 	case LDNS_DSA:
    204 	case LDNS_DSA_NSEC3:
    205 #if defined(USE_DSA) && defined(USE_SHA1)
    206 		return 1;
    207 #else
    208 		if(fake_dsa || fake_sha1) return 1;
    209 		return 0;
    210 #endif
    211 
    212 	case LDNS_RSASHA1:
    213 	case LDNS_RSASHA1_NSEC3:
    214 #ifdef USE_SHA1
    215 		return 1;
    216 #else
    217 		if(fake_sha1) return 1;
    218 		return 0;
    219 #endif
    220 
    221 #if defined(HAVE_EVP_SHA256) && defined(USE_SHA2)
    222 	case LDNS_RSASHA256:
    223 #endif
    224 #if defined(HAVE_EVP_SHA512) && defined(USE_SHA2)
    225 	case LDNS_RSASHA512:
    226 #endif
    227 #ifdef USE_ECDSA
    228 	case LDNS_ECDSAP256SHA256:
    229 	case LDNS_ECDSAP384SHA384:
    230 #endif
    231 #ifdef USE_ED25519
    232 	case LDNS_ED25519:
    233 #endif
    234 #if (defined(HAVE_EVP_SHA256) && defined(USE_SHA2)) || (defined(HAVE_EVP_SHA512) && defined(USE_SHA2)) || defined(USE_ECDSA)
    235 		return 1;
    236 #endif
    237 
    238 #ifdef USE_GOST
    239 	case LDNS_ECC_GOST:
    240 		/* we support GOST if it can be loaded */
    241 		return sldns_key_EVP_load_gost_id();
    242 #endif
    243 	default:
    244 		return 0;
    245 	}
    246 }
    247 
    248 /**
    249  * Output a libcrypto openssl error to the logfile.
    250  * @param str: string to add to it.
    251  * @param e: the error to output, error number from ERR_get_error().
    252  */
    253 static void
    254 log_crypto_error(const char* str, unsigned long e)
    255 {
    256 	char buf[128];
    257 	/* or use ERR_error_string if ERR_error_string_n is not avail TODO */
    258 	ERR_error_string_n(e, buf, sizeof(buf));
    259 	/* buf now contains */
    260 	/* error:[error code]:[library name]:[function name]:[reason string] */
    261 	log_err("%s crypto %s", str, buf);
    262 }
    263 
    264 #ifdef USE_DSA
    265 /**
    266  * Setup DSA key digest in DER encoding ...
    267  * @param sig: input is signature output alloced ptr (unless failure).
    268  * 	caller must free alloced ptr if this routine returns true.
    269  * @param len: input is initial siglen, output is output len.
    270  * @return false on failure.
    271  */
    272 static int
    273 setup_dsa_sig(unsigned char** sig, unsigned int* len)
    274 {
    275 	unsigned char* orig = *sig;
    276 	unsigned int origlen = *len;
    277 	int newlen;
    278 	BIGNUM *R, *S;
    279 	DSA_SIG *dsasig;
    280 
    281 	/* extract the R and S field from the sig buffer */
    282 	if(origlen < 1 + 2*SHA_DIGEST_LENGTH)
    283 		return 0;
    284 	R = BN_new();
    285 	if(!R) return 0;
    286 	(void) BN_bin2bn(orig + 1, SHA_DIGEST_LENGTH, R);
    287 	S = BN_new();
    288 	if(!S) return 0;
    289 	(void) BN_bin2bn(orig + 21, SHA_DIGEST_LENGTH, S);
    290 	dsasig = DSA_SIG_new();
    291 	if(!dsasig) return 0;
    292 
    293 #ifdef HAVE_DSA_SIG_SET0
    294 	if(!DSA_SIG_set0(dsasig, R, S)) return 0;
    295 #else
    296 	dsasig->r = R;
    297 	dsasig->s = S;
    298 #endif
    299 	*sig = NULL;
    300 	newlen = i2d_DSA_SIG(dsasig, sig);
    301 	if(newlen < 0) {
    302 		DSA_SIG_free(dsasig);
    303 		free(*sig);
    304 		return 0;
    305 	}
    306 	*len = (unsigned int)newlen;
    307 	DSA_SIG_free(dsasig);
    308 	return 1;
    309 }
    310 #endif /* USE_DSA */
    311 
    312 #ifdef USE_ECDSA
    313 /**
    314  * Setup the ECDSA signature in its encoding that the library wants.
    315  * Converts from plain numbers to ASN formatted.
    316  * @param sig: input is signature, output alloced ptr (unless failure).
    317  * 	caller must free alloced ptr if this routine returns true.
    318  * @param len: input is initial siglen, output is output len.
    319  * @return false on failure.
    320  */
    321 static int
    322 setup_ecdsa_sig(unsigned char** sig, unsigned int* len)
    323 {
    324         /* convert from two BIGNUMs in the rdata buffer, to ASN notation.
    325 	 * ASN preamble: 30440220 <R 32bytefor256> 0220 <S 32bytefor256>
    326 	 * the '20' is the length of that field (=bnsize).
    327 i	 * the '44' is the total remaining length.
    328 	 * if negative, start with leading zero.
    329 	 * if starts with 00s, remove them from the number.
    330 	 */
    331         uint8_t pre[] = {0x30, 0x44, 0x02, 0x20};
    332         int pre_len = 4;
    333         uint8_t mid[] = {0x02, 0x20};
    334         int mid_len = 2;
    335         int raw_sig_len, r_high, s_high, r_rem=0, s_rem=0;
    336 	int bnsize = (int)((*len)/2);
    337         unsigned char* d = *sig;
    338 	uint8_t* p;
    339 	/* if too short or not even length, fails */
    340 	if(*len < 16 || bnsize*2 != (int)*len)
    341 		return 0;
    342 
    343         /* strip leading zeroes from r (but not last one) */
    344         while(r_rem < bnsize-1 && d[r_rem] == 0)
    345                 r_rem++;
    346         /* strip leading zeroes from s (but not last one) */
    347         while(s_rem < bnsize-1 && d[bnsize+s_rem] == 0)
    348                 s_rem++;
    349 
    350         r_high = ((d[0+r_rem]&0x80)?1:0);
    351         s_high = ((d[bnsize+s_rem]&0x80)?1:0);
    352         raw_sig_len = pre_len + r_high + bnsize - r_rem + mid_len +
    353                 s_high + bnsize - s_rem;
    354 	*sig = (unsigned char*)malloc((size_t)raw_sig_len);
    355 	if(!*sig)
    356 		return 0;
    357 	p = (uint8_t*)*sig;
    358 	p[0] = pre[0];
    359 	p[1] = (uint8_t)(raw_sig_len-2);
    360 	p[2] = pre[2];
    361 	p[3] = (uint8_t)(bnsize + r_high - r_rem);
    362 	p += 4;
    363 	if(r_high) {
    364 		*p = 0;
    365 		p += 1;
    366 	}
    367 	memmove(p, d+r_rem, (size_t)bnsize-r_rem);
    368 	p += bnsize-r_rem;
    369 	memmove(p, mid, (size_t)mid_len-1);
    370 	p += mid_len-1;
    371 	*p = (uint8_t)(bnsize + s_high - s_rem);
    372 	p += 1;
    373         if(s_high) {
    374 		*p = 0;
    375 		p += 1;
    376 	}
    377 	memmove(p, d+bnsize+s_rem, (size_t)bnsize-s_rem);
    378 	*len = (unsigned int)raw_sig_len;
    379 	return 1;
    380 }
    381 #endif /* USE_ECDSA */
    382 
    383 #ifdef USE_ECDSA_EVP_WORKAROUND
    384 static EVP_MD ecdsa_evp_256_md;
    385 static EVP_MD ecdsa_evp_384_md;
    386 void ecdsa_evp_workaround_init(void)
    387 {
    388 	/* openssl before 1.0.0 fixes RSA with the SHA256
    389 	 * hash in EVP.  We create one for ecdsa_sha256 */
    390 	ecdsa_evp_256_md = *EVP_sha256();
    391 	ecdsa_evp_256_md.required_pkey_type[0] = EVP_PKEY_EC;
    392 	ecdsa_evp_256_md.verify = (void*)ECDSA_verify;
    393 
    394 	ecdsa_evp_384_md = *EVP_sha384();
    395 	ecdsa_evp_384_md.required_pkey_type[0] = EVP_PKEY_EC;
    396 	ecdsa_evp_384_md.verify = (void*)ECDSA_verify;
    397 }
    398 #endif /* USE_ECDSA_EVP_WORKAROUND */
    399 
    400 /**
    401  * Setup key and digest for verification. Adjust sig if necessary.
    402  *
    403  * @param algo: key algorithm
    404  * @param evp_key: EVP PKEY public key to create.
    405  * @param digest_type: digest type to use
    406  * @param key: key to setup for.
    407  * @param keylen: length of key.
    408  * @return false on failure.
    409  */
    410 static int
    411 setup_key_digest(int algo, EVP_PKEY** evp_key, const EVP_MD** digest_type,
    412 	unsigned char* key, size_t keylen)
    413 {
    414 #if defined(USE_DSA) && defined(USE_SHA1)
    415 	DSA* dsa;
    416 #endif
    417 	RSA* rsa;
    418 
    419 	switch(algo) {
    420 #if defined(USE_DSA) && defined(USE_SHA1)
    421 		case LDNS_DSA:
    422 		case LDNS_DSA_NSEC3:
    423 			*evp_key = EVP_PKEY_new();
    424 			if(!*evp_key) {
    425 				log_err("verify: malloc failure in crypto");
    426 				return 0;
    427 			}
    428 			dsa = sldns_key_buf2dsa_raw(key, keylen);
    429 			if(!dsa) {
    430 				verbose(VERB_QUERY, "verify: "
    431 					"sldns_key_buf2dsa_raw failed");
    432 				return 0;
    433 			}
    434 			if(EVP_PKEY_assign_DSA(*evp_key, dsa) == 0) {
    435 				verbose(VERB_QUERY, "verify: "
    436 					"EVP_PKEY_assign_DSA failed");
    437 				return 0;
    438 			}
    439 #ifdef HAVE_EVP_DSS1
    440 			*digest_type = EVP_dss1();
    441 #else
    442 			*digest_type = EVP_sha1();
    443 #endif
    444 
    445 			break;
    446 #endif /* USE_DSA && USE_SHA1 */
    447 
    448 #if defined(USE_SHA1) || (defined(HAVE_EVP_SHA256) && defined(USE_SHA2)) || (defined(HAVE_EVP_SHA512) && defined(USE_SHA2))
    449 #ifdef USE_SHA1
    450 		case LDNS_RSASHA1:
    451 		case LDNS_RSASHA1_NSEC3:
    452 #endif
    453 #if defined(HAVE_EVP_SHA256) && defined(USE_SHA2)
    454 		case LDNS_RSASHA256:
    455 #endif
    456 #if defined(HAVE_EVP_SHA512) && defined(USE_SHA2)
    457 		case LDNS_RSASHA512:
    458 #endif
    459 			*evp_key = EVP_PKEY_new();
    460 			if(!*evp_key) {
    461 				log_err("verify: malloc failure in crypto");
    462 				return 0;
    463 			}
    464 			rsa = sldns_key_buf2rsa_raw(key, keylen);
    465 			if(!rsa) {
    466 				verbose(VERB_QUERY, "verify: "
    467 					"sldns_key_buf2rsa_raw SHA failed");
    468 				return 0;
    469 			}
    470 			if(EVP_PKEY_assign_RSA(*evp_key, rsa) == 0) {
    471 				verbose(VERB_QUERY, "verify: "
    472 					"EVP_PKEY_assign_RSA SHA failed");
    473 				return 0;
    474 			}
    475 
    476 			/* select SHA version */
    477 #if defined(HAVE_EVP_SHA256) && defined(USE_SHA2)
    478 			if(algo == LDNS_RSASHA256)
    479 				*digest_type = EVP_sha256();
    480 			else
    481 #endif
    482 #if defined(HAVE_EVP_SHA512) && defined(USE_SHA2)
    483 				if(algo == LDNS_RSASHA512)
    484 				*digest_type = EVP_sha512();
    485 			else
    486 #endif
    487 #ifdef USE_SHA1
    488 				*digest_type = EVP_sha1();
    489 #else
    490 				{ verbose(VERB_QUERY, "no digest available"); return 0; }
    491 #endif
    492 			break;
    493 #endif /* defined(USE_SHA1) || (defined(HAVE_EVP_SHA256) && defined(USE_SHA2)) || (defined(HAVE_EVP_SHA512) && defined(USE_SHA2)) */
    494 
    495 		case LDNS_RSAMD5:
    496 			*evp_key = EVP_PKEY_new();
    497 			if(!*evp_key) {
    498 				log_err("verify: malloc failure in crypto");
    499 				return 0;
    500 			}
    501 			rsa = sldns_key_buf2rsa_raw(key, keylen);
    502 			if(!rsa) {
    503 				verbose(VERB_QUERY, "verify: "
    504 					"sldns_key_buf2rsa_raw MD5 failed");
    505 				return 0;
    506 			}
    507 			if(EVP_PKEY_assign_RSA(*evp_key, rsa) == 0) {
    508 				verbose(VERB_QUERY, "verify: "
    509 					"EVP_PKEY_assign_RSA MD5 failed");
    510 				return 0;
    511 			}
    512 			*digest_type = EVP_md5();
    513 
    514 			break;
    515 #ifdef USE_GOST
    516 		case LDNS_ECC_GOST:
    517 			*evp_key = sldns_gost2pkey_raw(key, keylen);
    518 			if(!*evp_key) {
    519 				verbose(VERB_QUERY, "verify: "
    520 					"sldns_gost2pkey_raw failed");
    521 				return 0;
    522 			}
    523 			*digest_type = EVP_get_digestbyname("md_gost94");
    524 			if(!*digest_type) {
    525 				verbose(VERB_QUERY, "verify: "
    526 					"EVP_getdigest md_gost94 failed");
    527 				return 0;
    528 			}
    529 			break;
    530 #endif
    531 #ifdef USE_ECDSA
    532 		case LDNS_ECDSAP256SHA256:
    533 			*evp_key = sldns_ecdsa2pkey_raw(key, keylen,
    534 				LDNS_ECDSAP256SHA256);
    535 			if(!*evp_key) {
    536 				verbose(VERB_QUERY, "verify: "
    537 					"sldns_ecdsa2pkey_raw failed");
    538 				return 0;
    539 			}
    540 #ifdef USE_ECDSA_EVP_WORKAROUND
    541 			*digest_type = &ecdsa_evp_256_md;
    542 #else
    543 			*digest_type = EVP_sha256();
    544 #endif
    545 			break;
    546 		case LDNS_ECDSAP384SHA384:
    547 			*evp_key = sldns_ecdsa2pkey_raw(key, keylen,
    548 				LDNS_ECDSAP384SHA384);
    549 			if(!*evp_key) {
    550 				verbose(VERB_QUERY, "verify: "
    551 					"sldns_ecdsa2pkey_raw failed");
    552 				return 0;
    553 			}
    554 #ifdef USE_ECDSA_EVP_WORKAROUND
    555 			*digest_type = &ecdsa_evp_384_md;
    556 #else
    557 			*digest_type = EVP_sha384();
    558 #endif
    559 			break;
    560 #endif /* USE_ECDSA */
    561 #ifdef USE_ED25519
    562 		case LDNS_ED25519:
    563 			*evp_key = sldns_ed255192pkey_raw(key, keylen);
    564 			if(!*evp_key) {
    565 				verbose(VERB_QUERY, "verify: "
    566 					"sldns_ed255192pkey_raw failed");
    567 				return 0;
    568 			}
    569 			*digest_type = NULL;
    570 			break;
    571 #endif /* USE_ED25519 */
    572 		default:
    573 			verbose(VERB_QUERY, "verify: unknown algorithm %d",
    574 				algo);
    575 			return 0;
    576 	}
    577 	return 1;
    578 }
    579 
    580 /**
    581  * Check a canonical sig+rrset and signature against a dnskey
    582  * @param buf: buffer with data to verify, the first rrsig part and the
    583  *	canonicalized rrset.
    584  * @param algo: DNSKEY algorithm.
    585  * @param sigblock: signature rdata field from RRSIG
    586  * @param sigblock_len: length of sigblock data.
    587  * @param key: public key data from DNSKEY RR.
    588  * @param keylen: length of keydata.
    589  * @param reason: bogus reason in more detail.
    590  * @return secure if verification succeeded, bogus on crypto failure,
    591  *	unchecked on format errors and alloc failures.
    592  */
    593 enum sec_status
    594 verify_canonrrset(sldns_buffer* buf, int algo, unsigned char* sigblock,
    595 	unsigned int sigblock_len, unsigned char* key, unsigned int keylen,
    596 	char** reason)
    597 {
    598 	const EVP_MD *digest_type;
    599 	EVP_MD_CTX* ctx;
    600 	int res, dofree = 0, docrypto_free = 0;
    601 	EVP_PKEY *evp_key = NULL;
    602 
    603 #ifndef USE_DSA
    604 	if((algo == LDNS_DSA || algo == LDNS_DSA_NSEC3) &&(fake_dsa||fake_sha1))
    605 		return sec_status_secure;
    606 #endif
    607 #ifndef USE_SHA1
    608 	if(fake_sha1 && (algo == LDNS_DSA || algo == LDNS_DSA_NSEC3 || algo == LDNS_RSASHA1 || algo == LDNS_RSASHA1_NSEC3))
    609 		return sec_status_secure;
    610 #endif
    611 
    612 	if(!setup_key_digest(algo, &evp_key, &digest_type, key, keylen)) {
    613 		verbose(VERB_QUERY, "verify: failed to setup key");
    614 		*reason = "use of key for crypto failed";
    615 		EVP_PKEY_free(evp_key);
    616 		return sec_status_bogus;
    617 	}
    618 #ifdef USE_DSA
    619 	/* if it is a DSA signature in bind format, convert to DER format */
    620 	if((algo == LDNS_DSA || algo == LDNS_DSA_NSEC3) &&
    621 		sigblock_len == 1+2*SHA_DIGEST_LENGTH) {
    622 		if(!setup_dsa_sig(&sigblock, &sigblock_len)) {
    623 			verbose(VERB_QUERY, "verify: failed to setup DSA sig");
    624 			*reason = "use of key for DSA crypto failed";
    625 			EVP_PKEY_free(evp_key);
    626 			return sec_status_bogus;
    627 		}
    628 		docrypto_free = 1;
    629 	}
    630 #endif
    631 #if defined(USE_ECDSA) && defined(USE_DSA)
    632 	else
    633 #endif
    634 #ifdef USE_ECDSA
    635 	if(algo == LDNS_ECDSAP256SHA256 || algo == LDNS_ECDSAP384SHA384) {
    636 		/* EVP uses ASN prefix on sig, which is not in the wire data */
    637 		if(!setup_ecdsa_sig(&sigblock, &sigblock_len)) {
    638 			verbose(VERB_QUERY, "verify: failed to setup ECDSA sig");
    639 			*reason = "use of signature for ECDSA crypto failed";
    640 			EVP_PKEY_free(evp_key);
    641 			return sec_status_bogus;
    642 		}
    643 		dofree = 1;
    644 	}
    645 #endif /* USE_ECDSA */
    646 
    647 	/* do the signature cryptography work */
    648 #ifdef HAVE_EVP_MD_CTX_NEW
    649 	ctx = EVP_MD_CTX_new();
    650 #else
    651 	ctx = (EVP_MD_CTX*)malloc(sizeof(*ctx));
    652 	if(ctx) EVP_MD_CTX_init(ctx);
    653 #endif
    654 	if(!ctx) {
    655 		log_err("EVP_MD_CTX_new: malloc failure");
    656 		EVP_PKEY_free(evp_key);
    657 		if(dofree) free(sigblock);
    658 		else if(docrypto_free) OPENSSL_free(sigblock);
    659 		return sec_status_unchecked;
    660 	}
    661 #ifndef HAVE_EVP_DIGESTVERIFY
    662 	if(EVP_DigestInit(ctx, digest_type) == 0) {
    663 		verbose(VERB_QUERY, "verify: EVP_DigestInit failed");
    664 #ifdef HAVE_EVP_MD_CTX_NEW
    665 		EVP_MD_CTX_destroy(ctx);
    666 #else
    667 		EVP_MD_CTX_cleanup(ctx);
    668 		free(ctx);
    669 #endif
    670 		EVP_PKEY_free(evp_key);
    671 		if(dofree) free(sigblock);
    672 		else if(docrypto_free) OPENSSL_free(sigblock);
    673 		return sec_status_unchecked;
    674 	}
    675 	if(EVP_DigestUpdate(ctx, (unsigned char*)sldns_buffer_begin(buf),
    676 		(unsigned int)sldns_buffer_limit(buf)) == 0) {
    677 		verbose(VERB_QUERY, "verify: EVP_DigestUpdate failed");
    678 #ifdef HAVE_EVP_MD_CTX_NEW
    679 		EVP_MD_CTX_destroy(ctx);
    680 #else
    681 		EVP_MD_CTX_cleanup(ctx);
    682 		free(ctx);
    683 #endif
    684 		EVP_PKEY_free(evp_key);
    685 		if(dofree) free(sigblock);
    686 		else if(docrypto_free) OPENSSL_free(sigblock);
    687 		return sec_status_unchecked;
    688 	}
    689 
    690 	res = EVP_VerifyFinal(ctx, sigblock, sigblock_len, evp_key);
    691 #else /* HAVE_EVP_DIGESTVERIFY */
    692 	if(EVP_DigestVerifyInit(ctx, NULL, digest_type, NULL, evp_key) == 0) {
    693 		verbose(VERB_QUERY, "verify: EVP_DigestVerifyInit failed");
    694 #ifdef HAVE_EVP_MD_CTX_NEW
    695 		EVP_MD_CTX_destroy(ctx);
    696 #else
    697 		EVP_MD_CTX_cleanup(ctx);
    698 		free(ctx);
    699 #endif
    700 		EVP_PKEY_free(evp_key);
    701 		if(dofree) free(sigblock);
    702 		else if(docrypto_free) OPENSSL_free(sigblock);
    703 		return sec_status_unchecked;
    704 	}
    705 	res = EVP_DigestVerify(ctx, sigblock, sigblock_len,
    706 		(unsigned char*)sldns_buffer_begin(buf),
    707 		sldns_buffer_limit(buf));
    708 #endif
    709 #ifdef HAVE_EVP_MD_CTX_NEW
    710 	EVP_MD_CTX_destroy(ctx);
    711 #else
    712 	EVP_MD_CTX_cleanup(ctx);
    713 	free(ctx);
    714 #endif
    715 	EVP_PKEY_free(evp_key);
    716 
    717 	if(dofree) free(sigblock);
    718 	else if(docrypto_free) OPENSSL_free(sigblock);
    719 
    720 	if(res == 1) {
    721 		return sec_status_secure;
    722 	} else if(res == 0) {
    723 		verbose(VERB_QUERY, "verify: signature mismatch");
    724 		*reason = "signature crypto failed";
    725 		return sec_status_bogus;
    726 	}
    727 
    728 	log_crypto_error("verify:", ERR_get_error());
    729 	return sec_status_unchecked;
    730 }
    731 
    732 /**************************************************/
    733 #elif defined(HAVE_NSS)
    734 /* libnss implementation */
    735 /* nss3 */
    736 #include "sechash.h"
    737 #include "pk11pub.h"
    738 #include "keyhi.h"
    739 #include "secerr.h"
    740 #include "cryptohi.h"
    741 /* nspr4 */
    742 #include "prerror.h"
    743 
    744 /* return size of digest if supported, or 0 otherwise */
    745 size_t
    746 nsec3_hash_algo_size_supported(int id)
    747 {
    748 	switch(id) {
    749 	case NSEC3_HASH_SHA1:
    750 		return SHA1_LENGTH;
    751 	default:
    752 		return 0;
    753 	}
    754 }
    755 
    756 /* perform nsec3 hash. return false on failure */
    757 int
    758 secalgo_nsec3_hash(int algo, unsigned char* buf, size_t len,
    759         unsigned char* res)
    760 {
    761 	switch(algo) {
    762 	case NSEC3_HASH_SHA1:
    763 		(void)HASH_HashBuf(HASH_AlgSHA1, res, buf, (unsigned long)len);
    764 		return 1;
    765 	default:
    766 		return 0;
    767 	}
    768 }
    769 
    770 void
    771 secalgo_hash_sha256(unsigned char* buf, size_t len, unsigned char* res)
    772 {
    773 	(void)HASH_HashBuf(HASH_AlgSHA256, res, buf, (unsigned long)len);
    774 }
    775 
    776 size_t
    777 ds_digest_size_supported(int algo)
    778 {
    779 	/* uses libNSS */
    780 	switch(algo) {
    781 #ifdef USE_SHA1
    782 		case LDNS_SHA1:
    783 			return SHA1_LENGTH;
    784 #endif
    785 #ifdef USE_SHA2
    786 		case LDNS_SHA256:
    787 			return SHA256_LENGTH;
    788 #endif
    789 #ifdef USE_ECDSA
    790 		case LDNS_SHA384:
    791 			return SHA384_LENGTH;
    792 #endif
    793 		/* GOST not supported in NSS */
    794 		case LDNS_HASH_GOST:
    795 		default: break;
    796 	}
    797 	return 0;
    798 }
    799 
    800 int
    801 secalgo_ds_digest(int algo, unsigned char* buf, size_t len,
    802 	unsigned char* res)
    803 {
    804 	/* uses libNSS */
    805 	switch(algo) {
    806 #ifdef USE_SHA1
    807 		case LDNS_SHA1:
    808 			return HASH_HashBuf(HASH_AlgSHA1, res, buf, len)
    809 				== SECSuccess;
    810 #endif
    811 #if defined(USE_SHA2)
    812 		case LDNS_SHA256:
    813 			return HASH_HashBuf(HASH_AlgSHA256, res, buf, len)
    814 				== SECSuccess;
    815 #endif
    816 #ifdef USE_ECDSA
    817 		case LDNS_SHA384:
    818 			return HASH_HashBuf(HASH_AlgSHA384, res, buf, len)
    819 				== SECSuccess;
    820 #endif
    821 		case LDNS_HASH_GOST:
    822 		default:
    823 			verbose(VERB_QUERY, "unknown DS digest algorithm %d",
    824 				algo);
    825 			break;
    826 	}
    827 	return 0;
    828 }
    829 
    830 int
    831 dnskey_algo_id_is_supported(int id)
    832 {
    833 	/* uses libNSS */
    834 	switch(id) {
    835 	case LDNS_RSAMD5:
    836 		/* RFC 6725 deprecates RSAMD5 */
    837 		return 0;
    838 #if defined(USE_SHA1) || defined(USE_SHA2)
    839 #if defined(USE_DSA) && defined(USE_SHA1)
    840 	case LDNS_DSA:
    841 	case LDNS_DSA_NSEC3:
    842 #endif
    843 #ifdef USE_SHA1
    844 	case LDNS_RSASHA1:
    845 	case LDNS_RSASHA1_NSEC3:
    846 #endif
    847 #ifdef USE_SHA2
    848 	case LDNS_RSASHA256:
    849 #endif
    850 #ifdef USE_SHA2
    851 	case LDNS_RSASHA512:
    852 #endif
    853 		return 1;
    854 #endif /* SHA1 or SHA2 */
    855 
    856 #ifdef USE_ECDSA
    857 	case LDNS_ECDSAP256SHA256:
    858 	case LDNS_ECDSAP384SHA384:
    859 		return PK11_TokenExists(CKM_ECDSA);
    860 #endif
    861 	case LDNS_ECC_GOST:
    862 	default:
    863 		return 0;
    864 	}
    865 }
    866 
    867 /* return a new public key for NSS */
    868 static SECKEYPublicKey* nss_key_create(KeyType ktype)
    869 {
    870 	SECKEYPublicKey* key;
    871 	PLArenaPool* arena = PORT_NewArena(DER_DEFAULT_CHUNKSIZE);
    872 	if(!arena) {
    873 		log_err("out of memory, PORT_NewArena failed");
    874 		return NULL;
    875 	}
    876 	key = PORT_ArenaZNew(arena, SECKEYPublicKey);
    877 	if(!key) {
    878 		log_err("out of memory, PORT_ArenaZNew failed");
    879 		PORT_FreeArena(arena, PR_FALSE);
    880 		return NULL;
    881 	}
    882 	key->arena = arena;
    883 	key->keyType = ktype;
    884 	key->pkcs11Slot = NULL;
    885 	key->pkcs11ID = CK_INVALID_HANDLE;
    886 	return key;
    887 }
    888 
    889 static SECKEYPublicKey* nss_buf2ecdsa(unsigned char* key, size_t len, int algo)
    890 {
    891 	SECKEYPublicKey* pk;
    892 	SECItem pub = {siBuffer, NULL, 0};
    893 	SECItem params = {siBuffer, NULL, 0};
    894 	static unsigned char param256[] = {
    895 		/* OBJECTIDENTIFIER 1.2.840.10045.3.1.7 (P-256)
    896 		 * {iso(1) member-body(2) us(840) ansi-x962(10045) curves(3) prime(1) prime256v1(7)} */
    897 		0x06, 0x08, 0x2a, 0x86, 0x48, 0xce, 0x3d, 0x03, 0x01, 0x07
    898 	};
    899 	static unsigned char param384[] = {
    900 		/* OBJECTIDENTIFIER 1.3.132.0.34 (P-384)
    901 		 * {iso(1) identified-organization(3) certicom(132) curve(0) ansip384r1(34)} */
    902 		0x06, 0x05, 0x2b, 0x81, 0x04, 0x00, 0x22
    903 	};
    904 	unsigned char buf[256+2]; /* sufficient for 2*384/8+1 */
    905 
    906 	/* check length, which uncompressed must be 2 bignums */
    907 	if(algo == LDNS_ECDSAP256SHA256) {
    908 		if(len != 2*256/8) return NULL;
    909 		/* ECCurve_X9_62_PRIME_256V1 */
    910 	} else if(algo == LDNS_ECDSAP384SHA384) {
    911 		if(len != 2*384/8) return NULL;
    912 		/* ECCurve_X9_62_PRIME_384R1 */
    913 	} else    return NULL;
    914 
    915 	buf[0] = 0x04; /* POINT_FORM_UNCOMPRESSED */
    916 	memmove(buf+1, key, len);
    917 	pub.data = buf;
    918 	pub.len = len+1;
    919 	if(algo == LDNS_ECDSAP256SHA256) {
    920 		params.data = param256;
    921 		params.len = sizeof(param256);
    922 	} else {
    923 		params.data = param384;
    924 		params.len = sizeof(param384);
    925 	}
    926 
    927 	pk = nss_key_create(ecKey);
    928 	if(!pk)
    929 		return NULL;
    930 	pk->u.ec.size = (len/2)*8;
    931 	if(SECITEM_CopyItem(pk->arena, &pk->u.ec.publicValue, &pub)) {
    932 		SECKEY_DestroyPublicKey(pk);
    933 		return NULL;
    934 	}
    935 	if(SECITEM_CopyItem(pk->arena, &pk->u.ec.DEREncodedParams, &params)) {
    936 		SECKEY_DestroyPublicKey(pk);
    937 		return NULL;
    938 	}
    939 
    940 	return pk;
    941 }
    942 
    943 static SECKEYPublicKey* nss_buf2dsa(unsigned char* key, size_t len)
    944 {
    945 	SECKEYPublicKey* pk;
    946 	uint8_t T;
    947 	uint16_t length;
    948 	uint16_t offset;
    949 	SECItem Q = {siBuffer, NULL, 0};
    950 	SECItem P = {siBuffer, NULL, 0};
    951 	SECItem G = {siBuffer, NULL, 0};
    952 	SECItem Y = {siBuffer, NULL, 0};
    953 
    954 	if(len == 0)
    955 		return NULL;
    956 	T = (uint8_t)key[0];
    957 	length = (64 + T * 8);
    958 	offset = 1;
    959 
    960 	if (T > 8) {
    961 		return NULL;
    962 	}
    963 	if(len < (size_t)1 + SHA1_LENGTH + 3*length)
    964 		return NULL;
    965 
    966 	Q.data = key+offset;
    967 	Q.len = SHA1_LENGTH;
    968 	offset += SHA1_LENGTH;
    969 
    970 	P.data = key+offset;
    971 	P.len = length;
    972 	offset += length;
    973 
    974 	G.data = key+offset;
    975 	G.len = length;
    976 	offset += length;
    977 
    978 	Y.data = key+offset;
    979 	Y.len = length;
    980 	offset += length;
    981 
    982 	pk = nss_key_create(dsaKey);
    983 	if(!pk)
    984 		return NULL;
    985 	if(SECITEM_CopyItem(pk->arena, &pk->u.dsa.params.prime, &P)) {
    986 		SECKEY_DestroyPublicKey(pk);
    987 		return NULL;
    988 	}
    989 	if(SECITEM_CopyItem(pk->arena, &pk->u.dsa.params.subPrime, &Q)) {
    990 		SECKEY_DestroyPublicKey(pk);
    991 		return NULL;
    992 	}
    993 	if(SECITEM_CopyItem(pk->arena, &pk->u.dsa.params.base, &G)) {
    994 		SECKEY_DestroyPublicKey(pk);
    995 		return NULL;
    996 	}
    997 	if(SECITEM_CopyItem(pk->arena, &pk->u.dsa.publicValue, &Y)) {
    998 		SECKEY_DestroyPublicKey(pk);
    999 		return NULL;
   1000 	}
   1001 	return pk;
   1002 }
   1003 
   1004 static SECKEYPublicKey* nss_buf2rsa(unsigned char* key, size_t len)
   1005 {
   1006 	SECKEYPublicKey* pk;
   1007 	uint16_t exp;
   1008 	uint16_t offset;
   1009 	uint16_t int16;
   1010 	SECItem modulus = {siBuffer, NULL, 0};
   1011 	SECItem exponent = {siBuffer, NULL, 0};
   1012 	if(len == 0)
   1013 		return NULL;
   1014 	if(key[0] == 0) {
   1015 		if(len < 3)
   1016 			return NULL;
   1017 		/* the exponent is too large so it's places further */
   1018 		memmove(&int16, key+1, 2);
   1019 		exp = ntohs(int16);
   1020 		offset = 3;
   1021 	} else {
   1022 		exp = key[0];
   1023 		offset = 1;
   1024 	}
   1025 
   1026 	/* key length at least one */
   1027 	if(len < (size_t)offset + exp + 1)
   1028 		return NULL;
   1029 
   1030 	exponent.data = key+offset;
   1031 	exponent.len = exp;
   1032 	offset += exp;
   1033 	modulus.data = key+offset;
   1034 	modulus.len = (len - offset);
   1035 
   1036 	pk = nss_key_create(rsaKey);
   1037 	if(!pk)
   1038 		return NULL;
   1039 	if(SECITEM_CopyItem(pk->arena, &pk->u.rsa.modulus, &modulus)) {
   1040 		SECKEY_DestroyPublicKey(pk);
   1041 		return NULL;
   1042 	}
   1043 	if(SECITEM_CopyItem(pk->arena, &pk->u.rsa.publicExponent, &exponent)) {
   1044 		SECKEY_DestroyPublicKey(pk);
   1045 		return NULL;
   1046 	}
   1047 	return pk;
   1048 }
   1049 
   1050 /**
   1051  * Setup key and digest for verification. Adjust sig if necessary.
   1052  *
   1053  * @param algo: key algorithm
   1054  * @param evp_key: EVP PKEY public key to create.
   1055  * @param digest_type: digest type to use
   1056  * @param key: key to setup for.
   1057  * @param keylen: length of key.
   1058  * @param prefix: if returned, the ASN prefix for the hashblob.
   1059  * @param prefixlen: length of the prefix.
   1060  * @return false on failure.
   1061  */
   1062 static int
   1063 nss_setup_key_digest(int algo, SECKEYPublicKey** pubkey, HASH_HashType* htype,
   1064 	unsigned char* key, size_t keylen, unsigned char** prefix,
   1065 	size_t* prefixlen)
   1066 {
   1067 	/* uses libNSS */
   1068 
   1069 	/* hash prefix for md5, RFC2537 */
   1070 	static unsigned char p_md5[] = {0x30, 0x20, 0x30, 0x0c, 0x06, 0x08, 0x2a,
   1071 	0x86, 0x48, 0x86, 0xf7, 0x0d, 0x02, 0x05, 0x05, 0x00, 0x04, 0x10};
   1072 	/* hash prefix to prepend to hash output, from RFC3110 */
   1073 	static unsigned char p_sha1[] = {0x30, 0x21, 0x30, 0x09, 0x06, 0x05, 0x2B,
   1074 		0x0E, 0x03, 0x02, 0x1A, 0x05, 0x00, 0x04, 0x14};
   1075 	/* from RFC5702 */
   1076 	static unsigned char p_sha256[] = {0x30, 0x31, 0x30, 0x0d, 0x06, 0x09, 0x60,
   1077 	0x86, 0x48, 0x01, 0x65, 0x03, 0x04, 0x02, 0x01, 0x05, 0x00, 0x04, 0x20};
   1078 	static unsigned char p_sha512[] = {0x30, 0x51, 0x30, 0x0d, 0x06, 0x09, 0x60,
   1079 	0x86, 0x48, 0x01, 0x65, 0x03, 0x04, 0x02, 0x03, 0x05, 0x00, 0x04, 0x40};
   1080 	/* from RFC6234 */
   1081 	/* for future RSASHA384 ..
   1082 	static unsigned char p_sha384[] = {0x30, 0x51, 0x30, 0x0d, 0x06, 0x09, 0x60,
   1083 	0x86, 0x48, 0x01, 0x65, 0x03, 0x04, 0x02, 0x02, 0x05, 0x00, 0x04, 0x30};
   1084 	*/
   1085 
   1086 	switch(algo) {
   1087 
   1088 #if defined(USE_SHA1) || defined(USE_SHA2)
   1089 #if defined(USE_DSA) && defined(USE_SHA1)
   1090 		case LDNS_DSA:
   1091 		case LDNS_DSA_NSEC3:
   1092 			*pubkey = nss_buf2dsa(key, keylen);
   1093 			if(!*pubkey) {
   1094 				log_err("verify: malloc failure in crypto");
   1095 				return 0;
   1096 			}
   1097 			*htype = HASH_AlgSHA1;
   1098 			/* no prefix for DSA verification */
   1099 			break;
   1100 #endif
   1101 #ifdef USE_SHA1
   1102 		case LDNS_RSASHA1:
   1103 		case LDNS_RSASHA1_NSEC3:
   1104 #endif
   1105 #ifdef USE_SHA2
   1106 		case LDNS_RSASHA256:
   1107 #endif
   1108 #ifdef USE_SHA2
   1109 		case LDNS_RSASHA512:
   1110 #endif
   1111 			*pubkey = nss_buf2rsa(key, keylen);
   1112 			if(!*pubkey) {
   1113 				log_err("verify: malloc failure in crypto");
   1114 				return 0;
   1115 			}
   1116 			/* select SHA version */
   1117 #ifdef USE_SHA2
   1118 			if(algo == LDNS_RSASHA256) {
   1119 				*htype = HASH_AlgSHA256;
   1120 				*prefix = p_sha256;
   1121 				*prefixlen = sizeof(p_sha256);
   1122 			} else
   1123 #endif
   1124 #ifdef USE_SHA2
   1125 				if(algo == LDNS_RSASHA512) {
   1126 				*htype = HASH_AlgSHA512;
   1127 				*prefix = p_sha512;
   1128 				*prefixlen = sizeof(p_sha512);
   1129 			} else
   1130 #endif
   1131 #ifdef USE_SHA1
   1132 			{
   1133 				*htype = HASH_AlgSHA1;
   1134 				*prefix = p_sha1;
   1135 				*prefixlen = sizeof(p_sha1);
   1136 			}
   1137 #else
   1138 			{
   1139 				verbose(VERB_QUERY, "verify: no digest algo");
   1140 				return 0;
   1141 			}
   1142 #endif
   1143 
   1144 			break;
   1145 #endif /* SHA1 or SHA2 */
   1146 
   1147 		case LDNS_RSAMD5:
   1148 			*pubkey = nss_buf2rsa(key, keylen);
   1149 			if(!*pubkey) {
   1150 				log_err("verify: malloc failure in crypto");
   1151 				return 0;
   1152 			}
   1153 			*htype = HASH_AlgMD5;
   1154 			*prefix = p_md5;
   1155 			*prefixlen = sizeof(p_md5);
   1156 
   1157 			break;
   1158 #ifdef USE_ECDSA
   1159 		case LDNS_ECDSAP256SHA256:
   1160 			*pubkey = nss_buf2ecdsa(key, keylen,
   1161 				LDNS_ECDSAP256SHA256);
   1162 			if(!*pubkey) {
   1163 				log_err("verify: malloc failure in crypto");
   1164 				return 0;
   1165 			}
   1166 			*htype = HASH_AlgSHA256;
   1167 			/* no prefix for DSA verification */
   1168 			break;
   1169 		case LDNS_ECDSAP384SHA384:
   1170 			*pubkey = nss_buf2ecdsa(key, keylen,
   1171 				LDNS_ECDSAP384SHA384);
   1172 			if(!*pubkey) {
   1173 				log_err("verify: malloc failure in crypto");
   1174 				return 0;
   1175 			}
   1176 			*htype = HASH_AlgSHA384;
   1177 			/* no prefix for DSA verification */
   1178 			break;
   1179 #endif /* USE_ECDSA */
   1180 		case LDNS_ECC_GOST:
   1181 		default:
   1182 			verbose(VERB_QUERY, "verify: unknown algorithm %d",
   1183 				algo);
   1184 			return 0;
   1185 	}
   1186 	return 1;
   1187 }
   1188 
   1189 /**
   1190  * Check a canonical sig+rrset and signature against a dnskey
   1191  * @param buf: buffer with data to verify, the first rrsig part and the
   1192  *	canonicalized rrset.
   1193  * @param algo: DNSKEY algorithm.
   1194  * @param sigblock: signature rdata field from RRSIG
   1195  * @param sigblock_len: length of sigblock data.
   1196  * @param key: public key data from DNSKEY RR.
   1197  * @param keylen: length of keydata.
   1198  * @param reason: bogus reason in more detail.
   1199  * @return secure if verification succeeded, bogus on crypto failure,
   1200  *	unchecked on format errors and alloc failures.
   1201  */
   1202 enum sec_status
   1203 verify_canonrrset(sldns_buffer* buf, int algo, unsigned char* sigblock,
   1204 	unsigned int sigblock_len, unsigned char* key, unsigned int keylen,
   1205 	char** reason)
   1206 {
   1207 	/* uses libNSS */
   1208 	/* large enough for the different hashes */
   1209 	unsigned char hash[HASH_LENGTH_MAX];
   1210 	unsigned char hash2[HASH_LENGTH_MAX*2];
   1211 	HASH_HashType htype = 0;
   1212 	SECKEYPublicKey* pubkey = NULL;
   1213 	SECItem secsig = {siBuffer, sigblock, sigblock_len};
   1214 	SECItem sechash = {siBuffer, hash, 0};
   1215 	SECStatus res;
   1216 	unsigned char* prefix = NULL; /* prefix for hash, RFC3110, RFC5702 */
   1217 	size_t prefixlen = 0;
   1218 	int err;
   1219 
   1220 	if(!nss_setup_key_digest(algo, &pubkey, &htype, key, keylen,
   1221 		&prefix, &prefixlen)) {
   1222 		verbose(VERB_QUERY, "verify: failed to setup key");
   1223 		*reason = "use of key for crypto failed";
   1224 		SECKEY_DestroyPublicKey(pubkey);
   1225 		return sec_status_bogus;
   1226 	}
   1227 
   1228 #if defined(USE_DSA) && defined(USE_SHA1)
   1229 	/* need to convert DSA, ECDSA signatures? */
   1230 	if((algo == LDNS_DSA || algo == LDNS_DSA_NSEC3)) {
   1231 		if(sigblock_len == 1+2*SHA1_LENGTH) {
   1232 			secsig.data ++;
   1233 			secsig.len --;
   1234 		} else {
   1235 			SECItem* p = DSAU_DecodeDerSig(&secsig);
   1236 			if(!p) {
   1237 				verbose(VERB_QUERY, "verify: failed DER decode");
   1238 				*reason = "signature DER decode failed";
   1239 				SECKEY_DestroyPublicKey(pubkey);
   1240 				return sec_status_bogus;
   1241 			}
   1242 			if(SECITEM_CopyItem(pubkey->arena, &secsig, p)) {
   1243 				log_err("alloc failure in DER decode");
   1244 				SECKEY_DestroyPublicKey(pubkey);
   1245 				SECITEM_FreeItem(p, PR_TRUE);
   1246 				return sec_status_unchecked;
   1247 			}
   1248 			SECITEM_FreeItem(p, PR_TRUE);
   1249 		}
   1250 	}
   1251 #endif /* USE_DSA */
   1252 
   1253 	/* do the signature cryptography work */
   1254 	/* hash the data */
   1255 	sechash.len = HASH_ResultLen(htype);
   1256 	if(sechash.len > sizeof(hash)) {
   1257 		verbose(VERB_QUERY, "verify: hash too large for buffer");
   1258 		SECKEY_DestroyPublicKey(pubkey);
   1259 		return sec_status_unchecked;
   1260 	}
   1261 	if(HASH_HashBuf(htype, hash, (unsigned char*)sldns_buffer_begin(buf),
   1262 		(unsigned int)sldns_buffer_limit(buf)) != SECSuccess) {
   1263 		verbose(VERB_QUERY, "verify: HASH_HashBuf failed");
   1264 		SECKEY_DestroyPublicKey(pubkey);
   1265 		return sec_status_unchecked;
   1266 	}
   1267 	if(prefix) {
   1268 		int hashlen = sechash.len;
   1269 		if(prefixlen+hashlen > sizeof(hash2)) {
   1270 			verbose(VERB_QUERY, "verify: hashprefix too large");
   1271 			SECKEY_DestroyPublicKey(pubkey);
   1272 			return sec_status_unchecked;
   1273 		}
   1274 		sechash.data = hash2;
   1275 		sechash.len = prefixlen+hashlen;
   1276 		memcpy(sechash.data, prefix, prefixlen);
   1277 		memmove(sechash.data+prefixlen, hash, hashlen);
   1278 	}
   1279 
   1280 	/* verify the signature */
   1281 	res = PK11_Verify(pubkey, &secsig, &sechash, NULL /*wincx*/);
   1282 	SECKEY_DestroyPublicKey(pubkey);
   1283 
   1284 	if(res == SECSuccess) {
   1285 		return sec_status_secure;
   1286 	}
   1287 	err = PORT_GetError();
   1288 	if(err != SEC_ERROR_BAD_SIGNATURE) {
   1289 		/* failed to verify */
   1290 		verbose(VERB_QUERY, "verify: PK11_Verify failed: %s",
   1291 			PORT_ErrorToString(err));
   1292 		/* if it is not supported, like ECC is removed, we get,
   1293 		 * SEC_ERROR_NO_MODULE */
   1294 		if(err == SEC_ERROR_NO_MODULE)
   1295 			return sec_status_unchecked;
   1296 		/* but other errors are commonly returned
   1297 		 * for a bad signature from NSS.  Thus we return bogus,
   1298 		 * not unchecked */
   1299 		*reason = "signature crypto failed";
   1300 		return sec_status_bogus;
   1301 	}
   1302 	verbose(VERB_QUERY, "verify: signature mismatch: %s",
   1303 		PORT_ErrorToString(err));
   1304 	*reason = "signature crypto failed";
   1305 	return sec_status_bogus;
   1306 }
   1307 
   1308 #elif defined(HAVE_NETTLE)
   1309 
   1310 #include "sha.h"
   1311 #include "bignum.h"
   1312 #include "macros.h"
   1313 #include "rsa.h"
   1314 #include "dsa.h"
   1315 #ifdef HAVE_NETTLE_DSA_COMPAT_H
   1316 #include "dsa-compat.h"
   1317 #endif
   1318 #include "asn1.h"
   1319 #ifdef USE_ECDSA
   1320 #include "ecdsa.h"
   1321 #include "ecc-curve.h"
   1322 #endif
   1323 #ifdef HAVE_NETTLE_EDDSA_H
   1324 #include "eddsa.h"
   1325 #endif
   1326 
   1327 static int
   1328 _digest_nettle(int algo, uint8_t* buf, size_t len,
   1329 	unsigned char* res)
   1330 {
   1331 	switch(algo) {
   1332 		case SHA1_DIGEST_SIZE:
   1333 		{
   1334 			struct sha1_ctx ctx;
   1335 			sha1_init(&ctx);
   1336 			sha1_update(&ctx, len, buf);
   1337 			sha1_digest(&ctx, SHA1_DIGEST_SIZE, res);
   1338 			return 1;
   1339 		}
   1340 		case SHA256_DIGEST_SIZE:
   1341 		{
   1342 			struct sha256_ctx ctx;
   1343 			sha256_init(&ctx);
   1344 			sha256_update(&ctx, len, buf);
   1345 			sha256_digest(&ctx, SHA256_DIGEST_SIZE, res);
   1346 			return 1;
   1347 		}
   1348 		case SHA384_DIGEST_SIZE:
   1349 		{
   1350 			struct sha384_ctx ctx;
   1351 			sha384_init(&ctx);
   1352 			sha384_update(&ctx, len, buf);
   1353 			sha384_digest(&ctx, SHA384_DIGEST_SIZE, res);
   1354 			return 1;
   1355 		}
   1356 		case SHA512_DIGEST_SIZE:
   1357 		{
   1358 			struct sha512_ctx ctx;
   1359 			sha512_init(&ctx);
   1360 			sha512_update(&ctx, len, buf);
   1361 			sha512_digest(&ctx, SHA512_DIGEST_SIZE, res);
   1362 			return 1;
   1363 		}
   1364 		default:
   1365 			break;
   1366 	}
   1367 	return 0;
   1368 }
   1369 
   1370 /* return size of digest if supported, or 0 otherwise */
   1371 size_t
   1372 nsec3_hash_algo_size_supported(int id)
   1373 {
   1374 	switch(id) {
   1375 	case NSEC3_HASH_SHA1:
   1376 		return SHA1_DIGEST_SIZE;
   1377 	default:
   1378 		return 0;
   1379 	}
   1380 }
   1381 
   1382 /* perform nsec3 hash. return false on failure */
   1383 int
   1384 secalgo_nsec3_hash(int algo, unsigned char* buf, size_t len,
   1385         unsigned char* res)
   1386 {
   1387 	switch(algo) {
   1388 	case NSEC3_HASH_SHA1:
   1389 		return _digest_nettle(SHA1_DIGEST_SIZE, (uint8_t*)buf, len,
   1390 			res);
   1391 	default:
   1392 		return 0;
   1393 	}
   1394 }
   1395 
   1396 void
   1397 secalgo_hash_sha256(unsigned char* buf, size_t len, unsigned char* res)
   1398 {
   1399 	_digest_nettle(SHA256_DIGEST_SIZE, (uint8_t*)buf, len, res);
   1400 }
   1401 
   1402 /**
   1403  * Return size of DS digest according to its hash algorithm.
   1404  * @param algo: DS digest algo.
   1405  * @return size in bytes of digest, or 0 if not supported.
   1406  */
   1407 size_t
   1408 ds_digest_size_supported(int algo)
   1409 {
   1410 	switch(algo) {
   1411 		case LDNS_SHA1:
   1412 #ifdef USE_SHA1
   1413 			return SHA1_DIGEST_SIZE;
   1414 #else
   1415 			if(fake_sha1) return 20;
   1416 			return 0;
   1417 #endif
   1418 #ifdef USE_SHA2
   1419 		case LDNS_SHA256:
   1420 			return SHA256_DIGEST_SIZE;
   1421 #endif
   1422 #ifdef USE_ECDSA
   1423 		case LDNS_SHA384:
   1424 			return SHA384_DIGEST_SIZE;
   1425 #endif
   1426 		/* GOST not supported */
   1427 		case LDNS_HASH_GOST:
   1428 		default:
   1429 			break;
   1430 	}
   1431 	return 0;
   1432 }
   1433 
   1434 int
   1435 secalgo_ds_digest(int algo, unsigned char* buf, size_t len,
   1436 	unsigned char* res)
   1437 {
   1438 	switch(algo) {
   1439 #ifdef USE_SHA1
   1440 		case LDNS_SHA1:
   1441 			return _digest_nettle(SHA1_DIGEST_SIZE, buf, len, res);
   1442 #endif
   1443 #if defined(USE_SHA2)
   1444 		case LDNS_SHA256:
   1445 			return _digest_nettle(SHA256_DIGEST_SIZE, buf, len, res);
   1446 #endif
   1447 #ifdef USE_ECDSA
   1448 		case LDNS_SHA384:
   1449 			return _digest_nettle(SHA384_DIGEST_SIZE, buf, len, res);
   1450 
   1451 #endif
   1452 		case LDNS_HASH_GOST:
   1453 		default:
   1454 			verbose(VERB_QUERY, "unknown DS digest algorithm %d",
   1455 				algo);
   1456 			break;
   1457 	}
   1458 	return 0;
   1459 }
   1460 
   1461 int
   1462 dnskey_algo_id_is_supported(int id)
   1463 {
   1464 	/* uses libnettle */
   1465 	switch(id) {
   1466 #if defined(USE_DSA) && defined(USE_SHA1)
   1467 	case LDNS_DSA:
   1468 	case LDNS_DSA_NSEC3:
   1469 #endif
   1470 #ifdef USE_SHA1
   1471 	case LDNS_RSASHA1:
   1472 	case LDNS_RSASHA1_NSEC3:
   1473 #endif
   1474 #ifdef USE_SHA2
   1475 	case LDNS_RSASHA256:
   1476 	case LDNS_RSASHA512:
   1477 #endif
   1478 #ifdef USE_ECDSA
   1479 	case LDNS_ECDSAP256SHA256:
   1480 	case LDNS_ECDSAP384SHA384:
   1481 #endif
   1482 		return 1;
   1483 #ifdef USE_ED25519
   1484 	case LDNS_ED25519:
   1485 		return 1;
   1486 #endif
   1487 	case LDNS_RSAMD5: /* RFC 6725 deprecates RSAMD5 */
   1488 	case LDNS_ECC_GOST:
   1489 	default:
   1490 		return 0;
   1491 	}
   1492 }
   1493 
   1494 #if defined(USE_DSA) && defined(USE_SHA1)
   1495 static char *
   1496 _verify_nettle_dsa(sldns_buffer* buf, unsigned char* sigblock,
   1497 	unsigned int sigblock_len, unsigned char* key, unsigned int keylen)
   1498 {
   1499 	uint8_t digest[SHA1_DIGEST_SIZE];
   1500 	uint8_t key_t_value;
   1501 	int res = 0;
   1502 	size_t offset;
   1503 	struct dsa_public_key pubkey;
   1504 	struct dsa_signature signature;
   1505 	unsigned int expected_len;
   1506 
   1507 	/* Extract DSA signature from the record */
   1508 	nettle_dsa_signature_init(&signature);
   1509 	/* Signature length: 41 bytes - RFC 2536 sec. 3 */
   1510 	if(sigblock_len == 41) {
   1511 		if(key[0] != sigblock[0])
   1512 			return "invalid T value in DSA signature or pubkey";
   1513 		nettle_mpz_set_str_256_u(signature.r, 20, sigblock+1);
   1514 		nettle_mpz_set_str_256_u(signature.s, 20, sigblock+1+20);
   1515 	} else {
   1516 		/* DER encoded, decode the ASN1 notated R and S bignums */
   1517 		/* SEQUENCE { r INTEGER, s INTEGER } */
   1518 		struct asn1_der_iterator i, seq;
   1519 		if(asn1_der_iterator_first(&i, sigblock_len,
   1520 			(uint8_t*)sigblock) != ASN1_ITERATOR_CONSTRUCTED
   1521 			|| i.type != ASN1_SEQUENCE)
   1522 			return "malformed DER encoded DSA signature";
   1523 		/* decode this element of i using the seq iterator */
   1524 		if(asn1_der_decode_constructed(&i, &seq) !=
   1525 			ASN1_ITERATOR_PRIMITIVE || seq.type != ASN1_INTEGER)
   1526 			return "malformed DER encoded DSA signature";
   1527 		if(!asn1_der_get_bignum(&seq, signature.r, 20*8))
   1528 			return "malformed DER encoded DSA signature";
   1529 		if(asn1_der_iterator_next(&seq) != ASN1_ITERATOR_PRIMITIVE
   1530 			|| seq.type != ASN1_INTEGER)
   1531 			return "malformed DER encoded DSA signature";
   1532 		if(!asn1_der_get_bignum(&seq, signature.s, 20*8))
   1533 			return "malformed DER encoded DSA signature";
   1534 		if(asn1_der_iterator_next(&i) != ASN1_ITERATOR_END)
   1535 			return "malformed DER encoded DSA signature";
   1536 	}
   1537 
   1538 	/* Validate T values constraints - RFC 2536 sec. 2 & sec. 3 */
   1539 	key_t_value = key[0];
   1540 	if (key_t_value > 8) {
   1541 		return "invalid T value in DSA pubkey";
   1542 	}
   1543 
   1544 	/* Pubkey minimum length: 21 bytes - RFC 2536 sec. 2 */
   1545 	if (keylen < 21) {
   1546 		return "DSA pubkey too short";
   1547 	}
   1548 
   1549 	expected_len =   1 +		/* T */
   1550 		        20 +		/* Q */
   1551 		       (64 + key_t_value*8) +	/* P */
   1552 		       (64 + key_t_value*8) +	/* G */
   1553 		       (64 + key_t_value*8);	/* Y */
   1554 	if (keylen != expected_len ) {
   1555 		return "invalid DSA pubkey length";
   1556 	}
   1557 
   1558 	/* Extract DSA pubkey from the record */
   1559 	nettle_dsa_public_key_init(&pubkey);
   1560 	offset = 1;
   1561 	nettle_mpz_set_str_256_u(pubkey.q, 20, key+offset);
   1562 	offset += 20;
   1563 	nettle_mpz_set_str_256_u(pubkey.p, (64 + key_t_value*8), key+offset);
   1564 	offset += (64 + key_t_value*8);
   1565 	nettle_mpz_set_str_256_u(pubkey.g, (64 + key_t_value*8), key+offset);
   1566 	offset += (64 + key_t_value*8);
   1567 	nettle_mpz_set_str_256_u(pubkey.y, (64 + key_t_value*8), key+offset);
   1568 
   1569 	/* Digest content of "buf" and verify its DSA signature in "sigblock"*/
   1570 	res = _digest_nettle(SHA1_DIGEST_SIZE, (unsigned char*)sldns_buffer_begin(buf),
   1571 						(unsigned int)sldns_buffer_limit(buf), (unsigned char*)digest);
   1572 	res &= dsa_sha1_verify_digest(&pubkey, digest, &signature);
   1573 
   1574 	/* Clear and return */
   1575 	nettle_dsa_signature_clear(&signature);
   1576 	nettle_dsa_public_key_clear(&pubkey);
   1577 	if (!res)
   1578 		return "DSA signature verification failed";
   1579 	else
   1580 		return NULL;
   1581 }
   1582 #endif /* USE_DSA */
   1583 
   1584 static char *
   1585 _verify_nettle_rsa(sldns_buffer* buf, unsigned int digest_size, char* sigblock,
   1586 	unsigned int sigblock_len, uint8_t* key, unsigned int keylen)
   1587 {
   1588 	uint16_t exp_len = 0;
   1589 	size_t exp_offset = 0, mod_offset = 0;
   1590 	struct rsa_public_key pubkey;
   1591 	mpz_t signature;
   1592 	int res = 0;
   1593 
   1594 	/* RSA pubkey parsing as per RFC 3110 sec. 2 */
   1595 	if( keylen <= 1) {
   1596 		return "null RSA key";
   1597 	}
   1598 	if (key[0] != 0) {
   1599 		/* 1-byte length */
   1600 		exp_len = key[0];
   1601 		exp_offset = 1;
   1602 	} else {
   1603 		/* 1-byte NUL + 2-bytes exponent length */
   1604 		if (keylen < 3) {
   1605 			return "incorrect RSA key length";
   1606 		}
   1607 		exp_len = READ_UINT16(key+1);
   1608 		if (exp_len == 0)
   1609 			return "null RSA exponent length";
   1610 		exp_offset = 3;
   1611 	}
   1612 	/* Check that we are not over-running input length */
   1613 	if (keylen < exp_offset + exp_len + 1) {
   1614 		return "RSA key content shorter than expected";
   1615 	}
   1616 	mod_offset = exp_offset + exp_len;
   1617 	nettle_rsa_public_key_init(&pubkey);
   1618 	pubkey.size = keylen - mod_offset;
   1619 	nettle_mpz_set_str_256_u(pubkey.e, exp_len, &key[exp_offset]);
   1620 	nettle_mpz_set_str_256_u(pubkey.n, pubkey.size, &key[mod_offset]);
   1621 
   1622 	/* Digest content of "buf" and verify its RSA signature in "sigblock"*/
   1623 	nettle_mpz_init_set_str_256_u(signature, sigblock_len, (uint8_t*)sigblock);
   1624 	switch (digest_size) {
   1625 		case SHA1_DIGEST_SIZE:
   1626 		{
   1627 			uint8_t digest[SHA1_DIGEST_SIZE];
   1628 			res = _digest_nettle(SHA1_DIGEST_SIZE, (unsigned char*)sldns_buffer_begin(buf),
   1629 						(unsigned int)sldns_buffer_limit(buf), (unsigned char*)digest);
   1630 			res &= rsa_sha1_verify_digest(&pubkey, digest, signature);
   1631 			break;
   1632 		}
   1633 		case SHA256_DIGEST_SIZE:
   1634 		{
   1635 			uint8_t digest[SHA256_DIGEST_SIZE];
   1636 			res = _digest_nettle(SHA256_DIGEST_SIZE, (unsigned char*)sldns_buffer_begin(buf),
   1637 						(unsigned int)sldns_buffer_limit(buf), (unsigned char*)digest);
   1638 			res &= rsa_sha256_verify_digest(&pubkey, digest, signature);
   1639 			break;
   1640 		}
   1641 		case SHA512_DIGEST_SIZE:
   1642 		{
   1643 			uint8_t digest[SHA512_DIGEST_SIZE];
   1644 			res = _digest_nettle(SHA512_DIGEST_SIZE, (unsigned char*)sldns_buffer_begin(buf),
   1645 						(unsigned int)sldns_buffer_limit(buf), (unsigned char*)digest);
   1646 			res &= rsa_sha512_verify_digest(&pubkey, digest, signature);
   1647 			break;
   1648 		}
   1649 		default:
   1650 			break;
   1651 	}
   1652 
   1653 	/* Clear and return */
   1654 	nettle_rsa_public_key_clear(&pubkey);
   1655 	mpz_clear(signature);
   1656 	if (!res) {
   1657 		return "RSA signature verification failed";
   1658 	} else {
   1659 		return NULL;
   1660 	}
   1661 }
   1662 
   1663 #ifdef USE_ECDSA
   1664 static char *
   1665 _verify_nettle_ecdsa(sldns_buffer* buf, unsigned int digest_size, unsigned char* sigblock,
   1666 	unsigned int sigblock_len, unsigned char* key, unsigned int keylen)
   1667 {
   1668 	int res = 0;
   1669 	struct ecc_point pubkey;
   1670 	struct dsa_signature signature;
   1671 
   1672 	/* Always matched strength, as per RFC 6605 sec. 1 */
   1673 	if (sigblock_len != 2*digest_size || keylen != 2*digest_size) {
   1674 		return "wrong ECDSA signature length";
   1675 	}
   1676 
   1677 	/* Parse ECDSA signature as per RFC 6605 sec. 4 */
   1678 	nettle_dsa_signature_init(&signature);
   1679 	switch (digest_size) {
   1680 		case SHA256_DIGEST_SIZE:
   1681 		{
   1682 			uint8_t digest[SHA256_DIGEST_SIZE];
   1683 			mpz_t x, y;
   1684 			nettle_ecc_point_init(&pubkey, &nettle_secp_256r1);
   1685 			nettle_mpz_init_set_str_256_u(x, SHA256_DIGEST_SIZE, key);
   1686 			nettle_mpz_init_set_str_256_u(y, SHA256_DIGEST_SIZE, key+SHA256_DIGEST_SIZE);
   1687 			nettle_mpz_set_str_256_u(signature.r, SHA256_DIGEST_SIZE, sigblock);
   1688 			nettle_mpz_set_str_256_u(signature.s, SHA256_DIGEST_SIZE, sigblock+SHA256_DIGEST_SIZE);
   1689 			res = _digest_nettle(SHA256_DIGEST_SIZE, (unsigned char*)sldns_buffer_begin(buf),
   1690 						(unsigned int)sldns_buffer_limit(buf), (unsigned char*)digest);
   1691 			res &= nettle_ecc_point_set(&pubkey, x, y);
   1692 			res &= nettle_ecdsa_verify (&pubkey, SHA256_DIGEST_SIZE, digest, &signature);
   1693 			mpz_clear(x);
   1694 			mpz_clear(y);
   1695 			break;
   1696 		}
   1697 		case SHA384_DIGEST_SIZE:
   1698 		{
   1699 			uint8_t digest[SHA384_DIGEST_SIZE];
   1700 			mpz_t x, y;
   1701 			nettle_ecc_point_init(&pubkey, &nettle_secp_384r1);
   1702 			nettle_mpz_init_set_str_256_u(x, SHA384_DIGEST_SIZE, key);
   1703 			nettle_mpz_init_set_str_256_u(y, SHA384_DIGEST_SIZE, key+SHA384_DIGEST_SIZE);
   1704 			nettle_mpz_set_str_256_u(signature.r, SHA384_DIGEST_SIZE, sigblock);
   1705 			nettle_mpz_set_str_256_u(signature.s, SHA384_DIGEST_SIZE, sigblock+SHA384_DIGEST_SIZE);
   1706 			res = _digest_nettle(SHA384_DIGEST_SIZE, (unsigned char*)sldns_buffer_begin(buf),
   1707 						(unsigned int)sldns_buffer_limit(buf), (unsigned char*)digest);
   1708 			res &= nettle_ecc_point_set(&pubkey, x, y);
   1709 			res &= nettle_ecdsa_verify (&pubkey, SHA384_DIGEST_SIZE, digest, &signature);
   1710 			mpz_clear(x);
   1711 			mpz_clear(y);
   1712 			nettle_ecc_point_clear(&pubkey);
   1713 			break;
   1714 		}
   1715 		default:
   1716 			return "unknown ECDSA algorithm";
   1717 	}
   1718 
   1719 	/* Clear and return */
   1720 	nettle_dsa_signature_clear(&signature);
   1721 	if (!res)
   1722 		return "ECDSA signature verification failed";
   1723 	else
   1724 		return NULL;
   1725 }
   1726 #endif
   1727 
   1728 #ifdef USE_ED25519
   1729 static char *
   1730 _verify_nettle_ed25519(sldns_buffer* buf, unsigned char* sigblock,
   1731 	unsigned int sigblock_len, unsigned char* key, unsigned int keylen)
   1732 {
   1733 	int res = 0;
   1734 
   1735 	if(sigblock_len != ED25519_SIGNATURE_SIZE) {
   1736 		return "wrong ED25519 signature length";
   1737 	}
   1738 	if(keylen != ED25519_KEY_SIZE) {
   1739 		return "wrong ED25519 key length";
   1740 	}
   1741 
   1742 	res = ed25519_sha512_verify((uint8_t*)key, sldns_buffer_limit(buf),
   1743 		sldns_buffer_begin(buf), (uint8_t*)sigblock);
   1744 
   1745 	if (!res)
   1746 		return "ED25519 signature verification failed";
   1747 	else
   1748 		return NULL;
   1749 }
   1750 #endif
   1751 
   1752 /**
   1753  * Check a canonical sig+rrset and signature against a dnskey
   1754  * @param buf: buffer with data to verify, the first rrsig part and the
   1755  *	canonicalized rrset.
   1756  * @param algo: DNSKEY algorithm.
   1757  * @param sigblock: signature rdata field from RRSIG
   1758  * @param sigblock_len: length of sigblock data.
   1759  * @param key: public key data from DNSKEY RR.
   1760  * @param keylen: length of keydata.
   1761  * @param reason: bogus reason in more detail.
   1762  * @return secure if verification succeeded, bogus on crypto failure,
   1763  *	unchecked on format errors and alloc failures.
   1764  */
   1765 enum sec_status
   1766 verify_canonrrset(sldns_buffer* buf, int algo, unsigned char* sigblock,
   1767 	unsigned int sigblock_len, unsigned char* key, unsigned int keylen,
   1768 	char** reason)
   1769 {
   1770 	unsigned int digest_size = 0;
   1771 
   1772 	if (sigblock_len == 0 || keylen == 0) {
   1773 		*reason = "null signature";
   1774 		return sec_status_bogus;
   1775 	}
   1776 
   1777 	switch(algo) {
   1778 #if defined(USE_DSA) && defined(USE_SHA1)
   1779 	case LDNS_DSA:
   1780 	case LDNS_DSA_NSEC3:
   1781 		*reason = _verify_nettle_dsa(buf, sigblock, sigblock_len, key, keylen);
   1782 		if (*reason != NULL)
   1783 			return sec_status_bogus;
   1784 		else
   1785 			return sec_status_secure;
   1786 #endif /* USE_DSA */
   1787 
   1788 #ifdef USE_SHA1
   1789 	case LDNS_RSASHA1:
   1790 	case LDNS_RSASHA1_NSEC3:
   1791 		digest_size = (digest_size ? digest_size : SHA1_DIGEST_SIZE);
   1792 #endif
   1793 		/* double fallthrough annotation to please gcc parser */
   1794 		/* fallthrough */
   1795 #ifdef USE_SHA2
   1796 		/* fallthrough */
   1797 	case LDNS_RSASHA256:
   1798 		digest_size = (digest_size ? digest_size : SHA256_DIGEST_SIZE);
   1799 		/* fallthrough */
   1800 	case LDNS_RSASHA512:
   1801 		digest_size = (digest_size ? digest_size : SHA512_DIGEST_SIZE);
   1802 
   1803 #endif
   1804 		*reason = _verify_nettle_rsa(buf, digest_size, (char*)sigblock,
   1805 						sigblock_len, key, keylen);
   1806 		if (*reason != NULL)
   1807 			return sec_status_bogus;
   1808 		else
   1809 			return sec_status_secure;
   1810 
   1811 #ifdef USE_ECDSA
   1812 	case LDNS_ECDSAP256SHA256:
   1813 		digest_size = (digest_size ? digest_size : SHA256_DIGEST_SIZE);
   1814 		/* fallthrough */
   1815 	case LDNS_ECDSAP384SHA384:
   1816 		digest_size = (digest_size ? digest_size : SHA384_DIGEST_SIZE);
   1817 		*reason = _verify_nettle_ecdsa(buf, digest_size, sigblock,
   1818 						sigblock_len, key, keylen);
   1819 		if (*reason != NULL)
   1820 			return sec_status_bogus;
   1821 		else
   1822 			return sec_status_secure;
   1823 #endif
   1824 #ifdef USE_ED25519
   1825 	case LDNS_ED25519:
   1826 		*reason = _verify_nettle_ed25519(buf, sigblock, sigblock_len,
   1827 			key, keylen);
   1828 		if (*reason != NULL)
   1829 			return sec_status_bogus;
   1830 		else
   1831 			return sec_status_secure;
   1832 #endif
   1833 	case LDNS_RSAMD5:
   1834 	case LDNS_ECC_GOST:
   1835 	default:
   1836 		*reason = "unable to verify signature, unknown algorithm";
   1837 		return sec_status_bogus;
   1838 	}
   1839 }
   1840 
   1841 #endif /* HAVE_SSL or HAVE_NSS or HAVE_NETTLE */
   1842