webhook-action/node_modules/eslint-plugin-import/lib/rules/extensions.js
Joel Male 1ada95e04a
v2.0.0 (#12)
- Convert project to Javascript/Typescript
- Allow custom headers to be passed in (optional)
- Allow body to be optional
2020-08-26 10:52:47 +10:00

189 lines
19 KiB
JavaScript

'use strict';var _path = require('path');var _path2 = _interopRequireDefault(_path);
var _resolve = require('eslint-module-utils/resolve');var _resolve2 = _interopRequireDefault(_resolve);
var _importType = require('../core/importType');
var _docsUrl = require('../docsUrl');var _docsUrl2 = _interopRequireDefault(_docsUrl);function _interopRequireDefault(obj) {return obj && obj.__esModule ? obj : { default: obj };}
const enumValues = { enum: ['always', 'ignorePackages', 'never'] };
const patternProperties = {
type: 'object',
patternProperties: { '.*': enumValues } };
const properties = {
type: 'object',
properties: {
'pattern': patternProperties,
'ignorePackages': { type: 'boolean' } } };
function buildProperties(context) {
const result = {
defaultConfig: 'never',
pattern: {},
ignorePackages: false };
context.options.forEach(obj => {
// If this is a string, set defaultConfig to its value
if (typeof obj === 'string') {
result.defaultConfig = obj;
return;
}
// If this is not the new structure, transfer all props to result.pattern
if (obj.pattern === undefined && obj.ignorePackages === undefined) {
Object.assign(result.pattern, obj);
return;
}
// If pattern is provided, transfer all props
if (obj.pattern !== undefined) {
Object.assign(result.pattern, obj.pattern);
}
// If ignorePackages is provided, transfer it to result
if (obj.ignorePackages !== undefined) {
result.ignorePackages = obj.ignorePackages;
}
});
if (result.defaultConfig === 'ignorePackages') {
result.defaultConfig = 'always';
result.ignorePackages = true;
}
return result;
}
module.exports = {
meta: {
type: 'suggestion',
docs: {
url: (0, _docsUrl2.default)('extensions') },
schema: {
anyOf: [
{
type: 'array',
items: [enumValues],
additionalItems: false },
{
type: 'array',
items: [
enumValues,
properties],
additionalItems: false },
{
type: 'array',
items: [properties],
additionalItems: false },
{
type: 'array',
items: [patternProperties],
additionalItems: false },
{
type: 'array',
items: [
enumValues,
patternProperties],
additionalItems: false }] } },
create: function (context) {
const props = buildProperties(context);
function getModifier(extension) {
return props.pattern[extension] || props.defaultConfig;
}
function isUseOfExtensionRequired(extension, isPackage) {
return getModifier(extension) === 'always' && (!props.ignorePackages || !isPackage);
}
function isUseOfExtensionForbidden(extension) {
return getModifier(extension) === 'never';
}
function isResolvableWithoutExtension(file) {
const extension = _path2.default.extname(file);
const fileWithoutExtension = file.slice(0, -extension.length);
const resolvedFileWithoutExtension = (0, _resolve2.default)(fileWithoutExtension, context);
return resolvedFileWithoutExtension === (0, _resolve2.default)(file, context);
}
function isExternalRootModule(file) {
const slashCount = file.split('/').length - 1;
if ((0, _importType.isScopedModule)(file) && slashCount <= 1) return true;
if ((0, _importType.isExternalModule)(file, context, (0, _resolve2.default)(file, context)) && !slashCount) return true;
return false;
}
function checkFileExtension(node) {const
source = node.source;
// bail if the declaration doesn't have a source, e.g. "export { foo };"
if (!source) return;
const importPathWithQueryString = source.value;
// don't enforce anything on builtins
if ((0, _importType.isBuiltIn)(importPathWithQueryString, context.settings)) return;
const importPath = importPathWithQueryString.replace(/\?(.*)$/, '');
// don't enforce in root external packages as they may have names with `.js`.
// Like `import Decimal from decimal.js`)
if (isExternalRootModule(importPath)) return;
const resolvedPath = (0, _resolve2.default)(importPath, context);
// get extension from resolved path, if possible.
// for unresolved, use source value.
const extension = _path2.default.extname(resolvedPath || importPath).substring(1);
// determine if this is a module
const isPackage = (0, _importType.isExternalModule)(importPath, context.settings) ||
(0, _importType.isScoped)(importPath);
if (!extension || !importPath.endsWith(`.${extension}`)) {
const extensionRequired = isUseOfExtensionRequired(extension, isPackage);
const extensionForbidden = isUseOfExtensionForbidden(extension);
if (extensionRequired && !extensionForbidden) {
context.report({
node: source,
message:
`Missing file extension ${extension ? `"${extension}" ` : ''}for "${importPathWithQueryString}"` });
}
} else if (extension) {
if (isUseOfExtensionForbidden(extension) && isResolvableWithoutExtension(importPath)) {
context.report({
node: source,
message: `Unexpected use of file extension "${extension}" for "${importPathWithQueryString}"` });
}
}
}
return {
ImportDeclaration: checkFileExtension,
ExportNamedDeclaration: checkFileExtension };
} };
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/rules/extensions.js"],"names":["enumValues","enum","patternProperties","type","properties","buildProperties","context","result","defaultConfig","pattern","ignorePackages","options","forEach","obj","undefined","Object","assign","module","exports","meta","docs","url","schema","anyOf","items","additionalItems","create","props","getModifier","extension","isUseOfExtensionRequired","isPackage","isUseOfExtensionForbidden","isResolvableWithoutExtension","file","path","extname","fileWithoutExtension","slice","length","resolvedFileWithoutExtension","isExternalRootModule","slashCount","split","checkFileExtension","node","source","importPathWithQueryString","value","settings","importPath","replace","resolvedPath","substring","endsWith","extensionRequired","extensionForbidden","report","message","ImportDeclaration","ExportNamedDeclaration"],"mappings":"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","file":"extensions.js","sourcesContent":["import path from 'path'\n\nimport resolve from 'eslint-module-utils/resolve'\nimport { isBuiltIn, isExternalModule, isScoped, isScopedModule } from '../core/importType'\nimport docsUrl from '../docsUrl'\n\nconst enumValues = { enum: [ 'always', 'ignorePackages', 'never' ] }\nconst patternProperties = {\n  type: 'object',\n  patternProperties: { '.*': enumValues },\n}\nconst properties = {\n  type: 'object',\n  properties: {\n    'pattern': patternProperties,\n    'ignorePackages': { type: 'boolean' },\n  },\n}\n\nfunction buildProperties(context) {\n\n    const result = {\n      defaultConfig: 'never',\n      pattern: {},\n      ignorePackages: false,\n    }\n\n    context.options.forEach(obj => {\n\n      // If this is a string, set defaultConfig to its value\n      if (typeof obj === 'string') {\n        result.defaultConfig = obj\n        return\n      }\n\n      // If this is not the new structure, transfer all props to result.pattern\n      if (obj.pattern === undefined && obj.ignorePackages === undefined) {\n        Object.assign(result.pattern, obj)\n        return\n      }\n\n      // If pattern is provided, transfer all props\n      if (obj.pattern !== undefined) {\n        Object.assign(result.pattern, obj.pattern)\n      }\n\n      // If ignorePackages is provided, transfer it to result\n      if (obj.ignorePackages !== undefined) {\n        result.ignorePackages = obj.ignorePackages\n      }\n    })\n\n    if (result.defaultConfig === 'ignorePackages') {\n      result.defaultConfig = 'always'\n      result.ignorePackages = true\n    }\n\n    return result\n}\n\nmodule.exports = {\n  meta: {\n    type: 'suggestion',\n    docs: {\n      url: docsUrl('extensions'),\n    },\n\n    schema: {\n      anyOf: [\n        {\n          type: 'array',\n          items: [enumValues],\n          additionalItems: false,\n        },\n        {\n          type: 'array',\n          items: [\n            enumValues,\n            properties,\n          ],\n          additionalItems: false,\n        },\n        {\n          type: 'array',\n          items: [properties],\n          additionalItems: false,\n        },\n        {\n          type: 'array',\n          items: [patternProperties],\n          additionalItems: false,\n        },\n        {\n          type: 'array',\n          items: [\n            enumValues,\n            patternProperties,\n          ],\n          additionalItems: false,\n        },\n      ],\n    },\n  },\n\n  create: function (context) {\n\n    const props = buildProperties(context)\n\n    function getModifier(extension) {\n      return props.pattern[extension] || props.defaultConfig\n    }\n\n    function isUseOfExtensionRequired(extension, isPackage) {\n      return getModifier(extension) === 'always' && (!props.ignorePackages || !isPackage)\n    }\n\n    function isUseOfExtensionForbidden(extension) {\n      return getModifier(extension) === 'never'\n    }\n\n    function isResolvableWithoutExtension(file) {\n      const extension = path.extname(file)\n      const fileWithoutExtension = file.slice(0, -extension.length)\n      const resolvedFileWithoutExtension = resolve(fileWithoutExtension, context)\n\n      return resolvedFileWithoutExtension === resolve(file, context)\n    }\n\n    function isExternalRootModule(file) {\n      const slashCount = file.split('/').length - 1\n\n      if (isScopedModule(file) && slashCount <= 1) return true\n      if (isExternalModule(file, context, resolve(file, context)) && !slashCount) return true\n      return false\n    }\n\n    function checkFileExtension(node) {\n      const { source } = node\n\n      // bail if the declaration doesn't have a source, e.g. \"export { foo };\"\n      if (!source) return\n\n      const importPathWithQueryString = source.value\n\n      // don't enforce anything on builtins\n      if (isBuiltIn(importPathWithQueryString, context.settings)) return\n\n      const importPath = importPathWithQueryString.replace(/\\?(.*)$/, '')\n\n      // don't enforce in root external packages as they may have names with `.js`.\n      // Like `import Decimal from decimal.js`)\n      if (isExternalRootModule(importPath)) return\n\n      const resolvedPath = resolve(importPath, context)\n\n      // get extension from resolved path, if possible.\n      // for unresolved, use source value.\n      const extension = path.extname(resolvedPath || importPath).substring(1)\n\n      // determine if this is a module\n      const isPackage = isExternalModule(importPath, context.settings)\n        || isScoped(importPath)\n\n      if (!extension || !importPath.endsWith(`.${extension}`)) {\n        const extensionRequired = isUseOfExtensionRequired(extension, isPackage)\n        const extensionForbidden = isUseOfExtensionForbidden(extension)\n        if (extensionRequired && !extensionForbidden) {\n          context.report({\n            node: source,\n            message:\n              `Missing file extension ${extension ? `\"${extension}\" ` : ''}for \"${importPathWithQueryString}\"`,\n          })\n        }\n      } else if (extension) {\n        if (isUseOfExtensionForbidden(extension) && isResolvableWithoutExtension(importPath)) {\n          context.report({\n            node: source,\n            message: `Unexpected use of file extension \"${extension}\" for \"${importPathWithQueryString}\"`,\n          })\n        }\n      }\n    }\n\n    return {\n      ImportDeclaration: checkFileExtension,\n      ExportNamedDeclaration: checkFileExtension,\n    }\n  },\n}\n"]}