@0xtorch/evm 0.0.11 → 0.0.13

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 (411) hide show
  1. package/.DS_Store +0 -0
  2. package/_cjs/analyzer/analyze.js.map +1 -1
  3. package/_cjs/analyzer/axieMarketplace/analyze.js +37 -130
  4. package/_cjs/analyzer/axieMarketplace/analyze.js.map +1 -1
  5. package/_cjs/analyzer/gasFee/analyze.js +22 -21
  6. package/_cjs/analyzer/gasFee/analyze.js.map +1 -1
  7. package/_cjs/analyzer/index.js +2 -1
  8. package/_cjs/analyzer/index.js.map +1 -1
  9. package/_cjs/analyzer/json/analyze.js +21 -29
  10. package/_cjs/analyzer/json/analyze.js.map +1 -1
  11. package/_cjs/analyzer/json/components/comment.js +47 -0
  12. package/_cjs/analyzer/json/components/comment.js.map +1 -0
  13. package/_cjs/analyzer/json/components/erc1155.js +93 -0
  14. package/_cjs/analyzer/json/components/erc1155.js.map +1 -0
  15. package/_cjs/analyzer/json/components/erc1155Raw.js +31 -0
  16. package/_cjs/analyzer/json/components/erc1155Raw.js.map +1 -0
  17. package/_cjs/analyzer/json/components/erc20.js +90 -0
  18. package/_cjs/analyzer/json/components/erc20.js.map +1 -0
  19. package/_cjs/analyzer/json/components/erc20Raw.js +28 -0
  20. package/_cjs/analyzer/json/components/erc20Raw.js.map +1 -0
  21. package/_cjs/analyzer/json/components/erc721.js +78 -0
  22. package/_cjs/analyzer/json/components/erc721.js.map +1 -0
  23. package/_cjs/analyzer/json/components/erc721Raw.js +29 -0
  24. package/_cjs/analyzer/json/components/erc721Raw.js.map +1 -0
  25. package/_cjs/analyzer/json/components/id.js +47 -0
  26. package/_cjs/analyzer/json/components/id.js.map +1 -0
  27. package/_cjs/analyzer/json/components/internal.js +78 -0
  28. package/_cjs/analyzer/json/components/internal.js.map +1 -0
  29. package/_cjs/analyzer/json/components/internalRaw.js +26 -0
  30. package/_cjs/analyzer/json/components/internalRaw.js.map +1 -0
  31. package/_cjs/analyzer/json/components/logArgument.js +67 -0
  32. package/_cjs/analyzer/json/components/logArgument.js.map +1 -0
  33. package/_cjs/analyzer/json/components/logArgumentRaw.js +41 -0
  34. package/_cjs/analyzer/json/components/logArgumentRaw.js.map +1 -0
  35. package/_cjs/analyzer/json/components/transfer.js +435 -0
  36. package/_cjs/analyzer/json/components/transfer.js.map +1 -0
  37. package/_cjs/analyzer/json/condition/address.js +106 -0
  38. package/_cjs/analyzer/json/condition/address.js.map +1 -0
  39. package/_cjs/analyzer/json/condition/argumentValue.js +31 -0
  40. package/_cjs/analyzer/json/condition/argumentValue.js.map +1 -0
  41. package/_cjs/analyzer/json/condition/index.js +10 -0
  42. package/_cjs/analyzer/json/condition/index.js.map +1 -0
  43. package/_cjs/analyzer/json/condition/value.js +65 -0
  44. package/_cjs/analyzer/json/condition/value.js.map +1 -0
  45. package/_cjs/analyzer/json/generator.js +791 -0
  46. package/_cjs/analyzer/json/generator.js.map +1 -0
  47. package/_cjs/analyzer/json/index.js +3 -1
  48. package/_cjs/analyzer/json/index.js.map +1 -1
  49. package/_cjs/analyzer/json/schemas/generator.js +280 -0
  50. package/_cjs/analyzer/json/schemas/generator.js.map +1 -0
  51. package/_cjs/analyzer/json/schemas/index.js +303 -0
  52. package/_cjs/analyzer/json/schemas/index.js.map +1 -0
  53. package/_cjs/analyzer/json/schemas/utils.js +14 -0
  54. package/_cjs/analyzer/json/schemas/utils.js.map +1 -0
  55. package/_cjs/analyzer/parsers/transfer.js +149 -0
  56. package/_cjs/analyzer/parsers/transfer.js.map +1 -0
  57. package/_cjs/analyzer/seaport/analyze.js +165 -157
  58. package/_cjs/analyzer/seaport/analyze.js.map +1 -1
  59. package/_cjs/analyzer/spam/analyze.js +61 -90
  60. package/_cjs/analyzer/spam/analyze.js.map +1 -1
  61. package/_cjs/analyzer/swap/analyze.js +50 -75
  62. package/_cjs/analyzer/swap/analyze.js.map +1 -1
  63. package/_cjs/analyzer/transfer/analyze.js +37 -84
  64. package/_cjs/analyzer/transfer/analyze.js.map +1 -1
  65. package/_cjs/index.js +3 -2
  66. package/_cjs/index.js.map +1 -1
  67. package/_cjs/utils/create.js +28 -0
  68. package/_cjs/utils/create.js.map +1 -0
  69. package/_cjs/utils/index.js +3 -1
  70. package/_cjs/utils/index.js.map +1 -1
  71. package/_esm/analyzer/analyze.js.map +1 -1
  72. package/_esm/analyzer/axieMarketplace/analyze.js +37 -130
  73. package/_esm/analyzer/axieMarketplace/analyze.js.map +1 -1
  74. package/_esm/analyzer/gasFee/analyze.js +23 -21
  75. package/_esm/analyzer/gasFee/analyze.js.map +1 -1
  76. package/_esm/analyzer/index.js +1 -1
  77. package/_esm/analyzer/index.js.map +1 -1
  78. package/_esm/analyzer/json/analyze.js +22 -29
  79. package/_esm/analyzer/json/analyze.js.map +1 -1
  80. package/_esm/analyzer/json/components/comment.js +43 -0
  81. package/_esm/analyzer/json/components/comment.js.map +1 -0
  82. package/_esm/analyzer/json/components/erc1155.js +88 -0
  83. package/_esm/analyzer/json/components/erc1155.js.map +1 -0
  84. package/_esm/analyzer/json/components/erc1155Raw.js +27 -0
  85. package/_esm/analyzer/json/components/erc1155Raw.js.map +1 -0
  86. package/_esm/analyzer/json/components/erc20.js +85 -0
  87. package/_esm/analyzer/json/components/erc20.js.map +1 -0
  88. package/_esm/analyzer/json/components/erc20Raw.js +24 -0
  89. package/_esm/analyzer/json/components/erc20Raw.js.map +1 -0
  90. package/_esm/analyzer/json/components/erc721.js +73 -0
  91. package/_esm/analyzer/json/components/erc721.js.map +1 -0
  92. package/_esm/analyzer/json/components/erc721Raw.js +25 -0
  93. package/_esm/analyzer/json/components/erc721Raw.js.map +1 -0
  94. package/_esm/analyzer/json/components/id.js +43 -0
  95. package/_esm/analyzer/json/components/id.js.map +1 -0
  96. package/_esm/analyzer/json/components/internal.js +73 -0
  97. package/_esm/analyzer/json/components/internal.js.map +1 -0
  98. package/_esm/analyzer/json/components/internalRaw.js +22 -0
  99. package/_esm/analyzer/json/components/internalRaw.js.map +1 -0
  100. package/_esm/analyzer/json/components/logArgument.js +62 -0
  101. package/_esm/analyzer/json/components/logArgument.js.map +1 -0
  102. package/_esm/analyzer/json/components/logArgumentRaw.js +37 -0
  103. package/_esm/analyzer/json/components/logArgumentRaw.js.map +1 -0
  104. package/_esm/analyzer/json/components/transfer.js +431 -0
  105. package/_esm/analyzer/json/components/transfer.js.map +1 -0
  106. package/_esm/analyzer/json/condition/address.js +102 -0
  107. package/_esm/analyzer/json/condition/address.js.map +1 -0
  108. package/_esm/analyzer/json/condition/argumentValue.js +27 -0
  109. package/_esm/analyzer/json/condition/argumentValue.js.map +1 -0
  110. package/_esm/analyzer/json/condition/index.js +4 -0
  111. package/_esm/analyzer/json/condition/index.js.map +1 -0
  112. package/_esm/analyzer/json/condition/value.js +61 -0
  113. package/_esm/analyzer/json/condition/value.js.map +1 -0
  114. package/_esm/analyzer/json/generator.js +842 -0
  115. package/_esm/analyzer/json/generator.js.map +1 -0
  116. package/_esm/analyzer/json/index.js +1 -0
  117. package/_esm/analyzer/json/index.js.map +1 -1
  118. package/_esm/analyzer/json/schemas/generator.js +341 -0
  119. package/_esm/analyzer/json/schemas/generator.js.map +1 -0
  120. package/_esm/analyzer/json/schemas/index.js +299 -0
  121. package/_esm/analyzer/json/schemas/index.js.map +1 -0
  122. package/_esm/analyzer/json/schemas/utils.js +11 -0
  123. package/_esm/analyzer/json/schemas/utils.js.map +1 -0
  124. package/_esm/analyzer/parsers/transfer.js +129 -0
  125. package/_esm/analyzer/parsers/transfer.js.map +1 -0
  126. package/_esm/analyzer/seaport/analyze.js +166 -157
  127. package/_esm/analyzer/seaport/analyze.js.map +1 -1
  128. package/_esm/analyzer/spam/analyze.js +62 -92
  129. package/_esm/analyzer/spam/analyze.js.map +1 -1
  130. package/_esm/analyzer/swap/analyze.js +51 -75
  131. package/_esm/analyzer/swap/analyze.js.map +1 -1
  132. package/_esm/analyzer/transfer/analyze.js +38 -86
  133. package/_esm/analyzer/transfer/analyze.js.map +1 -1
  134. package/_esm/index.js +1 -1
  135. package/_esm/index.js.map +1 -1
  136. package/_esm/utils/create.js +21 -0
  137. package/_esm/utils/create.js.map +1 -0
  138. package/_esm/utils/index.js +1 -0
  139. package/_esm/utils/index.js.map +1 -1
  140. package/_types/analyzer/analyze.d.ts +11 -16
  141. package/_types/analyzer/analyze.d.ts.map +1 -1
  142. package/_types/analyzer/analyzer.d.ts +9 -1
  143. package/_types/analyzer/analyzer.d.ts.map +1 -1
  144. package/_types/analyzer/axieMarketplace/analyze.d.ts +9 -2
  145. package/_types/analyzer/axieMarketplace/analyze.d.ts.map +1 -1
  146. package/_types/analyzer/gasFee/analyze.d.ts +9 -2
  147. package/_types/analyzer/gasFee/analyze.d.ts.map +1 -1
  148. package/_types/analyzer/index.d.ts +1 -1
  149. package/_types/analyzer/index.d.ts.map +1 -1
  150. package/_types/analyzer/json/analyze.d.ts +9 -2
  151. package/_types/analyzer/json/analyze.d.ts.map +1 -1
  152. package/_types/analyzer/json/components/comment.d.ts +20 -0
  153. package/_types/analyzer/json/components/comment.d.ts.map +1 -0
  154. package/_types/analyzer/json/components/erc1155.d.ts +32 -0
  155. package/_types/analyzer/json/components/erc1155.d.ts.map +1 -0
  156. package/_types/analyzer/json/components/erc1155Raw.d.ts +18 -0
  157. package/_types/analyzer/json/components/erc1155Raw.d.ts.map +1 -0
  158. package/_types/analyzer/json/components/erc20.d.ts +32 -0
  159. package/_types/analyzer/json/components/erc20.d.ts.map +1 -0
  160. package/_types/analyzer/json/components/erc20Raw.d.ts +18 -0
  161. package/_types/analyzer/json/components/erc20Raw.d.ts.map +1 -0
  162. package/_types/analyzer/json/components/erc721.d.ts +32 -0
  163. package/_types/analyzer/json/components/erc721.d.ts.map +1 -0
  164. package/_types/analyzer/json/components/erc721Raw.d.ts +18 -0
  165. package/_types/analyzer/json/components/erc721Raw.d.ts.map +1 -0
  166. package/_types/analyzer/json/components/id.d.ts +20 -0
  167. package/_types/analyzer/json/components/id.d.ts.map +1 -0
  168. package/_types/analyzer/json/components/internal.d.ts +32 -0
  169. package/_types/analyzer/json/components/internal.d.ts.map +1 -0
  170. package/_types/analyzer/json/components/internalRaw.d.ts +18 -0
  171. package/_types/analyzer/json/components/internalRaw.d.ts.map +1 -0
  172. package/_types/analyzer/json/components/logArgument.d.ts +32 -0
  173. package/_types/analyzer/json/components/logArgument.d.ts.map +1 -0
  174. package/_types/analyzer/json/components/logArgumentRaw.d.ts +18 -0
  175. package/_types/analyzer/json/components/logArgumentRaw.d.ts.map +1 -0
  176. package/_types/analyzer/json/components/transfer.d.ts +20 -0
  177. package/_types/analyzer/json/components/transfer.d.ts.map +1 -0
  178. package/_types/analyzer/json/condition/address.d.ts +18 -0
  179. package/_types/analyzer/json/condition/address.d.ts.map +1 -0
  180. package/_types/analyzer/json/condition/argumentValue.d.ts +18 -0
  181. package/_types/analyzer/json/condition/argumentValue.d.ts.map +1 -0
  182. package/_types/analyzer/json/condition/index.d.ts +4 -0
  183. package/_types/analyzer/json/condition/index.d.ts.map +1 -0
  184. package/_types/analyzer/json/condition/value.d.ts +18 -0
  185. package/_types/analyzer/json/condition/value.d.ts.map +1 -0
  186. package/_types/analyzer/json/generator.d.ts +20 -0
  187. package/_types/analyzer/json/generator.d.ts.map +1 -0
  188. package/_types/analyzer/json/index.d.ts +1 -0
  189. package/_types/analyzer/json/index.d.ts.map +1 -1
  190. package/_types/analyzer/json/schemas/generator.d.ts +56943 -0
  191. package/_types/analyzer/json/schemas/generator.d.ts.map +1 -0
  192. package/_types/analyzer/json/schemas/index.d.ts +1348 -0
  193. package/_types/analyzer/json/schemas/index.d.ts.map +1 -0
  194. package/_types/analyzer/json/schemas/utils.d.ts +4 -0
  195. package/_types/analyzer/json/schemas/utils.d.ts.map +1 -0
  196. package/_types/analyzer/json/types.d.ts +42 -172
  197. package/_types/analyzer/json/types.d.ts.map +1 -1
  198. package/_types/analyzer/parsers/transfer.d.ts +46 -0
  199. package/_types/analyzer/parsers/transfer.d.ts.map +1 -0
  200. package/_types/analyzer/seaport/analyze.d.ts +9 -2
  201. package/_types/analyzer/seaport/analyze.d.ts.map +1 -1
  202. package/_types/analyzer/seaport/orderFulfilled.d.ts +8 -8
  203. package/_types/analyzer/spam/analyze.d.ts +9 -2
  204. package/_types/analyzer/spam/analyze.d.ts.map +1 -1
  205. package/_types/analyzer/swap/analyze.d.ts +9 -2
  206. package/_types/analyzer/swap/analyze.d.ts.map +1 -1
  207. package/_types/analyzer/transfer/analyze.d.ts +9 -2
  208. package/_types/analyzer/transfer/analyze.d.ts.map +1 -1
  209. package/_types/analyzer/types.d.ts +6 -6
  210. package/_types/analyzer/types.d.ts.map +1 -1
  211. package/_types/decoder/tests.d.ts +2 -2
  212. package/_types/explorers/definitions/blockscout.d.ts +60 -4
  213. package/_types/explorers/definitions/blockscout.d.ts.map +1 -1
  214. package/_types/explorers/definitions/etherscan.d.ts +60 -4
  215. package/_types/explorers/definitions/etherscan.d.ts.map +1 -1
  216. package/_types/explorers/definitions/roninExplorer.d.ts +60 -4
  217. package/_types/explorers/definitions/roninExplorer.d.ts.map +1 -1
  218. package/_types/explorers/externals/blockscout/getInternalTransactionsByAddress.d.ts +2 -2
  219. package/_types/getAccountsTransactionFulls/getAccountsTransactionFulls.d.ts +9 -1
  220. package/_types/getAccountsTransactionFulls/getAccountsTransactionFulls.d.ts.map +1 -1
  221. package/_types/getTransactionFull/getTransactionFull.d.ts +9 -1
  222. package/_types/getTransactionFull/getTransactionFull.d.ts.map +1 -1
  223. package/_types/index.d.ts +1 -1
  224. package/_types/index.d.ts.map +1 -1
  225. package/_types/types/log.d.ts +6 -6
  226. package/_types/types/transaction.d.ts +3 -4
  227. package/_types/types/transaction.d.ts.map +1 -1
  228. package/_types/utils/create.d.ts +23 -0
  229. package/_types/utils/create.d.ts.map +1 -0
  230. package/_types/utils/index.d.ts +1 -0
  231. package/_types/utils/index.d.ts.map +1 -1
  232. package/analyzer/.DS_Store +0 -0
  233. package/analyzer/analyze.ts +6 -30
  234. package/analyzer/axieMarketplace/analyze.ts +67 -150
  235. package/analyzer/gasFee/analyze.ts +29 -36
  236. package/analyzer/index.ts +1 -1
  237. package/analyzer/json/analyze.ts +32 -53
  238. package/analyzer/json/components/comment.ts +62 -0
  239. package/analyzer/json/components/erc1155.ts +132 -0
  240. package/analyzer/json/components/erc1155Raw.ts +46 -0
  241. package/analyzer/json/components/erc20.ts +129 -0
  242. package/analyzer/json/components/erc20Raw.ts +43 -0
  243. package/analyzer/json/components/erc721.ts +117 -0
  244. package/analyzer/json/components/erc721Raw.ts +46 -0
  245. package/analyzer/json/components/id.ts +62 -0
  246. package/analyzer/json/components/internal.ts +117 -0
  247. package/analyzer/json/components/internalRaw.ts +39 -0
  248. package/analyzer/json/components/logArgument.ts +99 -0
  249. package/analyzer/json/components/logArgumentRaw.ts +57 -0
  250. package/analyzer/json/components/transfer.ts +531 -0
  251. package/analyzer/json/condition/address.ts +124 -0
  252. package/analyzer/json/condition/argumentValue.ts +43 -0
  253. package/analyzer/json/condition/index.ts +3 -0
  254. package/analyzer/json/condition/value.ts +76 -0
  255. package/analyzer/json/generator.ts +1184 -0
  256. package/analyzer/json/index.ts +1 -0
  257. package/analyzer/json/schemas/generator.ts +389 -0
  258. package/analyzer/json/schemas/index.ts +363 -0
  259. package/analyzer/json/schemas/utils.ts +12 -0
  260. package/analyzer/json/types.ts +111 -207
  261. package/analyzer/parsers/transfer.ts +301 -0
  262. package/analyzer/seaport/analyze.ts +228 -195
  263. package/analyzer/spam/analyze.ts +79 -112
  264. package/analyzer/swap/analyze.ts +67 -101
  265. package/analyzer/transfer/analyze.ts +54 -100
  266. package/analyzer/types.ts +5 -21
  267. package/index.ts +1 -0
  268. package/package.json +2 -2
  269. package/types/transaction.ts +2 -14
  270. package/utils/create.ts +57 -0
  271. package/utils/index.ts +1 -0
  272. package/_cjs/analyzer/createAccountActionByAction/addLiquidity.js +0 -28
  273. package/_cjs/analyzer/createAccountActionByAction/addLiquidity.js.map +0 -1
  274. package/_cjs/analyzer/createAccountActionByAction/atomicArbitrage.js +0 -79
  275. package/_cjs/analyzer/createAccountActionByAction/atomicArbitrage.js.map +0 -1
  276. package/_cjs/analyzer/createAccountActionByAction/bridgeFrom.js +0 -38
  277. package/_cjs/analyzer/createAccountActionByAction/bridgeFrom.js.map +0 -1
  278. package/_cjs/analyzer/createAccountActionByAction/bridgeTo.js +0 -38
  279. package/_cjs/analyzer/createAccountActionByAction/bridgeTo.js.map +0 -1
  280. package/_cjs/analyzer/createAccountActionByAction/buyNft.js +0 -59
  281. package/_cjs/analyzer/createAccountActionByAction/buyNft.js.map +0 -1
  282. package/_cjs/analyzer/createAccountActionByAction/createAccountActionByAction.js +0 -69
  283. package/_cjs/analyzer/createAccountActionByAction/createAccountActionByAction.js.map +0 -1
  284. package/_cjs/analyzer/createAccountActionByAction/deposit.js +0 -41
  285. package/_cjs/analyzer/createAccountActionByAction/deposit.js.map +0 -1
  286. package/_cjs/analyzer/createAccountActionByAction/depositWithBond.js +0 -28
  287. package/_cjs/analyzer/createAccountActionByAction/depositWithBond.js.map +0 -1
  288. package/_cjs/analyzer/createAccountActionByAction/freeMintNft.js +0 -32
  289. package/_cjs/analyzer/createAccountActionByAction/freeMintNft.js.map +0 -1
  290. package/_cjs/analyzer/createAccountActionByAction/index.js +0 -6
  291. package/_cjs/analyzer/createAccountActionByAction/index.js.map +0 -1
  292. package/_cjs/analyzer/createAccountActionByAction/removeLiquidity.js +0 -28
  293. package/_cjs/analyzer/createAccountActionByAction/removeLiquidity.js.map +0 -1
  294. package/_cjs/analyzer/createAccountActionByAction/spam.js +0 -58
  295. package/_cjs/analyzer/createAccountActionByAction/spam.js.map +0 -1
  296. package/_cjs/analyzer/createAccountActionByAction/trade.js +0 -59
  297. package/_cjs/analyzer/createAccountActionByAction/trade.js.map +0 -1
  298. package/_cjs/analyzer/createAccountActionByAction/transactionFee.js +0 -29
  299. package/_cjs/analyzer/createAccountActionByAction/transactionFee.js.map +0 -1
  300. package/_cjs/analyzer/createAccountActionByAction/transfer.js +0 -74
  301. package/_cjs/analyzer/createAccountActionByAction/transfer.js.map +0 -1
  302. package/_cjs/analyzer/createAccountActionByAction/withdraw.js +0 -38
  303. package/_cjs/analyzer/createAccountActionByAction/withdraw.js.map +0 -1
  304. package/_cjs/analyzer/createAccountActionByAction/withdrawWithBond.js +0 -28
  305. package/_cjs/analyzer/createAccountActionByAction/withdrawWithBond.js.map +0 -1
  306. package/_cjs/analyzer/json/generatorAnyLog.js +0 -163
  307. package/_cjs/analyzer/json/generatorAnyLog.js.map +0 -1
  308. package/_cjs/analyzer/json/generatorAnyTokenTransfer.js +0 -102
  309. package/_cjs/analyzer/json/generatorAnyTokenTransfer.js.map +0 -1
  310. package/_cjs/analyzer/json/generatorSpecificTokenTransfer.js +0 -343
  311. package/_cjs/analyzer/json/generatorSpecificTokenTransfer.js.map +0 -1
  312. package/_esm/analyzer/createAccountActionByAction/addLiquidity.js +0 -24
  313. package/_esm/analyzer/createAccountActionByAction/addLiquidity.js.map +0 -1
  314. package/_esm/analyzer/createAccountActionByAction/atomicArbitrage.js +0 -79
  315. package/_esm/analyzer/createAccountActionByAction/atomicArbitrage.js.map +0 -1
  316. package/_esm/analyzer/createAccountActionByAction/bridgeFrom.js +0 -34
  317. package/_esm/analyzer/createAccountActionByAction/bridgeFrom.js.map +0 -1
  318. package/_esm/analyzer/createAccountActionByAction/bridgeTo.js +0 -34
  319. package/_esm/analyzer/createAccountActionByAction/bridgeTo.js.map +0 -1
  320. package/_esm/analyzer/createAccountActionByAction/buyNft.js +0 -59
  321. package/_esm/analyzer/createAccountActionByAction/buyNft.js.map +0 -1
  322. package/_esm/analyzer/createAccountActionByAction/createAccountActionByAction.js +0 -80
  323. package/_esm/analyzer/createAccountActionByAction/createAccountActionByAction.js.map +0 -1
  324. package/_esm/analyzer/createAccountActionByAction/deposit.js +0 -38
  325. package/_esm/analyzer/createAccountActionByAction/deposit.js.map +0 -1
  326. package/_esm/analyzer/createAccountActionByAction/depositWithBond.js +0 -24
  327. package/_esm/analyzer/createAccountActionByAction/depositWithBond.js.map +0 -1
  328. package/_esm/analyzer/createAccountActionByAction/freeMintNft.js +0 -28
  329. package/_esm/analyzer/createAccountActionByAction/freeMintNft.js.map +0 -1
  330. package/_esm/analyzer/createAccountActionByAction/index.js +0 -2
  331. package/_esm/analyzer/createAccountActionByAction/index.js.map +0 -1
  332. package/_esm/analyzer/createAccountActionByAction/removeLiquidity.js +0 -24
  333. package/_esm/analyzer/createAccountActionByAction/removeLiquidity.js.map +0 -1
  334. package/_esm/analyzer/createAccountActionByAction/spam.js +0 -54
  335. package/_esm/analyzer/createAccountActionByAction/spam.js.map +0 -1
  336. package/_esm/analyzer/createAccountActionByAction/trade.js +0 -59
  337. package/_esm/analyzer/createAccountActionByAction/trade.js.map +0 -1
  338. package/_esm/analyzer/createAccountActionByAction/transactionFee.js +0 -25
  339. package/_esm/analyzer/createAccountActionByAction/transactionFee.js.map +0 -1
  340. package/_esm/analyzer/createAccountActionByAction/transfer.js +0 -70
  341. package/_esm/analyzer/createAccountActionByAction/transfer.js.map +0 -1
  342. package/_esm/analyzer/createAccountActionByAction/withdraw.js +0 -34
  343. package/_esm/analyzer/createAccountActionByAction/withdraw.js.map +0 -1
  344. package/_esm/analyzer/createAccountActionByAction/withdrawWithBond.js +0 -24
  345. package/_esm/analyzer/createAccountActionByAction/withdrawWithBond.js.map +0 -1
  346. package/_esm/analyzer/json/generatorAnyLog.js +0 -159
  347. package/_esm/analyzer/json/generatorAnyLog.js.map +0 -1
  348. package/_esm/analyzer/json/generatorAnyTokenTransfer.js +0 -98
  349. package/_esm/analyzer/json/generatorAnyTokenTransfer.js.map +0 -1
  350. package/_esm/analyzer/json/generatorSpecificTokenTransfer.js +0 -339
  351. package/_esm/analyzer/json/generatorSpecificTokenTransfer.js.map +0 -1
  352. package/_types/analyzer/createAccountActionByAction/addLiquidity.d.ts +0 -59
  353. package/_types/analyzer/createAccountActionByAction/addLiquidity.d.ts.map +0 -1
  354. package/_types/analyzer/createAccountActionByAction/atomicArbitrage.d.ts +0 -59
  355. package/_types/analyzer/createAccountActionByAction/atomicArbitrage.d.ts.map +0 -1
  356. package/_types/analyzer/createAccountActionByAction/bridgeFrom.d.ts +0 -59
  357. package/_types/analyzer/createAccountActionByAction/bridgeFrom.d.ts.map +0 -1
  358. package/_types/analyzer/createAccountActionByAction/bridgeTo.d.ts +0 -59
  359. package/_types/analyzer/createAccountActionByAction/bridgeTo.d.ts.map +0 -1
  360. package/_types/analyzer/createAccountActionByAction/buyNft.d.ts +0 -59
  361. package/_types/analyzer/createAccountActionByAction/buyNft.d.ts.map +0 -1
  362. package/_types/analyzer/createAccountActionByAction/createAccountActionByAction.d.ts +0 -59
  363. package/_types/analyzer/createAccountActionByAction/createAccountActionByAction.d.ts.map +0 -1
  364. package/_types/analyzer/createAccountActionByAction/deposit.d.ts +0 -59
  365. package/_types/analyzer/createAccountActionByAction/deposit.d.ts.map +0 -1
  366. package/_types/analyzer/createAccountActionByAction/depositWithBond.d.ts +0 -59
  367. package/_types/analyzer/createAccountActionByAction/depositWithBond.d.ts.map +0 -1
  368. package/_types/analyzer/createAccountActionByAction/freeMintNft.d.ts +0 -53
  369. package/_types/analyzer/createAccountActionByAction/freeMintNft.d.ts.map +0 -1
  370. package/_types/analyzer/createAccountActionByAction/index.d.ts +0 -2
  371. package/_types/analyzer/createAccountActionByAction/index.d.ts.map +0 -1
  372. package/_types/analyzer/createAccountActionByAction/removeLiquidity.d.ts +0 -59
  373. package/_types/analyzer/createAccountActionByAction/removeLiquidity.d.ts.map +0 -1
  374. package/_types/analyzer/createAccountActionByAction/spam.d.ts +0 -59
  375. package/_types/analyzer/createAccountActionByAction/spam.d.ts.map +0 -1
  376. package/_types/analyzer/createAccountActionByAction/trade.d.ts +0 -59
  377. package/_types/analyzer/createAccountActionByAction/trade.d.ts.map +0 -1
  378. package/_types/analyzer/createAccountActionByAction/transactionFee.d.ts +0 -59
  379. package/_types/analyzer/createAccountActionByAction/transactionFee.d.ts.map +0 -1
  380. package/_types/analyzer/createAccountActionByAction/transfer.d.ts +0 -59
  381. package/_types/analyzer/createAccountActionByAction/transfer.d.ts.map +0 -1
  382. package/_types/analyzer/createAccountActionByAction/withdraw.d.ts +0 -59
  383. package/_types/analyzer/createAccountActionByAction/withdraw.d.ts.map +0 -1
  384. package/_types/analyzer/createAccountActionByAction/withdrawWithBond.d.ts +0 -59
  385. package/_types/analyzer/createAccountActionByAction/withdrawWithBond.d.ts.map +0 -1
  386. package/_types/analyzer/json/generatorAnyLog.d.ts +0 -55
  387. package/_types/analyzer/json/generatorAnyLog.d.ts.map +0 -1
  388. package/_types/analyzer/json/generatorAnyTokenTransfer.d.ts +0 -54
  389. package/_types/analyzer/json/generatorAnyTokenTransfer.d.ts.map +0 -1
  390. package/_types/analyzer/json/generatorSpecificTokenTransfer.d.ts +0 -55
  391. package/_types/analyzer/json/generatorSpecificTokenTransfer.d.ts.map +0 -1
  392. package/analyzer/createAccountActionByAction/addLiquidity.ts +0 -60
  393. package/analyzer/createAccountActionByAction/atomicArbitrage.ts +0 -115
  394. package/analyzer/createAccountActionByAction/bridgeFrom.ts +0 -61
  395. package/analyzer/createAccountActionByAction/bridgeTo.ts +0 -61
  396. package/analyzer/createAccountActionByAction/buyNft.ts +0 -106
  397. package/analyzer/createAccountActionByAction/createAccountActionByAction.ts +0 -181
  398. package/analyzer/createAccountActionByAction/deposit.ts +0 -64
  399. package/analyzer/createAccountActionByAction/depositWithBond.ts +0 -60
  400. package/analyzer/createAccountActionByAction/freeMintNft.ts +0 -54
  401. package/analyzer/createAccountActionByAction/index.ts +0 -1
  402. package/analyzer/createAccountActionByAction/removeLiquidity.ts +0 -60
  403. package/analyzer/createAccountActionByAction/spam.ts +0 -79
  404. package/analyzer/createAccountActionByAction/trade.ts +0 -105
  405. package/analyzer/createAccountActionByAction/transactionFee.ts +0 -51
  406. package/analyzer/createAccountActionByAction/transfer.ts +0 -95
  407. package/analyzer/createAccountActionByAction/withdraw.ts +0 -61
  408. package/analyzer/createAccountActionByAction/withdrawWithBond.ts +0 -60
  409. package/analyzer/json/generatorAnyLog.ts +0 -207
  410. package/analyzer/json/generatorAnyTokenTransfer.ts +0 -118
  411. package/analyzer/json/generatorSpecificTokenTransfer.ts +0 -425
