From fc57f87a20f3e7aeaa1d58ffb7bfc44ce2dfbe27 Mon Sep 17 00:00:00 2001 From: Russel Van Tuyl Date: Wed, 3 Jan 2024 09:41:47 -0500 Subject: [PATCH] Upgraded Go modules and Dockerfile --- .github/workflows/qodana.yml | 19 +- .github/workflows/qodana_pr.yml | 33 + .qodana/qodana.sarif.json | 21908 ++++++++++++++++++++++++++++++ Dockerfile | 12 +- Makefile | 8 +- docs/CHANGELOG.MD | 17 + go.mod | 28 +- go.sum | 68 +- 8 files changed, 22033 insertions(+), 60 deletions(-) create mode 100644 .github/workflows/qodana_pr.yml create mode 100644 .qodana/qodana.sarif.json diff --git a/.github/workflows/qodana.yml b/.github/workflows/qodana.yml index 2df0ab6e..448b239c 100644 --- a/.github/workflows/qodana.yml +++ b/.github/workflows/qodana.yml @@ -1,8 +1,19 @@ -name: Qodana +name: "Qodana: Push" + on: workflow_dispatch: - pull_request: push: + paths-ignore: + - '.github/**' + - 'data/**' + - 'docs/**' + - '.gitattributes' + - '.gitignore' + - '.gitmodules' + - 'qodana.yaml' + - 'qodana.sarif.json' + - 'LICENSE' + - 'README.MD' jobs: @@ -19,6 +30,8 @@ jobs: ref: ${{ github.event.pull_request.head.sha }} # to check out the actual pull request commit, not the merge commit fetch-depth: 0 # a full history is required for pull request analysis - name: 'Qodana Scan' - uses: JetBrains/qodana-action@v2023.2 + uses: JetBrains/qodana-action@v2023.3 + with: + args: --baseline,.qodana/qodana.sarif.json env: QODANA_TOKEN: ${{ secrets.QODANA_TOKEN }} diff --git a/.github/workflows/qodana_pr.yml b/.github/workflows/qodana_pr.yml new file mode 100644 index 00000000..8d53a847 --- /dev/null +++ b/.github/workflows/qodana_pr.yml @@ -0,0 +1,33 @@ +name: "Qodana: Pull Request" + +on: + workflow_dispatch: + pull_request: + paths-ignore: + - '.github/**' + - 'data/**' + - 'docs/**' + - '.gitattributes' + - '.gitignore' + - '.gitmodules' + - 'LICENSE' + - 'README.MD' + +jobs: + qodana: + name: 'Qodana Job' + runs-on: ubuntu-latest + permissions: + contents: write + pull-requests: write + checks: write + steps: + - uses: actions/checkout@v3 + with: + ref: ${{ github.event.pull_request.head.sha }} # to check out the actual pull request commit, not the merge commit + fetch-depth: 0 # a full history is required for pull request analysis + - name: 'Qodana Scan' + uses: JetBrains/qodana-action@v2023.3 + with: + args: -l,jetbrains/qodana-go:2023.3-eap,--baseline,.qodana/qodana.sarif.json + pr-mode: false \ No newline at end of file diff --git a/.qodana/qodana.sarif.json b/.qodana/qodana.sarif.json new file mode 100644 index 00000000..64f47531 --- /dev/null +++ b/.qodana/qodana.sarif.json @@ -0,0 +1,21908 @@ +{ + "$schema": "https://raw.githubusercontent.com/schemastore/schemastore/master/src/schemas/json/sarif-2.1.0-rtm.5.json", + "version": "2.1.0", + "runs": [ + { + "tool": { + "driver": { + "name": "QDGO", + "fullName": "Qodana for Go", + "version": "233.13017.73", + "rules": [], + "taxa": [ + { + "id": "EditorConfig", + "name": "EditorConfig" + }, + { + "id": "JavaScript and TypeScript", + "name": "JavaScript and TypeScript" + }, + { + "id": "JavaScript and TypeScript/Control flow issues", + "name": "Control flow issues", + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript", + "index": 1, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "Go", + "name": "Go" + }, + { + "id": "Go/Probable bugs", + "name": "Probable bugs", + "relationships": [ + { + "target": { + "id": "Go", + "index": 3, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "Go/Declaration redundancy", + "name": "Declaration redundancy", + "relationships": [ + { + "target": { + "id": "Go", + "index": 3, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "Shell script", + "name": "Shell script" + }, + { + "id": "JavaScript and TypeScript/Unit testing", + "name": "Unit testing", + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript", + "index": 1, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JSON and JSON5", + "name": "JSON and JSON5" + }, + { + "id": "JavaScript and TypeScript/Code style issues", + "name": "Code style issues", + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript", + "index": 1, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JavaScript and TypeScript/General", + "name": "General", + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript", + "index": 1, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JavaScript and TypeScript/Potentially undesirable code constructs", + "name": "Potentially undesirable code constructs", + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript", + "index": 1, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JavaScript and TypeScript/Flow type checker", + "name": "Flow type checker", + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript", + "index": 1, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JavaScript and TypeScript/Probable bugs", + "name": "Probable bugs", + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript", + "index": 1, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "HTML", + "name": "HTML" + }, + { + "id": "JavaScript and TypeScript/Unused symbols", + "name": "Unused symbols", + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript", + "index": 1, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JavaScript and TypeScript/Data flow", + "name": "Data flow", + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript", + "index": 1, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JavaScript and TypeScript/Bitwise operation issues", + "name": "Bitwise operation issues", + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript", + "index": 1, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JavaScript and TypeScript/ES2015 migration aids", + "name": "ES2015 migration aids", + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript", + "index": 1, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "General", + "name": "General" + }, + { + "id": "HTML/Accessibility", + "name": "Accessibility", + "relationships": [ + { + "target": { + "id": "HTML", + "index": 14, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JavaScript and TypeScript/React", + "name": "React", + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript", + "index": 1, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JavaScript and TypeScript/TypeScript", + "name": "TypeScript", + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript", + "index": 1, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JavaScript and TypeScript/Validity issues", + "name": "Validity issues", + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript", + "index": 1, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JavaScript and TypeScript/Potentially confusing code constructs", + "name": "Potentially confusing code constructs", + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript", + "index": 1, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "CSS", + "name": "CSS" + }, + { + "id": "CSS/Invalid elements", + "name": "Invalid elements", + "relationships": [ + { + "target": { + "id": "CSS", + "index": 25, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JavaScript and TypeScript/Try statement issues", + "name": "Try statement issues", + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript", + "index": 1, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "Structural search", + "name": "Structural search" + }, + { + "id": "JavaScript and TypeScript/Function metrics", + "name": "Function metrics", + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript", + "index": 1, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "Dependency analysis", + "name": "Dependency analysis" + }, + { + "id": "Go/Code style issues", + "name": "Code style issues", + "relationships": [ + { + "target": { + "id": "Go", + "index": 3, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "YAML", + "name": "YAML" + }, + { + "id": "XML", + "name": "XML" + }, + { + "id": "JavaScript and TypeScript/Assignment issues", + "name": "Assignment issues", + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript", + "index": 1, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "CSS/Code style issues", + "name": "Code style issues", + "relationships": [ + { + "target": { + "id": "CSS", + "index": 25, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "Go/Security", + "name": "Security", + "relationships": [ + { + "target": { + "id": "Go", + "index": 3, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "RegExp", + "name": "RegExp" + }, + { + "id": "Go/General", + "name": "General", + "relationships": [ + { + "target": { + "id": "Go", + "index": 3, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JavaScript and TypeScript/Node.js", + "name": "Node.js", + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript", + "index": 1, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "Go Template", + "name": "Go Template" + }, + { + "id": "Go Template/General", + "name": "General", + "relationships": [ + { + "target": { + "id": "Go Template", + "index": 40, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JavaScript and TypeScript/Imports and dependencies", + "name": "Imports and dependencies", + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript", + "index": 1, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "RELAX NG", + "name": "RELAX NG" + }, + { + "id": "Code Coverage", + "name": "Code Coverage" + }, + { + "id": "CSS/Probable bugs", + "name": "Probable bugs", + "relationships": [ + { + "target": { + "id": "CSS", + "index": 25, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JavaScript and TypeScript/Naming conventions", + "name": "Naming conventions", + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript", + "index": 1, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JavaScript and TypeScript/Switch statement issues", + "name": "Switch statement issues", + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript", + "index": 1, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JavaScript and TypeScript/DOM issues", + "name": "DOM issues", + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript", + "index": 1, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JavaScript and TypeScript/Async code and promises", + "name": "Async code and promises", + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript", + "index": 1, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "Go/Control flow issues", + "name": "Control flow issues", + "relationships": [ + { + "target": { + "id": "Go", + "index": 3, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JavaScript and TypeScript/Code quality tools", + "name": "Code quality tools", + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript", + "index": 1, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "Proofreading", + "name": "Proofreading" + }, + { + "id": "Go modules", + "name": "Go modules" + }, + { + "id": "Go modules/Declaration redundancy", + "name": "Declaration redundancy", + "relationships": [ + { + "target": { + "id": "Go modules", + "index": 53, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "Security", + "name": "Security" + }, + { + "id": "CSS/Code quality tools", + "name": "Code quality tools", + "relationships": [ + { + "target": { + "id": "CSS", + "index": 25, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "Go modules/Dependency issues (go list -m -u)", + "name": "Dependency issues (go list -m -u)", + "relationships": [ + { + "target": { + "id": "Go modules", + "index": 53, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "Go modules/General", + "name": "General", + "relationships": [ + { + "target": { + "id": "Go modules", + "index": 53, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "Qodana", + "name": "Qodana" + }, + { + "id": "JavaScript and TypeScript/Security", + "name": "Security", + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript", + "index": 1, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "Internationalization", + "name": "Internationalization" + }, + { + "id": "Version control", + "name": "Version control" + } + ], + "language": "en-US", + "contents": [ + "localizedData", + "nonLocalizedData" + ], + "isComprehensive": false + }, + "extensions": [ + { + "name": "org.editorconfig.editorconfigjetbrains", + "version": "233.13017", + "rules": [ + { + "id": "EditorConfigCharClassRedundancy", + "shortDescription": { + "text": "Unnecessary character class" + }, + "fullDescription": { + "text": "Reports character classes that consist of a single character. Such classes can be simplified to a character, for example '[a]'→'a'.", + "markdown": "Reports character classes that consist of a single character. Such classes can be simplified to a character, for example `[a]`→`a`." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "EditorConfigCharClassRedundancy", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "EditorConfig", + "index": 0, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "EditorConfigRootDeclarationUniqueness", + "shortDescription": { + "text": "Extra top-level declaration" + }, + "fullDescription": { + "text": "Reports multiple top-level declarations. There can be only one optional “root=true” top-level declaration in the EditorConfig file. Using multiple top-level declarations is not allowed.", + "markdown": "Reports multiple top-level declarations. There can be only one optional \"root=true\" top-level declaration in the EditorConfig file. Using multiple top-level declarations is not allowed." + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "EditorConfigRootDeclarationUniqueness", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "EditorConfig", + "index": 0, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "EditorConfigNumerousWildcards", + "shortDescription": { + "text": "Too many wildcards" + }, + "fullDescription": { + "text": "Reports sections that contain too many wildcards. Using a lot of wildcards may lead to performance issues.", + "markdown": "Reports sections that contain too many wildcards. Using a lot of wildcards may lead to performance issues." + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "EditorConfigNumerousWildcards", + "ideaSeverity": "WEAK WARNING", + "qodanaSeverity": "Moderate" + } + }, + "relationships": [ + { + "target": { + "id": "EditorConfig", + "index": 0, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "EditorConfigPartialOverride", + "shortDescription": { + "text": "Overlapping sections" + }, + "fullDescription": { + "text": "Reports subsets of files specified in the current section that overlap with other subsets in other sections. For example: '[{foo,bar}]' and '[{foo,bas}]' both contain “foo”.", + "markdown": "Reports subsets of files specified in the current section that overlap with other subsets in other sections. For example: `[{foo,bar}]` and `[{foo,bas}]` both contain \"foo\"." + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "EditorConfigPartialOverride", + "ideaSeverity": "WEAK WARNING", + "qodanaSeverity": "Moderate" + } + }, + "relationships": [ + { + "target": { + "id": "EditorConfig", + "index": 0, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "EditorConfigEmptySection", + "shortDescription": { + "text": "Empty section" + }, + "fullDescription": { + "text": "Reports sections that do not contain any EditorConfig properties.", + "markdown": "Reports sections that do not contain any EditorConfig properties." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "EditorConfigEmptySection", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "EditorConfig", + "index": 0, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "EditorConfigShadowingOption", + "shortDescription": { + "text": "Overriding property" + }, + "fullDescription": { + "text": "Reports properties that override the same properties defined earlier in the file. For example: '[*.java]\nindent_size=4\n[{*.java,*.js}]\nindent_size=2' The second section includes the same files as '[*.java]' but also sets indent_size to value 2. Thus the first declaration 'indent_size=4'will be ignored.", + "markdown": "Reports properties that override the same properties defined earlier in the file.\n\nFor example:\n\n\n [*.java]\n indent_size=4\n [{*.java,*.js}]\n indent_size=2\n\nThe second section includes the same files as `[*.java]` but also sets indent_size to value 2. Thus the first declaration `indent_size=4`will be ignored." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "EditorConfigShadowingOption", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "EditorConfig", + "index": 0, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "EditorConfigListAcceptability", + "shortDescription": { + "text": "Unexpected value list" + }, + "fullDescription": { + "text": "Reports lists of values that are used in properties in which lists are not supported. In this case, only a single value can be specified.", + "markdown": "Reports lists of values that are used in properties in which lists are not supported. In this case, only a single value can be specified." + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "EditorConfigListAcceptability", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "EditorConfig", + "index": 0, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "EditorConfigKeyCorrectness", + "shortDescription": { + "text": "Unknown property" + }, + "fullDescription": { + "text": "Reports properties that are not supported by the IDE. Note: some “ij” domain properties may require specific language plugins.", + "markdown": "Reports properties that are not supported by the IDE. Note: some \"ij\" domain properties may require specific language plugins." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "EditorConfigKeyCorrectness", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "EditorConfig", + "index": 0, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "EditorConfigPatternEnumerationRedundancy", + "shortDescription": { + "text": "Unnecessary braces" + }, + "fullDescription": { + "text": "Reports pattern lists that are either empty '{}' or contain just one pattern, for example '{foo}' in contrast to a list containing multiple patterns, for example '{foo,bar}'. In this case braces are handled as a part of the name. For example, the pattern '*.{a}' will match the file 'my.{a}' but not 'my.a'.", + "markdown": "Reports pattern lists that are either empty `{}` or contain just one pattern, for example `{foo}` in contrast to a list containing multiple patterns, for example `{foo,bar}`. In this case braces are handled as a part of the name. For example, the pattern `*.{a}` will match the file `my.{a}` but not `my.a`." + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "EditorConfigPatternEnumerationRedundancy", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "EditorConfig", + "index": 0, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "EditorConfigEncoding", + "shortDescription": { + "text": "File encoding doesn't match EditorConfig charset" + }, + "fullDescription": { + "text": "Checks that current file encoding matches the encoding defined in \"charset\" property of .editorconfig file.", + "markdown": "Checks that current file encoding matches the encoding defined in \"charset\" property of .editorconfig file." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "EditorConfigEncoding", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "EditorConfig", + "index": 0, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "EditorConfigRootDeclarationCorrectness", + "shortDescription": { + "text": "Unexpected top-level declaration" + }, + "fullDescription": { + "text": "Reports unexpected top-level declarations. Top-level declarations other than “root=true” are not allowed in the EditorConfig file.", + "markdown": "Reports unexpected top-level declarations. Top-level declarations other than \"root=true\" are not allowed in the EditorConfig file." + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "EditorConfigRootDeclarationCorrectness", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "EditorConfig", + "index": 0, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "EditorConfigReferenceCorrectness", + "shortDescription": { + "text": "Invalid reference" + }, + "fullDescription": { + "text": "Reports identifiers that are either unknown or have a wrong type.", + "markdown": "Reports identifiers that are either unknown or have a wrong type." + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "EditorConfigReferenceCorrectness", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "EditorConfig", + "index": 0, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "EditorConfigPairAcceptability", + "shortDescription": { + "text": "Unexpected key-value pair" + }, + "fullDescription": { + "text": "Reports key-value pairs that are not allowed in the current context.", + "markdown": "Reports key-value pairs that are not allowed in the current context." + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "EditorConfigPairAcceptability", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "EditorConfig", + "index": 0, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "EditorConfigPatternRedundancy", + "shortDescription": { + "text": "Duplicate or redundant pattern" + }, + "fullDescription": { + "text": "Reports file patterns that are redundant as there already are other patterns that define the same scope of files or even a broader one. For example, in '[{*.java,*}]' the first '*.java' pattern defines a narrower scope compared to '*'. That is why it is redundant and can be removed.", + "markdown": "Reports file patterns that are redundant as there already are other patterns that define the same scope of files or even a broader one. For example, in `[{*.java,*}]` the first `*.java` pattern defines a narrower scope compared to `*`. That is why it is redundant and can be removed." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "EditorConfigPatternRedundancy", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "EditorConfig", + "index": 0, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "EditorConfigNoMatchingFiles", + "shortDescription": { + "text": "No matching files" + }, + "fullDescription": { + "text": "Reports sections with wildcard patterns that do not match any files under the directory in which the '.editorconfig' file is located.", + "markdown": "Reports sections with wildcard patterns that do not match any files under the directory in which the `.editorconfig` file is located." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "EditorConfigNoMatchingFiles", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "EditorConfig", + "index": 0, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "EditorConfigDeprecatedDescriptor", + "shortDescription": { + "text": "Deprecated property" + }, + "fullDescription": { + "text": "Reports EditorConfig properties that are no longer supported.", + "markdown": "Reports EditorConfig properties that are no longer supported." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "EditorConfigDeprecatedDescriptor", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "EditorConfig", + "index": 0, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "EditorConfigWildcardRedundancy", + "shortDescription": { + "text": "Redundant wildcard" + }, + "fullDescription": { + "text": "Reports wildcards that become redundant when the “**” wildcard is used in the same section. The “**” wildcard defines a broader set of files than any other wildcard. That is why, any other wildcard used in the same section has no affect and can be removed.", + "markdown": "Reports wildcards that become redundant when the \"\\*\\*\" wildcard is used in the same section.\n\n\nThe \"\\*\\*\" wildcard defines a broader set of files than any other wildcard.\nThat is why, any other wildcard used in the same section has no affect and can be removed." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "EditorConfigWildcardRedundancy", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "EditorConfig", + "index": 0, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "EditorConfigHeaderUniqueness", + "shortDescription": { + "text": "EditorConfig section is not unique" + }, + "fullDescription": { + "text": "Reports sections that define the same file pattern as other sections.", + "markdown": "Reports sections that define the same file pattern as other sections." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "EditorConfigHeaderUniqueness", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "EditorConfig", + "index": 0, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "EditorConfigShadowedOption", + "shortDescription": { + "text": "Overridden property" + }, + "fullDescription": { + "text": "Reports properties that are already defined in other sections. For example: '[*.java]\nindent_size=4\n[{*.java,*.js}]\nindent_size=2' The second section includes all '*.java' files too but it also redefines indent_size. As a result the value 2 will be used for files matching '*.java'.", + "markdown": "Reports properties that are already defined in other sections.\n\nFor example:\n\n\n [*.java]\n indent_size=4\n [{*.java,*.js}]\n indent_size=2\n\nThe second section includes all `*.java` files too but it also redefines indent_size. As a result the value 2 will be used for files matching `*.java`." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "EditorConfigShadowedOption", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "EditorConfig", + "index": 0, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "EditorConfigEmptyHeader", + "shortDescription": { + "text": "Empty header" + }, + "fullDescription": { + "text": "Reports sections with an empty header. Section header must contain file path globs in the format similar to one supported by 'gitignore'.", + "markdown": "Reports sections with an empty header. Section header must contain file path globs in the format similar to one supported by `gitignore`." + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "EditorConfigEmptyHeader", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "EditorConfig", + "index": 0, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "EditorConfigValueCorrectness", + "shortDescription": { + "text": "Invalid property value" + }, + "fullDescription": { + "text": "Reports property values that do not meet value restrictions. For example, some properties may be only “true” or “false”, others contain only integer numbers etc. If a value has a limited set of variants, use code completion to see all of them.", + "markdown": "Reports property values that do not meet value restrictions. For example, some properties may be only \"true\" or \"false\", others contain only integer numbers etc. If a value has a limited set of variants, use code completion to see all of them." + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "EditorConfigValueCorrectness", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "EditorConfig", + "index": 0, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "EditorConfigVerifyByCore", + "shortDescription": { + "text": "Invalid .editorconfig file" + }, + "fullDescription": { + "text": "Verifies the whole file using the backing EditorConfig core library and reports any failures. Any such failure would prevent EditorConfig properties from being correctly applied.", + "markdown": "Verifies the whole file using the backing EditorConfig core library and reports any failures. Any such failure would prevent EditorConfig properties from being correctly applied." + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "EditorConfigVerifyByCore", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "EditorConfig", + "index": 0, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "EditorConfigValueUniqueness", + "shortDescription": { + "text": "Non-unique list value" + }, + "fullDescription": { + "text": "Reports duplicates in lists of values.", + "markdown": "Reports duplicates in lists of values." + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "EditorConfigValueUniqueness", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "EditorConfig", + "index": 0, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "EditorConfigMissingRequiredDeclaration", + "shortDescription": { + "text": "Required declarations are missing" + }, + "fullDescription": { + "text": "Reports properties that miss the required declarations. Refer to the documentation for more information.", + "markdown": "Reports properties that miss the required declarations. Refer to the documentation for more information." + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "EditorConfigMissingRequiredDeclaration", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "EditorConfig", + "index": 0, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "EditorConfigCharClassLetterRedundancy", + "shortDescription": { + "text": "Duplicate character class letter" + }, + "fullDescription": { + "text": "Reports wildcard patterns in the EditorConfig section that contain a duplicate character in the character class, for example '[aa]'.", + "markdown": "Reports wildcard patterns in the EditorConfig section that contain a duplicate character in the character class, for example `[aa]`." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "EditorConfigCharClassLetterRedundancy", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "EditorConfig", + "index": 0, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "EditorConfigSpaceInHeader", + "shortDescription": { + "text": "Space in file pattern" + }, + "fullDescription": { + "text": "Reports space characters in wildcard patterns that affect pattern matching. If these characters are not intentional, they should be removed.", + "markdown": "Reports space characters in wildcard patterns that affect pattern matching. If these characters are not intentional, they should be removed." + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "EditorConfigSpaceInHeader", + "ideaSeverity": "WEAK WARNING", + "qodanaSeverity": "Moderate" + } + }, + "relationships": [ + { + "target": { + "id": "EditorConfig", + "index": 0, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "EditorConfigOptionRedundancy", + "shortDescription": { + "text": "Redundant property" + }, + "fullDescription": { + "text": "Reports properties that are redundant when another applicable section already contains the same property and value. For example: '[*]\nindent_size=4\n[*.java]\nindent_size=4' are both applicable to '*.java' files and define the same 'indent_size' value.", + "markdown": "Reports properties that are redundant when another applicable section already contains the same property and value.\n\n\nFor example:\n\n\n [*]\n indent_size=4\n [*.java]\n indent_size=4\n\nare both applicable to `*.java` files and define the same `indent_size` value." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "EditorConfigOptionRedundancy", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "EditorConfig", + "index": 0, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "EditorConfigUnusedDeclaration", + "shortDescription": { + "text": "Unused declaration" + }, + "fullDescription": { + "text": "Reports unused declarations. Such declarations can be removed.", + "markdown": "Reports unused declarations. Such declarations can be removed." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "EditorConfigUnusedDeclaration", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "EditorConfig", + "index": 0, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "EditorConfigUnexpectedComma", + "shortDescription": { + "text": "Unexpected comma" + }, + "fullDescription": { + "text": "Reports commas that cannot be used in the current context. Commas are allowed only as separators for values in lists.", + "markdown": "Reports commas that cannot be used in the current context. Commas are allowed only as separators for values in lists." + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "EditorConfigUnexpectedComma", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "EditorConfig", + "index": 0, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + } + ], + "language": "en-US", + "contents": [ + "localizedData", + "nonLocalizedData" + ], + "isComprehensive": false + }, + { + "name": "JavaScript", + "version": "233.13017", + "rules": [ + { + "id": "ConstantConditionalExpressionJS", + "shortDescription": { + "text": "Constant conditional expression" + }, + "fullDescription": { + "text": "Reports a conditional expression in the format 'true? result1: result2' or 'false? result1: result2. Suggests simplifying the expression.'", + "markdown": "Reports a conditional expression in the format `true? result1: result2` or `false? result1: result2``.\nSuggests simplifying the expression.\n`" + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "ConstantConditionalExpressionJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Control flow issues", + "index": 2, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JSTestFailedLine", + "shortDescription": { + "text": "Highlight failure line in test code" + }, + "fullDescription": { + "text": "Reports a failed method call or an assertion in a test.", + "markdown": "Reports a failed method call or an assertion in a test." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "JSTestFailedLine", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Unit testing", + "index": 7, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "NonBlockStatementBodyJS", + "shortDescription": { + "text": "Statement body without braces" + }, + "fullDescription": { + "text": "Reports a 'if', 'while', 'for', or 'with' statements whose body is not a block statement. Using code block in statement bodies is usually safer for downstream maintenance.", + "markdown": "Reports a `if`, `while`, `for`, or `with` statements whose body is not a block statement. Using code block in statement bodies is usually safer for downstream maintenance." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "NonBlockStatementBodyJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Code style issues", + "index": 9, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "IfStatementWithTooManyBranchesJS", + "shortDescription": { + "text": "'if' statement with too many branches" + }, + "fullDescription": { + "text": "Reports an 'if' statement with too many branches. Such statements may be confusing, and often indicate inadequate levels of design abstraction. Use the field below to specify the maximum number of branches expected.", + "markdown": "Reports an `if` statement with too many branches. Such statements may be confusing, and often indicate inadequate levels of design abstraction.\n\n\nUse the field below to specify the maximum number of branches expected." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "IfStatementWithTooManyBranchesJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Control flow issues", + "index": 2, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JSValidateJSDoc", + "shortDescription": { + "text": "Syntax errors and unresolved references in JSDoc" + }, + "fullDescription": { + "text": "Reports a syntax discrepancy in a documentation comment.", + "markdown": "Reports a syntax discrepancy in a documentation comment." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "JSValidateJSDoc", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/General", + "index": 10, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "BreakStatementJS", + "shortDescription": { + "text": "'break' statement" + }, + "fullDescription": { + "text": "Reports a 'break' statements. Ignores 'break' statements that end case blocks.", + "markdown": "Reports a `break` statements. Ignores `break` statements that end case blocks." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "BreakStatementJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Potentially undesirable code constructs", + "index": 11, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "FlowJSConfig", + "shortDescription": { + "text": "Missing .flowconfig" + }, + "fullDescription": { + "text": "Reports a JavaScript file with a '@flow' flag that doesn't have an associated '.flowconfig' file in the project.", + "markdown": "Reports a JavaScript file with a `@flow` flag that doesn't have an associated `.flowconfig` file in the project." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "FlowJSConfig", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Flow type checker", + "index": 12, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JSPotentiallyInvalidUsageOfClassThis", + "shortDescription": { + "text": "Potentially invalid reference to 'this' of a class from closure" + }, + "fullDescription": { + "text": "Reports an attempt to reference a member of an ECMAScript class via the 'this.' qualifier in a nested function that is not a lambda. 'this' in a nested function that is not a lambda is the function's own 'this' and doesn't relate to the outer class.", + "markdown": "Reports an attempt to reference a member of an ECMAScript class via the `this.` qualifier in a nested function that is not a lambda. \n`this` in a nested function that is not a lambda is the function's own `this` and doesn't relate to the outer class." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "JSPotentiallyInvalidUsageOfClassThis", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Probable bugs", + "index": 13, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "DebuggerStatementJS", + "shortDescription": { + "text": "'debugger' statement" + }, + "fullDescription": { + "text": "Reports a 'debugger' statement used for interaction with the Javascript debuggers. Such statements should not appear in production code.", + "markdown": "Reports a `debugger` statement used for interaction with the Javascript debuggers. Such statements should not appear in production code." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "DebuggerStatementJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Potentially undesirable code constructs", + "index": 11, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JSUnusedAssignment", + "shortDescription": { + "text": "Unused assignment" + }, + "fullDescription": { + "text": "Reports a variable whose value is never used after assignment. Suggests removing the unused variable to shorten the code and to avoid redundant allocations. The following cases are reported: A variable is never read after assignment. The value of a variable is always overwritten with another assignment before the variable is read next time. The initializer of a variable is redundant (for one of the above-mentioned reasons).", + "markdown": "Reports a variable whose value is never used after assignment. \nSuggests removing the unused variable to shorten the code and to avoid redundant allocations.\n\nThe following cases are reported:\n\n* A variable is never read after assignment.\n* The value of a variable is always overwritten with another assignment before the variable is read next time.\n* The initializer of a variable is redundant (for one of the above-mentioned reasons)." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "JSUnusedAssignment", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Unused symbols", + "index": 15, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "FlowJSError", + "shortDescription": { + "text": "Flow type checker" + }, + "fullDescription": { + "text": "Reports errors from Flow.", + "markdown": "Reports errors from [Flow](https://flowtype.org/)." + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "FlowJSError", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Flow type checker", + "index": 12, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "ReuseOfLocalVariableJS", + "shortDescription": { + "text": "Reuse of local variable" + }, + "fullDescription": { + "text": "Reports reusing a local variable and overwriting its value with a new value that is not related to the original variable usage. Reusing a local variable in this way may be confusing because the intended semantics of the local variable may vary with each usage. It may also cause bugs, if code changes result in values that were expected to be overwritten while they are actually live. It is good practices to keep variable lifetimes as short as possible, and not reuse local variables for the sake of brevity.", + "markdown": "Reports reusing a local variable and overwriting its value with a new value that is not related to the original variable usage. Reusing a local variable in this way may be confusing because the intended semantics of the local variable may vary with each usage. It may also cause bugs, if code changes result in values that were expected to be overwritten while they are actually live. It is good practices to keep variable lifetimes as short as possible, and not reuse local variables for the sake of brevity." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "ReuseOfLocalVariableJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Data flow", + "index": 16, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "ShiftOutOfRangeJS", + "shortDescription": { + "text": "Shift operation by possibly wrong constant" + }, + "fullDescription": { + "text": "Reports a shift operation where the second operand is a constant outside the reasonable range, for example, an integer shift operation outside the range '0..31', shifting by negative or overly large values.", + "markdown": "Reports a shift operation where the second operand is a constant outside the reasonable range, for example, an integer shift operation outside the range `0..31`, shifting by negative or overly large values." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "ShiftOutOfRangeJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Bitwise operation issues", + "index": 17, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JSClosureCompilerSyntax", + "shortDescription": { + "text": "Incorrect usage of JSDoc tags" + }, + "fullDescription": { + "text": "Reports warnings implied by Google Closure Compiler annotations including correct use of '@abstract', '@interface', and '@implements' tags.", + "markdown": "Reports warnings implied by *Google Closure Compiler* annotations including correct use of `@abstract`, `@interface`, and `@implements` tags." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "JSClosureCompilerSyntax", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/General", + "index": 10, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "UnnecessaryContinueJS", + "shortDescription": { + "text": "Unnecessary 'continue' statement" + }, + "fullDescription": { + "text": "Reports an unnecessary 'continue' statement at the end of a loop. Suggests removing such statements.", + "markdown": "Reports an unnecessary `continue` statement at the end of a loop. Suggests removing such statements." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "UnnecessaryContinueJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Control flow issues", + "index": 2, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "ES6ConvertLetToConst", + "shortDescription": { + "text": "'let' is used instead of 'const'" + }, + "fullDescription": { + "text": "Reports a 'let' declaration that can be made 'const'.", + "markdown": "Reports a `let` declaration that can be made `const`. " + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "ES6ConvertLetToConst", + "ideaSeverity": "INFORMATION", + "qodanaSeverity": "Info" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/ES2015 migration aids", + "index": 18, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JSXDomNesting", + "shortDescription": { + "text": "Invalid DOM element nesting" + }, + "fullDescription": { + "text": "Detects HTML elements in JSX files which are not nested properly according to the DOM specification. React reports runtime warnings on incorrectly nested elements.", + "markdown": "Detects HTML elements in JSX files which are not nested properly according to the DOM specification. React reports runtime warnings on incorrectly nested elements." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "JSXDomNesting", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/React", + "index": 21, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "TypeScriptValidateTypes", + "shortDescription": { + "text": "Type mismatch" + }, + "fullDescription": { + "text": "Reports a parameter, return value, or assigned expression of incorrect type.", + "markdown": "Reports a parameter, return value, or assigned expression of incorrect type." + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "TypeScriptValidateTypes", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/TypeScript", + "index": 22, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "BadExpressionStatementJS", + "shortDescription": { + "text": "Expression statement which is not assignment or call" + }, + "fullDescription": { + "text": "Reports an expression statement that is neither an assignment nor a call. Such statements usually indicate an error.", + "markdown": "Reports an expression statement that is neither an assignment nor a call. Such statements usually indicate an error." + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "BadExpressionStatementJS", + "ideaSeverity": "WEAK WARNING", + "qodanaSeverity": "Moderate" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Validity issues", + "index": 23, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "ConfusingFloatingPointLiteralJS", + "shortDescription": { + "text": "Confusing floating point literal" + }, + "fullDescription": { + "text": "Reports any floating point number that does not have a decimal point, or any numbers before the decimal point, or and numbers after the decimal point. Such literals may be confusing, and violate several coding standards.", + "markdown": "Reports any floating point number that does not have a decimal point, or any numbers before the decimal point, or and numbers after the decimal point. Such literals may be confusing, and violate several coding standards." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "ConfusingFloatingPointLiteralJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Potentially confusing code constructs", + "index": 24, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "BreakStatementWithLabelJS", + "shortDescription": { + "text": "'break' statement with label" + }, + "fullDescription": { + "text": "Reports a labeled 'break' statement.", + "markdown": "Reports a labeled `break` statement." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "BreakStatementWithLabelJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Potentially undesirable code constructs", + "index": 11, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "ContinueOrBreakFromFinallyBlockJS", + "shortDescription": { + "text": "'continue' or 'break' inside 'finally' block" + }, + "fullDescription": { + "text": "Reports a 'break' or 'continue' statement inside a 'finally' block. Such statements are very confusing, may hide exceptions, and complicate debugging.", + "markdown": "Reports a `break` or `continue` statement inside a `finally` block. Such statements are very confusing, may hide exceptions, and complicate debugging." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "ContinueOrBreakFromFinallyBlockJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Try statement issues", + "index": 27, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "StatementsPerFunctionJS", + "shortDescription": { + "text": "Overly long function" + }, + "fullDescription": { + "text": "Reports an overly long function. Function length is calculated by counting up the number of non-empty statements in the function. Functions that are too long are error-prone and difficult to test. Use the field below to specify the maximum acceptable number of statements in a function.", + "markdown": "Reports an overly long function. Function length is calculated by counting up the number of non-empty statements in the function. Functions that are too long are error-prone and difficult to test.\n\n\nUse the field below to specify the maximum acceptable number of statements in a function." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "FunctionTooLongJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Function metrics", + "index": 29, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "UnnecessaryLocalVariableJS", + "shortDescription": { + "text": "Redundant local variable" + }, + "fullDescription": { + "text": "Reports an unnecessary local variable that does not make a function more comprehensible: a local variable that is immediately returned a local variable that is immediately assigned to another variable and is not used anymore a local variable that always has the same value as another local variable or parameter. Use the checkbox below to have this inspection ignore variables that are immediately returned or thrown. Some coding styles suggest using such variables for clarity and ease of debugging.", + "markdown": "Reports an unnecessary local variable that does not make a function more comprehensible:\n\n* a local variable that is immediately returned\n* a local variable that is immediately assigned to another variable and is not used anymore\n* a local variable that always has the same value as another local variable or parameter.\n\n\nUse the checkbox below to have this inspection ignore variables that are immediately\nreturned or thrown. Some coding styles suggest using such variables for clarity and\nease of debugging." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "UnnecessaryLocalVariableJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Data flow", + "index": 16, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JSMethodCanBeStatic", + "shortDescription": { + "text": "Method can be made 'static'" + }, + "fullDescription": { + "text": "Reports a class method that can be safely made 'static'. A method can be 'static' if it does not reference any of its class' non-static methods and non-static fields and is not overridden in a subclass. Use the first checkbox below to inspect only 'private' methods.", + "markdown": "Reports a class method that can be safely made `static`. A method can be `static` if it does not reference any of its class' non-static methods and non-static fields and is not overridden in a subclass.\n\n\nUse the first checkbox below to inspect only `private` methods." + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "JSMethodCanBeStatic", + "ideaSeverity": "INFORMATION", + "qodanaSeverity": "Info" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/General", + "index": 10, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JSDeclarationsAtScopeStart", + "shortDescription": { + "text": "'var' declared not at the beginning of a function" + }, + "fullDescription": { + "text": "Checks that declarations of local variables declared with var are at the top of a function scope. By default, variable declarations are always moved (\"hoisted\") invisibly to the top of their containing scope when the code is executed. Therefore, declaring them at the top of the scope helps represent this behavior in the code.", + "markdown": "Checks that declarations of local variables declared with **var** are at the top of a function scope. \n\nBy default, variable declarations are always moved (\"hoisted\") invisibly to the top of their containing scope when the code is executed. Therefore, declaring them at the top of the scope helps represent this behavior in the code." + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "JSDeclarationsAtScopeStart", + "ideaSeverity": "WEAK WARNING", + "qodanaSeverity": "Moderate" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Code style issues", + "index": 9, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "ContinueStatementWithLabelJS", + "shortDescription": { + "text": "'continue' statement with label" + }, + "fullDescription": { + "text": "Reports a labeled 'continue' statement.", + "markdown": "Reports a labeled `continue` statement." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "ContinueStatementWithLabelJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Potentially undesirable code constructs", + "index": 11, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "TypeScriptMissingConfigOption", + "shortDescription": { + "text": "Missing tsconfig.json option " + }, + "fullDescription": { + "text": "Reports a usage that requires an explicit option in 'tsconfig.json'. For example, to use JSX in '.tsx' files, 'tsconfig.json' must contain '\"jsx\"' property.", + "markdown": "Reports a usage that requires an explicit option in `tsconfig.json`. For example, to use JSX in `.tsx` files, `tsconfig.json` must contain `\"jsx\"` property." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "TypeScriptMissingConfigOption", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/TypeScript", + "index": 22, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JSObjectNullOrUndefined", + "shortDescription": { + "text": "Object is 'null' or 'undefined'" + }, + "fullDescription": { + "text": "Reports an error caused by invoking a method, accessing a property, or calling a function on an object that is 'undefined' or 'null'.", + "markdown": "Reports an error caused by invoking a method, accessing a property, or calling a function on an object that is `undefined` or `null`." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "JSObjectNullOrUndefined", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Control flow issues", + "index": 2, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JSXUnresolvedComponent", + "shortDescription": { + "text": "Unresolved JSX component" + }, + "fullDescription": { + "text": "Reports an unresolved reference to a JSX component. Suggests adding a missing import statement if the referenced component is defined in the project or its dependencies or creating a new component with this name. The template for a new component can be modified in Editor | File and Code Templates.", + "markdown": "Reports an unresolved reference to a JSX component. Suggests adding a missing import statement if the referenced component is defined in the project or its dependencies or creating a new component with this name.\n\nThe template for a new component can be modified in Editor \\| File and Code Templates." + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "JSXUnresolvedComponent", + "ideaSeverity": "WEAK WARNING", + "qodanaSeverity": "Moderate" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/General", + "index": 10, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "UnnecessaryLabelOnBreakStatementJS", + "shortDescription": { + "text": "Unnecessary label on 'break' statement" + }, + "fullDescription": { + "text": "Reports a labeled 'break' statement whose labels may be removed without changing the flow of control.", + "markdown": "Reports a labeled `break` statement whose labels may be removed without changing the flow of control." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "UnnecessaryLabelOnBreakStatementJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Control flow issues", + "index": 2, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "ES6ShorthandObjectProperty", + "shortDescription": { + "text": "Property can be replaced with shorthand" + }, + "fullDescription": { + "text": "Reports an object property that can be converted to ES6 shorthand style and provides a quick-fix to do it. Example: 'var obj = {foo:foo}' After applying the quick-fix the code looks as follows: 'var obj = {foo}'", + "markdown": "Reports an object property that can be converted to ES6 shorthand style and provides a quick-fix to do it.\n\nExample:\n\n\n var obj = {foo:foo}\n\nAfter applying the quick-fix the code looks as follows:\n\n\n var obj = {foo}\n" + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "ES6ShorthandObjectProperty", + "ideaSeverity": "INFORMATION", + "qodanaSeverity": "Info" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/General", + "index": 10, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "ContinueStatementJS", + "shortDescription": { + "text": "'continue' statement" + }, + "fullDescription": { + "text": "Reports a 'continue' statement.", + "markdown": "Reports a `continue` statement." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "ContinueStatementJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Potentially undesirable code constructs", + "index": 11, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "AssignmentToForLoopParameterJS", + "shortDescription": { + "text": "Assignment to 'for' loop parameter" + }, + "fullDescription": { + "text": "Reports an assignment to a variable declared as a 'for' loop parameter. Although occasionally intended, this construct can be extremely confusing, and is often a result of an error.", + "markdown": "Reports an assignment to a variable declared as a `for` loop parameter. Although occasionally intended, this construct can be extremely confusing, and is often a result of an error." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "AssignmentToForLoopParameterJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Assignment issues", + "index": 34, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JSPotentiallyInvalidConstructorUsage", + "shortDescription": { + "text": "Potentially invalid constructor usage" + }, + "fullDescription": { + "text": "Reports a usage of a potentially invalid constructor function, for example: a function that is not a constructor after 'new', using a constructor's prototype or calling a constructor without 'new'. A constructor function is assumed to have an upper case name (optional) or have an explicit JSDoc '@constructor' tag.", + "markdown": "Reports a usage of a potentially invalid constructor function, for example: a function that is not a constructor after `new`, using a constructor's prototype or calling a constructor without `new`. A constructor function is assumed to have an upper case name (optional) or have an explicit JSDoc `@constructor` tag." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "JSPotentiallyInvalidConstructorUsage", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Probable bugs", + "index": 13, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "PointlessArithmeticExpressionJS", + "shortDescription": { + "text": "Pointless arithmetic expression" + }, + "fullDescription": { + "text": "Reports an arithmetic expression that include adding or subtracting zero, multiplying by zero or one, division by one, and shift by zero. Such expressions may result from not fully completed automated refactoring.", + "markdown": "Reports an arithmetic expression that include adding or subtracting zero, multiplying by zero or one, division by one, and shift by zero. Such expressions may result from not fully completed automated refactoring." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "PointlessArithmeticExpressionJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Potentially confusing code constructs", + "index": 24, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "NodeCoreCodingAssistance", + "shortDescription": { + "text": "Unresolved Node.js APIs" + }, + "fullDescription": { + "text": "Suggests configuring coding assistance for Node.js, for example, 'require' and/or core modules ('path', 'http', 'fs', etc.). See https://nodejs.org/api/ for the complete list.", + "markdown": "Suggests configuring coding assistance for Node.js, for example, `require` and/or core modules ('path', 'http', 'fs', etc.).\n\n\nSee for the complete list." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "NodeCoreCodingAssistance", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Node.js", + "index": 39, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JSUndeclaredVariable", + "shortDescription": { + "text": "Implicitly declared global JavaScript variable" + }, + "fullDescription": { + "text": "Reports an implicit declaration of a global variable. Example: 'var aaa = 1; // good\n bbb = 2; // bad, if bbb is not declared with 'var' somewhere'", + "markdown": "Reports an implicit declaration of a global variable.\n\nExample:\n\n\n var aaa = 1; // good\n bbb = 2; // bad, if bbb is not declared with 'var' somewhere\n" + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "JSUndeclaredVariable", + "ideaSeverity": "WEAK WARNING", + "qodanaSeverity": "Moderate" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/General", + "index": 10, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "DivideByZeroJS", + "shortDescription": { + "text": "Division by zero" + }, + "fullDescription": { + "text": "Reports division by zero or a remainder by zero.", + "markdown": "Reports division by zero or a remainder by zero." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "DivideByZeroJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Probable bugs", + "index": 13, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JSPrimitiveTypeWrapperUsage", + "shortDescription": { + "text": "Primitive type object wrapper used" + }, + "fullDescription": { + "text": "Reports an improper usage of a wrapper for primitive types or a property of a primitive type being modified, as in the latter case the assigned value will be lost.", + "markdown": "Reports an improper usage of a wrapper for primitive types or a property of a primitive type being modified, as in the latter case the assigned value will be lost." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "JSPrimitiveTypeWrapperUsage", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/General", + "index": 10, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "TypeScriptSmartCast", + "shortDescription": { + "text": "Narrowed type" + }, + "fullDescription": { + "text": "Reports a usage of a variable where the variable type is narrowed by a type guard. Note that severity level doesn't affect this inspection.", + "markdown": "Reports a usage of a variable where the variable type is narrowed by a type guard. Note that severity level doesn't affect this inspection." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "TypeScriptSmartCast", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/TypeScript", + "index": 22, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "ES6ConvertIndexedForToForOf", + "shortDescription": { + "text": "Indexed 'for' is used instead of 'for..of'" + }, + "fullDescription": { + "text": "Reports an indexed 'for' loop used on an array. Suggests replacing it with a 'for..of' loop. 'for..of' loops are introduced in ECMAScript 6 and iterate over 'iterable' objects.", + "markdown": "Reports an indexed [for](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Statements/for) loop used on an array. Suggests replacing it with a [for..of](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Statements/for...of) loop. \n`for..of` loops are introduced in ECMAScript 6 and iterate over `iterable` objects." + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "ES6ConvertIndexedForToForOf", + "ideaSeverity": "INFORMATION", + "qodanaSeverity": "Info" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/ES2015 migration aids", + "index": 18, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JSLastCommaInArrayLiteral", + "shortDescription": { + "text": "Unneeded last comma in array literal" + }, + "fullDescription": { + "text": "Reports a usage of a trailing comma in an array literal. The warning is reported only when the JavaScript language version is set to ECMAScript 5.1. Although trailing commas in arrays are allowed by the specification, some browsers may throw an error when a trailing comma is used. You can configure formatting options for trailing commas in Code Style | JavaScript or TypeScript | Punctuation.", + "markdown": "Reports a usage of a trailing comma in an array literal.\n\nThe warning is reported only when the JavaScript language version is set to ECMAScript 5.1.\n\nAlthough trailing commas in arrays are allowed by the specification, some browsers may throw an error when a trailing comma is used.\n\nYou can configure formatting options for trailing commas in **Code Style** \\| **JavaScript** or **TypeScript** \\| **Punctuation**." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "JSLastCommaInArrayLiteral", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/General", + "index": 10, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "ConditionalExpressionJS", + "shortDescription": { + "text": "Conditional expression" + }, + "fullDescription": { + "text": "Reports a ternary conditional expression. Some coding standards prohibit such expressions in favor of explicit 'if' statements.", + "markdown": "Reports a ternary conditional expression. Some coding standards prohibit such expressions in favor of explicit `if` statements." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "ConditionalExpressionJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Potentially undesirable code constructs", + "index": 11, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "ES6ConvertVarToLetConst", + "shortDescription": { + "text": "'var' is used instead of 'let' or 'const'" + }, + "fullDescription": { + "text": "Reports a 'var' declaration that is used instead of 'let' or 'const'. Both 'let' and 'const' are block-scoped and behave more strictly. Suggests replacing all 'var' declarations with 'let' or 'const' declarations, depending on the semantics of a particular value. The declarations may be moved to the top of the function or placed before the first usage of the variable to avoid Reference errors. Select the 'Conservatively convert var with Fix all action' option to prevent any changes in these complex cases when using the 'Fix all' action.", + "markdown": "Reports a `var` declaration that is used instead of `let` or `const`. \nBoth `let` and `const` are block-scoped and behave more strictly. \n\nSuggests replacing all `var` declarations with `let` or `const` declarations, depending on the semantics of a particular value. The declarations may be moved to the top of the function or placed before the first usage of the variable to avoid Reference errors. \nSelect the 'Conservatively convert var with Fix all action' option to prevent any changes in these complex cases when using the 'Fix all' action." + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "ES6ConvertVarToLetConst", + "ideaSeverity": "WEAK WARNING", + "qodanaSeverity": "Moderate" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/ES2015 migration aids", + "index": 18, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JSReferencingMutableVariableFromClosure", + "shortDescription": { + "text": "Referencing mutable variable from closure" + }, + "fullDescription": { + "text": "Reports access to outer mutable variables from functions. Example: 'for (var i = 1; i <= 3; i++) {\n setTimeout(function() {\n console.log(i); // bad\n }, 0);\n }'", + "markdown": "Reports access to outer mutable variables from functions.\n\nExample:\n\n\n for (var i = 1; i <= 3; i++) {\n setTimeout(function() {\n console.log(i); // bad\n }, 0);\n }\n" + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "JSReferencingMutableVariableFromClosure", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/General", + "index": 10, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "PointlessBooleanExpressionJS", + "shortDescription": { + "text": "Pointless statement or boolean expression" + }, + "fullDescription": { + "text": "Reports a pointless or pointlessly complicated boolean expression or statement. Example: 'let a = !(false && x);\n let b = false || x;' After the quick fix is applied the result looks like: 'let a = true;\n let b = x;'", + "markdown": "Reports a pointless or pointlessly complicated boolean expression or statement.\n\nExample:\n\n\n let a = !(false && x);\n let b = false || x;\n\nAfter the quick fix is applied the result looks like:\n\n\n let a = true;\n let b = x;\n" + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "PointlessBooleanExpressionJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Control flow issues", + "index": 2, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "DynamicallyGeneratedCodeJS", + "shortDescription": { + "text": "Execution of dynamically generated code" + }, + "fullDescription": { + "text": "Reports a call of the 'eval()', 'setTimeout()', or 'setInterval()' function or an allocation of a 'Function' object. These functions are used to execute arbitrary strings of JavaScript text, which often dynamically generated. This can be very confusing, and may be a security risk. Ignores the cases when a callback function is provided to these methods statically, without code generation.", + "markdown": "Reports a call of the `eval()`, `setTimeout()`, or `setInterval()` function or an allocation of a `Function` object. These functions are used to execute arbitrary strings of JavaScript text, which often dynamically generated. This can be very confusing, and may be a security risk. \n\nIgnores the cases when a callback function is provided to these methods statically, without code generation." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "DynamicallyGeneratedCodeJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Potentially confusing code constructs", + "index": 24, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "NegatedConditionalExpressionJS", + "shortDescription": { + "text": "Negated conditional expression" + }, + "fullDescription": { + "text": "Reports a conditional expression whose condition is negated. Suggests flipping the order of branches in the conditional expression to increase the clarity of the statement. Example: '!condition ? 2 : 1'", + "markdown": "Reports a conditional expression whose condition is negated. Suggests flipping the order of branches in the conditional expression to increase the clarity of the statement. Example: `!condition ? 2 : 1`" + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "NegatedConditionalExpressionJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Potentially confusing code constructs", + "index": 24, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JSUrlImportUsage", + "shortDescription": { + "text": "URL import is used" + }, + "fullDescription": { + "text": "Checks used URL imports in the JavaScript language. Suggests downloading the module for the specified remote URL. Such association enables the IDE to provide proper code completion and navigation. URLs in import specifiers are supported only for ECMAScript modules in the JavaScript language.", + "markdown": "Checks used URL imports in the JavaScript language. Suggests downloading the module for the specified remote URL. Such association enables the IDE to provide proper code completion and navigation. \n\nURLs in import specifiers are supported only for ECMAScript modules in the JavaScript language." + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "JSUrlImportUsage", + "ideaSeverity": "INFORMATION", + "qodanaSeverity": "Info" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Imports and dependencies", + "index": 42, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "UnnecessaryLabelOnContinueStatementJS", + "shortDescription": { + "text": "Unnecessary label on 'continue' statement" + }, + "fullDescription": { + "text": "Reports a labeled 'continue' statement whose labels may be removed without changing the flow of control.", + "markdown": "Reports a labeled `continue` statement whose labels may be removed without changing the flow of control." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "UnnecessaryLabelOnContinueStatementJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Control flow issues", + "index": 2, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "ChainedEqualityJS", + "shortDescription": { + "text": "Chained equality" + }, + "fullDescription": { + "text": "Reports a chained equality comparison (i.e. 'a==b==c'). Such comparisons are confusing.", + "markdown": "Reports a chained equality comparison (i.e. `a==b==c`). Such comparisons are confusing." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "ChainedEqualityComparisonsJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Code style issues", + "index": 9, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "SillyAssignmentJS", + "shortDescription": { + "text": "Variable is assigned to itself" + }, + "fullDescription": { + "text": "Reports an assignment in the form 'x = x'.", + "markdown": "Reports an assignment in the form `x = x`." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "SillyAssignmentJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Assignment issues", + "index": 34, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JSPotentiallyInvalidTargetOfIndexedPropertyAccess", + "shortDescription": { + "text": "Possibly incorrect target of indexed property access" + }, + "fullDescription": { + "text": "Reports a potentially invalid indexed property access, for example, 'Array[1]'.", + "markdown": "Reports a potentially invalid indexed property access, for example, `Array[1]`." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "JSPotentiallyInvalidTargetOfIndexedPropertyAccess", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Probable bugs", + "index": 13, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JSAccessibilityCheck", + "shortDescription": { + "text": "Inaccessible @private and @protected members referenced" + }, + "fullDescription": { + "text": "Reports a reference to a JavaScript member that is marked with a '@private' or '@protected' tag but does not comply with visibility rules that these tags imply.", + "markdown": "Reports a reference to a JavaScript member that is marked with a `@private` or `@protected` tag but does not comply with visibility rules that these tags imply." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "JSAccessibilityCheck", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/General", + "index": 10, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "ES6ConvertRequireIntoImport", + "shortDescription": { + "text": "'require()' is used instead of 'import'" + }, + "fullDescription": { + "text": "Reports a 'require()' statement. Suggests converting it to a 'require()' call with an 'import' statement. Enable 'Convert require() inside inner scopes with Fix all action' to convert all 'require()' calls inside the nested functions and statements when using the 'Fix all' action. Please note that converting 'require()' statements inside inner scopes to 'import' statements may cause changes in the semantics of the code. Import statements are static module dependencies and are hoisted, which means that they are moved to the top of the current module. 'require()' calls load modules dynamically. They can be executed conditionally, and their scope is defined by the expression in which they are used. Clear the 'Convert require() inside inner scopes with Fix all action' checkbox to prevent any changes in these complex cases when using the 'Fix all' action.", + "markdown": "Reports a `require()` statement. Suggests converting it to a `require()` call with an `import` statement. \n\nEnable 'Convert require() inside inner scopes with Fix all action' to convert all `require()` calls inside the nested functions and statements when using the 'Fix all' action. \n\nPlease note that converting `require()` statements inside inner scopes to `import` statements may cause changes in the semantics of the code. Import statements are static module dependencies and are hoisted, which means that they are moved to the top of the current module. `require()` calls load modules dynamically. They can be executed conditionally, and their scope is defined by the expression in which they are used. \nClear the 'Convert require() inside inner scopes with Fix all action' checkbox to prevent any changes in these complex cases when using the 'Fix all' action." + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "ES6ConvertRequireIntoImport", + "ideaSeverity": "INFORMATION", + "qodanaSeverity": "Info" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/ES2015 migration aids", + "index": 18, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "FunctionWithMultipleLoopsJS", + "shortDescription": { + "text": "Function with multiple loops" + }, + "fullDescription": { + "text": "Reports a function with multiple loop statements.", + "markdown": "Reports a function with multiple loop statements." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "FunctionWithMultipleLoopsJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Function metrics", + "index": 29, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "LabeledStatementJS", + "shortDescription": { + "text": "Labeled statement" + }, + "fullDescription": { + "text": "Reports a labeled statement.", + "markdown": "Reports a labeled statement." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "LabeledStatementJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Potentially undesirable code constructs", + "index": 11, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "UnusedCatchParameterJS", + "shortDescription": { + "text": "Unused 'catch' parameter" + }, + "fullDescription": { + "text": "Reports a 'catch' parameter that is not used in the corresponding block. The 'catch' parameters named 'ignore' or 'ignored' are ignored. Use the checkbox below to disable this inspection for 'catch' blocks with comments.", + "markdown": "Reports a `catch` parameter that is not used in the corresponding block. The `catch` parameters named `ignore` or `ignored` are ignored.\n\n\nUse the checkbox below to disable this inspection for `catch`\nblocks with comments." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "UnusedCatchParameterJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Try statement issues", + "index": 27, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "NpmUsedModulesInstalled", + "shortDescription": { + "text": "Missing module dependency" + }, + "fullDescription": { + "text": "Reports a module from a 'require()' call or an 'import' statement that is not installed or is not listed in package.json dependencies. Suggests installing the module and/or including it into package.json. For 'require()' calls, works only in the files from the scope of Node.js Core JavaScript library.", + "markdown": "Reports a module from a `require()` call or an `import` statement that is not installed or is not listed in package.json dependencies.\n\nSuggests installing the module and/or including it into package.json.\n\nFor `require()` calls, works only in the files from the scope of *Node.js Core* JavaScript library." + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "NpmUsedModulesInstalled", + "ideaSeverity": "WEAK WARNING", + "qodanaSeverity": "Moderate" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Imports and dependencies", + "index": 42, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "WithStatementJS", + "shortDescription": { + "text": "'with' statement" + }, + "fullDescription": { + "text": "Reports a 'with' statements. Such statements result in potentially confusing implicit bindings, and may behave strangely in setting new variables.", + "markdown": "Reports a `with` statements. Such statements result in potentially confusing implicit bindings, and may behave strangely in setting new variables." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "WithStatementJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Potentially undesirable code constructs", + "index": 11, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JSConstantReassignment", + "shortDescription": { + "text": "Attempt to assign to const or readonly variable" + }, + "fullDescription": { + "text": "Reports reassigning a value to a constant or a readonly variable.", + "markdown": "Reports reassigning a value to a constant or a readonly variable." + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "JSConstantReassignment", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Validity issues", + "index": 23, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "TypeScriptCheckImport", + "shortDescription": { + "text": "Unresolved imported name" + }, + "fullDescription": { + "text": "Reports an unresolved name or binding in an 'import' declaration in TypeScript code.", + "markdown": "Reports an unresolved name or binding in an `import` declaration in TypeScript code." + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "TypeScriptCheckImport", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/TypeScript", + "index": 22, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "MagicNumberJS", + "shortDescription": { + "text": "Magic number" + }, + "fullDescription": { + "text": "Reports a \"magic number\" that is a numeric literal used without being named by a constant declaration. Magic numbers can result in code whose intention is unclear, and may result in errors if a magic number is changed in one code location but remains unchanged in another. The numbers 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 100, 1000, 0.0 and 1.0 are ignored.", + "markdown": "Reports a \"magic number\" that is a numeric literal used without being named by a constant declaration. Magic numbers can result in code whose intention is unclear, and may result in errors if a magic number is changed in one code location but remains unchanged in another. The numbers 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 100, 1000, 0.0 and 1.0 are ignored." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "MagicNumberJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Potentially confusing code constructs", + "index": 24, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "FunctionNamingConventionJS", + "shortDescription": { + "text": "Function naming convention" + }, + "fullDescription": { + "text": "Reports a function whose name is too short, too long, or does not follow the specified regular expression pattern. Use the fields provided below to specify minimum length, maximum length, and a regular expression for function names. Use the standard 'java.util.regex' format for regular expressions.", + "markdown": "Reports a function whose name is too short, too long, or does not follow the specified regular expression pattern.\n\n\nUse the fields provided below to specify minimum length, maximum length, and a regular expression\nfor function names. Use the standard `java.util.regex` format for regular expressions." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "FunctionNamingConventionJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Naming conventions", + "index": 46, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JSXSyntaxUsed", + "shortDescription": { + "text": "JSX syntax used" + }, + "fullDescription": { + "text": "Reports a usage of a JSX tag in JavaScript code.", + "markdown": "Reports a usage of a JSX tag in JavaScript code." + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "JSXSyntaxUsed", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/General", + "index": 10, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JSJoinVariableDeclarationAndAssignment", + "shortDescription": { + "text": "Variable declaration can be merged with the first assignment to the variable" + }, + "fullDescription": { + "text": "Reports a variable that is declared without an initializer and is used much further in the code or in a single nested scope. Suggests moving the variable closer to its usages and joining it with the initializer expression.", + "markdown": "Reports a variable that is declared without an initializer and is used much further in the code or in a single nested scope. Suggests moving the variable closer to its usages and joining it with the initializer expression." + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "JSJoinVariableDeclarationAndAssignment", + "ideaSeverity": "INFORMATION", + "qodanaSeverity": "Info" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/General", + "index": 10, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JSRedundantSwitchStatement", + "shortDescription": { + "text": "'switch' statement is redundant and can be replaced" + }, + "fullDescription": { + "text": "Reports a 'switch' statement with an empty body, or with only one 'case' branch, or with a 'default' branch only.", + "markdown": "Reports a `switch` statement with an empty body, or with only one `case` branch, or with a `default` branch only." + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "JSRedundantSwitchStatement", + "ideaSeverity": "INFORMATION", + "qodanaSeverity": "Info" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Switch statement issues", + "index": 47, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "TypeScriptLibrary", + "shortDescription": { + "text": "Missing global library" + }, + "fullDescription": { + "text": "Reports a TypeScript library file that is required for a symbol but is not listed under the 'lib' compiler option in 'tsconfig.json'.", + "markdown": "Reports a TypeScript library file that is required for a symbol but is not listed under the `lib` compiler option in `tsconfig.json`." + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "TypeScriptLibrary", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/TypeScript", + "index": 22, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "TypeScriptMissingAugmentationImport", + "shortDescription": { + "text": "Missing augmentation import" + }, + "fullDescription": { + "text": "Reports a usage from augmentation module without an explicit import.", + "markdown": "Reports a usage from [augmentation module](https://www.typescriptlang.org/docs/handbook/declaration-merging.html#module-augmentation) without an explicit import." + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "TypeScriptMissingAugmentationImport", + "ideaSeverity": "INFORMATION", + "qodanaSeverity": "Info" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/TypeScript", + "index": 22, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JSUnusedGlobalSymbols", + "shortDescription": { + "text": "Unused global symbol" + }, + "fullDescription": { + "text": "Reports an unused globally accessible public function, variable, class, or property.", + "markdown": "Reports an unused globally accessible public function, variable, class, or property." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "JSUnusedGlobalSymbols", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Unused symbols", + "index": 15, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "ES6ConvertModuleExportToExport", + "shortDescription": { + "text": "'module.exports' is used instead of 'export'" + }, + "fullDescription": { + "text": "Reports a 'module.export' statement. Suggests replacing it with an 'export' or 'export default' statement. Please note that the quick-fix for converting 'module.export' into 'export' is not available for 'module.export' inside functions or statements because 'export' statements can only be at the top level of a module.", + "markdown": "Reports a `module.export` statement. Suggests replacing it with an `export` or `export default` statement. \n\nPlease note that the quick-fix for converting `module.export` into `export` is not available for `module.export` inside functions or statements because `export` statements can only be at the top level of a module." + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "ES6ConvertModuleExportToExport", + "ideaSeverity": "INFORMATION", + "qodanaSeverity": "Info" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/ES2015 migration aids", + "index": 18, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "DocumentWriteJS", + "shortDescription": { + "text": "Call to 'document.write()'" + }, + "fullDescription": { + "text": "Reports a method call to 'document.write()' or 'document.writeln()'. Most usages of such calls are performed better with explicit DOM calls, such as 'getElementByID()' and 'createElement()'. Additionally, the 'write()' and 'writeln()' calls will not work with XML DOMs, including DOMs for XHTML if viewed as XML. This can result in difficulty to point out bugs.", + "markdown": "Reports a method call to `document.write()` or `document.writeln()`. Most usages of such calls are performed better with explicit DOM calls, such as `getElementByID()` and `createElement()`. Additionally, the `write()` and `writeln()` calls will not work with XML DOMs, including DOMs for XHTML if viewed as XML. This can result in difficulty to point out bugs." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "DocumentWriteJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/DOM issues", + "index": 48, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "BlockStatementJS", + "shortDescription": { + "text": "Unnecessary block statement" + }, + "fullDescription": { + "text": "Reports a block statement that is not used as the body of 'if', 'for', 'while', 'do', 'with', or 'try' statements, or as the body of a function declaration. Starting from ECMAScript 6, JavaScript blocks introduce new scopes for 'let' and 'const' variables, but still free-standing block statements may be confusing and result in subtle bugs when used with 'var' variables.", + "markdown": "Reports a block statement that is not used as the body of `if`, `for`, `while`, `do`, `with`, or `try` statements, or as the body of a function declaration. Starting from ECMAScript 6, JavaScript blocks introduce new scopes for `let` and `const` variables, but still free-standing block statements may be confusing and result in subtle bugs when used with `var` variables." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "BlockStatementJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Potentially confusing code constructs", + "index": 24, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "AnonymousFunctionJS", + "shortDescription": { + "text": "Anonymous function" + }, + "fullDescription": { + "text": "Reports an anonymous function. An explicit name of a function expression may be helpful for debugging. Ignores function expressions without names if they have a 'name' property specified in the ECMAScript 6 standard. For example, 'var bar = function() {};' is not reported.", + "markdown": "Reports an anonymous function. An explicit name of a function expression may be helpful for debugging. Ignores function expressions without names if they have a `name` property specified in the ECMAScript 6 standard. For example, `var bar = function() {};` is not reported." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "AnonymousFunctionJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Potentially undesirable code constructs", + "index": 11, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "ObjectAllocationIgnoredJS", + "shortDescription": { + "text": "Result of object allocation ignored" + }, + "fullDescription": { + "text": "Reports object allocation where the result of the allocated object is ignored, for example, 'new Error();' as a statement, without any assignment. Such allocation expressions may indicate an odd object initialization strategy.", + "markdown": "Reports object allocation where the result of the allocated object is ignored, for example, `new Error();` as a statement, without any assignment. Such allocation expressions may indicate an odd object initialization strategy." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "ObjectAllocationIgnored", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Probable bugs", + "index": 13, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "InfiniteRecursionJS", + "shortDescription": { + "text": "Infinite recursion" + }, + "fullDescription": { + "text": "Reports a function which must either recurse infinitely or throw an exception. Such functions may not return normally.", + "markdown": "Reports a function which must either recurse infinitely or throw an exception. Such functions may not return normally." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "InfiniteRecursionJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Probable bugs", + "index": 13, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "NestedConditionalExpressionJS", + "shortDescription": { + "text": "Nested conditional expression" + }, + "fullDescription": { + "text": "Reports a ternary conditional expression within another ternary condition. Such nested conditionals may be extremely confusing, and best replaced by more explicit conditional logic.", + "markdown": "Reports a ternary conditional expression within another ternary condition. Such nested conditionals may be extremely confusing, and best replaced by more explicit conditional logic." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "NestedConditionalExpressionJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Potentially confusing code constructs", + "index": 24, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JSTypeOfValues", + "shortDescription": { + "text": "'typeof' comparison with non-standard value" + }, + "fullDescription": { + "text": "Reports a comparison of a 'typeof' expression with a literal string which is not one of the standard types: 'undefined', 'object', 'boolean', 'number', 'string', 'function', or 'symbol'. Such comparisons always return 'false'.", + "markdown": "Reports a comparison of a `typeof` expression with a literal string which is not one of the standard types: `undefined`, `object`, `boolean`, `number`, `string`, `function`, or `symbol`. Such comparisons always return `false`." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "JSTypeOfValues", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Probable bugs", + "index": 13, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "IncompatibleMaskJS", + "shortDescription": { + "text": "Incompatible bitwise mask operation" + }, + "fullDescription": { + "text": "Reports a bitwise mask expression which for sure evaluates to 'true' or 'false'. Expressions are of the form '(var & constant1) == constant2' or '(var | constant1) == constant2', where 'constant1' and 'constant2' are incompatible bitmask constants. Example: '// Incompatible mask: as the last byte in mask is zero,\n// something like 0x1200 would be possible, but not 0x1234\nif ((mask & 0xFF00) == 0x1234) {...}'", + "markdown": "Reports a bitwise mask expression which for sure evaluates to `true` or `false`. Expressions are of the form `(var & constant1) == constant2` or `(var | constant1) == constant2`, where `constant1` and `constant2` are incompatible bitmask constants.\n\nExample:\n\n\n // Incompatible mask: as the last byte in mask is zero,\n // something like 0x1200 would be possible, but not 0x1234\n if ((mask & 0xFF00) == 0x1234) {...}\n" + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "IncompatibleBitwiseMaskOperation", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Bitwise operation issues", + "index": 17, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "ES6PossiblyAsyncFunction", + "shortDescription": { + "text": "'await' in non-async function" + }, + "fullDescription": { + "text": "Reports a usage of 'await' in a function that was possibly intended to be async but is actually missing the 'async' modifier. Although 'await' can be used as an identifier, it is likely that it was intended to be used as an operator, so the containing function should be made 'async'.", + "markdown": "Reports a usage of `await` in a function that was possibly intended to be async but is actually missing the `async` modifier. Although `await` can be used as an identifier, it is likely that it was intended to be used as an operator, so the containing function should be made `async`." + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "ES6PossiblyAsyncFunction", + "ideaSeverity": "WEAK WARNING", + "qodanaSeverity": "Moderate" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Async code and promises", + "index": 49, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "TextLabelInSwitchStatementJS", + "shortDescription": { + "text": "Text label in 'switch' statement" + }, + "fullDescription": { + "text": "Reports a labeled statement inside a 'switch' statement, which often results from a typo. Example: 'switch(x)\n {\n case 1:\n case2: //typo!\n case 3:\n break;\n }'", + "markdown": "Reports a labeled statement inside a `switch` statement, which often results from a typo.\n\nExample:\n\n\n switch(x)\n {\n case 1:\n case2: //typo!\n case 3:\n break;\n }\n" + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "TextLabelInSwitchStatementJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Switch statement issues", + "index": 47, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "EmptyCatchBlockJS", + "shortDescription": { + "text": "Empty 'catch' block" + }, + "fullDescription": { + "text": "Reports an empty 'catch' block. This indicates that errors are simply ignored instead of handling them. Any comment in a 'catch' block mutes the inspection.", + "markdown": "Reports an empty `catch` block. This indicates that errors are simply ignored instead of handling them. \n\nAny comment in a `catch` block mutes the inspection." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "EmptyCatchBlockJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Try statement issues", + "index": 27, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JSHint", + "shortDescription": { + "text": "JSHint" + }, + "fullDescription": { + "text": "Reports a problem detected by the JSHint linter.", + "markdown": "Reports a problem detected by the [JSHint](https://jshint.com/) linter." + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "JSHint", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Code quality tools", + "index": 51, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "FlowJSFlagCommentPlacement", + "shortDescription": { + "text": "Misplaced @flow flag" + }, + "fullDescription": { + "text": "Reports a '@flow' flag comment that is not located at the top of a file.", + "markdown": "Reports a `@flow` flag comment that is not located at the top of a file." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "FlowJSFlagCommentPlacement", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Flow type checker", + "index": 12, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "Eslint", + "shortDescription": { + "text": "ESLint" + }, + "fullDescription": { + "text": "Reports a discrepancy detected by the ESLint linter. The highlighting is based on the rule severity specified in the ESLint configuration file for each individual rule. Clear the 'Use rule severity from the configuration file' checkbox to use the severity configured in this inspection for all ESLint rules.", + "markdown": "Reports a discrepancy detected by the [ESLint](https://eslint.org) linter. \n\nThe highlighting is based on the rule severity specified in the [ESLint configuration file](https://eslint.org/docs/user-guide/configuring) for each individual rule. \n\nClear the 'Use rule severity from the configuration file' checkbox to use the severity configured in this inspection for all ESLint rules." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "Eslint", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Code quality tools", + "index": 51, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JSDuplicatedDeclaration", + "shortDescription": { + "text": "Duplicate declaration" + }, + "fullDescription": { + "text": "Reports multiple declarations in a scope.", + "markdown": "Reports multiple declarations in a scope." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "JSDuplicatedDeclaration", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/General", + "index": 10, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JSEqualityComparisonWithCoercion.TS", + "shortDescription": { + "text": "Equality operator may cause type coercion" + }, + "fullDescription": { + "text": "Reports a usage of equality operators may cause unexpected type coercions. Suggests replacing '==' or '!=' equality operators with type-safe '===' or '!==' operators. Depending on the option selected, one of the following cases will be reported: All usages of '==' and '!=' operators. All usages except comparison with null. Some code styles allow using 'x == null' as a replacement for 'x === null || x === undefined'. Only suspicious expressions, such as: '==' or '!=' comparisons with '0', '''', 'null', 'true', 'false', or 'undefined'.", + "markdown": "Reports a usage of equality operators may cause unexpected type coercions. Suggests replacing `==` or `!=` equality operators with type-safe `===` or `!==` operators.\n\nDepending on the option selected, one of the following cases will be reported:\n\n* All usages of `==` and `!=` operators.\n* All usages except comparison with null. Some code styles allow using `x == null` as a replacement for `x === null || x === undefined`.\n* Only suspicious expressions, such as: `==` or `!=` comparisons with `0`, `''`, `null`, `true`, `false`, or `undefined`." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "EqualityComparisonWithCoercionJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/TypeScript", + "index": 22, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JSOctalInteger", + "shortDescription": { + "text": "Octal integer" + }, + "fullDescription": { + "text": "Reports a deprecated octal integer literal prefixed with '0' instead of '0o'. Such literals are not allowed in modern ECMAScript code, and using them in the strict mode is an error. To force this inspection for ES5 and ES3 language levels, select the 'Warn about obsolete octal literals in ES5- code' checkbox below.", + "markdown": "Reports a deprecated octal integer literal prefixed with `0` instead of `0o`. \nSuch literals are not allowed in modern ECMAScript code, and using them in the strict mode is an error. \nTo force this inspection for ES5 and ES3 language levels, select the 'Warn about obsolete octal literals in ES5- code' checkbox below." + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "JSOctalInteger", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Validity issues", + "index": 23, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "ExceptionCaughtLocallyJS", + "shortDescription": { + "text": "Exception used for local control-flow" + }, + "fullDescription": { + "text": "Reports a 'throw' statement whose exceptions are always caught by the containing 'try' statement. Using 'throw' statements as a 'goto' to change the local flow of control is confusing.", + "markdown": "Reports a `throw` statement whose exceptions are always caught by the containing `try` statement. Using `throw` statements as a `goto` to change the local flow of control is confusing." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "ExceptionCaughtLocallyJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Try statement issues", + "index": 27, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "ThrowFromFinallyBlockJS", + "shortDescription": { + "text": "'throw' inside 'finally' block" + }, + "fullDescription": { + "text": "Reports s 'throw' statement inside a 'finally' block. Such 'throw' statements may mask exceptions thrown, and complicate debugging.", + "markdown": "Reports s `throw` statement inside a `finally` block. Such `throw` statements may mask exceptions thrown, and complicate debugging." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "ThrowInsideFinallyBlockJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Try statement issues", + "index": 27, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "TypeScriptValidateGenericTypes", + "shortDescription": { + "text": "Incorrect generic type argument" + }, + "fullDescription": { + "text": "Reports an invalid type argument in a function, interface, or class declaration.", + "markdown": "Reports an invalid type argument in a function, interface, or class declaration." + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "TypeScriptValidateGenericTypes", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/TypeScript", + "index": 22, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "CyclomaticComplexityJS", + "shortDescription": { + "text": "Overly complex function" + }, + "fullDescription": { + "text": "Reports a function with too many branching points in a function (too high cyclomatic complexity). Such functions may be confusing and hard to test. Use the field provided below to specify the maximum acceptable cyclomatic complexity for a function.", + "markdown": "Reports a function with too many branching points in a function (too high cyclomatic complexity). Such functions may be confusing and hard to test.\n\n\nUse the field provided below to specify the maximum acceptable cyclomatic complexity for a function." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "OverlyComplexFunctionJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Function metrics", + "index": 29, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JSMismatchedCollectionQueryUpdate", + "shortDescription": { + "text": "Mismatched query and update of collection" + }, + "fullDescription": { + "text": "Reports a collection of fields or variables whose contents are either queried and not updated or updated and not queried. Such mismatched queries and updates are pointless and may indicate either dead code or a typographical error. Query methods are automatically detected, based on whether they return something, or a callback is passed to them. Use the table below to specify which methods are update methods.", + "markdown": "Reports a collection of fields or variables whose contents are either queried and not updated or updated and not queried. Such mismatched queries and updates are pointless and may indicate either dead code or a typographical error.\n\n\nQuery methods are automatically detected, based on whether they return something, or a callback is passed to them.\nUse the table below to specify which methods are update methods." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "JSMismatchedCollectionQueryUpdate", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/General", + "index": 10, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "PackageJsonMismatchedDependency", + "shortDescription": { + "text": "Mismatched dependencies in package.json" + }, + "fullDescription": { + "text": "Reports a dependency from package.json that is not installed or doesn't match the specified version range.", + "markdown": "Reports a dependency from package.json that is not installed or doesn't match the specified [version range](https://docs.npmjs.com/about-semantic-versioning)." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "PackageJsonMismatchedDependency", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Imports and dependencies", + "index": 42, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JSPotentiallyInvalidUsageOfThis", + "shortDescription": { + "text": "Potentially invalid reference to 'this' from closure" + }, + "fullDescription": { + "text": "Reports a 'this' in closure that is used for referencing properties of outer context. Example: 'function Outer() {\n this.outerProp = 1;\n function inner() {\n // bad, because 'outerProp' of Outer\n // won't be updated here\n // on calling 'new Outer()' as may be expected\n this.outerProp = 2;\n }\n inner();\n}'", + "markdown": "Reports a `this` in closure that is used for referencing properties of outer context.\n\nExample:\n\n\n function Outer() {\n this.outerProp = 1;\n function inner() {\n // bad, because 'outerProp' of Outer\n // won't be updated here\n // on calling 'new Outer()' as may be expected\n this.outerProp = 2;\n }\n inner();\n }\n" + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "JSPotentiallyInvalidUsageOfThis", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Probable bugs", + "index": 13, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JSMissingSwitchDefault", + "shortDescription": { + "text": "'switch' statement has no 'default' branch" + }, + "fullDescription": { + "text": "Reports a 'switch' statement without a 'default' clause when some possible values are not enumerated.", + "markdown": "Reports a `switch` statement without a `default` clause when some possible values are not enumerated." + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "JSMissingSwitchDefault", + "ideaSeverity": "INFORMATION", + "qodanaSeverity": "Info" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Switch statement issues", + "index": 47, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JSXNamespaceValidation", + "shortDescription": { + "text": "Missing JSX namespace" + }, + "fullDescription": { + "text": "Reports a usage of a JSX construction without importing namespace. Having the namespace in the file scope ensures proper code compilation.", + "markdown": "Reports a usage of a JSX construction without importing namespace. Having the namespace in the file scope ensures proper code compilation." + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "JSXNamespaceValidation", + "ideaSeverity": "INFORMATION", + "qodanaSeverity": "Info" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Imports and dependencies", + "index": 42, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JSUnresolvedLibraryURL", + "shortDescription": { + "text": "Missed locally stored library for HTTP link" + }, + "fullDescription": { + "text": "Reports a URL of an external JavaScript library that is not associated with any locally stored file. Suggests downloading the library. Such association enables the IDE to provide proper code completion and navigation.", + "markdown": "Reports a URL of an external JavaScript library that is not associated with any locally stored file. Suggests downloading the library. Such association enables the IDE to provide proper code completion and navigation." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "JSUnresolvedLibraryURL", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/General", + "index": 10, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "ES6PreferShortImport", + "shortDescription": { + "text": "Import can be shortened" + }, + "fullDescription": { + "text": "Reports an ES6 import whose 'from' part can be shortened. Suggests importing the parent directory.", + "markdown": "Reports an ES6 import whose `from` part can be shortened. Suggests importing the parent directory." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "ES6PreferShortImport", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/General", + "index": 10, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "PointlessBitwiseExpressionJS", + "shortDescription": { + "text": "Bitwise expression can be simplified" + }, + "fullDescription": { + "text": "Reports an expression that includes 'and' with zero, 'or' by zero, or shifting by zero. Such expressions may result from not fully completed automated refactorings.", + "markdown": "Reports an expression that includes `and` with zero, `or` by zero, or shifting by zero. Such expressions may result from not fully completed automated refactorings." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "PointlessBitwiseExpressionJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Bitwise operation issues", + "index": 17, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "InfiniteLoopJS", + "shortDescription": { + "text": "Infinite loop statement" + }, + "fullDescription": { + "text": "Reports a 'for', 'while', or 'do' statement which can only exit by throwing an exception. Such statements often indicate coding errors.", + "markdown": "Reports a `for`, `while`, or `do` statement which can only exit by throwing an exception. Such statements often indicate coding errors." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "InfiniteLoopJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Probable bugs", + "index": 13, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JSStringConcatenationToES6Template", + "shortDescription": { + "text": "String concatenation is used instead of template literal" + }, + "fullDescription": { + "text": "Reports a string concatenation. Suggests replacing it with a template literal Example '\"result: \" + a + \".\"' After applying the quick-fix the code looks as follows: '`result: ${a}.`'", + "markdown": "Reports a string concatenation. Suggests replacing it with a [template literal](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Template_literals)\n\nExample\n\n \"result: \" + a + \".\" \n\nAfter applying the quick-fix the code looks as follows:\n\n `result: ${a}.` \n" + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "JSStringConcatenationToES6Template", + "ideaSeverity": "INFORMATION", + "qodanaSeverity": "Info" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/ES2015 migration aids", + "index": 18, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JSArrowFunctionBracesCanBeRemoved", + "shortDescription": { + "text": "Redundant braces around arrow function body" + }, + "fullDescription": { + "text": "Reports an arrow function whose body only consists of braces and exactly one statement. Suggests converting to concise syntax without braces. 'let incrementer = (x) => {return x + 1};' After the quick-fix is applied, the code fragment looks as follows: 'let incrementer = (x) => x + 1;'", + "markdown": "Reports an arrow function whose body only consists of braces and exactly one statement. Suggests converting to concise syntax without braces.\n\n\n let incrementer = (x) => {return x + 1};\n\nAfter the quick-fix is applied, the code fragment looks as follows:\n\n\n let incrementer = (x) => x + 1;\n" + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "JSArrowFunctionBracesCanBeRemoved", + "ideaSeverity": "INFORMATION", + "qodanaSeverity": "Info" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Code style issues", + "index": 9, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "ReplaceAssignmentWithOperatorAssignmentJS", + "shortDescription": { + "text": "Assignment could be replaced with operator assignment" + }, + "fullDescription": { + "text": "Reports an assignment operation that can be replaced by an operator assignment to make your code shorter and probably clearer. Example: 'x = x + 3;'\n 'x = x / 3;'\n After the quick fix is applied the result looks like: 'x += 3;'\n 'x /= 3;'", + "markdown": "Reports an assignment operation that can be replaced by an operator assignment to make your code shorter and probably clearer.\n\n\nExample:\n\n x = x + 3;\n x = x / 3;\n\nAfter the quick fix is applied the result looks like:\n\n x += 3;\n x /= 3;\n" + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "AssignmentReplaceableWithOperatorAssignmentJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Assignment issues", + "index": 34, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JSFileReferences", + "shortDescription": { + "text": "Unresolved file reference" + }, + "fullDescription": { + "text": "Reports an unresolved file reference in a JavaScript file, including CommonJS and AMD modules references.", + "markdown": "Reports an unresolved file reference in a JavaScript file, including CommonJS and AMD modules references." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "JSFileReferences", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/General", + "index": 10, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "Stylelint", + "shortDescription": { + "text": "Stylelint" + }, + "fullDescription": { + "text": "Reports a discrepancy detected by the Stylelint linter. The highlighting is based on the rule severity specified in the Stylelint configuration file for each individual rule.", + "markdown": "Reports a discrepancy detected by the [Stylelint](http://stylelint.io) linter. \n\nThe highlighting is based on the rule severity specified in the [Stylelint configuration file](https://stylelint.io/user-guide/configure) for each individual rule." + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "Stylelint", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "CSS/Code quality tools", + "index": 56, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "FunctionWithInconsistentReturnsJS", + "shortDescription": { + "text": "Function with inconsistent returns" + }, + "fullDescription": { + "text": "Reports a function that returns a value in some cases while in other cases no value is returned. This usually indicates an error. Example: 'function foo() {\n if (true)\n return 3;\n return;\n}'", + "markdown": "Reports a function that returns a value in some cases while in other cases no value is returned. This usually indicates an error.\n\nExample:\n\n\n function foo() {\n if (true)\n return 3;\n return;\n }\n\n" + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "FunctionWithInconsistentReturnsJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Validity issues", + "index": 23, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "EmptyTryBlockJS", + "shortDescription": { + "text": "Empty 'try' block" + }, + "fullDescription": { + "text": "Reports an empty 'try' block, which usually indicates an error.", + "markdown": "Reports an empty `try` block, which usually indicates an error." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "EmptyTryBlockJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Try statement issues", + "index": 27, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "ES6ClassMemberInitializationOrder", + "shortDescription": { + "text": "Use of possibly unassigned property in a static initializer" + }, + "fullDescription": { + "text": "Reports a class member initializer which references another non-hoisted class member while the latter may be not initialized yet. Initialization of class members happens consequently for fields, so a field cannot reference another field that is declared later.", + "markdown": "Reports a class member initializer which references another non-hoisted class member while the latter may be not initialized yet. \n\nInitialization of class members happens consequently for fields, so a field cannot reference another field that is declared later." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "ES6ClassMemberInitializationOrder", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/General", + "index": 10, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "ReservedWordUsedAsNameJS", + "shortDescription": { + "text": "Reserved word used as name" + }, + "fullDescription": { + "text": "Reports a JavaScript reserved word used as a name. The JavaScript specification reserves a number of words which are currently not used as keywords. Using those words as identifiers may result in broken code if later versions of JavaScript start using them as keywords.", + "markdown": "Reports a JavaScript reserved word used as a name. The JavaScript specification reserves a number of words which are currently not used as keywords. Using those words as identifiers may result in broken code if later versions of JavaScript start using them as keywords." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "ReservedWordAsName", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Validity issues", + "index": 23, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JSClassNamingConvention", + "shortDescription": { + "text": "Class naming convention" + }, + "fullDescription": { + "text": "Reports a class or a function that is annotated with a JSDoc '@constructor' or '@class' tag whose names are too short, too long, or do not follow the specified regular expression pattern. Use the fields provided below to specify minimum length, maximum length, and a regular expression expected for classes names. Use the standard 'java.util.regex' format for regular expressions.", + "markdown": "Reports a class or a function that is annotated with a JSDoc `@constructor` or `@class` tag whose names are too short, too long, or do not follow the specified regular expression pattern.\n\n\nUse the fields provided below to specify minimum length, maximum length, and a regular expression\nexpected for classes names. Use the standard `java.util.regex` format for regular expressions." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "JSClassNamingConvention", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Naming conventions", + "index": 46, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "TypeScriptValidateJSTypes", + "shortDescription": { + "text": "Type mismatch in 'any' type" + }, + "fullDescription": { + "text": "Reports a function call with a parameter, return value, or assigned expression or incorrect type, if the context symbol can be implicitly resolved to the 'any' type. declare var test: any;\ntest.hasOwnProperty(true); //reports 'true'", + "markdown": "Reports a function call with a parameter, return value, or assigned expression or incorrect type, if the context symbol can be implicitly resolved to the `any` type.\n\n```\ndeclare var test: any;\ntest.hasOwnProperty(true); //reports 'true'\n```" + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "TypeScriptValidateJSTypes", + "ideaSeverity": "WEAK WARNING", + "qodanaSeverity": "Moderate" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/TypeScript", + "index": 22, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "NestedFunctionJS", + "shortDescription": { + "text": "Nested function" + }, + "fullDescription": { + "text": "Reports a function nested inside another function. Although JavaScript allows functions to be nested, such constructs may be confusing. Use the checkbox below to ignore anonymous nested functions.", + "markdown": "Reports a function nested inside another function. Although JavaScript allows functions to be nested, such constructs may be confusing.\n\n\nUse the checkbox below to ignore anonymous nested functions." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "NestedFunctionJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Potentially confusing code constructs", + "index": 24, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "XHTMLIncompatabilitiesJS", + "shortDescription": { + "text": "Incompatible XHTML usages" + }, + "fullDescription": { + "text": "Reports common JavaScript DOM patterns which may present problems with XHTML documents. In particular, the patterns detected will behave completely differently depending on whether the document is loaded as XML or HTML. This can result in subtle bugs where script behaviour is dependent on the MIME-type of the document, rather than its content. Patterns detected include document.body, document.images, document.applets, document.links, document.forms, and document.anchors.", + "markdown": "Reports common JavaScript DOM patterns which may present problems with XHTML documents. In particular, the patterns detected will behave completely differently depending on whether the document is loaded as XML or HTML. This can result in subtle bugs where script behaviour is dependent on the MIME-type of the document, rather than its content. Patterns detected include **document.body** , **document.images** , **document.applets** , **document.links** , **document.forms** , and **document.anchors**." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "XHTMLIncompatabilitiesJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/DOM issues", + "index": 48, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "IncrementDecrementResultUsedJS", + "shortDescription": { + "text": "Result of increment or decrement used" + }, + "fullDescription": { + "text": "Reports an increment ('++') or decrement ('--') expression where the result of the assignment is used in a containing expression. Such assignments can result in confusion due to the order of operations, as evaluation of the assignment may affect the outer expression in unexpected ways. Example: 'var a = b++'", + "markdown": "Reports an increment (`++`) or decrement (`--`) expression where the result of the assignment is used in a containing expression. Such assignments can result in confusion due to the order of operations, as evaluation of the assignment may affect the outer expression in unexpected ways. Example: `var a = b++`" + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "IncrementDecrementResultUsedJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Potentially confusing code constructs", + "index": 24, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "SuspiciousTypeOfGuard", + "shortDescription": { + "text": "Unsound type guard check" + }, + "fullDescription": { + "text": "Reports a 'typeof' or 'instanceof' unsound type guard check. The 'typeof x' type guard can be unsound in one of the following two cases: 'typeof x' never corresponds to the specified value (for example, 'typeof x === 'number'' when 'x' is of the type 'string | boolean') 'typeof x' always corresponds to the specified value (for example, 'typeof x === 'string'' when 'x' is of the type 'string') The 'x instanceof A' type guard can be unsound in one of the following two cases: The type of 'x' is not related to 'A' The type of 'x' is 'A' or a subtype of 'A'", + "markdown": "Reports a `typeof` or `instanceof` unsound type guard check. The `typeof x` type guard can be unsound in one of the following two cases:\n\n* `typeof x` never corresponds to the specified value (for example, `typeof x === 'number'` when `x` is of the type 'string \\| boolean')\n* `typeof x` always corresponds to the specified value (for example, `typeof x === 'string'` when `x` is of the type 'string')\n\nThe `x instanceof A` type guard can be unsound in one of the following two cases:\n\n* The type of `x` is not related to `A`\n* The type of `x` is `A` or a subtype of `A`" + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "SuspiciousTypeOfGuard", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Control flow issues", + "index": 2, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "TypeScriptJSXUnresolvedComponent", + "shortDescription": { + "text": "Unresolved JSX component" + }, + "fullDescription": { + "text": "Reports an unresolved reference to a JSX component. Suggests adding an import statement if the referenced component is defined in the project or its dependencies or creating a new component with the specified name. The template for a new component can be modified in Editor | File and Code Templates.", + "markdown": "Reports an unresolved reference to a JSX component. Suggests adding an import statement if the referenced component is defined in the project or its dependencies or creating a new component with the specified name.\n\nThe template for a new component can be modified in Editor \\| File and Code Templates." + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "TypeScriptJSXUnresolvedComponent", + "ideaSeverity": "WEAK WARNING", + "qodanaSeverity": "Moderate" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/TypeScript", + "index": 22, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "TypeScriptFieldCanBeMadeReadonly", + "shortDescription": { + "text": "Field can be readonly" + }, + "fullDescription": { + "text": "Reports a private field that can be made readonly (for example, if the field is assigned only in the constructor).", + "markdown": "Reports a private field that can be made readonly (for example, if the field is assigned only in the constructor)." + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "TypeScriptFieldCanBeMadeReadonly", + "ideaSeverity": "WEAK WARNING", + "qodanaSeverity": "Moderate" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/TypeScript", + "index": 22, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "ES6DestructuringVariablesMerge", + "shortDescription": { + "text": "Destructuring properties with the same key" + }, + "fullDescription": { + "text": "Reports multiple destructuring properties with identical keys. Suggests merging the properties.", + "markdown": "Reports multiple destructuring properties with identical keys. Suggests merging the properties." + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "ES6DestructuringVariablesMerge", + "ideaSeverity": "WEAK WARNING", + "qodanaSeverity": "Moderate" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/General", + "index": 10, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "LoopStatementThatDoesntLoopJS", + "shortDescription": { + "text": "Loop statement that doesn't loop" + }, + "fullDescription": { + "text": "Reports a 'for', 'while', or 'do' statement whose bodies are guaranteed to execute at most once. Normally, this indicates an error.", + "markdown": "Reports a `for`, `while`, or `do` statement whose bodies are guaranteed to execute at most once. Normally, this indicates an error." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "LoopStatementThatDoesntLoopJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Control flow issues", + "index": 2, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "NegatedIfStatementJS", + "shortDescription": { + "text": "Negated 'if' statement" + }, + "fullDescription": { + "text": "Reports if statements which have an else branch and a negated condition. Flipping the order of the if and else branches will usually increase the clarity of such statements.", + "markdown": "Reports **if** statements which have an **else** branch and a negated condition. Flipping the order of the **if** and **else** branches will usually increase the clarity of such statements." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "NegatedIfStatementJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Potentially confusing code constructs", + "index": 24, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JSNonASCIINames", + "shortDescription": { + "text": "Identifiers with non-ASCII symbols" + }, + "fullDescription": { + "text": "Reports a non-ASCII symbol in a name. If the 'Allow only ASCII names' option is selected, reports all names that contain non-ASCII symbols. Otherwise reports all names that contain both ASCII and non-ASCII symbols.", + "markdown": "Reports a non-ASCII symbol in a name. \n\nIf the 'Allow only ASCII names' option is selected, reports all names that contain non-ASCII symbols. \nOtherwise reports all names that contain both ASCII and non-ASCII symbols." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "JSNonASCIINames", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Naming conventions", + "index": 46, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "TypeScriptRedundantGenericType", + "shortDescription": { + "text": "Redundant type arguments" + }, + "fullDescription": { + "text": "Reports a type argument that is equal to the default one and can be removed. Example: 'type Foo = T;\nlet z: Foo;'", + "markdown": "Reports a type argument that is equal to the default one and can be removed.\n\n\nExample:\n\n\n type Foo = T;\n let z: Foo;\n" + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "TypeScriptRedundantGenericType", + "ideaSeverity": "WEAK WARNING", + "qodanaSeverity": "Moderate" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/TypeScript", + "index": 22, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "TypeScriptUMDGlobal", + "shortDescription": { + "text": "Referenced UMD global variable" + }, + "fullDescription": { + "text": "Reports a usage of a Universal Module Definition (UMD) global variable if the current file is a module (ECMAScript or CommonJS). Referencing UMD variables without explicit imports can lead to a runtime error if the library isn't included implicitly.", + "markdown": "Reports a usage of a Universal Module Definition (UMD) global variable if the current file is a module (ECMAScript or CommonJS). Referencing UMD variables without explicit imports can lead to a runtime error if the library isn't included implicitly." + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "TypeScriptUMDGlobal", + "ideaSeverity": "WEAK WARNING", + "qodanaSeverity": "Moderate" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/TypeScript", + "index": 22, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "UnnecessaryReturnJS", + "shortDescription": { + "text": "Unnecessary 'return' statement" + }, + "fullDescription": { + "text": "Reports an unnecessary 'return' statement, that is, a 'return' statement that returns no value and occurs just before the function would have \"fallen through\" the bottom. These statements may be safely removed.", + "markdown": "Reports an unnecessary `return` statement, that is, a `return` statement that returns no value and occurs just before the function would have \"fallen through\" the bottom. These statements may be safely removed." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "UnnecessaryReturnStatementJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Control flow issues", + "index": 2, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "ConditionalExpressionWithIdenticalBranchesJS", + "shortDescription": { + "text": "Conditional expression with identical branches" + }, + "fullDescription": { + "text": "Reports a ternary conditional expression with identical 'then' and 'else' branches.", + "markdown": "Reports a ternary conditional expression with identical `then` and `else` branches." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "ConditionalExpressionWithIdenticalBranchesJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Control flow issues", + "index": 2, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JSUnfilteredForInLoop", + "shortDescription": { + "text": "Unfiltered for..in loop" + }, + "fullDescription": { + "text": "Reports unfiltered 'for-in' loops. The use of this construct results in processing not only own properties of an object but properties from its prototype as well. It may be unexpected in some specific cases, for example, in utility methods that copy or modify all properties or when 'Object''s prototype may be incorrectly modified. For example, the following code will print 42 and myMethod: 'Object.prototype.myMethod = function myMethod() {};\nlet a = { foo: 42 };\nfor (let i in a) {\n console.log(a[i]);\n}' Suggests replacing the whole loop with a 'Object.keys()' method or adding a 'hasOwnProperty()' check. After applying the quick-fix the code looks as follows: 'for (let i in a) {\n if (a.hasOwnProperty(i)) {\n console.log(a[i]);\n }\n}'", + "markdown": "Reports unfiltered `for-in` loops. \n\nThe use of this construct results in processing not only own properties of an object but properties from its prototype as well. It may be unexpected in some specific cases, for example, in utility methods that copy or modify all properties or when `Object`'s prototype may be incorrectly modified. For example, the following code will print **42** and **myMethod** : \n\n\n Object.prototype.myMethod = function myMethod() {};\n let a = { foo: 42 };\n for (let i in a) {\n console.log(a[i]);\n }\n\nSuggests replacing the whole loop with a `Object.keys()` method or adding a `hasOwnProperty()` check. After applying the quick-fix the code looks as follows:\n\n\n for (let i in a) {\n if (a.hasOwnProperty(i)) {\n console.log(a[i]);\n }\n }\n" + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "JSUnfilteredForInLoop", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/General", + "index": 10, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JSAnnotator", + "shortDescription": { + "text": "ECMAScript specification is not followed" + }, + "fullDescription": { + "text": "Reports basic syntax issues and inconsistencies with language specification, such as invalid usages of keywords, usages of incompatible numeric format, or multiple parameters to getters/setters. Generally, such errors must always be reported and shouldn't be disabled. But in some cases, such as issues due to the dynamic nature of JavaScript, the use of not yet supported language features, or bugs in IDE's checker, it may be handy to disable reporting these very basic errors.", + "markdown": "Reports basic syntax issues and inconsistencies with language specification, such as invalid usages of keywords, usages of incompatible numeric format, or multiple parameters to getters/setters. \nGenerally, such errors must always be reported and shouldn't be disabled. But in some cases, such as issues due to the dynamic nature of JavaScript, the use of not yet supported language features, or bugs in IDE's checker, it may be handy to disable reporting these very basic errors." + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "JSAnnotator", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/General", + "index": 10, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JSIncompatibleTypesComparison", + "shortDescription": { + "text": "Comparison of expressions having incompatible types" + }, + "fullDescription": { + "text": "Reports a comparison with operands of incompatible types or an operand with a type without possible common values.", + "markdown": "Reports a comparison with operands of incompatible types or an operand with a type without possible common values." + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "JSIncompatibleTypesComparison", + "ideaSeverity": "WEAK WARNING", + "qodanaSeverity": "Moderate" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Probable bugs", + "index": 13, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JSLastCommaInObjectLiteral", + "shortDescription": { + "text": "Unneeded last comma in object literal" + }, + "fullDescription": { + "text": "Reports usages of a trailing comma in object literals. The warning is reported only when the JavaScript language version is set to ECMAScript 5.1. Trailing commas in object literals are allowed by the specification, however, some browsers might throw an error when a trailing comma is used. You can configure formatting options for trailing commas in Code Style | JavaScript or TypeScript | Punctuation.", + "markdown": "Reports usages of a trailing comma in object literals.\n\nThe warning is reported only when the JavaScript language version is set to ECMAScript 5.1.\n\nTrailing commas in object literals are allowed by the specification, however, some browsers might throw an error when a trailing comma is used.\n\nYou can configure formatting options for trailing commas in **Code Style** \\| **JavaScript** or **TypeScript** \\| **Punctuation**." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "JSLastCommaInObjectLiteral", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/General", + "index": 10, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JSFunctionExpressionToArrowFunction", + "shortDescription": { + "text": "Function expression is used instead of arrow function" + }, + "fullDescription": { + "text": "Reports a function expression. Suggests converting it to an arrow function. Example: 'arr.map(function(el) {return el + 1})' After applying the quick-fix the code looks as follows: 'arr.map(el => el + 1)'", + "markdown": "Reports a [function](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/function) expression. Suggests converting it to an [arrow function](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Functions/Arrow_functions).\n\nExample:\n\n arr.map(function(el) {return el + 1})\n\nAfter applying the quick-fix the code looks as follows:\n\n arr.map(el => el + 1)\n" + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "JSFunctionExpressionToArrowFunction", + "ideaSeverity": "INFORMATION", + "qodanaSeverity": "Info" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/ES2015 migration aids", + "index": 18, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "ES6TopLevelAwaitExpression", + "shortDescription": { + "text": "Top-level 'await' expression" + }, + "fullDescription": { + "text": "Reports a usage of a top-level 'await' expression. While the new 'top-level async' proposal is on its way, using 'await' outside async functions is not allowed.", + "markdown": "Reports a usage of a top-level `await` expression. While the new 'top-level async' proposal is on its way, using `await` outside async functions is not allowed." + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "ES6TopLevelAwaitExpression", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Async code and promises", + "index": 49, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "ES6MissingAwait", + "shortDescription": { + "text": "Missing await for an async function call" + }, + "fullDescription": { + "text": "Reports an 'async' function call without an expected 'await' prefix inside an 'async' function. Such call returns a 'Promise' and control flow is continued immediately. Example: 'async function bar() { /* ... */ }\nasync function foo() {\n bar(); // bad\n}' After the quick-fix is applied, the 'await' prefix is added: 'async function bar() { /* ... */ }\nasync function foo() {\n await bar(); // good\n}' When the 'Report for promises in return statements' checkbox is selected, also suggests adding 'await' in return statements. While this is generally not necessary, it gives two main benefits. You won't forget to add 'await' when surrounding your code with 'try-catch'. An explicit 'await' helps V8 runtime to provide async stack traces.", + "markdown": "Reports an `async` function call without an expected `await` prefix inside an `async` function. Such call returns a `Promise` and control flow is continued immediately.\n\nExample:\n\n\n async function bar() { /* ... */ }\n async function foo() {\n bar(); // bad\n }\n\n\nAfter the quick-fix is applied, the `await` prefix is added:\n\n\n async function bar() { /* ... */ }\n async function foo() {\n await bar(); // good\n }\n\nWhen the 'Report for promises in return statements' checkbox is selected, also suggests adding `await` in return statements. \nWhile this is generally not necessary, it gives two main benefits. \n\n* You won't forget to add `await` when surrounding your code with `try-catch`.\n* An explicit `await` helps V8 runtime to provide [async stack traces](https://bit.ly/v8-zero-cost-async-stack-traces)." + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "ES6MissingAwait", + "ideaSeverity": "WEAK WARNING", + "qodanaSeverity": "Moderate" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Async code and promises", + "index": 49, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "TailRecursionJS", + "shortDescription": { + "text": "Tail recursion" + }, + "fullDescription": { + "text": "Reports a tail recursion, that is, when a function calls itself as its last action before returning. A tail recursion can always be replaced by looping, which will be considerably faster. Some JavaScript engines perform this optimization, while others do not. Thus, tail recursive solutions may have considerably different performance characteristics in different environments.", + "markdown": "Reports a tail recursion, that is, when a function calls itself as its last action before returning. A tail recursion can always be replaced by looping, which will be considerably faster. Some JavaScript engines perform this optimization, while others do not. Thus, tail recursive solutions may have considerably different performance characteristics in different environments." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "TailRecursionJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Control flow issues", + "index": 2, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "ES6ConvertToForOf", + "shortDescription": { + "text": "'for..in' is used instead of 'for..of'" + }, + "fullDescription": { + "text": "Reports a usage of a 'for..in' loop on an array. Suggests replacing it with a 'for..of' loop. 'for..of' loops, which are introduced in ECMAScript 6, iterate over 'iterable' objects. For arrays, this structure is preferable to 'for..in', because it works only with array values but not with array object's properties.", + "markdown": "Reports a usage of a [for..in](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Statements/for...in) loop on an array. Suggests replacing it with a [for..of](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Statements/for...of) loop. \n`for..of` loops, which are introduced in ECMAScript 6, iterate over `iterable` objects. For arrays, this structure is preferable to `for..in`, because it works only with array values but not with array object's properties." + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "ES6ConvertToForOf", + "ideaSeverity": "INFORMATION", + "qodanaSeverity": "Info" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/ES2015 migration aids", + "index": 18, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "FlowJSCoverage", + "shortDescription": { + "text": "Code is not covered by Flow" + }, + "fullDescription": { + "text": "Reports JavaScript code fragments that are not covered by the Flow type checker. To use this inspection, configure the Flow executable in Settings | Languages & Frameworks | JavaScript.", + "markdown": "Reports JavaScript code fragments that are not covered by the Flow type checker. To use this inspection, configure the Flow executable in [Settings \\| Languages \\& Frameworks \\| JavaScript](settings://Settings.JavaScript)." + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "FlowJSCoverage", + "ideaSeverity": "WEAK WARNING", + "qodanaSeverity": "Moderate" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Flow type checker", + "index": 12, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "ParameterNamingConventionJS", + "shortDescription": { + "text": "Function parameter naming convention" + }, + "fullDescription": { + "text": "Reports a function parameter whose name is too short, too long, or doesn't follow the specified regular expression pattern. Use the fields provided below to specify minimum length, maximum length and regular expression expected for local variables names. Use the standard 'java.util.regex' format regular expressions.", + "markdown": "Reports a function parameter whose name is too short, too long, or doesn't follow the specified regular expression pattern.\n\n\nUse the fields provided below to specify minimum length, maximum length and regular expression\nexpected for local variables names. Use the standard `java.util.regex` format regular expressions." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "ParameterNamingConventionJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Naming conventions", + "index": 46, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JSUndefinedPropertyAssignment", + "shortDescription": { + "text": "Undefined property assignment" + }, + "fullDescription": { + "text": "Reports an assignment to a property that is not defined in the type of a variable. Example: '/**\n * @type {{ property1: string, property2: number }}\n */\nlet myVariable = create();\n\nmyVariable.newProperty = 3; // bad'", + "markdown": "Reports an assignment to a property that is not defined in the type of a variable.\n\nExample:\n\n\n /**\n * @type {{ property1: string, property2: number }}\n */\n let myVariable = create();\n\n myVariable.newProperty = 3; // bad\n" + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "JSUndefinedPropertyAssignment", + "ideaSeverity": "WEAK WARNING", + "qodanaSeverity": "Moderate" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Code style issues", + "index": 9, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "StandardJS", + "shortDescription": { + "text": "Standard code style" + }, + "fullDescription": { + "text": "Reports a discrepancy detected by the JavaScript Standard Style linter. The highlighting severity in the editor is based on the severity level the linter reports.", + "markdown": "Reports a discrepancy detected by the [JavaScript Standard Style](https://standardjs.com/) linter. \n\nThe highlighting severity in the editor is based on the severity level the linter reports." + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "StandardJS", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Code quality tools", + "index": 51, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "ParametersPerFunctionJS", + "shortDescription": { + "text": "Function with too many parameters" + }, + "fullDescription": { + "text": "Reports a function with too many parameters. Such functions often indicate problems with design. Use the field below to specify the maximum acceptable number of parameters for a function.", + "markdown": "Reports a function with too many parameters. Such functions often indicate problems with design.\n\n\nUse the field below to specify the maximum acceptable number of parameters for a function." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "OverlyComplexFunctionJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Function metrics", + "index": 29, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "ThisExpressionReferencesGlobalObjectJS", + "shortDescription": { + "text": "'this' expression which references the global object" + }, + "fullDescription": { + "text": "Reports a 'this' expression outside an object literal or a constructor body. Such 'this' expressions reference the top-level \"global\" JavaScript object, but are mostly useless.", + "markdown": "Reports a `this` expression outside an object literal or a constructor body. Such `this` expressions reference the top-level \"global\" JavaScript object, but are mostly useless." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "ThisExpressionReferencesGlobalObjectJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Validity issues", + "index": 23, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "NestedAssignmentJS", + "shortDescription": { + "text": "Nested assignment" + }, + "fullDescription": { + "text": "Reports an assignment expression nested inside another expression, for example, 'a = b = 1'. Such expressions may be confusing and violate the general design principle that a given construct should do precisely one thing.", + "markdown": "Reports an assignment expression nested inside another expression, for example, `a = b = 1`. Such expressions may be confusing and violate the general design principle that a given construct should do precisely one thing." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "NestedAssignmentJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Assignment issues", + "index": 34, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "DefaultNotLastCaseInSwitchJS", + "shortDescription": { + "text": "'default' not last case in 'switch'" + }, + "fullDescription": { + "text": "Reports a 'switch' statement where the 'default' case comes before another case instead of being the very last case, which may cause confusion.", + "markdown": "Reports a `switch` statement where the `default` case comes before another case instead of being the very last case, which may cause confusion." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "DefaultNotLastCaseInSwitchJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Switch statement issues", + "index": 47, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "ConfusingPlusesOrMinusesJS", + "shortDescription": { + "text": "Confusing sequence of '+' or '-'" + }, + "fullDescription": { + "text": "Reports a suspicious combination of '+' or '-' characters in JavaScript code (for example, 'a+++b'. Such sequences are confusing, and their semantics may change through changes in the whitespace.", + "markdown": "Reports a suspicious combination of `+` or `-` characters in JavaScript code (for example, `a+++b`. Such sequences are confusing, and their semantics may change through changes in the whitespace." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "ConfusingPlusesOrMinusesJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Potentially confusing code constructs", + "index": 24, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JSDeprecatedSymbols", + "shortDescription": { + "text": "Deprecated symbol used" + }, + "fullDescription": { + "text": "Reports a usage of a deprecated function variable.", + "markdown": "Reports a usage of a deprecated function variable." + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "JSDeprecatedSymbols", + "ideaSeverity": "WEAK WARNING", + "qodanaSeverity": "Moderate" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/General", + "index": 10, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "LocalVariableNamingConventionJS", + "shortDescription": { + "text": "Local variable naming convention" + }, + "fullDescription": { + "text": "Reports a local variable whose name is too short, too long, or doesn't follow the specified regular expression pattern. Use the fields provided below to specify minimum length, maximum length, and a regular expression expected for local variables names. Use the standard 'java.util.regex' format regular expressions.", + "markdown": "Reports a local variable whose name is too short, too long, or doesn't follow the specified regular expression pattern.\n\n\nUse the fields provided below to specify minimum length, maximum length, and a regular expression\nexpected for local variables names. Use the standard `java.util.regex` format regular expressions." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "LocalVariableNamingConventionJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Naming conventions", + "index": 46, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "EmptyFinallyBlockJS", + "shortDescription": { + "text": "Empty 'finally' block" + }, + "fullDescription": { + "text": "Reports an empty 'finally' block, which usually indicates an error.", + "markdown": "Reports an empty `finally` block, which usually indicates an error." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "EmptyFinallyBlockJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Try statement issues", + "index": 27, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JSCommentMatchesSignature", + "shortDescription": { + "text": "Mismatched JSDoc and function signature" + }, + "fullDescription": { + "text": "Reports mismatch between the names and the number of parameters within a JSDoc comment and the actual parameters of a function. Suggests updating parameters in JSDoc comment. Example: '/**\n * @param height Height in pixels\n */\nfunction sq(height, width) {} // width is not documented' After the quick-fix is applied: '/**\n * @param height Height in pixels\n * @param width\n */\nfunction sq(height, width) {}'", + "markdown": "Reports mismatch between the names and the number of parameters within a JSDoc comment and the actual parameters of a function. Suggests updating parameters in JSDoc comment.\n\n**Example:**\n\n\n /**\n * @param height Height in pixels\n */\n function sq(height, width) {} // width is not documented\n\nAfter the quick-fix is applied:\n\n\n /**\n * @param height Height in pixels\n * @param width\n */\n function sq(height, width) {}\n" + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "JSCommentMatchesSignature", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/General", + "index": 10, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "UpdateDependencyToLatestVersion", + "shortDescription": { + "text": "Update package.json dependencies to latest versions" + }, + "fullDescription": { + "text": "Suggests to upgrade your package.json dependencies to the latest versions, ignoring specified versions.", + "markdown": "Suggests to upgrade your package.json dependencies to the latest versions, ignoring specified versions." + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "UpdateDependencyToLatestVersion", + "ideaSeverity": "INFORMATION", + "qodanaSeverity": "Info" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Imports and dependencies", + "index": 42, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "TypeScriptConfig", + "shortDescription": { + "text": "Inconsistent tsconfig.json properties" + }, + "fullDescription": { + "text": "Reports inconsistency of a 'paths', 'checkJs', or 'extends' property in a tsconfig.json file. The 'checkJs' property requires 'allowJs'. The 'extends' property should be a valid file reference.", + "markdown": "Reports inconsistency of a `paths`, `checkJs`, or `extends` property in a tsconfig.json file. \nThe `checkJs` property requires `allowJs`. \nThe `extends` property should be a valid file reference." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "TypeScriptConfig", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/TypeScript", + "index": 22, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JSSuspiciousNameCombination", + "shortDescription": { + "text": "Suspicious variable/parameter name combination" + }, + "fullDescription": { + "text": "Reports an assignment or a function call where the name of the target variable or the function parameter does not match the name of the value assigned to it. Example: 'var x = 0;\n var y = x;' or 'var x = 0, y = 0;\n var rc = new Rectangle(y, x, 20, 20);' Here the inspection guesses that 'x' and 'y' are mixed up. Specify the names that should not be used together. An error is reported if a parameter name or an assignment target name contains words from one group while the name of the assigned or passed variable contains words from another group.", + "markdown": "Reports an assignment or a function call where the name of the target variable or the function parameter does not match the name of the value assigned to it.\n\nExample:\n\n\n var x = 0;\n var y = x;\n\nor\n\n\n var x = 0, y = 0;\n var rc = new Rectangle(y, x, 20, 20);\n\nHere the inspection guesses that `x` and `y` are mixed up.\n\nSpecify the names that should not be used together. An error is reported\nif a parameter name or an assignment target name contains words from one group while the name of the assigned or passed\nvariable contains words from another group." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "JSSuspiciousNameCombination", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Probable bugs", + "index": 13, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JSUnresolvedExtXType", + "shortDescription": { + "text": "Unresolved Ext JS xtype" + }, + "fullDescription": { + "text": "Reports an Ext JS 'xtype' reference that doesn't have a corresponding class.", + "markdown": "Reports an Ext JS `xtype` reference that doesn't have a corresponding class." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "JSUnresolvedExtXType", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/General", + "index": 10, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "ForLoopThatDoesntUseLoopVariableJS", + "shortDescription": { + "text": "'for' loop where update or condition does not use loop variable" + }, + "fullDescription": { + "text": "Reports a 'for' loop where the condition or update does not use the 'for' loop variable.", + "markdown": "Reports a `for` loop where the condition or update does not use the `for` loop variable." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "ForLoopThatDoesntUseLoopVariableJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Probable bugs", + "index": 13, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "TypeScriptAbstractClassConstructorCanBeMadeProtected", + "shortDescription": { + "text": "Abstract class constructor can be made protected" + }, + "fullDescription": { + "text": "Reports a public constructor of an abstract class and suggests making it protected (because it is useless to have it public).", + "markdown": "Reports a public constructor of an abstract class and suggests making it protected (because it is useless to have it public)." + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "TypeScriptAbstractClassConstructorCanBeMadeProtected", + "ideaSeverity": "WEAK WARNING", + "qodanaSeverity": "Moderate" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/TypeScript", + "index": 22, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "FunctionWithMultipleReturnPointsJS", + "shortDescription": { + "text": "Function with multiple return points" + }, + "fullDescription": { + "text": "Reports a function with multiple return points. Such functions are hard to understand and maintain.", + "markdown": "Reports a function with multiple return points. Such functions are hard to understand and maintain." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "FunctionWithMultipleReturnPointsJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Function metrics", + "index": 29, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JSIgnoredPromiseFromCall", + "shortDescription": { + "text": "Result of method call returning a promise is ignored" + }, + "fullDescription": { + "text": "Reports a function call that returns a 'Promise' that is not used later. Such calls are usually unintended and indicate an error.", + "markdown": "Reports a function call that returns a `Promise` that is not used later. Such calls are usually unintended and indicate an error." + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "JSIgnoredPromiseFromCall", + "ideaSeverity": "WEAK WARNING", + "qodanaSeverity": "Moderate" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Async code and promises", + "index": 49, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "ThreeNegationsPerFunctionJS", + "shortDescription": { + "text": "Function with more than three negations" + }, + "fullDescription": { + "text": "Reports a function with three or more negation operations ('!' or '!='). Such functions may be unnecessarily confusing.", + "markdown": "Reports a function with three or more negation operations (`!` or `!=`). Such functions may be unnecessarily confusing." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "FunctionWithMoreThanThreeNegationsJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Function metrics", + "index": 29, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JSRemoveUnnecessaryParentheses", + "shortDescription": { + "text": "Unnecessary parentheses" + }, + "fullDescription": { + "text": "Reports redundant parentheses. In expressions: 'var x = ((1) + 2) + 3' In arrow function argument lists: 'var incrementer = (x) => x + 1' In TypeScript and Flow type declarations: 'type Card = (Suit & Rank) | (Suit & Number)'", + "markdown": "Reports redundant parentheses.\n\nIn expressions:\n\n var x = ((1) + 2) + 3\n\nIn arrow function argument lists:\n\n var incrementer = (x) => x + 1\n\nIn TypeScript and Flow type declarations:\n\n type Card = (Suit & Rank) | (Suit & Number)\n" + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "JSRemoveUnnecessaryParentheses", + "ideaSeverity": "INFORMATION", + "qodanaSeverity": "Info" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Code style issues", + "index": 9, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "OverlyComplexBooleanExpressionJS", + "shortDescription": { + "text": "Overly complex boolean expression" + }, + "fullDescription": { + "text": "Reports a boolean expression with too many terms. Such expressions may be confusing and bug-prone. Use the field below to specify the maximum number of terms allowed in an arithmetic expression.", + "markdown": "Reports a boolean expression with too many terms. Such expressions may be confusing and bug-prone.\n\n\nUse the field below to specify the maximum number of terms allowed in an arithmetic expression." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "OverlyComplexBooleanExpressionJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Potentially confusing code constructs", + "index": 24, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "OverlyComplexArithmeticExpressionJS", + "shortDescription": { + "text": "Overly complex arithmetic expression" + }, + "fullDescription": { + "text": "Reports an arithmetic expression with too many terms. Such expressions may be confusing and bug-prone. Use the field below to specify the maximum number of terms allowed in an arithmetic expression.", + "markdown": "Reports an arithmetic expression with too many terms. Such expressions may be confusing and bug-prone.\n\n\nUse the field below to specify the maximum number of terms allowed in an arithmetic expression." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "OverlyComplexArithmeticExpressionJS", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Potentially confusing code constructs", + "index": 24, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "ES6RedundantNestingInTemplateLiteral", + "shortDescription": { + "text": "Redundant nesting in template literal" + }, + "fullDescription": { + "text": "Reports nested instances of a string or a template literal. Suggests inlining the nested instances into the containing template string. Example: 'let a = `Hello, ${`Brave ${\"New\"}`} ${\"World\"}!`' After applying the quick-fix the code looks as follows: 'let a = `Hello, Brave New World!`'", + "markdown": "Reports nested instances of a string or a template literal. Suggests inlining the nested instances into the containing template string.\n\nExample:\n\n\n let a = `Hello, ${`Brave ${\"New\"}`} ${\"World\"}!`\n\nAfter applying the quick-fix the code looks as follows:\n\n\n let a = `Hello, Brave New World!`\n" + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "ES6RedundantNestingInTemplateLiteral", + "ideaSeverity": "WEAK WARNING", + "qodanaSeverity": "Moderate" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/General", + "index": 10, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "StringLiteralBreaksHTMLJS", + "shortDescription": { + "text": "String literal which breaks HTML parsing" + }, + "fullDescription": { + "text": "Reports a string literal that contains a ' 0 && x > 0\n}' You can apply the Simplify expression quick-fix for the 'x > 0 && x > 0' part. After the quick-fix is applied, the expression looks as follows: 'x > 0'.", + "markdown": "Reports parts of boolean expressions that are either always `true`, always `false`, or redundant. Such boolean expressions can be simplified, which may improve a readability of the code. In some cases, this also indicates a presence of other issues.\n\nExample:\n\n func isNonZero(x, y int) bool {\n // the second comparison is either always true\n // or not executed at all\n return x > 0 && x > 0\n }\n\nYou can apply the **Simplify expression** quick-fix for the `x > 0 && x > 0` part. After the quick-fix\nis applied, the expression looks as follows: `x > 0`." + }, + "defaultConfiguration": { + "enabled": true, + "level": "warning", + "parameters": { + "suppressToolId": "GoBoolExpressions", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "Go/Declaration redundancy", + "index": 5, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "GoUnusedGlobalVariable", + "shortDescription": { + "text": "Unused global variable" + }, + "fullDescription": { + "text": "Reports global variables that are defined but are never used in code. If you have unused variables, the code will not compile. For more information about unused variables and imports, refer to Unused imports and variables at go.dev. 'func main() {\n a := 422\n}' Code in the example will not compile. Therefore, it is highlighted as an error. You can apply two quick-fixes for such cases: Delete variable and Rename to _. The first quick-fix deletes the variable, the second one will convert the variable to a blank identifier. After the Rename to _ quick-fix is applied: 'func main() {\n _ := 422\n}'", + "markdown": "Reports global variables that are defined but are never used in code.\n\nIf you have unused variables, the code will not compile.\nFor more information about unused variables and imports, refer to [Unused imports and\nvariables at go.dev](https://go.dev/doc/effective_go#blank_unused).\n\n func main() {\n a := 422\n }\n\nCode in the example will not compile. Therefore, it is highlighted as an error. You can apply two quick-fixes for such cases:\n**Delete variable** and **Rename to _**. The first quick-fix deletes the variable, the second one will convert the variable to a blank\nidentifier.\n\nAfter the **Rename to _** quick-fix is applied:\n\n func main() {\n _ := 422\n }\n" + }, + "defaultConfiguration": { + "enabled": true, + "level": "warning", + "parameters": { + "suppressToolId": "GoUnusedGlobalVariable", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "Go/Declaration redundancy", + "index": 5, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "GoLoopClosure", + "shortDescription": { + "text": "Loop variables captured by the func literal" + }, + "fullDescription": { + "text": "Reports references to loop variables from within 'func' literals in 'defer' and 'go' statements. Such variables might have unexpected values because they are not copied to 'func' literals, and the 'func' literals in 'defer' and 'go' are not executed immediately. For more information about closures and goroutines, refer to What happens with closures running as goroutines? at go.dev. Example: 'for _, v := range []string{\"a\", \"b\", \"c\"} {\n go func() {\n fmt.Println(v) // output will likely be `c c c`, not `a b c`\n }()\n}' After the quick-fix is applied: 'for _, v := range []string{\"a\", \"b\", \"c\"} {\n v := v // `v` is copied now\n go func() {\n fmt.Println(v)\n }()\n}' Note the analyzer only checks 'defer' and 'go' statements when they are the last statement in the loop body. Otherwise, the analysis might produce false detections.", + "markdown": "Reports references to loop variables from within `func` literals in `defer` and `go` statements. Such variables might have unexpected values because they are not copied to `func` literals, and the `func` literals in `defer` and `go` are not executed immediately.\n\nFor more information about closures and goroutines, refer to [What happens\nwith closures running as goroutines? at go.dev](https://go.dev/doc/faq#closures_and_goroutines).\n\nExample:\n\n for _, v := range []string{\"a\", \"b\", \"c\"} {\n go func() {\n fmt.Println(v) // output will likely be `c c c`, not `a b c`\n }()\n }\n\nAfter the quick-fix is applied:\n\n for _, v := range []string{\"a\", \"b\", \"c\"} {\n v := v // `v` is copied now\n go func() {\n fmt.Println(v)\n }()\n }\n\nNote the analyzer only checks `defer` and `go` statements when they are the last statement in the loop body.\nOtherwise, the analysis might produce false detections." + }, + "defaultConfiguration": { + "enabled": true, + "level": "warning", + "parameters": { + "suppressToolId": "GoLoopClosure", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "Go/Probable bugs", + "index": 4, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "GoAssignmentToReceiver", + "shortDescription": { + "text": "Assignment to a receiver" + }, + "fullDescription": { + "text": "Reports assignments to method receivers. When you assign a value to the method receiver, the value will not be reflected outside of the method itself. Values will be reflected in subsequent calls from the same method. Example: 'package main\n\nimport \"fmt\"\n\ntype demo struct {\n Val int\n}\n\nfunc (d *demo) change() {\n d = nil // Assignment to the method receiver propagates only to callees but not to callers\n d.myVal()\n}\n\nfunc (d *demo) myVal() {\n fmt.Printf(\"my val: %#v\\n\", d)\n}\n\nfunc (d demo) change2() {\n d = demo{} // Assignment to the method receiver doesn't propagate to other calls\n d.myVal()\n}\n\nfunc (d *demo) change3() {\n d.Val = 3\n d.myVal()\n}\n\nfunc main() {\n d := &demo{}\n d.myVal()\n d.change()\n d.myVal()\n d.Val = 2\n d.change2()\n d.myVal()\n d.change3()\n d.myVal()\n}'", + "markdown": "Reports assignments to method receivers.\n\nWhen you assign a value to the method receiver, the value will not be reflected outside of the method itself.\nValues will be reflected in subsequent calls from the same method.\n\nExample:\n\n package main\n\n import \"fmt\"\n\n type demo struct {\n Val int\n }\n\n func (d *demo) change() {\n d = nil // Assignment to the method receiver propagates only to callees but not to callers\n d.myVal()\n }\n\n func (d *demo) myVal() {\n fmt.Printf(\"my val: %#v\\n\", d)\n }\n\n func (d demo) change2() {\n d = demo{} // Assignment to the method receiver doesn't propagate to other calls\n d.myVal()\n }\n\n func (d *demo) change3() {\n d.Val = 3\n d.myVal()\n }\n\n func main() {\n d := &demo{}\n d.myVal()\n d.change()\n d.myVal()\n d.Val = 2\n d.change2()\n d.myVal()\n d.change3()\n d.myVal()\n }\n" + }, + "defaultConfiguration": { + "enabled": true, + "level": "note", + "parameters": { + "suppressToolId": "GoAssignmentToReceiver", + "ideaSeverity": "WEAK WARNING", + "qodanaSeverity": "Moderate" + } + }, + "relationships": [ + { + "target": { + "id": "Go/Control flow issues", + "index": 50, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "GoBuildTag", + "shortDescription": { + "text": "Malformed build tag" + }, + "fullDescription": { + "text": "Reports malformed build tags and build tags in the incorrect location. The 'go' tool expects build tags to be located in particular places and follow a special syntax. If these requirements are not followed, build tags could either be ignored or the files could be incorrectly excluded from the build. See Build Constraints at go.dev. Example: 'package main\n\n// +build ignore\n\nfunc main() {}' The '// +build ignore' part should be before the package declaration. To fix that, you can apply the Place build tag before package quick-fix. After the quick-fix is applied: '// +build ignore\n\npackage main\n\nimport \"fmt\"'", + "markdown": "Reports malformed build tags and build tags in the incorrect location. The `go` tool expects build tags to be located in particular places and follow a special syntax. If these requirements are not followed, build tags could either be ignored or the files could be incorrectly excluded from the build.\n\nSee [Build Constraints at go.dev](https://pkg.go.dev/go/build#hdr-Build_Constraints).\n\nExample:\n\n package main\n\n // +build ignore\n\n func main() {}\n\nThe `// +build ignore` part should be before the package declaration. To fix that, you can apply\nthe **Place build tag before package** quick-fix. After the quick-fix is applied:\n\n // +build ignore\n\n package main\n\n import \"fmt\"\n" + }, + "defaultConfiguration": { + "enabled": true, + "level": "note", + "parameters": { + "suppressToolId": "GoBuildTag", + "ideaSeverity": "WEAK WARNING", + "qodanaSeverity": "Moderate" + } + }, + "relationships": [ + { + "target": { + "id": "Go/Probable bugs", + "index": 4, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + } + ], + "language": "en-US", + "contents": [ + "localizedData", + "nonLocalizedData" + ], + "isComprehensive": false + }, + { + "name": "com.jetbrains.sh", + "version": "233.13017", + "rules": [ + { + "id": "ShellCheck", + "shortDescription": { + "text": "ShellCheck" + }, + "fullDescription": { + "text": "Reports shell script bugs detected by the integrated ShellCheck static analysis tool.", + "markdown": "Reports shell script bugs detected by the integrated [ShellCheck](https://github.com/koalaman/shellcheck) static analysis tool." + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "ShellCheck", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "Shell script", + "index": 6, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + } + ], + "language": "en-US", + "contents": [ + "localizedData", + "nonLocalizedData" + ], + "isComprehensive": false + }, + { + "name": "com.intellij", + "version": "233.13017.73", + "rules": [ + { + "id": "JsonSchemaDeprecation", + "shortDescription": { + "text": "Deprecated JSON property" + }, + "fullDescription": { + "text": "Reports a deprecated property in a JSON file. Note that deprecation mechanism is not defined in the JSON Schema specification yet, and this inspection uses a non-standard extension 'deprecationMessage'.", + "markdown": "Reports a deprecated property in a JSON file. \nNote that deprecation mechanism is not defined in the JSON Schema specification yet, and this inspection uses a non-standard extension 'deprecationMessage'." + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "JsonSchemaDeprecation", + "ideaSeverity": "WEAK WARNING", + "qodanaSeverity": "Moderate" + } + }, + "relationships": [ + { + "target": { + "id": "JSON and JSON5", + "index": 8, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JsonSchemaRefReference", + "shortDescription": { + "text": "Unresolved '$ref' and '$schema' references" + }, + "fullDescription": { + "text": "Reports an unresolved '$ref' or '$schema' path in a JSON schema.", + "markdown": "Reports an unresolved `$ref` or `$schema` path in a JSON schema. " + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "JsonSchemaRefReference", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JSON and JSON5", + "index": 8, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "HtmlUnknownBooleanAttribute", + "shortDescription": { + "text": "Incorrect boolean attribute" + }, + "fullDescription": { + "text": "Reports an HTML non-boolean attribute without a value. Suggests configuring attributes that should not be reported.", + "markdown": "Reports an HTML non-boolean attribute without a value. Suggests configuring attributes that should not be reported." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "HtmlUnknownBooleanAttribute", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "HTML", + "index": 14, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "DuplicatedCode", + "shortDescription": { + "text": "Duplicated code fragment" + }, + "fullDescription": { + "text": "Reports duplicated blocks of code from the selected scope: the same file or the entire project. The inspection features quick-fixes that help you to set the size of detected duplicates, navigate to repetitive code fragments, and compare them in a tool window. The inspection options allow you to select the scope of the reported duplicated fragments and set the initial size for the duplicated language constructs.", + "markdown": "Reports duplicated blocks of code from the selected scope: the same file or the entire project.\n\nThe inspection features quick-fixes that help you to set the size of detected duplicates, navigate to repetitive code fragments, and compare them in a tool window.\n\nThe inspection options allow you to select the scope of the reported duplicated fragments and set the initial size for the duplicated language constructs." + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "DuplicatedCode", + "ideaSeverity": "WEAK WARNING", + "qodanaSeverity": "Moderate" + } + }, + "relationships": [ + { + "target": { + "id": "General", + "index": 19, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "InconsistentLineSeparators", + "shortDescription": { + "text": "Inconsistent line separators" + }, + "fullDescription": { + "text": "Reports files with line separators different from the ones that are specified in the project's settings. For example, the inspection will be triggered if you set the line separator to '\\n' in Settings | Editor | Code Style | Line separator, while the file you are editing uses '\\r\\n' as a line separator. The inspection also warns you about mixed line separators within a file.", + "markdown": "Reports files with line separators different from the ones that are specified in the project's settings.\n\nFor example, the inspection will be triggered if you set the line separator to `\\n` in\n[Settings \\| Editor \\| Code Style \\| Line separator](settings://preferences.sourceCode?Line%20separator),\nwhile the file you are editing uses `\\r\\n` as a line separator.\n\nThe inspection also warns you about mixed line separators within a file." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "InconsistentLineSeparators", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "General", + "index": 19, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "RedundantSuppression", + "shortDescription": { + "text": "Redundant suppression" + }, + "fullDescription": { + "text": "Reports usages of the following elements that can be safely removed because the inspection they affect is no longer applicable in this context: '@SuppressWarning' annotation, or '// noinspection' line comment, or '/** noinspection */' JavaDoc comment Example: 'public class C {\n // symbol is already private,\n // but annotation is still around\n @SuppressWarnings({\"WeakerAccess\"})\n private boolean CONST = true;\n void f() {\n CONST = false;\n }\n}'", + "markdown": "Reports usages of the following elements that can be safely removed because the inspection they affect is no longer applicable in this context:\n\n* `@SuppressWarning` annotation, or\n* `// noinspection` line comment, or\n* `/** noinspection */` JavaDoc comment\n\nExample:\n\n\n public class C {\n // symbol is already private,\n // but annotation is still around\n @SuppressWarnings({\"WeakerAccess\"})\n private boolean CONST = true;\n void f() {\n CONST = false;\n }\n }\n" + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "RedundantSuppression", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "General", + "index": 19, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "ProblematicWhitespace", + "shortDescription": { + "text": "Problematic whitespace" + }, + "fullDescription": { + "text": "Reports the following problems: Tabs used for indentation when the code style is configured to use only spaces. Spaces used for indentation when the code style is configured to use only tabs. Spaces used for indentation and tabs used for alignment when the code style is configured to use smart tabs.", + "markdown": "Reports the following problems:\n\n* Tabs used for indentation when the code style is configured to use only spaces.\n* Spaces used for indentation when the code style is configured to use only tabs.\n* Spaces used for indentation and tabs used for alignment when the code style is configured to use smart tabs." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "ProblematicWhitespace", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "General", + "index": 19, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "HtmlUnknownTarget", + "shortDescription": { + "text": "Unresolved file in a link" + }, + "fullDescription": { + "text": "Reports an unresolved file in a link.", + "markdown": "Reports an unresolved file in a link." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "HtmlUnknownTarget", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "HTML", + "index": 14, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "SSBasedInspection", + "shortDescription": { + "text": "Structural search inspection" + }, + "fullDescription": { + "text": "Allows configuring Structural Search/Structural Replace templates that you can apply to the file you are editing. All matches will be highlighted and marked with the template name that you have configured. If you configure the Structural Replace pattern as well, the corresponding replace option will be available as a quick-fix.", + "markdown": "Allows configuring **Structural Search/Structural Replace** templates that you can apply to the file you are editing.\n\nAll matches will be highlighted and marked with the template name that you have configured.\nIf you configure the **Structural Replace** pattern as well, the corresponding replace option will be available as a quick-fix." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "SSBasedInspection", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "Structural search", + "index": 28, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "LongLine", + "shortDescription": { + "text": "Line is longer than allowed by code style" + }, + "fullDescription": { + "text": "Reports lines that are longer than the Hard wrap at parameter specified in Settings | Editor | Code Style | General.", + "markdown": "Reports lines that are longer than the **Hard wrap at** parameter specified in [Settings \\| Editor \\| Code Style \\| General](settings://preferences.sourceCode?Hard%20wrap%20at)." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "LongLine", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "General", + "index": 19, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "XmlWrongRootElement", + "shortDescription": { + "text": "Wrong root element" + }, + "fullDescription": { + "text": "Reports a root tag name different from the name specified in the '' tag.", + "markdown": "Reports a root tag name different from the name specified in the `` tag." + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "XmlWrongRootElement", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "XML", + "index": 33, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "CheckValidXmlInScriptTagBody", + "shortDescription": { + "text": "Malformed content of 'script' tag" + }, + "fullDescription": { + "text": "Reports contents of 'script' tags that are invalid XML. Example: '' After the quick-fix is applied: ''", + "markdown": "Reports contents of `script` tags that are invalid XML. \n\n**Example:**\n\n\n \n\nAfter the quick-fix is applied:\n\n\n \n" + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "CheckValidXmlInScriptTagBody", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "HTML", + "index": 14, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "RegExpSuspiciousBackref", + "shortDescription": { + "text": "Suspicious back reference" + }, + "fullDescription": { + "text": "Reports back references that will not be resolvable at runtime. This means that the back reference can never match anything. A back reference will not be resolvable when the group is defined after the back reference, or if the group is defined in a different branch of an alternation. Example of a group defined after its back reference: '\\1(abc)' Example of a group and a back reference in different branches: 'a(b)c|(xy)\\1z' New in 2022.1", + "markdown": "Reports back references that will not be resolvable at runtime. This means that the back reference can never match anything. A back reference will not be resolvable when the group is defined after the back reference, or if the group is defined in a different branch of an alternation.\n\n**Example of a group defined after its back reference:**\n\n\n \\1(abc)\n\n**Example of a group and a back reference in different branches:**\n\n\n a(b)c|(xy)\\1z\n\nNew in 2022.1" + }, + "defaultConfiguration": { + "enabled": true, + "level": "warning", + "parameters": { + "suppressToolId": "RegExpSuspiciousBackref", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "RegExp", + "index": 37, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "RegExpSingleCharAlternation", + "shortDescription": { + "text": "Single character alternation" + }, + "fullDescription": { + "text": "Reports single char alternation in a RegExp. It is simpler to use a character class instead. This may also provide better matching performance. Example: 'a|b|c|d' After the quick-fix is applied: '[abcd]' New in 2017.1", + "markdown": "Reports single char alternation in a RegExp. It is simpler to use a character class instead. This may also provide better matching performance.\n\n**Example:**\n\n\n a|b|c|d\n\nAfter the quick-fix is applied:\n\n\n [abcd]\n\n\nNew in 2017.1" + }, + "defaultConfiguration": { + "enabled": true, + "level": "warning", + "parameters": { + "suppressToolId": "RegExpSingleCharAlternation", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "RegExp", + "index": 37, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "HtmlUnknownAttribute", + "shortDescription": { + "text": "Unknown attribute" + }, + "fullDescription": { + "text": "Reports an unknown HTML attribute. Suggests configuring attributes that should not be reported.", + "markdown": "Reports an unknown HTML attribute. Suggests configuring attributes that should not be reported." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "HtmlUnknownAttribute", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "HTML", + "index": 14, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "CheckTagEmptyBody", + "shortDescription": { + "text": "Empty element content" + }, + "fullDescription": { + "text": "Reports XML elements without contents. Example: '\n \n ' After the quick-fix is applied: '\n \n '", + "markdown": "Reports XML elements without contents.\n\n**Example:**\n\n\n \n \n \n\nAfter the quick-fix is applied:\n\n\n \n \n \n" + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "CheckTagEmptyBody", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "XML", + "index": 33, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "RegExpRedundantEscape", + "shortDescription": { + "text": "Redundant character escape" + }, + "fullDescription": { + "text": "Reports redundant character escape sequences that can be replaced with unescaped characters preserving the meaning. Many escape sequences that are necessary outside of a character class are redundant inside square brackets '[]' of a character class. Although unescaped opening curly braces '{' outside of character classes are allowed in some dialects (JavaScript, Python, and so on), it can cause confusion and make the pattern less portable, because there are dialects that require escaping curly braces as characters. For this reason the inspection does not report escaped opening curly braces. Example: '\\-\\;[\\.]' After the quick-fix is applied: '-;[.]' The Ignore escaped closing brackets '}' and ']' option specifies whether to report '\\}' and '\\]' outside of a character class when they are allowed to be unescaped by the RegExp dialect. New in 2017.3", + "markdown": "Reports redundant character escape sequences that can be replaced with unescaped characters preserving the meaning. Many escape sequences that are necessary outside of a character class are redundant inside square brackets `[]` of a character class.\n\n\nAlthough unescaped opening curly braces `{` outside of character classes are allowed in some dialects (JavaScript, Python, and so on),\nit can cause confusion and make the pattern less portable, because there are dialects that require escaping curly braces as characters.\nFor this reason the inspection does not report escaped opening curly braces.\n\n**Example:**\n\n\n \\-\\;[\\.]\n\nAfter the quick-fix is applied:\n\n\n -;[.]\n\n\nThe **Ignore escaped closing brackets '}' and '\\]'** option specifies whether to report `\\}` and `\\]` outside of a character class\nwhen they are allowed to be unescaped by the RegExp dialect.\n\nNew in 2017.3" + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "RegExpRedundantEscape", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "RegExp", + "index": 37, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "UnresolvedReference", + "shortDescription": { + "text": "Unresolved reference" + }, + "fullDescription": { + "text": "Reports an unresolved reference to a named pattern ('define') in RELAX-NG files that use XML syntax. Suggests creating the referenced 'define' element.", + "markdown": "Reports an unresolved reference to a named pattern (`define`) in RELAX-NG files that use XML syntax. Suggests creating the referenced `define` element." + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "UnresolvedReference", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "RELAX NG", + "index": 43, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "HtmlMissingClosingTag", + "shortDescription": { + "text": "Missing closing tag" + }, + "fullDescription": { + "text": "Reports an HTML element without a closing tag. Some coding styles require that HTML elements have closing tags even where this is optional. Example: '\n \n

