]> git.ipfire.org Git - thirdparty/systemd.git/blame - src/shared/dns-domain.h
resolved: make sure DNS_ANSWER_FOREACH() can be nested
[thirdparty/systemd.git] / src / shared / dns-domain.h
CommitLineData
74b2466e
LP
1/*-*- Mode: C; c-basic-offset: 8; indent-tabs-mode: nil -*-*/
2
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
c9403dce
ZJS
22#pragma once
23
74b2466e
LP
24
25#include "hashmap.h"
26#include "in-addr-util.h"
27
3b37fa73 28/* Length of a single label, with all escaping removed, excluding any trailing dot or NUL byte */
74b2466e 29#define DNS_LABEL_MAX 63
3b37fa73
LP
30
31/* Worst case length of a single label, with all escaping applied and room for a trailing NUL byte. */
422baca0 32#define DNS_LABEL_ESCAPED_MAX (DNS_LABEL_MAX*4+1)
74b2466e 33
1dfbf000
LP
34/* Maximum length of a full hostname, consisting of a series of unescaped labels, and no trailing dot or NUL byte */
35#define DNS_HOSTNAME_MAX 253
36
74b2466e 37int dns_label_unescape(const char **name, char *dest, size_t sz);
642900d3 38int dns_label_unescape_suffix(const char *name, const char **label_end, char *dest, size_t sz);
422baca0
LP
39int dns_label_escape(const char *p, size_t l, char *dest, size_t sz);
40int dns_label_escape_new(const char *p, size_t l, char **ret);
74b2466e 41
bdf10b5b
LP
42int dns_label_apply_idna(const char *encoded, size_t encoded_size, char *decoded, size_t decoded_max);
43int dns_label_undo_idna(const char *encoded, size_t encoded_size, char *decoded, size_t decoded_max);
44
9ca45586
LP
45int dns_name_concat(const char *a, const char *b, char **ret);
46
47static inline int dns_name_normalize(const char *s, char **ret) {
48 /* dns_name_concat() normalizes as a side-effect */
49 return dns_name_concat(s, NULL, ret);
50}
51
df6cfeef
NO
52static inline int dns_name_is_valid(const char *s) {
53 int r;
9ca45586
LP
54
55 /* dns_name_normalize() verifies as a side effect */
df6cfeef
NO
56 r = dns_name_normalize(s, NULL);
57 if (r == -EINVAL)
58 return 0;
59 if (r < 0)
60 return r;
61 return 1;
62}
74b2466e 63
b826ab58 64void dns_name_hash_func(const void *s, struct siphash *state);
74b2466e 65int dns_name_compare_func(const void *a, const void *b);
d5099efc 66extern const struct hash_ops dns_name_hash_ops;
74b2466e 67
ae72b22c 68int dns_name_between(const char *a, const char *b, const char *c);
74b2466e
LP
69int dns_name_equal(const char *x, const char *y);
70int dns_name_endswith(const char *name, const char *suffix);
71
58db254a
LP
72int dns_name_change_suffix(const char *name, const char *old_suffix, const char *new_suffix, char **ret);
73
74b2466e 74int dns_name_reverse(int family, const union in_addr_union *a, char **ret);
b914e211 75int dns_name_address(const char *p, int *family, union in_addr_union *a);
74b2466e 76
dc477e73
LP
77bool dns_name_is_root(const char *name);
78bool dns_name_is_single_label(const char *name);
54adabf7
BG
79
80int dns_name_to_wire_format(const char *domain, uint8_t *buffer, size_t len);
0a49b6b6 81
7e8131e9 82bool dns_srv_type_is_valid(const char *name);
0a49b6b6 83bool dns_service_name_is_valid(const char *name);
0e8eedbb
LP
84
85int dns_service_join(const char *name, const char *type, const char *domain, char **ret);
86int dns_service_split(const char *joined, char **name, char **type, char **domain);