mirror of
https://github.com/joelwmale/webhook-action.git
synced 2024-11-26 01:16:56 +01:00
217 lines
No EOL
24 KiB
JavaScript
217 lines
No EOL
24 KiB
JavaScript
'use strict';var _declaredScope = require('eslint-module-utils/declaredScope');var _declaredScope2 = _interopRequireDefault(_declaredScope);
|
|
var _ExportMap = require('../ExportMap');var _ExportMap2 = _interopRequireDefault(_ExportMap);
|
|
var _importDeclaration = require('../importDeclaration');var _importDeclaration2 = _interopRequireDefault(_importDeclaration);
|
|
var _docsUrl = require('../docsUrl');var _docsUrl2 = _interopRequireDefault(_docsUrl);function _interopRequireDefault(obj) {return obj && obj.__esModule ? obj : { default: obj };}
|
|
|
|
module.exports = {
|
|
meta: {
|
|
type: 'problem',
|
|
docs: {
|
|
url: (0, _docsUrl2.default)('namespace') },
|
|
|
|
|
|
schema: [
|
|
{
|
|
type: 'object',
|
|
properties: {
|
|
allowComputed: {
|
|
description: 'If `false`, will report computed (and thus, un-lintable) references to namespace members.',
|
|
type: 'boolean',
|
|
default: false } },
|
|
|
|
|
|
additionalProperties: false }] },
|
|
|
|
|
|
|
|
|
|
create: function namespaceRule(context) {
|
|
|
|
// read options
|
|
var _ref =
|
|
|
|
context.options[0] || {},_ref$allowComputed = _ref.allowComputed;const allowComputed = _ref$allowComputed === undefined ? false : _ref$allowComputed;
|
|
|
|
const namespaces = new Map();
|
|
|
|
function makeMessage(last, namepath) {
|
|
return `'${last.name}' not found in ${namepath.length > 1 ? 'deeply ' : ''}imported namespace '${namepath.join('.')}'.`;
|
|
}
|
|
|
|
return {
|
|
// pick up all imports at body entry time, to properly respect hoisting
|
|
Program(_ref2) {let body = _ref2.body;
|
|
function processBodyStatement(declaration) {
|
|
if (declaration.type !== 'ImportDeclaration') return;
|
|
|
|
if (declaration.specifiers.length === 0) return;
|
|
|
|
const imports = _ExportMap2.default.get(declaration.source.value, context);
|
|
if (imports == null) return null;
|
|
|
|
if (imports.errors.length) {
|
|
imports.reportErrors(context, declaration);
|
|
return;
|
|
}
|
|
|
|
for (const specifier of declaration.specifiers) {
|
|
switch (specifier.type) {
|
|
case 'ImportNamespaceSpecifier':
|
|
if (!imports.size) {
|
|
context.report(
|
|
specifier,
|
|
`No exported names found in module '${declaration.source.value}'.`);
|
|
|
|
}
|
|
namespaces.set(specifier.local.name, imports);
|
|
break;
|
|
case 'ImportDefaultSpecifier':
|
|
case 'ImportSpecifier':{
|
|
const meta = imports.get(
|
|
// default to 'default' for default http://i.imgur.com/nj6qAWy.jpg
|
|
specifier.imported ? specifier.imported.name : 'default');
|
|
|
|
if (!meta || !meta.namespace) {break;}
|
|
namespaces.set(specifier.local.name, meta.namespace);
|
|
break;
|
|
}}
|
|
|
|
}
|
|
}
|
|
body.forEach(processBodyStatement);
|
|
},
|
|
|
|
// same as above, but does not add names to local map
|
|
ExportNamespaceSpecifier(namespace) {
|
|
var declaration = (0, _importDeclaration2.default)(context);
|
|
|
|
var imports = _ExportMap2.default.get(declaration.source.value, context);
|
|
if (imports == null) return null;
|
|
|
|
if (imports.errors.length) {
|
|
imports.reportErrors(context, declaration);
|
|
return;
|
|
}
|
|
|
|
if (!imports.size) {
|
|
context.report(
|
|
namespace,
|
|
`No exported names found in module '${declaration.source.value}'.`);
|
|
|
|
}
|
|
},
|
|
|
|
// todo: check for possible redefinition
|
|
|
|
MemberExpression(dereference) {
|
|
if (dereference.object.type !== 'Identifier') return;
|
|
if (!namespaces.has(dereference.object.name)) return;
|
|
if ((0, _declaredScope2.default)(context, dereference.object.name) !== 'module') return;
|
|
|
|
if (dereference.parent.type === 'AssignmentExpression' && dereference.parent.left === dereference) {
|
|
context.report(
|
|
dereference.parent,
|
|
`Assignment to member of namespace '${dereference.object.name}'.`);
|
|
|
|
}
|
|
|
|
// go deep
|
|
var namespace = namespaces.get(dereference.object.name);
|
|
var namepath = [dereference.object.name];
|
|
// while property is namespace and parent is member expression, keep validating
|
|
while (namespace instanceof _ExportMap2.default && dereference.type === 'MemberExpression') {
|
|
|
|
if (dereference.computed) {
|
|
if (!allowComputed) {
|
|
context.report(
|
|
dereference.property,
|
|
`Unable to validate computed reference to imported namespace '${dereference.object.name}'.`);
|
|
|
|
}
|
|
return;
|
|
}
|
|
|
|
if (!namespace.has(dereference.property.name)) {
|
|
context.report(
|
|
dereference.property,
|
|
makeMessage(dereference.property, namepath));
|
|
|
|
break;
|
|
}
|
|
|
|
const exported = namespace.get(dereference.property.name);
|
|
if (exported == null) return;
|
|
|
|
// stash and pop
|
|
namepath.push(dereference.property.name);
|
|
namespace = exported.namespace;
|
|
dereference = dereference.parent;
|
|
}
|
|
|
|
},
|
|
|
|
VariableDeclarator(_ref3) {let id = _ref3.id,init = _ref3.init;
|
|
if (init == null) return;
|
|
if (init.type !== 'Identifier') return;
|
|
if (!namespaces.has(init.name)) return;
|
|
|
|
// check for redefinition in intermediate scopes
|
|
if ((0, _declaredScope2.default)(context, init.name) !== 'module') return;
|
|
|
|
// DFS traverse child namespaces
|
|
function testKey(pattern, namespace) {let path = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : [init.name];
|
|
if (!(namespace instanceof _ExportMap2.default)) return;
|
|
|
|
if (pattern.type !== 'ObjectPattern') return;
|
|
|
|
for (const property of pattern.properties) {
|
|
if (
|
|
property.type === 'ExperimentalRestProperty' ||
|
|
property.type === 'RestElement' ||
|
|
!property.key)
|
|
{
|
|
continue;
|
|
}
|
|
|
|
if (property.key.type !== 'Identifier') {
|
|
context.report({
|
|
node: property,
|
|
message: 'Only destructure top-level names.' });
|
|
|
|
continue;
|
|
}
|
|
|
|
if (!namespace.has(property.key.name)) {
|
|
context.report({
|
|
node: property,
|
|
message: makeMessage(property.key, path) });
|
|
|
|
continue;
|
|
}
|
|
|
|
path.push(property.key.name);
|
|
const dependencyExportMap = namespace.get(property.key.name);
|
|
// could be null when ignored or ambiguous
|
|
if (dependencyExportMap !== null) {
|
|
testKey(property.value, dependencyExportMap.namespace, path);
|
|
}
|
|
path.pop();
|
|
}
|
|
}
|
|
|
|
testKey(id, namespaces.get(init.name));
|
|
},
|
|
|
|
JSXMemberExpression(_ref4) {let object = _ref4.object,property = _ref4.property;
|
|
if (!namespaces.has(object.name)) return;
|
|
var namespace = namespaces.get(object.name);
|
|
if (!namespace.has(property.name)) {
|
|
context.report({
|
|
node: property,
|
|
message: makeMessage(property, [object.name]) });
|
|
|
|
}
|
|
} };
|
|
|
|
} };
|
|
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/rules/namespace.js"],"names":["module","exports","meta","type","docs","url","schema","properties","allowComputed","description","default","additionalProperties","create","namespaceRule","context","options","namespaces","Map","makeMessage","last","namepath","name","length","join","Program","body","processBodyStatement","declaration","specifiers","imports","Exports","get","source","value","errors","reportErrors","specifier","size","report","set","local","imported","namespace","forEach","ExportNamespaceSpecifier","MemberExpression","dereference","object","has","parent","left","computed","property","exported","push","VariableDeclarator","id","init","testKey","pattern","path","key","node","message","dependencyExportMap","pop","JSXMemberExpression"],"mappings":"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","file":"namespace.js","sourcesContent":["import declaredScope from 'eslint-module-utils/declaredScope'\nimport Exports from '../ExportMap'\nimport importDeclaration from '../importDeclaration'\nimport docsUrl from '../docsUrl'\n\nmodule.exports = {\n  meta: {\n    type: 'problem',\n    docs: {\n      url: docsUrl('namespace'),\n    },\n\n    schema: [\n      {\n        type: 'object',\n        properties: {\n          allowComputed: {\n            description: 'If `false`, will report computed (and thus, un-lintable) references to namespace members.',\n            type: 'boolean',\n            default: false,\n          },\n        },\n        additionalProperties: false,\n      },\n    ],\n  },\n\n  create: function namespaceRule(context) {\n\n    // read options\n    const {\n      allowComputed = false,\n    } = context.options[0] || {}\n\n    const namespaces = new Map()\n\n    function makeMessage(last, namepath) {\n      return `'${last.name}' not found in ${namepath.length > 1 ? 'deeply ' : ''}imported namespace '${namepath.join('.')}'.`\n    }\n\n    return {\n      // pick up all imports at body entry time, to properly respect hoisting\n      Program({ body }) {\n        function processBodyStatement(declaration) {\n          if (declaration.type !== 'ImportDeclaration') return\n\n          if (declaration.specifiers.length === 0) return\n\n          const imports = Exports.get(declaration.source.value, context)\n          if (imports == null) return null\n\n          if (imports.errors.length) {\n            imports.reportErrors(context, declaration)\n            return\n          }\n\n          for (const specifier of declaration.specifiers) {\n            switch (specifier.type) {\n              case 'ImportNamespaceSpecifier':\n                if (!imports.size) {\n                  context.report(\n                    specifier,\n                    `No exported names found in module '${declaration.source.value}'.`\n                  )\n                }\n                namespaces.set(specifier.local.name, imports)\n                break\n              case 'ImportDefaultSpecifier':\n              case 'ImportSpecifier': {\n                const meta = imports.get(\n                  // default to 'default' for default http://i.imgur.com/nj6qAWy.jpg\n                  specifier.imported ? specifier.imported.name : 'default'\n                )\n                if (!meta || !meta.namespace) { break }\n                namespaces.set(specifier.local.name, meta.namespace)\n                break\n              }\n            }\n          }\n        }\n        body.forEach(processBodyStatement)\n      },\n\n      // same as above, but does not add names to local map\n      ExportNamespaceSpecifier(namespace) {\n        var declaration = importDeclaration(context)\n\n        var imports = Exports.get(declaration.source.value, context)\n        if (imports == null) return null\n\n        if (imports.errors.length) {\n          imports.reportErrors(context, declaration)\n          return\n        }\n\n        if (!imports.size) {\n          context.report(\n            namespace,\n            `No exported names found in module '${declaration.source.value}'.`\n          )\n        }\n      },\n\n      // todo: check for possible redefinition\n\n      MemberExpression(dereference) {\n        if (dereference.object.type !== 'Identifier') return\n        if (!namespaces.has(dereference.object.name)) return\n        if (declaredScope(context, dereference.object.name) !== 'module') return\n\n        if (dereference.parent.type === 'AssignmentExpression' && dereference.parent.left === dereference) {\n            context.report(\n              dereference.parent,\n              `Assignment to member of namespace '${dereference.object.name}'.`\n            )\n        }\n\n        // go deep\n        var namespace = namespaces.get(dereference.object.name)\n        var namepath = [dereference.object.name]\n        // while property is namespace and parent is member expression, keep validating\n        while (namespace instanceof Exports && dereference.type === 'MemberExpression') {\n\n          if (dereference.computed) {\n            if (!allowComputed) {\n              context.report(\n                dereference.property,\n                `Unable to validate computed reference to imported namespace '${dereference.object.name}'.`\n              )\n            }\n            return\n          }\n\n          if (!namespace.has(dereference.property.name)) {\n            context.report(\n              dereference.property,\n              makeMessage(dereference.property, namepath)\n            )\n            break\n          }\n\n          const exported = namespace.get(dereference.property.name)\n          if (exported == null) return\n\n          // stash and pop\n          namepath.push(dereference.property.name)\n          namespace = exported.namespace\n          dereference = dereference.parent\n        }\n\n      },\n\n      VariableDeclarator({ id, init }) {\n        if (init == null) return\n        if (init.type !== 'Identifier') return\n        if (!namespaces.has(init.name)) return\n\n        // check for redefinition in intermediate scopes\n        if (declaredScope(context, init.name) !== 'module') return\n\n        // DFS traverse child namespaces\n        function testKey(pattern, namespace, path = [init.name]) {\n          if (!(namespace instanceof Exports)) return\n\n          if (pattern.type !== 'ObjectPattern') return\n\n          for (const property of pattern.properties) {\n            if (\n              property.type === 'ExperimentalRestProperty'\n              || property.type === 'RestElement'\n              || !property.key\n            ) {\n              continue\n            }\n\n            if (property.key.type !== 'Identifier') {\n              context.report({\n                node: property,\n                message: 'Only destructure top-level names.',\n              })\n              continue\n            }\n\n            if (!namespace.has(property.key.name)) {\n              context.report({\n                node: property,\n                message: makeMessage(property.key, path),\n              })\n              continue\n            }\n\n            path.push(property.key.name)\n            const dependencyExportMap = namespace.get(property.key.name)\n            // could be null when ignored or ambiguous\n            if (dependencyExportMap !== null) {\n              testKey(property.value, dependencyExportMap.namespace, path)\n            }\n            path.pop()\n          }\n        }\n\n        testKey(id, namespaces.get(init.name))\n      },\n\n      JSXMemberExpression({object, property}) {\n         if (!namespaces.has(object.name)) return\n         var namespace = namespaces.get(object.name)\n         if (!namespace.has(property.name)) {\n           context.report({\n             node: property,\n             message: makeMessage(property, [object.name]),\n           })\n         }\n      },\n    }\n  },\n}\n"]}
|