X-Git-Url: https://git.sommitrealweird.co.uk/onak.git/blobdiff_plain/cd002cef518222c140de94b8817874b072b2d918..8a1337cda8055ff06e54c1def4b13eea133c7672:/add.c diff --git a/add.c b/add.c index f90dd88..a33b0c8 100644 --- a/add.c +++ b/add.c @@ -4,8 +4,6 @@ * Jonathan McDowell * * Copyright 2002 Project Purple - * - * $Id: add.c,v 1.12 2004/03/23 12:33:46 noodles Exp $ */ #include @@ -14,6 +12,8 @@ #include #include "armor.h" +#include "cleankey.h" +#include "cleanup.h" #include "charfuncs.h" #include "getcgi.h" #include "keydb.h" @@ -23,15 +23,15 @@ #include "merge.h" #include "onak-conf.h" #include "parsekey.h" -#include "sendsync.h" int main(int argc, char *argv[]) { - struct openpgp_packet_list *packets = NULL; - struct openpgp_publickey *keys = NULL; - char **params = NULL; - struct buffer_ctx ctx; - int i; + struct openpgp_packet_list *packets = NULL; + struct openpgp_publickey *keys = NULL; + char **params = NULL; + struct buffer_ctx ctx; + int count = 0; + int i; memset(&ctx, 0, sizeof(ctx)); @@ -55,6 +55,7 @@ int main(int argc, char *argv[]) start_html("onak : Add"); if (ctx.buffer == NULL) { puts("Error: No keytext to add supplied."); + end_html(); } else { readconfig(NULL); initlogthing("add", config.logfile); @@ -62,22 +63,42 @@ int main(int argc, char *argv[]) &ctx, &packets); if (packets != NULL) { - parse_keys(packets, &keys); - initdb(false); - printf("Got %d new keys.\n", - update_keys(&keys)); + count = parse_keys(packets, &keys); + logthing(LOGTHING_NOTICE, "Received %d keys.", + count); + printf("Key block added to key server database.\n"); + printf(" New public keys added: %d\n", count); + end_html(); + if (stdout != NULL && fileno(stdout) != -1) { + fclose(stdout); + } + if (stderr != NULL && stderr != stdout && + fileno(stderr) != -1) { + fclose(stderr); + } + catchsignals(); + config.dbbackend->initdb(false); + + count = cleankeys(keys); + logthing(LOGTHING_INFO, "%d keys cleaned.", + count); + + count = config.dbbackend->update_keys(&keys, true); + logthing(LOGTHING_NOTICE, "Got %d new keys.", + count); + if (keys != NULL) { - sendkeysync(keys); free_publickey(keys); keys = NULL; } - cleanupdb(); + + config.dbbackend->cleanupdb(); } else { puts("No OpenPGP packets found in input."); + end_html(); } cleanuplogthing(); cleanupconfig(); } - end_html(); return (EXIT_SUCCESS); }