/* This file is part of Pretty Curved Privacy (pcp1). Copyright (C) 2013 T.Linden. This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see . You can contact me by mail: . */ #include "keyprint.h" void pcptext_key(char *keyid) { pcp_key_t *s = pcpkey_exists(keyid); if(s != NULL) { if(debug) pcp_dumpkey(s); pcpkey_print(s, stdout); } else { pcp_pubkey_t *p = pcppubkey_exists(keyid); if(p != NULL) { if(debug) pcp_dumppubkey(p); pcppubkey_print(p, stdout); free(p); } else { fatal("No key with id 0x%s found!\n", keyid); } } } void pcptext_vault(vault_t *vault) { printf(" Key vault: %s\n", vault->filename); printf("Vault version: %08X\n", vault->version); printf(" Checksum: "); int i; for ( i = 0;i <15 ;++i) printf("%02X:",(unsigned int) vault->checksum[i]); printf("%02X", vault->checksum[15]); printf("\n "); for ( i = 16;i <31 ;++i) printf("%02X:",(unsigned int) vault->checksum[i]); printf("%02X", vault->checksum[31]); printf("\n"); printf(" Secret keys: %d\n", HASH_COUNT(pcpkey_hash)); printf(" Public keys: %d\n", HASH_COUNT(pcppubkey_hash)); } void pcpkey_printlineinfo(pcp_key_t *key) { struct tm *c; time_t t = (time_t)key->ctime; c = localtime(&t); printf("0x%s %s %04d-%02d-%02dT%02d:%02d:%02d %s <%s>\n", key->id, (key->type == PCP_KEY_TYPE_MAINSECRET) ? "primary" : " secret", c->tm_year+1900, c->tm_mon+1, c->tm_mday, c->tm_hour, c->tm_min, c->tm_sec, key->owner, key->mail); } void pcppubkey_printlineinfo(pcp_pubkey_t *key) { struct tm *c; time_t t = (time_t)key->ctime; c = localtime(&t); printf("0x%s public %04d-%02d-%02dT%02d:%02d:%02d %s <%s>\n", key->id, c->tm_year+1900, c->tm_mon+1, c->tm_mday, c->tm_hour, c->tm_min, c->tm_sec, key->owner, key->mail); } void pcpkey_print(pcp_key_t *key, FILE* out) { size_t zlen; key2be(key); char *z85encoded = pcp_z85_encode((unsigned char*)key, sizeof(pcp_key_t), &zlen); key2native(key); struct tm *c; time_t t = (time_t)key->ctime; c = localtime(&t); fprintf(out, "%s\n", PCP_KEY_HEADER); fprintf(out, " Generated by: %s Version %d.%d.%d\n", PCP_ME, PCP_VERSION_MAJOR, PCP_VERSION_MINOR, PCP_VERSION_PATCH); fprintf(out, " Cipher: %s\n", PCP_KEY_PRIMITIVE); fprintf(out, " Key-ID: 0x%s\n", key->id); //2004-06-14T23:34:30. fprintf(out, " Creation Time: %04d-%02d-%02dT%02d:%02d:%02d\n", c->tm_year+1900, c->tm_mon+1, c->tm_mday, c->tm_hour, c->tm_min, c->tm_sec); fprintf(out, " Serial Number: 0x%08X\n", key->serial); fprintf(out, " Key Version: 0x%08X\n", key->version); fprintf(out, "\n%s\n", z85encoded); fprintf(out, "%s\n", PCP_KEY_FOOTER); free(z85encoded); } void pcppubkey_print(pcp_pubkey_t *key, FILE* out) { size_t zlen; pubkey2be(key); char *z85encoded = pcp_z85_encode((unsigned char*)key, sizeof(pcp_pubkey_t), &zlen); pubkey2native(key); struct tm *c; time_t t = (time_t)key->ctime; c = localtime(&t); fprintf(out, "%s\n", PCP_PUBKEY_HEADER); fprintf(out, " Generated by: %s Version %d.%d.%d\n", PCP_ME, PCP_VERSION_MAJOR, PCP_VERSION_MINOR, PCP_VERSION_PATCH); fprintf(out, " Cipher: %s\n", PCP_KEY_PRIMITIVE); fprintf(out, " Owner: %s\n", key->owner); fprintf(out, " Mail: %s\n", key->mail); fprintf(out, " Key-ID: 0x%s\n", key->id); fprintf(out, " Public-Key: %s\n", pcp_z85_encode(key->public, 32, &zlen)); //2004-06-14T23:34:30. fprintf(out, " Creation Time: %04d-%02d-%02dT%02d:%02d:%02d\n", c->tm_year+1900, c->tm_mon+1, c->tm_mday, c->tm_hour, c->tm_min, c->tm_sec); unsigned char *hash = pcppubkey_getchecksum(key); fprintf(out, " Checksum: "); int i; for ( i = 0;i <15 ;++i) fprintf(out, "%02X:",(unsigned int) hash[i]); fprintf(out, "%02X", hash[15]); fprintf(out, "\n "); for ( i = 16;i <31 ;++i) fprintf(out, "%02X:",(unsigned int) hash[i]); fprintf(out, "%02X", hash[31]); fprintf(out, "\n"); fprintf(out, " Serial Number: 0x%08X\n", key->serial); fprintf(out, " Key Version: 0x%08X\n", key->version); char *r = pcppubkey_get_art(key); fprintf(out, " Random Art ID: "); for (i=0; ipublic[i]); printf("\n"); printf(" secret: "); for ( i = 0;i < 32;++i) printf("%02x",(unsigned int) k->secret[i]); printf("\n"); printf(" edpub: "); for ( i = 0;i < 32;++i) printf("%02x",(unsigned int) k->edpub[i]); printf("\n"); printf(" edsecret: "); for ( i = 0;i < 64;++i) printf("%02x",(unsigned int) k->edsecret[i]); printf("\n"); printf(" nonce: "); for ( i = 0;i < 24;++i) printf("%02x",(unsigned int) k->nonce[i]); printf("\n"); printf("encrypted: "); for ( i = 0;i < 80;++i) printf("%02x",(unsigned int) k->encrypted[i]); printf("\n"); printf(" owner: %s\n", k->owner); printf(" mail: %s\n", k->mail); printf(" id: %s\n", k->id); printf(" ctime: %ld\n", k->ctime); printf(" version: 0x%08X\n", k->version); printf(" serial: 0x%08X\n", k->serial); printf(" type: 0x%02X\n", k->type); } void pcp_dumppubkey(pcp_pubkey_t *k) { int i; printf("Dumping pcp_pubkey_t raw values:\n"); printf(" public: "); for ( i = 0;i < 32;++i) printf("%02x",(unsigned int) k->public[i]); printf("\n"); printf(" edpub: "); for ( i = 0;i < 32;++i) printf("%02x",(unsigned int) k->edpub[i]); printf("\n"); printf(" owner: %s\n", k->owner); printf(" mail: %s\n", k->mail); printf(" id: %s\n", k->id); printf(" ctime: %ld\n", k->ctime); printf(" version: 0x%08X\n", k->version); printf(" serial: 0x%08X\n", k->serial); printf(" type: 0x%02X\n", k->type); } void pcpkey_printshortinfo(pcp_key_t *key) { int i; printf(" Key-ID: 0x%s\n", key->id); printf(" Owner: %s\n", key->owner); char *r = pcpkey_get_art(key); printf(" Random Art ID: "); for (i=0; iid); printf(" Owner: %s\n", key->owner); char *r = pcppubkey_get_art(key); printf(" Random Art ID: "); for (i=0; ifilename); fprintf(out, "# Generated on: %04d-%02d-%02dT%02d:%02d:%02d\n", c->tm_year+1900, c->tm_mon+1, c->tm_mday, c->tm_hour, c->tm_min, c->tm_sec); fprintf(out, "---\n"); fprintf(out, "secret-keys:\n"); for(s=pcpkey_hash; s != NULL; s=(pcp_key_t*)(s->hh.next)) { fprintf(out, " -\n"); fprintf(out, " id: %s\n", s->id); fprintf(out, " owner: %s\n", s->owner); fprintf(out, " mail: %s\n", s->mail); fprintf(out, " ctime: %ld\n", s->ctime); fprintf(out, " version: %08x\n", s->version); fprintf(out, " serial: %08x\n", s->serial); fprintf(out, " type: %s\n", (s->type == PCP_KEY_TYPE_MAINSECRET) ? "primary" : " secret"); fprintf(out, " public: "); pcpprint_bin(out, s->public, 32); fprintf(out, "\n"); if(s->secret[0] == 0) { fprintf(out, " encrypted: yes\n"); fprintf(out, " nonce: "); pcpprint_bin(out, s->nonce, 24); fprintf(out, "\n"); fprintf(out, " secret: "); pcpprint_bin(out, s->encrypted, 80); fprintf(out, "\n"); } else { fprintf(out, " encrypted: no\n"); fprintf(out, " secret: "); pcpprint_bin(out, s->secret, 32); fprintf(out, "\n"); fprintf(out, " edsecret: "); pcpprint_bin(out, s->edsecret, 64); fprintf(out, "\n"); } fprintf(out, " edpub: "); pcpprint_bin(out, s->edpub, 32); fprintf(out, "\n"); } fprintf(out, "public-keys:\n"); for(p=pcppubkey_hash; p != NULL; p=(pcp_pubkey_t*)(p->hh.next)) { fprintf(out, " -\n"); fprintf(out, " id: %s\n", p->id); fprintf(out, " owner: %s\n", p->owner); fprintf(out, " mail: %s\n", p->mail); fprintf(out, " ctime: %ld\n", p->ctime); fprintf(out, " version: %08x\n", p->version); fprintf(out, " serial: %08x\n", p->serial); fprintf(out, " type: public\n"); fprintf(out, " public: "); pcpprint_bin(out, p->public, 32); fprintf(out, "\n"); fprintf(out, " edpub: "); pcpprint_bin(out, p->edpub, 32); fprintf(out, "\n"); } } } void pcpprint_bin(FILE *out, unsigned char *data, size_t len) { int i; for ( i = 0;i < len;++i) fprintf(out, "%02x", (unsigned int) data[i]); }