@granite-js/pulumi-aws 0.1.19 → 0.1.21

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (58) hide show
  1. package/CHANGELOG.md +8 -0
  2. package/dist/chunk-5W7B34BN.js +3307 -0
  3. package/dist/chunk-64IS37V6.js +17 -0
  4. package/dist/chunk-AEOST5WF.js +63 -0
  5. package/dist/chunk-B7OAPHPY.js +46 -0
  6. package/dist/chunk-FO7L563E.js +13695 -0
  7. package/dist/chunk-FRWSD3YQ.js +1722 -0
  8. package/dist/chunk-IEZY5C3G.js +120 -0
  9. package/dist/chunk-ITI6QA2Q.js +12 -0
  10. package/dist/chunk-IUKLHJNE.js +49 -0
  11. package/dist/chunk-JBVMOFGH.js +152 -0
  12. package/dist/chunk-JSBRDJBE.js +30 -0
  13. package/dist/chunk-KGNTV362.js +209 -0
  14. package/dist/chunk-KRJS4RAS.js +1732 -0
  15. package/dist/chunk-M5GUUX64.js +63 -0
  16. package/dist/chunk-QAE2S7MG.js +3351 -0
  17. package/dist/chunk-SX6SVQKS.js +67 -0
  18. package/dist/chunk-TJ744C2T.js +198 -0
  19. package/dist/chunk-UNXXS5FM.js +120 -0
  20. package/dist/chunk-UT2RMOJS.js +2447 -0
  21. package/dist/chunk-VOTRVWIB.js +1965 -0
  22. package/dist/chunk-W3VXP3A3.js +119 -0
  23. package/dist/chunk-WCHHWTND.js +113 -0
  24. package/dist/chunk-X6XO7USX.js +110 -0
  25. package/dist/chunk-XLUI7RQ4.js +115 -0
  26. package/dist/dist-es-2M7RLZ5O.js +200 -0
  27. package/dist/dist-es-ADTONJUN-RVFWNZHO.js +67 -0
  28. package/dist/dist-es-CDFIYJVE.js +163 -0
  29. package/dist/dist-es-GHYMLBON.js +379 -0
  30. package/dist/dist-es-HJVOMDYC-PIAMWMAL.js +87 -0
  31. package/dist/dist-es-IDBDK36G-Y6TQMRO5.js +299 -0
  32. package/dist/dist-es-OCQVKISC-TNAJ62WG.js +161 -0
  33. package/dist/dist-es-OZGLUDWT.js +305 -0
  34. package/dist/dist-es-PRWCVZGQ-HTTVI42T.js +21 -0
  35. package/dist/dist-es-S75EKWRJ.js +88 -0
  36. package/dist/dist-es-SUPEA6VE-3B5JSW5C.js +368 -0
  37. package/dist/dist-es-WQHDOVD7.js +21 -0
  38. package/dist/dist-es-XQME5F6W.js +67 -0
  39. package/dist/dist-es-Y7VN37H5-WQ3GYROF.js +196 -0
  40. package/dist/lambda/auto-cache-removal.d.cts +17 -0
  41. package/dist/lambda/auto-cache-removal.d.ts +17 -0
  42. package/dist/lambda/auto-cache-removal.js +5313 -0
  43. package/dist/lambda/origin-request.d.cts +14 -0
  44. package/dist/lambda/origin-request.d.ts +14 -0
  45. package/dist/lambda/origin-request.js +113 -0
  46. package/dist/lambda/origin-response.d.cts +6 -0
  47. package/dist/lambda/origin-response.d.ts +6 -0
  48. package/dist/lambda/origin-response.js +52 -0
  49. package/dist/loadSso-CZSSLFH6-SA5HOQAX.js +645 -0
  50. package/dist/loadSso-T7GJVVO2.js +655 -0
  51. package/dist/sso-oidc-55SJ27II.js +827 -0
  52. package/dist/sso-oidc-PKO5GYK5-LC65L46O.js +820 -0
  53. package/dist/sts-OPF4H3GL.js +1162 -0
  54. package/dist/sts-P7Q3MYTS-BKGWHQE4.js +1152 -0
  55. package/lambda/auto-cache-removal.d.ts +1 -0
  56. package/lambda/origin-request.d.ts +1 -0
  57. package/lambda/origin-response.d.ts +1 -0
  58. package/package.json +37 -10
@@ -0,0 +1,67 @@
1
+ import {
2
+ setCredentialFeature
3
+ } from "./chunk-64IS37V6.js";
4
+ import {
5
+ CredentialsProviderError,
6
+ init_esm_shims
7
+ } from "./chunk-JBVMOFGH.js";
8
+ import "./chunk-JSBRDJBE.js";
9
+
10
+ // ../deployment-manager/dist/dist-es-ADTONJUN.js
11
+ import { readFileSync } from "fs";
12
+ init_esm_shims();
13
+ init_esm_shims();
14
+ init_esm_shims();
15
+ var fromWebToken = (init) => async (awsIdentityProperties) => {
16
+ init.logger?.debug("@aws-sdk/credential-provider-web-identity - fromWebToken");
17
+ const { roleArn, roleSessionName, webIdentityToken, providerId, policyArns, policy, durationSeconds } = init;
18
+ let { roleAssumerWithWebIdentity } = init;
19
+ if (!roleAssumerWithWebIdentity) {
20
+ const { getDefaultRoleAssumerWithWebIdentity } = await import("./sts-P7Q3MYTS-BKGWHQE4.js");
21
+ roleAssumerWithWebIdentity = getDefaultRoleAssumerWithWebIdentity({
22
+ ...init.clientConfig,
23
+ credentialProviderLogger: init.logger,
24
+ parentClientConfig: {
25
+ ...awsIdentityProperties?.callerClientConfig,
26
+ ...init.parentClientConfig
27
+ }
28
+ }, init.clientPlugins);
29
+ }
30
+ return roleAssumerWithWebIdentity({
31
+ RoleArn: roleArn,
32
+ RoleSessionName: roleSessionName ?? `aws-sdk-js-session-${Date.now()}`,
33
+ WebIdentityToken: webIdentityToken,
34
+ ProviderId: providerId,
35
+ PolicyArns: policyArns,
36
+ Policy: policy,
37
+ DurationSeconds: durationSeconds
38
+ });
39
+ };
40
+ var ENV_TOKEN_FILE = "AWS_WEB_IDENTITY_TOKEN_FILE";
41
+ var ENV_ROLE_ARN = "AWS_ROLE_ARN";
42
+ var ENV_ROLE_SESSION_NAME = "AWS_ROLE_SESSION_NAME";
43
+ var fromTokenFile = (init = {}) => async () => {
44
+ init.logger?.debug("@aws-sdk/credential-provider-web-identity - fromTokenFile");
45
+ const webIdentityTokenFile = init?.webIdentityTokenFile ?? process.env[ENV_TOKEN_FILE];
46
+ const roleArn = init?.roleArn ?? process.env[ENV_ROLE_ARN];
47
+ const roleSessionName = init?.roleSessionName ?? process.env[ENV_ROLE_SESSION_NAME];
48
+ if (!webIdentityTokenFile || !roleArn) {
49
+ throw new CredentialsProviderError("Web identity configuration not specified", {
50
+ logger: init.logger
51
+ });
52
+ }
53
+ const credentials = await fromWebToken({
54
+ ...init,
55
+ webIdentityToken: readFileSync(webIdentityTokenFile, { encoding: "ascii" }),
56
+ roleArn,
57
+ roleSessionName
58
+ })();
59
+ if (webIdentityTokenFile === process.env[ENV_TOKEN_FILE]) {
60
+ setCredentialFeature(credentials, "CREDENTIALS_ENV_VARS_STS_WEB_ID_TOKEN", "h");
61
+ }
62
+ return credentials;
63
+ };
64
+ export {
65
+ fromTokenFile,
66
+ fromWebToken
67
+ };
@@ -0,0 +1,163 @@
1
+ import {
2
+ HttpRequest,
3
+ NodeHttpHandler,
4
+ parseRfc3339DateTime,
5
+ sdkStreamMixin
6
+ } from "./chunk-VOTRVWIB.js";
7
+ import {
8
+ setCredentialFeature
9
+ } from "./chunk-ITI6QA2Q.js";
10
+ import "./chunk-M5GUUX64.js";
11
+ import {
12
+ CredentialsProviderError
13
+ } from "./chunk-W3VXP3A3.js";
14
+ import "./chunk-JSBRDJBE.js";
15
+
16
+ // ../../.yarn/cache/@aws-sdk-credential-provider-http-npm-3.816.0-3c2ea7ee45-e44b2bc15b.zip/node_modules/@aws-sdk/credential-provider-http/dist-es/fromHttp/fromHttp.js
17
+ import fs from "fs/promises";
18
+
19
+ // ../../.yarn/cache/@aws-sdk-credential-provider-http-npm-3.816.0-3c2ea7ee45-e44b2bc15b.zip/node_modules/@aws-sdk/credential-provider-http/dist-es/fromHttp/checkUrl.js
20
+ var ECS_CONTAINER_HOST = "169.254.170.2";
21
+ var EKS_CONTAINER_HOST_IPv4 = "169.254.170.23";
22
+ var EKS_CONTAINER_HOST_IPv6 = "[fd00:ec2::23]";
23
+ var checkUrl = (url, logger) => {
24
+ if (url.protocol === "https:") {
25
+ return;
26
+ }
27
+ if (url.hostname === ECS_CONTAINER_HOST || url.hostname === EKS_CONTAINER_HOST_IPv4 || url.hostname === EKS_CONTAINER_HOST_IPv6) {
28
+ return;
29
+ }
30
+ if (url.hostname.includes("[")) {
31
+ if (url.hostname === "[::1]" || url.hostname === "[0000:0000:0000:0000:0000:0000:0000:0001]") {
32
+ return;
33
+ }
34
+ } else {
35
+ if (url.hostname === "localhost") {
36
+ return;
37
+ }
38
+ const ipComponents = url.hostname.split(".");
39
+ const inRange = (component) => {
40
+ const num = parseInt(component, 10);
41
+ return 0 <= num && num <= 255;
42
+ };
43
+ if (ipComponents[0] === "127" && inRange(ipComponents[1]) && inRange(ipComponents[2]) && inRange(ipComponents[3]) && ipComponents.length === 4) {
44
+ return;
45
+ }
46
+ }
47
+ throw new CredentialsProviderError(`URL not accepted. It must either be HTTPS or match one of the following:
48
+ - loopback CIDR 127.0.0.0/8 or [::1/128]
49
+ - ECS container host 169.254.170.2
50
+ - EKS container host 169.254.170.23 or [fd00:ec2::23]`, { logger });
51
+ };
52
+
53
+ // ../../.yarn/cache/@aws-sdk-credential-provider-http-npm-3.816.0-3c2ea7ee45-e44b2bc15b.zip/node_modules/@aws-sdk/credential-provider-http/dist-es/fromHttp/requestHelpers.js
54
+ function createGetRequest(url) {
55
+ return new HttpRequest({
56
+ protocol: url.protocol,
57
+ hostname: url.hostname,
58
+ port: Number(url.port),
59
+ path: url.pathname,
60
+ query: Array.from(url.searchParams.entries()).reduce((acc, [k, v]) => {
61
+ acc[k] = v;
62
+ return acc;
63
+ }, {}),
64
+ fragment: url.hash
65
+ });
66
+ }
67
+ async function getCredentials(response, logger) {
68
+ const stream = sdkStreamMixin(response.body);
69
+ const str = await stream.transformToString();
70
+ if (response.statusCode === 200) {
71
+ const parsed = JSON.parse(str);
72
+ if (typeof parsed.AccessKeyId !== "string" || typeof parsed.SecretAccessKey !== "string" || typeof parsed.Token !== "string" || typeof parsed.Expiration !== "string") {
73
+ throw new CredentialsProviderError("HTTP credential provider response not of the required format, an object matching: { AccessKeyId: string, SecretAccessKey: string, Token: string, Expiration: string(rfc3339) }", { logger });
74
+ }
75
+ return {
76
+ accessKeyId: parsed.AccessKeyId,
77
+ secretAccessKey: parsed.SecretAccessKey,
78
+ sessionToken: parsed.Token,
79
+ expiration: parseRfc3339DateTime(parsed.Expiration)
80
+ };
81
+ }
82
+ if (response.statusCode >= 400 && response.statusCode < 500) {
83
+ let parsedBody = {};
84
+ try {
85
+ parsedBody = JSON.parse(str);
86
+ } catch (e) {
87
+ }
88
+ throw Object.assign(new CredentialsProviderError(`Server responded with status: ${response.statusCode}`, { logger }), {
89
+ Code: parsedBody.Code,
90
+ Message: parsedBody.Message
91
+ });
92
+ }
93
+ throw new CredentialsProviderError(`Server responded with status: ${response.statusCode}`, { logger });
94
+ }
95
+
96
+ // ../../.yarn/cache/@aws-sdk-credential-provider-http-npm-3.816.0-3c2ea7ee45-e44b2bc15b.zip/node_modules/@aws-sdk/credential-provider-http/dist-es/fromHttp/retry-wrapper.js
97
+ var retryWrapper = (toRetry, maxRetries, delayMs) => {
98
+ return async () => {
99
+ for (let i = 0; i < maxRetries; ++i) {
100
+ try {
101
+ return await toRetry();
102
+ } catch (e) {
103
+ await new Promise((resolve) => setTimeout(resolve, delayMs));
104
+ }
105
+ }
106
+ return await toRetry();
107
+ };
108
+ };
109
+
110
+ // ../../.yarn/cache/@aws-sdk-credential-provider-http-npm-3.816.0-3c2ea7ee45-e44b2bc15b.zip/node_modules/@aws-sdk/credential-provider-http/dist-es/fromHttp/fromHttp.js
111
+ var AWS_CONTAINER_CREDENTIALS_RELATIVE_URI = "AWS_CONTAINER_CREDENTIALS_RELATIVE_URI";
112
+ var DEFAULT_LINK_LOCAL_HOST = "http://169.254.170.2";
113
+ var AWS_CONTAINER_CREDENTIALS_FULL_URI = "AWS_CONTAINER_CREDENTIALS_FULL_URI";
114
+ var AWS_CONTAINER_AUTHORIZATION_TOKEN_FILE = "AWS_CONTAINER_AUTHORIZATION_TOKEN_FILE";
115
+ var AWS_CONTAINER_AUTHORIZATION_TOKEN = "AWS_CONTAINER_AUTHORIZATION_TOKEN";
116
+ var fromHttp = (options = {}) => {
117
+ options.logger?.debug("@aws-sdk/credential-provider-http - fromHttp");
118
+ let host;
119
+ const relative = options.awsContainerCredentialsRelativeUri ?? process.env[AWS_CONTAINER_CREDENTIALS_RELATIVE_URI];
120
+ const full = options.awsContainerCredentialsFullUri ?? process.env[AWS_CONTAINER_CREDENTIALS_FULL_URI];
121
+ const token = options.awsContainerAuthorizationToken ?? process.env[AWS_CONTAINER_AUTHORIZATION_TOKEN];
122
+ const tokenFile = options.awsContainerAuthorizationTokenFile ?? process.env[AWS_CONTAINER_AUTHORIZATION_TOKEN_FILE];
123
+ const warn = options.logger?.constructor?.name === "NoOpLogger" || !options.logger ? console.warn : options.logger.warn;
124
+ if (relative && full) {
125
+ warn("@aws-sdk/credential-provider-http: you have set both awsContainerCredentialsRelativeUri and awsContainerCredentialsFullUri.");
126
+ warn("awsContainerCredentialsFullUri will take precedence.");
127
+ }
128
+ if (token && tokenFile) {
129
+ warn("@aws-sdk/credential-provider-http: you have set both awsContainerAuthorizationToken and awsContainerAuthorizationTokenFile.");
130
+ warn("awsContainerAuthorizationToken will take precedence.");
131
+ }
132
+ if (full) {
133
+ host = full;
134
+ } else if (relative) {
135
+ host = `${DEFAULT_LINK_LOCAL_HOST}${relative}`;
136
+ } else {
137
+ throw new CredentialsProviderError(`No HTTP credential provider host provided.
138
+ Set AWS_CONTAINER_CREDENTIALS_FULL_URI or AWS_CONTAINER_CREDENTIALS_RELATIVE_URI.`, { logger: options.logger });
139
+ }
140
+ const url = new URL(host);
141
+ checkUrl(url, options.logger);
142
+ const requestHandler = new NodeHttpHandler({
143
+ requestTimeout: options.timeout ?? 1e3,
144
+ connectionTimeout: options.timeout ?? 1e3
145
+ });
146
+ return retryWrapper(async () => {
147
+ const request = createGetRequest(url);
148
+ if (token) {
149
+ request.headers.Authorization = token;
150
+ } else if (tokenFile) {
151
+ request.headers.Authorization = (await fs.readFile(tokenFile)).toString();
152
+ }
153
+ try {
154
+ const result = await requestHandler.handle(request);
155
+ return getCredentials(result.response).then((creds) => setCredentialFeature(creds, "CREDENTIALS_HTTP", "z"));
156
+ } catch (e) {
157
+ throw new CredentialsProviderError(String(e), { logger: options.logger });
158
+ }
159
+ }, options.maxRetries ?? 3, options.timeout ?? 1e3);
160
+ };
161
+ export {
162
+ fromHttp
163
+ };
@@ -0,0 +1,379 @@
1
+ import {
2
+ loadConfig,
3
+ parseUrl
4
+ } from "./chunk-WCHHWTND.js";
5
+ import "./chunk-KGNTV362.js";
6
+ import "./chunk-M5GUUX64.js";
7
+ import {
8
+ CredentialsProviderError,
9
+ ProviderError
10
+ } from "./chunk-W3VXP3A3.js";
11
+ import "./chunk-JSBRDJBE.js";
12
+
13
+ // ../../.yarn/cache/@smithy-credential-provider-imds-npm-4.0.5-fd3ae8c67b-b992b7d5e4.zip/node_modules/@smithy/credential-provider-imds/dist-es/fromContainerMetadata.js
14
+ import { parse } from "url";
15
+
16
+ // ../../.yarn/cache/@smithy-credential-provider-imds-npm-4.0.5-fd3ae8c67b-b992b7d5e4.zip/node_modules/@smithy/credential-provider-imds/dist-es/remoteProvider/httpRequest.js
17
+ import { Buffer } from "buffer";
18
+ import { request } from "http";
19
+ function httpRequest(options) {
20
+ return new Promise((resolve, reject) => {
21
+ const req = request({
22
+ method: "GET",
23
+ ...options,
24
+ hostname: options.hostname?.replace(/^\[(.+)\]$/, "$1")
25
+ });
26
+ req.on("error", (err) => {
27
+ reject(Object.assign(new ProviderError("Unable to connect to instance metadata service"), err));
28
+ req.destroy();
29
+ });
30
+ req.on("timeout", () => {
31
+ reject(new ProviderError("TimeoutError from instance metadata service"));
32
+ req.destroy();
33
+ });
34
+ req.on("response", (res) => {
35
+ const { statusCode = 400 } = res;
36
+ if (statusCode < 200 || 300 <= statusCode) {
37
+ reject(Object.assign(new ProviderError("Error response received from instance metadata service"), { statusCode }));
38
+ req.destroy();
39
+ }
40
+ const chunks = [];
41
+ res.on("data", (chunk) => {
42
+ chunks.push(chunk);
43
+ });
44
+ res.on("end", () => {
45
+ resolve(Buffer.concat(chunks));
46
+ req.destroy();
47
+ });
48
+ });
49
+ req.end();
50
+ });
51
+ }
52
+
53
+ // ../../.yarn/cache/@smithy-credential-provider-imds-npm-4.0.5-fd3ae8c67b-b992b7d5e4.zip/node_modules/@smithy/credential-provider-imds/dist-es/remoteProvider/ImdsCredentials.js
54
+ var isImdsCredentials = (arg) => Boolean(arg) && typeof arg === "object" && typeof arg.AccessKeyId === "string" && typeof arg.SecretAccessKey === "string" && typeof arg.Token === "string" && typeof arg.Expiration === "string";
55
+ var fromImdsCredentials = (creds) => ({
56
+ accessKeyId: creds.AccessKeyId,
57
+ secretAccessKey: creds.SecretAccessKey,
58
+ sessionToken: creds.Token,
59
+ expiration: new Date(creds.Expiration),
60
+ ...creds.AccountId && { accountId: creds.AccountId }
61
+ });
62
+
63
+ // ../../.yarn/cache/@smithy-credential-provider-imds-npm-4.0.5-fd3ae8c67b-b992b7d5e4.zip/node_modules/@smithy/credential-provider-imds/dist-es/remoteProvider/RemoteProviderInit.js
64
+ var DEFAULT_TIMEOUT = 1e3;
65
+ var DEFAULT_MAX_RETRIES = 0;
66
+ var providerConfigFromInit = ({ maxRetries = DEFAULT_MAX_RETRIES, timeout = DEFAULT_TIMEOUT }) => ({ maxRetries, timeout });
67
+
68
+ // ../../.yarn/cache/@smithy-credential-provider-imds-npm-4.0.5-fd3ae8c67b-b992b7d5e4.zip/node_modules/@smithy/credential-provider-imds/dist-es/remoteProvider/retry.js
69
+ var retry = (toRetry, maxRetries) => {
70
+ let promise = toRetry();
71
+ for (let i = 0; i < maxRetries; i++) {
72
+ promise = promise.catch(toRetry);
73
+ }
74
+ return promise;
75
+ };
76
+
77
+ // ../../.yarn/cache/@smithy-credential-provider-imds-npm-4.0.5-fd3ae8c67b-b992b7d5e4.zip/node_modules/@smithy/credential-provider-imds/dist-es/fromContainerMetadata.js
78
+ var ENV_CMDS_FULL_URI = "AWS_CONTAINER_CREDENTIALS_FULL_URI";
79
+ var ENV_CMDS_RELATIVE_URI = "AWS_CONTAINER_CREDENTIALS_RELATIVE_URI";
80
+ var ENV_CMDS_AUTH_TOKEN = "AWS_CONTAINER_AUTHORIZATION_TOKEN";
81
+ var fromContainerMetadata = (init = {}) => {
82
+ const { timeout, maxRetries } = providerConfigFromInit(init);
83
+ return () => retry(async () => {
84
+ const requestOptions = await getCmdsUri({ logger: init.logger });
85
+ const credsResponse = JSON.parse(await requestFromEcsImds(timeout, requestOptions));
86
+ if (!isImdsCredentials(credsResponse)) {
87
+ throw new CredentialsProviderError("Invalid response received from instance metadata service.", {
88
+ logger: init.logger
89
+ });
90
+ }
91
+ return fromImdsCredentials(credsResponse);
92
+ }, maxRetries);
93
+ };
94
+ var requestFromEcsImds = async (timeout, options) => {
95
+ if (process.env[ENV_CMDS_AUTH_TOKEN]) {
96
+ options.headers = {
97
+ ...options.headers,
98
+ Authorization: process.env[ENV_CMDS_AUTH_TOKEN]
99
+ };
100
+ }
101
+ const buffer = await httpRequest({
102
+ ...options,
103
+ timeout
104
+ });
105
+ return buffer.toString();
106
+ };
107
+ var CMDS_IP = "169.254.170.2";
108
+ var GREENGRASS_HOSTS = {
109
+ localhost: true,
110
+ "127.0.0.1": true
111
+ };
112
+ var GREENGRASS_PROTOCOLS = {
113
+ "http:": true,
114
+ "https:": true
115
+ };
116
+ var getCmdsUri = async ({ logger }) => {
117
+ if (process.env[ENV_CMDS_RELATIVE_URI]) {
118
+ return {
119
+ hostname: CMDS_IP,
120
+ path: process.env[ENV_CMDS_RELATIVE_URI]
121
+ };
122
+ }
123
+ if (process.env[ENV_CMDS_FULL_URI]) {
124
+ const parsed = parse(process.env[ENV_CMDS_FULL_URI]);
125
+ if (!parsed.hostname || !(parsed.hostname in GREENGRASS_HOSTS)) {
126
+ throw new CredentialsProviderError(`${parsed.hostname} is not a valid container metadata service hostname`, {
127
+ tryNextLink: false,
128
+ logger
129
+ });
130
+ }
131
+ if (!parsed.protocol || !(parsed.protocol in GREENGRASS_PROTOCOLS)) {
132
+ throw new CredentialsProviderError(`${parsed.protocol} is not a valid container metadata service protocol`, {
133
+ tryNextLink: false,
134
+ logger
135
+ });
136
+ }
137
+ return {
138
+ ...parsed,
139
+ port: parsed.port ? parseInt(parsed.port, 10) : void 0
140
+ };
141
+ }
142
+ throw new CredentialsProviderError(`The container metadata credential provider cannot be used unless the ${ENV_CMDS_RELATIVE_URI} or ${ENV_CMDS_FULL_URI} environment variable is set`, {
143
+ tryNextLink: false,
144
+ logger
145
+ });
146
+ };
147
+
148
+ // ../../.yarn/cache/@smithy-credential-provider-imds-npm-4.0.5-fd3ae8c67b-b992b7d5e4.zip/node_modules/@smithy/credential-provider-imds/dist-es/error/InstanceMetadataV1FallbackError.js
149
+ var InstanceMetadataV1FallbackError = class _InstanceMetadataV1FallbackError extends CredentialsProviderError {
150
+ constructor(message, tryNextLink = true) {
151
+ super(message, tryNextLink);
152
+ this.tryNextLink = tryNextLink;
153
+ this.name = "InstanceMetadataV1FallbackError";
154
+ Object.setPrototypeOf(this, _InstanceMetadataV1FallbackError.prototype);
155
+ }
156
+ };
157
+
158
+ // ../../.yarn/cache/@smithy-credential-provider-imds-npm-4.0.5-fd3ae8c67b-b992b7d5e4.zip/node_modules/@smithy/credential-provider-imds/dist-es/config/Endpoint.js
159
+ var Endpoint;
160
+ (function(Endpoint2) {
161
+ Endpoint2["IPv4"] = "http://169.254.169.254";
162
+ Endpoint2["IPv6"] = "http://[fd00:ec2::254]";
163
+ })(Endpoint || (Endpoint = {}));
164
+
165
+ // ../../.yarn/cache/@smithy-credential-provider-imds-npm-4.0.5-fd3ae8c67b-b992b7d5e4.zip/node_modules/@smithy/credential-provider-imds/dist-es/config/EndpointConfigOptions.js
166
+ var ENV_ENDPOINT_NAME = "AWS_EC2_METADATA_SERVICE_ENDPOINT";
167
+ var CONFIG_ENDPOINT_NAME = "ec2_metadata_service_endpoint";
168
+ var ENDPOINT_CONFIG_OPTIONS = {
169
+ environmentVariableSelector: (env) => env[ENV_ENDPOINT_NAME],
170
+ configFileSelector: (profile) => profile[CONFIG_ENDPOINT_NAME],
171
+ default: void 0
172
+ };
173
+
174
+ // ../../.yarn/cache/@smithy-credential-provider-imds-npm-4.0.5-fd3ae8c67b-b992b7d5e4.zip/node_modules/@smithy/credential-provider-imds/dist-es/config/EndpointMode.js
175
+ var EndpointMode;
176
+ (function(EndpointMode2) {
177
+ EndpointMode2["IPv4"] = "IPv4";
178
+ EndpointMode2["IPv6"] = "IPv6";
179
+ })(EndpointMode || (EndpointMode = {}));
180
+
181
+ // ../../.yarn/cache/@smithy-credential-provider-imds-npm-4.0.5-fd3ae8c67b-b992b7d5e4.zip/node_modules/@smithy/credential-provider-imds/dist-es/config/EndpointModeConfigOptions.js
182
+ var ENV_ENDPOINT_MODE_NAME = "AWS_EC2_METADATA_SERVICE_ENDPOINT_MODE";
183
+ var CONFIG_ENDPOINT_MODE_NAME = "ec2_metadata_service_endpoint_mode";
184
+ var ENDPOINT_MODE_CONFIG_OPTIONS = {
185
+ environmentVariableSelector: (env) => env[ENV_ENDPOINT_MODE_NAME],
186
+ configFileSelector: (profile) => profile[CONFIG_ENDPOINT_MODE_NAME],
187
+ default: EndpointMode.IPv4
188
+ };
189
+
190
+ // ../../.yarn/cache/@smithy-credential-provider-imds-npm-4.0.5-fd3ae8c67b-b992b7d5e4.zip/node_modules/@smithy/credential-provider-imds/dist-es/utils/getInstanceMetadataEndpoint.js
191
+ var getInstanceMetadataEndpoint = async () => parseUrl(await getFromEndpointConfig() || await getFromEndpointModeConfig());
192
+ var getFromEndpointConfig = async () => loadConfig(ENDPOINT_CONFIG_OPTIONS)();
193
+ var getFromEndpointModeConfig = async () => {
194
+ const endpointMode = await loadConfig(ENDPOINT_MODE_CONFIG_OPTIONS)();
195
+ switch (endpointMode) {
196
+ case EndpointMode.IPv4:
197
+ return Endpoint.IPv4;
198
+ case EndpointMode.IPv6:
199
+ return Endpoint.IPv6;
200
+ default:
201
+ throw new Error(`Unsupported endpoint mode: ${endpointMode}. Select from ${Object.values(EndpointMode)}`);
202
+ }
203
+ };
204
+
205
+ // ../../.yarn/cache/@smithy-credential-provider-imds-npm-4.0.5-fd3ae8c67b-b992b7d5e4.zip/node_modules/@smithy/credential-provider-imds/dist-es/utils/getExtendedInstanceMetadataCredentials.js
206
+ var STATIC_STABILITY_REFRESH_INTERVAL_SECONDS = 5 * 60;
207
+ var STATIC_STABILITY_REFRESH_INTERVAL_JITTER_WINDOW_SECONDS = 5 * 60;
208
+ var STATIC_STABILITY_DOC_URL = "https://docs.aws.amazon.com/sdkref/latest/guide/feature-static-credentials.html";
209
+ var getExtendedInstanceMetadataCredentials = (credentials, logger) => {
210
+ const refreshInterval = STATIC_STABILITY_REFRESH_INTERVAL_SECONDS + Math.floor(Math.random() * STATIC_STABILITY_REFRESH_INTERVAL_JITTER_WINDOW_SECONDS);
211
+ const newExpiration = new Date(Date.now() + refreshInterval * 1e3);
212
+ logger.warn(`Attempting credential expiration extension due to a credential service availability issue. A refresh of these credentials will be attempted after ${new Date(newExpiration)}.
213
+ For more information, please visit: ` + STATIC_STABILITY_DOC_URL);
214
+ const originalExpiration = credentials.originalExpiration ?? credentials.expiration;
215
+ return {
216
+ ...credentials,
217
+ ...originalExpiration ? { originalExpiration } : {},
218
+ expiration: newExpiration
219
+ };
220
+ };
221
+
222
+ // ../../.yarn/cache/@smithy-credential-provider-imds-npm-4.0.5-fd3ae8c67b-b992b7d5e4.zip/node_modules/@smithy/credential-provider-imds/dist-es/utils/staticStabilityProvider.js
223
+ var staticStabilityProvider = (provider, options = {}) => {
224
+ const logger = options?.logger || console;
225
+ let pastCredentials;
226
+ return async () => {
227
+ let credentials;
228
+ try {
229
+ credentials = await provider();
230
+ if (credentials.expiration && credentials.expiration.getTime() < Date.now()) {
231
+ credentials = getExtendedInstanceMetadataCredentials(credentials, logger);
232
+ }
233
+ } catch (e) {
234
+ if (pastCredentials) {
235
+ logger.warn("Credential renew failed: ", e);
236
+ credentials = getExtendedInstanceMetadataCredentials(pastCredentials, logger);
237
+ } else {
238
+ throw e;
239
+ }
240
+ }
241
+ pastCredentials = credentials;
242
+ return credentials;
243
+ };
244
+ };
245
+
246
+ // ../../.yarn/cache/@smithy-credential-provider-imds-npm-4.0.5-fd3ae8c67b-b992b7d5e4.zip/node_modules/@smithy/credential-provider-imds/dist-es/fromInstanceMetadata.js
247
+ var IMDS_PATH = "/latest/meta-data/iam/security-credentials/";
248
+ var IMDS_TOKEN_PATH = "/latest/api/token";
249
+ var AWS_EC2_METADATA_V1_DISABLED = "AWS_EC2_METADATA_V1_DISABLED";
250
+ var PROFILE_AWS_EC2_METADATA_V1_DISABLED = "ec2_metadata_v1_disabled";
251
+ var X_AWS_EC2_METADATA_TOKEN = "x-aws-ec2-metadata-token";
252
+ var fromInstanceMetadata = (init = {}) => staticStabilityProvider(getInstanceMetadataProvider(init), { logger: init.logger });
253
+ var getInstanceMetadataProvider = (init = {}) => {
254
+ let disableFetchToken = false;
255
+ const { logger, profile } = init;
256
+ const { timeout, maxRetries } = providerConfigFromInit(init);
257
+ const getCredentials = async (maxRetries2, options) => {
258
+ const isImdsV1Fallback = disableFetchToken || options.headers?.[X_AWS_EC2_METADATA_TOKEN] == null;
259
+ if (isImdsV1Fallback) {
260
+ let fallbackBlockedFromProfile = false;
261
+ let fallbackBlockedFromProcessEnv = false;
262
+ const configValue = await loadConfig({
263
+ environmentVariableSelector: (env) => {
264
+ const envValue = env[AWS_EC2_METADATA_V1_DISABLED];
265
+ fallbackBlockedFromProcessEnv = !!envValue && envValue !== "false";
266
+ if (envValue === void 0) {
267
+ throw new CredentialsProviderError(`${AWS_EC2_METADATA_V1_DISABLED} not set in env, checking config file next.`, { logger: init.logger });
268
+ }
269
+ return fallbackBlockedFromProcessEnv;
270
+ },
271
+ configFileSelector: (profile2) => {
272
+ const profileValue = profile2[PROFILE_AWS_EC2_METADATA_V1_DISABLED];
273
+ fallbackBlockedFromProfile = !!profileValue && profileValue !== "false";
274
+ return fallbackBlockedFromProfile;
275
+ },
276
+ default: false
277
+ }, {
278
+ profile
279
+ })();
280
+ if (init.ec2MetadataV1Disabled || configValue) {
281
+ const causes = [];
282
+ if (init.ec2MetadataV1Disabled)
283
+ causes.push("credential provider initialization (runtime option ec2MetadataV1Disabled)");
284
+ if (fallbackBlockedFromProfile)
285
+ causes.push(`config file profile (${PROFILE_AWS_EC2_METADATA_V1_DISABLED})`);
286
+ if (fallbackBlockedFromProcessEnv)
287
+ causes.push(`process environment variable (${AWS_EC2_METADATA_V1_DISABLED})`);
288
+ throw new InstanceMetadataV1FallbackError(`AWS EC2 Metadata v1 fallback has been blocked by AWS SDK configuration in the following: [${causes.join(", ")}].`);
289
+ }
290
+ }
291
+ const imdsProfile = (await retry(async () => {
292
+ let profile2;
293
+ try {
294
+ profile2 = await getProfile(options);
295
+ } catch (err) {
296
+ if (err.statusCode === 401) {
297
+ disableFetchToken = false;
298
+ }
299
+ throw err;
300
+ }
301
+ return profile2;
302
+ }, maxRetries2)).trim();
303
+ return retry(async () => {
304
+ let creds;
305
+ try {
306
+ creds = await getCredentialsFromProfile(imdsProfile, options, init);
307
+ } catch (err) {
308
+ if (err.statusCode === 401) {
309
+ disableFetchToken = false;
310
+ }
311
+ throw err;
312
+ }
313
+ return creds;
314
+ }, maxRetries2);
315
+ };
316
+ return async () => {
317
+ const endpoint = await getInstanceMetadataEndpoint();
318
+ if (disableFetchToken) {
319
+ logger?.debug("AWS SDK Instance Metadata", "using v1 fallback (no token fetch)");
320
+ return getCredentials(maxRetries, { ...endpoint, timeout });
321
+ } else {
322
+ let token;
323
+ try {
324
+ token = (await getMetadataToken({ ...endpoint, timeout })).toString();
325
+ } catch (error) {
326
+ if (error?.statusCode === 400) {
327
+ throw Object.assign(error, {
328
+ message: "EC2 Metadata token request returned error"
329
+ });
330
+ } else if (error.message === "TimeoutError" || [403, 404, 405].includes(error.statusCode)) {
331
+ disableFetchToken = true;
332
+ }
333
+ logger?.debug("AWS SDK Instance Metadata", "using v1 fallback (initial)");
334
+ return getCredentials(maxRetries, { ...endpoint, timeout });
335
+ }
336
+ return getCredentials(maxRetries, {
337
+ ...endpoint,
338
+ headers: {
339
+ [X_AWS_EC2_METADATA_TOKEN]: token
340
+ },
341
+ timeout
342
+ });
343
+ }
344
+ };
345
+ };
346
+ var getMetadataToken = async (options) => httpRequest({
347
+ ...options,
348
+ path: IMDS_TOKEN_PATH,
349
+ method: "PUT",
350
+ headers: {
351
+ "x-aws-ec2-metadata-token-ttl-seconds": "21600"
352
+ }
353
+ });
354
+ var getProfile = async (options) => (await httpRequest({ ...options, path: IMDS_PATH })).toString();
355
+ var getCredentialsFromProfile = async (profile, options, init) => {
356
+ const credentialsResponse = JSON.parse((await httpRequest({
357
+ ...options,
358
+ path: IMDS_PATH + profile
359
+ })).toString());
360
+ if (!isImdsCredentials(credentialsResponse)) {
361
+ throw new CredentialsProviderError("Invalid response received from instance metadata service.", {
362
+ logger: init.logger
363
+ });
364
+ }
365
+ return fromImdsCredentials(credentialsResponse);
366
+ };
367
+ export {
368
+ DEFAULT_MAX_RETRIES,
369
+ DEFAULT_TIMEOUT,
370
+ ENV_CMDS_AUTH_TOKEN,
371
+ ENV_CMDS_FULL_URI,
372
+ ENV_CMDS_RELATIVE_URI,
373
+ Endpoint,
374
+ fromContainerMetadata,
375
+ fromInstanceMetadata,
376
+ getInstanceMetadataEndpoint,
377
+ httpRequest,
378
+ providerConfigFromInit
379
+ };