@flow-scanner/lightning-flow-scanner-core 6.17.1 → 6.17.2

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 (508) hide show
  1. package/README.md +642 -0
  2. package/package.json +9 -58
  3. package/.husky/pre-commit +0 -1
  4. package/.husky/pre-push +0 -1
  5. package/.prettierignore +0 -5
  6. package/.swcrc +0 -26
  7. package/.turbo/turbo-build.log +0 -17
  8. package/.turbo/turbo-test.log +0 -144
  9. package/.turbo/turbo-vite$colon$dist.log +0 -21
  10. package/coverage/coverage-final.json +0 -63
  11. package/coverage/lcov-report/base.css +0 -224
  12. package/coverage/lcov-report/block-navigation.js +0 -87
  13. package/coverage/lcov-report/favicon.png +0 -0
  14. package/coverage/lcov-report/index.html +0 -236
  15. package/coverage/lcov-report/prettify.css +0 -1
  16. package/coverage/lcov-report/prettify.js +0 -2
  17. package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
  18. package/coverage/lcov-report/sorter.js +0 -210
  19. package/coverage/lcov-report/src/index.html +0 -116
  20. package/coverage/lcov-report/src/index.ts.html +0 -238
  21. package/coverage/lcov-report/src/main/adapters/RegexAdapter.ts.html +0 -118
  22. package/coverage/lcov-report/src/main/adapters/index.html +0 -116
  23. package/coverage/lcov-report/src/main/config/NodeIcons.ts.html +0 -376
  24. package/coverage/lcov-report/src/main/config/RuleRegistry.ts.html +0 -646
  25. package/coverage/lcov-report/src/main/config/VariableIcons.ts.html +0 -253
  26. package/coverage/lcov-report/src/main/config/index.html +0 -146
  27. package/coverage/lcov-report/src/main/enums/MetaType.ts.html +0 -100
  28. package/coverage/lcov-report/src/main/enums/MetadataType.ts.html +0 -103
  29. package/coverage/lcov-report/src/main/enums/MetadataTypes.ts.html +0 -100
  30. package/coverage/lcov-report/src/main/enums/index.html +0 -116
  31. package/coverage/lcov-report/src/main/interfaces/IRulesConfig.ts.html +0 -133
  32. package/coverage/lcov-report/src/main/interfaces/index.html +0 -116
  33. package/coverage/lcov-report/src/main/internals/index.html +0 -116
  34. package/coverage/lcov-report/src/main/internals/internals.ts.html +0 -190
  35. package/coverage/lcov-report/src/main/libs/BuildFlow.ts.html +0 -127
  36. package/coverage/lcov-report/src/main/libs/Compiler.ts.html +0 -241
  37. package/coverage/lcov-report/src/main/libs/ConvertFlowNodes.ts.html +0 -97
  38. package/coverage/lcov-report/src/main/libs/DynamicRule.ts.html +0 -118
  39. package/coverage/lcov-report/src/main/libs/ExportDetails.ts.html +0 -256
  40. package/coverage/lcov-report/src/main/libs/ExportDiagram.ts.html +0 -331
  41. package/coverage/lcov-report/src/main/libs/ExportSarif.ts.html +0 -358
  42. package/coverage/lcov-report/src/main/libs/FixFlows.ts.html +0 -265
  43. package/coverage/lcov-report/src/main/libs/GenerateMarkdown.ts.html +0 -331
  44. package/coverage/lcov-report/src/main/libs/GetRuleDefinitions.ts.html +0 -274
  45. package/coverage/lcov-report/src/main/libs/ParseFlows.ts.html +0 -184
  46. package/coverage/lcov-report/src/main/libs/RuleDocumentation.ts.html +0 -190
  47. package/coverage/lcov-report/src/main/libs/ScanFlows.ts.html +0 -508
  48. package/coverage/lcov-report/src/main/libs/exportAsDetails.ts.html +0 -160
  49. package/coverage/lcov-report/src/main/libs/exportAsSarif.ts.html +0 -346
  50. package/coverage/lcov-report/src/main/libs/index.html +0 -251
  51. package/coverage/lcov-report/src/main/models/FlatViolation.ts.html +0 -106
  52. package/coverage/lcov-report/src/main/models/Flow.ts.html +0 -1057
  53. package/coverage/lcov-report/src/main/models/FlowAttribute.ts.html +0 -115
  54. package/coverage/lcov-report/src/main/models/FlowElement.ts.html +0 -133
  55. package/coverage/lcov-report/src/main/models/FlowElementConnector.ts.html +0 -169
  56. package/coverage/lcov-report/src/main/models/FlowGraph.ts.html +0 -1672
  57. package/coverage/lcov-report/src/main/models/FlowMetadata.ts.html +0 -106
  58. package/coverage/lcov-report/src/main/models/FlowNode.ts.html +0 -1252
  59. package/coverage/lcov-report/src/main/models/FlowResource.ts.html +0 -106
  60. package/coverage/lcov-report/src/main/models/FlowType.ts.html +0 -244
  61. package/coverage/lcov-report/src/main/models/FlowVariable.ts.html +0 -553
  62. package/coverage/lcov-report/src/main/models/LoopRuleCommon.ts.html +0 -235
  63. package/coverage/lcov-report/src/main/models/ParsedFlow.ts.html +0 -121
  64. package/coverage/lcov-report/src/main/models/RuleCommon.ts.html +0 -442
  65. package/coverage/lcov-report/src/main/models/RuleResult.ts.html +0 -172
  66. package/coverage/lcov-report/src/main/models/ScanResult.ts.html +0 -121
  67. package/coverage/lcov-report/src/main/models/Violation.ts.html +0 -316
  68. package/coverage/lcov-report/src/main/models/index.html +0 -341
  69. package/coverage/lcov-report/src/main/rules/APIVersion.ts.html +0 -361
  70. package/coverage/lcov-report/src/main/rules/ActionCallsInLoop.ts.html +0 -157
  71. package/coverage/lcov-report/src/main/rules/AutoLayout.ts.html +0 -220
  72. package/coverage/lcov-report/src/main/rules/CopyAPIName.ts.html +0 -175
  73. package/coverage/lcov-report/src/main/rules/CyclomaticComplexity.ts.html +0 -292
  74. package/coverage/lcov-report/src/main/rules/DMLStatementInLoop.ts.html +0 -163
  75. package/coverage/lcov-report/src/main/rules/DuplicateDMLOperation.ts.html +0 -334
  76. package/coverage/lcov-report/src/main/rules/FlowDescription.ts.html +0 -184
  77. package/coverage/lcov-report/src/main/rules/FlowName.ts.html +0 -229
  78. package/coverage/lcov-report/src/main/rules/GetRecordAllFields.ts.html +0 -280
  79. package/coverage/lcov-report/src/main/rules/HardcodedId.ts.html +0 -238
  80. package/coverage/lcov-report/src/main/rules/HardcodedSecret.ts.html +0 -238
  81. package/coverage/lcov-report/src/main/rules/HardcodedUrl.ts.html +0 -247
  82. package/coverage/lcov-report/src/main/rules/InactiveFlow.ts.html +0 -184
  83. package/coverage/lcov-report/src/main/rules/MissingFaultPath.ts.html +0 -397
  84. package/coverage/lcov-report/src/main/rules/MissingFilterRecordTrigger.ts.html +0 -229
  85. package/coverage/lcov-report/src/main/rules/MissingMetadataDescription.ts.html +0 -211
  86. package/coverage/lcov-report/src/main/rules/MissingNullHandler.ts.html +0 -460
  87. package/coverage/lcov-report/src/main/rules/MissingRecordTriggerFilter.ts.html +0 -235
  88. package/coverage/lcov-report/src/main/rules/ProcessBuilder.ts.html +0 -190
  89. package/coverage/lcov-report/src/main/rules/RecordIdAsString.ts.html +0 -274
  90. package/coverage/lcov-report/src/main/rules/RecursiveAfterUpdate.ts.html +0 -364
  91. package/coverage/lcov-report/src/main/rules/SOQLQueryInLoop.ts.html +0 -160
  92. package/coverage/lcov-report/src/main/rules/SameRecordFieldUpdates.ts.html +0 -283
  93. package/coverage/lcov-report/src/main/rules/TransformInsteadOfLoop.ts.html +0 -250
  94. package/coverage/lcov-report/src/main/rules/TriggerOrder.ts.html +0 -238
  95. package/coverage/lcov-report/src/main/rules/UnconnectedElement.ts.html +0 -178
  96. package/coverage/lcov-report/src/main/rules/UnsafeRunningContext.ts.html +0 -226
  97. package/coverage/lcov-report/src/main/rules/UnusedVariable.ts.html +0 -283
  98. package/coverage/lcov-report/src/main/rules/index.html +0 -521
  99. package/coverage/lcov-report/src/main/store/DefaultRuleStore.ts.html +0 -265
  100. package/coverage/lcov-report/src/main/store/RuleRegistry.ts.html +0 -118
  101. package/coverage/lcov-report/src/main/store/index.html +0 -116
  102. package/coverage/lcov.info +0 -6261
  103. package/eslint.config.mjs +0 -36
  104. package/jest.config.cjs +0 -32
  105. package/jest.env-setup.js +0 -101
  106. package/lint-staged.config.mjs +0 -8
  107. package/prettier.config.mjs +0 -5
  108. package/src/index.ts +0 -52
  109. package/src/main/config/NodeIcons.ts +0 -98
  110. package/src/main/config/RegexAdapter.ts +0 -98
  111. package/src/main/config/RuleRegistry.ts +0 -188
  112. package/src/main/config/VariableIcons.ts +0 -57
  113. package/src/main/enums/MetadataTypes.ts +0 -6
  114. package/src/main/interfaces/IExceptions.ts +0 -6
  115. package/src/main/interfaces/IRuleConfig.ts +0 -6
  116. package/src/main/interfaces/IRuleDefinition.ts +0 -15
  117. package/src/main/interfaces/IRuleOptions.ts +0 -5
  118. package/src/main/interfaces/IRulesConfig.ts +0 -17
  119. package/src/main/internals/internals.ts +0 -35
  120. package/src/main/libs/BuildFlow.ts +0 -14
  121. package/src/main/libs/Compiler.ts +0 -53
  122. package/src/main/libs/ExportDetails.ts +0 -58
  123. package/src/main/libs/ExportDiagram.ts +0 -83
  124. package/src/main/libs/ExportSarif.ts +0 -92
  125. package/src/main/libs/FixFlows.ts +0 -61
  126. package/src/main/libs/GetRuleDefinitions.ts +0 -64
  127. package/src/main/libs/ParseFlows.ts +0 -34
  128. package/src/main/libs/RuleDocumentation.ts +0 -35
  129. package/src/main/libs/ScanFlows.ts +0 -142
  130. package/src/main/models/FlatViolation.ts +0 -16
  131. package/src/main/models/Flow.ts +0 -325
  132. package/src/main/models/FlowAttribute.ts +0 -11
  133. package/src/main/models/FlowElement.ts +0 -16
  134. package/src/main/models/FlowElementConnector.ts +0 -28
  135. package/src/main/models/FlowGraph.ts +0 -530
  136. package/src/main/models/FlowMetadata.ts +0 -8
  137. package/src/main/models/FlowNode.ts +0 -390
  138. package/src/main/models/FlowResource.ts +0 -8
  139. package/src/main/models/FlowType.ts +0 -53
  140. package/src/main/models/FlowVariable.ts +0 -157
  141. package/src/main/models/LoopRuleCommon.ts +0 -51
  142. package/src/main/models/ParsedFlow.ts +0 -13
  143. package/src/main/models/RuleCommon.ts +0 -120
  144. package/src/main/models/RuleInfo.ts +0 -54
  145. package/src/main/models/RuleResult.ts +0 -29
  146. package/src/main/models/ScanResult.ts +0 -12
  147. package/src/main/models/Violation.ts +0 -78
  148. package/src/main/rules/APIVersion.ts +0 -93
  149. package/src/main/rules/ActionCallsInLoop.ts +0 -25
  150. package/src/main/rules/AutoLayout.ts +0 -46
  151. package/src/main/rules/CopyAPIName.ts +0 -31
  152. package/src/main/rules/CyclomaticComplexity.ts +0 -70
  153. package/src/main/rules/DMLStatementInLoop.ts +0 -26
  154. package/src/main/rules/DuplicateDMLOperation.ts +0 -83
  155. package/src/main/rules/FlowDescription.ts +0 -34
  156. package/src/main/rules/FlowName.ts +0 -49
  157. package/src/main/rules/GetRecordAllFields.ts +0 -65
  158. package/src/main/rules/HardcodedId.ts +0 -51
  159. package/src/main/rules/HardcodedSecret.ts +0 -51
  160. package/src/main/rules/HardcodedUrl.ts +0 -54
  161. package/src/main/rules/InactiveFlow.ts +0 -33
  162. package/src/main/rules/MissingFaultPath.ts +0 -105
  163. package/src/main/rules/MissingMetadataDescription.ts +0 -42
  164. package/src/main/rules/MissingNullHandler.ts +0 -126
  165. package/src/main/rules/MissingRecordTriggerFilter.ts +0 -51
  166. package/src/main/rules/ProcessBuilder.ts +0 -35
  167. package/src/main/rules/RecordIdAsString.ts +0 -64
  168. package/src/main/rules/RecursiveAfterUpdate.ts +0 -94
  169. package/src/main/rules/SOQLQueryInLoop.ts +0 -26
  170. package/src/main/rules/SameRecordFieldUpdates.ts +0 -66
  171. package/src/main/rules/TransformInsteadOfLoop.ts +0 -56
  172. package/src/main/rules/TriggerOrder.ts +0 -51
  173. package/src/main/rules/UnconnectedElement.ts +0 -32
  174. package/src/main/rules/UnsafeRunningContext.ts +0 -47
  175. package/src/main/rules/UnusedVariable.ts +0 -66
  176. package/stryker.config.mjs +0 -23
  177. package/tests/APIVersion.test.ts +0 -87
  178. package/tests/AutoLayout.test.ts +0 -41
  179. package/tests/Config.test.ts +0 -122
  180. package/tests/ConfigBetaMode.test.ts +0 -26
  181. package/tests/CopyAPIName.test.ts +0 -45
  182. package/tests/CyclomaticComplexity.test.ts +0 -125
  183. package/tests/DMLStatementInLoop.test.ts +0 -32
  184. package/tests/DuplicateDMLOperation.test.ts +0 -43
  185. package/tests/EnabledFalse.test.ts +0 -63
  186. package/tests/Exceptions.test.ts +0 -815
  187. package/tests/ExportSarif.test.ts +0 -62
  188. package/tests/FlowDescription.test.ts +0 -44
  189. package/tests/FlowDocumentation.test.ts +0 -74
  190. package/tests/FlowName.test.ts +0 -61
  191. package/tests/GetRecordElementAllFields.test.ts +0 -182
  192. package/tests/HardcodedId.test.ts +0 -16
  193. package/tests/HardcodedSecret.test.ts +0 -32
  194. package/tests/HardcodedUrl.test.ts +0 -253
  195. package/tests/InactiveFlow.test.ts +0 -103
  196. package/tests/MissingFaultPath.test.ts +0 -52
  197. package/tests/MissingMetadataDescription.test.ts +0 -25
  198. package/tests/MissingNullHandler.test.ts +0 -45
  199. package/tests/MissingRecordTriggerFilter.test.ts +0 -54
  200. package/tests/RecordIdAsString.test.ts +0 -60
  201. package/tests/RecursiveAfterUpdate.test.ts +0 -183
  202. package/tests/SOQLQueryInLoop.test.ts +0 -33
  203. package/tests/SameRecordFieldUpdates.test.ts +0 -205
  204. package/tests/SanityTest.test.ts +0 -15
  205. package/tests/TransformInsteadOfLoop.test.ts +0 -33
  206. package/tests/TriggerOrder.test.ts +0 -112
  207. package/tests/UnconnectedElement.test.ts +0 -76
  208. package/tests/UnsafeRunningContext.test.ts +0 -46
  209. package/tests/UnusedVariable.test.ts +0 -59
  210. package/tests/UnusedVariableExceptions.test.ts +0 -87
  211. package/tests/jsonfiles/MissingFaultPath_BeforeSave_Bypass.json +0 -128
  212. package/tests/jsonfiles/MissingFaultPath_WaitConditions.json +0 -102
  213. package/tests/jsonfiles/MissingFaultPath_WaitDate.json +0 -88
  214. package/tests/jsonfiles/MissingFaultPath_WaitDuration.json +0 -90
  215. package/tests/models/Flow.test.ts +0 -107
  216. package/tests/models/LoopRuleCommon.test.ts +0 -246
  217. package/tests/models/RuleCommon.test.ts +0 -41
  218. package/tsconfig.json +0 -28
  219. package/tsconfig.types.json +0 -26
  220. package/types/index.d.ts +0 -27
  221. package/types/index.d.ts.map +0 -1
  222. package/types/main/adapters/RegexAdapter.d.ts +0 -33
  223. package/types/main/adapters/RegexAdapter.d.ts.map +0 -1
  224. package/types/main/config/NodeIcons.d.ts +0 -25
  225. package/types/main/config/NodeIcons.d.ts.map +0 -1
  226. package/types/main/config/RegexAdapter.d.ts +0 -33
  227. package/types/main/config/RegexAdapter.d.ts.map +0 -1
  228. package/types/main/config/RuleRegistry.d.ts +0 -23
  229. package/types/main/config/RuleRegistry.d.ts.map +0 -1
  230. package/types/main/config/VariableIcons.d.ts +0 -26
  231. package/types/main/config/VariableIcons.d.ts.map +0 -1
  232. package/types/main/enums/MetadataTypes.d.ts +0 -7
  233. package/types/main/enums/MetadataTypes.d.ts.map +0 -1
  234. package/types/main/interfaces/IExceptions.d.ts +0 -6
  235. package/types/main/interfaces/IExceptions.d.ts.map +0 -1
  236. package/types/main/interfaces/IRuleConfig.d.ts +0 -7
  237. package/types/main/interfaces/IRuleConfig.d.ts.map +0 -1
  238. package/types/main/interfaces/IRuleDefinition.d.ts +0 -18
  239. package/types/main/interfaces/IRuleDefinition.d.ts.map +0 -1
  240. package/types/main/interfaces/IRuleOptions.d.ts +0 -5
  241. package/types/main/interfaces/IRuleOptions.d.ts.map +0 -1
  242. package/types/main/interfaces/IRulesConfig.d.ts +0 -16
  243. package/types/main/interfaces/IRulesConfig.d.ts.map +0 -1
  244. package/types/main/internals/internals.d.ts +0 -19
  245. package/types/main/internals/internals.d.ts.map +0 -1
  246. package/types/main/libs/BuildFlow.d.ts +0 -2
  247. package/types/main/libs/BuildFlow.d.ts.map +0 -1
  248. package/types/main/libs/Compiler.d.ts +0 -8
  249. package/types/main/libs/Compiler.d.ts.map +0 -1
  250. package/types/main/libs/ConvertFlowNodes.d.ts +0 -2
  251. package/types/main/libs/ConvertFlowNodes.d.ts.map +0 -1
  252. package/types/main/libs/DynamicRule.d.ts +0 -5
  253. package/types/main/libs/DynamicRule.d.ts.map +0 -1
  254. package/types/main/libs/ExportDetails.d.ts +0 -4
  255. package/types/main/libs/ExportDetails.d.ts.map +0 -1
  256. package/types/main/libs/ExportDiagram.d.ts +0 -42
  257. package/types/main/libs/ExportDiagram.d.ts.map +0 -1
  258. package/types/main/libs/ExportSarif.d.ts +0 -3
  259. package/types/main/libs/ExportSarif.d.ts.map +0 -1
  260. package/types/main/libs/FixFlows.d.ts +0 -4
  261. package/types/main/libs/FixFlows.d.ts.map +0 -1
  262. package/types/main/libs/GetRuleDefinitions.d.ts +0 -5
  263. package/types/main/libs/GetRuleDefinitions.d.ts.map +0 -1
  264. package/types/main/libs/ParseFlows.d.ts +0 -3
  265. package/types/main/libs/ParseFlows.d.ts.map +0 -1
  266. package/types/main/libs/RuleDocumentation.d.ts +0 -21
  267. package/types/main/libs/RuleDocumentation.d.ts.map +0 -1
  268. package/types/main/libs/ScanFlows.d.ts +0 -5
  269. package/types/main/libs/ScanFlows.d.ts.map +0 -1
  270. package/types/main/libs/exportAsDetails.d.ts +0 -4
  271. package/types/main/libs/exportAsDetails.d.ts.map +0 -1
  272. package/types/main/libs/exportAsSarif.d.ts +0 -3
  273. package/types/main/libs/exportAsSarif.d.ts.map +0 -1
  274. package/types/main/models/FlatViolation.d.ts +0 -16
  275. package/types/main/models/FlatViolation.d.ts.map +0 -1
  276. package/types/main/models/Flow.d.ts +0 -70
  277. package/types/main/models/Flow.d.ts.map +0 -1
  278. package/types/main/models/FlowAttribute.d.ts +0 -6
  279. package/types/main/models/FlowAttribute.d.ts.map +0 -1
  280. package/types/main/models/FlowElement.d.ts +0 -11
  281. package/types/main/models/FlowElement.d.ts.map +0 -1
  282. package/types/main/models/FlowElementConnector.d.ts +0 -16
  283. package/types/main/models/FlowElementConnector.d.ts.map +0 -1
  284. package/types/main/models/FlowGraph.d.ts +0 -86
  285. package/types/main/models/FlowGraph.d.ts.map +0 -1
  286. package/types/main/models/FlowMetadata.d.ts +0 -5
  287. package/types/main/models/FlowMetadata.d.ts.map +0 -1
  288. package/types/main/models/FlowNode.d.ts +0 -66
  289. package/types/main/models/FlowNode.d.ts.map +0 -1
  290. package/types/main/models/FlowResource.d.ts +0 -5
  291. package/types/main/models/FlowResource.d.ts.map +0 -1
  292. package/types/main/models/FlowType.d.ts +0 -24
  293. package/types/main/models/FlowType.d.ts.map +0 -1
  294. package/types/main/models/FlowVariable.d.ts +0 -64
  295. package/types/main/models/FlowVariable.d.ts.map +0 -1
  296. package/types/main/models/LoopRuleCommon.d.ts +0 -15
  297. package/types/main/models/LoopRuleCommon.d.ts.map +0 -1
  298. package/types/main/models/ParsedFlow.d.ts +0 -8
  299. package/types/main/models/ParsedFlow.d.ts.map +0 -1
  300. package/types/main/models/RuleCommon.d.ts +0 -58
  301. package/types/main/models/RuleCommon.d.ts.map +0 -1
  302. package/types/main/models/RuleInfo.d.ts +0 -50
  303. package/types/main/models/RuleInfo.d.ts.map +0 -1
  304. package/types/main/models/RuleResult.d.ts +0 -15
  305. package/types/main/models/RuleResult.d.ts.map +0 -1
  306. package/types/main/models/ScanResult.d.ts +0 -8
  307. package/types/main/models/ScanResult.d.ts.map +0 -1
  308. package/types/main/models/Violation.d.ts +0 -12
  309. package/types/main/models/Violation.d.ts.map +0 -1
  310. package/types/main/rules/APIVersion.d.ts +0 -10
  311. package/types/main/rules/APIVersion.d.ts.map +0 -1
  312. package/types/main/rules/ActionCallsInLoop.d.ts +0 -7
  313. package/types/main/rules/ActionCallsInLoop.d.ts.map +0 -1
  314. package/types/main/rules/AutoLayout.d.ts +0 -8
  315. package/types/main/rules/AutoLayout.d.ts.map +0 -1
  316. package/types/main/rules/CopyAPIName.d.ts +0 -8
  317. package/types/main/rules/CopyAPIName.d.ts.map +0 -1
  318. package/types/main/rules/CyclomaticComplexity.d.ts +0 -12
  319. package/types/main/rules/CyclomaticComplexity.d.ts.map +0 -1
  320. package/types/main/rules/DMLStatementInLoop.d.ts +0 -7
  321. package/types/main/rules/DMLStatementInLoop.d.ts.map +0 -1
  322. package/types/main/rules/DuplicateDMLOperation.d.ts +0 -9
  323. package/types/main/rules/DuplicateDMLOperation.d.ts.map +0 -1
  324. package/types/main/rules/FlowDescription.d.ts +0 -8
  325. package/types/main/rules/FlowDescription.d.ts.map +0 -1
  326. package/types/main/rules/FlowName.d.ts +0 -16
  327. package/types/main/rules/FlowName.d.ts.map +0 -1
  328. package/types/main/rules/GetRecordAllFields.d.ts +0 -8
  329. package/types/main/rules/GetRecordAllFields.d.ts.map +0 -1
  330. package/types/main/rules/HardcodedId.d.ts +0 -14
  331. package/types/main/rules/HardcodedId.d.ts.map +0 -1
  332. package/types/main/rules/HardcodedSecret.d.ts +0 -14
  333. package/types/main/rules/HardcodedSecret.d.ts.map +0 -1
  334. package/types/main/rules/HardcodedUrl.d.ts +0 -14
  335. package/types/main/rules/HardcodedUrl.d.ts.map +0 -1
  336. package/types/main/rules/InactiveFlow.d.ts +0 -8
  337. package/types/main/rules/InactiveFlow.d.ts.map +0 -1
  338. package/types/main/rules/MissingFaultPath.d.ts +0 -15
  339. package/types/main/rules/MissingFaultPath.d.ts.map +0 -1
  340. package/types/main/rules/MissingFilterRecordTrigger.d.ts +0 -8
  341. package/types/main/rules/MissingFilterRecordTrigger.d.ts.map +0 -1
  342. package/types/main/rules/MissingMetadataDescription.d.ts +0 -8
  343. package/types/main/rules/MissingMetadataDescription.d.ts.map +0 -1
  344. package/types/main/rules/MissingNullHandler.d.ts +0 -8
  345. package/types/main/rules/MissingNullHandler.d.ts.map +0 -1
  346. package/types/main/rules/MissingRecordTriggerFilter.d.ts +0 -8
  347. package/types/main/rules/MissingRecordTriggerFilter.d.ts.map +0 -1
  348. package/types/main/rules/ProcessBuilder.d.ts +0 -8
  349. package/types/main/rules/ProcessBuilder.d.ts.map +0 -1
  350. package/types/main/rules/RecordIdAsString.d.ts +0 -8
  351. package/types/main/rules/RecordIdAsString.d.ts.map +0 -1
  352. package/types/main/rules/RecursiveAfterUpdate.d.ts +0 -9
  353. package/types/main/rules/RecursiveAfterUpdate.d.ts.map +0 -1
  354. package/types/main/rules/SOQLQueryInLoop.d.ts +0 -7
  355. package/types/main/rules/SOQLQueryInLoop.d.ts.map +0 -1
  356. package/types/main/rules/SameRecordFieldUpdates.d.ts +0 -9
  357. package/types/main/rules/SameRecordFieldUpdates.d.ts.map +0 -1
  358. package/types/main/rules/TransformInsteadOfLoop.d.ts +0 -8
  359. package/types/main/rules/TransformInsteadOfLoop.d.ts.map +0 -1
  360. package/types/main/rules/TriggerOrder.d.ts +0 -8
  361. package/types/main/rules/TriggerOrder.d.ts.map +0 -1
  362. package/types/main/rules/UnconnectedElement.d.ts +0 -8
  363. package/types/main/rules/UnconnectedElement.d.ts.map +0 -1
  364. package/types/main/rules/UnsafeRunningContext.d.ts +0 -8
  365. package/types/main/rules/UnsafeRunningContext.d.ts.map +0 -1
  366. package/types/main/rules/UnusedVariable.d.ts +0 -8
  367. package/types/main/rules/UnusedVariable.d.ts.map +0 -1
  368. package/types/main/store/DefaultRuleStore.d.ts +0 -3
  369. package/types/main/store/DefaultRuleStore.d.ts.map +0 -1
  370. package/types/main/store/RuleRegistry.d.ts +0 -23
  371. package/types/main/store/RuleRegistry.d.ts.map +0 -1
  372. package/vite.config.ts +0 -33
  373. /package/{out/index.d.ts → index.d.ts} +0 -0
  374. /package/{out/index.js → index.js} +0 -0
  375. /package/{out/main → main}/config/NodeIcons.d.ts +0 -0
  376. /package/{out/main → main}/config/NodeIcons.js +0 -0
  377. /package/{out/main → main}/config/RegexAdapter.d.ts +0 -0
  378. /package/{out/main → main}/config/RegexAdapter.js +0 -0
  379. /package/{out/main → main}/config/RuleRegistry.d.ts +0 -0
  380. /package/{out/main → main}/config/RuleRegistry.js +0 -0
  381. /package/{out/main → main}/config/VariableIcons.d.ts +0 -0
  382. /package/{out/main → main}/config/VariableIcons.js +0 -0
  383. /package/{out/main → main}/enums/MetadataTypes.d.ts +0 -0
  384. /package/{out/main → main}/enums/MetadataTypes.js +0 -0
  385. /package/{out/main → main}/interfaces/IExceptions.d.ts +0 -0
  386. /package/{out/main → main}/interfaces/IExceptions.js +0 -0
  387. /package/{out/main → main}/interfaces/IRuleConfig.d.ts +0 -0
  388. /package/{out/main → main}/interfaces/IRuleConfig.js +0 -0
  389. /package/{out/main → main}/interfaces/IRuleDefinition.d.ts +0 -0
  390. /package/{out/main → main}/interfaces/IRuleDefinition.js +0 -0
  391. /package/{out/main → main}/interfaces/IRuleOptions.d.ts +0 -0
  392. /package/{out/main → main}/interfaces/IRuleOptions.js +0 -0
  393. /package/{out/main → main}/interfaces/IRulesConfig.d.ts +0 -0
  394. /package/{out/main → main}/interfaces/IRulesConfig.js +0 -0
  395. /package/{out/main → main}/internals/internals.d.ts +0 -0
  396. /package/{out/main → main}/internals/internals.js +0 -0
  397. /package/{out/main → main}/libs/BuildFlow.d.ts +0 -0
  398. /package/{out/main → main}/libs/BuildFlow.js +0 -0
  399. /package/{out/main → main}/libs/Compiler.d.ts +0 -0
  400. /package/{out/main → main}/libs/Compiler.js +0 -0
  401. /package/{out/main → main}/libs/ExportDetails.d.ts +0 -0
  402. /package/{out/main → main}/libs/ExportDetails.js +0 -0
  403. /package/{out/main → main}/libs/ExportDiagram.d.ts +0 -0
  404. /package/{out/main → main}/libs/ExportDiagram.js +0 -0
  405. /package/{out/main → main}/libs/ExportSarif.d.ts +0 -0
  406. /package/{out/main → main}/libs/ExportSarif.js +0 -0
  407. /package/{out/main → main}/libs/FixFlows.d.ts +0 -0
  408. /package/{out/main → main}/libs/FixFlows.js +0 -0
  409. /package/{out/main → main}/libs/GetRuleDefinitions.d.ts +0 -0
  410. /package/{out/main → main}/libs/GetRuleDefinitions.js +0 -0
  411. /package/{out/main → main}/libs/ParseFlows.d.ts +0 -0
  412. /package/{out/main → main}/libs/ParseFlows.js +0 -0
  413. /package/{out/main → main}/libs/RuleDocumentation.d.ts +0 -0
  414. /package/{out/main → main}/libs/RuleDocumentation.js +0 -0
  415. /package/{out/main → main}/libs/ScanFlows.d.ts +0 -0
  416. /package/{out/main → main}/libs/ScanFlows.js +0 -0
  417. /package/{out/main → main}/models/FlatViolation.d.ts +0 -0
  418. /package/{out/main → main}/models/FlatViolation.js +0 -0
  419. /package/{out/main → main}/models/Flow.d.ts +0 -0
  420. /package/{out/main → main}/models/Flow.js +0 -0
  421. /package/{out/main → main}/models/FlowAttribute.d.ts +0 -0
  422. /package/{out/main → main}/models/FlowAttribute.js +0 -0
  423. /package/{out/main → main}/models/FlowElement.d.ts +0 -0
  424. /package/{out/main → main}/models/FlowElement.js +0 -0
  425. /package/{out/main → main}/models/FlowElementConnector.d.ts +0 -0
  426. /package/{out/main → main}/models/FlowElementConnector.js +0 -0
  427. /package/{out/main → main}/models/FlowGraph.d.ts +0 -0
  428. /package/{out/main → main}/models/FlowGraph.js +0 -0
  429. /package/{out/main → main}/models/FlowMetadata.d.ts +0 -0
  430. /package/{out/main → main}/models/FlowMetadata.js +0 -0
  431. /package/{out/main → main}/models/FlowNode.d.ts +0 -0
  432. /package/{out/main → main}/models/FlowNode.js +0 -0
  433. /package/{out/main → main}/models/FlowResource.d.ts +0 -0
  434. /package/{out/main → main}/models/FlowResource.js +0 -0
  435. /package/{out/main → main}/models/FlowType.d.ts +0 -0
  436. /package/{out/main → main}/models/FlowType.js +0 -0
  437. /package/{out/main → main}/models/FlowVariable.d.ts +0 -0
  438. /package/{out/main → main}/models/FlowVariable.js +0 -0
  439. /package/{out/main → main}/models/LoopRuleCommon.d.ts +0 -0
  440. /package/{out/main → main}/models/LoopRuleCommon.js +0 -0
  441. /package/{out/main → main}/models/ParsedFlow.d.ts +0 -0
  442. /package/{out/main → main}/models/ParsedFlow.js +0 -0
  443. /package/{out/main → main}/models/RuleCommon.d.ts +0 -0
  444. /package/{out/main → main}/models/RuleCommon.js +0 -0
  445. /package/{out/main → main}/models/RuleInfo.d.ts +0 -0
  446. /package/{out/main → main}/models/RuleInfo.js +0 -0
  447. /package/{out/main → main}/models/RuleResult.d.ts +0 -0
  448. /package/{out/main → main}/models/RuleResult.js +0 -0
  449. /package/{out/main → main}/models/ScanResult.d.ts +0 -0
  450. /package/{out/main → main}/models/ScanResult.js +0 -0
  451. /package/{out/main → main}/models/Violation.d.ts +0 -0
  452. /package/{out/main → main}/models/Violation.js +0 -0
  453. /package/{out/main → main}/rules/APIVersion.d.ts +0 -0
  454. /package/{out/main → main}/rules/APIVersion.js +0 -0
  455. /package/{out/main → main}/rules/ActionCallsInLoop.d.ts +0 -0
  456. /package/{out/main → main}/rules/ActionCallsInLoop.js +0 -0
  457. /package/{out/main → main}/rules/AutoLayout.d.ts +0 -0
  458. /package/{out/main → main}/rules/AutoLayout.js +0 -0
  459. /package/{out/main → main}/rules/CopyAPIName.d.ts +0 -0
  460. /package/{out/main → main}/rules/CopyAPIName.js +0 -0
  461. /package/{out/main → main}/rules/CyclomaticComplexity.d.ts +0 -0
  462. /package/{out/main → main}/rules/CyclomaticComplexity.js +0 -0
  463. /package/{out/main → main}/rules/DMLStatementInLoop.d.ts +0 -0
  464. /package/{out/main → main}/rules/DMLStatementInLoop.js +0 -0
  465. /package/{out/main → main}/rules/DuplicateDMLOperation.d.ts +0 -0
  466. /package/{out/main → main}/rules/DuplicateDMLOperation.js +0 -0
  467. /package/{out/main → main}/rules/FlowDescription.d.ts +0 -0
  468. /package/{out/main → main}/rules/FlowDescription.js +0 -0
  469. /package/{out/main → main}/rules/FlowName.d.ts +0 -0
  470. /package/{out/main → main}/rules/FlowName.js +0 -0
  471. /package/{out/main → main}/rules/GetRecordAllFields.d.ts +0 -0
  472. /package/{out/main → main}/rules/GetRecordAllFields.js +0 -0
  473. /package/{out/main → main}/rules/HardcodedId.d.ts +0 -0
  474. /package/{out/main → main}/rules/HardcodedId.js +0 -0
  475. /package/{out/main → main}/rules/HardcodedSecret.d.ts +0 -0
  476. /package/{out/main → main}/rules/HardcodedSecret.js +0 -0
  477. /package/{out/main → main}/rules/HardcodedUrl.d.ts +0 -0
  478. /package/{out/main → main}/rules/HardcodedUrl.js +0 -0
  479. /package/{out/main → main}/rules/InactiveFlow.d.ts +0 -0
  480. /package/{out/main → main}/rules/InactiveFlow.js +0 -0
  481. /package/{out/main → main}/rules/MissingFaultPath.d.ts +0 -0
  482. /package/{out/main → main}/rules/MissingFaultPath.js +0 -0
  483. /package/{out/main → main}/rules/MissingMetadataDescription.d.ts +0 -0
  484. /package/{out/main → main}/rules/MissingMetadataDescription.js +0 -0
  485. /package/{out/main → main}/rules/MissingNullHandler.d.ts +0 -0
  486. /package/{out/main → main}/rules/MissingNullHandler.js +0 -0
  487. /package/{out/main → main}/rules/MissingRecordTriggerFilter.d.ts +0 -0
  488. /package/{out/main → main}/rules/MissingRecordTriggerFilter.js +0 -0
  489. /package/{out/main → main}/rules/ProcessBuilder.d.ts +0 -0
  490. /package/{out/main → main}/rules/ProcessBuilder.js +0 -0
  491. /package/{out/main → main}/rules/RecordIdAsString.d.ts +0 -0
  492. /package/{out/main → main}/rules/RecordIdAsString.js +0 -0
  493. /package/{out/main → main}/rules/RecursiveAfterUpdate.d.ts +0 -0
  494. /package/{out/main → main}/rules/RecursiveAfterUpdate.js +0 -0
  495. /package/{out/main → main}/rules/SOQLQueryInLoop.d.ts +0 -0
  496. /package/{out/main → main}/rules/SOQLQueryInLoop.js +0 -0
  497. /package/{out/main → main}/rules/SameRecordFieldUpdates.d.ts +0 -0
  498. /package/{out/main → main}/rules/SameRecordFieldUpdates.js +0 -0
  499. /package/{out/main → main}/rules/TransformInsteadOfLoop.d.ts +0 -0
  500. /package/{out/main → main}/rules/TransformInsteadOfLoop.js +0 -0
  501. /package/{out/main → main}/rules/TriggerOrder.d.ts +0 -0
  502. /package/{out/main → main}/rules/TriggerOrder.js +0 -0
  503. /package/{out/main → main}/rules/UnconnectedElement.d.ts +0 -0
  504. /package/{out/main → main}/rules/UnconnectedElement.js +0 -0
  505. /package/{out/main → main}/rules/UnsafeRunningContext.d.ts +0 -0
  506. /package/{out/main → main}/rules/UnsafeRunningContext.js +0 -0
  507. /package/{out/main → main}/rules/UnusedVariable.d.ts +0 -0
  508. /package/{out/main → main}/rules/UnusedVariable.js +0 -0
