mirror of
https://git.tartarus.org/simon/putty.git
synced 2025-01-25 01:02:24 +00:00
7eb7d5e2e9
(TL;DR: to suppress redundant 'Press Return to begin session' prompts in between hops of a jump-host configuration, in Plink.) This new query method directly asks the Seat the question: is the same stream of input used to provide responses to interactive login prompts, and the session input provided after login concludes? It's used to suppress the last-ditch anti-spoofing defence in Plink of interactively asking 'Access granted. Press Return to begin session', on the basis that any such spoofing attack works by confusing the user about what's a legit login prompt before the session begins and what's sent by the server after the main session begins - so if those two things take input from different places, the user can't be confused. This doesn't change the existing behaviour of Plink, which was already suppressing the antispoof prompt in cases where its standard input was redirected from something other than a terminal. But previously it was doing it within the can_set_trust_status() seat query, and I've now moved it out into a separate query function. The reason why these need to be separate is for SshProxy, which needs to give an unusual combination of answers when run inside Plink. For can_set_trust_status(), it needs to return whatever the parent Seat returns, so that all the login prompts for a string of proxy connections in session will be antispoofed the same way. But you only want that final 'Access granted' prompt to happen _once_, after all the proxy connection setup phases are done, because up until then you're still in the safe hands of PuTTY itself presenting an unbroken sequence of legit login prompts (even if they come from a succession of different servers). Hence, SshProxy unconditionally returns 'no' to the query of whether it has a single mixed input stream, because indeed, it never does - for purposes of session input it behaves like an always-redirected Plink, no matter what kind of real Seat it ends up sending its pre-session login prompts to. |
||
---|---|---|
.. | ||
agentf.c | ||
bpp1.c | ||
bpp2.c | ||
bpp-bare.c | ||
bpp.h | ||
censor1.c | ||
censor2.c | ||
channel.h | ||
CMakeLists.txt | ||
common.c | ||
connection1-client.c | ||
connection1-server.c | ||
connection1.c | ||
connection1.h | ||
connection2-client.c | ||
connection2-server.c | ||
connection2.c | ||
connection2.h | ||
crc-attack-detector.c | ||
gss.h | ||
gssc.c | ||
gssc.h | ||
kex2-client.c | ||
kex2-server.c | ||
login1-server.c | ||
login1.c | ||
mainchan.c | ||
nogss.c | ||
nosharing.c | ||
pgssapi.c | ||
pgssapi.h | ||
portfwd.c | ||
ppl.h | ||
scpserver.c | ||
server.c | ||
server.h | ||
sesschan.c | ||
sftp.c | ||
sftp.h | ||
sftpcommon.c | ||
sftpserver.c | ||
sharing.c | ||
signal-list.h | ||
ssh.c | ||
transient-hostkey-cache.c | ||
transport2.c | ||
transport2.h | ||
ttymode-list.h | ||
userauth2-client.c | ||
userauth2-server.c | ||
verstring.c | ||
x11fwd.c | ||
zlib.c |