@@ -0,0 +1,791 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.generateActionsByGenerator = void 0;
4
+ const core_1 = require("@0xtorch/core");
5
+ const comment_1 = require("./components/comment");
6
+ const erc1155_1 = require("./components/erc1155");
7
+ const erc20_1 = require("./components/erc20");
8
+ const erc721_1 = require("./components/erc721");
9
+ const id_1 = require("./components/id");
10
+ const internal_1 = require("./components/internal");
11
+ const logArgument_1 = require("./components/logArgument");
12
+ const transfer_1 = require("./components/transfer");
13
+ const generateActionsByGenerator = ({ generator, chain, transaction, }) => {
14
+ const { target } = generator;
15
+ if (target === undefined) {
16
+ return [
17
+ generateActionByGeneratorWithTargets({
18
+ generator,
19
+ chain,
20
+ transaction,
21
+ }),
22
+ ];
23
+ }
24
+ const mut_erc20Transfers = [...transaction.erc20Transfers];
25
+ const mut_erc721Transfers = [...transaction.erc721Transfers];
26
+ const mut_erc1155Transfers = [...transaction.erc1155Transfers];
27
+ const mut_internalTransactions = [...transaction.internalTransactions];
28
+ const mut_logs = [...transaction.logs];
29
+ const mut_targets = [];
30
+ let repeat = true;
31
+ while (repeat) {
32
+ const mut_targetsErc20 = [];
33
+ const mut_targetsErc721 = [];
34
+ const mut_targetsErc1155 = [];
35
+ const mut_targetsInternal = [];
36
+ const mut_targetsLog = [];
37
+ for (const component of target) {
38
+ switch (component.type) {
39
+ case 'erc20': {
40
+ const erc20Index = mut_erc20Transfers.findIndex((transfer) => (0, erc20_1.isMatchErc20Component)({
41
+ component: {
42
+ ...component,
43
+ index: 0,
44
+ },
45
+ transfer,
46
+ transaction,
47
+ }));
48
+ if (erc20Index === -1) {
49
+ repeat = false;
50
+ break;
51
+ }
52
+ mut_targetsErc20.push(mut_erc20Transfers[erc20Index]);
53
+ mut_erc20Transfers.splice(erc20Index, 1);
54
+ break;
55
+ }
56
+ case 'erc721': {
57
+ const erc721Index = mut_erc721Transfers.findIndex((transfer) => (0, erc721_1.isMatchErc721Component)({
58
+ component: {
59
+ ...component,
60
+ index: 0,
61
+ },
62
+ transfer,
63
+ transaction,
64
+ }));
65
+ if (erc721Index === -1) {
66
+ repeat = false;
67
+ break;
68
+ }
69
+ mut_targetsErc721.push(mut_erc721Transfers[erc721Index]);
70
+ mut_erc721Transfers.splice(erc721Index, 1);
71
+ break;
72
+ }
73
+ case 'erc1155': {
74
+ const erc1155Index = mut_erc1155Transfers.findIndex((transfer) => (0, erc1155_1.isMatchErc1155Component)({
75
+ component: {
76
+ ...component,
77
+ index: 0,
78
+ },
79
+ transfer,
80
+ transaction,
81
+ }));
82
+ if (erc1155Index === -1) {
83
+ repeat = false;
84
+ break;
85
+ }
86
+ mut_targetsErc1155.push(mut_erc1155Transfers[erc1155Index]);
87
+ mut_erc1155Transfers.splice(erc1155Index, 1);
88
+ break;
89
+ }
90
+ case 'internal': {
91
+ const internalIndex = mut_internalTransactions.findIndex((internal) => (0, internal_1.isMatchInternalComponent)({
92
+ component: {
93
+ ...component,
94
+ index: 0,
95
+ },
96
+ internal,
97
+ transaction,
98
+ }));
99
+ if (internalIndex === -1) {
100
+ repeat = false;
101
+ break;
102
+ }
103
+ mut_targetsInternal.push(mut_internalTransactions[internalIndex]);
104
+ mut_internalTransactions.splice(internalIndex, 1);
105
+ break;
106
+ }
107
+ case 'log': {
108
+ const logIndex = mut_logs.findIndex((log) => (0, logArgument_1.isMatchLogArgumentComponent)({
109
+ component: {
110
+ ...component,
111
+ index: 0,
112
+ argIndex: 0,
113
+ valueType: 'other',
114
+ },
115
+ log,
116
+ transaction,
117
+ }));
118
+ if (logIndex === -1) {
119
+ repeat = false;
120
+ break;
121
+ }
122
+ mut_targetsLog.push(mut_logs[logIndex]);
123
+ mut_logs.splice(logIndex, 1);
124
+ break;
125
+ }
126
+ }
127
+ if (!repeat) {
128
+ break;
129
+ }
130
+ }
131
+ if (!repeat) {
132
+ break;
133
+ }
134
+ mut_targets.push({
135
+ targetsErc20: mut_targetsErc20,
136
+ targetsErc721: mut_targetsErc721,
137
+ targetsErc1155: mut_targetsErc1155,
138
+ targetsInternal: mut_targetsInternal,
139
+ targetsLog: mut_targetsLog,
140
+ });
141
+ }
142
+ const actions = mut_targets.map((target) => generateActionByGeneratorWithTargets({
143
+ generator,
144
+ chain,
145
+ transaction,
146
+ ...target,
147
+ }));
148
+ return actions;
149
+ };
150
+ exports.generateActionsByGenerator = generateActionsByGenerator;
151
+ const generateActionByGeneratorWithTargets = ({ generator, chain, transaction, targetsErc20, targetsErc721, targetsErc1155, targetsInternal, targetsLog, }) => {
152
+ const action = {
153
+ type: 'NormalAction',
154
+ action: generator.action,
155
+ evidence: 'contract',
156
+ timestamp: Number(transaction.block.timestamp) * 1000,
157
+ comment: generator.comment === undefined
158
+ ? undefined
159
+ : generator.comment
160
+ .map((component) => (0, comment_1.createCommentByCommentComponent)({
161
+ component,
162
+ transaction,
163
+ chain,
164
+ targetsLog,
165
+ }))
166
+ .join(''),
167
+ app: transaction.app,
168
+ transfers: generator.transfers.flatMap((component) => (0, transfer_1.createTransfersByTransferComponent)({
169
+ component,
170
+ transaction,
171
+ chain,
172
+ targetsErc20,
173
+ targetsErc721,
174
+ targetsErc1155,
175
+ targetsInternal,
176
+ targetsLog,
177
+ })),
178
+ crossId: generator.crossId === undefined
179
+ ? undefined
180
+ : generator.crossId
181
+ .map((component) => (0, id_1.createIdByIdComponent)({
182
+ component,
183
+ transaction,
184
+ chain,
185
+ targetsLog,
186
+ }))
187
+ .join(''),
188
+ crossType: generator.crossType,
189
+ loanId: generator.loanId === undefined
190
+ ? undefined
191
+ : generator.loanId
192
+ .map((component) => (0, id_1.createIdByIdComponent)({
193
+ component,
194
+ transaction,
195
+ chain,
196
+ targetsLog,
197
+ }))
198
+ .join(''),
199
+ };
200
+ switch (action.action) {
201
+ case 'add-liquidity': {
202
+ const transfers = action.transfers.filter((transfer) => (0, core_1.isTransferCryptoCurrencyIn)(transfer) ||
203
+ (0, core_1.isTransferNftIn)(transfer) ||
204
+ (0, core_1.isTransferCryptoCurrencyOut)(transfer) ||
205
+ (0, core_1.isTransferNftOut)(transfer));
206
+ if (transfers.length !== action.transfers.length) {
207
+ throw new Error('Invalid action.transfers for add-liquidity');
208
+ }
209
+ if (action.loanId === undefined) {
210
+ throw new Error('action.loandId is required for add-liquidity');
211
+ }
212
+ return {
213
+ ...action,
214
+ type: 'LoanNormalAction',
215
+ action: 'add-liquidity',
216
+ loanId: action.loanId,
217
+ transfers,
218
+ };
219
+ }
220
+ case 'approve': {
221
+ if (action.transfers.length > 0) {
222
+ throw new Error('Invalid action.transfers for approve');
223
+ }
224
+ return {
225
+ ...action,
226
+ type: 'NormalAction',
227
+ action: 'approve',
228
+ transfers: [],
229
+ };
230
+ }
231
+ case 'atomic-arbitrage': {
232
+ const transfers = action.transfers.filter((transfer) => (0, core_1.isTransferCryptoCurrencyIn)(transfer) ||
233
+ (0, core_1.isTransferCryptoCurrencyOut)(transfer));
234
+ if (transfers.length !== action.transfers.length) {
235
+ throw new Error('Invalid action.transfers for atomic-arbitrage');
236
+ }
237
+ return {
238
+ ...action,
239
+ type: 'NormalAction',
240
+ action: 'atomic-arbitrage',
241
+ transfers,
242
+ };
243
+ }
244
+ case 'borrow': {
245
+ const transfers = action.transfers.filter((transfer) => (0, core_1.isTransferCryptoCurrencyIn)(transfer) || (0, core_1.isTransferNftIn)(transfer));
246
+ if (transfers.length !== action.transfers.length) {
247
+ throw new Error('Invalid action.transfers for borrow');
248
+ }
249
+ if (action.loanId === undefined) {
250
+ throw new Error('action.loandId is required for borrow');
251
+ }
252
+ return {
253
+ ...action,
254
+ type: 'LoanNormalAction',
255
+ action: 'borrow',
256
+ loanId: action.loanId,
257
+ transfers,
258
+ };
259
+ }
260
+ case 'borrow-with-debt': {
261
+ const transfers = action.transfers.filter((transfer) => (0, core_1.isTransferCryptoCurrencyIn)(transfer) ||
262
+ (0, core_1.isTransferNftIn)(transfer) ||
263
+ (0, core_1.isTransferCryptoCurrencyOut)(transfer) ||
264
+ (0, core_1.isTransferNftOut)(transfer));
265
+ if (transfers.length !== action.transfers.length) {
266
+ throw new Error('Invalid action.transfers for borrow-with-debt');
267
+ }
268
+ if (action.loanId === undefined) {
269
+ throw new Error('action.loandId is required for borrow-with-debt');
270
+ }
271
+ return {
272
+ ...action,
273
+ type: 'LoanNormalAction',
274
+ action: 'borrow-with-debt',
275
+ loanId: action.loanId,
276
+ transfers,
277
+ };
278
+ }
279
+ case 'bridge-from': {
280
+ const transfers = action.transfers.filter((transfer) => (0, core_1.isTransferCryptoCurrencyOut)(transfer) || (0, core_1.isTransferNftOut)(transfer));
281
+ if (transfers.length !== action.transfers.length) {
282
+ throw new Error('Invalid action.transfers for bridge-from');
283
+ }
284
+ if (action.crossId === undefined) {
285
+ throw new Error('action.crossId is required for bridge-from');
286
+ }
287
+ if (action.crossType === undefined) {
288
+ throw new Error('action.crossType is required for bridge-from');
289
+ }
290
+ return {
291
+ ...action,
292
+ type: 'CrossNormalAction',
293
+ action: 'bridge-from',
294
+ crossId: action.crossId,
295
+ crossType: action.crossType,
296
+ transfers,
297
+ };
298
+ }
299
+ case 'bridge-to': {
300
+ const transfers = action.transfers.filter((transfer) => (0, core_1.isTransferCryptoCurrencyIn)(transfer) || (0, core_1.isTransferNftIn)(transfer));
301
+ if (transfers.length !== action.transfers.length) {
302
+ throw new Error('Invalid action.transfers for bridge-to');
303
+ }
304
+ if (action.crossId === undefined) {
305
+ throw new Error('action.crossId is required for bridge-to');
306
+ }
307
+ if (action.crossType === undefined) {
308
+ throw new Error('action.crossType is required for bridge-to');
309
+ }
310
+ return {
311
+ ...action,
312
+ type: 'CrossNormalAction',
313
+ action: 'bridge-to',
314
+ crossId: action.crossId,
315
+ crossType: action.crossType,
316
+ transfers,
317
+ };
318
+ }
319
+ case 'buy-crypto': {
320
+ const transfers = action.transfers.filter((transfer) => (0, core_1.isTransferCryptoCurrencyIn)(transfer) ||
321
+ (0, core_1.isTransferFiatCurrencyOut)(transfer));
322
+ if (transfers.length !== action.transfers.length) {
323
+ throw new Error('Invalid action.transfers for buy-crypto');
324
+ }
325
+ return {
326
+ ...action,
327
+ type: 'NormalAction',
328
+ action: 'buy-crypto',
329
+ transfers,
330
+ };
331
+ }
332
+ case 'buy-nft': {
333
+ const transfers = action.transfers.filter((transfer) => (0, core_1.isTransferNftIn)(transfer) ||
334
+ (0, core_1.isTransferFiatCurrencyOut)(transfer) ||
335
+ (0, core_1.isTransferCryptoCurrencyOut)(transfer));
336
+ if (transfers.length !== action.transfers.length) {
337
+ throw new Error('Invalid action.transfers for buy-nft');
338
+ }
339
+ return {
340
+ ...action,
341
+ type: 'NormalAction',
342
+ action: 'buy-nft',
343
+ transfers,
344
+ };
345
+ }
346
+ case 'cross-replace': {
347
+ const transfers = action.transfers.filter((transfer) => (0, core_1.isTransferCryptoCurrencyIn)(transfer) ||
348
+ (0, core_1.isTransferNftIn)(transfer) ||
349
+ (0, core_1.isTransferFiatCurrencyIn)(transfer) ||
350
+ (0, core_1.isTransferCryptoCurrencyOut)(transfer) ||
351
+ (0, core_1.isTransferNftOut)(transfer) ||
352
+ (0, core_1.isTransferFiatCurrencyOut)(transfer));
353
+ if (transfers.length !== action.transfers.length) {
354
+ throw new Error('Invalid action.transfers for cross-replace');
355
+ }
356
+ if (action.crossId === undefined) {
357
+ throw new Error('action.crossId is required for cross-replace');
358
+ }
359
+ if (action.crossType === undefined) {
360
+ throw new Error('action.crossType is required for cross-replace');
361
+ }
362
+ return {
363
+ ...action,
364
+ type: 'CrossNormalAction',
365
+ action: 'cross-replace',
366
+ crossId: action.crossId,
367
+ crossType: action.crossType,
368
+ transfers,
369
+ };
370
+ }
371
+ case 'deposit': {
372
+ const transfers = action.transfers.filter((transfer) => (0, core_1.isTransferCryptoCurrencyOut)(transfer) || (0, core_1.isTransferNftOut)(transfer));
373
+ if (transfers.length !== action.transfers.length) {
374
+ throw new Error('Invalid action.transfers for deposit');
375
+ }
376
+ if (action.loanId === undefined) {
377
+ throw new Error('action.loandId is required for deposit');
378
+ }
379
+ return {
380
+ ...action,
381
+ type: 'LoanNormalAction',
382
+ action: 'deposit',
383
+ loanId: action.loanId,
384
+ transfers,
385
+ };
386
+ }
387
+ case 'cross-trade': {
388
+ const transfers = action.transfers.filter((transfer) => (0, core_1.isTransferCryptoCurrencyIn)(transfer) ||
389
+ (0, core_1.isTransferNftIn)(transfer) ||
390
+ (0, core_1.isTransferFiatCurrencyIn)(transfer) ||
391
+ (0, core_1.isTransferCryptoCurrencyOut)(transfer) ||
392
+ (0, core_1.isTransferNftOut)(transfer) ||
393
+ (0, core_1.isTransferFiatCurrencyOut)(transfer));
394
+ if (transfers.length !== action.transfers.length) {
395
+ throw new Error('Invalid action.transfers for cross-trade');
396
+ }
397
+ if (action.crossId === undefined) {
398
+ throw new Error('action.crossId is required for cross-trade');
399
+ }
400
+ if (action.crossType === undefined) {
401
+ throw new Error('action.crossType is required for cross-trade');
402
+ }
403
+ return {
404
+ ...action,
405
+ type: 'CrossNormalAction',
406
+ action: 'cross-trade',
407
+ crossId: action.crossId,
408
+ crossType: action.crossType,
409
+ transfers,
410
+ };
411
+ }
412
+ case 'deposit-with-bond': {
413
+ const transfers = action.transfers.filter((transfer) => (0, core_1.isTransferCryptoCurrencyIn)(transfer) ||
414
+ (0, core_1.isTransferNftIn)(transfer) ||
415
+ (0, core_1.isTransferCryptoCurrencyOut)(transfer) ||
416
+ (0, core_1.isTransferNftOut)(transfer));
417
+ if (transfers.length !== action.transfers.length) {
418
+ throw new Error('Invalid action.transfers for deposit-with-bond');
419
+ }
420
+ if (action.loanId === undefined) {
421
+ throw new Error('action.loandId is required for deposit-with-bond');
422
+ }
423
+ return {
424
+ ...action,
425
+ type: 'LoanNormalAction',
426
+ action: 'deposit-with-bond',
427
+ loanId: action.loanId,
428
+ transfers,
429
+ };
430
+ }
431
+ case 'fail-tx': {
432
+ if (action.transfers.length > 0) {
433
+ throw new Error('Invalid action.transfers for fail-tx');
434
+ }
435
+ return {
436
+ ...action,
437
+ type: 'NormalAction',
438
+ action: 'fail-tx',
439
+ transfers: [],
440
+ };
441
+ }
442
+ case 'fee': {
443
+ const transfers = action.transfers.filter((transfer) => (0, core_1.isTransferCryptoCurrencyOut)(transfer) ||
444
+ (0, core_1.isTransferFiatCurrencyOut)(transfer));
445
+ if (transfers.length !== action.transfers.length) {
446
+ throw new Error('Invalid action.transfers for fee');
447
+ }
448
+ return {
449
+ ...action,
450
+ type: 'NormalAction',
451
+ action: 'fee',
452
+ transfers,
453
+ };
454
+ }
455
+ case 'free-mint-nft': {
456
+ const transfers = action.transfers.filter((transfer) => (0, core_1.isTransferNftIn)(transfer));
457
+ if (transfers.length !== action.transfers.length) {
458
+ throw new Error('Invalid action.transfers for free-mint-nft');
459
+ }
460
+ return {
461
+ ...action,
462
+ type: 'NormalAction',
463
+ action: 'free-mint-nft',
464
+ transfers,
465
+ };
466
+ }
467
+ case 'income': {
468
+ const transfers = action.transfers.filter((transfer) => (0, core_1.isTransferCryptoCurrencyIn)(transfer) ||
469
+ (0, core_1.isTransferNftIn)(transfer) ||
470
+ (0, core_1.isTransferFiatCurrencyIn)(transfer));
471
+ if (transfers.length !== action.transfers.length) {
472
+ throw new Error('Invalid action.transfers for income');
473
+ }
474
+ return {
475
+ ...action,
476
+ type: 'NormalAction',
477
+ action: 'income',
478
+ transfers,
479
+ };
480
+ }
481
+ case 'mint-nft': {
482
+ const transfers = action.transfers.filter((transfer) => (0, core_1.isTransferNftIn)(transfer) ||
483
+ (0, core_1.isTransferFiatCurrencyOut)(transfer) ||
484
+ (0, core_1.isTransferCryptoCurrencyOut)(transfer));
485
+ if (transfers.length !== action.transfers.length) {
486
+ throw new Error('Invalid action.transfers for mint-nft');
487
+ }
488
+ return {
489
+ ...action,
490
+ type: 'NormalAction',
491
+ action: 'mint-nft',
492
+ transfers,
493
+ };
494
+ }
495
+ case 'receive-from-cex': {
496
+ const transfers = action.transfers.filter((transfer) => (0, core_1.isTransferCryptoCurrencyIn)(transfer) || (0, core_1.isTransferNftIn)(transfer));
497
+ if (transfers.length !== action.transfers.length) {
498
+ throw new Error('Invalid action.transfers for receive-from-cex');
499
+ }
500
+ return {
501
+ ...action,
502
+ type: 'NormalAction',
503
+ action: 'receive-from-cex',
504
+ transfers,
505
+ };
506
+ }
507
+ case 'remove-liquidity': {
508
+ const transfers = action.transfers.filter((transfer) => (0, core_1.isTransferCryptoCurrencyIn)(transfer) ||
509
+ (0, core_1.isTransferNftIn)(transfer) ||
510
+ (0, core_1.isTransferCryptoCurrencyOut)(transfer) ||
511
+ (0, core_1.isTransferNftOut)(transfer));
512
+ if (transfers.length !== action.transfers.length) {
513
+ throw new Error('Invalid action.transfers for remove-liquidity');
514
+ }
515
+ if (action.loanId === undefined) {
516
+ throw new Error('action.loandId is required for remove-liquidity');
517
+ }
518
+ return {
519
+ ...action,
520
+ type: 'LoanNormalAction',
521
+ action: 'remove-liquidity',
522
+ loanId: action.loanId,
523
+ transfers,
524
+ };
525
+ }
526
+ case 'repayment': {
527
+ const transfers = action.transfers.filter((transfer) => (0, core_1.isTransferCryptoCurrencyOut)(transfer) || (0, core_1.isTransferNftOut)(transfer));
528
+ if (transfers.length !== action.transfers.length) {
529
+ throw new Error('Invalid action.transfers for repayment');
530
+ }
531
+ if (action.loanId === undefined) {
532
+ throw new Error('action.loandId is required for repayment');
533
+ }
534
+ return {
535
+ ...action,
536
+ type: 'LoanNormalAction',
537
+ action: 'repayment',
538
+ loanId: action.loanId,
539
+ transfers,
540
+ };
541
+ }
542
+ case 'repayment-with-debt': {
543
+ const transfers = action.transfers.filter((transfer) => (0, core_1.isTransferCryptoCurrencyIn)(transfer) ||
544
+ (0, core_1.isTransferNftIn)(transfer) ||
545
+ (0, core_1.isTransferCryptoCurrencyOut)(transfer) ||
546
+ (0, core_1.isTransferNftOut)(transfer));
547
+ if (transfers.length !== action.transfers.length) {
548
+ throw new Error('Invalid action.transfers for repayment-with-debt');
549
+ }
550
+ if (action.loanId === undefined) {
551
+ throw new Error('action.loandId is required for repayment-with-debt');
552
+ }
553
+ return {
554
+ ...action,
555
+ type: 'LoanNormalAction',
556
+ action: 'repayment-with-debt',
557
+ loanId: action.loanId,
558
+ transfers,
559
+ };
560
+ }
561
+ case 'replace': {
562
+ const transfers = action.transfers.filter((transfer) => (0, core_1.isTransferCryptoCurrencyIn)(transfer) ||
563
+ (0, core_1.isTransferNftIn)(transfer) ||
564
+ (0, core_1.isTransferCryptoCurrencyOut)(transfer) ||
565
+ (0, core_1.isTransferNftOut)(transfer));
566
+ if (transfers.length !== action.transfers.length) {
567
+ throw new Error('Invalid action.transfers for replace');
568
+ }
569
+ return {
570
+ ...action,
571
+ type: 'NormalAction',
572
+ action: 'replace',
573
+ transfers,
574
+ };
575
+ }
576
+ case 'revoke': {
577
+ if (action.transfers.length > 0) {
578
+ throw new Error('Invalid action.transfers for revoke');
579
+ }
580
+ return {
581
+ ...action,
582
+ type: 'NormalAction',
583
+ action: 'revoke',
584
+ transfers: [],
585
+ };
586
+ }
587
+ case 'sell-crypto': {
588
+ const transfers = action.transfers.filter((transfer) => (0, core_1.isTransferFiatCurrencyIn)(transfer) ||
589
+ (0, core_1.isTransferCryptoCurrencyOut)(transfer));
590
+ if (transfers.length !== action.transfers.length) {
591
+ throw new Error('Invalid action.transfers for sell-crypto');
592
+ }
593
+ return {
594
+ ...action,
595
+ type: 'NormalAction',
596
+ action: 'sell-crypto',
597
+ transfers,
598
+ };
599
+ }
600
+ case 'sell-nft': {
601
+ const transfers = action.transfers.filter((transfer) => (0, core_1.isTransferFiatCurrencyIn)(transfer) ||
602
+ (0, core_1.isTransferCryptoCurrencyIn)(transfer) ||
603
+ (0, core_1.isTransferNftOut)(transfer));
604
+ if (transfers.length !== action.transfers.length) {
605
+ throw new Error('Invalid action.transfers for sell-nft');
606
+ }
607
+ return {
608
+ ...action,
609
+ type: 'NormalAction',
610
+ action: 'sell-nft',
611
+ transfers,
612
+ };
613
+ }
614
+ case 'send-to-cex': {
615
+ const transfers = action.transfers.filter((transfer) => (0, core_1.isTransferCryptoCurrencyOut)(transfer) || (0, core_1.isTransferNftOut)(transfer));
616
+ if (transfers.length !== action.transfers.length) {
617
+ throw new Error('Invalid action.transfers for send-to-cex');
618
+ }
619
+ return {
620
+ ...action,
621
+ type: 'NormalAction',
622
+ action: 'send-to-cex',
623
+ transfers,
624
+ };
625
+ }
626
+ case 'spam': {
627
+ const transfers = action.transfers.filter((transfer) => (0, core_1.isTransferCryptoCurrencyIn)(transfer) ||
628
+ (0, core_1.isTransferNftIn)(transfer) ||
629
+ (0, core_1.isTransferCryptoCurrencyOut)(transfer) ||
630
+ (0, core_1.isTransferNftOut)(transfer));
631
+ if (transfers.length !== action.transfers.length) {
632
+ throw new Error('Invalid action.transfers for spam');
633
+ }
634
+ return {
635
+ ...action,
636
+ type: 'NormalAction',
637
+ action: 'spam',
638
+ transfers,
639
+ };
640
+ }
641
+ case 'stake': {
642
+ const transfers = action.transfers.filter((transfer) => (0, core_1.isTransferCryptoCurrencyOut)(transfer) || (0, core_1.isTransferNftOut)(transfer));
643
+ if (transfers.length !== action.transfers.length) {
644
+ throw new Error('Invalid action.transfers for stake');
645
+ }
646
+ if (action.loanId === undefined) {
647
+ throw new Error('action.loandId is required for stake');
648
+ }
649
+ return {
650
+ ...action,
651
+ type: 'LoanNormalAction',
652
+ action: 'stake',
653
+ loanId: action.loanId,
654
+ transfers,
655
+ };
656
+ }
657
+ case 'swap-nft': {
658
+ const transfers = action.transfers.filter((transfer) => (0, core_1.isTransferNftIn)(transfer) || (0, core_1.isTransferNftOut)(transfer));
659
+ if (transfers.length !== action.transfers.length) {
660
+ throw new Error('Invalid action.transfers for swap-nft');
661
+ }
662
+ return {
663
+ ...action,
664
+ type: 'NormalAction',
665
+ action: 'swap-nft',
666
+ transfers,
667
+ };
668
+ }
669
+ case 'trade': {
670
+ const transfers = action.transfers.filter((transfer) => (0, core_1.isTransferCryptoCurrencyIn)(transfer) ||
671
+ (0, core_1.isTransferNftIn)(transfer) ||
672
+ (0, core_1.isTransferFiatCurrencyIn)(transfer) ||
673
+ (0, core_1.isTransferCryptoCurrencyOut)(transfer) ||
674
+ (0, core_1.isTransferNftOut)(transfer) ||
675
+ (0, core_1.isTransferFiatCurrencyOut)(transfer));
676
+ if (transfers.length !== action.transfers.length) {
677
+ throw new Error('Invalid action.transfers for trade');
678
+ }
679
+ return {
680
+ ...action,
681
+ type: 'NormalAction',
682
+ action: 'trade',
683
+ transfers,
684
+ };
685
+ }
686
+ case 'transaction-fee': {
687
+ const transfers = action.transfers.filter((transfer) => (0, core_1.isTransferCryptoCurrencyOut)(transfer));
688
+ if (transfers.length !== action.transfers.length) {
689
+ throw new Error('Invalid action.transfers for transaction-fee');
690
+ }
691
+ return {
692
+ ...action,
693
+ type: 'NormalAction',
694
+ action: 'transaction-fee',
695
+ transfers,
696
+ };
697
+ }
698
+ case 'transfer': {
699
+ return {
700
+ ...action,
701
+ type: 'NormalAction',
702
+ action: 'transfer',
703
+ transfers: [...action.transfers],
704
+ };
705
+ }
706
+ case 'unstake': {
707
+ const transfers = action.transfers.filter((transfer) => (0, core_1.isTransferCryptoCurrencyIn)(transfer) || (0, core_1.isTransferNftIn)(transfer));
708
+ if (transfers.length !== action.transfers.length) {
709
+ throw new Error('Invalid action.transfers for unstake');
710
+ }
711
+ if (action.loanId === undefined) {
712
+ throw new Error('action.loandId is required for unstake');
713
+ }
714
+ return {
715
+ ...action,
716
+ type: 'LoanNormalAction',
717
+ action: 'unstake',
718
+ loanId: action.loanId,
719
+ transfers,
720
+ };
721
+ }
722
+ case 'unwrap': {
723
+ const transfers = action.transfers.filter((transfer) => (0, core_1.isTransferCryptoCurrencyIn)(transfer) ||
724
+ (0, core_1.isTransferCryptoCurrencyOut)(transfer));
725
+ if (transfers.length !== action.transfers.length) {
726
+ throw new Error('Invalid action.transfers for unwrap');
727
+ }
728
+ return {
729
+ ...action,
730
+ type: 'NormalAction',
731
+ action: 'unwrap',
732
+ transfers,
733
+ };
734
+ }
735
+ case 'wrap': {
736
+ const transfers = action.transfers.filter((transfer) => (0, core_1.isTransferCryptoCurrencyIn)(transfer) ||
737
+ (0, core_1.isTransferCryptoCurrencyOut)(transfer));
738
+ if (transfers.length !== action.transfers.length) {
739
+ throw new Error('Invalid action.transfers for wrap');
740
+ }
741
+ return {
742
+ ...action,
743
+ type: 'NormalAction',
744
+ action: 'wrap',
745
+ transfers,
746
+ };
747
+ }
748
+ case 'valuedown': {
749
+ throw new Error('Not implemented for valuedown');
750
+ }
751
+ case 'valueup': {
752
+ throw new Error('Not implemented for valueup');
753
+ }
754
+ case 'withdraw': {
755
+ const transfers = action.transfers.filter((transfer) => (0, core_1.isTransferCryptoCurrencyIn)(transfer) || (0, core_1.isTransferNftIn)(transfer));
756
+ if (transfers.length !== action.transfers.length) {
757
+ throw new Error('Invalid action.transfers for withdraw');
758
+ }
759
+ if (action.loanId === undefined) {
760
+ throw new Error('action.loandId is required for withdraw');
761
+ }
762
+ return {
763
+ ...action,
764
+ type: 'LoanNormalAction',
765
+ action: 'withdraw',
766
+ loanId: action.loanId,
767
+ transfers,
768
+ };
769
+ }
770
+ case 'withdraw-with-bond': {
771
+ const transfers = action.transfers.filter((transfer) => (0, core_1.isTransferCryptoCurrencyIn)(transfer) ||
772
+ (0, core_1.isTransferNftIn)(transfer) ||
773
+ (0, core_1.isTransferCryptoCurrencyOut)(transfer) ||
774
+ (0, core_1.isTransferNftOut)(transfer));
775
+ if (transfers.length !== action.transfers.length) {
776
+ throw new Error('Invalid action.transfers for withdraw-with-bond');
777
+ }
778
+ if (action.loanId === undefined) {
779
+ throw new Error('action.loandId is required for withdraw-with-bond');
780
+ }
781
+ return {
782
+ ...action,
783
+ type: 'LoanNormalAction',
784
+ action: 'withdraw-with-bond',
785
+ loanId: action.loanId,
786
+ transfers,
787
+ };
788
+ }
789
+ }
790
+ };
791
+ //# sourceMappingURL=generator.js.map