OpenDNSSEC-enforcer  1.3.8
/build/buildd/opendnssec-1.3.8/enforcer/enforcerd/enforcer.h
Go to the documentation of this file.
00001 /*
00002  * $Id: communicator.h 1663 2009-08-19 09:04:23Z sion $
00003  *
00004  * Copyright (c) 2008-2009 Nominet UK. 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 
00029 #ifndef ENFORCER_H
00030 #define ENFORCER_H
00031 
00032 /* 
00033  * communicator.h code implements the server_main
00034  * function needed by daemon.c
00035  *
00036  * The bit that makes the daemon do something useful
00037  */
00038 
00039 #include "ksm/ksm.h"
00040 #include "libhsm.h"
00041 
00042 int server_init(DAEMONCONFIG *config);
00043 void server_main(DAEMONCONFIG *config);
00044 
00045 int do_keygen(DAEMONCONFIG *config, KSM_POLICY* policy, hsm_ctx_t *ctx);
00046 int do_communication(DAEMONCONFIG *config, KSM_POLICY* policy);
00047 
00048 int commGenSignConf(char* zone_name, int zone_id, char* current_filename, KSM_POLICY *policy, int* signer_flag, int run_interval, int man_key_gen, const char* DSSubmitCmd);
00049 int commKeyConfig(void* context, KSM_KEYDATA* key_data);
00050 int allocateKeysToZone(KSM_POLICY *policy, int key_type, int zone_id, uint16_t interval, const char* zone_name, int man_key_gen, int rollover_scheme);
00051 int read_zonelist_filename(const char* filename, char** zone_list_filename);
00052 int do_purge(int interval, int policy_id);
00053 int NewDSSet(int zone_id, const char* zone_name, const char* DSSubmitCmd);
00054 void check_hsm_connection(hsm_ctx_t **ctx, DAEMONCONFIG *config);
00055 
00056 #endif /* ENFORCER_H */