OpenDNSSEC-signer  1.4.5
namedb.h
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2009 NLNet Labs. All rights reserved.
3  *
4  * Redistribution and use in source and binary forms, with or without
5  * modification, are permitted provided that the following conditions
6  * are met:
7  * 1. Redistributions of source code must retain the above copyright
8  * notice, this list of conditions and the following disclaimer.
9  * 2. Redistributions in binary form must reproduce the above copyright
10  * notice, this list of conditions and the following disclaimer in the
11  * documentation and/or other materials provided with the distribution.
12  *
13  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
14  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
15  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
16  * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
17  * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
18  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE
19  * GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
20  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER
21  * IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
22  * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
23  * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
24  *
25  */
26 
32 #ifndef SIGNER_NAMEDB_H
33 #define SIGNER_NAMEDB_H
34 
35 #include "config.h"
36 #include "signer/denial.h"
37 #include "signer/domain.h"
38 #include "signer/nsec3params.h"
39 
40 #include <ldns/ldns.h>
41 
46 typedef struct namedb_struct namedb_type;
47 struct namedb_struct {
48  void* zone;
49  ldns_rbtree_t* domains;
50  ldns_rbtree_t* denials;
51  uint32_t inbserial;
52  uint32_t intserial;
53  uint32_t outserial;
54  uint32_t altserial;
55  unsigned is_initialized : 1;
56  unsigned is_processed : 1;
57  unsigned serial_updated : 1;
58  unsigned force_serial : 1;
59  unsigned have_serial : 1;
60 };
61 
68 
75 namedb_type* namedb_create(void* zone);
76 
86 ods_status namedb_update_serial(namedb_type* db, const char* zone_name,
87  const char* format, uint32_t inbound_serial);
88 
98  ldns_rdf* apex);
99 
107 domain_type* namedb_lookup_domain(namedb_type* db, ldns_rdf* dname);
108 
116 domain_type* namedb_add_domain(namedb_type* db, ldns_rdf* dname);
117 
126 
134 denial_type* namedb_lookup_denial(namedb_type* db, ldns_rdf* dname);
135 
144 denial_type* namedb_add_denial(namedb_type* db, ldns_rdf* dname,
145  nsec3params_type* n3p);
146 
155 
163 
171 void namedb_diff(namedb_type* db, unsigned is_ixfr, unsigned more_coming);
172 
179 void namedb_rollback(namedb_type* db, unsigned keepsc);
180 
187 void namedb_nsecify(namedb_type* db, uint32_t* num_added);
188 
196 void namedb_export(FILE* fd, namedb_type* db, ods_status* status);
197 
204 
211 
217 void namedb_cleanup(namedb_type* db);
218 
225 void namedb_backup2(FILE* fd, namedb_type* db);
226 
227 #endif /* SIGNER_NAMEDB_H */