OpenDNSSEC-signer  1.4.10
keys.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_KEYS_H
33 #define SIGNER_KEYS_H
34 
35 #include "shared/allocator.h"
36 #include "shared/status.h"
37 
38 #ifdef HAVE_SYS_TYPES_H
39 # include <sys/types.h>
40 #endif
41 #ifdef HAVE_UNISTD_H
42 # include <unistd.h>
43 #endif
44 #include <ldns/ldns.h>
45 #include <libhsm.h>
46 #include <libhsmdns.h>
47 
48 
53 typedef struct key_struct key_type;
54 struct key_struct {
55  ldns_rr* dnskey;
56  hsm_sign_params_t* params;
57  const char* locator;
58  uint8_t algorithm;
59  uint32_t flags;
60  int publish;
61  int ksk;
62  int zsk;
63  int rfc5011;
64 };
65 
72  void* sc;
74  size_t count;
75 };
76 
83 keylist_type* keylist_create(void* sc);
84 
93 
102 
116 key_type* keylist_push(keylist_type* kl, const char* locator,
117  uint8_t algorithm, uint32_t flags, int publish, int ksk, int zsk,
118  int rfc5011);
119 
126 void keylist_print(FILE* fd, keylist_type* kl);
127 
134 void keylist_log(keylist_type* kl, const char* name);
135 
141 void keylist_cleanup(keylist_type* kl);
142 
150 key_type* key_recover2(FILE* fd, keylist_type* kl);
151 
159 void keylist_backup(FILE* fd, keylist_type* kl, const char* version);
160 
161 #endif /* SIGNER_KEYS_H */
key_type * keylist_lookup_by_dnskey(keylist_type *kl, ldns_rr *dnskey)
Definition: keys.c:96
int publish
Definition: keys.h:60
int zsk
Definition: keys.h:62
void keylist_print(FILE *fd, keylist_type *kl)
Definition: keys.c:211
ldns_rr * dnskey
Definition: keys.h:55
key_type * keylist_lookup_by_locator(keylist_type *kl, const char *locator)
Definition: keys.c:74
int rfc5011
Definition: keys.h:63
keylist_type * keylist_create(void *sc)
Definition: keys.c:47
const char * locator
Definition: keys.h:57
key_type * keys
Definition: keys.h:73
void keylist_backup(FILE *fd, keylist_type *kl, const char *version)
Definition: keys.c:351
void keylist_cleanup(keylist_type *kl)
Definition: keys.c:264
key_type * keylist_push(keylist_type *kl, const char *locator, uint8_t algorithm, uint32_t flags, int publish, int ksk, int zsk, int rfc5011)
Definition: keys.c:118
size_t count
Definition: keys.h:74
void * sc
Definition: keys.h:72
int ksk
Definition: keys.h:61
uint8_t algorithm
Definition: keys.h:58
hsm_sign_params_t * params
Definition: keys.h:56
void keylist_log(keylist_type *kl, const char *name)
Definition: keys.c:229
key_type * key_recover2(FILE *fd, keylist_type *kl)
Definition: keys.c:308
uint32_t flags
Definition: keys.h:59