OpenDNSSEC-signer 1.3.0rc3
|
00001 /* 00002 * $Id: keys.h 5227 2011-06-12 08:51:24Z jakob $ 00003 * 00004 * Copyright (c) 2009 NLNet Labs. All rights reserved. 00005 * 00006 * Redistribution and use in source and binary forms, with or without 00007 * modification, are permitted provided that the following conditions 00008 * are met: 00009 * 1. Redistributions of source code must retain the above copyright 00010 * notice, this list of conditions and the following disclaimer. 00011 * 2. Redistributions in binary form must reproduce the above copyright 00012 * notice, this list of conditions and the following disclaimer in the 00013 * documentation and/or other materials provided with the distribution. 00014 * 00015 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR 00016 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED 00017 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 00018 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY 00019 * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 00020 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE 00021 * GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 00022 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER 00023 * IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR 00024 * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN 00025 * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 00026 * 00027 */ 00028 00034 #ifndef SIGNER_KEYS_H 00035 #define SIGNER_KEYS_H 00036 00037 #include "shared/allocator.h" 00038 #include "shared/status.h" 00039 00040 #ifdef HAVE_SYS_TYPES_H 00041 # include <sys/types.h> 00042 #endif 00043 #ifdef HAVE_UNISTD_H 00044 # include <unistd.h> 00045 #endif 00046 #include <ldns/ldns.h> 00047 #include <libhsm.h> 00048 #include <libhsmdns.h> 00049 00050 00055 typedef struct key_struct key_type; 00056 struct key_struct { 00057 allocator_type* allocator; 00058 const char* locator; 00059 ldns_rr* dnskey; 00060 hsm_key_t* hsmkey; 00061 hsm_sign_params_t* params; 00062 uint8_t algorithm; 00063 uint32_t flags; 00064 int publish; 00065 int ksk; 00066 int zsk; 00067 key_type* next; 00068 }; 00069 00074 typedef struct keylist_struct keylist_type; 00075 struct keylist_struct { 00076 allocator_type* allocator; 00077 size_t count; 00078 key_type* first_key; 00079 }; 00080 00093 key_type* key_create(allocator_type* allocator, const char* locator, 00094 uint8_t algorithm, uint32_t flags, int publish, int ksk, int zsk); 00095 00103 key_type* key_recover(FILE* fd, allocator_type* allocator); 00104 00111 keylist_type* keylist_create(allocator_type* allocator); 00112 00120 ods_status keylist_push(keylist_type* kl, key_type* key); 00121 00129 key_type* keylist_lookup(keylist_type* kl, const char* locator); 00130 00138 key_type* keylist_lookup_by_dnskey(keylist_type* kl, ldns_rr* dnskey); 00139 00145 void keylist_cleanup(keylist_type* kl); 00146 00153 void keylist_print(FILE* fd, keylist_type* kl); 00154 00161 void keylist_backup(FILE* fd, keylist_type* kl); 00162 00169 void keylist_log(keylist_type* kl, const char* name); 00170 00171 #endif /* SIGNER_KEYS_H */