@flow-scanner/lightning-flow-scanner-core 6.17.1 → 6.17.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 (508) hide show
  1. package/README.md +642 -0
  2. package/{types/main → main}/models/FlowGraph.d.ts +11 -1
  3. package/{out/main → main}/models/FlowGraph.js +18 -7
  4. package/{out/main → main}/rules/MissingRecordTriggerFilter.js +4 -2
  5. package/package.json +9 -58
  6. package/.husky/pre-commit +0 -1
  7. package/.husky/pre-push +0 -1
  8. package/.prettierignore +0 -5
  9. package/.swcrc +0 -26
  10. package/.turbo/turbo-build.log +0 -17
  11. package/.turbo/turbo-test.log +0 -144
  12. package/.turbo/turbo-vite$colon$dist.log +0 -21
  13. package/coverage/coverage-final.json +0 -63
  14. package/coverage/lcov-report/base.css +0 -224
  15. package/coverage/lcov-report/block-navigation.js +0 -87
  16. package/coverage/lcov-report/favicon.png +0 -0
  17. package/coverage/lcov-report/index.html +0 -236
  18. package/coverage/lcov-report/prettify.css +0 -1
  19. package/coverage/lcov-report/prettify.js +0 -2
  20. package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
  21. package/coverage/lcov-report/sorter.js +0 -210
  22. package/coverage/lcov-report/src/index.html +0 -116
  23. package/coverage/lcov-report/src/index.ts.html +0 -238
  24. package/coverage/lcov-report/src/main/adapters/RegexAdapter.ts.html +0 -118
  25. package/coverage/lcov-report/src/main/adapters/index.html +0 -116
  26. package/coverage/lcov-report/src/main/config/NodeIcons.ts.html +0 -376
  27. package/coverage/lcov-report/src/main/config/RuleRegistry.ts.html +0 -646
  28. package/coverage/lcov-report/src/main/config/VariableIcons.ts.html +0 -253
  29. package/coverage/lcov-report/src/main/config/index.html +0 -146
  30. package/coverage/lcov-report/src/main/enums/MetaType.ts.html +0 -100
  31. package/coverage/lcov-report/src/main/enums/MetadataType.ts.html +0 -103
  32. package/coverage/lcov-report/src/main/enums/MetadataTypes.ts.html +0 -100
  33. package/coverage/lcov-report/src/main/enums/index.html +0 -116
  34. package/coverage/lcov-report/src/main/interfaces/IRulesConfig.ts.html +0 -133
  35. package/coverage/lcov-report/src/main/interfaces/index.html +0 -116
  36. package/coverage/lcov-report/src/main/internals/index.html +0 -116
  37. package/coverage/lcov-report/src/main/internals/internals.ts.html +0 -190
  38. package/coverage/lcov-report/src/main/libs/BuildFlow.ts.html +0 -127
  39. package/coverage/lcov-report/src/main/libs/Compiler.ts.html +0 -241
  40. package/coverage/lcov-report/src/main/libs/ConvertFlowNodes.ts.html +0 -97
  41. package/coverage/lcov-report/src/main/libs/DynamicRule.ts.html +0 -118
  42. package/coverage/lcov-report/src/main/libs/ExportDetails.ts.html +0 -256
  43. package/coverage/lcov-report/src/main/libs/ExportDiagram.ts.html +0 -331
  44. package/coverage/lcov-report/src/main/libs/ExportSarif.ts.html +0 -358
  45. package/coverage/lcov-report/src/main/libs/FixFlows.ts.html +0 -265
  46. package/coverage/lcov-report/src/main/libs/GenerateMarkdown.ts.html +0 -331
  47. package/coverage/lcov-report/src/main/libs/GetRuleDefinitions.ts.html +0 -274
  48. package/coverage/lcov-report/src/main/libs/ParseFlows.ts.html +0 -184
  49. package/coverage/lcov-report/src/main/libs/RuleDocumentation.ts.html +0 -190
  50. package/coverage/lcov-report/src/main/libs/ScanFlows.ts.html +0 -508
  51. package/coverage/lcov-report/src/main/libs/exportAsDetails.ts.html +0 -160
  52. package/coverage/lcov-report/src/main/libs/exportAsSarif.ts.html +0 -346
  53. package/coverage/lcov-report/src/main/libs/index.html +0 -251
  54. package/coverage/lcov-report/src/main/models/FlatViolation.ts.html +0 -106
  55. package/coverage/lcov-report/src/main/models/Flow.ts.html +0 -1057
  56. package/coverage/lcov-report/src/main/models/FlowAttribute.ts.html +0 -115
  57. package/coverage/lcov-report/src/main/models/FlowElement.ts.html +0 -133
  58. package/coverage/lcov-report/src/main/models/FlowElementConnector.ts.html +0 -169
  59. package/coverage/lcov-report/src/main/models/FlowGraph.ts.html +0 -1672
  60. package/coverage/lcov-report/src/main/models/FlowMetadata.ts.html +0 -106
  61. package/coverage/lcov-report/src/main/models/FlowNode.ts.html +0 -1252
  62. package/coverage/lcov-report/src/main/models/FlowResource.ts.html +0 -106
  63. package/coverage/lcov-report/src/main/models/FlowType.ts.html +0 -244
  64. package/coverage/lcov-report/src/main/models/FlowVariable.ts.html +0 -553
  65. package/coverage/lcov-report/src/main/models/LoopRuleCommon.ts.html +0 -235
  66. package/coverage/lcov-report/src/main/models/ParsedFlow.ts.html +0 -121
  67. package/coverage/lcov-report/src/main/models/RuleCommon.ts.html +0 -442
  68. package/coverage/lcov-report/src/main/models/RuleResult.ts.html +0 -172
  69. package/coverage/lcov-report/src/main/models/ScanResult.ts.html +0 -121
  70. package/coverage/lcov-report/src/main/models/Violation.ts.html +0 -316
  71. package/coverage/lcov-report/src/main/models/index.html +0 -341
  72. package/coverage/lcov-report/src/main/rules/APIVersion.ts.html +0 -361
  73. package/coverage/lcov-report/src/main/rules/ActionCallsInLoop.ts.html +0 -157
  74. package/coverage/lcov-report/src/main/rules/AutoLayout.ts.html +0 -220
  75. package/coverage/lcov-report/src/main/rules/CopyAPIName.ts.html +0 -175
  76. package/coverage/lcov-report/src/main/rules/CyclomaticComplexity.ts.html +0 -292
  77. package/coverage/lcov-report/src/main/rules/DMLStatementInLoop.ts.html +0 -163
  78. package/coverage/lcov-report/src/main/rules/DuplicateDMLOperation.ts.html +0 -334
  79. package/coverage/lcov-report/src/main/rules/FlowDescription.ts.html +0 -184
  80. package/coverage/lcov-report/src/main/rules/FlowName.ts.html +0 -229
  81. package/coverage/lcov-report/src/main/rules/GetRecordAllFields.ts.html +0 -280
  82. package/coverage/lcov-report/src/main/rules/HardcodedId.ts.html +0 -238
  83. package/coverage/lcov-report/src/main/rules/HardcodedSecret.ts.html +0 -238
  84. package/coverage/lcov-report/src/main/rules/HardcodedUrl.ts.html +0 -247
  85. package/coverage/lcov-report/src/main/rules/InactiveFlow.ts.html +0 -184
  86. package/coverage/lcov-report/src/main/rules/MissingFaultPath.ts.html +0 -397
  87. package/coverage/lcov-report/src/main/rules/MissingFilterRecordTrigger.ts.html +0 -229
  88. package/coverage/lcov-report/src/main/rules/MissingMetadataDescription.ts.html +0 -211
  89. package/coverage/lcov-report/src/main/rules/MissingNullHandler.ts.html +0 -460
  90. package/coverage/lcov-report/src/main/rules/MissingRecordTriggerFilter.ts.html +0 -235
  91. package/coverage/lcov-report/src/main/rules/ProcessBuilder.ts.html +0 -190
  92. package/coverage/lcov-report/src/main/rules/RecordIdAsString.ts.html +0 -274
  93. package/coverage/lcov-report/src/main/rules/RecursiveAfterUpdate.ts.html +0 -364
  94. package/coverage/lcov-report/src/main/rules/SOQLQueryInLoop.ts.html +0 -160
  95. package/coverage/lcov-report/src/main/rules/SameRecordFieldUpdates.ts.html +0 -283
  96. package/coverage/lcov-report/src/main/rules/TransformInsteadOfLoop.ts.html +0 -250
  97. package/coverage/lcov-report/src/main/rules/TriggerOrder.ts.html +0 -238
  98. package/coverage/lcov-report/src/main/rules/UnconnectedElement.ts.html +0 -178
  99. package/coverage/lcov-report/src/main/rules/UnsafeRunningContext.ts.html +0 -226
  100. package/coverage/lcov-report/src/main/rules/UnusedVariable.ts.html +0 -283
  101. package/coverage/lcov-report/src/main/rules/index.html +0 -521
  102. package/coverage/lcov-report/src/main/store/DefaultRuleStore.ts.html +0 -265
  103. package/coverage/lcov-report/src/main/store/RuleRegistry.ts.html +0 -118
  104. package/coverage/lcov-report/src/main/store/index.html +0 -116
  105. package/coverage/lcov.info +0 -6261
  106. package/eslint.config.mjs +0 -36
  107. package/jest.config.cjs +0 -32
  108. package/jest.env-setup.js +0 -101
  109. package/lint-staged.config.mjs +0 -8
  110. package/out/main/models/FlowGraph.d.ts +0 -85
  111. package/prettier.config.mjs +0 -5
  112. package/src/index.ts +0 -52
  113. package/src/main/config/NodeIcons.ts +0 -98
  114. package/src/main/config/RegexAdapter.ts +0 -98
  115. package/src/main/config/RuleRegistry.ts +0 -188
  116. package/src/main/config/VariableIcons.ts +0 -57
  117. package/src/main/enums/MetadataTypes.ts +0 -6
  118. package/src/main/interfaces/IExceptions.ts +0 -6
  119. package/src/main/interfaces/IRuleConfig.ts +0 -6
  120. package/src/main/interfaces/IRuleDefinition.ts +0 -15
  121. package/src/main/interfaces/IRuleOptions.ts +0 -5
  122. package/src/main/interfaces/IRulesConfig.ts +0 -17
  123. package/src/main/internals/internals.ts +0 -35
  124. package/src/main/libs/BuildFlow.ts +0 -14
  125. package/src/main/libs/Compiler.ts +0 -53
  126. package/src/main/libs/ExportDetails.ts +0 -58
  127. package/src/main/libs/ExportDiagram.ts +0 -83
  128. package/src/main/libs/ExportSarif.ts +0 -92
  129. package/src/main/libs/FixFlows.ts +0 -61
  130. package/src/main/libs/GetRuleDefinitions.ts +0 -64
  131. package/src/main/libs/ParseFlows.ts +0 -34
  132. package/src/main/libs/RuleDocumentation.ts +0 -35
  133. package/src/main/libs/ScanFlows.ts +0 -142
  134. package/src/main/models/FlatViolation.ts +0 -16
  135. package/src/main/models/Flow.ts +0 -325
  136. package/src/main/models/FlowAttribute.ts +0 -11
  137. package/src/main/models/FlowElement.ts +0 -16
  138. package/src/main/models/FlowElementConnector.ts +0 -28
  139. package/src/main/models/FlowGraph.ts +0 -530
  140. package/src/main/models/FlowMetadata.ts +0 -8
  141. package/src/main/models/FlowNode.ts +0 -390
  142. package/src/main/models/FlowResource.ts +0 -8
  143. package/src/main/models/FlowType.ts +0 -53
  144. package/src/main/models/FlowVariable.ts +0 -157
  145. package/src/main/models/LoopRuleCommon.ts +0 -51
  146. package/src/main/models/ParsedFlow.ts +0 -13
  147. package/src/main/models/RuleCommon.ts +0 -120
  148. package/src/main/models/RuleInfo.ts +0 -54
  149. package/src/main/models/RuleResult.ts +0 -29
  150. package/src/main/models/ScanResult.ts +0 -12
  151. package/src/main/models/Violation.ts +0 -78
  152. package/src/main/rules/APIVersion.ts +0 -93
  153. package/src/main/rules/ActionCallsInLoop.ts +0 -25
  154. package/src/main/rules/AutoLayout.ts +0 -46
  155. package/src/main/rules/CopyAPIName.ts +0 -31
  156. package/src/main/rules/CyclomaticComplexity.ts +0 -70
  157. package/src/main/rules/DMLStatementInLoop.ts +0 -26
  158. package/src/main/rules/DuplicateDMLOperation.ts +0 -83
  159. package/src/main/rules/FlowDescription.ts +0 -34
  160. package/src/main/rules/FlowName.ts +0 -49
  161. package/src/main/rules/GetRecordAllFields.ts +0 -65
  162. package/src/main/rules/HardcodedId.ts +0 -51
  163. package/src/main/rules/HardcodedSecret.ts +0 -51
  164. package/src/main/rules/HardcodedUrl.ts +0 -54
  165. package/src/main/rules/InactiveFlow.ts +0 -33
  166. package/src/main/rules/MissingFaultPath.ts +0 -105
  167. package/src/main/rules/MissingMetadataDescription.ts +0 -42
  168. package/src/main/rules/MissingNullHandler.ts +0 -126
  169. package/src/main/rules/MissingRecordTriggerFilter.ts +0 -51
  170. package/src/main/rules/ProcessBuilder.ts +0 -35
  171. package/src/main/rules/RecordIdAsString.ts +0 -64
  172. package/src/main/rules/RecursiveAfterUpdate.ts +0 -94
  173. package/src/main/rules/SOQLQueryInLoop.ts +0 -26
  174. package/src/main/rules/SameRecordFieldUpdates.ts +0 -66
  175. package/src/main/rules/TransformInsteadOfLoop.ts +0 -56
  176. package/src/main/rules/TriggerOrder.ts +0 -51
  177. package/src/main/rules/UnconnectedElement.ts +0 -32
  178. package/src/main/rules/UnsafeRunningContext.ts +0 -47
  179. package/src/main/rules/UnusedVariable.ts +0 -66
  180. package/stryker.config.mjs +0 -23
  181. package/tests/APIVersion.test.ts +0 -87
  182. package/tests/AutoLayout.test.ts +0 -41
  183. package/tests/Config.test.ts +0 -122
  184. package/tests/ConfigBetaMode.test.ts +0 -26
  185. package/tests/CopyAPIName.test.ts +0 -45
  186. package/tests/CyclomaticComplexity.test.ts +0 -125
  187. package/tests/DMLStatementInLoop.test.ts +0 -32
  188. package/tests/DuplicateDMLOperation.test.ts +0 -43
  189. package/tests/EnabledFalse.test.ts +0 -63
  190. package/tests/Exceptions.test.ts +0 -815
  191. package/tests/ExportSarif.test.ts +0 -62
  192. package/tests/FlowDescription.test.ts +0 -44
  193. package/tests/FlowDocumentation.test.ts +0 -74
  194. package/tests/FlowName.test.ts +0 -61
  195. package/tests/GetRecordElementAllFields.test.ts +0 -182
  196. package/tests/HardcodedId.test.ts +0 -16
  197. package/tests/HardcodedSecret.test.ts +0 -32
  198. package/tests/HardcodedUrl.test.ts +0 -253
  199. package/tests/InactiveFlow.test.ts +0 -103
  200. package/tests/MissingFaultPath.test.ts +0 -52
  201. package/tests/MissingMetadataDescription.test.ts +0 -25
  202. package/tests/MissingNullHandler.test.ts +0 -45
  203. package/tests/MissingRecordTriggerFilter.test.ts +0 -54
  204. package/tests/RecordIdAsString.test.ts +0 -60
  205. package/tests/RecursiveAfterUpdate.test.ts +0 -183
  206. package/tests/SOQLQueryInLoop.test.ts +0 -33
  207. package/tests/SameRecordFieldUpdates.test.ts +0 -205
  208. package/tests/SanityTest.test.ts +0 -15
  209. package/tests/TransformInsteadOfLoop.test.ts +0 -33
  210. package/tests/TriggerOrder.test.ts +0 -112
  211. package/tests/UnconnectedElement.test.ts +0 -76
  212. package/tests/UnsafeRunningContext.test.ts +0 -46
  213. package/tests/UnusedVariable.test.ts +0 -59
  214. package/tests/UnusedVariableExceptions.test.ts +0 -87
  215. package/tests/jsonfiles/MissingFaultPath_BeforeSave_Bypass.json +0 -128
  216. package/tests/jsonfiles/MissingFaultPath_WaitConditions.json +0 -102
  217. package/tests/jsonfiles/MissingFaultPath_WaitDate.json +0 -88
  218. package/tests/jsonfiles/MissingFaultPath_WaitDuration.json +0 -90
  219. package/tests/models/Flow.test.ts +0 -107
  220. package/tests/models/LoopRuleCommon.test.ts +0 -246
  221. package/tests/models/RuleCommon.test.ts +0 -41
  222. package/tsconfig.json +0 -28
  223. package/tsconfig.types.json +0 -26
  224. package/types/index.d.ts +0 -27
  225. package/types/index.d.ts.map +0 -1
  226. package/types/main/adapters/RegexAdapter.d.ts +0 -33
  227. package/types/main/adapters/RegexAdapter.d.ts.map +0 -1
  228. package/types/main/config/NodeIcons.d.ts +0 -25
  229. package/types/main/config/NodeIcons.d.ts.map +0 -1
  230. package/types/main/config/RegexAdapter.d.ts +0 -33
  231. package/types/main/config/RegexAdapter.d.ts.map +0 -1
  232. package/types/main/config/RuleRegistry.d.ts +0 -23
  233. package/types/main/config/RuleRegistry.d.ts.map +0 -1
  234. package/types/main/config/VariableIcons.d.ts +0 -26
  235. package/types/main/config/VariableIcons.d.ts.map +0 -1
  236. package/types/main/enums/MetadataTypes.d.ts +0 -7
  237. package/types/main/enums/MetadataTypes.d.ts.map +0 -1
  238. package/types/main/interfaces/IExceptions.d.ts +0 -6
  239. package/types/main/interfaces/IExceptions.d.ts.map +0 -1
  240. package/types/main/interfaces/IRuleConfig.d.ts +0 -7
  241. package/types/main/interfaces/IRuleConfig.d.ts.map +0 -1
  242. package/types/main/interfaces/IRuleDefinition.d.ts +0 -18
  243. package/types/main/interfaces/IRuleDefinition.d.ts.map +0 -1
  244. package/types/main/interfaces/IRuleOptions.d.ts +0 -5
  245. package/types/main/interfaces/IRuleOptions.d.ts.map +0 -1
  246. package/types/main/interfaces/IRulesConfig.d.ts +0 -16
  247. package/types/main/interfaces/IRulesConfig.d.ts.map +0 -1
  248. package/types/main/internals/internals.d.ts +0 -19
  249. package/types/main/internals/internals.d.ts.map +0 -1
  250. package/types/main/libs/BuildFlow.d.ts +0 -2
  251. package/types/main/libs/BuildFlow.d.ts.map +0 -1
  252. package/types/main/libs/Compiler.d.ts +0 -8
  253. package/types/main/libs/Compiler.d.ts.map +0 -1
  254. package/types/main/libs/ConvertFlowNodes.d.ts +0 -2
  255. package/types/main/libs/ConvertFlowNodes.d.ts.map +0 -1
  256. package/types/main/libs/DynamicRule.d.ts +0 -5
  257. package/types/main/libs/DynamicRule.d.ts.map +0 -1
  258. package/types/main/libs/ExportDetails.d.ts +0 -4
  259. package/types/main/libs/ExportDetails.d.ts.map +0 -1
  260. package/types/main/libs/ExportDiagram.d.ts +0 -42
  261. package/types/main/libs/ExportDiagram.d.ts.map +0 -1
  262. package/types/main/libs/ExportSarif.d.ts +0 -3
  263. package/types/main/libs/ExportSarif.d.ts.map +0 -1
  264. package/types/main/libs/FixFlows.d.ts +0 -4
  265. package/types/main/libs/FixFlows.d.ts.map +0 -1
  266. package/types/main/libs/GetRuleDefinitions.d.ts +0 -5
  267. package/types/main/libs/GetRuleDefinitions.d.ts.map +0 -1
  268. package/types/main/libs/ParseFlows.d.ts +0 -3
  269. package/types/main/libs/ParseFlows.d.ts.map +0 -1
  270. package/types/main/libs/RuleDocumentation.d.ts +0 -21
  271. package/types/main/libs/RuleDocumentation.d.ts.map +0 -1
  272. package/types/main/libs/ScanFlows.d.ts +0 -5
  273. package/types/main/libs/ScanFlows.d.ts.map +0 -1
  274. package/types/main/libs/exportAsDetails.d.ts +0 -4
  275. package/types/main/libs/exportAsDetails.d.ts.map +0 -1
  276. package/types/main/libs/exportAsSarif.d.ts +0 -3
  277. package/types/main/libs/exportAsSarif.d.ts.map +0 -1
  278. package/types/main/models/FlatViolation.d.ts +0 -16
  279. package/types/main/models/FlatViolation.d.ts.map +0 -1
  280. package/types/main/models/Flow.d.ts +0 -70
  281. package/types/main/models/Flow.d.ts.map +0 -1
  282. package/types/main/models/FlowAttribute.d.ts +0 -6
  283. package/types/main/models/FlowAttribute.d.ts.map +0 -1
  284. package/types/main/models/FlowElement.d.ts +0 -11
  285. package/types/main/models/FlowElement.d.ts.map +0 -1
  286. package/types/main/models/FlowElementConnector.d.ts +0 -16
  287. package/types/main/models/FlowElementConnector.d.ts.map +0 -1
  288. package/types/main/models/FlowGraph.d.ts.map +0 -1
  289. package/types/main/models/FlowMetadata.d.ts +0 -5
  290. package/types/main/models/FlowMetadata.d.ts.map +0 -1
  291. package/types/main/models/FlowNode.d.ts +0 -66
  292. package/types/main/models/FlowNode.d.ts.map +0 -1
  293. package/types/main/models/FlowResource.d.ts +0 -5
  294. package/types/main/models/FlowResource.d.ts.map +0 -1
  295. package/types/main/models/FlowType.d.ts +0 -24
  296. package/types/main/models/FlowType.d.ts.map +0 -1
  297. package/types/main/models/FlowVariable.d.ts +0 -64
  298. package/types/main/models/FlowVariable.d.ts.map +0 -1
  299. package/types/main/models/LoopRuleCommon.d.ts +0 -15
  300. package/types/main/models/LoopRuleCommon.d.ts.map +0 -1
  301. package/types/main/models/ParsedFlow.d.ts +0 -8
  302. package/types/main/models/ParsedFlow.d.ts.map +0 -1
  303. package/types/main/models/RuleCommon.d.ts +0 -58
  304. package/types/main/models/RuleCommon.d.ts.map +0 -1
  305. package/types/main/models/RuleInfo.d.ts +0 -50
  306. package/types/main/models/RuleInfo.d.ts.map +0 -1
  307. package/types/main/models/RuleResult.d.ts +0 -15
  308. package/types/main/models/RuleResult.d.ts.map +0 -1
  309. package/types/main/models/ScanResult.d.ts +0 -8
  310. package/types/main/models/ScanResult.d.ts.map +0 -1
  311. package/types/main/models/Violation.d.ts +0 -12
  312. package/types/main/models/Violation.d.ts.map +0 -1
  313. package/types/main/rules/APIVersion.d.ts +0 -10
  314. package/types/main/rules/APIVersion.d.ts.map +0 -1
  315. package/types/main/rules/ActionCallsInLoop.d.ts +0 -7
  316. package/types/main/rules/ActionCallsInLoop.d.ts.map +0 -1
  317. package/types/main/rules/AutoLayout.d.ts +0 -8
  318. package/types/main/rules/AutoLayout.d.ts.map +0 -1
  319. package/types/main/rules/CopyAPIName.d.ts +0 -8
  320. package/types/main/rules/CopyAPIName.d.ts.map +0 -1
  321. package/types/main/rules/CyclomaticComplexity.d.ts +0 -12
  322. package/types/main/rules/CyclomaticComplexity.d.ts.map +0 -1
  323. package/types/main/rules/DMLStatementInLoop.d.ts +0 -7
  324. package/types/main/rules/DMLStatementInLoop.d.ts.map +0 -1
  325. package/types/main/rules/DuplicateDMLOperation.d.ts +0 -9
  326. package/types/main/rules/DuplicateDMLOperation.d.ts.map +0 -1
  327. package/types/main/rules/FlowDescription.d.ts +0 -8
  328. package/types/main/rules/FlowDescription.d.ts.map +0 -1
  329. package/types/main/rules/FlowName.d.ts +0 -16
  330. package/types/main/rules/FlowName.d.ts.map +0 -1
  331. package/types/main/rules/GetRecordAllFields.d.ts +0 -8
  332. package/types/main/rules/GetRecordAllFields.d.ts.map +0 -1
  333. package/types/main/rules/HardcodedId.d.ts +0 -14
  334. package/types/main/rules/HardcodedId.d.ts.map +0 -1
  335. package/types/main/rules/HardcodedSecret.d.ts +0 -14
  336. package/types/main/rules/HardcodedSecret.d.ts.map +0 -1
  337. package/types/main/rules/HardcodedUrl.d.ts +0 -14
  338. package/types/main/rules/HardcodedUrl.d.ts.map +0 -1
  339. package/types/main/rules/InactiveFlow.d.ts +0 -8
  340. package/types/main/rules/InactiveFlow.d.ts.map +0 -1
  341. package/types/main/rules/MissingFaultPath.d.ts +0 -15
  342. package/types/main/rules/MissingFaultPath.d.ts.map +0 -1
  343. package/types/main/rules/MissingFilterRecordTrigger.d.ts +0 -8
  344. package/types/main/rules/MissingFilterRecordTrigger.d.ts.map +0 -1
  345. package/types/main/rules/MissingMetadataDescription.d.ts +0 -8
  346. package/types/main/rules/MissingMetadataDescription.d.ts.map +0 -1
  347. package/types/main/rules/MissingNullHandler.d.ts +0 -8
  348. package/types/main/rules/MissingNullHandler.d.ts.map +0 -1
  349. package/types/main/rules/MissingRecordTriggerFilter.d.ts +0 -8
  350. package/types/main/rules/MissingRecordTriggerFilter.d.ts.map +0 -1
  351. package/types/main/rules/ProcessBuilder.d.ts +0 -8
  352. package/types/main/rules/ProcessBuilder.d.ts.map +0 -1
  353. package/types/main/rules/RecordIdAsString.d.ts +0 -8
  354. package/types/main/rules/RecordIdAsString.d.ts.map +0 -1
  355. package/types/main/rules/RecursiveAfterUpdate.d.ts +0 -9
  356. package/types/main/rules/RecursiveAfterUpdate.d.ts.map +0 -1
  357. package/types/main/rules/SOQLQueryInLoop.d.ts +0 -7
  358. package/types/main/rules/SOQLQueryInLoop.d.ts.map +0 -1
  359. package/types/main/rules/SameRecordFieldUpdates.d.ts +0 -9
  360. package/types/main/rules/SameRecordFieldUpdates.d.ts.map +0 -1
  361. package/types/main/rules/TransformInsteadOfLoop.d.ts +0 -8
  362. package/types/main/rules/TransformInsteadOfLoop.d.ts.map +0 -1
  363. package/types/main/rules/TriggerOrder.d.ts +0 -8
  364. package/types/main/rules/TriggerOrder.d.ts.map +0 -1
  365. package/types/main/rules/UnconnectedElement.d.ts +0 -8
  366. package/types/main/rules/UnconnectedElement.d.ts.map +0 -1
  367. package/types/main/rules/UnsafeRunningContext.d.ts +0 -8
  368. package/types/main/rules/UnsafeRunningContext.d.ts.map +0 -1
  369. package/types/main/rules/UnusedVariable.d.ts +0 -8
  370. package/types/main/rules/UnusedVariable.d.ts.map +0 -1
  371. package/types/main/store/DefaultRuleStore.d.ts +0 -3
  372. package/types/main/store/DefaultRuleStore.d.ts.map +0 -1
  373. package/types/main/store/RuleRegistry.d.ts +0 -23
  374. package/types/main/store/RuleRegistry.d.ts.map +0 -1
  375. package/vite.config.ts +0 -33
  376. /package/{out/index.d.ts → index.d.ts} +0 -0
  377. /package/{out/index.js → index.js} +0 -0
  378. /package/{out/main → main}/config/NodeIcons.d.ts +0 -0
  379. /package/{out/main → main}/config/NodeIcons.js +0 -0
  380. /package/{out/main → main}/config/RegexAdapter.d.ts +0 -0
  381. /package/{out/main → main}/config/RegexAdapter.js +0 -0
  382. /package/{out/main → main}/config/RuleRegistry.d.ts +0 -0
  383. /package/{out/main → main}/config/RuleRegistry.js +0 -0
  384. /package/{out/main → main}/config/VariableIcons.d.ts +0 -0
  385. /package/{out/main → main}/config/VariableIcons.js +0 -0
  386. /package/{out/main → main}/enums/MetadataTypes.d.ts +0 -0
  387. /package/{out/main → main}/enums/MetadataTypes.js +0 -0
  388. /package/{out/main → main}/interfaces/IExceptions.d.ts +0 -0
  389. /package/{out/main → main}/interfaces/IExceptions.js +0 -0
  390. /package/{out/main → main}/interfaces/IRuleConfig.d.ts +0 -0
  391. /package/{out/main → main}/interfaces/IRuleConfig.js +0 -0
  392. /package/{out/main → main}/interfaces/IRuleDefinition.d.ts +0 -0
  393. /package/{out/main → main}/interfaces/IRuleDefinition.js +0 -0
  394. /package/{out/main → main}/interfaces/IRuleOptions.d.ts +0 -0
  395. /package/{out/main → main}/interfaces/IRuleOptions.js +0 -0
  396. /package/{out/main → main}/interfaces/IRulesConfig.d.ts +0 -0
  397. /package/{out/main → main}/interfaces/IRulesConfig.js +0 -0
  398. /package/{out/main → main}/internals/internals.d.ts +0 -0
  399. /package/{out/main → main}/internals/internals.js +0 -0
  400. /package/{out/main → main}/libs/BuildFlow.d.ts +0 -0
  401. /package/{out/main → main}/libs/BuildFlow.js +0 -0
  402. /package/{out/main → main}/libs/Compiler.d.ts +0 -0
  403. /package/{out/main → main}/libs/Compiler.js +0 -0
  404. /package/{out/main → main}/libs/ExportDetails.d.ts +0 -0
  405. /package/{out/main → main}/libs/ExportDetails.js +0 -0
  406. /package/{out/main → main}/libs/ExportDiagram.d.ts +0 -0
  407. /package/{out/main → main}/libs/ExportDiagram.js +0 -0
  408. /package/{out/main → main}/libs/ExportSarif.d.ts +0 -0
  409. /package/{out/main → main}/libs/ExportSarif.js +0 -0
  410. /package/{out/main → main}/libs/FixFlows.d.ts +0 -0
  411. /package/{out/main → main}/libs/FixFlows.js +0 -0
  412. /package/{out/main → main}/libs/GetRuleDefinitions.d.ts +0 -0
  413. /package/{out/main → main}/libs/GetRuleDefinitions.js +0 -0
  414. /package/{out/main → main}/libs/ParseFlows.d.ts +0 -0
  415. /package/{out/main → main}/libs/ParseFlows.js +0 -0
  416. /package/{out/main → main}/libs/RuleDocumentation.d.ts +0 -0
  417. /package/{out/main → main}/libs/RuleDocumentation.js +0 -0
  418. /package/{out/main → main}/libs/ScanFlows.d.ts +0 -0
  419. /package/{out/main → main}/libs/ScanFlows.js +0 -0
  420. /package/{out/main → main}/models/FlatViolation.d.ts +0 -0
  421. /package/{out/main → main}/models/FlatViolation.js +0 -0
  422. /package/{out/main → main}/models/Flow.d.ts +0 -0
  423. /package/{out/main → main}/models/Flow.js +0 -0
  424. /package/{out/main → main}/models/FlowAttribute.d.ts +0 -0
  425. /package/{out/main → main}/models/FlowAttribute.js +0 -0
  426. /package/{out/main → main}/models/FlowElement.d.ts +0 -0
  427. /package/{out/main → main}/models/FlowElement.js +0 -0
  428. /package/{out/main → main}/models/FlowElementConnector.d.ts +0 -0
  429. /package/{out/main → main}/models/FlowElementConnector.js +0 -0
  430. /package/{out/main → main}/models/FlowMetadata.d.ts +0 -0
  431. /package/{out/main → main}/models/FlowMetadata.js +0 -0
  432. /package/{out/main → main}/models/FlowNode.d.ts +0 -0
  433. /package/{out/main → main}/models/FlowNode.js +0 -0
  434. /package/{out/main → main}/models/FlowResource.d.ts +0 -0
  435. /package/{out/main → main}/models/FlowResource.js +0 -0
  436. /package/{out/main → main}/models/FlowType.d.ts +0 -0
  437. /package/{out/main → main}/models/FlowType.js +0 -0
  438. /package/{out/main → main}/models/FlowVariable.d.ts +0 -0
  439. /package/{out/main → main}/models/FlowVariable.js +0 -0
  440. /package/{out/main → main}/models/LoopRuleCommon.d.ts +0 -0
  441. /package/{out/main → main}/models/LoopRuleCommon.js +0 -0
  442. /package/{out/main → main}/models/ParsedFlow.d.ts +0 -0
  443. /package/{out/main → main}/models/ParsedFlow.js +0 -0
  444. /package/{out/main → main}/models/RuleCommon.d.ts +0 -0
  445. /package/{out/main → main}/models/RuleCommon.js +0 -0
  446. /package/{out/main → main}/models/RuleInfo.d.ts +0 -0
  447. /package/{out/main → main}/models/RuleInfo.js +0 -0
  448. /package/{out/main → main}/models/RuleResult.d.ts +0 -0
  449. /package/{out/main → main}/models/RuleResult.js +0 -0
  450. /package/{out/main → main}/models/ScanResult.d.ts +0 -0
  451. /package/{out/main → main}/models/ScanResult.js +0 -0
  452. /package/{out/main → main}/models/Violation.d.ts +0 -0
  453. /package/{out/main → main}/models/Violation.js +0 -0
  454. /package/{out/main → main}/rules/APIVersion.d.ts +0 -0
  455. /package/{out/main → main}/rules/APIVersion.js +0 -0
  456. /package/{out/main → main}/rules/ActionCallsInLoop.d.ts +0 -0
  457. /package/{out/main → main}/rules/ActionCallsInLoop.js +0 -0
  458. /package/{out/main → main}/rules/AutoLayout.d.ts +0 -0
  459. /package/{out/main → main}/rules/AutoLayout.js +0 -0
  460. /package/{out/main → main}/rules/CopyAPIName.d.ts +0 -0
  461. /package/{out/main → main}/rules/CopyAPIName.js +0 -0
  462. /package/{out/main → main}/rules/CyclomaticComplexity.d.ts +0 -0
  463. /package/{out/main → main}/rules/CyclomaticComplexity.js +0 -0
  464. /package/{out/main → main}/rules/DMLStatementInLoop.d.ts +0 -0
  465. /package/{out/main → main}/rules/DMLStatementInLoop.js +0 -0
  466. /package/{out/main → main}/rules/DuplicateDMLOperation.d.ts +0 -0
  467. /package/{out/main → main}/rules/DuplicateDMLOperation.js +0 -0
  468. /package/{out/main → main}/rules/FlowDescription.d.ts +0 -0
  469. /package/{out/main → main}/rules/FlowDescription.js +0 -0
  470. /package/{out/main → main}/rules/FlowName.d.ts +0 -0
  471. /package/{out/main → main}/rules/FlowName.js +0 -0
  472. /package/{out/main → main}/rules/GetRecordAllFields.d.ts +0 -0
  473. /package/{out/main → main}/rules/GetRecordAllFields.js +0 -0
  474. /package/{out/main → main}/rules/HardcodedId.d.ts +0 -0
  475. /package/{out/main → main}/rules/HardcodedId.js +0 -0
  476. /package/{out/main → main}/rules/HardcodedSecret.d.ts +0 -0
  477. /package/{out/main → main}/rules/HardcodedSecret.js +0 -0
  478. /package/{out/main → main}/rules/HardcodedUrl.d.ts +0 -0
  479. /package/{out/main → main}/rules/HardcodedUrl.js +0 -0
  480. /package/{out/main → main}/rules/InactiveFlow.d.ts +0 -0
  481. /package/{out/main → main}/rules/InactiveFlow.js +0 -0
  482. /package/{out/main → main}/rules/MissingFaultPath.d.ts +0 -0
  483. /package/{out/main → main}/rules/MissingFaultPath.js +0 -0
  484. /package/{out/main → main}/rules/MissingMetadataDescription.d.ts +0 -0
  485. /package/{out/main → main}/rules/MissingMetadataDescription.js +0 -0
  486. /package/{out/main → main}/rules/MissingNullHandler.d.ts +0 -0
  487. /package/{out/main → main}/rules/MissingNullHandler.js +0 -0
  488. /package/{out/main → main}/rules/MissingRecordTriggerFilter.d.ts +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
- });