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

Send ProxyNegotiator output even when pn->done is set.

This fixes the Telnet proxy, which was the only one of the proxy types
I forgot to test when I pushed the previous patch series, and
therefore, naturally, the one I left a bug in: if a ProxyNegotiator
returns both some output to be transmitted _and_ the 'done' flag, we
were forgetting to do anything with the former. So the proxy command
was being carefully constructed by TelnetProxyNegotiator, and then
promptly dropped on the floor by the owning ProxySocket.
This commit is contained in:
Simon Tatham 2021-11-19 16:36:29 +00:00
parent d8ecba71b7
commit 445bcd7030

View File

@ -209,24 +209,27 @@ static void proxy_negotiate(ProxySocket *ps)
{ {
assert(ps->pn); assert(ps->pn);
proxy_negotiator_process_queue(ps->pn); proxy_negotiator_process_queue(ps->pn);
if (ps->pn->done) {
proxy_activate(ps); if (ps->pn->error) {
} else if (ps->pn->error) {
char *err = dupprintf("Proxy error: %s", ps->pn->error); char *err = dupprintf("Proxy error: %s", ps->pn->error);
sfree(ps->pn->error); sfree(ps->pn->error);
proxy_negotiator_cleanup(ps); proxy_negotiator_cleanup(ps);
plug_closing_error(ps->plug, err); plug_closing_error(ps->plug, err);
sfree(err); sfree(err);
return;
} else if (ps->pn->aborted) { } else if (ps->pn->aborted) {
proxy_negotiator_cleanup(ps); proxy_negotiator_cleanup(ps);
plug_closing_user_abort(ps->plug); plug_closing_user_abort(ps->plug);
} else { return;
}
while (bufchain_size(&ps->output_from_negotiator)) { while (bufchain_size(&ps->output_from_negotiator)) {
ptrlen data = bufchain_prefix(&ps->output_from_negotiator); ptrlen data = bufchain_prefix(&ps->output_from_negotiator);
sk_write(ps->sub_socket, data.ptr, data.len); sk_write(ps->sub_socket, data.ptr, data.len);
bufchain_consume(&ps->output_from_negotiator, data.len); bufchain_consume(&ps->output_from_negotiator, data.len);
} }
} if (ps->pn->done)
proxy_activate(ps);
} }
static void plug_proxy_receive( static void plug_proxy_receive(