HEX
Server: Apache/2.4.52 (Ubuntu)
System: Linux ip-172-31-4-197 6.8.0-1036-aws #38~22.04.1-Ubuntu SMP Fri Aug 22 15:44:33 UTC 2025 x86_64
User: ubuntu (1000)
PHP: 7.4.33
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: /var/www/api-storage/node_modules/eslint/lib/rules/no-new-func.js
/**
 * @fileoverview Rule to flag when using new Function
 * @author Ilya Volodin
 */

"use strict";

//------------------------------------------------------------------------------
// Requirements
//------------------------------------------------------------------------------

const astUtils = require("./utils/ast-utils");

//------------------------------------------------------------------------------
// Helpers
//------------------------------------------------------------------------------

const callMethods = new Set(["apply", "bind", "call"]);

//------------------------------------------------------------------------------
// Rule Definition
//------------------------------------------------------------------------------

/** @type {import('../types').Rule.RuleModule} */
module.exports = {
	meta: {
		type: "suggestion",

		docs: {
			description: "Disallow `new` operators with the `Function` object",
			recommended: false,
			url: "https://eslint.org/docs/latest/rules/no-new-func",
		},

		schema: [],

		messages: {
			noFunctionConstructor: "The Function constructor is eval.",
		},
	},

	create(context) {
		const sourceCode = context.sourceCode;

		return {
			"Program:exit"(node) {
				const globalScope = sourceCode.getScope(node);
				const variable = globalScope.set.get("Function");

				if (variable && variable.defs.length === 0) {
					variable.references.forEach(ref => {
						const idNode = ref.identifier;
						const { parent } = idNode;
						let evalNode;

						if (parent) {
							if (
								idNode === parent.callee &&
								(parent.type === "NewExpression" ||
									parent.type === "CallExpression")
							) {
								evalNode = parent;
							} else if (
								parent.type === "MemberExpression" &&
								idNode === parent.object &&
								callMethods.has(
									astUtils.getStaticPropertyName(parent),
								)
							) {
								const maybeCallee =
									parent.parent.type === "ChainExpression"
										? parent.parent
										: parent;

								if (
									maybeCallee.parent.type ===
										"CallExpression" &&
									maybeCallee.parent.callee === maybeCallee
								) {
									evalNode = maybeCallee.parent;
								}
							}
						}

						if (evalNode) {
							context.report({
								node: evalNode,
								messageId: "noFunctionConstructor",
							});
						}
					});
				}
			},
		};
	},
};