@snovon/solast 0.2.0

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 (738) hide show
  1. package/LICENSE +201 -0
  2. package/README.md +190 -0
  3. package/dist/api.d.ts +89 -0
  4. package/dist/api.js +33 -0
  5. package/dist/ast/resolve-return-names.d.ts +2 -0
  6. package/dist/ast/resolve-return-names.js +199 -0
  7. package/dist/ast/solc-walker.d.ts +17 -0
  8. package/dist/ast/solc-walker.js +497 -0
  9. package/dist/ast/storage-layout.d.ts +21 -0
  10. package/dist/ast/storage-layout.js +64 -0
  11. package/dist/cli.d.ts +65 -0
  12. package/dist/cli.js +755 -0
  13. package/dist/config.d.ts +9 -0
  14. package/dist/config.js +284 -0
  15. package/dist/dedup/files.d.ts +1 -0
  16. package/dist/dedup/files.js +74 -0
  17. package/dist/dedup/findings.d.ts +41 -0
  18. package/dist/dedup/findings.js +211 -0
  19. package/dist/detectors/_common/access-control.d.ts +204 -0
  20. package/dist/detectors/_common/access-control.js +377 -0
  21. package/dist/detectors/_common/ast.d.ts +139 -0
  22. package/dist/detectors/_common/ast.js +239 -0
  23. package/dist/detectors/_common/compiler-profile.d.ts +14 -0
  24. package/dist/detectors/_common/compiler-profile.js +66 -0
  25. package/dist/detectors/_common/dataflow.d.ts +75 -0
  26. package/dist/detectors/_common/dataflow.js +57 -0
  27. package/dist/detectors/_common/fhe.d.ts +7 -0
  28. package/dist/detectors/_common/fhe.js +40 -0
  29. package/dist/detectors/_common/integer-overflow-helpers.d.ts +58 -0
  30. package/dist/detectors/_common/integer-overflow-helpers.js +422 -0
  31. package/dist/detectors/_common/loop-call-stack.d.ts +9 -0
  32. package/dist/detectors/_common/loop-call-stack.js +132 -0
  33. package/dist/detectors/_common/oracle.d.ts +5 -0
  34. package/dist/detectors/_common/oracle.js +64 -0
  35. package/dist/detectors/_common/price-rate.d.ts +116 -0
  36. package/dist/detectors/_common/price-rate.js +446 -0
  37. package/dist/detectors/_common/source-text.d.ts +11 -0
  38. package/dist/detectors/_common/source-text.js +82 -0
  39. package/dist/detectors/_common/weighted-pool-invariant.d.ts +21 -0
  40. package/dist/detectors/_common/weighted-pool-invariant.js +105 -0
  41. package/dist/detectors/aave-v2-reentrancy.d.ts +7 -0
  42. package/dist/detectors/aave-v2-reentrancy.js +286 -0
  43. package/dist/detectors/access-control.d.ts +103 -0
  44. package/dist/detectors/access-control.js +983 -0
  45. package/dist/detectors/add-reentrancy-on-weth-contract.d.ts +7 -0
  46. package/dist/detectors/add-reentrancy-on-weth-contract.js +536 -0
  47. package/dist/detectors/ai-generated-randomness.d.ts +32 -0
  48. package/dist/detectors/ai-generated-randomness.js +239 -0
  49. package/dist/detectors/amm-spot-oracle-manipulation.d.ts +52 -0
  50. package/dist/detectors/amm-spot-oracle-manipulation.js +420 -0
  51. package/dist/detectors/analyzing-the-uniswap-v3-exploit.d.ts +26 -0
  52. package/dist/detectors/analyzing-the-uniswap-v3-exploit.js +279 -0
  53. package/dist/detectors/any-token-is-destroyed.d.ts +34 -0
  54. package/dist/detectors/any-token-is-destroyed.js +527 -0
  55. package/dist/detectors/anyswap-anytoken-permit-allowance-drain.d.ts +7 -0
  56. package/dist/detectors/anyswap-anytoken-permit-allowance-drain.js +524 -0
  57. package/dist/detectors/anyswap-insufficient-token-validation.d.ts +24 -0
  58. package/dist/detectors/anyswap-insufficient-token-validation.js +342 -0
  59. package/dist/detectors/approval-based-drain.d.ts +7 -0
  60. package/dist/detectors/approval-based-drain.js +772 -0
  61. package/dist/detectors/arbitrary-account-balance-transfer.d.ts +7 -0
  62. package/dist/detectors/arbitrary-account-balance-transfer.js +485 -0
  63. package/dist/detectors/arbitrary-address-spoofing-attack.d.ts +7 -0
  64. package/dist/detectors/arbitrary-address-spoofing-attack.js +444 -0
  65. package/dist/detectors/arbitrary-address-spoofing.d.ts +9 -0
  66. package/dist/detectors/arbitrary-address-spoofing.js +657 -0
  67. package/dist/detectors/arbitrary-call-error.d.ts +127 -0
  68. package/dist/detectors/arbitrary-call-error.js +1163 -0
  69. package/dist/detectors/arbitrary-call.d.ts +4 -0
  70. package/dist/detectors/arbitrary-call.js +11 -0
  71. package/dist/detectors/arbitrary-delegatecall-target.d.ts +35 -0
  72. package/dist/detectors/arbitrary-delegatecall-target.js +554 -0
  73. package/dist/detectors/arbitrary-recipient-no-access-control.d.ts +7 -0
  74. package/dist/detectors/arbitrary-recipient-no-access-control.js +638 -0
  75. package/dist/detectors/arbitrary-storage-proof-forgery.d.ts +35 -0
  76. package/dist/detectors/arbitrary-storage-proof-forgery.js +340 -0
  77. package/dist/detectors/arbitrary-transfer-from.d.ts +38 -0
  78. package/dist/detectors/arbitrary-transfer-from.js +339 -0
  79. package/dist/detectors/arbitrum-cross-chain-message-replay.d.ts +22 -0
  80. package/dist/detectors/arbitrum-cross-chain-message-replay.js +477 -0
  81. package/dist/detectors/avs-slashing-without-quorum-check.d.ts +50 -0
  82. package/dist/detectors/avs-slashing-without-quorum-check.js +386 -0
  83. package/dist/detectors/bad-debt-propagation.d.ts +13 -0
  84. package/dist/detectors/bad-debt-propagation.js +480 -0
  85. package/dist/detectors/bad-k-value-verification.d.ts +7 -0
  86. package/dist/detectors/bad-k-value-verification.js +512 -0
  87. package/dist/detectors/bad-randomness-zero-blockhash.d.ts +29 -0
  88. package/dist/detectors/bad-randomness-zero-blockhash.js +115 -0
  89. package/dist/detectors/balancer-flash-loan-manipulation.d.ts +33 -0
  90. package/dist/detectors/balancer-flash-loan-manipulation.js +178 -0
  91. package/dist/detectors/balancer-pause-guard.d.ts +33 -0
  92. package/dist/detectors/balancer-pause-guard.js +307 -0
  93. package/dist/detectors/balancer-weighted-pool-flash-loan.d.ts +42 -0
  94. package/dist/detectors/balancer-weighted-pool-flash-loan.js +275 -0
  95. package/dist/detectors/batch-transfer-overflow.d.ts +7 -0
  96. package/dist/detectors/batch-transfer-overflow.js +465 -0
  97. package/dist/detectors/beneficiary-validation.d.ts +7 -0
  98. package/dist/detectors/beneficiary-validation.js +696 -0
  99. package/dist/detectors/borrow-behalf-consent.d.ts +7 -0
  100. package/dist/detectors/borrow-behalf-consent.js +400 -0
  101. package/dist/detectors/break-continue-scope.d.ts +7 -0
  102. package/dist/detectors/break-continue-scope.js +194 -0
  103. package/dist/detectors/bridge-accounting-bypass.d.ts +65 -0
  104. package/dist/detectors/bridge-accounting-bypass.js +449 -0
  105. package/dist/detectors/bridge-business-logic-flaw-incorrect-acc.d.ts +43 -0
  106. package/dist/detectors/bridge-business-logic-flaw-incorrect-acc.js +394 -0
  107. package/dist/detectors/bridge-collateral-drain.d.ts +7 -0
  108. package/dist/detectors/bridge-collateral-drain.js +630 -0
  109. package/dist/detectors/bridge-forged-proof.d.ts +7 -0
  110. package/dist/detectors/bridge-forged-proof.js +754 -0
  111. package/dist/detectors/bridge-missing-message-nonce.d.ts +57 -0
  112. package/dist/detectors/bridge-missing-message-nonce.js +638 -0
  113. package/dist/detectors/bridge-swap-metapool-attack.d.ts +20 -0
  114. package/dist/detectors/bridge-swap-metapool-attack.js +230 -0
  115. package/dist/detectors/business-logic-flaw-flashloan-price-mani.d.ts +7 -0
  116. package/dist/detectors/business-logic-flaw-flashloan-price-mani.js +353 -0
  117. package/dist/detectors/business-logic-flaw-incorrect-recipient-balance.d.ts +7 -0
  118. package/dist/detectors/business-logic-flaw-incorrect-recipient-balance.js +403 -0
  119. package/dist/detectors/business-logic-flaw.d.ts +21 -0
  120. package/dist/detectors/business-logic-flaw.js +339 -0
  121. package/dist/detectors/business-logic.d.ts +17 -0
  122. package/dist/detectors/business-logic.js +22 -0
  123. package/dist/detectors/bypassed-insolvency-check.d.ts +30 -0
  124. package/dist/detectors/bypassed-insolvency-check.js +232 -0
  125. package/dist/detectors/bytecode-divergence-risk.d.ts +32 -0
  126. package/dist/detectors/bytecode-divergence-risk.js +150 -0
  127. package/dist/detectors/cache-array-length.d.ts +30 -0
  128. package/dist/detectors/cache-array-length.js +177 -0
  129. package/dist/detectors/cache-storage-reads.d.ts +46 -0
  130. package/dist/detectors/cache-storage-reads.js +323 -0
  131. package/dist/detectors/calldata-secret-access-control.d.ts +36 -0
  132. package/dist/detectors/calldata-secret-access-control.js +446 -0
  133. package/dist/detectors/capital-cross-contract-reentrancy.d.ts +34 -0
  134. package/dist/detectors/capital-cross-contract-reentrancy.js +481 -0
  135. package/dist/detectors/cartel-custom-approval-logic.d.ts +7 -0
  136. package/dist/detectors/cartel-custom-approval-logic.js +407 -0
  137. package/dist/detectors/ccip-receiver-missing-replay-guard.d.ts +22 -0
  138. package/dist/detectors/ccip-receiver-missing-replay-guard.js +413 -0
  139. package/dist/detectors/chain-coupling-risk.d.ts +8 -0
  140. package/dist/detectors/chain-coupling-risk.js +203 -0
  141. package/dist/detectors/chainlink-deprecated-function.d.ts +7 -0
  142. package/dist/detectors/chainlink-deprecated-function.js +205 -0
  143. package/dist/detectors/chainlink-tx-origin.d.ts +7 -0
  144. package/dist/detectors/chainlink-tx-origin.js +363 -0
  145. package/dist/detectors/check-effects-interactions.d.ts +39 -0
  146. package/dist/detectors/check-effects-interactions.js +783 -0
  147. package/dist/detectors/check-permit-missing-chainid.d.ts +27 -0
  148. package/dist/detectors/check-permit-missing-chainid.js +456 -0
  149. package/dist/detectors/classic-reentrancy.d.ts +93 -0
  150. package/dist/detectors/classic-reentrancy.js +645 -0
  151. package/dist/detectors/coinbase-morpho-wethloan-policy.d.ts +29 -0
  152. package/dist/detectors/coinbase-morpho-wethloan-policy.js +368 -0
  153. package/dist/detectors/compoundv2-inflation-attack.d.ts +7 -0
  154. package/dist/detectors/compoundv2-inflation-attack.js +675 -0
  155. package/dist/detectors/constructor-address-validation.d.ts +24 -0
  156. package/dist/detectors/constructor-address-validation.js +335 -0
  157. package/dist/detectors/constructor-interface-no-address-validation.d.ts +32 -0
  158. package/dist/detectors/constructor-interface-no-address-validation.js +283 -0
  159. package/dist/detectors/cross-chain-arbitrary-call.d.ts +7 -0
  160. package/dist/detectors/cross-chain-arbitrary-call.js +601 -0
  161. package/dist/detectors/cross-chain-input-validation.d.ts +31 -0
  162. package/dist/detectors/cross-chain-input-validation.js +347 -0
  163. package/dist/detectors/cross-chain-intent-replay.d.ts +38 -0
  164. package/dist/detectors/cross-chain-intent-replay.js +453 -0
  165. package/dist/detectors/cross-chain-intent-stale-resolution.d.ts +7 -0
  166. package/dist/detectors/cross-chain-intent-stale-resolution.js +463 -0
  167. package/dist/detectors/cross-chain-message-order-dependency.d.ts +8 -0
  168. package/dist/detectors/cross-chain-message-order-dependency.js +472 -0
  169. package/dist/detectors/cross-chain-message-replay.d.ts +8 -0
  170. package/dist/detectors/cross-chain-message-replay.js +568 -0
  171. package/dist/detectors/cross-chain-messaging.d.ts +7 -0
  172. package/dist/detectors/cross-chain-messaging.js +663 -0
  173. package/dist/detectors/cross-chain-msg-truncation.d.ts +7 -0
  174. package/dist/detectors/cross-chain-msg-truncation.js +453 -0
  175. package/dist/detectors/cross-chain-truncation.d.ts +7 -0
  176. package/dist/detectors/cross-chain-truncation.js +422 -0
  177. package/dist/detectors/cross-contract-integer-overflow.d.ts +76 -0
  178. package/dist/detectors/cross-contract-integer-overflow.js +554 -0
  179. package/dist/detectors/cross-contract-reentrancy-trusted-callee.d.ts +39 -0
  180. package/dist/detectors/cross-contract-reentrancy-trusted-callee.js +385 -0
  181. package/dist/detectors/cross-contract-reentrancy.d.ts +63 -0
  182. package/dist/detectors/cross-contract-reentrancy.js +631 -0
  183. package/dist/detectors/cross-function-reentrancy.d.ts +37 -0
  184. package/dist/detectors/cross-function-reentrancy.js +648 -0
  185. package/dist/detectors/cross-protocol-contagion.d.ts +20 -0
  186. package/dist/detectors/cross-protocol-contagion.js +445 -0
  187. package/dist/detectors/cross-protocol-oracle-collateral.d.ts +38 -0
  188. package/dist/detectors/cross-protocol-oracle-collateral.js +487 -0
  189. package/dist/detectors/cross-vm-reentrancy.d.ts +7 -0
  190. package/dist/detectors/cross-vm-reentrancy.js +484 -0
  191. package/dist/detectors/decimals-mismatch.d.ts +89 -0
  192. package/dist/detectors/decimals-mismatch.js +451 -0
  193. package/dist/detectors/deferred-state-update.d.ts +16 -0
  194. package/dist/detectors/deferred-state-update.js +35 -0
  195. package/dist/detectors/deflationary-token.d.ts +27 -0
  196. package/dist/detectors/deflationary-token.js +751 -0
  197. package/dist/detectors/delegate-transfer-unrestricted-caller.d.ts +44 -0
  198. package/dist/detectors/delegate-transfer-unrestricted-caller.js +410 -0
  199. package/dist/detectors/delegatecall-fallback-reentrancy-bypass.d.ts +14 -0
  200. package/dist/detectors/delegatecall-fallback-reentrancy-bypass.js +241 -0
  201. package/dist/detectors/delegatecall-in-loops.d.ts +7 -0
  202. package/dist/detectors/delegatecall-in-loops.js +129 -0
  203. package/dist/detectors/delegatecall-init-owner-mutator.d.ts +8 -0
  204. package/dist/detectors/delegatecall-init-owner-mutator.js +655 -0
  205. package/dist/detectors/delegatecall-init.d.ts +7 -0
  206. package/dist/detectors/delegatecall-init.js +769 -0
  207. package/dist/detectors/delegatecall-untrusted-implementation.d.ts +41 -0
  208. package/dist/detectors/delegatecall-untrusted-implementation.js +888 -0
  209. package/dist/detectors/delegated-authorization-bypass.d.ts +7 -0
  210. package/dist/detectors/delegated-authorization-bypass.js +370 -0
  211. package/dist/detectors/denial-of-service.d.ts +117 -0
  212. package/dist/detectors/denial-of-service.js +947 -0
  213. package/dist/detectors/division-before-multiplication.d.ts +7 -0
  214. package/dist/detectors/division-before-multiplication.js +303 -0
  215. package/dist/detectors/dn404-mirror-access-control.d.ts +26 -0
  216. package/dist/detectors/dn404-mirror-access-control.js +315 -0
  217. package/dist/detectors/doge-flashloan.d.ts +29 -0
  218. package/dist/detectors/doge-flashloan.js +329 -0
  219. package/dist/detectors/donate-inflation-exchangerate-roundin.d.ts +7 -0
  220. package/dist/detectors/donate-inflation-exchangerate-roundin.js +621 -0
  221. package/dist/detectors/donation-share-inflation.d.ts +24 -0
  222. package/dist/detectors/donation-share-inflation.js +466 -0
  223. package/dist/detectors/dont-let-eth-get-rekt.d.ts +84 -0
  224. package/dist/detectors/dont-let-eth-get-rekt.js +1151 -0
  225. package/dist/detectors/dos-unbounded-loop-external-call-revert.d.ts +37 -0
  226. package/dist/detectors/dos-unbounded-loop-external-call-revert.js +541 -0
  227. package/dist/detectors/eip1167-proxy-reentrancy.d.ts +7 -0
  228. package/dist/detectors/eip1167-proxy-reentrancy.js +508 -0
  229. package/dist/detectors/eip4626-vault-reentrancy.d.ts +32 -0
  230. package/dist/detectors/eip4626-vault-reentrancy.js +312 -0
  231. package/dist/detectors/eip5792-auth-replay.d.ts +45 -0
  232. package/dist/detectors/eip5792-auth-replay.js +519 -0
  233. package/dist/detectors/eip712-domain-separator.d.ts +42 -0
  234. package/dist/detectors/eip712-domain-separator.js +524 -0
  235. package/dist/detectors/eip712-signature-verification.d.ts +49 -0
  236. package/dist/detectors/eip712-signature-verification.js +689 -0
  237. package/dist/detectors/eip7702-auth-replay.d.ts +7 -0
  238. package/dist/detectors/eip7702-auth-replay.js +768 -0
  239. package/dist/detectors/eip7702-cross-chain-replay.d.ts +27 -0
  240. package/dist/detectors/eip7702-cross-chain-replay.js +307 -0
  241. package/dist/detectors/eip7702-delegated-eoa-approval-race.d.ts +39 -0
  242. package/dist/detectors/eip7702-delegated-eoa-approval-race.js +413 -0
  243. package/dist/detectors/eip7702-delegation-reentrancy.d.ts +21 -0
  244. package/dist/detectors/eip7702-delegation-reentrancy.js +705 -0
  245. package/dist/detectors/eip7702-delegation-risk.d.ts +7 -0
  246. package/dist/detectors/eip7702-delegation-risk.js +745 -0
  247. package/dist/detectors/eip7702-eoa-assumption.d.ts +57 -0
  248. package/dist/detectors/eip7702-eoa-assumption.js +461 -0
  249. package/dist/detectors/erc1155-batch-missing-per-id-approval.d.ts +23 -0
  250. package/dist/detectors/erc1155-batch-missing-per-id-approval.js +343 -0
  251. package/dist/detectors/erc1155-reentrancy.d.ts +31 -0
  252. package/dist/detectors/erc1155-reentrancy.js +217 -0
  253. package/dist/detectors/erc1271-stub-implementation.d.ts +21 -0
  254. package/dist/detectors/erc1271-stub-implementation.js +268 -0
  255. package/dist/detectors/erc20-safe-wrapper-return-unchecked.d.ts +43 -0
  256. package/dist/detectors/erc20-safe-wrapper-return-unchecked.js +368 -0
  257. package/dist/detectors/erc20-unchecked-non-standard-return.d.ts +55 -0
  258. package/dist/detectors/erc20-unchecked-non-standard-return.js +454 -0
  259. package/dist/detectors/erc2612-permit-frontrunning.d.ts +23 -0
  260. package/dist/detectors/erc2612-permit-frontrunning.js +246 -0
  261. package/dist/detectors/erc2771-context-spoofing.d.ts +41 -0
  262. package/dist/detectors/erc2771-context-spoofing.js +510 -0
  263. package/dist/detectors/erc4337-validation-storage-access.d.ts +35 -0
  264. package/dist/detectors/erc4337-validation-storage-access.js +232 -0
  265. package/dist/detectors/erc4626-totalassets-stub.d.ts +17 -0
  266. package/dist/detectors/erc4626-totalassets-stub.js +216 -0
  267. package/dist/detectors/erc6909-balance-overflow.d.ts +7 -0
  268. package/dist/detectors/erc6909-balance-overflow.js +688 -0
  269. package/dist/detectors/erc6909-operator-scope.d.ts +49 -0
  270. package/dist/detectors/erc6909-operator-scope.js +494 -0
  271. package/dist/detectors/erc721-unchecked-transfer.d.ts +38 -0
  272. package/dist/detectors/erc721-unchecked-transfer.js +364 -0
  273. package/dist/detectors/erc7579-module-install-without-threshold.d.ts +40 -0
  274. package/dist/detectors/erc7579-module-install-without-threshold.js +338 -0
  275. package/dist/detectors/erc7683-fill-validation.d.ts +53 -0
  276. package/dist/detectors/erc7683-fill-validation.js +758 -0
  277. package/dist/detectors/erc7683-intent-resolution.d.ts +7 -0
  278. package/dist/detectors/erc7683-intent-resolution.js +457 -0
  279. package/dist/detectors/erc777-callback-reentrancy.d.ts +8 -0
  280. package/dist/detectors/erc777-callback-reentrancy.js +439 -0
  281. package/dist/detectors/erc777-reentrancy.d.ts +7 -0
  282. package/dist/detectors/erc777-reentrancy.js +488 -0
  283. package/dist/detectors/erc777-tokens-to-send-reentrancy.d.ts +47 -0
  284. package/dist/detectors/erc777-tokens-to-send-reentrancy.js +674 -0
  285. package/dist/detectors/estuary-token-flaw.d.ts +16 -0
  286. package/dist/detectors/estuary-token-flaw.js +547 -0
  287. package/dist/detectors/euler-debt-token-manipulation.d.ts +32 -0
  288. package/dist/detectors/euler-debt-token-manipulation.js +347 -0
  289. package/dist/detectors/exploiting-a-vulnerability-in-curve-fina.d.ts +29 -0
  290. package/dist/detectors/exploiting-a-vulnerability-in-curve-fina.js +210 -0
  291. package/dist/detectors/fallback-delegatecall-reentrancy.d.ts +14 -0
  292. package/dist/detectors/fallback-delegatecall-reentrancy.js +236 -0
  293. package/dist/detectors/farm-business-logic-flaw-lack-of-access.d.ts +7 -0
  294. package/dist/detectors/farm-business-logic-flaw-lack-of-access.js +665 -0
  295. package/dist/detectors/fee-mechanism-exploitation.d.ts +20 -0
  296. package/dist/detectors/fee-mechanism-exploitation.js +400 -0
  297. package/dist/detectors/fee-on-transfer-balance-mismatch.d.ts +49 -0
  298. package/dist/detectors/fee-on-transfer-balance-mismatch.js +394 -0
  299. package/dist/detectors/fhe-encrypted-input-validation.d.ts +29 -0
  300. package/dist/detectors/fhe-encrypted-input-validation.js +210 -0
  301. package/dist/detectors/fhe-handle-leakage.d.ts +44 -0
  302. package/dist/detectors/fhe-handle-leakage.js +315 -0
  303. package/dist/detectors/fhe-oz-pattern-misuse.d.ts +26 -0
  304. package/dist/detectors/fhe-oz-pattern-misuse.js +311 -0
  305. package/dist/detectors/fhe-state-leakage.d.ts +8 -0
  306. package/dist/detectors/fhe-state-leakage.js +400 -0
  307. package/dist/detectors/fi-bridges.d.ts +33 -0
  308. package/dist/detectors/fi-bridges.js +428 -0
  309. package/dist/detectors/finance-access-control-price-oracle-man.d.ts +9 -0
  310. package/dist/detectors/finance-access-control-price-oracle-man.js +640 -0
  311. package/dist/detectors/finance-bridge-address0safetransferfrom.d.ts +8 -0
  312. package/dist/detectors/finance-bridge-address0safetransferfrom.js +574 -0
  313. package/dist/detectors/finance-business-logic-in-mint.d.ts +54 -0
  314. package/dist/detectors/finance-business-logic-in-mint.js +687 -0
  315. package/dist/detectors/finance-erc667-reentrancy.d.ts +7 -0
  316. package/dist/detectors/finance-erc667-reentrancy.js +509 -0
  317. package/dist/detectors/finance-flashloan-price-oracle-manipul.d.ts +7 -0
  318. package/dist/detectors/finance-flashloan-price-oracle-manipul.js +546 -0
  319. package/dist/detectors/finance-flashloan-reentrancy.d.ts +7 -0
  320. package/dist/detectors/finance-flashloan-reentrancy.js +547 -0
  321. package/dist/detectors/finance-swap-metapool-attack.d.ts +19 -0
  322. package/dist/detectors/finance-swap-metapool-attack.js +321 -0
  323. package/dist/detectors/flashloan-price-manipulation.d.ts +7 -0
  324. package/dist/detectors/flashloan-price-manipulation.js +950 -0
  325. package/dist/detectors/flashloan-reentrancy-rari.d.ts +28 -0
  326. package/dist/detectors/flashloan-reentrancy-rari.js +577 -0
  327. package/dist/detectors/flashloan-reentrancy.d.ts +7 -0
  328. package/dist/detectors/flashloan-reentrancy.js +383 -0
  329. package/dist/detectors/flashloan-token-migrate.d.ts +7 -0
  330. package/dist/detectors/flashloan-token-migrate.js +274 -0
  331. package/dist/detectors/force-fed-eth-state-corruption.d.ts +32 -0
  332. package/dist/detectors/force-fed-eth-state-corruption.js +293 -0
  333. package/dist/detectors/free-mint-bug.d.ts +41 -0
  334. package/dist/detectors/free-mint-bug.js +483 -0
  335. package/dist/detectors/front-running-orderbook-state-update.d.ts +37 -0
  336. package/dist/detectors/front-running-orderbook-state-update.js +471 -0
  337. package/dist/detectors/front-running-shared-collateral-write.d.ts +41 -0
  338. package/dist/detectors/front-running-shared-collateral-write.js +508 -0
  339. package/dist/detectors/fusion-v1-settlement-arbitrary-yul-calld.d.ts +30 -0
  340. package/dist/detectors/fusion-v1-settlement-arbitrary-yul-calld.js +354 -0
  341. package/dist/detectors/generalized-frontrunning.d.ts +7 -0
  342. package/dist/detectors/generalized-frontrunning.js +836 -0
  343. package/dist/detectors/governance-flash-loan.d.ts +62 -0
  344. package/dist/detectors/governance-flash-loan.js +452 -0
  345. package/dist/detectors/governance-flashloan-vote.d.ts +41 -0
  346. package/dist/detectors/governance-flashloan-vote.js +272 -0
  347. package/dist/detectors/halborn-security-report-aave-v3.d.ts +6 -0
  348. package/dist/detectors/halborn-security-report-aave-v3.js +357 -0
  349. package/dist/detectors/incorrect-access-control.d.ts +26 -0
  350. package/dist/detectors/incorrect-access-control.js +328 -0
  351. package/dist/detectors/incorrect-burn-accounting.d.ts +10 -0
  352. package/dist/detectors/incorrect-burn-accounting.js +387 -0
  353. package/dist/detectors/incorrect-dividends-calculation.d.ts +27 -0
  354. package/dist/detectors/incorrect-dividends-calculation.js +524 -0
  355. package/dist/detectors/incorrect-dividends.d.ts +27 -0
  356. package/dist/detectors/incorrect-dividends.js +485 -0
  357. package/dist/detectors/incorrect-input-validation.d.ts +23 -0
  358. package/dist/detectors/incorrect-input-validation.js +312 -0
  359. package/dist/detectors/incorrect-signature-verification.d.ts +26 -0
  360. package/dist/detectors/incorrect-signature-verification.js +530 -0
  361. package/dist/detectors/infinite-loop.d.ts +7 -0
  362. package/dist/detectors/infinite-loop.js +440 -0
  363. package/dist/detectors/infinite-number-of-loans.d.ts +13 -0
  364. package/dist/detectors/infinite-number-of-loans.js +565 -0
  365. package/dist/detectors/inheritance-override.d.ts +26 -0
  366. package/dist/detectors/inheritance-override.js +320 -0
  367. package/dist/detectors/initialization-access-control.d.ts +8 -0
  368. package/dist/detectors/initialization-access-control.js +659 -0
  369. package/dist/detectors/insecure-randomness.d.ts +73 -0
  370. package/dist/detectors/insecure-randomness.js +610 -0
  371. package/dist/detectors/insufficient-access-control-trusted-param.d.ts +39 -0
  372. package/dist/detectors/insufficient-access-control-trusted-param.js +356 -0
  373. package/dist/detectors/insufficient-dvn-threshold.d.ts +32 -0
  374. package/dist/detectors/insufficient-dvn-threshold.js +585 -0
  375. package/dist/detectors/integer-overflow-detector.d.ts +45 -0
  376. package/dist/detectors/integer-overflow-detector.js +284 -0
  377. package/dist/detectors/integer-overflow.d.ts +95 -0
  378. package/dist/detectors/integer-overflow.js +344 -0
  379. package/dist/detectors/integer-underflow.d.ts +7 -0
  380. package/dist/detectors/integer-underflow.js +422 -0
  381. package/dist/detectors/intent-settlement-balance-manipulation.d.ts +22 -0
  382. package/dist/detectors/intent-settlement-balance-manipulation.js +548 -0
  383. package/dist/detectors/l1-to-l2-message-reentrancy.d.ts +7 -0
  384. package/dist/detectors/l1-to-l2-message-reentrancy.js +545 -0
  385. package/dist/detectors/l2-withdrawal-validation.d.ts +8 -0
  386. package/dist/detectors/l2-withdrawal-validation.js +303 -0
  387. package/dist/detectors/lack-of-access-control.d.ts +7 -0
  388. package/dist/detectors/lack-of-access-control.js +425 -0
  389. package/dist/detectors/lack-of-calldata-validation.d.ts +16 -0
  390. package/dist/detectors/lack-of-calldata-validation.js +914 -0
  391. package/dist/detectors/lack-of-input-validation-reentrancy.d.ts +7 -0
  392. package/dist/detectors/lack-of-input-validation-reentrancy.js +637 -0
  393. package/dist/detectors/lack-of-slippage-control.d.ts +7 -0
  394. package/dist/detectors/lack-of-slippage-control.js +513 -0
  395. package/dist/detectors/lack-of-slippage-protection.d.ts +7 -0
  396. package/dist/detectors/lack-of-slippage-protection.js +474 -0
  397. package/dist/detectors/lack-of-validation-data.d.ts +23 -0
  398. package/dist/detectors/lack-of-validation-data.js +391 -0
  399. package/dist/detectors/lack-of-validation-pool.d.ts +7 -0
  400. package/dist/detectors/lack-of-validation-pool.js +492 -0
  401. package/dist/detectors/lack-of-validation-userdata.d.ts +7 -0
  402. package/dist/detectors/lack-of-validation-userdata.js +583 -0
  403. package/dist/detectors/lack-of-validation.d.ts +27 -0
  404. package/dist/detectors/lack-of-validation.js +609 -0
  405. package/dist/detectors/layerzero-dvn-quorum-missing.d.ts +22 -0
  406. package/dist/detectors/layerzero-dvn-quorum-missing.js +464 -0
  407. package/dist/detectors/layerzero-v2-unverified-origin.d.ts +40 -0
  408. package/dist/detectors/layerzero-v2-unverified-origin.js +368 -0
  409. package/dist/detectors/liquidation-accounting-desync.d.ts +14 -0
  410. package/dist/detectors/liquidation-accounting-desync.js +145 -0
  411. package/dist/detectors/liquidation-gain-manipulation.d.ts +42 -0
  412. package/dist/detectors/liquidation-gain-manipulation.js +606 -0
  413. package/dist/detectors/liquidation-price-rounding-advantage.d.ts +26 -0
  414. package/dist/detectors/liquidation-price-rounding-advantage.js +283 -0
  415. package/dist/detectors/liquidity-poisoning.d.ts +25 -0
  416. package/dist/detectors/liquidity-poisoning.js +339 -0
  417. package/dist/detectors/loans-malicious-proposal-price-oracle.d.ts +44 -0
  418. package/dist/detectors/loans-malicious-proposal-price-oracle.js +813 -0
  419. package/dist/detectors/logic-flaw.d.ts +186 -0
  420. package/dist/detectors/logic-flaw.js +3356 -0
  421. package/dist/detectors/manipulation-of-funds.d.ts +31 -0
  422. package/dist/detectors/manipulation-of-funds.js +304 -0
  423. package/dist/detectors/merkl-unsafe-claim-callback.d.ts +22 -0
  424. package/dist/detectors/merkl-unsafe-claim-callback.js +94 -0
  425. package/dist/detectors/mev-boost-timestamp.d.ts +7 -0
  426. package/dist/detectors/mev-boost-timestamp.js +318 -0
  427. package/dist/detectors/mev-merge-exploit.d.ts +29 -0
  428. package/dist/detectors/mev-merge-exploit.js +397 -0
  429. package/dist/detectors/mev-sandwich-vulnerability.d.ts +24 -0
  430. package/dist/detectors/mev-sandwich-vulnerability.js +648 -0
  431. package/dist/detectors/mev-slot-manipulation.d.ts +36 -0
  432. package/dist/detectors/mev-slot-manipulation.js +691 -0
  433. package/dist/detectors/mevbot-insufficient-validation.d.ts +48 -0
  434. package/dist/detectors/mevbot-insufficient-validation.js +574 -0
  435. package/dist/detectors/migration-rebalance-without-bound.d.ts +7 -0
  436. package/dist/detectors/migration-rebalance-without-bound.js +514 -0
  437. package/dist/detectors/mint-hardcoded-asset-parity.d.ts +31 -0
  438. package/dist/detectors/mint-hardcoded-asset-parity.js +356 -0
  439. package/dist/detectors/miscalculation-on-spendallowance.d.ts +7 -0
  440. package/dist/detectors/miscalculation-on-spendallowance.js +188 -0
  441. package/dist/detectors/misconfiguration.d.ts +27 -0
  442. package/dist/detectors/misconfiguration.js +410 -0
  443. package/dist/detectors/missing-access-control-caller-supplied-auth.d.ts +7 -0
  444. package/dist/detectors/missing-access-control-caller-supplied-auth.js +550 -0
  445. package/dist/detectors/missing-access-control-receiver-payout.d.ts +7 -0
  446. package/dist/detectors/missing-access-control-receiver-payout.js +460 -0
  447. package/dist/detectors/missing-access-control-role-or-transferfrom.d.ts +7 -0
  448. package/dist/detectors/missing-access-control-role-or-transferfrom.js +663 -0
  449. package/dist/detectors/missing-access-control.d.ts +19 -0
  450. package/dist/detectors/missing-access-control.js +781 -0
  451. package/dist/detectors/missing-sequencer-uptime-check.d.ts +30 -0
  452. package/dist/detectors/missing-sequencer-uptime-check.js +348 -0
  453. package/dist/detectors/missing-storage-gap.d.ts +19 -0
  454. package/dist/detectors/missing-storage-gap.js +193 -0
  455. package/dist/detectors/missing-swap-deadline-slippage.d.ts +31 -0
  456. package/dist/detectors/missing-swap-deadline-slippage.js +231 -0
  457. package/dist/detectors/missing-zk-proof-verification.d.ts +60 -0
  458. package/dist/detectors/missing-zk-proof-verification.js +547 -0
  459. package/dist/detectors/my-experience-with-yearn-finance.d.ts +7 -0
  460. package/dist/detectors/my-experience-with-yearn-finance.js +552 -0
  461. package/dist/detectors/network-bridge-ronin.d.ts +7 -0
  462. package/dist/detectors/network-bridge-ronin.js +408 -0
  463. package/dist/detectors/network-bridge.d.ts +7 -0
  464. package/dist/detectors/network-bridge.js +444 -0
  465. package/dist/detectors/network-underflow.d.ts +7 -0
  466. package/dist/detectors/network-underflow.js +517 -0
  467. package/dist/detectors/nft-denial-of-service.d.ts +7 -0
  468. package/dist/detectors/nft-denial-of-service.js +223 -0
  469. package/dist/detectors/nft-marketplace-order-reentrancy.d.ts +7 -0
  470. package/dist/detectors/nft-marketplace-order-reentrancy.js +427 -0
  471. package/dist/detectors/nft-token-standard-access-control.d.ts +7 -0
  472. package/dist/detectors/nft-token-standard-access-control.js +455 -0
  473. package/dist/detectors/oracle-manipulation-amm-spot-price.d.ts +42 -0
  474. package/dist/detectors/oracle-manipulation-amm-spot-price.js +321 -0
  475. package/dist/detectors/oracle-manipulation-liquidity-withdrawal.d.ts +27 -0
  476. package/dist/detectors/oracle-manipulation-liquidity-withdrawal.js +192 -0
  477. package/dist/detectors/oracle-manipulation.d.ts +90 -0
  478. package/dist/detectors/oracle-manipulation.js +1023 -0
  479. package/dist/detectors/oracle-vortex-manipulation.d.ts +30 -0
  480. package/dist/detectors/oracle-vortex-manipulation.js +473 -0
  481. package/dist/detectors/overpriced-asset-in-oracle.d.ts +41 -0
  482. package/dist/detectors/overpriced-asset-in-oracle.js +420 -0
  483. package/dist/detectors/oz-access-control-roles.d.ts +33 -0
  484. package/dist/detectors/oz-access-control-roles.js +359 -0
  485. package/dist/detectors/pair-manipulation-transfer-hook.d.ts +38 -0
  486. package/dist/detectors/pair-manipulation-transfer-hook.js +366 -0
  487. package/dist/detectors/parameter-access-control.d.ts +47 -0
  488. package/dist/detectors/parameter-access-control.js +511 -0
  489. package/dist/detectors/parameter-manipulation.d.ts +7 -0
  490. package/dist/detectors/parameter-manipulation.js +505 -0
  491. package/dist/detectors/parity-multisig-delegatecall.d.ts +7 -0
  492. package/dist/detectors/parity-multisig-delegatecall.js +707 -0
  493. package/dist/detectors/permissionless-claim-amm-spot-pricing.d.ts +7 -0
  494. package/dist/detectors/permissionless-claim-amm-spot-pricing.js +351 -0
  495. package/dist/detectors/permit-future-dated-deadline.d.ts +31 -0
  496. package/dist/detectors/permit-future-dated-deadline.js +339 -0
  497. package/dist/detectors/phishing-attack-bybit.d.ts +37 -0
  498. package/dist/detectors/phishing-attack-bybit.js +513 -0
  499. package/dist/detectors/post-insolvency-check.d.ts +7 -0
  500. package/dist/detectors/post-insolvency-check.js +277 -0
  501. package/dist/detectors/precision-loss-vulnerability.d.ts +7 -0
  502. package/dist/detectors/precision-loss-vulnerability.js +472 -0
  503. package/dist/detectors/precision-truncation.d.ts +8 -0
  504. package/dist/detectors/precision-truncation.js +425 -0
  505. package/dist/detectors/price-dependency-veth.d.ts +41 -0
  506. package/dist/detectors/price-dependency-veth.js +588 -0
  507. package/dist/detectors/price-feed-verification.d.ts +7 -0
  508. package/dist/detectors/price-feed-verification.js +557 -0
  509. package/dist/detectors/price-manipulation-reentrancy.d.ts +32 -0
  510. package/dist/detectors/price-manipulation-reentrancy.js +445 -0
  511. package/dist/detectors/price-manipulation-via-reentranc.d.ts +7 -0
  512. package/dist/detectors/price-manipulation-via-reentranc.js +569 -0
  513. package/dist/detectors/price-oracle-manipulation.d.ts +25 -0
  514. package/dist/detectors/price-oracle-manipulation.js +530 -0
  515. package/dist/detectors/project-instant-rewards-unlocked.d.ts +6 -0
  516. package/dist/detectors/project-instant-rewards-unlocked.js +462 -0
  517. package/dist/detectors/protocol-reentrancy.d.ts +7 -0
  518. package/dist/detectors/protocol-reentrancy.js +457 -0
  519. package/dist/detectors/proxy-init-race.d.ts +11 -0
  520. package/dist/detectors/proxy-init-race.js +634 -0
  521. package/dist/detectors/proxy-storage-slot-collision.d.ts +7 -0
  522. package/dist/detectors/proxy-storage-slot-collision.js +135 -0
  523. package/dist/detectors/public-internal-function.d.ts +39 -0
  524. package/dist/detectors/public-internal-function.js +233 -0
  525. package/dist/detectors/quote-silent-zero.d.ts +25 -0
  526. package/dist/detectors/quote-silent-zero.js +156 -0
  527. package/dist/detectors/readonly-reentrancy.d.ts +9 -0
  528. package/dist/detectors/readonly-reentrancy.js +108 -0
  529. package/dist/detectors/receipt-redemption-missing-validation.d.ts +31 -0
  530. package/dist/detectors/receipt-redemption-missing-validation.js +453 -0
  531. package/dist/detectors/reentrancy-balance.d.ts +36 -0
  532. package/dist/detectors/reentrancy-balance.js +577 -0
  533. package/dist/detectors/reentrancy-business-logic-game.d.ts +36 -0
  534. package/dist/detectors/reentrancy-business-logic-game.js +616 -0
  535. package/dist/detectors/reentrancy-on-sell-nft.d.ts +23 -0
  536. package/dist/detectors/reentrancy-on-sell-nft.js +510 -0
  537. package/dist/detectors/reflection-token-balance-desync.d.ts +28 -0
  538. package/dist/detectors/reflection-token-balance-desync.js +246 -0
  539. package/dist/detectors/registry-engine.d.ts +34 -0
  540. package/dist/detectors/registry-engine.js +388 -0
  541. package/dist/detectors/rollup-unvalidated-state-update.d.ts +35 -0
  542. package/dist/detectors/rollup-unvalidated-state-update.js +286 -0
  543. package/dist/detectors/s-horizon-bridge-private-key-compromis.d.ts +8 -0
  544. package/dist/detectors/s-horizon-bridge-private-key-compromis.js +615 -0
  545. package/dist/detectors/share-price-manipulation.d.ts +7 -0
  546. package/dist/detectors/share-price-manipulation.js +653 -0
  547. package/dist/detectors/signature-replay.d.ts +30 -0
  548. package/dist/detectors/signature-replay.js +367 -0
  549. package/dist/detectors/simpleswap-unverified-approval.d.ts +27 -0
  550. package/dist/detectors/simpleswap-unverified-approval.js +198 -0
  551. package/dist/detectors/single-spot-oracle-collateral-valuation.d.ts +22 -0
  552. package/dist/detectors/single-spot-oracle-collateral-valuation.js +419 -0
  553. package/dist/detectors/skim-token-balance.d.ts +7 -0
  554. package/dist/detectors/skim-token-balance.js +788 -0
  555. package/dist/detectors/sky-oft-governance-payload.d.ts +7 -0
  556. package/dist/detectors/sky-oft-governance-payload.js +515 -0
  557. package/dist/detectors/sky-oft-governance-truncation.d.ts +32 -0
  558. package/dist/detectors/sky-oft-governance-truncation.js +377 -0
  559. package/dist/detectors/solana-evm-bridge-truncation.d.ts +7 -0
  560. package/dist/detectors/solana-evm-bridge-truncation.js +638 -0
  561. package/dist/detectors/solhint-unchecked-low-level-call.d.ts +74 -0
  562. package/dist/detectors/solhint-unchecked-low-level-call.js +463 -0
  563. package/dist/detectors/stablecoin-pair-spot-oracle.d.ts +7 -0
  564. package/dist/detectors/stablecoin-pair-spot-oracle.js +364 -0
  565. package/dist/detectors/staked-rate-as-oracle.d.ts +44 -0
  566. package/dist/detectors/staked-rate-as-oracle.js +497 -0
  567. package/dist/detectors/stale-oracle.d.ts +63 -0
  568. package/dist/detectors/stale-oracle.js +649 -0
  569. package/dist/detectors/starkware-proof-validation-gap.d.ts +18 -0
  570. package/dist/detectors/starkware-proof-validation-gap.js +629 -0
  571. package/dist/detectors/steth-transfer-reentrancy.d.ts +8 -0
  572. package/dist/detectors/steth-transfer-reentrancy.js +317 -0
  573. package/dist/detectors/storage-collision-malicious-proposal.d.ts +27 -0
  574. package/dist/detectors/storage-collision-malicious-proposal.js +386 -0
  575. package/dist/detectors/timestamp-manipulation.d.ts +49 -0
  576. package/dist/detectors/timestamp-manipulation.js +383 -0
  577. package/dist/detectors/token-access-control.d.ts +7 -0
  578. package/dist/detectors/token-access-control.js +544 -0
  579. package/dist/detectors/token-incorrect-signature-verification.d.ts +23 -0
  580. package/dist/detectors/token-incorrect-signature-verification.js +434 -0
  581. package/dist/detectors/token-transfer-logic-flaw.d.ts +33 -0
  582. package/dist/detectors/token-transfer-logic-flaw.js +267 -0
  583. package/dist/detectors/transfer-double-debit-pool-recipient.d.ts +7 -0
  584. package/dist/detectors/transfer-double-debit-pool-recipient.js +542 -0
  585. package/dist/detectors/treasury-reentrancy.d.ts +7 -0
  586. package/dist/detectors/treasury-reentrancy.js +442 -0
  587. package/dist/detectors/tstore-poison.d.ts +32 -0
  588. package/dist/detectors/tstore-poison.js +417 -0
  589. package/dist/detectors/tstore-race-condition.d.ts +7 -0
  590. package/dist/detectors/tstore-race-condition.js +632 -0
  591. package/dist/detectors/types.d.ts +85 -0
  592. package/dist/detectors/types.js +20 -0
  593. package/dist/detectors/unauthorized-payer-transferfrom.d.ts +66 -0
  594. package/dist/detectors/unauthorized-payer-transferfrom.js +339 -0
  595. package/dist/detectors/unauthorized-transferfrom-shell.d.ts +7 -0
  596. package/dist/detectors/unauthorized-transferfrom-shell.js +504 -0
  597. package/dist/detectors/unauthorized-transferfrom.d.ts +16 -0
  598. package/dist/detectors/unauthorized-transferfrom.js +838 -0
  599. package/dist/detectors/unbound-zk-verifier-input.d.ts +7 -0
  600. package/dist/detectors/unbound-zk-verifier-input.js +445 -0
  601. package/dist/detectors/unbounded-share-price-collateral-oracle.d.ts +48 -0
  602. package/dist/detectors/unbounded-share-price-collateral-oracle.js +566 -0
  603. package/dist/detectors/uncapped-reward-emission.d.ts +7 -0
  604. package/dist/detectors/uncapped-reward-emission.js +493 -0
  605. package/dist/detectors/unchecked-call-forwarding.d.ts +31 -0
  606. package/dist/detectors/unchecked-call-forwarding.js +330 -0
  607. package/dist/detectors/unchecked-external-call-unconditional-state-mutation.d.ts +18 -0
  608. package/dist/detectors/unchecked-external-call-unconditional-state-mutation.js +311 -0
  609. package/dist/detectors/unchecked-external-call.d.ts +66 -0
  610. package/dist/detectors/unchecked-external-call.js +389 -0
  611. package/dist/detectors/unchecked-oft-return.d.ts +13 -0
  612. package/dist/detectors/unchecked-oft-return.js +118 -0
  613. package/dist/detectors/unguarded-governance-execution.d.ts +35 -0
  614. package/dist/detectors/unguarded-governance-execution.js +422 -0
  615. package/dist/detectors/unguarded-governance-executor.d.ts +35 -0
  616. package/dist/detectors/unguarded-governance-executor.js +349 -0
  617. package/dist/detectors/unindexed-event-address.d.ts +7 -0
  618. package/dist/detectors/unindexed-event-address.js +268 -0
  619. package/dist/detectors/uninitialized-implementation.d.ts +27 -0
  620. package/dist/detectors/uninitialized-implementation.js +333 -0
  621. package/dist/detectors/uninitialized-storage-pointer.d.ts +7 -0
  622. package/dist/detectors/uninitialized-storage-pointer.js +110 -0
  623. package/dist/detectors/uniswap-skim-token-balance-attack.d.ts +8 -0
  624. package/dist/detectors/uniswap-skim-token-balance-attack.js +331 -0
  625. package/dist/detectors/uniswap-v4-hook-state-manipulation.d.ts +7 -0
  626. package/dist/detectors/uniswap-v4-hook-state-manipulation.js +296 -0
  627. package/dist/detectors/unprotected-admin-or-fund-sink.d.ts +7 -0
  628. package/dist/detectors/unprotected-admin-or-fund-sink.js +643 -0
  629. package/dist/detectors/unprotected-dex-swap.d.ts +43 -0
  630. package/dist/detectors/unprotected-dex-swap.js +334 -0
  631. package/dist/detectors/unprotected-initializer.d.ts +7 -0
  632. package/dist/detectors/unprotected-initializer.js +707 -0
  633. package/dist/detectors/unprotected-pair-initializer.d.ts +22 -0
  634. package/dist/detectors/unprotected-pair-initializer.js +359 -0
  635. package/dist/detectors/unprotected-upgrade-function.d.ts +7 -0
  636. package/dist/detectors/unprotected-upgrade-function.js +180 -0
  637. package/dist/detectors/unreachable-code-0.8.28.d.ts +19 -0
  638. package/dist/detectors/unreachable-code-0.8.28.js +206 -0
  639. package/dist/detectors/unsafe-proxy-storage.d.ts +7 -0
  640. package/dist/detectors/unsafe-proxy-storage.js +436 -0
  641. package/dist/detectors/unsafe-transient-storage.d.ts +7 -0
  642. package/dist/detectors/unsafe-transient-storage.js +1052 -0
  643. package/dist/detectors/unsafe-tx-origin.d.ts +9 -0
  644. package/dist/detectors/unsafe-tx-origin.js +179 -0
  645. package/dist/detectors/unsigned-validity-window.d.ts +20 -0
  646. package/dist/detectors/unsigned-validity-window.js +220 -0
  647. package/dist/detectors/unvalidated-interface-address.d.ts +25 -0
  648. package/dist/detectors/unvalidated-interface-address.js +377 -0
  649. package/dist/detectors/uups-uninitialized-storage.d.ts +9 -0
  650. package/dist/detectors/uups-uninitialized-storage.js +366 -0
  651. package/dist/detectors/v2-error-k-value-attack.d.ts +33 -0
  652. package/dist/detectors/v2-error-k-value-attack.js +276 -0
  653. package/dist/detectors/v2-k-invariant-bypass.d.ts +33 -0
  654. package/dist/detectors/v2-k-invariant-bypass.js +283 -0
  655. package/dist/detectors/v4-hook-reentrancy.d.ts +9 -0
  656. package/dist/detectors/v4-hook-reentrancy.js +488 -0
  657. package/dist/detectors/vault-inflation-rounding.d.ts +23 -0
  658. package/dist/detectors/vault-inflation-rounding.js +477 -0
  659. package/dist/detectors/vault-share-price-manipulation.d.ts +7 -0
  660. package/dist/detectors/vault-share-price-manipulation.js +332 -0
  661. package/dist/detectors/vortex-interaction-guard.d.ts +45 -0
  662. package/dist/detectors/vortex-interaction-guard.js +275 -0
  663. package/dist/detectors/vortex-protocol-reentrancy-guard.d.ts +27 -0
  664. package/dist/detectors/vortex-protocol-reentrancy-guard.js +408 -0
  665. package/dist/detectors/vulnerable-price-dependency.d.ts +41 -0
  666. package/dist/detectors/vulnerable-price-dependency.js +473 -0
  667. package/dist/detectors/weak-random-mint.d.ts +37 -0
  668. package/dist/detectors/weak-random-mint.js +271 -0
  669. package/dist/detectors/withdraw-be-to-withdraw.d.ts +26 -0
  670. package/dist/detectors/withdraw-be-to-withdraw.js +329 -0
  671. package/dist/detectors/wrong-function-visibility.d.ts +29 -0
  672. package/dist/detectors/wrong-function-visibility.js +147 -0
  673. package/dist/detectors/wrong-price-calculation.d.ts +42 -0
  674. package/dist/detectors/wrong-price-calculation.js +387 -0
  675. package/dist/detectors/yearn-vault-v2-share-price-manipulation.d.ts +32 -0
  676. package/dist/detectors/yearn-vault-v2-share-price-manipulation.js +248 -0
  677. package/dist/detectors/zero-fee.d.ts +7 -0
  678. package/dist/detectors/zero-fee.js +596 -0
  679. package/dist/detectors/zetachain-gateway-hack-analysis.d.ts +7 -0
  680. package/dist/detectors/zetachain-gateway-hack-analysis.js +629 -0
  681. package/dist/detectors/zk-rollup-da-gap.d.ts +8 -0
  682. package/dist/detectors/zk-rollup-da-gap.js +322 -0
  683. package/dist/detectors/zksync-batch-validation.d.ts +8 -0
  684. package/dist/detectors/zksync-batch-validation.js +461 -0
  685. package/dist/detectors/zksync-era-rollup-state-update.d.ts +60 -0
  686. package/dist/detectors/zksync-era-rollup-state-update.js +360 -0
  687. package/dist/detectors/zksync-simulation-drift.d.ts +35 -0
  688. package/dist/detectors/zksync-simulation-drift.js +309 -0
  689. package/dist/exit-codes.d.ts +15 -0
  690. package/dist/exit-codes.js +18 -0
  691. package/dist/formatters/github-actions.d.ts +2 -0
  692. package/dist/formatters/github-actions.js +61 -0
  693. package/dist/formatters/sarif.d.ts +24 -0
  694. package/dist/formatters/sarif.js +670 -0
  695. package/dist/formatters/text.d.ts +14 -0
  696. package/dist/formatters/text.js +152 -0
  697. package/dist/fp-rates.json +70 -0
  698. package/dist/identity/diff-baseline.d.ts +16 -0
  699. package/dist/identity/diff-baseline.js +152 -0
  700. package/dist/identity/hashing.d.ts +39 -0
  701. package/dist/identity/hashing.js +96 -0
  702. package/dist/index.d.ts +174 -0
  703. package/dist/index.js +358 -0
  704. package/dist/parallel-scan.d.ts +66 -0
  705. package/dist/parallel-scan.js +227 -0
  706. package/dist/registry.d.ts +17 -0
  707. package/dist/registry.js +118 -0
  708. package/dist/rules/glob.d.ts +5 -0
  709. package/dist/rules/glob.js +76 -0
  710. package/dist/rules/suppressions.d.ts +23 -0
  711. package/dist/rules/suppressions.js +136 -0
  712. package/dist/rules/tiers.d.ts +23 -0
  713. package/dist/rules/tiers.js +341 -0
  714. package/dist/scan-worker.d.ts +1 -0
  715. package/dist/scan-worker.js +61 -0
  716. package/dist/scan.d.ts +24 -0
  717. package/dist/scan.js +558 -0
  718. package/dist/semantic/contracts.d.ts +10 -0
  719. package/dist/semantic/contracts.js +141 -0
  720. package/dist/semantic/diagnostics.d.ts +29 -0
  721. package/dist/semantic/diagnostics.js +25 -0
  722. package/dist/semantic/eog.d.ts +56 -0
  723. package/dist/semantic/eog.js +545 -0
  724. package/dist/semantic/imports.d.ts +88 -0
  725. package/dist/semantic/imports.js +246 -0
  726. package/dist/semantic/index.d.ts +2 -0
  727. package/dist/semantic/index.js +8 -0
  728. package/dist/semantic/inheritance.d.ts +33 -0
  729. package/dist/semantic/inheritance.js +137 -0
  730. package/dist/semantic/model.d.ts +95 -0
  731. package/dist/semantic/model.js +232 -0
  732. package/dist/semantic/taint-tracker.d.ts +49 -0
  733. package/dist/semantic/taint-tracker.js +410 -0
  734. package/dist/semantic/types.d.ts +119 -0
  735. package/dist/semantic/types.js +18 -0
  736. package/dist/severity.d.ts +10 -0
  737. package/dist/severity.js +78 -0
  738. package/package.json +52 -0
