Skip to content

Commit be37764

Browse files
committed
chore(credential-providers): attribute credential feature sources
1 parent 7a4c3f6 commit be37764

File tree

25 files changed

+108
-32
lines changed

25 files changed

+108
-32
lines changed

clients/client-sts/src/defaultStsRoleAssumers.ts

Lines changed: 10 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,7 @@
11
// smithy-typescript generated code
22
// Please do not touch this file. It's generated from template in:
33
// https://github.com/aws/aws-sdk-js-v3/blob/main/codegen/smithy-aws-typescript-codegen/src/main/resources/software/amazon/smithy/aws/typescript/codegen/sts-client-defaultStsRoleAssumers.ts
4+
import { setCredentialFeature } from "@aws-sdk/core";
45
import type { CredentialProviderOptions } from "@aws-sdk/types";
56
import { AwsCredentialIdentity, Logger, Provider } from "@smithy/types";
67

@@ -118,7 +119,7 @@ export const getDefaultRoleAssumer = (
118119

119120
const accountId = getAccountIdFromAssumedRoleUser(AssumedRoleUser);
120121

121-
return {
122+
const credentials = {
122123
accessKeyId: Credentials.AccessKeyId,
123124
secretAccessKey: Credentials.SecretAccessKey,
124125
sessionToken: Credentials.SessionToken,
@@ -127,6 +128,8 @@ export const getDefaultRoleAssumer = (
127128
...((Credentials as any).CredentialScope && { credentialScope: (Credentials as any).CredentialScope }),
128129
...(accountId && { accountId }),
129130
};
131+
setCredentialFeature(credentials, "CREDENTIALS_STS_ASSUME_ROLE", "i");
132+
return credentials;
130133
};
131134
};
132135

@@ -174,7 +177,7 @@ export const getDefaultRoleAssumerWithWebIdentity = (
174177

175178
const accountId = getAccountIdFromAssumedRoleUser(AssumedRoleUser);
176179

177-
return {
180+
const credentials = {
178181
accessKeyId: Credentials.AccessKeyId,
179182
secretAccessKey: Credentials.SecretAccessKey,
180183
sessionToken: Credentials.SessionToken,
@@ -183,6 +186,11 @@ export const getDefaultRoleAssumerWithWebIdentity = (
183186
...((Credentials as any).CredentialScope && { credentialScope: (Credentials as any).CredentialScope }),
184187
...(accountId && { accountId }),
185188
};
189+
if (accountId) {
190+
setCredentialFeature(credentials, "RESOLVED_ACCOUNT_ID", "T");
191+
}
192+
setCredentialFeature(credentials, "CREDENTIALS_STS_ASSUME_ROLE_WEB_ID", "k");
193+
return credentials;
186194
};
187195
};
188196

codegen/smithy-aws-typescript-codegen/src/main/resources/software/amazon/smithy/aws/typescript/codegen/sts-client-defaultStsRoleAssumers.ts

Lines changed: 10 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1,3 +1,4 @@
1+
import { setCredentialFeature } from "@aws-sdk/core";
12
import type { CredentialProviderOptions } from "@aws-sdk/types";
23
import { AwsCredentialIdentity, Logger, Provider } from "@smithy/types";
34

@@ -115,7 +116,7 @@ export const getDefaultRoleAssumer = (
115116

116117
const accountId = getAccountIdFromAssumedRoleUser(AssumedRoleUser);
117118

118-
return {
119+
const credentials = {
119120
accessKeyId: Credentials.AccessKeyId,
120121
secretAccessKey: Credentials.SecretAccessKey,
121122
sessionToken: Credentials.SessionToken,
@@ -124,6 +125,8 @@ export const getDefaultRoleAssumer = (
124125
...((Credentials as any).CredentialScope && { credentialScope: (Credentials as any).CredentialScope }),
125126
...(accountId && { accountId }),
126127
};
128+
setCredentialFeature(credentials, "CREDENTIALS_STS_ASSUME_ROLE", "i");
129+
return credentials;
127130
};
128131
};
129132

@@ -171,7 +174,7 @@ export const getDefaultRoleAssumerWithWebIdentity = (
171174

172175
const accountId = getAccountIdFromAssumedRoleUser(AssumedRoleUser);
173176

174-
return {
177+
const credentials = {
175178
accessKeyId: Credentials.AccessKeyId,
176179
secretAccessKey: Credentials.SecretAccessKey,
177180
sessionToken: Credentials.SessionToken,
@@ -180,6 +183,11 @@ export const getDefaultRoleAssumerWithWebIdentity = (
180183
...((Credentials as any).CredentialScope && { credentialScope: (Credentials as any).CredentialScope }),
181184
...(accountId && { accountId }),
182185
};
186+
if (accountId) {
187+
setCredentialFeature(credentials, "RESOLVED_ACCOUNT_ID", "T");
188+
}
189+
setCredentialFeature(credentials, "CREDENTIALS_STS_ASSUME_ROLE_WEB_ID", "k");
190+
return credentials;
183191
};
184192
};
185193

packages/core/src/submodules/client/setFeature.ts

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -33,7 +33,7 @@ export function setFeature<F extends keyof AwsSdkFeatures>(
3333
/**
3434
* @internal
3535
*
36-
* sets feature attribution on the credential object.
36+
* @returns the credentials with source feature attribution.
3737
*/
3838
export function setCredentialFeature<F extends keyof AwsSdkCredentialsFeatures>(
3939
credentials: AttributedAwsCredentialIdentity,

packages/core/src/submodules/httpAuthSchemes/aws_sdk/resolveAwsSdkSigV4Config.ts

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,4 @@
1-
import { setCredentialFeature } from "@aws-sdk/core/client";
1+
import { setCredentialFeature } from "@aws-sdk/core";
22
import { AttributedAwsCredentialIdentity } from "@aws-sdk/types";
33
import {
44
doesIdentityRequireRefresh,

packages/credential-provider-env/package.json

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -24,6 +24,7 @@
2424
},
2525
"license": "Apache-2.0",
2626
"dependencies": {
27+
"@aws-sdk/core": "*",
2728
"@aws-sdk/types": "*",
2829
"@smithy/property-provider": "^3.1.7",
2930
"@smithy/types": "^3.5.0",

packages/credential-provider-env/src/fromEnv.ts

Lines changed: 1 addition & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,4 @@
1-
import { setCredentialFeature } from "@aws-sdk/core/client";
1+
import { setCredentialFeature } from "@aws-sdk/core";
22
import type { AttributedAwsCredentialIdentity, CredentialProviderOptions } from "@aws-sdk/types";
33
import { CredentialsProviderError } from "@smithy/property-provider";
44
import { AwsCredentialIdentityProvider } from "@smithy/types";
@@ -58,9 +58,6 @@ export const fromEnv =
5858
...(accountId && { accountId }),
5959
} as AttributedAwsCredentialIdentity;
6060
setCredentialFeature(credentials, "CREDENTIALS_ENV_VARS", "g");
61-
if (accountId) {
62-
setCredentialFeature(credentials, "RESOLVED_ACCOUNT_ID", "T");
63-
}
6461
return credentials;
6562
}
6663

packages/credential-provider-http/package.json

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -26,6 +26,7 @@
2626
},
2727
"license": "Apache-2.0",
2828
"dependencies": {
29+
"@aws-sdk/core": "*",
2930
"@aws-sdk/types": "*",
3031
"@smithy/fetch-http-handler": "^3.2.9",
3132
"@smithy/node-http-handler": "^3.2.4",

packages/credential-provider-http/src/fromHttp/fromHttp.ts

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1,3 +1,4 @@
1+
import { setCredentialFeature } from "@aws-sdk/core";
12
import { NodeHttpHandler } from "@smithy/node-http-handler";
23
import { CredentialsProviderError } from "@smithy/property-provider";
34
import { AwsCredentialIdentity, AwsCredentialIdentityProvider } from "@smithy/types";
@@ -81,7 +82,7 @@ Set AWS_CONTAINER_CREDENTIALS_FULL_URI or AWS_CONTAINER_CREDENTIALS_RELATIVE_URI
8182
}
8283
try {
8384
const result = await requestHandler.handle(request);
84-
return getCredentials(result.response);
85+
return getCredentials(result.response).then((creds) => setCredentialFeature(creds, "CREDENTIALS_HTTP", "z"));
8586
} catch (e: unknown) {
8687
throw new CredentialsProviderError(String(e), { logger: options.logger });
8788
}

packages/credential-provider-ini/package.json

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -24,6 +24,7 @@
2424
},
2525
"license": "Apache-2.0",
2626
"dependencies": {
27+
"@aws-sdk/core": "*",
2728
"@aws-sdk/credential-provider-env": "*",
2829
"@aws-sdk/credential-provider-http": "*",
2930
"@aws-sdk/credential-provider-process": "*",

packages/credential-provider-ini/src/resolveAssumeRoleCredentials.ts

Lines changed: 5 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1,3 +1,4 @@
1+
import { setCredentialFeature } from "@aws-sdk/core";
12
import { CredentialsProviderError } from "@smithy/property-provider";
23
import { getProfileName } from "@smithy/shared-ini-file-loader";
34
import { AwsCredentialIdentity, IniSection, Logger, ParsedIniData, Profile } from "@smithy/types";
@@ -159,7 +160,7 @@ export const resolveAssumeRoleCredentials = async (
159160
* can use its role_arn instead of redundantly needing another role_arn at
160161
* this final layer.
161162
*/
162-
return sourceCredsProvider;
163+
return sourceCredsProvider.then((creds) => setCredentialFeature(creds, "CREDENTIALS_PROFILE_SOURCE_PROFILE", "o"));
163164
} else {
164165
const params: AssumeRoleParams = {
165166
RoleArn: data.role_arn!,
@@ -181,7 +182,9 @@ export const resolveAssumeRoleCredentials = async (
181182
}
182183

183184
const sourceCreds = await sourceCredsProvider;
184-
return options.roleAssumer!(sourceCreds, params);
185+
return options.roleAssumer!(sourceCreds, params).then((creds) =>
186+
setCredentialFeature(creds, "CREDENTIALS_PROFILE_SOURCE_PROFILE", "o")
187+
);
185188
}
186189
};
187190

0 commit comments

Comments
 (0)