- djm@cvs.openbsd.org 2011/06/22 22:08:42
[channels.c channels.h clientloop.c clientloop.h mux.c ssh.c] hook up a channel confirm callback to warn the user then requested X11 forwarding was refused by the server; ok markus@
This commit is contained in:
parent
69ff1df952
commit
6d7b4377dd
|
@ -23,6 +23,10 @@
|
||||||
so please start testing it now.
|
so please start testing it now.
|
||||||
|
|
||||||
feedback dtucker@; ok markus@
|
feedback dtucker@; ok markus@
|
||||||
|
- djm@cvs.openbsd.org 2011/06/22 22:08:42
|
||||||
|
[channels.c channels.h clientloop.c clientloop.h mux.c ssh.c]
|
||||||
|
hook up a channel confirm callback to warn the user then requested X11
|
||||||
|
forwarding was refused by the server; ok markus@
|
||||||
|
|
||||||
20110620
|
20110620
|
||||||
- OpenBSD CVS Sync
|
- OpenBSD CVS Sync
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
/* $OpenBSD: channels.c,v 1.310 2010/11/24 01:24:14 djm Exp $ */
|
/* $OpenBSD: channels.c,v 1.311 2011/06/22 22:08:42 djm Exp $ */
|
||||||
/*
|
/*
|
||||||
* Author: Tatu Ylonen <ylo@cs.hut.fi>
|
* Author: Tatu Ylonen <ylo@cs.hut.fi>
|
||||||
* Copyright (c) 1995 Tatu Ylonen <ylo@cs.hut.fi>, Espoo, Finland
|
* Copyright (c) 1995 Tatu Ylonen <ylo@cs.hut.fi>, Espoo, Finland
|
||||||
|
@ -3562,7 +3562,7 @@ deny_input_open(int type, u_int32_t seq, void *ctxt)
|
||||||
*/
|
*/
|
||||||
void
|
void
|
||||||
x11_request_forwarding_with_spoofing(int client_session_id, const char *disp,
|
x11_request_forwarding_with_spoofing(int client_session_id, const char *disp,
|
||||||
const char *proto, const char *data)
|
const char *proto, const char *data, int want_reply)
|
||||||
{
|
{
|
||||||
u_int data_len = (u_int) strlen(data) / 2;
|
u_int data_len = (u_int) strlen(data) / 2;
|
||||||
u_int i, value;
|
u_int i, value;
|
||||||
|
@ -3615,7 +3615,7 @@ x11_request_forwarding_with_spoofing(int client_session_id, const char *disp,
|
||||||
|
|
||||||
/* Send the request packet. */
|
/* Send the request packet. */
|
||||||
if (compat20) {
|
if (compat20) {
|
||||||
channel_request_start(client_session_id, "x11-req", 0);
|
channel_request_start(client_session_id, "x11-req", want_reply);
|
||||||
packet_put_char(0); /* XXX bool single connection */
|
packet_put_char(0); /* XXX bool single connection */
|
||||||
} else {
|
} else {
|
||||||
packet_start(SSH_CMSG_X11_REQUEST_FORWARDING);
|
packet_start(SSH_CMSG_X11_REQUEST_FORWARDING);
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
/* $OpenBSD: channels.h,v 1.104 2010/05/14 23:29:23 djm Exp $ */
|
/* $OpenBSD: channels.h,v 1.105 2011/06/22 22:08:42 djm Exp $ */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Author: Tatu Ylonen <ylo@cs.hut.fi>
|
* Author: Tatu Ylonen <ylo@cs.hut.fi>
|
||||||
|
@ -271,7 +271,7 @@ int x11_connect_display(void);
|
||||||
int x11_create_display_inet(int, int, int, u_int *, int **);
|
int x11_create_display_inet(int, int, int, u_int *, int **);
|
||||||
void x11_input_open(int, u_int32_t, void *);
|
void x11_input_open(int, u_int32_t, void *);
|
||||||
void x11_request_forwarding_with_spoofing(int, const char *, const char *,
|
void x11_request_forwarding_with_spoofing(int, const char *, const char *,
|
||||||
const char *);
|
const char *, int);
|
||||||
void deny_input_open(int, u_int32_t, void *);
|
void deny_input_open(int, u_int32_t, void *);
|
||||||
|
|
||||||
/* agent forwarding */
|
/* agent forwarding */
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
/* $OpenBSD: clientloop.c,v 1.235 2011/06/17 21:57:25 djm Exp $ */
|
/* $OpenBSD: clientloop.c,v 1.236 2011/06/22 22:08:42 djm Exp $ */
|
||||||
/*
|
/*
|
||||||
* Author: Tatu Ylonen <ylo@cs.hut.fi>
|
* Author: Tatu Ylonen <ylo@cs.hut.fi>
|
||||||
* Copyright (c) 1995 Tatu Ylonen <ylo@cs.hut.fi>, Espoo, Finland
|
* Copyright (c) 1995 Tatu Ylonen <ylo@cs.hut.fi>, Espoo, Finland
|
||||||
|
@ -174,7 +174,6 @@ struct escape_filter_ctx {
|
||||||
};
|
};
|
||||||
|
|
||||||
/* Context for channel confirmation replies */
|
/* Context for channel confirmation replies */
|
||||||
enum confirm_action { CONFIRM_WARN = 0, CONFIRM_CLOSE, CONFIRM_TTY };
|
|
||||||
struct channel_reply_ctx {
|
struct channel_reply_ctx {
|
||||||
const char *request_type;
|
const char *request_type;
|
||||||
int id;
|
int id;
|
||||||
|
@ -801,7 +800,7 @@ client_abandon_status_confirm(Channel *c, void *ctx)
|
||||||
xfree(ctx);
|
xfree(ctx);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
void
|
||||||
client_expect_confirm(int id, const char *request,
|
client_expect_confirm(int id, const char *request,
|
||||||
enum confirm_action action)
|
enum confirm_action action)
|
||||||
{
|
{
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
/* $OpenBSD: clientloop.h,v 1.27 2011/05/08 12:52:01 djm Exp $ */
|
/* $OpenBSD: clientloop.h,v 1.28 2011/06/22 22:08:42 djm Exp $ */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Author: Tatu Ylonen <ylo@cs.hut.fi>
|
* Author: Tatu Ylonen <ylo@cs.hut.fi>
|
||||||
|
@ -56,6 +56,10 @@ int client_simple_escape_filter(Channel *, char *, int);
|
||||||
typedef void global_confirm_cb(int, u_int32_t seq, void *);
|
typedef void global_confirm_cb(int, u_int32_t seq, void *);
|
||||||
void client_register_global_confirm(global_confirm_cb *, void *);
|
void client_register_global_confirm(global_confirm_cb *, void *);
|
||||||
|
|
||||||
|
/* Channel request confirmation callbacks */
|
||||||
|
enum confirm_action { CONFIRM_WARN = 0, CONFIRM_CLOSE, CONFIRM_TTY };
|
||||||
|
void client_expect_confirm(int, const char *, enum confirm_action);
|
||||||
|
|
||||||
/* Multiplexing protocol version */
|
/* Multiplexing protocol version */
|
||||||
#define SSHMUX_VER 4
|
#define SSHMUX_VER 4
|
||||||
|
|
||||||
|
|
8
mux.c
8
mux.c
|
@ -1,4 +1,4 @@
|
||||||
/* $OpenBSD: mux.c,v 1.28 2011/05/08 12:52:01 djm Exp $ */
|
/* $OpenBSD: mux.c,v 1.29 2011/06/22 22:08:42 djm Exp $ */
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2002-2008 Damien Miller <djm@openbsd.org>
|
* Copyright (c) 2002-2008 Damien Miller <djm@openbsd.org>
|
||||||
*
|
*
|
||||||
|
@ -1214,8 +1214,10 @@ mux_session_confirm(int id, int success, void *arg)
|
||||||
/* Request forwarding with authentication spoofing. */
|
/* Request forwarding with authentication spoofing. */
|
||||||
debug("Requesting X11 forwarding with authentication "
|
debug("Requesting X11 forwarding with authentication "
|
||||||
"spoofing.");
|
"spoofing.");
|
||||||
x11_request_forwarding_with_spoofing(id, display, proto, data);
|
x11_request_forwarding_with_spoofing(id, display, proto,
|
||||||
/* XXX wait for reply */
|
data, 1);
|
||||||
|
client_expect_confirm(id, "X11 forwarding", CONFIRM_WARN);
|
||||||
|
/* XXX exit_on_forward_failure */
|
||||||
}
|
}
|
||||||
|
|
||||||
if (cctx->want_agent_fwd && options.forward_agent) {
|
if (cctx->want_agent_fwd && options.forward_agent) {
|
||||||
|
|
12
ssh.c
12
ssh.c
|
@ -1,4 +1,4 @@
|
||||||
/* $OpenBSD: ssh.c,v 1.362 2011/06/03 00:54:38 djm Exp $ */
|
/* $OpenBSD: ssh.c,v 1.363 2011/06/22 22:08:42 djm Exp $ */
|
||||||
/*
|
/*
|
||||||
* Author: Tatu Ylonen <ylo@cs.hut.fi>
|
* Author: Tatu Ylonen <ylo@cs.hut.fi>
|
||||||
* Copyright (c) 1995 Tatu Ylonen <ylo@cs.hut.fi>, Espoo, Finland
|
* Copyright (c) 1995 Tatu Ylonen <ylo@cs.hut.fi>, Espoo, Finland
|
||||||
|
@ -1239,8 +1239,8 @@ ssh_session(void)
|
||||||
/* Request forwarding with authentication spoofing. */
|
/* Request forwarding with authentication spoofing. */
|
||||||
debug("Requesting X11 forwarding with authentication "
|
debug("Requesting X11 forwarding with authentication "
|
||||||
"spoofing.");
|
"spoofing.");
|
||||||
x11_request_forwarding_with_spoofing(0, display, proto, data);
|
x11_request_forwarding_with_spoofing(0, display, proto,
|
||||||
|
data, 0);
|
||||||
/* Read response from the server. */
|
/* Read response from the server. */
|
||||||
type = packet_read();
|
type = packet_read();
|
||||||
if (type == SSH_SMSG_SUCCESS) {
|
if (type == SSH_SMSG_SUCCESS) {
|
||||||
|
@ -1338,9 +1338,11 @@ ssh_session2_setup(int id, int success, void *arg)
|
||||||
/* Request forwarding with authentication spoofing. */
|
/* Request forwarding with authentication spoofing. */
|
||||||
debug("Requesting X11 forwarding with authentication "
|
debug("Requesting X11 forwarding with authentication "
|
||||||
"spoofing.");
|
"spoofing.");
|
||||||
x11_request_forwarding_with_spoofing(id, display, proto, data);
|
x11_request_forwarding_with_spoofing(id, display, proto,
|
||||||
|
data, 1);
|
||||||
|
client_expect_confirm(id, "X11 forwarding", CONFIRM_WARN);
|
||||||
|
/* XXX exit_on_forward_failure */
|
||||||
interactive = 1;
|
interactive = 1;
|
||||||
/* XXX wait for reply */
|
|
||||||
}
|
}
|
||||||
|
|
||||||
check_agent_present();
|
check_agent_present();
|
||||||
|
|
Loading…
Reference in New Issue