Page MenuHomePhabricator

Correctly identify more SSH private key problems as "formatting" or "passphrase" related
ClosedPublic

Authored by epriestley on Nov 13 2019, 6:17 PM.
Tags
None
Referenced Files
Unknown Object (File)
Sat, Jan 25, 6:09 AM
Unknown Object (File)
Sat, Jan 25, 6:09 AM
Unknown Object (File)
Sat, Jan 25, 6:09 AM
Unknown Object (File)
Tue, Jan 21, 10:34 AM
Unknown Object (File)
Fri, Jan 17, 10:41 PM
Unknown Object (File)
Sun, Jan 12, 7:04 PM
Unknown Object (File)
Sat, Jan 11, 1:58 PM
Unknown Object (File)
Sat, Dec 28, 4:09 AM
Subscribers
None

Details

Summary

Ref T13454. Fixes T13006. When a user provide us with an SSH private key and (possibly) a passphrase:

  1. Try to verify that they're correct by extracting the public key.
  2. If that fails, try to figure out why it didn't work.

Our success in step (2) will vary depending on what the problem is, and we may end up falling through to a very generic error, but the outcome should generally be better than the old approach.

Previously, we had a very unsophisticated test for the text "ENCRYPTED" in the key body and questionable handling of the results: for example, providing a passphrase when a key did not require one did not raise an error.

Test Plan

Created and edited credentials with:

  • Valid, passphrase-free keys.
  • Valid, passphrased keys with the right passphrase.
  • Valid, passphrase-free keys with a passphrase ("surplus passphrase" error).
  • Valid, passphrased keys with no passphrase ("missing passphrase" error).
  • Valid, passphrased keys with an invalid passphrase ("invalid passphrase" error).
  • Invalid keys ("format" error).

The precision of these errors will vary depending on how helpful "ssh-keygen" is.

Diff Detail

Repository
rP Phabricator
Branch
ssh1
Lint
Lint Passed
Unit
Tests Passed
Build Status
Buildable 23653
Build 32516: Run Core Tests
Build 32515: arc lint + arc unit