- (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:
Damien Miller 2003-12-17 16:27:32 +11:00
parent 5cd9d443ef
commit b5820f40bf
2 changed files with 25 additions and 18 deletions

View File

@ -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 $

View File

@ -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);
} }