]> git.ipfire.org Git - thirdparty/systemd.git/blame - src/shared/dns-domain.h
man: document what SIGUSR1 and SIGUSR2 do to resolved
[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
bdf10b5b
LP
54int dns_label_apply_idna(const char *encoded, size_t encoded_size, char *decoded, size_t decoded_max);
55int dns_label_undo_idna(const char *encoded, size_t encoded_size, char *decoded, size_t decoded_max);
56
9ca45586
LP
57int dns_name_concat(const char *a, const char *b, char **ret);
58
59static inline int dns_name_normalize(const char *s, char **ret) {
60 /* dns_name_concat() normalizes as a side-effect */
61 return dns_name_concat(s, NULL, ret);
62}
63
df6cfeef
NO
64static inline int dns_name_is_valid(const char *s) {
65 int r;
9ca45586
LP
66
67 /* dns_name_normalize() verifies as a side effect */
df6cfeef
NO
68 r = dns_name_normalize(s, NULL);
69 if (r == -EINVAL)
70 return 0;
71 if (r < 0)
72 return r;
73 return 1;
74}
74b2466e 75
b826ab58 76void dns_name_hash_func(const void *s, struct siphash *state);
74b2466e 77int dns_name_compare_func(const void *a, const void *b);
d5099efc 78extern const struct hash_ops dns_name_hash_ops;
74b2466e 79
ae72b22c 80int dns_name_between(const char *a, const char *b, const char *c);
74b2466e
LP
81int dns_name_equal(const char *x, const char *y);
82int dns_name_endswith(const char *name, const char *suffix);
eb241cdb 83int dns_name_startswith(const char *name, const char *prefix);
74b2466e 84
58db254a
LP
85int dns_name_change_suffix(const char *name, const char *old_suffix, const char *new_suffix, char **ret);
86
74b2466e 87int dns_name_reverse(int family, const union in_addr_union *a, char **ret);
b914e211 88int dns_name_address(const char *p, int *family, union in_addr_union *a);
74b2466e 89
dc477e73
LP
90bool dns_name_is_root(const char *name);
91bool dns_name_is_single_label(const char *name);
54adabf7 92
3cd03457 93int dns_name_to_wire_format(const char *domain, uint8_t *buffer, size_t len, bool canonical);
0a49b6b6 94
7e8131e9 95bool dns_srv_type_is_valid(const char *name);
0a49b6b6 96bool dns_service_name_is_valid(const char *name);
0e8eedbb
LP
97
98int dns_service_join(const char *name, const char *type, const char *domain, char **ret);
99int dns_service_split(const char *joined, char **name, char **type, char **domain);
e7ff0e0b
LP
100
101int dns_name_suffix(const char *name, unsigned n_labels, const char **ret);
102int dns_name_count_labels(const char *name);
db5b0e92 103
97c67192 104int dns_name_skip(const char *a, unsigned n_labels, const char **ret);
db5b0e92 105int dns_name_equal_skip(const char *a, unsigned n_labels, const char *b);
b9282bc1
LP
106
107int dns_name_common_suffix(const char *a, const char *b, const char **ret);
0cf40f55
LP
108
109int dns_name_apply_idna(const char *name, char **ret);