mirror of
https://git.tartarus.org/simon/putty.git
synced 2025-01-25 09:12:24 +00:00
do_ssh1_login: remove user input parameters.
This is the first refactoring of a major coroutine enabled by adding the ssh->user_input queue. Now, instead of receiving a fixed block of parameter data, do_ssh1_login reads directly from the user input bufchain. In particular, I can get rid of all the temporary bufchains I constructed to pass to get_userpass_input (or rather, the ones in this particular function), because now we can let get_userpass_input read directly from the main user_input bufchain, and it will read only as much data as it has an interest in, and leave the rest as type-ahead for future prompts or the main session.
This commit is contained in:
parent
c3abc30405
commit
265365ab80
50
ssh.c
50
ssh.c
@ -384,8 +384,7 @@ static void ssh2_pkt_addmp(struct Packet *, Bignum b);
|
|||||||
static int ssh2_pkt_construct(Ssh, struct Packet *);
|
static int ssh2_pkt_construct(Ssh, struct Packet *);
|
||||||
static void ssh2_pkt_send(Ssh, struct Packet *);
|
static void ssh2_pkt_send(Ssh, struct Packet *);
|
||||||
static void ssh2_pkt_send_noqueue(Ssh, struct Packet *);
|
static void ssh2_pkt_send_noqueue(Ssh, struct Packet *);
|
||||||
static int do_ssh1_login(Ssh ssh, const unsigned char *in, int inlen,
|
static int do_ssh1_login(Ssh ssh, struct Packet *pktin);
|
||||||
struct Packet *pktin);
|
|
||||||
static void do_ssh2_authconn(Ssh ssh, const unsigned char *in, int inlen,
|
static void do_ssh2_authconn(Ssh ssh, const unsigned char *in, int inlen,
|
||||||
struct Packet *pktin);
|
struct Packet *pktin);
|
||||||
static void ssh_channel_init(struct ssh_channel *c);
|
static void ssh_channel_init(struct ssh_channel *c);
|
||||||
@ -3953,7 +3952,7 @@ static void ssh_agent_callback(void *sshv, void *reply, int replylen)
|
|||||||
ssh->agent_response_len = replylen;
|
ssh->agent_response_len = replylen;
|
||||||
|
|
||||||
if (ssh->version == 1)
|
if (ssh->version == 1)
|
||||||
do_ssh1_login(ssh, NULL, -1, NULL);
|
do_ssh1_login(ssh, NULL);
|
||||||
else
|
else
|
||||||
do_ssh2_authconn(ssh, NULL, -1, NULL);
|
do_ssh2_authconn(ssh, NULL, -1, NULL);
|
||||||
}
|
}
|
||||||
@ -3965,7 +3964,7 @@ static void ssh_dialog_callback(void *sshv, int ret)
|
|||||||
ssh->user_response = ret;
|
ssh->user_response = ret;
|
||||||
|
|
||||||
if (ssh->version == 1)
|
if (ssh->version == 1)
|
||||||
do_ssh1_login(ssh, NULL, -1, NULL);
|
do_ssh1_login(ssh, NULL);
|
||||||
else
|
else
|
||||||
do_ssh2_transport(ssh, NULL, -1, NULL);
|
do_ssh2_transport(ssh, NULL, -1, NULL);
|
||||||
|
|
||||||
@ -4199,8 +4198,7 @@ int verify_ssh_manual_host_key(Ssh ssh, const char *fingerprint,
|
|||||||
/*
|
/*
|
||||||
* Handle the key exchange and user authentication phases.
|
* Handle the key exchange and user authentication phases.
|
||||||
*/
|
*/
|
||||||
static int do_ssh1_login(Ssh ssh, const unsigned char *in, int inlen,
|
static int do_ssh1_login(Ssh ssh, struct Packet *pktin)
|
||||||
struct Packet *pktin)
|
|
||||||
{
|
{
|
||||||
int i, j, ret;
|
int i, j, ret;
|
||||||
unsigned char *ptr;
|
unsigned char *ptr;
|
||||||
@ -4338,6 +4336,7 @@ static int do_ssh1_login(Ssh ssh, const unsigned char *in, int inlen,
|
|||||||
s->dlgret = 1;
|
s->dlgret = 1;
|
||||||
#endif
|
#endif
|
||||||
if (s->dlgret < 0) {
|
if (s->dlgret < 0) {
|
||||||
|
ssh->user_response = -1;
|
||||||
do {
|
do {
|
||||||
crReturn(0);
|
crReturn(0);
|
||||||
if (pktin) {
|
if (pktin) {
|
||||||
@ -4345,7 +4344,7 @@ static int do_ssh1_login(Ssh ssh, const unsigned char *in, int inlen,
|
|||||||
" for user host key response"));
|
" for user host key response"));
|
||||||
crStop(0);
|
crStop(0);
|
||||||
}
|
}
|
||||||
} while (pktin || inlen > 0);
|
} while (ssh->user_response < 0);
|
||||||
s->dlgret = ssh->user_response;
|
s->dlgret = ssh->user_response;
|
||||||
}
|
}
|
||||||
ssh_set_frozen(ssh, 0);
|
ssh_set_frozen(ssh, 0);
|
||||||
@ -4424,6 +4423,7 @@ static int do_ssh1_login(Ssh ssh, const unsigned char *in, int inlen,
|
|||||||
s->dlgret = askalg(ssh->frontend, "cipher", cipher_string,
|
s->dlgret = askalg(ssh->frontend, "cipher", cipher_string,
|
||||||
ssh_dialog_callback, ssh);
|
ssh_dialog_callback, ssh);
|
||||||
if (s->dlgret < 0) {
|
if (s->dlgret < 0) {
|
||||||
|
ssh->user_response = -1;
|
||||||
do {
|
do {
|
||||||
crReturn(0);
|
crReturn(0);
|
||||||
if (pktin) {
|
if (pktin) {
|
||||||
@ -4431,7 +4431,7 @@ static int do_ssh1_login(Ssh ssh, const unsigned char *in, int inlen,
|
|||||||
" for user response"));
|
" for user response"));
|
||||||
crStop(0);
|
crStop(0);
|
||||||
}
|
}
|
||||||
} while (pktin || inlen > 0);
|
} while (ssh->user_response < 0);
|
||||||
s->dlgret = ssh->user_response;
|
s->dlgret = ssh->user_response;
|
||||||
}
|
}
|
||||||
ssh_set_frozen(ssh, 0);
|
ssh_set_frozen(ssh, 0);
|
||||||
@ -4511,13 +4511,9 @@ static int do_ssh1_login(Ssh ssh, const unsigned char *in, int inlen,
|
|||||||
add_prompt(s->cur_prompt, dupstr("login as: "), TRUE);
|
add_prompt(s->cur_prompt, dupstr("login as: "), TRUE);
|
||||||
ret = get_userpass_input(s->cur_prompt, NULL);
|
ret = get_userpass_input(s->cur_prompt, NULL);
|
||||||
while (ret < 0) {
|
while (ret < 0) {
|
||||||
bufchain tmp_user_input;
|
|
||||||
ssh->send_ok = 1;
|
ssh->send_ok = 1;
|
||||||
crWaitUntil(!pktin);
|
crWaitUntil(!pktin);
|
||||||
bufchain_init(&tmp_user_input);
|
ret = get_userpass_input(s->cur_prompt, &ssh->user_input);
|
||||||
bufchain_add(&tmp_user_input, in, inlen);
|
|
||||||
ret = get_userpass_input(s->cur_prompt, &tmp_user_input);
|
|
||||||
bufchain_clear(&tmp_user_input);
|
|
||||||
ssh->send_ok = 0;
|
ssh->send_ok = 0;
|
||||||
}
|
}
|
||||||
if (!ret) {
|
if (!ret) {
|
||||||
@ -4619,6 +4615,7 @@ static int do_ssh1_login(Ssh ssh, const unsigned char *in, int inlen,
|
|||||||
ssh->auth_agent_query = agent_query(
|
ssh->auth_agent_query = agent_query(
|
||||||
s->request, 5, &r, &s->responselen, ssh_agent_callback, ssh);
|
s->request, 5, &r, &s->responselen, ssh_agent_callback, ssh);
|
||||||
if (ssh->auth_agent_query) {
|
if (ssh->auth_agent_query) {
|
||||||
|
ssh->agent_response = NULL;
|
||||||
do {
|
do {
|
||||||
crReturn(0);
|
crReturn(0);
|
||||||
if (pktin) {
|
if (pktin) {
|
||||||
@ -4626,7 +4623,7 @@ static int do_ssh1_login(Ssh ssh, const unsigned char *in, int inlen,
|
|||||||
" for agent response"));
|
" for agent response"));
|
||||||
crStop(0);
|
crStop(0);
|
||||||
}
|
}
|
||||||
} while (pktin || inlen > 0);
|
} while (!ssh->agent_response);
|
||||||
r = ssh->agent_response;
|
r = ssh->agent_response;
|
||||||
s->responselen = ssh->agent_response_len;
|
s->responselen = ssh->agent_response_len;
|
||||||
}
|
}
|
||||||
@ -4728,6 +4725,7 @@ static int do_ssh1_login(Ssh ssh, const unsigned char *in, int inlen,
|
|||||||
ssh_agent_callback, ssh);
|
ssh_agent_callback, ssh);
|
||||||
if (ssh->auth_agent_query) {
|
if (ssh->auth_agent_query) {
|
||||||
sfree(agentreq);
|
sfree(agentreq);
|
||||||
|
ssh->agent_response = NULL;
|
||||||
do {
|
do {
|
||||||
crReturn(0);
|
crReturn(0);
|
||||||
if (pktin) {
|
if (pktin) {
|
||||||
@ -4736,7 +4734,7 @@ static int do_ssh1_login(Ssh ssh, const unsigned char *in, int inlen,
|
|||||||
" response"));
|
" response"));
|
||||||
crStop(0);
|
crStop(0);
|
||||||
}
|
}
|
||||||
} while (pktin || inlen > 0);
|
} while (!ssh->agent_response);
|
||||||
vret = ssh->agent_response;
|
vret = ssh->agent_response;
|
||||||
retlen = ssh->agent_response_len;
|
retlen = ssh->agent_response_len;
|
||||||
} else
|
} else
|
||||||
@ -4822,14 +4820,10 @@ static int do_ssh1_login(Ssh ssh, const unsigned char *in, int inlen,
|
|||||||
s->publickey_comment), FALSE);
|
s->publickey_comment), FALSE);
|
||||||
ret = get_userpass_input(s->cur_prompt, NULL);
|
ret = get_userpass_input(s->cur_prompt, NULL);
|
||||||
while (ret < 0) {
|
while (ret < 0) {
|
||||||
bufchain tmp_user_input;
|
|
||||||
ssh->send_ok = 1;
|
ssh->send_ok = 1;
|
||||||
crWaitUntil(!pktin);
|
crWaitUntil(!pktin);
|
||||||
bufchain_init(&tmp_user_input);
|
|
||||||
bufchain_add(&tmp_user_input, in, inlen);
|
|
||||||
ret = get_userpass_input(s->cur_prompt,
|
ret = get_userpass_input(s->cur_prompt,
|
||||||
&tmp_user_input);
|
&ssh->user_input);
|
||||||
bufchain_clear(&tmp_user_input);
|
|
||||||
ssh->send_ok = 0;
|
ssh->send_ok = 0;
|
||||||
}
|
}
|
||||||
if (!ret) {
|
if (!ret) {
|
||||||
@ -5047,13 +5041,9 @@ static int do_ssh1_login(Ssh ssh, const unsigned char *in, int inlen,
|
|||||||
int ret; /* need not be kept over crReturn */
|
int ret; /* need not be kept over crReturn */
|
||||||
ret = get_userpass_input(s->cur_prompt, NULL);
|
ret = get_userpass_input(s->cur_prompt, NULL);
|
||||||
while (ret < 0) {
|
while (ret < 0) {
|
||||||
bufchain tmp_user_input;
|
|
||||||
ssh->send_ok = 1;
|
ssh->send_ok = 1;
|
||||||
crWaitUntil(!pktin);
|
crWaitUntil(!pktin);
|
||||||
bufchain_init(&tmp_user_input);
|
ret = get_userpass_input(s->cur_prompt, &ssh->user_input);
|
||||||
bufchain_add(&tmp_user_input, in, inlen);
|
|
||||||
ret = get_userpass_input(s->cur_prompt, &tmp_user_input);
|
|
||||||
bufchain_clear(&tmp_user_input);
|
|
||||||
ssh->send_ok = 0;
|
ssh->send_ok = 0;
|
||||||
}
|
}
|
||||||
if (!ret) {
|
if (!ret) {
|
||||||
@ -6275,13 +6265,7 @@ static void ssh_msg_ignore(Ssh ssh, struct Packet *pktin)
|
|||||||
|
|
||||||
static void ssh1_login_input(Ssh ssh)
|
static void ssh1_login_input(Ssh ssh)
|
||||||
{
|
{
|
||||||
while (bufchain_size(&ssh->user_input) > 0) {
|
do_ssh1_login(ssh, NULL);
|
||||||
void *data;
|
|
||||||
int len;
|
|
||||||
bufchain_prefix(&ssh->user_input, &data, &len);
|
|
||||||
do_ssh1_login(ssh, data, len, NULL);
|
|
||||||
bufchain_consume(&ssh->user_input, len);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void ssh1_connection_input(Ssh ssh)
|
static void ssh1_connection_input(Ssh ssh)
|
||||||
@ -6299,7 +6283,7 @@ static void ssh1_coro_wrapper_session(Ssh ssh, struct Packet *pktin);
|
|||||||
|
|
||||||
static void ssh1_coro_wrapper_initial(Ssh ssh, struct Packet *pktin)
|
static void ssh1_coro_wrapper_initial(Ssh ssh, struct Packet *pktin)
|
||||||
{
|
{
|
||||||
if (do_ssh1_login(ssh, NULL, 0, pktin)) {
|
if (do_ssh1_login(ssh, pktin)) {
|
||||||
int i;
|
int i;
|
||||||
for (i = 0; i < 256; i++)
|
for (i = 0; i < 256; i++)
|
||||||
if (ssh->packet_dispatch[i] == ssh1_coro_wrapper_initial)
|
if (ssh->packet_dispatch[i] == ssh1_coro_wrapper_initial)
|
||||||
|
Loading…
Reference in New Issue
Block a user