Socket
Socket
Sign inDemoInstall

@aws-sdk/credential-provider-ini

Package Overview
Dependencies
Maintainers
5
Versions
345
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 1.0.0-gamma.9 to 1.0.0-rc.1

11

CHANGELOG.md

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

# [1.0.0-rc.1](https://github.com/aws/aws-sdk-js-v3/compare/v1.0.0-gamma.11...v1.0.0-rc.1) (2020-10-19)
### Features
* ready for release candidate ([#1578](https://github.com/aws/aws-sdk-js-v3/issues/1578)) ([519f66c](https://github.com/aws/aws-sdk-js-v3/commit/519f66c6388b91d0bd750a511e6d1af56196835e))
# [1.0.0-gamma.9](https://github.com/aws/aws-sdk-js-v3/compare/@aws-sdk/credential-provider-ini@1.0.0-gamma.8...@aws-sdk/credential-provider-ini@1.0.0-gamma.9) (2020-10-07)

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

124

dist/cjs/index.js
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.parseKnownFiles = exports.getMasterProfileName = exports.fromIni = exports.ENV_PROFILE = void 0;
var tslib_1 = require("tslib");
var property_provider_1 = require("@aws-sdk/property-provider");
var shared_ini_file_loader_1 = require("@aws-sdk/shared-ini-file-loader");
var DEFAULT_PROFILE = "default";
const property_provider_1 = require("@aws-sdk/property-provider");
const shared_ini_file_loader_1 = require("@aws-sdk/shared-ini-file-loader");
const DEFAULT_PROFILE = "default";
exports.ENV_PROFILE = "AWS_PROFILE";

@@ -29,5 +28,4 @@ function isStaticCredsProfile(arg) {

*/
function fromIni(init) {
if (init === void 0) { init = {}; }
return function () { return parseKnownFiles(init).then(function (profiles) { return resolveProfileData(getMasterProfileName(init), profiles, init); }); };
function fromIni(init = {}) {
return () => parseKnownFiles(init).then((profiles) => resolveProfileData(getMasterProfileName(init), profiles, init));
}

@@ -39,64 +37,56 @@ exports.fromIni = fromIni;

exports.getMasterProfileName = getMasterProfileName;
function resolveProfileData(profileName, profiles, options, visitedProfiles) {
if (visitedProfiles === void 0) { visitedProfiles = {}; }
return tslib_1.__awaiter(this, void 0, void 0, function () {
var data, ExternalId, mfa_serial, RoleArn, _a, RoleSessionName, source_profile, sourceCreds, params, _b, _c, _d;
var _e;
return tslib_1.__generator(this, function (_f) {
switch (_f.label) {
case 0:
data = profiles[profileName];
// If this is not the first profile visited, static credentials should be
// preferred over role assumption metadata. This special treatment of
// second and subsequent hops is to ensure compatibility with the AWS CLI.
if (Object.keys(visitedProfiles).length > 0 && isStaticCredsProfile(data)) {
return [2 /*return*/, resolveStaticCredentials(data)];
}
if (!isAssumeRoleProfile(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;
if (!options.roleAssumer) {
throw new property_provider_1.ProviderError("Profile " + profileName + " requires a role to be assumed, but no" + " role assumption callback was provided.", false);
}
if (source_profile in visitedProfiles) {
throw new property_provider_1.ProviderError("Detected a cycle attempting to resolve credentials for profile" +
(" " + getMasterProfileName(options) + ". Profiles visited: ") +
Object.keys(visitedProfiles).join(", "), false);
}
sourceCreds = resolveProfileData(source_profile, profiles, options, tslib_1.__assign(tslib_1.__assign({}, visitedProfiles), (_e = {}, _e[source_profile] = true, _e)));
params = { RoleArn: RoleArn, RoleSessionName: RoleSessionName, ExternalId: ExternalId };
if (!mfa_serial) return [3 /*break*/, 2];
if (!options.mfaCodeProvider) {
throw new property_provider_1.ProviderError("Profile " + profileName + " requires multi-factor authentication," + " but no MFA code callback was provided.", false);
}
params.SerialNumber = mfa_serial;
_b = params;
return [4 /*yield*/, options.mfaCodeProvider(mfa_serial)];
case 1:
_b.TokenCode = _f.sent();
_f.label = 2;
case 2:
_d = (_c = options).roleAssumer;
return [4 /*yield*/, sourceCreds];
case 3: return [2 /*return*/, _d.apply(_c, [_f.sent(), params])];
case 4:
// If no role assumption metadata is present, attempt to load static
// credentials from the selected profile.
if (isStaticCredsProfile(data)) {
return [2 /*return*/, resolveStaticCredentials(data)];
}
// If the profile cannot be parsed or contains neither static credentials
// nor role assumption metadata, throw an error. This should be considered a
// terminal resolution error if a profile has been specified by the user
// (whether via a parameter, an environment variable, or another profile's
// `source_profile` key).
throw new property_provider_1.ProviderError("Profile " + profileName + " could not be found or parsed in shared" + " credentials file.");
async function resolveProfileData(profileName, profiles, options, visitedProfiles = {}) {
const data = profiles[profileName];
// If this is not the first profile visited, static credentials should be
// preferred over role assumption metadata. This special treatment of
// second and subsequent hops is to ensure compatibility with the AWS CLI.
if (Object.keys(visitedProfiles).length > 0 && isStaticCredsProfile(data)) {
return resolveStaticCredentials(data);
}
// If this is the first profile visited, role assumption keys should be
// given precedence over static credentials.
if (isAssumeRoleProfile(data)) {
const { external_id: ExternalId, mfa_serial, role_arn: RoleArn, role_session_name: RoleSessionName = "aws-sdk-js-" + Date.now(), source_profile, } = data;
if (!options.roleAssumer) {
throw new property_provider_1.ProviderError(`Profile ${profileName} requires a role to be assumed, but no` + ` role assumption callback was provided.`, false);
}
if (source_profile in visitedProfiles) {
throw new property_provider_1.ProviderError(`Detected a cycle attempting to resolve credentials for profile` +
` ${getMasterProfileName(options)}. Profiles visited: ` +
Object.keys(visitedProfiles).join(", "), false);
}
const sourceCreds = resolveProfileData(source_profile, profiles, options, {
...visitedProfiles,
[source_profile]: true,
});
const params = { RoleArn, RoleSessionName, ExternalId };
if (mfa_serial) {
if (!options.mfaCodeProvider) {
throw new property_provider_1.ProviderError(`Profile ${profileName} requires multi-factor authentication,` + ` but no MFA code callback was provided.`, false);
}
});
});
params.SerialNumber = mfa_serial;
params.TokenCode = await options.mfaCodeProvider(mfa_serial);
}
return options.roleAssumer(await sourceCreds, params);
}
// If no role assumption metadata is present, attempt to load static
// credentials from the selected profile.
if (isStaticCredsProfile(data)) {
return resolveStaticCredentials(data);
}
// If the profile cannot be parsed or contains neither static credentials
// nor role assumption metadata, throw an error. This should be considered a
// terminal resolution error if a profile has been specified by the user
// (whether via a parameter, an environment variable, or another profile's
// `source_profile` key).
throw new property_provider_1.ProviderError(`Profile ${profileName} could not be found or parsed in shared` + ` credentials file.`);
}
function parseKnownFiles(init) {
var _a = init.loadedConfig, loadedConfig = _a === void 0 ? shared_ini_file_loader_1.loadSharedConfigFiles(init) : _a;
return loadedConfig.then(function (parsedFiles) {
var configFile = parsedFiles.configFile, credentialsFile = parsedFiles.credentialsFile;
return tslib_1.__assign(tslib_1.__assign({}, configFile), credentialsFile);
const { loadedConfig = shared_ini_file_loader_1.loadSharedConfigFiles(init) } = init;
return loadedConfig.then((parsedFiles) => {
const { configFile, credentialsFile } = parsedFiles;
return {
...configFile,
...credentialsFile,
};
});

@@ -112,2 +102,2 @@ }

}
//# 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 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"]}
{
"name": "@aws-sdk/credential-provider-ini",
"version": "1.0.0-gamma.9",
"version": "1.0.0-rc.1",
"description": "AWS credential provider that sources credentials from ~/.aws/credentials and ~/.aws/config",

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

"dependencies": {
"@aws-sdk/property-provider": "1.0.0-gamma.8",
"@aws-sdk/shared-ini-file-loader": "1.0.0-gamma.8",
"@aws-sdk/types": "1.0.0-gamma.7",
"@aws-sdk/property-provider": "1.0.0-rc.1",
"@aws-sdk/shared-ini-file-loader": "1.0.0-rc.1",
"@aws-sdk/types": "1.0.0-rc.1",
"tslib": "^1.8.0"

@@ -37,3 +37,6 @@ },

},
"types": "./dist/cjs/index.d.ts"
"types": "./dist/cjs/index.d.ts",
"engines": {
"node": ">= 10.0.0"
}
}
{
"compilerOptions": {
"declaration": true,
"strict": true,
"sourceMap": false,
"importHelpers": true,
"lib": ["es5", "es2015.promise", "es2015.collection"],
"rootDir": "./src",
"outDir": "./dist/cjs",
"noEmitHelpers": true,
"inlineSourceMap": true,
"inlineSources": true,
"baseUrl": "."

@@ -14,0 +6,0 @@ },

{
"compilerOptions": {
"declaration": true,
"strict": true,
"sourceMap": false,
"importHelpers": true,
"lib": ["es5", "es2015.promise", "es2015.collection"],
"rootDir": "./src",
"outDir": "./dist/es",
"noEmitHelpers": true,
"inlineSourceMap": true,
"inlineSources": true,
"baseUrl": "."

@@ -14,0 +7,0 @@ },

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