X2Go Bug report logs -
#1345
x2goclient overrides user-specified SSH port with wrong default
Reply or subscribe to this bug.
Toggle useless messages
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):
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):
[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):
[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:
Wed Jan 22 13:49:39 2025;
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.