static void printcompatkey(int sockfd, zone_t* zone, key_data_t* key, char*tchange, hsm_key_t* hsmkey) { (void)hsmkey; client_printf(sockfd, "%-31s %-8s %-9s %s\n", zone_name(zone), key_data_role_text(key), map_keystate(key), tchange); }
static void printverboseparsablekey(int sockfd, zone_t* zone, key_data_t* key, char* tchange, hsm_key_t* hsmkey) { client_printf(sockfd, "%s;%s;%s;%s;%d;%d;%s;%s;%d\n", zone_name(zone), key_data_role_text(key), map_keystate(key), tchange, hsm_key_bits(hsmkey), hsm_key_algorithm(hsmkey), hsm_key_locator(hsmkey), hsm_key_repository(hsmkey), key_data_keytag(key)); }
static void print_zone(int sockfd, const char* fmt, const zone_t* zone) { key_data_list_t *keylist; const key_data_t *key; keylist = zone_get_keys(zone); while ((key = key_data_list_next(keylist))) { char *tchange = map_keytime(zone, key); client_printf(sockfd, fmt, zone_name(zone), key_data_role_text(key), tchange); free(tchange); } key_data_list_free(keylist); }
static void printdebugparsablekey(int sockfd, zone_t* zone, key_data_t* key, char* tchange, hsm_key_t* hsmkey) { (void)tchange; client_printf(sockfd, "%s;%s;%s;%s;%s;%s;%d;%d;%s\n", zone_name(zone), key_data_role_text(key), key_state_state_text(key_data_cached_ds(key)), key_state_state_text(key_data_cached_dnskey(key)), key_state_state_text(key_data_cached_rrsigdnskey(key)), key_state_state_text(key_data_cached_rrsig(key)), key_data_publish(key), key_data_active_ksk(key) | key_data_active_zsk(key), hsm_key_locator(hsmkey)); }
static void printverbosekey(int sockfd, zone_t* zone, key_data_t* key, char* tchange, hsm_key_t* hsmkey) { (void)tchange; client_printf(sockfd, "%-31s %-8s %-9s %-24s %-5d %-10d %-32s %-11s %d\n", zone_name(zone), key_data_role_text(key), map_keystate(key), tchange, hsm_key_bits(hsmkey), hsm_key_algorithm(hsmkey), hsm_key_locator(hsmkey), hsm_key_repository(hsmkey), key_data_keytag(key)); }
static int delete_key_data(zone_db_t* zone, db_connection_t *dbconn, int sockfd) { int successful; key_data_list_t* key_data_list; key_data_t* key_data; key_state_list_t* key_state_list; key_state_t* key_state; /* * Get key data for the zone and for each key data get the key state * and try to delete all key state then the key data */ if (!(key_data_list = key_data_list_new_get_by_zone_id(dbconn, zone_db_id(zone)))) { client_printf_err(sockfd, "Unable to get key data for zone %s from database!\n", zone_db_name(zone)); return 0; } successful = 1; for (key_data = key_data_list_get_next(key_data_list); key_data; key_data_free(key_data), key_data = key_data_list_get_next(key_data_list)) { if (!(key_state_list = key_state_list_new_get_by_key_data_id(dbconn, key_data_id(key_data)))) { client_printf_err(sockfd, "Unable to get key states for key data %s of zone %s from database!\n", key_data_role_text(key_data), zone_db_name(zone)); successful = 0; continue; } for (key_state = key_state_list_get_next(key_state_list); key_state; key_state_free(key_state), key_state = key_state_list_get_next(key_state_list)) { if (key_state_delete(key_state)) { client_printf_err(sockfd, "Unable to delete key state %s for key data %s of zone %s from database!\n", key_state_type_text(key_state), key_data_role_text(key_data), zone_db_name(zone)); successful = 0; continue; } } key_state_list_free(key_state_list); if (key_data_delete(key_data)) { client_printf_err(sockfd, "Unable to delete key data %s of zone %s from database!\n", key_data_role_text(key_data), zone_db_name(zone)); successful = 0; continue; } if (hsm_key_factory_release_key_id(key_data_hsm_key_id(key_data), dbconn)) { client_printf_err(sockfd, "Unable to release HSM key for key data %s of zone %s from database!\n", key_data_role_text(key_data), zone_db_name(zone)); successful = 0; continue; } } key_data_list_free(key_data_list); return successful; }
static int perform_keystate_list(int sockfd, db_connection_t *dbconn, const char* filterZone, char** filterKeytype, char** filterKeystate, void (printheader)(int sockfd), void (printkey)(int sockfd, zone_t* zone, key_data_t* key, char*tchange, hsm_key_t* hsmKey)) { key_data_list_t* key_list; key_data_t* key; zone_t *zone = NULL; char* tchange; hsm_key_t *hsmkey; int cmp; int i, skipPrintKey; if (!(key_list = key_data_list_new_get(dbconn))) { client_printf_err(sockfd, "Unable to get list of keys, memory " "allocation or database error!\n"); return 1; } if (printheader) { (*printheader)(sockfd); } while ((key = key_data_list_get_next(key_list))) { /* only refetches zone if different from previous */ if (zone && (db_value_cmp(zone_id(zone), key_data_zone_id(key), &cmp) || cmp)) { zone_free(zone); zone = NULL; } if (!zone) { zone = key_data_get_zone(key); } hsmkey = key_data_get_hsm_key(key); key_data_cache_key_states(key); tchange = map_keytime(zone, key); /* allocs */ skipPrintKey = 0; if(printkey == NULL) skipPrintKey = 1; if(filterZone != NULL && strcmp(zone_name(zone), filterZone)) skipPrintKey = 1; for(i=0; filterKeytype && filterKeytype[i]; i++) if(!strcasecmp(filterKeytype[i],key_data_role_text(key))) break; if(filterKeytype && filterKeytype[i] == NULL) skipPrintKey = 1; for(i=0; filterKeystate && filterKeystate[i]; i++) if(!strcasecmp(filterKeystate[i],map_keystate(key))) break; if(filterKeystate && filterKeystate[i] == NULL) skipPrintKey = 1; if (!skipPrintKey) { (*printkey)(sockfd, zone, key, tchange, hsmkey); } free(tchange); hsm_key_free(hsmkey); key_data_free(key); } zone_free(zone); key_data_list_free(key_list); return 0; }