15185a700Sflorian /*
25185a700Sflorian * Copyright (C) Internet Systems Consortium, Inc. ("ISC")
35185a700Sflorian *
45185a700Sflorian * Permission to use, copy, modify, and/or distribute this software for any
55185a700Sflorian * purpose with or without fee is hereby granted, provided that the above
65185a700Sflorian * copyright notice and this permission notice appear in all copies.
75185a700Sflorian *
85185a700Sflorian * THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES WITH
95185a700Sflorian * REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
105185a700Sflorian * AND FITNESS. IN NO EVENT SHALL ISC BE LIABLE FOR ANY SPECIAL, DIRECT,
115185a700Sflorian * INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
125185a700Sflorian * LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE
135185a700Sflorian * OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
145185a700Sflorian * PERFORMANCE OF THIS SOFTWARE.
155185a700Sflorian */
165185a700Sflorian
17*1fb015a8Sflorian /* $Id: sig_24.c,v 1.13 2020/09/14 08:40:43 florian Exp $ */
185185a700Sflorian
195185a700Sflorian /* Reviewed: Fri Mar 17 09:05:02 PST 2000 by gson */
205185a700Sflorian
215185a700Sflorian /* RFC2535 */
225185a700Sflorian
235185a700Sflorian #ifndef RDATA_GENERIC_SIG_24_C
245185a700Sflorian #define RDATA_GENERIC_SIG_24_C
255185a700Sflorian
265185a700Sflorian static inline isc_result_t
totext_sig(ARGS_TOTEXT)275185a700Sflorian totext_sig(ARGS_TOTEXT) {
285185a700Sflorian isc_region_t sr;
295185a700Sflorian char buf[sizeof("4294967295")];
305185a700Sflorian dns_rdatatype_t covered;
315185a700Sflorian unsigned long ttl;
325185a700Sflorian unsigned long when;
335185a700Sflorian unsigned long exp;
345185a700Sflorian unsigned long foot;
355185a700Sflorian dns_name_t name;
365185a700Sflorian dns_name_t prefix;
37*1fb015a8Sflorian int sub;
385185a700Sflorian
395185a700Sflorian REQUIRE(rdata->type == dns_rdatatype_sig);
405185a700Sflorian REQUIRE(rdata->length != 0);
415185a700Sflorian
425185a700Sflorian dns_rdata_toregion(rdata, &sr);
435185a700Sflorian
445185a700Sflorian /*
455185a700Sflorian * Type covered.
465185a700Sflorian */
475185a700Sflorian covered = uint16_fromregion(&sr);
485185a700Sflorian isc_region_consume(&sr, 2);
49abb8b8a3Sflorian
505185a700Sflorian RETERR(dns_rdatatype_totext(covered, target));
51873f12b9Sflorian RETERR(isc_str_tobuffer(" ", target));
525185a700Sflorian
535185a700Sflorian /*
545185a700Sflorian * Algorithm.
555185a700Sflorian */
565185a700Sflorian snprintf(buf, sizeof(buf), "%u", sr.base[0]);
575185a700Sflorian isc_region_consume(&sr, 1);
58873f12b9Sflorian RETERR(isc_str_tobuffer(buf, target));
59873f12b9Sflorian RETERR(isc_str_tobuffer(" ", target));
605185a700Sflorian
615185a700Sflorian /*
625185a700Sflorian * Labels.
635185a700Sflorian */
645185a700Sflorian snprintf(buf, sizeof(buf), "%u", sr.base[0]);
655185a700Sflorian isc_region_consume(&sr, 1);
66873f12b9Sflorian RETERR(isc_str_tobuffer(buf, target));
67873f12b9Sflorian RETERR(isc_str_tobuffer(" ", target));
685185a700Sflorian
695185a700Sflorian /*
705185a700Sflorian * Ttl.
715185a700Sflorian */
725185a700Sflorian ttl = uint32_fromregion(&sr);
735185a700Sflorian isc_region_consume(&sr, 4);
745185a700Sflorian snprintf(buf, sizeof(buf), "%lu", ttl);
75873f12b9Sflorian RETERR(isc_str_tobuffer(buf, target));
76873f12b9Sflorian RETERR(isc_str_tobuffer(" ", target));
775185a700Sflorian
785185a700Sflorian /*
795185a700Sflorian * Sig exp.
805185a700Sflorian */
815185a700Sflorian exp = uint32_fromregion(&sr);
825185a700Sflorian isc_region_consume(&sr, 4);
835185a700Sflorian RETERR(dns_time32_totext(exp, target));
845185a700Sflorian
855185a700Sflorian if ((tctx->flags & DNS_STYLEFLAG_MULTILINE) != 0)
86873f12b9Sflorian RETERR(isc_str_tobuffer(" (", target));
87873f12b9Sflorian RETERR(isc_str_tobuffer(tctx->linebreak, target));
885185a700Sflorian
895185a700Sflorian /*
905185a700Sflorian * Time signed.
915185a700Sflorian */
925185a700Sflorian when = uint32_fromregion(&sr);
935185a700Sflorian isc_region_consume(&sr, 4);
945185a700Sflorian RETERR(dns_time32_totext(when, target));
95873f12b9Sflorian RETERR(isc_str_tobuffer(" ", target));
965185a700Sflorian
975185a700Sflorian /*
985185a700Sflorian * Footprint.
995185a700Sflorian */
1005185a700Sflorian foot = uint16_fromregion(&sr);
1015185a700Sflorian isc_region_consume(&sr, 2);
1025185a700Sflorian snprintf(buf, sizeof(buf), "%lu", foot);
103873f12b9Sflorian RETERR(isc_str_tobuffer(buf, target));
104873f12b9Sflorian RETERR(isc_str_tobuffer(" ", target));
1055185a700Sflorian
1065185a700Sflorian /*
1075185a700Sflorian * Signer.
1085185a700Sflorian */
1095185a700Sflorian dns_name_init(&name, NULL);
1105185a700Sflorian dns_name_init(&prefix, NULL);
1115185a700Sflorian dns_name_fromregion(&name, &sr);
1125185a700Sflorian isc_region_consume(&sr, name_length(&name));
1135185a700Sflorian sub = name_prefix(&name, tctx->origin, &prefix);
1145185a700Sflorian RETERR(dns_name_totext(&prefix, sub, target));
1155185a700Sflorian
1165185a700Sflorian /*
1175185a700Sflorian * Sig.
1185185a700Sflorian */
119873f12b9Sflorian RETERR(isc_str_tobuffer(tctx->linebreak, target));
1205185a700Sflorian if (tctx->width == 0) /* No splitting */
1215185a700Sflorian RETERR(isc_base64_totext(&sr, 60, "", target));
1225185a700Sflorian else
1235185a700Sflorian RETERR(isc_base64_totext(&sr, tctx->width - 2,
1245185a700Sflorian tctx->linebreak, target));
1255185a700Sflorian if ((tctx->flags & DNS_STYLEFLAG_MULTILINE) != 0)
126873f12b9Sflorian RETERR(isc_str_tobuffer(" )", target));
1275185a700Sflorian
1285185a700Sflorian return (ISC_R_SUCCESS);
1295185a700Sflorian }
1305185a700Sflorian
1315185a700Sflorian static inline isc_result_t
fromwire_sig(ARGS_FROMWIRE)1325185a700Sflorian fromwire_sig(ARGS_FROMWIRE) {
1335185a700Sflorian isc_region_t sr;
1345185a700Sflorian dns_name_t name;
1355185a700Sflorian
1365185a700Sflorian REQUIRE(type == dns_rdatatype_sig);
1375185a700Sflorian
1385185a700Sflorian UNUSED(type);
1395185a700Sflorian UNUSED(rdclass);
1405185a700Sflorian
1415185a700Sflorian dns_decompress_setmethods(dctx, DNS_COMPRESS_NONE);
1425185a700Sflorian
1435185a700Sflorian isc_buffer_activeregion(source, &sr);
1445185a700Sflorian /*
1455185a700Sflorian * type covered: 2
1465185a700Sflorian * algorithm: 1
1475185a700Sflorian * labels: 1
1485185a700Sflorian * original ttl: 4
1495185a700Sflorian * signature expiration: 4
1505185a700Sflorian * time signed: 4
1515185a700Sflorian * key footprint: 2
1525185a700Sflorian */
1535185a700Sflorian if (sr.length < 18)
1545185a700Sflorian return (ISC_R_UNEXPECTEDEND);
1555185a700Sflorian
1565185a700Sflorian isc_buffer_forward(source, 18);
157637d8eb6Sflorian RETERR(isc_mem_tobuffer(target, sr.base, 18));
1585185a700Sflorian
1595185a700Sflorian /*
1605185a700Sflorian * Signer.
1615185a700Sflorian */
1625185a700Sflorian dns_name_init(&name, NULL);
1635185a700Sflorian RETERR(dns_name_fromwire(&name, source, dctx, options, target));
1645185a700Sflorian
1655185a700Sflorian /*
1665185a700Sflorian * Sig.
1675185a700Sflorian */
1685185a700Sflorian isc_buffer_activeregion(source, &sr);
1695185a700Sflorian isc_buffer_forward(source, sr.length);
170637d8eb6Sflorian return (isc_mem_tobuffer(target, sr.base, sr.length));
1715185a700Sflorian }
1725185a700Sflorian
1735185a700Sflorian static inline isc_result_t
towire_sig(ARGS_TOWIRE)1745185a700Sflorian towire_sig(ARGS_TOWIRE) {
1755185a700Sflorian isc_region_t sr;
1765185a700Sflorian dns_name_t name;
1775185a700Sflorian dns_offsets_t offsets;
1785185a700Sflorian
1795185a700Sflorian REQUIRE(rdata->type == dns_rdatatype_sig);
1805185a700Sflorian REQUIRE(rdata->length != 0);
1815185a700Sflorian
1825185a700Sflorian dns_compress_setmethods(cctx, DNS_COMPRESS_NONE);
1835185a700Sflorian dns_rdata_toregion(rdata, &sr);
1845185a700Sflorian /*
1855185a700Sflorian * type covered: 2
1865185a700Sflorian * algorithm: 1
1875185a700Sflorian * labels: 1
1885185a700Sflorian * original ttl: 4
1895185a700Sflorian * signature expiration: 4
1905185a700Sflorian * time signed: 4
1915185a700Sflorian * key footprint: 2
1925185a700Sflorian */
193637d8eb6Sflorian RETERR(isc_mem_tobuffer(target, sr.base, 18));
1945185a700Sflorian isc_region_consume(&sr, 18);
1955185a700Sflorian
1965185a700Sflorian /*
1975185a700Sflorian * Signer.
1985185a700Sflorian */
1995185a700Sflorian dns_name_init(&name, offsets);
2005185a700Sflorian dns_name_fromregion(&name, &sr);
2015185a700Sflorian isc_region_consume(&sr, name_length(&name));
2025185a700Sflorian RETERR(dns_name_towire(&name, cctx, target));
2035185a700Sflorian
2045185a700Sflorian /*
2055185a700Sflorian * Signature.
2065185a700Sflorian */
207637d8eb6Sflorian return (isc_mem_tobuffer(target, sr.base, sr.length));
2085185a700Sflorian }
2095185a700Sflorian
2105185a700Sflorian static inline dns_rdatatype_t
covers_sig(dns_rdata_t * rdata)2115185a700Sflorian covers_sig(dns_rdata_t *rdata) {
2125185a700Sflorian dns_rdatatype_t type;
2135185a700Sflorian isc_region_t r;
2145185a700Sflorian
2155185a700Sflorian REQUIRE(rdata->type == dns_rdatatype_sig);
2165185a700Sflorian
2175185a700Sflorian dns_rdata_toregion(rdata, &r);
2185185a700Sflorian type = uint16_fromregion(&r);
2195185a700Sflorian
2205185a700Sflorian return (type);
2215185a700Sflorian }
2225185a700Sflorian
2235185a700Sflorian #endif /* RDATA_GENERIC_SIG_24_C */
224