mirror of
https://github.com/systemd/systemd.git
synced 2024-12-26 03:22:00 +03:00
util-lib: update dns_name_to_wire_format() to optionally generate DNSSEC canonical names
We'll need this later when putting together RR serializations to checksum.
This commit is contained in:
parent
92aea95e16
commit
3cd03457bd
@ -554,7 +554,7 @@ static int client_append_fqdn_option(DHCPMessage *message, size_t optlen, size_t
|
||||
buffer[1] = 0; /* RCODE1 (deprecated) */
|
||||
buffer[2] = 0; /* RCODE2 (deprecated) */
|
||||
|
||||
r = dns_name_to_wire_format(fqdn, buffer + 3, sizeof(buffer) - 3);
|
||||
r = dns_name_to_wire_format(fqdn, buffer + 3, sizeof(buffer) - 3, false);
|
||||
if (r > 0)
|
||||
r = dhcp_option_append(message, optlen, optoffset, 0,
|
||||
DHCP_OPTION_FQDN, 3 + r, buffer);
|
||||
|
@ -865,7 +865,7 @@ bool dns_name_is_single_label(const char *name) {
|
||||
}
|
||||
|
||||
/* Encode a domain name according to RFC 1035 Section 3.1, without compression */
|
||||
int dns_name_to_wire_format(const char *domain, uint8_t *buffer, size_t len) {
|
||||
int dns_name_to_wire_format(const char *domain, uint8_t *buffer, size_t len, bool canonical) {
|
||||
uint8_t *label_length, *out;
|
||||
int r;
|
||||
|
||||
@ -890,6 +890,20 @@ int dns_name_to_wire_format(const char *domain, uint8_t *buffer, size_t len) {
|
||||
if (r < 0)
|
||||
return r;
|
||||
|
||||
if (canonical) {
|
||||
size_t i;
|
||||
|
||||
/* Optionally, output the name in DNSSEC
|
||||
* canonical format, as described in RFC 4034,
|
||||
* section 6.2. Or in other words: in
|
||||
* lower-case. */
|
||||
|
||||
for (i = 0; i < (size_t) r; i++) {
|
||||
if (out[i] >= 'A' && out[i] <= 'Z')
|
||||
out[i] = out[i] - 'A' + 'a';
|
||||
}
|
||||
}
|
||||
|
||||
/* Fill label length, move forward */
|
||||
*label_length = r;
|
||||
out += r;
|
||||
|
@ -77,7 +77,7 @@ int dns_name_address(const char *p, int *family, union in_addr_union *a);
|
||||
bool dns_name_is_root(const char *name);
|
||||
bool dns_name_is_single_label(const char *name);
|
||||
|
||||
int dns_name_to_wire_format(const char *domain, uint8_t *buffer, size_t len);
|
||||
int dns_name_to_wire_format(const char *domain, uint8_t *buffer, size_t len, bool canonical);
|
||||
|
||||
bool dns_srv_type_is_valid(const char *name);
|
||||
bool dns_service_name_is_valid(const char *name);
|
||||
|
@ -56,7 +56,7 @@ static void test_dns_name_to_wire_format_one(const char *what, const char *expec
|
||||
uint8_t buffer[buffer_sz];
|
||||
int r;
|
||||
|
||||
r = dns_name_to_wire_format(what, buffer, buffer_sz);
|
||||
r = dns_name_to_wire_format(what, buffer, buffer_sz, false);
|
||||
assert_se(r == ret);
|
||||
|
||||
if (r < 0)
|
||||
|
Loading…
Reference in New Issue
Block a user