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

fix #966 by using fixed folders #1362

Open
wants to merge 9 commits into
base: main
Choose a base branch
from

Conversation

fidgetingbits
Copy link
Collaborator

@fidgetingbits fidgetingbits commented Jan 19, 2024

This is a fix for #966. I've got three different systems where I run into this issue, so want to finally address it for everyone.

There is a corresponding PR for command-server at cursorless-dev/command-server#21

I haven't actually tested this on windows, as I don't have it, so I'm not sure if the path I used is sufficient. On this side it is TALON_HOME, and on command-server side it is hardcoded which I think is the same but not positive. Also in the discussion there was a suggestion to make the folder hidden. I left a commented out cmd for setting the folder as hidden, but again not sure if it is right and can't test it, so feedback on if that's the right approach is welcome. Will be good if someone can test/verify the windows side (I added a few windows users as requested reviewers).

Its also worth noting that in #966 discussion, @auscompgeek suggested to use XDG_RUNTIME_DIR on Linux, which I had implemented and tested originally. However, when looking into snaps I ran across https://forum.snapcraft.io/t/rethinking-how-we-handle-xdg-runtime-dir/22223 which suggests that they may want to change snaps to no longer have access to the same XDG_RUNTIME_DIR folder. If they actually ever implemented that then this would break, so in the end I opted not to use it.

There's also per user temp directories on mac, which you can query using getconf DARWIN_USER_TEMP_DIR, but I decided not to keep that code in the end since it keeps the mac/linux case simpler both using /tmp, especially in light of not using XDG_RUNTIME_DIR in the end.

ATM I cache the result in a global, and this was mostly because originally I had code that was calling getconf DARWIN_USER_TEMP_DIR, but I chose to just leave the global afterwards anyway.

I've tested the changes using /tmp on both Linux and Mac and it works fine.

  • Test on Windows
  • Test on Mac
  • Test on Linux

@lunixbochs
Copy link
Collaborator

please don't merge until I do security review

Copy link
Collaborator

@pokey pokey left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks fine but I haven't tried it locally. See comments inline

apps/vscode/command_client/command_client.py Outdated Show resolved Hide resolved
apps/vscode/command_client/command_client.py Outdated Show resolved Hide resolved
home_dir = Path(os.path.expanduser("~"))
if app.platform == "linux" or app.platform == "mac":
return (
Path(home_dir) / f".talon/.comms/{actions.user.command_server_directory()}"
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I thought accessing a hidden folder was also a problem for snaps, no? Cc/ @auscompgeek

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is true for most snaps by default iirc, but afaik vscode uses something called classic confinement, which has unrestricted access to files. This makes sense since it's an IDE and users would expected to be able to access anything as their user anyway. So I think we should be okay here (though I haven't tested with the snap yet).

apps/vscode/command_client/command_client.py Outdated Show resolved Hide resolved
@pokey
Copy link
Collaborator

pokey commented Jan 23, 2024

Once everything is reviewed and ready to merge, we should do one final test on each platform, given the potential repercussions of this code breaking 😅

@nriley nriley changed the title fix #996 by using fixed folders fix #966 by using fixed folders Feb 3, 2024
apps/vscode/command_client/command_client.py Show resolved Hide resolved
if app.platform == "linux" or app.platform == "mac":
return home_dir / ".talon" / " .comms" / directory_name
elif app.platform == "windows":
# subprocess.run(["attrib","+H","myfile.txt"],check=True)
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This seems like it may have been some testing code?

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I left this in for someone with access to Windows in case they want to test using a hidden folder, but didn't uncomment it because I can't test if it works.

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@knausj85 any thoughts about that part? I'm happy to just delete the commented out bit if windows users don't care to add it

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I have no concerns with leaving this file unhidden. Thoughts on this @AndreasArvidsson ?

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

fyi I'm not sure I want plugins making top-level directories under .talon, hidden or not

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Sounds good. Should we continue that discussion in the issue or here?

Personally I would prefer to keep it in the temp directory and agree with @rntz arguments in the issue that the extension should respect TMPDIR.

If that doesn't work for some technical reason we should probably just create a new directory in user home. eg ~/.rpc.

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I believe TMPDIR doesn't work as a solution because it can be different path in talon vs vscode. This can definitely be the case on nix, as noted here #966 (comment) and also unrelated to that plugin which I've run into (which I already forget where as I've been using this PR for ~ 1 year). I originally hardcoded /tmp in the PR, but then eventually we opted for a /home-based path, which unfortunately I now can't find the reason/comment for it seems.

But I think because of all the potential snap/flatpak/nix related issues mentioned it's likely just best to avoid hoping one of those tmpdir/runtime path solutions work everywhere? Pretty sure atm we don't have the capacity to actually test it.

Something like ~/.rpc is fine with me if that's what people like (I just want it fixed at this point :D), but imo it does seem a bit opaque and potentially collision prone vs some name that associates it with talon, which was why I chose to drop the folder in ~/.talon/... ~/.talon-rpc or similar maybe makes more sense?

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

If someone on purpose has set a different environment variable in Talon and vscode they kind off asking for trouble. As long as we check the sources in the same order we should get the same result.

Year that is a real problem because we don't want to break it for existing users.

~/.talon-rpc would be fine with me, but I'm not sure the home directory is any more stable than the temp directory since the home directory can also be moved with environment variables.

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

FWIW I agree if it were actually the user just wantonly changing environment variables, it shouldn't something that needs catering to. However, this isn't a case of a user choosing to change TMPDIR, it's being done somewhere behind the scenes, so it's not something they can just choose not to do.

In addition to the original bug filer, there were numerous (#966 (comment)) cases of it differing in practice, as well as in my systems and for some other Nix users. When it started breaking for me (which prompted finally creating the PR) it's certainly not from me explicitly changing TMPDIR myself. This comment #966 (comment) also implies this type of thing happens on windows.

In light of that, I don't see how keeping the order checking consistent is enough, unless you mean you have some other mechanism to ensure the paths they are checking in the same order are actually matching? Maybe I'm missing something.

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

If we can't make the temp directory work reliably then we can't of course use that. I assume the home directory is more reliable?

apps/vscode/command_client/command_client.py Outdated Show resolved Hide resolved
@fidgetingbits
Copy link
Collaborator Author

Aside from the Path.home() bit which will be quick to fix, this is still mostly waiting on someone who uses Windows to test that it actually works as intended. Anyone have time to try?

@DonnerWolfBach
Copy link
Contributor

@fidgetingbits I will hopefully have time (about 2-6h) to try it on windows on Saturday and I can find more time after that.
I assume I would just have to apply this PR to my personal talon community fork (and remove the dirty fixes I Currently Have in Place).
However, how would I go about applying cursorless-dev/command-server#21 ?

@fidgetingbits
Copy link
Collaborator Author

fidgetingbits commented May 9, 2024

@fidgetingbits I will hopefully have time (about 2-6h) to try it on windows on Saturday and I can find more time after that. I assume I would just have to apply this PR to my personal talon community fork (and remove the dirty fixes I Currently Have in Place). However, how would I go about applying pokey/command-server#21 ?

Hey @DonnerWolfBach thanks! Reminds me @saidelike recently said they could also test this on Windows.

Easiest is to merge the PR into some temporary branch you want to build from:

git clone https://github.com/pokey/command-server
cd command-server
git switch -c dev-build
git fetch origin pull/21/head:static-tmp-dir
git merge static-tmp-dir -m "Merge branch 'use-static-tmp-dir' into dev"

Then you need to build and install. I do it on nix on both macOS and linux, so merge yet another PR so I can just run nix build. I do it like this:

git fetch origin pull/22/head:nix-flake
git merge nix-flake -m "Merge branch 'nix-flake' into dev"
nix build
code --force --install-extension result/*.vsix

If you have a nix box and can do the above, I think the .vsix file will actually work on windows too.

But, if you have to build the extension on windows, presumably you need to run the same yarn commands as what the flake PR does. But note that I also had to update package.json to add vsce to yarn dependencies so it didn't have to be installed separately (not sure off the top of my head where it comes from otherwise). So if you don't want to find where vsce comes from, you may want to do that too, and then you just need to install yarn on windows (however one does that).

Then the manual build will be something like this:

yarn run compile
yarn vsce package --yarn -o ./command-server.vsix
code --force --install-extension ./command-server.vsix

@pokey might be worth adding a small note to the command-server README about how to "officially" build it. I'll file an issue.

home_dir = Path(os.path.expanduser("~"))
directory_name = actions.user.command_server_directory()
if app.platform == "linux" or app.platform == "mac":
return home_dir / ".talon" / " .comms" / directory_name
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Don't snaps prevent access to ~/.*?

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

In the default containment profiles yes (I believe you need to request personal confinement to access dotfiles), but from what I read vscode should be okay due to it using classic confinement (which is effectively no confinement). See here from this same PR where I said similar: #1362 (comment)

@DonnerWolfBach said he was using VSCodium. I suspect since it's just an open source build of VSCode (?) and an IDE when packaged as a snap it would use the same classic confinement. Maybe if he's using the snap, he could confirm though.

From what I've seen they tend to grant classic confinement to all IDEs under the assumption they will be used to edit any files. For instance neovim snap also has classic confinement.

I think the only other option if we want to assume we need to communicate with a snaps with restricted confinement is /tmp, and the discussion on #966 people couldn't agree, and it seemed some (pokey and rntz at least iirc) were leaning towards using $HOME over /tmp, so I just used $HOME for the sake of getting anything going.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I don't use VSCodium in a snap unfortunately. I use the nix package

@DonnerWolfBach
Copy link
Contributor

DonnerWolfBach commented May 11, 2024

git merge origin/static-tmp-dir -m "Merge branch 'use-static-tmp-dir' into dev"

The origin in there is a typo isn't it? With it it doesn't work, but without it does, at least on my machine that branch was created locally from your PR

edit: @fidgetingbits (sorry, I am unfamiliar with how github commenting works, not sure whether this is the right way to point out such a small thing)^^'

@fidgetingbits
Copy link
Collaborator Author

git merge origin/static-tmp-dir -m "Merge branch 'use-static-tmp-dir' into dev"

The origin in there is a typo isn't it? With it it doesn't work, but without it does, at least on my machine that branch was created locally from your PR

edit: @fidgetingbits (sorry, I am unfamiliar with how github commenting works, not sure whether this is the right way to point out such a small thing)^^'

I modified the commands from a script that uses my local branches rather than the PRs, so likely why. I'll edit the comment in case anyone else tries to use it.

@DonnerWolfBach
Copy link
Contributor

yarn vsce package --yarn -o ./command-server.vsix

Here I am running into troubles once again:

PS C:\Users\Sebastian\Repos\command-server> corepack yarn vsce package --yarn -o ./command-server.vsix
Executing prepublish script 'yarn run vscode:prepublish'...
 ERROR  Command failed: yarn list --prod --json

PS C:\Users\Sebastian\Repos\command-server> corepack yarn list --prod --json

Usage Error: Couldn't find a script named "list".

$ yarn run [--inspect] [--inspect-brk] [-T,--top-level] [-B,--binaries-only] [--require #0] <scriptName> ...
PS C:\Users\Sebastian\Repos\command-server>

Due to lacking knowledge of yarn etc. I don't think I am able to troubleshoot that myself farther than this.

Version info:

PS C:\Users\Sebastian\Repos\command-server> corepack yarn vsce --version
2.15.0
PS C:\Users\Sebastian\Repos\command-server> corepack yarn --version
4.2.2
PS C:\Users\Sebastian\Repos\command-server> node --version
v20.13.1

(cartago delenda est - I mean I think cursorless-dev/command-server#26 really makes sense)

@fidgetingbits
Copy link
Collaborator Author

Any chance the instructions saidelike posted on that other issue would help building on windows? He implies 'pnpm compile' is enough. I don't even remember why I used yarn anymore..

@saidelike
Copy link
Contributor

Any chance the instructions saidelike posted on that other issue would help building on windows? He implies 'pnpm compile' is enough. I don't even remember why I used yarn anymore..

Fwiw i used "pnpm" for neovim's command-server because cursorless used "pnpm" and i didn't realise command-server was using "yarn" by default (as indicated in the package.json). Maybe @pokey can indicate how he builds the vscode's command-server?

Btw, I am happy to test these command-client's changes along with corresponding changes in my neovim command-server extension.

@DonnerWolfBach
Copy link
Contributor

DonnerWolfBach commented Jun 15, 2024

@fidgetingbits managed to test it on windows 10 with the newest version of both branches. 2024-06-15 10:28:07.578 IO communication_dir_path=WindowsPath('C:/Users/Sebastian/AppData/Roaming/talon/.comms/vscode-command-server') and indeed cursorless works

@saidelike thanks for the hint, changing yarn to pnpm in the package.json solved the problem

Interestingly it also worked if I just changed the command server and not the talon user files. there was still a command server in the temporary directory and it was working...

@knausj85
Copy link
Member

knausj85 commented Nov 3, 2024

I'm going through some of the older PRs. This looks like it's ready to be merged to me? Something I'm missing?

@fidgetingbits
Copy link
Collaborator Author

I'm going through some of the older PRs. This looks like it's ready to be merged to me? Something I'm missing?

I think so, with the caveat I think the @pokey command server vscode extension will have to merge the PR and release an updated version first. Otherwise it will break RPC for users.

There was the snap concern about home access, which I've noted I don't think is valid for editors.

There is also the commented code for setting a hidden file attribute for windows, which I don't know if windows people want and couldn't test, but happy to just have that deleted before merge.

@fidgetingbits
Copy link
Collaborator Author

Also @lunixbochs had commented they wanted to do a security review before this gets merged, so will need to take a look.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

9 participants