mirror of
https://git.tartarus.org/simon/putty.git
synced 2025-01-25 09:12:24 +00:00
Slight change to password expiry UI for the benefit of Cisco servers, which
are as usual slightly odd. [originally from svn r6845]
This commit is contained in:
parent
16510bf3b9
commit
e67b9cfd78
38
ssh.c
38
ssh.c
@ -7497,6 +7497,21 @@ static void do_ssh2_authconn(Ssh ssh, unsigned char *in, int inlen,
|
|||||||
s->cur_prompt->instruction =
|
s->cur_prompt->instruction =
|
||||||
dupprintf("%.*s", prompt_len, prompt);
|
dupprintf("%.*s", prompt_len, prompt);
|
||||||
s->cur_prompt->instr_reqd = TRUE;
|
s->cur_prompt->instr_reqd = TRUE;
|
||||||
|
/*
|
||||||
|
* There's no explicit requirement in the protocol
|
||||||
|
* for the "old" passwords in the original and
|
||||||
|
* password-change messages to be the same, and
|
||||||
|
* apparently some Cisco kit supports password change
|
||||||
|
* by the user entering a blank password originally
|
||||||
|
* and the real password subsequently, so,
|
||||||
|
* reluctantly, we prompt for the old password again.
|
||||||
|
*
|
||||||
|
* (On the other hand, some servers don't even bother
|
||||||
|
* to check this field.)
|
||||||
|
*/
|
||||||
|
add_prompt(s->cur_prompt,
|
||||||
|
dupstr("Current password (blank for previously entered password): "),
|
||||||
|
FALSE, SSH_MAX_PASSWORD_LEN);
|
||||||
add_prompt(s->cur_prompt, dupstr("Enter new password: "),
|
add_prompt(s->cur_prompt, dupstr("Enter new password: "),
|
||||||
FALSE, SSH_MAX_PASSWORD_LEN);
|
FALSE, SSH_MAX_PASSWORD_LEN);
|
||||||
add_prompt(s->cur_prompt, dupstr("Confirm new password: "),
|
add_prompt(s->cur_prompt, dupstr("Confirm new password: "),
|
||||||
@ -7530,10 +7545,25 @@ static void do_ssh2_authconn(Ssh ssh, unsigned char *in, int inlen,
|
|||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Check the two passwords match.
|
* If the user specified a new original password
|
||||||
|
* (IYSWIM), overwrite any previously specified
|
||||||
|
* one.
|
||||||
|
* (A side effect is that the user doesn't have to
|
||||||
|
* re-enter it if they louse up the new password.)
|
||||||
*/
|
*/
|
||||||
got_new = (strcmp(s->cur_prompt->prompts[0]->result,
|
if (s->cur_prompt->prompts[0]->result[0]) {
|
||||||
s->cur_prompt->prompts[1]->result)
|
memset(s->password, 0, strlen(s->password));
|
||||||
|
/* burn the evidence */
|
||||||
|
sfree(s->password);
|
||||||
|
s->password =
|
||||||
|
dupstr(s->cur_prompt->prompts[0]->result);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Check the two new passwords match.
|
||||||
|
*/
|
||||||
|
got_new = (strcmp(s->cur_prompt->prompts[1]->result,
|
||||||
|
s->cur_prompt->prompts[2]->result)
|
||||||
== 0);
|
== 0);
|
||||||
if (!got_new)
|
if (!got_new)
|
||||||
/* They don't. Silly user. */
|
/* They don't. Silly user. */
|
||||||
@ -7555,7 +7585,7 @@ static void do_ssh2_authconn(Ssh ssh, unsigned char *in, int inlen,
|
|||||||
dont_log_password(ssh, s->pktout, PKTLOG_BLANK);
|
dont_log_password(ssh, s->pktout, PKTLOG_BLANK);
|
||||||
ssh2_pkt_addstring(s->pktout, s->password);
|
ssh2_pkt_addstring(s->pktout, s->password);
|
||||||
ssh2_pkt_addstring(s->pktout,
|
ssh2_pkt_addstring(s->pktout,
|
||||||
s->cur_prompt->prompts[0]->result);
|
s->cur_prompt->prompts[1]->result);
|
||||||
free_prompts(s->cur_prompt);
|
free_prompts(s->cur_prompt);
|
||||||
end_log_omission(ssh, s->pktout);
|
end_log_omission(ssh, s->pktout);
|
||||||
ssh2_pkt_send(ssh, s->pktout);
|
ssh2_pkt_send(ssh, s->pktout);
|
||||||
|
Loading…
Reference in New Issue
Block a user