@@ -0,0 +1,66 @@
1
+ /**
2
+ * Worker-pool dispatcher for SolAST's file scan.
3
+ *
4
+ * The synchronous `scanFiles` walks ~100+ detectors against every file
5
+ * on a single thread. `scanFilesParallel` shards a file list across
6
+ * `worker_threads` Workers, each of which calls the same `scanFiles`
7
+ * on its slice. The async public surface is intentional: Node has no
8
+ * non-hacky way to wait synchronously for parallel workers, and the
9
+ * existing CLI is already comfortable with async (see
10
+ * `runAddressScanCommand` in `src/cli.ts`).
11
+ *
12
+ * Design choices:
13
+ *
14
+ * - **Opt-in, gated by a threshold.** Worker startup costs ~hundreds
15
+ * of ms because each Worker imports the solast module and
16
+ * constructs the detector registry. For small file sets the
17
+ * overhead exceeds the parallelism win, so callers explicitly
18
+ * pass `workerCount > 0` and we additionally insist on
19
+ * `files.length >= MIN_FILES_PER_WORKER * workerCount` before
20
+ * splitting at all.
21
+ * - **Round-robin slicing.** Files are interleaved across workers
22
+ * instead of contiguous chunks. Real-world contract directories
23
+ * tend to have heavy files clustered (deep dependency trees in
24
+ * one folder, leaf libraries in another). Round-robin spreads
25
+ * the heavy ones across workers.
26
+ * - **Deterministic output ordering.** Each finding carries the
27
+ * index of its source file in the original list; after merging
28
+ * we sort by that index then by line, restoring exactly the
29
+ * order the sync path would have produced.
30
+ * - **Failure propagation.** A worker that throws bubbles its
31
+ * error up; the dispatcher rejects the returned Promise after
32
+ * terminating any still-running siblings.
33
+ */
34
+ import { ScanOptions, ScanResult } from './index';
35
+ export declare const DEFAULT_MIN_FILES_PER_WORKER = 8;
36
+ export interface ParallelScanOptions extends ScanOptions {
37
+ /**
38
+ * Maximum number of worker threads to use. The actual count is
39
+ * clamped to `[1, files.length]` and to a safety cap of 32 to keep
40
+ * memory predictable. When unset or `<= 1`, the call falls through
41
+ * to the synchronous `scanFiles` path.
42
+ */
43
+ workerCount?: number;
44
+ /**
45
+ * Minimum files per worker before the work is parallelised.
46
+ * Defaults to `DEFAULT_MIN_FILES_PER_WORKER`. With fewer than
47
+ * `workerCount * minFilesPerWorker` files the call falls through
48
+ * to the synchronous path so we never pay worker startup for a
49
+ * trivial scan.
50
+ */
51
+ minFilesPerWorker?: number;
52
+ }
53
+ export declare function shouldUseWorkers(fileCount: number, options: ParallelScanOptions): boolean;
54
+ /**
55
+ * Run an SolAST scan over `files` using a worker_threads pool.
56
+ * Falls through to the synchronous `scanFiles` when the file count is
57
+ * below the parallelism threshold so the call site doesn't have to
58
+ * special-case small scans.
59
+ */
60
+ export declare function scanFilesParallel(files: string[], options?: ParallelScanOptions): Promise<ScanResult[]>;
61
+ /**
62
+ * Convenience helper for the CLI: pick a sensible worker count given
63
+ * a user request and the host CPU. Returns `0` when workers should be
64
+ * skipped entirely (the request was zero, negative, or NaN).
65
+ */
66
+ export declare function resolveWorkerCount(requested: number | undefined): number;
@@ -0,0 +1,227 @@
1
+ "use strict";
2
+ /**
3
+ * Worker-pool dispatcher for SolAST's file scan.
4
+ *
5
+ * The synchronous `scanFiles` walks ~100+ detectors against every file
6
+ * on a single thread. `scanFilesParallel` shards a file list across
7
+ * `worker_threads` Workers, each of which calls the same `scanFiles`
8
+ * on its slice. The async public surface is intentional: Node has no
9
+ * non-hacky way to wait synchronously for parallel workers, and the
10
+ * existing CLI is already comfortable with async (see
11
+ * `runAddressScanCommand` in `src/cli.ts`).
12
+ *
13
+ * Design choices:
14
+ *
15
+ * - **Opt-in, gated by a threshold.** Worker startup costs ~hundreds
16
+ * of ms because each Worker imports the solast module and
17
+ * constructs the detector registry. For small file sets the
18
+ * overhead exceeds the parallelism win, so callers explicitly
19
+ * pass `workerCount > 0` and we additionally insist on
20
+ * `files.length >= MIN_FILES_PER_WORKER * workerCount` before
21
+ * splitting at all.
22
+ * - **Round-robin slicing.** Files are interleaved across workers
23
+ * instead of contiguous chunks. Real-world contract directories
24
+ * tend to have heavy files clustered (deep dependency trees in
25
+ * one folder, leaf libraries in another). Round-robin spreads
26
+ * the heavy ones across workers.
27
+ * - **Deterministic output ordering.** Each finding carries the
28
+ * index of its source file in the original list; after merging
29
+ * we sort by that index then by line, restoring exactly the
30
+ * order the sync path would have produced.
31
+ * - **Failure propagation.** A worker that throws bubbles its
32
+ * error up; the dispatcher rejects the returned Promise after
33
+ * terminating any still-running siblings.
34
+ */
35
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
36
+ if (k2 === undefined) k2 = k;
37
+ var desc = Object.getOwnPropertyDescriptor(m, k);
38
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
39
+ desc = { enumerable: true, get: function() { return m[k]; } };
40
+ }
41
+ Object.defineProperty(o, k2, desc);
42
+ }) : (function(o, m, k, k2) {
43
+ if (k2 === undefined) k2 = k;
44
+ o[k2] = m[k];
45
+ }));
46
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
47
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
48
+ }) : function(o, v) {
49
+ o["default"] = v;
50
+ });
51
+ var __importStar = (this && this.__importStar) || (function () {
52
+ var ownKeys = function(o) {
53
+ ownKeys = Object.getOwnPropertyNames || function (o) {
54
+ var ar = [];
55
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
56
+ return ar;
57
+ };
58
+ return ownKeys(o);
59
+ };
60
+ return function (mod) {
61
+ if (mod && mod.__esModule) return mod;
62
+ var result = {};
63
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
64
+ __setModuleDefault(result, mod);
65
+ return result;
66
+ };
67
+ })();
68
+ Object.defineProperty(exports, "__esModule", { value: true });
69
+ exports.DEFAULT_MIN_FILES_PER_WORKER = void 0;
70
+ exports.shouldUseWorkers = shouldUseWorkers;
71
+ exports.scanFilesParallel = scanFilesParallel;
72
+ exports.resolveWorkerCount = resolveWorkerCount;
73
+ const os = __importStar(require("os"));
74
+ const path = __importStar(require("path"));
75
+ const worker_threads_1 = require("worker_threads");
76
+ const index_1 = require("./index");
77
+ const findings_1 = require("./dedup/findings");
78
+ const files_1 = require("./dedup/files");
79
+ exports.DEFAULT_MIN_FILES_PER_WORKER = 8;
80
+ function shouldUseWorkers(fileCount, options) {
81
+ const requested = options.workerCount ?? 0;
82
+ if (requested <= 1)
83
+ return false;
84
+ const minPerWorker = options.minFilesPerWorker ?? exports.DEFAULT_MIN_FILES_PER_WORKER;
85
+ return fileCount >= requested * minPerWorker;
86
+ }
87
+ function effectiveWorkerCount(fileCount, requested) {
88
+ return Math.max(1, Math.min(fileCount, requested, 32));
89
+ }
90
+ function sliceRoundRobin(items, slices) {
91
+ const out = Array.from({ length: slices }, () => []);
92
+ for (let i = 0; i < items.length; i++)
93
+ out[i % slices].push(items[i]);
94
+ return out;
95
+ }
96
+ /**
97
+ * Run an SolAST scan over `files` using a worker_threads pool.
98
+ * Falls through to the synchronous `scanFiles` when the file count is
99
+ * below the parallelism threshold so the call site doesn't have to
100
+ * special-case small scans.
101
+ */
102
+ async function scanFilesParallel(files, options = {}) {
103
+ files = (0, files_1.deduplicateFilesByContent)(files);
104
+ if (!shouldUseWorkers(files.length, options)) {
105
+ // Strip parallel-only options before delegating to keep the sync
106
+ // path's contract clean.
107
+ const { workerCount: _wc, minFilesPerWorker: _mfp, ...rest } = options;
108
+ return (0, index_1.scanFiles)(files, rest);
109
+ }
110
+ const requested = options.workerCount ?? 0;
111
+ const workerCount = effectiveWorkerCount(files.length, requested);
112
+ const batches = sliceRoundRobin(files, workerCount);
113
+ // Pass only the ScanOptions fields the worker understands. Extra
114
+ // ParallelScanOptions fields (workerCount, minFilesPerWorker) are
115
+ // intentionally not forwarded.
116
+ const workerScanOptions = {};
117
+ if (options.rules)
118
+ workerScanOptions.rules = options.rules;
119
+ if (options.enabledRules)
120
+ workerScanOptions.enabledRules = options.enabledRules;
121
+ if (options.solcVersion)
122
+ workerScanOptions.solcVersion = options.solcVersion;
123
+ if (options.ignorePatterns)
124
+ workerScanOptions.ignorePatterns = options.ignorePatterns;
125
+ if (options.tier)
126
+ workerScanOptions.tier = options.tier;
127
+ // detectorOptions carries per-detector config from `.solast.yml`
128
+ // (e.g. custom Vortex bracket names). It is plain YAML-derived data,
129
+ // so it survives the worker `postMessage` boundary as-is. Without
130
+ // this line a `--workers` scan silently runs detectors with their
131
+ // defaults while the synchronous path honours the config.
132
+ if (options.detectorOptions)
133
+ workerScanOptions.detectorOptions = options.detectorOptions;
134
+ const workerScript = path.join(__dirname, 'scan-worker.js');
135
+ const workers = [];
136
+ const pending = [];
137
+ for (let i = 0; i < batches.length; i++) {
138
+ const batch = batches[i];
139
+ const worker = new worker_threads_1.Worker(workerScript, {
140
+ workerData: { options: workerScanOptions },
141
+ });
142
+ workers.push(worker);
143
+ pending.push(new Promise((resolve, reject) => {
144
+ worker.once('message', (msg) => {
145
+ if (msg.type === 'result' && msg.batchId === i) {
146
+ if (msg.sourceSuppressionDiagnostics && msg.sourceSuppressionDiagnostics.length > 0) {
147
+ msg.findings._sourceSuppressionDiagnostics = msg.sourceSuppressionDiagnostics;
148
+ }
149
+ resolve(msg.findings);
150
+ }
151
+ else if (msg.type === 'error' && msg.batchId === i) {
152
+ const err = new Error(`scan worker ${i} failed: ${msg.message}`);
153
+ if (msg.stack)
154
+ err.workerStack = msg.stack;
155
+ reject(err);
156
+ }
157
+ else {
158
+ reject(new Error(`unexpected message from scan worker ${i}: ${msg.type}`));
159
+ }
160
+ });
161
+ worker.once('error', reject);
162
+ worker.once('exit', code => {
163
+ if (code !== 0)
164
+ reject(new Error(`scan worker ${i} exited with code ${code}`));
165
+ });
166
+ worker.postMessage({ type: 'scan', batchId: i, files: batch });
167
+ }));
168
+ }
169
+ let perBatchFindings;
170
+ try {
171
+ perBatchFindings = await Promise.all(pending);
172
+ }
173
+ finally {
174
+ for (const worker of workers) {
175
+ worker.postMessage({ type: 'shutdown' });
176
+ // terminate() is idempotent and forces shutdown if the worker
177
+ // ignores our shutdown message for any reason.
178
+ worker.terminate().catch(() => undefined);
179
+ }
180
+ }
181
+ // Reassemble in original file order. Each finding identifies its
182
+ // source file via `finding.file`, so an indexOf lookup against the
183
+ // original list is enough — and avoids needing the worker to echo
184
+ // a per-finding original index back.
185
+ const fileOrder = new Map();
186
+ for (let i = 0; i < files.length; i++)
187
+ fileOrder.set(files[i], i);
188
+ const merged = perBatchFindings.flat();
189
+ const sourceSuppressionDiagnostics = perBatchFindings.flatMap(findings => findings._sourceSuppressionDiagnostics ?? []);
190
+ merged.sort((a, b) => {
191
+ const orderA = fileOrder.get(a.file) ?? Number.MAX_SAFE_INTEGER;
192
+ const orderB = fileOrder.get(b.file) ?? Number.MAX_SAFE_INTEGER;
193
+ if (orderA !== orderB)
194
+ return orderA - orderB;
195
+ if ((a.line || 0) !== (b.line || 0))
196
+ return (a.line || 0) - (b.line || 0);
197
+ return (a.ruleId || '').localeCompare(b.ruleId || '');
198
+ });
199
+ if (options.dedup && merged.length > 0) {
200
+ const { findings: deduped, rawCount, uniqueCount } = (0, findings_1.dedupFindings)(merged);
201
+ deduped._dedup = { rawCount, uniqueCount };
202
+ if (sourceSuppressionDiagnostics.length > 0) {
203
+ deduped._sourceSuppressionDiagnostics = sourceSuppressionDiagnostics;
204
+ }
205
+ return deduped;
206
+ }
207
+ if (sourceSuppressionDiagnostics.length > 0) {
208
+ merged._sourceSuppressionDiagnostics = sourceSuppressionDiagnostics;
209
+ }
210
+ return merged;
211
+ }
212
+ /**
213
+ * Convenience helper for the CLI: pick a sensible worker count given
214
+ * a user request and the host CPU. Returns `0` when workers should be
215
+ * skipped entirely (the request was zero, negative, or NaN).
216
+ */
217
+ function resolveWorkerCount(requested) {
218
+ if (requested === undefined)
219
+ return 0;
220
+ if (!Number.isFinite(requested) || requested <= 0)
221
+ return 0;
222
+ const cpus = typeof os.availableParallelism === 'function'
223
+ ? os.availableParallelism()
224
+ : Math.max(1, (os.cpus() || []).length || 1);
225
+ return Math.max(1, Math.min(Math.floor(requested), cpus, 32));
226
+ }
227
+ //# sourceMappingURL=parallel-scan.js.map
@@ -0,0 +1,17 @@
1
+ import { DetectorRegistry } from './detectors/registry-engine';
2
+ /**
3
+ * Build the default registry by auto-discovering every detector class.
4
+ *
5
+ * Each src/detectors/*.ts file exports a `*Detector` class that self-declares its id
6
+ * and supportedAstKinds. We glob the compiled detector directory, instantiate each such
7
+ * class, and register it — skipping the EXPLICIT (registered below) and UNREGISTERED
8
+ * (curated-out) sets.
9
+ *
10
+ * Registration order is not significant: dedup picks its surviving finding by a
11
+ * deterministic severity/confidence/findingId sort, and scan output is location-sorted —
12
+ * so the id-sort below is purely for stable iteration.
13
+ */
14
+ export declare function createDefaultDetectorRegistry(options?: {
15
+ profile?: boolean;
16
+ detectorOptions?: Record<string, any>;
17
+ }): DetectorRegistry;
@@ -0,0 +1,118 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.createDefaultDetectorRegistry = createDefaultDetectorRegistry;
37
+ const fs = __importStar(require("fs"));
38
+ const path = __importStar(require("path"));
39
+ const registry_engine_1 = require("./detectors/registry-engine");
40
+ // Four detectors need non-standard construction (a constructor argument, or a
41
+ // registry-assigned id/patternKey/supportedAstKinds the class does not self-declare),
42
+ // so they are registered explicitly below and skipped by the auto-discovery loop.
43
+ const vortex_interaction_guard_1 = require("./detectors/vortex-interaction-guard");
44
+ const protocol_reentrancy_1 = require("./detectors/protocol-reentrancy");
45
+ const readonly_reentrancy_1 = require("./detectors/readonly-reentrancy");
46
+ const v4_hook_reentrancy_1 = require("./detectors/v4-hook-reentrancy");
47
+ const EXPLICIT = new Set([
48
+ 'VortexInteractionGuardDetector',
49
+ 'ProtocolReentrancyDetector',
50
+ 'ReadOnlyReentrancyDetector',
51
+ 'V4HookReentrancyDetector',
52
+ ]);
53
+ // Detector classes that exist as files but are intentionally NOT registered — kept as
54
+ // reference implementations (e.g. they do not declare supportedAstKinds). This short,
55
+ // explicit list is the curation that the old hand-written import list used to encode.
56
+ const UNREGISTERED = new Set([
57
+ 'HalbornSecurityReportAaveV3Detector',
58
+ 'ProjectInstantRewardsUnlockedDetector',
59
+ 'BusinessLogicDetector', // third unauthorized-transferfrom variant; original registers only the other two
60
+ ]);
61
+ /**
62
+ * Build the default registry by auto-discovering every detector class.
63
+ *
64
+ * Each src/detectors/*.ts file exports a `*Detector` class that self-declares its id
65
+ * and supportedAstKinds. We glob the compiled detector directory, instantiate each such
66
+ * class, and register it — skipping the EXPLICIT (registered below) and UNREGISTERED
67
+ * (curated-out) sets.
68
+ *
69
+ * Registration order is not significant: dedup picks its surviving finding by a
70
+ * deterministic severity/confidence/findingId sort, and scan output is location-sorted —
71
+ * so the id-sort below is purely for stable iteration.
72
+ */
73
+ function createDefaultDetectorRegistry(options = {}) {
74
+ const registry = new registry_engine_1.DetectorRegistry(options);
75
+ const dir = path.join(__dirname, 'detectors');
76
+ const discovered = [];
77
+ for (const file of fs.readdirSync(dir)) {
78
+ if (!file.endsWith('.js') || file === 'types.js' || file === 'registry-engine.js')
79
+ continue;
80
+ const mod = require(path.join(dir, file));
81
+ for (const exportName of Object.keys(mod)) {
82
+ if (!exportName.endsWith('Detector') || EXPLICIT.has(exportName) || UNREGISTERED.has(exportName))
83
+ continue;
84
+ const Ctor = mod[exportName];
85
+ if (typeof Ctor !== 'function')
86
+ continue;
87
+ let instance;
88
+ try {
89
+ instance = new Ctor();
90
+ }
91
+ catch (e) {
92
+ // A detector whose constructor throws would otherwise vanish from
93
+ // the registry with no trace — make the drop loud so a regression
94
+ // in one of 300+ files can't silently disable a rule.
95
+ process.stderr.write(`warning: detector class ${exportName} (${file}) failed to construct and was skipped: `
96
+ + `${e instanceof Error ? e.message : String(e)}\n`);
97
+ continue;
98
+ }
99
+ if (instance && typeof instance.id === 'string')
100
+ discovered.push(instance);
101
+ }
102
+ }
103
+ discovered.sort((a, b) => a.id.localeCompare(b.id));
104
+ for (const detector of discovered)
105
+ registry.register(detector);
106
+ registry.register(new vortex_interaction_guard_1.VortexInteractionGuardDetector(options.detectorOptions?.['vortex-interaction-guard']));
107
+ registry.register(Object.assign(new protocol_reentrancy_1.ProtocolReentrancyDetector(), {
108
+ id: 'protocol-reentrancy', patternKey: 'protocol-reentrancy', supportedAstKinds: ['parser'],
109
+ }));
110
+ registry.register(Object.assign(new readonly_reentrancy_1.ReadOnlyReentrancyDetector(), {
111
+ id: 'read-only-reentrancy', patternKey: 'read-only-reentrancy', supportedAstKinds: ['parser'],
112
+ }));
113
+ registry.register(Object.assign(new v4_hook_reentrancy_1.V4HookReentrancyDetector(), {
114
+ id: 'v4-hook-reentrancy', patternKey: 'v4-hook-reentrancy', supportedAstKinds: ['parser'],
115
+ }));
116
+ return registry;
117
+ }
118
+ //# sourceMappingURL=registry.js.map
@@ -0,0 +1,5 @@
1
+ export declare class GlobPatternError extends Error {
2
+ constructor(message: string);
3
+ }
4
+ export declare function validateGlobPattern(pattern: string): string;
5
+ export declare function matchesRuleGlob(ruleId: string, pattern: string): boolean;
@@ -0,0 +1,76 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.GlobPatternError = void 0;
4
+ exports.validateGlobPattern = validateGlobPattern;
5
+ exports.matchesRuleGlob = matchesRuleGlob;
6
+ class GlobPatternError extends Error {
7
+ constructor(message) {
8
+ super(message);
9
+ this.name = 'GlobPatternError';
10
+ }
11
+ }
12
+ exports.GlobPatternError = GlobPatternError;
13
+ function validateGlobPattern(pattern) {
14
+ const trimmed = pattern.trim();
15
+ if (!trimmed) {
16
+ throw new GlobPatternError('--ignore-pattern must not be empty');
17
+ }
18
+ compileRuleGlob(trimmed);
19
+ return trimmed;
20
+ }
21
+ function matchesRuleGlob(ruleId, pattern) {
22
+ return compileRuleGlob(pattern).test(ruleId);
23
+ }
24
+ function compileRuleGlob(pattern) {
25
+ let regex = '^';
26
+ for (let i = 0; i < pattern.length; i++) {
27
+ const ch = pattern[i];
28
+ if (ch === '*') {
29
+ regex += '.*';
30
+ }
31
+ else if (ch === '?') {
32
+ regex += '.';
33
+ }
34
+ else if (ch === '[') {
35
+ const end = findCharacterClassEnd(pattern, i + 1);
36
+ if (end === -1) {
37
+ throw new GlobPatternError(`malformed glob pattern ${JSON.stringify(pattern)}: unterminated character class`);
38
+ }
39
+ const body = pattern.slice(i + 1, end);
40
+ if (body.length === 0 || body === '!' || body === '^') {
41
+ throw new GlobPatternError(`malformed glob pattern ${JSON.stringify(pattern)}: empty character class`);
42
+ }
43
+ const negated = body[0] === '!' || body[0] === '^';
44
+ const classBody = negated ? body.slice(1) : body;
45
+ regex += `[${negated ? '^' : ''}${classBody.replace(/\\/g, '\\\\')}]`;
46
+ i = end;
47
+ }
48
+ else if (ch === '\\') {
49
+ if (i === pattern.length - 1) {
50
+ throw new GlobPatternError(`malformed glob pattern ${JSON.stringify(pattern)}: trailing escape`);
51
+ }
52
+ regex += escapeRegExp(pattern[++i]);
53
+ }
54
+ else {
55
+ regex += escapeRegExp(ch);
56
+ }
57
+ }
58
+ regex += '$';
59
+ try {
60
+ return new RegExp(regex);
61
+ }
62
+ catch (e) {
63
+ throw new GlobPatternError(`malformed glob pattern ${JSON.stringify(pattern)}: ${e instanceof Error ? e.message : String(e)}`);
64
+ }
65
+ }
66
+ function findCharacterClassEnd(pattern, start) {
67
+ for (let i = start; i < pattern.length; i++) {
68
+ if (pattern[i] === ']')
69
+ return i;
70
+ }
71
+ return -1;
72
+ }
73
+ function escapeRegExp(value) {
74
+ return value.replace(/[|\\{}()[\]^$+?.]/g, '\\$&');
75
+ }
76
+ //# sourceMappingURL=glob.js.map
@@ -0,0 +1,23 @@
1
+ import type { ScanResult } from '../api';
2
+ type SourceSuppression = {
3
+ kind: 'all';
4
+ } | {
5
+ kind: 'rules';
6
+ ruleIds: Set<string>;
7
+ };
8
+ export interface SourceSuppressionDiagnostic {
9
+ file: string;
10
+ line: number;
11
+ ruleId: string;
12
+ message: string;
13
+ }
14
+ export interface SourceSuppressionResult {
15
+ findings: ScanResult[];
16
+ diagnostics: SourceSuppressionDiagnostic[];
17
+ }
18
+ export declare function applySourceSuppressions(findings: ScanResult[], file: string, sourceText: string | undefined, validRuleIds: ReadonlySet<string>): SourceSuppressionResult;
19
+ export declare function parseSourceSuppressions(file: string, sourceText: string, validRuleIds: ReadonlySet<string>): {
20
+ suppressions: Map<number, SourceSuppression>;
21
+ diagnostics: SourceSuppressionDiagnostic[];
22
+ };
23
+ export {};
@@ -0,0 +1,136 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.applySourceSuppressions = applySourceSuppressions;
4
+ exports.parseSourceSuppressions = parseSourceSuppressions;
5
+ const DIRECTIVE = 'solast-disable-next-line';
6
+ function applySourceSuppressions(findings, file, sourceText, validRuleIds) {
7
+ if (!sourceText) {
8
+ return { findings, diagnostics: [] };
9
+ }
10
+ const { suppressions, diagnostics } = parseSourceSuppressions(file, sourceText, validRuleIds);
11
+ if (suppressions.size === 0)
12
+ return { findings, diagnostics };
13
+ return {
14
+ findings: findings.filter(finding => !isSuppressed(finding, suppressions)),
15
+ diagnostics,
16
+ };
17
+ }
18
+ function parseSourceSuppressions(file, sourceText, validRuleIds) {
19
+ const suppressions = new Map();
20
+ const diagnostics = [];
21
+ const lines = sourceText.split(/\r?\n/);
22
+ let inBlockComment = false;
23
+ for (let i = 0; i < lines.length; i++) {
24
+ const scan = findLineCommentStart(lines[i], inBlockComment);
25
+ inBlockComment = scan.inBlockComment;
26
+ if (scan.commentStart < 0)
27
+ continue;
28
+ const comment = lines[i].slice(scan.commentStart + 2).trim();
29
+ if (!comment.startsWith(DIRECTIVE))
30
+ continue;
31
+ const next = comment.charAt(DIRECTIVE.length);
32
+ if (next && !/\s/.test(next))
33
+ continue;
34
+ const targetLine = nextNonBlankLine(lines, i + 1);
35
+ if (targetLine === undefined)
36
+ continue;
37
+ const scopeText = stripTrailingLineComment(comment.slice(DIRECTIVE.length)).trim();
38
+ if (!scopeText) {
39
+ mergeSuppression(suppressions, targetLine, { kind: 'all' });
40
+ continue;
41
+ }
42
+ const knownRuleIds = new Set();
43
+ for (const ruleId of parseScopedRuleIds(scopeText)) {
44
+ if (validRuleIds.has(ruleId)) {
45
+ knownRuleIds.add(ruleId);
46
+ }
47
+ else {
48
+ diagnostics.push({
49
+ file,
50
+ line: i + 1,
51
+ ruleId,
52
+ message: `warning: ${file}:${i + 1} solast-disable-next-line references unknown rule id '${ruleId}'`,
53
+ });
54
+ }
55
+ }
56
+ mergeSuppression(suppressions, targetLine, { kind: 'rules', ruleIds: knownRuleIds });
57
+ }
58
+ return { suppressions, diagnostics };
59
+ }
60
+ function isSuppressed(finding, suppressions) {
61
+ if (!Number.isFinite(finding.line) || finding.line <= 0)
62
+ return false;
63
+ const suppression = suppressions.get(finding.line);
64
+ if (!suppression)
65
+ return false;
66
+ if (suppression.kind === 'all')
67
+ return true;
68
+ return suppression.ruleIds.has(finding.ruleId);
69
+ }
70
+ function nextNonBlankLine(lines, startIndex) {
71
+ for (let i = startIndex; i < lines.length; i++) {
72
+ if (lines[i].trim().length > 0)
73
+ return i + 1;
74
+ }
75
+ return undefined;
76
+ }
77
+ function parseScopedRuleIds(scopeText) {
78
+ const ids = [];
79
+ for (const part of scopeText.split(',')) {
80
+ const token = part.trim().split(/\s+/)[0];
81
+ if (token)
82
+ ids.push(token);
83
+ }
84
+ return ids;
85
+ }
86
+ function stripTrailingLineComment(text) {
87
+ const nestedComment = text.indexOf('//');
88
+ return nestedComment >= 0 ? text.slice(0, nestedComment) : text;
89
+ }
90
+ function mergeSuppression(suppressions, line, next) {
91
+ const existing = suppressions.get(line);
92
+ if (!existing || existing.kind === 'all' || next.kind === 'all') {
93
+ suppressions.set(line, existing?.kind === 'all' ? existing : next);
94
+ return;
95
+ }
96
+ for (const ruleId of next.ruleIds)
97
+ existing.ruleIds.add(ruleId);
98
+ }
99
+ function findLineCommentStart(line, inBlockCommentAtStart) {
100
+ let inBlockComment = inBlockCommentAtStart;
101
+ let quote = null;
102
+ for (let i = 0; i < line.length; i++) {
103
+ const ch = line[i];
104
+ const next = line[i + 1];
105
+ if (quote) {
106
+ if (ch === '\\') {
107
+ i++;
108
+ }
109
+ else if (ch === quote) {
110
+ quote = null;
111
+ }
112
+ continue;
113
+ }
114
+ if (inBlockComment) {
115
+ if (ch === '*' && next === '/') {
116
+ inBlockComment = false;
117
+ i++;
118
+ }
119
+ continue;
120
+ }
121
+ if (ch === '"' || ch === "'") {
122
+ quote = ch;
123
+ continue;
124
+ }
125
+ if (ch === '/' && next === '*') {
126
+ inBlockComment = true;
127
+ i++;
128
+ continue;
129
+ }
130
+ if (ch === '/' && next === '/') {
131
+ return { commentStart: i, inBlockComment };
132
+ }
133
+ }
134
+ return { commentStart: -1, inBlockComment };
135
+ }
136
+ //# sourceMappingURL=suppressions.js.map