xref: /openbsd-src/usr.bin/dig/lib/dns/rdata/generic/sig_24.c (revision 1fb015a8af3a7e9b85db2510147a155826ef04d9)
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