Skip to content

Commit

Permalink
upstream: Also compare username when checking for JumpHost loops.
Browse files Browse the repository at this point in the history
bz#3057, ok djm@

OpenBSD-Commit-ID: 9bbc1d138adb34c54f3c03a15a91f75dbf418782
  • Loading branch information
daztucker authored and djmdjm committed Aug 3, 2020
1 parent ae75270 commit ced327b
Showing 1 changed file with 9 additions and 6 deletions.
15 changes: 9 additions & 6 deletions ssh.c
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
/* $OpenBSD: ssh.c,v 1.533 2020/07/17 03:43:42 dtucker Exp $ */
/* $OpenBSD: ssh.c,v 1.534 2020/07/31 04:19:37 dtucker Exp $ */
/*
* Author: Tatu Ylonen <[email protected]>
* Copyright (c) 1995 Tatu Ylonen <[email protected]>, Espoo, Finland
Expand Down Expand Up @@ -1256,19 +1256,25 @@ main(int ac, char **av)
/* Fill configuration defaults. */
fill_default_options(&options);

if (options.user == NULL)
options.user = xstrdup(pw->pw_name);

/*
* If ProxyJump option specified, then construct a ProxyCommand now.
*/
if (options.jump_host != NULL) {
char port_s[8];
const char *sshbin = argv0;
const char *jumpuser = options.jump_user, *sshbin = argv0;
int port = options.port, jumpport = options.jump_port;

if (port <= 0)
port = default_ssh_port();
if (jumpport <= 0)
jumpport = default_ssh_port();
if (strcmp(options.jump_host, host) == 0 && port == jumpport)
if (jumpuser == NULL)
jumpuser = options.user;
if (strcmp(options.jump_host, host) == 0 && port == jumpport &&
strcmp(options.user, jumpuser) == 0)
fatal("jumphost loop via %s", options.jump_host);

/*
Expand Down Expand Up @@ -1371,9 +1377,6 @@ main(int ac, char **av)
tty_flag = 0;
}

if (options.user == NULL)
options.user = xstrdup(pw->pw_name);

/* Set up strings used to percent_expand() arguments */
if (gethostname(thishost, sizeof(thishost)) == -1)
fatal("gethostname: %s", strerror(errno));
Expand Down

0 comments on commit ced327b

Please sign in to comment.