2 * Copyright (C) 2012, 2014, 2015 Internet Systems Consortium, Inc. ("ISC")
4 * Permission to use, copy, modify, and/or distribute this software for any
5 * purpose with or without fee is hereby granted, provided that the above
6 * copyright notice and this permission notice appear in all copies.
8 * THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES WITH
9 * REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
10 * AND FITNESS. IN NO EVENT SHALL ISC BE LIABLE FOR ANY SPECIAL, DIRECT,
11 * INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
12 * LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE
13 * OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
14 * PERFORMANCE OF THIS SOFTWARE.
19 #ifndef RDATA_GENERIC_TLSA_52_C
20 #define RDATA_GENERIC_TLSA_52_C
22 #define RRTYPE_TLSA_ATTRIBUTES 0
24 static inline isc_result_t
25 generic_fromtext_tlsa(ARGS_FROMTEXT) {
37 RETERR(isc_lex_getmastertoken(lexer, &token, isc_tokentype_number,
39 if (token.value.as_ulong > 0xffU)
41 RETERR(uint8_tobuffer(token.value.as_ulong, target));
46 RETERR(isc_lex_getmastertoken(lexer, &token, isc_tokentype_number,
48 if (token.value.as_ulong > 0xffU)
50 RETERR(uint8_tobuffer(token.value.as_ulong, target));
55 RETERR(isc_lex_getmastertoken(lexer, &token, isc_tokentype_number,
57 if (token.value.as_ulong > 0xffU)
59 RETERR(uint8_tobuffer(token.value.as_ulong, target));
62 * Certificate Association Data.
64 return (isc_hex_tobuffer(lexer, target, -1));
67 static inline isc_result_t
68 generic_totext_tlsa(ARGS_TOTEXT) {
70 char buf[sizeof("64000 ")];
73 REQUIRE(rdata->length != 0);
77 dns_rdata_toregion(rdata, &sr);
82 n = uint8_fromregion(&sr);
83 isc_region_consume(&sr, 1);
84 sprintf(buf, "%u ", n);
85 RETERR(str_totext(buf, target));
90 n = uint8_fromregion(&sr);
91 isc_region_consume(&sr, 1);
92 sprintf(buf, "%u ", n);
93 RETERR(str_totext(buf, target));
98 n = uint8_fromregion(&sr);
99 isc_region_consume(&sr, 1);
100 sprintf(buf, "%u", n);
101 RETERR(str_totext(buf, target));
104 * Certificate Association Data.
106 if ((tctx->flags & DNS_STYLEFLAG_MULTILINE) != 0)
107 RETERR(str_totext(" (", target));
108 RETERR(str_totext(tctx->linebreak, target));
109 if (tctx->width == 0) /* No splitting */
110 RETERR(isc_hex_totext(&sr, 0, "", target));
112 RETERR(isc_hex_totext(&sr, tctx->width - 2,
113 tctx->linebreak, target));
114 if ((tctx->flags & DNS_STYLEFLAG_MULTILINE) != 0)
115 RETERR(str_totext(" )", target));
116 return (ISC_R_SUCCESS);
119 static inline isc_result_t
120 generic_fromwire_tlsa(ARGS_FROMWIRE) {
128 isc_buffer_activeregion(source, &sr);
131 return (ISC_R_UNEXPECTEDEND);
133 isc_buffer_forward(source, sr.length);
134 return (mem_tobuffer(target, sr.base, sr.length));
137 static inline isc_result_t
138 fromtext_tlsa(ARGS_FROMTEXT) {
140 REQUIRE(type == dns_rdatatype_tlsa);
142 return (generic_fromtext_tlsa(rdclass, type, lexer, origin, options,
146 static inline isc_result_t
147 totext_tlsa(ARGS_TOTEXT) {
149 REQUIRE(rdata->type == dns_rdatatype_tlsa);
151 return (generic_totext_tlsa(rdata, tctx, target));
154 static inline isc_result_t
155 fromwire_tlsa(ARGS_FROMWIRE) {
157 REQUIRE(type == dns_rdatatype_tlsa);
159 return (generic_fromwire_tlsa(rdclass, type, source, dctx, options,
163 static inline isc_result_t
164 towire_tlsa(ARGS_TOWIRE) {
167 REQUIRE(rdata->type == dns_rdatatype_tlsa);
168 REQUIRE(rdata->length != 0);
172 dns_rdata_toregion(rdata, &sr);
173 return (mem_tobuffer(target, sr.base, sr.length));
177 compare_tlsa(ARGS_COMPARE) {
181 REQUIRE(rdata1->type == rdata2->type);
182 REQUIRE(rdata1->rdclass == rdata2->rdclass);
183 REQUIRE(rdata1->type == dns_rdatatype_tlsa);
184 REQUIRE(rdata1->length != 0);
185 REQUIRE(rdata2->length != 0);
187 dns_rdata_toregion(rdata1, &r1);
188 dns_rdata_toregion(rdata2, &r2);
189 return (isc_region_compare(&r1, &r2));
192 static inline isc_result_t
193 generic_fromstruct_tlsa(ARGS_FROMSTRUCT) {
194 dns_rdata_tlsa_t *tlsa = source;
196 REQUIRE(source != NULL);
197 REQUIRE(tlsa->common.rdtype == type);
198 REQUIRE(tlsa->common.rdclass == rdclass);
203 RETERR(uint8_tobuffer(tlsa->usage, target));
204 RETERR(uint8_tobuffer(tlsa->selector, target));
205 RETERR(uint8_tobuffer(tlsa->match, target));
207 return (mem_tobuffer(target, tlsa->data, tlsa->length));
210 static inline isc_result_t
211 generic_tostruct_tlsa(ARGS_TOSTRUCT) {
212 dns_rdata_tlsa_t *tlsa = target;
215 REQUIRE(target != NULL);
216 REQUIRE(rdata->length != 0);
218 tlsa->common.rdclass = rdata->rdclass;
219 tlsa->common.rdtype = rdata->type;
220 ISC_LINK_INIT(&tlsa->common, link);
222 dns_rdata_toregion(rdata, ®ion);
224 tlsa->usage = uint8_fromregion(®ion);
225 isc_region_consume(®ion, 1);
226 tlsa->selector = uint8_fromregion(®ion);
227 isc_region_consume(®ion, 1);
228 tlsa->match = uint8_fromregion(®ion);
229 isc_region_consume(®ion, 1);
230 tlsa->length = region.length;
232 tlsa->data = mem_maybedup(mctx, region.base, region.length);
233 if (tlsa->data == NULL)
234 return (ISC_R_NOMEMORY);
237 return (ISC_R_SUCCESS);
241 generic_freestruct_tlsa(ARGS_FREESTRUCT) {
242 dns_rdata_tlsa_t *tlsa = source;
244 REQUIRE(tlsa != NULL);
246 if (tlsa->mctx == NULL)
249 if (tlsa->data != NULL)
250 isc_mem_free(tlsa->mctx, tlsa->data);
254 static inline isc_result_t
255 fromstruct_tlsa(ARGS_FROMSTRUCT) {
257 REQUIRE(type == dns_rdatatype_tlsa);
259 return (generic_fromstruct_tlsa(rdclass, type, source, target));
262 static inline isc_result_t
263 tostruct_tlsa(ARGS_TOSTRUCT) {
264 dns_rdata_txt_t *txt = target;
266 REQUIRE(rdata->type == dns_rdatatype_tlsa);
267 REQUIRE(target != NULL);
269 txt->common.rdclass = rdata->rdclass;
270 txt->common.rdtype = rdata->type;
271 ISC_LINK_INIT(&txt->common, link);
273 return (generic_tostruct_tlsa(rdata, target, mctx));
277 freestruct_tlsa(ARGS_FREESTRUCT) {
278 dns_rdata_txt_t *txt = source;
280 REQUIRE(source != NULL);
281 REQUIRE(txt->common.rdtype == dns_rdatatype_tlsa);
283 generic_freestruct_tlsa(source);
286 static inline isc_result_t
287 additionaldata_tlsa(ARGS_ADDLDATA) {
288 REQUIRE(rdata->type == dns_rdatatype_tlsa);
294 return (ISC_R_SUCCESS);
297 static inline isc_result_t
298 digest_tlsa(ARGS_DIGEST) {
301 REQUIRE(rdata->type == dns_rdatatype_tlsa);
303 dns_rdata_toregion(rdata, &r);
305 return ((digest)(arg, &r));
308 static inline isc_boolean_t
309 checkowner_tlsa(ARGS_CHECKOWNER) {
311 REQUIRE(type == dns_rdatatype_tlsa);
321 static inline isc_boolean_t
322 checknames_tlsa(ARGS_CHECKNAMES) {
324 REQUIRE(rdata->type == dns_rdatatype_tlsa);
334 casecompare_tlsa(ARGS_COMPARE) {
335 return (compare_tlsa(rdata1, rdata2));
338 #endif /* RDATA_GENERIC_TLSA_52_C */