1
0
mirror of https://git.tartarus.org/simon/putty.git synced 2025-01-25 09:12:24 +00:00

PuTTY can now detect when one of the Pageant keys it tries matches

the private key file given in the config; if it spots this then it
avoids trying it again (and in particular avoids needing to ask for
the passphrase when it knows perfectly well it won't work).

[originally from svn r1523]
This commit is contained in:
Simon Tatham 2001-12-30 16:20:31 +00:00
parent cf356a9a5f
commit 2ce502eae2

27
ssh.c
View File

@ -1859,6 +1859,8 @@ static int do_ssh1_login(unsigned char *in, int inlen, int ispkt)
static unsigned char session_id[16]; static unsigned char session_id[16];
static int cipher_type; static int cipher_type;
static char username[100]; static char username[100];
static void *publickey_blob;
int publickey_bloblen;
crBegin; crBegin;
@ -2105,6 +2107,12 @@ static int do_ssh1_login(unsigned char *in, int inlen, int ispkt)
tried_publickey = 0; tried_publickey = 0;
tis_auth_refused = ccard_auth_refused = 0; tis_auth_refused = ccard_auth_refused = 0;
/* Load the public half of cfg.keyfile so we notice if it's in Pageant */
if (*cfg.keyfile) {
if (!rsakey_pubblob(cfg.keyfile, &publickey_blob, &publickey_bloblen))
publickey_blob = NULL;
} else
publickey_blob = NULL;
while (pktin.type == SSH1_SMSG_FAILURE) { while (pktin.type == SSH1_SMSG_FAILURE) {
static char password[100]; static char password[100];
@ -2152,6 +2160,11 @@ static int do_ssh1_login(unsigned char *in, int inlen, int ispkt)
sprintf(buf, "Trying Pageant key #%d", i); sprintf(buf, "Trying Pageant key #%d", i);
logevent(buf); logevent(buf);
} }
if (publickey_blob &&
!memcmp(p, publickey_blob, publickey_bloblen)) {
logevent("This key matches configured key file");
tried_publickey = 1;
}
p += 4; p += 4;
p += ssh1_read_bignum(p, &key.exponent); p += ssh1_read_bignum(p, &key.exponent);
p += ssh1_read_bignum(p, &key.modulus); p += ssh1_read_bignum(p, &key.modulus);
@ -3751,6 +3764,8 @@ static void do_ssh2_authconn(unsigned char *in, int inlen, int ispkt)
static char username[100]; static char username[100];
static char pwprompt[200]; static char pwprompt[200];
static char password[100]; static char password[100];
static void *publickey_blob;
static int publickey_bloblen;
crBegin; crBegin;
@ -3891,6 +3906,12 @@ static void do_ssh2_authconn(unsigned char *in, int inlen, int ispkt)
tried_agent = FALSE; tried_agent = FALSE;
tried_keyb_inter = FALSE; tried_keyb_inter = FALSE;
kbd_inter_running = FALSE; kbd_inter_running = FALSE;
/* Load the pub half of cfg.keyfile so we notice if it's in Pageant */
if (*cfg.keyfile) {
publickey_blob = ssh2_userkey_loadpub(cfg.keyfile, NULL,
&publickey_bloblen);
} else
publickey_blob = NULL;
while (1) { while (1) {
/* /*
@ -4046,6 +4067,12 @@ static void do_ssh2_authconn(unsigned char *in, int inlen, int ispkt)
} }
pklen = GET_32BIT(p); pklen = GET_32BIT(p);
p += 4; p += 4;
if (publickey_blob &&
pklen == publickey_bloblen &&
!memcmp(p, publickey_blob, publickey_bloblen)) {
logevent("This key matches configured key file");
tried_pubkey_config = 1;
}
pkblob = p; pkblob = p;
p += pklen; p += pklen;
alglen = GET_32BIT(pkblob); alglen = GET_32BIT(pkblob);