@@ -1,35 +0,0 @@
1
- import * as core from "../internals/internals";
2
- import { RuleCommon } from "../models/RuleCommon";
3
- import { IRuleDefinition } from "../interfaces/IRuleDefinition";
4
-
5
- export class ProcessBuilder extends RuleCommon implements IRuleDefinition {
6
- constructor() {
7
- super({
8
- ruleId: "process-builder-usage",
9
- category: "problem",
10
- name: "ProcessBuilder",
11
- label: "Process Builder",
12
- description: "Process Builder is retired. Continuing to use it increases maintenance overhead and risks future compatibility issues. Migrating automation to Flow reduces risk and improves maintainability.",
13
- summary: "Process Builder is retired, migrate to Flow",
14
- supportedTypes: core.FlowType.processBuilder,
15
- docRefs: [
16
- {
17
- label: "Process Builder Retirement",
18
- path: "https://help.salesforce.com/s/articleView?id=000389396&type=1",
19
- },
20
- ],
21
- }, { severity: "error" });
22
- }
23
-
24
- protected check(
25
- flow: core.Flow,
26
- _options: object | undefined,
27
- _suppressions: Set<string>
28
- ): core.Violation[] {
29
- return [
30
- new core.Violation(
31
- new core.FlowAttribute("Workflow", "processType", "== Workflow")
32
- ),
33
- ];
34
- }
35
- }
@@ -1,64 +0,0 @@
1
- import * as core from "../internals/internals";
2
- import { RuleCommon } from "../models/RuleCommon";
3
- import { IRuleDefinition } from "../interfaces/IRuleDefinition";
4
-
5
- export class RecordIdAsString extends RuleCommon implements IRuleDefinition {
6
- constructor() {
7
- super({
8
- ruleId: "record-id-as-string",
9
- category: "suggestion",
10
- name: "RecordIdAsString",
11
- label: "Record ID as String",
12
- description: "Flows that use a String variable for a record ID instead of receiving the full record introduce unnecessary complexity and additional Get Records queries. Using the complete record simplifies the Flow and improves performance.",
13
- summary: "String record IDs add complexity and queries",
14
- supportedTypes: [
15
- ...core.FlowType.visualTypes,
16
- core.FlowType.autolaunchedType,
17
- ],
18
- docRefs: [
19
- {
20
- label: "Screen Flow Distribution",
21
- path: "https://help.salesforce.com/s/articleView?id=sf.flow_distribute_screen.htm",
22
- },
23
- ],
24
- }, { severity: "note" });
25
- }
26
-
27
- protected check(
28
- flow: core.Flow,
29
- _options: object | undefined,
30
- _suppressions: Set<string>
31
- ): core.Violation[] {
32
- const violations: core.Violation[] = [];
33
-
34
- // Skip record-triggered flows - they don't support this pattern
35
- const triggerType = this.getStartProperty(flow, 'triggerType');
36
- const isRecordTriggered =
37
- triggerType === "RecordAfterSave" ||
38
- triggerType === "RecordBeforeDelete" ||
39
- triggerType === "RecordBeforeSave";
40
-
41
- if (isRecordTriggered) {
42
- return violations;
43
- }
44
-
45
- // Find input variables named "recordId" (case-insensitive)
46
- const variables = flow.elements?.filter(
47
- (e) => e.subtype === "variables"
48
- ) as core.FlowVariable[];
49
-
50
- for (const variable of variables) {
51
- const varElement = variable.element as any;
52
-
53
- if (
54
- (varElement.isInput === true || varElement.isInput === "true") &&
55
- variable.name.toLowerCase() === "recordid" &&
56
- varElement.dataType === "String"
57
- ) {
58
- violations.push(new core.Violation(variable));
59
- }
60
- }
61
-
62
- return violations;
63
- }
64
- }
@@ -1,94 +0,0 @@
1
- import * as core from "../internals/internals";
2
- import { RuleCommon } from "../models/RuleCommon";
3
- import { IRuleDefinition } from "../interfaces/IRuleDefinition";
4
- export class RecursiveAfterUpdate extends RuleCommon implements IRuleDefinition {
5
- protected qualifiedRecordTriggerTypes: Set<string> = new Set<string>([
6
- "Create",
7
- "CreateAndUpdate",
8
- "Update",
9
- ]);
10
- constructor() {
11
- super(
12
- {
13
- ruleId: "recursive-record-update",
14
- category: "problem",
15
- description: "After-save Flows that update the same record can trigger recursion, causing unintended behavior or performance issues. Avoid updating the triggering record in after-save Flows; use before-save Flows instead to prevent recursion.",
16
- summary: "After-save updates to same record trigger recursion",
17
- docRefs: [
18
- {
19
- label: "Learn about same record field updates",
20
- path: "https://architect.salesforce.com/decision-guides/trigger-automation#Same_Record_Field_Updates",
21
- },
22
- ],
23
- label: "Recursive After Update",
24
- name: "RecursiveAfterUpdate",
25
- supportedTypes: [...core.FlowType.backEndTypes],
26
- },
27
- { severity: "warning" }
28
- );
29
- }
30
- protected check(
31
- flow: core.Flow,
32
- _options: object | undefined,
33
- suppressions: Set<string>
34
- ): core.Violation[] {
35
- const results: core.Violation[] = [];
36
-
37
- const triggerType = this.getStartProperty(flow, 'triggerType');
38
- const recordTriggerType = this.getStartProperty(flow, 'recordTriggerType');
39
-
40
- const isAfterSave = triggerType === "RecordAfterSave";
41
- const isQualifiedTriggerTypes = this.qualifiedRecordTriggerTypes.has(recordTriggerType);
42
-
43
- if (!isAfterSave || !isQualifiedTriggerTypes) {
44
- return results;
45
- }
46
- const potentialElements = flow.elements?.filter(
47
- (node) => node.subtype === "recordUpdates"
48
- ) as core.FlowNode[];
49
- if (potentialElements == null || typeof potentialElements[Symbol.iterator] !== "function") {
50
- return results;
51
- }
52
- // === $Record updates ===
53
- for (const node of potentialElements) {
54
- if (
55
- typeof node.element === "object" &&
56
- "inputReference" in node.element &&
57
- node.element.inputReference === "$Record"
58
- ) {
59
- if (!suppressions.has(node.name)) {
60
- results.push(new core.Violation(node));
61
- }
62
- }
63
- }
64
- // === Lookup → same object type updates ===
65
- const flowObject = this.getStartProperty(flow, 'object');
66
- const lookupElementsWithTheSameObjectType = flow.elements
67
- ?.filter(
68
- (node) =>
69
- node.subtype === "recordLookups" &&
70
- typeof node.element === "object" &&
71
- "object" in node.element &&
72
- flowObject === node.element["object"]
73
- )
74
- ?.map((node) => node.name);
75
- if (
76
- lookupElementsWithTheSameObjectType == null ||
77
- typeof lookupElementsWithTheSameObjectType[Symbol.iterator] !== "function"
78
- ) {
79
- return results;
80
- }
81
- for (const node of potentialElements) {
82
- if (
83
- typeof node.element === "object" &&
84
- "inputReference" in node.element &&
85
- lookupElementsWithTheSameObjectType.includes(node.element.inputReference as string)
86
- ) {
87
- if (!suppressions.has(node.name)) {
88
- results.push(new core.Violation(node));
89
- }
90
- }
91
- }
92
- return results;
93
- }
94
- }
@@ -1,26 +0,0 @@
1
- import { FlowType, IRuleDefinition } from "../internals/internals";
2
- import { LoopRuleCommon } from "../models/LoopRuleCommon";
3
-
4
- export class SOQLQueryInLoop extends LoopRuleCommon implements IRuleDefinition {
5
- constructor() {
6
- super({
7
- ruleId: "soql-in-loop",
8
- category: "problem",
9
- description: "Running SOQL queries inside a loop can rapidly exceed query limits and severely degrade performance. Queries should be executed once, with results reused throughout the loop.",
10
- summary: "SOQL queries inside loop risk governor limits",
11
- docRefs: [
12
- {
13
- label: "Flow Best Practices",
14
- path: "https://help.salesforce.com/s/articleView?id=sf.flow_prep_bestpractices.htm&type=5",
15
- },
16
- ],
17
- label: "SOQL Query In A Loop",
18
- name: "SOQLQueryInLoop",
19
- supportedTypes: FlowType.backEndTypes,
20
- }, { severity: "error" });
21
- }
22
-
23
- protected getStatementTypes(): string[] {
24
- return ["recordLookups"];
25
- }
26
- }
@@ -1,66 +0,0 @@
1
- import * as core from "../internals/internals";
2
- import { RuleCommon } from "../models/RuleCommon";
3
- import { IRuleDefinition } from "../interfaces/IRuleDefinition";
4
-
5
- export class SameRecordFieldUpdates extends RuleCommon implements IRuleDefinition {
6
- protected qualifiedRecordTriggerTypes: Set<string> = new Set<string>([
7
- "Create",
8
- "Update",
9
- "CreateAndUpdate",
10
- ]);
11
-
12
- constructor() {
13
- super(
14
- {
15
- ruleId: "same-record-field-updates",
16
- category: "suggestion",
17
- name: "SameRecordFieldUpdates",
18
- label: "Same Record Field Updates",
19
- description: "Before-save Flows can safely update the triggering record directly via $Record, applying changes efficiently without extra DML operations. Using before-save updates improves performance",
20
- summary: "Before-save Flows can update $Record directly",
21
- supportedTypes: [...core.FlowType.backEndTypes],
22
- docRefs: [
23
- {
24
- label: "Learn about same record field updates",
25
- path: "https://architect.salesforce.com/decision-guides/trigger-automation#Same_Record_Field_Updates",
26
- },
27
- ],
28
- },
29
- { severity: "warning" }
30
- );
31
- }
32
-
33
- protected check(
34
- flow: core.Flow,
35
- _options: object | undefined,
36
- _suppressions: Set<string>
37
- ): core.Violation[] {
38
- const results: core.Violation[] = [];
39
- const triggerType = this.getStartProperty(flow, 'triggerType');
40
- const recordTriggerType = this.getStartProperty(flow, 'recordTriggerType');
41
-
42
- const isBeforeSaveType = triggerType === "RecordBeforeSave";
43
- const isQualifiedTriggerTypes = this.qualifiedRecordTriggerTypes.has(recordTriggerType);
44
- if (!isBeforeSaveType || !isQualifiedTriggerTypes) {
45
- return results;
46
- }
47
-
48
- const potentialElements = flow.elements?.filter(
49
- (node) => node.subtype === "recordUpdates"
50
- ) as core.FlowNode[];
51
-
52
- if (!potentialElements) return results;
53
-
54
- for (const node of potentialElements) {
55
- if (
56
- typeof node.element === "object" &&
57
- "inputReference" in node.element &&
58
- node.element.inputReference === "$Record"
59
- ) {
60
- results.push(new core.Violation(node));
61
- }
62
- }
63
-
64
- return results;
65
- }
66
- }
@@ -1,56 +0,0 @@
1
- import * as core from "../internals/internals";
2
- import { RuleCommon } from "../models/RuleCommon";
3
- import { IRuleDefinition } from "../interfaces/IRuleDefinition";
4
-
5
- export class TransformInsteadOfLoop extends RuleCommon implements IRuleDefinition {
6
- constructor() {
7
- super({
8
- ruleId: "transform-instead-of-loop",
9
- category: "suggestion",
10
- name: "TransformInsteadOfLoop",
11
- label: "Transform Instead of Loop",
12
- description: "Loop elements that perform direct Assignments on each item can slow down Flows. Using Transform elements allows bulk operations on collections, improving performance and reducing complexity.",
13
- summary: "Transform elements enable faster bulk operations",
14
- supportedTypes: core.FlowType.allTypes(),
15
- docRefs: [
16
- {
17
- label: "Transform Multiple Records - Trailhead",
18
- path: "https://trailhead.salesforce.com/content/learn/modules/multirecord-elements-and-transforms-in-flows/transform-multiple-records",
19
- },
20
- ],
21
- }, { severity: "note" });
22
- }
23
-
24
- protected check(
25
- flow: core.Flow,
26
- _options: object | undefined,
27
- _suppressions: Set<string>
28
- ): core.Violation[] {
29
- const violations: core.Violation[] = [];
30
-
31
- const triggerType = this.getStartProperty(flow, 'triggerType');
32
- const isRecordBeforeSave = triggerType === "RecordBeforeSave";
33
- if (isRecordBeforeSave) {
34
- return violations;
35
- }
36
-
37
- const loops = flow.graph.getLoopNodes();
38
-
39
- for (const loopNode of loops) {
40
- // Get elements that the loop connects to (includes nextValueConnector)
41
- const nextElements = flow.graph.getNextElements(loopNode.name);
42
-
43
- // Check if any directly connected element is an assignment
44
- for (const nextElementName of nextElements) {
45
- const nextElement = flow.graph.getNode(nextElementName);
46
-
47
- if (nextElement?.subtype === "assignments") {
48
- violations.push(new core.Violation(loopNode));
49
- break; // Only report once per loop
50
- }
51
- }
52
- }
53
-
54
- return violations;
55
- }
56
- }
@@ -1,51 +0,0 @@
1
- import * as core from "../internals/internals";
2
- import { RuleCommon } from "../models/RuleCommon";
3
- import { IRuleDefinition } from "../interfaces/IRuleDefinition";
4
-
5
- export class TriggerOrder extends RuleCommon implements IRuleDefinition {
6
-
7
- constructor() {
8
- super(
9
- {
10
- ruleId: "unspecified-trigger-order",
11
- category: "suggestion",
12
- name: "TriggerOrder",
13
- label: "Missing Trigger Order",
14
- description: "Record-triggered Flows without a specified Trigger Order may execute in an unpredictable sequence. Setting a Trigger Order ensures your Flows run in the intended order.",
15
- summary: "Trigger Order ensures predictable execution sequence",
16
- supportedTypes: [core.FlowType.autolaunchedType],
17
- docRefs: [
18
- {
19
- label: "Learn more about flow ordering orchestration",
20
- path: "https://architect.salesforce.com/decision-guides/trigger-automation#Ordering___Orchestration",
21
- },
22
- ],
23
- },
24
- { severity: "note" }
25
- );
26
- }
27
-
28
- protected check(
29
- flow: core.Flow,
30
- _options: object | undefined,
31
- _suppressions: Set<string>
32
- ): core.Violation[] {
33
-
34
- const startObject = this.getStartProperty(flow, "object");
35
- // If there's no `object` on the start node, this is NOT a record-triggered flow
36
- if (!startObject) {
37
- return [];
38
- }
39
-
40
- // This *is* a record-triggered flow → should have triggerOrder
41
- if (!flow.triggerOrder) {
42
- return [
43
- new core.Violation(
44
- new core.FlowAttribute("TriggerOrder", "TriggerOrder", "10, 20, 30 ...")
45
- ),
46
- ];
47
- }
48
-
49
- return [];
50
- }
51
- }
@@ -1,32 +0,0 @@
1
- import * as core from "../internals/internals";
2
- import { RuleCommon } from "../models/RuleCommon";
3
- import { IRuleDefinition } from "../interfaces/IRuleDefinition";
4
- export class UnconnectedElement extends RuleCommon implements IRuleDefinition {
5
- constructor() {
6
- super({
7
- ruleId: "unreachable-element",
8
- category: "layout",
9
- description: "Unconnected elements never execute and add unnecessary clutter. Remove or connect unused Flow elements to keep Flows clean and efficient.",
10
- summary: "Unconnected elements add clutter without executing",
11
- docRefs: [],
12
- label: "Unreachable Element",
13
- name: "UnconnectedElement",
14
- supportedTypes: [...core.FlowType.backEndTypes, ...core.FlowType.visualTypes],
15
- });
16
- }
17
- protected check(
18
- flow: core.Flow,
19
- _options: object | undefined,
20
- suppressions: Set<string>
21
- ): core.Violation[] {
22
- const connectedElements: Set<string> = flow.graph?.getReachableElements() || new Set<string>();
23
-
24
- const flowElements: core.FlowNode[] = flow.elements.filter(
25
- (node): node is core.FlowNode => node instanceof core.FlowNode
26
- );
27
- const unconnectedElements: core.FlowNode[] = flowElements.filter(
28
- (element) => !connectedElements.has(element.name) && !suppressions.has(element.name)
29
- );
30
- return unconnectedElements.map((det) => new core.Violation(det));
31
- }
32
- }
@@ -1,47 +0,0 @@
1
- import * as core from "../internals/internals";
2
- import { RuleCommon } from "../models/RuleCommon";
3
- import { IRuleDefinition } from "../interfaces/IRuleDefinition";
4
-
5
- export class UnsafeRunningContext extends RuleCommon implements IRuleDefinition {
6
- constructor() {
7
- super({
8
- ruleId: "unsafe-running-context",
9
- category: "problem",
10
- name: "UnsafeRunningContext",
11
- label: "Unsafe Running Context",
12
- description: "Flows configured to run in System Mode without Sharing grant access to all data, bypassing user permissions. Avoid this setting to prevent security risks and protect sensitive data.",
13
- summary: "System mode without sharing creates security risks",
14
- supportedTypes: [...core.FlowType.backEndTypes, ...core.FlowType.visualTypes],
15
- docRefs: [
16
- {
17
- label:
18
- "Learn about data safety when running flows in system context in Salesforce Help",
19
- path: "https://help.salesforce.com/s/articleView?id=sf.flow_distribute_context_data_safety_system_context.htm&type=5",
20
- },
21
- ],
22
- }, { severity: "error" });
23
- }
24
-
25
- protected check(
26
- flow: core.Flow,
27
- _options: object | undefined,
28
- _suppressions: Set<string>
29
- ): core.Violation[] {
30
- if (!("runInMode" in flow.xmldata)) {
31
- return [];
32
- }
33
-
34
- const runInMode: string = flow.xmldata.runInMode;
35
- const riskyMode: string = "SystemModeWithoutSharing";
36
-
37
- if (runInMode === riskyMode) {
38
- return [
39
- new core.Violation(
40
- new core.FlowAttribute(runInMode, "runInMode", `== ${riskyMode}`)
41
- )
42
- ];
43
- }
44
-
45
- return [];
46
- }
47
- }
@@ -1,66 +0,0 @@
1
- import * as core from "../internals/internals";
2
- import { RuleCommon } from "../models/RuleCommon";
3
- import { IRuleDefinition } from "../interfaces/IRuleDefinition";
4
-
5
- export class UnusedVariable extends RuleCommon implements IRuleDefinition {
6
- constructor() {
7
- super({
8
- ruleId: "unused-variable",
9
- category: "layout",
10
- name: "UnusedVariable",
11
- label: "Unused Variable",
12
- description: "Unused variables are never referenced and add unnecessary clutter. Remove them to keep Flows efficient and easy to maintain.",
13
- summary: "Unused variables add clutter and hurt maintainability",
14
- supportedTypes: [...core.FlowType.backEndTypes, ...core.FlowType.visualTypes],
15
- docRefs: [],
16
- });
17
- }
18
-
19
- protected check(
20
- flow: core.Flow,
21
- _options: object | undefined,
22
- _suppressions: Set<string>
23
- ): core.Violation[] {
24
- const variables = flow.elements.filter(
25
- (node) => node instanceof core.FlowVariable
26
- ) as core.FlowVariable[];
27
-
28
- const unusedVariables: core.FlowVariable[] = [];
29
-
30
- for (const variable of variables) {
31
- const variableName = variable.name;
32
-
33
- const nodeMatches = [
34
- ...JSON.stringify(flow.elements.filter((node) => node instanceof core.FlowNode)).matchAll(
35
- new RegExp(variableName, "gi")
36
- ),
37
- ].map((a) => a.index);
38
-
39
- if (nodeMatches.length > 0) continue;
40
-
41
- const resourceMatches = [
42
- ...JSON.stringify(flow.elements.filter((node) => node instanceof core.FlowResource)).matchAll(
43
- new RegExp(variableName, "gi")
44
- ),
45
- ].map((a) => a.index);
46
-
47
- if (resourceMatches.length > 0) continue;
48
-
49
- const insideCounter = [
50
- ...JSON.stringify(variable).matchAll(new RegExp(variable.name, "gi")),
51
- ].map((a) => a.index);
52
-
53
- const variableUsage = [
54
- ...JSON.stringify(flow.elements.filter((node) => node instanceof core.FlowVariable)).matchAll(
55
- new RegExp(variableName, "gi")
56
- ),
57
- ].map((a) => a.index);
58
-
59
- if (variableUsage.length === insideCounter.length) {
60
- unusedVariables.push(variable);
61
- }
62
- }
63
-
64
- return unusedVariables.map((variable) => new core.Violation(variable));
65
- }
66
- }
@@ -1,23 +0,0 @@
1
- // @ts-check
2
- /** @type {import('@stryker-mutator/api/core').PartialStrykerOptions} */
3
- const config = {
4
- _comment:
5
- "This config was generated using 'stryker init'. Please take a look at: https://stryker-mutator.io/docs/stryker-js/configuration/ for more information.",
6
- packageManager: "npm",
7
- reporters: ["html", "clear-text", "progress", "dashboard"],
8
- commandRunner: { command: "npm test" },
9
- testRunner: "jest",
10
- jest: {
11
- config: {
12
- testEnvironment: "node",
13
- },
14
- enableFindRelatedTests: true,
15
- },
16
- testRunnerNodeArgs: ["--experimental-vm-modules"],
17
- testRunner_comment:
18
- "Take a look at https://stryker-mutator.io/docs/stryker-js/jest-runner for information about the jest plugin.",
19
- coverageAnalysis: "perTest",
20
- mutate: ["src/**/*.ts", "!tests/**/*.test.ts"],
21
- ignoreStatic: true,
22
- };
23
- export default config;
@@ -1,87 +0,0 @@
1
- import * as core from "../src";
2
- import * as path from "path";
3
-
4
- import { describe, it, expect } from "@jest/globals";
5
-
6
- describe("APIVersion", () => {
7
- const example_uri = path.join(__dirname, "../../../example-flows/force-app/demo/Invalid_API_Version.flow-meta.xml");
8
- const fixed_uri = path.join(__dirname, "../../../example-flows/force-app/testing/Outdated_API_Version_Fixed.flow-meta.xml");
9
-
10
- it("should have a result when attribute is missing", async () => {
11
- const flows = await core.parse([example_uri]);
12
- const ruleConfig = {
13
- ruleMode: "isolated",
14
- rules: {
15
- APIVersion: {
16
- severity: "error",
17
- },
18
- },
19
- };
20
-
21
- const results: core.ScanResult[] = core.scan(flows, ruleConfig);
22
- expect(results[0].ruleResults).toHaveLength(1);
23
- expect(results[0].ruleResults[0].ruleName).toBe("APIVersion");
24
- expect(results[0].ruleResults[0].occurs).toBe(true);
25
- });
26
-
27
- it("should have a result when below configured threshold", async () => {
28
- const flows = await core.parse([example_uri]);
29
- const ruleConfig = {
30
- ruleMode: "isolated",
31
- rules: {
32
- APIVersion: {
33
- severity: "error",
34
- expression: ">55",
35
- },
36
- },
37
- };
38
-
39
- const results: core.ScanResult[] = core.scan(flows, ruleConfig);
40
- expect(results[0].ruleResults).toHaveLength(1);
41
- expect(results[0].ruleResults[0].ruleName).toBe("APIVersion");
42
- expect(results[0].ruleResults[0].occurs).toBe(true);
43
- });
44
-
45
- it("should have no result when version is meeting threshold", async () => {
46
- const flows = await core.parse([fixed_uri]);
47
- const ruleConfig = {
48
- ruleMode: "isolated",
49
- rules: {
50
- APIVersion: {
51
- severity: "error",
52
- expression: ">55",
53
- },
54
- },
55
- };
56
-
57
- const results: core.ScanResult[] = core.scan(flows, ruleConfig);
58
- expect(results[0].ruleResults).toHaveLength(1);
59
- expect(results[0].ruleResults[0].ruleName).toBe("APIVersion");
60
- expect(results[0].ruleResults[0].occurs).toBe(false);
61
- });
62
-
63
- it("should have a result when configured is more than what the file has", async () => {
64
- const flows = await core.parse([fixed_uri]);
65
- const ruleConfig = {
66
- ruleMode: "isolated",
67
- rules: {
68
- APIVersion: {
69
- severity: "error",
70
- expression: ">=60",
71
- },
72
- },
73
- };
74
-
75
- const results: core.ScanResult[] = core.scan(flows, ruleConfig);
76
- expect(results[0].ruleResults).toHaveLength(1);
77
- expect(results[0].ruleResults[0].ruleName).toBe("APIVersion");
78
- expect(results[0].ruleResults[0].occurs).toBe(true);
79
-
80
- const violations = results[0].ruleResults[0].details;
81
- if (violations.length > 0) {
82
- // ensure tag level line numbers are correct
83
- expect(violations[0].lineNumber).toBeDefined();
84
- expect(violations[0].lineNumber).toBeGreaterThan(1);
85
- }
86
- });
87
- });