mirror of
https://git.tartarus.org/simon/putty.git
synced 2025-01-09 17:38:00 +00:00
Add ability for ssh2_userkey_loadpub() to return the key comment.
(Not actually used currently, but it makes life easier for a patch I'm working on.) [originally from svn r6433]
This commit is contained in:
parent
69ac38c1a8
commit
49d2cf19ac
2
cmdgen.c
2
cmdgen.c
@ -722,7 +722,7 @@ int main(int argc, char **argv)
|
||||
case SSH_KEYTYPE_SSH2:
|
||||
if (!load_encrypted) {
|
||||
ssh2blob = ssh2_userkey_loadpub(&infilename, &ssh2alg,
|
||||
&ssh2bloblen, &error);
|
||||
&ssh2bloblen, NULL, &error);
|
||||
ssh2algf = find_pubkey_alg(ssh2alg);
|
||||
if (ssh2algf)
|
||||
bits = ssh2algf->pubkey_bits(ssh2blob, ssh2bloblen);
|
||||
|
4
ssh.c
4
ssh.c
@ -6640,7 +6640,7 @@ static void do_ssh2_authconn(Ssh ssh, unsigned char *in, int inlen,
|
||||
if (keytype == SSH_KEYTYPE_SSH2) {
|
||||
s->publickey_blob =
|
||||
ssh2_userkey_loadpub(&ssh->cfg.keyfile, NULL,
|
||||
&s->publickey_bloblen, NULL);
|
||||
&s->publickey_bloblen, NULL, NULL);
|
||||
} else {
|
||||
char *msgbuf;
|
||||
logeventf(ssh, "Unable to use this key file (%s)",
|
||||
@ -6982,7 +6982,7 @@ static void do_ssh2_authconn(Ssh ssh, unsigned char *in, int inlen,
|
||||
(unsigned char *)ssh2_userkey_loadpub(&ssh->cfg.keyfile,
|
||||
&algorithm,
|
||||
&pub_blob_len,
|
||||
NULL);
|
||||
NULL, NULL);
|
||||
if (pub_blob) {
|
||||
s->pktout = ssh2_pkt_init(SSH2_MSG_USERAUTH_REQUEST);
|
||||
ssh2_pkt_addstring(s->pktout, s->username);
|
||||
|
3
ssh.h
3
ssh.h
@ -400,7 +400,8 @@ int ssh2_userkey_encrypted(const Filename *filename, char **comment);
|
||||
struct ssh2_userkey *ssh2_load_userkey(const Filename *filename,
|
||||
char *passphrase, const char **errorstr);
|
||||
char *ssh2_userkey_loadpub(const Filename *filename, char **algorithm,
|
||||
int *pub_blob_len, const char **errorstr);
|
||||
int *pub_blob_len, char **commentptr,
|
||||
const char **errorstr);
|
||||
int ssh2_save_userkey(const Filename *filename, struct ssh2_userkey *key,
|
||||
char *passphrase);
|
||||
const struct ssh_signkey *find_pubkey_alg(const char *name);
|
||||
|
12
sshpubk.c
12
sshpubk.c
@ -866,7 +866,8 @@ struct ssh2_userkey *ssh2_load_userkey(const Filename *filename,
|
||||
}
|
||||
|
||||
char *ssh2_userkey_loadpub(const Filename *filename, char **algorithm,
|
||||
int *pub_blob_len, const char **errorstr)
|
||||
int *pub_blob_len, char **commentptr,
|
||||
const char **errorstr)
|
||||
{
|
||||
FILE *fp;
|
||||
char header[40], *b;
|
||||
@ -875,6 +876,7 @@ char *ssh2_userkey_loadpub(const Filename *filename, char **algorithm,
|
||||
int public_blob_len;
|
||||
int i;
|
||||
const char *error = NULL;
|
||||
char *comment;
|
||||
|
||||
public_blob = NULL;
|
||||
|
||||
@ -912,9 +914,13 @@ char *ssh2_userkey_loadpub(const Filename *filename, char **algorithm,
|
||||
/* Read the Comment header line. */
|
||||
if (!read_header(fp, header) || 0 != strcmp(header, "Comment"))
|
||||
goto error;
|
||||
if ((b = read_body(fp)) == NULL)
|
||||
if ((comment = read_body(fp)) == NULL)
|
||||
goto error;
|
||||
sfree(b); /* we don't care */
|
||||
|
||||
if (commentptr)
|
||||
*commentptr = comment;
|
||||
else
|
||||
sfree(comment);
|
||||
|
||||
/* Read the Public-Lines header line and the public blob. */
|
||||
if (!read_header(fp, header) || 0 != strcmp(header, "Public-Lines"))
|
||||
|
@ -425,7 +425,8 @@ static void add_keyfile(Filename filename)
|
||||
keylist = get_keylist1(&keylistlen);
|
||||
} else {
|
||||
unsigned char *blob2;
|
||||
blob = ssh2_userkey_loadpub(&filename, NULL, &bloblen, &error);
|
||||
blob = ssh2_userkey_loadpub(&filename, NULL, &bloblen,
|
||||
NULL, &error);
|
||||
if (!blob) {
|
||||
char *msg = dupprintf("Couldn't load private key (%s)", error);
|
||||
message_box(msg, APPNAME, MB_OK | MB_ICONERROR,
|
||||
|
Loading…
Reference in New Issue
Block a user