mirror of
https://github.com/isc-projects/bind9.git
synced 2026-02-28 12:31:29 -05:00
The three functions has been modeled after the arc4random family of functions, and they will always return random bytes. The isc_random family of functions internally use these CSPRNG (if available): 1. getrandom() libc call (might be available on Linux and Solaris) 2. SYS_getrandom syscall (might be available on Linux, detected at runtime) 3. arc4random(), arc4random_buf() and arc4random_uniform() (available on BSDs and Mac OS X) 4. crypto library function: 4a. RAND_bytes in case OpenSSL 4b. pkcs_C_GenerateRandom() in case PKCS#11 library
35 lines
896 B
C
35 lines
896 B
C
/*
|
|
* Copyright (C) Internet Systems Consortium, Inc. ("ISC")
|
|
*
|
|
* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
*
|
|
* See the COPYRIGHT file distributed with this work for additional
|
|
* information regarding copyright ownership.
|
|
*/
|
|
|
|
|
|
#ifndef RNDC_KEYGEN_H
|
|
#define RNDC_KEYGEN_H 1
|
|
|
|
/*! \file */
|
|
|
|
#include <isc/lang.h>
|
|
|
|
ISC_LANG_BEGINDECLS
|
|
|
|
void generate_key(isc_mem_t *mctx, dns_secalg_t alg, int keysize,
|
|
isc_buffer_t *key_txtbuffer);
|
|
|
|
void write_key_file(const char *keyfile, const char *user,
|
|
const char *keyname, isc_buffer_t *secret,
|
|
dns_secalg_t alg);
|
|
|
|
const char *alg_totext(dns_secalg_t alg);
|
|
dns_secalg_t alg_fromtext(const char *name);
|
|
int alg_bits(dns_secalg_t alg);
|
|
|
|
ISC_LANG_ENDDECLS
|
|
|
|
#endif /* RNDC_KEYGEN_H */
|