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.
Files changed (504) hide show
  1. package/README.md +155 -95
  2. package/dist/_internal/code-scanning-workflow.d.ts +37 -0
  3. package/dist/_internal/code-scanning-workflow.d.ts.map +1 -0
  4. package/dist/_internal/code-scanning-workflow.js +73 -0
  5. package/dist/_internal/code-scanning-workflow.js.map +1 -0
  6. package/dist/_internal/dependabot-automation-workflow.d.ts +26 -0
  7. package/dist/_internal/dependabot-automation-workflow.d.ts.map +1 -0
  8. package/dist/_internal/dependabot-automation-workflow.js +25 -0
  9. package/dist/_internal/dependabot-automation-workflow.js.map +1 -0
  10. package/dist/_internal/dependabot-yaml.d.ts +63 -0
  11. package/dist/_internal/dependabot-yaml.d.ts.map +1 -0
  12. package/dist/_internal/dependabot-yaml.js +139 -0
  13. package/dist/_internal/dependabot-yaml.js.map +1 -0
  14. package/dist/_internal/dependency-review-workflow.d.ts +20 -0
  15. package/dist/_internal/dependency-review-workflow.d.ts.map +1 -0
  16. package/dist/_internal/dependency-review-workflow.js +9 -0
  17. package/dist/_internal/dependency-review-workflow.js.map +1 -0
  18. package/dist/_internal/github-actions-config-references.d.ts +1 -1
  19. package/dist/_internal/github-actions-config-references.d.ts.map +1 -1
  20. package/dist/_internal/github-actions-config-references.js +19 -2
  21. package/dist/_internal/github-actions-config-references.js.map +1 -1
  22. package/dist/_internal/lint-targets.d.ts +8 -0
  23. package/dist/_internal/lint-targets.d.ts.map +1 -1
  24. package/dist/_internal/lint-targets.js +26 -0
  25. package/dist/_internal/lint-targets.js.map +1 -1
  26. package/dist/_internal/rules-registry.d.ts +90 -0
  27. package/dist/_internal/rules-registry.d.ts.map +1 -1
  28. package/dist/_internal/rules-registry.js +90 -0
  29. package/dist/_internal/rules-registry.js.map +1 -1
  30. package/dist/_internal/secret-scanning-workflow.d.ts +24 -0
  31. package/dist/_internal/secret-scanning-workflow.d.ts.map +1 -0
  32. package/dist/_internal/secret-scanning-workflow.js +21 -0
  33. package/dist/_internal/secret-scanning-workflow.js.map +1 -0
  34. package/dist/_internal/workflow-action-steps.d.ts +35 -0
  35. package/dist/_internal/workflow-action-steps.d.ts.map +1 -0
  36. package/dist/_internal/workflow-action-steps.js +75 -0
  37. package/dist/_internal/workflow-action-steps.js.map +1 -0
  38. package/dist/_internal/workflow-permissions.d.ts +11 -0
  39. package/dist/_internal/workflow-permissions.d.ts.map +1 -0
  40. package/dist/_internal/workflow-permissions.js +50 -0
  41. package/dist/_internal/workflow-permissions.js.map +1 -0
  42. package/dist/_internal/yaml-fixes.d.ts +13 -0
  43. package/dist/_internal/yaml-fixes.d.ts.map +1 -0
  44. package/dist/_internal/yaml-fixes.js +77 -0
  45. package/dist/_internal/yaml-fixes.js.map +1 -0
  46. package/dist/plugin.cjs +3526 -294
  47. package/dist/plugin.cjs.map +4 -4
  48. package/dist/plugin.d.ts.map +1 -1
  49. package/dist/plugin.js +2 -0
  50. package/dist/plugin.js.map +1 -1
  51. package/dist/rules/action-name-casing.d.ts.map +1 -1
  52. package/dist/rules/action-name-casing.js +3 -0
  53. package/dist/rules/action-name-casing.js.map +1 -1
  54. package/dist/rules/job-id-casing.d.ts.map +1 -1
  55. package/dist/rules/job-id-casing.js +3 -0
  56. package/dist/rules/job-id-casing.js.map +1 -1
  57. package/dist/rules/max-jobs-per-action.d.ts.map +1 -1
  58. package/dist/rules/max-jobs-per-action.js +3 -0
  59. package/dist/rules/max-jobs-per-action.js.map +1 -1
  60. package/dist/rules/no-case-insensitive-input-id-collision.d.ts.map +1 -1
  61. package/dist/rules/no-case-insensitive-input-id-collision.js +3 -0
  62. package/dist/rules/no-case-insensitive-input-id-collision.js.map +1 -1
  63. package/dist/rules/no-codeql-autobuild-for-javascript-typescript.d.ts +9 -0
  64. package/dist/rules/no-codeql-autobuild-for-javascript-typescript.d.ts.map +1 -0
  65. package/dist/rules/no-codeql-autobuild-for-javascript-typescript.js +54 -0
  66. package/dist/rules/no-codeql-autobuild-for-javascript-typescript.js.map +1 -0
  67. package/dist/rules/no-codeql-javascript-typescript-split-language-matrix.d.ts +9 -0
  68. package/dist/rules/no-codeql-javascript-typescript-split-language-matrix.d.ts.map +1 -0
  69. package/dist/rules/no-codeql-javascript-typescript-split-language-matrix.js +50 -0
  70. package/dist/rules/no-codeql-javascript-typescript-split-language-matrix.js.map +1 -0
  71. package/dist/rules/no-composite-input-env-access.d.ts.map +1 -1
  72. package/dist/rules/no-composite-input-env-access.js +3 -0
  73. package/dist/rules/no-composite-input-env-access.js.map +1 -1
  74. package/dist/rules/no-deprecated-node-runtime.d.ts.map +1 -1
  75. package/dist/rules/no-deprecated-node-runtime.js +3 -0
  76. package/dist/rules/no-deprecated-node-runtime.js.map +1 -1
  77. package/dist/rules/no-duplicate-composite-step-id.d.ts.map +1 -1
  78. package/dist/rules/no-duplicate-composite-step-id.js +3 -0
  79. package/dist/rules/no-duplicate-composite-step-id.js.map +1 -1
  80. package/dist/rules/no-empty-template-file-pattern.d.ts.map +1 -1
  81. package/dist/rules/no-empty-template-file-pattern.js +6 -0
  82. package/dist/rules/no-empty-template-file-pattern.js.map +1 -1
  83. package/dist/rules/no-external-job.d.ts.map +1 -1
  84. package/dist/rules/no-external-job.js +3 -0
  85. package/dist/rules/no-external-job.js.map +1 -1
  86. package/dist/rules/no-hardcoded-default-branch-in-template.d.ts.map +1 -1
  87. package/dist/rules/no-hardcoded-default-branch-in-template.js +3 -0
  88. package/dist/rules/no-hardcoded-default-branch-in-template.js.map +1 -1
  89. package/dist/rules/no-icon-file-extension-in-template-icon-name.d.ts.map +1 -1
  90. package/dist/rules/no-icon-file-extension-in-template-icon-name.js +13 -3
  91. package/dist/rules/no-icon-file-extension-in-template-icon-name.js.map +1 -1
  92. package/dist/rules/no-inherit-secrets.d.ts.map +1 -1
  93. package/dist/rules/no-inherit-secrets.js +3 -0
  94. package/dist/rules/no-inherit-secrets.js.map +1 -1
  95. package/dist/rules/no-invalid-concurrency-context.d.ts.map +1 -1
  96. package/dist/rules/no-invalid-concurrency-context.js +3 -0
  97. package/dist/rules/no-invalid-concurrency-context.js.map +1 -1
  98. package/dist/rules/no-invalid-key.d.ts.map +1 -1
  99. package/dist/rules/no-invalid-key.js +3 -0
  100. package/dist/rules/no-invalid-key.js.map +1 -1
  101. package/dist/rules/no-invalid-reusable-workflow-job-key.d.ts.map +1 -1
  102. package/dist/rules/no-invalid-reusable-workflow-job-key.js +3 -0
  103. package/dist/rules/no-invalid-reusable-workflow-job-key.js.map +1 -1
  104. package/dist/rules/no-invalid-template-file-pattern-regex.d.ts.map +1 -1
  105. package/dist/rules/no-invalid-template-file-pattern-regex.js +3 -0
  106. package/dist/rules/no-invalid-template-file-pattern-regex.js.map +1 -1
  107. package/dist/rules/no-invalid-workflow-call-output-value.d.ts.map +1 -1
  108. package/dist/rules/no-invalid-workflow-call-output-value.js +3 -0
  109. package/dist/rules/no-invalid-workflow-call-output-value.js.map +1 -1
  110. package/dist/rules/no-overlapping-dependabot-directories.d.ts +9 -0
  111. package/dist/rules/no-overlapping-dependabot-directories.d.ts.map +1 -0
  112. package/dist/rules/no-overlapping-dependabot-directories.js +151 -0
  113. package/dist/rules/no-overlapping-dependabot-directories.js.map +1 -0
  114. package/dist/rules/no-path-separators-in-template-icon-name.d.ts.map +1 -1
  115. package/dist/rules/no-path-separators-in-template-icon-name.js +26 -3
  116. package/dist/rules/no-path-separators-in-template-icon-name.js.map +1 -1
  117. package/dist/rules/no-post-if-without-post.d.ts.map +1 -1
  118. package/dist/rules/no-post-if-without-post.js +6 -0
  119. package/dist/rules/no-post-if-without-post.js.map +1 -1
  120. package/dist/rules/no-pr-head-checkout-in-pull-request-target.d.ts.map +1 -1
  121. package/dist/rules/no-pr-head-checkout-in-pull-request-target.js +3 -0
  122. package/dist/rules/no-pr-head-checkout-in-pull-request-target.js.map +1 -1
  123. package/dist/rules/no-pre-if-without-pre.d.ts.map +1 -1
  124. package/dist/rules/no-pre-if-without-pre.js +6 -0
  125. package/dist/rules/no-pre-if-without-pre.js.map +1 -1
  126. package/dist/rules/no-required-input-with-default.d.ts.map +1 -1
  127. package/dist/rules/no-required-input-with-default.js +23 -0
  128. package/dist/rules/no-required-input-with-default.js.map +1 -1
  129. package/dist/rules/no-secrets-in-if.d.ts.map +1 -1
  130. package/dist/rules/no-secrets-in-if.js +3 -0
  131. package/dist/rules/no-secrets-in-if.js.map +1 -1
  132. package/dist/rules/no-self-hosted-runner-on-fork-pr-events.d.ts.map +1 -1
  133. package/dist/rules/no-self-hosted-runner-on-fork-pr-events.js +3 -0
  134. package/dist/rules/no-self-hosted-runner-on-fork-pr-events.js.map +1 -1
  135. package/dist/rules/no-subdirectory-template-file-pattern.d.ts.map +1 -1
  136. package/dist/rules/no-subdirectory-template-file-pattern.js +3 -0
  137. package/dist/rules/no-subdirectory-template-file-pattern.js.map +1 -1
  138. package/dist/rules/no-template-placeholder-in-non-template-workflow.d.ts.map +1 -1
  139. package/dist/rules/no-template-placeholder-in-non-template-workflow.js +3 -0
  140. package/dist/rules/no-template-placeholder-in-non-template-workflow.js.map +1 -1
  141. package/dist/rules/no-top-level-env.d.ts.map +1 -1
  142. package/dist/rules/no-top-level-env.js +3 -0
  143. package/dist/rules/no-top-level-env.js.map +1 -1
  144. package/dist/rules/no-top-level-permissions.d.ts.map +1 -1
  145. package/dist/rules/no-top-level-permissions.js +3 -0
  146. package/dist/rules/no-top-level-permissions.js.map +1 -1
  147. package/dist/rules/no-universal-template-file-pattern.d.ts.map +1 -1
  148. package/dist/rules/no-universal-template-file-pattern.js +3 -0
  149. package/dist/rules/no-universal-template-file-pattern.js.map +1 -1
  150. package/dist/rules/no-unknown-dependabot-multi-ecosystem-group.d.ts +9 -0
  151. package/dist/rules/no-unknown-dependabot-multi-ecosystem-group.d.ts.map +1 -0
  152. package/dist/rules/no-unknown-dependabot-multi-ecosystem-group.js +58 -0
  153. package/dist/rules/no-unknown-dependabot-multi-ecosystem-group.js.map +1 -0
  154. package/dist/rules/no-unknown-input-reference-in-composite.d.ts.map +1 -1
  155. package/dist/rules/no-unknown-input-reference-in-composite.js +3 -0
  156. package/dist/rules/no-unknown-input-reference-in-composite.js.map +1 -1
  157. package/dist/rules/no-unknown-job-output-reference.d.ts.map +1 -1
  158. package/dist/rules/no-unknown-job-output-reference.js +3 -0
  159. package/dist/rules/no-unknown-job-output-reference.js.map +1 -1
  160. package/dist/rules/no-unknown-step-reference.d.ts.map +1 -1
  161. package/dist/rules/no-unknown-step-reference.js +3 -0
  162. package/dist/rules/no-unknown-step-reference.js.map +1 -1
  163. package/dist/rules/no-untrusted-input-in-run.d.ts.map +1 -1
  164. package/dist/rules/no-untrusted-input-in-run.js +3 -0
  165. package/dist/rules/no-untrusted-input-in-run.js.map +1 -1
  166. package/dist/rules/no-unused-dependabot-enable-beta-ecosystems.d.ts +9 -0
  167. package/dist/rules/no-unused-dependabot-enable-beta-ecosystems.d.ts.map +1 -0
  168. package/dist/rules/no-unused-dependabot-enable-beta-ecosystems.js +51 -0
  169. package/dist/rules/no-unused-dependabot-enable-beta-ecosystems.js.map +1 -0
  170. package/dist/rules/no-unused-input-in-composite.d.ts.map +1 -1
  171. package/dist/rules/no-unused-input-in-composite.js +3 -0
  172. package/dist/rules/no-unused-input-in-composite.js.map +1 -1
  173. package/dist/rules/no-write-all-permissions.d.ts.map +1 -1
  174. package/dist/rules/no-write-all-permissions.js +3 -0
  175. package/dist/rules/no-write-all-permissions.js.map +1 -1
  176. package/dist/rules/pin-action-shas.d.ts.map +1 -1
  177. package/dist/rules/pin-action-shas.js +3 -0
  178. package/dist/rules/pin-action-shas.js.map +1 -1
  179. package/dist/rules/prefer-action-yml.d.ts.map +1 -1
  180. package/dist/rules/prefer-action-yml.js +3 -0
  181. package/dist/rules/prefer-action-yml.js.map +1 -1
  182. package/dist/rules/prefer-fail-fast.d.ts.map +1 -1
  183. package/dist/rules/prefer-fail-fast.js +3 -0
  184. package/dist/rules/prefer-fail-fast.js.map +1 -1
  185. package/dist/rules/prefer-file-extension.d.ts.map +1 -1
  186. package/dist/rules/prefer-file-extension.js +3 -0
  187. package/dist/rules/prefer-file-extension.js.map +1 -1
  188. package/dist/rules/prefer-inputs-context.d.ts.map +1 -1
  189. package/dist/rules/prefer-inputs-context.js +3 -0
  190. package/dist/rules/prefer-inputs-context.js.map +1 -1
  191. package/dist/rules/prefer-step-uses-style.d.ts.map +1 -1
  192. package/dist/rules/prefer-step-uses-style.js +3 -0
  193. package/dist/rules/prefer-step-uses-style.js.map +1 -1
  194. package/dist/rules/prefer-template-yml-extension.d.ts.map +1 -1
  195. package/dist/rules/prefer-template-yml-extension.js +3 -0
  196. package/dist/rules/prefer-template-yml-extension.js.map +1 -1
  197. package/dist/rules/require-action-name.d.ts.map +1 -1
  198. package/dist/rules/require-action-name.js +3 -0
  199. package/dist/rules/require-action-name.js.map +1 -1
  200. package/dist/rules/require-action-run-name.d.ts.map +1 -1
  201. package/dist/rules/require-action-run-name.js +3 -0
  202. package/dist/rules/require-action-run-name.js.map +1 -1
  203. package/dist/rules/require-checkout-before-local-action.d.ts.map +1 -1
  204. package/dist/rules/require-checkout-before-local-action.js +3 -0
  205. package/dist/rules/require-checkout-before-local-action.js.map +1 -1
  206. package/dist/rules/require-codeql-actions-read.d.ts +9 -0
  207. package/dist/rules/require-codeql-actions-read.d.ts.map +1 -0
  208. package/dist/rules/require-codeql-actions-read.js +63 -0
  209. package/dist/rules/require-codeql-actions-read.js.map +1 -0
  210. package/dist/rules/require-codeql-branch-filters.d.ts +12 -0
  211. package/dist/rules/require-codeql-branch-filters.d.ts.map +1 -0
  212. package/dist/rules/require-codeql-branch-filters.js +83 -0
  213. package/dist/rules/require-codeql-branch-filters.js.map +1 -0
  214. package/dist/rules/require-codeql-category-when-language-matrix.d.ts +12 -0
  215. package/dist/rules/require-codeql-category-when-language-matrix.d.ts.map +1 -0
  216. package/dist/rules/require-codeql-category-when-language-matrix.js +68 -0
  217. package/dist/rules/require-codeql-category-when-language-matrix.js.map +1 -0
  218. package/dist/rules/require-codeql-pull-request-trigger.d.ts +9 -0
  219. package/dist/rules/require-codeql-pull-request-trigger.d.ts.map +1 -0
  220. package/dist/rules/require-codeql-pull-request-trigger.js +46 -0
  221. package/dist/rules/require-codeql-pull-request-trigger.js.map +1 -0
  222. package/dist/rules/require-codeql-schedule.d.ts +9 -0
  223. package/dist/rules/require-codeql-schedule.d.ts.map +1 -0
  224. package/dist/rules/require-codeql-schedule.js +46 -0
  225. package/dist/rules/require-codeql-schedule.js.map +1 -0
  226. package/dist/rules/require-codeql-security-events-write.d.ts +9 -0
  227. package/dist/rules/require-codeql-security-events-write.d.ts.map +1 -0
  228. package/dist/rules/require-codeql-security-events-write.js +53 -0
  229. package/dist/rules/require-codeql-security-events-write.js.map +1 -0
  230. package/dist/rules/require-composite-step-name.d.ts.map +1 -1
  231. package/dist/rules/require-composite-step-name.js +3 -0
  232. package/dist/rules/require-composite-step-name.js.map +1 -1
  233. package/dist/rules/require-dependabot-assignees.d.ts +9 -0
  234. package/dist/rules/require-dependabot-assignees.d.ts.map +1 -0
  235. package/dist/rules/require-dependabot-assignees.js +53 -0
  236. package/dist/rules/require-dependabot-assignees.js.map +1 -0
  237. package/dist/rules/require-dependabot-automation-permissions.d.ts +9 -0
  238. package/dist/rules/require-dependabot-automation-permissions.d.ts.map +1 -0
  239. package/dist/rules/require-dependabot-automation-permissions.js +68 -0
  240. package/dist/rules/require-dependabot-automation-permissions.js.map +1 -0
  241. package/dist/rules/require-dependabot-automation-pull-request-trigger.d.ts +12 -0
  242. package/dist/rules/require-dependabot-automation-pull-request-trigger.d.ts.map +1 -0
  243. package/dist/rules/require-dependabot-automation-pull-request-trigger.js +49 -0
  244. package/dist/rules/require-dependabot-automation-pull-request-trigger.js.map +1 -0
  245. package/dist/rules/require-dependabot-bot-actor-guard.d.ts +9 -0
  246. package/dist/rules/require-dependabot-bot-actor-guard.d.ts.map +1 -0
  247. package/dist/rules/require-dependabot-bot-actor-guard.js +64 -0
  248. package/dist/rules/require-dependabot-bot-actor-guard.js.map +1 -0
  249. package/dist/rules/require-dependabot-commit-message-include-scope.d.ts +9 -0
  250. package/dist/rules/require-dependabot-commit-message-include-scope.d.ts.map +1 -0
  251. package/dist/rules/require-dependabot-commit-message-include-scope.js +60 -0
  252. package/dist/rules/require-dependabot-commit-message-include-scope.js.map +1 -0
  253. package/dist/rules/require-dependabot-commit-message-prefix-development.d.ts +9 -0
  254. package/dist/rules/require-dependabot-commit-message-prefix-development.d.ts.map +1 -0
  255. package/dist/rules/require-dependabot-commit-message-prefix-development.js +75 -0
  256. package/dist/rules/require-dependabot-commit-message-prefix-development.js.map +1 -0
  257. package/dist/rules/require-dependabot-commit-message-prefix.d.ts +9 -0
  258. package/dist/rules/require-dependabot-commit-message-prefix.d.ts.map +1 -0
  259. package/dist/rules/require-dependabot-commit-message-prefix.js +60 -0
  260. package/dist/rules/require-dependabot-commit-message-prefix.js.map +1 -0
  261. package/dist/rules/require-dependabot-cooldown.d.ts +9 -0
  262. package/dist/rules/require-dependabot-cooldown.d.ts.map +1 -0
  263. package/dist/rules/require-dependabot-cooldown.js +52 -0
  264. package/dist/rules/require-dependabot-cooldown.js.map +1 -0
  265. package/dist/rules/require-dependabot-directory.d.ts +9 -0
  266. package/dist/rules/require-dependabot-directory.d.ts.map +1 -0
  267. package/dist/rules/require-dependabot-directory.js +68 -0
  268. package/dist/rules/require-dependabot-directory.js.map +1 -0
  269. package/dist/rules/require-dependabot-github-actions-directory-root.d.ts +9 -0
  270. package/dist/rules/require-dependabot-github-actions-directory-root.d.ts.map +1 -0
  271. package/dist/rules/require-dependabot-github-actions-directory-root.js +76 -0
  272. package/dist/rules/require-dependabot-github-actions-directory-root.js.map +1 -0
  273. package/dist/rules/require-dependabot-labels.d.ts +9 -0
  274. package/dist/rules/require-dependabot-labels.d.ts.map +1 -0
  275. package/dist/rules/require-dependabot-labels.js +52 -0
  276. package/dist/rules/require-dependabot-labels.js.map +1 -0
  277. package/dist/rules/require-dependabot-open-pull-requests-limit.d.ts +9 -0
  278. package/dist/rules/require-dependabot-open-pull-requests-limit.d.ts.map +1 -0
  279. package/dist/rules/require-dependabot-open-pull-requests-limit.js +55 -0
  280. package/dist/rules/require-dependabot-open-pull-requests-limit.js.map +1 -0
  281. package/dist/rules/require-dependabot-package-ecosystem.d.ts +9 -0
  282. package/dist/rules/require-dependabot-package-ecosystem.d.ts.map +1 -0
  283. package/dist/rules/require-dependabot-package-ecosystem.js +79 -0
  284. package/dist/rules/require-dependabot-package-ecosystem.js.map +1 -0
  285. package/dist/rules/require-dependabot-patterns-for-multi-ecosystem-group.d.ts +9 -0
  286. package/dist/rules/require-dependabot-patterns-for-multi-ecosystem-group.d.ts.map +1 -0
  287. package/dist/rules/require-dependabot-patterns-for-multi-ecosystem-group.js +58 -0
  288. package/dist/rules/require-dependabot-patterns-for-multi-ecosystem-group.js.map +1 -0
  289. package/dist/rules/require-dependabot-schedule-cronjob.d.ts +9 -0
  290. package/dist/rules/require-dependabot-schedule-cronjob.d.ts.map +1 -0
  291. package/dist/rules/require-dependabot-schedule-cronjob.js +82 -0
  292. package/dist/rules/require-dependabot-schedule-cronjob.js.map +1 -0
  293. package/dist/rules/require-dependabot-schedule-interval.d.ts +9 -0
  294. package/dist/rules/require-dependabot-schedule-interval.d.ts.map +1 -0
  295. package/dist/rules/require-dependabot-schedule-interval.js +73 -0
  296. package/dist/rules/require-dependabot-schedule-interval.js.map +1 -0
  297. package/dist/rules/require-dependabot-schedule-time.d.ts +9 -0
  298. package/dist/rules/require-dependabot-schedule-time.d.ts.map +1 -0
  299. package/dist/rules/require-dependabot-schedule-time.js +68 -0
  300. package/dist/rules/require-dependabot-schedule-time.js.map +1 -0
  301. package/dist/rules/require-dependabot-schedule-timezone.d.ts +9 -0
  302. package/dist/rules/require-dependabot-schedule-timezone.d.ts.map +1 -0
  303. package/dist/rules/require-dependabot-schedule-timezone.js +69 -0
  304. package/dist/rules/require-dependabot-schedule-timezone.js.map +1 -0
  305. package/dist/rules/require-dependabot-target-branch.d.ts +9 -0
  306. package/dist/rules/require-dependabot-target-branch.d.ts.map +1 -0
  307. package/dist/rules/require-dependabot-target-branch.js +53 -0
  308. package/dist/rules/require-dependabot-target-branch.js.map +1 -0
  309. package/dist/rules/require-dependabot-updates.d.ts +9 -0
  310. package/dist/rules/require-dependabot-updates.d.ts.map +1 -0
  311. package/dist/rules/require-dependabot-updates.js +54 -0
  312. package/dist/rules/require-dependabot-updates.js.map +1 -0
  313. package/dist/rules/require-dependabot-version.d.ts +9 -0
  314. package/dist/rules/require-dependabot-version.d.ts.map +1 -0
  315. package/dist/rules/require-dependabot-version.js +62 -0
  316. package/dist/rules/require-dependabot-version.js.map +1 -0
  317. package/dist/rules/require-dependabot-versioning-strategy-for-npm.d.ts +9 -0
  318. package/dist/rules/require-dependabot-versioning-strategy-for-npm.d.ts.map +1 -0
  319. package/dist/rules/require-dependabot-versioning-strategy-for-npm.js +58 -0
  320. package/dist/rules/require-dependabot-versioning-strategy-for-npm.js.map +1 -0
  321. package/dist/rules/require-dependency-review-action.d.ts +9 -0
  322. package/dist/rules/require-dependency-review-action.d.ts.map +1 -0
  323. package/dist/rules/require-dependency-review-action.js +51 -0
  324. package/dist/rules/require-dependency-review-action.js.map +1 -0
  325. package/dist/rules/require-dependency-review-fail-on-severity.d.ts +9 -0
  326. package/dist/rules/require-dependency-review-fail-on-severity.d.ts.map +1 -0
  327. package/dist/rules/require-dependency-review-fail-on-severity.js +62 -0
  328. package/dist/rules/require-dependency-review-fail-on-severity.js.map +1 -0
  329. package/dist/rules/require-dependency-review-permissions-contents-read.d.ts +9 -0
  330. package/dist/rules/require-dependency-review-permissions-contents-read.d.ts.map +1 -0
  331. package/dist/rules/require-dependency-review-permissions-contents-read.js +55 -0
  332. package/dist/rules/require-dependency-review-permissions-contents-read.js.map +1 -0
  333. package/dist/rules/require-dependency-review-pull-request-trigger.d.ts +9 -0
  334. package/dist/rules/require-dependency-review-pull-request-trigger.d.ts.map +1 -0
  335. package/dist/rules/require-dependency-review-pull-request-trigger.js +47 -0
  336. package/dist/rules/require-dependency-review-pull-request-trigger.js.map +1 -0
  337. package/dist/rules/require-fetch-metadata-github-token.d.ts +9 -0
  338. package/dist/rules/require-fetch-metadata-github-token.d.ts.map +1 -0
  339. package/dist/rules/require-fetch-metadata-github-token.js +57 -0
  340. package/dist/rules/require-fetch-metadata-github-token.js.map +1 -0
  341. package/dist/rules/require-job-name.d.ts.map +1 -1
  342. package/dist/rules/require-job-name.js +35 -0
  343. package/dist/rules/require-job-name.js.map +1 -1
  344. package/dist/rules/require-job-step-name.d.ts.map +1 -1
  345. package/dist/rules/require-job-step-name.js +76 -0
  346. package/dist/rules/require-job-step-name.js.map +1 -1
  347. package/dist/rules/require-job-timeout-minutes.d.ts.map +1 -1
  348. package/dist/rules/require-job-timeout-minutes.js +3 -0
  349. package/dist/rules/require-job-timeout-minutes.js.map +1 -1
  350. package/dist/rules/require-merge-group-trigger.d.ts.map +1 -1
  351. package/dist/rules/require-merge-group-trigger.js +3 -0
  352. package/dist/rules/require-merge-group-trigger.js.map +1 -1
  353. package/dist/rules/require-pull-request-target-branches.d.ts.map +1 -1
  354. package/dist/rules/require-pull-request-target-branches.js +3 -0
  355. package/dist/rules/require-pull-request-target-branches.js.map +1 -1
  356. package/dist/rules/require-run-step-shell.d.ts.map +1 -1
  357. package/dist/rules/require-run-step-shell.js +3 -0
  358. package/dist/rules/require-run-step-shell.js.map +1 -1
  359. package/dist/rules/require-sarif-upload-security-events-write.d.ts +9 -0
  360. package/dist/rules/require-sarif-upload-security-events-write.d.ts.map +1 -0
  361. package/dist/rules/require-sarif-upload-security-events-write.js +51 -0
  362. package/dist/rules/require-sarif-upload-security-events-write.js.map +1 -0
  363. package/dist/rules/require-scorecard-results-format-sarif.d.ts +9 -0
  364. package/dist/rules/require-scorecard-results-format-sarif.d.ts.map +1 -0
  365. package/dist/rules/require-scorecard-results-format-sarif.js +57 -0
  366. package/dist/rules/require-scorecard-results-format-sarif.js.map +1 -0
  367. package/dist/rules/require-scorecard-upload-sarif-step.d.ts +9 -0
  368. package/dist/rules/require-scorecard-upload-sarif-step.d.ts.map +1 -0
  369. package/dist/rules/require-scorecard-upload-sarif-step.js +46 -0
  370. package/dist/rules/require-scorecard-upload-sarif-step.js.map +1 -0
  371. package/dist/rules/require-secret-scan-contents-read.d.ts +12 -0
  372. package/dist/rules/require-secret-scan-contents-read.d.ts.map +1 -0
  373. package/dist/rules/require-secret-scan-contents-read.js +53 -0
  374. package/dist/rules/require-secret-scan-contents-read.js.map +1 -0
  375. package/dist/rules/require-secret-scan-fetch-depth-zero.d.ts +9 -0
  376. package/dist/rules/require-secret-scan-fetch-depth-zero.d.ts.map +1 -0
  377. package/dist/rules/require-secret-scan-fetch-depth-zero.js +77 -0
  378. package/dist/rules/require-secret-scan-fetch-depth-zero.js.map +1 -0
  379. package/dist/rules/require-secret-scan-schedule.d.ts +9 -0
  380. package/dist/rules/require-secret-scan-schedule.d.ts.map +1 -0
  381. package/dist/rules/require-secret-scan-schedule.js +46 -0
  382. package/dist/rules/require-secret-scan-schedule.js.map +1 -0
  383. package/dist/rules/require-template-categories.d.ts.map +1 -1
  384. package/dist/rules/require-template-categories.js +3 -0
  385. package/dist/rules/require-template-categories.js.map +1 -1
  386. package/dist/rules/require-template-file-patterns.d.ts.map +1 -1
  387. package/dist/rules/require-template-file-patterns.js +3 -0
  388. package/dist/rules/require-template-file-patterns.js.map +1 -1
  389. package/dist/rules/require-template-icon-file-exists.d.ts.map +1 -1
  390. package/dist/rules/require-template-icon-file-exists.js +3 -0
  391. package/dist/rules/require-template-icon-file-exists.js.map +1 -1
  392. package/dist/rules/require-template-icon-name.d.ts.map +1 -1
  393. package/dist/rules/require-template-icon-name.js +3 -0
  394. package/dist/rules/require-template-icon-name.js.map +1 -1
  395. package/dist/rules/require-template-workflow-name.d.ts.map +1 -1
  396. package/dist/rules/require-template-workflow-name.js +3 -0
  397. package/dist/rules/require-template-workflow-name.js.map +1 -1
  398. package/dist/rules/require-trigger-types.d.ts.map +1 -1
  399. package/dist/rules/require-trigger-types.js +3 -0
  400. package/dist/rules/require-trigger-types.js.map +1 -1
  401. package/dist/rules/require-trufflehog-verified-results-mode.d.ts +9 -0
  402. package/dist/rules/require-trufflehog-verified-results-mode.d.ts.map +1 -0
  403. package/dist/rules/require-trufflehog-verified-results-mode.js +59 -0
  404. package/dist/rules/require-trufflehog-verified-results-mode.js.map +1 -0
  405. package/dist/rules/require-workflow-call-input-type.d.ts.map +1 -1
  406. package/dist/rules/require-workflow-call-input-type.js +3 -0
  407. package/dist/rules/require-workflow-call-input-type.js.map +1 -1
  408. package/dist/rules/require-workflow-call-output-value.d.ts.map +1 -1
  409. package/dist/rules/require-workflow-call-output-value.js +3 -0
  410. package/dist/rules/require-workflow-call-output-value.js.map +1 -1
  411. package/dist/rules/require-workflow-concurrency.d.ts.map +1 -1
  412. package/dist/rules/require-workflow-concurrency.js +3 -0
  413. package/dist/rules/require-workflow-concurrency.js.map +1 -1
  414. package/dist/rules/require-workflow-dispatch-input-type.d.ts.map +1 -1
  415. package/dist/rules/require-workflow-dispatch-input-type.js +3 -0
  416. package/dist/rules/require-workflow-dispatch-input-type.js.map +1 -1
  417. package/dist/rules/require-workflow-interface-description.d.ts.map +1 -1
  418. package/dist/rules/require-workflow-interface-description.js +3 -0
  419. package/dist/rules/require-workflow-interface-description.js.map +1 -1
  420. package/dist/rules/require-workflow-permissions.d.ts.map +1 -1
  421. package/dist/rules/require-workflow-permissions.js +3 -0
  422. package/dist/rules/require-workflow-permissions.js.map +1 -1
  423. package/dist/rules/require-workflow-run-branches.d.ts.map +1 -1
  424. package/dist/rules/require-workflow-run-branches.js +3 -0
  425. package/dist/rules/require-workflow-run-branches.js.map +1 -1
  426. package/dist/rules/require-workflow-template-pair.d.ts.map +1 -1
  427. package/dist/rules/require-workflow-template-pair.js +3 -0
  428. package/dist/rules/require-workflow-template-pair.js.map +1 -1
  429. package/dist/rules/require-workflow-template-properties-pair.d.ts.map +1 -1
  430. package/dist/rules/require-workflow-template-properties-pair.js +3 -0
  431. package/dist/rules/require-workflow-template-properties-pair.js.map +1 -1
  432. package/dist/rules/valid-timeout-minutes.d.ts.map +1 -1
  433. package/dist/rules/valid-timeout-minutes.js +3 -0
  434. package/dist/rules/valid-timeout-minutes.js.map +1 -1
  435. package/dist/rules/valid-trigger-events.d.ts.map +1 -1
  436. package/dist/rules/valid-trigger-events.js +3 -0
  437. package/dist/rules/valid-trigger-events.js.map +1 -1
  438. package/docs/rules/action-name-casing.md +6 -2
  439. package/docs/rules/no-codeql-autobuild-for-javascript-typescript.md +55 -0
  440. package/docs/rules/no-codeql-javascript-typescript-split-language-matrix.md +51 -0
  441. package/docs/rules/no-empty-template-file-pattern.md +5 -1
  442. package/docs/rules/no-icon-file-extension-in-template-icon-name.md +5 -1
  443. package/docs/rules/no-overlapping-dependabot-directories.md +87 -0
  444. package/docs/rules/no-path-separators-in-template-icon-name.md +5 -1
  445. package/docs/rules/no-post-if-without-post.md +5 -1
  446. package/docs/rules/no-pre-if-without-pre.md +5 -1
  447. package/docs/rules/no-required-input-with-default.md +10 -1
  448. package/docs/rules/no-unknown-dependabot-multi-ecosystem-group.md +62 -0
  449. package/docs/rules/no-unused-dependabot-enable-beta-ecosystems.md +63 -0
  450. package/docs/rules/overview.md +47 -1
  451. package/docs/rules/prefer-inputs-context.md +6 -2
  452. package/docs/rules/presets/action-metadata.md +22 -11
  453. package/docs/rules/presets/all.md +125 -69
  454. package/docs/rules/presets/code-scanning.md +33 -0
  455. package/docs/rules/presets/dependabot.md +40 -0
  456. package/docs/rules/presets/index.md +144 -73
  457. package/docs/rules/presets/recommended.md +30 -19
  458. package/docs/rules/presets/security.md +35 -9
  459. package/docs/rules/presets/strict.md +52 -41
  460. package/docs/rules/presets/workflow-template-properties.md +22 -11
  461. package/docs/rules/presets/workflow-templates.md +26 -15
  462. package/docs/rules/require-codeql-actions-read.md +50 -0
  463. package/docs/rules/require-codeql-branch-filters.md +53 -0
  464. package/docs/rules/require-codeql-category-when-language-matrix.md +49 -0
  465. package/docs/rules/require-codeql-pull-request-trigger.md +53 -0
  466. package/docs/rules/require-codeql-schedule.md +57 -0
  467. package/docs/rules/require-codeql-security-events-write.md +50 -0
  468. package/docs/rules/require-dependabot-assignees.md +64 -0
  469. package/docs/rules/require-dependabot-automation-permissions.md +53 -0
  470. package/docs/rules/require-dependabot-automation-pull-request-trigger.md +49 -0
  471. package/docs/rules/require-dependabot-bot-actor-guard.md +52 -0
  472. package/docs/rules/require-dependabot-commit-message-include-scope.md +58 -0
  473. package/docs/rules/require-dependabot-commit-message-prefix-development.md +60 -0
  474. package/docs/rules/require-dependabot-commit-message-prefix.md +64 -0
  475. package/docs/rules/require-dependabot-cooldown.md +59 -0
  476. package/docs/rules/require-dependabot-directory.md +79 -0
  477. package/docs/rules/require-dependabot-github-actions-directory-root.md +62 -0
  478. package/docs/rules/require-dependabot-labels.md +65 -0
  479. package/docs/rules/require-dependabot-open-pull-requests-limit.md +58 -0
  480. package/docs/rules/require-dependabot-package-ecosystem.md +57 -0
  481. package/docs/rules/require-dependabot-patterns-for-multi-ecosystem-group.md +67 -0
  482. package/docs/rules/require-dependabot-schedule-cronjob.md +74 -0
  483. package/docs/rules/require-dependabot-schedule-interval.md +66 -0
  484. package/docs/rules/require-dependabot-schedule-time.md +60 -0
  485. package/docs/rules/require-dependabot-schedule-timezone.md +61 -0
  486. package/docs/rules/require-dependabot-target-branch.md +63 -0
  487. package/docs/rules/require-dependabot-updates.md +58 -0
  488. package/docs/rules/require-dependabot-version.md +70 -0
  489. package/docs/rules/require-dependabot-versioning-strategy-for-npm.md +58 -0
  490. package/docs/rules/require-dependency-review-action.md +60 -0
  491. package/docs/rules/require-dependency-review-fail-on-severity.md +57 -0
  492. package/docs/rules/require-dependency-review-permissions-contents-read.md +62 -0
  493. package/docs/rules/require-dependency-review-pull-request-trigger.md +57 -0
  494. package/docs/rules/require-fetch-metadata-github-token.md +49 -0
  495. package/docs/rules/require-job-name.md +6 -2
  496. package/docs/rules/require-job-step-name.md +11 -2
  497. package/docs/rules/require-sarif-upload-security-events-write.md +50 -0
  498. package/docs/rules/require-scorecard-results-format-sarif.md +49 -0
  499. package/docs/rules/require-scorecard-upload-sarif-step.md +55 -0
  500. package/docs/rules/require-secret-scan-contents-read.md +48 -0
  501. package/docs/rules/require-secret-scan-fetch-depth-zero.md +50 -0
  502. package/docs/rules/require-secret-scan-schedule.md +50 -0
  503. package/docs/rules/require-trufflehog-verified-results-mode.md +49 -0
  504. package/package.json +52 -59
