X-Git-Url: https://the.earth.li/gitweb/?a=blobdiff_plain;f=onak.c;h=f4ece8f2150b2eb9f0795a271e7edf98ffc8c55f;hb=a8c0920cce727a12697154a85896f2a3ba47eb75;hp=b7cfc80205a55e89184f738f12332267f2701f41;hpb=85187675424f3854869f1607afd8a1e84e536946;p=onak.git diff --git a/onak.c b/onak.c index b7cfc80..f4ece8f 100644 --- a/onak.c +++ b/onak.c @@ -387,9 +387,16 @@ int main(int argc, char *argv[]) puts("Key not found"); } } else if (!strcmp("delete", argv[optind])) { - dbctx->delete_key(dbctx, - dbctx->getfullkeyid(dbctx, keyid), - false); + if (!isfp) { + if (dbctx->fetch_key_id(dbctx, keyid, &keys, + false)) { + get_fingerprint(keys->publickey, + &fingerprint); + dbctx->delete_key(dbctx, &fingerprint, + false); + } + } else + dbctx->delete_key(dbctx, &fingerprint, false); } else if (!strcmp("get", argv[optind])) { if (!(ishex || isfp)) { puts("Can't get a key on uid text." @@ -448,7 +455,8 @@ int main(int argc, char *argv[]) } else if (!strcmp("reindex", argv[optind])) { dbctx->starttrans(dbctx); if (dbctx->fetch_key_id(dbctx, keyid, &keys, true)) { - dbctx->delete_key(dbctx, keyid, true); + get_fingerprint(keys->publickey, &fingerprint); + dbctx->delete_key(dbctx, &fingerprint, true); cleankeys(&keys, config.clean_policies); dbctx->store_key(dbctx, keys, true, false); } else {