1
0
mirror of https://git.tartarus.org/simon/putty.git synced 2025-01-10 01:48:00 +00:00

sshproxy: keep addr and free it on close.

The caller of new_connection has relinquished ownership of the
SockAddr it passes in. So the receiver of that SockAddr must remember
to free it, or else we leak memory.

(Additionally, this means SshProxy will be able to remember the
address during its run, e.g. to use in calls to its Plug. But that's
not implemented yet.)
This commit is contained in:
Simon Tatham 2021-09-12 09:52:46 +01:00
parent bff0c590e5
commit 80f5105dad

View File

@ -65,6 +65,8 @@ typedef struct SshProxy {
bufchain ssh_to_socket; bufchain ssh_to_socket;
bool rcvd_eof_ssh_to_socket, sent_eof_ssh_to_socket; bool rcvd_eof_ssh_to_socket, sent_eof_ssh_to_socket;
SockAddr *addr;
/* Traits implemented: we're a Socket from the point of view of /* Traits implemented: we're a Socket from the point of view of
* the client connection, and a Seat from the POV of the SSH * the client connection, and a Seat from the POV of the SSH
* backend we instantiate. */ * backend we instantiate. */
@ -86,6 +88,7 @@ static void sshproxy_close(Socket *s)
{ {
SshProxy *sp = container_of(s, SshProxy, sock); SshProxy *sp = container_of(s, SshProxy, sock);
sk_addr_free(sp->addr);
sfree(sp->errmsg); sfree(sp->errmsg);
conf_free(sp->conf); conf_free(sp->conf);
if (sp->backend) if (sp->backend)
@ -460,6 +463,8 @@ Socket *sshproxy_new_connection(SockAddr *addr, const char *hostname,
psb_init(&sp->psb); psb_init(&sp->psb);
bufchain_init(&sp->ssh_to_socket); bufchain_init(&sp->ssh_to_socket);
sp->addr = addr;
sp->conf = conf_new(); sp->conf = conf_new();
/* Try to treat proxy_hostname as the title of a saved session. If /* Try to treat proxy_hostname as the title of a saved session. If
* that fails, set up a default Conf of our own treating it as a * that fails, set up a default Conf of our own treating it as a