resolved-dns-rr.h revision d75acfb059ece4512278b8820a9103664996f1e5
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek/*-*- Mode: C; c-basic-offset: 8; indent-tabs-mode: nil -*-*/
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek#pragma once
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek/***
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek This file is part of systemd.
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek Copyright 2014 Lennart Poettering
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek systemd is free software; you can redistribute it and/or modify it
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek under the terms of the GNU Lesser General Public License as published by
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek the Free Software Foundation; either version 2.1 of the License, or
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek (at your option) any later version.
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek systemd is distributed in the hope that it will be useful, but
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek WITHOUT ANY WARRANTY; without even the implied warranty of
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek Lesser General Public License for more details.
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek You should have received a copy of the GNU Lesser General Public License
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek along with systemd; If not, see <http://www.gnu.org/licenses/>.
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek ***/
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek#include <netinet/in.h>
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek#include "bitmap.h"
8eea868708923a092ee85d6146ba4c04b7baea06Zbigniew Jędrzejewski-Szmek#include "dns-type.h"
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek#include "hashmap.h"
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek#include "in-addr-util.h"
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek#include "list.h"
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmektypedef struct DnsResourceKey DnsResourceKey;
8eea868708923a092ee85d6146ba4c04b7baea06Zbigniew Jędrzejewski-Szmektypedef struct DnsResourceRecord DnsResourceRecord;
8eea868708923a092ee85d6146ba4c04b7baea06Zbigniew Jędrzejewski-Szmektypedef struct DnsTxtItem DnsTxtItem;
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek/* DNS record classes, see RFC 1035 */
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmekenum {
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek DNS_CLASS_IN = 0x01,
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek DNS_CLASS_ANY = 0xFF,
8eea868708923a092ee85d6146ba4c04b7baea06Zbigniew Jędrzejewski-Szmek _DNS_CLASS_MAX,
8eea868708923a092ee85d6146ba4c04b7baea06Zbigniew Jędrzejewski-Szmek _DNS_CLASS_INVALID = -1
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek};
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek/* DNSKEY RR flags */
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek#define DNSKEY_FLAG_ZONE_KEY (UINT16_C(1) << 8)
ae6c3cc009a21df4b51851fb8fe3fde0b7d6d8f0Lennart Poettering#define DNSKEY_FLAG_SEP (UINT16_C(1) << 0)
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek/* mDNS RR flags */
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek#define MDNS_RR_CACHE_FLUSH (UINT16_C(1) << 15)
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek/* DNSSEC algorithm identifiers, see
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek * http://tools.ietf.org/html/rfc4034#appendix-A.1 and
8eea868708923a092ee85d6146ba4c04b7baea06Zbigniew Jędrzejewski-Szmek * https://www.iana.org/assignments/dns-sec-alg-numbers/dns-sec-alg-numbers.xhtml */
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmekenum {
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek DNSSEC_ALGORITHM_RSAMD5 = 1,
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek DNSSEC_ALGORITHM_DH,
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek DNSSEC_ALGORITHM_DSA,
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek DNSSEC_ALGORITHM_ECC,
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek DNSSEC_ALGORITHM_RSASHA1,
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek DNSSEC_ALGORITHM_DSA_NSEC3_SHA1,
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek DNSSEC_ALGORITHM_RSASHA1_NSEC3_SHA1,
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek DNSSEC_ALGORITHM_RSASHA256 = 8, /* RFC 5702 */
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek DNSSEC_ALGORITHM_RSASHA512 = 10, /* RFC 5702 */
8eea868708923a092ee85d6146ba4c04b7baea06Zbigniew Jędrzejewski-Szmek DNSSEC_ALGORITHM_INDIRECT = 252,
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek DNSSEC_ALGORITHM_PRIVATEDNS,
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek DNSSEC_ALGORITHM_PRIVATEOID,
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek _DNSSEC_ALGORITHM_MAX_DEFINED
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek};
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek/* DNSSEC digest identifiers, see
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek * https://www.iana.org/assignments/ds-rr-types/ds-rr-types.xhtml */
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmekenum {
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek DNSSEC_DIGEST_SHA1 = 1,
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek DNSSEC_DIGEST_SHA256 = 2,
8eea868708923a092ee85d6146ba4c04b7baea06Zbigniew Jędrzejewski-Szmek _DNSSEC_DIGEST_MAX_DEFINED
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek};
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmekstruct DnsResourceKey {
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek unsigned n_ref;
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek uint16_t class, type;
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek char *_name; /* don't access directy, use DNS_RESOURCE_KEY_NAME()! */
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek bool cache_flush:1;
8eea868708923a092ee85d6146ba4c04b7baea06Zbigniew Jędrzejewski-Szmek};
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek/* Creates a temporary resource key. This is only useful to quickly
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek * look up something, without allocating a full DnsResourceKey object
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek * for it. Note that it is not OK to take references to this kind of
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek * resource key object. */
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek#define DNS_RESOURCE_KEY_CONST(c, t, n) \
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek ((DnsResourceKey) { \
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek .n_ref = (unsigned) -1, \
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek .class = c, \
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek .type = t, \
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek ._name = (char*) n, \
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek })
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmekstruct DnsTxtItem {
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek size_t length;
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek LIST_FIELDS(DnsTxtItem, items);
8eea868708923a092ee85d6146ba4c04b7baea06Zbigniew Jędrzejewski-Szmek uint8_t data[];
2968644080fd103062f070e83edd620e0a58c44dZbigniew Jędrzejewski-Szmek};
struct DnsResourceRecord {
unsigned n_ref;
DnsResourceKey *key;
uint32_t ttl;
bool unparseable:1;
bool wire_format_canonical:1;
void *wire_format;
size_t wire_format_size;
size_t wire_format_rdata_offset;
union {
struct {
void *data;
size_t size;
} generic, opt;
struct {
uint16_t priority;
uint16_t weight;
uint16_t port;
char *name;
} srv;
struct {
char *name;
} ptr, ns, cname, dname;
struct {
char *cpu;
char *os;
} hinfo;
struct {
DnsTxtItem *items;
} txt, spf;
struct {
struct in_addr in_addr;
} a;
struct {
struct in6_addr in6_addr;
} aaaa;
struct {
char *mname;
char *rname;
uint32_t serial;
uint32_t refresh;
uint32_t retry;
uint32_t expire;
uint32_t minimum;
} soa;
struct {
uint16_t priority;
char *exchange;
} mx;
struct {
uint8_t version;
uint8_t size;
uint8_t horiz_pre;
uint8_t vert_pre;
uint32_t latitude;
uint32_t longitude;
uint32_t altitude;
} loc;
struct {
uint16_t key_tag;
uint8_t algorithm;
uint8_t digest_type;
void *digest;
size_t digest_size;
} ds;
/* https://tools.ietf.org/html/rfc4255#section-3.1 */
struct {
uint8_t algorithm;
uint8_t fptype;
void *fingerprint;
size_t fingerprint_size;
} sshfp;
/* http://tools.ietf.org/html/rfc4034#section-2.1 */
struct {
uint16_t flags;
uint8_t protocol;
uint8_t algorithm;
void* key;
size_t key_size;
} dnskey;
/* http://tools.ietf.org/html/rfc4034#section-3.1 */
struct {
uint16_t type_covered;
uint8_t algorithm;
uint8_t labels;
uint32_t original_ttl;
uint32_t expiration;
uint32_t inception;
uint16_t key_tag;
char *signer;
void *signature;
size_t signature_size;
} rrsig;
/* https://tools.ietf.org/html/rfc4034#section-4.1 */
struct {
char *next_domain_name;
Bitmap *types;
} nsec;
struct {
uint8_t algorithm;
uint8_t flags;
uint16_t iterations;
void *salt;
size_t salt_size;
void *next_hashed_name;
size_t next_hashed_name_size;
Bitmap *types;
} nsec3;
};
};
static inline const char* DNS_RESOURCE_KEY_NAME(const DnsResourceKey *key) {
if (_unlikely_(!key))
return NULL;
if (key->_name)
return key->_name;
return (char*) key + sizeof(DnsResourceKey);
}
DnsResourceKey* dns_resource_key_new(uint16_t class, uint16_t type, const char *name);
DnsResourceKey* dns_resource_key_new_redirect(const DnsResourceKey *key, const DnsResourceRecord *cname);
int dns_resource_key_new_append_suffix(DnsResourceKey **ret, DnsResourceKey *key, char *name);
DnsResourceKey* dns_resource_key_new_consume(uint16_t class, uint16_t type, char *name);
DnsResourceKey* dns_resource_key_ref(DnsResourceKey *key);
DnsResourceKey* dns_resource_key_unref(DnsResourceKey *key);
bool dns_resource_key_is_address(const DnsResourceKey *key);
int dns_resource_key_equal(const DnsResourceKey *a, const DnsResourceKey *b);
int dns_resource_key_match_rr(const DnsResourceKey *key, const DnsResourceRecord *rr, const char *search_domain);
int dns_resource_key_match_cname(const DnsResourceKey *key, const DnsResourceRecord *rr, const char *search_domain);
int dns_resource_key_to_string(const DnsResourceKey *key, char **ret);
DEFINE_TRIVIAL_CLEANUP_FUNC(DnsResourceKey*, dns_resource_key_unref);
static inline bool dns_key_is_shared(const DnsResourceKey *key) {
return IN_SET(key->type, DNS_TYPE_PTR);
}
DnsResourceRecord* dns_resource_record_new(DnsResourceKey *key);
DnsResourceRecord* dns_resource_record_new_full(uint16_t class, uint16_t type, const char *name);
DnsResourceRecord* dns_resource_record_ref(DnsResourceRecord *rr);
DnsResourceRecord* dns_resource_record_unref(DnsResourceRecord *rr);
int dns_resource_record_new_reverse(DnsResourceRecord **ret, int family, const union in_addr_union *address, const char *name);
int dns_resource_record_new_address(DnsResourceRecord **ret, int family, const union in_addr_union *address, const char *name);
int dns_resource_record_equal(const DnsResourceRecord *a, const DnsResourceRecord *b);
int dns_resource_record_to_string(const DnsResourceRecord *rr, char **ret);
DEFINE_TRIVIAL_CLEANUP_FUNC(DnsResourceRecord*, dns_resource_record_unref);
int dns_resource_record_to_wire_format(DnsResourceRecord *rr, bool canonical);
DnsTxtItem *dns_txt_item_free_all(DnsTxtItem *i);
bool dns_txt_item_equal(DnsTxtItem *a, DnsTxtItem *b);
const char *dns_class_to_string(uint16_t type);
int dns_class_from_string(const char *name, uint16_t *class);
extern const struct hash_ops dns_resource_key_hash_ops;
const char* dnssec_algorithm_to_string(int i) _const_;
int dnssec_algorithm_from_string(const char *s) _pure_;
const char *dnssec_digest_to_string(int i) _const_;
int dnssec_digest_from_string(const char *s) _pure_;