Behold!\n \n ' After the quick-fix is applied: '\n \n

Behold!

\n \n '", + "markdown": "Reports an HTML element without a closing tag. Some coding styles require that HTML elements have closing tags even where this is optional.\n\n**Example:**\n\n\n \n \n

Behold!\n \n \n\nAfter the quick-fix is applied:\n\n\n \n \n

Behold!

\n \n \n" + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "HtmlMissingClosingTag", + "ideaSeverity": "INFORMATION", + "qodanaSeverity": "Info" + } + }, + "relationships": [ + { + "target": { + "id": "HTML", + "index": 14, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "CustomRegExpInspection", + "shortDescription": { + "text": "Custom RegExp inspection" + }, + "fullDescription": { + "text": "Custom Regex Inspection", + "markdown": "Custom Regex Inspection" + }, + "defaultConfiguration": { + "enabled": true, + "level": "warning", + "parameters": { + "suppressToolId": "CustomRegExpInspection", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "RegExp", + "index": 37, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "IncorrectFormatting", + "shortDescription": { + "text": "Incorrect formatting" + }, + "fullDescription": { + "text": "Reports formatting issues that appear if your code doesn't follow your project's code style settings. This inspection is not compatible with languages that require third-party formatters for code formatting, for example, Go or C with CLangFormat enabled.", + "markdown": "Reports formatting issues that appear if your code doesn't\nfollow your project's code style settings.\n\n\nThis inspection is not compatible with languages that require\nthird-party formatters for code formatting, for example, Go or\nC with CLangFormat enabled." + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "IncorrectFormatting", + "ideaSeverity": "WEAK WARNING", + "qodanaSeverity": "Moderate" + } + }, + "relationships": [ + { + "target": { + "id": "General", + "index": 19, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "HtmlExtraClosingTag", + "shortDescription": { + "text": "Redundant closing tag" + }, + "fullDescription": { + "text": "Reports redundant closing tags on empty elements, for example, 'img' or 'br'. Example: '\n \n

