Socket
Socket
Sign inDemoInstall

@aws-sdk/credential-provider-ini

Package Overview
Dependencies
Maintainers
5
Versions
342
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.4.1 to 3.5.1-rc.0

12

CHANGELOG.md

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

## [3.5.1-rc.0](https://github.com/aws/aws-sdk-js-v3/compare/v3.5.0...v3.5.1-rc.0) (2021-02-19)
### Bug Fixes
* **credential-provider-ini:** refactor provider options interfaces ([#2048](https://github.com/aws/aws-sdk-js-v3/issues/2048)) ([34cecf1](https://github.com/aws/aws-sdk-js-v3/commit/34cecf1e3b4048dfdf88422e369615843d798c81))
* **credential-provider-node:** read config and credentials files only once ([#2045](https://github.com/aws/aws-sdk-js-v3/issues/2045)) ([7db14b1](https://github.com/aws/aws-sdk-js-v3/commit/7db14b1646b299da403fc152765fbc40cd2970b0))
## [3.4.1](https://github.com/aws/aws-sdk-js-v3/compare/v3.4.0...v3.4.1) (2021-01-29)

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

90

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

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

exports.ENV_PROFILE = "AWS_PROFILE";
function isStaticCredsProfile(arg) {
return (Boolean(arg) &&
typeof arg === "object" &&
typeof arg.aws_access_key_id === "string" &&
typeof arg.aws_secret_access_key === "string" &&
["undefined", "string"].indexOf(typeof arg.aws_session_token) > -1);
}
function isAssumeRoleProfile(arg) {
return (Boolean(arg) &&
typeof arg === "object" &&
typeof arg.role_arn === "string" &&
typeof arg.source_profile === "string" &&
["undefined", "string"].indexOf(typeof arg.role_session_name) > -1 &&
["undefined", "string"].indexOf(typeof arg.external_id) > -1 &&
["undefined", "string"].indexOf(typeof arg.mfa_serial) > -1);
}
const isStaticCredsProfile = (arg) => Boolean(arg) &&
typeof arg === "object" &&
typeof arg.aws_access_key_id === "string" &&
typeof arg.aws_secret_access_key === "string" &&
["undefined", "string"].indexOf(typeof arg.aws_session_token) > -1;
const isAssumeRoleProfile = (arg) => Boolean(arg) &&
typeof arg === "object" &&
typeof arg.role_arn === "string" &&
typeof arg.source_profile === "string" &&
["undefined", "string"].indexOf(typeof arg.role_session_name) > -1 &&
["undefined", "string"].indexOf(typeof arg.external_id) > -1 &&
["undefined", "string"].indexOf(typeof arg.mfa_serial) > -1;
/**

@@ -29,11 +25,28 @@ * Creates a credential provider that will read from ini files and supports

*/
function fromIni(init = {}) {
return () => parseKnownFiles(init).then((profiles) => resolveProfileData(getMasterProfileName(init), profiles, init));
}
const fromIni = (init = {}) => async () => {
const profiles = await exports.parseKnownFiles(init);
return resolveProfileData(exports.getMasterProfileName(init), profiles, init);
};
exports.fromIni = fromIni;
function getMasterProfileName(init) {
return init.profile || process.env[exports.ENV_PROFILE] || DEFAULT_PROFILE;
}
/**
* Load profiles from credentials and config INI files and normalize them into a
* single profile list.
*
* @internal
*/
const parseKnownFiles = async (init) => {
const { loadedConfig = shared_ini_file_loader_1.loadSharedConfigFiles(init) } = init;
const parsedFiles = await loadedConfig;
return {
...parsedFiles.configFile,
...parsedFiles.credentialsFile,
};
};
exports.parseKnownFiles = parseKnownFiles;
/**
* @internal
*/
const getMasterProfileName = (init) => init.profile || process.env[exports.ENV_PROFILE] || DEFAULT_PROFILE;
exports.getMasterProfileName = getMasterProfileName;
async function resolveProfileData(profileName, profiles, options, visitedProfiles = {}) {
const resolveProfileData = async (profileName, profiles, options, visitedProfiles = {}) => {
const data = profiles[profileName];

@@ -55,3 +68,3 @@ // If this is not the first profile visited, static credentials should be

throw new property_provider_1.ProviderError(`Detected a cycle attempting to resolve credentials for profile` +
` ${getMasterProfileName(options)}. Profiles visited: ` +
` ${exports.getMasterProfileName(options)}. Profiles visited: ` +
Object.keys(visitedProfiles).join(", "), false);

@@ -84,21 +97,8 @@ }

throw new property_provider_1.ProviderError(`Profile ${profileName} could not be found or parsed in shared` + ` credentials file.`);
}
function parseKnownFiles(init) {
const { loadedConfig = shared_ini_file_loader_1.loadSharedConfigFiles(init) } = init;
return loadedConfig.then((parsedFiles) => {
const { configFile, credentialsFile } = parsedFiles;
return {
...configFile,
...credentialsFile,
};
});
}
exports.parseKnownFiles = parseKnownFiles;
function resolveStaticCredentials(profile) {
return Promise.resolve({
accessKeyId: profile.aws_access_key_id,
secretAccessKey: profile.aws_secret_access_key,
sessionToken: profile.aws_session_token,
});
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":";;;AAAA,kEAA2D;AAC3D,4EAMyC;AAGzC,MAAM,eAAe,GAAG,SAAS,CAAC;AACrB,QAAA,WAAW,GAAG,aAAa,CAAC;AAyEzC,SAAS,oBAAoB,CAAC,GAAQ;IACpC,OAAO,CACL,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,CACnE,CAAC;AACJ,CAAC;AAOD,SAAS,mBAAmB,CAAC,GAAQ;IACnC,OAAO,CACL,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,CAC5D,CAAC;AACJ,CAAC;AAED;;;GAGG;AACH,SAAgB,OAAO,CAAC,OAAoB,EAAE;IAC5C,OAAO,GAAG,EAAE,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,kBAAkB,CAAC,oBAAoB,CAAC,IAAI,CAAC,EAAE,QAAQ,EAAE,IAAI,CAAC,CAAC,CAAC;AACxH,CAAC;AAFD,0BAEC;AAED,SAAgB,oBAAoB,CAAC,IAAiB;IACpD,OAAO,IAAI,CAAC,OAAO,IAAI,OAAO,CAAC,GAAG,CAAC,mBAAW,CAAC,IAAI,eAAe,CAAC;AACrE,CAAC;AAFD,oDAEC;AAED,KAAK,UAAU,kBAAkB,CAC/B,WAAmB,EACnB,QAAuB,EACvB,OAAoB,EACpB,kBAAmD,EAAE;IAErD,MAAM,IAAI,GAAG,QAAQ,CAAC,WAAW,CAAC,CAAC;IAEnC,yEAAyE;IACzE,qEAAqE;IACrE,0EAA0E;IAC1E,IAAI,MAAM,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,MAAM,GAAG,CAAC,IAAI,oBAAoB,CAAC,IAAI,CAAC,EAAE;QACzE,OAAO,wBAAwB,CAAC,IAAI,CAAC,CAAC;KACvC;IAED,uEAAuE;IACvE,4CAA4C;IAC5C,IAAI,mBAAmB,CAAC,IAAI,CAAC,EAAE;QAC7B,MAAM,EACJ,WAAW,EAAE,UAAU,EACvB,UAAU,EACV,QAAQ,EAAE,OAAO,EACjB,iBAAiB,EAAE,eAAe,GAAG,aAAa,GAAG,IAAI,CAAC,GAAG,EAAE,EAC/D,cAAc,GACf,GAAG,IAAI,CAAC;QAET,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE;YACxB,MAAM,IAAI,iCAAa,CACrB,WAAW,WAAW,wCAAwC,GAAG,yCAAyC,EAC1G,KAAK,CACN,CAAC;SACH;QAED,IAAI,cAAc,IAAI,eAAe,EAAE;YACrC,MAAM,IAAI,iCAAa,CACrB,gEAAgE;gBAC9D,IAAI,oBAAoB,CAAC,OAAO,CAAC,sBAAsB;gBACvD,MAAM,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,EACzC,KAAK,CACN,CAAC;SACH;QAED,MAAM,WAAW,GAAG,kBAAkB,CAAC,cAAc,EAAE,QAAQ,EAAE,OAAO,EAAE;YACxE,GAAG,eAAe;YAClB,CAAC,cAAc,CAAC,EAAE,IAAI;SACvB,CAAC,CAAC;QACH,MAAM,MAAM,GAAqB,EAAE,OAAO,EAAE,eAAe,EAAE,UAAU,EAAE,CAAC;QAC1E,IAAI,UAAU,EAAE;YACd,IAAI,CAAC,OAAO,CAAC,eAAe,EAAE;gBAC5B,MAAM,IAAI,iCAAa,CACrB,WAAW,WAAW,wCAAwC,GAAG,yCAAyC,EAC1G,KAAK,CACN,CAAC;aACH;YACD,MAAM,CAAC,YAAY,GAAG,UAAU,CAAC;YACjC,MAAM,CAAC,SAAS,GAAG,MAAM,OAAO,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC;SAC9D;QAED,OAAO,OAAO,CAAC,WAAW,CAAC,MAAM,WAAW,EAAE,MAAM,CAAC,CAAC;KACvD;IAED,oEAAoE;IACpE,yCAAyC;IACzC,IAAI,oBAAoB,CAAC,IAAI,CAAC,EAAE;QAC9B,OAAO,wBAAwB,CAAC,IAAI,CAAC,CAAC;KACvC;IAED,yEAAyE;IACzE,4EAA4E;IAC5E,wEAAwE;IACxE,0EAA0E;IAC1E,yBAAyB;IACzB,MAAM,IAAI,iCAAa,CAAC,WAAW,WAAW,yCAAyC,GAAG,oBAAoB,CAAC,CAAC;AAClH,CAAC;AAED,SAAgB,eAAe,CAAC,IAAiB;IAC/C,MAAM,EAAE,YAAY,GAAG,8CAAqB,CAAC,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC;IAE5D,OAAO,YAAY,CAAC,IAAI,CAAC,CAAC,WAAW,EAAE,EAAE;QACvC,MAAM,EAAE,UAAU,EAAE,eAAe,EAAE,GAAG,WAAW,CAAC;QACpD,OAAO;YACL,GAAG,UAAU;YACb,GAAG,eAAe;SACnB,CAAC;IACJ,CAAC,CAAC,CAAC;AACL,CAAC;AAVD,0CAUC;AAED,SAAS,wBAAwB,CAAC,OAA2B;IAC3D,OAAO,OAAO,CAAC,OAAO,CAAC;QACrB,WAAW,EAAE,OAAO,CAAC,iBAAiB;QACtC,eAAe,EAAE,OAAO,CAAC,qBAAqB;QAC9C,YAAY,EAAE,OAAO,CAAC,iBAAiB;KACxC,CAAC,CAAC;AACL,CAAC","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 FromIniInit 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  loadedConfig?: Promise<SharedConfigFiles>;\n\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\nfunction isStaticCredsProfile(arg: any): arg is StaticCredsProfile {\n  return (\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  );\n}\n\ninterface AssumeRoleProfile extends Profile {\n  role_arn: string;\n  source_profile: string;\n}\n\nfunction isAssumeRoleProfile(arg: any): arg is AssumeRoleProfile {\n  return (\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\n/**\n * Creates a credential provider that will read from ini files and supports\n * role assumption and multi-factor authentication.\n */\nexport function fromIni(init: FromIniInit = {}): CredentialProvider {\n  return () => parseKnownFiles(init).then((profiles) => resolveProfileData(getMasterProfileName(init), profiles, init));\n}\n\nexport function getMasterProfileName(init: FromIniInit): string {\n  return init.profile || process.env[ENV_PROFILE] || DEFAULT_PROFILE;\n}\n\nasync function resolveProfileData(\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\nexport function parseKnownFiles(init: FromIniInit): Promise<ParsedIniData> {\n  const { loadedConfig = loadSharedConfigFiles(init) } = init;\n\n  return loadedConfig.then((parsedFiles) => {\n    const { configFile, credentialsFile } = parsedFiles;\n    return {\n      ...configFile,\n      ...credentialsFile,\n    };\n  });\n}\n\nfunction resolveStaticCredentials(profile: StaticCredsProfile): Promise<Credentials> {\n  return Promise.resolve({\n    accessKeyId: profile.aws_access_key_id,\n    secretAccessKey: profile.aws_secret_access_key,\n    sessionToken: profile.aws_session_token,\n  });\n}\n"]}
};
const resolveStaticCredentials = (profile) => Promise.resolve({
accessKeyId: profile.aws_access_key_id,
secretAccessKey: profile.aws_secret_access_key,
sessionToken: profile.aws_session_token,
});
//# 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"]}

@@ -6,11 +6,11 @@ import { __assign, __awaiter, __generator } from "tslib";

export var ENV_PROFILE = "AWS_PROFILE";
function isStaticCredsProfile(arg) {
return (Boolean(arg) &&
var isStaticCredsProfile = function (arg) {
return Boolean(arg) &&
typeof arg === "object" &&
typeof arg.aws_access_key_id === "string" &&
typeof arg.aws_secret_access_key === "string" &&
["undefined", "string"].indexOf(typeof arg.aws_session_token) > -1);
}
function isAssumeRoleProfile(arg) {
return (Boolean(arg) &&
["undefined", "string"].indexOf(typeof arg.aws_session_token) > -1;
};
var isAssumeRoleProfile = function (arg) {
return Boolean(arg) &&
typeof arg === "object" &&

@@ -21,4 +21,4 @@ typeof arg.role_arn === "string" &&

["undefined", "string"].indexOf(typeof arg.external_id) > -1 &&
["undefined", "string"].indexOf(typeof arg.mfa_serial) > -1);
}
["undefined", "string"].indexOf(typeof arg.mfa_serial) > -1;
};
/**

@@ -28,12 +28,44 @@ * Creates a credential provider that will read from ini files and supports

*/
export function fromIni(init) {
export var fromIni = function (init) {
if (init === void 0) { init = {}; }
return function () { return parseKnownFiles(init).then(function (profiles) { return resolveProfileData(getMasterProfileName(init), profiles, init); }); };
}
export function getMasterProfileName(init) {
return function () { return __awaiter(void 0, void 0, void 0, function () {
var profiles;
return __generator(this, function (_a) {
switch (_a.label) {
case 0: return [4 /*yield*/, parseKnownFiles(init)];
case 1:
profiles = _a.sent();
return [2 /*return*/, resolveProfileData(getMasterProfileName(init), profiles, init)];
}
});
}); };
};
/**
* Load profiles from credentials and config INI files and normalize them into a
* single profile list.
*
* @internal
*/
export var parseKnownFiles = function (init) { return __awaiter(void 0, void 0, void 0, function () {
var _a, loadedConfig, parsedFiles;
return __generator(this, function (_b) {
switch (_b.label) {
case 0:
_a = init.loadedConfig, loadedConfig = _a === void 0 ? loadSharedConfigFiles(init) : _a;
return [4 /*yield*/, loadedConfig];
case 1:
parsedFiles = _b.sent();
return [2 /*return*/, __assign(__assign({}, parsedFiles.configFile), parsedFiles.credentialsFile)];
}
});
}); };
/**
* @internal
*/
export var getMasterProfileName = function (init) {
return init.profile || process.env[ENV_PROFILE] || DEFAULT_PROFILE;
}
function resolveProfileData(profileName, profiles, options, visitedProfiles) {
};
var resolveProfileData = function (profileName, profiles, options, visitedProfiles) {
if (visitedProfiles === void 0) { visitedProfiles = {}; }
return __awaiter(this, void 0, void 0, function () {
return __awaiter(void 0, void 0, void 0, function () {
var data, ExternalId, mfa_serial, RoleArn, _a, RoleSessionName, source_profile, sourceCreds, params, _b, _c, _d;

@@ -92,11 +124,4 @@ var _e;

});
}
export function parseKnownFiles(init) {
var _a = init.loadedConfig, loadedConfig = _a === void 0 ? loadSharedConfigFiles(init) : _a;
return loadedConfig.then(function (parsedFiles) {
var configFile = parsedFiles.configFile, credentialsFile = parsedFiles.credentialsFile;
return __assign(__assign({}, configFile), credentialsFile);
});
}
function resolveStaticCredentials(profile) {
};
var resolveStaticCredentials = function (profile) {
return Promise.resolve({

@@ -107,3 +132,3 @@ accessKeyId: profile.aws_access_key_id,

});
}
//# 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 FromIniInit 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  loadedConfig?: Promise<SharedConfigFiles>;\n\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\nfunction isStaticCredsProfile(arg: any): arg is StaticCredsProfile {\n  return (\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  );\n}\n\ninterface AssumeRoleProfile extends Profile {\n  role_arn: string;\n  source_profile: string;\n}\n\nfunction isAssumeRoleProfile(arg: any): arg is AssumeRoleProfile {\n  return (\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\n/**\n * Creates a credential provider that will read from ini files and supports\n * role assumption and multi-factor authentication.\n */\nexport function fromIni(init: FromIniInit = {}): CredentialProvider {\n  return () => parseKnownFiles(init).then((profiles) => resolveProfileData(getMasterProfileName(init), profiles, init));\n}\n\nexport function getMasterProfileName(init: FromIniInit): string {\n  return init.profile || process.env[ENV_PROFILE] || DEFAULT_PROFILE;\n}\n\nasync function resolveProfileData(\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\nexport function parseKnownFiles(init: FromIniInit): Promise<ParsedIniData> {\n  const { loadedConfig = loadSharedConfigFiles(init) } = init;\n\n  return loadedConfig.then((parsedFiles) => {\n    const { configFile, credentialsFile } = parsedFiles;\n    return {\n      ...configFile,\n      ...credentialsFile,\n    };\n  });\n}\n\nfunction resolveStaticCredentials(profile: StaticCredsProfile): Promise<Credentials> {\n  return Promise.resolve({\n    accessKeyId: profile.aws_access_key_id,\n    secretAccessKey: profile.aws_secret_access_key,\n    sessionToken: profile.aws_session_token,\n  });\n}\n"]}
};
//# 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"]}
{
"name": "@aws-sdk/credential-provider-ini",
"version": "3.4.1",
"version": "3.5.1-rc.0",
"description": "AWS credential provider that sources credentials from ~/.aws/credentials and ~/.aws/config",

@@ -5,0 +5,0 @@ "main": "./dist/cjs/index.js",

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

export interface FromIniInit extends SharedConfigInit {
export interface SourceProfileInit extends SharedConfigInit {
/**

@@ -57,5 +57,9 @@ * The configuration profile to use.

* Used to avoid loading shared config files multiple times.
*
* @internal
*/
loadedConfig?: Promise<SharedConfigFiles>;
}
export interface FromIniInit extends SourceProfileInit {
/**

@@ -87,11 +91,8 @@ * A function that returna a promise fulfilled with an MFA token code for

function isStaticCredsProfile(arg: any): arg is StaticCredsProfile {
return (
Boolean(arg) &&
typeof arg === "object" &&
typeof arg.aws_access_key_id === "string" &&
typeof arg.aws_secret_access_key === "string" &&
["undefined", "string"].indexOf(typeof arg.aws_session_token) > -1
);
}
const isStaticCredsProfile = (arg: any): arg is StaticCredsProfile =>
Boolean(arg) &&
typeof arg === "object" &&
typeof arg.aws_access_key_id === "string" &&
typeof arg.aws_secret_access_key === "string" &&
["undefined", "string"].indexOf(typeof arg.aws_session_token) > -1;

@@ -103,13 +104,10 @@ interface AssumeRoleProfile extends Profile {

function isAssumeRoleProfile(arg: any): arg is AssumeRoleProfile {
return (
Boolean(arg) &&
typeof arg === "object" &&
typeof arg.role_arn === "string" &&
typeof arg.source_profile === "string" &&
["undefined", "string"].indexOf(typeof arg.role_session_name) > -1 &&
["undefined", "string"].indexOf(typeof arg.external_id) > -1 &&
["undefined", "string"].indexOf(typeof arg.mfa_serial) > -1
);
}
const isAssumeRoleProfile = (arg: any): arg is AssumeRoleProfile =>
Boolean(arg) &&
typeof arg === "object" &&
typeof arg.role_arn === "string" &&
typeof arg.source_profile === "string" &&
["undefined", "string"].indexOf(typeof arg.role_session_name) > -1 &&
["undefined", "string"].indexOf(typeof arg.external_id) > -1 &&
["undefined", "string"].indexOf(typeof arg.mfa_serial) > -1;

@@ -120,11 +118,30 @@ /**

*/
export function fromIni(init: FromIniInit = {}): CredentialProvider {
return () => parseKnownFiles(init).then((profiles) => resolveProfileData(getMasterProfileName(init), profiles, init));
}
export const fromIni = (init: FromIniInit = {}): CredentialProvider => async () => {
const profiles = await parseKnownFiles(init);
return resolveProfileData(getMasterProfileName(init), profiles, init);
};
export function getMasterProfileName(init: FromIniInit): string {
return init.profile || process.env[ENV_PROFILE] || DEFAULT_PROFILE;
}
/**
* Load profiles from credentials and config INI files and normalize them into a
* single profile list.
*
* @internal
*/
export const parseKnownFiles = async (init: SourceProfileInit): Promise<ParsedIniData> => {
const { loadedConfig = loadSharedConfigFiles(init) } = init;
async function resolveProfileData(
const parsedFiles = await loadedConfig;
return {
...parsedFiles.configFile,
...parsedFiles.credentialsFile,
};
};
/**
* @internal
*/
export const getMasterProfileName = (init: { profile?: string }): string =>
init.profile || process.env[ENV_PROFILE] || DEFAULT_PROFILE;
const resolveProfileData = async (
profileName: string,

@@ -134,3 +151,3 @@ profiles: ParsedIniData,

visitedProfiles: { [profileName: string]: true } = {}
): Promise<Credentials> {
): Promise<Credentials> => {
const data = profiles[profileName];

@@ -203,18 +220,6 @@

throw new ProviderError(`Profile ${profileName} could not be found or parsed in shared` + ` credentials file.`);
}
};
export function parseKnownFiles(init: FromIniInit): Promise<ParsedIniData> {
const { loadedConfig = loadSharedConfigFiles(init) } = init;
return loadedConfig.then((parsedFiles) => {
const { configFile, credentialsFile } = parsedFiles;
return {
...configFile,
...credentialsFile,
};
});
}
function resolveStaticCredentials(profile: StaticCredsProfile): Promise<Credentials> {
return Promise.resolve({
const resolveStaticCredentials = (profile: StaticCredsProfile): Promise<Credentials> =>
Promise.resolve({
accessKeyId: profile.aws_access_key_id,

@@ -224,2 +229,1 @@ secretAccessKey: profile.aws_secret_access_key,

});
}

@@ -32,3 +32,3 @@ import { ParsedIniData, SharedConfigFiles, SharedConfigInit } from "@aws-sdk/shared-ini-file-loader";

}
export interface FromIniInit extends SharedConfigInit {
export interface SourceProfileInit extends SharedConfigInit {
/**

@@ -41,4 +41,8 @@ * The configuration profile to use.

* Used to avoid loading shared config files multiple times.
*
* @internal
*/
loadedConfig?: Promise<SharedConfigFiles>;
}
export interface FromIniInit extends SourceProfileInit {
/**

@@ -66,4 +70,15 @@ * A function that returna a promise fulfilled with an MFA token code for

*/
export declare function fromIni(init?: FromIniInit): CredentialProvider;
export declare function getMasterProfileName(init: FromIniInit): string;
export declare function parseKnownFiles(init: FromIniInit): Promise<ParsedIniData>;
export declare const fromIni: (init?: FromIniInit) => CredentialProvider;
/**
* Load profiles from credentials and config INI files and normalize them into a
* single profile list.
*
* @internal
*/
export declare const parseKnownFiles: (init: SourceProfileInit) => Promise<ParsedIniData>;
/**
* @internal
*/
export declare const getMasterProfileName: (init: {
profile?: string;
}) => string;

@@ -32,3 +32,3 @@ import { ParsedIniData, SharedConfigFiles, SharedConfigInit } from "@aws-sdk/shared-ini-file-loader";

}
export interface FromIniInit extends SharedConfigInit {
export interface SourceProfileInit extends SharedConfigInit {
/**

@@ -41,4 +41,8 @@ * The configuration profile to use.

* Used to avoid loading shared config files multiple times.
*
* @internal
*/
loadedConfig?: Promise<SharedConfigFiles>;
}
export interface FromIniInit extends SourceProfileInit {
/**

@@ -66,4 +70,15 @@ * A function that returna a promise fulfilled with an MFA token code for

*/
export declare function fromIni(init?: FromIniInit): CredentialProvider;
export declare function getMasterProfileName(init: FromIniInit): string;
export declare function parseKnownFiles(init: FromIniInit): Promise<ParsedIniData>;
export declare const fromIni: (init?: FromIniInit) => CredentialProvider;
/**
* Load profiles from credentials and config INI files and normalize them into a
* single profile list.
*
* @internal
*/
export declare const parseKnownFiles: (init: SourceProfileInit) => Promise<ParsedIniData>;
/**
* @internal
*/
export declare const getMasterProfileName: (init: {
profile?: string;
}) => string;
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