Page MenuHomePhabricator

Perform a more sophisticated test for private keys with credentials
AbandonedPublic

Authored by epriestley on Nov 11 2019, 7:19 PM.
Tags
None
Referenced Files
F14710672: D20904.diff
Fri, Jan 17, 2:15 PM
Unknown Object (File)
Sun, Jan 5, 11:30 PM
Unknown Object (File)
Thu, Jan 2, 6:59 PM
Unknown Object (File)
Sat, Dec 28, 4:10 AM
Unknown Object (File)
Nov 18 2024, 8:40 PM
Unknown Object (File)
Oct 19 2024, 4:12 AM
Unknown Object (File)
Oct 19 2024, 4:07 AM
Unknown Object (File)
Oct 17 2024, 3:00 AM
Subscribers
None

Details

Summary

Ref T13454. Ref T13123. Ref T13006. We currently test if a private key has a password by looking for the text "ENCRYPTED" in the key body. This test is obviously unsophisticated, and can not identify all keys with passphrases.

Modern keys with passphrases look like this:

-----BEGIN OPENSSH PRIVATE KEY-----
b3BlbnNzaC1rZXktdjEAAAAACmFlczI1Ni1jdHIAAAAGYmNyeXB0AAAAGAAAABDvWlhrGB
...
BMtSyiq+AScOPPbrkMZzOdqbo97JyO3hMe8Ha8bhuclZiM0qWg
-----END OPENSSH PRIVATE KEY-----

Instead, detect that a key has a passphrase by changing the passphrase from "" (the empty string) to "" (the empty string). If this works: no passphrase. If it fails, assume that indicates it's a passphrase protected key (although it could indicate that it's just a bad key).

There's another technique here with SSH_ASKPASS=... but:

  • I couldn't get that to work at all; and
  • I couldn't come up with a simple way to determine that our ASKPASS binary has been invoked, to improve our confidence that we're geninely detecting a private key with a password.
Test Plan

Uploaded a modern private key with a password; saw it detect properly.

Diff Detail

Repository
rP Phabricator
Branch
ssh1
Lint
Lint Passed
Unit
Tests Passed
Build Status
Buildable 23652
Build 32514: Run Core Tests
Build 32513: arc lint + arc unit