mirror of
https://git.tartarus.org/simon/putty.git
synced 2025-01-25 09:12:24 +00:00
Pass the Ssh structure to portfwd.c with a tag.
Again, safer than using a 'void *'.
This commit is contained in:
parent
3814a5cee8
commit
c51fe7c217
1
defs.h
1
defs.h
@ -47,6 +47,7 @@ typedef struct Plug_vtable Plug_vtable;
|
|||||||
typedef struct Ldisc_tag Ldisc;
|
typedef struct Ldisc_tag Ldisc;
|
||||||
typedef struct LogContext_tag LogContext;
|
typedef struct LogContext_tag LogContext;
|
||||||
|
|
||||||
|
typedef struct ssh_tag *Ssh;
|
||||||
/* Note indirection: for historical reasons (it used to be closer to
|
/* Note indirection: for historical reasons (it used to be closer to
|
||||||
* the OS socket type), the type that most code uses for a socket is
|
* the OS socket type), the type that most code uses for a socket is
|
||||||
* 'Socket', not 'Socket *'. So an implementation of Socket or Plug
|
* 'Socket', not 'Socket *'. So an implementation of Socket or Plug
|
||||||
|
18
portfwd.c
18
portfwd.c
@ -23,8 +23,8 @@ typedef enum {
|
|||||||
|
|
||||||
struct PortForwarding {
|
struct PortForwarding {
|
||||||
struct ssh_channel *c; /* channel structure held by ssh.c */
|
struct ssh_channel *c; /* channel structure held by ssh.c */
|
||||||
void *backhandle; /* instance of SSH backend itself */
|
Ssh ssh; /* instance of SSH backend itself */
|
||||||
/* Note that backhandle need not be filled in if c is non-NULL */
|
/* Note that ssh need not be filled in if c is non-NULL */
|
||||||
Socket s;
|
Socket s;
|
||||||
int throttled, throttle_override;
|
int throttled, throttle_override;
|
||||||
int ready;
|
int ready;
|
||||||
@ -47,7 +47,7 @@ struct PortForwarding {
|
|||||||
};
|
};
|
||||||
|
|
||||||
struct PortListener {
|
struct PortListener {
|
||||||
void *backhandle; /* instance of SSH backend itself */
|
Ssh ssh; /* instance of SSH backend itself */
|
||||||
Socket s;
|
Socket s;
|
||||||
int is_dynamic;
|
int is_dynamic;
|
||||||
/*
|
/*
|
||||||
@ -396,7 +396,7 @@ static void pfd_receive(Plug plug, int urgent, char *data, int len)
|
|||||||
*/
|
*/
|
||||||
sk_set_frozen(pf->s, 1);
|
sk_set_frozen(pf->s, 1);
|
||||||
|
|
||||||
pf->c = new_sock_channel(pf->backhandle, pf);
|
pf->c = new_sock_channel(pf->ssh, pf);
|
||||||
if (pf->c == NULL) {
|
if (pf->c == NULL) {
|
||||||
pfd_close(pf);
|
pfd_close(pf);
|
||||||
return;
|
return;
|
||||||
@ -464,7 +464,7 @@ char *pfd_connect(struct PortForwarding **pf_ret, char *hostname,int port,
|
|||||||
pf->throttled = pf->throttle_override = 0;
|
pf->throttled = pf->throttle_override = 0;
|
||||||
pf->ready = 1;
|
pf->ready = 1;
|
||||||
pf->c = c;
|
pf->c = c;
|
||||||
pf->backhandle = NULL; /* we shouldn't need this */
|
pf->ssh = NULL; /* we shouldn't need this */
|
||||||
pf->socks_state = SOCKS_NONE;
|
pf->socks_state = SOCKS_NONE;
|
||||||
|
|
||||||
pf->s = new_connection(addr, dummy_realhost, port,
|
pf->s = new_connection(addr, dummy_realhost, port,
|
||||||
@ -497,7 +497,7 @@ static int pfl_accepting(Plug p, accept_fn_t constructor, accept_ctx_t ctx)
|
|||||||
pf->plugvt = &PortForwarding_plugvt;
|
pf->plugvt = &PortForwarding_plugvt;
|
||||||
|
|
||||||
pf->c = NULL;
|
pf->c = NULL;
|
||||||
pf->backhandle = pl->backhandle;
|
pf->ssh = pl->ssh;
|
||||||
|
|
||||||
pf->s = s = constructor(ctx, &pf->plugvt);
|
pf->s = s = constructor(ctx, &pf->plugvt);
|
||||||
if ((err = sk_socket_error(s)) != NULL) {
|
if ((err = sk_socket_error(s)) != NULL) {
|
||||||
@ -518,7 +518,7 @@ static int pfl_accepting(Plug p, accept_fn_t constructor, accept_ctx_t ctx)
|
|||||||
pf->socks_state = SOCKS_NONE;
|
pf->socks_state = SOCKS_NONE;
|
||||||
pf->hostname = dupstr(pl->hostname);
|
pf->hostname = dupstr(pl->hostname);
|
||||||
pf->port = pl->port;
|
pf->port = pl->port;
|
||||||
pf->c = new_sock_channel(pl->backhandle, pf);
|
pf->c = new_sock_channel(pl->ssh, pf);
|
||||||
|
|
||||||
if (pf->c == NULL) {
|
if (pf->c == NULL) {
|
||||||
free_portfwd_state(pf);
|
free_portfwd_state(pf);
|
||||||
@ -547,7 +547,7 @@ static const Plug_vtable PortListener_plugvt = {
|
|||||||
* dynamically allocated error message string.
|
* dynamically allocated error message string.
|
||||||
*/
|
*/
|
||||||
char *pfl_listen(char *desthost, int destport, char *srcaddr,
|
char *pfl_listen(char *desthost, int destport, char *srcaddr,
|
||||||
int port, void *backhandle, Conf *conf,
|
int port, Ssh ssh, Conf *conf,
|
||||||
struct PortListener **pl_ret, int address_family)
|
struct PortListener **pl_ret, int address_family)
|
||||||
{
|
{
|
||||||
const char *err;
|
const char *err;
|
||||||
@ -564,7 +564,7 @@ char *pfl_listen(char *desthost, int destport, char *srcaddr,
|
|||||||
pl->is_dynamic = FALSE;
|
pl->is_dynamic = FALSE;
|
||||||
} else
|
} else
|
||||||
pl->is_dynamic = TRUE;
|
pl->is_dynamic = TRUE;
|
||||||
pl->backhandle = backhandle;
|
pl->ssh = ssh;
|
||||||
|
|
||||||
pl->s = new_listener(srcaddr, port, &pl->plugvt,
|
pl->s = new_listener(srcaddr, port, &pl->plugvt,
|
||||||
!conf_get_int(conf, CONF_lport_acceptall),
|
!conf_get_int(conf, CONF_lport_acceptall),
|
||||||
|
3
ssh.c
3
ssh.c
@ -11293,9 +11293,8 @@ static void ssh_special(void *handle, Telnet_Special code)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void *new_sock_channel(void *handle, struct PortForwarding *pf)
|
void *new_sock_channel(Ssh ssh, struct PortForwarding *pf)
|
||||||
{
|
{
|
||||||
Ssh ssh = (Ssh) handle;
|
|
||||||
struct ssh_channel *c;
|
struct ssh_channel *c;
|
||||||
c = snew(struct ssh_channel);
|
c = snew(struct ssh_channel);
|
||||||
|
|
||||||
|
5
ssh.h
5
ssh.h
@ -8,7 +8,6 @@
|
|||||||
#include "misc.h"
|
#include "misc.h"
|
||||||
|
|
||||||
struct ssh_channel;
|
struct ssh_channel;
|
||||||
typedef struct ssh_tag *Ssh;
|
|
||||||
|
|
||||||
extern int sshfwd_write(struct ssh_channel *c, const void *, int);
|
extern int sshfwd_write(struct ssh_channel *c, const void *, int);
|
||||||
extern void sshfwd_write_eof(struct ssh_channel *c);
|
extern void sshfwd_write_eof(struct ssh_channel *c);
|
||||||
@ -666,7 +665,7 @@ void logevent(void *, const char *);
|
|||||||
struct PortForwarding;
|
struct PortForwarding;
|
||||||
|
|
||||||
/* Allocate and register a new channel for port forwarding */
|
/* Allocate and register a new channel for port forwarding */
|
||||||
void *new_sock_channel(void *handle, struct PortForwarding *pf);
|
void *new_sock_channel(Ssh ssh, struct PortForwarding *pf);
|
||||||
void ssh_send_port_open(void *channel, const char *hostname, int port,
|
void ssh_send_port_open(void *channel, const char *hostname, int port,
|
||||||
const char *org);
|
const char *org);
|
||||||
|
|
||||||
@ -682,7 +681,7 @@ extern void pfd_override_throttle(struct PortForwarding *, int enable);
|
|||||||
struct PortListener;
|
struct PortListener;
|
||||||
/* desthost == NULL indicates dynamic (SOCKS) port forwarding */
|
/* desthost == NULL indicates dynamic (SOCKS) port forwarding */
|
||||||
extern char *pfl_listen(char *desthost, int destport, char *srcaddr,
|
extern char *pfl_listen(char *desthost, int destport, char *srcaddr,
|
||||||
int port, void *backhandle, Conf *conf,
|
int port, Ssh ssh, Conf *conf,
|
||||||
struct PortListener **pl, int address_family);
|
struct PortListener **pl, int address_family);
|
||||||
extern void pfl_terminate(struct PortListener *);
|
extern void pfl_terminate(struct PortListener *);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user