Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@aws-sdk/credential-provider-ini

Package Overview
Dependencies
Maintainers
5
Versions
359
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

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

Comparing version 3.8.0 to 3.10.0

dist/types/index.d.ts

12

CHANGELOG.md

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

# [3.10.0](https://github.com/aws/aws-sdk-js-v3/compare/v3.9.0...v3.10.0) (2021-03-26)
### Features
* **credential-provider-ini:** call fromTokenFile in assumeRole chaining ([#2178](https://github.com/aws/aws-sdk-js-v3/issues/2178)) ([fb95408](https://github.com/aws/aws-sdk-js-v3/commit/fb95408d999c8322a12fcc1459e3a56b289048b4))
* use ts-jest for running jest tests ([#2088](https://github.com/aws/aws-sdk-js-v3/issues/2088)) ([456002c](https://github.com/aws/aws-sdk-js-v3/commit/456002cf7fa16864b72c3c279b094886a42abddb))
# [3.8.0](https://github.com/aws/aws-sdk-js-v3/compare/v3.7.0...v3.8.0) (2021-03-05)

@@ -8,0 +20,0 @@

23

dist/cjs/index.js
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.getMasterProfileName = exports.parseKnownFiles = exports.fromIni = exports.ENV_PROFILE = void 0;
const credential_provider_web_identity_1 = require("@aws-sdk/credential-provider-web-identity");
const property_provider_1 = require("@aws-sdk/property-provider");

@@ -13,5 +14,10 @@ const shared_ini_file_loader_1 = require("@aws-sdk/shared-ini-file-loader");

["undefined", "string"].indexOf(typeof arg.aws_session_token) > -1;
const isAssumeRoleProfile = (arg) => Boolean(arg) &&
const isWebIdentityProfile = (arg) => Boolean(arg) &&
typeof arg === "object" &&
typeof arg.web_identity_token_file === "string" &&
typeof arg.role_arn === "string" &&
["undefined", "string"].indexOf(typeof arg.role_session_name) > -1;
const isAssumeRoleWithSourceProfile = (arg) => Boolean(arg) &&
typeof arg === "object" &&
typeof arg.role_arn === "string" &&
typeof arg.source_profile === "string" &&

@@ -60,3 +66,3 @@ ["undefined", "string"].indexOf(typeof arg.role_session_name) > -1 &&

// given precedence over static credentials.
if (isAssumeRoleProfile(data)) {
if (isAssumeRoleWithSourceProfile(data)) {
const { external_id: ExternalId, mfa_serial, role_arn: RoleArn, role_session_name: RoleSessionName = "aws-sdk-js-" + Date.now(), source_profile, } = data;

@@ -90,2 +96,7 @@ if (!options.roleAssumer) {

}
// If no static credentials are present, attempt to assume role with
// web identity if web_identity_token_file and role_arn is available
if (isWebIdentityProfile(data)) {
return resolveWebIdentityCredentials(data, options);
}
// If the profile cannot be parsed or contains neither static credentials

@@ -103,2 +114,8 @@ // nor role assumption metadata, throw an error. This should be considered a

});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["import { ProviderError } from \"@aws-sdk/property-provider\";\nimport {\n  loadSharedConfigFiles,\n  ParsedIniData,\n  Profile,\n  SharedConfigFiles,\n  SharedConfigInit,\n} from \"@aws-sdk/shared-ini-file-loader\";\nimport { CredentialProvider, Credentials } from \"@aws-sdk/types\";\n\nconst DEFAULT_PROFILE = \"default\";\nexport const ENV_PROFILE = \"AWS_PROFILE\";\n\n/**\n * @see http://docs.aws.amazon.com/AWSJavaScriptSDK/latest/AWS/STS.html#assumeRole-property\n * TODO update the above to link to V3 docs\n */\nexport interface AssumeRoleParams {\n  /**\n   * The identifier of the role to be assumed.\n   */\n  RoleArn: string;\n\n  /**\n   * A name for the assumed role session.\n   */\n  RoleSessionName: string;\n\n  /**\n   * A unique identifier that is used by third parties when assuming roles in\n   * their customers' accounts.\n   */\n  ExternalId?: string;\n\n  /**\n   * The identification number of the MFA device that is associated with the\n   * user who is making the `AssumeRole` call.\n   */\n  SerialNumber?: string;\n\n  /**\n   * The value provided by the MFA device.\n   */\n  TokenCode?: string;\n}\n\nexport interface SourceProfileInit extends SharedConfigInit {\n  /**\n   * The configuration profile to use.\n   */\n  profile?: string;\n\n  /**\n   * A promise that will be resolved with loaded and parsed credentials files.\n   * Used to avoid loading shared config files multiple times.\n   *\n   * @internal\n   */\n  loadedConfig?: Promise<SharedConfigFiles>;\n}\n\nexport interface FromIniInit extends SourceProfileInit {\n  /**\n   * A function that returna a promise fulfilled with an MFA token code for\n   * the provided MFA Serial code. If a profile requires an MFA code and\n   * `mfaCodeProvider` is not a valid function, the credential provider\n   * promise will be rejected.\n   *\n   * @param mfaSerial The serial code of the MFA device specified.\n   */\n  mfaCodeProvider?: (mfaSerial: string) => Promise<string>;\n\n  /**\n   * A function that assumes a role and returns a promise fulfilled with\n   * credentials for the assumed role.\n   *\n   * @param sourceCreds The credentials with which to assume a role.\n   * @param params\n   */\n  roleAssumer?: (sourceCreds: Credentials, params: AssumeRoleParams) => Promise<Credentials>;\n}\n\ninterface StaticCredsProfile extends Profile {\n  aws_access_key_id: string;\n  aws_secret_access_key: string;\n  aws_session_token?: string;\n}\n\nconst isStaticCredsProfile = (arg: any): arg is StaticCredsProfile =>\n  Boolean(arg) &&\n  typeof arg === \"object\" &&\n  typeof arg.aws_access_key_id === \"string\" &&\n  typeof arg.aws_secret_access_key === \"string\" &&\n  [\"undefined\", \"string\"].indexOf(typeof arg.aws_session_token) > -1;\n\ninterface AssumeRoleProfile extends Profile {\n  role_arn: string;\n  source_profile: string;\n}\n\nconst isAssumeRoleProfile = (arg: any): arg is AssumeRoleProfile =>\n  Boolean(arg) &&\n  typeof arg === \"object\" &&\n  typeof arg.role_arn === \"string\" &&\n  typeof arg.source_profile === \"string\" &&\n  [\"undefined\", \"string\"].indexOf(typeof arg.role_session_name) > -1 &&\n  [\"undefined\", \"string\"].indexOf(typeof arg.external_id) > -1 &&\n  [\"undefined\", \"string\"].indexOf(typeof arg.mfa_serial) > -1;\n\n/**\n * Creates a credential provider that will read from ini files and supports\n * role assumption and multi-factor authentication.\n */\nexport const fromIni = (init: FromIniInit = {}): CredentialProvider => async () => {\n  const profiles = await parseKnownFiles(init);\n  return resolveProfileData(getMasterProfileName(init), profiles, init);\n};\n\n/**\n * Load profiles from credentials and config INI files and normalize them into a\n * single profile list.\n *\n * @internal\n */\nexport const parseKnownFiles = async (init: SourceProfileInit): Promise<ParsedIniData> => {\n  const { loadedConfig = loadSharedConfigFiles(init) } = init;\n\n  const parsedFiles = await loadedConfig;\n  return {\n    ...parsedFiles.configFile,\n    ...parsedFiles.credentialsFile,\n  };\n};\n\n/**\n * @internal\n */\nexport const getMasterProfileName = (init: { profile?: string }): string =>\n  init.profile || process.env[ENV_PROFILE] || DEFAULT_PROFILE;\n\nconst resolveProfileData = async (\n  profileName: string,\n  profiles: ParsedIniData,\n  options: FromIniInit,\n  visitedProfiles: { [profileName: string]: true } = {}\n): Promise<Credentials> => {\n  const data = profiles[profileName];\n\n  // If this is not the first profile visited, static credentials should be\n  // preferred over role assumption metadata. This special treatment of\n  // second and subsequent hops is to ensure compatibility with the AWS CLI.\n  if (Object.keys(visitedProfiles).length > 0 && isStaticCredsProfile(data)) {\n    return resolveStaticCredentials(data);\n  }\n\n  // If this is the first profile visited, role assumption keys should be\n  // given precedence over static credentials.\n  if (isAssumeRoleProfile(data)) {\n    const {\n      external_id: ExternalId,\n      mfa_serial,\n      role_arn: RoleArn,\n      role_session_name: RoleSessionName = \"aws-sdk-js-\" + Date.now(),\n      source_profile,\n    } = data;\n\n    if (!options.roleAssumer) {\n      throw new ProviderError(\n        `Profile ${profileName} requires a role to be assumed, but no` + ` role assumption callback was provided.`,\n        false\n      );\n    }\n\n    if (source_profile in visitedProfiles) {\n      throw new ProviderError(\n        `Detected a cycle attempting to resolve credentials for profile` +\n          ` ${getMasterProfileName(options)}. Profiles visited: ` +\n          Object.keys(visitedProfiles).join(\", \"),\n        false\n      );\n    }\n\n    const sourceCreds = resolveProfileData(source_profile, profiles, options, {\n      ...visitedProfiles,\n      [source_profile]: true,\n    });\n    const params: AssumeRoleParams = { RoleArn, RoleSessionName, ExternalId };\n    if (mfa_serial) {\n      if (!options.mfaCodeProvider) {\n        throw new ProviderError(\n          `Profile ${profileName} requires multi-factor authentication,` + ` but no MFA code callback was provided.`,\n          false\n        );\n      }\n      params.SerialNumber = mfa_serial;\n      params.TokenCode = await options.mfaCodeProvider(mfa_serial);\n    }\n\n    return options.roleAssumer(await sourceCreds, params);\n  }\n\n  // If no role assumption metadata is present, attempt to load static\n  // credentials from the selected profile.\n  if (isStaticCredsProfile(data)) {\n    return resolveStaticCredentials(data);\n  }\n\n  // If the profile cannot be parsed or contains neither static credentials\n  // nor role assumption metadata, throw an error. This should be considered a\n  // terminal resolution error if a profile has been specified by the user\n  // (whether via a parameter, an environment variable, or another profile's\n  // `source_profile` key).\n  throw new ProviderError(`Profile ${profileName} could not be found or parsed in shared` + ` credentials file.`);\n};\n\nconst resolveStaticCredentials = (profile: StaticCredsProfile): Promise<Credentials> =>\n  Promise.resolve({\n    accessKeyId: profile.aws_access_key_id,\n    secretAccessKey: profile.aws_secret_access_key,\n    sessionToken: profile.aws_session_token,\n  });\n"]}
const resolveWebIdentityCredentials = async (profile, options) => credential_provider_web_identity_1.fromTokenFile({
webIdentityTokenFile: profile.web_identity_token_file,
roleArn: profile.role_arn,
roleSessionName: profile.role_session_name,
roleAssumerWithWebIdentity: options.roleAssumerWithWebIdentity,
})();
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["import { AssumeRoleWithWebIdentityParams, fromTokenFile } from \"@aws-sdk/credential-provider-web-identity\";\nimport { ProviderError } from \"@aws-sdk/property-provider\";\nimport {\n  loadSharedConfigFiles,\n  ParsedIniData,\n  Profile,\n  SharedConfigFiles,\n  SharedConfigInit,\n} from \"@aws-sdk/shared-ini-file-loader\";\nimport { CredentialProvider, Credentials } from \"@aws-sdk/types\";\n\nconst DEFAULT_PROFILE = \"default\";\nexport const ENV_PROFILE = \"AWS_PROFILE\";\n\n/**\n * @see http://docs.aws.amazon.com/AWSJavaScriptSDK/latest/AWS/STS.html#assumeRole-property\n * TODO update the above to link to V3 docs\n */\nexport interface AssumeRoleParams {\n  /**\n   * The identifier of the role to be assumed.\n   */\n  RoleArn: string;\n\n  /**\n   * A name for the assumed role session.\n   */\n  RoleSessionName: string;\n\n  /**\n   * A unique identifier that is used by third parties when assuming roles in\n   * their customers' accounts.\n   */\n  ExternalId?: string;\n\n  /**\n   * The identification number of the MFA device that is associated with the\n   * user who is making the `AssumeRole` call.\n   */\n  SerialNumber?: string;\n\n  /**\n   * The value provided by the MFA device.\n   */\n  TokenCode?: string;\n}\n\nexport interface SourceProfileInit extends SharedConfigInit {\n  /**\n   * The configuration profile to use.\n   */\n  profile?: string;\n\n  /**\n   * A promise that will be resolved with loaded and parsed credentials files.\n   * Used to avoid loading shared config files multiple times.\n   *\n   * @internal\n   */\n  loadedConfig?: Promise<SharedConfigFiles>;\n}\n\nexport interface FromIniInit extends SourceProfileInit {\n  /**\n   * A function that returns a promise fulfilled with an MFA token code for\n   * the provided MFA Serial code. If a profile requires an MFA code and\n   * `mfaCodeProvider` is not a valid function, the credential provider\n   * promise will be rejected.\n   *\n   * @param mfaSerial The serial code of the MFA device specified.\n   */\n  mfaCodeProvider?: (mfaSerial: string) => Promise<string>;\n\n  /**\n   * A function that assumes a role and returns a promise fulfilled with\n   * credentials for the assumed role.\n   *\n   * @param sourceCreds The credentials with which to assume a role.\n   * @param params\n   */\n  roleAssumer?: (sourceCreds: Credentials, params: AssumeRoleParams) => Promise<Credentials>;\n\n  /**\n   * A function that assumes a role with web identity and returns a promise fulfilled with\n   * credentials for the assumed role.\n   *\n   * @param sourceCreds The credentials with which to assume a role.\n   * @param params\n   */\n  roleAssumerWithWebIdentity?: (params: AssumeRoleWithWebIdentityParams) => Promise<Credentials>;\n}\n\ninterface StaticCredsProfile extends Profile {\n  aws_access_key_id: string;\n  aws_secret_access_key: string;\n  aws_session_token?: string;\n}\n\nconst isStaticCredsProfile = (arg: any): arg is StaticCredsProfile =>\n  Boolean(arg) &&\n  typeof arg === \"object\" &&\n  typeof arg.aws_access_key_id === \"string\" &&\n  typeof arg.aws_secret_access_key === \"string\" &&\n  [\"undefined\", \"string\"].indexOf(typeof arg.aws_session_token) > -1;\n\ninterface WebIdentityProfile extends Profile {\n  web_identity_token_file: string;\n  role_arn: string;\n  role_session_name?: string;\n}\n\nconst isWebIdentityProfile = (arg: any): arg is WebIdentityProfile =>\n  Boolean(arg) &&\n  typeof arg === \"object\" &&\n  typeof arg.web_identity_token_file === \"string\" &&\n  typeof arg.role_arn === \"string\" &&\n  [\"undefined\", \"string\"].indexOf(typeof arg.role_session_name) > -1;\ninterface AssumeRoleProfile extends Profile {\n  role_arn: string;\n  source_profile: string;\n}\n\nconst isAssumeRoleWithSourceProfile = (arg: any): arg is AssumeRoleProfile =>\n  Boolean(arg) &&\n  typeof arg === \"object\" &&\n  typeof arg.role_arn === \"string\" &&\n  typeof arg.source_profile === \"string\" &&\n  [\"undefined\", \"string\"].indexOf(typeof arg.role_session_name) > -1 &&\n  [\"undefined\", \"string\"].indexOf(typeof arg.external_id) > -1 &&\n  [\"undefined\", \"string\"].indexOf(typeof arg.mfa_serial) > -1;\n\n/**\n * Creates a credential provider that will read from ini files and supports\n * role assumption and multi-factor authentication.\n */\nexport const fromIni = (init: FromIniInit = {}): CredentialProvider => async () => {\n  const profiles = await parseKnownFiles(init);\n  return resolveProfileData(getMasterProfileName(init), profiles, init);\n};\n\n/**\n * Load profiles from credentials and config INI files and normalize them into a\n * single profile list.\n *\n * @internal\n */\nexport const parseKnownFiles = async (init: SourceProfileInit): Promise<ParsedIniData> => {\n  const { loadedConfig = loadSharedConfigFiles(init) } = init;\n\n  const parsedFiles = await loadedConfig;\n  return {\n    ...parsedFiles.configFile,\n    ...parsedFiles.credentialsFile,\n  };\n};\n\n/**\n * @internal\n */\nexport const getMasterProfileName = (init: { profile?: string }): string =>\n  init.profile || process.env[ENV_PROFILE] || DEFAULT_PROFILE;\n\nconst resolveProfileData = async (\n  profileName: string,\n  profiles: ParsedIniData,\n  options: FromIniInit,\n  visitedProfiles: { [profileName: string]: true } = {}\n): Promise<Credentials> => {\n  const data = profiles[profileName];\n\n  // If this is not the first profile visited, static credentials should be\n  // preferred over role assumption metadata. This special treatment of\n  // second and subsequent hops is to ensure compatibility with the AWS CLI.\n  if (Object.keys(visitedProfiles).length > 0 && isStaticCredsProfile(data)) {\n    return resolveStaticCredentials(data);\n  }\n\n  // If this is the first profile visited, role assumption keys should be\n  // given precedence over static credentials.\n  if (isAssumeRoleWithSourceProfile(data)) {\n    const {\n      external_id: ExternalId,\n      mfa_serial,\n      role_arn: RoleArn,\n      role_session_name: RoleSessionName = \"aws-sdk-js-\" + Date.now(),\n      source_profile,\n    } = data;\n\n    if (!options.roleAssumer) {\n      throw new ProviderError(\n        `Profile ${profileName} requires a role to be assumed, but no` + ` role assumption callback was provided.`,\n        false\n      );\n    }\n\n    if (source_profile in visitedProfiles) {\n      throw new ProviderError(\n        `Detected a cycle attempting to resolve credentials for profile` +\n          ` ${getMasterProfileName(options)}. Profiles visited: ` +\n          Object.keys(visitedProfiles).join(\", \"),\n        false\n      );\n    }\n\n    const sourceCreds = resolveProfileData(source_profile, profiles, options, {\n      ...visitedProfiles,\n      [source_profile]: true,\n    });\n    const params: AssumeRoleParams = { RoleArn, RoleSessionName, ExternalId };\n    if (mfa_serial) {\n      if (!options.mfaCodeProvider) {\n        throw new ProviderError(\n          `Profile ${profileName} requires multi-factor authentication,` + ` but no MFA code callback was provided.`,\n          false\n        );\n      }\n      params.SerialNumber = mfa_serial;\n      params.TokenCode = await options.mfaCodeProvider(mfa_serial);\n    }\n\n    return options.roleAssumer(await sourceCreds, params);\n  }\n\n  // If no role assumption metadata is present, attempt to load static\n  // credentials from the selected profile.\n  if (isStaticCredsProfile(data)) {\n    return resolveStaticCredentials(data);\n  }\n\n  // If no static credentials are present, attempt to assume role with\n  // web identity if web_identity_token_file and role_arn is available\n  if (isWebIdentityProfile(data)) {\n    return resolveWebIdentityCredentials(data, options);\n  }\n\n  // If the profile cannot be parsed or contains neither static credentials\n  // nor role assumption metadata, throw an error. This should be considered a\n  // terminal resolution error if a profile has been specified by the user\n  // (whether via a parameter, an environment variable, or another profile's\n  // `source_profile` key).\n  throw new ProviderError(`Profile ${profileName} could not be found or parsed in shared` + ` credentials file.`);\n};\n\nconst resolveStaticCredentials = (profile: StaticCredsProfile): Promise<Credentials> =>\n  Promise.resolve({\n    accessKeyId: profile.aws_access_key_id,\n    secretAccessKey: profile.aws_secret_access_key,\n    sessionToken: profile.aws_session_token,\n  });\n\nconst resolveWebIdentityCredentials = async (profile: WebIdentityProfile, options: FromIniInit): Promise<Credentials> =>\n  fromTokenFile({\n    webIdentityTokenFile: profile.web_identity_token_file,\n    roleArn: profile.role_arn,\n    roleSessionName: profile.role_session_name,\n    roleAssumerWithWebIdentity: options.roleAssumerWithWebIdentity,\n  })();\n"]}
import { __assign, __awaiter, __generator } from "tslib";
import { fromTokenFile } from "@aws-sdk/credential-provider-web-identity";
import { ProviderError } from "@aws-sdk/property-provider";

@@ -13,6 +14,13 @@ import { loadSharedConfigFiles, } from "@aws-sdk/shared-ini-file-loader";

};
var isAssumeRoleProfile = function (arg) {
var isWebIdentityProfile = function (arg) {
return Boolean(arg) &&
typeof arg === "object" &&
typeof arg.web_identity_token_file === "string" &&
typeof arg.role_arn === "string" &&
["undefined", "string"].indexOf(typeof arg.role_session_name) > -1;
};
var isAssumeRoleWithSourceProfile = function (arg) {
return Boolean(arg) &&
typeof arg === "object" &&
typeof arg.role_arn === "string" &&
typeof arg.source_profile === "string" &&

@@ -81,3 +89,3 @@ ["undefined", "string"].indexOf(typeof arg.role_session_name) > -1 &&

}
if (!isAssumeRoleProfile(data)) return [3 /*break*/, 4];
if (!isAssumeRoleWithSourceProfile(data)) return [3 /*break*/, 4];
ExternalId = data.external_id, mfa_serial = data.mfa_serial, RoleArn = data.role_arn, _a = data.role_session_name, RoleSessionName = _a === void 0 ? "aws-sdk-js-" + Date.now() : _a, source_profile = data.source_profile;

@@ -114,2 +122,7 @@ if (!options.roleAssumer) {

}
// If no static credentials are present, attempt to assume role with
// web identity if web_identity_token_file and role_arn is available
if (isWebIdentityProfile(data)) {
return [2 /*return*/, resolveWebIdentityCredentials(data, options)];
}
// If the profile cannot be parsed or contains neither static credentials

@@ -132,2 +145,12 @@ // nor role assumption metadata, throw an error. This should be considered a

};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["import { ProviderError } from \"@aws-sdk/property-provider\";\nimport {\n  loadSharedConfigFiles,\n  ParsedIniData,\n  Profile,\n  SharedConfigFiles,\n  SharedConfigInit,\n} from \"@aws-sdk/shared-ini-file-loader\";\nimport { CredentialProvider, Credentials } from \"@aws-sdk/types\";\n\nconst DEFAULT_PROFILE = \"default\";\nexport const ENV_PROFILE = \"AWS_PROFILE\";\n\n/**\n * @see http://docs.aws.amazon.com/AWSJavaScriptSDK/latest/AWS/STS.html#assumeRole-property\n * TODO update the above to link to V3 docs\n */\nexport interface AssumeRoleParams {\n  /**\n   * The identifier of the role to be assumed.\n   */\n  RoleArn: string;\n\n  /**\n   * A name for the assumed role session.\n   */\n  RoleSessionName: string;\n\n  /**\n   * A unique identifier that is used by third parties when assuming roles in\n   * their customers' accounts.\n   */\n  ExternalId?: string;\n\n  /**\n   * The identification number of the MFA device that is associated with the\n   * user who is making the `AssumeRole` call.\n   */\n  SerialNumber?: string;\n\n  /**\n   * The value provided by the MFA device.\n   */\n  TokenCode?: string;\n}\n\nexport interface SourceProfileInit extends SharedConfigInit {\n  /**\n   * The configuration profile to use.\n   */\n  profile?: string;\n\n  /**\n   * A promise that will be resolved with loaded and parsed credentials files.\n   * Used to avoid loading shared config files multiple times.\n   *\n   * @internal\n   */\n  loadedConfig?: Promise<SharedConfigFiles>;\n}\n\nexport interface FromIniInit extends SourceProfileInit {\n  /**\n   * A function that returna a promise fulfilled with an MFA token code for\n   * the provided MFA Serial code. If a profile requires an MFA code and\n   * `mfaCodeProvider` is not a valid function, the credential provider\n   * promise will be rejected.\n   *\n   * @param mfaSerial The serial code of the MFA device specified.\n   */\n  mfaCodeProvider?: (mfaSerial: string) => Promise<string>;\n\n  /**\n   * A function that assumes a role and returns a promise fulfilled with\n   * credentials for the assumed role.\n   *\n   * @param sourceCreds The credentials with which to assume a role.\n   * @param params\n   */\n  roleAssumer?: (sourceCreds: Credentials, params: AssumeRoleParams) => Promise<Credentials>;\n}\n\ninterface StaticCredsProfile extends Profile {\n  aws_access_key_id: string;\n  aws_secret_access_key: string;\n  aws_session_token?: string;\n}\n\nconst isStaticCredsProfile = (arg: any): arg is StaticCredsProfile =>\n  Boolean(arg) &&\n  typeof arg === \"object\" &&\n  typeof arg.aws_access_key_id === \"string\" &&\n  typeof arg.aws_secret_access_key === \"string\" &&\n  [\"undefined\", \"string\"].indexOf(typeof arg.aws_session_token) > -1;\n\ninterface AssumeRoleProfile extends Profile {\n  role_arn: string;\n  source_profile: string;\n}\n\nconst isAssumeRoleProfile = (arg: any): arg is AssumeRoleProfile =>\n  Boolean(arg) &&\n  typeof arg === \"object\" &&\n  typeof arg.role_arn === \"string\" &&\n  typeof arg.source_profile === \"string\" &&\n  [\"undefined\", \"string\"].indexOf(typeof arg.role_session_name) > -1 &&\n  [\"undefined\", \"string\"].indexOf(typeof arg.external_id) > -1 &&\n  [\"undefined\", \"string\"].indexOf(typeof arg.mfa_serial) > -1;\n\n/**\n * Creates a credential provider that will read from ini files and supports\n * role assumption and multi-factor authentication.\n */\nexport const fromIni = (init: FromIniInit = {}): CredentialProvider => async () => {\n  const profiles = await parseKnownFiles(init);\n  return resolveProfileData(getMasterProfileName(init), profiles, init);\n};\n\n/**\n * Load profiles from credentials and config INI files and normalize them into a\n * single profile list.\n *\n * @internal\n */\nexport const parseKnownFiles = async (init: SourceProfileInit): Promise<ParsedIniData> => {\n  const { loadedConfig = loadSharedConfigFiles(init) } = init;\n\n  const parsedFiles = await loadedConfig;\n  return {\n    ...parsedFiles.configFile,\n    ...parsedFiles.credentialsFile,\n  };\n};\n\n/**\n * @internal\n */\nexport const getMasterProfileName = (init: { profile?: string }): string =>\n  init.profile || process.env[ENV_PROFILE] || DEFAULT_PROFILE;\n\nconst resolveProfileData = async (\n  profileName: string,\n  profiles: ParsedIniData,\n  options: FromIniInit,\n  visitedProfiles: { [profileName: string]: true } = {}\n): Promise<Credentials> => {\n  const data = profiles[profileName];\n\n  // If this is not the first profile visited, static credentials should be\n  // preferred over role assumption metadata. This special treatment of\n  // second and subsequent hops is to ensure compatibility with the AWS CLI.\n  if (Object.keys(visitedProfiles).length > 0 && isStaticCredsProfile(data)) {\n    return resolveStaticCredentials(data);\n  }\n\n  // If this is the first profile visited, role assumption keys should be\n  // given precedence over static credentials.\n  if (isAssumeRoleProfile(data)) {\n    const {\n      external_id: ExternalId,\n      mfa_serial,\n      role_arn: RoleArn,\n      role_session_name: RoleSessionName = \"aws-sdk-js-\" + Date.now(),\n      source_profile,\n    } = data;\n\n    if (!options.roleAssumer) {\n      throw new ProviderError(\n        `Profile ${profileName} requires a role to be assumed, but no` + ` role assumption callback was provided.`,\n        false\n      );\n    }\n\n    if (source_profile in visitedProfiles) {\n      throw new ProviderError(\n        `Detected a cycle attempting to resolve credentials for profile` +\n          ` ${getMasterProfileName(options)}. Profiles visited: ` +\n          Object.keys(visitedProfiles).join(\", \"),\n        false\n      );\n    }\n\n    const sourceCreds = resolveProfileData(source_profile, profiles, options, {\n      ...visitedProfiles,\n      [source_profile]: true,\n    });\n    const params: AssumeRoleParams = { RoleArn, RoleSessionName, ExternalId };\n    if (mfa_serial) {\n      if (!options.mfaCodeProvider) {\n        throw new ProviderError(\n          `Profile ${profileName} requires multi-factor authentication,` + ` but no MFA code callback was provided.`,\n          false\n        );\n      }\n      params.SerialNumber = mfa_serial;\n      params.TokenCode = await options.mfaCodeProvider(mfa_serial);\n    }\n\n    return options.roleAssumer(await sourceCreds, params);\n  }\n\n  // If no role assumption metadata is present, attempt to load static\n  // credentials from the selected profile.\n  if (isStaticCredsProfile(data)) {\n    return resolveStaticCredentials(data);\n  }\n\n  // If the profile cannot be parsed or contains neither static credentials\n  // nor role assumption metadata, throw an error. This should be considered a\n  // terminal resolution error if a profile has been specified by the user\n  // (whether via a parameter, an environment variable, or another profile's\n  // `source_profile` key).\n  throw new ProviderError(`Profile ${profileName} could not be found or parsed in shared` + ` credentials file.`);\n};\n\nconst resolveStaticCredentials = (profile: StaticCredsProfile): Promise<Credentials> =>\n  Promise.resolve({\n    accessKeyId: profile.aws_access_key_id,\n    secretAccessKey: profile.aws_secret_access_key,\n    sessionToken: profile.aws_session_token,\n  });\n"]}
var resolveWebIdentityCredentials = function (profile, options) { return __awaiter(void 0, void 0, void 0, function () {
return __generator(this, function (_a) {
return [2 /*return*/, fromTokenFile({
webIdentityTokenFile: profile.web_identity_token_file,
roleArn: profile.role_arn,
roleSessionName: profile.role_session_name,
roleAssumerWithWebIdentity: options.roleAssumerWithWebIdentity,
})()];
});
}); };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":";AAAA,OAAO,EAAmC,aAAa,EAAE,MAAM,2CAA2C,CAAC;AAC3G,OAAO,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAC;AAC3D,OAAO,EACL,qBAAqB,GAKtB,MAAM,iCAAiC,CAAC;AAGzC,IAAM,eAAe,GAAG,SAAS,CAAC;AAClC,MAAM,CAAC,IAAM,WAAW,GAAG,aAAa,CAAC;AAsFzC,IAAM,oBAAoB,GAAG,UAAC,GAAQ;IACpC,OAAA,OAAO,CAAC,GAAG,CAAC;QACZ,OAAO,GAAG,KAAK,QAAQ;QACvB,OAAO,GAAG,CAAC,iBAAiB,KAAK,QAAQ;QACzC,OAAO,GAAG,CAAC,qBAAqB,KAAK,QAAQ;QAC7C,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC,OAAO,CAAC,OAAO,GAAG,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAC;AAJlE,CAIkE,CAAC;AAQrE,IAAM,oBAAoB,GAAG,UAAC,GAAQ;IACpC,OAAA,OAAO,CAAC,GAAG,CAAC;QACZ,OAAO,GAAG,KAAK,QAAQ;QACvB,OAAO,GAAG,CAAC,uBAAuB,KAAK,QAAQ;QAC/C,OAAO,GAAG,CAAC,QAAQ,KAAK,QAAQ;QAChC,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC,OAAO,CAAC,OAAO,GAAG,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAC;AAJlE,CAIkE,CAAC;AAMrE,IAAM,6BAA6B,GAAG,UAAC,GAAQ;IAC7C,OAAA,OAAO,CAAC,GAAG,CAAC;QACZ,OAAO,GAAG,KAAK,QAAQ;QACvB,OAAO,GAAG,CAAC,QAAQ,KAAK,QAAQ;QAChC,OAAO,GAAG,CAAC,cAAc,KAAK,QAAQ;QACtC,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC,OAAO,CAAC,OAAO,GAAG,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAC;QAClE,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC,OAAO,CAAC,OAAO,GAAG,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;QAC5D,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC,OAAO,CAAC,OAAO,GAAG,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC;AAN3D,CAM2D,CAAC;AAE9D;;;GAGG;AACH,MAAM,CAAC,IAAM,OAAO,GAAG,UAAC,IAAsB;IAAtB,qBAAA,EAAA,SAAsB;IAAyB,OAAA;;;;wBACpD,qBAAM,eAAe,CAAC,IAAI,CAAC,EAAA;;oBAAtC,QAAQ,GAAG,SAA2B;oBAC5C,sBAAO,kBAAkB,CAAC,oBAAoB,CAAC,IAAI,CAAC,EAAE,QAAQ,EAAE,IAAI,CAAC,EAAC;;;SACvE;AAHsE,CAGtE,CAAC;AAEF;;;;;GAKG;AACH,MAAM,CAAC,IAAM,eAAe,GAAG,UAAO,IAAuB;;;;;gBACnD,KAA+C,IAAI,aAAT,EAA1C,YAAY,mBAAG,qBAAqB,CAAC,IAAI,CAAC,KAAA,CAAU;gBAExC,qBAAM,YAAY,EAAA;;gBAAhC,WAAW,GAAG,SAAkB;gBACtC,4CACK,WAAW,CAAC,UAAU,GACtB,WAAW,CAAC,eAAe,GAC9B;;;KACH,CAAC;AAEF;;GAEG;AACH,MAAM,CAAC,IAAM,oBAAoB,GAAG,UAAC,IAA0B;IAC7D,OAAA,IAAI,CAAC,OAAO,IAAI,OAAO,CAAC,GAAG,CAAC,WAAW,CAAC,IAAI,eAAe;AAA3D,CAA2D,CAAC;AAE9D,IAAM,kBAAkB,GAAG,UACzB,WAAmB,EACnB,QAAuB,EACvB,OAAoB,EACpB,eAAqD;IAArD,gCAAA,EAAA,oBAAqD;;;;;;;oBAE/C,IAAI,GAAG,QAAQ,CAAC,WAAW,CAAC,CAAC;oBAEnC,yEAAyE;oBACzE,qEAAqE;oBACrE,0EAA0E;oBAC1E,IAAI,MAAM,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,MAAM,GAAG,CAAC,IAAI,oBAAoB,CAAC,IAAI,CAAC,EAAE;wBACzE,sBAAO,wBAAwB,CAAC,IAAI,CAAC,EAAC;qBACvC;yBAIG,6BAA6B,CAAC,IAAI,CAAC,EAAnC,wBAAmC;oBAEtB,UAAU,GAKrB,IAAI,YALiB,EACvB,UAAU,GAIR,IAAI,WAJI,EACA,OAAO,GAGf,IAAI,SAHW,EACjB,KAEE,IAAI,kBAFyD,EAA5C,eAAe,mBAAG,aAAa,GAAG,IAAI,CAAC,GAAG,EAAE,KAAA,EAC/D,cAAc,GACZ,IAAI,eADQ,CACP;oBAET,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE;wBACxB,MAAM,IAAI,aAAa,CACrB,aAAW,WAAW,2CAAwC,GAAG,yCAAyC,EAC1G,KAAK,CACN,CAAC;qBACH;oBAED,IAAI,cAAc,IAAI,eAAe,EAAE;wBACrC,MAAM,IAAI,aAAa,CACrB,gEAAgE;6BAC9D,MAAI,oBAAoB,CAAC,OAAO,CAAC,yBAAsB,CAAA;4BACvD,MAAM,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,EACzC,KAAK,CACN,CAAC;qBACH;oBAEK,WAAW,GAAG,kBAAkB,CAAC,cAAc,EAAE,QAAQ,EAAE,OAAO,wBACnE,eAAe,gBACjB,cAAc,IAAG,IAAI,OACtB,CAAC;oBACG,MAAM,GAAqB,EAAE,OAAO,SAAA,EAAE,eAAe,iBAAA,EAAE,UAAU,YAAA,EAAE,CAAC;yBACtE,UAAU,EAAV,wBAAU;oBACZ,IAAI,CAAC,OAAO,CAAC,eAAe,EAAE;wBAC5B,MAAM,IAAI,aAAa,CACrB,aAAW,WAAW,2CAAwC,GAAG,yCAAyC,EAC1G,KAAK,CACN,CAAC;qBACH;oBACD,MAAM,CAAC,YAAY,GAAG,UAAU,CAAC;oBACjC,KAAA,MAAM,CAAA;oBAAa,qBAAM,OAAO,CAAC,eAAe,CAAC,UAAU,CAAC,EAAA;;oBAA5D,GAAO,SAAS,GAAG,SAAyC,CAAC;;;oBAGxD,KAAA,CAAA,KAAA,OAAO,CAAA,CAAC,WAAW,CAAA;oBAAC,qBAAM,WAAW,EAAA;wBAA5C,sBAAO,cAAoB,SAAiB,EAAE,MAAM,EAAC,EAAC;;oBAGxD,oEAAoE;oBACpE,yCAAyC;oBACzC,IAAI,oBAAoB,CAAC,IAAI,CAAC,EAAE;wBAC9B,sBAAO,wBAAwB,CAAC,IAAI,CAAC,EAAC;qBACvC;oBAED,oEAAoE;oBACpE,oEAAoE;oBACpE,IAAI,oBAAoB,CAAC,IAAI,CAAC,EAAE;wBAC9B,sBAAO,6BAA6B,CAAC,IAAI,EAAE,OAAO,CAAC,EAAC;qBACrD;oBAED,yEAAyE;oBACzE,4EAA4E;oBAC5E,wEAAwE;oBACxE,0EAA0E;oBAC1E,yBAAyB;oBACzB,MAAM,IAAI,aAAa,CAAC,aAAW,WAAW,4CAAyC,GAAG,oBAAoB,CAAC,CAAC;;;;CACjH,CAAC;AAEF,IAAM,wBAAwB,GAAG,UAAC,OAA2B;IAC3D,OAAA,OAAO,CAAC,OAAO,CAAC;QACd,WAAW,EAAE,OAAO,CAAC,iBAAiB;QACtC,eAAe,EAAE,OAAO,CAAC,qBAAqB;QAC9C,YAAY,EAAE,OAAO,CAAC,iBAAiB;KACxC,CAAC;AAJF,CAIE,CAAC;AAEL,IAAM,6BAA6B,GAAG,UAAO,OAA2B,EAAE,OAAoB;;QAC5F,sBAAA,aAAa,CAAC;gBACZ,oBAAoB,EAAE,OAAO,CAAC,uBAAuB;gBACrD,OAAO,EAAE,OAAO,CAAC,QAAQ;gBACzB,eAAe,EAAE,OAAO,CAAC,iBAAiB;gBAC1C,0BAA0B,EAAE,OAAO,CAAC,0BAA0B;aAC/D,CAAC,EAAE,EAAA;;KAAA,CAAC","sourcesContent":["import { AssumeRoleWithWebIdentityParams, fromTokenFile } from \"@aws-sdk/credential-provider-web-identity\";\nimport { ProviderError } from \"@aws-sdk/property-provider\";\nimport {\n  loadSharedConfigFiles,\n  ParsedIniData,\n  Profile,\n  SharedConfigFiles,\n  SharedConfigInit,\n} from \"@aws-sdk/shared-ini-file-loader\";\nimport { CredentialProvider, Credentials } from \"@aws-sdk/types\";\n\nconst DEFAULT_PROFILE = \"default\";\nexport const ENV_PROFILE = \"AWS_PROFILE\";\n\n/**\n * @see http://docs.aws.amazon.com/AWSJavaScriptSDK/latest/AWS/STS.html#assumeRole-property\n * TODO update the above to link to V3 docs\n */\nexport interface AssumeRoleParams {\n  /**\n   * The identifier of the role to be assumed.\n   */\n  RoleArn: string;\n\n  /**\n   * A name for the assumed role session.\n   */\n  RoleSessionName: string;\n\n  /**\n   * A unique identifier that is used by third parties when assuming roles in\n   * their customers' accounts.\n   */\n  ExternalId?: string;\n\n  /**\n   * The identification number of the MFA device that is associated with the\n   * user who is making the `AssumeRole` call.\n   */\n  SerialNumber?: string;\n\n  /**\n   * The value provided by the MFA device.\n   */\n  TokenCode?: string;\n}\n\nexport interface SourceProfileInit extends SharedConfigInit {\n  /**\n   * The configuration profile to use.\n   */\n  profile?: string;\n\n  /**\n   * A promise that will be resolved with loaded and parsed credentials files.\n   * Used to avoid loading shared config files multiple times.\n   *\n   * @internal\n   */\n  loadedConfig?: Promise<SharedConfigFiles>;\n}\n\nexport interface FromIniInit extends SourceProfileInit {\n  /**\n   * A function that returns a promise fulfilled with an MFA token code for\n   * the provided MFA Serial code. If a profile requires an MFA code and\n   * `mfaCodeProvider` is not a valid function, the credential provider\n   * promise will be rejected.\n   *\n   * @param mfaSerial The serial code of the MFA device specified.\n   */\n  mfaCodeProvider?: (mfaSerial: string) => Promise<string>;\n\n  /**\n   * A function that assumes a role and returns a promise fulfilled with\n   * credentials for the assumed role.\n   *\n   * @param sourceCreds The credentials with which to assume a role.\n   * @param params\n   */\n  roleAssumer?: (sourceCreds: Credentials, params: AssumeRoleParams) => Promise<Credentials>;\n\n  /**\n   * A function that assumes a role with web identity and returns a promise fulfilled with\n   * credentials for the assumed role.\n   *\n   * @param sourceCreds The credentials with which to assume a role.\n   * @param params\n   */\n  roleAssumerWithWebIdentity?: (params: AssumeRoleWithWebIdentityParams) => Promise<Credentials>;\n}\n\ninterface StaticCredsProfile extends Profile {\n  aws_access_key_id: string;\n  aws_secret_access_key: string;\n  aws_session_token?: string;\n}\n\nconst isStaticCredsProfile = (arg: any): arg is StaticCredsProfile =>\n  Boolean(arg) &&\n  typeof arg === \"object\" &&\n  typeof arg.aws_access_key_id === \"string\" &&\n  typeof arg.aws_secret_access_key === \"string\" &&\n  [\"undefined\", \"string\"].indexOf(typeof arg.aws_session_token) > -1;\n\ninterface WebIdentityProfile extends Profile {\n  web_identity_token_file: string;\n  role_arn: string;\n  role_session_name?: string;\n}\n\nconst isWebIdentityProfile = (arg: any): arg is WebIdentityProfile =>\n  Boolean(arg) &&\n  typeof arg === \"object\" &&\n  typeof arg.web_identity_token_file === \"string\" &&\n  typeof arg.role_arn === \"string\" &&\n  [\"undefined\", \"string\"].indexOf(typeof arg.role_session_name) > -1;\ninterface AssumeRoleProfile extends Profile {\n  role_arn: string;\n  source_profile: string;\n}\n\nconst isAssumeRoleWithSourceProfile = (arg: any): arg is AssumeRoleProfile =>\n  Boolean(arg) &&\n  typeof arg === \"object\" &&\n  typeof arg.role_arn === \"string\" &&\n  typeof arg.source_profile === \"string\" &&\n  [\"undefined\", \"string\"].indexOf(typeof arg.role_session_name) > -1 &&\n  [\"undefined\", \"string\"].indexOf(typeof arg.external_id) > -1 &&\n  [\"undefined\", \"string\"].indexOf(typeof arg.mfa_serial) > -1;\n\n/**\n * Creates a credential provider that will read from ini files and supports\n * role assumption and multi-factor authentication.\n */\nexport const fromIni = (init: FromIniInit = {}): CredentialProvider => async () => {\n  const profiles = await parseKnownFiles(init);\n  return resolveProfileData(getMasterProfileName(init), profiles, init);\n};\n\n/**\n * Load profiles from credentials and config INI files and normalize them into a\n * single profile list.\n *\n * @internal\n */\nexport const parseKnownFiles = async (init: SourceProfileInit): Promise<ParsedIniData> => {\n  const { loadedConfig = loadSharedConfigFiles(init) } = init;\n\n  const parsedFiles = await loadedConfig;\n  return {\n    ...parsedFiles.configFile,\n    ...parsedFiles.credentialsFile,\n  };\n};\n\n/**\n * @internal\n */\nexport const getMasterProfileName = (init: { profile?: string }): string =>\n  init.profile || process.env[ENV_PROFILE] || DEFAULT_PROFILE;\n\nconst resolveProfileData = async (\n  profileName: string,\n  profiles: ParsedIniData,\n  options: FromIniInit,\n  visitedProfiles: { [profileName: string]: true } = {}\n): Promise<Credentials> => {\n  const data = profiles[profileName];\n\n  // If this is not the first profile visited, static credentials should be\n  // preferred over role assumption metadata. This special treatment of\n  // second and subsequent hops is to ensure compatibility with the AWS CLI.\n  if (Object.keys(visitedProfiles).length > 0 && isStaticCredsProfile(data)) {\n    return resolveStaticCredentials(data);\n  }\n\n  // If this is the first profile visited, role assumption keys should be\n  // given precedence over static credentials.\n  if (isAssumeRoleWithSourceProfile(data)) {\n    const {\n      external_id: ExternalId,\n      mfa_serial,\n      role_arn: RoleArn,\n      role_session_name: RoleSessionName = \"aws-sdk-js-\" + Date.now(),\n      source_profile,\n    } = data;\n\n    if (!options.roleAssumer) {\n      throw new ProviderError(\n        `Profile ${profileName} requires a role to be assumed, but no` + ` role assumption callback was provided.`,\n        false\n      );\n    }\n\n    if (source_profile in visitedProfiles) {\n      throw new ProviderError(\n        `Detected a cycle attempting to resolve credentials for profile` +\n          ` ${getMasterProfileName(options)}. Profiles visited: ` +\n          Object.keys(visitedProfiles).join(\", \"),\n        false\n      );\n    }\n\n    const sourceCreds = resolveProfileData(source_profile, profiles, options, {\n      ...visitedProfiles,\n      [source_profile]: true,\n    });\n    const params: AssumeRoleParams = { RoleArn, RoleSessionName, ExternalId };\n    if (mfa_serial) {\n      if (!options.mfaCodeProvider) {\n        throw new ProviderError(\n          `Profile ${profileName} requires multi-factor authentication,` + ` but no MFA code callback was provided.`,\n          false\n        );\n      }\n      params.SerialNumber = mfa_serial;\n      params.TokenCode = await options.mfaCodeProvider(mfa_serial);\n    }\n\n    return options.roleAssumer(await sourceCreds, params);\n  }\n\n  // If no role assumption metadata is present, attempt to load static\n  // credentials from the selected profile.\n  if (isStaticCredsProfile(data)) {\n    return resolveStaticCredentials(data);\n  }\n\n  // If no static credentials are present, attempt to assume role with\n  // web identity if web_identity_token_file and role_arn is available\n  if (isWebIdentityProfile(data)) {\n    return resolveWebIdentityCredentials(data, options);\n  }\n\n  // If the profile cannot be parsed or contains neither static credentials\n  // nor role assumption metadata, throw an error. This should be considered a\n  // terminal resolution error if a profile has been specified by the user\n  // (whether via a parameter, an environment variable, or another profile's\n  // `source_profile` key).\n  throw new ProviderError(`Profile ${profileName} could not be found or parsed in shared` + ` credentials file.`);\n};\n\nconst resolveStaticCredentials = (profile: StaticCredsProfile): Promise<Credentials> =>\n  Promise.resolve({\n    accessKeyId: profile.aws_access_key_id,\n    secretAccessKey: profile.aws_secret_access_key,\n    sessionToken: profile.aws_session_token,\n  });\n\nconst resolveWebIdentityCredentials = async (profile: WebIdentityProfile, options: FromIniInit): Promise<Credentials> =>\n  fromTokenFile({\n    webIdentityTokenFile: profile.web_identity_token_file,\n    roleArn: profile.role_arn,\n    roleSessionName: profile.role_session_name,\n    roleAssumerWithWebIdentity: options.roleAssumerWithWebIdentity,\n  })();\n"]}

