X-Git-Url: http://the.earth.li/gitweb/?a=blobdiff_plain;f=add.c;h=a784fac358fb4d9565c84dfb274734b2c61d89df;hb=8b4052ad6015aa9f54c9c824f28655f230d09d8d;hp=f65203c3a06b906486686e8c131f8a2f093aeade;hpb=556f51f104fbbb5bd0d51b61a18d7e5af2759079;p=onak.git diff --git a/add.c b/add.c index f65203c..a784fac 100644 --- a/add.c +++ b/add.c @@ -12,10 +12,12 @@ #include #include "armor.h" +#include "cleankey.h" #include "charfuncs.h" #include "getcgi.h" #include "keydb.h" #include "keystructs.h" +#include "log.h" #include "mem.h" #include "merge.h" #include "onak-conf.h" @@ -24,11 +26,12 @@ 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)); @@ -52,16 +55,29 @@ 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); dearmor_openpgp_stream(buffer_fetchchar, &ctx, &packets); if (packets != NULL) { - parse_keys(packets, &keys); - readconfig(); - initdb(); - printf("Got %d new keys.\n", - update_keys(&keys, false)); + printf("Storing %d keys.\n", + parse_keys(packets, &keys)); + end_html(); + fclose(stdout); + fclose(stderr); + initdb(false); + + count = cleankeys(keys); + logthing(LOGTHING_INFO, "%d keys cleaned.", + count); + + count = update_keys(&keys); + printf("Got %d new keys.\n", count); + logthing(LOGTHING_NOTICE, "Got %d new keys.", + count); if (keys != NULL) { sendkeysync(keys); free_publickey(keys); @@ -70,8 +86,10 @@ int main(int argc, char *argv[]) cleanupdb(); } else { puts("No OpenPGP packets found in input."); + end_html(); } + cleanuplogthing(); + cleanupconfig(); } - end_html(); return (EXIT_SUCCESS); }