]> git.ipfire.org Git - thirdparty/systemd.git/blame - src/shared/dns-domain.h
build-sys: use #if Y instead of #ifdef Y everywhere
[thirdparty/systemd.git] / src / shared / dns-domain.h
CommitLineData
0ef6f454
LP
1#pragma once
2
74b2466e
LP
3/***
4 This file is part of systemd.
5
6 Copyright 2014 Lennart Poettering
7
8 systemd is free software; you can redistribute it and/or modify it
9 under the terms of the GNU Lesser General Public License as published by
10 the Free Software Foundation; either version 2.1 of the License, or
11 (at your option) any later version.
12
13 systemd is distributed in the hope that it will be useful, but
14 WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16 Lesser General Public License for more details.
17
18 You should have received a copy of the GNU Lesser General Public License
19 along with systemd; If not, see <http://www.gnu.org/licenses/>.
20 ***/
21
a8fbdf54
TA
22#include <errno.h>
23#include <stdbool.h>
24#include <stddef.h>
25#include <stdint.h>
26
74b2466e
LP
27#include "hashmap.h"
28#include "in-addr-util.h"
29
3b37fa73 30/* Length of a single label, with all escaping removed, excluding any trailing dot or NUL byte */
74b2466e 31#define DNS_LABEL_MAX 63
3b37fa73
LP
32
33/* Worst case length of a single label, with all escaping applied and room for a trailing NUL byte. */
422baca0 34#define DNS_LABEL_ESCAPED_MAX (DNS_LABEL_MAX*4+1)
74b2466e 35
1dfbf000
LP
36/* Maximum length of a full hostname, consisting of a series of unescaped labels, and no trailing dot or NUL byte */
37#define DNS_HOSTNAME_MAX 253
38
2b442ac8
LP
39/* Maximum length of a full hostname, on the wire, including the final NUL byte */
40#define DNS_WIRE_FOMAT_HOSTNAME_MAX 255
41
e7ff0e0b
LP
42/* Maximum number of labels per valid hostname */
43#define DNS_N_LABELS_MAX 127
44
74b2466e 45int dns_label_unescape(const char **name, char *dest, size_t sz);
642900d3 46int dns_label_unescape_suffix(const char *name, const char **label_end, char *dest, size_t sz);
422baca0
LP
47int dns_label_escape(const char *p, size_t l, char *dest, size_t sz);
48int dns_label_escape_new(const char *p, size_t l, char **ret);
74b2466e 49
f7455baa
LP
50static inline int dns_name_parent(const char **name) {
51 return dns_label_unescape(name, NULL, DNS_LABEL_MAX);
52}
53
349cc4a5 54#if HAVE_LIBIDN
bdf10b5b
LP
55int dns_label_apply_idna(const char *encoded, size_t encoded_size, char *decoded, size_t decoded_max);
56int dns_label_undo_idna(const char *encoded, size_t encoded_size, char *decoded, size_t decoded_max);
87057e24 57#endif
bdf10b5b 58
9ca45586
LP
59int dns_name_concat(const char *a, const char *b, char **ret);
60
61static inline int dns_name_normalize(const char *s, char **ret) {
62 /* dns_name_concat() normalizes as a side-effect */
63 return dns_name_concat(s, NULL, ret);
64}
65
df6cfeef
NO
66static inline int dns_name_is_valid(const char *s) {
67 int r;
9ca45586
LP
68
69 /* dns_name_normalize() verifies as a side effect */
df6cfeef
NO
70 r = dns_name_normalize(s, NULL);
71 if (r == -EINVAL)
72 return 0;
73 if (r < 0)
74 return r;
75 return 1;
76}
74b2466e 77
b826ab58 78void dns_name_hash_func(const void *s, struct siphash *state);
74b2466e 79int dns_name_compare_func(const void *a, const void *b);
d5099efc 80extern const struct hash_ops dns_name_hash_ops;
74b2466e 81
ae72b22c 82int dns_name_between(const char *a, const char *b, const char *c);
74b2466e
LP
83int dns_name_equal(const char *x, const char *y);
84int dns_name_endswith(const char *name, const char *suffix);
eb241cdb 85int dns_name_startswith(const char *name, const char *prefix);
74b2466e 86
58db254a
LP
87int dns_name_change_suffix(const char *name, const char *old_suffix, const char *new_suffix, char **ret);
88
74b2466e 89int dns_name_reverse(int family, const union in_addr_union *a, char **ret);
b914e211 90int dns_name_address(const char *p, int *family, union in_addr_union *a);
74b2466e 91
dc477e73
LP
92bool dns_name_is_root(const char *name);
93bool dns_name_is_single_label(const char *name);
54adabf7 94
3cd03457 95int dns_name_to_wire_format(const char *domain, uint8_t *buffer, size_t len, bool canonical);
0a49b6b6 96
7e8131e9 97bool dns_srv_type_is_valid(const char *name);
0a49b6b6 98bool dns_service_name_is_valid(const char *name);
0e8eedbb
LP
99
100int dns_service_join(const char *name, const char *type, const char *domain, char **ret);
101int dns_service_split(const char *joined, char **name, char **type, char **domain);
e7ff0e0b
LP
102
103int dns_name_suffix(const char *name, unsigned n_labels, const char **ret);
104int dns_name_count_labels(const char *name);
db5b0e92 105
97c67192 106int dns_name_skip(const char *a, unsigned n_labels, const char **ret);
db5b0e92 107int dns_name_equal_skip(const char *a, unsigned n_labels, const char *b);
b9282bc1
LP
108
109int dns_name_common_suffix(const char *a, const char *b, const char **ret);
0cf40f55
LP
110
111int dns_name_apply_idna(const char *name, char **ret);
08a4849e
LP
112
113int dns_name_is_valid_or_address(const char *name);