xref: /minix3/external/bsd/bind/dist/lib/dns/rdata/generic/cdnskey_60.c (revision 00b67f09dd46474d133c95011a48590a8e8f94c7)
1*00b67f09SDavid van Moolenbroek /*	$NetBSD: cdnskey_60.c,v 1.1.1.4 2015/07/08 15:38:03 christos Exp $	*/
2*00b67f09SDavid van Moolenbroek 
3*00b67f09SDavid van Moolenbroek /*
4*00b67f09SDavid van Moolenbroek  * Copyright (C) 2014, 2015  Internet Systems Consortium, Inc. ("ISC")
5*00b67f09SDavid van Moolenbroek  *
6*00b67f09SDavid van Moolenbroek  * Permission to use, copy, modify, and/or distribute this software for any
7*00b67f09SDavid van Moolenbroek  * purpose with or without fee is hereby granted, provided that the above
8*00b67f09SDavid van Moolenbroek  * copyright notice and this permission notice appear in all copies.
9*00b67f09SDavid van Moolenbroek  *
10*00b67f09SDavid van Moolenbroek  * THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES WITH
11*00b67f09SDavid van Moolenbroek  * REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
12*00b67f09SDavid van Moolenbroek  * AND FITNESS.  IN NO EVENT SHALL ISC BE LIABLE FOR ANY SPECIAL, DIRECT,
13*00b67f09SDavid van Moolenbroek  * INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
14*00b67f09SDavid van Moolenbroek  * LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE
15*00b67f09SDavid van Moolenbroek  * OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
16*00b67f09SDavid van Moolenbroek  * PERFORMANCE OF THIS SOFTWARE.
17*00b67f09SDavid van Moolenbroek  */
18*00b67f09SDavid van Moolenbroek 
19*00b67f09SDavid van Moolenbroek /* draft-ietf-dnsop-delegation-trust-maintainance-14 */
20*00b67f09SDavid van Moolenbroek 
21*00b67f09SDavid van Moolenbroek #ifndef RDATA_GENERIC_CDNSKEY_60_C
22*00b67f09SDavid van Moolenbroek #define RDATA_GENERIC_CDNSKEY_60_C
23*00b67f09SDavid van Moolenbroek 
24*00b67f09SDavid van Moolenbroek #include <dst/dst.h>
25*00b67f09SDavid van Moolenbroek 
26*00b67f09SDavid van Moolenbroek #define RRTYPE_CDNSKEY_ATTRIBUTES 0
27*00b67f09SDavid van Moolenbroek 
28*00b67f09SDavid van Moolenbroek static inline isc_result_t
fromtext_cdnskey(ARGS_FROMTEXT)29*00b67f09SDavid van Moolenbroek fromtext_cdnskey(ARGS_FROMTEXT) {
30*00b67f09SDavid van Moolenbroek 	isc_result_t result;
31*00b67f09SDavid van Moolenbroek 	isc_token_t token;
32*00b67f09SDavid van Moolenbroek 	dns_secalg_t alg;
33*00b67f09SDavid van Moolenbroek 	dns_secproto_t proto;
34*00b67f09SDavid van Moolenbroek 	dns_keyflags_t flags;
35*00b67f09SDavid van Moolenbroek 
36*00b67f09SDavid van Moolenbroek 	REQUIRE(type == 60);
37*00b67f09SDavid van Moolenbroek 
38*00b67f09SDavid van Moolenbroek 	UNUSED(type);
39*00b67f09SDavid van Moolenbroek 	UNUSED(rdclass);
40*00b67f09SDavid van Moolenbroek 	UNUSED(origin);
41*00b67f09SDavid van Moolenbroek 	UNUSED(options);
42*00b67f09SDavid van Moolenbroek 	UNUSED(callbacks);
43*00b67f09SDavid van Moolenbroek 
44*00b67f09SDavid van Moolenbroek 	/* flags */
45*00b67f09SDavid van Moolenbroek 	RETERR(isc_lex_getmastertoken(lexer, &token, isc_tokentype_string,
46*00b67f09SDavid van Moolenbroek 				      ISC_FALSE));
47*00b67f09SDavid van Moolenbroek 	RETTOK(dns_keyflags_fromtext(&flags, &token.value.as_textregion));
48*00b67f09SDavid van Moolenbroek 	RETERR(uint16_tobuffer(flags, target));
49*00b67f09SDavid van Moolenbroek 
50*00b67f09SDavid van Moolenbroek 	/* protocol */
51*00b67f09SDavid van Moolenbroek 	RETERR(isc_lex_getmastertoken(lexer, &token, isc_tokentype_string,
52*00b67f09SDavid van Moolenbroek 				      ISC_FALSE));
53*00b67f09SDavid van Moolenbroek 	RETTOK(dns_secproto_fromtext(&proto, &token.value.as_textregion));
54*00b67f09SDavid van Moolenbroek 	RETERR(mem_tobuffer(target, &proto, 1));
55*00b67f09SDavid van Moolenbroek 
56*00b67f09SDavid van Moolenbroek 	/* algorithm */
57*00b67f09SDavid van Moolenbroek 	RETERR(isc_lex_getmastertoken(lexer, &token, isc_tokentype_string,
58*00b67f09SDavid van Moolenbroek 				      ISC_FALSE));
59*00b67f09SDavid van Moolenbroek 	RETTOK(dns_secalg_fromtext(&alg, &token.value.as_textregion));
60*00b67f09SDavid van Moolenbroek 	RETERR(mem_tobuffer(target, &alg, 1));
61*00b67f09SDavid van Moolenbroek 
62*00b67f09SDavid van Moolenbroek 	/* No Key? */
63*00b67f09SDavid van Moolenbroek 	if ((flags & 0xc000) == 0xc000)
64*00b67f09SDavid van Moolenbroek 		return (ISC_R_SUCCESS);
65*00b67f09SDavid van Moolenbroek 
66*00b67f09SDavid van Moolenbroek 	result = isc_base64_tobuffer(lexer, target, -1);
67*00b67f09SDavid van Moolenbroek 	if (result != ISC_R_SUCCESS)
68*00b67f09SDavid van Moolenbroek 		return (result);
69*00b67f09SDavid van Moolenbroek 
70*00b67f09SDavid van Moolenbroek 	/* Ensure there's at least enough data to compute a key ID for MD5 */
71*00b67f09SDavid van Moolenbroek 	if (alg == DST_ALG_RSAMD5 && isc_buffer_usedlength(target) < 7)
72*00b67f09SDavid van Moolenbroek 		return (ISC_R_UNEXPECTEDEND);
73*00b67f09SDavid van Moolenbroek 
74*00b67f09SDavid van Moolenbroek 	return (ISC_R_SUCCESS);
75*00b67f09SDavid van Moolenbroek }
76*00b67f09SDavid van Moolenbroek 
77*00b67f09SDavid van Moolenbroek static inline isc_result_t
totext_cdnskey(ARGS_TOTEXT)78*00b67f09SDavid van Moolenbroek totext_cdnskey(ARGS_TOTEXT) {
79*00b67f09SDavid van Moolenbroek 	isc_region_t sr;
80*00b67f09SDavid van Moolenbroek 	char buf[sizeof("[key id = 64000]")];
81*00b67f09SDavid van Moolenbroek 	unsigned int flags;
82*00b67f09SDavid van Moolenbroek 	unsigned char algorithm;
83*00b67f09SDavid van Moolenbroek 	char algbuf[DNS_NAME_FORMATSIZE];
84*00b67f09SDavid van Moolenbroek 	const char *keyinfo;
85*00b67f09SDavid van Moolenbroek 	isc_region_t tmpr;
86*00b67f09SDavid van Moolenbroek 
87*00b67f09SDavid van Moolenbroek 	REQUIRE(rdata->type == 60);
88*00b67f09SDavid van Moolenbroek 	REQUIRE(rdata->length != 0);
89*00b67f09SDavid van Moolenbroek 
90*00b67f09SDavid van Moolenbroek 	dns_rdata_toregion(rdata, &sr);
91*00b67f09SDavid van Moolenbroek 
92*00b67f09SDavid van Moolenbroek 	/* flags */
93*00b67f09SDavid van Moolenbroek 	flags = uint16_fromregion(&sr);
94*00b67f09SDavid van Moolenbroek 	isc_region_consume(&sr, 2);
95*00b67f09SDavid van Moolenbroek 	sprintf(buf, "%u", flags);
96*00b67f09SDavid van Moolenbroek 	RETERR(str_totext(buf, target));
97*00b67f09SDavid van Moolenbroek 	RETERR(str_totext(" ", target));
98*00b67f09SDavid van Moolenbroek 	if ((flags & DNS_KEYFLAG_KSK) != 0) {
99*00b67f09SDavid van Moolenbroek 		if (flags & DNS_KEYFLAG_REVOKE)
100*00b67f09SDavid van Moolenbroek 			keyinfo = "revoked KSK";
101*00b67f09SDavid van Moolenbroek 		else
102*00b67f09SDavid van Moolenbroek 			keyinfo = "KSK";
103*00b67f09SDavid van Moolenbroek 	} else
104*00b67f09SDavid van Moolenbroek 		keyinfo = "ZSK";
105*00b67f09SDavid van Moolenbroek 
106*00b67f09SDavid van Moolenbroek 	/* protocol */
107*00b67f09SDavid van Moolenbroek 	sprintf(buf, "%u", sr.base[0]);
108*00b67f09SDavid van Moolenbroek 	isc_region_consume(&sr, 1);
109*00b67f09SDavid van Moolenbroek 	RETERR(str_totext(buf, target));
110*00b67f09SDavid van Moolenbroek 	RETERR(str_totext(" ", target));
111*00b67f09SDavid van Moolenbroek 
112*00b67f09SDavid van Moolenbroek 	/* algorithm */
113*00b67f09SDavid van Moolenbroek 	algorithm = sr.base[0];
114*00b67f09SDavid van Moolenbroek 	sprintf(buf, "%u", algorithm);
115*00b67f09SDavid van Moolenbroek 	isc_region_consume(&sr, 1);
116*00b67f09SDavid van Moolenbroek 	RETERR(str_totext(buf, target));
117*00b67f09SDavid van Moolenbroek 
118*00b67f09SDavid van Moolenbroek 	/* No Key? */
119*00b67f09SDavid van Moolenbroek 	if ((flags & 0xc000) == 0xc000)
120*00b67f09SDavid van Moolenbroek 		return (ISC_R_SUCCESS);
121*00b67f09SDavid van Moolenbroek 
122*00b67f09SDavid van Moolenbroek 	if ((tctx->flags & DNS_STYLEFLAG_RRCOMMENT) != 0 &&
123*00b67f09SDavid van Moolenbroek 	     algorithm == DNS_KEYALG_PRIVATEDNS) {
124*00b67f09SDavid van Moolenbroek 		dns_name_t name;
125*00b67f09SDavid van Moolenbroek 		dns_name_init(&name, NULL);
126*00b67f09SDavid van Moolenbroek 		dns_name_fromregion(&name, &sr);
127*00b67f09SDavid van Moolenbroek 		dns_name_format(&name, algbuf, sizeof(algbuf));
128*00b67f09SDavid van Moolenbroek 	} else {
129*00b67f09SDavid van Moolenbroek 		dns_secalg_format((dns_secalg_t) algorithm, algbuf,
130*00b67f09SDavid van Moolenbroek 				  sizeof(algbuf));
131*00b67f09SDavid van Moolenbroek 	}
132*00b67f09SDavid van Moolenbroek 
133*00b67f09SDavid van Moolenbroek 	/* key */
134*00b67f09SDavid van Moolenbroek 	if ((tctx->flags & DNS_STYLEFLAG_MULTILINE) != 0)
135*00b67f09SDavid van Moolenbroek 		RETERR(str_totext(" (", target));
136*00b67f09SDavid van Moolenbroek 	RETERR(str_totext(tctx->linebreak, target));
137*00b67f09SDavid van Moolenbroek 
138*00b67f09SDavid van Moolenbroek 	if ((tctx->flags & DNS_STYLEFLAG_NOCRYPTO) == 0) {
139*00b67f09SDavid van Moolenbroek 		if (tctx->width == 0)   /* No splitting */
140*00b67f09SDavid van Moolenbroek 			RETERR(isc_base64_totext(&sr, 0, "", target));
141*00b67f09SDavid van Moolenbroek 		else
142*00b67f09SDavid van Moolenbroek 			RETERR(isc_base64_totext(&sr, tctx->width - 2,
143*00b67f09SDavid van Moolenbroek 						 tctx->linebreak, target));
144*00b67f09SDavid van Moolenbroek 	} else {
145*00b67f09SDavid van Moolenbroek 		dns_rdata_toregion(rdata, &tmpr);
146*00b67f09SDavid van Moolenbroek 		snprintf(buf, sizeof(buf), "[key id = %u]",
147*00b67f09SDavid van Moolenbroek 			 dst_region_computeid(&tmpr, algorithm));
148*00b67f09SDavid van Moolenbroek 		RETERR(str_totext(buf, target));
149*00b67f09SDavid van Moolenbroek 	}
150*00b67f09SDavid van Moolenbroek 
151*00b67f09SDavid van Moolenbroek 	if ((tctx->flags & DNS_STYLEFLAG_RRCOMMENT) != 0)
152*00b67f09SDavid van Moolenbroek 		RETERR(str_totext(tctx->linebreak, target));
153*00b67f09SDavid van Moolenbroek 	else if ((tctx->flags & DNS_STYLEFLAG_MULTILINE) != 0)
154*00b67f09SDavid van Moolenbroek 		RETERR(str_totext(" ", target));
155*00b67f09SDavid van Moolenbroek 
156*00b67f09SDavid van Moolenbroek 	if ((tctx->flags & DNS_STYLEFLAG_MULTILINE) != 0)
157*00b67f09SDavid van Moolenbroek 		RETERR(str_totext(")", target));
158*00b67f09SDavid van Moolenbroek 
159*00b67f09SDavid van Moolenbroek 	if ((tctx->flags & DNS_STYLEFLAG_RRCOMMENT) != 0) {
160*00b67f09SDavid van Moolenbroek 
161*00b67f09SDavid van Moolenbroek 		RETERR(str_totext(" ; ", target));
162*00b67f09SDavid van Moolenbroek 		RETERR(str_totext(keyinfo, target));
163*00b67f09SDavid van Moolenbroek 		RETERR(str_totext("; alg = ", target));
164*00b67f09SDavid van Moolenbroek 		RETERR(str_totext(algbuf, target));
165*00b67f09SDavid van Moolenbroek 		RETERR(str_totext("; key id = ", target));
166*00b67f09SDavid van Moolenbroek 		dns_rdata_toregion(rdata, &tmpr);
167*00b67f09SDavid van Moolenbroek 		sprintf(buf, "%u", dst_region_computeid(&tmpr, algorithm));
168*00b67f09SDavid van Moolenbroek 		RETERR(str_totext(buf, target));
169*00b67f09SDavid van Moolenbroek 	}
170*00b67f09SDavid van Moolenbroek 	return (ISC_R_SUCCESS);
171*00b67f09SDavid van Moolenbroek }
172*00b67f09SDavid van Moolenbroek 
173*00b67f09SDavid van Moolenbroek static inline isc_result_t
fromwire_cdnskey(ARGS_FROMWIRE)174*00b67f09SDavid van Moolenbroek fromwire_cdnskey(ARGS_FROMWIRE) {
175*00b67f09SDavid van Moolenbroek 	unsigned char algorithm;
176*00b67f09SDavid van Moolenbroek 	isc_region_t sr;
177*00b67f09SDavid van Moolenbroek 
178*00b67f09SDavid van Moolenbroek 	REQUIRE(type == 60);
179*00b67f09SDavid van Moolenbroek 
180*00b67f09SDavid van Moolenbroek 	UNUSED(type);
181*00b67f09SDavid van Moolenbroek 	UNUSED(rdclass);
182*00b67f09SDavid van Moolenbroek 	UNUSED(dctx);
183*00b67f09SDavid van Moolenbroek 	UNUSED(options);
184*00b67f09SDavid van Moolenbroek 
185*00b67f09SDavid van Moolenbroek 	isc_buffer_activeregion(source, &sr);
186*00b67f09SDavid van Moolenbroek 	if (sr.length < 4)
187*00b67f09SDavid van Moolenbroek 		return (ISC_R_UNEXPECTEDEND);
188*00b67f09SDavid van Moolenbroek 
189*00b67f09SDavid van Moolenbroek 	algorithm = sr.base[3];
190*00b67f09SDavid van Moolenbroek 	RETERR(mem_tobuffer(target, sr.base, 4));
191*00b67f09SDavid van Moolenbroek 	isc_region_consume(&sr, 4);
192*00b67f09SDavid van Moolenbroek 	isc_buffer_forward(source, 4);
193*00b67f09SDavid van Moolenbroek 
194*00b67f09SDavid van Moolenbroek 	if (algorithm == DNS_KEYALG_PRIVATEDNS) {
195*00b67f09SDavid van Moolenbroek 		dns_name_t name;
196*00b67f09SDavid van Moolenbroek 		dns_decompress_setmethods(dctx, DNS_COMPRESS_NONE);
197*00b67f09SDavid van Moolenbroek 		dns_name_init(&name, NULL);
198*00b67f09SDavid van Moolenbroek 		RETERR(dns_name_fromwire(&name, source, dctx, options, target));
199*00b67f09SDavid van Moolenbroek 	}
200*00b67f09SDavid van Moolenbroek 
201*00b67f09SDavid van Moolenbroek 	/*
202*00b67f09SDavid van Moolenbroek 	 * RSAMD5 computes key ID differently from other
203*00b67f09SDavid van Moolenbroek 	 * algorithms: we need to ensure there's enough data
204*00b67f09SDavid van Moolenbroek 	 * present for the computation
205*00b67f09SDavid van Moolenbroek 	 */
206*00b67f09SDavid van Moolenbroek 	if (algorithm == DST_ALG_RSAMD5 && sr.length < 3)
207*00b67f09SDavid van Moolenbroek 		return (ISC_R_UNEXPECTEDEND);
208*00b67f09SDavid van Moolenbroek 
209*00b67f09SDavid van Moolenbroek 	isc_buffer_activeregion(source, &sr);
210*00b67f09SDavid van Moolenbroek 	isc_buffer_forward(source, sr.length);
211*00b67f09SDavid van Moolenbroek 	return (mem_tobuffer(target, sr.base, sr.length));
212*00b67f09SDavid van Moolenbroek }
213*00b67f09SDavid van Moolenbroek 
214*00b67f09SDavid van Moolenbroek static inline isc_result_t
towire_cdnskey(ARGS_TOWIRE)215*00b67f09SDavid van Moolenbroek towire_cdnskey(ARGS_TOWIRE) {
216*00b67f09SDavid van Moolenbroek 	isc_region_t sr;
217*00b67f09SDavid van Moolenbroek 
218*00b67f09SDavid van Moolenbroek 	REQUIRE(rdata->type == 60);
219*00b67f09SDavid van Moolenbroek 	REQUIRE(rdata->length != 0);
220*00b67f09SDavid van Moolenbroek 
221*00b67f09SDavid van Moolenbroek 	UNUSED(cctx);
222*00b67f09SDavid van Moolenbroek 
223*00b67f09SDavid van Moolenbroek 	dns_rdata_toregion(rdata, &sr);
224*00b67f09SDavid van Moolenbroek 	return (mem_tobuffer(target, sr.base, sr.length));
225*00b67f09SDavid van Moolenbroek }
226*00b67f09SDavid van Moolenbroek 
227*00b67f09SDavid van Moolenbroek static inline int
compare_cdnskey(ARGS_COMPARE)228*00b67f09SDavid van Moolenbroek compare_cdnskey(ARGS_COMPARE) {
229*00b67f09SDavid van Moolenbroek 	isc_region_t r1;
230*00b67f09SDavid van Moolenbroek 	isc_region_t r2;
231*00b67f09SDavid van Moolenbroek 
232*00b67f09SDavid van Moolenbroek 	REQUIRE(rdata1->type == rdata2->type);
233*00b67f09SDavid van Moolenbroek 	REQUIRE(rdata1->rdclass == rdata2->rdclass);
234*00b67f09SDavid van Moolenbroek 	REQUIRE(rdata1->type == 60);
235*00b67f09SDavid van Moolenbroek 	REQUIRE(rdata1->length != 0);
236*00b67f09SDavid van Moolenbroek 	REQUIRE(rdata2->length != 0);
237*00b67f09SDavid van Moolenbroek 
238*00b67f09SDavid van Moolenbroek 	dns_rdata_toregion(rdata1, &r1);
239*00b67f09SDavid van Moolenbroek 	dns_rdata_toregion(rdata2, &r2);
240*00b67f09SDavid van Moolenbroek 	return (isc_region_compare(&r1, &r2));
241*00b67f09SDavid van Moolenbroek }
242*00b67f09SDavid van Moolenbroek 
243*00b67f09SDavid van Moolenbroek static inline isc_result_t
fromstruct_cdnskey(ARGS_FROMSTRUCT)244*00b67f09SDavid van Moolenbroek fromstruct_cdnskey(ARGS_FROMSTRUCT) {
245*00b67f09SDavid van Moolenbroek 	dns_rdata_cdnskey_t *dnskey = source;
246*00b67f09SDavid van Moolenbroek 
247*00b67f09SDavid van Moolenbroek 	REQUIRE(type == 60);
248*00b67f09SDavid van Moolenbroek 	REQUIRE(source != NULL);
249*00b67f09SDavid van Moolenbroek 	REQUIRE(dnskey->common.rdtype == type);
250*00b67f09SDavid van Moolenbroek 	REQUIRE(dnskey->common.rdclass == rdclass);
251*00b67f09SDavid van Moolenbroek 
252*00b67f09SDavid van Moolenbroek 	UNUSED(type);
253*00b67f09SDavid van Moolenbroek 	UNUSED(rdclass);
254*00b67f09SDavid van Moolenbroek 
255*00b67f09SDavid van Moolenbroek 	/* Flags */
256*00b67f09SDavid van Moolenbroek 	RETERR(uint16_tobuffer(dnskey->flags, target));
257*00b67f09SDavid van Moolenbroek 
258*00b67f09SDavid van Moolenbroek 	/* Protocol */
259*00b67f09SDavid van Moolenbroek 	RETERR(uint8_tobuffer(dnskey->protocol, target));
260*00b67f09SDavid van Moolenbroek 
261*00b67f09SDavid van Moolenbroek 	/* Algorithm */
262*00b67f09SDavid van Moolenbroek 	RETERR(uint8_tobuffer(dnskey->algorithm, target));
263*00b67f09SDavid van Moolenbroek 
264*00b67f09SDavid van Moolenbroek 	/* Data */
265*00b67f09SDavid van Moolenbroek 	return (mem_tobuffer(target, dnskey->data, dnskey->datalen));
266*00b67f09SDavid van Moolenbroek }
267*00b67f09SDavid van Moolenbroek 
268*00b67f09SDavid van Moolenbroek static inline isc_result_t
tostruct_cdnskey(ARGS_TOSTRUCT)269*00b67f09SDavid van Moolenbroek tostruct_cdnskey(ARGS_TOSTRUCT) {
270*00b67f09SDavid van Moolenbroek 	dns_rdata_cdnskey_t *dnskey = target;
271*00b67f09SDavid van Moolenbroek 	isc_region_t sr;
272*00b67f09SDavid van Moolenbroek 
273*00b67f09SDavid van Moolenbroek 	REQUIRE(rdata->type == 60);
274*00b67f09SDavid van Moolenbroek 	REQUIRE(target != NULL);
275*00b67f09SDavid van Moolenbroek 	REQUIRE(rdata->length != 0);
276*00b67f09SDavid van Moolenbroek 
277*00b67f09SDavid van Moolenbroek 	dnskey->common.rdclass = rdata->rdclass;
278*00b67f09SDavid van Moolenbroek 	dnskey->common.rdtype = rdata->type;
279*00b67f09SDavid van Moolenbroek 	ISC_LINK_INIT(&dnskey->common, link);
280*00b67f09SDavid van Moolenbroek 
281*00b67f09SDavid van Moolenbroek 	dns_rdata_toregion(rdata, &sr);
282*00b67f09SDavid van Moolenbroek 
283*00b67f09SDavid van Moolenbroek 	/* Flags */
284*00b67f09SDavid van Moolenbroek 	if (sr.length < 2)
285*00b67f09SDavid van Moolenbroek 		return (ISC_R_UNEXPECTEDEND);
286*00b67f09SDavid van Moolenbroek 	dnskey->flags = uint16_fromregion(&sr);
287*00b67f09SDavid van Moolenbroek 	isc_region_consume(&sr, 2);
288*00b67f09SDavid van Moolenbroek 
289*00b67f09SDavid van Moolenbroek 	/* Protocol */
290*00b67f09SDavid van Moolenbroek 	if (sr.length < 1)
291*00b67f09SDavid van Moolenbroek 		return (ISC_R_UNEXPECTEDEND);
292*00b67f09SDavid van Moolenbroek 	dnskey->protocol = uint8_fromregion(&sr);
293*00b67f09SDavid van Moolenbroek 	isc_region_consume(&sr, 1);
294*00b67f09SDavid van Moolenbroek 
295*00b67f09SDavid van Moolenbroek 	/* Algorithm */
296*00b67f09SDavid van Moolenbroek 	if (sr.length < 1)
297*00b67f09SDavid van Moolenbroek 		return (ISC_R_UNEXPECTEDEND);
298*00b67f09SDavid van Moolenbroek 	dnskey->algorithm = uint8_fromregion(&sr);
299*00b67f09SDavid van Moolenbroek 	isc_region_consume(&sr, 1);
300*00b67f09SDavid van Moolenbroek 
301*00b67f09SDavid van Moolenbroek 	/* Data */
302*00b67f09SDavid van Moolenbroek 	dnskey->datalen = sr.length;
303*00b67f09SDavid van Moolenbroek 	dnskey->data = mem_maybedup(mctx, sr.base, dnskey->datalen);
304*00b67f09SDavid van Moolenbroek 	if (dnskey->data == NULL)
305*00b67f09SDavid van Moolenbroek 		return (ISC_R_NOMEMORY);
306*00b67f09SDavid van Moolenbroek 
307*00b67f09SDavid van Moolenbroek 	dnskey->mctx = mctx;
308*00b67f09SDavid van Moolenbroek 	return (ISC_R_SUCCESS);
309*00b67f09SDavid van Moolenbroek }
310*00b67f09SDavid van Moolenbroek 
311*00b67f09SDavid van Moolenbroek static inline void
freestruct_cdnskey(ARGS_FREESTRUCT)312*00b67f09SDavid van Moolenbroek freestruct_cdnskey(ARGS_FREESTRUCT) {
313*00b67f09SDavid van Moolenbroek 	dns_rdata_cdnskey_t *dnskey = (dns_rdata_cdnskey_t *) source;
314*00b67f09SDavid van Moolenbroek 
315*00b67f09SDavid van Moolenbroek 	REQUIRE(source != NULL);
316*00b67f09SDavid van Moolenbroek 	REQUIRE(dnskey->common.rdtype == 60);
317*00b67f09SDavid van Moolenbroek 
318*00b67f09SDavid van Moolenbroek 	if (dnskey->mctx == NULL)
319*00b67f09SDavid van Moolenbroek 		return;
320*00b67f09SDavid van Moolenbroek 
321*00b67f09SDavid van Moolenbroek 	if (dnskey->data != NULL)
322*00b67f09SDavid van Moolenbroek 		isc_mem_free(dnskey->mctx, dnskey->data);
323*00b67f09SDavid van Moolenbroek 	dnskey->mctx = NULL;
324*00b67f09SDavid van Moolenbroek }
325*00b67f09SDavid van Moolenbroek 
326*00b67f09SDavid van Moolenbroek static inline isc_result_t
additionaldata_cdnskey(ARGS_ADDLDATA)327*00b67f09SDavid van Moolenbroek additionaldata_cdnskey(ARGS_ADDLDATA) {
328*00b67f09SDavid van Moolenbroek 	REQUIRE(rdata->type == 60);
329*00b67f09SDavid van Moolenbroek 
330*00b67f09SDavid van Moolenbroek 	UNUSED(rdata);
331*00b67f09SDavid van Moolenbroek 	UNUSED(add);
332*00b67f09SDavid van Moolenbroek 	UNUSED(arg);
333*00b67f09SDavid van Moolenbroek 
334*00b67f09SDavid van Moolenbroek 	return (ISC_R_SUCCESS);
335*00b67f09SDavid van Moolenbroek }
336*00b67f09SDavid van Moolenbroek 
337*00b67f09SDavid van Moolenbroek static inline isc_result_t
digest_cdnskey(ARGS_DIGEST)338*00b67f09SDavid van Moolenbroek digest_cdnskey(ARGS_DIGEST) {
339*00b67f09SDavid van Moolenbroek 	isc_region_t r;
340*00b67f09SDavid van Moolenbroek 
341*00b67f09SDavid van Moolenbroek 	REQUIRE(rdata->type == 60);
342*00b67f09SDavid van Moolenbroek 
343*00b67f09SDavid van Moolenbroek 	dns_rdata_toregion(rdata, &r);
344*00b67f09SDavid van Moolenbroek 
345*00b67f09SDavid van Moolenbroek 	return ((digest)(arg, &r));
346*00b67f09SDavid van Moolenbroek }
347*00b67f09SDavid van Moolenbroek 
348*00b67f09SDavid van Moolenbroek static inline isc_boolean_t
checkowner_cdnskey(ARGS_CHECKOWNER)349*00b67f09SDavid van Moolenbroek checkowner_cdnskey(ARGS_CHECKOWNER) {
350*00b67f09SDavid van Moolenbroek 
351*00b67f09SDavid van Moolenbroek 	REQUIRE(type == 60);
352*00b67f09SDavid van Moolenbroek 
353*00b67f09SDavid van Moolenbroek 	UNUSED(name);
354*00b67f09SDavid van Moolenbroek 	UNUSED(type);
355*00b67f09SDavid van Moolenbroek 	UNUSED(rdclass);
356*00b67f09SDavid van Moolenbroek 	UNUSED(wildcard);
357*00b67f09SDavid van Moolenbroek 
358*00b67f09SDavid van Moolenbroek 	return (ISC_TRUE);
359*00b67f09SDavid van Moolenbroek }
360*00b67f09SDavid van Moolenbroek 
361*00b67f09SDavid van Moolenbroek static inline isc_boolean_t
checknames_cdnskey(ARGS_CHECKNAMES)362*00b67f09SDavid van Moolenbroek checknames_cdnskey(ARGS_CHECKNAMES) {
363*00b67f09SDavid van Moolenbroek 
364*00b67f09SDavid van Moolenbroek 	REQUIRE(rdata->type == 60);
365*00b67f09SDavid van Moolenbroek 
366*00b67f09SDavid van Moolenbroek 	UNUSED(rdata);
367*00b67f09SDavid van Moolenbroek 	UNUSED(owner);
368*00b67f09SDavid van Moolenbroek 	UNUSED(bad);
369*00b67f09SDavid van Moolenbroek 
370*00b67f09SDavid van Moolenbroek 	return (ISC_TRUE);
371*00b67f09SDavid van Moolenbroek }
372*00b67f09SDavid van Moolenbroek 
373*00b67f09SDavid van Moolenbroek static inline int
casecompare_cdnskey(ARGS_COMPARE)374*00b67f09SDavid van Moolenbroek casecompare_cdnskey(ARGS_COMPARE) {
375*00b67f09SDavid van Moolenbroek 
376*00b67f09SDavid van Moolenbroek 	/*
377*00b67f09SDavid van Moolenbroek 	 * Treat ALG 253 (private DNS) subtype name case sensistively.
378*00b67f09SDavid van Moolenbroek 	 */
379*00b67f09SDavid van Moolenbroek 	return (compare_cdnskey(rdata1, rdata2));
380*00b67f09SDavid van Moolenbroek }
381*00b67f09SDavid van Moolenbroek 
382*00b67f09SDavid van Moolenbroek #endif	/* RDATA_GENERIC_CDNSKEY_60_C */
383