1999-07-12 16:08:42 -04:00
|
|
|
/*
|
2018-03-15 21:32:45 -04:00
|
|
|
* Portions Copyright (C) Internet Systems Consortium, Inc. ("ISC")
|
2007-06-18 19:47:57 -04:00
|
|
|
*
|
2016-06-27 00:56:38 -04:00
|
|
|
* 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
|
2020-09-14 19:50:58 -04:00
|
|
|
* file, you can obtain one at https://mozilla.org/MPL/2.0/.
|
2007-06-18 19:47:57 -04:00
|
|
|
*
|
2018-02-23 03:53:12 -05:00
|
|
|
* See the COPYRIGHT file distributed with this work for additional
|
|
|
|
|
* information regarding copyright ownership.
|
|
|
|
|
*
|
|
|
|
|
* Portions Copyright (C) Network Associates, Inc.
|
2000-07-31 21:33:37 -04:00
|
|
|
*
|
2007-08-28 03:20:43 -04:00
|
|
|
* Permission to use, copy, modify, and/or distribute this software for any
|
1999-07-12 16:08:42 -04:00
|
|
|
* purpose with or without fee is hereby granted, provided that the above
|
|
|
|
|
* copyright notice and this permission notice appear in all copies.
|
2000-07-31 21:33:37 -04:00
|
|
|
*
|
2004-03-05 00:14:21 -05:00
|
|
|
* THE SOFTWARE IS PROVIDED "AS IS" AND ISC AND NETWORK ASSOCIATES DISCLAIMS
|
|
|
|
|
* ALL WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
|
|
|
|
|
* WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL ISC BE LIABLE
|
|
|
|
|
* FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
|
|
|
|
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
|
|
|
|
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR
|
|
|
|
|
* IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
1999-07-12 16:08:42 -04:00
|
|
|
*/
|
2000-06-21 18:38:33 -04:00
|
|
|
|
2005-04-27 00:57:32 -04:00
|
|
|
/*! \file */
|
2000-04-28 22:02:38 -04:00
|
|
|
#ifndef DST_DST_PARSE_H
|
|
|
|
|
#define DST_DST_PARSE_H 1
|
|
|
|
|
|
1999-07-12 16:08:42 -04:00
|
|
|
#include <isc/lang.h>
|
|
|
|
|
|
2000-05-08 10:38:29 -04:00
|
|
|
#include <dst/dst.h>
|
1999-07-12 16:08:42 -04:00
|
|
|
|
2020-02-12 09:33:32 -05:00
|
|
|
#define MAXFIELDSIZE 512
|
2009-07-19 00:18:05 -04:00
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Maximum number of fields in a private file is 18 (12 algorithm-
|
|
|
|
|
* specific fields for RSA, plus 6 generic fields).
|
|
|
|
|
*/
|
2020-02-12 09:33:32 -05:00
|
|
|
#define MAXFIELDS 12 + 6
|
1999-07-12 16:08:42 -04:00
|
|
|
|
2020-02-14 00:35:17 -05:00
|
|
|
#define TAG_SHIFT 4
|
|
|
|
|
#define TAG_ALG(tag) ((unsigned int)(tag) >> TAG_SHIFT)
|
2020-02-12 09:33:32 -05:00
|
|
|
#define TAG(alg, off) (((alg) << TAG_SHIFT) + (off))
|
1999-07-12 16:08:42 -04:00
|
|
|
|
2018-10-25 04:27:49 -04:00
|
|
|
/* These are used by RSA-SHA1, RSASHA256 and RSASHA512 */
|
2020-02-14 00:35:17 -05:00
|
|
|
#define RSA_NTAGS 11
|
|
|
|
|
#define TAG_RSA_MODULUS ((DST_ALG_RSA << TAG_SHIFT) + 0)
|
|
|
|
|
#define TAG_RSA_PUBLICEXPONENT ((DST_ALG_RSA << TAG_SHIFT) + 1)
|
2020-02-12 09:33:32 -05:00
|
|
|
#define TAG_RSA_PRIVATEEXPONENT ((DST_ALG_RSA << TAG_SHIFT) + 2)
|
2020-02-14 00:35:17 -05:00
|
|
|
#define TAG_RSA_PRIME1 ((DST_ALG_RSA << TAG_SHIFT) + 3)
|
|
|
|
|
#define TAG_RSA_PRIME2 ((DST_ALG_RSA << TAG_SHIFT) + 4)
|
|
|
|
|
#define TAG_RSA_EXPONENT1 ((DST_ALG_RSA << TAG_SHIFT) + 5)
|
|
|
|
|
#define TAG_RSA_EXPONENT2 ((DST_ALG_RSA << TAG_SHIFT) + 6)
|
|
|
|
|
#define TAG_RSA_COEFFICIENT ((DST_ALG_RSA << TAG_SHIFT) + 7)
|
|
|
|
|
#define TAG_RSA_ENGINE ((DST_ALG_RSA << TAG_SHIFT) + 8)
|
|
|
|
|
#define TAG_RSA_LABEL ((DST_ALG_RSA << TAG_SHIFT) + 9)
|
|
|
|
|
|
|
|
|
|
#define DH_NTAGS 4
|
|
|
|
|
#define TAG_DH_PRIME ((DST_ALG_DH << TAG_SHIFT) + 0)
|
2020-02-12 09:33:32 -05:00
|
|
|
#define TAG_DH_GENERATOR ((DST_ALG_DH << TAG_SHIFT) + 1)
|
2020-02-14 00:35:17 -05:00
|
|
|
#define TAG_DH_PRIVATE ((DST_ALG_DH << TAG_SHIFT) + 2)
|
|
|
|
|
#define TAG_DH_PUBLIC ((DST_ALG_DH << TAG_SHIFT) + 3)
|
2020-02-12 09:33:32 -05:00
|
|
|
|
2020-02-14 00:35:17 -05:00
|
|
|
#define ECDSA_NTAGS 4
|
2020-02-12 09:33:32 -05:00
|
|
|
#define TAG_ECDSA_PRIVATEKEY ((DST_ALG_ECDSA256 << TAG_SHIFT) + 0)
|
2020-02-14 00:35:17 -05:00
|
|
|
#define TAG_ECDSA_ENGINE ((DST_ALG_ECDSA256 << TAG_SHIFT) + 1)
|
|
|
|
|
#define TAG_ECDSA_LABEL ((DST_ALG_ECDSA256 << TAG_SHIFT) + 2)
|
2020-02-12 09:33:32 -05:00
|
|
|
|
2020-02-14 00:35:17 -05:00
|
|
|
#define EDDSA_NTAGS 4
|
2020-02-12 09:33:32 -05:00
|
|
|
#define TAG_EDDSA_PRIVATEKEY ((DST_ALG_ED25519 << TAG_SHIFT) + 0)
|
2020-02-14 00:35:17 -05:00
|
|
|
#define TAG_EDDSA_ENGINE ((DST_ALG_ED25519 << TAG_SHIFT) + 1)
|
|
|
|
|
#define TAG_EDDSA_LABEL ((DST_ALG_ED25519 << TAG_SHIFT) + 2)
|
2020-02-12 09:33:32 -05:00
|
|
|
|
|
|
|
|
#define OLD_HMACMD5_NTAGS 1
|
2020-02-14 00:35:17 -05:00
|
|
|
#define HMACMD5_NTAGS 2
|
|
|
|
|
#define TAG_HMACMD5_KEY ((DST_ALG_HMACMD5 << TAG_SHIFT) + 0)
|
|
|
|
|
#define TAG_HMACMD5_BITS ((DST_ALG_HMACMD5 << TAG_SHIFT) + 1)
|
2020-02-12 09:33:32 -05:00
|
|
|
|
2020-02-14 00:35:17 -05:00
|
|
|
#define HMACSHA1_NTAGS 2
|
|
|
|
|
#define TAG_HMACSHA1_KEY ((DST_ALG_HMACSHA1 << TAG_SHIFT) + 0)
|
2020-02-12 09:33:32 -05:00
|
|
|
#define TAG_HMACSHA1_BITS ((DST_ALG_HMACSHA1 << TAG_SHIFT) + 1)
|
|
|
|
|
|
2020-02-14 00:35:17 -05:00
|
|
|
#define HMACSHA224_NTAGS 2
|
|
|
|
|
#define TAG_HMACSHA224_KEY ((DST_ALG_HMACSHA224 << TAG_SHIFT) + 0)
|
2020-02-12 09:33:32 -05:00
|
|
|
#define TAG_HMACSHA224_BITS ((DST_ALG_HMACSHA224 << TAG_SHIFT) + 1)
|
|
|
|
|
|
2020-02-14 00:35:17 -05:00
|
|
|
#define HMACSHA256_NTAGS 2
|
|
|
|
|
#define TAG_HMACSHA256_KEY ((DST_ALG_HMACSHA256 << TAG_SHIFT) + 0)
|
2020-02-12 09:33:32 -05:00
|
|
|
#define TAG_HMACSHA256_BITS ((DST_ALG_HMACSHA256 << TAG_SHIFT) + 1)
|
|
|
|
|
|
2020-02-14 00:35:17 -05:00
|
|
|
#define HMACSHA384_NTAGS 2
|
|
|
|
|
#define TAG_HMACSHA384_KEY ((DST_ALG_HMACSHA384 << TAG_SHIFT) + 0)
|
2020-02-12 09:33:32 -05:00
|
|
|
#define TAG_HMACSHA384_BITS ((DST_ALG_HMACSHA384 << TAG_SHIFT) + 1)
|
|
|
|
|
|
2020-02-14 00:35:17 -05:00
|
|
|
#define HMACSHA512_NTAGS 2
|
|
|
|
|
#define TAG_HMACSHA512_KEY ((DST_ALG_HMACSHA512 << TAG_SHIFT) + 0)
|
2020-02-12 09:33:32 -05:00
|
|
|
#define TAG_HMACSHA512_BITS ((DST_ALG_HMACSHA512 << TAG_SHIFT) + 1)
|
1999-07-12 16:08:42 -04:00
|
|
|
|
|
|
|
|
struct dst_private_element {
|
|
|
|
|
unsigned short tag;
|
|
|
|
|
unsigned short length;
|
|
|
|
|
unsigned char *data;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
typedef struct dst_private_element dst_private_element_t;
|
|
|
|
|
|
|
|
|
|
struct dst_private {
|
2020-02-14 03:45:45 -05:00
|
|
|
unsigned short nelements;
|
1999-07-12 16:08:42 -04:00
|
|
|
dst_private_element_t elements[MAXFIELDS];
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
typedef struct dst_private dst_private_t;
|
|
|
|
|
|
2000-05-08 10:38:29 -04:00
|
|
|
ISC_LANG_BEGINDECLS
|
|
|
|
|
|
|
|
|
|
void
|
2000-06-02 19:36:14 -04:00
|
|
|
dst__privstruct_free(dst_private_t *priv, isc_mem_t *mctx);
|
2000-05-08 10:38:29 -04:00
|
|
|
|
2009-09-02 02:29:01 -04:00
|
|
|
isc_result_t
|
2002-02-27 17:12:06 -05:00
|
|
|
dst__privstruct_parse(dst_key_t *key, unsigned int alg, isc_lex_t *lex,
|
|
|
|
|
isc_mem_t *mctx, dst_private_t *priv);
|
2000-05-08 10:38:29 -04:00
|
|
|
|
2009-09-02 02:29:01 -04:00
|
|
|
isc_result_t
|
2000-06-06 17:58:16 -04:00
|
|
|
dst__privstruct_writefile(const dst_key_t *key, const dst_private_t *priv,
|
|
|
|
|
const char *directory);
|
1999-07-12 16:08:42 -04:00
|
|
|
|
|
|
|
|
ISC_LANG_ENDDECLS
|
|
|
|
|
|
2000-04-28 22:02:38 -04:00
|
|
|
#endif /* DST_DST_PARSE_H */
|