From 188f46d294ae8ed23dbf8eae9f8c5d2cff273376 Mon Sep 17 00:00:00 2001 From: Zeke Gabrielse Date: Fri, 7 Jun 2024 14:37:09 -0500 Subject: [PATCH] add better errors for authn failures --- client.go | 10 ++++++++++ errors.go | 9 +++++++++ 2 files changed, 19 insertions(+) diff --git a/client.go b/client.go index bec59d2..918bd06 100644 --- a/client.go +++ b/client.go @@ -374,6 +374,16 @@ func (c *Client) send(req *http.Request, model interface{}) (*Response, error) { // Handle certain license auth error codes so that we emit helpful errors switch { + case code == ErrorCodeTokenNotAllowed: + return response, ErrTokenNotAllowed + case code == ErrorCodeTokenFormatInvalid: + return response, ErrTokenFormatInvalid + case code == ErrorCodeTokenInvalid: + return response, ErrTokenInvalid + case code == ErrorCodeTokenExpired: + return response, ErrTokenExpired + case code == ErrorCodeLicenseNotAllowed: + return response, ErrLicenseNotAllowed case code == ErrorCodeLicenseSuspended: return response, ErrLicenseSuspended case code == ErrorCodeLicenseExpired: diff --git a/errors.go b/errors.go index d4e8178..003ab3d 100644 --- a/errors.go +++ b/errors.go @@ -12,10 +12,14 @@ type ErrorCode string const ( ErrorCodeEnvironmentInvalid ErrorCode = "ENVIRONMENT_INVALID" ErrorCodeEnvironmentNotSupported ErrorCode = "ENVIRONMENT_NOT_SUPPORTED" + ErrorCodeTokenFormatInvalid ErrorCode = "TOKEN_FORMAT_INVALID" ErrorCodeTokenInvalid ErrorCode = "TOKEN_INVALID" + ErrorCodeTokenExpired ErrorCode = "TOKEN_EXPIRED" + ErrorCodeTokenNotAllowed ErrorCode = "TOKEN_NOT_ALLOWED" ErrorCodeLicenseInvalid ErrorCode = "LICENSE_INVALID" ErrorCodeLicenseExpired ErrorCode = "LICENSE_EXPIRED" ErrorCodeLicenseSuspended ErrorCode = "LICENSE_SUSPENDED" + ErrorCodeLicenseNotAllowed ErrorCode = "LICENSE_NOT_ALLOWED" ErrorCodeFingerprintTaken ErrorCode = "FINGERPRINT_TAKEN" ErrorCodeMachineLimitExceeded ErrorCode = "MACHINE_LIMIT_EXCEEDED" ErrorCodeProcessLimitExceeded ErrorCode = "MACHINE_PROCESS_LIMIT_EXCEEDED" @@ -140,6 +144,7 @@ var ( ErrLicenseKeyMissing = errors.New("license key is missing") ErrLicenseKeyNotGenuine = errors.New("license key is not genuine") ErrLicenseNotActivated = errors.New("license is not activated") + ErrLicenseNotAllowed = errors.New("license authentication is not allowed by policy") ErrLicenseExpired = errors.New("license is expired") ErrLicenseSuspended = errors.New("license is suspended") ErrLicenseTooManyMachines = errors.New("license has too many machines") @@ -152,5 +157,9 @@ var ( ErrLicenseFileNotGenuine = errors.New("license file is not genuine") ErrLicenseFileExpired = errors.New("license file is expired") ErrLicenseFileSecretMissing = errors.New("license file secret is missing") + ErrTokenNotAllowed = errors.New("token authentication is not allowed by policy") + ErrTokenFormatInvalid = errors.New("token format is invalid") + ErrTokenInvalid = errors.New("token is invalid") + ErrTokenExpired = errors.New("token is expired") ErrSystemClockUnsynced = errors.New("system clock is out of sync") )