eslint-plugin-github-actions-2 1.0.1 → 1.0.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +155 -95
- package/dist/_internal/code-scanning-workflow.d.ts +37 -0
- package/dist/_internal/code-scanning-workflow.d.ts.map +1 -0
- package/dist/_internal/code-scanning-workflow.js +73 -0
- package/dist/_internal/code-scanning-workflow.js.map +1 -0
- package/dist/_internal/dependabot-automation-workflow.d.ts +26 -0
- package/dist/_internal/dependabot-automation-workflow.d.ts.map +1 -0
- package/dist/_internal/dependabot-automation-workflow.js +25 -0
- package/dist/_internal/dependabot-automation-workflow.js.map +1 -0
- package/dist/_internal/dependabot-yaml.d.ts +63 -0
- package/dist/_internal/dependabot-yaml.d.ts.map +1 -0
- package/dist/_internal/dependabot-yaml.js +139 -0
- package/dist/_internal/dependabot-yaml.js.map +1 -0
- package/dist/_internal/dependency-review-workflow.d.ts +20 -0
- package/dist/_internal/dependency-review-workflow.d.ts.map +1 -0
- package/dist/_internal/dependency-review-workflow.js +9 -0
- package/dist/_internal/dependency-review-workflow.js.map +1 -0
- package/dist/_internal/github-actions-config-references.d.ts +1 -1
- package/dist/_internal/github-actions-config-references.d.ts.map +1 -1
- package/dist/_internal/github-actions-config-references.js +19 -2
- package/dist/_internal/github-actions-config-references.js.map +1 -1
- package/dist/_internal/lint-targets.d.ts +8 -0
- package/dist/_internal/lint-targets.d.ts.map +1 -1
- package/dist/_internal/lint-targets.js +26 -0
- package/dist/_internal/lint-targets.js.map +1 -1
- package/dist/_internal/rules-registry.d.ts +90 -0
- package/dist/_internal/rules-registry.d.ts.map +1 -1
- package/dist/_internal/rules-registry.js +90 -0
- package/dist/_internal/rules-registry.js.map +1 -1
- package/dist/_internal/secret-scanning-workflow.d.ts +24 -0
- package/dist/_internal/secret-scanning-workflow.d.ts.map +1 -0
- package/dist/_internal/secret-scanning-workflow.js +21 -0
- package/dist/_internal/secret-scanning-workflow.js.map +1 -0
- package/dist/_internal/workflow-action-steps.d.ts +35 -0
- package/dist/_internal/workflow-action-steps.d.ts.map +1 -0
- package/dist/_internal/workflow-action-steps.js +75 -0
- package/dist/_internal/workflow-action-steps.js.map +1 -0
- package/dist/_internal/workflow-permissions.d.ts +11 -0
- package/dist/_internal/workflow-permissions.d.ts.map +1 -0
- package/dist/_internal/workflow-permissions.js +50 -0
- package/dist/_internal/workflow-permissions.js.map +1 -0
- package/dist/_internal/yaml-fixes.d.ts +13 -0
- package/dist/_internal/yaml-fixes.d.ts.map +1 -0
- package/dist/_internal/yaml-fixes.js +77 -0
- package/dist/_internal/yaml-fixes.js.map +1 -0
- package/dist/plugin.cjs +3526 -294
- package/dist/plugin.cjs.map +4 -4
- package/dist/plugin.d.ts.map +1 -1
- package/dist/plugin.js +2 -0
- package/dist/plugin.js.map +1 -1
- package/dist/rules/action-name-casing.d.ts.map +1 -1
- package/dist/rules/action-name-casing.js +3 -0
- package/dist/rules/action-name-casing.js.map +1 -1
- package/dist/rules/job-id-casing.d.ts.map +1 -1
- package/dist/rules/job-id-casing.js +3 -0
- package/dist/rules/job-id-casing.js.map +1 -1
- package/dist/rules/max-jobs-per-action.d.ts.map +1 -1
- package/dist/rules/max-jobs-per-action.js +3 -0
- package/dist/rules/max-jobs-per-action.js.map +1 -1
- package/dist/rules/no-case-insensitive-input-id-collision.d.ts.map +1 -1
- package/dist/rules/no-case-insensitive-input-id-collision.js +3 -0
- package/dist/rules/no-case-insensitive-input-id-collision.js.map +1 -1
- package/dist/rules/no-codeql-autobuild-for-javascript-typescript.d.ts +9 -0
- package/dist/rules/no-codeql-autobuild-for-javascript-typescript.d.ts.map +1 -0
- package/dist/rules/no-codeql-autobuild-for-javascript-typescript.js +54 -0
- package/dist/rules/no-codeql-autobuild-for-javascript-typescript.js.map +1 -0
- package/dist/rules/no-codeql-javascript-typescript-split-language-matrix.d.ts +9 -0
- package/dist/rules/no-codeql-javascript-typescript-split-language-matrix.d.ts.map +1 -0
- package/dist/rules/no-codeql-javascript-typescript-split-language-matrix.js +50 -0
- package/dist/rules/no-codeql-javascript-typescript-split-language-matrix.js.map +1 -0
- package/dist/rules/no-composite-input-env-access.d.ts.map +1 -1
- package/dist/rules/no-composite-input-env-access.js +3 -0
- package/dist/rules/no-composite-input-env-access.js.map +1 -1
- package/dist/rules/no-deprecated-node-runtime.d.ts.map +1 -1
- package/dist/rules/no-deprecated-node-runtime.js +3 -0
- package/dist/rules/no-deprecated-node-runtime.js.map +1 -1
- package/dist/rules/no-duplicate-composite-step-id.d.ts.map +1 -1
- package/dist/rules/no-duplicate-composite-step-id.js +3 -0
- package/dist/rules/no-duplicate-composite-step-id.js.map +1 -1
- package/dist/rules/no-empty-template-file-pattern.d.ts.map +1 -1
- package/dist/rules/no-empty-template-file-pattern.js +6 -0
- package/dist/rules/no-empty-template-file-pattern.js.map +1 -1
- package/dist/rules/no-external-job.d.ts.map +1 -1
- package/dist/rules/no-external-job.js +3 -0
- package/dist/rules/no-external-job.js.map +1 -1
- package/dist/rules/no-hardcoded-default-branch-in-template.d.ts.map +1 -1
- package/dist/rules/no-hardcoded-default-branch-in-template.js +3 -0
- package/dist/rules/no-hardcoded-default-branch-in-template.js.map +1 -1
- package/dist/rules/no-icon-file-extension-in-template-icon-name.d.ts.map +1 -1
- package/dist/rules/no-icon-file-extension-in-template-icon-name.js +13 -3
- package/dist/rules/no-icon-file-extension-in-template-icon-name.js.map +1 -1
- package/dist/rules/no-inherit-secrets.d.ts.map +1 -1
- package/dist/rules/no-inherit-secrets.js +3 -0
- package/dist/rules/no-inherit-secrets.js.map +1 -1
- package/dist/rules/no-invalid-concurrency-context.d.ts.map +1 -1
- package/dist/rules/no-invalid-concurrency-context.js +3 -0
- package/dist/rules/no-invalid-concurrency-context.js.map +1 -1
- package/dist/rules/no-invalid-key.d.ts.map +1 -1
- package/dist/rules/no-invalid-key.js +3 -0
- package/dist/rules/no-invalid-key.js.map +1 -1
- package/dist/rules/no-invalid-reusable-workflow-job-key.d.ts.map +1 -1
- package/dist/rules/no-invalid-reusable-workflow-job-key.js +3 -0
- package/dist/rules/no-invalid-reusable-workflow-job-key.js.map +1 -1
- package/dist/rules/no-invalid-template-file-pattern-regex.d.ts.map +1 -1
- package/dist/rules/no-invalid-template-file-pattern-regex.js +3 -0
- package/dist/rules/no-invalid-template-file-pattern-regex.js.map +1 -1
- package/dist/rules/no-invalid-workflow-call-output-value.d.ts.map +1 -1
- package/dist/rules/no-invalid-workflow-call-output-value.js +3 -0
- package/dist/rules/no-invalid-workflow-call-output-value.js.map +1 -1
- package/dist/rules/no-overlapping-dependabot-directories.d.ts +9 -0
- package/dist/rules/no-overlapping-dependabot-directories.d.ts.map +1 -0
- package/dist/rules/no-overlapping-dependabot-directories.js +151 -0
- package/dist/rules/no-overlapping-dependabot-directories.js.map +1 -0
- package/dist/rules/no-path-separators-in-template-icon-name.d.ts.map +1 -1
- package/dist/rules/no-path-separators-in-template-icon-name.js +26 -3
- package/dist/rules/no-path-separators-in-template-icon-name.js.map +1 -1
- package/dist/rules/no-post-if-without-post.d.ts.map +1 -1
- package/dist/rules/no-post-if-without-post.js +6 -0
- package/dist/rules/no-post-if-without-post.js.map +1 -1
- package/dist/rules/no-pr-head-checkout-in-pull-request-target.d.ts.map +1 -1
- package/dist/rules/no-pr-head-checkout-in-pull-request-target.js +3 -0
- package/dist/rules/no-pr-head-checkout-in-pull-request-target.js.map +1 -1
- package/dist/rules/no-pre-if-without-pre.d.ts.map +1 -1
- package/dist/rules/no-pre-if-without-pre.js +6 -0
- package/dist/rules/no-pre-if-without-pre.js.map +1 -1
- package/dist/rules/no-required-input-with-default.d.ts.map +1 -1
- package/dist/rules/no-required-input-with-default.js +23 -0
- package/dist/rules/no-required-input-with-default.js.map +1 -1
- package/dist/rules/no-secrets-in-if.d.ts.map +1 -1
- package/dist/rules/no-secrets-in-if.js +3 -0
- package/dist/rules/no-secrets-in-if.js.map +1 -1
- package/dist/rules/no-self-hosted-runner-on-fork-pr-events.d.ts.map +1 -1
- package/dist/rules/no-self-hosted-runner-on-fork-pr-events.js +3 -0
- package/dist/rules/no-self-hosted-runner-on-fork-pr-events.js.map +1 -1
- package/dist/rules/no-subdirectory-template-file-pattern.d.ts.map +1 -1
- package/dist/rules/no-subdirectory-template-file-pattern.js +3 -0
- package/dist/rules/no-subdirectory-template-file-pattern.js.map +1 -1
- package/dist/rules/no-template-placeholder-in-non-template-workflow.d.ts.map +1 -1
- package/dist/rules/no-template-placeholder-in-non-template-workflow.js +3 -0
- package/dist/rules/no-template-placeholder-in-non-template-workflow.js.map +1 -1
- package/dist/rules/no-top-level-env.d.ts.map +1 -1
- package/dist/rules/no-top-level-env.js +3 -0
- package/dist/rules/no-top-level-env.js.map +1 -1
- package/dist/rules/no-top-level-permissions.d.ts.map +1 -1
- package/dist/rules/no-top-level-permissions.js +3 -0
- package/dist/rules/no-top-level-permissions.js.map +1 -1
- package/dist/rules/no-universal-template-file-pattern.d.ts.map +1 -1
- package/dist/rules/no-universal-template-file-pattern.js +3 -0
- package/dist/rules/no-universal-template-file-pattern.js.map +1 -1
- package/dist/rules/no-unknown-dependabot-multi-ecosystem-group.d.ts +9 -0
- package/dist/rules/no-unknown-dependabot-multi-ecosystem-group.d.ts.map +1 -0
- package/dist/rules/no-unknown-dependabot-multi-ecosystem-group.js +58 -0
- package/dist/rules/no-unknown-dependabot-multi-ecosystem-group.js.map +1 -0
- package/dist/rules/no-unknown-input-reference-in-composite.d.ts.map +1 -1
- package/dist/rules/no-unknown-input-reference-in-composite.js +3 -0
- package/dist/rules/no-unknown-input-reference-in-composite.js.map +1 -1
- package/dist/rules/no-unknown-job-output-reference.d.ts.map +1 -1
- package/dist/rules/no-unknown-job-output-reference.js +3 -0
- package/dist/rules/no-unknown-job-output-reference.js.map +1 -1
- package/dist/rules/no-unknown-step-reference.d.ts.map +1 -1
- package/dist/rules/no-unknown-step-reference.js +3 -0
- package/dist/rules/no-unknown-step-reference.js.map +1 -1
- package/dist/rules/no-untrusted-input-in-run.d.ts.map +1 -1
- package/dist/rules/no-untrusted-input-in-run.js +3 -0
- package/dist/rules/no-untrusted-input-in-run.js.map +1 -1
- package/dist/rules/no-unused-dependabot-enable-beta-ecosystems.d.ts +9 -0
- package/dist/rules/no-unused-dependabot-enable-beta-ecosystems.d.ts.map +1 -0
- package/dist/rules/no-unused-dependabot-enable-beta-ecosystems.js +51 -0
- package/dist/rules/no-unused-dependabot-enable-beta-ecosystems.js.map +1 -0
- package/dist/rules/no-unused-input-in-composite.d.ts.map +1 -1
- package/dist/rules/no-unused-input-in-composite.js +3 -0
- package/dist/rules/no-unused-input-in-composite.js.map +1 -1
- package/dist/rules/no-write-all-permissions.d.ts.map +1 -1
- package/dist/rules/no-write-all-permissions.js +3 -0
- package/dist/rules/no-write-all-permissions.js.map +1 -1
- package/dist/rules/pin-action-shas.d.ts.map +1 -1
- package/dist/rules/pin-action-shas.js +3 -0
- package/dist/rules/pin-action-shas.js.map +1 -1
- package/dist/rules/prefer-action-yml.d.ts.map +1 -1
- package/dist/rules/prefer-action-yml.js +3 -0
- package/dist/rules/prefer-action-yml.js.map +1 -1
- package/dist/rules/prefer-fail-fast.d.ts.map +1 -1
- package/dist/rules/prefer-fail-fast.js +3 -0
- package/dist/rules/prefer-fail-fast.js.map +1 -1
- package/dist/rules/prefer-file-extension.d.ts.map +1 -1
- package/dist/rules/prefer-file-extension.js +3 -0
- package/dist/rules/prefer-file-extension.js.map +1 -1
- package/dist/rules/prefer-inputs-context.d.ts.map +1 -1
- package/dist/rules/prefer-inputs-context.js +3 -0
- package/dist/rules/prefer-inputs-context.js.map +1 -1
- package/dist/rules/prefer-step-uses-style.d.ts.map +1 -1
- package/dist/rules/prefer-step-uses-style.js +3 -0
- package/dist/rules/prefer-step-uses-style.js.map +1 -1
- package/dist/rules/prefer-template-yml-extension.d.ts.map +1 -1
- package/dist/rules/prefer-template-yml-extension.js +3 -0
- package/dist/rules/prefer-template-yml-extension.js.map +1 -1
- package/dist/rules/require-action-name.d.ts.map +1 -1
- package/dist/rules/require-action-name.js +3 -0
- package/dist/rules/require-action-name.js.map +1 -1
- package/dist/rules/require-action-run-name.d.ts.map +1 -1
- package/dist/rules/require-action-run-name.js +3 -0
- package/dist/rules/require-action-run-name.js.map +1 -1
- package/dist/rules/require-checkout-before-local-action.d.ts.map +1 -1
- package/dist/rules/require-checkout-before-local-action.js +3 -0
- package/dist/rules/require-checkout-before-local-action.js.map +1 -1
- package/dist/rules/require-codeql-actions-read.d.ts +9 -0
- package/dist/rules/require-codeql-actions-read.d.ts.map +1 -0
- package/dist/rules/require-codeql-actions-read.js +63 -0
- package/dist/rules/require-codeql-actions-read.js.map +1 -0
- package/dist/rules/require-codeql-branch-filters.d.ts +12 -0
- package/dist/rules/require-codeql-branch-filters.d.ts.map +1 -0
- package/dist/rules/require-codeql-branch-filters.js +83 -0
- package/dist/rules/require-codeql-branch-filters.js.map +1 -0
- package/dist/rules/require-codeql-category-when-language-matrix.d.ts +12 -0
- package/dist/rules/require-codeql-category-when-language-matrix.d.ts.map +1 -0
- package/dist/rules/require-codeql-category-when-language-matrix.js +68 -0
- package/dist/rules/require-codeql-category-when-language-matrix.js.map +1 -0
- package/dist/rules/require-codeql-pull-request-trigger.d.ts +9 -0
- package/dist/rules/require-codeql-pull-request-trigger.d.ts.map +1 -0
- package/dist/rules/require-codeql-pull-request-trigger.js +46 -0
- package/dist/rules/require-codeql-pull-request-trigger.js.map +1 -0
- package/dist/rules/require-codeql-schedule.d.ts +9 -0
- package/dist/rules/require-codeql-schedule.d.ts.map +1 -0
- package/dist/rules/require-codeql-schedule.js +46 -0
- package/dist/rules/require-codeql-schedule.js.map +1 -0
- package/dist/rules/require-codeql-security-events-write.d.ts +9 -0
- package/dist/rules/require-codeql-security-events-write.d.ts.map +1 -0
- package/dist/rules/require-codeql-security-events-write.js +53 -0
- package/dist/rules/require-codeql-security-events-write.js.map +1 -0
- package/dist/rules/require-composite-step-name.d.ts.map +1 -1
- package/dist/rules/require-composite-step-name.js +3 -0
- package/dist/rules/require-composite-step-name.js.map +1 -1
- package/dist/rules/require-dependabot-assignees.d.ts +9 -0
- package/dist/rules/require-dependabot-assignees.d.ts.map +1 -0
- package/dist/rules/require-dependabot-assignees.js +53 -0
- package/dist/rules/require-dependabot-assignees.js.map +1 -0
- package/dist/rules/require-dependabot-automation-permissions.d.ts +9 -0
- package/dist/rules/require-dependabot-automation-permissions.d.ts.map +1 -0
- package/dist/rules/require-dependabot-automation-permissions.js +68 -0
- package/dist/rules/require-dependabot-automation-permissions.js.map +1 -0
- package/dist/rules/require-dependabot-automation-pull-request-trigger.d.ts +12 -0
- package/dist/rules/require-dependabot-automation-pull-request-trigger.d.ts.map +1 -0
- package/dist/rules/require-dependabot-automation-pull-request-trigger.js +49 -0
- package/dist/rules/require-dependabot-automation-pull-request-trigger.js.map +1 -0
- package/dist/rules/require-dependabot-bot-actor-guard.d.ts +9 -0
- package/dist/rules/require-dependabot-bot-actor-guard.d.ts.map +1 -0
- package/dist/rules/require-dependabot-bot-actor-guard.js +64 -0
- package/dist/rules/require-dependabot-bot-actor-guard.js.map +1 -0
- package/dist/rules/require-dependabot-commit-message-include-scope.d.ts +9 -0
- package/dist/rules/require-dependabot-commit-message-include-scope.d.ts.map +1 -0
- package/dist/rules/require-dependabot-commit-message-include-scope.js +60 -0
- package/dist/rules/require-dependabot-commit-message-include-scope.js.map +1 -0
- package/dist/rules/require-dependabot-commit-message-prefix-development.d.ts +9 -0
- package/dist/rules/require-dependabot-commit-message-prefix-development.d.ts.map +1 -0
- package/dist/rules/require-dependabot-commit-message-prefix-development.js +75 -0
- package/dist/rules/require-dependabot-commit-message-prefix-development.js.map +1 -0
- package/dist/rules/require-dependabot-commit-message-prefix.d.ts +9 -0
- package/dist/rules/require-dependabot-commit-message-prefix.d.ts.map +1 -0
- package/dist/rules/require-dependabot-commit-message-prefix.js +60 -0
- package/dist/rules/require-dependabot-commit-message-prefix.js.map +1 -0
- package/dist/rules/require-dependabot-cooldown.d.ts +9 -0
- package/dist/rules/require-dependabot-cooldown.d.ts.map +1 -0
- package/dist/rules/require-dependabot-cooldown.js +52 -0
- package/dist/rules/require-dependabot-cooldown.js.map +1 -0
- package/dist/rules/require-dependabot-directory.d.ts +9 -0
- package/dist/rules/require-dependabot-directory.d.ts.map +1 -0
- package/dist/rules/require-dependabot-directory.js +68 -0
- package/dist/rules/require-dependabot-directory.js.map +1 -0
- package/dist/rules/require-dependabot-github-actions-directory-root.d.ts +9 -0
- package/dist/rules/require-dependabot-github-actions-directory-root.d.ts.map +1 -0
- package/dist/rules/require-dependabot-github-actions-directory-root.js +76 -0
- package/dist/rules/require-dependabot-github-actions-directory-root.js.map +1 -0
- package/dist/rules/require-dependabot-labels.d.ts +9 -0
- package/dist/rules/require-dependabot-labels.d.ts.map +1 -0
- package/dist/rules/require-dependabot-labels.js +52 -0
- package/dist/rules/require-dependabot-labels.js.map +1 -0
- package/dist/rules/require-dependabot-open-pull-requests-limit.d.ts +9 -0
- package/dist/rules/require-dependabot-open-pull-requests-limit.d.ts.map +1 -0
- package/dist/rules/require-dependabot-open-pull-requests-limit.js +55 -0
- package/dist/rules/require-dependabot-open-pull-requests-limit.js.map +1 -0
- package/dist/rules/require-dependabot-package-ecosystem.d.ts +9 -0
- package/dist/rules/require-dependabot-package-ecosystem.d.ts.map +1 -0
- package/dist/rules/require-dependabot-package-ecosystem.js +79 -0
- package/dist/rules/require-dependabot-package-ecosystem.js.map +1 -0
- package/dist/rules/require-dependabot-patterns-for-multi-ecosystem-group.d.ts +9 -0
- package/dist/rules/require-dependabot-patterns-for-multi-ecosystem-group.d.ts.map +1 -0
- package/dist/rules/require-dependabot-patterns-for-multi-ecosystem-group.js +58 -0
- package/dist/rules/require-dependabot-patterns-for-multi-ecosystem-group.js.map +1 -0
- package/dist/rules/require-dependabot-schedule-cronjob.d.ts +9 -0
- package/dist/rules/require-dependabot-schedule-cronjob.d.ts.map +1 -0
- package/dist/rules/require-dependabot-schedule-cronjob.js +82 -0
- package/dist/rules/require-dependabot-schedule-cronjob.js.map +1 -0
- package/dist/rules/require-dependabot-schedule-interval.d.ts +9 -0
- package/dist/rules/require-dependabot-schedule-interval.d.ts.map +1 -0
- package/dist/rules/require-dependabot-schedule-interval.js +73 -0
- package/dist/rules/require-dependabot-schedule-interval.js.map +1 -0
- package/dist/rules/require-dependabot-schedule-time.d.ts +9 -0
- package/dist/rules/require-dependabot-schedule-time.d.ts.map +1 -0
- package/dist/rules/require-dependabot-schedule-time.js +68 -0
- package/dist/rules/require-dependabot-schedule-time.js.map +1 -0
- package/dist/rules/require-dependabot-schedule-timezone.d.ts +9 -0
- package/dist/rules/require-dependabot-schedule-timezone.d.ts.map +1 -0
- package/dist/rules/require-dependabot-schedule-timezone.js +69 -0
- package/dist/rules/require-dependabot-schedule-timezone.js.map +1 -0
- package/dist/rules/require-dependabot-target-branch.d.ts +9 -0
- package/dist/rules/require-dependabot-target-branch.d.ts.map +1 -0
- package/dist/rules/require-dependabot-target-branch.js +53 -0
- package/dist/rules/require-dependabot-target-branch.js.map +1 -0
- package/dist/rules/require-dependabot-updates.d.ts +9 -0
- package/dist/rules/require-dependabot-updates.d.ts.map +1 -0
- package/dist/rules/require-dependabot-updates.js +54 -0
- package/dist/rules/require-dependabot-updates.js.map +1 -0
- package/dist/rules/require-dependabot-version.d.ts +9 -0
- package/dist/rules/require-dependabot-version.d.ts.map +1 -0
- package/dist/rules/require-dependabot-version.js +62 -0
- package/dist/rules/require-dependabot-version.js.map +1 -0
- package/dist/rules/require-dependabot-versioning-strategy-for-npm.d.ts +9 -0
- package/dist/rules/require-dependabot-versioning-strategy-for-npm.d.ts.map +1 -0
- package/dist/rules/require-dependabot-versioning-strategy-for-npm.js +58 -0
- package/dist/rules/require-dependabot-versioning-strategy-for-npm.js.map +1 -0
- package/dist/rules/require-dependency-review-action.d.ts +9 -0
- package/dist/rules/require-dependency-review-action.d.ts.map +1 -0
- package/dist/rules/require-dependency-review-action.js +51 -0
- package/dist/rules/require-dependency-review-action.js.map +1 -0
- package/dist/rules/require-dependency-review-fail-on-severity.d.ts +9 -0
- package/dist/rules/require-dependency-review-fail-on-severity.d.ts.map +1 -0
- package/dist/rules/require-dependency-review-fail-on-severity.js +62 -0
- package/dist/rules/require-dependency-review-fail-on-severity.js.map +1 -0
- package/dist/rules/require-dependency-review-permissions-contents-read.d.ts +9 -0
- package/dist/rules/require-dependency-review-permissions-contents-read.d.ts.map +1 -0
- package/dist/rules/require-dependency-review-permissions-contents-read.js +55 -0
- package/dist/rules/require-dependency-review-permissions-contents-read.js.map +1 -0
- package/dist/rules/require-dependency-review-pull-request-trigger.d.ts +9 -0
- package/dist/rules/require-dependency-review-pull-request-trigger.d.ts.map +1 -0
- package/dist/rules/require-dependency-review-pull-request-trigger.js +47 -0
- package/dist/rules/require-dependency-review-pull-request-trigger.js.map +1 -0
- package/dist/rules/require-fetch-metadata-github-token.d.ts +9 -0
- package/dist/rules/require-fetch-metadata-github-token.d.ts.map +1 -0
- package/dist/rules/require-fetch-metadata-github-token.js +57 -0
- package/dist/rules/require-fetch-metadata-github-token.js.map +1 -0
- package/dist/rules/require-job-name.d.ts.map +1 -1
- package/dist/rules/require-job-name.js +35 -0
- package/dist/rules/require-job-name.js.map +1 -1
- package/dist/rules/require-job-step-name.d.ts.map +1 -1
- package/dist/rules/require-job-step-name.js +76 -0
- package/dist/rules/require-job-step-name.js.map +1 -1
- package/dist/rules/require-job-timeout-minutes.d.ts.map +1 -1
- package/dist/rules/require-job-timeout-minutes.js +3 -0
- package/dist/rules/require-job-timeout-minutes.js.map +1 -1
- package/dist/rules/require-merge-group-trigger.d.ts.map +1 -1
- package/dist/rules/require-merge-group-trigger.js +3 -0
- package/dist/rules/require-merge-group-trigger.js.map +1 -1
- package/dist/rules/require-pull-request-target-branches.d.ts.map +1 -1
- package/dist/rules/require-pull-request-target-branches.js +3 -0
- package/dist/rules/require-pull-request-target-branches.js.map +1 -1
- package/dist/rules/require-run-step-shell.d.ts.map +1 -1
- package/dist/rules/require-run-step-shell.js +3 -0
- package/dist/rules/require-run-step-shell.js.map +1 -1
- package/dist/rules/require-sarif-upload-security-events-write.d.ts +9 -0
- package/dist/rules/require-sarif-upload-security-events-write.d.ts.map +1 -0
- package/dist/rules/require-sarif-upload-security-events-write.js +51 -0
- package/dist/rules/require-sarif-upload-security-events-write.js.map +1 -0
- package/dist/rules/require-scorecard-results-format-sarif.d.ts +9 -0
- package/dist/rules/require-scorecard-results-format-sarif.d.ts.map +1 -0
- package/dist/rules/require-scorecard-results-format-sarif.js +57 -0
- package/dist/rules/require-scorecard-results-format-sarif.js.map +1 -0
- package/dist/rules/require-scorecard-upload-sarif-step.d.ts +9 -0
- package/dist/rules/require-scorecard-upload-sarif-step.d.ts.map +1 -0
- package/dist/rules/require-scorecard-upload-sarif-step.js +46 -0
- package/dist/rules/require-scorecard-upload-sarif-step.js.map +1 -0
- package/dist/rules/require-secret-scan-contents-read.d.ts +12 -0
- package/dist/rules/require-secret-scan-contents-read.d.ts.map +1 -0
- package/dist/rules/require-secret-scan-contents-read.js +53 -0
- package/dist/rules/require-secret-scan-contents-read.js.map +1 -0
- package/dist/rules/require-secret-scan-fetch-depth-zero.d.ts +9 -0
- package/dist/rules/require-secret-scan-fetch-depth-zero.d.ts.map +1 -0
- package/dist/rules/require-secret-scan-fetch-depth-zero.js +77 -0
- package/dist/rules/require-secret-scan-fetch-depth-zero.js.map +1 -0
- package/dist/rules/require-secret-scan-schedule.d.ts +9 -0
- package/dist/rules/require-secret-scan-schedule.d.ts.map +1 -0
- package/dist/rules/require-secret-scan-schedule.js +46 -0
- package/dist/rules/require-secret-scan-schedule.js.map +1 -0
- package/dist/rules/require-template-categories.d.ts.map +1 -1
- package/dist/rules/require-template-categories.js +3 -0
- package/dist/rules/require-template-categories.js.map +1 -1
- package/dist/rules/require-template-file-patterns.d.ts.map +1 -1
- package/dist/rules/require-template-file-patterns.js +3 -0
- package/dist/rules/require-template-file-patterns.js.map +1 -1
- package/dist/rules/require-template-icon-file-exists.d.ts.map +1 -1
- package/dist/rules/require-template-icon-file-exists.js +3 -0
- package/dist/rules/require-template-icon-file-exists.js.map +1 -1
- package/dist/rules/require-template-icon-name.d.ts.map +1 -1
- package/dist/rules/require-template-icon-name.js +3 -0
- package/dist/rules/require-template-icon-name.js.map +1 -1
- package/dist/rules/require-template-workflow-name.d.ts.map +1 -1
- package/dist/rules/require-template-workflow-name.js +3 -0
- package/dist/rules/require-template-workflow-name.js.map +1 -1
- package/dist/rules/require-trigger-types.d.ts.map +1 -1
- package/dist/rules/require-trigger-types.js +3 -0
- package/dist/rules/require-trigger-types.js.map +1 -1
- package/dist/rules/require-trufflehog-verified-results-mode.d.ts +9 -0
- package/dist/rules/require-trufflehog-verified-results-mode.d.ts.map +1 -0
- package/dist/rules/require-trufflehog-verified-results-mode.js +59 -0
- package/dist/rules/require-trufflehog-verified-results-mode.js.map +1 -0
- package/dist/rules/require-workflow-call-input-type.d.ts.map +1 -1
- package/dist/rules/require-workflow-call-input-type.js +3 -0
- package/dist/rules/require-workflow-call-input-type.js.map +1 -1
- package/dist/rules/require-workflow-call-output-value.d.ts.map +1 -1
- package/dist/rules/require-workflow-call-output-value.js +3 -0
- package/dist/rules/require-workflow-call-output-value.js.map +1 -1
- package/dist/rules/require-workflow-concurrency.d.ts.map +1 -1
- package/dist/rules/require-workflow-concurrency.js +3 -0
- package/dist/rules/require-workflow-concurrency.js.map +1 -1
- package/dist/rules/require-workflow-dispatch-input-type.d.ts.map +1 -1
- package/dist/rules/require-workflow-dispatch-input-type.js +3 -0
- package/dist/rules/require-workflow-dispatch-input-type.js.map +1 -1
- package/dist/rules/require-workflow-interface-description.d.ts.map +1 -1
- package/dist/rules/require-workflow-interface-description.js +3 -0
- package/dist/rules/require-workflow-interface-description.js.map +1 -1
- package/dist/rules/require-workflow-permissions.d.ts.map +1 -1
- package/dist/rules/require-workflow-permissions.js +3 -0
- package/dist/rules/require-workflow-permissions.js.map +1 -1
- package/dist/rules/require-workflow-run-branches.d.ts.map +1 -1
- package/dist/rules/require-workflow-run-branches.js +3 -0
- package/dist/rules/require-workflow-run-branches.js.map +1 -1
- package/dist/rules/require-workflow-template-pair.d.ts.map +1 -1
- package/dist/rules/require-workflow-template-pair.js +3 -0
- package/dist/rules/require-workflow-template-pair.js.map +1 -1
- package/dist/rules/require-workflow-template-properties-pair.d.ts.map +1 -1
- package/dist/rules/require-workflow-template-properties-pair.js +3 -0
- package/dist/rules/require-workflow-template-properties-pair.js.map +1 -1
- package/dist/rules/valid-timeout-minutes.d.ts.map +1 -1
- package/dist/rules/valid-timeout-minutes.js +3 -0
- package/dist/rules/valid-timeout-minutes.js.map +1 -1
- package/dist/rules/valid-trigger-events.d.ts.map +1 -1
- package/dist/rules/valid-trigger-events.js +3 -0
- package/dist/rules/valid-trigger-events.js.map +1 -1
- package/docs/rules/action-name-casing.md +6 -2
- package/docs/rules/no-codeql-autobuild-for-javascript-typescript.md +55 -0
- package/docs/rules/no-codeql-javascript-typescript-split-language-matrix.md +51 -0
- package/docs/rules/no-empty-template-file-pattern.md +5 -1
- package/docs/rules/no-icon-file-extension-in-template-icon-name.md +5 -1
- package/docs/rules/no-overlapping-dependabot-directories.md +87 -0
- package/docs/rules/no-path-separators-in-template-icon-name.md +5 -1
- package/docs/rules/no-post-if-without-post.md +5 -1
- package/docs/rules/no-pre-if-without-pre.md +5 -1
- package/docs/rules/no-required-input-with-default.md +10 -1
- package/docs/rules/no-unknown-dependabot-multi-ecosystem-group.md +62 -0
- package/docs/rules/no-unused-dependabot-enable-beta-ecosystems.md +63 -0
- package/docs/rules/overview.md +47 -1
- package/docs/rules/prefer-inputs-context.md +6 -2
- package/docs/rules/presets/action-metadata.md +22 -11
- package/docs/rules/presets/all.md +125 -69
- package/docs/rules/presets/code-scanning.md +33 -0
- package/docs/rules/presets/dependabot.md +40 -0
- package/docs/rules/presets/index.md +144 -73
- package/docs/rules/presets/recommended.md +30 -19
- package/docs/rules/presets/security.md +35 -9
- package/docs/rules/presets/strict.md +52 -41
- package/docs/rules/presets/workflow-template-properties.md +22 -11
- package/docs/rules/presets/workflow-templates.md +26 -15
- package/docs/rules/require-codeql-actions-read.md +50 -0
- package/docs/rules/require-codeql-branch-filters.md +53 -0
- package/docs/rules/require-codeql-category-when-language-matrix.md +49 -0
- package/docs/rules/require-codeql-pull-request-trigger.md +53 -0
- package/docs/rules/require-codeql-schedule.md +57 -0
- package/docs/rules/require-codeql-security-events-write.md +50 -0
- package/docs/rules/require-dependabot-assignees.md +64 -0
- package/docs/rules/require-dependabot-automation-permissions.md +53 -0
- package/docs/rules/require-dependabot-automation-pull-request-trigger.md +49 -0
- package/docs/rules/require-dependabot-bot-actor-guard.md +52 -0
- package/docs/rules/require-dependabot-commit-message-include-scope.md +58 -0
- package/docs/rules/require-dependabot-commit-message-prefix-development.md +60 -0
- package/docs/rules/require-dependabot-commit-message-prefix.md +64 -0
- package/docs/rules/require-dependabot-cooldown.md +59 -0
- package/docs/rules/require-dependabot-directory.md +79 -0
- package/docs/rules/require-dependabot-github-actions-directory-root.md +62 -0
- package/docs/rules/require-dependabot-labels.md +65 -0
- package/docs/rules/require-dependabot-open-pull-requests-limit.md +58 -0
- package/docs/rules/require-dependabot-package-ecosystem.md +57 -0
- package/docs/rules/require-dependabot-patterns-for-multi-ecosystem-group.md +67 -0
- package/docs/rules/require-dependabot-schedule-cronjob.md +74 -0
- package/docs/rules/require-dependabot-schedule-interval.md +66 -0
- package/docs/rules/require-dependabot-schedule-time.md +60 -0
- package/docs/rules/require-dependabot-schedule-timezone.md +61 -0
- package/docs/rules/require-dependabot-target-branch.md +63 -0
- package/docs/rules/require-dependabot-updates.md +58 -0
- package/docs/rules/require-dependabot-version.md +70 -0
- package/docs/rules/require-dependabot-versioning-strategy-for-npm.md +58 -0
- package/docs/rules/require-dependency-review-action.md +60 -0
- package/docs/rules/require-dependency-review-fail-on-severity.md +57 -0
- package/docs/rules/require-dependency-review-permissions-contents-read.md +62 -0
- package/docs/rules/require-dependency-review-pull-request-trigger.md +57 -0
- package/docs/rules/require-fetch-metadata-github-token.md +49 -0
- package/docs/rules/require-job-name.md +6 -2
- package/docs/rules/require-job-step-name.md +11 -2
- package/docs/rules/require-sarif-upload-security-events-write.md +50 -0
- package/docs/rules/require-scorecard-results-format-sarif.md +49 -0
- package/docs/rules/require-scorecard-upload-sarif-step.md +55 -0
- package/docs/rules/require-secret-scan-contents-read.md +48 -0
- package/docs/rules/require-secret-scan-fetch-depth-zero.md +50 -0
- package/docs/rules/require-secret-scan-schedule.md +50 -0
- package/docs/rules/require-trufflehog-verified-results-mode.md +49 -0
- package/package.json +52 -59
package/README.md
CHANGED
|
@@ -2,26 +2,23 @@
|
|
|
2
2
|
|
|
3
3
|
[](https://github.com/Nick2bad4u/eslint-plugin-github-actions-2/blob/main/LICENSE) [](https://www.npmjs.com/package/eslint-plugin-github-actions-2) [](https://github.com/Nick2bad4u/eslint-plugin-github-actions-2/releases) [](https://github.com/Nick2bad4u/eslint-plugin-github-actions-2/stargazers) [](https://github.com/Nick2bad4u/eslint-plugin-github-actions-2/forks) [](https://github.com/Nick2bad4u/eslint-plugin-github-actions-2/issues) [](https://codecov.io/gh/Nick2bad4u/eslint-plugin-github-actions-2)
|
|
4
4
|
|
|
5
|
-
ESLint plugin for GitHub Actions
|
|
5
|
+
ESLint plugin for GitHub Actions quality, reliability, security, and maintainability across the full GitHub Actions ecosystem.
|
|
6
6
|
|
|
7
|
-
The plugin
|
|
7
|
+
The plugin covers:
|
|
8
8
|
|
|
9
9
|
- workflow YAML files (`.github/workflows/*.{yml,yaml}`)
|
|
10
10
|
- action metadata files (`**/action.yml`, `**/action.yaml`)
|
|
11
|
+
- Dependabot configuration (`.github/dependabot.{yml,yaml}`)
|
|
11
12
|
- workflow template packages (`**/workflow-templates/*.{yml,yaml}` and `**/workflow-templates/*.properties.json`)
|
|
12
13
|
|
|
13
|
-
|
|
14
|
+
The rules help teams:
|
|
14
15
|
|
|
15
|
-
- standardize workflow
|
|
16
|
-
-
|
|
17
|
-
-
|
|
18
|
-
-
|
|
19
|
-
-
|
|
20
|
-
-
|
|
21
|
-
- pin third-party `uses:` references to immutable SHAs
|
|
22
|
-
- configure top-level `concurrency` for duplicate-run control
|
|
23
|
-
- catch invalid trigger events, oversized workflow files, and inconsistent workflow filename extensions
|
|
24
|
-
- require explicit shells for `run` steps and explicit `workflow_dispatch` input types
|
|
16
|
+
- standardize workflow, job, and step naming along with file-level conventions
|
|
17
|
+
- validate workflow structure, supported keys, trigger declarations, interface definitions, timeouts, and concurrency settings
|
|
18
|
+
- enforce safer permissions, shells, input handling, and pinned action references
|
|
19
|
+
- harden CodeQL, dependency review, SARIF upload, secret-scanning, and Dependabot automation workflows
|
|
20
|
+
- keep Dependabot and workflow-template metadata complete, consistent, and reviewable
|
|
21
|
+
- apply targeted autofixes and suggestions where the intended change is safe and unambiguous
|
|
25
22
|
|
|
26
23
|
## Installation
|
|
27
24
|
|
|
@@ -41,91 +38,154 @@ Every exported preset already scopes itself to the intended GitHub Actions file
|
|
|
41
38
|
|
|
42
39
|
## Presets
|
|
43
40
|
|
|
44
|
-
| Preset
|
|
45
|
-
|
|
|
46
|
-
| `githubActions.configs.actionMetadata`
|
|
47
|
-
| `githubActions.configs.
|
|
48
|
-
| `githubActions.configs.
|
|
49
|
-
| `githubActions.configs.
|
|
50
|
-
| `githubActions.configs.
|
|
51
|
-
| `githubActions.configs.
|
|
52
|
-
| `githubActions.configs.
|
|
41
|
+
| Preset | Purpose |
|
|
42
|
+
| ----------------------------------------------------------------------------------------------------------------------------------------------------------------- | -------------------------------------------------------------------- |
|
|
43
|
+
| [`githubActions.configs.actionMetadata`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/action-metadata) | Action metadata hygiene and correctness checks. |
|
|
44
|
+
| [`githubActions.configs.codeScanning`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/code-scanning) | CodeQL, dependency review, SARIF, and code-scanning workflow checks. |
|
|
45
|
+
| [`githubActions.configs.dependabot`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/dependabot) | Dependabot configuration quality and policy checks. |
|
|
46
|
+
| [`githubActions.configs.workflowTemplateProperties`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/workflow-template-properties) | Workflow-template metadata quality checks. |
|
|
47
|
+
| [`githubActions.configs.workflowTemplates`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/workflow-templates) | Combined workflow-template YAML + metadata checks. |
|
|
48
|
+
| [`githubActions.configs.recommended`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/recommended) | Balanced defaults for most repositories. |
|
|
49
|
+
| [`githubActions.configs.security`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/security) | Security-focused checks like immutable SHA pinning. |
|
|
50
|
+
| [`githubActions.configs.strict`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/strict) | Operational guardrails for mature workflow estates. |
|
|
51
|
+
| [`githubActions.configs.all`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) | Every rule published by the plugin. |
|
|
53
52
|
|
|
54
53
|
## Rules
|
|
55
54
|
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
|
75
|
-
|
|
|
76
|
-
|
|
|
77
|
-
|
|
|
78
|
-
| [`
|
|
79
|
-
| [`no-
|
|
80
|
-
| [`no-
|
|
81
|
-
| [`no-
|
|
82
|
-
| [`no-
|
|
83
|
-
| [`no-
|
|
84
|
-
| [`no-
|
|
85
|
-
| [`no-template-
|
|
86
|
-
| [`no-
|
|
87
|
-
| [`no-
|
|
88
|
-
| [`no-
|
|
89
|
-
| [`no-
|
|
90
|
-
| [`no-
|
|
91
|
-
| [`no-
|
|
92
|
-
| [`no-
|
|
93
|
-
| [`no-
|
|
94
|
-
| [`no-
|
|
95
|
-
| [`
|
|
96
|
-
| [`
|
|
97
|
-
| [`
|
|
98
|
-
| [`
|
|
99
|
-
| [`
|
|
100
|
-
| [`
|
|
101
|
-
| [`
|
|
102
|
-
| [`
|
|
103
|
-
| [`
|
|
104
|
-
| [`
|
|
105
|
-
| [`
|
|
106
|
-
| [`
|
|
107
|
-
| [`
|
|
108
|
-
| [`
|
|
109
|
-
| [`
|
|
110
|
-
| [`
|
|
111
|
-
| [`
|
|
112
|
-
| [`
|
|
113
|
-
| [`
|
|
114
|
-
| [`
|
|
115
|
-
| [`
|
|
116
|
-
| [`
|
|
117
|
-
| [`
|
|
118
|
-
| [`
|
|
119
|
-
| [`
|
|
120
|
-
| [`
|
|
121
|
-
| [`
|
|
122
|
-
| [`
|
|
123
|
-
| [`require-
|
|
124
|
-
| [`require-
|
|
125
|
-
| [`require-
|
|
126
|
-
| [`require-
|
|
127
|
-
| [`
|
|
128
|
-
| [`
|
|
55
|
+
Fix legend:
|
|
56
|
+
|
|
57
|
+
- 🔧 = autofixable
|
|
58
|
+
- 💡 = suggestions available
|
|
59
|
+
- — = report only
|
|
60
|
+
|
|
61
|
+
Preset key legend:
|
|
62
|
+
|
|
63
|
+
- [🧩](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/action-metadata) — [`githubActions.configs.actionMetadata`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/action-metadata)
|
|
64
|
+
- [🔎](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/code-scanning) — [`githubActions.configs.codeScanning`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/code-scanning)
|
|
65
|
+
- [🤖](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/dependabot) — [`githubActions.configs.dependabot`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/dependabot)
|
|
66
|
+
- [🗂️](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/workflow-template-properties) — [`githubActions.configs.workflowTemplateProperties`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/workflow-template-properties)
|
|
67
|
+
- [🧱](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/workflow-templates) — [`githubActions.configs.workflowTemplates`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/workflow-templates)
|
|
68
|
+
- [🟡](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/recommended) — [`githubActions.configs.recommended`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/recommended)
|
|
69
|
+
- [🛡️](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/security) — [`githubActions.configs.security`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/security)
|
|
70
|
+
- [🔴](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/strict) — [`githubActions.configs.strict`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/strict)
|
|
71
|
+
- [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) — [`githubActions.configs.all`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all)
|
|
72
|
+
|
|
73
|
+
| Rule | Fix | Preset key |
|
|
74
|
+
| --- | :-: | --- |
|
|
75
|
+
| <span class="sb-inline-rule-number">R009</span> [`action-name-casing`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/action-name-casing) | 🔧 | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🔴](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/strict) |
|
|
76
|
+
| <span class="sb-inline-rule-number">R010</span> [`job-id-casing`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/job-id-casing) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🔴](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/strict) |
|
|
77
|
+
| <span class="sb-inline-rule-number">R011</span> [`max-jobs-per-action`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/max-jobs-per-action) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🔴](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/strict) |
|
|
78
|
+
| <span class="sb-inline-rule-number">R048</span> [`no-case-insensitive-input-id-collision`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-case-insensitive-input-id-collision) | — | [🧩](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/action-metadata) [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) |
|
|
79
|
+
| <span class="sb-inline-rule-number">R097</span> [`no-codeql-autobuild-for-javascript-typescript`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-codeql-autobuild-for-javascript-typescript) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🔎](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/code-scanning) |
|
|
80
|
+
| <span class="sb-inline-rule-number">R096</span> [`no-codeql-javascript-typescript-split-language-matrix`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-codeql-javascript-typescript-split-language-matrix) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🔎](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/code-scanning) |
|
|
81
|
+
| <span class="sb-inline-rule-number">R049</span> [`no-composite-input-env-access`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-composite-input-env-access) | — | [🧩](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/action-metadata) [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) |
|
|
82
|
+
| <span class="sb-inline-rule-number">R044</span> [`no-deprecated-node-runtime`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-deprecated-node-runtime) | — | [🧩](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/action-metadata) [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) |
|
|
83
|
+
| <span class="sb-inline-rule-number">R051</span> [`no-duplicate-composite-step-id`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-duplicate-composite-step-id) | — | [🧩](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/action-metadata) [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) |
|
|
84
|
+
| <span class="sb-inline-rule-number">R060</span> [`no-empty-template-file-pattern`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-empty-template-file-pattern) | 🔧 | [🗂️](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/workflow-template-properties) [🧱](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/workflow-templates) [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) |
|
|
85
|
+
| <span class="sb-inline-rule-number">R012</span> [`no-external-job`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-external-job) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🔴](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/strict) |
|
|
86
|
+
| <span class="sb-inline-rule-number">R068</span> [`no-hardcoded-default-branch-in-template`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-hardcoded-default-branch-in-template) | — | [🧱](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/workflow-templates) [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) |
|
|
87
|
+
| <span class="sb-inline-rule-number">R063</span> [`no-icon-file-extension-in-template-icon-name`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-icon-file-extension-in-template-icon-name) | 🔧 | [🗂️](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/workflow-template-properties) [🧱](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/workflow-templates) [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) |
|
|
88
|
+
| <span class="sb-inline-rule-number">R026</span> [`no-inherit-secrets`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-inherit-secrets) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🛡️](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/security) [🔴](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/strict) |
|
|
89
|
+
| <span class="sb-inline-rule-number">R042</span> [`no-invalid-concurrency-context`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-invalid-concurrency-context) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🟡](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/recommended) [🔴](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/strict) |
|
|
90
|
+
| <span class="sb-inline-rule-number">R019</span> [`no-invalid-key`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-invalid-key) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🟡](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/recommended) [🔴](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/strict) |
|
|
91
|
+
| <span class="sb-inline-rule-number">R041</span> [`no-invalid-reusable-workflow-job-key`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-invalid-reusable-workflow-job-key) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🟡](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/recommended) [🔴](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/strict) |
|
|
92
|
+
| <span class="sb-inline-rule-number">R059</span> [`no-invalid-template-file-pattern-regex`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-invalid-template-file-pattern-regex) | — | [🗂️](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/workflow-template-properties) [🧱](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/workflow-templates) [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) |
|
|
93
|
+
| <span class="sb-inline-rule-number">R040</span> [`no-invalid-workflow-call-output-value`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-invalid-workflow-call-output-value) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🟡](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/recommended) [🔴](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/strict) |
|
|
94
|
+
| <span class="sb-inline-rule-number">R095</span> [`no-overlapping-dependabot-directories`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-overlapping-dependabot-directories) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🤖](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/dependabot) |
|
|
95
|
+
| <span class="sb-inline-rule-number">R064</span> [`no-path-separators-in-template-icon-name`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-path-separators-in-template-icon-name) | 💡 | [🗂️](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/workflow-template-properties) [🧱](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/workflow-templates) [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) |
|
|
96
|
+
| <span class="sb-inline-rule-number">R046</span> [`no-post-if-without-post`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-post-if-without-post) | 🔧 | [🧩](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/action-metadata) [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) |
|
|
97
|
+
| <span class="sb-inline-rule-number">R030</span> [`no-pr-head-checkout-in-pull-request-target`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-pr-head-checkout-in-pull-request-target) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🛡️](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/security) [🔴](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/strict) |
|
|
98
|
+
| <span class="sb-inline-rule-number">R045</span> [`no-pre-if-without-pre`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-pre-if-without-pre) | 🔧 | [🧩](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/action-metadata) [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) |
|
|
99
|
+
| <span class="sb-inline-rule-number">R047</span> [`no-required-input-with-default`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-required-input-with-default) | 💡 | [🧩](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/action-metadata) [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) |
|
|
100
|
+
| <span class="sb-inline-rule-number">R027</span> [`no-secrets-in-if`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-secrets-in-if) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🟡](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/recommended) [🛡️](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/security) [🔴](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/strict) |
|
|
101
|
+
| <span class="sb-inline-rule-number">R036</span> [`no-self-hosted-runner-on-fork-pr-events`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-self-hosted-runner-on-fork-pr-events) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🛡️](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/security) [🔴](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/strict) |
|
|
102
|
+
| <span class="sb-inline-rule-number">R062</span> [`no-subdirectory-template-file-pattern`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-subdirectory-template-file-pattern) | — | [🗂️](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/workflow-template-properties) [🧱](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/workflow-templates) [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) |
|
|
103
|
+
| <span class="sb-inline-rule-number">R069</span> [`no-template-placeholder-in-non-template-workflow`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-template-placeholder-in-non-template-workflow) | — | [🟡](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/recommended) [🔴](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/strict) [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) |
|
|
104
|
+
| <span class="sb-inline-rule-number">R013</span> [`no-top-level-env`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-top-level-env) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🔴](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/strict) |
|
|
105
|
+
| <span class="sb-inline-rule-number">R014</span> [`no-top-level-permissions`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-top-level-permissions) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) |
|
|
106
|
+
| <span class="sb-inline-rule-number">R061</span> [`no-universal-template-file-pattern`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-universal-template-file-pattern) | — | [🗂️](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/workflow-template-properties) [🧱](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/workflow-templates) [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) |
|
|
107
|
+
| <span class="sb-inline-rule-number">R081</span> [`no-unknown-dependabot-multi-ecosystem-group`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-unknown-dependabot-multi-ecosystem-group) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🤖](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/dependabot) |
|
|
108
|
+
| <span class="sb-inline-rule-number">R050</span> [`no-unknown-input-reference-in-composite`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-unknown-input-reference-in-composite) | — | [🧩](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/action-metadata) [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) |
|
|
109
|
+
| <span class="sb-inline-rule-number">R037</span> [`no-unknown-job-output-reference`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-unknown-job-output-reference) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🟡](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/recommended) [🔴](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/strict) |
|
|
110
|
+
| <span class="sb-inline-rule-number">R038</span> [`no-unknown-step-reference`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-unknown-step-reference) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🔴](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/strict) |
|
|
111
|
+
| <span class="sb-inline-rule-number">R029</span> [`no-untrusted-input-in-run`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-untrusted-input-in-run) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🛡️](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/security) [🔴](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/strict) |
|
|
112
|
+
| <span class="sb-inline-rule-number">R085</span> [`no-unused-dependabot-enable-beta-ecosystems`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-unused-dependabot-enable-beta-ecosystems) | 🔧 | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🤖](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/dependabot) |
|
|
113
|
+
| <span class="sb-inline-rule-number">R053</span> [`no-unused-input-in-composite`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-unused-input-in-composite) | — | [🧩](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/action-metadata) [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) |
|
|
114
|
+
| <span class="sb-inline-rule-number">R023</span> [`no-write-all-permissions`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-write-all-permissions) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🟡](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/recommended) [🛡️](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/security) [🔴](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/strict) |
|
|
115
|
+
| <span class="sb-inline-rule-number">R003</span> [`pin-action-shas`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/pin-action-shas) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🛡️](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/security) [🔴](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/strict) |
|
|
116
|
+
| <span class="sb-inline-rule-number">R043</span> [`prefer-action-yml`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/prefer-action-yml) | — | [🧩](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/action-metadata) [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) |
|
|
117
|
+
| <span class="sb-inline-rule-number">R015</span> [`prefer-fail-fast`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/prefer-fail-fast) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🔴](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/strict) |
|
|
118
|
+
| <span class="sb-inline-rule-number">R020</span> [`prefer-file-extension`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/prefer-file-extension) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🟡](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/recommended) [🔴](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/strict) |
|
|
119
|
+
| <span class="sb-inline-rule-number">R033</span> [`prefer-inputs-context`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/prefer-inputs-context) | 🔧 | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🟡](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/recommended) [🔴](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/strict) |
|
|
120
|
+
| <span class="sb-inline-rule-number">R016</span> [`prefer-step-uses-style`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/prefer-step-uses-style) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) |
|
|
121
|
+
| <span class="sb-inline-rule-number">R066</span> [`prefer-template-yml-extension`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/prefer-template-yml-extension) | — | [🧱](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/workflow-templates) [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) |
|
|
122
|
+
| <span class="sb-inline-rule-number">R005</span> [`require-action-name`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-action-name) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🟡](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/recommended) [🔴](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/strict) |
|
|
123
|
+
| <span class="sb-inline-rule-number">R006</span> [`require-action-run-name`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-action-run-name) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🔴](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/strict) |
|
|
124
|
+
| <span class="sb-inline-rule-number">R025</span> [`require-checkout-before-local-action`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-checkout-before-local-action) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🟡](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/recommended) [🔴](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/strict) |
|
|
125
|
+
| <span class="sb-inline-rule-number">R099</span> [`require-codeql-actions-read`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-codeql-actions-read) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🔎](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/code-scanning) |
|
|
126
|
+
| <span class="sb-inline-rule-number">R113</span> [`require-codeql-branch-filters`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-codeql-branch-filters) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🔎](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/code-scanning) |
|
|
127
|
+
| <span class="sb-inline-rule-number">R114</span> [`require-codeql-category-when-language-matrix`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-codeql-category-when-language-matrix) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🔎](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/code-scanning) |
|
|
128
|
+
| <span class="sb-inline-rule-number">R100</span> [`require-codeql-pull-request-trigger`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-codeql-pull-request-trigger) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🔎](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/code-scanning) |
|
|
129
|
+
| <span class="sb-inline-rule-number">R101</span> [`require-codeql-schedule`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-codeql-schedule) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🔎](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/code-scanning) |
|
|
130
|
+
| <span class="sb-inline-rule-number">R098</span> [`require-codeql-security-events-write`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-codeql-security-events-write) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🔎](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/code-scanning) [🛡️](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/security) |
|
|
131
|
+
| <span class="sb-inline-rule-number">R052</span> [`require-composite-step-name`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-composite-step-name) | — | [🧩](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/action-metadata) [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) |
|
|
132
|
+
| <span class="sb-inline-rule-number">R077</span> [`require-dependabot-assignees`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-dependabot-assignees) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🤖](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/dependabot) |
|
|
133
|
+
| <span class="sb-inline-rule-number">R111</span> [`require-dependabot-automation-permissions`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-dependabot-automation-permissions) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🛡️](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/security) |
|
|
134
|
+
| <span class="sb-inline-rule-number">R112</span> [`require-dependabot-automation-pull-request-trigger`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-dependabot-automation-pull-request-trigger) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🛡️](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/security) |
|
|
135
|
+
| <span class="sb-inline-rule-number">R109</span> [`require-dependabot-bot-actor-guard`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-dependabot-bot-actor-guard) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🛡️](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/security) |
|
|
136
|
+
| <span class="sb-inline-rule-number">R089</span> [`require-dependabot-commit-message-include-scope`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-dependabot-commit-message-include-scope) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🤖](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/dependabot) |
|
|
137
|
+
| <span class="sb-inline-rule-number">R079</span> [`require-dependabot-commit-message-prefix`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-dependabot-commit-message-prefix) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🤖](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/dependabot) |
|
|
138
|
+
| <span class="sb-inline-rule-number">R090</span> [`require-dependabot-commit-message-prefix-development`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-dependabot-commit-message-prefix-development) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🤖](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/dependabot) |
|
|
139
|
+
| <span class="sb-inline-rule-number">R086</span> [`require-dependabot-cooldown`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-dependabot-cooldown) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🤖](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/dependabot) |
|
|
140
|
+
| <span class="sb-inline-rule-number">R073</span> [`require-dependabot-directory`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-dependabot-directory) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🤖](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/dependabot) |
|
|
141
|
+
| <span class="sb-inline-rule-number">R084</span> [`require-dependabot-github-actions-directory-root`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-dependabot-github-actions-directory-root) | 🔧 | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🤖](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/dependabot) |
|
|
142
|
+
| <span class="sb-inline-rule-number">R080</span> [`require-dependabot-labels`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-dependabot-labels) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🤖](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/dependabot) |
|
|
143
|
+
| <span class="sb-inline-rule-number">R087</span> [`require-dependabot-open-pull-requests-limit`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-dependabot-open-pull-requests-limit) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🤖](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/dependabot) |
|
|
144
|
+
| <span class="sb-inline-rule-number">R072</span> [`require-dependabot-package-ecosystem`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-dependabot-package-ecosystem) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🤖](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/dependabot) |
|
|
145
|
+
| <span class="sb-inline-rule-number">R082</span> [`require-dependabot-patterns-for-multi-ecosystem-group`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-dependabot-patterns-for-multi-ecosystem-group) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🤖](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/dependabot) |
|
|
146
|
+
| <span class="sb-inline-rule-number">R083</span> [`require-dependabot-schedule-cronjob`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-dependabot-schedule-cronjob) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🤖](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/dependabot) |
|
|
147
|
+
| <span class="sb-inline-rule-number">R074</span> [`require-dependabot-schedule-interval`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-dependabot-schedule-interval) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🤖](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/dependabot) |
|
|
148
|
+
| <span class="sb-inline-rule-number">R075</span> [`require-dependabot-schedule-time`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-dependabot-schedule-time) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🤖](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/dependabot) |
|
|
149
|
+
| <span class="sb-inline-rule-number">R076</span> [`require-dependabot-schedule-timezone`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-dependabot-schedule-timezone) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🤖](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/dependabot) |
|
|
150
|
+
| <span class="sb-inline-rule-number">R078</span> [`require-dependabot-target-branch`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-dependabot-target-branch) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🤖](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/dependabot) |
|
|
151
|
+
| <span class="sb-inline-rule-number">R071</span> [`require-dependabot-updates`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-dependabot-updates) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🤖](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/dependabot) |
|
|
152
|
+
| <span class="sb-inline-rule-number">R070</span> [`require-dependabot-version`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-dependabot-version) | 🔧 | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🤖](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/dependabot) |
|
|
153
|
+
| <span class="sb-inline-rule-number">R088</span> [`require-dependabot-versioning-strategy-for-npm`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-dependabot-versioning-strategy-for-npm) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🤖](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/dependabot) |
|
|
154
|
+
| <span class="sb-inline-rule-number">R091</span> [`require-dependency-review-action`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-dependency-review-action) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🔎](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/code-scanning) [🛡️](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/security) |
|
|
155
|
+
| <span class="sb-inline-rule-number">R093</span> [`require-dependency-review-fail-on-severity`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-dependency-review-fail-on-severity) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🔎](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/code-scanning) [🛡️](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/security) |
|
|
156
|
+
| <span class="sb-inline-rule-number">R092</span> [`require-dependency-review-permissions-contents-read`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-dependency-review-permissions-contents-read) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🔎](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/code-scanning) [🛡️](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/security) |
|
|
157
|
+
| <span class="sb-inline-rule-number">R094</span> [`require-dependency-review-pull-request-trigger`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-dependency-review-pull-request-trigger) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🔎](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/code-scanning) [🛡️](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/security) |
|
|
158
|
+
| <span class="sb-inline-rule-number">R110</span> [`require-fetch-metadata-github-token`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-fetch-metadata-github-token) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🛡️](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/security) |
|
|
159
|
+
| <span class="sb-inline-rule-number">R007</span> [`require-job-name`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-job-name) | 💡 | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🔴](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/strict) |
|
|
160
|
+
| <span class="sb-inline-rule-number">R008</span> [`require-job-step-name`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-job-step-name) | 💡 | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🔴](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/strict) |
|
|
161
|
+
| <span class="sb-inline-rule-number">R002</span> [`require-job-timeout-minutes`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-job-timeout-minutes) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🟡](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/recommended) [🔴](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/strict) |
|
|
162
|
+
| <span class="sb-inline-rule-number">R035</span> [`require-merge-group-trigger`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-merge-group-trigger) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🔴](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/strict) |
|
|
163
|
+
| <span class="sb-inline-rule-number">R032</span> [`require-pull-request-target-branches`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-pull-request-target-branches) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🛡️](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/security) [🔴](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/strict) |
|
|
164
|
+
| <span class="sb-inline-rule-number">R021</span> [`require-run-step-shell`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-run-step-shell) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🔴](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/strict) |
|
|
165
|
+
| <span class="sb-inline-rule-number">R102</span> [`require-sarif-upload-security-events-write`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-sarif-upload-security-events-write) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🔎](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/code-scanning) [🛡️](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/security) |
|
|
166
|
+
| <span class="sb-inline-rule-number">R103</span> [`require-scorecard-results-format-sarif`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-scorecard-results-format-sarif) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🔎](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/code-scanning) |
|
|
167
|
+
| <span class="sb-inline-rule-number">R104</span> [`require-scorecard-upload-sarif-step`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-scorecard-upload-sarif-step) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🔎](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/code-scanning) |
|
|
168
|
+
| <span class="sb-inline-rule-number">R107</span> [`require-secret-scan-contents-read`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-secret-scan-contents-read) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🛡️](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/security) |
|
|
169
|
+
| <span class="sb-inline-rule-number">R105</span> [`require-secret-scan-fetch-depth-zero`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-secret-scan-fetch-depth-zero) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🛡️](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/security) |
|
|
170
|
+
| <span class="sb-inline-rule-number">R106</span> [`require-secret-scan-schedule`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-secret-scan-schedule) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🛡️](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/security) |
|
|
171
|
+
| <span class="sb-inline-rule-number">R057</span> [`require-template-categories`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-template-categories) | — | [🗂️](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/workflow-template-properties) [🧱](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/workflow-templates) [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) |
|
|
172
|
+
| <span class="sb-inline-rule-number">R058</span> [`require-template-file-patterns`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-template-file-patterns) | — | [🗂️](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/workflow-template-properties) [🧱](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/workflow-templates) [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) |
|
|
173
|
+
| <span class="sb-inline-rule-number">R065</span> [`require-template-icon-file-exists`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-template-icon-file-exists) | — | [🗂️](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/workflow-template-properties) [🧱](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/workflow-templates) [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) |
|
|
174
|
+
| <span class="sb-inline-rule-number">R056</span> [`require-template-icon-name`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-template-icon-name) | — | [🗂️](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/workflow-template-properties) [🧱](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/workflow-templates) [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) |
|
|
175
|
+
| <span class="sb-inline-rule-number">R067</span> [`require-template-workflow-name`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-template-workflow-name) | — | [🧱](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/workflow-templates) [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) |
|
|
176
|
+
| <span class="sb-inline-rule-number">R031</span> [`require-trigger-types`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-trigger-types) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🔴](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/strict) |
|
|
177
|
+
| <span class="sb-inline-rule-number">R108</span> [`require-trufflehog-verified-results-mode`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-trufflehog-verified-results-mode) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🛡️](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/security) |
|
|
178
|
+
| <span class="sb-inline-rule-number">R034</span> [`require-workflow-call-input-type`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-workflow-call-input-type) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🟡](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/recommended) [🔴](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/strict) |
|
|
179
|
+
| <span class="sb-inline-rule-number">R039</span> [`require-workflow-call-output-value`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-workflow-call-output-value) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🟡](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/recommended) [🔴](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/strict) |
|
|
180
|
+
| <span class="sb-inline-rule-number">R004</span> [`require-workflow-concurrency`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-workflow-concurrency) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🔴](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/strict) |
|
|
181
|
+
| <span class="sb-inline-rule-number">R022</span> [`require-workflow-dispatch-input-type`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-workflow-dispatch-input-type) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🟡](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/recommended) [🔴](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/strict) |
|
|
182
|
+
| <span class="sb-inline-rule-number">R024</span> [`require-workflow-interface-description`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-workflow-interface-description) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🔴](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/strict) |
|
|
183
|
+
| <span class="sb-inline-rule-number">R001</span> [`require-workflow-permissions`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-workflow-permissions) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🟡](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/recommended) [🛡️](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/security) [🔴](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/strict) |
|
|
184
|
+
| <span class="sb-inline-rule-number">R028</span> [`require-workflow-run-branches`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-workflow-run-branches) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🛡️](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/security) [🔴](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/strict) |
|
|
185
|
+
| <span class="sb-inline-rule-number">R054</span> [`require-workflow-template-pair`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-workflow-template-pair) | — | [🧱](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/workflow-templates) [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) |
|
|
186
|
+
| <span class="sb-inline-rule-number">R055</span> [`require-workflow-template-properties-pair`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-workflow-template-properties-pair) | — | [🗂️](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/workflow-template-properties) [🧱](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/workflow-templates) [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) |
|
|
187
|
+
| <span class="sb-inline-rule-number">R017</span> [`valid-timeout-minutes`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/valid-timeout-minutes) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🟡](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/recommended) [🔴](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/strict) |
|
|
188
|
+
| <span class="sb-inline-rule-number">R018</span> [`valid-trigger-events`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/valid-trigger-events) | — | [🟣](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/all) [🟡](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/recommended) [🔴](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/presets/strict) |
|
|
129
189
|
|
|
130
190
|
## Example
|
|
131
191
|
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @packageDocumentation
|
|
3
|
+
* Helpers for CodeQL, SARIF, and code-scanning related workflows.
|
|
4
|
+
*/
|
|
5
|
+
import type { AST } from "yaml-eslint-parser";
|
|
6
|
+
import type { WorkflowActionStep } from "./workflow-action-steps.js";
|
|
7
|
+
/** Determine whether a `uses` reference points to the CodeQL init action. */
|
|
8
|
+
export declare const isCodeqlInitReference: (usesReference: string) => boolean;
|
|
9
|
+
/** Determine whether a `uses` reference points to the CodeQL analyze action. */
|
|
10
|
+
export declare const isCodeqlAnalyzeReference: (usesReference: string) => boolean;
|
|
11
|
+
/** Determine whether a `uses` reference points to the CodeQL autobuild action. */
|
|
12
|
+
export declare const isCodeqlAutobuildReference: (usesReference: string) => boolean;
|
|
13
|
+
/**
|
|
14
|
+
* Determine whether a `uses` reference points to the CodeQL SARIF upload
|
|
15
|
+
* action.
|
|
16
|
+
*/
|
|
17
|
+
export declare const isSarifUploadReference: (usesReference: string) => boolean;
|
|
18
|
+
/** Determine whether a `uses` reference points to the Scorecard action. */
|
|
19
|
+
export declare const isScorecardActionReference: (usesReference: string) => boolean;
|
|
20
|
+
/** Collect all CodeQL init steps in a workflow. */
|
|
21
|
+
export declare const getCodeqlInitSteps: (root: AST.YAMLMapping) => readonly WorkflowActionStep[];
|
|
22
|
+
/** Collect all CodeQL analyze steps in a workflow. */
|
|
23
|
+
export declare const getCodeqlAnalyzeSteps: (root: AST.YAMLMapping) => readonly WorkflowActionStep[];
|
|
24
|
+
/** Collect all CodeQL autobuild steps in a workflow. */
|
|
25
|
+
export declare const getCodeqlAutobuildSteps: (root: AST.YAMLMapping) => readonly WorkflowActionStep[];
|
|
26
|
+
/** Collect all CodeQL SARIF upload steps in a workflow. */
|
|
27
|
+
export declare const getSarifUploadSteps: (root: AST.YAMLMapping) => readonly WorkflowActionStep[];
|
|
28
|
+
/** Collect all Scorecard action steps in a workflow. */
|
|
29
|
+
export declare const getScorecardSteps: (root: AST.YAMLMapping) => readonly WorkflowActionStep[];
|
|
30
|
+
/**
|
|
31
|
+
* Resolve literal language values used by a CodeQL init step when statically
|
|
32
|
+
* knowable.
|
|
33
|
+
*/
|
|
34
|
+
export declare const getCodeqlLanguageValues: (step: WorkflowActionStep) => readonly string[];
|
|
35
|
+
/** Determine whether all statically resolved CodeQL languages are JS/TS aliases. */
|
|
36
|
+
export declare const codeqlLanguagesAreOnlyJavaScriptTypeScript: (languages: readonly string[]) => boolean;
|
|
37
|
+
//# sourceMappingURL=code-scanning-workflow.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"code-scanning-workflow.d.ts","sourceRoot":"","sources":["../../src/_internal/code-scanning-workflow.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,oBAAoB,CAAC;AAE9C,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,4BAA4B,CAAC;AAyBrE,6EAA6E;AAC7E,eAAO,MAAM,qBAAqB,GAAI,eAAe,MAAM,KAAG,OACZ,CAAC;AAEnD,gFAAgF;AAChF,eAAO,MAAM,wBAAwB,GAAI,eAAe,MAAM,KAAG,OACZ,CAAC;AAEtD,kFAAkF;AAClF,eAAO,MAAM,0BAA0B,GAAI,eAAe,MAAM,KAAG,OACZ,CAAC;AAExD;;;GAGG;AACH,eAAO,MAAM,sBAAsB,GAAI,eAAe,MAAM,KAAG,OACL,CAAC;AAE3D,2EAA2E;AAC3E,eAAO,MAAM,0BAA0B,GAAI,eAAe,MAAM,KAAG,OACN,CAAC;AAE9D,mDAAmD;AACnD,eAAO,MAAM,kBAAkB,GAC3B,MAAM,GAAG,CAAC,WAAW,KACtB,SAAS,kBAAkB,EACyB,CAAC;AAExD,sDAAsD;AACtD,eAAO,MAAM,qBAAqB,GAC9B,MAAM,GAAG,CAAC,WAAW,KACtB,SAAS,kBAAkB,EAC4B,CAAC;AAE3D,wDAAwD;AACxD,eAAO,MAAM,uBAAuB,GAChC,MAAM,GAAG,CAAC,WAAW,KACtB,SAAS,kBAAkB,EAC8B,CAAC;AAE7D,2DAA2D;AAC3D,eAAO,MAAM,mBAAmB,GAC5B,MAAM,GAAG,CAAC,WAAW,KACtB,SAAS,kBAAkB,EAC0B,CAAC;AAEzD,wDAAwD;AACxD,eAAO,MAAM,iBAAiB,GAC1B,MAAM,GAAG,CAAC,WAAW,KACtB,SAAS,kBAAkB,EAC8B,CAAC;AAE7D;;;GAGG;AACH,eAAO,MAAM,uBAAuB,GAChC,MAAM,kBAAkB,KACzB,SAAS,MAAM,EAyDjB,CAAC;AAEF,oFAAoF;AACpF,eAAO,MAAM,0CAA0C,GACnD,WAAW,SAAS,MAAM,EAAE,KAC7B,OAEmE,CAAC"}
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
import { getWorkflowActionSteps } from "./workflow-action-steps.js";
|
|
2
|
+
import { getMappingPair, getMappingValueAsMapping, getMappingValueAsSequence, getScalarStringValue, } from "./workflow-yaml.js";
|
|
3
|
+
const codeqlLanguageAliases = new Set([
|
|
4
|
+
"javascript",
|
|
5
|
+
"javascript-typescript",
|
|
6
|
+
"typescript",
|
|
7
|
+
]);
|
|
8
|
+
const matrixLanguageExpression = `\${{ matrix.language }}`;
|
|
9
|
+
/** Determine whether a `uses` reference points to a specific CodeQL action step. */
|
|
10
|
+
const isCodeqlActionReference = (usesReference, actionName) => usesReference.trim().startsWith(`github/codeql-action/${actionName}@`);
|
|
11
|
+
/** Determine whether a `uses` reference points to the CodeQL init action. */
|
|
12
|
+
export const isCodeqlInitReference = (usesReference) => isCodeqlActionReference(usesReference, "init");
|
|
13
|
+
/** Determine whether a `uses` reference points to the CodeQL analyze action. */
|
|
14
|
+
export const isCodeqlAnalyzeReference = (usesReference) => isCodeqlActionReference(usesReference, "analyze");
|
|
15
|
+
/** Determine whether a `uses` reference points to the CodeQL autobuild action. */
|
|
16
|
+
export const isCodeqlAutobuildReference = (usesReference) => isCodeqlActionReference(usesReference, "autobuild");
|
|
17
|
+
/**
|
|
18
|
+
* Determine whether a `uses` reference points to the CodeQL SARIF upload
|
|
19
|
+
* action.
|
|
20
|
+
*/
|
|
21
|
+
export const isSarifUploadReference = (usesReference) => isCodeqlActionReference(usesReference, "upload-sarif");
|
|
22
|
+
/** Determine whether a `uses` reference points to the Scorecard action. */
|
|
23
|
+
export const isScorecardActionReference = (usesReference) => usesReference.trim().startsWith("ossf/scorecard-action@");
|
|
24
|
+
/** Collect all CodeQL init steps in a workflow. */
|
|
25
|
+
export const getCodeqlInitSteps = (root) => getWorkflowActionSteps(root, isCodeqlInitReference);
|
|
26
|
+
/** Collect all CodeQL analyze steps in a workflow. */
|
|
27
|
+
export const getCodeqlAnalyzeSteps = (root) => getWorkflowActionSteps(root, isCodeqlAnalyzeReference);
|
|
28
|
+
/** Collect all CodeQL autobuild steps in a workflow. */
|
|
29
|
+
export const getCodeqlAutobuildSteps = (root) => getWorkflowActionSteps(root, isCodeqlAutobuildReference);
|
|
30
|
+
/** Collect all CodeQL SARIF upload steps in a workflow. */
|
|
31
|
+
export const getSarifUploadSteps = (root) => getWorkflowActionSteps(root, isSarifUploadReference);
|
|
32
|
+
/** Collect all Scorecard action steps in a workflow. */
|
|
33
|
+
export const getScorecardSteps = (root) => getWorkflowActionSteps(root, isScorecardActionReference);
|
|
34
|
+
/**
|
|
35
|
+
* Resolve literal language values used by a CodeQL init step when statically
|
|
36
|
+
* knowable.
|
|
37
|
+
*/
|
|
38
|
+
export const getCodeqlLanguageValues = (step) => {
|
|
39
|
+
const languagesMappingValue = getScalarStringValue(getMappingPair(getMappingValueAsMapping(step.stepMapping, "with") ??
|
|
40
|
+
step.stepMapping, "languages")?.value ?? null)?.trim();
|
|
41
|
+
if (languagesMappingValue === undefined ||
|
|
42
|
+
languagesMappingValue.length === 0) {
|
|
43
|
+
return [];
|
|
44
|
+
}
|
|
45
|
+
if (languagesMappingValue === matrixLanguageExpression) {
|
|
46
|
+
const strategyMapping = getMappingValueAsMapping(step.job.mapping, "strategy");
|
|
47
|
+
const matrixMapping = strategyMapping === null
|
|
48
|
+
? null
|
|
49
|
+
: getMappingValueAsMapping(strategyMapping, "matrix");
|
|
50
|
+
if (matrixMapping === null) {
|
|
51
|
+
return [];
|
|
52
|
+
}
|
|
53
|
+
const languageSequence = getMappingValueAsSequence(matrixMapping, "language");
|
|
54
|
+
if (languageSequence !== null) {
|
|
55
|
+
return languageSequence.entries
|
|
56
|
+
.map((entry) => getScalarStringValue(entry)?.trim() ?? null)
|
|
57
|
+
.filter((value) => value !== null && value.length > 0);
|
|
58
|
+
}
|
|
59
|
+
const singleLanguage = getScalarStringValue(getMappingPair(matrixMapping, "language")?.value ?? null)?.trim();
|
|
60
|
+
return singleLanguage === undefined || singleLanguage.length === 0
|
|
61
|
+
? []
|
|
62
|
+
: [singleLanguage];
|
|
63
|
+
}
|
|
64
|
+
return languagesMappingValue
|
|
65
|
+
.split(",")
|
|
66
|
+
.map((value) => value.trim())
|
|
67
|
+
.filter((value) => value.length > 0);
|
|
68
|
+
};
|
|
69
|
+
/** Determine whether all statically resolved CodeQL languages are JS/TS aliases. */
|
|
70
|
+
export const codeqlLanguagesAreOnlyJavaScriptTypeScript = (languages) => languages.length > 0 &&
|
|
71
|
+
languages.every((language) => codeqlLanguageAliases.has(language));
|
|
72
|
+
/* eslint-enable @typescript-eslint/prefer-readonly-parameter-types -- Re-enable readonly-parameter checks outside parser AST helper signatures. */
|
|
73
|
+
//# sourceMappingURL=code-scanning-workflow.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"code-scanning-workflow.js","sourceRoot":"","sources":["../../src/_internal/code-scanning-workflow.ts"],"names":[],"mappings":"AASA,OAAO,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAC;AACpE,OAAO,EACH,cAAc,EACd,wBAAwB,EACxB,yBAAyB,EACzB,oBAAoB,GACvB,MAAM,oBAAoB,CAAC;AAE5B,MAAM,qBAAqB,GAAG,IAAI,GAAG,CAAC;IAClC,YAAY;IACZ,uBAAuB;IACvB,YAAY;CACf,CAAC,CAAC;AAEH,MAAM,wBAAwB,GAAG,yBAAyB,CAAC;AAE3D,oFAAoF;AACpF,MAAM,uBAAuB,GAAG,CAC5B,aAAqB,EACrB,UAAkB,EACX,EAAE,CACT,aAAa,CAAC,IAAI,EAAE,CAAC,UAAU,CAAC,wBAAwB,UAAU,GAAG,CAAC,CAAC;AAE3E,6EAA6E;AAC7E,MAAM,CAAC,MAAM,qBAAqB,GAAG,CAAC,aAAqB,EAAW,EAAE,CACpE,uBAAuB,CAAC,aAAa,EAAE,MAAM,CAAC,CAAC;AAEnD,gFAAgF;AAChF,MAAM,CAAC,MAAM,wBAAwB,GAAG,CAAC,aAAqB,EAAW,EAAE,CACvE,uBAAuB,CAAC,aAAa,EAAE,SAAS,CAAC,CAAC;AAEtD,kFAAkF;AAClF,MAAM,CAAC,MAAM,0BAA0B,GAAG,CAAC,aAAqB,EAAW,EAAE,CACzE,uBAAuB,CAAC,aAAa,EAAE,WAAW,CAAC,CAAC;AAExD;;;GAGG;AACH,MAAM,CAAC,MAAM,sBAAsB,GAAG,CAAC,aAAqB,EAAW,EAAE,CACrE,uBAAuB,CAAC,aAAa,EAAE,cAAc,CAAC,CAAC;AAE3D,2EAA2E;AAC3E,MAAM,CAAC,MAAM,0BAA0B,GAAG,CAAC,aAAqB,EAAW,EAAE,CACzE,aAAa,CAAC,IAAI,EAAE,CAAC,UAAU,CAAC,wBAAwB,CAAC,CAAC;AAE9D,mDAAmD;AACnD,MAAM,CAAC,MAAM,kBAAkB,GAAG,CAC9B,IAAqB,EACQ,EAAE,CAC/B,sBAAsB,CAAC,IAAI,EAAE,qBAAqB,CAAC,CAAC;AAExD,sDAAsD;AACtD,MAAM,CAAC,MAAM,qBAAqB,GAAG,CACjC,IAAqB,EACQ,EAAE,CAC/B,sBAAsB,CAAC,IAAI,EAAE,wBAAwB,CAAC,CAAC;AAE3D,wDAAwD;AACxD,MAAM,CAAC,MAAM,uBAAuB,GAAG,CACnC,IAAqB,EACQ,EAAE,CAC/B,sBAAsB,CAAC,IAAI,EAAE,0BAA0B,CAAC,CAAC;AAE7D,2DAA2D;AAC3D,MAAM,CAAC,MAAM,mBAAmB,GAAG,CAC/B,IAAqB,EACQ,EAAE,CAC/B,sBAAsB,CAAC,IAAI,EAAE,sBAAsB,CAAC,CAAC;AAEzD,wDAAwD;AACxD,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAC7B,IAAqB,EACQ,EAAE,CAC/B,sBAAsB,CAAC,IAAI,EAAE,0BAA0B,CAAC,CAAC;AAE7D;;;GAGG;AACH,MAAM,CAAC,MAAM,uBAAuB,GAAG,CACnC,IAAwB,EACP,EAAE;IACnB,MAAM,qBAAqB,GAAG,oBAAoB,CAC9C,cAAc,CACV,wBAAwB,CAAC,IAAI,CAAC,WAAW,EAAE,MAAM,CAAC;QAC9C,IAAI,CAAC,WAAW,EACpB,WAAW,CACd,EAAE,KAAK,IAAI,IAAI,CACnB,EAAE,IAAI,EAAE,CAAC;IAEV,IACI,qBAAqB,KAAK,SAAS;QACnC,qBAAqB,CAAC,MAAM,KAAK,CAAC,EACpC,CAAC;QACC,OAAO,EAAE,CAAC;IACd,CAAC;IAED,IAAI,qBAAqB,KAAK,wBAAwB,EAAE,CAAC;QACrD,MAAM,eAAe,GAAG,wBAAwB,CAC5C,IAAI,CAAC,GAAG,CAAC,OAAO,EAChB,UAAU,CACb,CAAC;QACF,MAAM,aAAa,GACf,eAAe,KAAK,IAAI;YACpB,CAAC,CAAC,IAAI;YACN,CAAC,CAAC,wBAAwB,CAAC,eAAe,EAAE,QAAQ,CAAC,CAAC;QAE9D,IAAI,aAAa,KAAK,IAAI,EAAE,CAAC;YACzB,OAAO,EAAE,CAAC;QACd,CAAC;QAED,MAAM,gBAAgB,GAAG,yBAAyB,CAC9C,aAAa,EACb,UAAU,CACb,CAAC;QAEF,IAAI,gBAAgB,KAAK,IAAI,EAAE,CAAC;YAC5B,OAAO,gBAAgB,CAAC,OAAO;iBAC1B,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,oBAAoB,CAAC,KAAK,CAAC,EAAE,IAAI,EAAE,IAAI,IAAI,CAAC;iBAC3D,MAAM,CACH,CAAC,KAAK,EAAmB,EAAE,CACvB,KAAK,KAAK,IAAI,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,CACzC,CAAC;QACV,CAAC;QAED,MAAM,cAAc,GAAG,oBAAoB,CACvC,cAAc,CAAC,aAAa,EAAE,UAAU,CAAC,EAAE,KAAK,IAAI,IAAI,CAC3D,EAAE,IAAI,EAAE,CAAC;QAEV,OAAO,cAAc,KAAK,SAAS,IAAI,cAAc,CAAC,MAAM,KAAK,CAAC;YAC9D,CAAC,CAAC,EAAE;YACJ,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC;IAC3B,CAAC;IAED,OAAO,qBAAqB;SACvB,KAAK,CAAC,GAAG,CAAC;SACV,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;SAC5B,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;AAC7C,CAAC,CAAC;AAEF,oFAAoF;AACpF,MAAM,CAAC,MAAM,0CAA0C,GAAG,CACtD,SAA4B,EACrB,EAAE,CACT,SAAS,CAAC,MAAM,GAAG,CAAC;IACpB,SAAS,CAAC,KAAK,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,qBAAqB,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC,CAAC;AAEvE,mJAAmJ"}
|