2 * Copyright (C) 2004, 2006, 2007, 2009, 2011-2013 Internet Systems Consortium, Inc. ("ISC")
3 * Copyright (C) 2003 Internet Software Consortium.
5 * Permission to use, copy, modify, and/or distribute this software for any
6 * purpose with or without fee is hereby granted, provided that the above
7 * copyright notice and this permission notice appear in all copies.
9 * THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES WITH
10 * REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
11 * AND FITNESS. IN NO EVENT SHALL ISC BE LIABLE FOR ANY SPECIAL, DIRECT,
12 * INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
13 * LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE
14 * OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
15 * PERFORMANCE OF THIS SOFTWARE.
22 #ifndef RDATA_GENERIC_SSHFP_44_C
23 #define RDATA_GENERIC_SSHFP_44_C
25 #define RRTYPE_SSHFP_ATTRIBUTES (0)
27 static inline isc_result_t
28 fromtext_sshfp(ARGS_FROMTEXT) {
42 RETERR(isc_lex_getmastertoken(lexer, &token, isc_tokentype_number,
44 if (token.value.as_ulong > 0xffU)
46 RETERR(uint8_tobuffer(token.value.as_ulong, target));
51 RETERR(isc_lex_getmastertoken(lexer, &token, isc_tokentype_number,
53 if (token.value.as_ulong > 0xffU)
55 RETERR(uint8_tobuffer(token.value.as_ulong, target));
60 return (isc_hex_tobuffer(lexer, target, -1));
63 static inline isc_result_t
64 totext_sshfp(ARGS_TOTEXT) {
66 char buf[sizeof("64000 ")];
69 REQUIRE(rdata->type == 44);
70 REQUIRE(rdata->length != 0);
74 dns_rdata_toregion(rdata, &sr);
79 n = uint8_fromregion(&sr);
80 isc_region_consume(&sr, 1);
81 sprintf(buf, "%u ", n);
82 RETERR(str_totext(buf, target));
87 n = uint8_fromregion(&sr);
88 isc_region_consume(&sr, 1);
89 sprintf(buf, "%u", n);
90 RETERR(str_totext(buf, target));
95 if ((tctx->flags & DNS_STYLEFLAG_MULTILINE) != 0)
96 RETERR(str_totext(" (", target));
97 RETERR(str_totext(tctx->linebreak, target));
98 if (tctx->width == 0) /* No splitting */
99 RETERR(isc_hex_totext(&sr, 0, "", target));
101 RETERR(isc_hex_totext(&sr, tctx->width - 2,
102 tctx->linebreak, target));
103 if ((tctx->flags & DNS_STYLEFLAG_MULTILINE) != 0)
104 RETERR(str_totext(" )", target));
105 return (ISC_R_SUCCESS);
108 static inline isc_result_t
109 fromwire_sshfp(ARGS_FROMWIRE) {
119 isc_buffer_activeregion(source, &sr);
121 return (ISC_R_UNEXPECTEDEND);
123 isc_buffer_forward(source, sr.length);
124 return (mem_tobuffer(target, sr.base, sr.length));
127 static inline isc_result_t
128 towire_sshfp(ARGS_TOWIRE) {
131 REQUIRE(rdata->type == 44);
132 REQUIRE(rdata->length != 0);
136 dns_rdata_toregion(rdata, &sr);
137 return (mem_tobuffer(target, sr.base, sr.length));
141 compare_sshfp(ARGS_COMPARE) {
145 REQUIRE(rdata1->type == rdata2->type);
146 REQUIRE(rdata1->rdclass == rdata2->rdclass);
147 REQUIRE(rdata1->type == 44);
148 REQUIRE(rdata1->length != 0);
149 REQUIRE(rdata2->length != 0);
151 dns_rdata_toregion(rdata1, &r1);
152 dns_rdata_toregion(rdata2, &r2);
153 return (isc_region_compare(&r1, &r2));
156 static inline isc_result_t
157 fromstruct_sshfp(ARGS_FROMSTRUCT) {
158 dns_rdata_sshfp_t *sshfp = source;
161 REQUIRE(source != NULL);
162 REQUIRE(sshfp->common.rdtype == type);
163 REQUIRE(sshfp->common.rdclass == rdclass);
168 RETERR(uint8_tobuffer(sshfp->algorithm, target));
169 RETERR(uint8_tobuffer(sshfp->digest_type, target));
171 return (mem_tobuffer(target, sshfp->digest, sshfp->length));
174 static inline isc_result_t
175 tostruct_sshfp(ARGS_TOSTRUCT) {
176 dns_rdata_sshfp_t *sshfp = target;
179 REQUIRE(rdata->type == 44);
180 REQUIRE(target != NULL);
181 REQUIRE(rdata->length != 0);
183 sshfp->common.rdclass = rdata->rdclass;
184 sshfp->common.rdtype = rdata->type;
185 ISC_LINK_INIT(&sshfp->common, link);
187 dns_rdata_toregion(rdata, ®ion);
189 sshfp->algorithm = uint8_fromregion(®ion);
190 isc_region_consume(®ion, 1);
191 sshfp->digest_type = uint8_fromregion(®ion);
192 isc_region_consume(®ion, 1);
193 sshfp->length = region.length;
195 sshfp->digest = mem_maybedup(mctx, region.base, region.length);
196 if (sshfp->digest == NULL)
197 return (ISC_R_NOMEMORY);
200 return (ISC_R_SUCCESS);
204 freestruct_sshfp(ARGS_FREESTRUCT) {
205 dns_rdata_sshfp_t *sshfp = source;
207 REQUIRE(sshfp != NULL);
208 REQUIRE(sshfp->common.rdtype == 44);
210 if (sshfp->mctx == NULL)
213 if (sshfp->digest != NULL)
214 isc_mem_free(sshfp->mctx, sshfp->digest);
218 static inline isc_result_t
219 additionaldata_sshfp(ARGS_ADDLDATA) {
220 REQUIRE(rdata->type == 44);
226 return (ISC_R_SUCCESS);
229 static inline isc_result_t
230 digest_sshfp(ARGS_DIGEST) {
233 REQUIRE(rdata->type == 44);
235 dns_rdata_toregion(rdata, &r);
237 return ((digest)(arg, &r));
240 static inline isc_boolean_t
241 checkowner_sshfp(ARGS_CHECKOWNER) {
253 static inline isc_boolean_t
254 checknames_sshfp(ARGS_CHECKNAMES) {
256 REQUIRE(rdata->type == 44);
266 casecompare_sshfp(ARGS_COMPARE) {
267 return (compare_sshfp(rdata1, rdata2));
270 #endif /* RDATA_GENERIC_SSHFP_44_C */