-
-
Notifications
You must be signed in to change notification settings - Fork 39
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
Opening file via commandline on remote? #267
Comments
It'll take a little bit to implement, but I think this can be done when #253 is (partially) implemented/released. Basically bind to e.g. |
The only caveat I'd add: We're trying to migrate our users to SSH-FS away from remote-ssh, because we have thousands of users connecting to our servers, and the .vscode-server backend that remote-ssh uses is a massive CPU/RAM/pid/disk hog - trivial for single-user boxes, but a major problem for significantly-multi-user environments. (it's also hilariously insecure by default, and people can end up running other users' shells accidentally unless they drill down into the config to use sockets instead of TCP...) Killing stuck or leftover backend processes by the hundreds, and fielding multiple tickets daily to clear out corrupted or quota-eating .vscode-server directories is also a significant chunk of our daily workflow that we really want to get away from, and if we end up going back there, I may possibly cry. If you do implement a backend process, I beg you to focus on keeping it as lightweight and stateless as possible. I will owe you one, seriously. |
I wasn't really thinking about a backend process anyway, as this would require the host to have NodeJS to run the backend code. That, or me having to write and provide (built) executables for every OS, which I'm even less a fan of. My idea was just to have a simple socket (a UNIX one, to prevent having to deal with reserved ports and such) which is either port forwarded through SSH, or optionally running a background SSH terminal that creates and listens to this socket, although the latter is unlikely. |
Made some progress, although actually injecting the Currently I'm overwriting the It's either that, going through all possible Besides the "how to load
Both issues are already quite complex on their own, so it's taking quite some time and effort to get it working consistently across multiple shells. And I've only tried (and perhaps might even only try) TL;DR: Lots of work with complex Unix/shell mechanics, but there's at least progress. I'll probably quickly finish the current half-baked setup I have and push it to a feature branch (or publicly released but only enabled with certain flags), so you can try the |
I've pushed an initial prototype to the master branch, you can download the extension from the latest build in this list. To activate this feature, there are two ways:
"sshfs.flags": [
"REMOTE_COMMANDS"
],
"sshfs.configs": [
{
"name": "some-config",
"host": "hostname",
"putty": true,
"flags": [
"REMOTE_COMMANDS"
]
}
], Once that's added, every new connection will make use of the feature, so I recommend reloading the window. When you open a remote terminal through the extension, it should display The Like I mentioned in my previous comment, the current setup isn't the most elegant or robust, your mileage might vary. Also note that the |
The initial prototype is available in v1.21.0 of the extension, so you don't require to manually download and install the built |
Thanks heaps @SchoofsKelvin - this looks awesome! I'll have a play around 🥳 |
Hi @SchoofsKelvin, this seems to be working wonderfully! That being said, I was wondering if it'd be possible for the Thanks 😄 |
@abiramen Can you test the latest build (68 or later) from here? Run the Mind that it does actually create that empty file. The extension API doesn't seem to allow me to (easily) create an unsaved document for a non-existing URI. Technically I could trick VS Code into allowing this, but hacky and a bit of work. |
This works great! Thanks @SchoofsKelvin 🎉 |
Would it be possible to add this functionality for the So far the profile config files haven't really helped in deciphering how this works. |
I've just pushed some commits that should, if I didn't do anything wrong, support most shells. Below is the current list, which I didn't test in-depth yet, but should work for those shells and most shells based on them: vscode-sshfs/src/shellConfig.ts Lines 74 to 83 in 06a397e
You can get the latest build from here (build 87 or later) if you want to try it out yourself. I'll release it after some more feedback/testing. |
More shell support (from my previous comment) added in v1.24.0 of the extension. |
Hello, I'm trying to use this on systems where the default shell is /bin/csh, but it doesn't work. It appears that the shell type is not being detected correctly because the extension tries to use the "export" command to set things up instead of "setenv". EDIT: I switched on logging but I don't see any errors in the SSH FS log. example terminal output: Connecting to eda... So, check the SHELL value... $ echo $SHELL this is actually a link to tcsh: /bin/csh -> tcsh Thanks |
This issue would be easier to solve with debug logs, so please follow these steps:
That should log which kind of shell it actually thinks you're using. My guess is the detection goes wrong, since vscode-sshfs/src/shellConfig.ts Line 82 in 2673c72
|
Thanks for the response, here's the log I've just noticed that as you suspected there is an error when detecting the shell config : [ERROR] [createConnection(eda,config)] Error calculating ShellConfig: Error: Command 'echo :::SHELL:$SHELL:SHELL:::' failed with exit code 1: I guess this needs to be changed by adding braces: echo :::SHELL:${SHELL}:SHELL::: which for csh at least should return: :::SHELL:/bin/csh:SHELL::: UPDATE: I can confirm that changing |
Hi!
I was wondering if there's any way to open a mounted file on the commandline from my ssh-terminal (as opened by the extension)?
Thanks!
The text was updated successfully, but these errors were encountered: