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

RFD 195: Windows VNet Support #50850

Open
wants to merge 2 commits into
base: master
Choose a base branch
from
Open

RFD 195: Windows VNet Support #50850

wants to merge 2 commits into from

Conversation

nklaassen
Copy link
Contributor

No description provided.

@github-actions github-actions bot added rfd Request for Discussion size/md labels Jan 8, 2025
@nklaassen nklaassen mentioned this pull request Jan 8, 2025
1 task
Comment on lines +160 to +168
When calling the `AuthenticateProcess` RPC, the Windows service will:
1. Create a Windows named pipe and give the installing user SID permission to open the pipe.
1. Pass the name of the pipe (via the RPC) to the user process.
1. Wait for the user process to dial the named pipe.
1. Use the Windows API `GetNamedPipeClientProcessId` to get the pipe client
process handle.
1. Once it has the user process handle, it can confirm the path of the exe
matches the path of the Windows service, and confirm that the exe is signed
by the same issuer as itself.
Copy link
Contributor

Choose a reason for hiding this comment

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

What happens if this fails for some reason? What is the UX for the user?

rfd/0195-vnet-windows.md Outdated Show resolved Hide resolved
@nklaassen nklaassen force-pushed the rfd/0195-vnet-windows branch from aa25e62 to 2b4ce36 Compare January 9, 2025 21:45
@nklaassen nklaassen added the no-changelog Indicates that a PR does not require a changelog entry label Jan 9, 2025
@nklaassen
Copy link
Contributor Author

TODO: when installing the windows service, the exe for the service is identified by a filesystem path to the exe, and every time the service starts it will execute that exe. if any user can overwrite the exe at that path, they could run their own exe as a service, with admin rights, and they would be allowed to start the service without admin rights in the current design. To prevent this we need to install the tsh exe in a path that cannot be written without admin rights, probably under "Program Files". Currently the electron installer installs everything under C:\Users<user>\AppData, which the user can always overwrite, so this is a problem. Perhaps when we install the service we can copy the tsh exe to "Program Files" and use that path for the service. Need to consider conflicts if the user installs both Connect and standalone tsh, and if they can share this path

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
no-changelog Indicates that a PR does not require a changelog entry rfd Request for Discussion size/md
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants