From c14f259ba2ebd7963c987af5811c8244c455317d Mon Sep 17 00:00:00 2001 From: Jacob Nevins Date: Sun, 30 Oct 2005 15:16:42 +0000 Subject: [PATCH] Allow rsakey_pubblob() to return the key comment. (like r6433 but for SSH-1) [originally from svn r6434] [r6433 == 49d2cf19accb059b3b68d1fc2b78e606a578c3e8] --- cmdgen.c | 3 ++- ssh.c | 3 ++- ssh.h | 2 +- sshpubk.c | 4 ++-- windows/winpgnt.c | 2 +- 5 files changed, 8 insertions(+), 6 deletions(-) diff --git a/cmdgen.c b/cmdgen.c index f84938e4..13c9ca13 100644 --- a/cmdgen.c +++ b/cmdgen.c @@ -690,7 +690,8 @@ int main(int argc, char **argv) char *blob; int n, l, bloblen; - ret = rsakey_pubblob(&infilename, &vblob, &bloblen, &error); + ret = rsakey_pubblob(&infilename, &vblob, &bloblen, NULL, + &error); blob = (char *)vblob; n = 4; /* skip modulus bits */ diff --git a/ssh.c b/ssh.c index b30d0265..5493191e 100644 --- a/ssh.c +++ b/ssh.c @@ -3256,7 +3256,8 @@ static int do_ssh1_login(Ssh ssh, unsigned char *in, int inlen, /* Load the public half of ssh->cfg.keyfile so we notice if it's in Pageant */ if (!filename_is_null(ssh->cfg.keyfile)) { if (!rsakey_pubblob(&ssh->cfg.keyfile, - &s->publickey_blob, &s->publickey_bloblen, NULL)) + &s->publickey_blob, &s->publickey_bloblen, + NULL, NULL)) s->publickey_blob = NULL; } else s->publickey_blob = NULL; diff --git a/ssh.h b/ssh.h index 61de0448..d0543cd9 100644 --- a/ssh.h +++ b/ssh.h @@ -383,7 +383,7 @@ int loadrsakey(const Filename *filename, struct RSAKey *key, char *passphrase, const char **errorstr); int rsakey_encrypted(const Filename *filename, char **comment); int rsakey_pubblob(const Filename *filename, void **blob, int *bloblen, - const char **errorstr); + char **commentptr, const char **errorstr); int saversakey(const Filename *filename, struct RSAKey *key, char *passphrase); diff --git a/sshpubk.c b/sshpubk.c index 923ebe9d..fddc6e56 100644 --- a/sshpubk.c +++ b/sshpubk.c @@ -225,7 +225,7 @@ int rsakey_encrypted(const Filename *filename, char **comment) * exponent, modulus). */ int rsakey_pubblob(const Filename *filename, void **blob, int *bloblen, - const char **errorstr) + char **commentptr, const char **errorstr) { FILE *fp; char buf[64]; @@ -250,7 +250,7 @@ int rsakey_pubblob(const Filename *filename, void **blob, int *bloblen, */ if (fgets(buf, sizeof(buf), fp) && !strcmp(buf, rsa_signature)) { memset(&key, 0, sizeof(key)); - if (loadrsakey_main(fp, &key, TRUE, NULL, NULL, &error)) { + if (loadrsakey_main(fp, &key, TRUE, commentptr, NULL, &error)) { *blob = rsa_public_blob(&key, bloblen); freersakey(&key); ret = 1; diff --git a/windows/winpgnt.c b/windows/winpgnt.c index d4463155..d4b445ba 100644 --- a/windows/winpgnt.c +++ b/windows/winpgnt.c @@ -415,7 +415,7 @@ static void add_keyfile(Filename filename) int i, nkeys, bloblen, keylistlen; if (type == SSH_KEYTYPE_SSH1) { - if (!rsakey_pubblob(&filename, &blob, &bloblen, &error)) { + if (!rsakey_pubblob(&filename, &blob, &bloblen, NULL, &error)) { char *msg = dupprintf("Couldn't load private key (%s)", error); message_box(msg, APPNAME, MB_OK | MB_ICONERROR, HELPCTXID(errors_cantloadkey));