OpenDNSSEC-signer 1.2.1
|
00001 /* 00002 * $Id: se_key.h 4294 2011-01-13 19:58:29Z 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_SE_KEY_H 00035 #define SIGNER_SE_KEY_H 00036 00037 #ifdef HAVE_SYS_TYPES_H 00038 # include <sys/types.h> 00039 #endif 00040 #ifdef HAVE_UNISTD_H 00041 # include <unistd.h> 00042 #endif 00043 #include <ldns/ldns.h> 00044 #include <libhsm.h> 00045 #include <libhsmdns.h> 00046 00051 typedef struct key_struct key_type; 00052 struct key_struct { 00053 const char* locator; 00054 ldns_rr* dnskey; 00055 hsm_key_t* hsmkey; 00056 hsm_sign_params_t* params; 00057 uint8_t algorithm; 00058 uint32_t flags; 00059 int publish; 00060 int ksk; 00061 int zsk; 00062 key_type* next; 00063 }; 00064 00069 typedef struct keylist_struct keylist_type; 00070 struct keylist_struct { 00071 size_t count; 00072 key_type* first_key; 00073 }; 00074 00086 key_type* key_create(const char* locator, uint8_t algorithm, uint32_t flags, 00087 int publish, int ksk, int zsk); 00088 00095 key_type* key_recover_from_backup(FILE* fd); 00096 00102 void key_cleanup(key_type* key); 00103 00110 void key_print(FILE* out, key_type* key); 00111 00117 keylist_type* keylist_create(void); 00118 00126 int keylist_add(keylist_type* kl, key_type* key); 00127 00135 int key_compare(key_type* a, key_type* b); 00136 00144 key_type* keylist_lookup(keylist_type* kl, const char* locator); 00145 00146 00154 int keylist_delete(keylist_type* kl, key_type* key); 00155 00163 int keylist_compare(keylist_type* a, keylist_type* b); 00164 00170 void keylist_cleanup(keylist_type* kl); 00171 00178 void keylist_print(FILE* out, keylist_type* kl); 00179 00180 #endif /* SIGNER_SE_KEY_H */