\n \n ' After the quick-fix is applied: '\n \n
\n \n '", + "markdown": "Reports redundant closing tags on empty elements, for example, `img` or `br`.\n\n**Example:**\n\n\n \n \n

\n \n \n\nAfter the quick-fix is applied:\n\n\n \n \n
\n \n \n" + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "HtmlExtraClosingTag", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "HTML", + "index": 14, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "HtmlUnknownAnchorTarget", + "shortDescription": { + "text": "Unresolved fragment in a link" + }, + "fullDescription": { + "text": "Reports an unresolved last part of an URL after the '#' sign.", + "markdown": "Reports an unresolved last part of an URL after the `#` sign." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "HtmlUnknownAnchorTarget", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "HTML", + "index": 14, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "RegExpUnexpectedAnchor", + "shortDescription": { + "text": "Begin or end anchor in unexpected position" + }, + "fullDescription": { + "text": "Reports '^' or '\\A' anchors not at the beginning of the pattern and '$', '\\Z' or '\\z' anchors not at the end of the pattern. In the wrong position these RegExp anchors prevent the pattern from matching anything. In case of the '^' and '$' anchors, most likely the literal character was meant and the escape forgotten. Example: '(Price $10)' New in 2018.1", + "markdown": "Reports `^` or `\\A` anchors not at the beginning of the pattern and `$`, `\\Z` or `\\z` anchors not at the end of the pattern. In the wrong position these RegExp anchors prevent the pattern from matching anything. In case of the `^` and `$` anchors, most likely the literal character was meant and the escape forgotten.\n\n**Example:**\n\n\n (Price $10)\n\n\nNew in 2018.1" + }, + "defaultConfiguration": { + "enabled": true, + "level": "warning", + "parameters": { + "suppressToolId": "RegExpUnexpectedAnchor", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "RegExp", + "index": 37, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "SpellCheckingInspection", + "shortDescription": { + "text": "Typo" + }, + "fullDescription": { + "text": "Reports typos and misspellings in your code, comments, and literals and fixes them with one click.", + "markdown": "Reports typos and misspellings in your code, comments, and literals and fixes them with one click." + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "SpellCheckingInspection", + "ideaSeverity": "TYPO", + "qodanaSeverity": "Low" + } + }, + "relationships": [ + { + "target": { + "id": "Proofreading", + "index": 52, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "CheckXmlFileWithXercesValidator", + "shortDescription": { + "text": "Failed external validation" + }, + "fullDescription": { + "text": "Reports a discrepancy in an XML file with the specified DTD or schema detected by the Xerces validator.", + "markdown": "Reports a discrepancy in an XML file with the specified DTD or schema detected by the Xerces validator." + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "CheckXmlFileWithXercesValidator", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "XML", + "index": 33, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "HtmlUnknownTag", + "shortDescription": { + "text": "Unknown tag" + }, + "fullDescription": { + "text": "Reports an unknown HTML tag. Suggests configuring tags that should not be reported.", + "markdown": "Reports an unknown HTML tag. Suggests configuring tags that should not be reported." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "HtmlUnknownTag", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "HTML", + "index": 14, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "RegExpEscapedMetaCharacter", + "shortDescription": { + "text": "Escaped meta character" + }, + "fullDescription": { + "text": "Reports escaped meta characters. Some RegExp coding styles specify that meta characters should be placed inside a character class, to make the regular expression easier to understand. This inspection does not warn about the meta character '[', ']' and '^', because those would need additional escaping inside a character class. Example: '\\d+\\.\\d+' After the quick-fix is applied: '\\d+[.]\\d+' New in 2017.1", + "markdown": "Reports escaped meta characters. Some RegExp coding styles specify that meta characters should be placed inside a character class, to make the regular expression easier to understand. This inspection does not warn about the meta character `[`, `]` and `^`, because those would need additional escaping inside a character class.\n\n**Example:**\n\n\n \\d+\\.\\d+\n\nAfter the quick-fix is applied:\n\n\n \\d+[.]\\d+\n\nNew in 2017.1" + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "RegExpEscapedMetaCharacter", + "ideaSeverity": "INFORMATION", + "qodanaSeverity": "Info" + } + }, + "relationships": [ + { + "target": { + "id": "RegExp", + "index": 37, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "XmlHighlighting", + "shortDescription": { + "text": "XML highlighting" + }, + "fullDescription": { + "text": "Reports XML validation problems in the results of a batch code inspection.", + "markdown": "Reports XML validation problems in the results of a batch code inspection." + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "XmlHighlighting", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "XML", + "index": 33, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "XmlDuplicatedId", + "shortDescription": { + "text": "Duplicate 'id' attribute" + }, + "fullDescription": { + "text": "Reports a duplicate 'id' attribute in XML.", + "markdown": "Reports a duplicate `id` attribute in XML." + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "XmlDuplicatedId", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "XML", + "index": 33, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "RegExpDuplicateCharacterInClass", + "shortDescription": { + "text": "Duplicate character in character class" + }, + "fullDescription": { + "text": "Reports duplicate characters inside a RegExp character class. Duplicate characters are unnecessary and can be removed without changing the semantics of the regex. Example: '[aabc]' After the quick-fix is applied: '[abc]'", + "markdown": "Reports duplicate characters inside a RegExp character class. Duplicate characters are unnecessary and can be removed without changing the semantics of the regex.\n\n**Example:**\n\n\n [aabc]\n\nAfter the quick-fix is applied:\n\n\n [abc]\n" + }, + "defaultConfiguration": { + "enabled": true, + "level": "warning", + "parameters": { + "suppressToolId": "RegExpDuplicateCharacterInClass", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "RegExp", + "index": 37, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "XmlInvalidId", + "shortDescription": { + "text": "Unresolved 'id' reference" + }, + "fullDescription": { + "text": "Reports an unresolved 'id' reference in XML.", + "markdown": "Reports an unresolved `id` reference in XML." + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "XmlInvalidId", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "XML", + "index": 33, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "XmlUnboundNsPrefix", + "shortDescription": { + "text": "Unbound namespace prefix" + }, + "fullDescription": { + "text": "Reports an unbound namespace prefix in XML.", + "markdown": "Reports an unbound namespace prefix in XML." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "XmlUnboundNsPrefix", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "XML", + "index": 33, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "RequiredAttributes", + "shortDescription": { + "text": "Missing required attribute" + }, + "fullDescription": { + "text": "Reports a missing mandatory attribute in an XML/HTML tag. Suggests configuring attributes that should not be reported.", + "markdown": "Reports a missing mandatory attribute in an XML/HTML tag. Suggests configuring attributes that should not be reported." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "RequiredAttributes", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "HTML", + "index": 14, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "ReassignedToPlainText", + "shortDescription": { + "text": "Reassigned to plain text" + }, + "fullDescription": { + "text": "Reports files that were explicitly re-assigned to Plain Text File Type. This association is unnecessary because the platform auto-detects text files by content automatically. You can dismiss this warning by removing the file type association in Settings | Editor | File Types | Text.", + "markdown": "Reports files that were explicitly re-assigned to Plain Text File Type. This association is unnecessary because the platform auto-detects text files by content automatically.\n\nYou can dismiss this warning by removing the file type association\nin **Settings \\| Editor \\| File Types \\| Text**." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "ReassignedToPlainText", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "General", + "index": 19, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "XmlUnusedNamespaceDeclaration", + "shortDescription": { + "text": "Unused schema declaration" + }, + "fullDescription": { + "text": "Reports an unused namespace declaration or location hint in XML.", + "markdown": "Reports an unused namespace declaration or location hint in XML." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "XmlUnusedNamespaceDeclaration", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "XML", + "index": 33, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "RegExpRedundantClassElement", + "shortDescription": { + "text": "Redundant '\\d', '[:digit:]', or '\\D' class elements" + }, + "fullDescription": { + "text": "Reports redundant '\\d' or '[:digit:]' that are used in one class with '\\w' or '[:word:]' ('\\D' with '\\W') and can be removed. Example: '[\\w\\d]' After the quick-fix is applied: '[\\w]' New in 2022.2", + "markdown": "Reports redundant `\\d` or `[:digit:]` that are used in one class with `\\w` or `[:word:]` (`\\D` with `\\W`) and can be removed.\n\n**Example:**\n\n\n [\\w\\d]\n\nAfter the quick-fix is applied:\n\n\n [\\w]\n\nNew in 2022.2" + }, + "defaultConfiguration": { + "enabled": true, + "level": "note", + "parameters": { + "suppressToolId": "RegExpRedundantClassElement", + "ideaSeverity": "WEAK WARNING", + "qodanaSeverity": "Moderate" + } + }, + "relationships": [ + { + "target": { + "id": "RegExp", + "index": 37, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "RegExpSimplifiable", + "shortDescription": { + "text": "Regular expression can be simplified" + }, + "fullDescription": { + "text": "Reports regular expressions that can be simplified. Example: '[a] xx* [ah-hz]' After the quick-fix is applied: 'a x+ [ahz]' New in 2022.1", + "markdown": "Reports regular expressions that can be simplified.\n\n**Example:**\n\n\n [a] xx* [ah-hz]\n\nAfter the quick-fix is applied:\n\n\n a x+ [ahz]\n\nNew in 2022.1" + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "RegExpSimplifiable", + "ideaSeverity": "WEAK WARNING", + "qodanaSeverity": "Moderate" + } + }, + "relationships": [ + { + "target": { + "id": "RegExp", + "index": 37, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "RegExpEmptyAlternationBranch", + "shortDescription": { + "text": "Empty branch in alternation" + }, + "fullDescription": { + "text": "Reports empty branches in a RegExp alternation. An empty branch will only match the empty string, and in most cases that is not what is desired. This inspection will not report a single empty branch at the start or the end of an alternation. Example: '(alpha||bravo)' After the quick-fix is applied: '(alpha|bravo)' New in 2017.2", + "markdown": "Reports empty branches in a RegExp alternation. An empty branch will only match the empty string, and in most cases that is not what is desired. This inspection will not report a single empty branch at the start or the end of an alternation.\n\n**Example:**\n\n\n (alpha||bravo)\n\nAfter the quick-fix is applied:\n\n\n (alpha|bravo)\n\nNew in 2017.2" + }, + "defaultConfiguration": { + "enabled": true, + "level": "warning", + "parameters": { + "suppressToolId": "RegExpEmptyAlternationBranch", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "RegExp", + "index": 37, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "Annotator", + "shortDescription": { + "text": "Annotator" + }, + "fullDescription": { + "text": "Reports issues essential to this file (e.g., syntax errors) in the result of a batch code inspection run. These issues are usually always highlighted in the editor and can't be configured, unlike inspections. These options control the scope of checks performed by this inspection: Option \"Report syntax errors\": report parser-related issues. Option \"Report issues from language-specific annotators\": report issues found by annotators configured for the relevant language. See Custom Language Support: Annotators for details. Option \"Report other highlighting problems\": report issues specific to the language of the current file (e.g., type mismatches or unreported exceptions). See Custom Language Support: Highlighting for details.", + "markdown": "Reports issues essential to this file (e.g., syntax errors) in the result of a batch code inspection run. These issues are usually always highlighted in the editor and can't be configured, unlike inspections. These options control the scope of checks performed by this inspection:\n\n* Option \"**Report syntax errors**\": report parser-related issues.\n* Option \"**Report issues from language-specific annotators** \": report issues found by annotators configured for the relevant language. See [Custom Language Support: Annotators](https://plugins.jetbrains.com/docs/intellij/annotator.html) for details.\n* Option \"**Report other highlighting problems** \": report issues specific to the language of the current file (e.g., type mismatches or unreported exceptions). See [Custom Language Support: Highlighting](https://plugins.jetbrains.com/docs/intellij/syntax-highlighting-and-error-highlighting.html#semantic-highlighting) for details." + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "Annotator", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "General", + "index": 19, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "XmlPathReference", + "shortDescription": { + "text": "Unresolved file reference" + }, + "fullDescription": { + "text": "Reports an unresolved file reference in XML.", + "markdown": "Reports an unresolved file reference in XML." + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "XmlPathReference", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "XML", + "index": 33, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "RegExpUnnecessaryNonCapturingGroup", + "shortDescription": { + "text": "Unnecessary non-capturing group" + }, + "fullDescription": { + "text": "Reports unnecessary non-capturing groups, which have no influence on the match result. Example: 'Everybody be cool, (?:this) is a robbery!' After the quick-fix is applied: 'Everybody be cool, this is a robbery!' New in 2021.1", + "markdown": "Reports unnecessary non-capturing groups, which have no influence on the match result.\n\n**Example:**\n\n\n Everybody be cool, (?:this) is a robbery!\n\nAfter the quick-fix is applied:\n\n\n Everybody be cool, this is a robbery!\n\nNew in 2021.1" + }, + "defaultConfiguration": { + "enabled": true, + "level": "warning", + "parameters": { + "suppressToolId": "RegExpUnnecessaryNonCapturingGroup", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "RegExp", + "index": 37, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "TodoComment", + "shortDescription": { + "text": "TODO comment" + }, + "fullDescription": { + "text": "Reports TODO comments in your code. You can configure the format for TODO comments in Settings | Editor | TODO. Enable the Only warn on TODO comments without any details option to only warn on empty TODO comments, that don't provide any description on the task that should be done. Disable to report all TODO comments.", + "markdown": "Reports **TODO** comments in your code.\n\nYou can configure the format for **TODO** comments in [Settings \\| Editor \\| TODO](settings://preferences.toDoOptions).\n\nEnable the **Only warn on TODO comments without any details** option to only warn on empty TODO comments, that\ndon't provide any description on the task that should be done. Disable to report all TODO comments." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "TodoComment", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "General", + "index": 19, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "Json5StandardCompliance", + "shortDescription": { + "text": "Compliance with JSON5 standard" + }, + "fullDescription": { + "text": "Reports inconsistency with the language specification in a JSON5 file.", + "markdown": "Reports inconsistency with [the language specification](http://json5.org) in a JSON5 file." + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "Json5StandardCompliance", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "JSON and JSON5", + "index": 8, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JsonDuplicatePropertyKeys", + "shortDescription": { + "text": "Duplicate keys in object literals" + }, + "fullDescription": { + "text": "Reports a duplicate key in an object literal.", + "markdown": "Reports a duplicate key in an object literal." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "JsonDuplicatePropertyKeys", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JSON and JSON5", + "index": 8, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "XmlDeprecatedElement", + "shortDescription": { + "text": "Deprecated symbol" + }, + "fullDescription": { + "text": "Reports a deprecated XML element or attribute. Symbols can be marked by XML comment or documentation tag with text 'deprecated'.", + "markdown": "Reports a deprecated XML element or attribute.\n\nSymbols can be marked by XML comment or documentation tag with text 'deprecated'." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "XmlDeprecatedElement", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "XML", + "index": 33, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "RegExpRedundantNestedCharacterClass", + "shortDescription": { + "text": "Redundant nested character class" + }, + "fullDescription": { + "text": "Reports unnecessary nested character classes. Example: '[a-c[x-z]]' After the quick-fix is applied: '[a-cx-z]' New in 2020.2", + "markdown": "Reports unnecessary nested character classes.\n\n**Example:**\n\n\n [a-c[x-z]]\n\nAfter the quick-fix is applied:\n\n\n [a-cx-z]\n\nNew in 2020.2" + }, + "defaultConfiguration": { + "enabled": true, + "level": "warning", + "parameters": { + "suppressToolId": "RegExpRedundantNestedCharacterClass", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "RegExp", + "index": 37, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "HtmlWrongAttributeValue", + "shortDescription": { + "text": "Wrong attribute value" + }, + "fullDescription": { + "text": "Reports an incorrect HTML attribute value.", + "markdown": "Reports an incorrect HTML attribute value." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "HtmlWrongAttributeValue", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "HTML", + "index": 14, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "XmlDefaultAttributeValue", + "shortDescription": { + "text": "Redundant attribute with default value" + }, + "fullDescription": { + "text": "Reports a redundant assignment of the default value to an XML attribute.", + "markdown": "Reports a redundant assignment of the default value to an XML attribute." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "XmlDefaultAttributeValue", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "XML", + "index": 33, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "RegExpOctalEscape", + "shortDescription": { + "text": "Octal escape" + }, + "fullDescription": { + "text": "Reports octal escapes, which are easily confused with back references. Use hexadecimal escapes to avoid confusion. Example: '\\07' After the quick-fix is applied: '\\x07' New in 2017.1", + "markdown": "Reports octal escapes, which are easily confused with back references. Use hexadecimal escapes to avoid confusion.\n\n**Example:**\n\n\n \\07\n\nAfter the quick-fix is applied:\n\n\n \\x07\n\nNew in 2017.1" + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "RegExpOctalEscape", + "ideaSeverity": "INFORMATION", + "qodanaSeverity": "Info" + } + }, + "relationships": [ + { + "target": { + "id": "RegExp", + "index": 37, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "UnusedDefine", + "shortDescription": { + "text": "Unused define" + }, + "fullDescription": { + "text": "Reports an unused named pattern ('define') in a RELAX-NG file (XML or Compact Syntax). 'define' elements that are used through an include in another file are ignored.", + "markdown": "Reports an unused named pattern (`define`) in a RELAX-NG file (XML or Compact Syntax). `define` elements that are used through an include in another file are ignored." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "UnusedDefine", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "RELAX NG", + "index": 43, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JsonSchemaCompliance", + "shortDescription": { + "text": "Compliance with JSON schema" + }, + "fullDescription": { + "text": "Reports inconsistence between a JSON file and the JSON schema that is assigned to it.", + "markdown": "Reports inconsistence between a JSON file and the [JSON schema](https://json-schema.org) that is assigned to it. " + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "JsonSchemaCompliance", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JSON and JSON5", + "index": 8, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "EmptyDirectory", + "shortDescription": { + "text": "Empty directory" + }, + "fullDescription": { + "text": "Reports empty directories. Available only from Code | Inspect Code or Code | Analyze Code | Run Inspection by Name and isn't reported in the editor. Use the Only report empty directories located under a source folder option to have only directories under source roots reported.", + "markdown": "Reports empty directories.\n\nAvailable only from **Code \\| Inspect Code** or\n**Code \\| Analyze Code \\| Run Inspection by Name** and isn't reported in the editor.\n\nUse the **Only report empty directories located under a source folder** option to have only directories under source\nroots reported." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "EmptyDirectory", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "General", + "index": 19, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "RegExpAnonymousGroup", + "shortDescription": { + "text": "Anonymous capturing group or numeric back reference" + }, + "fullDescription": { + "text": "Reports anonymous capturing groups and numeric back references in a RegExp. These are only reported when the RegExp dialect supports named group and named group references. Named groups and named back references improve code readability and are recommended to use instead. When a capture is not needed, matching can be more performant and use less memory by using a non-capturing group, i.e. '(?:xxx)' instead of '(xxx)'. Example: '(\\d\\d\\d\\d)\\1' A better regex pattern could look like this: '(?\\d\\d\\d\\d)\\k' New in 2017.2", + "markdown": "Reports anonymous capturing groups and numeric back references in a RegExp. These are only reported when the RegExp dialect supports named group and named group references. Named groups and named back references improve code readability and are recommended to use instead. When a capture is not needed, matching can be more performant and use less memory by using a non-capturing group, i.e. `(?:xxx)` instead of `(xxx)`.\n\n**Example:**\n\n\n (\\d\\d\\d\\d)\\1\n\nA better regex pattern could look like this:\n\n\n (?\\d\\d\\d\\d)\\k\n\nNew in 2017.2" + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "RegExpAnonymousGroup", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "RegExp", + "index": 37, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "CheckDtdRefs", + "shortDescription": { + "text": "Unresolved DTD reference" + }, + "fullDescription": { + "text": "Reports inconsistency in a DTD-specific reference, for example, in a reference to an XML entity or to a DTD element declaration. Works in DTD an XML files.", + "markdown": "Reports inconsistency in a DTD-specific reference, for example, in a reference to an XML entity or to a DTD element declaration. Works in DTD an XML files." + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "CheckDtdRefs", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "XML", + "index": 33, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "NonAsciiCharacters", + "shortDescription": { + "text": "Non-ASCII characters" + }, + "fullDescription": { + "text": "Reports code elements that use non-ASCII symbols in an unusual context. Example: Non-ASCII characters used in identifiers, strings, or comments. Identifiers written in different languages, such as 'myСollection' with the letter 'C' written in Cyrillic. Comments or strings containing Unicode symbols, such as long dashes and arrows.", + "markdown": "Reports code elements that use non-ASCII symbols in an unusual context.\n\nExample:\n\n* Non-ASCII characters used in identifiers, strings, or comments.\n* Identifiers written in different languages, such as `my`**С**`ollection` with the letter **C** written in Cyrillic.\n* Comments or strings containing Unicode symbols, such as long dashes and arrows." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "NonAsciiCharacters", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "Internationalization", + "index": 61, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "LossyEncoding", + "shortDescription": { + "text": "Lossy encoding" + }, + "fullDescription": { + "text": "Reports characters that cannot be displayed because of the current document encoding. Examples: If you type international characters in a document with the US-ASCII charset, some characters will be lost on save. If you load a UTF-8-encoded file using the ISO-8859-1 one-byte charset, some characters will be displayed incorrectly. You can fix this by changing the file encoding either by specifying the encoding directly in the file, e.g. by editing 'encoding=' attribute in the XML prolog of XML file, or by changing the corresponding options in Settings | Editor | File Encodings.", + "markdown": "Reports characters that cannot be displayed because of the current document encoding.\n\nExamples:\n\n* If you type international characters in a document with the **US-ASCII** charset, some characters will be lost on save.\n* If you load a **UTF-8** -encoded file using the **ISO-8859-1** one-byte charset, some characters will be displayed incorrectly.\n\nYou can fix this by changing the file encoding\neither by specifying the encoding directly in the file, e.g. by editing `encoding=` attribute in the XML prolog of XML file,\nor by changing the corresponding options in **Settings \\| Editor \\| File Encodings**." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "LossyEncoding", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "Internationalization", + "index": 61, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "RegExpRepeatedSpace", + "shortDescription": { + "text": "Consecutive spaces" + }, + "fullDescription": { + "text": "Reports multiple consecutive spaces in a RegExp. Because spaces are not visible by default, it can be hard to see how many spaces are required. The RegExp can be made more clear by replacing the consecutive spaces with a single space and a counted quantifier. Example: '( )' After the quick-fix is applied: '( {5})' New in 2017.1", + "markdown": "Reports multiple consecutive spaces in a RegExp. Because spaces are not visible by default, it can be hard to see how many spaces are required. The RegExp can be made more clear by replacing the consecutive spaces with a single space and a counted quantifier.\n\n**Example:**\n\n\n ( )\n\nAfter the quick-fix is applied:\n\n\n ( {5})\n\n\nNew in 2017.1" + }, + "defaultConfiguration": { + "enabled": true, + "level": "warning", + "parameters": { + "suppressToolId": "RegExpRepeatedSpace", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "RegExp", + "index": 37, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "RegExpDuplicateAlternationBranch", + "shortDescription": { + "text": "Duplicate branch in alternation" + }, + "fullDescription": { + "text": "Reports duplicate branches in a RegExp alternation. Duplicate branches slow down matching and obscure the intent of the expression. Example: '(alpha|bravo|charlie|alpha)' After the quick-fix is applied: '(alpha|bravo|charlie)' New in 2017.1", + "markdown": "Reports duplicate branches in a RegExp alternation. Duplicate branches slow down matching and obscure the intent of the expression.\n\n**Example:**\n\n\n (alpha|bravo|charlie|alpha)\n\nAfter the quick-fix is applied:\n\n\n (alpha|bravo|charlie)\n\nNew in 2017.1" + }, + "defaultConfiguration": { + "enabled": true, + "level": "warning", + "parameters": { + "suppressToolId": "RegExpDuplicateAlternationBranch", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "RegExp", + "index": 37, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "IgnoreFileDuplicateEntry", + "shortDescription": { + "text": "Ignore file duplicates" + }, + "fullDescription": { + "text": "Reports duplicate entries (patterns) in the ignore file (e.g. .gitignore, .hgignore). Duplicate entries in these files are redundant and can be removed. Example: '# Output directories\n /out/\n /target/\n /out/'", + "markdown": "Reports duplicate entries (patterns) in the ignore file (e.g. .gitignore, .hgignore). Duplicate entries in these files are redundant and can be removed.\n\nExample:\n\n\n # Output directories\n /out/\n /target/\n /out/\n" + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "IgnoreFileDuplicateEntry", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "Version control", + "index": 62, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "JsonStandardCompliance", + "shortDescription": { + "text": "Compliance with JSON standard" + }, + "fullDescription": { + "text": "Reports the following discrepancies of a JSON file with the language specification: A line or block comment (configurable). Multiple top-level values (expect for JSON Lines files, configurable for others). A trailing comma in an object or array (configurable). A single quoted string. A property key is a not a double quoted strings. A NaN or Infinity/-Infinity numeric value as a floating point literal (configurable).", + "markdown": "Reports the following discrepancies of a JSON file with [the language specification](https://tools.ietf.org/html/rfc7159):\n\n* A line or block comment (configurable).\n* Multiple top-level values (expect for JSON Lines files, configurable for others).\n* A trailing comma in an object or array (configurable).\n* A single quoted string.\n* A property key is a not a double quoted strings.\n* A NaN or Infinity/-Infinity numeric value as a floating point literal (configurable)." + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "JsonStandardCompliance", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "JSON and JSON5", + "index": 8, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "CheckEmptyScriptTag", + "shortDescription": { + "text": "Empty tag" + }, + "fullDescription": { + "text": "Reports empty tags that do not work in some browsers. Example: '\n \n '", + "markdown": "Reports empty tags that do not work in some browsers.\n\n**Example:**\n\n\n \n \n \n" + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "CheckEmptyScriptTag", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "HTML", + "index": 14, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + } + ], + "language": "en-US", + "contents": [ + "localizedData", + "nonLocalizedData" + ], + "isComprehensive": false + }, + { + "name": "HtmlTools", + "version": "233.13017", + "rules": [ + { + "id": "HtmlRequiredAltAttribute", + "shortDescription": { + "text": "Missing required 'alt' attribute" + }, + "fullDescription": { + "text": "Reports a missing 'alt' attribute in a 'img' or 'applet' tag or in a 'area' element of an image map. Suggests adding a required attribute with a text alternative for the contents of the tag. Based on WCAG 2.0: H24, H35, H36, H37.", + "markdown": "Reports a missing `alt` attribute in a `img` or `applet` tag or in a `area` element of an image map. Suggests adding a required attribute with a text alternative for the contents of the tag. Based on WCAG 2.0: [H24](https://www.w3.org/TR/WCAG20-TECHS/H24.html), [H35](https://www.w3.org/TR/WCAG20-TECHS/H35.html), [H36](https://www.w3.org/TR/WCAG20-TECHS/H36.html), [H37](https://www.w3.org/TR/WCAG20-TECHS/H37.html)." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "HtmlRequiredAltAttribute", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "HTML/Accessibility", + "index": 20, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "HtmlFormInputWithoutLabel", + "shortDescription": { + "text": "Missing associated label" + }, + "fullDescription": { + "text": "Reports a form element ('input', 'textarea', or 'select') without an associated label. Suggests creating a new label. Based on WCAG 2.0: H44.", + "markdown": "Reports a form element (`input`, `textarea`, or `select`) without an associated label. Suggests creating a new label. Based on WCAG 2.0: [H44](https://www.w3.org/TR/WCAG20-TECHS/H44.html). " + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "HtmlFormInputWithoutLabel", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "HTML/Accessibility", + "index": 20, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "HtmlRequiredTitleAttribute", + "shortDescription": { + "text": "Missing required 'title' attribute" + }, + "fullDescription": { + "text": "Reports a missing title attribute 'frame', 'iframe', 'dl', and 'a' tags. Suggests adding a title attribute. Based on WCAG 2.0: H33, H40, and H64.", + "markdown": "Reports a missing title attribute `frame`, `iframe`, `dl`, and `a` tags. Suggests adding a title attribute. Based on WCAG 2.0: [H33](https://www.w3.org/TR/WCAG20-TECHS/H33.html), [H40](https://www.w3.org/TR/WCAG20-TECHS/H40.html), and [H64](https://www.w3.org/TR/WCAG20-TECHS/H64.html)." + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "HtmlRequiredTitleAttribute", + "ideaSeverity": "INFORMATION", + "qodanaSeverity": "Info" + } + }, + "relationships": [ + { + "target": { + "id": "HTML/Accessibility", + "index": 20, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "HtmlDeprecatedTag", + "shortDescription": { + "text": "Obsolete tag" + }, + "fullDescription": { + "text": "Reports an obsolete HTML5 tag. Suggests replacing the obsolete tag with a CSS or another tag.", + "markdown": "Reports an obsolete HTML5 tag. Suggests replacing the obsolete tag with a CSS or another tag." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "HtmlDeprecatedTag", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "HTML", + "index": 14, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "CheckImageSize", + "shortDescription": { + "text": "Mismatched image size" + }, + "fullDescription": { + "text": "Reports a 'width' and 'height' attribute value of a 'img' tag that is different from the actual width and height of the referenced image.", + "markdown": "Reports a `width` and `height` attribute value of a `img` tag that is different from the actual width and height of the referenced image." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "CheckImageSize", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "HTML", + "index": 14, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "HtmlRequiredSummaryAttribute", + "shortDescription": { + "text": "Missing required 'summary' attribute" + }, + "fullDescription": { + "text": "Reports a missing 'summary' attribute in a 'table' tag. Suggests adding a'summary' attribute. Based on WCAG 2.0: H73.", + "markdown": "Reports a missing `summary` attribute in a `table` tag. Suggests adding a`summary` attribute. Based on WCAG 2.0: [H73](https://www.w3.org/TR/WCAG20-TECHS/H73.html)." + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "HtmlRequiredSummaryAttribute", + "ideaSeverity": "INFORMATION", + "qodanaSeverity": "Info" + } + }, + "relationships": [ + { + "target": { + "id": "HTML/Accessibility", + "index": 20, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "HtmlRequiredLangAttribute", + "shortDescription": { + "text": "Missing required 'lang' attribute" + }, + "fullDescription": { + "text": "Reports a missing 'lang' (or 'xml:lang') attribute in a 'html' tag. Suggests adding a required attribute to state the default language of the document. Based on WCAG 2.0: H57.", + "markdown": "Reports a missing `lang` (or `xml:lang`) attribute in a `html` tag. Suggests adding a required attribute to state the default language of the document. Based on WCAG 2.0: [H57](https://www.w3.org/TR/WCAG20-TECHS/H57.html)." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "HtmlRequiredLangAttribute", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "HTML/Accessibility", + "index": 20, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "HtmlNonExistentInternetResource", + "shortDescription": { + "text": "Unresolved web link" + }, + "fullDescription": { + "text": "Reports an unresolved web link. Works by making network requests in the background.", + "markdown": "Reports an unresolved web link. Works by making network requests in the background." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "HtmlNonExistentInternetResource", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "HTML", + "index": 14, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "HtmlRequiredTitleElement", + "shortDescription": { + "text": "Missing required 'title' element" + }, + "fullDescription": { + "text": "Reports a missing 'title' element inside a 'head' section. Suggests adding a 'title' element. The title should describe the document. Based on WCAG 2.0: H25.", + "markdown": "Reports a missing `title` element inside a `head` section. Suggests adding a `title` element. The title should describe the document. Based on WCAG 2.0: [H25](https://www.w3.org/TR/WCAG20-TECHS/H25.html)." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "HtmlRequiredTitleElement", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "HTML/Accessibility", + "index": 20, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "HtmlDeprecatedAttribute", + "shortDescription": { + "text": "Obsolete attribute" + }, + "fullDescription": { + "text": "Reports an obsolete HTML5 attribute.", + "markdown": "Reports an obsolete HTML5 attribute." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "HtmlDeprecatedAttribute", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "HTML", + "index": 14, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "HtmlPresentationalElement", + "shortDescription": { + "text": "Presentational tag" + }, + "fullDescription": { + "text": "Reports a presentational HTML tag. Suggests replacing the presentational tag with a CSS or another tag.", + "markdown": "Reports a presentational HTML tag. Suggests replacing the presentational tag with a CSS or another tag." + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "HtmlPresentationalElement", + "ideaSeverity": "INFORMATION", + "qodanaSeverity": "Info" + } + }, + "relationships": [ + { + "target": { + "id": "HTML", + "index": 14, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + } + ], + "language": "en-US", + "contents": [ + "localizedData", + "nonLocalizedData" + ], + "isComprehensive": false + }, + { + "name": "com.intellij.css", + "version": "233.13017", + "rules": [ + { + "id": "CssInvalidHtmlTagReference", + "shortDescription": { + "text": "Invalid type selector" + }, + "fullDescription": { + "text": "Reports a CSS type selector that matches an unknown HTML element.", + "markdown": "Reports a CSS [type selector](https://developer.mozilla.org/en-US/docs/Web/CSS/Type_selectors) that matches an unknown HTML element." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "CssInvalidHtmlTagReference", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "CSS/Invalid elements", + "index": 26, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "CssInvalidCustomPropertyAtRuleDeclaration", + "shortDescription": { + "text": "Invalid @property declaration" + }, + "fullDescription": { + "text": "Reports a missing required syntax, inherits, or initial-value property in a declaration of a custom property.", + "markdown": "Reports a missing required [syntax](https://developer.mozilla.org/en-US/docs/web/css/@property/syntax), [inherits](https://developer.mozilla.org/en-US/docs/web/css/@property/inherits), or [initial-value](https://developer.mozilla.org/en-US/docs/web/css/@property/initial-value) property in a declaration of a custom property." + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "CssInvalidCustomPropertyAtRuleDeclaration", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "CSS/Invalid elements", + "index": 26, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "CssInvalidFunction", + "shortDescription": { + "text": "Invalid function" + }, + "fullDescription": { + "text": "Reports an unknown CSS function or an incorrect function parameter.", + "markdown": "Reports an unknown [CSS function](https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Functions) or an incorrect function parameter." + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "CssInvalidFunction", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "CSS/Invalid elements", + "index": 26, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "CssMissingSemicolon", + "shortDescription": { + "text": "Missing semicolon" + }, + "fullDescription": { + "text": "Reports a missing semicolon at the end of a declaration.", + "markdown": "Reports a missing semicolon at the end of a declaration." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "CssMissingSemicolon", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "CSS/Code style issues", + "index": 35, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "CssRedundantUnit", + "shortDescription": { + "text": "Redundant measure unit" + }, + "fullDescription": { + "text": "Reports a measure unit of a zero value where units are not required by the specification. Example: 'width: 0px'", + "markdown": "Reports a measure unit of a zero value where units are not required by the specification.\n\n**Example:**\n\n width: 0px\n" + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "CssRedundantUnit", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "CSS/Code style issues", + "index": 35, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "CssMissingComma", + "shortDescription": { + "text": "Missing comma in selector list" + }, + "fullDescription": { + "text": "Reports a multi-line selector. Most likely this means that several single-line selectors are actually intended but a comma is missing at the end of one or several lines. Example: 'input /* comma has probably been forgotten */\n.button {\n margin: 1px;\n}'", + "markdown": "Reports a multi-line selector. Most likely this means that several single-line selectors are actually intended but a comma is missing at the end of one or several lines.\n\n**Example:**\n\n\n input /* comma has probably been forgotten */\n .button {\n margin: 1px;\n }\n" + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "CssMissingComma", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "CSS/Probable bugs", + "index": 45, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "CssInvalidPropertyValue", + "shortDescription": { + "text": "Invalid property value" + }, + "fullDescription": { + "text": "Reports an incorrect CSS property value.", + "markdown": "Reports an incorrect CSS property value." + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "CssInvalidPropertyValue", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "CSS/Invalid elements", + "index": 26, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "CssBrowserCompatibilityForProperties", + "shortDescription": { + "text": "Property is incompatible with selected browsers" + }, + "fullDescription": { + "text": "Reports a CSS property that is not supported by the specified browsers. Based on the MDN Compatibility Data.", + "markdown": "Reports a CSS property that is not supported by the specified browsers. Based on the [MDN Compatibility Data](https://github.com/mdn/browser-compat-data)." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "CssBrowserCompatibilityForProperties", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "CSS", + "index": 25, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "CssInvalidCustomPropertyAtRuleName", + "shortDescription": { + "text": "Invalid @property name" + }, + "fullDescription": { + "text": "Reports an invalid custom property name. Custom property name should be prefixed with two dashes. Example: '@property invalid-property-name {\n ...\n}\n\n@property --valid-property-name {\n ...\n}'", + "markdown": "Reports an invalid custom property name. Custom property name should be prefixed with two dashes.\n\n**Example:**\n\n\n @property invalid-property-name {\n ...\n }\n\n @property --valid-property-name {\n ...\n }\n" + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "CssInvalidCustomPropertyAtRuleName", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "CSS/Invalid elements", + "index": 26, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "CssConvertColorToHexInspection", + "shortDescription": { + "text": "Color could be replaced with #-hex" + }, + "fullDescription": { + "text": "Reports an 'rgb()', 'hsl()', or other color function. Suggests replacing a color function with an equivalent hexadecimal notation. Example: 'rgb(12, 15, 255)' After the quick-fix is applied: '#0c0fff'.", + "markdown": "Reports an `rgb()`, `hsl()`, or other color function.\n\nSuggests replacing a color function with an equivalent hexadecimal notation.\n\n**Example:**\n\n rgb(12, 15, 255)\n\nAfter the quick-fix is applied:\n\n #0c0fff.\n" + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "CssConvertColorToHexInspection", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "CSS", + "index": 25, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "CssReplaceWithShorthandUnsafely", + "shortDescription": { + "text": "Properties may probably be replaced with a shorthand" + }, + "fullDescription": { + "text": "Reports a set of longhand CSS properties and suggests replacing an incomplete set of longhand CSS properties with a shorthand form, which is however not 100% equivalent in this case. For example, 2 properties: 'outline-color' and 'outline-style' may be replaced with a single 'outline'. Such replacement is not 100% equivalent because shorthands reset all omitted sub-values to their initial states. In this example, switching to the 'outline' shorthand means that 'outline-width' is also set to its initial value, which is 'medium'. This inspection doesn't handle full sets of longhand properties (when switching to shorthand is 100% safe). For such cases see the 'Properties may be safely replaced with a shorthand' inspection instead.", + "markdown": "Reports a set of longhand CSS properties and suggests replacing an incomplete set of longhand CSS properties with a shorthand form, which is however not 100% equivalent in this case.\n\n\nFor example, 2 properties: `outline-color` and `outline-style` may be replaced with a single `outline`.\nSuch replacement is not 100% equivalent because shorthands reset all omitted sub-values to their initial states.\nIn this example, switching to the `outline` shorthand means that `outline-width` is also set to its initial value,\nwhich is `medium`.\n\n\nThis inspection doesn't handle full sets of longhand properties (when switching to shorthand is 100% safe).\nFor such cases see the 'Properties may be safely replaced with a shorthand' inspection instead." + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "CssReplaceWithShorthandUnsafely", + "ideaSeverity": "INFORMATION", + "qodanaSeverity": "Info" + } + }, + "relationships": [ + { + "target": { + "id": "CSS", + "index": 25, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "CssUnknownUnit", + "shortDescription": { + "text": "Unknown unit" + }, + "fullDescription": { + "text": "Reports an unknown unit.", + "markdown": "Reports an unknown unit." + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "CssUnknownUnit", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "CSS/Invalid elements", + "index": 26, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "CssInvalidMediaFeature", + "shortDescription": { + "text": "Invalid media feature" + }, + "fullDescription": { + "text": "Reports an unknown CSS media feature or an incorrect media feature value.", + "markdown": "Reports an unknown [CSS media feature](https://developer.mozilla.org/en-US/docs/Web/CSS/Media_Queries/Using_media_queries) or an incorrect media feature value." + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "CssInvalidMediaFeature", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "CSS/Invalid elements", + "index": 26, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "CssConvertColorToRgbInspection", + "shortDescription": { + "text": "Color could be replaced with rgb()" + }, + "fullDescription": { + "text": "Reports an 'hsl()' or 'hwb()' color function or a hexadecimal color notation. Suggests replacing such color value with an equivalent 'rgb()' or 'rgba()' color function. Example: '#0c0fff' After the quick-fix is applied: 'rgb(12, 15, 255)'.", + "markdown": "Reports an `hsl()` or `hwb()` color function or a hexadecimal color notation.\n\nSuggests replacing such color value with an equivalent `rgb()` or `rgba()` color function.\n\n**Example:**\n\n #0c0fff\n\nAfter the quick-fix is applied:\n\n rgb(12, 15, 255).\n" + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "CssConvertColorToRgbInspection", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "CSS", + "index": 25, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "CssUnusedSymbol", + "shortDescription": { + "text": "Unused selector" + }, + "fullDescription": { + "text": "Reports a CSS class or an element IDs that appears in selectors but is not used in HTML. Note that complete inspection results are available only when running it via Code | Inspect Code or Code | Analyze Code | Run Inspection by Name. Due to performance reasons, style sheet files are not inspected on the fly.", + "markdown": "Reports a CSS class or an element IDs that appears in selectors but is not used in HTML.\n\n\nNote that complete inspection results are available only when running it via **Code \\| Inspect Code** or\n**Code \\| Analyze Code \\| Run Inspection by Name**.\nDue to performance reasons, style sheet files are not inspected on the fly." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "CssUnusedSymbol", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "CSS", + "index": 25, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "CssDeprecatedValue", + "shortDescription": { + "text": "Deprecated value" + }, + "fullDescription": { + "text": "Reports a deprecated CSS value. Suggests replacing the deprecated value with its valid equivalent.", + "markdown": "Reports a deprecated CSS value. Suggests replacing the deprecated value with its valid equivalent." + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "CssDeprecatedValue", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "CSS", + "index": 25, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "CssNonIntegerLengthInPixels", + "shortDescription": { + "text": "Non-integer length in pixels" + }, + "fullDescription": { + "text": "Reports a non-integer length in pixels. Example: 'width: 3.14px'", + "markdown": "Reports a non-integer length in pixels.\n\n**Example:**\n\n width: 3.14px\n" + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "CssNonIntegerLengthInPixels", + "ideaSeverity": "WEAK WARNING", + "qodanaSeverity": "Moderate" + } + }, + "relationships": [ + { + "target": { + "id": "CSS/Probable bugs", + "index": 45, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "CssInvalidImport", + "shortDescription": { + "text": "Misplaced @import" + }, + "fullDescription": { + "text": "Reports a misplaced '@import' statement. According to the specification, '@import' rules must precede all other types of rules, except '@charset' rules.", + "markdown": "Reports a misplaced `@import` statement.\n\n\nAccording to the [specification](https://developer.mozilla.org/en-US/docs/Web/CSS/@import),\n`@import` rules must precede all other types of rules, except `@charset` rules." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "CssInvalidImport", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "CSS/Invalid elements", + "index": 26, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "CssInvalidAtRule", + "shortDescription": { + "text": "Unknown at-rule" + }, + "fullDescription": { + "text": "Reports an unknown CSS at-rule.", + "markdown": "Reports an unknown [CSS at-rule](https://developer.mozilla.org/en-US/docs/Web/CSS/At-rule)." + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "CssInvalidAtRule", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "CSS/Invalid elements", + "index": 26, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "CssUnresolvedCustomProperty", + "shortDescription": { + "text": "Unresolved custom property" + }, + "fullDescription": { + "text": "Reports an unresolved reference to a custom property among the arguments of the 'var()' function.", + "markdown": "Reports an unresolved reference to a [custom property](https://developer.mozilla.org/en-US/docs/Web/CSS/--*) among the arguments of the `var()` function." + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "CssUnresolvedCustomProperty", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "CSS/Invalid elements", + "index": 26, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "CssOverwrittenProperties", + "shortDescription": { + "text": "Overwritten property" + }, + "fullDescription": { + "text": "Reports a duplicated CSS property within a ruleset. Respects shorthand properties. Example: '.foo {\n margin-bottom: 1px;\n margin-bottom: 1px; /* duplicates margin-bottom */\n margin: 0; /* overrides margin-bottom */\n}'", + "markdown": "Reports a duplicated CSS property within a ruleset. Respects shorthand properties.\n\n**Example:**\n\n\n .foo {\n margin-bottom: 1px;\n margin-bottom: 1px; /* duplicates margin-bottom */\n margin: 0; /* overrides margin-bottom */\n }\n" + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "CssOverwrittenProperties", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "CSS", + "index": 25, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "CssUnknownTarget", + "shortDescription": { + "text": "Unresolved file reference" + }, + "fullDescription": { + "text": "Reports an unresolved file reference, for example, an incorrect path in an '@import' statement.", + "markdown": "Reports an unresolved file reference, for example, an incorrect path in an `@import` statement." + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "CssUnknownTarget", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "CSS/Invalid elements", + "index": 26, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "CssNegativeValue", + "shortDescription": { + "text": "Negative property value" + }, + "fullDescription": { + "text": "Reports a negative value of a CSS property that is not expected to be less than zero, for example, object width or height.", + "markdown": "Reports a negative value of a CSS property that is not expected to be less than zero, for example, object width or height." + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "CssNegativeValue", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "CSS/Invalid elements", + "index": 26, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "CssNoGenericFontName", + "shortDescription": { + "text": "Missing generic font family name" + }, + "fullDescription": { + "text": "Verifies that the 'font-family' property contains a generic font family name as a fallback alternative. Generic font family names are: 'serif', 'sans-serif', 'cursive', 'fantasy', and 'monospace'.", + "markdown": "Verifies that the [font-family](https://developer.mozilla.org/en-US/docs/Web/CSS/font-family) property contains a generic font family name as a fallback alternative.\n\n\nGeneric font family names are: `serif`, `sans-serif`, `cursive`, `fantasy`,\nand `monospace`." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "CssNoGenericFontName", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "CSS/Probable bugs", + "index": 45, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "CssUnresolvedClassInComposesRule", + "shortDescription": { + "text": "Unresolved class in 'composes' rule" + }, + "fullDescription": { + "text": "Reports a CSS class reference in the 'composes' rule that cannot be resolved to any valid target. Example: '.className {/* ... */}\n\n .otherClassName {\n composes: className;\n }'", + "markdown": "Reports a CSS class reference in the ['composes'](https://github.com/css-modules/css-modules#composition) rule that cannot be resolved to any valid target.\n\n**Example:**\n\n\n .className {/* ... */}\n\n .otherClassName {\n composes: className;\n }\n" + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "CssUnresolvedClassInComposesRule", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "CSS/Invalid elements", + "index": 26, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "CssInvalidCharsetRule", + "shortDescription": { + "text": "Misplaced or incorrect @charset" + }, + "fullDescription": { + "text": "Reports a misplaced '@charset' at-rule or an incorrect charset value.", + "markdown": "Reports a misplaced `@charset` at-rule or an incorrect charset value." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "CssInvalidCharsetRule", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "CSS/Invalid elements", + "index": 26, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "CssReplaceWithShorthandSafely", + "shortDescription": { + "text": "Properties may be safely replaced with a shorthand" + }, + "fullDescription": { + "text": "Reports a set of longhand properties. Suggests replacing a complete set of longhand CSS properties with an equivalent shorthand form. For example, 4 properties: 'padding-top', 'padding-right', 'padding-bottom', and 'padding-left' can be safely replaced with a single 'padding' property. Note that this inspection doesn't show up if the set of longhand properties is incomplete (e.g. only 3 'padding-xxx' properties in a ruleset) because switching to a shorthand may change the result. For such cases consider the 'Properties may probably be replaced with a shorthand' inspection.", + "markdown": "Reports a set of longhand properties. Suggests replacing a complete set of longhand CSS properties with an equivalent shorthand form.\n\n\nFor example, 4 properties: `padding-top`, `padding-right`, `padding-bottom`, and\n`padding-left`\ncan be safely replaced with a single `padding` property.\n\n\nNote that this inspection doesn't show up if the set of longhand properties is incomplete\n(e.g. only 3 `padding-xxx` properties in a ruleset)\nbecause switching to a shorthand may change the result.\nFor such cases consider the 'Properties may probably be replaced with a shorthand'\ninspection." + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "CssReplaceWithShorthandSafely", + "ideaSeverity": "WEAK WARNING", + "qodanaSeverity": "Moderate" + } + }, + "relationships": [ + { + "target": { + "id": "CSS", + "index": 25, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "CssUnknownProperty", + "shortDescription": { + "text": "Unknown property" + }, + "fullDescription": { + "text": "Reports an unknown CSS property or a property used in a wrong context. Add the unknown property to the 'Custom CSS properties' list to skip validation.", + "markdown": "Reports an unknown CSS property or a property used in a wrong context.\n\nAdd the unknown property to the 'Custom CSS properties' list to skip validation." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "CssUnknownProperty", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "CSS/Invalid elements", + "index": 26, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "CssInvalidPseudoSelector", + "shortDescription": { + "text": "Invalid pseudo-selector" + }, + "fullDescription": { + "text": "Reports an incorrect CSS pseudo-class pseudo-element.", + "markdown": "Reports an incorrect CSS [pseudo-class](https://developer.mozilla.org/en-US/docs/Web/CSS/Pseudo-classes) [pseudo-element](https://developer.mozilla.org/en-US/docs/Web/CSS/Pseudo-elements)." + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "CssInvalidPseudoSelector", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "CSS/Invalid elements", + "index": 26, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "CssInvalidNestedSelector", + "shortDescription": { + "text": "Invalid nested selector" + }, + "fullDescription": { + "text": "Reports a nested selector starting with an identifier or a functional notation.", + "markdown": "Reports a nested selector starting with an identifier or a functional notation." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "CssInvalidNestedSelector", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "CSS/Invalid elements", + "index": 26, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + } + ], + "language": "en-US", + "contents": [ + "localizedData", + "nonLocalizedData" + ], + "isComprehensive": false + }, + { + "name": "com.intellij.plugins.dependencyAnalysis", + "version": "233.13017", + "rules": [ + { + "id": "CheckThirdPartySoftwareList", + "shortDescription": { + "text": "Check third party software list" + }, + "fullDescription": { + "text": "Check project for possible problems: user's third party software list does not match the collected project metadata", + "markdown": "Check project for possible problems: user's third party software list does not match the collected project metadata" + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "CheckThirdPartySoftwareList", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "Dependency analysis", + "index": 30, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "CheckDependencyLicenses", + "shortDescription": { + "text": "Check dependency licenses" + }, + "fullDescription": { + "text": "Check dependencies licenses for possible problems: missing or prohibited licenses, or other compliance issues", + "markdown": "Check dependencies licenses for possible problems: missing or prohibited licenses, or other compliance issues" + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "CheckDependencyLicenses", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "Dependency analysis", + "index": 30, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "CheckModuleLicenses", + "shortDescription": { + "text": "Check module licenses" + }, + "fullDescription": { + "text": "Check module licenses for possible problems: missing licenses or other compliance issues", + "markdown": "Check module licenses for possible problems: missing licenses or other compliance issues" + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "CheckModuleLicenses", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "Dependency analysis", + "index": 30, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + } + ], + "language": "en-US", + "contents": [ + "localizedData", + "nonLocalizedData" + ], + "isComprehensive": false + }, + { + "name": "org.jetbrains.plugins.yaml", + "version": "233.13017", + "rules": [ + { + "id": "YAMLSchemaValidation", + "shortDescription": { + "text": "Validation by JSON Schema" + }, + "fullDescription": { + "text": "Reports inconsistencies between a YAML file and a JSON Schema if the schema is specified. Scheme example: '{\n \"properties\": {\n \"SomeNumberProperty\": {\n \"type\": \"number\"\n }\n }\n }' The following is an example with the corresponding warning: 'SomeNumberProperty: hello world'", + "markdown": "Reports inconsistencies between a YAML file and a JSON Schema if the schema is specified.\n\n**Scheme example:**\n\n\n {\n \"properties\": {\n \"SomeNumberProperty\": {\n \"type\": \"number\"\n }\n }\n }\n\n**The following is an example with the corresponding warning:**\n\n\n SomeNumberProperty: hello world\n" + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "YAMLSchemaValidation", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "YAML", + "index": 32, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "YAMLIncompatibleTypes", + "shortDescription": { + "text": "Suspicious type mismatch" + }, + "fullDescription": { + "text": "Reports a mismatch between a scalar value type in YAML file and types of the values in the similar positions. Example: 'myElements:\n - value1\n - value2\n - false # <- reported, because it is a boolean value, while other values are strings'", + "markdown": "Reports a mismatch between a scalar value type in YAML file and types of the values in the similar positions.\n\n**Example:**\n\n\n myElements:\n - value1\n - value2\n - false # <- reported, because it is a boolean value, while other values are strings\n" + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "YAMLIncompatibleTypes", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "YAML", + "index": 32, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "YAMLUnresolvedAlias", + "shortDescription": { + "text": "Unresolved alias" + }, + "fullDescription": { + "text": "Reports unresolved aliases in YAML files. Example: 'some_key: *unknown_alias'", + "markdown": "Reports unresolved aliases in YAML files.\n\n**Example:**\n\n\n some_key: *unknown_alias\n" + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "YAMLUnresolvedAlias", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "YAML", + "index": 32, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "YAMLSchemaDeprecation", + "shortDescription": { + "text": "Deprecated YAML key" + }, + "fullDescription": { + "text": "Reports deprecated keys in YAML files. Deprecation is checked only if there exists a JSON schema associated with the corresponding YAML file. Note that the deprecation mechanism is not defined in the JSON Schema specification yet, and this inspection uses a non-standard 'deprecationMessage' extension. Scheme deprecation example: '{\n \"properties\": {\n \"SomeDeprecatedProperty\": {\n \"deprecationMessage\": \"Baz\",\n \"description\": \"Foo bar\"\n }\n }\n }' The following is an example with the corresponding warning: 'SomeDeprecatedProperty: some value'", + "markdown": "Reports deprecated keys in YAML files.\n\nDeprecation is checked only if there exists a JSON schema associated with the corresponding YAML file.\n\nNote that the deprecation mechanism is not defined in the JSON Schema specification yet,\nand this inspection uses a non-standard `deprecationMessage` extension.\n\n**Scheme deprecation example:**\n\n\n {\n \"properties\": {\n \"SomeDeprecatedProperty\": {\n \"deprecationMessage\": \"Baz\",\n \"description\": \"Foo bar\"\n }\n }\n }\n\n**The following is an example with the corresponding warning:**\n\n\n SomeDeprecatedProperty: some value\n" + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "YAMLSchemaDeprecation", + "ideaSeverity": "WEAK WARNING", + "qodanaSeverity": "Moderate" + } + }, + "relationships": [ + { + "target": { + "id": "YAML", + "index": 32, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "YAMLRecursiveAlias", + "shortDescription": { + "text": "Recursive alias" + }, + "fullDescription": { + "text": "Reports recursion in YAML aliases. Alias can't be recursive and be used inside the data referenced by a corresponding anchor. Example: 'some_key: &some_anchor\n sub_key1: value1\n sub_key2: *some_anchor'", + "markdown": "Reports recursion in YAML aliases.\n\nAlias can't be recursive and be used inside the data referenced by a corresponding anchor.\n\n**Example:**\n\n\n some_key: &some_anchor\n sub_key1: value1\n sub_key2: *some_anchor\n" + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "YAMLRecursiveAlias", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "YAML", + "index": 32, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "YAMLDuplicatedKeys", + "shortDescription": { + "text": "Duplicated YAML keys" + }, + "fullDescription": { + "text": "Reports duplicated keys in YAML files. Example: 'same_key: some value\n same_key: another value'", + "markdown": "Reports duplicated keys in YAML files.\n\n**Example:**\n\n\n same_key: some value\n same_key: another value\n" + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "YAMLDuplicatedKeys", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "YAML", + "index": 32, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "YAMLUnusedAnchor", + "shortDescription": { + "text": "Unused anchor" + }, + "fullDescription": { + "text": "Reports unused anchors. Example: 'some_key: &some_anchor\n key1: value1'", + "markdown": "Reports unused anchors.\n\n**Example:**\n\n\n some_key: &some_anchor\n key1: value1\n" + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "YAMLUnusedAnchor", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "YAML", + "index": 32, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + } + ], + "language": "en-US", + "contents": [ + "localizedData", + "nonLocalizedData" + ], + "isComprehensive": false + }, + { + "name": "org.jetbrains.security.package-checker", + "version": "233.13017", + "rules": [ + { + "id": "GoVulnerableCodeUsages", + "shortDescription": { + "text": "Vulnerable API usage" + }, + "fullDescription": { + "text": "Reports usages of Vulnerable APIs of imported dependencies. Fixing the reported problems helps prevent your software from being compromised by an attacker. To solve a problem, you can update to a version where the vulnerability is fixed (if available) or switch to a dependency that doesn't have the vulnerability. Vulnerability data provided by Checkmarx (c).", + "markdown": "Reports usages of Vulnerable APIs of imported dependencies.\n\nFixing the reported problems helps prevent your software from being compromised by an attacker.\n\nTo solve a problem, you can update to a version where the vulnerability is fixed (if available) or switch to a dependency that doesn't have the vulnerability.\n\nVulnerability data provided by [Checkmarx](https://checkmarx.com/) (c)." + }, + "defaultConfiguration": { + "enabled": true, + "level": "warning", + "parameters": { + "suppressToolId": "GoVulnerableCodeUsages", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "Go/Security", + "index": 36, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "VulnerableLibrariesLocal", + "shortDescription": { + "text": "Vulnerable declared dependency" + }, + "fullDescription": { + "text": "Reports vulnerabilities in Gradle, Maven, NPM and PyPI dependencies declared in your project. A full list of Gradle and Maven dependencies is shown in the Project tool window under External Libraries. Fixing the reported problems helps prevent your software from being compromised by an attacker. To solve a problem, you can update to a version where the vulnerability is fixed (if available) or switch to a dependency that doesn't have the vulnerability. The quick-fixes available may suggest updating to a safe version or visiting the Checkmarx website to learn more about a particular vulnerability. Vulnerability data provided by Checkmarx (c).", + "markdown": "Reports vulnerabilities in Gradle, Maven, NPM and PyPI dependencies declared in your project.\nA full list of Gradle and Maven dependencies is shown in the Project tool window under External Libraries.\n\nFixing the reported problems helps prevent your software from being compromised by an attacker.\n\nTo solve a problem, you can update to a version where the vulnerability is fixed (if available) or switch to a dependency that doesn't have the vulnerability.\n\nThe quick-fixes available may suggest updating to a safe version or visiting the Checkmarx website to learn more about a particular vulnerability.\n\nVulnerability data provided by [Checkmarx](https://checkmarx.com/) (c)." + }, + "defaultConfiguration": { + "enabled": true, + "level": "warning", + "parameters": { + "suppressToolId": "VulnerableLibrariesLocal", + "cweIds": [ + 1395 + ], + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "Security", + "index": 55, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "NpmVulnerableApiCode", + "shortDescription": { + "text": "Vulnerable API usage" + }, + "fullDescription": { + "text": "Reports usages of Vulnerable APIs of imported dependencies. Fixing the reported problems helps prevent your software from being compromised by an attacker. To solve a problem, you can update to a version where the vulnerability is fixed (if available) or switch to a dependency that doesn't have the vulnerability. Vulnerability data provided by Checkmarx (c).", + "markdown": "Reports usages of Vulnerable APIs of imported dependencies.\n\nFixing the reported problems helps prevent your software from being compromised by an attacker.\n\nTo solve a problem, you can update to a version where the vulnerability is fixed (if available) or switch to a dependency that doesn't have the vulnerability.\n\nVulnerability data provided by [Checkmarx](https://checkmarx.com/) (c)." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "NpmVulnerableApiCode", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "JavaScript and TypeScript/Security", + "index": 60, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + } + ], + "language": "en-US", + "contents": [ + "localizedData", + "nonLocalizedData" + ], + "isComprehensive": false + }, + { + "name": "org.intellij.intelliLang", + "version": "233.13017", + "rules": [ + { + "id": "InjectedReferences", + "shortDescription": { + "text": "Injected references" + }, + "fullDescription": { + "text": "Reports unresolved references injected by Language Injections. Example: '@Language(\"file-reference\")\n String fileName = \"/home/user/nonexistent.file\"; // highlighted if file doesn't exist'", + "markdown": "Reports unresolved references injected by [Language Injections](https://www.jetbrains.com/help/idea/using-language-injections.html).\n\nExample:\n\n\n @Language(\"file-reference\")\n String fileName = \"/home/user/nonexistent.file\"; // highlighted if file doesn't exist\n" + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "InjectedReferences", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "General", + "index": 19, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + } + ], + "language": "en-US", + "contents": [ + "localizedData", + "nonLocalizedData" + ], + "isComprehensive": false + }, + { + "name": "org.jetbrains.plugins.go-template", + "version": "233.13017", + "rules": [ + { + "id": "GoTemplateUnknownVariable", + "shortDescription": { + "text": "Unknown variable" + }, + "fullDescription": { + "text": "Reports usages of unknown variables in Go Templates. Parsing of such templates will cause panic because variables must be declared before usage. Example: '{{$v}} is zero. {{/* bad, $v is unknown */}}\n{{$v := 0}}{{$v}} is zero. {{/* good */}}'", + "markdown": "Reports usages of unknown variables in Go Templates.\n\nParsing of such templates will cause panic because variables must be declared before usage.\n\nExample:\n\n {{$v}} is zero. {{/* bad, $v is unknown */}}\n {{$v := 0}}{{$v}} is zero. {{/* good */}}\n" + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "GoTemplateUnknownVariable", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "Go Template/General", + "index": 41, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "GoTemplateDuplicateVariable", + "shortDescription": { + "text": "Duplicate variable" + }, + "fullDescription": { + "text": "Reports duplicate Go Template variables that are declared in the same scope. Duplicating a variable reassigns the existing variable with the same name. This operation might lead to different unpredicatable issues. Example: '{{$v := 0}}{{$v := 1}}{{$v}} is 0. {{/* evaluates to '1 is 0' */}}\n{{$v := 0}}{{$w := 1}}{{$v}} is 0. {{/* works as expected */}}'", + "markdown": "Reports duplicate Go Template variables that are declared in the same scope.\n\nDuplicating a variable reassigns the existing variable with the same name. This operation might lead to different\nunpredicatable issues.\n\nExample:\n\n {{$v := 0}}{{$v := 1}}{{$v}} is 0. {{/* evaluates to '1 is 0' */}}\n {{$v := 0}}{{$w := 1}}{{$v}} is 0. {{/* works as expected */}}\n" + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "GoTemplateDuplicateVariable", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "Go Template/General", + "index": 41, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + } + ], + "language": "en-US", + "contents": [ + "localizedData", + "nonLocalizedData" + ], + "isComprehensive": false + }, + { + "name": "org.intellij.qodana", + "version": "233.13017", + "rules": [ + { + "id": "GoCoverageInspection", + "shortDescription": { + "text": "Check GO source code coverage" + }, + "fullDescription": { + "text": "Reports methods and files whose coverage is below a certain threshold.", + "markdown": "Reports methods and files whose coverage is below a certain threshold." + }, + "defaultConfiguration": { + "enabled": true, + "level": "warning", + "parameters": { + "suppressToolId": "GoCoverageInspection", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "Code Coverage", + "index": 44, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "QodanaSanity", + "shortDescription": { + "text": "Sanity" + }, + "fullDescription": { + "text": "Reports issues essential to this file like syntax errors, unresolved methods and variables, etc...", + "markdown": "Reports issues essential to this file like syntax errors, unresolved methods and variables, etc..." + }, + "defaultConfiguration": { + "enabled": false, + "level": "error", + "parameters": { + "suppressToolId": "QodanaSanity", + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + "relationships": [ + { + "target": { + "id": "Qodana", + "index": 59, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + } + ], + "language": "en-US", + "contents": [ + "localizedData", + "nonLocalizedData" + ], + "isComprehensive": false + }, + { + "name": "tanvd.grazi", + "version": "233.13017", + "rules": [ + { + "id": "LanguageDetectionInspection", + "shortDescription": { + "text": "Natural language detection" + }, + "fullDescription": { + "text": "Detects natural languages and suggests enabling corresponding grammar and spelling checks.", + "markdown": "Detects natural languages and suggests enabling corresponding grammar and spelling checks." + }, + "defaultConfiguration": { + "enabled": false, + "level": "warning", + "parameters": { + "suppressToolId": "LanguageDetectionInspection", + "ideaSeverity": "WARNING", + "qodanaSeverity": "High" + } + }, + "relationships": [ + { + "target": { + "id": "Proofreading", + "index": 52, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + }, + { + "id": "GrazieInspection", + "shortDescription": { + "text": "Grammar" + }, + "fullDescription": { + "text": "Reports grammar mistakes in your text. You can configure the inspection in Settings | Editor | Natural Languages | Grammar.", + "markdown": "Reports grammar mistakes in your text. You can configure the inspection in [Settings \\| Editor \\| Natural Languages \\| Grammar](settings://reference.settingsdialog.project.grazie)." + }, + "defaultConfiguration": { + "enabled": false, + "level": "note", + "parameters": { + "suppressToolId": "GrazieInspection", + "ideaSeverity": "GRAMMAR_ERROR", + "qodanaSeverity": "Info" + } + }, + "relationships": [ + { + "target": { + "id": "Proofreading", + "index": 52, + "toolComponent": { + "name": "QDGO" + } + }, + "kinds": [ + "superset" + ] + } + ] + } + ], + "language": "en-US", + "contents": [ + "localizedData", + "nonLocalizedData" + ], + "isComprehensive": false + } + ] + }, + "invocations": [ + { + "startTimeUtc": "2024-01-03T14:13:44.532072263Z", + "exitCode": 0, + "toolExecutionNotifications": [ + { + "message": { + "text": "Reporting from [\"Sanity\"] 'sanity' inspections was suspended due to high problems count." + }, + "level": "error", + "timeUtc": "2024-01-03T14:14:00.08461703Z", + "properties": { + "qodanaKind": "sanityFailure" + } + } + ], + "executionSuccessful": true + } + ], + "language": "en-US", + "versionControlProvenance": [ + { + "repositoryUri": "https://github.com/Ne0nd0g/merlin", + "revisionId": "d4144736c5478dd7e0cd72e01cc5802c3f793e69", + "branch": "dev", + "properties": { + "repoUrl": "https://github.com/Ne0nd0g/merlin", + "lastAuthorName": "Russel Van Tuyl", + "vcsType": "Git", + "lastAuthorEmail": "russel.vantuyl@gmail.com" + } + } + ], + "results": [ + { + "ruleId": "GoUnusedConst", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused constant 'LevelDebug'", + "markdown": "Unused constant `LevelDebug`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/logging/logging.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 34, + "startColumn": 2, + "charOffset": 817, + "charLength": 10, + "snippet": { + "text": "LevelDebug" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 32, + "startColumn": 1, + "charOffset": 807, + "charLength": 147, + "snippet": { + "text": "\nconst (\n\tLevelDebug = slog.LevelDebug\n\t// LevelTrace is a custom log level for tracing every function call entry/exit\n\tLevelTrace = slog.Level(-8)" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "0d4b26669242818cf5d9177df92b5247b211b757d1401201a7ba6b73b4c6d7b1" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedConst", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused constant 'Plain'", + "markdown": "Unused constant `Plain`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/client/message/message.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 47, + "startColumn": 2, + "charOffset": 1574, + "charLength": 5, + "snippet": { + "text": "Plain" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 45, + "startColumn": 1, + "charOffset": 1475, + "charLength": 107, + "snippet": { + "text": "\tSuccess\n\t// Plain messages have no color or other formatting applied and are used for edge cases\n\tPlain\n)\n" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "19de9a5a87eb45e196fde5d2042f42d52832034c179705f859d1485544ea2935" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedConst", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused constant 'UNDEFINED'", + "markdown": "Unused constant `UNDEFINED`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/jobs/jobs.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 38, + "startColumn": 2, + "charOffset": 932, + "charLength": 9, + "snippet": { + "text": "UNDEFINED" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 36, + "startColumn": 1, + "charOffset": 922, + "charLength": 98, + "snippet": { + "text": "\nconst (\n\tUNDEFINED Status = iota\n\t// CREATED is used to denote that job has been created\n\tCREATED" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "634e8fa3acb6904919ce670ccd3b3d72fe3eac97fe91354fd07d2e80ef30c17b" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedConst", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused constant 'Info'", + "markdown": "Unused constant `Info`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/client/message/message.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 37, + "startColumn": 2, + "charOffset": 1059, + "charLength": 4, + "snippet": { + "text": "Info" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 35, + "startColumn": 1, + "charOffset": 936, + "charLength": 229, + "snippet": { + "text": "\tUndefined Level = iota\n\t// Info messages are used just to inform the user and do not indicate that an action is required\n\tInfo\n\t// Note messages are used similar to verbose messages and are used to keep the user up to date\n\tNote" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "68430aa8e643b65e070bf7e158dae222eb75cd94046fac298e15848ed342d4ae" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedConst", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused constant 'Note'", + "markdown": "Unused constant `Note`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/client/message/message.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 39, + "startColumn": 2, + "charOffset": 1161, + "charLength": 4, + "snippet": { + "text": "Note" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 37, + "startColumn": 1, + "charOffset": 1058, + "charLength": 224, + "snippet": { + "text": "\tInfo\n\t// Note messages are used similar to verbose messages and are used to keep the user up to date\n\tNote\n\t// Warn messages are used to notify the user that there was an error or that something didn't work as planned\n\tWarn" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "6aefc2a4ef039adca049c449e0cc0b5246308c1bdce5661b9e2424321e9faf00" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedConst", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused constant 'Version'", + "markdown": "Unused constant `Version`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/merlin.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 24, + "startColumn": 7, + "charOffset": 820, + "charLength": 7, + "snippet": { + "text": "Version" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 22, + "startColumn": 1, + "charOffset": 726, + "charLength": 184, + "snippet": { + "text": "\n// Version is a constant variable containing the version number for the Merlin package\nconst Version = \"2.1.0\"\n\n// Build is a hash off the git commit and is stamped it at compile time" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "6db9203efd74ecc459f8fff0359cb21dace4f044924b8319e96f46a2200ea38d" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedConst", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused constant 'Undefined'", + "markdown": "Unused constant `Undefined`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/client/message/message.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 35, + "startColumn": 2, + "charOffset": 937, + "charLength": 9, + "snippet": { + "text": "Undefined" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 33, + "startColumn": 1, + "charOffset": 927, + "charLength": 136, + "snippet": { + "text": "\nconst (\n\tUndefined Level = iota\n\t// Info messages are used just to inform the user and do not indicate that an action is required\n\tInfo" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "aadc8257ea19159722376bde5428bf34d10631aa31ca7f6669a2b8884134f8be" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedConst", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused constant 'Success'", + "markdown": "Unused constant `Success`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/client/message/message.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 45, + "startColumn": 2, + "charOffset": 1476, + "charLength": 7, + "snippet": { + "text": "Success" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 43, + "startColumn": 1, + "charOffset": 1377, + "charLength": 202, + "snippet": { + "text": "\tDebug\n\t// Success messages are you to notify the user that an action was completed without error\n\tSuccess\n\t// Plain messages have no color or other formatting applied and are used for edge cases\n\tPlain" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "b9b52296401756708a70b0aff2ef08ae1944d16d7be7f6d6c8273f64c57a381b" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedConst", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused constant 'Debug'", + "markdown": "Unused constant `Debug`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/client/message/message.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 43, + "startColumn": 2, + "charOffset": 1378, + "charLength": 5, + "snippet": { + "text": "Debug" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 41, + "startColumn": 1, + "charOffset": 1277, + "charLength": 206, + "snippet": { + "text": "\tWarn\n\t// Debug messages are displayed while debugging the program and display a lot of information\n\tDebug\n\t// Success messages are you to notify the user that an action was completed without error\n\tSuccess" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "ec5d34ecee9e0a9e4ff878f73e69fda2b17fca1f3d517eb58ec7ecc691258607" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'Parse'", + "markdown": "Unused function `Parse`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/modules/sharpgen/sharpgen.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 40, + "startColumn": 6, + "charOffset": 1299, + "charLength": 5, + "snippet": { + "text": "Parse" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 38, + "startColumn": 1, + "charOffset": 1077, + "charLength": 531, + "snippet": { + "text": "// Parse is the initial entry point for all extended modules. All validation checks and processing will be performed here\n// The function input types are limited to strings and therefore require additional processing\nfunc Parse(options map[string]string) ([]string, error) {\n\t// Verify the expected options are present\n\topts := []string{\"dotnetbin\", \"sharpgenbin\", \"help\", \"file\", \"dotnet\", \"output-kind\", \"platform\", \"no-optimization\", \"assembly-name\", \"source-file\", \"class-name\", \"confuse\", \"code\", \"verbose\", \"spawnto\", \"args\"}" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "03d6d462892c160c0af4daee485011b1b7a170962c9388f49228cf051f43756a" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'ServerAuthenticateComplete'", + "markdown": "Unused function `ServerAuthenticateComplete`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/opaque/opaque.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 162, + "startColumn": 6, + "charOffset": 6333, + "charLength": 26, + "snippet": { + "text": "ServerAuthenticateComplete" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 160, + "startColumn": 1, + "charOffset": 6203, + "charLength": 276, + "snippet": { + "text": "\n// ServerAuthenticateComplete consumes the Agent's authentication messages and finishes the authentication and key exchange\nfunc ServerAuthenticateComplete(o opaque.Opaque, server *Server) error {\n\tslog.Log(context.Background(), logging.LevelTrace, \"entering into function\")\n" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "07393f6ac08c79601ecaa0657fc16e20c2f799ff4c35c22b23ff8250959195a8" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'NewEncrypter'", + "markdown": "Unused function `NewEncrypter`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/transformer/encrypters/jwe/jwe.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 36, + "startColumn": 6, + "charOffset": 1034, + "charLength": 12, + "snippet": { + "text": "NewEncrypter" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 34, + "startColumn": 1, + "charOffset": 935, + "charLength": 149, + "snippet": { + "text": "\n// NewEncrypter is a factory to return a structure that implements the Transformer interface\nfunc NewEncrypter() *Encrypter {\n\treturn &Encrypter{}\n}" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "0b600c85d9f871ddab3aa95e65a807a310133b7c343804ccd48d8de5444d6e62" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'Parse'", + "markdown": "Unused function `Parse`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/modules/shellcode/shellcode.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 35, + "startColumn": 6, + "charOffset": 1057, + "charLength": 5, + "snippet": { + "text": "Parse" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 33, + "startColumn": 1, + "charOffset": 835, + "charLength": 384, + "snippet": { + "text": "// Parse is the initial entry point for all extended modules. All validation checks and processing will be performed here\n// The function input types are limited to strings and therefore require additional processing\nfunc Parse(options map[string]string) ([]string, error) {\n\tif len(options) != 3 {\n\t\treturn nil, fmt.Errorf(\"3 arguments were expected, %d were provided\", len(options))" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "0c693a38d5db029da2566feead326e4c118dfc4e4c16a52c3f226df908fb34b7" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'SetLevel'", + "markdown": "Unused function `SetLevel`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/logging/logging.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 97, + "startColumn": 6, + "charOffset": 2992, + "charLength": 8, + "snippet": { + "text": "SetLevel" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 95, + "startColumn": 1, + "charOffset": 2984, + "charLength": 59, + "snippet": { + "text": "}\n\nfunc SetLevel(newLevel slog.Level) {\n\tlevel = newLevel\n}" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "0ecdd58d2a37ff0f6c09204fbd81060a55c3d01dafd11b18487dab100c2ee77f" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'Parse'", + "markdown": "Unused function `Parse`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/modules/winapi/createprocess/createProcess.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 34, + "startColumn": 6, + "charOffset": 1073, + "charLength": 5, + "snippet": { + "text": "Parse" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 32, + "startColumn": 1, + "charOffset": 851, + "charLength": 306, + "snippet": { + "text": "// Parse is the initial entry point for all extended modules. All validation checks and processing will be performed here\n// The function input types are limited to strings and therefore require additional processing\nfunc Parse(options map[string]string) ([]string, error) {\n\t// 1. Shellcode\n\t// 2. SpawnTo" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "0f50c68135cee170bf83214f4f3ba4fffecdb66199ebe56fbd2180b1c2eb2ade" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'ServerAuthenticateInit'", + "markdown": "Unused function `ServerAuthenticateInit`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/opaque/opaque.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 122, + "startColumn": 6, + "charOffset": 4546, + "charLength": 22, + "snippet": { + "text": "ServerAuthenticateInit" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 120, + "startColumn": 1, + "charOffset": 4407, + "charLength": 298, + "snippet": { + "text": "\n// ServerAuthenticateInit is used to authenticate an agent leveraging the OPAQUE Password Authenticated Key Exchange (PAKE) protocol\nfunc ServerAuthenticateInit(o opaque.Opaque, server *Server) (opaque.Opaque, error) {\n\tslog.Log(context.Background(), logging.LevelTrace, \"entering into function\")\n" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "12a296fee3cf1594484c948740976e00dfe0956bf3edee74045e4fcaef17debe" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'NewEncoder'", + "markdown": "Unused function `NewEncoder`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/transformer/encoders/base64/base64.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 39, + "startColumn": 6, + "charOffset": 985, + "charLength": 10, + "snippet": { + "text": "NewEncoder" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 37, + "startColumn": 1, + "charOffset": 885, + "charLength": 170, + "snippet": { + "text": "\n// NewEncoder is a factory that returns a structure that implements the Transformer interface\nfunc NewEncoder(concrete int) *Coder {\n\treturn &Coder{concrete: concrete}\n}" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "143b393993028c30f0cc3dc875cd3c55efd48657ab13da32b15eb0359b98f991" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'NewEncrypter'", + "markdown": "Unused function `NewEncrypter`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/transformer/encrypters/rc4/rc4.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 33, + "startColumn": 6, + "charOffset": 992, + "charLength": 12, + "snippet": { + "text": "NewEncrypter" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 31, + "startColumn": 1, + "charOffset": 893, + "charLength": 149, + "snippet": { + "text": "\n// NewEncrypter is a factory to return a structure that implements the Transformer interface\nfunc NewEncrypter() *Encrypter {\n\treturn &Encrypter{}\n}" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "17ee3bb0591bc88c57f2fcc42b9392617f5a72b856fd0a0df77bc8df9d82a1c5" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'NewAuthenticator'", + "markdown": "Unused function `NewAuthenticator`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/authenticators/none/none.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 49, + "startColumn": 6, + "charOffset": 1450, + "charLength": 16, + "snippet": { + "text": "NewAuthenticator" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 47, + "startColumn": 1, + "charOffset": 1322, + "charLength": 232, + "snippet": { + "text": "\n// NewAuthenticator is a factory to create and return an OPAQUE authenticator that implements the Authenticator interface\nfunc NewAuthenticator() *Authenticator {\n\tvar auth Authenticator\n\tauth.agentService = agent.NewAgentService()" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "1bab5404252b24b1689f3d3d06bbfa3b873513c515644c379908c16e723942c6" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'NewSMBListener'", + "markdown": "Unused function `NewSMBListener`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/listeners/smb/smb.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 70, + "startColumn": 6, + "charOffset": 3182, + "charLength": 14, + "snippet": { + "text": "NewSMBListener" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 68, + "startColumn": 1, + "charOffset": 3060, + "charLength": 258, + "snippet": { + "text": "\n// NewSMBListener is a factory that creates and returns a Listener aggregate that implements the Listener interface\nfunc NewSMBListener(options map[string]string) (listener Listener, err error) {\n\t// Create and set the listener's ID\n\tid, ok := options[\"ID\"]" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "1bb3cb260f3008c1901e428b03ce55d0087e2eb89138a16812713f57e6648073" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'NewClientWithID'", + "markdown": "Unused function `NewClientWithID`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/client/client.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 34, + "startColumn": 6, + "charOffset": 976, + "charLength": 15, + "snippet": { + "text": "NewClientWithID" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 32, + "startColumn": 1, + "charOffset": 968, + "charLength": 71, + "snippet": { + "text": "}\n\nfunc NewClientWithID(id uuid.UUID) Client {\n\treturn Client{id: id}\n}" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "1efc83202b25d9a9cb7068dfa8e3d5c7cc21999fcfc8af9164b2a5e4601b180c" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'ServerRegisterComplete'", + "markdown": "Unused function `ServerRegisterComplete`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/opaque/opaque.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 93, + "startColumn": 6, + "charOffset": 3313, + "charLength": 22, + "snippet": { + "text": "ServerRegisterComplete" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 91, + "startColumn": 1, + "charOffset": 3219, + "charLength": 272, + "snippet": { + "text": "\n// ServerRegisterComplete consumes the User's response and finishes OPAQUE Registration\nfunc ServerRegisterComplete(AgentID uuid.UUID, o opaque.Opaque, server *Server) (opaque.Opaque, error) {\n\tslog.Log(context.Background(), logging.LevelTrace, \"entering into function\")\n" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "2c6fd8e9b3f0f415229d998d54e6d34d5f45c492423052d5a1d1f7c44e92ff66" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'NewClient'", + "markdown": "Unused function `NewClient`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/client/client.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 30, + "startColumn": 6, + "charOffset": 916, + "charLength": 9, + "snippet": { + "text": "NewClient" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 28, + "startColumn": 1, + "charOffset": 908, + "charLength": 61, + "snippet": { + "text": "}\n\nfunc NewClient() Client {\n\treturn Client{id: uuid.New()}\n}" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "306a7883744793c4a5f6ba0c04b6b065f3536b5addcfa8f1cc5dd5b6f35b707e" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'NewJobService'", + "markdown": "Unused function `NewJobService`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/services/job/job.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 62, + "startColumn": 6, + "charOffset": 1822, + "charLength": 13, + "snippet": { + "text": "NewJobService" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 60, + "startColumn": 1, + "charOffset": 1721, + "charLength": 182, + "snippet": { + "text": "\n// NewJobService is a factory to create a Job service to be used by other packages or services\nfunc NewJobService() *Service {\n\tif memoryService == nil {\n\t\tmemoryService = &Service{" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "30f46498b26ce31bee04fc60770998ee73adbfc72310bd57b3cfc20444909824" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'NewRepository'", + "markdown": "Unused function `NewRepository`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/listeners/http/memory/memory.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 46, + "startColumn": 6, + "charOffset": 1360, + "charLength": 13, + "snippet": { + "text": "NewRepository" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 44, + "startColumn": 1, + "charOffset": 1253, + "charLength": 183, + "snippet": { + "text": "\n// NewRepository is a factory to create and return a repository object to store and manage listeners\nfunc NewRepository() *Repository {\n\treturn &Repository{\n\t\tlisteners: listenerMap," + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "3242f93433c4fe33437e0a5c783c912a854b889d388f9a329d0d7052982a9f6c" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'NewRepository'", + "markdown": "Unused function `NewRepository`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/agents/memory/memory.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 52, + "startColumn": 6, + "charOffset": 1539, + "charLength": 13, + "snippet": { + "text": "NewRepository" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 50, + "startColumn": 1, + "charOffset": 1432, + "charLength": 151, + "snippet": { + "text": "\n// NewRepository creates and returns a Repository structure that contains an in-memory map of agents\nfunc NewRepository() *Repository {\n\treturn repo\n}" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "3250e660df0079871f41ae2e76fcc1eddb35bc3a096d2f89e3926dc1b9b8fa28" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'NewModule'", + "markdown": "Unused function `NewModule`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/modules/modules.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 79, + "startColumn": 6, + "charOffset": 4008, + "charLength": 9, + "snippet": { + "text": "NewModule" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 77, + "startColumn": 1, + "charOffset": 3892, + "charLength": 194, + "snippet": { + "text": "\n// NewModule is a factory to instantiate a module object using the provided file path to a module's json file\nfunc NewModule(modulePath string) (Module, error) {\n\tm := Module{\n\t\tid: uuid.New()," + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "35557cbb590625c07847dc9a27b9715e3dc28b2d05678c8bbb09d557c0753a82" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'DefaultOptions'", + "markdown": "Unused function `DefaultOptions`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/listeners/smb/smb.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 185, + "startColumn": 6, + "charOffset": 6264, + "charLength": 14, + "snippet": { + "text": "DefaultOptions" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 183, + "startColumn": 1, + "charOffset": 6129, + "charLength": 227, + "snippet": { + "text": "\n// DefaultOptions returns a map of configurable listener options that will subsequently be passed to the NewSMBListener function\nfunc DefaultOptions() map[string]string {\n\toptions := make(map[string]string)\n\toptions[\"ID\"] = \"\"" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "3691a018fd3e45ba10f4067caaf8fb6ae83136c3d81d4d053d3044b44f705d4d" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'NewMessage'", + "markdown": "Unused function `NewMessage`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/client/message/message.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 60, + "startColumn": 6, + "charOffset": 1843, + "charLength": 10, + "snippet": { + "text": "NewMessage" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 58, + "startColumn": 1, + "charOffset": 1766, + "charLength": 170, + "snippet": { + "text": "\n// NewMessage is a factory that builds and returns a Message structure\nfunc NewMessage(level Level, message string) *Message {\n\treturn &Message{\n\t\tid: uuid.New()," + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "3b6861b1c20479898d14540a8903be59870b87265847d9a6a87d9b501b641ed7" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'Parse'", + "markdown": "Unused function `Parse`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/modules/srdi/srdi.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 41, + "startColumn": 6, + "charOffset": 1312, + "charLength": 5, + "snippet": { + "text": "Parse" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 39, + "startColumn": 1, + "charOffset": 1090, + "charLength": 358, + "snippet": { + "text": "// Parse is the initial entry point for all extended modules. All validation checks and processing will be performed here\n// The function input types are limited to strings and therefore require additional processing\nfunc Parse(options map[string]string) ([]string, error) {\n\t// 1. Check to make sure all of the arguments are there\n\t// 2. Check each argument" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "431d5122eb5b725008d15619a150e99cc76fd400e57f8fb9e5e3d7871a77668e" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'NewAuthenticator'", + "markdown": "Unused function `NewAuthenticator`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/authenticators/opaque/opaque.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 66, + "startColumn": 6, + "charOffset": 2039, + "charLength": 16, + "snippet": { + "text": "NewAuthenticator" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 64, + "startColumn": 1, + "charOffset": 1911, + "charLength": 211, + "snippet": { + "text": "\n// NewAuthenticator is a factory to create and return an OPAQUE authenticator that implements the Authenticator interface\nfunc NewAuthenticator() (*Authenticator, error) {\n\tvar err error\n\tvar auth Authenticator" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "44cd09f36defc8d859109ffa5719c053553b398ddb2b51123320a8847f2772ff" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'NewUDPListener'", + "markdown": "Unused function `NewUDPListener`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/listeners/udp/udp.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 74, + "startColumn": 6, + "charOffset": 3332, + "charLength": 14, + "snippet": { + "text": "NewUDPListener" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 72, + "startColumn": 1, + "charOffset": 3210, + "charLength": 258, + "snippet": { + "text": "\n// NewUDPListener is a factory that creates and returns a Listener aggregate that implements the Listener interface\nfunc NewUDPListener(options map[string]string) (listener Listener, err error) {\n\t// Create and set the listener's ID\n\tid, ok := options[\"ID\"]" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "493a6961b86cd278a37aa3a932aeb2a151b5934f11fdde39e9546f7bbcface55" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'NewRepository'", + "markdown": "Unused function `NewRepository`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/listeners/smb/memory/memory.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 46, + "startColumn": 6, + "charOffset": 1357, + "charLength": 13, + "snippet": { + "text": "NewRepository" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 44, + "startColumn": 1, + "charOffset": 1250, + "charLength": 183, + "snippet": { + "text": "\n// NewRepository is a factory to create and return a repository object to store and manage listeners\nfunc NewRepository() *Repository {\n\treturn &Repository{\n\t\tlisteners: listenerMap," + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "4bb82fe6722236c65710a724e43da03e7f55a84f7f3accf89f99bc9040c400aa" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'GetLevel'", + "markdown": "Unused function `GetLevel`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/logging/logging.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 101, + "startColumn": 6, + "charOffset": 3050, + "charLength": 8, + "snippet": { + "text": "GetLevel" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 99, + "startColumn": 1, + "charOffset": 3042, + "charLength": 47, + "snippet": { + "text": "}\n\nfunc GetLevel() slog.Level {\n\treturn level\n}" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "5008bfcf5781e1b7406e1f3dcb64004fdcd2cadbd423fac8758a61e9c7bffb27" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'EnableExtraDebug'", + "markdown": "Unused function `EnableExtraDebug`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/logging/logging.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 110, + "startColumn": 6, + "charOffset": 3161, + "charLength": 16, + "snippet": { + "text": "EnableExtraDebug" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 108, + "startColumn": 1, + "charOffset": 3153, + "charLength": 69, + "snippet": { + "text": "}\n\nfunc EnableExtraDebug() {\n\tlevel = LevelExtraDebug\n\tupdateLogger()" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "5178bf0a00c52848aa2b39b60526486db2abfe526b2d0c4f2d22340583aad71d" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'NewTCPListener'", + "markdown": "Unused function `NewTCPListener`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/listeners/tcp/tcp.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 75, + "startColumn": 6, + "charOffset": 3386, + "charLength": 14, + "snippet": { + "text": "NewTCPListener" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 73, + "startColumn": 1, + "charOffset": 3264, + "charLength": 258, + "snippet": { + "text": "\n// NewTCPListener is a factory that creates and returns a Listener aggregate that implements the Listener interface\nfunc NewTCPListener(options map[string]string) (listener Listener, err error) {\n\t// Create and set the listener's ID\n\tid, ok := options[\"ID\"]" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "52a0f5742b3ba04d898b1695bae9f08f8aac8c9a1537a7c01291efd330b9780c" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'NewRepository'", + "markdown": "Unused function `NewRepository`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/client/message/memory/memory.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 47, + "startColumn": 6, + "charOffset": 1285, + "charLength": 13, + "snippet": { + "text": "NewRepository" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 45, + "startColumn": 1, + "charOffset": 1199, + "charLength": 155, + "snippet": { + "text": "\n// NewRepository is a factory that returns an instantiated in-memory repository\nfunc NewRepository() *Repository {\n\tif repo == nil {\n\t\trepo = &Repository{" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "53379ff4ab586bcac6cff371fe44f25b437d6acc35cf0add5b22256725532690" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'NewRPCService'", + "markdown": "Unused function `NewRPCService`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/services/rpc/rpc.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 98, + "startColumn": 6, + "charOffset": 3441, + "charLength": 13, + "snippet": { + "text": "NewRPCService" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 96, + "startColumn": 1, + "charOffset": 3323, + "charLength": 248, + "snippet": { + "text": "\n// NewRPCService is a factory to instantiate the server-side RPC Service, and it's an embedded Server structure\nfunc NewRPCService(password string, secure bool, tlsCert, tlsKey, tlsCA string) (*Service, error) {\n\t// Setup the logger\n\tlogging.Run()" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "5a86424d9a2c4d464d68482d4ae3937f10192fc125df2802b9227bfd76ed48af" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'Protocol'", + "markdown": "Unused function `Protocol`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/servers/servers.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 66, + "startColumn": 6, + "charOffset": 1872, + "charLength": 8, + "snippet": { + "text": "Protocol" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 64, + "startColumn": 1, + "charOffset": 1756, + "charLength": 178, + "snippet": { + "text": "\n// Protocol is used to transform a server protocol constant into a string for use in written messages or logs\nfunc Protocol(protocol int) string {\n\tswitch protocol {\n\tcase HTTP:" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "5a87bcf13943649ae9f1a7e5c5cec105b324d87b76dda0c3fbbe6c86fa71d73f" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'In'", + "markdown": "Unused function `In`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/modules/socks/socks.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 286, + "startColumn": 6, + "charOffset": 8929, + "charLength": 2, + "snippet": { + "text": "In" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 284, + "startColumn": 1, + "charOffset": 8802, + "charLength": 251, + "snippet": { + "text": "\n// In is the entrypoint for accepting SOCKS messages that came in from the agent and need to be sent to the SOCKS client\nfunc In(job merlinJob.Job) {\n\tif core.Debug {\n\t\tslog.Debug(fmt.Sprintf(\"Entered into SOCKS module In() function with: %+v\", job))" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "5d12c3e95590be00cbaee9938003af0bf9c86f5dafefa4473d84c96d3466c49c" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'Parse'", + "markdown": "Unused function `Parse`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/modules/socks/socks.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 70, + "startColumn": 6, + "charOffset": 2234, + "charLength": 5, + "snippet": { + "text": "Parse" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 68, + "startColumn": 1, + "charOffset": 2134, + "charLength": 255, + "snippet": { + "text": "\n// Parse is the main entry point for the SOCKS module used to receive commands from operators\nfunc Parse(options map[string]string) ([]string, error) {\n\t// Verify the expected options are present\n\topts := []string{\"agent\", \"command\", \"port\", \"interface\"}" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "5e7d775931f925dfd4a746a3c781e8791d1839e5afb163afd8958bf018679a66" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'Parse'", + "markdown": "Unused function `Parse`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/modules/minidump/minidump.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 30, + "startColumn": 6, + "charOffset": 981, + "charLength": 5, + "snippet": { + "text": "Parse" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 28, + "startColumn": 1, + "charOffset": 759, + "charLength": 353, + "snippet": { + "text": "// Parse is the initial entry point for all extended modules. All validation checks and processing will be performed here\n// The function input types are limited to strings and therefore require additional processing\nfunc Parse(options map[string]string) ([]string, error) {\n\t// Convert PID to integer\n\tif options[\"pid\"] != \"\" && options[\"pid\"] != \"0\" {" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "6ffcc98742686abdbb715e0bd63ff15b4d9eb407e8616da66615d89462d3d112" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'NewInfo'", + "markdown": "Unused function `NewInfo`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/jobs/jobs.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 68, + "startColumn": 6, + "charOffset": 2262, + "charLength": 7, + "snippet": { + "text": "NewInfo" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 66, + "startColumn": 1, + "charOffset": 2175, + "charLength": 209, + "snippet": { + "text": "\n// NewInfo is a factory to return an Info structure used to track a job's status\nfunc NewInfo(agent uuid.UUID, jobType string, cmd string) Info {\n\tinfo := Info{\n\t\tid: core.RandStringBytesMaskImprSrc(10)," + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "81496712dcf24eb3ee7775e1df5ff65bb4a018bfaf8a46e6d4b284c718bc0d8a" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'ServerRegisterInit'", + "markdown": "Unused function `ServerRegisterInit`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/opaque/opaque.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 53, + "startColumn": 6, + "charOffset": 1597, + "charLength": 18, + "snippet": { + "text": "ServerRegisterInit" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 51, + "startColumn": 1, + "charOffset": 1453, + "charLength": 329, + "snippet": { + "text": "\n// ServerRegisterInit is used to perform the OPAQUE Password Authenticated Key Exchange (PAKE) protocol Registration steps for the server\nfunc ServerRegisterInit(AgentID uuid.UUID, o opaque.Opaque, key kyber.Scalar) (opaque.Opaque, *Server, error) {\n\tslog.Log(context.Background(), logging.LevelTrace, \"entering into function\")\n" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "870d0153154cbe885989380172b94fa57ef2be4b7dca371305ae430f51146165" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'NewAgent'", + "markdown": "Unused function `NewAgent`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/agents/agents.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 58, + "startColumn": 6, + "charOffset": 2463, + "charLength": 8, + "snippet": { + "text": "NewAgent" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 56, + "startColumn": 1, + "charOffset": 2363, + "charLength": 244, + "snippet": { + "text": "\n// NewAgent is a factory to create and return an Agent structure based on the provided inputs\nfunc NewAgent(id uuid.UUID, secret []byte, opaque *opaque.Server, initial time.Time) (agent Agent, err error) {\n\tagent.id = id\n\tagent.secret = secret" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "891fc4853d2f838126d8e95edcbf6a307853be34f2dd066cbf92e146bf8cd9ed" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'ParseShellcode'", + "markdown": "Unused function `ParseShellcode`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/modules/shellcode/shellcode.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 107, + "startColumn": 6, + "charOffset": 3518, + "charLength": 14, + "snippet": { + "text": "ParseShellcode" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 105, + "startColumn": 1, + "charOffset": 3343, + "charLength": 303, + "snippet": { + "text": "// ParseShellcode determines if the inputs is a file and/or what format the shellcode is in (hex, binary, CSharp)\n// Input string can be a file path or shellcode itself\nfunc ParseShellcode(shellcode string) ([]byte, error) {\n\t// Check if shellcode argument is a file path\n\tf, errF := os.Stat(shellcode)" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "8a8bea494d90e1b5be460fcf1a5a475ad525c4a9f46dcb922f39076a448cd280" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'NewEncrypter'", + "markdown": "Unused function `NewEncrypter`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/transformer/encrypters/xor/xor.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 32, + "startColumn": 6, + "charOffset": 916, + "charLength": 12, + "snippet": { + "text": "NewEncrypter" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 30, + "startColumn": 1, + "charOffset": 817, + "charLength": 149, + "snippet": { + "text": "\n// NewEncrypter is a factory to return a structure that implements the Transformer interface\nfunc NewEncrypter() *Encrypter {\n\treturn &Encrypter{}\n}" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "9346fc983a63759e7c98a165b58646e7aefd681145b6271645b43e0eac2e6c64" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'FromString'", + "markdown": "Unused function `FromString`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/servers/servers.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 84, + "startColumn": 6, + "charOffset": 2188, + "charLength": 10, + "snippet": { + "text": "FromString" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 82, + "startColumn": 1, + "charOffset": 2110, + "charLength": 161, + "snippet": { + "text": "\n// FromString converts a protocol constant to its string representation\nfunc FromString(protocol string) int {\n\tswitch strings.ToLower(protocol) {\n\tcase \"http\":" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "9604f5f4d267e3234258a29490ebe8661dd911559ee5207b023265f006100d66" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'NewService'", + "markdown": "Unused function `NewService`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/services/client/client.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 32, + "startColumn": 6, + "charOffset": 939, + "charLength": 10, + "snippet": { + "text": "NewService" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 30, + "startColumn": 1, + "charOffset": 912, + "charLength": 94, + "snippet": { + "text": "var service *Service\n\nfunc NewService() *Service {\n\tif service == nil {\n\t\tservice = &Service{}" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "96fd31c4e10033d22defb55a06fd71bdc17f93a48b2e3cd770c94658e648b31a" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'NewEncrypter'", + "markdown": "Unused function `NewEncrypter`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/transformer/encrypters/aes/aes.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 40, + "startColumn": 6, + "charOffset": 1022, + "charLength": 12, + "snippet": { + "text": "NewEncrypter" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 38, + "startColumn": 1, + "charOffset": 923, + "charLength": 149, + "snippet": { + "text": "\n// NewEncrypter is a factory to return a structure that implements the Transformer interface\nfunc NewEncrypter() *Encrypter {\n\treturn &Encrypter{}\n}" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "97bffcd583d58f88bfd44262499eb88cafb034eca20d1c04b682f7af5f992d23" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'FromString'", + "markdown": "Unused function `FromString`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/listeners/listeners.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 69, + "startColumn": 6, + "charOffset": 2180, + "charLength": 10, + "snippet": { + "text": "FromString" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 67, + "startColumn": 1, + "charOffset": 2082, + "charLength": 207, + "snippet": { + "text": "\n// FromString converts a string representation of the Listener type, or kind, to a constant\nfunc FromString(kind string) int {\n\tswitch strings.ToLower(kind) {\n\tcase \"http\", \"https\", \"h2c\", \"http2\", \"http3\":" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "9b34d606068eb5fe983b7a7dd0bd2ba574e5ba39f20f345b5f96d67d69fb08fa" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'NewHTTPListener'", + "markdown": "Unused function `NewHTTPListener`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/listeners/http/http.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 72, + "startColumn": 6, + "charOffset": 3257, + "charLength": 15, + "snippet": { + "text": "NewHTTPListener" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 70, + "startColumn": 1, + "charOffset": 3038, + "charLength": 399, + "snippet": { + "text": "// NewHTTPListener is a factory that creates and returns a Listener aggregate that implements the Listener interface\n// The HTTP listener requires an instantiated server object to send/receive messages with Agents\nfunc NewHTTPListener(server servers.ServerInterface, options map[string]string) (listener Listener, err error) {\n\t// Ensure a listener name was provided\n\tlistener.name = options[\"Name\"]" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "9d76da1795a65683c752d9fbd51d963eca1971f6e5fdf76a1319522a646033fb" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'GetDefaultOptions'", + "markdown": "Unused function `GetDefaultOptions`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/servers/http/http.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 431, + "startColumn": 6, + "charOffset": 12685, + "charLength": 17, + "snippet": { + "text": "GetDefaultOptions" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 429, + "startColumn": 1, + "charOffset": 12573, + "charLength": 235, + "snippet": { + "text": "\n// GetDefaultOptions returns a map of configurable server options typically used when creating a listener\nfunc GetDefaultOptions(protocol int) map[string]string {\n\toptions := make(map[string]string)\n\toptions[\"Interface\"] = \"127.0.0.1\"" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "a1f8c873b86f6902ae329a08386ad9c5b9798ef22813b6c23bdc372817fb572f" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'NewRepository'", + "markdown": "Unused function `NewRepository`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/group/memory/memory.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 44, + "startColumn": 6, + "charOffset": 1264, + "charLength": 13, + "snippet": { + "text": "NewRepository" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 42, + "startColumn": 1, + "charOffset": 1146, + "charLength": 188, + "snippet": { + "text": "\n// NewRepository is a factory that returns a structure that implements the group package's Repository interface\nfunc NewRepository() *Repository {\n\tgroups := make(map[string][]uuid.UUID)\n" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "a47801ab2574d71c08aef48ce757916b48ed816cce86291d4019e28cf077414f" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'NewRepository'", + "markdown": "Unused function `NewRepository`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/jobs/memory/memory.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 50, + "startColumn": 6, + "charOffset": 1565, + "charLength": 13, + "snippet": { + "text": "NewRepository" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 48, + "startColumn": 1, + "charOffset": 1463, + "charLength": 171, + "snippet": { + "text": "\n// NewRepository creates and returns a new in-memory repository for interacting with Agent Jobs\nfunc NewRepository() *Repository {\n\tif repo == nil {\n\t\trepo = &Repository{" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "a53ab0d10985062166c395d8b8b5057d7d932b70ce95ae4e13a15ce4be6bbe56" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'NewEncoder'", + "markdown": "Unused function `NewEncoder`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/transformer/encoders/gob/gob.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 50, + "startColumn": 6, + "charOffset": 1154, + "charLength": 10, + "snippet": { + "text": "NewEncoder" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 48, + "startColumn": 1, + "charOffset": 1054, + "charLength": 170, + "snippet": { + "text": "\n// NewEncoder is a factory that returns a structure that implements the Transformer interface\nfunc NewEncoder(concrete int) *Coder {\n\treturn &Coder{concrete: concrete}\n}" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "a7b4d6557f95405c603dfca64764edc6817a73d656aa2dc9e9e162a566f3d223" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'Run'", + "markdown": "Unused function `Run`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/logging/logging.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 46, + "startColumn": 6, + "charOffset": 1289, + "charLength": 3, + "snippet": { + "text": "Run" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 44, + "startColumn": 1, + "charOffset": 1150, + "charLength": 190, + "snippet": { + "text": "// Run sets up the logging for the program\n// The default log file path is in Merlin's root directory at data/log/merlinServerLog.txt\nfunc Run() {\n\t// Open the log file\n\tvar logFile *os.File" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "af18a7f8cf5b8f147450a0e1e4e5a7507493d5cf593f1dd576eb2d337ecc7e90" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'NewListenerService'", + "markdown": "Unused function `NewListenerService`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/services/listeners/listeners.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 59, + "startColumn": 6, + "charOffset": 2013, + "charLength": 18, + "snippet": { + "text": "NewListenerService" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 57, + "startColumn": 1, + "charOffset": 1933, + "charLength": 227, + "snippet": { + "text": "\n// NewListenerService is a factory to create and return a ListenerService\nfunc NewListenerService() (ls ListenerService) {\n\tls.httpRepo = WithHTTPMemoryListenerRepository()\n\tls.httpServerRepo = WithHTTPMemoryServerRepository()" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "b7feb571531de092e73e6cca8a61550cad18b0cd4de200058c94b4301bebb07f" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'NewRepository'", + "markdown": "Unused function `NewRepository`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/delegate/memory/memory.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 41, + "startColumn": 6, + "charOffset": 1012, + "charLength": 13, + "snippet": { + "text": "NewRepository" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 39, + "startColumn": 1, + "charOffset": 943, + "charLength": 179, + "snippet": { + "text": "\n// NewRepository is a factory to return a repository structure\nfunc NewRepository() *Repository {\n\tif repo == nil {\n\t\trepo = &Repository{messages: make(map[uuid.UUID][]delegate)}" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "b8b664ce5cfceeb22b622ee5d63c68dcc17060e1deb9ca70f8305b01da0c1624" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'GetDonutDefaultConfig'", + "markdown": "Unused function `GetDonutDefaultConfig`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/modules/donut/donut.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 254, + "startColumn": 6, + "charOffset": 8362, + "charLength": 21, + "snippet": { + "text": "GetDonutDefaultConfig" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 252, + "startColumn": 1, + "charOffset": 8291, + "charLength": 147, + "snippet": { + "text": "\n// GetDonutDefaultConfig returns a default DonutConfig structure\nfunc GetDonutDefaultConfig() *donut.DonutConfig {\n\treturn donut.DefaultConfig()\n}" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "ba6e092b13d064187607adb16cd1390499102621aea7ee954709b7fc15a33eac" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'String'", + "markdown": "Unused function `String`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/listeners/listeners.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 84, + "startColumn": 6, + "charOffset": 2420, + "charLength": 6, + "snippet": { + "text": "String" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 82, + "startColumn": 1, + "charOffset": 2412, + "charLength": 60, + "snippet": { + "text": "}\n\nfunc String(kind int) string {\n\tswitch kind {\n\tcase HTTP:" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "bc88d4318e02c747d82059ab153e9f54b187b373154756d0e10383fac9541a87" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'DefaultOptions'", + "markdown": "Unused function `DefaultOptions`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/listeners/tcp/tcp.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 190, + "startColumn": 6, + "charOffset": 6448, + "charLength": 14, + "snippet": { + "text": "DefaultOptions" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 188, + "startColumn": 1, + "charOffset": 6313, + "charLength": 227, + "snippet": { + "text": "\n// DefaultOptions returns a map of configurable listener options that will subsequently be passed to the NewTCPListener function\nfunc DefaultOptions() map[string]string {\n\toptions := make(map[string]string)\n\toptions[\"ID\"] = \"\"" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "bd7e6c73d43411c3f6a5d5e7d6e2e124a515b1df588bee455fd14b09d5f955c0" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'New'", + "markdown": "Unused function `New`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/servers/http/http.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 112, + "startColumn": 6, + "charOffset": 3850, + "charLength": 3, + "snippet": { + "text": "New" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 110, + "startColumn": 1, + "charOffset": 3779, + "charLength": 148, + "snippet": { + "text": "\n// New creates a new HTTP server based on the passed in Template\nfunc New(options map[string]string) (Server, error) {\n\tvar err error\n\tvar s Server" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "be57ae3e2d2be13ea9ea6c0782018ded60ac4c84b1a628d916742c346cd5241d" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'Listeners'", + "markdown": "Unused function `Listeners`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/listeners/listeners.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 99, + "startColumn": 6, + "charOffset": 2644, + "charLength": 9, + "snippet": { + "text": "Listeners" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 97, + "startColumn": 1, + "charOffset": 2636, + "charLength": 64, + "snippet": { + "text": "}\n\nfunc Listeners() []int {\n\treturn []int{HTTP, SMB, TCP, UDP}\n}" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "c0de66a18bf6c4f61d620d57f570adcc2b6e5923f6a2c29118b476542ebfdbc4" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'NewRepository'", + "markdown": "Unused function `NewRepository`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/listeners/tcp/memory/memory.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 45, + "startColumn": 6, + "charOffset": 1354, + "charLength": 13, + "snippet": { + "text": "NewRepository" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 43, + "startColumn": 1, + "charOffset": 1247, + "charLength": 183, + "snippet": { + "text": "\n// NewRepository is a factory to create and return a repository object to store and manage listeners\nfunc NewRepository() *Repository {\n\treturn &Repository{\n\t\tlisteners: listenerMap," + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "c1c053ba469cf099463294456a065a58cffc5b33a9c04b059d099d491d20c84b" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'NewErrorMessage'", + "markdown": "Unused function `NewErrorMessage`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/client/message/message.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 70, + "startColumn": 6, + "charOffset": 2041, + "charLength": 15, + "snippet": { + "text": "NewErrorMessage" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 68, + "startColumn": 1, + "charOffset": 2033, + "charLength": 88, + "snippet": { + "text": "}\n\nfunc NewErrorMessage(err error) *Message {\n\treturn &Message{\n\t\tid: uuid.New()," + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "cca7c874077eefe0f513fd9d5bb3a33623c160067a967824c5b4473925b08ad1" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'NewAgentService'", + "markdown": "Unused function `NewAgentService`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/services/agent/agent.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 53, + "startColumn": 6, + "charOffset": 1552, + "charLength": 15, + "snippet": { + "text": "NewAgentService" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 51, + "startColumn": 1, + "charOffset": 1446, + "charLength": 189, + "snippet": { + "text": "\n// NewAgentService is a factory to create an Agent service to be used by other packages or services\nfunc NewAgentService() *Service {\n\tif memoryService == nil {\n\t\tmemoryService = &Service{" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "ce66d3c14d21bfd5448d593679c5f1c8ace2d55d5c22a71a33fc6f999003d1c7" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'GetModuleList'", + "markdown": "Unused function `GetModuleList`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/modules/modules.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 192, + "startColumn": 6, + "charOffset": 7034, + "charLength": 13, + "snippet": { + "text": "GetModuleList" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 190, + "startColumn": 1, + "charOffset": 6903, + "charLength": 198, + "snippet": { + "text": "\n// GetModuleList generates and returns a list of all modules in Merlin's \"module\" directory folder. Used with tab completion\nfunc GetModuleList() []string {\n\tdir, err := os.Getwd()\n\tif err != nil {" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "d22fe0087132f3607f08fb11f9ded206c3eb70fd5d3e6f3ce401edec3f33c984" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'NewRepository'", + "markdown": "Unused function `NewRepository`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/client/memory/memory.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 37, + "startColumn": 6, + "charOffset": 927, + "charLength": 13, + "snippet": { + "text": "NewRepository" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 35, + "startColumn": 1, + "charOffset": 900, + "charLength": 96, + "snippet": { + "text": "var repo *Repository\n\nfunc NewRepository() *Repository {\n\tif repo == nil {\n\t\trepo = &Repository{" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "d2fea99c5797043bf6e8b6ca7a379a1ea6683e84407a54e3b7c2b57876df5002" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'GetListeners'", + "markdown": "Unused function `GetListeners`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/modules/socks/socks.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 310, + "startColumn": 6, + "charOffset": 9539, + "charLength": 12, + "snippet": { + "text": "GetListeners" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 308, + "startColumn": 1, + "charOffset": 9440, + "charLength": 191, + "snippet": { + "text": "\n// GetListeners returns a list of tracked listeners and the interface/port they are bound to\nfunc GetListeners() [][]string {\n\tvar l [][]string\n\tlisteners.Range(func(k, v interface{}) bool {" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "d9c549069c7ad2c58178a0ea411f35e510ec4d580a912e2abf502470c01956ca" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'BytesFromString'", + "markdown": "Unused function `BytesFromString`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/modules/donut/donut.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 270, + "startColumn": 6, + "charOffset": 9071, + "charLength": 15, + "snippet": { + "text": "BytesFromString" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 268, + "startColumn": 1, + "charOffset": 8925, + "charLength": 313, + "snippet": { + "text": "\n// BytesFromString takes a base64 encoded .NET assembly and a donut configuration as inputs and returns the donut payload as a bytes buffer\nfunc BytesFromString(assembly string, config *donut.DonutConfig) (*bytes.Buffer, error) {\n\t// Base64 decode assembly\n\tdata, err := base64.StdEncoding.DecodeString(assembly)" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "dc3c0c25b832aa01fd90bf69272d385dc627d8da0b609ba5ed842afe12cc38e4" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'DefaultOptions'", + "markdown": "Unused function `DefaultOptions`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/listeners/http/http.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 156, + "startColumn": 6, + "charOffset": 5612, + "charLength": 14, + "snippet": { + "text": "DefaultOptions" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 154, + "startColumn": 1, + "charOffset": 5476, + "charLength": 246, + "snippet": { + "text": "\n// DefaultOptions returns a map of configurable listener options that will subsequently be passed to the NewHTTPListener function\nfunc DefaultOptions() map[string]string {\n\toptions := make(map[string]string)\n\toptions[\"Name\"] = \"My HTTP Listener\"" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "dc8104394fd038c5c71a38220f8f10836334c5f474e9974f0d4706d9134b06ab" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'RandStringBytesMaskImprSrc'", + "markdown": "Unused function `RandStringBytesMaskImprSrc`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/core/core.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 45, + "startColumn": 6, + "charOffset": 1401, + "charLength": 26, + "snippet": { + "text": "RandStringBytesMaskImprSrc" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 43, + "startColumn": 1, + "charOffset": 1306, + "charLength": 267, + "snippet": { + "text": "\n// RandStringBytesMaskImprSrc generates and returns a random string of n characters long\nfunc RandStringBytesMaskImprSrc(n int) string {\n\t// http://stackoverflow.com/questions/22892120/how-to-generate-a-random-string-of-a-fixed-length-in-golang\n\tb := make([]byte, n)" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "dd82fd6a134d9f67c85ab9aeb53ddb3a225468952076cf9a8f26530cda050f4c" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'DefaultOptions'", + "markdown": "Unused function `DefaultOptions`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/listeners/udp/udp.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 189, + "startColumn": 6, + "charOffset": 6394, + "charLength": 14, + "snippet": { + "text": "DefaultOptions" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 187, + "startColumn": 1, + "charOffset": 6259, + "charLength": 227, + "snippet": { + "text": "\n// DefaultOptions returns a map of configurable listener options that will subsequently be passed to the NewUDPListener function\nfunc DefaultOptions() map[string]string {\n\toptions := make(map[string]string)\n\toptions[\"ID\"] = \"\"" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "e018c89a4e2db1eb6920ebcc5cb14d191665273dccb904a958b1b0af8e12da6c" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'EnableTrace'", + "markdown": "Unused function `EnableTrace`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/logging/logging.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 115, + "startColumn": 6, + "charOffset": 3231, + "charLength": 11, + "snippet": { + "text": "EnableTrace" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 113, + "startColumn": 1, + "charOffset": 3223, + "charLength": 59, + "snippet": { + "text": "}\n\nfunc EnableTrace() {\n\tlevel = LevelTrace\n\tupdateLogger()" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "e7b65802cc6e438740bbb300ce14a762c1ec8766c0187058b1ad47b291c10eb3" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'NewRepository'", + "markdown": "Unused function `NewRepository`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/servers/http/memory/memory.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 46, + "startColumn": 6, + "charOffset": 1367, + "charLength": 13, + "snippet": { + "text": "NewRepository" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 44, + "startColumn": 1, + "charOffset": 1260, + "charLength": 179, + "snippet": { + "text": "\n// NewRepository is a factory to create and return a repository object to store and manage listeners\nfunc NewRepository() *Repository {\n\treturn &Repository{\n\t\tservers: serverMap," + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "ec18d398ec9c750b407d1d8030758c8ffd484e3e1550be81e9c51b8520c1dca1" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'NewRepository'", + "markdown": "Unused function `NewRepository`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/listeners/udp/memory/memory.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 46, + "startColumn": 6, + "charOffset": 1355, + "charLength": 13, + "snippet": { + "text": "NewRepository" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 44, + "startColumn": 1, + "charOffset": 1248, + "charLength": 183, + "snippet": { + "text": "\n// NewRepository is a factory to create and return a repository object to store and manage listeners\nfunc NewRepository() *Repository {\n\treturn &Repository{\n\t\tlisteners: listenerMap," + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "ecd30e2d8d5e13e64f45f0c243f37c73077a03177276cb779cd54bb01040acfe" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'EnableDebug'", + "markdown": "Unused function `EnableDebug`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/logging/logging.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 105, + "startColumn": 6, + "charOffset": 3096, + "charLength": 11, + "snippet": { + "text": "EnableDebug" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 103, + "startColumn": 1, + "charOffset": 3088, + "charLength": 64, + "snippet": { + "text": "}\n\nfunc EnableDebug() {\n\tlevel = slog.LevelDebug\n\tupdateLogger()" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "f2fcfad72dd0ddcf5f8a8f6dff0fd20e78d4cb07c33d5d283ded9de5f7334656" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'Parse'", + "markdown": "Unused function `Parse`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/modules/donut/donut.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 40, + "startColumn": 6, + "charOffset": 1097, + "charLength": 5, + "snippet": { + "text": "Parse" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 38, + "startColumn": 1, + "charOffset": 875, + "charLength": 518, + "snippet": { + "text": "// Parse is the initial entry point for all extended modules. All validation checks and processing will be performed here\n// The function input types are limited to strings and therefore require additional processing\nfunc Parse(options map[string]string) ([]string, error) {\n\targuments := []string{\"arch\", \"bypass\", \"class\", \"domain\", \"entropy\", \"format\", \"method\", \"name\", \"output\", \"parameters\", \"runtime\", \"server\", \"entrypoint\", \"unicode\", \"exit\", \"thread\", \"compress\", \"sourcefile\", \"spawnto\", \"args\", \"verbose\"}\n" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "fb52c179d27ff54544c94ea3348ab775a1b67518a1f46a6167fb65490e0a25c4" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedExportedFunction", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused function 'NewEncoder'", + "markdown": "Unused function `NewEncoder`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/transformer/encoders/hex/hex.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 39, + "startColumn": 6, + "charOffset": 976, + "charLength": 10, + "snippet": { + "text": "NewEncoder" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 37, + "startColumn": 1, + "charOffset": 876, + "charLength": 170, + "snippet": { + "text": "\n// NewEncoder is a factory that returns a structure that implements the Transformer interface\nfunc NewEncoder(concrete int) *Coder {\n\treturn &Coder{concrete: concrete}\n}" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "fcf1817541e1f1c7f448c03a9bbbb25808673e18bc1d2dfd0aff15e093d01c53" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedGlobalVariable", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused variable 'RegisteredServers'", + "markdown": "Unused variable `RegisteredServers`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/servers/servers.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 47, + "startColumn": 5, + "charOffset": 1334, + "charLength": 17, + "snippet": { + "text": "RegisteredServers" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 45, + "startColumn": 1, + "charOffset": 1263, + "charLength": 225, + "snippet": { + "text": "\n// RegisteredServers contains an array of registered server types\nvar RegisteredServers = make(map[int]string)\n\n// ServerInterface is used to provide a standard set of methods a server module must support to work with Merlin" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "1ad5ce23c02ccc384f8614316d768ce3e1575e2d545739a9ea7f50e95cac1581" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedGlobalVariable", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused variable 'Debug'", + "markdown": "Unused variable `Debug`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/core/core.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 29, + "startColumn": 5, + "charOffset": 827, + "charLength": 5, + "snippet": { + "text": "Debug" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 27, + "startColumn": 1, + "charOffset": 757, + "charLength": 152, + "snippet": { + "text": "\n// Debug puts Merlin into debug mode and displays debug messages\nvar Debug bool\n\n// Verbose puts Merlin into verbose mode and displays verbose messages" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "6288f0d11f5c1d11ca02d9a3b07f042a45cdc6536f3193f67fadf373682b1a69" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedGlobalVariable", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused variable 'Build'", + "markdown": "Unused variable `Build`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/merlin.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 27, + "startColumn": 5, + "charOffset": 915, + "charLength": 5, + "snippet": { + "text": "Build" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 25, + "startColumn": 1, + "charOffset": 838, + "charLength": 98, + "snippet": { + "text": "\n// Build is a hash off the git commit and is stamped it at compile time\nvar Build = \"nonRelease\"\n" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "a59a3bce37dbe08ba584e456e4586a698a2c54153214d20f6ea930b520a5e256" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedGlobalVariable", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused variable 'Verbose'", + "markdown": "Unused variable `Verbose`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/core/core.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 32, + "startColumn": 5, + "charOffset": 914, + "charLength": 7, + "snippet": { + "text": "Verbose" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 30, + "startColumn": 1, + "charOffset": 838, + "charLength": 137, + "snippet": { + "text": "\n// Verbose puts Merlin into verbose mode and displays verbose messages\nvar Verbose bool\n\nvar src = rand.NewSource(time.Now().UnixNano())" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "edbc8d7a701355a1f61a910963acc4afc9ee5437f86072561596fd93515a76e1" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedParameter", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused parameter 'data interface{}'", + "markdown": "Unused parameter `data interface{}`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/authenticators/none/none.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 56, + "startColumn": 52, + "charOffset": 1662, + "charLength": 16, + "snippet": { + "text": "data interface{}" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 54, + "startColumn": 1, + "charOffset": 1608, + "charLength": 251, + "snippet": { + "text": "}\n\nfunc (a *Authenticator) Authenticate(id uuid.UUID, data interface{}) (msg messages.Base, err error) {\n\t// Create a new Agent object\n\t// Agents that don't have an authentication mechanism will not have a per-agent secret and will perpetually use the" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "1bd0fdb5bca82a0028e8fddba90cf3de2f3119cad3cfaafce9380ba5c61d2486" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedParameter", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused parameter 'key'", + "markdown": "Unused parameter `key`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/transformer/encoders/gob/gob.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 60, + "startColumn": 35, + "charOffset": 1504, + "charLength": 3, + "snippet": { + "text": "key" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 58, + "startColumn": 1, + "charOffset": 1399, + "charLength": 156, + "snippet": { + "text": "\n// Deconstruct takes in bytes and Gob decodes it to its original type\nfunc (c *Coder) Deconstruct(data, key []byte) (any, error) {\n\treturn c.Decode(data)\n}" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "39fafa5b398cc996e0108fe3e1a9026d229f16ed8706aa407ebdd9051f4e54e3" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedParameter", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused parameter 'key'", + "markdown": "Unused parameter `key`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/transformer/encoders/hex/hex.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 58, + "startColumn": 35, + "charOffset": 1635, + "charLength": 3, + "snippet": { + "text": "key" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 56, + "startColumn": 1, + "charOffset": 1530, + "charLength": 220, + "snippet": { + "text": "\n// Deconstruct takes in bytes and hex decodes it to its original type\nfunc (c *Coder) Deconstruct(data, key []byte) (any, error) {\n\tretData := make([]byte, hex.DecodedLen(len(data)))\n\t_, err := hex.Decode(retData, data)" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "5c73803504d4b67dce503277e4143a66cb44c66ca4a2430cd5b9ba52ac7c1a4e" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedParameter", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused parameter 'key []byte'", + "markdown": "Unused parameter `key []byte`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/transformer/encoders/base64/base64.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 44, + "startColumn": 37, + "charOffset": 1178, + "charLength": 10, + "snippet": { + "text": "key []byte" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 42, + "startColumn": 1, + "charOffset": 1056, + "charLength": 196, + "snippet": { + "text": "\n// Construct takes in data, Base64 encodes it, and returns the encoded data as bytes\nfunc (c *Coder) Construct(data any, key []byte) (retData []byte, err error) {\n\tswitch c.concrete {\n\tcase BYTE:" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "6e82296d90fd6d2a011cf8f01fb32b51991a7c6b7216c75fb1e5724266f2cbbc" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedParameter", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused parameter 'key []byte'", + "markdown": "Unused parameter `key []byte`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/transformer/encoders/hex/hex.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 44, + "startColumn": 37, + "charOffset": 1166, + "charLength": 10, + "snippet": { + "text": "key []byte" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 42, + "startColumn": 1, + "charOffset": 1047, + "charLength": 193, + "snippet": { + "text": "\n// Construct takes in data, hex encodes it, and returns the encoded data as bytes\nfunc (c *Coder) Construct(data any, key []byte) (retData []byte, err error) {\n\tswitch c.concrete {\n\tcase BYTE:" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "9087f4f36a0cd027ee3f82f22cfe94e6340897901af7af74567af557e1c72296" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedParameter", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused parameter 'key'", + "markdown": "Unused parameter `key`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/transformer/encoders/base64/base64.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 56, + "startColumn": 35, + "charOffset": 1585, + "charLength": 3, + "snippet": { + "text": "key" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 54, + "startColumn": 1, + "charOffset": 1477, + "charLength": 167, + "snippet": { + "text": "\n// Deconstruct takes in bytes and Base64 decodes it to its original type\nfunc (c *Coder) Deconstruct(data, key []byte) (any, error) {\n\tswitch c.concrete {\n\tcase BYTE:" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "c74f966f726eaf1241f089770bf9feac55fb1149bbb771f54e63450ec676625f" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + }, + { + "ruleId": "GoUnusedParameter", + "kind": "fail", + "level": "warning", + "message": { + "text": "Unused parameter 'key []byte'", + "markdown": "Unused parameter `key []byte`" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/transformer/encoders/gob/gob.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 55, + "startColumn": 37, + "charOffset": 1344, + "charLength": 10, + "snippet": { + "text": "key []byte" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 53, + "startColumn": 1, + "charOffset": 1225, + "charLength": 173, + "snippet": { + "text": "\n// Construct takes in data, Gob encodes it, and returns the encoded data as bytes\nfunc (c *Coder) Construct(data any, key []byte) ([]byte, error) {\n\treturn c.Encode(data)\n}" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "fc496b2e27d64ec2e4b1dc0df14d5a72f0db6422d8e148f0d996781649f52868" + }, + "properties": { + "ideaSeverity": "WARNING", + "qodanaSeverity": "High", + "tags": [ + "go" + ] + } + } + ], + "automationDetails": { + "id": "project/qodana/2024-01-03", + "guid": "49d0e660-f236-4916-b0ac-34862134d562", + "properties": { + "jobUrl": "" + } + }, + "newlineSequences": [ + "\r\n", + "\n" + ], + "properties": { + "qodana.sanity.results": [ + { + "ruleId": "QodanaSanity", + "kind": "fail", + "level": "error", + "message": { + "text": "Cannot resolve symbol 'slog'", + "markdown": "Cannot resolve symbol 'slog'" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/agents/agents.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 26, + "startColumn": 7, + "charOffset": 762, + "charLength": 4, + "snippet": { + "text": "slog" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 24, + "startColumn": 1, + "charOffset": 736, + "charLength": 54, + "snippet": { + "text": "\t// Standard\n\t\"fmt\"\n\t\"log/slog\"\n\t\"os\"\n\t\"path/filepath\"" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "07675be7307a9b5c4cea2982b160d0037d7189d2fea575728bf78a06a9f5561e" + }, + "properties": { + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + { + "ruleId": "QodanaSanity", + "kind": "fail", + "level": "error", + "message": { + "text": "Cannot resolve symbol 'time'", + "markdown": "Cannot resolve symbol 'time'" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/agents/repository.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 25, + "startColumn": 3, + "charOffset": 764, + "charLength": 4, + "snippet": { + "text": "time" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 23, + "startColumn": 1, + "charOffset": 727, + "charLength": 45, + "snippet": { + "text": "import (\n\t\"github.com/google/uuid\"\n\t\"time\"\n)\n" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "1795ffbc6a2a5504c06f43ce927a0005e05f316087fae3508d79c5510dfcc826" + }, + "properties": { + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + { + "ruleId": "QodanaSanity", + "kind": "fail", + "level": "error", + "message": { + "text": "Unresolved type 'string'", + "markdown": "Unresolved type 'string'" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/agents/structs.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 32, + "startColumn": 15, + "charOffset": 1190, + "charLength": 6, + "snippet": { + "text": "string" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 30, + "startColumn": 1, + "charOffset": 1054, + "charLength": 368, + "snippet": { + "text": "type Host struct {\n\tArchitecture string // The operating system architecture the agent is running on (e.g., x86 or x64)\n\tName string // The host name the agent is running on\n\tPlatform string // The platform, or operating system, the agent is running on\n\tIPs []string // A list of interface IP addresses on the host where the agent is running" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "34bc5a6e5ee131b17b12ea860dc1a85ee25396408297cbaabfc1ed5c8c52d855" + }, + "properties": { + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + { + "ruleId": "QodanaSanity", + "kind": "fail", + "level": "error", + "message": { + "text": "Cannot resolve symbol 'uuid'", + "markdown": "Cannot resolve symbol 'uuid'" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/agents/repository.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 24, + "startColumn": 21, + "charOffset": 756, + "charLength": 4, + "snippet": { + "text": "uuid" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 22, + "startColumn": 1, + "charOffset": 726, + "charLength": 45, + "snippet": { + "text": "\nimport (\n\t\"github.com/google/uuid\"\n\t\"time\"\n)" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "3cf0ddcad161c09cbde017a951f55a2fb3b504be90dcf693ee0c015a701a4fea" + }, + "properties": { + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + { + "ruleId": "QodanaSanity", + "kind": "fail", + "level": "error", + "message": { + "text": "Cannot resolve symbol 'log'", + "markdown": "Cannot resolve symbol 'log'" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "main.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 27, + "startColumn": 3, + "charOffset": 764, + "charLength": 3, + "snippet": { + "text": "log" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 25, + "startColumn": 1, + "charOffset": 747, + "charLength": 35, + "snippet": { + "text": "\t\"flag\"\n\t\"fmt\"\n\t\"log\"\n\n\t// Internal" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "3f5b558319f04d034831587d8150e3548d447591224816f5a5f33579134194b4" + }, + "properties": { + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + { + "ruleId": "QodanaSanity", + "kind": "fail", + "level": "error", + "message": { + "text": "Cannot resolve symbol 'flag'", + "markdown": "Cannot resolve symbol 'flag'" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "main.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 25, + "startColumn": 3, + "charOffset": 749, + "charLength": 4, + "snippet": { + "text": "flag" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 23, + "startColumn": 1, + "charOffset": 725, + "charLength": 43, + "snippet": { + "text": "import (\n\t// Standard\n\t\"flag\"\n\t\"fmt\"\n\t\"log\"" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "4a721f0341bf96014387ff8169597696443e00d2ec97233f0f7fabbd241fc50a" + }, + "properties": { + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + { + "ruleId": "QodanaSanity", + "kind": "fail", + "level": "error", + "message": { + "text": "Cannot resolve symbol 'time'", + "markdown": "Cannot resolve symbol 'time'" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/agents/memory/memory.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 27, + "startColumn": 3, + "charOffset": 769, + "charLength": 4, + "snippet": { + "text": "time" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 25, + "startColumn": 1, + "charOffset": 749, + "charLength": 40, + "snippet": { + "text": "\t\"errors\"\n\t\"sync\"\n\t\"time\"\n\n\t// 3rd Party" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "7c8a28240ceb73c4ead6898bbff00ccab1cd71eb4cdd20fa39c811c50b161f96" + }, + "properties": { + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + { + "ruleId": "QodanaSanity", + "kind": "fail", + "level": "error", + "message": { + "text": "Cannot resolve symbol 'github.com'", + "markdown": "Cannot resolve symbol 'github.com'" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/agents/memory/memory.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 30, + "startColumn": 3, + "charOffset": 792, + "charLength": 10, + "snippet": { + "text": "github.com" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 28, + "startColumn": 1, + "charOffset": 775, + "charLength": 52, + "snippet": { + "text": "\n\t// 3rd Party\n\t\"github.com/google/uuid\"\n\n\t// Merlin" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "9245d27ae0dc608526f6e4cb4840955e16bb90465588f3cf7f387413d1b86156" + }, + "properties": { + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + { + "ruleId": "QodanaSanity", + "kind": "fail", + "level": "error", + "message": { + "text": "Unresolved type 'string'", + "markdown": "Unresolved type 'string'" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/agents/structs.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 25, + "startColumn": 10, + "charOffset": 871, + "charLength": 6, + "snippet": { + "text": "string" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 23, + "startColumn": 1, + "charOffset": 727, + "charLength": 224, + "snippet": { + "text": "// Build is a structure that holds information about an Agent's compiled build hash and the Agent's version number\ntype Build struct {\n\tBuild string // The agent's build hash\n\tVersion string // The agent's version number\n}" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "95c4a418ff885c0753b30e378b43fcdbd60393fae89cfaa5ce01af3cc2bf2744" + }, + "properties": { + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + { + "ruleId": "QodanaSanity", + "kind": "fail", + "level": "error", + "message": { + "text": "Cannot resolve symbol 'os'", + "markdown": "Cannot resolve symbol 'os'" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/agents/agents.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 27, + "startColumn": 3, + "charOffset": 770, + "charLength": 2, + "snippet": { + "text": "os" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 25, + "startColumn": 1, + "charOffset": 749, + "charLength": 49, + "snippet": { + "text": "\t\"fmt\"\n\t\"log/slog\"\n\t\"os\"\n\t\"path/filepath\"\n\t\"time\"" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "9956c1e9ef8f98c68d0b190df07767089c7c18d9e9e2f44dfc63d9462c19691b" + }, + "properties": { + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + { + "ruleId": "QodanaSanity", + "kind": "fail", + "level": "error", + "message": { + "text": "Cannot resolve symbol 'github.com'", + "markdown": "Cannot resolve symbol 'github.com'" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "main.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 30, + "startColumn": 10, + "charOffset": 792, + "charLength": 10, + "snippet": { + "text": "github.com" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 28, + "startColumn": 1, + "charOffset": 769, + "charLength": 149, + "snippet": { + "text": "\n\t// Internal\n\tmerlin \"github.com/Ne0nd0g/merlin/v2/pkg\"\n\t\"github.com/Ne0nd0g/merlin/v2/pkg/logging\"\n\t\"github.com/Ne0nd0g/merlin/v2/pkg/services/rpc\"" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "9a8cb8fe7fb394f251680c9b112498ffa3ee8bf98c144c50116621c34732bbf0" + }, + "properties": { + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + { + "ruleId": "QodanaSanity", + "kind": "fail", + "level": "error", + "message": { + "text": "Unresolved type 'string'", + "markdown": "Unresolved type 'string'" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/agents/structs.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 26, + "startColumn": 10, + "charOffset": 913, + "charLength": 6, + "snippet": { + "text": "string" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 24, + "startColumn": 1, + "charOffset": 842, + "charLength": 110, + "snippet": { + "text": "type Build struct {\n\tBuild string // The agent's build hash\n\tVersion string // The agent's version number\n}\n" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "ab1f56451323e33614c2529a96c4ceeac0797f4e3146734a253588b6927e94dc" + }, + "properties": { + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + { + "ruleId": "QodanaSanity", + "kind": "fail", + "level": "error", + "message": { + "text": "Cannot resolve symbol 'fmt'", + "markdown": "Cannot resolve symbol 'fmt'" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "main.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 26, + "startColumn": 3, + "charOffset": 757, + "charLength": 3, + "snippet": { + "text": "fmt" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 24, + "startColumn": 1, + "charOffset": 734, + "charLength": 35, + "snippet": { + "text": "\t// Standard\n\t\"flag\"\n\t\"fmt\"\n\t\"log\"\n" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "afcc503a416d7604e9ae0ff801c142cee105264596184fac90cbcbfa7965f277" + }, + "properties": { + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + { + "ruleId": "QodanaSanity", + "kind": "fail", + "level": "error", + "message": { + "text": "Cannot resolve symbol 'google'", + "markdown": "Cannot resolve symbol 'google'" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/agents/repository.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 24, + "startColumn": 14, + "charOffset": 749, + "charLength": 6, + "snippet": { + "text": "google" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 22, + "startColumn": 1, + "charOffset": 726, + "charLength": 45, + "snippet": { + "text": "\nimport (\n\t\"github.com/google/uuid\"\n\t\"time\"\n)" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "b432b98958af982bbd6ed101c2ba3a1799aab934f75618aac109347297bd3034" + }, + "properties": { + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + { + "ruleId": "QodanaSanity", + "kind": "fail", + "level": "error", + "message": { + "text": "Cannot resolve symbol 'sync'", + "markdown": "Cannot resolve symbol 'sync'" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/agents/memory/memory.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 26, + "startColumn": 3, + "charOffset": 761, + "charLength": 4, + "snippet": { + "text": "sync" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 24, + "startColumn": 1, + "charOffset": 736, + "charLength": 39, + "snippet": { + "text": "\t// Standard\n\t\"errors\"\n\t\"sync\"\n\t\"time\"\n" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "b480cfc21bd16f1b9f785bb8129d14d0972d002c81215ad8fbc2257e7db5084f" + }, + "properties": { + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + { + "ruleId": "QodanaSanity", + "kind": "fail", + "level": "error", + "message": { + "text": "Cannot resolve symbol 'fmt'", + "markdown": "Cannot resolve symbol 'fmt'" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/agents/agents.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 25, + "startColumn": 3, + "charOffset": 751, + "charLength": 3, + "snippet": { + "text": "fmt" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 23, + "startColumn": 1, + "charOffset": 727, + "charLength": 46, + "snippet": { + "text": "import (\n\t// Standard\n\t\"fmt\"\n\t\"log/slog\"\n\t\"os\"" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "cb97675d6e10f2f357e81f02ccfbffb0b97701cc0f02006d69f6ed33d7ef9090" + }, + "properties": { + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + { + "ruleId": "QodanaSanity", + "kind": "fail", + "level": "error", + "message": { + "text": "Cannot resolve symbol 'errors'", + "markdown": "Cannot resolve symbol 'errors'" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/agents/memory/memory.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 25, + "startColumn": 3, + "charOffset": 751, + "charLength": 6, + "snippet": { + "text": "errors" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 23, + "startColumn": 1, + "charOffset": 727, + "charLength": 47, + "snippet": { + "text": "import (\n\t// Standard\n\t\"errors\"\n\t\"sync\"\n\t\"time\"" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "d07aec97989b15788b6e2ee3da9cb65fa52ddc981e18b342fa669d4a76ff8f13" + }, + "properties": { + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + { + "ruleId": "QodanaSanity", + "kind": "fail", + "level": "error", + "message": { + "text": "Cannot resolve symbol 'log'", + "markdown": "Cannot resolve symbol 'log'" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/agents/agents.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 26, + "startColumn": 3, + "charOffset": 758, + "charLength": 3, + "snippet": { + "text": "log" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 24, + "startColumn": 1, + "charOffset": 736, + "charLength": 54, + "snippet": { + "text": "\t// Standard\n\t\"fmt\"\n\t\"log/slog\"\n\t\"os\"\n\t\"path/filepath\"" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "e113e23373cea7c17e990ed072c100dd350ba34fcdbf0205dafbb4abe3d7d8c1" + }, + "properties": { + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + { + "ruleId": "QodanaSanity", + "kind": "fail", + "level": "error", + "message": { + "text": "Cannot resolve symbol 'github.com'", + "markdown": "Cannot resolve symbol 'github.com'" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/agents/repository.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 24, + "startColumn": 3, + "charOffset": 738, + "charLength": 10, + "snippet": { + "text": "github.com" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 22, + "startColumn": 1, + "charOffset": 726, + "charLength": 45, + "snippet": { + "text": "\nimport (\n\t\"github.com/google/uuid\"\n\t\"time\"\n)" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "ecbcb1b46fde15480b632f8f52fe4665dc602f5e327909fbef9935cf748d87f5" + }, + "properties": { + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + }, + { + "ruleId": "QodanaSanity", + "kind": "fail", + "level": "error", + "message": { + "text": "Unresolved type 'string'", + "markdown": "Unresolved type 'string'" + }, + "locations": [ + { + "physicalLocation": { + "artifactLocation": { + "uri": "pkg/agents/structs.go", + "uriBaseId": "SRCROOT" + }, + "region": { + "startLine": 31, + "startColumn": 15, + "charOffset": 1087, + "charLength": 6, + "snippet": { + "text": "string" + }, + "sourceLanguage": "go" + }, + "contextRegion": { + "startLine": 29, + "startColumn": 1, + "charOffset": 953, + "charLength": 371, + "snippet": { + "text": "// Host is a structure that holds information about the Host operating system an Agent is running on\ntype Host struct {\n\tArchitecture string // The operating system architecture the agent is running on (e.g., x86 or x64)\n\tName string // The host name the agent is running on\n\tPlatform string // The platform, or operating system, the agent is running on" + }, + "sourceLanguage": "go" + } + }, + "logicalLocations": [ + { + "fullyQualifiedName": "merlin", + "kind": "module" + } + ] + } + ], + "partialFingerprints": { + "equalIndicator/v1": "f9bc2f6f2493cdb9defe50787d3ac96b5a2ccee9e4ab961ee3896f44618c7fa0" + }, + "properties": { + "ideaSeverity": "ERROR", + "qodanaSeverity": "Critical" + } + } + ], + "configProfile": "absent", + "deviceId": "200820300000000-a40d-b3de-642f-8779309d59d1", + "qodanaNewResultSummary": { + "high": 91, + "total": 91 + } + } + } + ] +} \ No newline at end of file diff --git a/Dockerfile b/Dockerfile index 0c15f028..3475c7d4 100644 --- a/Dockerfile +++ b/Dockerfile @@ -1,13 +1,17 @@ # Image source is located at https://github.com/Ne0nd0g/merlin-docker/blob/main/Dockerfile # Image repository is at https://hub.docker.com/r/ne0nd0g/merlin-base -FROM ne0nd0g/merlin-base +FROM ne0nd0g/merlin-base:v1.5.0 # Build the Docker image first -# > sudo docker build -t merlin . +# > sudo docker build -t merlin-server . # To start the Merlin Server and interact with it, run: -# > sudo docker run -it -p 50051:50051 -p 443:443 -v ~/merlin:/opt/merlin/data merlin:latest +# > sudo docker run -p 50051:50051 -p 443:443 -v ~/merlin:/opt/merlin/data merlin-server:latest + +# Port 50051 is the gRPC port for the Merlin CLI to connect to +# Port 443 is the port where a Merlin listener will bind to +# Run the docker image with extra '-p' arguments to expose more ports for Merlin listeners to bind to WORKDIR /opt/merlin -ENTRYPOINT ["go", "run", "main.go"] +ENTRYPOINT ["./merlinServer-Linux-x64", "-addr", "0.0.0.0:50051"] diff --git a/Makefile b/Makefile index c7a2782c..68a08e0d 100644 --- a/Makefile +++ b/Makefile @@ -10,8 +10,6 @@ $(shell mkdir -p ${DIR}) LDFLAGS=-ldflags '-X github.com/Ne0nd0g/merlin/v2/pkg.Build=${BUILD} -buildid=' # Misc -# GOGARBLE contains a list of all the packages to obfuscate -GOGARBLE=golang.org,gopkg.in,github.com # The Merlin server and agent MUST be built with the same seed value # Set during build with "make linux-garble SEED= SEED=d0d03a0ae4722535a0e1d5d0c8385ce42015511e68d960fadef4b4eaf5942feb @@ -26,7 +24,7 @@ windows: # The SEED must be the exact same that was used when compiling the agent # Garble version 0.5.2 or later must be installed and accessible in the PATH environment variable windows-garble: - export GOGARBLE=${GOGARBLE} && export GOOS=windows GOARCH=amd64 &&garble -tiny -literals -seed ${SEED} build ${LDFLAGS} -o ${DIR}/merlinServer-Windows-x64.exe main.go + export GOOS=windows GOARCH=amd64 &&garble -tiny -literals -seed ${SEED} build ${LDFLAGS} -o ${DIR}/merlinServer-Windows-x64.exe main.go # Compile Server - Linux x64 linux: @@ -35,7 +33,7 @@ linux: # The SEED must be the exact same that was used when compiling the agent # Garble version 0.5.2 or later must be installed and accessible in the PATH environment variable linux-garble: - export GOGARBLE=${GOGARBLE} && export GOOS=linux GOARCH=amd64 && garble -tiny -literals -seed ${SEED} build ${LDFLAGS} -o ${DIR}/merlinServer-Linux-x64 main.go + export GOOS=linux GOARCH=amd64 && garble -tiny -literals -seed ${SEED} build ${LDFLAGS} -o ${DIR}/merlinServer-Linux-x64 main.go # Compile Server - Darwin x64 darwin: @@ -44,7 +42,7 @@ darwin: # The SEED must be the exact same that was used when compiling the agent # Garble version 0.5.2 or later must be installed and accessible in the PATH environment variable darwin-garble: - export GOGARBLE=${GOGARBLE} && export GOOS=darwin GOARCH=amd64 && garble -tiny -literals -seed ${SEED} build ${LDFLAGS} -o ${DIR}/merlinServer-Darwin-x64.exe main.go + export GOOS=darwin GOARCH=amd64 && garble -tiny -literals -seed ${SEED} build ${LDFLAGS} -o ${DIR}/merlinServer-Darwin-x64.exe main.go distro: windows linux darwin diff --git a/docs/CHANGELOG.MD b/docs/CHANGELOG.MD index 9624f397..8340447d 100644 --- a/docs/CHANGELOG.MD +++ b/docs/CHANGELOG.MD @@ -4,6 +4,23 @@ All notable changes to this project will be documented in this file. The format is based on [Keep a Changelog](http://keepachangelog.com/en/1.0.0/) and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0.html). +## 2.1.1 - 2024-01-03 + +### Added + +- Added Qodana baseline file + +### Changed + +- Upgraded packages + - `github.com/Ne0nd0g/merlin-message` to v1.3.0 + - `github.com/quic-go/quic-go` to v0.40.1 + - `google.golang.org/grpc` to v1.60.0 +- Modified Dockerfile + - Upgraded `ne0nd0g/merlin-base` v1.5.0 in Dockerfile + - Changed `ENTRYPOINT` to execute a compiled binary instead of `go run` +- Removed `GOGARBLE` environment variable from Makefile + ## 2.1.0 - 2023-12-14 ### Fixed diff --git a/go.mod b/go.mod index 6c97862f..1f2b6f97 100644 --- a/go.mod +++ b/go.mod @@ -4,33 +4,33 @@ go 1.21 require ( github.com/Binject/go-donut v0.0.0-20201215224200-d947cf4d090d - github.com/Ne0nd0g/merlin-message v1.2.0 + github.com/Ne0nd0g/merlin-message v1.3.0 github.com/cretz/gopaque v0.1.0 github.com/go-jose/go-jose/v3 v3.0.1 - github.com/google/uuid v1.4.0 - github.com/quic-go/quic-go v0.40.0 + github.com/google/uuid v1.5.0 + github.com/quic-go/quic-go v0.40.1 go.dedis.ch/kyber/v3 v3.1.0 - golang.org/x/net v0.17.0 - golang.org/x/sync v0.4.0 - google.golang.org/grpc v1.59.0 - google.golang.org/protobuf v1.31.0 + golang.org/x/net v0.19.0 + golang.org/x/sync v0.5.0 + google.golang.org/grpc v1.60.1 + google.golang.org/protobuf v1.32.0 ) require ( github.com/Binject/debug v0.0.0-20201228082058-60012895f187 // indirect github.com/go-task/slim-sprig v0.0.0-20230315185526-52ccab3ef572 // indirect github.com/golang/protobuf v1.5.3 // indirect - github.com/google/pprof v0.0.0-20231023181126-ff6d637d2a7b // indirect - github.com/onsi/ginkgo/v2 v2.13.0 // indirect + github.com/google/pprof v0.0.0-20231229205709-960ae82b1e42 // indirect + github.com/onsi/ginkgo/v2 v2.13.2 // indirect github.com/quic-go/qpack v0.4.0 // indirect github.com/quic-go/qtls-go1-20 v0.4.1 // indirect go.dedis.ch/fixbuf v1.0.3 // indirect - go.uber.org/mock v0.3.0 // indirect + go.uber.org/mock v0.4.0 // indirect golang.org/x/crypto v0.17.0 // indirect - golang.org/x/exp v0.0.0-20231006140011-7918f672742d // indirect - golang.org/x/mod v0.13.0 // indirect + golang.org/x/exp v0.0.0-20231226003508-02704c960a9b // indirect + golang.org/x/mod v0.14.0 // indirect golang.org/x/sys v0.15.0 // indirect golang.org/x/text v0.14.0 // indirect - golang.org/x/tools v0.14.0 // indirect - google.golang.org/genproto/googleapis/rpc v0.0.0-20231016165738-49dd2c1f3d0b // indirect + golang.org/x/tools v0.16.1 // indirect + google.golang.org/genproto/googleapis/rpc v0.0.0-20240102182953-50ed04b92917 // indirect ) diff --git a/go.sum b/go.sum index c5cc40e6..4d45fd48 100644 --- a/go.sum +++ b/go.sum @@ -2,8 +2,8 @@ github.com/Binject/debug v0.0.0-20201228082058-60012895f187 h1:1X9jYT7Hq1fhPIv6a github.com/Binject/debug v0.0.0-20201228082058-60012895f187/go.mod h1:QzgxDLY/qdKlvnbnb65eqTedhvQPbaSP2NqIbcuKvsQ= github.com/Binject/go-donut v0.0.0-20201215224200-d947cf4d090d h1:p1nbUZVkTna5JW0jUpmnXaLc9enF3CwcRisYwUuNiz4= github.com/Binject/go-donut v0.0.0-20201215224200-d947cf4d090d/go.mod h1:+HPTw2E7tpmDKnls6np/4DMINtku9rw3TgLtKoydgMI= -github.com/Ne0nd0g/merlin-message v1.2.0 h1:ooJ6mxUqh5e+SSrUfo10szLlMAI2FgdtxHUOZmvibb8= -github.com/Ne0nd0g/merlin-message v1.2.0/go.mod h1:ww4j4qnG9efG4Dq3CZiGIgCS4rtFDa6cN3nPohIvOMk= +github.com/Ne0nd0g/merlin-message v1.3.0 h1:HelXwN6Gtk80C2ted0+PAprq+zRiQRGLG6s6phyFY5o= +github.com/Ne0nd0g/merlin-message v1.3.0/go.mod h1:6eAh2KI4XrOAF+y4W2DN0qfRVWiAGzYlq148iKe3sSA= github.com/cretz/gopaque v0.1.0 h1:rC+coO7LzXnstyG7FmwK0XD7oV93tg9EZ+Fl2yZOeto= github.com/cretz/gopaque v0.1.0/go.mod h1:0npz8L/gL98OX2nWKF8WRSP8ZCAg89UKBBrBVrDXJQg= github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= @@ -11,8 +11,8 @@ github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= github.com/go-jose/go-jose/v3 v3.0.1 h1:pWmKFVtt+Jl0vBZTIpz/eAKwsm6LkIxDVVbFHKkchhA= github.com/go-jose/go-jose/v3 v3.0.1/go.mod h1:RNkWWRld676jZEYoV3+XK8L2ZnNSvIsxFMht0mSX+u8= -github.com/go-logr/logr v1.2.4 h1:g01GSCwiDw2xSZfjJ2/T9M+S6pFdcNtFYsp+Y43HYDQ= -github.com/go-logr/logr v1.2.4/go.mod h1:jdQByPbusPIv2/zmleS9BjJVeZ6kBagPoEUsqbVz/1A= +github.com/go-logr/logr v1.3.0 h1:2y3SDp0ZXuc6/cjLSZ+Q3ir+QB9T/iG5yYRXqsagWSY= +github.com/go-logr/logr v1.3.0/go.mod h1:9T104GzyrTigFIr8wt5mBrctHMim0Nb2HLGrmQ40KvY= github.com/go-task/slim-sprig v0.0.0-20230315185526-52ccab3ef572 h1:tfuBGBXKqDEevZMzYi5KSi8KkcZtzBcTgAUUtapy0OI= github.com/go-task/slim-sprig v0.0.0-20230315185526-52ccab3ef572/go.mod h1:9Pwr4B2jHnOSGXyyzV8ROjYa2ojvAY6HCGYYfMoC3Ls= github.com/golang/protobuf v1.5.0/go.mod h1:FsONVRAS9T7sI+LIUmWTfcYkHO4aIWwzhcaSAoJOfIk= @@ -20,24 +20,24 @@ github.com/golang/protobuf v1.5.3 h1:KhyjKVUg7Usr/dYsdSqoFveMYd5ko72D+zANwlG1mmg github.com/golang/protobuf v1.5.3/go.mod h1:XVQd3VNwM+JqD3oG2Ue2ip4fOMUkwXdXDdiuN0vRsmY= github.com/google/go-cmp v0.5.0/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= github.com/google/go-cmp v0.5.5/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= -github.com/google/go-cmp v0.5.9 h1:O2Tfq5qg4qc4AmwVlvv0oLiVAGB7enBSJ2x2DqQFi38= -github.com/google/go-cmp v0.5.9/go.mod h1:17dUlkBOakJ0+DkrSSNjCkIjxS6bF9zb3elmeNGIjoY= -github.com/google/pprof v0.0.0-20231023181126-ff6d637d2a7b h1:RMpPgZTSApbPf7xaVel+QkoGPRLFLrwFO89uDUHEGf0= -github.com/google/pprof v0.0.0-20231023181126-ff6d637d2a7b/go.mod h1:czg5+yv1E0ZGTi6S6vVK1mke0fV+FaUhNGcd6VRS9Ik= -github.com/google/uuid v1.4.0 h1:MtMxsa51/r9yyhkyLsVeVt0B+BGQZzpQiTQ4eHZ8bc4= -github.com/google/uuid v1.4.0/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo= -github.com/onsi/ginkgo/v2 v2.13.0 h1:0jY9lJquiL8fcf3M4LAXN5aMlS/b2BV86HFFPCPMgE4= -github.com/onsi/ginkgo/v2 v2.13.0/go.mod h1:TE309ZR8s5FsKKpuB1YAQYBzCaAfUgatB/xlT/ETL/o= -github.com/onsi/gomega v1.27.10 h1:naR28SdDFlqrG6kScpT8VWpu1xWY5nJRCF3XaYyBjhI= -github.com/onsi/gomega v1.27.10/go.mod h1:RsS8tutOdbdgzbPtzzATp12yT7kM5I5aElG3evPbQ0M= +github.com/google/go-cmp v0.6.0 h1:ofyhxvXcZhMsU5ulbFiLKl/XBFqE1GSq7atu8tAmTRI= +github.com/google/go-cmp v0.6.0/go.mod h1:17dUlkBOakJ0+DkrSSNjCkIjxS6bF9zb3elmeNGIjoY= +github.com/google/pprof v0.0.0-20231229205709-960ae82b1e42 h1:dHLYa5D8/Ta0aLR2XcPsrkpAgGeFs6thhMcQK0oQ0n8= +github.com/google/pprof v0.0.0-20231229205709-960ae82b1e42/go.mod h1:czg5+yv1E0ZGTi6S6vVK1mke0fV+FaUhNGcd6VRS9Ik= +github.com/google/uuid v1.5.0 h1:1p67kYwdtXjb0gL0BPiP1Av9wiZPo5A8z2cWkTZ+eyU= +github.com/google/uuid v1.5.0/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo= +github.com/onsi/ginkgo/v2 v2.13.2 h1:Bi2gGVkfn6gQcjNjZJVO8Gf0FHzMPf2phUei9tejVMs= +github.com/onsi/ginkgo/v2 v2.13.2/go.mod h1:XStQ8QcGwLyF4HdfcZB8SFOS/MWCgDuXMSBe6zrvLgM= +github.com/onsi/gomega v1.29.0 h1:KIA/t2t5UBzoirT4H9tsML45GEbo3ouUnBHsCfD2tVg= +github.com/onsi/gomega v1.29.0/go.mod h1:9sxs+SwGrKI0+PWe4Fxa9tFQQBG5xSsSbMXOI8PPpoQ= github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM= github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4= github.com/quic-go/qpack v0.4.0 h1:Cr9BXA1sQS2SmDUWjSofMPNKmvF6IiIfDRmgU0w1ZCo= github.com/quic-go/qpack v0.4.0/go.mod h1:UZVnYIfi5GRk+zI9UMaCPsmZ2xKJP7XBUvVyT1Knj9A= github.com/quic-go/qtls-go1-20 v0.4.1 h1:D33340mCNDAIKBqXuAvexTNMUByrYmFYVfKfDN5nfFs= github.com/quic-go/qtls-go1-20 v0.4.1/go.mod h1:X9Nh97ZL80Z+bX/gUXMbipO6OxdiDi58b/fMC9mAL+k= -github.com/quic-go/quic-go v0.40.0 h1:GYd1iznlKm7dpHD7pOVpUvItgMPo/jrMgDWZhMCecqw= -github.com/quic-go/quic-go v0.40.0/go.mod h1:PeN7kuVJ4xZbxSv/4OX6S1USOX8MJvydwpTx31vx60c= +github.com/quic-go/quic-go v0.40.1 h1:X3AGzUNFs0jVuO3esAGnTfvdgvL4fq655WaOi1snv1Q= +github.com/quic-go/quic-go v0.40.1/go.mod h1:PeN7kuVJ4xZbxSv/4OX6S1USOX8MJvydwpTx31vx60c= github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME= github.com/stretchr/testify v1.3.0/go.mod h1:M5WIy9Dh21IEIfnGCwXGc5bZfKNJtfHm1UVUgZn+9EI= github.com/stretchr/testify v1.6.1 h1:hDPOHmpOpP40lSULcqw7IrRb/u7w6RpDC9399XyoNd0= @@ -53,23 +53,23 @@ go.dedis.ch/protobuf v1.0.5/go.mod h1:eIV4wicvi6JK0q/QnfIEGeSFNG0ZeB24kzut5+HaRL go.dedis.ch/protobuf v1.0.7/go.mod h1:pv5ysfkDX/EawiPqcW3ikOxsL5t+BqnV6xHSmE79KI4= go.dedis.ch/protobuf v1.0.11 h1:FTYVIEzY/bfl37lu3pR4lIj+F9Vp1jE8oh91VmxKgLo= go.dedis.ch/protobuf v1.0.11/go.mod h1:97QR256dnkimeNdfmURz0wAMNVbd1VmLXhG1CrTYrJ4= -go.uber.org/mock v0.3.0 h1:3mUxI1No2/60yUYax92Pt8eNOEecx2D3lcXZh2NEZJo= -go.uber.org/mock v0.3.0/go.mod h1:a6FSlNadKUHUa9IP5Vyt1zh4fC7uAwxMutEAscFbkZc= +go.uber.org/mock v0.4.0 h1:VcM4ZOtdbR4f6VXfiOpwpVJDL6lCReaZ6mw31wqh7KU= +go.uber.org/mock v0.4.0/go.mod h1:a6FSlNadKUHUa9IP5Vyt1zh4fC7uAwxMutEAscFbkZc= golang.org/x/crypto v0.0.0-20190123085648-057139ce5d2b/go.mod h1:6SG95UA2DQfeDnfUPMdvaQW0Q7yPrPDi9nlGo2tz2b4= golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w= golang.org/x/crypto v0.0.0-20190911031432-227b76d455e7/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI= golang.org/x/crypto v0.0.0-20200622213623-75b288015ac9/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto= golang.org/x/crypto v0.17.0 h1:r8bRNjWL3GshPW3gkd+RpvzWrZAwPS49OmTGZ/uhM4k= golang.org/x/crypto v0.17.0/go.mod h1:gCAAfMLgwOJRpTjQ2zCCt2OcSfYMTeZVSRtQlPC7Nq4= -golang.org/x/exp v0.0.0-20231006140011-7918f672742d h1:jtJma62tbqLibJ5sFQz8bKtEM8rJBtfilJ2qTU199MI= -golang.org/x/exp v0.0.0-20231006140011-7918f672742d/go.mod h1:ldy0pHrwJyGW56pPQzzkH36rKxoZW1tw7ZJpeKx+hdo= -golang.org/x/mod v0.13.0 h1:I/DsJXRlw/8l/0c24sM9yb0T4z9liZTduXvdAWYiysY= -golang.org/x/mod v0.13.0/go.mod h1:hTbmBsO62+eylJbnUtE2MGJUyE7QWk4xUqPFrRgJ+7c= +golang.org/x/exp v0.0.0-20231226003508-02704c960a9b h1:kLiC65FbiHWFAOu+lxwNPujcsl8VYyTYYEZnsOO1WK4= +golang.org/x/exp v0.0.0-20231226003508-02704c960a9b/go.mod h1:iRJReGqOEeBhDZGkGbynYwcHlctCvnjTYIamk7uXpHI= +golang.org/x/mod v0.14.0 h1:dGoOF9QVLYng8IHTm7BAyWqCqSheQ5pYWGhzW00YJr0= +golang.org/x/mod v0.14.0/go.mod h1:hTbmBsO62+eylJbnUtE2MGJUyE7QWk4xUqPFrRgJ+7c= golang.org/x/net v0.0.0-20190404232315-eb5bcb51f2a3/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg= -golang.org/x/net v0.17.0 h1:pVaXccu2ozPjCXewfr1S7xza/zcXTity9cCdXQYSjIM= -golang.org/x/net v0.17.0/go.mod h1:NxSsAGuq816PNPmqtQdLE42eU2Fs7NoRIZrHJAlaCOE= -golang.org/x/sync v0.4.0 h1:zxkM55ReGkDlKSM+Fu41A+zmbZuaPVbGMzvvdUPznYQ= -golang.org/x/sync v0.4.0/go.mod h1:FU7BRWz2tNW+3quACPkgCx/L+uEAv1htQ0V83Z9Rj+Y= +golang.org/x/net v0.19.0 h1:zTwKpTd2XuCqf8huc7Fo2iSy+4RHPd10s4KzeTnVr1c= +golang.org/x/net v0.19.0/go.mod h1:CfAk/cbD4CthTvqiEl8NpboMuiuOYsAr/7NOjZJtv1U= +golang.org/x/sync v0.5.0 h1:60k92dhOjHxJkrqnwsfl8KuaHbn/5dl0lUPUklKo3qE= +golang.org/x/sync v0.5.0/go.mod h1:Czt+wKu1gCyEFDUtn0jG5QVvpJ6rzVqr5aXyt9drQfk= golang.org/x/sys v0.0.0-20190124100055-b90733256f2e/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= golang.org/x/sys v0.0.0-20190215142949-d0b11bdaac8a/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= golang.org/x/sys v0.0.0-20190412213103-97732733099d/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= @@ -79,17 +79,17 @@ golang.org/x/sys v0.15.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ= golang.org/x/text v0.14.0 h1:ScX5w1eTa3QqT8oi6+ziP7dTV1S2+ALU0bI+0zXKWiQ= golang.org/x/text v0.14.0/go.mod h1:18ZOQIKpY8NJVqYksKHtTdi31H5itFRjB5/qKTNYzSU= -golang.org/x/tools v0.14.0 h1:jvNa2pY0M4r62jkRQ6RwEZZyPcymeL9XZMLBbV7U2nc= -golang.org/x/tools v0.14.0/go.mod h1:uYBEerGOWcJyEORxN+Ek8+TT266gXkNlHdJBwexUsBg= +golang.org/x/tools v0.16.1 h1:TLyB3WofjdOEepBHAU20JdNC1Zbg87elYofWYAY5oZA= +golang.org/x/tools v0.16.1/go.mod h1:kYVVN6I1mBNoB1OX+noeBjbRk4IUEPa7JJ+TJMEooJ0= golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= -google.golang.org/genproto/googleapis/rpc v0.0.0-20231016165738-49dd2c1f3d0b h1:ZlWIi1wSK56/8hn4QcBp/j9M7Gt3U/3hZw3mC7vDICo= -google.golang.org/genproto/googleapis/rpc v0.0.0-20231016165738-49dd2c1f3d0b/go.mod h1:swOH3j0KzcDDgGUWr+SNpyTen5YrXjS3eyPzFYKc6lc= -google.golang.org/grpc v1.59.0 h1:Z5Iec2pjwb+LEOqzpB2MR12/eKFhDPhuqW91O+4bwUk= -google.golang.org/grpc v1.59.0/go.mod h1:aUPDwccQo6OTjy7Hct4AfBPD1GptF4fyUjIkQ9YtF98= +google.golang.org/genproto/googleapis/rpc v0.0.0-20240102182953-50ed04b92917 h1:6G8oQ016D88m1xAKljMlBOOGWDZkes4kMhgGFlf8WcQ= +google.golang.org/genproto/googleapis/rpc v0.0.0-20240102182953-50ed04b92917/go.mod h1:xtjpI3tXFPP051KaWnhvxkiubL/6dJ18vLVf7q2pTOU= +google.golang.org/grpc v1.60.1 h1:26+wFr+cNqSGFcOXcabYC0lUVJVRa2Sb2ortSK7VrEU= +google.golang.org/grpc v1.60.1/go.mod h1:OlCHIeLYqSSsLi6i49B5QGdzaMZK9+M7LXN2FKz4eGM= google.golang.org/protobuf v1.26.0-rc.1/go.mod h1:jlhhOSvTdKEhbULTjvd4ARK9grFBp09yW+WbY/TyQbw= google.golang.org/protobuf v1.26.0/go.mod h1:9q0QmTI4eRPtz6boOQmLYwt+qCgq0jsYwAQnmE0givc= -google.golang.org/protobuf v1.31.0 h1:g0LDEJHgrBl9N9r17Ru3sqWhkIx2NB67okBHPwC7hs8= -google.golang.org/protobuf v1.31.0/go.mod h1:HV8QOd/L58Z+nl8r43ehVNZIU/HEI6OcFqwMG9pJV4I= +google.golang.org/protobuf v1.32.0 h1:pPC6BG5ex8PDFnkbrGU3EixyhKcQ2aDuBS36lqK/C7I= +google.golang.org/protobuf v1.32.0/go.mod h1:c6P6GXX6sHbq/GpV6MGZEdwhWPcYBgnhAHhKbcUYpos= gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM= gopkg.in/yaml.v3 v3.0.1 h1:fxVm/GzAzEWqLHuvctI91KS9hhNmmWOoWu0XTYJS7CA=