Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Couldn't detect the home directory for 'configuration' #273

Closed
tlaerm opened this issue Jul 6, 2021 · 9 comments
Closed

Couldn't detect the home directory for 'configuration' #273

tlaerm opened this issue Jul 6, 2021 · 9 comments
Labels
bug Something isn't working waiting Waiting for confirmation, more information, ...

Comments

@tlaerm
Copy link

tlaerm commented Jul 6, 2021

I have a weird issue with one server, that has a nonstandard ssh port. When opening a terminal or trying to add the folder to workspace I get the same error: Couldn't detect the home directory for 'configuration'
Debug output is as follows:

[INFO]    Command received to open a terminal for FileSystemConfig(configuration)
[INFO]    [createConnection(configuration,config)] Creating a new connection for 'configuration'
[INFO]    Calculating actual config
[DEBUG]   	Final configuration:
{
    "name": "configueation",
    "host": "host.name",
    "port": NONSTANDARD-PORT,
    "username": "root",
    "agent": "/tmp/ssh-XXXXXXtzOm0y/agent.1292",
    "root": "/root/",
    "_location": 1,
    "_locations": [
        1
    ],
    "_calculated": {
        "name": "configuration",
        "host": "host.name",
        "port": NONSTANDARD-PORT,
        "username": "root",
        "agent": "$SSH_AUTH_SOCK",
        "root": "/root/",
        "_location": 1,
        "_locations": [
            1
        ]
    }
}
[INFO]    [createSocket(configuration)] Creating socket
[DEBUG]   [createSocket(configuration)] Connecting to host.name:NONSTANDARD-PORT

Running on Linux Vscodium 1.57.1
vscode-sshfs v1.21.0
Host is Ubuntu 20.04
Connecting in the terminal with ssh root@host.name -p NONSTANDARD-PORT works fine.
I'd be really grateful for any pointers. vscode-sshfs works flawlessly for other hosts.

Thomas

@SchoofsKelvin
Copy link
Owner

What is the actual home directory for the root user? E.g. what would echo ~ output, and does that path lead to a directory your user can actually access?

@SchoofsKelvin SchoofsKelvin added bug Something isn't working waiting Waiting for confirmation, more information, ... labels Jul 6, 2021
@SchoofsKelvin
Copy link
Owner

I've pushed a small commit (bda36c9) which you can download here (or from later builds).

Besides displaying a better warning in the output log, it also allows you to add a -CHECK_HOME flag (see #270 on how) and it should ignore this error and default the home directory to / instead. As long as you don't use ~ anywhere (except terminals, since those run on the server), it shouldn't affect anything anyway.

@tlaerm
Copy link
Author

tlaerm commented Jul 6, 2021

echo ~ indeed gives /root on the server. Your patch works when I run with "-CHECK_HOME" flag.

Thank you for getting into this so quickly.

@tlaerm tlaerm closed this as completed Jul 6, 2021
@SchoofsKelvin
Copy link
Owner

I'm still interested in what caused this. Detecting the home directory is done by running an echo Home: ~ and looking for "Home: ..." in the output, as can be seen here:

async function tryGetHome(ssh: Client): Promise<string | null> {
const exec = await toPromise<ClientChannel>(cb => ssh.exec('echo Home: ~', cb));
let home = '';
exec.stdout.on('data', (chunk: any) => home += chunk);
await toPromise(cb => exec.on('close', cb));
if (!home) return null;
const mat = home.match(/^Home: (.*?)\r?\n?$/);
if (!mat) return null;
return mat[1];
}

Are you using a special shell for the root user, different from sh/bash? (Pretty sure OpenSSH copies your user shell). What OS are you using? And just regular OpenSSH I assume, apart from running on a different port?

@tlaerm
Copy link
Author

tlaerm commented Jul 8, 2021

Sorry for the delay. So, the box uses fish as default shell. This however gives the same result to the echo Home: ~ command. I have tested again and now it works even without the flag. There is an explanation however:
After your patch I still could not connect and got another error: Unexpected packet before version
I checked issue #185 and silenced a script that was adding some ssh keys to the agent on login. After silencing the login completely, it worked. So this leads me to believe that both problems are related to this. Maybe the tryGetHome call is somehow interrupted or confused because the shell is sending some output from the login script.

@SchoofsKelvin
Copy link
Owner

Hmm, I do use the regex /^Home: (.*?)\r?\n?$/, which would fail should anything appear before (or even after) the echo.

I'll see about merging tryGetHome into the background command shell from #267 where it runs echo ::sshfs:home:$(echo ~) instead and checks for the pattern in all stdout lines, making it immune to weird shell startup or weird P1 etc. Good to know login scripts can break this, thanks for discovering that.

If your login script still runs for SFTP sessions like in #185, then that's not something I can solve I think. It should run the shell non-interactively which might help configuring the script, although I'm not too sure about how the underlying ssh2 library handles SSH subsystem "shells" for e.g. SFTP.

@tlaerm
Copy link
Author

tlaerm commented Jul 9, 2021

Alright. That sounds like it should solve the problem. Ping me when you want it tested. I'll de-silence the login.

@pelesh
Copy link

pelesh commented Dec 30, 2021

I am running into similar issue with SSH FS extension v1.24.1. When I try to log in I get an error message "Couldn't detect the home directory for 'configuration'".

My json config is:

{
    "sshfs.configs": [
        {
            "name": "configuration",
            "host": "remotehostname.org",
            "username": "myusername",
            "root": "/my/homedir/path",
            "flags": ["CHECK_HOME"]
        }
    ]
}

I checked that /my/homedir/path is what I get when I echo ~ on the remote.

Could you suggest how to troubleshoot this? I haven't used this plugin before, so I might be missing something obvious.

@luckman212
Copy link

@pelesh I think the flag needs a dash:

{
    "sshfs.configs": [
        {
            ...
            "flags": ["-CHECK_HOME"]
        }
    ]
}

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working waiting Waiting for confirmation, more information, ...
Projects
None yet
Development

No branches or pull requests

4 participants