X2Go Bug report logs - #1345
x2goclient overrides user-specified SSH port with wrong default

version graph

Package: x2goclient; Maintainer for x2goclient is X2Go Developers <x2go-dev@lists.x2go.org>; Source for x2goclient is src:x2goclient.

Reported by: m.r.nemoinis@antichef.net

Date: Thu, 22 Nov 2018 02:55:02 UTC

Severity: important

Found in version 4.1.2.2

Reply or subscribe to this bug.

Toggle useless messages

View this report as an mbox folder, status mbox, maintainer mbox


Report forwarded to x2go-dev@lists.x2go.org, X2Go Developers <x2go-dev@lists.x2go.org>:
Bug#1345; Package x2goclient. (Thu, 22 Nov 2018 02:55:02 GMT) (full text, mbox, link).


Acknowledgement sent to m.r.nemoinis@antichef.net:
New Bug report received and forwarded. Copy sent to X2Go Developers <x2go-dev@lists.x2go.org>. (Thu, 22 Nov 2018 02:55:02 GMT) (full text, mbox, link).


Message #5 received at submit@bugs.x2go.org (full text, mbox, reply):

From: m.r.nemoinis@antichef.net
To: submit@bugs.x2go.org
Subject: x2goclient overrides user-specified SSH port with wrong default
Date: Wed, 21 Nov 2018 18:43:30 -0800
Package: x2goclient
Version: 4.1.2.2
Severity: Important

OS: Linux Debian Buster
x2goclient:  4.1.2.2-0x2go1~git20181113.1828+10.heuler.1


There is a bug in x2goclient's port handling that was introduced when adding support for libssh
Config file (bug #1121):

sshmasterconnection.cpp uses ssh_options_parse_config in an attempt to obtain config-based
values for hostname and port, in case the values supplied by the user are short-hands or
defaults.  The problem is that sshmasterconnection takes the values returned by
ssh_options_parse_config even when the x2goclient user has given explicit hostnames and ports.

So let's say I want to connect to "frobisher.example.com" which has a ssh server on port 3322,
and I explicitly give these parameters in the x2goclient session.

All works well if "Host *" in /etc/ssh/ssh_config (and ~/.ssh/config) does not have a default port.
But if it does, like this:

Host *
  Port 6789

Then that port is taken and sshmasterconnection tries (and fails) to connect to
frobisher.example.com on port 6789.
The code should not override a port that is specified by the interactive user.
This is the way ssh works: command line options take precedence over config values, and so
system and user files are setup accordingly.

Second, what if the default port in /etc/ssh/ssh_config or ~/.ssh/config is actually 6789 (or
22, or any explicit value)? That fails too, because the following code in
SshMasterConnection::channelLoop() will override x2go's own channel forwarding ports:


/* The host and port might be a shorthand and zero, so fetch the actual data. */
if (ssh_options_parse_config (tmp_session, NULL) < 0) {
x2goDebug << "Warning: unable to parse the SSH config file.";
}

unsigned int inferred_port = 0;
ssh_options_get_port (tmp_session, &inferred_port);
x2goDebug << "Temporary session port after config file parse: " << inferred_port;

char *inferred_host = NULL;
ssh_options_get (tmp_session, SSH_OPTIONS_HOST, &inferred_host);
x2goDebug << "Temporary session host after config file parse: " << inferred_host;



Here is the debugging output of the code above when it works and when it doesn't:

GOOD (default Port commented out in /etc/ssh/ssh_config for "Host *"):

x2go-DEBUG-../src/sshmasterconnection.cpp:2111> Forwarding parameters: from remote
("localhost":49471) to local ("localhost":34508)
x2go-DEBUG-../src/sshmasterconnection.cpp:2148> Temporary session port after config file parse:
49471
x2go-DEBUG-../src/sshmasterconnection.cpp:2152> Temporary session host after config file parse:
localhost
x2go-DEBUG-../src/sshmasterconnection.cpp:2182> New channel forwarded.


BAD (/etc/ssh/ssh_config has an explicit "Port 6789"  for "Host *" ):

x2go-DEBUG-../src/sshmasterconnection.cpp:2111> Forwarding parameters: from remote
("localhost":40052) to local ("localhost":54592)
x2go-DEBUG-../src/sshmasterconnection.cpp:2148> Temporary session port after config file parse:
6789
x2go-DEBUG-../src/sshmasterconnection.cpp:2152> Temporary session host after config file parse:
localhost
x2go-DEBUG-../src/sshmasterconnection.cpp:2182> New channel forwarded.



Information forwarded to x2go-dev@lists.x2go.org, X2Go Developers <x2go-dev@lists.x2go.org>:
Bug#1345; Package x2goclient. (Sun, 13 Dec 2020 17:25:02 GMT) (full text, mbox, link).


Acknowledgement sent to Олег Кочкин (Oleg Kochkin) <oleg.kochkin@gmail.com>:
Extra info received and forwarded to list. Copy sent to X2Go Developers <x2go-dev@lists.x2go.org>. (Sun, 13 Dec 2020 17:25:03 GMT) (full text, mbox, link).


Message #10 received at 1345@bugs.x2go.org (full text, mbox, reply):

From: Олег Кочкин (Oleg Kochkin) <oleg.kochkin@gmail.com>
To: 1345@bugs.x2go.org
Subject: The same problem is in Fedora 33.
Date: Sun, 13 Dec 2020 20:22:43 +0300
[Message part 1 (text/plain, inline)]
This bug showed up for me too.
Not noticing your message, I sent a report to 
https://bugs.x2go.org/cgi-bin/bugreport.cgi?bug=195#38
[Message part 2 (text/html, inline)]

Information forwarded to x2go-dev@lists.x2go.org, X2Go Developers <x2go-dev@lists.x2go.org>:
Bug#1345; Package x2goclient. (Fri, 25 Dec 2020 11:50:01 GMT) (full text, mbox, link).


Acknowledgement sent to Олег Кочкин (Oleg Kochkin) <oleg.kochkin@gmail.com>:
Extra info received and forwarded to list. Copy sent to X2Go Developers <x2go-dev@lists.x2go.org>. (Fri, 25 Dec 2020 11:50:01 GMT) (full text, mbox, link).


Message #15 received at 1345@bugs.x2go.org (full text, mbox, reply):

From: Олег Кочкин (Oleg Kochkin) <oleg.kochkin@gmail.com>
To: 1345@bugs.x2go.org
Subject: This is not a bug in the x2go client.
Date: Fri, 25 Dec 2020 14:49:14 +0300
[Message part 1 (text/plain, inline)]
This is not a bug in the x2go client.

The same is in the KDE file manager Dolphin (version 20.08.3) when 
connecting via SFTP.
If the "port" is not commented out in /etc/ssh/ssh_config, then Dolphin 
connects to the port specified in /etc/ssh/ssh_config, and not the one 
specified in the address bar.

If comment the "port" in /etc/ssh/ssh_config, then both the x2go client 
and Dolphin begin to connect using the ports specified in them.

[Message part 2 (text/html, inline)]

Send a report that this bug log contains spam.


X2Go Developers <owner@bugs.x2go.org>. Last modified: Fri Mar 29 05:31:28 2024; Machine Name: ymir.das-netzwerkteam.de

X2Go Bug tracking system

Debbugs is free software and licensed under the terms of the GNU Public License version 2. The current version can be obtained from https://bugs.debian.org/debbugs-source/.

Copyright © 1999 Darren O. Benham, 1997,2003 nCipher Corporation Ltd, 1994-97 Ian Jackson, 2005-2017 Don Armstrong, and many other contributors.