OpenDNSSEC-enforcer
1.3.4
|
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 */