14

package.json
{
"name": "@aws-sdk/credential-provider-ini",
"version": "3.8.0",
"version": "3.10.0",
"description": "AWS credential provider that sources credentials from ~/.aws/credentials and ~/.aws/config",

@@ -9,7 +9,6 @@ "main": "./dist/cjs/index.js",

"prepublishOnly": "yarn build:cjs && yarn build:es",
"pretest": "yarn build:cjs",
"build:cjs": "tsc -p tsconfig.cjs.json",
"build:es": "tsc -p tsconfig.es.json",
"build": "yarn build:es && yarn build:cjs",
"postbuild": "downlevel-dts types types/ts3.4",
"postbuild": "downlevel-dts dist/types dist/types/ts3.4",
"test": "jest"

@@ -27,5 +26,6 @@ },

"dependencies": {
"@aws-sdk/property-provider": "3.8.0",
"@aws-sdk/shared-ini-file-loader": "3.8.0",
"@aws-sdk/types": "3.6.1",
"@aws-sdk/credential-provider-web-identity": "3.10.0",
"@aws-sdk/property-provider": "3.10.0",
"@aws-sdk/shared-ini-file-loader": "3.10.0",
"@aws-sdk/types": "3.10.0",
"tslib": "^1.8.0"

@@ -39,3 +39,3 @@ },

},
"types": "./types/index.d.ts",
"types": "./dist/types/index.d.ts",
"engines": {

@@ -42,0 +42,0 @@ "node": ">= 10.0.0"

@@ -8,3 +8,3 @@ # @aws-sdk/credential-provider-ini

This module provides a function, `fromSharedConfigFiles` that will create
This module provides a function, `fromIni` that will create
`CredentialProvider` functions that read from a shared credentials file at

@@ -14,3 +14,4 @@ `~/.aws/credentials` and a shared configuration file at `~/.aws/config`. Both

profiles. Sections in the credentials file are treated as profile names, whereas
profile sections in the config file must have the format of`[profile profile-name]`, except for the default profile. Please see the [sample
profile sections in the config file must have the format of`[profile profile-name]`,
except for the default profile. Please see the [sample
files](#sample-files) below for examples of well-formed configuration and

@@ -26,4 +27,3 @@ credentials files.

You may customize how credentials are resolved by providing an options hash to
the `fromSharedConfigFiles` factory function. The following options are
supported:
the `fromIni` factory function. The following options are supported:

@@ -44,3 +44,7 @@ - `profile` - The configuration profile to use. If not specified, the provider

- `roleAssumer` - A function that assumes a role and returns a promise
fulfilled with credentials for the assumed role.
fulfilled with credentials for the assumed role. You may call `sts:assumeRole`
API within this function.
- `roleAssumerWithWebIdentity` - A function that assumes a role with web identity
and returns a promise fulfilled with credentials for the assumed role. You may call
`sts:assumeRoleWithWebIdentity` API within this function.

@@ -84,1 +88,21 @@ ## Sample files

```
### source profile with static credentials
```ini
[second]
aws_access_key_id=foo
aws_secret_access_key=bar
[first]
source_profile=first
role_arn=arn:aws:iam::123456789012:role/example-role-arn
```
### profile with web_identity_token_file
```ini
[default]
web_identity_token_file=/temp/token
role_arn=arn:aws:iam::123456789012:role/example-role-arn
```

@@ -0,1 +1,2 @@

import { AssumeRoleWithWebIdentityParams, fromTokenFile } from "@aws-sdk/credential-provider-web-identity";
import { ProviderError } from "@aws-sdk/property-provider";

@@ -64,3 +65,3 @@ import {

/**
* A function that returna a promise fulfilled with an MFA token code for
* A function that returns a promise fulfilled with an MFA token code for
* the provided MFA Serial code. If a profile requires an MFA code and

@@ -82,2 +83,11 @@ * `mfaCodeProvider` is not a valid function, the credential provider

roleAssumer?: (sourceCreds: Credentials, params: AssumeRoleParams) => Promise<Credentials>;
/**
* A function that assumes a role with web identity and returns a promise fulfilled with
* credentials for the assumed role.
*
* @param sourceCreds The credentials with which to assume a role.
* @param params
*/
roleAssumerWithWebIdentity?: (params: AssumeRoleWithWebIdentityParams) => Promise<Credentials>;
}

@@ -98,2 +108,14 @@

interface WebIdentityProfile extends Profile {
web_identity_token_file: string;
role_arn: string;
role_session_name?: string;
}
const isWebIdentityProfile = (arg: any): arg is WebIdentityProfile =>
Boolean(arg) &&
typeof arg === "object" &&
typeof arg.web_identity_token_file === "string" &&
typeof arg.role_arn === "string" &&
["undefined", "string"].indexOf(typeof arg.role_session_name) > -1;
interface AssumeRoleProfile extends Profile {

@@ -104,3 +126,3 @@ role_arn: string;

const isAssumeRoleProfile = (arg: any): arg is AssumeRoleProfile =>
const isAssumeRoleWithSourceProfile = (arg: any): arg is AssumeRoleProfile =>
Boolean(arg) &&

@@ -162,3 +184,3 @@ typeof arg === "object" &&

// given precedence over static credentials.
if (isAssumeRoleProfile(data)) {
if (isAssumeRoleWithSourceProfile(data)) {
const {

@@ -213,2 +235,8 @@ external_id: ExternalId,

// If no static credentials are present, attempt to assume role with
// web identity if web_identity_token_file and role_arn is available
if (isWebIdentityProfile(data)) {
return resolveWebIdentityCredentials(data, options);
}
// If the profile cannot be parsed or contains neither static credentials

@@ -228,1 +256,9 @@ // nor role assumption metadata, throw an error. This should be considered a

});
const resolveWebIdentityCredentials = async (profile: WebIdentityProfile, options: FromIniInit): Promise<Credentials> =>
fromTokenFile({
webIdentityTokenFile: profile.web_identity_token_file,
roleArn: profile.role_arn,
roleSessionName: profile.role_session_name,
roleAssumerWithWebIdentity: options.roleAssumerWithWebIdentity,
})();
{
"compilerOptions": {
"declarationDir": "./types",
"declarationDir": "./dist/types",
"rootDir": "./src",

@@ -5,0 +5,0 @@ "outDir": "./dist/cjs",

{
"compilerOptions": {
"lib": ["es5", "es2015.promise", "es2015.collection"],
"declarationDir": "./types",
"declarationDir": "./dist/types",
"rootDir": "./src",

@@ -6,0 +6,0 @@ "outDir": "./dist/es",

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