]> git.ipfire.org Git - thirdparty/systemd.git/commitdiff
util-lib: update dns_name_to_wire_format() to optionally generate DNSSEC canonical...
authorLennart Poettering <lennart@poettering.net>
Wed, 2 Dec 2015 19:47:11 +0000 (20:47 +0100)
committerLennart Poettering <lennart@poettering.net>
Wed, 2 Dec 2015 21:50:11 +0000 (22:50 +0100)
We'll need this later when putting together RR serializations to
checksum.

src/libsystemd-network/sd-dhcp-client.c
src/shared/dns-domain.c
src/shared/dns-domain.h
src/test/test-dns-domain.c

index a03c8460a875cd6f7aee3552d55c5c8c0b0343d4..4521f8f0b1cb300d69d3c91d650d688dd6fddb4c 100644 (file)
@@ -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);
index 5ac8ad5b7a57e939f01102299538209e4c0f6b23..429aa6d2cb451580110094916b701db3590cfcd4 100644 (file)
@@ -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;
index 44a99755419ade88050a54e4adde0ff8424a1ba5..17dab1da18dd9ea584e796a92fbc373df1c565fa 100644 (file)
@@ -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);
index 7f53a8cc562e27f49d1c63b44271f9cff65a1938..de003e251cd58dd3c3078c4c6657b092d095ca27 100644 (file)
@@ -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)