Created
June 27, 2016 15:06
-
-
Save ianphil/b5e051cd1c34de95a693a633737a6ae1 to your computer and use it in GitHub Desktop.
Read and Write passwords securely from PowerShell
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
function New-PasswordFile { | |
param($cert) | |
try { | |
$secureString = Read-Host -Prompt 'Enter password...' -AsSecureString | |
$rng = [System.Security.Cryptography.RNGCryptoServiceProvider]::Create() | |
$key = New-Object byte[](32) | |
$rng.GetBytes($key) | |
$encryptedSecureString = ConvertFrom-SecureString -SecureString $secureString -Key $key | |
$encryptedKey = New-Object psobject -Property @{ | |
Thumbprint = $cert.Thumbprint | |
Key = $cert.PublicKey.Key.Encrypt($key, $true) | |
} | |
$outputObject = New-Object psobject -Property @{ | |
Payload = $encryptedSecureString | |
KeyInfo = $encryptedKey | |
} | |
$outputObject | Export-Clixml -Path C:\tools\password.xml | |
Write-Host 'Created file C:\tools\password.xml' | |
} | |
finally { | |
if ($null -ne $key) | |
{ | |
[array]::Clear($key, 0, $key.Length) | |
$key = $null | |
} | |
} | |
} | |
function Get-CredentialFromFile { | |
param($cert) | |
try { | |
$object = Import-Clixml -Path C:\tools\password.xml | |
$key = $null | |
if ($cert.Thumbprint -eq $object.KeyInfo.Thumbprint) { | |
$key = $cert.PrivateKey.Decrypt($object.KeyInfo.Key, $true) | |
} | |
else { | |
Write-Error "No certificate matching thumbprint '$($cert.Thumbprint)' was used to protect the data." | |
} | |
$secureString = ConvertTo-SecureString -String $object.Payload -Key $key | |
$cred = New-Object System.Management.Automation.PSCredential('[email protected]', $secureString) | |
return $cred | |
} | |
finally { | |
if ($null -ne $key) | |
{ | |
[array]::Clear($key, 0, $key.Length) | |
$key = $null | |
} | |
} | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment