X-Git-Url: http://the.earth.li/gitweb/?a=blobdiff_plain;f=onak.c;h=3a4c4e8d01ecc3ac952e69dbdfcdb68fdc0f76a1;hb=42d43e0ec08e249cecf74ec448cb6405b3c89d84;hp=0fdb7e4bf7510456cd9498422b808cc4e773201b;hpb=1d268f8b7df33d0985b63f7f99b9e3ed597a9982;p=onak.git diff --git a/onak.c b/onak.c index 0fdb7e4..3a4c4e8 100644 --- a/onak.c +++ b/onak.c @@ -7,7 +7,7 @@ * * Copyright 2002 Project Purple * - * $Id: onak.c,v 1.19 2004/03/23 12:33:47 noodles Exp $ + * $Id: onak.c,v 1.20 2004/05/27 01:25:37 noodles Exp $ */ #include @@ -26,6 +26,7 @@ #include "merge.h" #include "onak-conf.h" #include "parsekey.h" +#include "photoid.h" void find_keys(char *search, uint64_t keyid, bool ishex, bool fingerprint, bool exact, bool verbose) @@ -173,6 +174,27 @@ int main(int argc, char *argv[]) } else if (!strcmp("vindex", argv[optind])) { find_keys(search, keyid, ishex, fingerprint, false, true); + } else if (!strcmp("getphoto", argv[optind])) { + if (!ishex) { + puts("Can't get a key on uid text." + " You must supply a keyid."); + } else if (fetch_key(keyid, &keys, false)) { + struct openpgp_packet *photo = NULL; + FILE *photof = NULL; + photo = getphoto(keys, 0); + if (photo != NULL) { + photof = fopen("keyphoto.jpg", "w"); + fwrite(photo->data+19, + 1, + (photo->length - 19), + photof); + fclose(photof); + } + free_publickey(keys); + keys = NULL; + } else { + puts("Key not found"); + } } else if (!strcmp("delete", argv[optind])) { delete_key(getfullkeyid(keyid), false); } else if (!strcmp("get", argv[optind])) {