OpenDNSSEC-signer  1.4.8.2
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_key_t* hsmkey;
57  hsm_sign_params_t* params;
58  const char* locator;
59  uint8_t algorithm;
60  uint32_t flags;
61  int publish;
62  int ksk;
63  int zsk;
64  int rfc5011;
65 };
66 
73  void* sc;
75  size_t count;
76 };
77 
84 keylist_type* keylist_create(void* sc);
85 
94 
103 
117 key_type* keylist_push(keylist_type* kl, const char* locator,
118  uint8_t algorithm, uint32_t flags, int publish, int ksk, int zsk,
119  int rfc5011);
120 
127 void keylist_print(FILE* fd, keylist_type* kl);
128 
135 void keylist_log(keylist_type* kl, const char* name);
136 
142 void keylist_cleanup(keylist_type* kl);
143 
151 key_type* key_recover2(FILE* fd, keylist_type* kl);
152 
160 void keylist_backup(FILE* fd, keylist_type* kl, const char* version);
161 
162 #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:61
int zsk
Definition: keys.h:63
void keylist_print(FILE *fd, keylist_type *kl)
Definition: keys.c:212
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:64
keylist_type * keylist_create(void *sc)
Definition: keys.c:47
const char * locator
Definition: keys.h:58
key_type * keys
Definition: keys.h:74
void keylist_backup(FILE *fd, keylist_type *kl, const char *version)
Definition: keys.c:353
void keylist_cleanup(keylist_type *kl)
Definition: keys.c:266
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:75
void * sc
Definition: keys.h:73
int ksk
Definition: keys.h:62
uint8_t algorithm
Definition: keys.h:59
hsm_sign_params_t * params
Definition: keys.h:57
void keylist_log(keylist_type *kl, const char *name)
Definition: keys.c:230
key_type * key_recover2(FILE *fd, keylist_type *kl)
Definition: keys.c:310
uint32_t flags
Definition: keys.h:60
hsm_key_t * hsmkey
Definition: keys.h:56