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