2 * keyindex.c - Routines to list an OpenPGP key.
4 * Copyright 2002-2008 Jonathan McDowell <noodles@earth.li>
14 #include "decodekey.h"
20 #include "keystructs.h"
22 #include "onak-conf.h"
24 int list_sigs(struct openpgp_packet_list *sigs, bool html)
30 while (sigs != NULL) {
31 sigid = sig_keyid(sigs->packet);
32 uid = config.dbbackend->keyid2uid(sigid);
33 if (sigs->packet->data[0] == 4 &&
34 sigs->packet->data[1] == 0x30) {
35 /* It's a Type 4 sig revocation */
40 if (html && uid != NULL) {
41 printf("%s <a href=\"lookup?op=get&"
42 "search=%016" PRIX64 "\">%08" PRIX64
44 "<a href=\"lookup?op=vindex&search=0x%016"
51 } else if (html && uid == NULL) {
52 printf("%s %08" PRIX64 " "
53 "[User id not found]\n",
57 printf("%s %08" PRIX64
62 "[User id not found]");
74 int list_uids(uint64_t keyid, struct openpgp_signedpacket_list *uids,
75 bool verbose, bool html)
80 while (uids != NULL) {
81 if (uids->packet->tag == 13) {
82 snprintf(buf, 1023, "%.*s",
83 (int) uids->packet->length,
86 (html) ? txt2html(buf) : buf);
87 } else if (uids->packet->tag == 17) {
90 printf("<img src=\"lookup?op=photo&search="
91 "0x%016" PRIX64 "&idx=%d\" alt=\""
97 printf("[photo id]\n");
101 list_sigs(uids->sigs, html);
109 int list_subkeys(struct openpgp_signedpacket_list *subkeys, bool verbose,
112 struct tm *created = NULL;
113 time_t created_time = 0;
117 while (subkeys != NULL) {
118 if (subkeys->packet->tag == 14) {
120 created_time = (subkeys->packet->data[1] << 24) +
121 (subkeys->packet->data[2] << 16) +
122 (subkeys->packet->data[3] << 8) +
123 subkeys->packet->data[4];
124 created = gmtime(&created_time);
126 switch (subkeys->packet->data[0]) {
129 type = subkeys->packet->data[7];
130 length = (subkeys->packet->data[8] << 8) +
131 subkeys->packet->data[9];
134 type = subkeys->packet->data[5];
135 length = (subkeys->packet->data[6] << 8) +
136 subkeys->packet->data[7];
139 logthing(LOGTHING_ERROR,
140 "Unknown key type: %d",
141 subkeys->packet->data[0]);
144 printf("sub %5d%c/%08X %04d/%02d/%02d\n",
146 (type == 1) ? 'R' : ((type == 16) ? 'g' :
147 ((type == 17) ? 'D' : '?')),
148 (uint32_t) (get_packetid(subkeys->packet) &
150 created->tm_year + 1900,
156 list_sigs(subkeys->sigs, html);
158 subkeys = subkeys->next;
164 void display_fingerprint(struct openpgp_publickey *key)
168 unsigned char fp[20];
170 get_fingerprint(key->publickey, fp, &length);
171 printf(" Key fingerprint =");
172 for (i = 0; i < length; i++) {
173 if ((length == 16) ||
177 printf("%02X", fp[i]);
178 if ((i * 2) == length) {
188 * key_index - List a set of OpenPGP keys.
189 * @keys: The keys to display.
190 * @verbose: Should we list sigs as well?
191 * @fingerprint: List the fingerprint?
192 * @html: Should the output be tailored for HTML?
194 * This function takes a list of OpenPGP public keys and displays an index
195 * of them. Useful for debugging or the keyserver Index function.
197 int key_index(struct openpgp_publickey *keys, bool verbose, bool fingerprint,
200 struct openpgp_signedpacket_list *curuid = NULL;
201 struct tm *created = NULL;
202 time_t created_time = 0;
212 puts("Type bits/keyID Date User ID");
213 while (keys != NULL) {
214 created_time = (keys->publickey->data[1] << 24) +
215 (keys->publickey->data[2] << 16) +
216 (keys->publickey->data[3] << 8) +
217 keys->publickey->data[4];
218 created = gmtime(&created_time);
220 switch (keys->publickey->data[0]) {
223 type = keys->publickey->data[7];
224 length = (keys->publickey->data[8] << 8) +
225 keys->publickey->data[9];
228 type = keys->publickey->data[5];
229 length = (keys->publickey->data[6] << 8) +
230 keys->publickey->data[7];
233 logthing(LOGTHING_ERROR, "Unknown key type: %d",
234 keys->publickey->data[0]);
237 keyid = get_keyid(keys);
258 printf("pub %5d%c/<a href=\"lookup?op=get&"
259 "search=%016" PRIX64 "\">%08" PRIX64
260 "</a> %04d/%02d/%02d ",
265 created->tm_year + 1900,
269 printf("pub %5d%c/%08" PRIX64 " %04d/%02d/%02d ",
273 created->tm_year + 1900,
279 if (curuid != NULL && curuid->packet->tag == 13) {
280 snprintf(buf, 1023, "%.*s",
281 (int) curuid->packet->length,
282 curuid->packet->data);
284 printf("<a href=\"lookup?op=vindex&"
285 "search=0x%016" PRIX64 "\">",
289 (html) ? txt2html(buf) : buf,
290 (html) ? "</a>" : "",
291 (keys->revoked) ? " *** REVOKED ***" : "");
293 display_fingerprint(keys);
296 list_sigs(curuid->sigs, html);
298 curuid = curuid->next;
301 (keys->revoked) ? "*** REVOKED ***": "");
303 display_fingerprint(keys);
307 list_uids(keyid, curuid, verbose, html);
309 list_subkeys(keys->subkeys, verbose, html);
323 * mrkey_index - List a set of OpenPGP keys in the MRHKP format.
324 * @keys: The keys to display.
326 * This function takes a list of OpenPGP public keys and displays a
327 * machine readable list of them.
329 int mrkey_index(struct openpgp_publickey *keys)
331 struct openpgp_signedpacket_list *curuid = NULL;
332 time_t created_time = 0;
337 unsigned char fp[20];
340 while (keys != NULL) {
341 created_time = (keys->publickey->data[1] << 24) +
342 (keys->publickey->data[2] << 16) +
343 (keys->publickey->data[3] << 8) +
344 keys->publickey->data[4];
348 switch (keys->publickey->data[0]) {
351 printf("%016" PRIX64, get_keyid(keys));
352 type = keys->publickey->data[7];
353 length = (keys->publickey->data[8] << 8) +
354 keys->publickey->data[9];
357 (void) get_fingerprint(keys->publickey, fp, &fplength);
359 for (i = 0; i < fplength; i++) {
360 printf("%02X", fp[i]);
363 type = keys->publickey->data[5];
364 length = (keys->publickey->data[6] << 8) +
365 keys->publickey->data[7];
368 logthing(LOGTHING_ERROR, "Unknown key type: %d",
369 keys->publickey->data[0]);
372 printf(":%d:%d:%ld::%s\n",
376 (keys->revoked) ? "r" : "");
378 for (curuid = keys->uids; curuid != NULL;
379 curuid = curuid->next) {
381 if (curuid->packet->tag == 13) {
383 for (i = 0; i < (int) curuid->packet->length;
385 c = curuid->packet->data[i];
389 } else if (c == ':' || c > 127) {