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

ssh issues with encrypted identity files on MacOS #20

Open
dtrifiro opened this issue Dec 2, 2022 · 3 comments
Open

ssh issues with encrypted identity files on MacOS #20

dtrifiro opened this issue Dec 2, 2022 · 3 comments

Comments

@dtrifiro
Copy link
Contributor

dtrifiro commented Dec 2, 2022

SSH on MacOS provides the UseKeychain option (man ssh_config) that makes it possible to decrypt encrypted ssh identity files on-the-fly by retrieving the passphrase from MacOS' keychain.

This works with git clone and other git cli commands, but fails when using certain dvc operations (dvc exp list, dvc get, ...) because the ssh vendor we use for git operations and for remote operations (asyncssh) does not support Apple keychain integration.

Using UseKeychain can result in authentication issues (unexpected CloneError or Permission Denied errors).

The solution is to decrypt the ssh key and add it to the ssh agent:

ssh-add --apple-load-keychain ~/.ssh/ed255

(note that --apple-load-keychain used to be -A)

By adding the key to the ssh-agent, asyncssh is able to properly use the (decrypted) key.

First noted by @shcheklein in iterative/dvc#7702 (comment)_

@dtrifiro dtrifiro changed the title ssh issues with encrypted keys on MacOS ssh issues with encrypted identity files on MacOS Dec 2, 2022
@efiop efiop transferred this issue from iterative/dvc Jan 1, 2023
@dberenbaum dberenbaum added this to DVC Jan 31, 2023
@github-project-automation github-project-automation bot moved this to Backlog in DVC Jan 31, 2023
@dberenbaum dberenbaum removed this from DVC Jan 31, 2023
@pmrowla
Copy link
Contributor

pmrowla commented Mar 21, 2023

reposting from iterative/scmrepo#210 (comment)

Porting the apple openssh to asyncssh is non-trivial and probably not what we want. What we should be doing in dulwich is checking for unsupported configuration options in our asyncssh vendor (like UseKeychain which specifies using the apple keychain behavior) and then fallback to the default dulwich SSH vendor instead (which just calls system ssh via subprocess, and would use apple's openssh build and work as expected).

We default to using asyncssh since it removes a dependency on ssh, which is not always available in windows (or in containers)

@efiop
Copy link
Contributor

efiop commented Mar 21, 2023

@pmrowla Thank you for clarifying! That sounds very good.

@pmrowla pmrowla self-assigned this Mar 21, 2023
@pmrowla pmrowla added this to DVC Mar 21, 2023
@github-project-automation github-project-automation bot moved this to Backlog in DVC Mar 21, 2023
@pmrowla pmrowla moved this from Backlog to Todo in DVC Mar 21, 2023
@pmrowla
Copy link
Contributor

pmrowla commented Mar 23, 2023

This issue probably should not have been moved into dvc-ssh, since it was a git+SSH problem (I'm assuming that at some point it got marked fs: ssh in the DVC repo).

However, the underlying issue w/asyncssh not supporting all OpenSSH flags does actually affect dvc-ssh, and the scmrepo change does not actually fix the problem in dvc-ssh, so I will keep this issue open.

Essentially, the macos UseKeychain option will now work properly for git operations (meaning clone/fetch on anything that uses DVC erepo), but it will still result in authentication errors if a DVC user is using an SSH DVC remote with a key stored in the macos/apple keychain.

We don't have a straightforward fallback mechanism for DVC remotes, since DVC was never using subprocess to run system ssh in the first place for DVC remotes (before asyncssh/sshfs we used paramiko, which also does not support UseKeychain without setting AddKeysToAgent)

To handle this properly for DVC remotes we would need an fsspec sftp implementation that is capable of using CLI ssh (fsspec's native ssh/sftp implementation uses paramiko)

@pmrowla pmrowla moved this from Todo to Done in DVC Mar 23, 2023
@pmrowla pmrowla removed their assignment Mar 23, 2023
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
No open projects
Archived in project
Development

No branches or pull requests

3 participants