]> CyberLeo.Net >> Repos - FreeBSD/releng/9.2.git/blob - contrib/bind9/lib/dns/dst_parse.h
- Copy stable/9 to releng/9.2 as part of the 9.2-RELEASE cycle.
[FreeBSD/releng/9.2.git] / contrib / bind9 / lib / dns / dst_parse.h
1 /*
2  * Portions Copyright (C) 2004-2010, 2012  Internet Systems Consortium, Inc. ("ISC")
3  * Portions Copyright (C) 2000-2002  Internet Software Consortium.
4  *
5  * Permission to use, copy, modify, and/or distribute this software for any
6  * purpose with or without fee is hereby granted, provided that the above
7  * copyright notice and this permission notice appear in all copies.
8  *
9  * THE SOFTWARE IS PROVIDED "AS IS" AND ISC AND NETWORK ASSOCIATES DISCLAIMS
10  * ALL WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
11  * WARRANTIES OF MERCHANTABILITY AND FITNESS.  IN NO EVENT SHALL ISC BE LIABLE
12  * FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
13  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
14  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR
15  * IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
16  *
17  * Portions Copyright (C) 1995-2000 by Network Associates, Inc.
18  *
19  * Permission to use, copy, modify, and/or distribute this software for any
20  * purpose with or without fee is hereby granted, provided that the above
21  * copyright notice and this permission notice appear in all copies.
22  *
23  * THE SOFTWARE IS PROVIDED "AS IS" AND ISC AND NETWORK ASSOCIATES DISCLAIMS
24  * ALL WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
25  * WARRANTIES OF MERCHANTABILITY AND FITNESS.  IN NO EVENT SHALL ISC BE LIABLE
26  * FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
27  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
28  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR
29  * IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
30  */
31
32 /* $Id: dst_parse.h,v 1.17 2010/12/23 23:47:08 tbox Exp $ */
33
34 /*! \file */
35 #ifndef DST_DST_PARSE_H
36 #define DST_DST_PARSE_H 1
37
38 #include <isc/lang.h>
39
40 #include <dst/dst.h>
41
42 #define MAXFIELDSIZE            512
43
44 /*
45  * Maximum number of fields in a private file is 18 (12 algorithm-
46  * specific fields for RSA, plus 6 generic fields).
47  */
48 #define MAXFIELDS               12+6
49
50 #define TAG_SHIFT               4
51 #define TAG_ALG(tag)            ((unsigned int)(tag) >> TAG_SHIFT)
52 #define TAG(alg, off)           (((alg) << TAG_SHIFT) + (off))
53
54 /* These are used by both RSA-MD5 and RSA-SHA1 */
55 #define RSA_NTAGS               11
56 #define TAG_RSA_MODULUS         ((DST_ALG_RSAMD5 << TAG_SHIFT) + 0)
57 #define TAG_RSA_PUBLICEXPONENT  ((DST_ALG_RSAMD5 << TAG_SHIFT) + 1)
58 #define TAG_RSA_PRIVATEEXPONENT ((DST_ALG_RSAMD5 << TAG_SHIFT) + 2)
59 #define TAG_RSA_PRIME1          ((DST_ALG_RSAMD5 << TAG_SHIFT) + 3)
60 #define TAG_RSA_PRIME2          ((DST_ALG_RSAMD5 << TAG_SHIFT) + 4)
61 #define TAG_RSA_EXPONENT1       ((DST_ALG_RSAMD5 << TAG_SHIFT) + 5)
62 #define TAG_RSA_EXPONENT2       ((DST_ALG_RSAMD5 << TAG_SHIFT) + 6)
63 #define TAG_RSA_COEFFICIENT     ((DST_ALG_RSAMD5 << TAG_SHIFT) + 7)
64 #define TAG_RSA_ENGINE          ((DST_ALG_RSAMD5 << TAG_SHIFT) + 8)
65 #define TAG_RSA_LABEL           ((DST_ALG_RSAMD5 << TAG_SHIFT) + 9)
66 #define TAG_RSA_PIN             ((DST_ALG_RSAMD5 << TAG_SHIFT) + 10)
67
68 #define DH_NTAGS                4
69 #define TAG_DH_PRIME            ((DST_ALG_DH << TAG_SHIFT) + 0)
70 #define TAG_DH_GENERATOR        ((DST_ALG_DH << TAG_SHIFT) + 1)
71 #define TAG_DH_PRIVATE          ((DST_ALG_DH << TAG_SHIFT) + 2)
72 #define TAG_DH_PUBLIC           ((DST_ALG_DH << TAG_SHIFT) + 3)
73
74 #define DSA_NTAGS               5
75 #define TAG_DSA_PRIME           ((DST_ALG_DSA << TAG_SHIFT) + 0)
76 #define TAG_DSA_SUBPRIME        ((DST_ALG_DSA << TAG_SHIFT) + 1)
77 #define TAG_DSA_BASE            ((DST_ALG_DSA << TAG_SHIFT) + 2)
78 #define TAG_DSA_PRIVATE         ((DST_ALG_DSA << TAG_SHIFT) + 3)
79 #define TAG_DSA_PUBLIC          ((DST_ALG_DSA << TAG_SHIFT) + 4)
80
81 #define GOST_NTAGS              1
82 #define TAG_GOST_PRIVASN1       ((DST_ALG_ECCGOST << TAG_SHIFT) + 0)
83
84 #define ECDSA_NTAGS             1
85 #define TAG_ECDSA_PRIVATEKEY    ((DST_ALG_ECDSA256 << TAG_SHIFT) + 0)
86
87 #define OLD_HMACMD5_NTAGS       1
88 #define HMACMD5_NTAGS           2
89 #define TAG_HMACMD5_KEY         ((DST_ALG_HMACMD5 << TAG_SHIFT) + 0)
90 #define TAG_HMACMD5_BITS        ((DST_ALG_HMACMD5 << TAG_SHIFT) + 1)
91
92 #define HMACSHA1_NTAGS          2
93 #define TAG_HMACSHA1_KEY        ((DST_ALG_HMACSHA1 << TAG_SHIFT) + 0)
94 #define TAG_HMACSHA1_BITS       ((DST_ALG_HMACSHA1 << TAG_SHIFT) + 1)
95
96 #define HMACSHA224_NTAGS        2
97 #define TAG_HMACSHA224_KEY      ((DST_ALG_HMACSHA224 << TAG_SHIFT) + 0)
98 #define TAG_HMACSHA224_BITS     ((DST_ALG_HMACSHA224 << TAG_SHIFT) + 1)
99
100 #define HMACSHA256_NTAGS        2
101 #define TAG_HMACSHA256_KEY      ((DST_ALG_HMACSHA256 << TAG_SHIFT) + 0)
102 #define TAG_HMACSHA256_BITS     ((DST_ALG_HMACSHA256 << TAG_SHIFT) + 1)
103
104 #define HMACSHA384_NTAGS        2
105 #define TAG_HMACSHA384_KEY      ((DST_ALG_HMACSHA384 << TAG_SHIFT) + 0)
106 #define TAG_HMACSHA384_BITS     ((DST_ALG_HMACSHA384 << TAG_SHIFT) + 1)
107
108 #define HMACSHA512_NTAGS        2
109 #define TAG_HMACSHA512_KEY      ((DST_ALG_HMACSHA512 << TAG_SHIFT) + 0)
110 #define TAG_HMACSHA512_BITS     ((DST_ALG_HMACSHA512 << TAG_SHIFT) + 1)
111
112 struct dst_private_element {
113         unsigned short tag;
114         unsigned short length;
115         unsigned char *data;
116 };
117
118 typedef struct dst_private_element dst_private_element_t;
119
120 struct dst_private {
121         unsigned short nelements;
122         dst_private_element_t elements[MAXFIELDS];
123 };
124
125 typedef struct dst_private dst_private_t;
126
127 ISC_LANG_BEGINDECLS
128
129 void
130 dst__privstruct_free(dst_private_t *priv, isc_mem_t *mctx);
131
132 isc_result_t
133 dst__privstruct_parse(dst_key_t *key, unsigned int alg, isc_lex_t *lex,
134                       isc_mem_t *mctx, dst_private_t *priv);
135
136 isc_result_t
137 dst__privstruct_writefile(const dst_key_t *key, const dst_private_t *priv,
138                           const char *directory);
139
140 ISC_LANG_ENDDECLS
141
142 #endif /* DST_DST_PARSE_H */