Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

(cli): CLI may fail on credentials coming from credential provider plugins #32653

Closed
1 task done
HBobertz opened this issue Dec 24, 2024 · 4 comments
Closed
1 task done
Labels
@aws-cdk/core Related to core CDK functionality bug This issue is a bug. management/tracking Issues that track a subject or multiple issues p0 package/tools Related to AWS CDK Tools or CLI potential-regression Marking this issue as a potential regression to be checked by team member

Comments

@HBobertz
Copy link
Contributor

HBobertz commented Dec 24, 2024

Please add your +1 👍 to let us know you have encountered this

Status: IN-PROGRESS

Overview:

Regression introduced here: #32354

It seems credential plugins returning empty credentials, or credentials with null expiration fields, would cause the CLI to throw an exception from CDK versions >=2.172.0 and <=2.173.1

UPDATE: As of patch release 2.173.2 it appears some customers are still reporting impact, if you are impacted please downgrade your cdk version to <= 2.171.0.

Complete Error Message:

Plugin returned a value that doesn't resemble AWS credentials: myAwesomeCredentials {
  expired: false,
  expireTime: 1970-01-01T00:00:00.000Z,
  // ...
}

or

TypeError: Cannot read properties of null (reading 'getTime')

Workaround:

Downgrade to CDK version <=2.171.0

Solution:

Upgrade to CDK version 2.173.2

Some users are reporting that even after upgrading to version 2.173.2, they are still seeing the same failures. If upgrading to version <=2.171.0

Related Issues:


Original issue

Describe the bug

The CDK Cli from versions 2.172.0 to 2.173.1 improperly handled edge case scenarios related to credential providers.
Specifically the scenarios where the CLI would throw an error were:

Credential Provider plugins providing initially empty credentials, which would fail a property check validating if the credentials were SDKv2 configured, causing the CLI to reject the credentials:

Plugin returned a value that doesn't resemble AWS credentials: myAwesomeCredentials {
  expired: false,
  expireTime: 1970-01-01T00:00:00.000Z,
  // ...
}

Or if the credentials specifically had a null value for expiration time which would result in an expiration time check throwing an exception:

TypeError: Cannot read properties of null (reading 'getTime')

If your CLI credential provider plugin was returning credentials in either state, then any CDK Command requiring credentials would fail.

Regression Issue

  • Select this option if this issue appears to be a regression.

Last Known Working CDK Version

2.171.0

Expected Behavior

CLI should not throw exceptions when receiving empty credentials or credentials with null expiration times as these are potentially valid states for a credential provider to return.

Current Behavior

If the credential provider returns empty credentials the, CLI Throws with the error:

Plugin returned a value that doesn't resemble AWS credentials:

and if the credentials expiration field is null instead of undefined the CLI throws with the error:

TypeError: Cannot read properties of null (reading 'getTime')

Reproduction Steps

Run any cdk cli command which requires credentials with a credential provider returning either empty credentials, or a null value for expiration

cdk bootstrap

Possible Solution

Upgrade to cdk version 2.173.2

Additional Information/Context

No response

CDK CLI Version

2.173.0

Framework Version

No response

Node.js Version

v22.12.0

OS

MacOS

Language

TypeScript

Language Version

No response

Other information

No response

@HBobertz HBobertz added bug This issue is a bug. needs-triage This issue or PR still needs to be triaged. labels Dec 24, 2024
@github-actions github-actions bot added package/tools Related to AWS CDK Tools or CLI potential-regression Marking this issue as a potential regression to be checked by team member labels Dec 24, 2024
@HBobertz HBobertz added p0 management/tracking Issues that track a subject or multiple issues @aws-cdk/core Related to core CDK functionality and removed needs-triage This issue or PR still needs to be triaged. labels Dec 24, 2024
@HBobertz
Copy link
Contributor Author

Fixed by #32554 and #32552

Copy link

Comments on closed issues and PRs are hard for our team to see.
If you need help, please open a new issue that references this one.

@github-actions github-actions bot locked as resolved and limited conversation to collaborators Dec 24, 2024
@HBobertz HBobertz pinned this issue Dec 24, 2024
@HBobertz HBobertz changed the title (credentials): CLI fails to validate initially empty credentials or credentials with null expiration time (cli): CLI fails to validate initially empty credentials or credentials with null expiration time Dec 24, 2024
@HBobertz HBobertz reopened this Dec 24, 2024
@HBobertz
Copy link
Contributor Author

Re-opening issue as some customers are still reporting impact on version 2.173.2

Unfortunately this happened on Christmas eve, but calling out to downgrade version if you are affected for now

@HBobertz HBobertz changed the title (cli): CLI fails to validate initially empty credentials or credentials with null expiration time (cli): CLI may fail on credentials coming from credential provider plugins Dec 24, 2024
@HBobertz HBobertz changed the title (cli): CLI may fail on credentials coming from credential provider plugins (cli): CLI may fail on credentials coming from credential provider plugins on versions >=172.0 Dec 24, 2024
@HBobertz HBobertz changed the title (cli): CLI may fail on credentials coming from credential provider plugins on versions >=172.0 (cli): CLI may fail on credentials coming from credential provider plugins on versions Dec 24, 2024
@HBobertz HBobertz changed the title (cli): CLI may fail on credentials coming from credential provider plugins on versions (cli): CLI may fail on credentials coming from credential provider plugins Dec 24, 2024
@iliapolo
Copy link
Contributor

iliapolo commented Jan 6, 2025

Got internal confirmation this is resolved

@iliapolo iliapolo closed this as completed Jan 6, 2025
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
@aws-cdk/core Related to core CDK functionality bug This issue is a bug. management/tracking Issues that track a subject or multiple issues p0 package/tools Related to AWS CDK Tools or CLI potential-regression Marking this issue as a potential regression to be checked by team member
Projects
None yet
Development

No branches or pull requests

2 participants