package/README.md CHANGED
@@ -2,26 +2,23 @@
2
2
 
3
3
  [![npm license.](https://flat.badgen.net/npm/license/eslint-plugin-github-actions-2?color=purple)](https://github.com/Nick2bad4u/eslint-plugin-github-actions-2/blob/main/LICENSE) [![npm total downloads.](https://flat.badgen.net/npm/dt/eslint-plugin-github-actions-2?color=pink)](https://www.npmjs.com/package/eslint-plugin-github-actions-2) [![latest GitHub release.](https://flat.badgen.net/github/release/Nick2bad4u/eslint-plugin-github-actions-2?color=cyan)](https://github.com/Nick2bad4u/eslint-plugin-github-actions-2/releases) [![GitHub stars.](https://flat.badgen.net/github/stars/Nick2bad4u/eslint-plugin-github-actions-2?color=yellow)](https://github.com/Nick2bad4u/eslint-plugin-github-actions-2/stargazers) [![GitHub forks.](https://flat.badgen.net/github/forks/Nick2bad4u/eslint-plugin-github-actions-2?color=green)](https://github.com/Nick2bad4u/eslint-plugin-github-actions-2/forks) [![GitHub open issues.](https://flat.badgen.net/github/open-issues/Nick2bad4u/eslint-plugin-github-actions-2?color=red)](https://github.com/Nick2bad4u/eslint-plugin-github-actions-2/issues) [![codecov.](https://codecov.io/gh/Nick2bad4u/eslint-plugin-github-actions-2/branch/main/graph/badge.svg)](https://codecov.io/gh/Nick2bad4u/eslint-plugin-github-actions-2)
4
4
 
5
- ESLint plugin for GitHub Actions workflow quality, reliability, and security.
5
+ ESLint plugin for GitHub Actions quality, reliability, security, and maintainability across the full GitHub Actions ecosystem.
6
6
 
7
- The plugin now covers:
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
- Rules help teams:
14
+ The rules help teams:
14
15
 
15
- - standardize workflow names and job identifiers
16
- - require descriptive workflow, job, and step names
17
- - make `run` steps and manual workflow inputs more explicit
18
- - declare explicit token `permissions`
19
- - reject unsupported workflow keys in common workflow structures
20
- - validate and bound `timeout-minutes` values
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 | Purpose |
45
- | -------------------------------------------------- | --------------------------------------------------- |
46
- | `githubActions.configs.actionMetadata` | Action metadata hygiene and correctness checks. |
47
- | `githubActions.configs.workflowTemplateProperties` | Workflow-template metadata quality checks. |
48
- | `githubActions.configs.workflowTemplates` | Combined workflow-template YAML + metadata checks. |
49
- | `githubActions.configs.recommended` | Balanced defaults for most repositories. |
50
- | `githubActions.configs.security` | Security-focused checks like immutable SHA pinning. |
51
- | `githubActions.configs.strict` | Operational guardrails for mature workflow estates. |
52
- | `githubActions.configs.all` | Every rule published by the plugin. |
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
- Rule matrix by preset (matches the presets docs page).
57
-
58
- | Rule | 🧩 actionMetadata | 🗂️ workflowTemplateProperties | 🧱 workflowTemplates | 🟡 recommended | 🛡️ security | 🔴 strict | 🟣 all |
59
- | --- | :-: | :-: | :-: | :-: | :-: | :-: | :-: |
60
- | [`action-name-casing`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/action-name-casing) | | | — | — | — | ✅ | ✅ |
61
- | [`job-id-casing`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/job-id-casing) | — | — | — | — | — | ✅ | ✅ |
62
- | [`max-jobs-per-action`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/max-jobs-per-action) | — | — | — | — | — | ✅ | ✅ |
63
- | [`no-case-insensitive-input-id-collision`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-case-insensitive-input-id-collision) | ✅ | — | — | — | — | — | ✅ |
64
- | [`no-composite-input-env-access`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-composite-input-env-access) | ✅ | — | — | — | — | — | ✅ |
65
- | [`no-deprecated-node-runtime`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-deprecated-node-runtime) | ✅ | — | — | — | — | — | ✅ |
66
- | [`no-duplicate-composite-step-id`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-duplicate-composite-step-id) | ✅ | — | — | — | — | — | ✅ |
67
- | [`no-empty-template-file-pattern`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-empty-template-file-pattern) | — | ✅ | ✅ | — | — | — | ✅ |
68
- | [`no-external-job`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-external-job) | — | — | — | — | — | ✅ | ✅ |
69
- | [`no-hardcoded-default-branch-in-template`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-hardcoded-default-branch-in-template) | — | — | ✅ | — | — | — | ✅ |
70
- | [`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) | — | ✅ | ✅ | — | — | — | ✅ |
71
- | [`no-inherit-secrets`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-inherit-secrets) | — | — | — | — | ✅ | ✅ | ✅ |
72
- | [`no-invalid-concurrency-context`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-invalid-concurrency-context) | — | — | — | ✅ | — | ✅ | ✅ |
73
- | [`no-invalid-key`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-invalid-key) | — | — | — | ✅ | — | ✅ | ✅ |
74
- | [`no-invalid-reusable-workflow-job-key`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-invalid-reusable-workflow-job-key) | | | | ✅ | — | ✅ | ✅ |
75
- | [`no-invalid-template-file-pattern-regex`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-invalid-template-file-pattern-regex) | | | ✅ | — | — | — | ✅ |
76
- | [`no-invalid-workflow-call-output-value`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-invalid-workflow-call-output-value) | | | | ✅ | — | ✅ | ✅ |
77
- | [`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) | — | | | — | — | — | ✅ |
78
- | [`no-post-if-without-post`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-post-if-without-post) | ✅ | — | | | — | — | ✅ |
79
- | [`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) | — | | | — | ✅ | ✅ | ✅ |
80
- | [`no-pre-if-without-pre`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-pre-if-without-pre) | ✅ | — | | | — | — | ✅ |
81
- | [`no-required-input-with-default`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-required-input-with-default) | ✅ | — | | | — | — | ✅ |
82
- | [`no-secrets-in-if`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-secrets-in-if) | — | | | ✅ | ✅ | ✅ | ✅ |
83
- | [`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) | — | | | — | ✅ | ✅ | ✅ |
84
- | [`no-subdirectory-template-file-pattern`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-subdirectory-template-file-pattern) | — | | | — | — | — | ✅ |
85
- | [`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) | | | | ✅ | — | ✅ | ✅ |
86
- | [`no-top-level-env`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-top-level-env) | — | | | — | — | ✅ | ✅ |
87
- | [`no-top-level-permissions`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-top-level-permissions) | — | | | — | — | — | ✅ |
88
- | [`no-universal-template-file-pattern`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-universal-template-file-pattern) | | | | — | — | — | ✅ |
89
- | [`no-unknown-input-reference-in-composite`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-unknown-input-reference-in-composite) | ✅ | — | | | — | — | ✅ |
90
- | [`no-unknown-job-output-reference`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-unknown-job-output-reference) | — | | | ✅ | — | ✅ | ✅ |
91
- | [`no-unknown-step-reference`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-unknown-step-reference) | — | | | — | — | ✅ | ✅ |
92
- | [`no-untrusted-input-in-run`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-untrusted-input-in-run) | — | | | — | ✅ | ✅ | ✅ |
93
- | [`no-unused-input-in-composite`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-unused-input-in-composite) | ✅ | — | | | — | — | ✅ |
94
- | [`no-write-all-permissions`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/no-write-all-permissions) | — | | | ✅ | ✅ | ✅ | ✅ |
95
- | [`pin-action-shas`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/pin-action-shas) | — | | | — | ✅ | ✅ | ✅ |
96
- | [`prefer-action-yml`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/prefer-action-yml) | | | | — | — | — | ✅ |
97
- | [`prefer-fail-fast`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/prefer-fail-fast) | | | | — | — | ✅ | ✅ |
98
- | [`prefer-file-extension`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/prefer-file-extension) | — | | | ✅ | — | ✅ | ✅ |
99
- | [`prefer-inputs-context`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/prefer-inputs-context) | | | | ✅ | — | ✅ | ✅ |
100
- | [`prefer-step-uses-style`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/prefer-step-uses-style) | | | | — | — | — | ✅ |
101
- | [`prefer-template-yml-extension`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/prefer-template-yml-extension) | — | | | | — | — | ✅ |
102
- | [`require-action-name`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-action-name) | — | | | ✅ | — | ✅ | ✅ |
103
- | [`require-action-run-name`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-action-run-name) | — | | | — | — | ✅ | ✅ |
104
- | [`require-checkout-before-local-action`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-checkout-before-local-action) | — | | | ✅ | — | ✅ | ✅ |
105
- | [`require-composite-step-name`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-composite-step-name) | ✅ | — | | | — | — | ✅ |
106
- | [`require-job-name`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-job-name) | — | | — | — | — | ✅ | ✅ |
107
- | [`require-job-step-name`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-job-step-name) | — | | | — | — | ✅ | ✅ |
108
- | [`require-job-timeout-minutes`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-job-timeout-minutes) | — | | | ✅ | — | ✅ | ✅ |
109
- | [`require-merge-group-trigger`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-merge-group-trigger) | — | | | — | — | ✅ | ✅ |
110
- | [`require-pull-request-target-branches`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-pull-request-target-branches) | — | | | — | ✅ | ✅ | ✅ |
111
- | [`require-run-step-shell`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-run-step-shell) | — | | | — | — | ✅ | ✅ |
112
- | [`require-template-categories`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-template-categories) | — | | | — | — | — | ✅ |
113
- | [`require-template-file-patterns`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-template-file-patterns) | | | | — | — | — | ✅ |
114
- | [`require-template-icon-file-exists`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-template-icon-file-exists) | — | | | — | — | — | ✅ |
115
- | [`require-template-icon-name`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-template-icon-name) | — | | | | — | — | ✅ |
116
- | [`require-template-workflow-name`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-template-workflow-name) | — | | | — | — | — | ✅ |
117
- | [`require-trigger-types`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-trigger-types) | — | | | — | — | ✅ | ✅ |
118
- | [`require-workflow-call-input-type`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-workflow-call-input-type) | — | | | ✅ | — | ✅ | ✅ |
119
- | [`require-workflow-call-output-value`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-workflow-call-output-value) | — | | | ✅ | — | ✅ | ✅ |
120
- | [`require-workflow-concurrency`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-workflow-concurrency) | | | | — | — | ✅ | ✅ |
121
- | [`require-workflow-dispatch-input-type`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-workflow-dispatch-input-type) | — | | — | ✅ | — | ✅ | ✅ |
122
- | [`require-workflow-interface-description`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-workflow-interface-description) | — | | | — | — | ✅ | ✅ |
123
- | [`require-workflow-permissions`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-workflow-permissions) | — | | | ✅ | ✅ | ✅ | ✅ |
124
- | [`require-workflow-run-branches`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-workflow-run-branches) | — | | | — | ✅ | ✅ | ✅ |
125
- | [`require-workflow-template-pair`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-workflow-template-pair) | — | | | — | — | — | ✅ |
126
- | [`require-workflow-template-properties-pair`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/require-workflow-template-properties-pair) | — | | | — | — | — | ✅ |
127
- | [`valid-timeout-minutes`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/valid-timeout-minutes) | — | | | ✅ | — | ✅ | ✅ |
128
- | [`valid-trigger-events`](https://nick2bad4u.github.io/eslint-plugin-github-actions-2/docs/rules/valid-trigger-events) | — | | | ✅ | — | ✅ | ✅ |
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"}