PowerShell
PowerShell
SSH Auth Failure Reason (AuthenticatePwPk)
See more SSH Examples
This example demonstrates how to determine the failure reason for the case where both a password and private key are required for authentication. If authentication fails, was it because of an invalid private key, or an invalid password?Chilkat PowerShell Downloads
Add-Type -Path "C:\chilkat\ChilkatDotNet47-x64\ChilkatDotNet47.dll"
$success = $false
# This example assumes the Chilkat API to have been previously unlocked.
# See Global Unlock Sample for sample code.
# Load a private key to be used for SSH authentication.
$key = New-Object Chilkat.SshKey
$key.Password = "key_password"
$success = $key.FromOpenSshPrivateKey($key.LoadText("qa_data/my_private_key_file"))
if ($success -eq $false) {
$($key.LastErrorText)
exit
}
$ssh = New-Object Chilkat.Ssh
$success = $ssh.Connect("ssh.example.com",22)
if ($success -eq $false) {
$($ssh.LastErrorText)
exit
}
# Authenticate using both a password and private key.
$success = $ssh.AuthenticatePwPk("myLogin","myPassword",$key)
if ($success -eq $true) {
$("Authentication is successful!")
exit
}
# If we get here, it means the authentication failed.
# Examine the last JSON data to get information..
$json = New-Object Chilkat.JsonObject
$ssh.GetLastJsonData($json)
$json.EmitCompact = $false
# This is the JSON if the key is correct, but the password is incorrect:
# {
# "public_key_type": "rsa",
# "partialAuthResult": "publickey success. continue to authenticate with password...",
# "authResult": "failed",
# "authFailReason": "Password is incorrect"
# }
# This is the JSON if the key is incorrect. We won't know if the password is also incorrect until
# the key is made correct so that authentication proceeds to check the password.
# {
# "public_key_type": "rsa",
# "authResult": "failed",
# "authFailReason": "Key is incorrect"
# }
# To get the authResult anbd authFailReason:
$("authResult: " + $json.StringOf("authResult"))
$("authFailReason: " + $json.StringOf("authFailReason"))