X-Git-Url: https://git.sommitrealweird.co.uk/onak.git/blobdiff_plain/8e58a1769ce5e492dd68904dfc81b6e077fc2a3a..5ba02c41963a4c4077a873a3c686a61cb84d56b7:/add.c?ds=inline diff --git a/add.c b/add.c index d820b52..f90dd88 100644 --- a/add.c +++ b/add.c @@ -4,6 +4,8 @@ * Jonathan McDowell * * Copyright 2002 Project Purple + * + * $Id: add.c,v 1.12 2004/03/23 12:33:46 noodles Exp $ */ #include @@ -12,37 +14,23 @@ #include #include "armor.h" +#include "charfuncs.h" #include "getcgi.h" #include "keydb.h" #include "keystructs.h" -#include "parsekey.h" +#include "log.h" +#include "mem.h" #include "merge.h" - -struct cgi_get_ctx { - char *buffer; - int offset; -}; - - -int cgi_getchar(void *ctx, size_t count, unsigned char *c) -{ - struct cgi_get_ctx *buf = NULL; - - buf = (struct cgi_get_ctx *) ctx; - - while (count-- > 0 && *c != 0) { - *c = buf->buffer[buf->offset++]; - } - - return (*c == 0); -} +#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 cgi_get_ctx ctx; + struct buffer_ctx ctx; int i; memset(&ctx, 0, sizeof(ctx)); @@ -51,27 +39,45 @@ int main(int argc, char *argv[]) for (i = 0; params != NULL && params[i] != NULL; i += 2) { if (!strcmp(params[i], "keytext")) { ctx.buffer = params[i+1]; + ctx.size = strlen(ctx.buffer); + } else { + free(params[i+1]); } + params[i+1] = NULL; + free(params[i]); + params[i] = NULL; + } + if (params != NULL) { + free(params); + params = NULL; } - puts("Content-Type: text/html\n"); - puts("onak : Add"); + start_html("onak : Add"); if (ctx.buffer == NULL) { puts("Error: No keytext to add supplied."); } else { - dearmor_openpgp_stream(cgi_getchar, + readconfig(NULL); + initlogthing("add", config.logfile); + dearmor_openpgp_stream(buffer_fetchchar, &ctx, &packets); if (packets != NULL) { parse_keys(packets, &keys); - initdb(); + initdb(false); printf("Got %d new keys.\n", update_keys(&keys)); + if (keys != NULL) { + sendkeysync(keys); + free_publickey(keys); + keys = NULL; + } cleanupdb(); } else { puts("No OpenPGP packets found in input."); } + cleanuplogthing(); + cleanupconfig(); } - puts(""); + end_html(); return (EXIT_SUCCESS); }