xref: /minix3/external/bsd/bind/dist/lib/dns/rdata/generic/sig_24.c (revision 00b67f09dd46474d133c95011a48590a8e8f94c7)
1*00b67f09SDavid van Moolenbroek /*	$NetBSD: sig_24.c,v 1.6 2015/07/08 17:28:59 christos Exp $	*/
2*00b67f09SDavid van Moolenbroek 
3*00b67f09SDavid van Moolenbroek /*
4*00b67f09SDavid van Moolenbroek  * Copyright (C) 2004, 2005, 2007, 2009, 2011, 2012, 2015  Internet Systems Consortium, Inc. ("ISC")
5*00b67f09SDavid van Moolenbroek  * Copyright (C) 1999-2003  Internet Software Consortium.
6*00b67f09SDavid van Moolenbroek  *
7*00b67f09SDavid van Moolenbroek  * Permission to use, copy, modify, and/or distribute this software for any
8*00b67f09SDavid van Moolenbroek  * purpose with or without fee is hereby granted, provided that the above
9*00b67f09SDavid van Moolenbroek  * copyright notice and this permission notice appear in all copies.
10*00b67f09SDavid van Moolenbroek  *
11*00b67f09SDavid van Moolenbroek  * THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES WITH
12*00b67f09SDavid van Moolenbroek  * REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
13*00b67f09SDavid van Moolenbroek  * AND FITNESS.  IN NO EVENT SHALL ISC BE LIABLE FOR ANY SPECIAL, DIRECT,
14*00b67f09SDavid van Moolenbroek  * INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
15*00b67f09SDavid van Moolenbroek  * LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE
16*00b67f09SDavid van Moolenbroek  * OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
17*00b67f09SDavid van Moolenbroek  * PERFORMANCE OF THIS SOFTWARE.
18*00b67f09SDavid van Moolenbroek  */
19*00b67f09SDavid van Moolenbroek 
20*00b67f09SDavid van Moolenbroek /* Id */
21*00b67f09SDavid van Moolenbroek 
22*00b67f09SDavid van Moolenbroek /* Reviewed: Fri Mar 17 09:05:02 PST 2000 by gson */
23*00b67f09SDavid van Moolenbroek 
24*00b67f09SDavid van Moolenbroek /* RFC2535 */
25*00b67f09SDavid van Moolenbroek 
26*00b67f09SDavid van Moolenbroek #ifndef RDATA_GENERIC_SIG_24_C
27*00b67f09SDavid van Moolenbroek #define RDATA_GENERIC_SIG_24_C
28*00b67f09SDavid van Moolenbroek 
29*00b67f09SDavid van Moolenbroek #define RRTYPE_SIG_ATTRIBUTES (0)
30*00b67f09SDavid van Moolenbroek 
31*00b67f09SDavid van Moolenbroek static inline isc_result_t
fromtext_sig(ARGS_FROMTEXT)32*00b67f09SDavid van Moolenbroek fromtext_sig(ARGS_FROMTEXT) {
33*00b67f09SDavid van Moolenbroek 	isc_token_t token;
34*00b67f09SDavid van Moolenbroek 	unsigned char c;
35*00b67f09SDavid van Moolenbroek 	long i;
36*00b67f09SDavid van Moolenbroek 	dns_rdatatype_t covered;
37*00b67f09SDavid van Moolenbroek 	char *e;
38*00b67f09SDavid van Moolenbroek 	isc_result_t result;
39*00b67f09SDavid van Moolenbroek 	dns_name_t name;
40*00b67f09SDavid van Moolenbroek 	isc_buffer_t buffer;
41*00b67f09SDavid van Moolenbroek 	isc_uint32_t time_signed, time_expire;
42*00b67f09SDavid van Moolenbroek 
43*00b67f09SDavid van Moolenbroek 	REQUIRE(type == 24);
44*00b67f09SDavid van Moolenbroek 
45*00b67f09SDavid van Moolenbroek 	UNUSED(type);
46*00b67f09SDavid van Moolenbroek 	UNUSED(rdclass);
47*00b67f09SDavid van Moolenbroek 	UNUSED(callbacks);
48*00b67f09SDavid van Moolenbroek 
49*00b67f09SDavid van Moolenbroek 	/*
50*00b67f09SDavid van Moolenbroek 	 * Type covered.
51*00b67f09SDavid van Moolenbroek 	 */
52*00b67f09SDavid van Moolenbroek 	RETERR(isc_lex_getmastertoken(lexer, &token, isc_tokentype_string,
53*00b67f09SDavid van Moolenbroek 				      ISC_FALSE));
54*00b67f09SDavid van Moolenbroek 	result = dns_rdatatype_fromtext(&covered, &token.value.as_textregion);
55*00b67f09SDavid van Moolenbroek 	if (result != ISC_R_SUCCESS && result != ISC_R_NOTIMPLEMENTED) {
56*00b67f09SDavid van Moolenbroek 		i = strtol(DNS_AS_STR(token), &e, 10);
57*00b67f09SDavid van Moolenbroek 		if (i < 0 || i > 65535)
58*00b67f09SDavid van Moolenbroek 			RETTOK(ISC_R_RANGE);
59*00b67f09SDavid van Moolenbroek 		if (*e != 0)
60*00b67f09SDavid van Moolenbroek 			RETTOK(result);
61*00b67f09SDavid van Moolenbroek 		covered = (dns_rdatatype_t)i;
62*00b67f09SDavid van Moolenbroek 	}
63*00b67f09SDavid van Moolenbroek 	RETERR(uint16_tobuffer(covered, target));
64*00b67f09SDavid van Moolenbroek 
65*00b67f09SDavid van Moolenbroek 	/*
66*00b67f09SDavid van Moolenbroek 	 * Algorithm.
67*00b67f09SDavid van Moolenbroek 	 */
68*00b67f09SDavid van Moolenbroek 	RETERR(isc_lex_getmastertoken(lexer, &token, isc_tokentype_string,
69*00b67f09SDavid van Moolenbroek 				      ISC_FALSE));
70*00b67f09SDavid van Moolenbroek 	RETTOK(dns_secalg_fromtext(&c, &token.value.as_textregion));
71*00b67f09SDavid van Moolenbroek 	RETERR(mem_tobuffer(target, &c, 1));
72*00b67f09SDavid van Moolenbroek 
73*00b67f09SDavid van Moolenbroek 	/*
74*00b67f09SDavid van Moolenbroek 	 * Labels.
75*00b67f09SDavid van Moolenbroek 	 */
76*00b67f09SDavid van Moolenbroek 	RETERR(isc_lex_getmastertoken(lexer, &token, isc_tokentype_number,
77*00b67f09SDavid van Moolenbroek 				      ISC_FALSE));
78*00b67f09SDavid van Moolenbroek 	if (token.value.as_ulong > 0xffU)
79*00b67f09SDavid van Moolenbroek 		RETTOK(ISC_R_RANGE);
80*00b67f09SDavid van Moolenbroek 	c = (unsigned char)token.value.as_ulong;
81*00b67f09SDavid van Moolenbroek 	RETERR(mem_tobuffer(target, &c, 1));
82*00b67f09SDavid van Moolenbroek 
83*00b67f09SDavid van Moolenbroek 	/*
84*00b67f09SDavid van Moolenbroek 	 * Original ttl.
85*00b67f09SDavid van Moolenbroek 	 */
86*00b67f09SDavid van Moolenbroek 	RETERR(isc_lex_getmastertoken(lexer, &token, isc_tokentype_number,
87*00b67f09SDavid van Moolenbroek 				      ISC_FALSE));
88*00b67f09SDavid van Moolenbroek 	RETERR(uint32_tobuffer(token.value.as_ulong, target));
89*00b67f09SDavid van Moolenbroek 
90*00b67f09SDavid van Moolenbroek 	/*
91*00b67f09SDavid van Moolenbroek 	 * Signature expiration.
92*00b67f09SDavid van Moolenbroek 	 */
93*00b67f09SDavid van Moolenbroek 	RETERR(isc_lex_getmastertoken(lexer, &token, isc_tokentype_string,
94*00b67f09SDavid van Moolenbroek 				      ISC_FALSE));
95*00b67f09SDavid van Moolenbroek 	RETTOK(dns_time32_fromtext(DNS_AS_STR(token), &time_expire));
96*00b67f09SDavid van Moolenbroek 	RETERR(uint32_tobuffer(time_expire, target));
97*00b67f09SDavid van Moolenbroek 
98*00b67f09SDavid van Moolenbroek 	/*
99*00b67f09SDavid van Moolenbroek 	 * Time signed.
100*00b67f09SDavid van Moolenbroek 	 */
101*00b67f09SDavid van Moolenbroek 	RETERR(isc_lex_getmastertoken(lexer, &token, isc_tokentype_string,
102*00b67f09SDavid van Moolenbroek 				      ISC_FALSE));
103*00b67f09SDavid van Moolenbroek 	RETTOK(dns_time32_fromtext(DNS_AS_STR(token), &time_signed));
104*00b67f09SDavid van Moolenbroek 	RETERR(uint32_tobuffer(time_signed, target));
105*00b67f09SDavid van Moolenbroek 
106*00b67f09SDavid van Moolenbroek 	/*
107*00b67f09SDavid van Moolenbroek 	 * Key footprint.
108*00b67f09SDavid van Moolenbroek 	 */
109*00b67f09SDavid van Moolenbroek 	RETERR(isc_lex_getmastertoken(lexer, &token, isc_tokentype_number,
110*00b67f09SDavid van Moolenbroek 				      ISC_FALSE));
111*00b67f09SDavid van Moolenbroek 	RETERR(uint16_tobuffer(token.value.as_ulong, target));
112*00b67f09SDavid van Moolenbroek 
113*00b67f09SDavid van Moolenbroek 	/*
114*00b67f09SDavid van Moolenbroek 	 * Signer.
115*00b67f09SDavid van Moolenbroek 	 */
116*00b67f09SDavid van Moolenbroek 	RETERR(isc_lex_getmastertoken(lexer, &token, isc_tokentype_string,
117*00b67f09SDavid van Moolenbroek 				      ISC_FALSE));
118*00b67f09SDavid van Moolenbroek 	dns_name_init(&name, NULL);
119*00b67f09SDavid van Moolenbroek 	buffer_fromregion(&buffer, &token.value.as_region);
120*00b67f09SDavid van Moolenbroek 	origin = (origin != NULL) ? origin : dns_rootname;
121*00b67f09SDavid van Moolenbroek 	RETTOK(dns_name_fromtext(&name, &buffer, origin, options, target));
122*00b67f09SDavid van Moolenbroek 
123*00b67f09SDavid van Moolenbroek 	/*
124*00b67f09SDavid van Moolenbroek 	 * Sig.
125*00b67f09SDavid van Moolenbroek 	 */
126*00b67f09SDavid van Moolenbroek 	return (isc_base64_tobuffer(lexer, target, -1));
127*00b67f09SDavid van Moolenbroek }
128*00b67f09SDavid van Moolenbroek 
129*00b67f09SDavid van Moolenbroek static inline isc_result_t
totext_sig(ARGS_TOTEXT)130*00b67f09SDavid van Moolenbroek totext_sig(ARGS_TOTEXT) {
131*00b67f09SDavid van Moolenbroek 	isc_region_t sr;
132*00b67f09SDavid van Moolenbroek 	char buf[sizeof("4294967295")];
133*00b67f09SDavid van Moolenbroek 	dns_rdatatype_t covered;
134*00b67f09SDavid van Moolenbroek 	unsigned long ttl;
135*00b67f09SDavid van Moolenbroek 	unsigned long when;
136*00b67f09SDavid van Moolenbroek 	unsigned long exp;
137*00b67f09SDavid van Moolenbroek 	unsigned long foot;
138*00b67f09SDavid van Moolenbroek 	dns_name_t name;
139*00b67f09SDavid van Moolenbroek 	dns_name_t prefix;
140*00b67f09SDavid van Moolenbroek 	isc_boolean_t sub;
141*00b67f09SDavid van Moolenbroek 
142*00b67f09SDavid van Moolenbroek 	REQUIRE(rdata->type == 24);
143*00b67f09SDavid van Moolenbroek 	REQUIRE(rdata->length != 0);
144*00b67f09SDavid van Moolenbroek 
145*00b67f09SDavid van Moolenbroek 	dns_rdata_toregion(rdata, &sr);
146*00b67f09SDavid van Moolenbroek 
147*00b67f09SDavid van Moolenbroek 	/*
148*00b67f09SDavid van Moolenbroek 	 * Type covered.
149*00b67f09SDavid van Moolenbroek 	 */
150*00b67f09SDavid van Moolenbroek 	covered = uint16_fromregion(&sr);
151*00b67f09SDavid van Moolenbroek 	isc_region_consume(&sr, 2);
152*00b67f09SDavid van Moolenbroek 	/*
153*00b67f09SDavid van Moolenbroek 	 * XXXAG We should have something like dns_rdatatype_isknown()
154*00b67f09SDavid van Moolenbroek 	 * that does the right thing with type 0.
155*00b67f09SDavid van Moolenbroek 	 */
156*00b67f09SDavid van Moolenbroek 	if (dns_rdatatype_isknown(covered) && covered != 0) {
157*00b67f09SDavid van Moolenbroek 		RETERR(dns_rdatatype_totext(covered, target));
158*00b67f09SDavid van Moolenbroek 	} else {
159*00b67f09SDavid van Moolenbroek 		sprintf(buf, "%u", covered);
160*00b67f09SDavid van Moolenbroek 		RETERR(str_totext(buf, target));
161*00b67f09SDavid van Moolenbroek 	}
162*00b67f09SDavid van Moolenbroek 	RETERR(str_totext(" ", target));
163*00b67f09SDavid van Moolenbroek 
164*00b67f09SDavid van Moolenbroek 	/*
165*00b67f09SDavid van Moolenbroek 	 * Algorithm.
166*00b67f09SDavid van Moolenbroek 	 */
167*00b67f09SDavid van Moolenbroek 	sprintf(buf, "%u", sr.base[0]);
168*00b67f09SDavid van Moolenbroek 	isc_region_consume(&sr, 1);
169*00b67f09SDavid van Moolenbroek 	RETERR(str_totext(buf, target));
170*00b67f09SDavid van Moolenbroek 	RETERR(str_totext(" ", target));
171*00b67f09SDavid van Moolenbroek 
172*00b67f09SDavid van Moolenbroek 	/*
173*00b67f09SDavid van Moolenbroek 	 * Labels.
174*00b67f09SDavid van Moolenbroek 	 */
175*00b67f09SDavid van Moolenbroek 	sprintf(buf, "%u", sr.base[0]);
176*00b67f09SDavid van Moolenbroek 	isc_region_consume(&sr, 1);
177*00b67f09SDavid van Moolenbroek 	RETERR(str_totext(buf, target));
178*00b67f09SDavid van Moolenbroek 	RETERR(str_totext(" ", target));
179*00b67f09SDavid van Moolenbroek 
180*00b67f09SDavid van Moolenbroek 	/*
181*00b67f09SDavid van Moolenbroek 	 * Ttl.
182*00b67f09SDavid van Moolenbroek 	 */
183*00b67f09SDavid van Moolenbroek 	ttl = uint32_fromregion(&sr);
184*00b67f09SDavid van Moolenbroek 	isc_region_consume(&sr, 4);
185*00b67f09SDavid van Moolenbroek 	sprintf(buf, "%lu", ttl);
186*00b67f09SDavid van Moolenbroek 	RETERR(str_totext(buf, target));
187*00b67f09SDavid van Moolenbroek 	RETERR(str_totext(" ", target));
188*00b67f09SDavid van Moolenbroek 
189*00b67f09SDavid van Moolenbroek 	/*
190*00b67f09SDavid van Moolenbroek 	 * Sig exp.
191*00b67f09SDavid van Moolenbroek 	 */
192*00b67f09SDavid van Moolenbroek 	exp = uint32_fromregion(&sr);
193*00b67f09SDavid van Moolenbroek 	isc_region_consume(&sr, 4);
194*00b67f09SDavid van Moolenbroek 	RETERR(dns_time32_totext(exp, target));
195*00b67f09SDavid van Moolenbroek 
196*00b67f09SDavid van Moolenbroek 	if ((tctx->flags & DNS_STYLEFLAG_MULTILINE) != 0)
197*00b67f09SDavid van Moolenbroek 		RETERR(str_totext(" (", target));
198*00b67f09SDavid van Moolenbroek 	RETERR(str_totext(tctx->linebreak, target));
199*00b67f09SDavid van Moolenbroek 
200*00b67f09SDavid van Moolenbroek 	/*
201*00b67f09SDavid van Moolenbroek 	 * Time signed.
202*00b67f09SDavid van Moolenbroek 	 */
203*00b67f09SDavid van Moolenbroek 	when = uint32_fromregion(&sr);
204*00b67f09SDavid van Moolenbroek 	isc_region_consume(&sr, 4);
205*00b67f09SDavid van Moolenbroek 	RETERR(dns_time32_totext(when, target));
206*00b67f09SDavid van Moolenbroek 	RETERR(str_totext(" ", target));
207*00b67f09SDavid van Moolenbroek 
208*00b67f09SDavid van Moolenbroek 	/*
209*00b67f09SDavid van Moolenbroek 	 * Footprint.
210*00b67f09SDavid van Moolenbroek 	 */
211*00b67f09SDavid van Moolenbroek 	foot = uint16_fromregion(&sr);
212*00b67f09SDavid van Moolenbroek 	isc_region_consume(&sr, 2);
213*00b67f09SDavid van Moolenbroek 	sprintf(buf, "%lu", foot);
214*00b67f09SDavid van Moolenbroek 	RETERR(str_totext(buf, target));
215*00b67f09SDavid van Moolenbroek 	RETERR(str_totext(" ", target));
216*00b67f09SDavid van Moolenbroek 
217*00b67f09SDavid van Moolenbroek 	/*
218*00b67f09SDavid van Moolenbroek 	 * Signer.
219*00b67f09SDavid van Moolenbroek 	 */
220*00b67f09SDavid van Moolenbroek 	dns_name_init(&name, NULL);
221*00b67f09SDavid van Moolenbroek 	dns_name_init(&prefix, NULL);
222*00b67f09SDavid van Moolenbroek 	dns_name_fromregion(&name, &sr);
223*00b67f09SDavid van Moolenbroek 	isc_region_consume(&sr, name_length(&name));
224*00b67f09SDavid van Moolenbroek 	sub = name_prefix(&name, tctx->origin, &prefix);
225*00b67f09SDavid van Moolenbroek 	RETERR(dns_name_totext(&prefix, sub, target));
226*00b67f09SDavid van Moolenbroek 
227*00b67f09SDavid van Moolenbroek 	/*
228*00b67f09SDavid van Moolenbroek 	 * Sig.
229*00b67f09SDavid van Moolenbroek 	 */
230*00b67f09SDavid van Moolenbroek 	RETERR(str_totext(tctx->linebreak, target));
231*00b67f09SDavid van Moolenbroek 	if (tctx->width == 0)   /* No splitting */
232*00b67f09SDavid van Moolenbroek 		RETERR(isc_base64_totext(&sr, 60, "", target));
233*00b67f09SDavid van Moolenbroek 	else
234*00b67f09SDavid van Moolenbroek 		RETERR(isc_base64_totext(&sr, tctx->width - 2,
235*00b67f09SDavid van Moolenbroek 					 tctx->linebreak, target));
236*00b67f09SDavid van Moolenbroek 	if ((tctx->flags & DNS_STYLEFLAG_MULTILINE) != 0)
237*00b67f09SDavid van Moolenbroek 		RETERR(str_totext(" )", target));
238*00b67f09SDavid van Moolenbroek 
239*00b67f09SDavid van Moolenbroek 	return (ISC_R_SUCCESS);
240*00b67f09SDavid van Moolenbroek }
241*00b67f09SDavid van Moolenbroek 
242*00b67f09SDavid van Moolenbroek static inline isc_result_t
fromwire_sig(ARGS_FROMWIRE)243*00b67f09SDavid van Moolenbroek fromwire_sig(ARGS_FROMWIRE) {
244*00b67f09SDavid van Moolenbroek 	isc_region_t sr;
245*00b67f09SDavid van Moolenbroek 	dns_name_t name;
246*00b67f09SDavid van Moolenbroek 
247*00b67f09SDavid van Moolenbroek 	REQUIRE(type == 24);
248*00b67f09SDavid van Moolenbroek 
249*00b67f09SDavid van Moolenbroek 	UNUSED(type);
250*00b67f09SDavid van Moolenbroek 	UNUSED(rdclass);
251*00b67f09SDavid van Moolenbroek 
252*00b67f09SDavid van Moolenbroek 	dns_decompress_setmethods(dctx, DNS_COMPRESS_NONE);
253*00b67f09SDavid van Moolenbroek 
254*00b67f09SDavid van Moolenbroek 	isc_buffer_activeregion(source, &sr);
255*00b67f09SDavid van Moolenbroek 	/*
256*00b67f09SDavid van Moolenbroek 	 * type covered: 2
257*00b67f09SDavid van Moolenbroek 	 * algorithm: 1
258*00b67f09SDavid van Moolenbroek 	 * labels: 1
259*00b67f09SDavid van Moolenbroek 	 * original ttl: 4
260*00b67f09SDavid van Moolenbroek 	 * signature expiration: 4
261*00b67f09SDavid van Moolenbroek 	 * time signed: 4
262*00b67f09SDavid van Moolenbroek 	 * key footprint: 2
263*00b67f09SDavid van Moolenbroek 	 */
264*00b67f09SDavid van Moolenbroek 	if (sr.length < 18)
265*00b67f09SDavid van Moolenbroek 		return (ISC_R_UNEXPECTEDEND);
266*00b67f09SDavid van Moolenbroek 
267*00b67f09SDavid van Moolenbroek 	isc_buffer_forward(source, 18);
268*00b67f09SDavid van Moolenbroek 	RETERR(mem_tobuffer(target, sr.base, 18));
269*00b67f09SDavid van Moolenbroek 
270*00b67f09SDavid van Moolenbroek 	/*
271*00b67f09SDavid van Moolenbroek 	 * Signer.
272*00b67f09SDavid van Moolenbroek 	 */
273*00b67f09SDavid van Moolenbroek 	dns_name_init(&name, NULL);
274*00b67f09SDavid van Moolenbroek 	RETERR(dns_name_fromwire(&name, source, dctx, options, target));
275*00b67f09SDavid van Moolenbroek 
276*00b67f09SDavid van Moolenbroek 	/*
277*00b67f09SDavid van Moolenbroek 	 * Sig.
278*00b67f09SDavid van Moolenbroek 	 */
279*00b67f09SDavid van Moolenbroek 	isc_buffer_activeregion(source, &sr);
280*00b67f09SDavid van Moolenbroek 	isc_buffer_forward(source, sr.length);
281*00b67f09SDavid van Moolenbroek 	return (mem_tobuffer(target, sr.base, sr.length));
282*00b67f09SDavid van Moolenbroek }
283*00b67f09SDavid van Moolenbroek 
284*00b67f09SDavid van Moolenbroek static inline isc_result_t
towire_sig(ARGS_TOWIRE)285*00b67f09SDavid van Moolenbroek towire_sig(ARGS_TOWIRE) {
286*00b67f09SDavid van Moolenbroek 	isc_region_t sr;
287*00b67f09SDavid van Moolenbroek 	dns_name_t name;
288*00b67f09SDavid van Moolenbroek 	dns_offsets_t offsets;
289*00b67f09SDavid van Moolenbroek 
290*00b67f09SDavid van Moolenbroek 	REQUIRE(rdata->type == 24);
291*00b67f09SDavid van Moolenbroek 	REQUIRE(rdata->length != 0);
292*00b67f09SDavid van Moolenbroek 
293*00b67f09SDavid van Moolenbroek 	dns_compress_setmethods(cctx, DNS_COMPRESS_NONE);
294*00b67f09SDavid van Moolenbroek 	dns_rdata_toregion(rdata, &sr);
295*00b67f09SDavid van Moolenbroek 	/*
296*00b67f09SDavid van Moolenbroek 	 * type covered: 2
297*00b67f09SDavid van Moolenbroek 	 * algorithm: 1
298*00b67f09SDavid van Moolenbroek 	 * labels: 1
299*00b67f09SDavid van Moolenbroek 	 * original ttl: 4
300*00b67f09SDavid van Moolenbroek 	 * signature expiration: 4
301*00b67f09SDavid van Moolenbroek 	 * time signed: 4
302*00b67f09SDavid van Moolenbroek 	 * key footprint: 2
303*00b67f09SDavid van Moolenbroek 	 */
304*00b67f09SDavid van Moolenbroek 	RETERR(mem_tobuffer(target, sr.base, 18));
305*00b67f09SDavid van Moolenbroek 	isc_region_consume(&sr, 18);
306*00b67f09SDavid van Moolenbroek 
307*00b67f09SDavid van Moolenbroek 	/*
308*00b67f09SDavid van Moolenbroek 	 * Signer.
309*00b67f09SDavid van Moolenbroek 	 */
310*00b67f09SDavid van Moolenbroek 	dns_name_init(&name, offsets);
311*00b67f09SDavid van Moolenbroek 	dns_name_fromregion(&name, &sr);
312*00b67f09SDavid van Moolenbroek 	isc_region_consume(&sr, name_length(&name));
313*00b67f09SDavid van Moolenbroek 	RETERR(dns_name_towire(&name, cctx, target));
314*00b67f09SDavid van Moolenbroek 
315*00b67f09SDavid van Moolenbroek 	/*
316*00b67f09SDavid van Moolenbroek 	 * Signature.
317*00b67f09SDavid van Moolenbroek 	 */
318*00b67f09SDavid van Moolenbroek 	return (mem_tobuffer(target, sr.base, sr.length));
319*00b67f09SDavid van Moolenbroek }
320*00b67f09SDavid van Moolenbroek 
321*00b67f09SDavid van Moolenbroek static inline int
compare_sig(ARGS_COMPARE)322*00b67f09SDavid van Moolenbroek compare_sig(ARGS_COMPARE) {
323*00b67f09SDavid van Moolenbroek 	isc_region_t r1;
324*00b67f09SDavid van Moolenbroek 	isc_region_t r2;
325*00b67f09SDavid van Moolenbroek 	dns_name_t name1;
326*00b67f09SDavid van Moolenbroek 	dns_name_t name2;
327*00b67f09SDavid van Moolenbroek 	int order;
328*00b67f09SDavid van Moolenbroek 
329*00b67f09SDavid van Moolenbroek 	REQUIRE(rdata1->type == rdata2->type);
330*00b67f09SDavid van Moolenbroek 	REQUIRE(rdata1->rdclass == rdata2->rdclass);
331*00b67f09SDavid van Moolenbroek 	REQUIRE(rdata1->type == 24);
332*00b67f09SDavid van Moolenbroek 	REQUIRE(rdata1->length != 0);
333*00b67f09SDavid van Moolenbroek 	REQUIRE(rdata2->length != 0);
334*00b67f09SDavid van Moolenbroek 
335*00b67f09SDavid van Moolenbroek 	dns_rdata_toregion(rdata1, &r1);
336*00b67f09SDavid van Moolenbroek 	dns_rdata_toregion(rdata2, &r2);
337*00b67f09SDavid van Moolenbroek 
338*00b67f09SDavid van Moolenbroek 	INSIST(r1.length > 18);
339*00b67f09SDavid van Moolenbroek 	INSIST(r2.length > 18);
340*00b67f09SDavid van Moolenbroek 	r1.length = 18;
341*00b67f09SDavid van Moolenbroek 	r2.length = 18;
342*00b67f09SDavid van Moolenbroek 	order = isc_region_compare(&r1, &r2);
343*00b67f09SDavid van Moolenbroek 	if (order != 0)
344*00b67f09SDavid van Moolenbroek 		return (order);
345*00b67f09SDavid van Moolenbroek 
346*00b67f09SDavid van Moolenbroek 	dns_name_init(&name1, NULL);
347*00b67f09SDavid van Moolenbroek 	dns_name_init(&name2, NULL);
348*00b67f09SDavid van Moolenbroek 	dns_rdata_toregion(rdata1, &r1);
349*00b67f09SDavid van Moolenbroek 	dns_rdata_toregion(rdata2, &r2);
350*00b67f09SDavid van Moolenbroek 	isc_region_consume(&r1, 18);
351*00b67f09SDavid van Moolenbroek 	isc_region_consume(&r2, 18);
352*00b67f09SDavid van Moolenbroek 	dns_name_fromregion(&name1, &r1);
353*00b67f09SDavid van Moolenbroek 	dns_name_fromregion(&name2, &r2);
354*00b67f09SDavid van Moolenbroek 	order = dns_name_rdatacompare(&name1, &name2);
355*00b67f09SDavid van Moolenbroek 	if (order != 0)
356*00b67f09SDavid van Moolenbroek 		return (order);
357*00b67f09SDavid van Moolenbroek 
358*00b67f09SDavid van Moolenbroek 	isc_region_consume(&r1, name_length(&name1));
359*00b67f09SDavid van Moolenbroek 	isc_region_consume(&r2, name_length(&name2));
360*00b67f09SDavid van Moolenbroek 
361*00b67f09SDavid van Moolenbroek 	return (isc_region_compare(&r1, &r2));
362*00b67f09SDavid van Moolenbroek }
363*00b67f09SDavid van Moolenbroek 
364*00b67f09SDavid van Moolenbroek static inline isc_result_t
fromstruct_sig(ARGS_FROMSTRUCT)365*00b67f09SDavid van Moolenbroek fromstruct_sig(ARGS_FROMSTRUCT) {
366*00b67f09SDavid van Moolenbroek 	dns_rdata_sig_t *sig = source;
367*00b67f09SDavid van Moolenbroek 
368*00b67f09SDavid van Moolenbroek 	REQUIRE(type == 24);
369*00b67f09SDavid van Moolenbroek 	REQUIRE(source != NULL);
370*00b67f09SDavid van Moolenbroek 	REQUIRE(sig->common.rdtype == type);
371*00b67f09SDavid van Moolenbroek 	REQUIRE(sig->common.rdclass == rdclass);
372*00b67f09SDavid van Moolenbroek 	REQUIRE(sig->signature != NULL || sig->siglen == 0);
373*00b67f09SDavid van Moolenbroek 
374*00b67f09SDavid van Moolenbroek 	UNUSED(type);
375*00b67f09SDavid van Moolenbroek 	UNUSED(rdclass);
376*00b67f09SDavid van Moolenbroek 
377*00b67f09SDavid van Moolenbroek 	/*
378*00b67f09SDavid van Moolenbroek 	 * Type covered.
379*00b67f09SDavid van Moolenbroek 	 */
380*00b67f09SDavid van Moolenbroek 	RETERR(uint16_tobuffer(sig->covered, target));
381*00b67f09SDavid van Moolenbroek 
382*00b67f09SDavid van Moolenbroek 	/*
383*00b67f09SDavid van Moolenbroek 	 * Algorithm.
384*00b67f09SDavid van Moolenbroek 	 */
385*00b67f09SDavid van Moolenbroek 	RETERR(uint8_tobuffer(sig->algorithm, target));
386*00b67f09SDavid van Moolenbroek 
387*00b67f09SDavid van Moolenbroek 	/*
388*00b67f09SDavid van Moolenbroek 	 * Labels.
389*00b67f09SDavid van Moolenbroek 	 */
390*00b67f09SDavid van Moolenbroek 	RETERR(uint8_tobuffer(sig->labels, target));
391*00b67f09SDavid van Moolenbroek 
392*00b67f09SDavid van Moolenbroek 	/*
393*00b67f09SDavid van Moolenbroek 	 * Original TTL.
394*00b67f09SDavid van Moolenbroek 	 */
395*00b67f09SDavid van Moolenbroek 	RETERR(uint32_tobuffer(sig->originalttl, target));
396*00b67f09SDavid van Moolenbroek 
397*00b67f09SDavid van Moolenbroek 	/*
398*00b67f09SDavid van Moolenbroek 	 * Expire time.
399*00b67f09SDavid van Moolenbroek 	 */
400*00b67f09SDavid van Moolenbroek 	RETERR(uint32_tobuffer(sig->timeexpire, target));
401*00b67f09SDavid van Moolenbroek 
402*00b67f09SDavid van Moolenbroek 	/*
403*00b67f09SDavid van Moolenbroek 	 * Time signed.
404*00b67f09SDavid van Moolenbroek 	 */
405*00b67f09SDavid van Moolenbroek 	RETERR(uint32_tobuffer(sig->timesigned, target));
406*00b67f09SDavid van Moolenbroek 
407*00b67f09SDavid van Moolenbroek 	/*
408*00b67f09SDavid van Moolenbroek 	 * Key ID.
409*00b67f09SDavid van Moolenbroek 	 */
410*00b67f09SDavid van Moolenbroek 	RETERR(uint16_tobuffer(sig->keyid, target));
411*00b67f09SDavid van Moolenbroek 
412*00b67f09SDavid van Moolenbroek 	/*
413*00b67f09SDavid van Moolenbroek 	 * Signer name.
414*00b67f09SDavid van Moolenbroek 	 */
415*00b67f09SDavid van Moolenbroek 	RETERR(name_tobuffer(&sig->signer, target));
416*00b67f09SDavid van Moolenbroek 
417*00b67f09SDavid van Moolenbroek 	/*
418*00b67f09SDavid van Moolenbroek 	 * Signature.
419*00b67f09SDavid van Moolenbroek 	 */
420*00b67f09SDavid van Moolenbroek 	return (mem_tobuffer(target, sig->signature, sig->siglen));
421*00b67f09SDavid van Moolenbroek }
422*00b67f09SDavid van Moolenbroek 
423*00b67f09SDavid van Moolenbroek static inline isc_result_t
tostruct_sig(ARGS_TOSTRUCT)424*00b67f09SDavid van Moolenbroek tostruct_sig(ARGS_TOSTRUCT) {
425*00b67f09SDavid van Moolenbroek 	isc_region_t sr;
426*00b67f09SDavid van Moolenbroek 	dns_rdata_sig_t *sig = target;
427*00b67f09SDavid van Moolenbroek 	dns_name_t signer;
428*00b67f09SDavid van Moolenbroek 
429*00b67f09SDavid van Moolenbroek 	REQUIRE(rdata->type == 24);
430*00b67f09SDavid van Moolenbroek 	REQUIRE(target != NULL);
431*00b67f09SDavid van Moolenbroek 	REQUIRE(rdata->length != 0);
432*00b67f09SDavid van Moolenbroek 
433*00b67f09SDavid van Moolenbroek 	sig->common.rdclass = rdata->rdclass;
434*00b67f09SDavid van Moolenbroek 	sig->common.rdtype = rdata->type;
435*00b67f09SDavid van Moolenbroek 	ISC_LINK_INIT(&sig->common, link);
436*00b67f09SDavid van Moolenbroek 
437*00b67f09SDavid van Moolenbroek 	dns_rdata_toregion(rdata, &sr);
438*00b67f09SDavid van Moolenbroek 
439*00b67f09SDavid van Moolenbroek 	/*
440*00b67f09SDavid van Moolenbroek 	 * Type covered.
441*00b67f09SDavid van Moolenbroek 	 */
442*00b67f09SDavid van Moolenbroek 	sig->covered = uint16_fromregion(&sr);
443*00b67f09SDavid van Moolenbroek 	isc_region_consume(&sr, 2);
444*00b67f09SDavid van Moolenbroek 
445*00b67f09SDavid van Moolenbroek 	/*
446*00b67f09SDavid van Moolenbroek 	 * Algorithm.
447*00b67f09SDavid van Moolenbroek 	 */
448*00b67f09SDavid van Moolenbroek 	sig->algorithm = uint8_fromregion(&sr);
449*00b67f09SDavid van Moolenbroek 	isc_region_consume(&sr, 1);
450*00b67f09SDavid van Moolenbroek 
451*00b67f09SDavid van Moolenbroek 	/*
452*00b67f09SDavid van Moolenbroek 	 * Labels.
453*00b67f09SDavid van Moolenbroek 	 */
454*00b67f09SDavid van Moolenbroek 	sig->labels = uint8_fromregion(&sr);
455*00b67f09SDavid van Moolenbroek 	isc_region_consume(&sr, 1);
456*00b67f09SDavid van Moolenbroek 
457*00b67f09SDavid van Moolenbroek 	/*
458*00b67f09SDavid van Moolenbroek 	 * Original TTL.
459*00b67f09SDavid van Moolenbroek 	 */
460*00b67f09SDavid van Moolenbroek 	sig->originalttl = uint32_fromregion(&sr);
461*00b67f09SDavid van Moolenbroek 	isc_region_consume(&sr, 4);
462*00b67f09SDavid van Moolenbroek 
463*00b67f09SDavid van Moolenbroek 	/*
464*00b67f09SDavid van Moolenbroek 	 * Expire time.
465*00b67f09SDavid van Moolenbroek 	 */
466*00b67f09SDavid van Moolenbroek 	sig->timeexpire = uint32_fromregion(&sr);
467*00b67f09SDavid van Moolenbroek 	isc_region_consume(&sr, 4);
468*00b67f09SDavid van Moolenbroek 
469*00b67f09SDavid van Moolenbroek 	/*
470*00b67f09SDavid van Moolenbroek 	 * Time signed.
471*00b67f09SDavid van Moolenbroek 	 */
472*00b67f09SDavid van Moolenbroek 	sig->timesigned = uint32_fromregion(&sr);
473*00b67f09SDavid van Moolenbroek 	isc_region_consume(&sr, 4);
474*00b67f09SDavid van Moolenbroek 
475*00b67f09SDavid van Moolenbroek 	/*
476*00b67f09SDavid van Moolenbroek 	 * Key ID.
477*00b67f09SDavid van Moolenbroek 	 */
478*00b67f09SDavid van Moolenbroek 	sig->keyid = uint16_fromregion(&sr);
479*00b67f09SDavid van Moolenbroek 	isc_region_consume(&sr, 2);
480*00b67f09SDavid van Moolenbroek 
481*00b67f09SDavid van Moolenbroek 	dns_name_init(&signer, NULL);
482*00b67f09SDavid van Moolenbroek 	dns_name_fromregion(&signer, &sr);
483*00b67f09SDavid van Moolenbroek 	dns_name_init(&sig->signer, NULL);
484*00b67f09SDavid van Moolenbroek 	RETERR(name_duporclone(&signer, mctx, &sig->signer));
485*00b67f09SDavid van Moolenbroek 	isc_region_consume(&sr, name_length(&sig->signer));
486*00b67f09SDavid van Moolenbroek 
487*00b67f09SDavid van Moolenbroek 	/*
488*00b67f09SDavid van Moolenbroek 	 * Signature.
489*00b67f09SDavid van Moolenbroek 	 */
490*00b67f09SDavid van Moolenbroek 	sig->siglen = sr.length;
491*00b67f09SDavid van Moolenbroek 	sig->signature = mem_maybedup(mctx, sr.base, sig->siglen);
492*00b67f09SDavid van Moolenbroek 	if (sig->signature == NULL)
493*00b67f09SDavid van Moolenbroek 		goto cleanup;
494*00b67f09SDavid van Moolenbroek 
495*00b67f09SDavid van Moolenbroek 
496*00b67f09SDavid van Moolenbroek 	sig->mctx = mctx;
497*00b67f09SDavid van Moolenbroek 	return (ISC_R_SUCCESS);
498*00b67f09SDavid van Moolenbroek 
499*00b67f09SDavid van Moolenbroek  cleanup:
500*00b67f09SDavid van Moolenbroek 	if (mctx != NULL)
501*00b67f09SDavid van Moolenbroek 		dns_name_free(&sig->signer, mctx);
502*00b67f09SDavid van Moolenbroek 	return (ISC_R_NOMEMORY);
503*00b67f09SDavid van Moolenbroek }
504*00b67f09SDavid van Moolenbroek 
505*00b67f09SDavid van Moolenbroek static inline void
freestruct_sig(ARGS_FREESTRUCT)506*00b67f09SDavid van Moolenbroek freestruct_sig(ARGS_FREESTRUCT) {
507*00b67f09SDavid van Moolenbroek 	dns_rdata_sig_t *sig = (dns_rdata_sig_t *) source;
508*00b67f09SDavid van Moolenbroek 
509*00b67f09SDavid van Moolenbroek 	REQUIRE(source != NULL);
510*00b67f09SDavid van Moolenbroek 	REQUIRE(sig->common.rdtype == 24);
511*00b67f09SDavid van Moolenbroek 
512*00b67f09SDavid van Moolenbroek 	if (sig->mctx == NULL)
513*00b67f09SDavid van Moolenbroek 		return;
514*00b67f09SDavid van Moolenbroek 
515*00b67f09SDavid van Moolenbroek 	dns_name_free(&sig->signer, sig->mctx);
516*00b67f09SDavid van Moolenbroek 	if (sig->signature != NULL)
517*00b67f09SDavid van Moolenbroek 		isc_mem_free(sig->mctx, sig->signature);
518*00b67f09SDavid van Moolenbroek 	sig->mctx = NULL;
519*00b67f09SDavid van Moolenbroek }
520*00b67f09SDavid van Moolenbroek 
521*00b67f09SDavid van Moolenbroek static inline isc_result_t
additionaldata_sig(ARGS_ADDLDATA)522*00b67f09SDavid van Moolenbroek additionaldata_sig(ARGS_ADDLDATA) {
523*00b67f09SDavid van Moolenbroek 	REQUIRE(rdata->type == 24);
524*00b67f09SDavid van Moolenbroek 
525*00b67f09SDavid van Moolenbroek 	UNUSED(rdata);
526*00b67f09SDavid van Moolenbroek 	UNUSED(add);
527*00b67f09SDavid van Moolenbroek 	UNUSED(arg);
528*00b67f09SDavid van Moolenbroek 
529*00b67f09SDavid van Moolenbroek 	return (ISC_R_SUCCESS);
530*00b67f09SDavid van Moolenbroek }
531*00b67f09SDavid van Moolenbroek 
532*00b67f09SDavid van Moolenbroek static inline isc_result_t
digest_sig(ARGS_DIGEST)533*00b67f09SDavid van Moolenbroek digest_sig(ARGS_DIGEST) {
534*00b67f09SDavid van Moolenbroek 
535*00b67f09SDavid van Moolenbroek 	REQUIRE(rdata->type == 24);
536*00b67f09SDavid van Moolenbroek 
537*00b67f09SDavid van Moolenbroek 	UNUSED(rdata);
538*00b67f09SDavid van Moolenbroek 	UNUSED(digest);
539*00b67f09SDavid van Moolenbroek 	UNUSED(arg);
540*00b67f09SDavid van Moolenbroek 
541*00b67f09SDavid van Moolenbroek 	return (ISC_R_NOTIMPLEMENTED);
542*00b67f09SDavid van Moolenbroek }
543*00b67f09SDavid van Moolenbroek 
544*00b67f09SDavid van Moolenbroek static inline dns_rdatatype_t
covers_sig(dns_rdata_t * rdata)545*00b67f09SDavid van Moolenbroek covers_sig(dns_rdata_t *rdata) {
546*00b67f09SDavid van Moolenbroek 	dns_rdatatype_t type;
547*00b67f09SDavid van Moolenbroek 	isc_region_t r;
548*00b67f09SDavid van Moolenbroek 
549*00b67f09SDavid van Moolenbroek 	REQUIRE(rdata->type == 24);
550*00b67f09SDavid van Moolenbroek 
551*00b67f09SDavid van Moolenbroek 	dns_rdata_toregion(rdata, &r);
552*00b67f09SDavid van Moolenbroek 	type = uint16_fromregion(&r);
553*00b67f09SDavid van Moolenbroek 
554*00b67f09SDavid van Moolenbroek 	return (type);
555*00b67f09SDavid van Moolenbroek }
556*00b67f09SDavid van Moolenbroek 
557*00b67f09SDavid van Moolenbroek static inline isc_boolean_t
checkowner_sig(ARGS_CHECKOWNER)558*00b67f09SDavid van Moolenbroek checkowner_sig(ARGS_CHECKOWNER) {
559*00b67f09SDavid van Moolenbroek 
560*00b67f09SDavid van Moolenbroek 	REQUIRE(type == 24);
561*00b67f09SDavid van Moolenbroek 
562*00b67f09SDavid van Moolenbroek 	UNUSED(name);
563*00b67f09SDavid van Moolenbroek 	UNUSED(type);
564*00b67f09SDavid van Moolenbroek 	UNUSED(rdclass);
565*00b67f09SDavid van Moolenbroek 	UNUSED(wildcard);
566*00b67f09SDavid van Moolenbroek 
567*00b67f09SDavid van Moolenbroek 	return (ISC_TRUE);
568*00b67f09SDavid van Moolenbroek }
569*00b67f09SDavid van Moolenbroek 
570*00b67f09SDavid van Moolenbroek static inline isc_boolean_t
checknames_sig(ARGS_CHECKNAMES)571*00b67f09SDavid van Moolenbroek checknames_sig(ARGS_CHECKNAMES) {
572*00b67f09SDavid van Moolenbroek 
573*00b67f09SDavid van Moolenbroek 	REQUIRE(rdata->type == 24);
574*00b67f09SDavid van Moolenbroek 
575*00b67f09SDavid van Moolenbroek 	UNUSED(rdata);
576*00b67f09SDavid van Moolenbroek 	UNUSED(owner);
577*00b67f09SDavid van Moolenbroek 	UNUSED(bad);
578*00b67f09SDavid van Moolenbroek 
579*00b67f09SDavid van Moolenbroek 	return (ISC_TRUE);
580*00b67f09SDavid van Moolenbroek }
581*00b67f09SDavid van Moolenbroek 
582*00b67f09SDavid van Moolenbroek static inline int
casecompare_sig(ARGS_COMPARE)583*00b67f09SDavid van Moolenbroek casecompare_sig(ARGS_COMPARE) {
584*00b67f09SDavid van Moolenbroek 	return (compare_sig(rdata1, rdata2));
585*00b67f09SDavid van Moolenbroek }
586*00b67f09SDavid van Moolenbroek #endif	/* RDATA_GENERIC_SIG_24_C */
587