X-Git-Url: https://git.sommitrealweird.co.uk/onak.git/blobdiff_plain/e02c731dfbb288c736f2cd09a9b6df0507c59ddd..62c94dacbe471278972813b59776a5fadbd8a543:/parsekey.c diff --git a/parsekey.c b/parsekey.c index fbdde15..4ec7ef3 100644 --- a/parsekey.c +++ b/parsekey.c @@ -39,11 +39,16 @@ int add_key(struct openpgp_publickey *key) { * * This function takes an list of OpenPGP packets and attempts to parse it * into a list of public keys with signatures and subkeys. + * + * Returns a count of how many keys we parsed. */ int parse_keys(struct openpgp_packet_list *packets, struct openpgp_publickey **keys) { struct openpgp_publickey *curkey = NULL; + int count; + + count = 0; /* * If keys already has some keys in it then set curkey to the last one @@ -89,6 +94,7 @@ int parse_keys(struct openpgp_packet_list *packets, } memset(curkey, 0, sizeof(*curkey)); curkey->publickey = packet_dup(packets->packet); + count++; break; case 13: case 17: @@ -126,7 +132,7 @@ int parse_keys(struct openpgp_packet_list *packets, packets = packets->next; } - return 0; + return count; } /** @@ -254,14 +260,21 @@ int read_openpgp_stream(int (*getchar_func)(void *ctx, size_t count, break; case 3: fprintf(stderr, "Unsupported length type 3.\n"); + curpacket->packet->length = 0; + curpacket->packet->data = NULL; + rc = -1; break; } } - curpacket->packet->data = - malloc(curpacket->packet->length * + + if (rc == 0) { + curpacket->packet->data = + malloc(curpacket->packet->length * sizeof(unsigned char)); - rc = getchar_func(ctx, curpacket->packet->length, + rc = getchar_func(ctx, + curpacket->packet->length, curpacket->packet->data); + } inpacket = false; } else { fprintf(stderr, "Unexpected character: 0x%X\n",