OpenDNSSEC-signer 1.2.1

/build/buildd-opendnssec_1.2.1.dfsg-1-mips-p9AT07/opendnssec-1.2.1.dfsg/signer/src/signer/se_key.h

Go to the documentation of this file.
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 */