20031217
- (djm) OpenBSD CVS Sync - markus@cvs.openbsd.org 2003/12/09 15:28:43 [serverloop.c] make ClientKeepAlive work for ssh -N, too (no login shell requested). 1) send a bogus channel request if we find a channel 2) send a bogus global request if we don't have a channel ok + test beck@
This commit is contained in:
parent
5cd9d443ef
commit
b5820f40bf
11
ChangeLog
11
ChangeLog
|
@ -1,3 +1,12 @@
|
||||||
|
20031217
|
||||||
|
- (djm) OpenBSD CVS Sync
|
||||||
|
- markus@cvs.openbsd.org 2003/12/09 15:28:43
|
||||||
|
[serverloop.c]
|
||||||
|
make ClientKeepAlive work for ssh -N, too (no login shell requested).
|
||||||
|
1) send a bogus channel request if we find a channel
|
||||||
|
2) send a bogus global request if we don't have a channel
|
||||||
|
ok + test beck@
|
||||||
|
|
||||||
20031209
|
20031209
|
||||||
- (dtucker) OpenBSD CVS Sync
|
- (dtucker) OpenBSD CVS Sync
|
||||||
- matthieu@cvs.openbsd.org 2003/11/25 23:10:08
|
- matthieu@cvs.openbsd.org 2003/11/25 23:10:08
|
||||||
|
@ -1566,4 +1575,4 @@
|
||||||
- Fix sshd BindAddress and -b options for systems using fake-getaddrinfo.
|
- Fix sshd BindAddress and -b options for systems using fake-getaddrinfo.
|
||||||
Report from murple@murple.net, diagnosis from dtucker@zip.com.au
|
Report from murple@murple.net, diagnosis from dtucker@zip.com.au
|
||||||
|
|
||||||
$Id: ChangeLog,v 1.3139 2003/12/09 13:54:38 dtucker Exp $
|
$Id: ChangeLog,v 1.3140 2003/12/17 05:27:32 djm Exp $
|
||||||
|
|
32
serverloop.c
32
serverloop.c
|
@ -35,7 +35,7 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "includes.h"
|
#include "includes.h"
|
||||||
RCSID("$OpenBSD: serverloop.c,v 1.113 2003/11/18 00:40:05 dtucker Exp $");
|
RCSID("$OpenBSD: serverloop.c,v 1.114 2003/12/09 15:28:43 markus Exp $");
|
||||||
|
|
||||||
#include "xmalloc.h"
|
#include "xmalloc.h"
|
||||||
#include "packet.h"
|
#include "packet.h"
|
||||||
|
@ -212,26 +212,23 @@ make_packets_from_stdout_data(void)
|
||||||
static void
|
static void
|
||||||
client_alive_check(void)
|
client_alive_check(void)
|
||||||
{
|
{
|
||||||
static int had_channel = 0;
|
int channel_id;
|
||||||
int id;
|
|
||||||
|
|
||||||
id = channel_find_open();
|
|
||||||
if (id == -1) {
|
|
||||||
if (!had_channel)
|
|
||||||
return;
|
|
||||||
packet_disconnect("No open channels after timeout!");
|
|
||||||
}
|
|
||||||
had_channel = 1;
|
|
||||||
|
|
||||||
/* timeout, check to see how many we have had */
|
/* timeout, check to see how many we have had */
|
||||||
if (++client_alive_timeouts > options.client_alive_count_max)
|
if (++client_alive_timeouts > options.client_alive_count_max)
|
||||||
packet_disconnect("Timeout, your session not responding.");
|
packet_disconnect("Timeout, your session not responding.");
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* send a bogus channel request with "wantreply",
|
* send a bogus global/channel request with "wantreply",
|
||||||
* we should get back a failure
|
* we should get back a failure
|
||||||
*/
|
*/
|
||||||
channel_request_start(id, "keepalive@openssh.com", 1);
|
if ((channel_id = channel_find_open()) == -1) {
|
||||||
|
packet_start(SSH2_MSG_GLOBAL_REQUEST);
|
||||||
|
packet_put_cstring("keepalive@openssh.com");
|
||||||
|
packet_put_char(1); /* boolean: want reply */
|
||||||
|
} else {
|
||||||
|
channel_request_start(channel_id, "keepalive@openssh.com", 1);
|
||||||
|
}
|
||||||
packet_send();
|
packet_send();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -797,9 +794,9 @@ server_loop2(Authctxt *authctxt)
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
server_input_channel_failure(int type, u_int32_t seq, void *ctxt)
|
server_input_keep_alive(int type, u_int32_t seq, void *ctxt)
|
||||||
{
|
{
|
||||||
debug("Got CHANNEL_FAILURE for keepalive");
|
debug("Got %d/%u for keepalive", type, seq);
|
||||||
/*
|
/*
|
||||||
* reset timeout, since we got a sane answer from the client.
|
* reset timeout, since we got a sane answer from the client.
|
||||||
* even if this was generated by something other than
|
* even if this was generated by something other than
|
||||||
|
@ -808,7 +805,6 @@ server_input_channel_failure(int type, u_int32_t seq, void *ctxt)
|
||||||
client_alive_timeouts = 0;
|
client_alive_timeouts = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
server_input_stdin_data(int type, u_int32_t seq, void *ctxt)
|
server_input_stdin_data(int type, u_int32_t seq, void *ctxt)
|
||||||
{
|
{
|
||||||
|
@ -1048,7 +1044,9 @@ server_init_dispatch_20(void)
|
||||||
dispatch_set(SSH2_MSG_CHANNEL_WINDOW_ADJUST, &channel_input_window_adjust);
|
dispatch_set(SSH2_MSG_CHANNEL_WINDOW_ADJUST, &channel_input_window_adjust);
|
||||||
dispatch_set(SSH2_MSG_GLOBAL_REQUEST, &server_input_global_request);
|
dispatch_set(SSH2_MSG_GLOBAL_REQUEST, &server_input_global_request);
|
||||||
/* client_alive */
|
/* client_alive */
|
||||||
dispatch_set(SSH2_MSG_CHANNEL_FAILURE, &server_input_channel_failure);
|
dispatch_set(SSH2_MSG_CHANNEL_FAILURE, &server_input_keep_alive);
|
||||||
|
dispatch_set(SSH2_MSG_REQUEST_SUCCESS, &server_input_keep_alive);
|
||||||
|
dispatch_set(SSH2_MSG_REQUEST_FAILURE, &server_input_keep_alive);
|
||||||
/* rekeying */
|
/* rekeying */
|
||||||
dispatch_set(SSH2_MSG_KEXINIT, &kex_input_kexinit);
|
dispatch_set(SSH2_MSG_KEXINIT, &kex_input_kexinit);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue