Socket
Socket
Sign inDemoInstall

@aws-sdk/credential-provider-imds

Package Overview
Dependencies
Maintainers
7
Versions
140
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@aws-sdk/credential-provider-imds - npm Package Compare versions

Comparing version 3.25.0 to 3.26.0

dist/cjs/config/Endpoint.js

11

CHANGELOG.md

@@ -6,2 +6,13 @@ # Change Log

# [3.26.0](https://github.com/aws/aws-sdk-js-v3/compare/v3.25.0...v3.26.0) (2021-08-13)
### Features
* **credential-provider-imds:** support IMDS for IPv6 endpoints ([#2660](https://github.com/aws/aws-sdk-js-v3/issues/2660)) ([c458481](https://github.com/aws/aws-sdk-js-v3/commit/c458481ce07b14017a671603b79111a9958d7f0c))
# [3.25.0](https://github.com/aws/aws-sdk-js-v3/compare/v3.24.0...v3.25.0) (2021-08-05)

@@ -8,0 +19,0 @@

18

dist/cjs/fromInstanceMetadata.js

@@ -9,3 +9,3 @@ "use strict";

const retry_1 = require("./remoteProvider/retry");
const IMDS_IP = "169.254.169.254";
const getInstanceMetadataEndpoint_1 = require("./utils/getInstanceMetadataEndpoint");
const IMDS_PATH = "/latest/meta-data/iam/security-credentials/";

@@ -50,4 +50,5 @@ const IMDS_TOKEN_PATH = "/latest/api/token";

return async () => {
const endpoint = await getInstanceMetadataEndpoint_1.getInstanceMetadataEndpoint();
if (disableFetchToken) {
return getCredentials(maxRetries, { timeout });
return getCredentials(maxRetries, { ...endpoint, timeout });
}

@@ -57,3 +58,3 @@ else {

try {
token = (await getMetadataToken({ timeout })).toString();
token = (await getMetadataToken({ ...endpoint, timeout })).toString();
}

@@ -69,9 +70,10 @@ catch (error) {

}
return getCredentials(maxRetries, { timeout });
return getCredentials(maxRetries, { ...endpoint, timeout });
}
return getCredentials(maxRetries, {
timeout,
...endpoint,
headers: {
"x-aws-ec2-metadata-token": token,
},
timeout,
});

@@ -84,3 +86,2 @@ }

...options,
host: IMDS_IP,
path: IMDS_TOKEN_PATH,

@@ -92,7 +93,6 @@ method: "PUT",

});
const getProfile = async (options) => (await httpRequest_1.httpRequest({ ...options, host: IMDS_IP, path: IMDS_PATH })).toString();
const getProfile = async (options) => (await httpRequest_1.httpRequest({ ...options, path: IMDS_PATH })).toString();
const getCredentialsFromProfile = async (profile, options) => {
const credsResponse = JSON.parse((await httpRequest_1.httpRequest({
...options,
host: IMDS_IP,
path: IMDS_PATH + profile,

@@ -105,2 +105,2 @@ })).toString());

};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fromInstanceMetadata.js","sourceRoot":"","sources":["../../src/fromInstanceMetadata.ts"],"names":[],"mappings":"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","sourcesContent":["import { CredentialsProviderError } from \"@aws-sdk/property-provider\";\nimport { CredentialProvider, Credentials } from \"@aws-sdk/types\";\nimport { RequestOptions } from \"http\";\n\nimport { httpRequest } from \"./remoteProvider/httpRequest\";\nimport { fromImdsCredentials, isImdsCredentials } from \"./remoteProvider/ImdsCredentials\";\nimport { providerConfigFromInit, RemoteProviderInit } from \"./remoteProvider/RemoteProviderInit\";\nimport { retry } from \"./remoteProvider/retry\";\n\nconst IMDS_IP = \"169.254.169.254\";\nconst IMDS_PATH = \"/latest/meta-data/iam/security-credentials/\";\nconst IMDS_TOKEN_PATH = \"/latest/api/token\";\n\n/**\n * Creates a credential provider that will source credentials from the EC2\n * Instance Metadata Service\n */\nexport const fromInstanceMetadata = (init: RemoteProviderInit = {}): CredentialProvider => {\n  // when set to true, metadata service will not fetch token\n  let disableFetchToken = false;\n  const { timeout, maxRetries } = providerConfigFromInit(init);\n\n  const getCredentials = async (maxRetries: number, options: RequestOptions) => {\n    const profile = (\n      await retry<string>(async () => {\n        let profile: string;\n        try {\n          profile = await getProfile(options);\n        } catch (err) {\n          if (err.statusCode === 401) {\n            disableFetchToken = false;\n          }\n          throw err;\n        }\n        return profile;\n      }, maxRetries)\n    ).trim();\n\n    return retry(async () => {\n      let creds: Credentials;\n      try {\n        creds = await getCredentialsFromProfile(profile, options);\n      } catch (err) {\n        if (err.statusCode === 401) {\n          disableFetchToken = false;\n        }\n        throw err;\n      }\n      return creds;\n    }, maxRetries);\n  };\n\n  return async () => {\n    if (disableFetchToken) {\n      return getCredentials(maxRetries, { timeout });\n    } else {\n      let token: string;\n      try {\n        token = (await getMetadataToken({ timeout })).toString();\n      } catch (error) {\n        if (error?.statusCode === 400) {\n          throw Object.assign(error, {\n            message: \"EC2 Metadata token request returned error\",\n          });\n        } else if (error.message === \"TimeoutError\" || [403, 404, 405].includes(error.statusCode)) {\n          disableFetchToken = true;\n        }\n        return getCredentials(maxRetries, { timeout });\n      }\n      return getCredentials(maxRetries, {\n        timeout,\n        headers: {\n          \"x-aws-ec2-metadata-token\": token,\n        },\n      });\n    }\n  };\n};\n\nconst getMetadataToken = async (options: RequestOptions) =>\n  httpRequest({\n    ...options,\n    host: IMDS_IP,\n    path: IMDS_TOKEN_PATH,\n    method: \"PUT\",\n    headers: {\n      \"x-aws-ec2-metadata-token-ttl-seconds\": \"21600\",\n    },\n  });\n\nconst getProfile = async (options: RequestOptions) =>\n  (await httpRequest({ ...options, host: IMDS_IP, path: IMDS_PATH })).toString();\n\nconst getCredentialsFromProfile = async (profile: string, options: RequestOptions) => {\n  const credsResponse = JSON.parse(\n    (\n      await httpRequest({\n        ...options,\n        host: IMDS_IP,\n        path: IMDS_PATH + profile,\n      })\n    ).toString()\n  );\n\n  if (!isImdsCredentials(credsResponse)) {\n    throw new CredentialsProviderError(\"Invalid response received from instance metadata service.\");\n  }\n\n  return fromImdsCredentials(credsResponse);\n};\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fromInstanceMetadata.js","sourceRoot":"","sources":["../../src/fromInstanceMetadata.ts"],"names":[],"mappings":"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","sourcesContent":["import { CredentialsProviderError } from \"@aws-sdk/property-provider\";\nimport { CredentialProvider, Credentials } from \"@aws-sdk/types\";\nimport { RequestOptions } from \"http\";\n\nimport { httpRequest } from \"./remoteProvider/httpRequest\";\nimport { fromImdsCredentials, isImdsCredentials } from \"./remoteProvider/ImdsCredentials\";\nimport { providerConfigFromInit, RemoteProviderInit } from \"./remoteProvider/RemoteProviderInit\";\nimport { retry } from \"./remoteProvider/retry\";\nimport { getInstanceMetadataEndpoint } from \"./utils/getInstanceMetadataEndpoint\";\n\nconst IMDS_PATH = \"/latest/meta-data/iam/security-credentials/\";\nconst IMDS_TOKEN_PATH = \"/latest/api/token\";\n\n/**\n * Creates a credential provider that will source credentials from the EC2\n * Instance Metadata Service\n */\nexport const fromInstanceMetadata = (init: RemoteProviderInit = {}): CredentialProvider => {\n  // when set to true, metadata service will not fetch token\n  let disableFetchToken = false;\n  const { timeout, maxRetries } = providerConfigFromInit(init);\n\n  const getCredentials = async (maxRetries: number, options: RequestOptions) => {\n    const profile = (\n      await retry<string>(async () => {\n        let profile: string;\n        try {\n          profile = await getProfile(options);\n        } catch (err) {\n          if (err.statusCode === 401) {\n            disableFetchToken = false;\n          }\n          throw err;\n        }\n        return profile;\n      }, maxRetries)\n    ).trim();\n\n    return retry(async () => {\n      let creds: Credentials;\n      try {\n        creds = await getCredentialsFromProfile(profile, options);\n      } catch (err) {\n        if (err.statusCode === 401) {\n          disableFetchToken = false;\n        }\n        throw err;\n      }\n      return creds;\n    }, maxRetries);\n  };\n\n  return async () => {\n    const endpoint = await getInstanceMetadataEndpoint();\n    if (disableFetchToken) {\n      return getCredentials(maxRetries, { ...endpoint, timeout });\n    } else {\n      let token: string;\n      try {\n        token = (await getMetadataToken({ ...endpoint, timeout })).toString();\n      } catch (error) {\n        if (error?.statusCode === 400) {\n          throw Object.assign(error, {\n            message: \"EC2 Metadata token request returned error\",\n          });\n        } else if (error.message === \"TimeoutError\" || [403, 404, 405].includes(error.statusCode)) {\n          disableFetchToken = true;\n        }\n        return getCredentials(maxRetries, { ...endpoint, timeout });\n      }\n      return getCredentials(maxRetries, {\n        ...endpoint,\n        headers: {\n          \"x-aws-ec2-metadata-token\": token,\n        },\n        timeout,\n      });\n    }\n  };\n};\n\nconst getMetadataToken = async (options: RequestOptions) =>\n  httpRequest({\n    ...options,\n    path: IMDS_TOKEN_PATH,\n    method: \"PUT\",\n    headers: {\n      \"x-aws-ec2-metadata-token-ttl-seconds\": \"21600\",\n    },\n  });\n\nconst getProfile = async (options: RequestOptions) => (await httpRequest({ ...options, path: IMDS_PATH })).toString();\n\nconst getCredentialsFromProfile = async (profile: string, options: RequestOptions) => {\n  const credsResponse = JSON.parse(\n    (\n      await httpRequest({\n        ...options,\n        path: IMDS_PATH + profile,\n      })\n    ).toString()\n  );\n\n  if (!isImdsCredentials(credsResponse)) {\n    throw new CredentialsProviderError(\"Invalid response received from instance metadata service.\");\n  }\n\n  return fromImdsCredentials(credsResponse);\n};\n"]}

@@ -12,3 +12,10 @@ "use strict";

return new Promise((resolve, reject) => {
const req = http_1.request({ method: "GET", ...options });
var _a;
const req = http_1.request({
method: "GET",
...options,
// Node.js http module doesn't accept hostname with square brackets
// Refs: https://github.com/nodejs/node/issues/39738
hostname: (_a = options.hostname) === null || _a === void 0 ? void 0 : _a.replace(/^\[(.+)\]$/, "$1"),
});
req.on("error", (err) => {

@@ -41,2 +48,2 @@ reject(Object.assign(new property_provider_1.ProviderError("Unable to connect to instance metadata service"), err));

exports.httpRequest = httpRequest;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaHR0cFJlcXVlc3QuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvcmVtb3RlUHJvdmlkZXIvaHR0cFJlcXVlc3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsa0VBQTJEO0FBQzNELG1DQUFnQztBQUNoQywrQkFBZ0U7QUFFaEU7O0dBRUc7QUFDSCxTQUFnQixXQUFXLENBQUMsT0FBdUI7SUFDakQsT0FBTyxJQUFJLE9BQU8sQ0FBQyxDQUFDLE9BQU8sRUFBRSxNQUFNLEVBQUUsRUFBRTtRQUNyQyxNQUFNLEdBQUcsR0FBRyxjQUFPLENBQUMsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFLEdBQUcsT0FBTyxFQUFFLENBQUMsQ0FBQztRQUVuRCxHQUFHLENBQUMsRUFBRSxDQUFDLE9BQU8sRUFBRSxDQUFDLEdBQUcsRUFBRSxFQUFFO1lBQ3RCLE1BQU0sQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLElBQUksaUNBQWEsQ0FBQyxnREFBZ0QsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxDQUFDLENBQUM7WUFDaEcsR0FBRyxDQUFDLE9BQU8sRUFBRSxDQUFDO1FBQ2hCLENBQUMsQ0FBQyxDQUFDO1FBRUgsR0FBRyxDQUFDLEVBQUUsQ0FBQyxTQUFTLEVBQUUsR0FBRyxFQUFFO1lBQ3JCLE1BQU0sQ0FBQyxJQUFJLGlDQUFhLENBQUMsNkNBQTZDLENBQUMsQ0FBQyxDQUFDO1lBQ3pFLEdBQUcsQ0FBQyxPQUFPLEVBQUUsQ0FBQztRQUNoQixDQUFDLENBQUMsQ0FBQztRQUVILEdBQUcsQ0FBQyxFQUFFLENBQUMsVUFBVSxFQUFFLENBQUMsR0FBb0IsRUFBRSxFQUFFO1lBQzFDLE1BQU0sRUFBRSxVQUFVLEdBQUcsR0FBRyxFQUFFLEdBQUcsR0FBRyxDQUFDO1lBQ2pDLElBQUksVUFBVSxHQUFHLEdBQUcsSUFBSSxHQUFHLElBQUksVUFBVSxFQUFFO2dCQUN6QyxNQUFNLENBQ0osTUFBTSxDQUFDLE1BQU0sQ0FBQyxJQUFJLGlDQUFhLENBQUMsd0RBQXdELENBQUMsRUFBRSxFQUFFLFVBQVUsRUFBRSxDQUFDLENBQzNHLENBQUM7Z0JBQ0YsR0FBRyxDQUFDLE9BQU8sRUFBRSxDQUFDO2FBQ2Y7WUFFRCxNQUFNLE1BQU0sR0FBa0IsRUFBRSxDQUFDO1lBQ2pDLEdBQUcsQ0FBQyxFQUFFLENBQUMsTUFBTSxFQUFFLENBQUMsS0FBSyxFQUFFLEVBQUU7Z0JBQ3ZCLE1BQU0sQ0FBQyxJQUFJLENBQUMsS0FBZSxDQUFDLENBQUM7WUFDL0IsQ0FBQyxDQUFDLENBQUM7WUFDSCxHQUFHLENBQUMsRUFBRSxDQUFDLEtBQUssRUFBRSxHQUFHLEVBQUU7Z0JBQ2pCLE9BQU8sQ0FBQyxlQUFNLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUM7Z0JBQy9CLEdBQUcsQ0FBQyxPQUFPLEVBQUUsQ0FBQztZQUNoQixDQUFDLENBQUMsQ0FBQztRQUNMLENBQUMsQ0FBQyxDQUFDO1FBRUgsR0FBRyxDQUFDLEdBQUcsRUFBRSxDQUFDO0lBQ1osQ0FBQyxDQUFDLENBQUM7QUFDTCxDQUFDO0FBbkNELGtDQW1DQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFByb3ZpZGVyRXJyb3IgfSBmcm9tIFwiQGF3cy1zZGsvcHJvcGVydHktcHJvdmlkZXJcIjtcbmltcG9ydCB7IEJ1ZmZlciB9IGZyb20gXCJidWZmZXJcIjtcbmltcG9ydCB7IEluY29taW5nTWVzc2FnZSwgcmVxdWVzdCwgUmVxdWVzdE9wdGlvbnMgfSBmcm9tIFwiaHR0cFwiO1xuXG4vKipcbiAqIEBpbnRlcm5hbFxuICovXG5leHBvcnQgZnVuY3Rpb24gaHR0cFJlcXVlc3Qob3B0aW9uczogUmVxdWVzdE9wdGlvbnMpOiBQcm9taXNlPEJ1ZmZlcj4ge1xuICByZXR1cm4gbmV3IFByb21pc2UoKHJlc29sdmUsIHJlamVjdCkgPT4ge1xuICAgIGNvbnN0IHJlcSA9IHJlcXVlc3QoeyBtZXRob2Q6IFwiR0VUXCIsIC4uLm9wdGlvbnMgfSk7XG5cbiAgICByZXEub24oXCJlcnJvclwiLCAoZXJyKSA9PiB7XG4gICAgICByZWplY3QoT2JqZWN0LmFzc2lnbihuZXcgUHJvdmlkZXJFcnJvcihcIlVuYWJsZSB0byBjb25uZWN0IHRvIGluc3RhbmNlIG1ldGFkYXRhIHNlcnZpY2VcIiksIGVycikpO1xuICAgICAgcmVxLmRlc3Ryb3koKTtcbiAgICB9KTtcblxuICAgIHJlcS5vbihcInRpbWVvdXRcIiwgKCkgPT4ge1xuICAgICAgcmVqZWN0KG5ldyBQcm92aWRlckVycm9yKFwiVGltZW91dEVycm9yIGZyb20gaW5zdGFuY2UgbWV0YWRhdGEgc2VydmljZVwiKSk7XG4gICAgICByZXEuZGVzdHJveSgpO1xuICAgIH0pO1xuXG4gICAgcmVxLm9uKFwicmVzcG9uc2VcIiwgKHJlczogSW5jb21pbmdNZXNzYWdlKSA9PiB7XG4gICAgICBjb25zdCB7IHN0YXR1c0NvZGUgPSA0MDAgfSA9IHJlcztcbiAgICAgIGlmIChzdGF0dXNDb2RlIDwgMjAwIHx8IDMwMCA8PSBzdGF0dXNDb2RlKSB7XG4gICAgICAgIHJlamVjdChcbiAgICAgICAgICBPYmplY3QuYXNzaWduKG5ldyBQcm92aWRlckVycm9yKFwiRXJyb3IgcmVzcG9uc2UgcmVjZWl2ZWQgZnJvbSBpbnN0YW5jZSBtZXRhZGF0YSBzZXJ2aWNlXCIpLCB7IHN0YXR1c0NvZGUgfSlcbiAgICAgICAgKTtcbiAgICAgICAgcmVxLmRlc3Ryb3koKTtcbiAgICAgIH1cblxuICAgICAgY29uc3QgY2h1bmtzOiBBcnJheTxCdWZmZXI+ID0gW107XG4gICAgICByZXMub24oXCJkYXRhXCIsIChjaHVuaykgPT4ge1xuICAgICAgICBjaHVua3MucHVzaChjaHVuayBhcyBCdWZmZXIpO1xuICAgICAgfSk7XG4gICAgICByZXMub24oXCJlbmRcIiwgKCkgPT4ge1xuICAgICAgICByZXNvbHZlKEJ1ZmZlci5jb25jYXQoY2h1bmtzKSk7XG4gICAgICAgIHJlcS5kZXN0cm95KCk7XG4gICAgICB9KTtcbiAgICB9KTtcblxuICAgIHJlcS5lbmQoKTtcbiAgfSk7XG59XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaHR0cFJlcXVlc3QuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvcmVtb3RlUHJvdmlkZXIvaHR0cFJlcXVlc3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsa0VBQTJEO0FBQzNELG1DQUFnQztBQUNoQywrQkFBZ0U7QUFFaEU7O0dBRUc7QUFDSCxTQUFnQixXQUFXLENBQUMsT0FBdUI7SUFDakQsT0FBTyxJQUFJLE9BQU8sQ0FBQyxDQUFDLE9BQU8sRUFBRSxNQUFNLEVBQUUsRUFBRTs7UUFDckMsTUFBTSxHQUFHLEdBQUcsY0FBTyxDQUFDO1lBQ2xCLE1BQU0sRUFBRSxLQUFLO1lBQ2IsR0FBRyxPQUFPO1lBQ1YsbUVBQW1FO1lBQ25FLG9EQUFvRDtZQUNwRCxRQUFRLEVBQUUsTUFBQSxPQUFPLENBQUMsUUFBUSwwQ0FBRSxPQUFPLENBQUMsWUFBWSxFQUFFLElBQUksQ0FBQztTQUN4RCxDQUFDLENBQUM7UUFFSCxHQUFHLENBQUMsRUFBRSxDQUFDLE9BQU8sRUFBRSxDQUFDLEdBQUcsRUFBRSxFQUFFO1lBQ3RCLE1BQU0sQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLElBQUksaUNBQWEsQ0FBQyxnREFBZ0QsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxDQUFDLENBQUM7WUFDaEcsR0FBRyxDQUFDLE9BQU8sRUFBRSxDQUFDO1FBQ2hCLENBQUMsQ0FBQyxDQUFDO1FBRUgsR0FBRyxDQUFDLEVBQUUsQ0FBQyxTQUFTLEVBQUUsR0FBRyxFQUFFO1lBQ3JCLE1BQU0sQ0FBQyxJQUFJLGlDQUFhLENBQUMsNkNBQTZDLENBQUMsQ0FBQyxDQUFDO1lBQ3pFLEdBQUcsQ0FBQyxPQUFPLEVBQUUsQ0FBQztRQUNoQixDQUFDLENBQUMsQ0FBQztRQUVILEdBQUcsQ0FBQyxFQUFFLENBQUMsVUFBVSxFQUFFLENBQUMsR0FBb0IsRUFBRSxFQUFFO1lBQzFDLE1BQU0sRUFBRSxVQUFVLEdBQUcsR0FBRyxFQUFFLEdBQUcsR0FBRyxDQUFDO1lBQ2pDLElBQUksVUFBVSxHQUFHLEdBQUcsSUFBSSxHQUFHLElBQUksVUFBVSxFQUFFO2dCQUN6QyxNQUFNLENBQ0osTUFBTSxDQUFDLE1BQU0sQ0FBQyxJQUFJLGlDQUFhLENBQUMsd0RBQXdELENBQUMsRUFBRSxFQUFFLFVBQVUsRUFBRSxDQUFDLENBQzNHLENBQUM7Z0JBQ0YsR0FBRyxDQUFDLE9BQU8sRUFBRSxDQUFDO2FBQ2Y7WUFFRCxNQUFNLE1BQU0sR0FBa0IsRUFBRSxDQUFDO1lBQ2pDLEdBQUcsQ0FBQyxFQUFFLENBQUMsTUFBTSxFQUFFLENBQUMsS0FBSyxFQUFFLEVBQUU7Z0JBQ3ZCLE1BQU0sQ0FBQyxJQUFJLENBQUMsS0FBZSxDQUFDLENBQUM7WUFDL0IsQ0FBQyxDQUFDLENBQUM7WUFDSCxHQUFHLENBQUMsRUFBRSxDQUFDLEtBQUssRUFBRSxHQUFHLEVBQUU7Z0JBQ2pCLE9BQU8sQ0FBQyxlQUFNLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUM7Z0JBQy9CLEdBQUcsQ0FBQyxPQUFPLEVBQUUsQ0FBQztZQUNoQixDQUFDLENBQUMsQ0FBQztRQUNMLENBQUMsQ0FBQyxDQUFDO1FBRUgsR0FBRyxDQUFDLEdBQUcsRUFBRSxDQUFDO0lBQ1osQ0FBQyxDQUFDLENBQUM7QUFDTCxDQUFDO0FBekNELGtDQXlDQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFByb3ZpZGVyRXJyb3IgfSBmcm9tIFwiQGF3cy1zZGsvcHJvcGVydHktcHJvdmlkZXJcIjtcbmltcG9ydCB7IEJ1ZmZlciB9IGZyb20gXCJidWZmZXJcIjtcbmltcG9ydCB7IEluY29taW5nTWVzc2FnZSwgcmVxdWVzdCwgUmVxdWVzdE9wdGlvbnMgfSBmcm9tIFwiaHR0cFwiO1xuXG4vKipcbiAqIEBpbnRlcm5hbFxuICovXG5leHBvcnQgZnVuY3Rpb24gaHR0cFJlcXVlc3Qob3B0aW9uczogUmVxdWVzdE9wdGlvbnMpOiBQcm9taXNlPEJ1ZmZlcj4ge1xuICByZXR1cm4gbmV3IFByb21pc2UoKHJlc29sdmUsIHJlamVjdCkgPT4ge1xuICAgIGNvbnN0IHJlcSA9IHJlcXVlc3Qoe1xuICAgICAgbWV0aG9kOiBcIkdFVFwiLFxuICAgICAgLi4ub3B0aW9ucyxcbiAgICAgIC8vIE5vZGUuanMgaHR0cCBtb2R1bGUgZG9lc24ndCBhY2NlcHQgaG9zdG5hbWUgd2l0aCBzcXVhcmUgYnJhY2tldHNcbiAgICAgIC8vIFJlZnM6IGh0dHBzOi8vZ2l0aHViLmNvbS9ub2RlanMvbm9kZS9pc3N1ZXMvMzk3MzhcbiAgICAgIGhvc3RuYW1lOiBvcHRpb25zLmhvc3RuYW1lPy5yZXBsYWNlKC9eXFxbKC4rKVxcXSQvLCBcIiQxXCIpLFxuICAgIH0pO1xuXG4gICAgcmVxLm9uKFwiZXJyb3JcIiwgKGVycikgPT4ge1xuICAgICAgcmVqZWN0KE9iamVjdC5hc3NpZ24obmV3IFByb3ZpZGVyRXJyb3IoXCJVbmFibGUgdG8gY29ubmVjdCB0byBpbnN0YW5jZSBtZXRhZGF0YSBzZXJ2aWNlXCIpLCBlcnIpKTtcbiAgICAgIHJlcS5kZXN0cm95KCk7XG4gICAgfSk7XG5cbiAgICByZXEub24oXCJ0aW1lb3V0XCIsICgpID0+IHtcbiAgICAgIHJlamVjdChuZXcgUHJvdmlkZXJFcnJvcihcIlRpbWVvdXRFcnJvciBmcm9tIGluc3RhbmNlIG1ldGFkYXRhIHNlcnZpY2VcIikpO1xuICAgICAgcmVxLmRlc3Ryb3koKTtcbiAgICB9KTtcblxuICAgIHJlcS5vbihcInJlc3BvbnNlXCIsIChyZXM6IEluY29taW5nTWVzc2FnZSkgPT4ge1xuICAgICAgY29uc3QgeyBzdGF0dXNDb2RlID0gNDAwIH0gPSByZXM7XG4gICAgICBpZiAoc3RhdHVzQ29kZSA8IDIwMCB8fCAzMDAgPD0gc3RhdHVzQ29kZSkge1xuICAgICAgICByZWplY3QoXG4gICAgICAgICAgT2JqZWN0LmFzc2lnbihuZXcgUHJvdmlkZXJFcnJvcihcIkVycm9yIHJlc3BvbnNlIHJlY2VpdmVkIGZyb20gaW5zdGFuY2UgbWV0YWRhdGEgc2VydmljZVwiKSwgeyBzdGF0dXNDb2RlIH0pXG4gICAgICAgICk7XG4gICAgICAgIHJlcS5kZXN0cm95KCk7XG4gICAgICB9XG5cbiAgICAgIGNvbnN0IGNodW5rczogQXJyYXk8QnVmZmVyPiA9IFtdO1xuICAgICAgcmVzLm9uKFwiZGF0YVwiLCAoY2h1bmspID0+IHtcbiAgICAgICAgY2h1bmtzLnB1c2goY2h1bmsgYXMgQnVmZmVyKTtcbiAgICAgIH0pO1xuICAgICAgcmVzLm9uKFwiZW5kXCIsICgpID0+IHtcbiAgICAgICAgcmVzb2x2ZShCdWZmZXIuY29uY2F0KGNodW5rcykpO1xuICAgICAgICByZXEuZGVzdHJveSgpO1xuICAgICAgfSk7XG4gICAgfSk7XG5cbiAgICByZXEuZW5kKCk7XG4gIH0pO1xufVxuIl19

@@ -7,3 +7,3 @@ import { __assign, __awaiter, __generator } from "tslib";

import { retry } from "./remoteProvider/retry";
var IMDS_IP = "169.254.169.254";
import { getInstanceMetadataEndpoint } from "./utils/getInstanceMetadataEndpoint";
var IMDS_PATH = "/latest/meta-data/iam/security-credentials/";

@@ -70,18 +70,20 @@ var IMDS_TOKEN_PATH = "/latest/api/token";

return function () { return __awaiter(void 0, void 0, void 0, function () {
var token, error_1;
var endpoint, token, error_1;
return __generator(this, function (_a) {
switch (_a.label) {
case 0:
if (!disableFetchToken) return [3 /*break*/, 1];
return [2 /*return*/, getCredentials(maxRetries, { timeout: timeout })];
case 0: return [4 /*yield*/, getInstanceMetadataEndpoint()];
case 1:
endpoint = _a.sent();
if (!disableFetchToken) return [3 /*break*/, 2];
return [2 /*return*/, getCredentials(maxRetries, __assign(__assign({}, endpoint), { timeout: timeout }))];
case 2:
token = void 0;
_a.label = 2;
case 2:
_a.trys.push([2, 4, , 5]);
return [4 /*yield*/, getMetadataToken({ timeout: timeout })];
_a.label = 3;
case 3:
_a.trys.push([3, 5, , 6]);
return [4 /*yield*/, getMetadataToken(__assign(__assign({}, endpoint), { timeout: timeout }))];
case 4:
token = (_a.sent()).toString();
return [3 /*break*/, 5];
case 4:
return [3 /*break*/, 6];
case 5:
error_1 = _a.sent();

@@ -96,9 +98,6 @@ if ((error_1 === null || error_1 === void 0 ? void 0 : error_1.statusCode) === 400) {

}
return [2 /*return*/, getCredentials(maxRetries, { timeout: timeout })];
case 5: return [2 /*return*/, getCredentials(maxRetries, {
timeout: timeout,
headers: {
return [2 /*return*/, getCredentials(maxRetries, __assign(__assign({}, endpoint), { timeout: timeout }))];
case 6: return [2 /*return*/, getCredentials(maxRetries, __assign(__assign({}, endpoint), { headers: {
"x-aws-ec2-metadata-token": token,
},
})];
}, timeout: timeout }))];
}

@@ -110,3 +109,3 @@ });

return __generator(this, function (_a) {
return [2 /*return*/, httpRequest(__assign(__assign({}, options), { host: IMDS_IP, path: IMDS_TOKEN_PATH, method: "PUT", headers: {
return [2 /*return*/, httpRequest(__assign(__assign({}, options), { path: IMDS_TOKEN_PATH, method: "PUT", headers: {
"x-aws-ec2-metadata-token-ttl-seconds": "21600",

@@ -118,3 +117,3 @@ } }))];

switch (_a.label) {
case 0: return [4 /*yield*/, httpRequest(__assign(__assign({}, options), { host: IMDS_IP, path: IMDS_PATH }))];
case 0: return [4 /*yield*/, httpRequest(__assign(__assign({}, options), { path: IMDS_PATH }))];
case 1: return [2 /*return*/, (_a.sent()).toString()];

@@ -129,3 +128,3 @@ }

_b = (_a = JSON).parse;
return [4 /*yield*/, httpRequest(__assign(__assign({}, options), { host: IMDS_IP, path: IMDS_PATH + profile }))];
return [4 /*yield*/, httpRequest(__assign(__assign({}, options), { path: IMDS_PATH + profile }))];
case 1:

@@ -140,2 +139,2 @@ credsResponse = _b.apply(_a, [(_c.sent()).toString()]);

}); };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fromInstanceMetadata.js","sourceRoot":"","sources":["../../src/fromInstanceMetadata.ts"],"names":[],"mappings":"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","sourcesContent":["import { CredentialsProviderError } from \"@aws-sdk/property-provider\";\nimport { CredentialProvider, Credentials } from \"@aws-sdk/types\";\nimport { RequestOptions } from \"http\";\n\nimport { httpRequest } from \"./remoteProvider/httpRequest\";\nimport { fromImdsCredentials, isImdsCredentials } from \"./remoteProvider/ImdsCredentials\";\nimport { providerConfigFromInit, RemoteProviderInit } from \"./remoteProvider/RemoteProviderInit\";\nimport { retry } from \"./remoteProvider/retry\";\n\nconst IMDS_IP = \"169.254.169.254\";\nconst IMDS_PATH = \"/latest/meta-data/iam/security-credentials/\";\nconst IMDS_TOKEN_PATH = \"/latest/api/token\";\n\n/**\n * Creates a credential provider that will source credentials from the EC2\n * Instance Metadata Service\n */\nexport const fromInstanceMetadata = (init: RemoteProviderInit = {}): CredentialProvider => {\n  // when set to true, metadata service will not fetch token\n  let disableFetchToken = false;\n  const { timeout, maxRetries } = providerConfigFromInit(init);\n\n  const getCredentials = async (maxRetries: number, options: RequestOptions) => {\n    const profile = (\n      await retry<string>(async () => {\n        let profile: string;\n        try {\n          profile = await getProfile(options);\n        } catch (err) {\n          if (err.statusCode === 401) {\n            disableFetchToken = false;\n          }\n          throw err;\n        }\n        return profile;\n      }, maxRetries)\n    ).trim();\n\n    return retry(async () => {\n      let creds: Credentials;\n      try {\n        creds = await getCredentialsFromProfile(profile, options);\n      } catch (err) {\n        if (err.statusCode === 401) {\n          disableFetchToken = false;\n        }\n        throw err;\n      }\n      return creds;\n    }, maxRetries);\n  };\n\n  return async () => {\n    if (disableFetchToken) {\n      return getCredentials(maxRetries, { timeout });\n    } else {\n      let token: string;\n      try {\n        token = (await getMetadataToken({ timeout })).toString();\n      } catch (error) {\n        if (error?.statusCode === 400) {\n          throw Object.assign(error, {\n            message: \"EC2 Metadata token request returned error\",\n          });\n        } else if (error.message === \"TimeoutError\" || [403, 404, 405].includes(error.statusCode)) {\n          disableFetchToken = true;\n        }\n        return getCredentials(maxRetries, { timeout });\n      }\n      return getCredentials(maxRetries, {\n        timeout,\n        headers: {\n          \"x-aws-ec2-metadata-token\": token,\n        },\n      });\n    }\n  };\n};\n\nconst getMetadataToken = async (options: RequestOptions) =>\n  httpRequest({\n    ...options,\n    host: IMDS_IP,\n    path: IMDS_TOKEN_PATH,\n    method: \"PUT\",\n    headers: {\n      \"x-aws-ec2-metadata-token-ttl-seconds\": \"21600\",\n    },\n  });\n\nconst getProfile = async (options: RequestOptions) =>\n  (await httpRequest({ ...options, host: IMDS_IP, path: IMDS_PATH })).toString();\n\nconst getCredentialsFromProfile = async (profile: string, options: RequestOptions) => {\n  const credsResponse = JSON.parse(\n    (\n      await httpRequest({\n        ...options,\n        host: IMDS_IP,\n        path: IMDS_PATH + profile,\n      })\n    ).toString()\n  );\n\n  if (!isImdsCredentials(credsResponse)) {\n    throw new CredentialsProviderError(\"Invalid response received from instance metadata service.\");\n  }\n\n  return fromImdsCredentials(credsResponse);\n};\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fromInstanceMetadata.js","sourceRoot":"","sources":["../../src/fromInstanceMetadata.ts"],"names":[],"mappings":"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","sourcesContent":["import { CredentialsProviderError } from \"@aws-sdk/property-provider\";\nimport { CredentialProvider, Credentials } from \"@aws-sdk/types\";\nimport { RequestOptions } from \"http\";\n\nimport { httpRequest } from \"./remoteProvider/httpRequest\";\nimport { fromImdsCredentials, isImdsCredentials } from \"./remoteProvider/ImdsCredentials\";\nimport { providerConfigFromInit, RemoteProviderInit } from \"./remoteProvider/RemoteProviderInit\";\nimport { retry } from \"./remoteProvider/retry\";\nimport { getInstanceMetadataEndpoint } from \"./utils/getInstanceMetadataEndpoint\";\n\nconst IMDS_PATH = \"/latest/meta-data/iam/security-credentials/\";\nconst IMDS_TOKEN_PATH = \"/latest/api/token\";\n\n/**\n * Creates a credential provider that will source credentials from the EC2\n * Instance Metadata Service\n */\nexport const fromInstanceMetadata = (init: RemoteProviderInit = {}): CredentialProvider => {\n  // when set to true, metadata service will not fetch token\n  let disableFetchToken = false;\n  const { timeout, maxRetries } = providerConfigFromInit(init);\n\n  const getCredentials = async (maxRetries: number, options: RequestOptions) => {\n    const profile = (\n      await retry<string>(async () => {\n        let profile: string;\n        try {\n          profile = await getProfile(options);\n        } catch (err) {\n          if (err.statusCode === 401) {\n            disableFetchToken = false;\n          }\n          throw err;\n        }\n        return profile;\n      }, maxRetries)\n    ).trim();\n\n    return retry(async () => {\n      let creds: Credentials;\n      try {\n        creds = await getCredentialsFromProfile(profile, options);\n      } catch (err) {\n        if (err.statusCode === 401) {\n          disableFetchToken = false;\n        }\n        throw err;\n      }\n      return creds;\n    }, maxRetries);\n  };\n\n  return async () => {\n    const endpoint = await getInstanceMetadataEndpoint();\n    if (disableFetchToken) {\n      return getCredentials(maxRetries, { ...endpoint, timeout });\n    } else {\n      let token: string;\n      try {\n        token = (await getMetadataToken({ ...endpoint, timeout })).toString();\n      } catch (error) {\n        if (error?.statusCode === 400) {\n          throw Object.assign(error, {\n            message: \"EC2 Metadata token request returned error\",\n          });\n        } else if (error.message === \"TimeoutError\" || [403, 404, 405].includes(error.statusCode)) {\n          disableFetchToken = true;\n        }\n        return getCredentials(maxRetries, { ...endpoint, timeout });\n      }\n      return getCredentials(maxRetries, {\n        ...endpoint,\n        headers: {\n          \"x-aws-ec2-metadata-token\": token,\n        },\n        timeout,\n      });\n    }\n  };\n};\n\nconst getMetadataToken = async (options: RequestOptions) =>\n  httpRequest({\n    ...options,\n    path: IMDS_TOKEN_PATH,\n    method: \"PUT\",\n    headers: {\n      \"x-aws-ec2-metadata-token-ttl-seconds\": \"21600\",\n    },\n  });\n\nconst getProfile = async (options: RequestOptions) => (await httpRequest({ ...options, path: IMDS_PATH })).toString();\n\nconst getCredentialsFromProfile = async (profile: string, options: RequestOptions) => {\n  const credsResponse = JSON.parse(\n    (\n      await httpRequest({\n        ...options,\n        path: IMDS_PATH + profile,\n      })\n    ).toString()\n  );\n\n  if (!isImdsCredentials(credsResponse)) {\n    throw new CredentialsProviderError(\"Invalid response received from instance metadata service.\");\n  }\n\n  return fromImdsCredentials(credsResponse);\n};\n"]}

@@ -10,3 +10,7 @@ import { __assign } from "tslib";

return new Promise(function (resolve, reject) {
var req = request(__assign({ method: "GET" }, options));
var _a;
var req = request(__assign(__assign({ method: "GET" }, options), {
// Node.js http module doesn't accept hostname with square brackets
// Refs: https://github.com/nodejs/node/issues/39738
hostname: (_a = options.hostname) === null || _a === void 0 ? void 0 : _a.replace(/^\[(.+)\]$/, "$1") }));
req.on("error", function (err) {

@@ -38,2 +42,2 @@ reject(Object.assign(new ProviderError("Unable to connect to instance metadata service"), err));

}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaHR0cFJlcXVlc3QuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvcmVtb3RlUHJvdmlkZXIvaHR0cFJlcXVlc3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0sUUFBUSxDQUFDO0FBQ2hDLE9BQU8sRUFBbUIsT0FBTyxFQUFrQixNQUFNLE1BQU0sQ0FBQztBQUVoRTs7R0FFRztBQUNILE1BQU0sVUFBVSxXQUFXLENBQUMsT0FBdUI7SUFDakQsT0FBTyxJQUFJLE9BQU8sQ0FBQyxVQUFDLE9BQU8sRUFBRSxNQUFNO1FBQ2pDLElBQU0sR0FBRyxHQUFHLE9BQU8sWUFBRyxNQUFNLEVBQUUsS0FBSyxJQUFLLE9BQU8sRUFBRyxDQUFDO1FBRW5ELEdBQUcsQ0FBQyxFQUFFLENBQUMsT0FBTyxFQUFFLFVBQUMsR0FBRztZQUNsQixNQUFNLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxJQUFJLGFBQWEsQ0FBQyxnREFBZ0QsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxDQUFDLENBQUM7WUFDaEcsR0FBRyxDQUFDLE9BQU8sRUFBRSxDQUFDO1FBQ2hCLENBQUMsQ0FBQyxDQUFDO1FBRUgsR0FBRyxDQUFDLEVBQUUsQ0FBQyxTQUFTLEVBQUU7WUFDaEIsTUFBTSxDQUFDLElBQUksYUFBYSxDQUFDLDZDQUE2QyxDQUFDLENBQUMsQ0FBQztZQUN6RSxHQUFHLENBQUMsT0FBTyxFQUFFLENBQUM7UUFDaEIsQ0FBQyxDQUFDLENBQUM7UUFFSCxHQUFHLENBQUMsRUFBRSxDQUFDLFVBQVUsRUFBRSxVQUFDLEdBQW9CO1lBQzlCLElBQUEsS0FBcUIsR0FBRyxXQUFSLEVBQWhCLFVBQVUsbUJBQUcsR0FBRyxLQUFBLENBQVM7WUFDakMsSUFBSSxVQUFVLEdBQUcsR0FBRyxJQUFJLEdBQUcsSUFBSSxVQUFVLEVBQUU7Z0JBQ3pDLE1BQU0sQ0FDSixNQUFNLENBQUMsTUFBTSxDQUFDLElBQUksYUFBYSxDQUFDLHdEQUF3RCxDQUFDLEVBQUUsRUFBRSxVQUFVLFlBQUEsRUFBRSxDQUFDLENBQzNHLENBQUM7Z0JBQ0YsR0FBRyxDQUFDLE9BQU8sRUFBRSxDQUFDO2FBQ2Y7WUFFRCxJQUFNLE1BQU0sR0FBa0IsRUFBRSxDQUFDO1lBQ2pDLEdBQUcsQ0FBQyxFQUFFLENBQUMsTUFBTSxFQUFFLFVBQUMsS0FBSztnQkFDbkIsTUFBTSxDQUFDLElBQUksQ0FBQyxLQUFlLENBQUMsQ0FBQztZQUMvQixDQUFDLENBQUMsQ0FBQztZQUNILEdBQUcsQ0FBQyxFQUFFLENBQUMsS0FBSyxFQUFFO2dCQUNaLE9BQU8sQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUM7Z0JBQy9CLEdBQUcsQ0FBQyxPQUFPLEVBQUUsQ0FBQztZQUNoQixDQUFDLENBQUMsQ0FBQztRQUNMLENBQUMsQ0FBQyxDQUFDO1FBRUgsR0FBRyxDQUFDLEdBQUcsRUFBRSxDQUFDO0lBQ1osQ0FBQyxDQUFDLENBQUM7QUFDTCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUHJvdmlkZXJFcnJvciB9IGZyb20gXCJAYXdzLXNkay9wcm9wZXJ0eS1wcm92aWRlclwiO1xuaW1wb3J0IHsgQnVmZmVyIH0gZnJvbSBcImJ1ZmZlclwiO1xuaW1wb3J0IHsgSW5jb21pbmdNZXNzYWdlLCByZXF1ZXN0LCBSZXF1ZXN0T3B0aW9ucyB9IGZyb20gXCJodHRwXCI7XG5cbi8qKlxuICogQGludGVybmFsXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBodHRwUmVxdWVzdChvcHRpb25zOiBSZXF1ZXN0T3B0aW9ucyk6IFByb21pc2U8QnVmZmVyPiB7XG4gIHJldHVybiBuZXcgUHJvbWlzZSgocmVzb2x2ZSwgcmVqZWN0KSA9PiB7XG4gICAgY29uc3QgcmVxID0gcmVxdWVzdCh7IG1ldGhvZDogXCJHRVRcIiwgLi4ub3B0aW9ucyB9KTtcblxuICAgIHJlcS5vbihcImVycm9yXCIsIChlcnIpID0+IHtcbiAgICAgIHJlamVjdChPYmplY3QuYXNzaWduKG5ldyBQcm92aWRlckVycm9yKFwiVW5hYmxlIHRvIGNvbm5lY3QgdG8gaW5zdGFuY2UgbWV0YWRhdGEgc2VydmljZVwiKSwgZXJyKSk7XG4gICAgICByZXEuZGVzdHJveSgpO1xuICAgIH0pO1xuXG4gICAgcmVxLm9uKFwidGltZW91dFwiLCAoKSA9PiB7XG4gICAgICByZWplY3QobmV3IFByb3ZpZGVyRXJyb3IoXCJUaW1lb3V0RXJyb3IgZnJvbSBpbnN0YW5jZSBtZXRhZGF0YSBzZXJ2aWNlXCIpKTtcbiAgICAgIHJlcS5kZXN0cm95KCk7XG4gICAgfSk7XG5cbiAgICByZXEub24oXCJyZXNwb25zZVwiLCAocmVzOiBJbmNvbWluZ01lc3NhZ2UpID0+IHtcbiAgICAgIGNvbnN0IHsgc3RhdHVzQ29kZSA9IDQwMCB9ID0gcmVzO1xuICAgICAgaWYgKHN0YXR1c0NvZGUgPCAyMDAgfHwgMzAwIDw9IHN0YXR1c0NvZGUpIHtcbiAgICAgICAgcmVqZWN0KFxuICAgICAgICAgIE9iamVjdC5hc3NpZ24obmV3IFByb3ZpZGVyRXJyb3IoXCJFcnJvciByZXNwb25zZSByZWNlaXZlZCBmcm9tIGluc3RhbmNlIG1ldGFkYXRhIHNlcnZpY2VcIiksIHsgc3RhdHVzQ29kZSB9KVxuICAgICAgICApO1xuICAgICAgICByZXEuZGVzdHJveSgpO1xuICAgICAgfVxuXG4gICAgICBjb25zdCBjaHVua3M6IEFycmF5PEJ1ZmZlcj4gPSBbXTtcbiAgICAgIHJlcy5vbihcImRhdGFcIiwgKGNodW5rKSA9PiB7XG4gICAgICAgIGNodW5rcy5wdXNoKGNodW5rIGFzIEJ1ZmZlcik7XG4gICAgICB9KTtcbiAgICAgIHJlcy5vbihcImVuZFwiLCAoKSA9PiB7XG4gICAgICAgIHJlc29sdmUoQnVmZmVyLmNvbmNhdChjaHVua3MpKTtcbiAgICAgICAgcmVxLmRlc3Ryb3koKTtcbiAgICAgIH0pO1xuICAgIH0pO1xuXG4gICAgcmVxLmVuZCgpO1xuICB9KTtcbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaHR0cFJlcXVlc3QuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvcmVtb3RlUHJvdmlkZXIvaHR0cFJlcXVlc3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0sUUFBUSxDQUFDO0FBQ2hDLE9BQU8sRUFBbUIsT0FBTyxFQUFrQixNQUFNLE1BQU0sQ0FBQztBQUVoRTs7R0FFRztBQUNILE1BQU0sVUFBVSxXQUFXLENBQUMsT0FBdUI7SUFDakQsT0FBTyxJQUFJLE9BQU8sQ0FBQyxVQUFDLE9BQU8sRUFBRSxNQUFNOztRQUNqQyxJQUFNLEdBQUcsR0FBRyxPQUFPLHFCQUNqQixNQUFNLEVBQUUsS0FBSyxJQUNWLE9BQU87WUFDVixtRUFBbUU7WUFDbkUsb0RBQW9EO1lBQ3BELFFBQVEsRUFBRSxNQUFBLE9BQU8sQ0FBQyxRQUFRLDBDQUFFLE9BQU8sQ0FBQyxZQUFZLEVBQUUsSUFBSSxDQUFDLElBQ3ZELENBQUM7UUFFSCxHQUFHLENBQUMsRUFBRSxDQUFDLE9BQU8sRUFBRSxVQUFDLEdBQUc7WUFDbEIsTUFBTSxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsSUFBSSxhQUFhLENBQUMsZ0RBQWdELENBQUMsRUFBRSxHQUFHLENBQUMsQ0FBQyxDQUFDO1lBQ2hHLEdBQUcsQ0FBQyxPQUFPLEVBQUUsQ0FBQztRQUNoQixDQUFDLENBQUMsQ0FBQztRQUVILEdBQUcsQ0FBQyxFQUFFLENBQUMsU0FBUyxFQUFFO1lBQ2hCLE1BQU0sQ0FBQyxJQUFJLGFBQWEsQ0FBQyw2Q0FBNkMsQ0FBQyxDQUFDLENBQUM7WUFDekUsR0FBRyxDQUFDLE9BQU8sRUFBRSxDQUFDO1FBQ2hCLENBQUMsQ0FBQyxDQUFDO1FBRUgsR0FBRyxDQUFDLEVBQUUsQ0FBQyxVQUFVLEVBQUUsVUFBQyxHQUFvQjtZQUM5QixJQUFBLEtBQXFCLEdBQUcsV0FBUixFQUFoQixVQUFVLG1CQUFHLEdBQUcsS0FBQSxDQUFTO1lBQ2pDLElBQUksVUFBVSxHQUFHLEdBQUcsSUFBSSxHQUFHLElBQUksVUFBVSxFQUFFO2dCQUN6QyxNQUFNLENBQ0osTUFBTSxDQUFDLE1BQU0sQ0FBQyxJQUFJLGFBQWEsQ0FBQyx3REFBd0QsQ0FBQyxFQUFFLEVBQUUsVUFBVSxZQUFBLEVBQUUsQ0FBQyxDQUMzRyxDQUFDO2dCQUNGLEdBQUcsQ0FBQyxPQUFPLEVBQUUsQ0FBQzthQUNmO1lBRUQsSUFBTSxNQUFNLEdBQWtCLEVBQUUsQ0FBQztZQUNqQyxHQUFHLENBQUMsRUFBRSxDQUFDLE1BQU0sRUFBRSxVQUFDLEtBQUs7Z0JBQ25CLE1BQU0sQ0FBQyxJQUFJLENBQUMsS0FBZSxDQUFDLENBQUM7WUFDL0IsQ0FBQyxDQUFDLENBQUM7WUFDSCxHQUFHLENBQUMsRUFBRSxDQUFDLEtBQUssRUFBRTtnQkFDWixPQUFPLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDO2dCQUMvQixHQUFHLENBQUMsT0FBTyxFQUFFLENBQUM7WUFDaEIsQ0FBQyxDQUFDLENBQUM7UUFDTCxDQUFDLENBQUMsQ0FBQztRQUVILEdBQUcsQ0FBQyxHQUFHLEVBQUUsQ0FBQztJQUNaLENBQUMsQ0FBQyxDQUFDO0FBQ0wsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFByb3ZpZGVyRXJyb3IgfSBmcm9tIFwiQGF3cy1zZGsvcHJvcGVydHktcHJvdmlkZXJcIjtcbmltcG9ydCB7IEJ1ZmZlciB9IGZyb20gXCJidWZmZXJcIjtcbmltcG9ydCB7IEluY29taW5nTWVzc2FnZSwgcmVxdWVzdCwgUmVxdWVzdE9wdGlvbnMgfSBmcm9tIFwiaHR0cFwiO1xuXG4vKipcbiAqIEBpbnRlcm5hbFxuICovXG5leHBvcnQgZnVuY3Rpb24gaHR0cFJlcXVlc3Qob3B0aW9uczogUmVxdWVzdE9wdGlvbnMpOiBQcm9taXNlPEJ1ZmZlcj4ge1xuICByZXR1cm4gbmV3IFByb21pc2UoKHJlc29sdmUsIHJlamVjdCkgPT4ge1xuICAgIGNvbnN0IHJlcSA9IHJlcXVlc3Qoe1xuICAgICAgbWV0aG9kOiBcIkdFVFwiLFxuICAgICAgLi4ub3B0aW9ucyxcbiAgICAgIC8vIE5vZGUuanMgaHR0cCBtb2R1bGUgZG9lc24ndCBhY2NlcHQgaG9zdG5hbWUgd2l0aCBzcXVhcmUgYnJhY2tldHNcbiAgICAgIC8vIFJlZnM6IGh0dHBzOi8vZ2l0aHViLmNvbS9ub2RlanMvbm9kZS9pc3N1ZXMvMzk3MzhcbiAgICAgIGhvc3RuYW1lOiBvcHRpb25zLmhvc3RuYW1lPy5yZXBsYWNlKC9eXFxbKC4rKVxcXSQvLCBcIiQxXCIpLFxuICAgIH0pO1xuXG4gICAgcmVxLm9uKFwiZXJyb3JcIiwgKGVycikgPT4ge1xuICAgICAgcmVqZWN0KE9iamVjdC5hc3NpZ24obmV3IFByb3ZpZGVyRXJyb3IoXCJVbmFibGUgdG8gY29ubmVjdCB0byBpbnN0YW5jZSBtZXRhZGF0YSBzZXJ2aWNlXCIpLCBlcnIpKTtcbiAgICAgIHJlcS5kZXN0cm95KCk7XG4gICAgfSk7XG5cbiAgICByZXEub24oXCJ0aW1lb3V0XCIsICgpID0+IHtcbiAgICAgIHJlamVjdChuZXcgUHJvdmlkZXJFcnJvcihcIlRpbWVvdXRFcnJvciBmcm9tIGluc3RhbmNlIG1ldGFkYXRhIHNlcnZpY2VcIikpO1xuICAgICAgcmVxLmRlc3Ryb3koKTtcbiAgICB9KTtcblxuICAgIHJlcS5vbihcInJlc3BvbnNlXCIsIChyZXM6IEluY29taW5nTWVzc2FnZSkgPT4ge1xuICAgICAgY29uc3QgeyBzdGF0dXNDb2RlID0gNDAwIH0gPSByZXM7XG4gICAgICBpZiAoc3RhdHVzQ29kZSA8IDIwMCB8fCAzMDAgPD0gc3RhdHVzQ29kZSkge1xuICAgICAgICByZWplY3QoXG4gICAgICAgICAgT2JqZWN0LmFzc2lnbihuZXcgUHJvdmlkZXJFcnJvcihcIkVycm9yIHJlc3BvbnNlIHJlY2VpdmVkIGZyb20gaW5zdGFuY2UgbWV0YWRhdGEgc2VydmljZVwiKSwgeyBzdGF0dXNDb2RlIH0pXG4gICAgICAgICk7XG4gICAgICAgIHJlcS5kZXN0cm95KCk7XG4gICAgICB9XG5cbiAgICAgIGNvbnN0IGNodW5rczogQXJyYXk8QnVmZmVyPiA9IFtdO1xuICAgICAgcmVzLm9uKFwiZGF0YVwiLCAoY2h1bmspID0+IHtcbiAgICAgICAgY2h1bmtzLnB1c2goY2h1bmsgYXMgQnVmZmVyKTtcbiAgICAgIH0pO1xuICAgICAgcmVzLm9uKFwiZW5kXCIsICgpID0+IHtcbiAgICAgICAgcmVzb2x2ZShCdWZmZXIuY29uY2F0KGNodW5rcykpO1xuICAgICAgICByZXEuZGVzdHJveSgpO1xuICAgICAgfSk7XG4gICAgfSk7XG5cbiAgICByZXEuZW5kKCk7XG4gIH0pO1xufVxuIl19
{
"name": "@aws-sdk/credential-provider-imds",
"version": "3.25.0",
"version": "3.26.0",
"description": "AWS credential provider that sources credentials from the EC2 instance metadata service and ECS container metadata service",

@@ -24,4 +24,6 @@ "main": "./dist/cjs/index.js",

"dependencies": {
"@aws-sdk/node-config-provider": "3.25.0",
"@aws-sdk/property-provider": "3.25.0",
"@aws-sdk/types": "3.25.0",
"@aws-sdk/url-parser": "3.25.0",
"tslib": "^2.3.0"

@@ -28,0 +30,0 @@ },

@@ -9,4 +9,4 @@ import { CredentialsProviderError } from "@aws-sdk/property-provider";

import { retry } from "./remoteProvider/retry";
import { getInstanceMetadataEndpoint } from "./utils/getInstanceMetadataEndpoint";
const IMDS_IP = "169.254.169.254";
const IMDS_PATH = "/latest/meta-data/iam/security-credentials/";

@@ -55,8 +55,9 @@ const IMDS_TOKEN_PATH = "/latest/api/token";

return async () => {
const endpoint = await getInstanceMetadataEndpoint();
if (disableFetchToken) {
return getCredentials(maxRetries, { timeout });
return getCredentials(maxRetries, { ...endpoint, timeout });
} else {
let token: string;
try {
token = (await getMetadataToken({ timeout })).toString();
token = (await getMetadataToken({ ...endpoint, timeout })).toString();
} catch (error) {

@@ -70,9 +71,10 @@ if (error?.statusCode === 400) {

}
return getCredentials(maxRetries, { timeout });
return getCredentials(maxRetries, { ...endpoint, timeout });
}
return getCredentials(maxRetries, {
timeout,
...endpoint,
headers: {
"x-aws-ec2-metadata-token": token,
},
timeout,
});

@@ -86,3 +88,2 @@ }

...options,
host: IMDS_IP,
path: IMDS_TOKEN_PATH,

@@ -95,4 +96,3 @@ method: "PUT",

const getProfile = async (options: RequestOptions) =>
(await httpRequest({ ...options, host: IMDS_IP, path: IMDS_PATH })).toString();
const getProfile = async (options: RequestOptions) => (await httpRequest({ ...options, path: IMDS_PATH })).toString();

@@ -104,3 +104,2 @@ const getCredentialsFromProfile = async (profile: string, options: RequestOptions) => {

...options,
host: IMDS_IP,
path: IMDS_PATH + profile,

@@ -107,0 +106,0 @@ })

@@ -10,3 +10,9 @@ import { ProviderError } from "@aws-sdk/property-provider";

return new Promise((resolve, reject) => {
const req = request({ method: "GET", ...options });
const req = request({
method: "GET",
...options,
// Node.js http module doesn't accept hostname with square brackets
// Refs: https://github.com/nodejs/node/issues/39738
hostname: options.hostname?.replace(/^\[(.+)\]$/, "$1"),
});

@@ -13,0 +19,0 @@ req.on("error", (err) => {

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc