]> git.ipfire.org Git - thirdparty/systemd.git/blame - src/resolve/resolved-dns-trust-anchor.h
resolved: when validating, first strip revoked trust anchor keys from validated keys...
[thirdparty/systemd.git] / src / resolve / resolved-dns-trust-anchor.h
CommitLineData
0d2cd476
LP
1/*-*- Mode: C; c-basic-offset: 8; indent-tabs-mode: nil -*-*/
2
3#pragma once
4
5/***
6 This file is part of systemd.
7
8 Copyright 2015 Lennart Poettering
9
10 systemd is free software; you can redistribute it and/or modify it
11 under the terms of the GNU Lesser General Public License as published by
12 the Free Software Foundation; either version 2.1 of the License, or
13 (at your option) any later version.
14
15 systemd is distributed in the hope that it will be useful, but
16 WITHOUT ANY WARRANTY; without even the implied warranty of
17 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
18 Lesser General Public License for more details.
19
20 You should have received a copy of the GNU Lesser General Public License
21 along with systemd; If not, see <http://www.gnu.org/licenses/>.
22***/
23
24typedef struct DnsTrustAnchor DnsTrustAnchor;
25
26#include "hashmap.h"
27#include "resolved-dns-answer.h"
28#include "resolved-dns-rr.h"
29
30/* This contains a fixed database mapping domain names to DS or DNSKEY records. */
31
32struct DnsTrustAnchor {
8e54f5d9
LP
33 Hashmap *positive_by_key;
34 Set *negative_by_name;
c9c72065 35 Set *revoked_by_rr;
0d2cd476
LP
36};
37
38int dns_trust_anchor_load(DnsTrustAnchor *d);
39void dns_trust_anchor_flush(DnsTrustAnchor *d);
40
8e54f5d9
LP
41int dns_trust_anchor_lookup_positive(DnsTrustAnchor *d, const DnsResourceKey* key, DnsAnswer **answer);
42int dns_trust_anchor_lookup_negative(DnsTrustAnchor *d, const char *name);
0c857028 43
d424da2a 44int dns_trust_anchor_check_revoked(DnsTrustAnchor *d, DnsResourceRecord *dnskey, DnsAnswer *rrs);
c9c72065 45int dns_trust_anchor_is_revoked(DnsTrustAnchor *d, DnsResourceRecord *rr);