├── .github └── dependabot.yml ├── .gitignore ├── .prettierrc ├── LICENSE ├── README.md ├── eslint.config.mjs ├── index.cjs ├── index.d.ts ├── index.mjs ├── package-lock.json └── package.json /.github/dependabot.yml: -------------------------------------------------------------------------------- 1 | # To get started with Dependabot version updates, you'll need to specify which 2 | # package ecosystems to update and where the package manifests are located. 3 | # Please see the documentation for all configuration options: 4 | # https://docs.github.com/github/administering-a-repository/configuration-options-for-dependency-updates 5 | 6 | version: 2 7 | updates: 8 | - package-ecosystem: 'npm' # See documentation for possible values 9 | directory: '/' # Location of package manifests 10 | schedule: 11 | interval: 'weekly' 12 | target-branch: 'master' 13 | labels: 14 | - 'dependencies' 15 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | # Logs 2 | logs 3 | *.log 4 | npm-debug.log* 5 | yarn-debug.log* 6 | yarn-error.log* 7 | 8 | # Runtime data 9 | pids 10 | *.pid 11 | *.seed 12 | *.pid.lock 13 | 14 | # Directory for instrumented libs generated by jscoverage/JSCover 15 | lib-cov 16 | 17 | # Coverage directory used by tools like istanbul 18 | coverage 19 | 20 | # nyc test coverage 21 | .nyc_output 22 | 23 | # Grunt intermediate storage (http://gruntjs.com/creating-plugins#storing-task-files) 24 | .grunt 25 | 26 | # Bower dependency directory (https://bower.io/) 27 | bower_components 28 | 29 | # node-waf configuration 30 | .lock-wscript 31 | 32 | # Compiled binary addons (https://nodejs.org/api/addons.html) 33 | build/Release 34 | 35 | # Dependency directories 36 | node_modules/ 37 | jspm_packages/ 38 | 39 | # TypeScript v1 declaration files 40 | typings/ 41 | 42 | # Optional npm cache directory 43 | .npm 44 | 45 | # Optional eslint cache 46 | .eslintcache 47 | 48 | # Optional REPL history 49 | .node_repl_history 50 | 51 | # Output of 'npm pack' 52 | *.tgz 53 | 54 | # Yarn Integrity file 55 | .yarn-integrity 56 | 57 | # dotenv environment variables file 58 | .env 59 | 60 | # next.js build output 61 | .next 62 | -------------------------------------------------------------------------------- /.prettierrc: -------------------------------------------------------------------------------- 1 | { 2 | "useTabs": true, 3 | "tabWidth": 4, 4 | "singleQuote": true, 5 | "printWidth": 120 6 | } 7 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2019 Jörn Berkefeld 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in all 13 | copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 21 | SOFTWARE. 22 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # eslint-config-ssjs 2 | 3 | Preset for Salesforce Marketing Cloud's Server-Side JavaScript. 4 | 5 | > ESLint [shareable config](http://eslint.org/docs/developer-guide/shareable-configs.html) 6 | 7 | [![NPM](https://nodei.co/npm/eslint-config-ssjs.png?downloads=true&downloadRank=true&stars=true)](https://nodei.co/npm/eslint-config-ssjs/) 8 | 9 | ## Features 10 | 11 | - rules limited to \*.ssjs files but can be extended to other files by adapting your eslint.config.js 12 | - all SSJS classes/methods offered by SFMC are defined as unchangable globals 13 | - ecma script 3 pre-defined 14 | - quirks of SSJS handled via custom rules 15 | - based on eslint recommended rules with as little changes as possible 16 | 17 | ## Installation 18 | 19 | ```batch 20 | npm install --save-dev eslint eslint-config-ssjs 21 | ``` 22 | 23 | ## Usage 24 | 25 | ### Flat Config: eslint.config.js 26 | 27 | **Important:** Requires ESLint >=8.56.0 and eslint-config-ssjs >=2.0.0 28 | 29 | This plugin exports a recommended config that enforces good practices. 30 | 31 | #### ES Module (Recommended) 32 | 33 | The folowing will limit SSJS rules to files ending on `*.ssjs`: 34 | 35 | ```js 36 | import sfmcSsjs from 'eslint-config-ssjs'; 37 | 38 | export default [ 39 | // … 40 | { 41 | ...sfmcSsjs.configs.recommended, 42 | files: ['**/*.ssjs'], 43 | }, 44 | ]; 45 | ``` 46 | 47 | If you don't plan on writing any browser (normal) JavaScript, you can also use the following. This will apply the rules to all files:ggn 48 | 49 | ```js 50 | import sfmcSsjs from 'eslint-config-ssjs'; 51 | 52 | export default [ 53 | // … 54 | sfmcSsjs.configs.recommended, 55 | ]; 56 | ``` 57 | 58 | #### CommonJS 59 | 60 | ```js 61 | 'use strict'; 62 | const sfmcSsjs = require('eslint-config-ssjs'); 63 | 64 | module.exports = [ 65 | // … 66 | { 67 | ...sfmcSsjs.configs.recommended, 68 | files: ['**/*.ssjs'], 69 | }, 70 | ]; 71 | ``` 72 | 73 | ### Legacy: .eslintrc.\* or package.json 74 | 75 | **Important:** Requires ESLint <9.0.0 and eslint-config-ssjs <2.0.0 76 | 77 | Once the `eslint-config-ssjs` package is installed, you can use it by specifying `ssjs` in the [`extends`](http://eslint.org/docs/user-guide/configuring#extending-configuration-files) section of your [ESLint configuration](http://eslint.org/docs/user-guide/configuring). 78 | 79 | **Important:** Make sure that your SSJS files end on `*.ssjs` and not on `*.js`. 80 | 81 | ```js 82 | { 83 | "extends": "ssjs", 84 | "rules": { 85 | // your other rules 86 | } 87 | } 88 | ``` 89 | 90 | It's good practice to use [`eslint:recommended` ruleset](http://eslint.org/docs/rules/) in your project to support front end scripts. 91 | 92 | To use SSJS in conjunction with ESLint's recommended rule set, extend with both, making sure to list `ssjs` last. We do recommend to also use this together with `eslint-config-prettier` and `eslint-plugin-prettier` 93 | 94 | ```js 95 | { 96 | "extends": ["eslint:recommended", "prettier", "ssjs"], 97 | "plugins": ["prettier"], 98 | "rules": { 99 | // your other rules that don't conflict with the SSJS config 100 | }, 101 | } 102 | ``` 103 | 104 | ## Using Prettier with SSJS 105 | 106 | Starting with version 2.x of prettier, the plugin automatically has "trailingComma" set to "es5". That's a problem because SSJS actually does not support this. 107 | 108 | Also, SFMC tends to remove all tabs when you save queries, scripts, code snippets, emails and cloud pages. We hence strongly recommend to set `useTabs` to `false` and define `tabWidth` according to your liking (2 or 4 are typical values). 109 | 110 | Add the following to your `.prettierrc` file to ensure the above concerns are adressed: 111 | 112 | ```json 113 | { 114 | "useTabs": false, 115 | "tabWidth": 4, 116 | "singleQuote": true, 117 | "overrides": [ 118 | { 119 | "files": "*.ssjs", 120 | "options": { 121 | "trailingComma": "none" 122 | } 123 | } 124 | ] 125 | } 126 | ``` 127 | 128 | ## Using the .ssjs extension in VSCode 129 | 130 | Make sure you associate `*.ssjs` with JavaScript in your IDE. That should automatically enable linting via ESLint. 131 | 132 | ## License 133 | 134 | MIT licensed 135 | -------------------------------------------------------------------------------- /eslint.config.mjs: -------------------------------------------------------------------------------- 1 | import globals from "globals"; 2 | import pluginJs from "@eslint/js"; 3 | 4 | 5 | export default [ 6 | {languageOptions: { globals: globals.node }}, 7 | pluginJs.configs.recommended, 8 | ]; -------------------------------------------------------------------------------- /index.cjs: -------------------------------------------------------------------------------- 1 | /** 2 | * Copyright 2020-2024 Jörn Berkefeld / joern.berkefeld@gmail.com 3 | * 4 | * Licensed under the MIT License. 5 | */ 6 | 7 | const eslintConfigSsjs = { 8 | meta: {}, 9 | configs: {}, 10 | rules: {}, 11 | processors: {}, 12 | }; 13 | 14 | // assign configs here so we can reference `plugin` 15 | Object.assign(eslintConfigSsjs.configs, { 16 | recommended: { 17 | languageOptions: { 18 | ecmaVersion: 3, 19 | sourceType: 'script', 20 | globals: { 21 | Account: 'readonly', 22 | AccountUser: 'readonly', 23 | Attribute: 'readonly', 24 | Base64Decode: 'readonly', 25 | Base64Encode: 'readonly', 26 | BeginImpressionRegion: 'readonly', 27 | BounceEvent: 'readonly', 28 | ContentArea: 'readonly', 29 | ContentAreaByName: 'readonly', 30 | ContentAreaObj: 'readonly', 31 | DataExtension: 'readonly', 32 | DateTime: 'readonly', 33 | DeliveryProfile: 'readonly', 34 | Email: 'readonly', 35 | EndImpressionRegion: 'readonly', 36 | FilterDefinition: 'readonly', 37 | Folder: 'readonly', 38 | Format: 'readonly', 39 | HTTP: 'readonly', 40 | HTTPHeader: 'readonly', 41 | List: 'readonly', 42 | Logout: 'readonly', 43 | Now: 'readonly', 44 | Platform: 'readonly', 45 | Portfolio: 'readonly', 46 | QueryDefinition: 'readonly', 47 | Redirect: 'readonly', 48 | Request: 'readonly', 49 | Script: 'readonly', 50 | Send: 'readonly', 51 | SendClassification: 'readonly', 52 | SenderProfile: 'readonly', 53 | Stringify: 'readonly', 54 | Subscriber: 'readonly', 55 | Substring: 'readonly', 56 | Template: 'readonly', 57 | TriggeredSend: 'readonly', 58 | Variable: 'readonly', 59 | Write: 'readonly', 60 | }, 61 | }, 62 | rules: { 63 | 'comma-dangle': ['error', 'never'], 64 | 'new-cap': 'off', 65 | 'no-console': 'off', 66 | 'no-extend-native': 'off', 67 | 'no-new': 'error', 68 | 'no-prototype-builtins': 'off', 69 | 'no-throw-literal': 'off', 70 | 'no-use-before-define': ['error', { variables: true, functions: false, classes: false }], 71 | 'no-var': 'off', 72 | }, 73 | }, 74 | legacy: { 75 | recommended: { 76 | overrides: [ 77 | { 78 | files: ['*.ssjs'], 79 | parserOptions: { 80 | ecmaVersion: 3, 81 | }, 82 | rules: { 83 | 'comma-dangle': ['error', 'never'], 84 | 'new-cap': 'off', 85 | 'no-console': 'off', 86 | 'no-extend-native': 'off', 87 | 'no-new': 'error', 88 | 'no-prototype-builtins': 'off', 89 | 'no-throw-literal': 'off', 90 | 'no-use-before-define': ['error', { variables: true, functions: false, classes: false }], 91 | 'no-var': 'off', 92 | }, 93 | globals: { 94 | Account: false, 95 | AccountUser: false, 96 | Attribute: false, 97 | Base64Decode: false, 98 | Base64Encode: false, 99 | BeginImpressionRegion: false, 100 | BounceEvent: false, 101 | ContentArea: false, 102 | ContentAreaByName: false, 103 | ContentAreaObj: false, 104 | DataExtension: false, 105 | DateTime: false, 106 | DeliveryProfile: false, 107 | Email: false, 108 | EndImpressionRegion: false, 109 | FilterDefinition: false, 110 | Folder: false, 111 | Format: false, 112 | HTTP: false, 113 | HTTPHeader: false, 114 | List: false, 115 | Logout: false, 116 | Now: false, 117 | Platform: false, 118 | Portfolio: false, 119 | QueryDefinition: false, 120 | Redirect: false, 121 | Request: false, 122 | Script: false, 123 | Send: false, 124 | SendClassification: false, 125 | SenderProfile: false, 126 | Stringify: false, 127 | Subscriber: false, 128 | Substring: false, 129 | Template: false, 130 | TriggeredSend: false, 131 | Variable: false, 132 | Write: false, 133 | }, 134 | }, 135 | ], 136 | }, 137 | }, 138 | }); 139 | 140 | // for CommonJS 141 | module.exports = eslintConfigSsjs; 142 | -------------------------------------------------------------------------------- /index.d.ts: -------------------------------------------------------------------------------- 1 | import { ESLint, Linter } from 'eslint'; 2 | 3 | interface ESLintSfmcSsjsConfigs { 4 | configs: { 5 | recommended: Linter.FlatConfig; 6 | legacy: { 7 | recommended: Linter.Config; 8 | }; 9 | }; 10 | } 11 | 12 | declare const plugin: ESLintSfmcSsjsConfigs & ESLint.Plugin; 13 | 14 | export = plugin; 15 | -------------------------------------------------------------------------------- /index.mjs: -------------------------------------------------------------------------------- 1 | /** 2 | * Copyright 2020-2024 Jörn Berkefeld / joern.berkefeld@gmail.com 3 | * 4 | * Licensed under the MIT License. 5 | */ 6 | 7 | const eslintConfigSsjs = { 8 | meta: {}, 9 | configs: {}, 10 | rules: {}, 11 | processors: {}, 12 | }; 13 | 14 | // assign configs here so we can reference `plugin` 15 | Object.assign(eslintConfigSsjs.configs, { 16 | recommended: { 17 | languageOptions: { 18 | ecmaVersion: 3, 19 | sourceType: 'script', 20 | globals: { 21 | Account: 'readonly', 22 | AccountUser: 'readonly', 23 | Attribute: 'readonly', 24 | Base64Decode: 'readonly', 25 | Base64Encode: 'readonly', 26 | BeginImpressionRegion: 'readonly', 27 | BounceEvent: 'readonly', 28 | ContentArea: 'readonly', 29 | ContentAreaByName: 'readonly', 30 | ContentAreaObj: 'readonly', 31 | DataExtension: 'readonly', 32 | DateTime: 'readonly', 33 | DeliveryProfile: 'readonly', 34 | Email: 'readonly', 35 | EndImpressionRegion: 'readonly', 36 | FilterDefinition: 'readonly', 37 | Folder: 'readonly', 38 | Format: 'readonly', 39 | HTTP: 'readonly', 40 | HTTPHeader: 'readonly', 41 | List: 'readonly', 42 | Logout: 'readonly', 43 | Now: 'readonly', 44 | Platform: 'readonly', 45 | Portfolio: 'readonly', 46 | QueryDefinition: 'readonly', 47 | Redirect: 'readonly', 48 | Request: 'readonly', 49 | Script: 'readonly', 50 | Send: 'readonly', 51 | SendClassification: 'readonly', 52 | SenderProfile: 'readonly', 53 | Stringify: 'readonly', 54 | Subscriber: 'readonly', 55 | Substring: 'readonly', 56 | Template: 'readonly', 57 | TriggeredSend: 'readonly', 58 | Variable: 'readonly', 59 | Write: 'readonly', 60 | }, 61 | }, 62 | rules: { 63 | 'comma-dangle': ['error', 'never'], 64 | 'new-cap': 'off', 65 | 'no-console': 'off', 66 | 'no-extend-native': 'off', 67 | 'no-new': 'error', 68 | 'no-prototype-builtins': 'off', 69 | 'no-throw-literal': 'off', 70 | 'no-use-before-define': ['error', { variables: true, functions: false, classes: false }], 71 | 'no-var': 'off', 72 | }, 73 | }, 74 | 75 | legacy: { 76 | recommended: { 77 | overrides: [ 78 | { 79 | files: ['*.ssjs'], 80 | parserOptions: { 81 | ecmaVersion: 3, 82 | }, 83 | rules: { 84 | 'comma-dangle': ['error', 'never'], 85 | 'new-cap': 'off', 86 | 'no-console': 'off', 87 | 'no-extend-native': 'off', 88 | 'no-new': 'error', 89 | 'no-prototype-builtins': 'off', 90 | 'no-throw-literal': 'off', 91 | 'no-use-before-define': ['error', { variables: true, functions: false, classes: false }], 92 | 'no-var': 'off', 93 | }, 94 | globals: { 95 | Account: false, 96 | AccountUser: false, 97 | Attribute: false, 98 | Base64Decode: false, 99 | Base64Encode: false, 100 | BeginImpressionRegion: false, 101 | BounceEvent: false, 102 | ContentArea: false, 103 | ContentAreaByName: false, 104 | ContentAreaObj: false, 105 | DataExtension: false, 106 | DateTime: false, 107 | DeliveryProfile: false, 108 | Email: false, 109 | EndImpressionRegion: false, 110 | FilterDefinition: false, 111 | Folder: false, 112 | Format: false, 113 | HTTP: false, 114 | HTTPHeader: false, 115 | List: false, 116 | Logout: false, 117 | Now: false, 118 | Platform: false, 119 | Portfolio: false, 120 | QueryDefinition: false, 121 | Redirect: false, 122 | Request: false, 123 | Script: false, 124 | Send: false, 125 | SendClassification: false, 126 | SenderProfile: false, 127 | Stringify: false, 128 | Subscriber: false, 129 | Substring: false, 130 | Template: false, 131 | TriggeredSend: false, 132 | Variable: false, 133 | Write: false, 134 | }, 135 | }, 136 | ], 137 | }, 138 | }, 139 | }); 140 | 141 | // for ESM 142 | export default eslintConfigSsjs; 143 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "eslint-config-ssjs", 3 | "version": "2.0.0", 4 | "lockfileVersion": 3, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "eslint-config-ssjs", 9 | "version": "2.0.0", 10 | "license": "MIT", 11 | "devDependencies": { 12 | "@eslint/js": "^9.6.0", 13 | "eslint": "^9.6.0", 14 | "globals": "^15.6.0", 15 | "prettier": "^3.3.2" 16 | }, 17 | "engines": { 18 | "node": "^6.14.0 || ^8.10.0 || >=9.10.0" 19 | }, 20 | "peerDependencies": { 21 | "eslint": ">=8.56.0", 22 | "eslint-config-prettier": ">=6.11.0", 23 | "eslint-plugin-prettier": ">=3.1.3", 24 | "prettier": ">=3.0.0" 25 | } 26 | }, 27 | "node_modules/@eslint-community/eslint-utils": { 28 | "version": "4.4.0", 29 | "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.4.0.tgz", 30 | "integrity": "sha512-1/sA4dwrzBAyeUoQ6oxahHKmrZvsnLCg4RfxW3ZFGGmQkSNQPFNLV9CUEFQP1x9EYXHTo5p6xdhZM1Ne9p/AfA==", 31 | "dependencies": { 32 | "eslint-visitor-keys": "^3.3.0" 33 | }, 34 | "engines": { 35 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 36 | }, 37 | "peerDependencies": { 38 | "eslint": "^6.0.0 || ^7.0.0 || >=8.0.0" 39 | } 40 | }, 41 | "node_modules/@eslint-community/eslint-utils/node_modules/eslint-visitor-keys": { 42 | "version": "3.4.3", 43 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz", 44 | "integrity": "sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag==", 45 | "engines": { 46 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0" 47 | }, 48 | "funding": { 49 | "url": "https://opencollective.com/eslint" 50 | } 51 | }, 52 | "node_modules/@eslint-community/regexpp": { 53 | "version": "4.11.0", 54 | "resolved": "https://registry.npmjs.org/@eslint-community/regexpp/-/regexpp-4.11.0.tgz", 55 | "integrity": "sha512-G/M/tIiMrTAxEWRfLfQJMmGNX28IxBg4PBz8XqQhqUHLFI6TL2htpIB1iQCj144V5ee/JaKyT9/WZ0MGZWfA7A==", 56 | "engines": { 57 | "node": "^12.0.0 || ^14.0.0 || >=16.0.0" 58 | } 59 | }, 60 | "node_modules/@eslint/config-array": { 61 | "version": "0.17.0", 62 | "resolved": "https://registry.npmjs.org/@eslint/config-array/-/config-array-0.17.0.tgz", 63 | "integrity": "sha512-A68TBu6/1mHHuc5YJL0U0VVeGNiklLAL6rRmhTCP2B5XjWLMnrX+HkO+IAXyHvks5cyyY1jjK5ITPQ1HGS2EVA==", 64 | "dependencies": { 65 | "@eslint/object-schema": "^2.1.4", 66 | "debug": "^4.3.1", 67 | "minimatch": "^3.1.2" 68 | }, 69 | "engines": { 70 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0" 71 | } 72 | }, 73 | "node_modules/@eslint/eslintrc": { 74 | "version": "3.1.0", 75 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-3.1.0.tgz", 76 | "integrity": "sha512-4Bfj15dVJdoy3RfZmmo86RK1Fwzn6SstsvK9JS+BaVKqC6QQQQyXekNaC+g+LKNgkQ+2VhGAzm6hO40AhMR3zQ==", 77 | "dependencies": { 78 | "ajv": "^6.12.4", 79 | "debug": "^4.3.2", 80 | "espree": "^10.0.1", 81 | "globals": "^14.0.0", 82 | "ignore": "^5.2.0", 83 | "import-fresh": "^3.2.1", 84 | "js-yaml": "^4.1.0", 85 | "minimatch": "^3.1.2", 86 | "strip-json-comments": "^3.1.1" 87 | }, 88 | "engines": { 89 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0" 90 | }, 91 | "funding": { 92 | "url": "https://opencollective.com/eslint" 93 | } 94 | }, 95 | "node_modules/@eslint/eslintrc/node_modules/globals": { 96 | "version": "14.0.0", 97 | "resolved": "https://registry.npmjs.org/globals/-/globals-14.0.0.tgz", 98 | "integrity": "sha512-oahGvuMGQlPw/ivIYBjVSrWAfWLBeku5tpPE2fOPLi+WHffIWbuh2tCjhyQhTBPMf5E9jDEH4FOmTYgYwbKwtQ==", 99 | "engines": { 100 | "node": ">=18" 101 | }, 102 | "funding": { 103 | "url": "https://github.com/sponsors/sindresorhus" 104 | } 105 | }, 106 | "node_modules/@eslint/js": { 107 | "version": "9.6.0", 108 | "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.6.0.tgz", 109 | "integrity": "sha512-D9B0/3vNg44ZeWbYMpBoXqNP4j6eQD5vNwIlGAuFRRzK/WtT/jvDQW3Bi9kkf3PMDMlM7Yi+73VLUsn5bJcl8A==", 110 | "engines": { 111 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0" 112 | } 113 | }, 114 | "node_modules/@eslint/object-schema": { 115 | "version": "2.1.4", 116 | "resolved": "https://registry.npmjs.org/@eslint/object-schema/-/object-schema-2.1.4.tgz", 117 | "integrity": "sha512-BsWiH1yFGjXXS2yvrf5LyuoSIIbPrGUWob917o+BTKuZ7qJdxX8aJLRxs1fS9n6r7vESrq1OUqb68dANcFXuQQ==", 118 | "engines": { 119 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0" 120 | } 121 | }, 122 | "node_modules/@humanwhocodes/module-importer": { 123 | "version": "1.0.1", 124 | "resolved": "https://registry.npmjs.org/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz", 125 | "integrity": "sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA==", 126 | "engines": { 127 | "node": ">=12.22" 128 | }, 129 | "funding": { 130 | "type": "github", 131 | "url": "https://github.com/sponsors/nzakas" 132 | } 133 | }, 134 | "node_modules/@humanwhocodes/retry": { 135 | "version": "0.3.0", 136 | "resolved": "https://registry.npmjs.org/@humanwhocodes/retry/-/retry-0.3.0.tgz", 137 | "integrity": "sha512-d2CGZR2o7fS6sWB7DG/3a95bGKQyHMACZ5aW8qGkkqQpUoZV6C0X7Pc7l4ZNMZkfNBf4VWNe9E1jRsf0G146Ew==", 138 | "engines": { 139 | "node": ">=18.18" 140 | }, 141 | "funding": { 142 | "type": "github", 143 | "url": "https://github.com/sponsors/nzakas" 144 | } 145 | }, 146 | "node_modules/@nodelib/fs.scandir": { 147 | "version": "2.1.5", 148 | "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz", 149 | "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==", 150 | "dependencies": { 151 | "@nodelib/fs.stat": "2.0.5", 152 | "run-parallel": "^1.1.9" 153 | }, 154 | "engines": { 155 | "node": ">= 8" 156 | } 157 | }, 158 | "node_modules/@nodelib/fs.stat": { 159 | "version": "2.0.5", 160 | "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz", 161 | "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==", 162 | "engines": { 163 | "node": ">= 8" 164 | } 165 | }, 166 | "node_modules/@nodelib/fs.walk": { 167 | "version": "1.2.8", 168 | "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz", 169 | "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==", 170 | "dependencies": { 171 | "@nodelib/fs.scandir": "2.1.5", 172 | "fastq": "^1.6.0" 173 | }, 174 | "engines": { 175 | "node": ">= 8" 176 | } 177 | }, 178 | "node_modules/@pkgr/core": { 179 | "version": "0.1.1", 180 | "resolved": "https://registry.npmjs.org/@pkgr/core/-/core-0.1.1.tgz", 181 | "integrity": "sha512-cq8o4cWH0ibXh9VGi5P20Tu9XF/0fFXl9EUinr9QfTM7a7p0oTA4iJRCQWppXR1Pg8dSM0UCItCkPwsk9qWWYA==", 182 | "peer": true, 183 | "engines": { 184 | "node": "^12.20.0 || ^14.18.0 || >=16.0.0" 185 | }, 186 | "funding": { 187 | "url": "https://opencollective.com/unts" 188 | } 189 | }, 190 | "node_modules/acorn": { 191 | "version": "8.12.0", 192 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.12.0.tgz", 193 | "integrity": "sha512-RTvkC4w+KNXrM39/lWCUaG0IbRkWdCv7W/IOW9oU6SawyxulvkQy5HQPVTKxEjczcUvapcrw3cFx/60VN/NRNw==", 194 | "bin": { 195 | "acorn": "bin/acorn" 196 | }, 197 | "engines": { 198 | "node": ">=0.4.0" 199 | } 200 | }, 201 | "node_modules/acorn-jsx": { 202 | "version": "5.3.2", 203 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", 204 | "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", 205 | "peerDependencies": { 206 | "acorn": "^6.0.0 || ^7.0.0 || ^8.0.0" 207 | } 208 | }, 209 | "node_modules/ajv": { 210 | "version": "6.12.6", 211 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", 212 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", 213 | "dependencies": { 214 | "fast-deep-equal": "^3.1.1", 215 | "fast-json-stable-stringify": "^2.0.0", 216 | "json-schema-traverse": "^0.4.1", 217 | "uri-js": "^4.2.2" 218 | }, 219 | "funding": { 220 | "type": "github", 221 | "url": "https://github.com/sponsors/epoberezkin" 222 | } 223 | }, 224 | "node_modules/ansi-regex": { 225 | "version": "5.0.1", 226 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 227 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 228 | "engines": { 229 | "node": ">=8" 230 | } 231 | }, 232 | "node_modules/argparse": { 233 | "version": "2.0.1", 234 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", 235 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==" 236 | }, 237 | "node_modules/balanced-match": { 238 | "version": "1.0.2", 239 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 240 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==" 241 | }, 242 | "node_modules/brace-expansion": { 243 | "version": "1.1.11", 244 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 245 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 246 | "dependencies": { 247 | "balanced-match": "^1.0.0", 248 | "concat-map": "0.0.1" 249 | } 250 | }, 251 | "node_modules/callsites": { 252 | "version": "3.1.0", 253 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 254 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 255 | "engines": { 256 | "node": ">=6" 257 | } 258 | }, 259 | "node_modules/concat-map": { 260 | "version": "0.0.1", 261 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 262 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==" 263 | }, 264 | "node_modules/cross-spawn": { 265 | "version": "7.0.3", 266 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 267 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 268 | "dependencies": { 269 | "path-key": "^3.1.0", 270 | "shebang-command": "^2.0.0", 271 | "which": "^2.0.1" 272 | }, 273 | "engines": { 274 | "node": ">= 8" 275 | } 276 | }, 277 | "node_modules/cross-spawn/node_modules/path-key": { 278 | "version": "3.1.1", 279 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 280 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 281 | "engines": { 282 | "node": ">=8" 283 | } 284 | }, 285 | "node_modules/cross-spawn/node_modules/shebang-command": { 286 | "version": "2.0.0", 287 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 288 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 289 | "dependencies": { 290 | "shebang-regex": "^3.0.0" 291 | }, 292 | "engines": { 293 | "node": ">=8" 294 | } 295 | }, 296 | "node_modules/cross-spawn/node_modules/shebang-regex": { 297 | "version": "3.0.0", 298 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 299 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 300 | "engines": { 301 | "node": ">=8" 302 | } 303 | }, 304 | "node_modules/cross-spawn/node_modules/which": { 305 | "version": "2.0.2", 306 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 307 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 308 | "dependencies": { 309 | "isexe": "^2.0.0" 310 | }, 311 | "bin": { 312 | "node-which": "bin/node-which" 313 | }, 314 | "engines": { 315 | "node": ">= 8" 316 | } 317 | }, 318 | "node_modules/debug": { 319 | "version": "4.3.5", 320 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.5.tgz", 321 | "integrity": "sha512-pt0bNEmneDIvdL1Xsd9oDQ/wrQRkXDT4AUWlNZNPKvW5x/jyO9VFXkJUP07vQ2upmw5PlaITaPKc31jK13V+jg==", 322 | "dependencies": { 323 | "ms": "2.1.2" 324 | }, 325 | "engines": { 326 | "node": ">=6.0" 327 | }, 328 | "peerDependenciesMeta": { 329 | "supports-color": { 330 | "optional": true 331 | } 332 | } 333 | }, 334 | "node_modules/deep-is": { 335 | "version": "0.1.4", 336 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", 337 | "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==" 338 | }, 339 | "node_modules/escape-string-regexp": { 340 | "version": "4.0.0", 341 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", 342 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", 343 | "engines": { 344 | "node": ">=10" 345 | }, 346 | "funding": { 347 | "url": "https://github.com/sponsors/sindresorhus" 348 | } 349 | }, 350 | "node_modules/eslint": { 351 | "version": "9.6.0", 352 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-9.6.0.tgz", 353 | "integrity": "sha512-ElQkdLMEEqQNM9Njff+2Y4q2afHk7JpkPvrd7Xh7xefwgQynqPxwf55J7di9+MEibWUGdNjFF9ITG9Pck5M84w==", 354 | "dependencies": { 355 | "@eslint-community/eslint-utils": "^4.2.0", 356 | "@eslint-community/regexpp": "^4.6.1", 357 | "@eslint/config-array": "^0.17.0", 358 | "@eslint/eslintrc": "^3.1.0", 359 | "@eslint/js": "9.6.0", 360 | "@humanwhocodes/module-importer": "^1.0.1", 361 | "@humanwhocodes/retry": "^0.3.0", 362 | "@nodelib/fs.walk": "^1.2.8", 363 | "ajv": "^6.12.4", 364 | "chalk": "^4.0.0", 365 | "cross-spawn": "^7.0.2", 366 | "debug": "^4.3.2", 367 | "escape-string-regexp": "^4.0.0", 368 | "eslint-scope": "^8.0.1", 369 | "eslint-visitor-keys": "^4.0.0", 370 | "espree": "^10.1.0", 371 | "esquery": "^1.5.0", 372 | "esutils": "^2.0.2", 373 | "fast-deep-equal": "^3.1.3", 374 | "file-entry-cache": "^8.0.0", 375 | "find-up": "^5.0.0", 376 | "glob-parent": "^6.0.2", 377 | "ignore": "^5.2.0", 378 | "imurmurhash": "^0.1.4", 379 | "is-glob": "^4.0.0", 380 | "is-path-inside": "^3.0.3", 381 | "json-stable-stringify-without-jsonify": "^1.0.1", 382 | "levn": "^0.4.1", 383 | "lodash.merge": "^4.6.2", 384 | "minimatch": "^3.1.2", 385 | "natural-compare": "^1.4.0", 386 | "optionator": "^0.9.3", 387 | "strip-ansi": "^6.0.1", 388 | "text-table": "^0.2.0" 389 | }, 390 | "bin": { 391 | "eslint": "bin/eslint.js" 392 | }, 393 | "engines": { 394 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0" 395 | }, 396 | "funding": { 397 | "url": "https://eslint.org/donate" 398 | } 399 | }, 400 | "node_modules/eslint-config-prettier": { 401 | "version": "9.1.0", 402 | "resolved": "https://registry.npmjs.org/eslint-config-prettier/-/eslint-config-prettier-9.1.0.tgz", 403 | "integrity": "sha512-NSWl5BFQWEPi1j4TjVNItzYV7dZXZ+wP6I6ZhrBGpChQhZRUaElihE9uRRkcbRnNb76UMKDF3r+WTmNcGPKsqw==", 404 | "peer": true, 405 | "bin": { 406 | "eslint-config-prettier": "bin/cli.js" 407 | }, 408 | "peerDependencies": { 409 | "eslint": ">=7.0.0" 410 | } 411 | }, 412 | "node_modules/eslint-plugin-prettier": { 413 | "version": "5.1.3", 414 | "resolved": "https://registry.npmjs.org/eslint-plugin-prettier/-/eslint-plugin-prettier-5.1.3.tgz", 415 | "integrity": "sha512-C9GCVAs4Eq7ZC/XFQHITLiHJxQngdtraXaM+LoUFoFp/lHNl2Zn8f3WQbe9HvTBBQ9YnKFB0/2Ajdqwo5D1EAw==", 416 | "peer": true, 417 | "dependencies": { 418 | "prettier-linter-helpers": "^1.0.0", 419 | "synckit": "^0.8.6" 420 | }, 421 | "engines": { 422 | "node": "^14.18.0 || >=16.0.0" 423 | }, 424 | "funding": { 425 | "url": "https://opencollective.com/eslint-plugin-prettier" 426 | }, 427 | "peerDependencies": { 428 | "@types/eslint": ">=8.0.0", 429 | "eslint": ">=8.0.0", 430 | "eslint-config-prettier": "*", 431 | "prettier": ">=3.0.0" 432 | }, 433 | "peerDependenciesMeta": { 434 | "@types/eslint": { 435 | "optional": true 436 | }, 437 | "eslint-config-prettier": { 438 | "optional": true 439 | } 440 | } 441 | }, 442 | "node_modules/eslint-scope": { 443 | "version": "8.0.1", 444 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-8.0.1.tgz", 445 | "integrity": "sha512-pL8XjgP4ZOmmwfFE8mEhSxA7ZY4C+LWyqjQ3o4yWkkmD0qcMT9kkW3zWHOczhWcjTSgqycYAgwSlXvZltv65og==", 446 | "dependencies": { 447 | "esrecurse": "^4.3.0", 448 | "estraverse": "^5.2.0" 449 | }, 450 | "engines": { 451 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0" 452 | }, 453 | "funding": { 454 | "url": "https://opencollective.com/eslint" 455 | } 456 | }, 457 | "node_modules/eslint-visitor-keys": { 458 | "version": "4.0.0", 459 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-4.0.0.tgz", 460 | "integrity": "sha512-OtIRv/2GyiF6o/d8K7MYKKbXrOUBIK6SfkIRM4Z0dY3w+LiQ0vy3F57m0Z71bjbyeiWFiHJ8brqnmE6H6/jEuw==", 461 | "engines": { 462 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0" 463 | }, 464 | "funding": { 465 | "url": "https://opencollective.com/eslint" 466 | } 467 | }, 468 | "node_modules/eslint/node_modules/ansi-styles": { 469 | "version": "4.3.0", 470 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 471 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 472 | "dependencies": { 473 | "color-convert": "^2.0.1" 474 | }, 475 | "engines": { 476 | "node": ">=8" 477 | }, 478 | "funding": { 479 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 480 | } 481 | }, 482 | "node_modules/eslint/node_modules/chalk": { 483 | "version": "4.1.0", 484 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz", 485 | "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==", 486 | "dependencies": { 487 | "ansi-styles": "^4.1.0", 488 | "supports-color": "^7.1.0" 489 | }, 490 | "engines": { 491 | "node": ">=10" 492 | }, 493 | "funding": { 494 | "url": "https://github.com/chalk/chalk?sponsor=1" 495 | } 496 | }, 497 | "node_modules/eslint/node_modules/color-convert": { 498 | "version": "2.0.1", 499 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 500 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 501 | "dependencies": { 502 | "color-name": "~1.1.4" 503 | }, 504 | "engines": { 505 | "node": ">=7.0.0" 506 | } 507 | }, 508 | "node_modules/eslint/node_modules/color-name": { 509 | "version": "1.1.4", 510 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 511 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" 512 | }, 513 | "node_modules/eslint/node_modules/has-flag": { 514 | "version": "4.0.0", 515 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 516 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 517 | "engines": { 518 | "node": ">=8" 519 | } 520 | }, 521 | "node_modules/eslint/node_modules/supports-color": { 522 | "version": "7.2.0", 523 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 524 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 525 | "dependencies": { 526 | "has-flag": "^4.0.0" 527 | }, 528 | "engines": { 529 | "node": ">=8" 530 | } 531 | }, 532 | "node_modules/espree": { 533 | "version": "10.1.0", 534 | "resolved": "https://registry.npmjs.org/espree/-/espree-10.1.0.tgz", 535 | "integrity": "sha512-M1M6CpiE6ffoigIOWYO9UDP8TMUw9kqb21tf+08IgDYjCsOvCuDt4jQcZmoYxx+w7zlKw9/N0KXfto+I8/FrXA==", 536 | "dependencies": { 537 | "acorn": "^8.12.0", 538 | "acorn-jsx": "^5.3.2", 539 | "eslint-visitor-keys": "^4.0.0" 540 | }, 541 | "engines": { 542 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0" 543 | }, 544 | "funding": { 545 | "url": "https://opencollective.com/eslint" 546 | } 547 | }, 548 | "node_modules/esquery": { 549 | "version": "1.5.0", 550 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.5.0.tgz", 551 | "integrity": "sha512-YQLXUplAwJgCydQ78IMJywZCceoqk1oH01OERdSAJc/7U2AylwjhSCLDEtqwg811idIS/9fIU5GjG73IgjKMVg==", 552 | "dependencies": { 553 | "estraverse": "^5.1.0" 554 | }, 555 | "engines": { 556 | "node": ">=0.10" 557 | } 558 | }, 559 | "node_modules/esrecurse": { 560 | "version": "4.3.0", 561 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", 562 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", 563 | "dependencies": { 564 | "estraverse": "^5.2.0" 565 | }, 566 | "engines": { 567 | "node": ">=4.0" 568 | } 569 | }, 570 | "node_modules/estraverse": { 571 | "version": "5.3.0", 572 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", 573 | "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", 574 | "engines": { 575 | "node": ">=4.0" 576 | } 577 | }, 578 | "node_modules/esutils": { 579 | "version": "2.0.3", 580 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 581 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 582 | "engines": { 583 | "node": ">=0.10.0" 584 | } 585 | }, 586 | "node_modules/fast-deep-equal": { 587 | "version": "3.1.3", 588 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", 589 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==" 590 | }, 591 | "node_modules/fast-diff": { 592 | "version": "1.3.0", 593 | "resolved": "https://registry.npmjs.org/fast-diff/-/fast-diff-1.3.0.tgz", 594 | "integrity": "sha512-VxPP4NqbUjj6MaAOafWeUn2cXWLcCtljklUtZf0Ind4XQ+QPtmA0b18zZy0jIQx+ExRVCR/ZQpBmik5lXshNsw==", 595 | "peer": true 596 | }, 597 | "node_modules/fast-json-stable-stringify": { 598 | "version": "2.1.0", 599 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 600 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==" 601 | }, 602 | "node_modules/fast-levenshtein": { 603 | "version": "2.0.6", 604 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 605 | "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==" 606 | }, 607 | "node_modules/fastq": { 608 | "version": "1.17.1", 609 | "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.17.1.tgz", 610 | "integrity": "sha512-sRVD3lWVIXWg6By68ZN7vho9a1pQcN/WBFaAAsDDFzlJjvoGx0P8z7V1t72grFJfJhu3YPZBuu25f7Kaw2jN1w==", 611 | "dependencies": { 612 | "reusify": "^1.0.4" 613 | } 614 | }, 615 | "node_modules/file-entry-cache": { 616 | "version": "8.0.0", 617 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-8.0.0.tgz", 618 | "integrity": "sha512-XXTUwCvisa5oacNGRP9SfNtYBNAMi+RPwBFmblZEF7N7swHYQS6/Zfk7SRwx4D5j3CH211YNRco1DEMNVfZCnQ==", 619 | "dependencies": { 620 | "flat-cache": "^4.0.0" 621 | }, 622 | "engines": { 623 | "node": ">=16.0.0" 624 | } 625 | }, 626 | "node_modules/find-up": { 627 | "version": "5.0.0", 628 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", 629 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", 630 | "dependencies": { 631 | "locate-path": "^6.0.0", 632 | "path-exists": "^4.0.0" 633 | }, 634 | "engines": { 635 | "node": ">=10" 636 | }, 637 | "funding": { 638 | "url": "https://github.com/sponsors/sindresorhus" 639 | } 640 | }, 641 | "node_modules/flat-cache": { 642 | "version": "4.0.1", 643 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-4.0.1.tgz", 644 | "integrity": "sha512-f7ccFPK3SXFHpx15UIGyRJ/FJQctuKZ0zVuN3frBo4HnK3cay9VEW0R6yPYFHC0AgqhukPzKjq22t5DmAyqGyw==", 645 | "dependencies": { 646 | "flatted": "^3.2.9", 647 | "keyv": "^4.5.4" 648 | }, 649 | "engines": { 650 | "node": ">=16" 651 | } 652 | }, 653 | "node_modules/flatted": { 654 | "version": "3.3.1", 655 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.3.1.tgz", 656 | "integrity": "sha512-X8cqMLLie7KsNUDSdzeN8FYK9rEt4Dt67OsG/DNGnYTSDBG4uFAJFBnUeiV+zCVAvwFy56IjM9sH51jVaEhNxw==" 657 | }, 658 | "node_modules/glob-parent": { 659 | "version": "6.0.2", 660 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", 661 | "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==", 662 | "dependencies": { 663 | "is-glob": "^4.0.3" 664 | }, 665 | "engines": { 666 | "node": ">=10.13.0" 667 | } 668 | }, 669 | "node_modules/globals": { 670 | "version": "15.6.0", 671 | "resolved": "https://registry.npmjs.org/globals/-/globals-15.6.0.tgz", 672 | "integrity": "sha512-UzcJi88Hw//CurUIRa9Jxb0vgOCcuD/MNjwmXp633cyaRKkCWACkoqHCtfZv43b1kqXGg/fpOa8bwgacCeXsVg==", 673 | "dev": true, 674 | "engines": { 675 | "node": ">=18" 676 | }, 677 | "funding": { 678 | "url": "https://github.com/sponsors/sindresorhus" 679 | } 680 | }, 681 | "node_modules/ignore": { 682 | "version": "5.3.1", 683 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.3.1.tgz", 684 | "integrity": "sha512-5Fytz/IraMjqpwfd34ke28PTVMjZjJG2MPn5t7OE4eUCUNf8BAa7b5WUS9/Qvr6mwOQS7Mk6vdsMno5he+T8Xw==", 685 | "engines": { 686 | "node": ">= 4" 687 | } 688 | }, 689 | "node_modules/import-fresh": { 690 | "version": "3.3.0", 691 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", 692 | "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", 693 | "dependencies": { 694 | "parent-module": "^1.0.0", 695 | "resolve-from": "^4.0.0" 696 | }, 697 | "engines": { 698 | "node": ">=6" 699 | }, 700 | "funding": { 701 | "url": "https://github.com/sponsors/sindresorhus" 702 | } 703 | }, 704 | "node_modules/imurmurhash": { 705 | "version": "0.1.4", 706 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 707 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 708 | "engines": { 709 | "node": ">=0.8.19" 710 | } 711 | }, 712 | "node_modules/is-extglob": { 713 | "version": "2.1.1", 714 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 715 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 716 | "engines": { 717 | "node": ">=0.10.0" 718 | } 719 | }, 720 | "node_modules/is-glob": { 721 | "version": "4.0.3", 722 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 723 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 724 | "dependencies": { 725 | "is-extglob": "^2.1.1" 726 | }, 727 | "engines": { 728 | "node": ">=0.10.0" 729 | } 730 | }, 731 | "node_modules/is-path-inside": { 732 | "version": "3.0.3", 733 | "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-3.0.3.tgz", 734 | "integrity": "sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ==", 735 | "engines": { 736 | "node": ">=8" 737 | } 738 | }, 739 | "node_modules/isexe": { 740 | "version": "2.0.0", 741 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 742 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=" 743 | }, 744 | "node_modules/js-yaml": { 745 | "version": "4.1.0", 746 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", 747 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", 748 | "dependencies": { 749 | "argparse": "^2.0.1" 750 | }, 751 | "bin": { 752 | "js-yaml": "bin/js-yaml.js" 753 | } 754 | }, 755 | "node_modules/json-buffer": { 756 | "version": "3.0.1", 757 | "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.1.tgz", 758 | "integrity": "sha512-4bV5BfR2mqfQTJm+V5tPPdf+ZpuhiIvTuAB5g8kcrXOZpTT/QwwVRWBywX1ozr6lEuPdbHxwaJlm9G6mI2sfSQ==" 759 | }, 760 | "node_modules/json-schema-traverse": { 761 | "version": "0.4.1", 762 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 763 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==" 764 | }, 765 | "node_modules/json-stable-stringify-without-jsonify": { 766 | "version": "1.0.1", 767 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 768 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=" 769 | }, 770 | "node_modules/keyv": { 771 | "version": "4.5.4", 772 | "resolved": "https://registry.npmjs.org/keyv/-/keyv-4.5.4.tgz", 773 | "integrity": "sha512-oxVHkHR/EJf2CNXnWxRLW6mg7JyCCUcG0DtEGmL2ctUo1PNTin1PUil+r/+4r5MpVgC/fn1kjsx7mjSujKqIpw==", 774 | "dependencies": { 775 | "json-buffer": "3.0.1" 776 | } 777 | }, 778 | "node_modules/levn": { 779 | "version": "0.4.1", 780 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", 781 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", 782 | "dependencies": { 783 | "prelude-ls": "^1.2.1", 784 | "type-check": "~0.4.0" 785 | }, 786 | "engines": { 787 | "node": ">= 0.8.0" 788 | } 789 | }, 790 | "node_modules/locate-path": { 791 | "version": "6.0.0", 792 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", 793 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", 794 | "dependencies": { 795 | "p-locate": "^5.0.0" 796 | }, 797 | "engines": { 798 | "node": ">=10" 799 | }, 800 | "funding": { 801 | "url": "https://github.com/sponsors/sindresorhus" 802 | } 803 | }, 804 | "node_modules/lodash.merge": { 805 | "version": "4.6.2", 806 | "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", 807 | "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==" 808 | }, 809 | "node_modules/minimatch": { 810 | "version": "3.1.2", 811 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 812 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 813 | "dependencies": { 814 | "brace-expansion": "^1.1.7" 815 | }, 816 | "engines": { 817 | "node": "*" 818 | } 819 | }, 820 | "node_modules/ms": { 821 | "version": "2.1.2", 822 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 823 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 824 | }, 825 | "node_modules/natural-compare": { 826 | "version": "1.4.0", 827 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 828 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=" 829 | }, 830 | "node_modules/optionator": { 831 | "version": "0.9.4", 832 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.4.tgz", 833 | "integrity": "sha512-6IpQ7mKUxRcZNLIObR0hz7lxsapSSIYNZJwXPGeF0mTVqGKFIXj1DQcMoT22S3ROcLyY/rz0PWaWZ9ayWmad9g==", 834 | "dependencies": { 835 | "deep-is": "^0.1.3", 836 | "fast-levenshtein": "^2.0.6", 837 | "levn": "^0.4.1", 838 | "prelude-ls": "^1.2.1", 839 | "type-check": "^0.4.0", 840 | "word-wrap": "^1.2.5" 841 | }, 842 | "engines": { 843 | "node": ">= 0.8.0" 844 | } 845 | }, 846 | "node_modules/p-limit": { 847 | "version": "3.1.0", 848 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", 849 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", 850 | "dependencies": { 851 | "yocto-queue": "^0.1.0" 852 | }, 853 | "engines": { 854 | "node": ">=10" 855 | }, 856 | "funding": { 857 | "url": "https://github.com/sponsors/sindresorhus" 858 | } 859 | }, 860 | "node_modules/p-locate": { 861 | "version": "5.0.0", 862 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", 863 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", 864 | "dependencies": { 865 | "p-limit": "^3.0.2" 866 | }, 867 | "engines": { 868 | "node": ">=10" 869 | }, 870 | "funding": { 871 | "url": "https://github.com/sponsors/sindresorhus" 872 | } 873 | }, 874 | "node_modules/parent-module": { 875 | "version": "1.0.1", 876 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 877 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 878 | "dependencies": { 879 | "callsites": "^3.0.0" 880 | }, 881 | "engines": { 882 | "node": ">=6" 883 | } 884 | }, 885 | "node_modules/path-exists": { 886 | "version": "4.0.0", 887 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 888 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 889 | "engines": { 890 | "node": ">=8" 891 | } 892 | }, 893 | "node_modules/prelude-ls": { 894 | "version": "1.2.1", 895 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", 896 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", 897 | "engines": { 898 | "node": ">= 0.8.0" 899 | } 900 | }, 901 | "node_modules/prettier": { 902 | "version": "3.3.2", 903 | "resolved": "https://registry.npmjs.org/prettier/-/prettier-3.3.2.tgz", 904 | "integrity": "sha512-rAVeHYMcv8ATV5d508CFdn+8/pHPpXeIid1DdrPwXnaAdH7cqjVbpJaT5eq4yRAFU/lsbwYwSF/n5iNrdJHPQA==", 905 | "bin": { 906 | "prettier": "bin/prettier.cjs" 907 | }, 908 | "engines": { 909 | "node": ">=14" 910 | }, 911 | "funding": { 912 | "url": "https://github.com/prettier/prettier?sponsor=1" 913 | } 914 | }, 915 | "node_modules/prettier-linter-helpers": { 916 | "version": "1.0.0", 917 | "resolved": "https://registry.npmjs.org/prettier-linter-helpers/-/prettier-linter-helpers-1.0.0.tgz", 918 | "integrity": "sha512-GbK2cP9nraSSUF9N2XwUwqfzlAFlMNYYl+ShE/V+H8a9uNl/oUqB1w2EL54Jh0OlyRSd8RfWYJ3coVS4TROP2w==", 919 | "peer": true, 920 | "dependencies": { 921 | "fast-diff": "^1.1.2" 922 | }, 923 | "engines": { 924 | "node": ">=6.0.0" 925 | } 926 | }, 927 | "node_modules/punycode": { 928 | "version": "2.3.1", 929 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz", 930 | "integrity": "sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==", 931 | "engines": { 932 | "node": ">=6" 933 | } 934 | }, 935 | "node_modules/queue-microtask": { 936 | "version": "1.2.3", 937 | "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", 938 | "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==", 939 | "funding": [ 940 | { 941 | "type": "github", 942 | "url": "https://github.com/sponsors/feross" 943 | }, 944 | { 945 | "type": "patreon", 946 | "url": "https://www.patreon.com/feross" 947 | }, 948 | { 949 | "type": "consulting", 950 | "url": "https://feross.org/support" 951 | } 952 | ] 953 | }, 954 | "node_modules/resolve-from": { 955 | "version": "4.0.0", 956 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 957 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 958 | "engines": { 959 | "node": ">=4" 960 | } 961 | }, 962 | "node_modules/reusify": { 963 | "version": "1.0.4", 964 | "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz", 965 | "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==", 966 | "engines": { 967 | "iojs": ">=1.0.0", 968 | "node": ">=0.10.0" 969 | } 970 | }, 971 | "node_modules/run-parallel": { 972 | "version": "1.2.0", 973 | "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz", 974 | "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==", 975 | "funding": [ 976 | { 977 | "type": "github", 978 | "url": "https://github.com/sponsors/feross" 979 | }, 980 | { 981 | "type": "patreon", 982 | "url": "https://www.patreon.com/feross" 983 | }, 984 | { 985 | "type": "consulting", 986 | "url": "https://feross.org/support" 987 | } 988 | ], 989 | "dependencies": { 990 | "queue-microtask": "^1.2.2" 991 | } 992 | }, 993 | "node_modules/strip-ansi": { 994 | "version": "6.0.1", 995 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 996 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 997 | "dependencies": { 998 | "ansi-regex": "^5.0.1" 999 | }, 1000 | "engines": { 1001 | "node": ">=8" 1002 | } 1003 | }, 1004 | "node_modules/strip-json-comments": { 1005 | "version": "3.1.1", 1006 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", 1007 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", 1008 | "engines": { 1009 | "node": ">=8" 1010 | }, 1011 | "funding": { 1012 | "url": "https://github.com/sponsors/sindresorhus" 1013 | } 1014 | }, 1015 | "node_modules/synckit": { 1016 | "version": "0.8.8", 1017 | "resolved": "https://registry.npmjs.org/synckit/-/synckit-0.8.8.tgz", 1018 | "integrity": "sha512-HwOKAP7Wc5aRGYdKH+dw0PRRpbO841v2DENBtjnR5HFWoiNByAl7vrx3p0G/rCyYXQsrxqtX48TImFtPcIHSpQ==", 1019 | "peer": true, 1020 | "dependencies": { 1021 | "@pkgr/core": "^0.1.0", 1022 | "tslib": "^2.6.2" 1023 | }, 1024 | "engines": { 1025 | "node": "^14.18.0 || >=16.0.0" 1026 | }, 1027 | "funding": { 1028 | "url": "https://opencollective.com/unts" 1029 | } 1030 | }, 1031 | "node_modules/text-table": { 1032 | "version": "0.2.0", 1033 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 1034 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=" 1035 | }, 1036 | "node_modules/tslib": { 1037 | "version": "2.6.3", 1038 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.6.3.tgz", 1039 | "integrity": "sha512-xNvxJEOUiWPGhUuUdQgAJPKOOJfGnIyKySOc09XkKsgdUV/3E2zvwZYdejjmRgPCgcym1juLH3226yA7sEFJKQ==", 1040 | "peer": true 1041 | }, 1042 | "node_modules/type-check": { 1043 | "version": "0.4.0", 1044 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", 1045 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", 1046 | "dependencies": { 1047 | "prelude-ls": "^1.2.1" 1048 | }, 1049 | "engines": { 1050 | "node": ">= 0.8.0" 1051 | } 1052 | }, 1053 | "node_modules/uri-js": { 1054 | "version": "4.4.1", 1055 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", 1056 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", 1057 | "dependencies": { 1058 | "punycode": "^2.1.0" 1059 | } 1060 | }, 1061 | "node_modules/word-wrap": { 1062 | "version": "1.2.5", 1063 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.5.tgz", 1064 | "integrity": "sha512-BN22B5eaMMI9UMtjrGd5g5eCYPpCPDUy0FJXbYsaT5zYxjFOckS53SQDE3pWkVoWpHXVb3BrYcEN4Twa55B5cA==", 1065 | "engines": { 1066 | "node": ">=0.10.0" 1067 | } 1068 | }, 1069 | "node_modules/yocto-queue": { 1070 | "version": "0.1.0", 1071 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", 1072 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", 1073 | "engines": { 1074 | "node": ">=10" 1075 | }, 1076 | "funding": { 1077 | "url": "https://github.com/sponsors/sindresorhus" 1078 | } 1079 | } 1080 | } 1081 | } 1082 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "eslint-config-ssjs", 3 | "version": "2.0.0", 4 | "description": "ESLint config for Salesforce Marketing Cloud's Server-Side JavaScript", 5 | "main": "index.mjs", 6 | "exports": { 7 | ".": { 8 | "types": "./index.d.ts", 9 | "import": "./index.mjs", 10 | "require": "./index.cjs" 11 | } 12 | }, 13 | "scripts": {}, 14 | "engines": { 15 | "node": "^6.14.0 || ^8.10.0 || >=9.10.0" 16 | }, 17 | "repository": { 18 | "type": "git", 19 | "url": "git+https://github.com/JoernBerkefeld/eslint-config-ssjs.git" 20 | }, 21 | "keywords": [ 22 | "ssjs", 23 | "eslint", 24 | "eslint-config", 25 | "eslintconfig", 26 | "sfmc", 27 | "linter", 28 | "jshint", 29 | "jslint", 30 | "quality" 31 | ], 32 | "author": "joern.berkefeld@gmail.com", 33 | "license": "MIT", 34 | "bugs": { 35 | "url": "https://github.com/JoernBerkefeld/eslint-config-ssjs/issues" 36 | }, 37 | "homepage": "https://github.com/JoernBerkefeld/eslint-config-ssjs#readme", 38 | "devDependencies": { 39 | "@eslint/js": "^9.6.0", 40 | "eslint": "^9.6.0", 41 | "globals": "^15.6.0", 42 | "prettier": "^3.3.2" 43 | }, 44 | "peerDependencies": { 45 | "eslint": ">=8.56.0", 46 | "eslint-config-prettier": ">=6.11.0", 47 | "eslint-plugin-prettier": ">=3.1.3", 48 | "prettier": ">=3.0.0" 49 | } 50 | } 51 | --------------------------------------------------------------------------------