@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,34 +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 FlowDescription extends RuleCommon implements IRuleDefinition {
6
- constructor() {
7
- super({
8
- ruleId: "missing-flow-description",
9
- category: "layout",
10
- description: "Flow descriptions are essential for documentation and maintainability. Include a description for each Flow, explaining its purpose and where it's used.",
11
- summary: "Flow descriptions improve documentation and maintainability",
12
- docRefs: [],
13
- label: "Missing Flow Description",
14
- name: "FlowDescription",
15
- supportedTypes: [...core.FlowType.backEndTypes, ...core.FlowType.visualTypes],
16
- }, { severity: "error" });
17
- }
18
-
19
- protected check(
20
- flow: core.Flow,
21
- _options: object | undefined,
22
- _suppressions: Set<string>
23
- ): core.Violation[] {
24
- if (flow.xmldata?.description) {
25
- return [];
26
- }
27
-
28
- return [
29
- new core.Violation(
30
- new core.FlowAttribute("undefined", "description", "!==null")
31
- )
32
- ];
33
- }
34
- }
@@ -1,49 +0,0 @@
1
- import * as core from "../internals/internals";
2
- import { RuleCommon } from "../models/RuleCommon";
3
- import { IRuleDefinition } from "../interfaces/IRuleDefinition";
4
- import { NamingConvention } from "@flow-scanner/regex-scanner";
5
- import { toMetadataFile, toViolations } from "../config/RegexAdapter";
6
-
7
- /**
8
- * Flow naming convention rule.
9
- * This is a wrapper around the regex-scanner's NamingConvention rule,
10
- * maintaining backward compatibility with the core scanner interface.
11
- */
12
- export class FlowName extends RuleCommon implements IRuleDefinition {
13
- private regexRule = new NamingConvention();
14
-
15
- constructor() {
16
- super({
17
- ruleId: "invalid-naming-convention",
18
- category: "layout",
19
- description: "Using clear and consistent Flow names improves readability, discoverability, and maintainability. A good naming convention helps team members quickly understand a Flow's purpose—for example, including a domain and brief description like Service_OrderFulfillment. Adopt a naming pattern that aligns with your organization's standards.",
20
- summary: "Consistent naming improves Flow discoverability and maintainability",
21
- docRefs: [
22
- {
23
- label: "Naming your Flows is more critical than ever. By Stephen Church",
24
- path: "https://www.linkedin.com/posts/stephen-n-church_naming-your-flows-this-is-more-critical-activity-7099733198175158274-1sPx",
25
- },
26
- ],
27
- label: "Flow Naming Convention",
28
- name: "FlowName",
29
- supportedTypes: core.FlowType.allTypes(),
30
- }, { severity: "error" });
31
- }
32
-
33
- protected check(
34
- flow: core.Flow,
35
- options: { expression?: string } | undefined,
36
- _suppressions: Set<string>
37
- ): core.Violation[] {
38
- // Convert Flow to MetadataFile for regex-scanner
39
- const metadataFile = toMetadataFile(flow);
40
-
41
- // Execute regex rule
42
- const regexViolations = this.regexRule.execute(metadataFile, {
43
- expression: options?.expression,
44
- });
45
-
46
- // Convert back to core Violations
47
- return toViolations(regexViolations);
48
- }
49
- }
@@ -1,65 +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 GetRecordAllFields extends RuleCommon implements IRuleDefinition {
6
- constructor() {
7
- super(
8
- {
9
- ruleId: "get-record-all-fields",
10
- category: "suggestion",
11
- description: "Avoid using Get Records to retrieve all fields unless necessary. This improves performance, reduces processing time, and limits exposure of unnecessary data.",
12
- summary: "Retrieving all fields harms performance and security",
13
- docRefs: [
14
- {
15
- label: "Get Records Stores All Fields",
16
- path: "https://developer.salesforce.com/docs/atlas.en-us.salesforce_large_data_volumes_bp.meta/salesforce_large_data_volumes_bp/ldv_deployments_best_practices_soql_and_sosl.htm",
17
- },
18
- {
19
- label: "Indexes | Best Practices",
20
- path: "https://developer.salesforce.com/docs/atlas.en-us.salesforce_large_data_volumes_bp.meta/salesforce_large_data_volumes_bp/ldv_deployments_infrastructure_indexes.htm",
21
- },
22
- ],
23
- label: "Get Record All Fields",
24
- name: "GetRecordAllFields",
25
- supportedTypes: core.FlowType.allTypes(),
26
- },
27
- { severity: "warning" }
28
- );
29
- }
30
-
31
- protected check(
32
- flow: core.Flow,
33
- _options: object | undefined,
34
- _suppressions: Set<string>
35
- ): core.Violation[] {
36
- const lookupNodes = flow.elements?.filter(
37
- (e) => e.subtype === "recordLookups"
38
- ) ?? [];
39
-
40
- const violations = lookupNodes
41
- .filter((node) => {
42
- const el = (node as core.FlowNode).element as core.FlowElement;
43
-
44
- const storeAllFields =
45
- typeof el === "object" &&
46
- "storeOutputAutomatically" in el &&
47
- el.storeOutputAutomatically;
48
-
49
- // Handle both single field (string) and multiple fields (array)
50
- const queriedFields = (el as any).queriedFields;
51
- const hasQueriedFields =
52
- queriedFields &&
53
- (
54
- (Array.isArray(queriedFields) && queriedFields.length > 0) ||
55
- typeof queriedFields === "string"
56
- );
57
-
58
- return storeAllFields && !hasQueriedFields;
59
- })
60
- .map((node) => new core.Violation(node));
61
-
62
- return violations;
63
- }
64
-
65
- }
@@ -1,51 +0,0 @@
1
- import * as core from "../internals/internals";
2
- import { RuleCommon } from "../models/RuleCommon";
3
- import { IRuleDefinition } from "../interfaces/IRuleDefinition";
4
- import { HardcodedId as RegexHardcodedId } from "@flow-scanner/regex-scanner";
5
- import { toMetadataFile, toViolations } from "../config/RegexAdapter";
6
-
7
- /**
8
- * Hardcoded Salesforce ID detection rule.
9
- * This is a wrapper around the regex-scanner's HardcodedId rule,
10
- * maintaining backward compatibility with the core scanner interface.
11
- */
12
- export class HardcodedId extends RuleCommon implements IRuleDefinition {
13
- private regexRule = new RegexHardcodedId();
14
-
15
- constructor() {
16
- super({
17
- ruleId: "hardcoded-id",
18
- name: "HardcodedId",
19
- category: "problem",
20
- label: "Hardcoded Salesforce Id",
21
- description: "Avoid hard-coding record IDs, as they are unique to a specific org and will not work in other environments. Instead, store IDs in variables—such as merge-field URL parameters or a **Get Records** element—to make the Flow portable, maintainable, and flexible.",
22
- summary: "Hardcoded IDs break portability across environments",
23
- supportedTypes: core.FlowType.allTypes(),
24
- docRefs: [
25
- {
26
- label: "Flow Best Practices",
27
- path: "https://help.salesforce.com/s/articleView?id=sf.flow_prep_bestpractices.htm&type=5",
28
- },
29
- {
30
- label: "Don't hard code Record Type IDs in Flow. By Stephen Church.",
31
- path: "https://www.linkedin.com/feed/update/urn:li:activity:6947530300012826624/",
32
- },
33
- ],
34
- }, { severity: "error" });
35
- }
36
-
37
- protected check(
38
- flow: core.Flow,
39
- _options: object | undefined,
40
- _suppressions: Set<string>
41
- ): core.Violation[] {
42
- // Convert Flow to MetadataFile for regex-scanner
43
- const metadataFile = toMetadataFile(flow);
44
-
45
- // Execute regex rule
46
- const regexViolations = this.regexRule.execute(metadataFile);
47
-
48
- // Convert back to core Violations
49
- return toViolations(regexViolations);
50
- }
51
- }
@@ -1,51 +0,0 @@
1
- import * as core from "../internals/internals";
2
- import { RuleCommon } from "../models/RuleCommon";
3
- import { IRuleDefinition } from "../interfaces/IRuleDefinition";
4
- import { HardcodedSecret as RegexHardcodedSecret } from "@flow-scanner/regex-scanner";
5
- import { toMetadataFile, toViolations } from "../config/RegexAdapter";
6
-
7
- /**
8
- * Hardcoded secrets detection rule.
9
- * This is a wrapper around the regex-scanner's HardcodedSecret rule,
10
- * maintaining backward compatibility with the core scanner interface.
11
- */
12
- export class HardcodedSecret extends RuleCommon implements IRuleDefinition {
13
- private regexRule = new RegexHardcodedSecret();
14
-
15
- constructor() {
16
- super({
17
- ruleId: "hardcoded-secret",
18
- name: "HardcodedSecret",
19
- category: "problem",
20
- label: "Hardcoded Secret",
21
- description: "Avoid hardcoding secrets, API keys, tokens, or credentials in Flows. These should be stored securely in Named Credentials, Custom Settings, Custom Metadata, or external secret management systems.",
22
- summary: "Hardcoded secrets pose security risks",
23
- supportedTypes: core.FlowType.allTypes(),
24
- docRefs: [
25
- {
26
- label: "Salesforce Named Credentials",
27
- path: "https://help.salesforce.com/s/articleView?id=sf.named_credentials_about.htm",
28
- },
29
- {
30
- label: "OWASP Secrets Management Cheat Sheet",
31
- path: "https://cheatsheetseries.owasp.org/cheatsheets/Secrets_Management_Cheat_Sheet.html",
32
- },
33
- ],
34
- }, { severity: "error" });
35
- }
36
-
37
- protected check(
38
- flow: core.Flow,
39
- _options: object | undefined,
40
- _suppressions: Set<string>
41
- ): core.Violation[] {
42
- // Convert Flow to MetadataFile for regex-scanner
43
- const metadataFile = toMetadataFile(flow);
44
-
45
- // Execute regex rule
46
- const regexViolations = this.regexRule.execute(metadataFile);
47
-
48
- // Convert back to core Violations
49
- return toViolations(regexViolations);
50
- }
51
- }
@@ -1,54 +0,0 @@
1
- import { Flow, FlowType, Violation } from "../internals/internals";
2
- import { RuleCommon } from "../models/RuleCommon";
3
- import { IRuleDefinition } from "../interfaces/IRuleDefinition";
4
- import { HardcodedUrl as RegexHardcodedUrl } from "@flow-scanner/regex-scanner";
5
- import { toMetadataFile, toViolations } from "../config/RegexAdapter";
6
-
7
- /**
8
- * Hardcoded Salesforce URL detection rule.
9
- * This is a wrapper around the regex-scanner's HardcodedUrl rule,
10
- * maintaining backward compatibility with the core scanner interface.
11
- */
12
- export class HardcodedUrl extends RuleCommon implements IRuleDefinition {
13
- private regexRule = new RegexHardcodedUrl();
14
-
15
- constructor() {
16
- super(
17
- {
18
- ruleId: "hardcoded-url",
19
- category: "problem",
20
- description: "Avoid hard-coding URLs, as they may change between environments or over time. Instead, store URLs in variables or custom settings to make the Flow adaptable, maintainable, and environment-independent.",
21
- summary: "Hardcoded URLs break across different environments",
22
- docRefs: [
23
- {
24
- label: "The Ultimate Guide to Salesforce Flow Best Practices",
25
- path: "https://admin.salesforce.com/blog/2021/the-ultimate-guide-to-flow-best-practices-and-standards",
26
- },
27
- {
28
- label: "Why You Should Avoid Hard Coding and Three Alternative Solutions",
29
- path: "https://admin.salesforce.com/blog/2021/why-you-should-avoid-hard-coding-and-three-alternative-solutions",
30
- },
31
- ],
32
- label: "Hardcoded Salesforce Url",
33
- name: "HardcodedUrl",
34
- supportedTypes: FlowType.allTypes(),
35
- },
36
- { severity: "error" }
37
- );
38
- }
39
-
40
- protected check(
41
- flow: Flow,
42
- _options: object | undefined,
43
- _suppressions: Set<string>
44
- ): Violation[] {
45
- // Convert Flow to MetadataFile for regex-scanner
46
- const metadataFile = toMetadataFile(flow);
47
-
48
- // Execute regex rule
49
- const regexViolations = this.regexRule.execute(metadataFile);
50
-
51
- // Convert back to core Violations
52
- return toViolations(regexViolations);
53
- }
54
- }
@@ -1,33 +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 InactiveFlow extends RuleCommon implements IRuleDefinition {
6
- constructor() {
7
- super({
8
- ruleId: "inactive-flow",
9
- category: "suggestion",
10
- name: "InactiveFlow",
11
- label: "Inactive Flow",
12
- description: "Inactive Flows should be deleted or archived to reduce risk. Even when inactive, they can cause unintended record changes during testing or be activated as subflows. Keeping only active, relevant Flows improves safety and maintainability.",
13
- summary: "Inactive Flows should be deleted or archived",
14
- supportedTypes: core.FlowType.allTypes(),
15
- docRefs: [],
16
- });
17
- }
18
-
19
- protected check(
20
- flow: core.Flow,
21
- _options: object | undefined,
22
- _suppressions: Set<string>
23
- ): core.Violation[] {
24
- if (flow.status !== "Active") {
25
- return [
26
- new core.Violation(
27
- new core.FlowAttribute(flow.status, "status", "!= Active")
28
- ),
29
- ];
30
- }
31
- return [];
32
- }
33
- }
@@ -1,105 +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 MissingFaultPath extends RuleCommon implements IRuleDefinition {
6
- protected applicableElements: string[] = [
7
- "recordLookups",
8
- "recordDeletes",
9
- "recordUpdates",
10
- "recordCreates",
11
- "waits",
12
- "actionCalls",
13
- "apexPluginCalls",
14
- ];
15
-
16
- constructor() {
17
- super({
18
- ruleId: "missing-fault-path",
19
- category: "problem",
20
- description: "Elements that can fail should include a Fault Path to handle errors gracefully. Without it, failures show generic errors to users. Fault Paths improve reliability and user experience.",
21
- summary: "Fault Paths enable graceful error handling",
22
- docRefs: [
23
- {
24
- label: "Flow Best Practices",
25
- path: "https://help.salesforce.com/s/articleView?id=sf.flow_prep_bestpractices.htm&type=5",
26
- },
27
- ],
28
- label: "Missing Fault Path",
29
- name: "MissingFaultPath",
30
- supportedTypes: [...core.FlowType.backEndTypes, ...core.FlowType.visualTypes],
31
- });
32
- }
33
-
34
- private isValidSubtype(proxyNode: core.FlowNode): boolean {
35
- if (!this.applicableElements.includes(proxyNode.subtype)) {
36
- return false;
37
- }
38
-
39
- // Exclude specific wait element subtypes that don't need fault paths
40
- if (proxyNode.subtype === "waits") {
41
- const elementSubtype: string = (proxyNode.element as Record<string, unknown>)?.["elementSubtype"] as string;
42
- const excludedSubtypes: string[] = ["WaitDuration", "WaitDate"];
43
- return !excludedSubtypes.includes(elementSubtype);
44
- }
45
-
46
- return true;
47
- }
48
-
49
- protected check(
50
- flow: core.Flow,
51
- _options: object | undefined,
52
- suppressions: Set<string>
53
- ): core.Violation[] {
54
- const results: core.Violation[] = [];
55
-
56
- const elementsWhereFaultPathIsApplicable = (
57
- flow.elements.filter((node) => {
58
- const proxyNode = node as unknown as core.FlowNode;
59
- return this.isValidSubtype(proxyNode);
60
- }) as core.FlowNode[]
61
- ).map((e) => e.name);
62
-
63
- // Check if this is a RecordBeforeSave flow
64
- const isRecordBeforeSave = this.isRecordBeforeSaveFlow(flow);
65
-
66
- const visitCallback = (element: core.FlowNode) => {
67
- if (
68
- !element?.connectors?.find((connector) => connector.type === "faultConnector") &&
69
- elementsWhereFaultPathIsApplicable.includes(element.name)
70
- ) {
71
- // Skip record updates in before-save flows (they're safe by design)
72
- if (isRecordBeforeSave && element.subtype === "recordUpdates") {
73
- return;
74
- }
75
-
76
- if (!this.isPartOfFaultHandlingFlow(element, flow)) {
77
- if (!suppressions.has(element.name)) {
78
- results.push(new core.Violation(element));
79
- }
80
- }
81
- }
82
- };
83
-
84
- flow.graph?.forEachReachable(visitCallback);
85
-
86
- return results;
87
- }
88
-
89
- /**
90
- * Determine if this is a RecordBeforeSave flow.
91
- */
92
- private isRecordBeforeSaveFlow(flow: core.Flow): boolean {
93
- if (flow.startNode?.element) {
94
- const triggerType = (flow.startNode.element as Record<string, unknown>)?.["triggerType"];
95
- if (triggerType === "RecordBeforeSave") {
96
- return true;
97
- }
98
- }
99
- return false;
100
- }
101
-
102
- private isPartOfFaultHandlingFlow(element: core.FlowNode, flow: core.Flow): boolean {
103
- return flow.graph?.isPartOfFaultHandling(element.name) || false;
104
- }
105
- }
@@ -1,42 +0,0 @@
1
- import { IRuleDefinition } from "../interfaces/IRuleDefinition";
2
- import * as core from "../internals/internals";
3
- import { RuleCommon } from "../models/RuleCommon";
4
-
5
- export class MissingMetadataDescription extends RuleCommon implements IRuleDefinition {
6
- constructor() {
7
- super({
8
- ruleId: "missing-metadata-description",
9
- category: "layout",
10
- description: "Elements and metadata without a description reduce clarity and maintainability. Adding descriptions improves readability and makes your automation easier to understand.",
11
- summary: "Element descriptions improve clarity and maintainability",
12
- docRefs: [],
13
- label: "Missing Metadata Description",
14
- name: "MissingMetadataDescription",
15
- supportedTypes: core.FlowType.allTypes(),
16
- }, { severity: "warning" });
17
- }
18
-
19
- protected check(
20
- flow: core.Flow,
21
- _options: object | undefined,
22
- _suppression: Set<string>
23
- ): core.Violation[] {
24
- const violations: core.Violation[] = [];
25
-
26
- flow.elements
27
- .filter((elem) => {
28
- if (
29
- elem.metaType !== "attribute" &&
30
- !elem.element["description"] &&
31
- elem.subtype !== "start"
32
- ) {
33
- return elem;
34
- }
35
- })
36
- .forEach((elem) => {
37
- return violations.push(new core.Violation(elem));
38
- });
39
-
40
- return violations;
41
- }
42
- }
@@ -1,126 +0,0 @@
1
- import * as core from "../internals/internals";
2
- import { RuleCommon } from "../models/RuleCommon";
3
- import { IRuleDefinition } from "../interfaces/IRuleDefinition";
4
- export class MissingNullHandler extends RuleCommon implements IRuleDefinition {
5
- constructor() {
6
- super({
7
- ruleId: "missing-null-handler",
8
- category: "problem",
9
- description: "Get Records operations return null when no data is found. Without handling these null values, Flows can fail or produce unintended results. Adding a null check improves reliability and ensures the Flow behaves as expected.",
10
- summary: "Null checks prevent failures from missing records",
11
- docRefs: [],
12
- label: "Missing Null Handler",
13
- name: "MissingNullHandler",
14
- supportedTypes: [...core.FlowType.backEndTypes, ...core.FlowType.visualTypes],
15
- });
16
- }
17
-
18
- protected check(
19
- flow: core.Flow,
20
- _options: object | undefined,
21
- suppressions: Set<string>
22
- ): core.Violation[] {
23
- const getOperations = ["recordLookups"];
24
- const getOperationElements: core.FlowNode[] = flow.elements.filter(
25
- (node) => node.metaType === "node" && getOperations.includes(node.subtype)
26
- ) as core.FlowNode[];
27
-
28
- const decisionElements: core.FlowNode[] = flow.elements.filter(
29
- (node) => node.metaType === "node" && node.subtype === "decisions"
30
- ) as core.FlowNode[];
31
-
32
- const violations: core.FlowNode[] = [];
33
-
34
- for (const getElement of getOperationElements) {
35
- if (suppressions.has(getElement.name)) continue;
36
-
37
- const elementName = getElement.name;
38
- const assignNulls = String(getElement.element["assignNullValuesIfNoRecordsFound"]).toLowerCase() === "true";
39
-
40
- const hasFaultConnector =
41
- !!getElement.element["faultConnector"] ||
42
- getElement.connectors?.some((c) => c.type === "faultConnector");
43
-
44
- // Only skip if NOT assigning nulls AND has fault connector
45
- // (because fault will catch the "no records" error)
46
- if (!assignNulls && hasFaultConnector) {
47
- continue;
48
- }
49
-
50
- const resultReferences: string[] = [];
51
- if (getElement.element["storeOutputAutomatically"]) {
52
- resultReferences.push(elementName);
53
- } else if (getElement.element["outputReference"]) {
54
- resultReferences.push(getElement.element["outputReference"] as string);
55
- } else if (getElement.element["outputAssignments"]) {
56
- const assignments = getElement.element["outputAssignments"] as any[];
57
- for (const a of assignments) {
58
- resultReferences.push(a.assignToReference);
59
- }
60
- }
61
-
62
- const resultIsUsed = flow.elements.some((el) => {
63
- if (el.name === getElement.name) return false;
64
- const json = JSON.stringify(el.element);
65
- return resultReferences.some(
66
- (ref) => json.includes(`"${ref}"`) || json.includes(`"${ref}.`)
67
- );
68
- });
69
-
70
- if (!resultIsUsed) continue;
71
-
72
- // If assignNullValuesIfNoRecordsFound is TRUE, we need a null check decision
73
- if (!assignNulls) {
74
- // If FALSE and no fault connector, that's also a problem
75
- // (already handled above)
76
- continue;
77
- }
78
-
79
- let nullCheckFound = false;
80
- for (const decision of decisionElements) {
81
- let rules = decision.element["rules"];
82
- if (!Array.isArray(rules)) rules = [rules];
83
-
84
- for (const rule of rules) {
85
- let conditions = rule.conditions;
86
- if (!Array.isArray(conditions)) conditions = [conditions];
87
-
88
- for (const condition of conditions) {
89
- let referenceFound = false;
90
- let isNullOperator = false;
91
- let checksFalse = false;
92
-
93
- if (condition.leftValueReference) {
94
- const ref = condition.leftValueReference as string;
95
- if (resultReferences.some((r) => ref.startsWith(r))) {
96
- referenceFound = true;
97
- }
98
- }
99
-
100
- if (condition.operator === "IsNull") {
101
- isNullOperator = true;
102
- }
103
-
104
- const rightBool = condition.rightValue?.booleanValue;
105
- if (rightBool != null && String(rightBool).toLowerCase() === "false") {
106
- checksFalse = true;
107
- }
108
-
109
- if (referenceFound && isNullOperator && checksFalse) {
110
- nullCheckFound = true;
111
- break;
112
- }
113
- }
114
- if (nullCheckFound) break;
115
- }
116
- if (nullCheckFound) break;
117
- }
118
-
119
- if (!nullCheckFound) {
120
- violations.push(getElement);
121
- }
122
- }
123
-
124
- return violations.map((det) => new core.Violation(det));
125
- }
126
- }
@@ -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 MissingRecordTriggerFilter extends RuleCommon implements IRuleDefinition {
6
- constructor() {
7
- super({
8
- ruleId: "missing-record-trigger-filter",
9
- category: "suggestion",
10
- name: "MissingRecordTriggerFilter",
11
- label: "Missing Filter Record Trigger",
12
- description: "Record-triggered Flows without filters on changed fields or entry conditions execute on every record change. Adding filters ensures the Flow runs only when needed, improving performance.",
13
- summary: "Filters ensure Flows run only when needed",
14
- supportedTypes: [core.FlowType.autolaunchedType],
15
- docRefs: [],
16
- }, { severity: "warning" });
17
- }
18
-
19
- protected check(
20
- flow: core.Flow,
21
- _options: object | undefined,
22
- _suppressions: Set<string>
23
- ): core.Violation[] {
24
- const violations: core.Violation[] = [];
25
- // Check if this is a record-triggered flow
26
- const triggerType = this.getStartProperty(flow, 'triggerType');
27
- // Only check flows with record trigger types
28
- if (!triggerType || !["RecordAfterSave", "RecordBeforeSave"].includes(triggerType)) {
29
- return violations;
30
- }
31
- // Check if the flow has filters or entry conditions at the flow level
32
- const filters = this.getStartProperty(flow, 'filters');
33
-
34
- const hasFilters = !!filters;
35
- const scheduledPaths = flow.xmldata?.start?.scheduledPaths;
36
- const hasScheduledPaths = !!scheduledPaths;
37
- // If no filters or scheduled paths (which have their own conditions), flag as violation
38
- if (!hasFilters && !hasScheduledPaths) {
39
- violations.push(
40
- new core.Violation(
41
- new core.FlowAttribute(
42
- triggerType,
43
- "triggerType",
44
- "autolaunched && triggerType"
45
- )
46
- )
47
- );
48
- }
49
- return violations;
50
- }
51
- }