1*00b67f09SDavid van Moolenbroek /*	$NetBSD: tlsa_52.c,v 1.1.1.4 2014/12/10 03:34:42 christos Exp $	*/
2*00b67f09SDavid van Moolenbroek 
3*00b67f09SDavid van Moolenbroek /*
4*00b67f09SDavid van Moolenbroek  * Copyright (C) 2012, 2014  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 /* Id */
20*00b67f09SDavid van Moolenbroek 
21*00b67f09SDavid van Moolenbroek /* rfc6698.txt */
22*00b67f09SDavid van Moolenbroek 
23*00b67f09SDavid van Moolenbroek #ifndef RDATA_GENERIC_TLSA_52_C
24*00b67f09SDavid van Moolenbroek #define RDATA_GENERIC_TLSA_52_C
25*00b67f09SDavid van Moolenbroek 
26*00b67f09SDavid van Moolenbroek #define RRTYPE_TLSA_ATTRIBUTES 0
27*00b67f09SDavid van Moolenbroek 
28*00b67f09SDavid van Moolenbroek static inline isc_result_t
fromtext_tlsa(ARGS_FROMTEXT)29*00b67f09SDavid van Moolenbroek fromtext_tlsa(ARGS_FROMTEXT) {
30*00b67f09SDavid van Moolenbroek 	isc_token_t token;
31*00b67f09SDavid van Moolenbroek 
32*00b67f09SDavid van Moolenbroek 	REQUIRE(type == 52);
33*00b67f09SDavid van Moolenbroek 
34*00b67f09SDavid van Moolenbroek 	UNUSED(type);
35*00b67f09SDavid van Moolenbroek 	UNUSED(rdclass);
36*00b67f09SDavid van Moolenbroek 	UNUSED(origin);
37*00b67f09SDavid van Moolenbroek 	UNUSED(options);
38*00b67f09SDavid van Moolenbroek 	UNUSED(callbacks);
39*00b67f09SDavid van Moolenbroek 
40*00b67f09SDavid van Moolenbroek 	/*
41*00b67f09SDavid van Moolenbroek 	 * Certificate Usage.
42*00b67f09SDavid van Moolenbroek 	 */
43*00b67f09SDavid van Moolenbroek 	RETERR(isc_lex_getmastertoken(lexer, &token, isc_tokentype_number,
44*00b67f09SDavid van Moolenbroek 				      ISC_FALSE));
45*00b67f09SDavid van Moolenbroek 	if (token.value.as_ulong > 0xffU)
46*00b67f09SDavid van Moolenbroek 		RETTOK(ISC_R_RANGE);
47*00b67f09SDavid van Moolenbroek 	RETERR(uint8_tobuffer(token.value.as_ulong, target));
48*00b67f09SDavid van Moolenbroek 
49*00b67f09SDavid van Moolenbroek 	/*
50*00b67f09SDavid van Moolenbroek 	 * Selector.
51*00b67f09SDavid van Moolenbroek 	 */
52*00b67f09SDavid van Moolenbroek 	RETERR(isc_lex_getmastertoken(lexer, &token, isc_tokentype_number,
53*00b67f09SDavid van Moolenbroek 				      ISC_FALSE));
54*00b67f09SDavid van Moolenbroek 	if (token.value.as_ulong > 0xffU)
55*00b67f09SDavid van Moolenbroek 		RETTOK(ISC_R_RANGE);
56*00b67f09SDavid van Moolenbroek 	RETERR(uint8_tobuffer(token.value.as_ulong, target));
57*00b67f09SDavid van Moolenbroek 
58*00b67f09SDavid van Moolenbroek 	/*
59*00b67f09SDavid van Moolenbroek 	 * Matching type.
60*00b67f09SDavid van Moolenbroek 	 */
61*00b67f09SDavid van Moolenbroek 	RETERR(isc_lex_getmastertoken(lexer, &token, isc_tokentype_number,
62*00b67f09SDavid van Moolenbroek 				      ISC_FALSE));
63*00b67f09SDavid van Moolenbroek 	if (token.value.as_ulong > 0xffU)
64*00b67f09SDavid van Moolenbroek 		RETTOK(ISC_R_RANGE);
65*00b67f09SDavid van Moolenbroek 	RETERR(uint8_tobuffer(token.value.as_ulong, target));
66*00b67f09SDavid van Moolenbroek 
67*00b67f09SDavid van Moolenbroek 	/*
68*00b67f09SDavid van Moolenbroek 	 * Certificate Association Data.
69*00b67f09SDavid van Moolenbroek 	 */
70*00b67f09SDavid van Moolenbroek 	return (isc_hex_tobuffer(lexer, target, -1));
71*00b67f09SDavid van Moolenbroek }
72*00b67f09SDavid van Moolenbroek 
73*00b67f09SDavid van Moolenbroek static inline isc_result_t
totext_tlsa(ARGS_TOTEXT)74*00b67f09SDavid van Moolenbroek totext_tlsa(ARGS_TOTEXT) {
75*00b67f09SDavid van Moolenbroek 	isc_region_t sr;
76*00b67f09SDavid van Moolenbroek 	char buf[sizeof("64000 ")];
77*00b67f09SDavid van Moolenbroek 	unsigned int n;
78*00b67f09SDavid van Moolenbroek 
79*00b67f09SDavid van Moolenbroek 	REQUIRE(rdata->type == 52);
80*00b67f09SDavid van Moolenbroek 	REQUIRE(rdata->length != 0);
81*00b67f09SDavid van Moolenbroek 
82*00b67f09SDavid van Moolenbroek 	UNUSED(tctx);
83*00b67f09SDavid van Moolenbroek 
84*00b67f09SDavid van Moolenbroek 	dns_rdata_toregion(rdata, &sr);
85*00b67f09SDavid van Moolenbroek 
86*00b67f09SDavid van Moolenbroek 	/*
87*00b67f09SDavid van Moolenbroek 	 * Certificate Usage.
88*00b67f09SDavid van Moolenbroek 	 */
89*00b67f09SDavid van Moolenbroek 	n = uint8_fromregion(&sr);
90*00b67f09SDavid van Moolenbroek 	isc_region_consume(&sr, 1);
91*00b67f09SDavid van Moolenbroek 	sprintf(buf, "%u ", n);
92*00b67f09SDavid van Moolenbroek 	RETERR(str_totext(buf, target));
93*00b67f09SDavid van Moolenbroek 
94*00b67f09SDavid van Moolenbroek 	/*
95*00b67f09SDavid van Moolenbroek 	 * Selector.
96*00b67f09SDavid van Moolenbroek 	 */
97*00b67f09SDavid van Moolenbroek 	n = uint8_fromregion(&sr);
98*00b67f09SDavid van Moolenbroek 	isc_region_consume(&sr, 1);
99*00b67f09SDavid van Moolenbroek 	sprintf(buf, "%u ", n);
100*00b67f09SDavid van Moolenbroek 	RETERR(str_totext(buf, target));
101*00b67f09SDavid van Moolenbroek 
102*00b67f09SDavid van Moolenbroek 	/*
103*00b67f09SDavid van Moolenbroek 	 * Matching type.
104*00b67f09SDavid van Moolenbroek 	 */
105*00b67f09SDavid van Moolenbroek 	n = uint8_fromregion(&sr);
106*00b67f09SDavid van Moolenbroek 	isc_region_consume(&sr, 1);
107*00b67f09SDavid van Moolenbroek 	sprintf(buf, "%u", n);
108*00b67f09SDavid van Moolenbroek 	RETERR(str_totext(buf, target));
109*00b67f09SDavid van Moolenbroek 
110*00b67f09SDavid van Moolenbroek 	/*
111*00b67f09SDavid van Moolenbroek 	 * Certificate Association Data.
112*00b67f09SDavid van Moolenbroek 	 */
113*00b67f09SDavid van Moolenbroek 	if ((tctx->flags & DNS_STYLEFLAG_MULTILINE) != 0)
114*00b67f09SDavid van Moolenbroek 		RETERR(str_totext(" (", target));
115*00b67f09SDavid van Moolenbroek 	RETERR(str_totext(tctx->linebreak, target));
116*00b67f09SDavid van Moolenbroek 	if (tctx->width == 0) /* No splitting */
117*00b67f09SDavid van Moolenbroek 		RETERR(isc_hex_totext(&sr, 0, "", target));
118*00b67f09SDavid van Moolenbroek 	else
119*00b67f09SDavid van Moolenbroek 		RETERR(isc_hex_totext(&sr, tctx->width - 2,
120*00b67f09SDavid van Moolenbroek 				      tctx->linebreak, target));
121*00b67f09SDavid van Moolenbroek 	if ((tctx->flags & DNS_STYLEFLAG_MULTILINE) != 0)
122*00b67f09SDavid van Moolenbroek 		RETERR(str_totext(" )", target));
123*00b67f09SDavid van Moolenbroek 	return (ISC_R_SUCCESS);
124*00b67f09SDavid van Moolenbroek }
125*00b67f09SDavid van Moolenbroek 
126*00b67f09SDavid van Moolenbroek static inline isc_result_t
fromwire_tlsa(ARGS_FROMWIRE)127*00b67f09SDavid van Moolenbroek fromwire_tlsa(ARGS_FROMWIRE) {
128*00b67f09SDavid van Moolenbroek 	isc_region_t sr;
129*00b67f09SDavid van Moolenbroek 
130*00b67f09SDavid van Moolenbroek 	REQUIRE(type == 52);
131*00b67f09SDavid van Moolenbroek 
132*00b67f09SDavid van Moolenbroek 	UNUSED(type);
133*00b67f09SDavid van Moolenbroek 	UNUSED(rdclass);
134*00b67f09SDavid van Moolenbroek 	UNUSED(dctx);
135*00b67f09SDavid van Moolenbroek 	UNUSED(options);
136*00b67f09SDavid van Moolenbroek 
137*00b67f09SDavid van Moolenbroek 	isc_buffer_activeregion(source, &sr);
138*00b67f09SDavid van Moolenbroek 
139*00b67f09SDavid van Moolenbroek 	if (sr.length < 3)
140*00b67f09SDavid van Moolenbroek 		return (ISC_R_UNEXPECTEDEND);
141*00b67f09SDavid van Moolenbroek 
142*00b67f09SDavid van Moolenbroek 	isc_buffer_forward(source, sr.length);
143*00b67f09SDavid van Moolenbroek 	return (mem_tobuffer(target, sr.base, sr.length));
144*00b67f09SDavid van Moolenbroek }
145*00b67f09SDavid van Moolenbroek 
146*00b67f09SDavid van Moolenbroek static inline isc_result_t
towire_tlsa(ARGS_TOWIRE)147*00b67f09SDavid van Moolenbroek towire_tlsa(ARGS_TOWIRE) {
148*00b67f09SDavid van Moolenbroek 	isc_region_t sr;
149*00b67f09SDavid van Moolenbroek 
150*00b67f09SDavid van Moolenbroek 	REQUIRE(rdata->type == 52);
151*00b67f09SDavid van Moolenbroek 	REQUIRE(rdata->length != 0);
152*00b67f09SDavid van Moolenbroek 
153*00b67f09SDavid van Moolenbroek 	UNUSED(cctx);
154*00b67f09SDavid van Moolenbroek 
155*00b67f09SDavid van Moolenbroek 	dns_rdata_toregion(rdata, &sr);
156*00b67f09SDavid van Moolenbroek 	return (mem_tobuffer(target, sr.base, sr.length));
157*00b67f09SDavid van Moolenbroek }
158*00b67f09SDavid van Moolenbroek 
159*00b67f09SDavid van Moolenbroek static inline int
compare_tlsa(ARGS_COMPARE)160*00b67f09SDavid van Moolenbroek compare_tlsa(ARGS_COMPARE) {
161*00b67f09SDavid van Moolenbroek 	isc_region_t r1;
162*00b67f09SDavid van Moolenbroek 	isc_region_t r2;
163*00b67f09SDavid van Moolenbroek 
164*00b67f09SDavid van Moolenbroek 	REQUIRE(rdata1->type == rdata2->type);
165*00b67f09SDavid van Moolenbroek 	REQUIRE(rdata1->rdclass == rdata2->rdclass);
166*00b67f09SDavid van Moolenbroek 	REQUIRE(rdata1->type == 52);
167*00b67f09SDavid van Moolenbroek 	REQUIRE(rdata1->length != 0);
168*00b67f09SDavid van Moolenbroek 	REQUIRE(rdata2->length != 0);
169*00b67f09SDavid van Moolenbroek 
170*00b67f09SDavid van Moolenbroek 	dns_rdata_toregion(rdata1, &r1);
171*00b67f09SDavid van Moolenbroek 	dns_rdata_toregion(rdata2, &r2);
172*00b67f09SDavid van Moolenbroek 	return (isc_region_compare(&r1, &r2));
173*00b67f09SDavid van Moolenbroek }
174*00b67f09SDavid van Moolenbroek 
175*00b67f09SDavid van Moolenbroek static inline isc_result_t
fromstruct_tlsa(ARGS_FROMSTRUCT)176*00b67f09SDavid van Moolenbroek fromstruct_tlsa(ARGS_FROMSTRUCT) {
177*00b67f09SDavid van Moolenbroek 	dns_rdata_tlsa_t *tlsa = source;
178*00b67f09SDavid van Moolenbroek 
179*00b67f09SDavid van Moolenbroek 	REQUIRE(type == 52);
180*00b67f09SDavid van Moolenbroek 	REQUIRE(source != NULL);
181*00b67f09SDavid van Moolenbroek 	REQUIRE(tlsa->common.rdtype == type);
182*00b67f09SDavid van Moolenbroek 	REQUIRE(tlsa->common.rdclass == rdclass);
183*00b67f09SDavid van Moolenbroek 
184*00b67f09SDavid van Moolenbroek 	UNUSED(type);
185*00b67f09SDavid van Moolenbroek 	UNUSED(rdclass);
186*00b67f09SDavid van Moolenbroek 
187*00b67f09SDavid van Moolenbroek 	RETERR(uint8_tobuffer(tlsa->usage, target));
188*00b67f09SDavid van Moolenbroek 	RETERR(uint8_tobuffer(tlsa->selector, target));
189*00b67f09SDavid van Moolenbroek 	RETERR(uint8_tobuffer(tlsa->match, target));
190*00b67f09SDavid van Moolenbroek 
191*00b67f09SDavid van Moolenbroek 	return (mem_tobuffer(target, tlsa->data, tlsa->length));
192*00b67f09SDavid van Moolenbroek }
193*00b67f09SDavid van Moolenbroek 
194*00b67f09SDavid van Moolenbroek static inline isc_result_t
tostruct_tlsa(ARGS_TOSTRUCT)195*00b67f09SDavid van Moolenbroek tostruct_tlsa(ARGS_TOSTRUCT) {
196*00b67f09SDavid van Moolenbroek 	dns_rdata_tlsa_t *tlsa = target;
197*00b67f09SDavid van Moolenbroek 	isc_region_t region;
198*00b67f09SDavid van Moolenbroek 
199*00b67f09SDavid van Moolenbroek 	REQUIRE(rdata->type == 52);
200*00b67f09SDavid van Moolenbroek 	REQUIRE(target != NULL);
201*00b67f09SDavid van Moolenbroek 	REQUIRE(rdata->length != 0);
202*00b67f09SDavid van Moolenbroek 
203*00b67f09SDavid van Moolenbroek 	tlsa->common.rdclass = rdata->rdclass;
204*00b67f09SDavid van Moolenbroek 	tlsa->common.rdtype = rdata->type;
205*00b67f09SDavid van Moolenbroek 	ISC_LINK_INIT(&tlsa->common, link);
206*00b67f09SDavid van Moolenbroek 
207*00b67f09SDavid van Moolenbroek 	dns_rdata_toregion(rdata, &region);
208*00b67f09SDavid van Moolenbroek 
209*00b67f09SDavid van Moolenbroek 	tlsa->usage = uint8_fromregion(&region);
210*00b67f09SDavid van Moolenbroek 	isc_region_consume(&region, 1);
211*00b67f09SDavid van Moolenbroek 	tlsa->selector = uint8_fromregion(&region);
212*00b67f09SDavid van Moolenbroek 	isc_region_consume(&region, 1);
213*00b67f09SDavid van Moolenbroek 	tlsa->match = uint8_fromregion(&region);
214*00b67f09SDavid van Moolenbroek 	isc_region_consume(&region, 1);
215*00b67f09SDavid van Moolenbroek 	tlsa->length = region.length;
216*00b67f09SDavid van Moolenbroek 
217*00b67f09SDavid van Moolenbroek 	tlsa->data = mem_maybedup(mctx, region.base, region.length);
218*00b67f09SDavid van Moolenbroek 	if (tlsa->data == NULL)
219*00b67f09SDavid van Moolenbroek 		return (ISC_R_NOMEMORY);
220*00b67f09SDavid van Moolenbroek 
221*00b67f09SDavid van Moolenbroek 	tlsa->mctx = mctx;
222*00b67f09SDavid van Moolenbroek 	return (ISC_R_SUCCESS);
223*00b67f09SDavid van Moolenbroek }
224*00b67f09SDavid van Moolenbroek 
225*00b67f09SDavid van Moolenbroek static inline void
freestruct_tlsa(ARGS_FREESTRUCT)226*00b67f09SDavid van Moolenbroek freestruct_tlsa(ARGS_FREESTRUCT) {
227*00b67f09SDavid van Moolenbroek 	dns_rdata_tlsa_t *tlsa = source;
228*00b67f09SDavid van Moolenbroek 
229*00b67f09SDavid van Moolenbroek 	REQUIRE(tlsa != NULL);
230*00b67f09SDavid van Moolenbroek 	REQUIRE(tlsa->common.rdtype == 52);
231*00b67f09SDavid van Moolenbroek 
232*00b67f09SDavid van Moolenbroek 	if (tlsa->mctx == NULL)
233*00b67f09SDavid van Moolenbroek 		return;
234*00b67f09SDavid van Moolenbroek 
235*00b67f09SDavid van Moolenbroek 	if (tlsa->data != NULL)
236*00b67f09SDavid van Moolenbroek 		isc_mem_free(tlsa->mctx, tlsa->data);
237*00b67f09SDavid van Moolenbroek 	tlsa->mctx = NULL;
238*00b67f09SDavid van Moolenbroek }
239*00b67f09SDavid van Moolenbroek 
240*00b67f09SDavid van Moolenbroek static inline isc_result_t
additionaldata_tlsa(ARGS_ADDLDATA)241*00b67f09SDavid van Moolenbroek additionaldata_tlsa(ARGS_ADDLDATA) {
242*00b67f09SDavid van Moolenbroek 	REQUIRE(rdata->type == 52);
243*00b67f09SDavid van Moolenbroek 
244*00b67f09SDavid van Moolenbroek 	UNUSED(rdata);
245*00b67f09SDavid van Moolenbroek 	UNUSED(add);
246*00b67f09SDavid van Moolenbroek 	UNUSED(arg);
247*00b67f09SDavid van Moolenbroek 
248*00b67f09SDavid van Moolenbroek 	return (ISC_R_SUCCESS);
249*00b67f09SDavid van Moolenbroek }
250*00b67f09SDavid van Moolenbroek 
251*00b67f09SDavid van Moolenbroek static inline isc_result_t
digest_tlsa(ARGS_DIGEST)252*00b67f09SDavid van Moolenbroek digest_tlsa(ARGS_DIGEST) {
253*00b67f09SDavid van Moolenbroek 	isc_region_t r;
254*00b67f09SDavid van Moolenbroek 
255*00b67f09SDavid van Moolenbroek 	REQUIRE(rdata->type == 52);
256*00b67f09SDavid van Moolenbroek 
257*00b67f09SDavid van Moolenbroek 	dns_rdata_toregion(rdata, &r);
258*00b67f09SDavid van Moolenbroek 
259*00b67f09SDavid van Moolenbroek 	return ((digest)(arg, &r));
260*00b67f09SDavid van Moolenbroek }
261*00b67f09SDavid van Moolenbroek 
262*00b67f09SDavid van Moolenbroek static inline isc_boolean_t
checkowner_tlsa(ARGS_CHECKOWNER)263*00b67f09SDavid van Moolenbroek checkowner_tlsa(ARGS_CHECKOWNER) {
264*00b67f09SDavid van Moolenbroek 
265*00b67f09SDavid van Moolenbroek 	REQUIRE(type == 52);
266*00b67f09SDavid van Moolenbroek 
267*00b67f09SDavid van Moolenbroek 	UNUSED(name);
268*00b67f09SDavid van Moolenbroek 	UNUSED(type);
269*00b67f09SDavid van Moolenbroek 	UNUSED(rdclass);
270*00b67f09SDavid van Moolenbroek 	UNUSED(wildcard);
271*00b67f09SDavid van Moolenbroek 
272*00b67f09SDavid van Moolenbroek 	return (ISC_TRUE);
273*00b67f09SDavid van Moolenbroek }
274*00b67f09SDavid van Moolenbroek 
275*00b67f09SDavid van Moolenbroek static inline isc_boolean_t
checknames_tlsa(ARGS_CHECKNAMES)276*00b67f09SDavid van Moolenbroek checknames_tlsa(ARGS_CHECKNAMES) {
277*00b67f09SDavid van Moolenbroek 
278*00b67f09SDavid van Moolenbroek 	REQUIRE(rdata->type == 52);
279*00b67f09SDavid van Moolenbroek 
280*00b67f09SDavid van Moolenbroek 	UNUSED(rdata);
281*00b67f09SDavid van Moolenbroek 	UNUSED(owner);
282*00b67f09SDavid van Moolenbroek 	UNUSED(bad);
283*00b67f09SDavid van Moolenbroek 
284*00b67f09SDavid van Moolenbroek 	return (ISC_TRUE);
285*00b67f09SDavid van Moolenbroek }
286*00b67f09SDavid van Moolenbroek 
287*00b67f09SDavid van Moolenbroek static inline int
casecompare_tlsa(ARGS_COMPARE)288*00b67f09SDavid van Moolenbroek casecompare_tlsa(ARGS_COMPARE) {
289*00b67f09SDavid van Moolenbroek 	return (compare_tlsa(rdata1, rdata2));
290*00b67f09SDavid van Moolenbroek }
291*00b67f09SDavid van Moolenbroek 
292*00b67f09SDavid van Moolenbroek #endif	/* RDATA_GENERIC_TLSA_52_C */
293