@alephium/web3 1.8.3-rc.1 → 1.8.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (444) hide show
  1. package/dist/{_umd/alephium-web3.min.js → alephium-web3.min.js} +1 -1
  2. package/dist/alephium-web3.min.js.map +1 -0
  3. package/dist/scripts/check-versions.d.ts +1 -0
  4. package/dist/{_cjs/scripts → scripts}/check-versions.js +0 -1
  5. package/dist/scripts/header.d.ts +0 -0
  6. package/dist/{_esm/scripts → scripts}/header.js +0 -1
  7. package/dist/{_types/src → src}/address/address.d.ts +0 -1
  8. package/dist/{_cjs/src → src}/address/address.js +0 -1
  9. package/dist/src/address/index.d.ts +1 -0
  10. package/dist/{_cjs/src → src}/address/index.js +0 -1
  11. package/dist/{_types/src → src}/api/api-alephium.d.ts +0 -1
  12. package/dist/{_cjs/src → src}/api/api-alephium.js +0 -1
  13. package/dist/{_types/src → src}/api/api-explorer.d.ts +0 -1
  14. package/dist/{_cjs/src → src}/api/api-explorer.js +0 -1
  15. package/dist/{_types/src → src}/api/explorer-provider.d.ts +0 -1
  16. package/dist/{_cjs/src → src}/api/explorer-provider.js +0 -1
  17. package/dist/{_types/src → src}/api/index.d.ts +0 -1
  18. package/dist/{_cjs/src → src}/api/index.js +0 -1
  19. package/dist/{_types/src → src}/api/node-provider.d.ts +0 -1
  20. package/dist/{_cjs/src → src}/api/node-provider.js +0 -1
  21. package/dist/{_types/src → src}/api/types.d.ts +0 -1
  22. package/dist/{_cjs/src → src}/api/types.js +0 -1
  23. package/dist/{_types/src → src}/api/utils.d.ts +0 -1
  24. package/dist/{_cjs/src → src}/api/utils.js +0 -1
  25. package/dist/{_types/src → src}/block/block.d.ts +0 -1
  26. package/dist/{_cjs/src → src}/block/block.js +0 -1
  27. package/dist/{_types/src → src}/block/index.d.ts +0 -1
  28. package/dist/{_cjs/src → src}/block/index.js +0 -1
  29. package/dist/{_types/src → src}/codec/array-codec.d.ts +0 -1
  30. package/dist/{_cjs/src → src}/codec/array-codec.js +0 -1
  31. package/dist/{_types/src → src}/codec/asset-output-codec.d.ts +0 -1
  32. package/dist/{_cjs/src → src}/codec/asset-output-codec.js +0 -1
  33. package/dist/{_types/src → src}/codec/bigint-codec.d.ts +0 -1
  34. package/dist/{_cjs/src → src}/codec/bigint-codec.js +0 -1
  35. package/dist/{_types/src → src}/codec/bytestring-codec.d.ts +0 -1
  36. package/dist/{_cjs/src → src}/codec/bytestring-codec.js +0 -1
  37. package/dist/{_types/src → src}/codec/codec.d.ts +0 -1
  38. package/dist/{_cjs/src → src}/codec/codec.js +0 -1
  39. package/dist/{_types/src → src}/codec/compact-int-codec.d.ts +0 -1
  40. package/dist/{_cjs/src → src}/codec/compact-int-codec.js +0 -1
  41. package/dist/{_types/src → src}/codec/contract-codec.d.ts +0 -1
  42. package/dist/{_cjs/src → src}/codec/contract-codec.js +0 -1
  43. package/dist/{_types/src → src}/codec/contract-output-codec.d.ts +0 -1
  44. package/dist/{_cjs/src → src}/codec/contract-output-codec.js +0 -1
  45. package/dist/{_types/src → src}/codec/contract-output-ref-codec.d.ts +0 -1
  46. package/dist/{_cjs/src → src}/codec/contract-output-ref-codec.js +0 -1
  47. package/dist/{_types/src → src}/codec/either-codec.d.ts +0 -1
  48. package/dist/{_cjs/src → src}/codec/either-codec.js +0 -1
  49. package/dist/{_types/src → src}/codec/hash.d.ts +0 -1
  50. package/dist/{_cjs/src → src}/codec/hash.js +0 -1
  51. package/dist/{_types/src → src}/codec/index.d.ts +0 -1
  52. package/dist/{_cjs/src → src}/codec/index.js +0 -1
  53. package/dist/{_types/src → src}/codec/input-codec.d.ts +0 -1
  54. package/dist/{_cjs/src → src}/codec/input-codec.js +0 -1
  55. package/dist/{_types/src → src}/codec/instr-codec.d.ts +0 -1
  56. package/dist/{_cjs/src → src}/codec/instr-codec.js +0 -1
  57. package/dist/{_types/src → src}/codec/int-as-4bytes-codec.d.ts +0 -1
  58. package/dist/{_cjs/src → src}/codec/int-as-4bytes-codec.js +0 -1
  59. package/dist/{_types/src → src}/codec/lockup-script-codec.d.ts +0 -1
  60. package/dist/{_cjs/src → src}/codec/lockup-script-codec.js +0 -1
  61. package/dist/{_types/src → src}/codec/method-codec.d.ts +0 -1
  62. package/dist/{_cjs/src → src}/codec/method-codec.js +0 -1
  63. package/dist/{_types/src → src}/codec/option-codec.d.ts +0 -1
  64. package/dist/{_cjs/src → src}/codec/option-codec.js +0 -1
  65. package/dist/{_types/src → src}/codec/output-codec.d.ts +0 -1
  66. package/dist/{_cjs/src → src}/codec/output-codec.js +0 -1
  67. package/dist/{_types/src → src}/codec/reader.d.ts +0 -1
  68. package/dist/{_cjs/src → src}/codec/reader.js +0 -1
  69. package/dist/{_types/src → src}/codec/script-codec.d.ts +0 -1
  70. package/dist/{_cjs/src → src}/codec/script-codec.js +0 -1
  71. package/dist/{_types/src → src}/codec/signature-codec.d.ts +0 -1
  72. package/dist/{_cjs/src → src}/codec/signature-codec.js +0 -1
  73. package/dist/{_types/src → src}/codec/timestamp-codec.d.ts +0 -1
  74. package/dist/{_cjs/src → src}/codec/timestamp-codec.js +0 -1
  75. package/dist/{_types/src → src}/codec/token-codec.d.ts +0 -1
  76. package/dist/{_cjs/src → src}/codec/token-codec.js +0 -1
  77. package/dist/{_types/src → src}/codec/transaction-codec.d.ts +0 -1
  78. package/dist/{_cjs/src → src}/codec/transaction-codec.js +0 -1
  79. package/dist/{_types/src → src}/codec/unlock-script-codec.d.ts +0 -1
  80. package/dist/{_cjs/src → src}/codec/unlock-script-codec.js +0 -1
  81. package/dist/{_types/src → src}/codec/unsigned-tx-codec.d.ts +0 -1
  82. package/dist/{_cjs/src → src}/codec/unsigned-tx-codec.js +0 -1
  83. package/dist/{_types/src → src}/codec/val.d.ts +0 -1
  84. package/dist/{_cjs/src → src}/codec/val.js +0 -1
  85. package/dist/{_types/src → src}/constants.d.ts +0 -1
  86. package/dist/{_cjs/src → src}/constants.js +0 -1
  87. package/dist/{_types/src → src}/contract/contract.d.ts +0 -1
  88. package/dist/{_cjs/src → src}/contract/contract.js +0 -1
  89. package/dist/{_types/src → src}/contract/events.d.ts +0 -1
  90. package/dist/{_cjs/src → src}/contract/events.js +0 -1
  91. package/dist/{_types/src → src}/contract/index.d.ts +0 -1
  92. package/dist/{_cjs/src → src}/contract/index.js +0 -1
  93. package/dist/{_types/src → src}/contract/ralph.d.ts +0 -1
  94. package/dist/{_cjs/src → src}/contract/ralph.js +0 -1
  95. package/dist/{_types/src → src}/contract/script-simulator.d.ts +0 -1
  96. package/dist/{_cjs/src → src}/contract/script-simulator.js +0 -1
  97. package/dist/{_types/src → src}/debug.d.ts +0 -1
  98. package/dist/{_cjs/src → src}/debug.js +0 -1
  99. package/dist/{_types/src → src}/error.d.ts +0 -1
  100. package/dist/{_cjs/src → src}/error.js +0 -1
  101. package/dist/{_types/src → src}/exchange/exchange.d.ts +0 -1
  102. package/dist/{_cjs/src → src}/exchange/exchange.js +0 -1
  103. package/dist/{_types/src → src}/exchange/index.d.ts +0 -1
  104. package/dist/{_cjs/src → src}/exchange/index.js +0 -1
  105. package/dist/{_types/src → src}/global.d.ts +0 -1
  106. package/dist/{_cjs/src → src}/global.js +0 -1
  107. package/dist/{_types/src → src}/index.d.ts +0 -1
  108. package/dist/{_cjs/src → src}/index.js +0 -1
  109. package/dist/{_types/src → src}/signer/index.d.ts +0 -1
  110. package/dist/{_cjs/src → src}/signer/index.js +0 -1
  111. package/dist/{_types/src → src}/signer/signer.d.ts +0 -1
  112. package/dist/{_cjs/src → src}/signer/signer.js +1 -2
  113. package/dist/{_types/src → src}/signer/tx-builder.d.ts +1 -2
  114. package/dist/{_cjs/src → src}/signer/tx-builder.js +1 -2
  115. package/dist/{_types/src → src}/signer/types.d.ts +0 -1
  116. package/dist/{_cjs/src → src}/signer/types.js +0 -1
  117. package/dist/src/token/index.d.ts +1 -0
  118. package/dist/{_cjs/src → src}/token/index.js +0 -1
  119. package/dist/{_types/src → src}/token/nft.d.ts +0 -1
  120. package/dist/{_cjs/src → src}/token/nft.js +0 -1
  121. package/dist/{_types/src → src}/transaction/index.d.ts +0 -1
  122. package/dist/{_cjs/src → src}/transaction/index.js +0 -1
  123. package/dist/{_types/src → src}/transaction/sign-verify.d.ts +0 -1
  124. package/dist/{_cjs/src → src}/transaction/sign-verify.js +0 -1
  125. package/dist/{_types/src → src}/transaction/status.d.ts +0 -1
  126. package/dist/{_cjs/src → src}/transaction/status.js +0 -1
  127. package/dist/{_types/src → src}/transaction/utils.d.ts +0 -1
  128. package/dist/{_cjs/src → src}/transaction/utils.js +0 -1
  129. package/dist/{_types/src → src}/utils/bs58.d.ts +0 -1
  130. package/dist/{_cjs/src → src}/utils/bs58.js +0 -1
  131. package/dist/{_types/src → src}/utils/djb2.d.ts +0 -1
  132. package/dist/{_cjs/src → src}/utils/djb2.js +0 -1
  133. package/dist/{_types/src → src}/utils/index.d.ts +0 -1
  134. package/dist/{_cjs/src → src}/utils/index.js +0 -1
  135. package/dist/{_types/src → src}/utils/number.d.ts +0 -1
  136. package/dist/{_types/src → src}/utils/number.fixture.d.ts +0 -1
  137. package/dist/{_cjs/src → src}/utils/number.fixture.js +0 -1
  138. package/dist/{_cjs/src → src}/utils/number.js +0 -1
  139. package/dist/{_types/src → src}/utils/sign.d.ts +0 -1
  140. package/dist/{_cjs/src → src}/utils/sign.js +0 -1
  141. package/dist/{_types/src → src}/utils/subscription.d.ts +0 -1
  142. package/dist/{_cjs/src → src}/utils/subscription.js +0 -1
  143. package/dist/{_types/src → src}/utils/utils.d.ts +0 -1
  144. package/dist/{_cjs/src → src}/utils/utils.js +0 -1
  145. package/dist/{_types/src → src}/utils/webcrypto.d.ts +0 -1
  146. package/dist/{_cjs/src → src}/utils/webcrypto.js +0 -1
  147. package/package.json +23 -21
  148. package/src/signer/signer.ts +1 -1
  149. package/src/signer/tx-builder.ts +1 -1
  150. package/{webpack.config.cjs → webpack.config.js} +2 -2
  151. package/dist/_cjs/scripts/check-versions.js.map +0 -1
  152. package/dist/_cjs/scripts/header.js +0 -19
  153. package/dist/_cjs/scripts/header.js.map +0 -1
  154. package/dist/_cjs/src/address/address.js.map +0 -1
  155. package/dist/_cjs/src/address/index.js.map +0 -1
  156. package/dist/_cjs/src/api/api-alephium.js.map +0 -1
  157. package/dist/_cjs/src/api/api-explorer.js.map +0 -1
  158. package/dist/_cjs/src/api/explorer-provider.js.map +0 -1
  159. package/dist/_cjs/src/api/index.js.map +0 -1
  160. package/dist/_cjs/src/api/node-provider.js.map +0 -1
  161. package/dist/_cjs/src/api/types.js.map +0 -1
  162. package/dist/_cjs/src/api/utils.js.map +0 -1
  163. package/dist/_cjs/src/block/block.js.map +0 -1
  164. package/dist/_cjs/src/block/index.js.map +0 -1
  165. package/dist/_cjs/src/codec/array-codec.js.map +0 -1
  166. package/dist/_cjs/src/codec/asset-output-codec.js.map +0 -1
  167. package/dist/_cjs/src/codec/bigint-codec.js.map +0 -1
  168. package/dist/_cjs/src/codec/bytestring-codec.js.map +0 -1
  169. package/dist/_cjs/src/codec/codec.js.map +0 -1
  170. package/dist/_cjs/src/codec/compact-int-codec.js.map +0 -1
  171. package/dist/_cjs/src/codec/contract-codec.js.map +0 -1
  172. package/dist/_cjs/src/codec/contract-output-codec.js.map +0 -1
  173. package/dist/_cjs/src/codec/contract-output-ref-codec.js.map +0 -1
  174. package/dist/_cjs/src/codec/either-codec.js.map +0 -1
  175. package/dist/_cjs/src/codec/hash.js.map +0 -1
  176. package/dist/_cjs/src/codec/index.js.map +0 -1
  177. package/dist/_cjs/src/codec/input-codec.js.map +0 -1
  178. package/dist/_cjs/src/codec/instr-codec.js.map +0 -1
  179. package/dist/_cjs/src/codec/int-as-4bytes-codec.js.map +0 -1
  180. package/dist/_cjs/src/codec/lockup-script-codec.js.map +0 -1
  181. package/dist/_cjs/src/codec/method-codec.js.map +0 -1
  182. package/dist/_cjs/src/codec/option-codec.js.map +0 -1
  183. package/dist/_cjs/src/codec/output-codec.js.map +0 -1
  184. package/dist/_cjs/src/codec/reader.js.map +0 -1
  185. package/dist/_cjs/src/codec/script-codec.js.map +0 -1
  186. package/dist/_cjs/src/codec/signature-codec.js.map +0 -1
  187. package/dist/_cjs/src/codec/timestamp-codec.js.map +0 -1
  188. package/dist/_cjs/src/codec/token-codec.js.map +0 -1
  189. package/dist/_cjs/src/codec/transaction-codec.js.map +0 -1
  190. package/dist/_cjs/src/codec/unlock-script-codec.js.map +0 -1
  191. package/dist/_cjs/src/codec/unsigned-tx-codec.js.map +0 -1
  192. package/dist/_cjs/src/codec/val.js.map +0 -1
  193. package/dist/_cjs/src/constants.js.map +0 -1
  194. package/dist/_cjs/src/contract/contract.js.map +0 -1
  195. package/dist/_cjs/src/contract/events.js.map +0 -1
  196. package/dist/_cjs/src/contract/index.js.map +0 -1
  197. package/dist/_cjs/src/contract/ralph.js.map +0 -1
  198. package/dist/_cjs/src/contract/script-simulator.js.map +0 -1
  199. package/dist/_cjs/src/debug.js.map +0 -1
  200. package/dist/_cjs/src/error.js.map +0 -1
  201. package/dist/_cjs/src/exchange/exchange.js.map +0 -1
  202. package/dist/_cjs/src/exchange/index.js.map +0 -1
  203. package/dist/_cjs/src/global.js.map +0 -1
  204. package/dist/_cjs/src/index.js.map +0 -1
  205. package/dist/_cjs/src/signer/index.js.map +0 -1
  206. package/dist/_cjs/src/signer/signer.js.map +0 -1
  207. package/dist/_cjs/src/signer/tx-builder.js.map +0 -1
  208. package/dist/_cjs/src/signer/types.js.map +0 -1
  209. package/dist/_cjs/src/token/index.js.map +0 -1
  210. package/dist/_cjs/src/token/nft.js.map +0 -1
  211. package/dist/_cjs/src/transaction/index.js.map +0 -1
  212. package/dist/_cjs/src/transaction/sign-verify.js.map +0 -1
  213. package/dist/_cjs/src/transaction/status.js.map +0 -1
  214. package/dist/_cjs/src/transaction/utils.js.map +0 -1
  215. package/dist/_cjs/src/utils/bs58.js.map +0 -1
  216. package/dist/_cjs/src/utils/djb2.js.map +0 -1
  217. package/dist/_cjs/src/utils/index.js.map +0 -1
  218. package/dist/_cjs/src/utils/number.fixture.js.map +0 -1
  219. package/dist/_cjs/src/utils/number.js.map +0 -1
  220. package/dist/_cjs/src/utils/sign.js.map +0 -1
  221. package/dist/_cjs/src/utils/subscription.js.map +0 -1
  222. package/dist/_cjs/src/utils/utils.js.map +0 -1
  223. package/dist/_cjs/src/utils/webcrypto.js.map +0 -1
  224. package/dist/_esm/scripts/check-versions.js +0 -40
  225. package/dist/_esm/scripts/check-versions.js.map +0 -1
  226. package/dist/_esm/scripts/header.js.map +0 -1
  227. package/dist/_esm/src/address/address.js +0 -220
  228. package/dist/_esm/src/address/address.js.map +0 -1
  229. package/dist/_esm/src/address/index.js +0 -19
  230. package/dist/_esm/src/address/index.js.map +0 -1
  231. package/dist/_esm/src/api/api-alephium.js +0 -1519
  232. package/dist/_esm/src/api/api-alephium.js.map +0 -1
  233. package/dist/_esm/src/api/api-explorer.js +0 -964
  234. package/dist/_esm/src/api/api-explorer.js.map +0 -1
  235. package/dist/_esm/src/api/explorer-provider.js +0 -66
  236. package/dist/_esm/src/api/explorer-provider.js.map +0 -1
  237. package/dist/_esm/src/api/index.js +0 -24
  238. package/dist/_esm/src/api/index.js.map +0 -1
  239. package/dist/_esm/src/api/node-provider.js +0 -201
  240. package/dist/_esm/src/api/node-provider.js.map +0 -1
  241. package/dist/_esm/src/api/types.js +0 -211
  242. package/dist/_esm/src/api/types.js.map +0 -1
  243. package/dist/_esm/src/api/utils.js +0 -51
  244. package/dist/_esm/src/api/utils.js.map +0 -1
  245. package/dist/_esm/src/block/block.js +0 -145
  246. package/dist/_esm/src/block/block.js.map +0 -1
  247. package/dist/_esm/src/block/index.js +0 -19
  248. package/dist/_esm/src/block/index.js.map +0 -1
  249. package/dist/_esm/src/codec/array-codec.js +0 -42
  250. package/dist/_esm/src/codec/array-codec.js.map +0 -1
  251. package/dist/_esm/src/codec/asset-output-codec.js +0 -91
  252. package/dist/_esm/src/codec/asset-output-codec.js.map +0 -1
  253. package/dist/_esm/src/codec/bigint-codec.js +0 -94
  254. package/dist/_esm/src/codec/bigint-codec.js.map +0 -1
  255. package/dist/_esm/src/codec/bytestring-codec.js +0 -33
  256. package/dist/_esm/src/codec/bytestring-codec.js.map +0 -1
  257. package/dist/_esm/src/codec/codec.js +0 -131
  258. package/dist/_esm/src/codec/codec.js.map +0 -1
  259. package/dist/_esm/src/codec/compact-int-codec.js +0 -304
  260. package/dist/_esm/src/codec/compact-int-codec.js.map +0 -1
  261. package/dist/_esm/src/codec/contract-codec.js +0 -64
  262. package/dist/_esm/src/codec/contract-codec.js.map +0 -1
  263. package/dist/_esm/src/codec/contract-output-codec.js +0 -57
  264. package/dist/_esm/src/codec/contract-output-codec.js.map +0 -1
  265. package/dist/_esm/src/codec/contract-output-ref-codec.js +0 -26
  266. package/dist/_esm/src/codec/contract-output-ref-codec.js.map +0 -1
  267. package/dist/_esm/src/codec/either-codec.js +0 -22
  268. package/dist/_esm/src/codec/either-codec.js.map +0 -1
  269. package/dist/_esm/src/codec/hash.js +0 -32
  270. package/dist/_esm/src/codec/hash.js.map +0 -1
  271. package/dist/_esm/src/codec/index.js +0 -42
  272. package/dist/_esm/src/codec/index.js.map +0 -1
  273. package/dist/_esm/src/codec/input-codec.js +0 -33
  274. package/dist/_esm/src/codec/input-codec.js.map +0 -1
  275. package/dist/_esm/src/codec/instr-codec.js +0 -1067
  276. package/dist/_esm/src/codec/instr-codec.js.map +0 -1
  277. package/dist/_esm/src/codec/int-as-4bytes-codec.js +0 -29
  278. package/dist/_esm/src/codec/int-as-4bytes-codec.js.map +0 -1
  279. package/dist/_esm/src/codec/lockup-script-codec.js +0 -32
  280. package/dist/_esm/src/codec/lockup-script-codec.js.map +0 -1
  281. package/dist/_esm/src/codec/method-codec.js +0 -71
  282. package/dist/_esm/src/codec/method-codec.js.map +0 -1
  283. package/dist/_esm/src/codec/option-codec.js +0 -33
  284. package/dist/_esm/src/codec/option-codec.js.map +0 -1
  285. package/dist/_esm/src/codec/output-codec.js +0 -24
  286. package/dist/_esm/src/codec/output-codec.js.map +0 -1
  287. package/dist/_esm/src/codec/reader.js +0 -45
  288. package/dist/_esm/src/codec/reader.js.map +0 -1
  289. package/dist/_esm/src/codec/script-codec.js +0 -31
  290. package/dist/_esm/src/codec/script-codec.js.map +0 -1
  291. package/dist/_esm/src/codec/signature-codec.js +0 -22
  292. package/dist/_esm/src/codec/signature-codec.js.map +0 -1
  293. package/dist/_esm/src/codec/timestamp-codec.js +0 -36
  294. package/dist/_esm/src/codec/timestamp-codec.js.map +0 -1
  295. package/dist/_esm/src/codec/token-codec.js +0 -26
  296. package/dist/_esm/src/codec/token-codec.js.map +0 -1
  297. package/dist/_esm/src/codec/transaction-codec.js +0 -99
  298. package/dist/_esm/src/codec/transaction-codec.js.map +0 -1
  299. package/dist/_esm/src/codec/unlock-script-codec.js +0 -47
  300. package/dist/_esm/src/codec/unlock-script-codec.js.map +0 -1
  301. package/dist/_esm/src/codec/unsigned-tx-codec.js +0 -57
  302. package/dist/_esm/src/codec/unsigned-tx-codec.js.map +0 -1
  303. package/dist/_esm/src/codec/val.js +0 -31
  304. package/dist/_esm/src/codec/val.js.map +0 -1
  305. package/dist/_esm/src/constants.js +0 -31
  306. package/dist/_esm/src/constants.js.map +0 -1
  307. package/dist/_esm/src/contract/contract.js +0 -1361
  308. package/dist/_esm/src/contract/contract.js.map +0 -1
  309. package/dist/_esm/src/contract/events.js +0 -56
  310. package/dist/_esm/src/contract/events.js.map +0 -1
  311. package/dist/_esm/src/contract/index.js +0 -22
  312. package/dist/_esm/src/contract/index.js.map +0 -1
  313. package/dist/_esm/src/contract/ralph.js +0 -415
  314. package/dist/_esm/src/contract/ralph.js.map +0 -1
  315. package/dist/_esm/src/contract/script-simulator.js +0 -754
  316. package/dist/_esm/src/contract/script-simulator.js.map +0 -1
  317. package/dist/_esm/src/debug.js +0 -38
  318. package/dist/_esm/src/debug.js.map +0 -1
  319. package/dist/_esm/src/error.js +0 -33
  320. package/dist/_esm/src/error.js.map +0 -1
  321. package/dist/_esm/src/exchange/exchange.js +0 -119
  322. package/dist/_esm/src/exchange/exchange.js.map +0 -1
  323. package/dist/_esm/src/exchange/index.js +0 -19
  324. package/dist/_esm/src/exchange/index.js.map +0 -1
  325. package/dist/_esm/src/global.js +0 -48
  326. package/dist/_esm/src/global.js.map +0 -1
  327. package/dist/_esm/src/index.js +0 -36
  328. package/dist/_esm/src/index.js.map +0 -1
  329. package/dist/_esm/src/signer/index.js +0 -21
  330. package/dist/_esm/src/signer/index.js.map +0 -1
  331. package/dist/_esm/src/signer/signer.js +0 -206
  332. package/dist/_esm/src/signer/signer.js.map +0 -1
  333. package/dist/_esm/src/signer/tx-builder.js +0 -182
  334. package/dist/_esm/src/signer/tx-builder.js.map +0 -1
  335. package/dist/_esm/src/signer/types.js +0 -29
  336. package/dist/_esm/src/signer/types.js.map +0 -1
  337. package/dist/_esm/src/token/index.js +0 -19
  338. package/dist/_esm/src/token/index.js.map +0 -1
  339. package/dist/_esm/src/token/nft.js +0 -115
  340. package/dist/_esm/src/token/nft.js.map +0 -1
  341. package/dist/_esm/src/transaction/index.js +0 -21
  342. package/dist/_esm/src/transaction/index.js.map +0 -1
  343. package/dist/_esm/src/transaction/sign-verify.js +0 -25
  344. package/dist/_esm/src/transaction/sign-verify.js.map +0 -1
  345. package/dist/_esm/src/transaction/status.js +0 -50
  346. package/dist/_esm/src/transaction/status.js.map +0 -1
  347. package/dist/_esm/src/transaction/utils.js +0 -52
  348. package/dist/_esm/src/transaction/utils.js.map +0 -1
  349. package/dist/_esm/src/utils/bs58.js +0 -43
  350. package/dist/_esm/src/utils/bs58.js.map +0 -1
  351. package/dist/_esm/src/utils/djb2.js +0 -25
  352. package/dist/_esm/src/utils/djb2.js.map +0 -1
  353. package/dist/_esm/src/utils/index.js +0 -25
  354. package/dist/_esm/src/utils/index.js.map +0 -1
  355. package/dist/_esm/src/utils/number.fixture.js +0 -187
  356. package/dist/_esm/src/utils/number.fixture.js.map +0 -1
  357. package/dist/_esm/src/utils/number.js +0 -139
  358. package/dist/_esm/src/utils/number.js.map +0 -1
  359. package/dist/_esm/src/utils/sign.js +0 -62
  360. package/dist/_esm/src/utils/sign.js.map +0 -1
  361. package/dist/_esm/src/utils/subscription.js +0 -48
  362. package/dist/_esm/src/utils/subscription.js.map +0 -1
  363. package/dist/_esm/src/utils/utils.js +0 -144
  364. package/dist/_esm/src/utils/utils.js.map +0 -1
  365. package/dist/_esm/src/utils/webcrypto.js +0 -38
  366. package/dist/_esm/src/utils/webcrypto.js.map +0 -1
  367. package/dist/_types/scripts/check-versions.d.ts +0 -2
  368. package/dist/_types/scripts/check-versions.d.ts.map +0 -1
  369. package/dist/_types/scripts/header.d.ts +0 -1
  370. package/dist/_types/scripts/header.d.ts.map +0 -1
  371. package/dist/_types/src/address/address.d.ts.map +0 -1
  372. package/dist/_types/src/address/index.d.ts +0 -2
  373. package/dist/_types/src/address/index.d.ts.map +0 -1
  374. package/dist/_types/src/api/api-alephium.d.ts.map +0 -1
  375. package/dist/_types/src/api/api-explorer.d.ts.map +0 -1
  376. package/dist/_types/src/api/explorer-provider.d.ts.map +0 -1
  377. package/dist/_types/src/api/index.d.ts.map +0 -1
  378. package/dist/_types/src/api/node-provider.d.ts.map +0 -1
  379. package/dist/_types/src/api/types.d.ts.map +0 -1
  380. package/dist/_types/src/api/utils.d.ts.map +0 -1
  381. package/dist/_types/src/block/block.d.ts.map +0 -1
  382. package/dist/_types/src/block/index.d.ts.map +0 -1
  383. package/dist/_types/src/codec/array-codec.d.ts.map +0 -1
  384. package/dist/_types/src/codec/asset-output-codec.d.ts.map +0 -1
  385. package/dist/_types/src/codec/bigint-codec.d.ts.map +0 -1
  386. package/dist/_types/src/codec/bytestring-codec.d.ts.map +0 -1
  387. package/dist/_types/src/codec/codec.d.ts.map +0 -1
  388. package/dist/_types/src/codec/compact-int-codec.d.ts.map +0 -1
  389. package/dist/_types/src/codec/contract-codec.d.ts.map +0 -1
  390. package/dist/_types/src/codec/contract-output-codec.d.ts.map +0 -1
  391. package/dist/_types/src/codec/contract-output-ref-codec.d.ts.map +0 -1
  392. package/dist/_types/src/codec/either-codec.d.ts.map +0 -1
  393. package/dist/_types/src/codec/hash.d.ts.map +0 -1
  394. package/dist/_types/src/codec/index.d.ts.map +0 -1
  395. package/dist/_types/src/codec/input-codec.d.ts.map +0 -1
  396. package/dist/_types/src/codec/instr-codec.d.ts.map +0 -1
  397. package/dist/_types/src/codec/int-as-4bytes-codec.d.ts.map +0 -1
  398. package/dist/_types/src/codec/lockup-script-codec.d.ts.map +0 -1
  399. package/dist/_types/src/codec/method-codec.d.ts.map +0 -1
  400. package/dist/_types/src/codec/option-codec.d.ts.map +0 -1
  401. package/dist/_types/src/codec/output-codec.d.ts.map +0 -1
  402. package/dist/_types/src/codec/reader.d.ts.map +0 -1
  403. package/dist/_types/src/codec/script-codec.d.ts.map +0 -1
  404. package/dist/_types/src/codec/signature-codec.d.ts.map +0 -1
  405. package/dist/_types/src/codec/timestamp-codec.d.ts.map +0 -1
  406. package/dist/_types/src/codec/token-codec.d.ts.map +0 -1
  407. package/dist/_types/src/codec/transaction-codec.d.ts.map +0 -1
  408. package/dist/_types/src/codec/unlock-script-codec.d.ts.map +0 -1
  409. package/dist/_types/src/codec/unsigned-tx-codec.d.ts.map +0 -1
  410. package/dist/_types/src/codec/val.d.ts.map +0 -1
  411. package/dist/_types/src/constants.d.ts.map +0 -1
  412. package/dist/_types/src/contract/contract.d.ts.map +0 -1
  413. package/dist/_types/src/contract/events.d.ts.map +0 -1
  414. package/dist/_types/src/contract/index.d.ts.map +0 -1
  415. package/dist/_types/src/contract/ralph.d.ts.map +0 -1
  416. package/dist/_types/src/contract/script-simulator.d.ts.map +0 -1
  417. package/dist/_types/src/debug.d.ts.map +0 -1
  418. package/dist/_types/src/error.d.ts.map +0 -1
  419. package/dist/_types/src/exchange/exchange.d.ts.map +0 -1
  420. package/dist/_types/src/exchange/index.d.ts.map +0 -1
  421. package/dist/_types/src/global.d.ts.map +0 -1
  422. package/dist/_types/src/index.d.ts.map +0 -1
  423. package/dist/_types/src/signer/index.d.ts.map +0 -1
  424. package/dist/_types/src/signer/signer.d.ts.map +0 -1
  425. package/dist/_types/src/signer/tx-builder.d.ts.map +0 -1
  426. package/dist/_types/src/signer/types.d.ts.map +0 -1
  427. package/dist/_types/src/token/index.d.ts +0 -2
  428. package/dist/_types/src/token/index.d.ts.map +0 -1
  429. package/dist/_types/src/token/nft.d.ts.map +0 -1
  430. package/dist/_types/src/transaction/index.d.ts.map +0 -1
  431. package/dist/_types/src/transaction/sign-verify.d.ts.map +0 -1
  432. package/dist/_types/src/transaction/status.d.ts.map +0 -1
  433. package/dist/_types/src/transaction/utils.d.ts.map +0 -1
  434. package/dist/_types/src/utils/bs58.d.ts.map +0 -1
  435. package/dist/_types/src/utils/djb2.d.ts.map +0 -1
  436. package/dist/_types/src/utils/index.d.ts.map +0 -1
  437. package/dist/_types/src/utils/number.d.ts.map +0 -1
  438. package/dist/_types/src/utils/number.fixture.d.ts.map +0 -1
  439. package/dist/_types/src/utils/sign.d.ts.map +0 -1
  440. package/dist/_types/src/utils/subscription.d.ts.map +0 -1
  441. package/dist/_types/src/utils/utils.d.ts.map +0 -1
  442. package/dist/_types/src/utils/webcrypto.d.ts.map +0 -1
  443. package/dist/_umd/alephium-web3.min.js.map +0 -1
  444. /package/dist/{_umd/alephium-web3.min.js.LICENSE.txt → alephium-web3.min.js.LICENSE.txt} +0 -0
@@ -1,754 +0,0 @@
1
- /*
2
- Copyright 2018 - 2022 The Alephium Authors
3
- This file is part of the alephium project.
4
-
5
- The library is free software: you can redistribute it and/or modify
6
- it under the terms of the GNU Lesser General Public License as published by
7
- the Free Software Foundation, either version 3 of the License, or
8
- (at your option) any later version.
9
-
10
- The library is distributed in the hope that it will be useful,
11
- but WITHOUT ANY WARRANTY; without even the implied warranty of
12
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13
- GNU Lesser General Public License for more details.
14
-
15
- You should have received a copy of the GNU Lesser General Public License
16
- along with the library. If not, see <http://www.gnu.org/licenses/>.
17
- */
18
- import { addressFromContractId } from '../address';
19
- import { boolCodec, unsignedTxCodec } from '../codec';
20
- import { lockupScriptCodec } from '../codec/lockup-script-codec';
21
- import { ALPH_TOKEN_ID } from '../constants';
22
- import { binToHex, hexToBinUnsafe } from '../utils';
23
- export class ScriptSimulator {
24
- // This function without errors is recommended for now as the simulator does not support all instructions
25
- static extractContractCalls(unsignedTx) {
26
- try {
27
- return this.extractContractCallsWithErrors(unsignedTx);
28
- }
29
- catch (e) {
30
- console.debug('Error extracting contract calls from script', e);
31
- return [];
32
- }
33
- }
34
- static extractContractCallsWithErrors(unsignedTx) {
35
- const unsignedTxBytes = hexToBinUnsafe(unsignedTx);
36
- const decodedUnsignedTx = unsignedTxCodec.decode(unsignedTxBytes);
37
- const scriptOpt = decodedUnsignedTx.statefulScript;
38
- switch (scriptOpt.kind) {
39
- case 'Some': {
40
- return this.extractContractCallsFromScript(scriptOpt.value);
41
- }
42
- case 'None': {
43
- return [];
44
- }
45
- }
46
- }
47
- static extractContractCallsFromScript(script) {
48
- const methods = script.methods;
49
- if (methods.length === 0) {
50
- return [];
51
- }
52
- const mainMethod = methods[0];
53
- return this.extractContractCallsFromMainMethod(mainMethod);
54
- }
55
- static extractContractCallsFromMainMethod(mainMethod) {
56
- const operandStack = new Stack();
57
- const localVariables = new LocalVariables();
58
- const contractCalls = [];
59
- const callerAddress = {
60
- kind: 'Address',
61
- value: { kind: 'P2PKH', value: random32Bytes() }
62
- };
63
- const approved = new ApprovedAccumulator();
64
- for (const instr of mainMethod.instrs) {
65
- switch (instr.name) {
66
- case 'ConstTrue':
67
- operandStack.push({ kind: 'Bool', value: true });
68
- break;
69
- case 'ConstFalse':
70
- operandStack.push({ kind: 'Bool', value: false });
71
- break;
72
- case 'I256Const0':
73
- operandStack.push({ kind: 'I256', value: 0n });
74
- break;
75
- case 'I256Const1':
76
- operandStack.push({ kind: 'I256', value: 1n });
77
- break;
78
- case 'I256Const2':
79
- operandStack.push({ kind: 'I256', value: 2n });
80
- break;
81
- case 'I256Const3':
82
- operandStack.push({ kind: 'I256', value: 3n });
83
- break;
84
- case 'I256Const4':
85
- operandStack.push({ kind: 'I256', value: 4n });
86
- break;
87
- case 'I256Const5':
88
- operandStack.push({ kind: 'I256', value: 5n });
89
- break;
90
- case 'I256ConstN1':
91
- operandStack.push({ kind: 'I256', value: -1n });
92
- break;
93
- case 'I256Const':
94
- operandStack.push({ kind: 'I256', value: instr.value });
95
- break;
96
- case 'U256Const0':
97
- operandStack.push({ kind: 'U256', value: 0n });
98
- break;
99
- case 'U256Const1':
100
- operandStack.push({ kind: 'U256', value: 1n });
101
- break;
102
- case 'U256Const2':
103
- operandStack.push({ kind: 'U256', value: 2n });
104
- break;
105
- case 'U256Const3':
106
- operandStack.push({ kind: 'U256', value: 3n });
107
- break;
108
- case 'U256Const4':
109
- operandStack.push({ kind: 'U256', value: 4n });
110
- break;
111
- case 'U256Const5':
112
- operandStack.push({ kind: 'U256', value: 5n });
113
- break;
114
- case 'U256Const':
115
- operandStack.push({ kind: 'U256', value: instr.value });
116
- break;
117
- case 'BytesConst':
118
- operandStack.push({ kind: 'ByteVec', value: instr.value });
119
- break;
120
- case 'AddressConst':
121
- operandStack.push({ kind: 'Address', value: instr.value });
122
- break;
123
- case 'LoadLocal':
124
- operandStack.push(localVariables.get(instr.index));
125
- break;
126
- case 'StoreLocal':
127
- localVariables.set(instr.index, operandStack.pop());
128
- break;
129
- case 'Pop':
130
- operandStack.pop();
131
- break;
132
- case 'Dup':
133
- const val = operandStack.pop();
134
- operandStack.push(val);
135
- operandStack.push(val);
136
- break;
137
- case 'Swap':
138
- const val1 = operandStack.pop();
139
- const val2 = operandStack.pop();
140
- operandStack.push(val1);
141
- operandStack.push(val2);
142
- break;
143
- case 'BoolNot':
144
- const bool = operandStack.popBool();
145
- const result = unaryOp(bool, (x) => !x);
146
- operandStack.push(result);
147
- case 'BoolAnd': {
148
- const bool1 = operandStack.popBool();
149
- const bool2 = operandStack.popBool();
150
- binaryOp(bool1, bool2, (x, y) => x && y, operandStack.push);
151
- break;
152
- }
153
- case 'BoolOr': {
154
- const bool1 = operandStack.popBool();
155
- const bool2 = operandStack.popBool();
156
- binaryOp(bool1, bool2, (x, y) => x || y, operandStack.push);
157
- break;
158
- }
159
- case 'BoolEq': {
160
- const bool1 = operandStack.popBool();
161
- const bool2 = operandStack.popBool();
162
- binaryOp(bool1, bool2, (x, y) => x === y, operandStack.push);
163
- break;
164
- }
165
- case 'BoolNeq': {
166
- const bool1 = operandStack.popBool();
167
- const bool2 = operandStack.popBool();
168
- binaryOp(bool1, bool2, (x, y) => x !== y, operandStack.push);
169
- break;
170
- }
171
- case 'BoolToByteVec': {
172
- const bool = operandStack.popBool();
173
- if (bool.kind === 'Symbol-Bool') {
174
- operandStack.push(bool);
175
- }
176
- else {
177
- operandStack.push({ kind: 'ByteVec', value: boolCodec.encode(bool.value) });
178
- }
179
- break;
180
- }
181
- case 'I256Add': {
182
- // unsafe
183
- const i256_2 = operandStack.popI256();
184
- const i256_1 = operandStack.popI256();
185
- binaryOp(i256_1, i256_2, (x, y) => x + y, operandStack.push);
186
- break;
187
- }
188
- case 'I256Sub': {
189
- // unsafe
190
- const i256_2 = operandStack.popI256();
191
- const i256_1 = operandStack.popI256();
192
- binaryOp(i256_1, i256_2, (x, y) => x - y, operandStack.push);
193
- break;
194
- }
195
- case 'I256Mul': {
196
- // unsafe
197
- const i256_2 = operandStack.popI256();
198
- const i256_1 = operandStack.popI256();
199
- binaryOp(i256_1, i256_2, (x, y) => x * y, operandStack.push);
200
- break;
201
- }
202
- case 'I256Div': {
203
- // unsafe
204
- const i256_2 = operandStack.popI256();
205
- const i256_1 = operandStack.popI256();
206
- binaryOp(i256_1, i256_2, (x, y) => x / y, operandStack.push);
207
- break;
208
- }
209
- case 'I256Eq': {
210
- // unsafe
211
- const i256_2 = operandStack.popI256();
212
- const i256_1 = operandStack.popI256();
213
- comparisonOp(i256_1, i256_2, (x, y) => x === y, operandStack.push);
214
- break;
215
- }
216
- case 'I256Neq': {
217
- // unsafe
218
- const i256_2 = operandStack.popI256();
219
- const i256_1 = operandStack.popI256();
220
- comparisonOp(i256_1, i256_2, (x, y) => x !== y, operandStack.push);
221
- break;
222
- }
223
- case 'I256Lt': {
224
- // unsafe
225
- const i256_2 = operandStack.popI256();
226
- const i256_1 = operandStack.popI256();
227
- comparisonOp(i256_1, i256_2, (x, y) => x < y, operandStack.push);
228
- break;
229
- }
230
- case 'I256Le': {
231
- // unsafe
232
- const i256_2 = operandStack.popI256();
233
- const i256_1 = operandStack.popI256();
234
- comparisonOp(i256_1, i256_2, (x, y) => x <= y, operandStack.push);
235
- break;
236
- }
237
- case 'I256Gt': {
238
- // unsafe
239
- const i256_2 = operandStack.popI256();
240
- const i256_1 = operandStack.popI256();
241
- comparisonOp(i256_1, i256_2, (x, y) => x > y, operandStack.push);
242
- break;
243
- }
244
- case 'I256Ge': {
245
- // unsafe
246
- const i256_2 = operandStack.popI256();
247
- const i256_1 = operandStack.popI256();
248
- comparisonOp(i256_1, i256_2, (x, y) => x >= y, operandStack.push);
249
- break;
250
- }
251
- case 'U256Add': {
252
- // unsafe
253
- const u256_2 = operandStack.popU256();
254
- const u256_1 = operandStack.popU256();
255
- binaryOp(u256_1, u256_2, (x, y) => x + y, operandStack.push);
256
- break;
257
- }
258
- case 'U256Sub': {
259
- // unsafe
260
- const u256_2 = operandStack.popU256();
261
- const u256_1 = operandStack.popU256();
262
- binaryOp(u256_1, u256_2, (x, y) => x - y, operandStack.push);
263
- break;
264
- }
265
- case 'U256Mul': {
266
- // unsafe
267
- const u256_2 = operandStack.popU256();
268
- const u256_1 = operandStack.popU256();
269
- binaryOp(u256_1, u256_2, (x, y) => x * y, operandStack.push);
270
- break;
271
- }
272
- case 'U256Div': {
273
- // unsafe
274
- const u256_2 = operandStack.popU256();
275
- const u256_1 = operandStack.popU256();
276
- binaryOp(u256_1, u256_2, (x, y) => x / y, operandStack.push);
277
- break;
278
- }
279
- case 'U256Eq': {
280
- // unsafe
281
- const u256_2 = operandStack.popU256();
282
- const u256_1 = operandStack.popU256();
283
- comparisonOp(u256_1, u256_2, (x, y) => x === y, operandStack.push);
284
- break;
285
- }
286
- case 'U256Neq': {
287
- // unsafe
288
- const u256_2 = operandStack.popU256();
289
- const u256_1 = operandStack.popU256();
290
- comparisonOp(u256_1, u256_2, (x, y) => x !== y, operandStack.push);
291
- break;
292
- }
293
- case 'U256Lt': {
294
- // unsafe
295
- const u256_2 = operandStack.popU256();
296
- const u256_1 = operandStack.popU256();
297
- comparisonOp(u256_1, u256_2, (x, y) => x < y, operandStack.push);
298
- break;
299
- }
300
- case 'U256Le': {
301
- // unsafe
302
- const u256_2 = operandStack.popU256();
303
- const u256_1 = operandStack.popU256();
304
- comparisonOp(u256_1, u256_2, (x, y) => x <= y, operandStack.push);
305
- break;
306
- }
307
- case 'U256Gt': {
308
- // unsafe
309
- const u256_2 = operandStack.popU256();
310
- const u256_1 = operandStack.popU256();
311
- comparisonOp(u256_1, u256_2, (x, y) => x > y, operandStack.push);
312
- break;
313
- }
314
- case 'U256Ge': {
315
- // unsafe
316
- const u256_2 = operandStack.popU256();
317
- const u256_1 = operandStack.popU256();
318
- comparisonOp(u256_1, u256_2, (x, y) => x >= y, operandStack.push);
319
- break;
320
- }
321
- case 'ByteVecEq': {
322
- const byteVec1 = operandStack.popByteVec();
323
- const byteVec2 = operandStack.popByteVec();
324
- comparisonOp(byteVec1, byteVec2, (x, y) => arrayEquals(x, y), operandStack.push);
325
- break;
326
- }
327
- case 'ByteVecNeq': {
328
- const byteVec1 = operandStack.popByteVec();
329
- const byteVec2 = operandStack.popByteVec();
330
- comparisonOp(byteVec1, byteVec2, (x, y) => !arrayEquals(x, y), operandStack.push);
331
- break;
332
- }
333
- case 'ByteVecSize': {
334
- const byteVec = operandStack.popByteVec();
335
- if (byteVec.kind === 'Symbol-ByteVec') {
336
- operandStack.push({ kind: 'Symbol-U256', value: undefined });
337
- }
338
- else {
339
- operandStack.push({ kind: 'U256', value: BigInt(byteVec.value.length) });
340
- }
341
- break;
342
- }
343
- case 'ByteVecConcat': {
344
- const byteVec2 = operandStack.popByteVec();
345
- const byteVec1 = operandStack.popByteVec();
346
- binaryOp(byteVec1, byteVec2, (x, y) => new Uint8Array([...x, ...y]), operandStack.push);
347
- break;
348
- }
349
- case 'ByteVecSlice': {
350
- const end = operandStack.popU256();
351
- const start = operandStack.popU256();
352
- const byteVec = operandStack.popByteVec();
353
- if (byteVec.kind === 'Symbol-ByteVec' || start.kind === 'Symbol-U256' || end.kind === 'Symbol-U256') {
354
- operandStack.push({ kind: 'Symbol-ByteVec', value: undefined });
355
- }
356
- else {
357
- operandStack.push({
358
- kind: 'ByteVec',
359
- value: byteVec.value.slice(Number(start.value), Number(end.value))
360
- });
361
- }
362
- break;
363
- }
364
- case 'AddressEq': {
365
- const address1 = operandStack.popAddress();
366
- const address2 = operandStack.popAddress();
367
- comparisonOp(address1, address2, (x, y) => arrayEquals(lockupScriptCodec.encode(x), lockupScriptCodec.encode(y)), operandStack.push);
368
- break;
369
- }
370
- case 'AddressNeq': {
371
- const address1 = operandStack.popAddress();
372
- const address2 = operandStack.popAddress();
373
- comparisonOp(address1, address2, (x, y) => !arrayEquals(lockupScriptCodec.encode(x), lockupScriptCodec.encode(y)), operandStack.push);
374
- break;
375
- }
376
- case 'AddressToByteVec': {
377
- const address = operandStack.popAddress();
378
- if (address.kind === 'Symbol-Address') {
379
- operandStack.push({ kind: 'Symbol-ByteVec', value: undefined });
380
- }
381
- else {
382
- operandStack.push({ kind: 'ByteVec', value: lockupScriptCodec.encode(address.value) });
383
- }
384
- break;
385
- }
386
- case 'Assert': {
387
- const bool = operandStack.popBool();
388
- if (!bool) {
389
- throw new Error('Assertion failed');
390
- }
391
- break;
392
- }
393
- case 'Blake2b':
394
- case 'Sha256':
395
- case 'Sha3':
396
- case 'Keccak256': {
397
- dummyImplementation(instr.name);
398
- operandStack.popByteVec();
399
- operandStack.push({ kind: 'ByteVec', value: new Uint8Array(32) });
400
- break;
401
- }
402
- case 'ByteVecToAddress': {
403
- const byteVec = operandStack.popByteVec();
404
- if (byteVec.kind === 'Symbol-ByteVec') {
405
- operandStack.push({ kind: 'Symbol-Address', value: undefined });
406
- }
407
- else {
408
- operandStack.push({ kind: 'Address', value: lockupScriptCodec.decode(byteVec.value) });
409
- }
410
- break;
411
- }
412
- case 'Zeros': {
413
- const size = operandStack.popU256();
414
- if (size.kind === 'Symbol-U256') {
415
- operandStack.push({ kind: 'Symbol-ByteVec', value: undefined });
416
- }
417
- else {
418
- if (size.value > 4096) {
419
- throw new Error('Zeros size is too large');
420
- }
421
- operandStack.push({ kind: 'ByteVec', value: new Uint8Array(Number(size.value)) });
422
- }
423
- break;
424
- }
425
- case 'U256To1Byte':
426
- case 'U256To2Byte':
427
- case 'U256To4Byte':
428
- case 'U256To8Byte':
429
- case 'U256To16Byte':
430
- case 'U256To32Byte': {
431
- dummyImplementation(instr.name);
432
- operandStack.popU256();
433
- operandStack.push({ kind: 'Symbol-ByteVec', value: undefined });
434
- break;
435
- }
436
- case 'U256From1Byte':
437
- case 'U256From2Byte':
438
- case 'U256From4Byte':
439
- case 'U256From8Byte':
440
- case 'U256From16Byte':
441
- case 'U256From32Byte': {
442
- dummyImplementation(instr.name);
443
- operandStack.popByteVec();
444
- operandStack.push({ kind: 'Symbol-U256', value: undefined });
445
- break;
446
- }
447
- case 'CallExternal':
448
- case 'CallExternalBySelector': {
449
- const contractId = operandStack.popByteVec();
450
- const returnLength = operandStack.popU256(); // method return length
451
- operandStack.popU256(); // method args length
452
- if (contractId.kind !== 'Symbol-ByteVec') {
453
- contractCalls.push({
454
- contractAddress: addressFromContractId(binToHex(contractId.value)),
455
- approvedAttoAlphAmount: approved.getApprovedAttoAlph(),
456
- approvedTokens: approved.getApprovedTokens()
457
- });
458
- }
459
- approved.reset();
460
- if (returnLength.kind !== 'Symbol-U256') {
461
- for (let i = 0; i < returnLength.value; i++) {
462
- operandStack.push({ kind: 'Symbol-Any', value: undefined });
463
- }
464
- }
465
- break;
466
- }
467
- case 'ContractIdToAddress': {
468
- const contractId = operandStack.popByteVec();
469
- if (contractId.kind === 'Symbol-ByteVec') {
470
- operandStack.push({ kind: 'Symbol-Address', value: undefined });
471
- }
472
- else {
473
- operandStack.push({ kind: 'Address', value: { kind: 'P2C', value: contractId.value } });
474
- }
475
- break;
476
- }
477
- case 'LoadLocalByIndex': {
478
- const index = operandStack.popU256();
479
- if (index.kind === 'Symbol-U256') {
480
- throw new Error('LoadLocalByIndex index is a symbol');
481
- }
482
- else {
483
- operandStack.push(localVariables.get(Number(index.value)));
484
- }
485
- break;
486
- }
487
- case 'StoreLocalByIndex': {
488
- const index = operandStack.popU256();
489
- if (index.kind === 'Symbol-U256') {
490
- throw new Error('StoreLocalByIndex index is a symbol');
491
- }
492
- else {
493
- localVariables.set(Number(index.value), operandStack.pop());
494
- }
495
- break;
496
- }
497
- case 'CallerAddress': {
498
- operandStack.push(callerAddress);
499
- break;
500
- }
501
- case 'ApproveAlph': {
502
- const amount = operandStack.popU256(); // amount
503
- const spender = operandStack.popAddress(); // spender
504
- if (spender.kind.startsWith('Symbol')) {
505
- approved.setUnknown(); // The spender might be the caller
506
- }
507
- else if (spender === callerAddress) {
508
- approved.addApprovedAttoAlph(amount);
509
- }
510
- break;
511
- }
512
- case 'ApproveToken': {
513
- const amount = operandStack.popU256(); // amount
514
- const tokenId = operandStack.popByteVec(); // token
515
- const spender = operandStack.popAddress(); // spender
516
- if (spender.kind.startsWith('Symbol')) {
517
- approved.setUnknown(); // The spender might be the caller
518
- }
519
- else if (spender === callerAddress) {
520
- approved.addApprovedToken(tokenId, amount);
521
- }
522
- break;
523
- }
524
- case 'CreateContractAndTransferToken': {
525
- operandStack.popAddress(); // token owner
526
- }
527
- case 'CreateContractWithToken': {
528
- operandStack.popU256(); // token amount
529
- }
530
- case 'CreateContract': {
531
- operandStack.popByteVec(); // mutable fields
532
- operandStack.popByteVec(); // immutable fields
533
- operandStack.popByteVec(); // contract code
534
- operandStack.push({ kind: 'Symbol-ByteVec', value: undefined }); // new contract id
535
- break;
536
- }
537
- case 'TransferAlph': {
538
- operandStack.popU256(); // amount
539
- operandStack.popAddress(); // recipient
540
- operandStack.popAddress(); // sender
541
- break;
542
- }
543
- case 'TransferToken': {
544
- operandStack.popU256(); // amount
545
- operandStack.popByteVec(); // token
546
- operandStack.popAddress(); // recipient
547
- operandStack.popAddress(); // sender
548
- break;
549
- }
550
- default:
551
- unimplemented(instr.name);
552
- break;
553
- }
554
- }
555
- return contractCalls;
556
- }
557
- }
558
- function unaryOp(x, op) {
559
- if (x.kind.startsWith('Symbol')) {
560
- return x;
561
- }
562
- else {
563
- return { kind: x.kind, value: op(x.value) };
564
- }
565
- }
566
- function binaryOp(x, y, op, push) {
567
- const result = x.kind.startsWith('Symbol')
568
- ? x
569
- : y.kind.startsWith('Symbol')
570
- ? y
571
- : { kind: x.kind, value: op(x.value, y.value) };
572
- push(result);
573
- }
574
- function comparisonOp(x, y, op, push) {
575
- const result = x.kind.startsWith('Symbol') || y.kind.startsWith('Symbol')
576
- ? { kind: 'Symbol-Bool', value: undefined }
577
- : { kind: 'Bool', value: op(x.value, y.value) };
578
- push(result);
579
- }
580
- // implement arrayEquals
581
- function arrayEquals(x, y) {
582
- return x.length === y.length && x.every((value, index) => value === y[`${index}`]);
583
- }
584
- // generate 32 bytes array with random numbers
585
- function random32Bytes() {
586
- const result = new Uint8Array(32);
587
- for (let i = 0; i < 32; i++) {
588
- result[`${i}`] = Math.floor(Math.random() * 256);
589
- }
590
- return result;
591
- }
592
- class Stack {
593
- constructor() {
594
- this.stack = [];
595
- this.push = (val) => {
596
- this.stack.push(val);
597
- };
598
- // TODO
599
- }
600
- pop() {
601
- const result = this.stack.pop();
602
- if (result === undefined) {
603
- throw new Error('Stack is empty');
604
- }
605
- return result;
606
- }
607
- size() {
608
- return this.stack.length;
609
- }
610
- checkedResult(result, expected) {
611
- if (result.kind.startsWith('Symbol')) {
612
- if (result.kind !== `Symbol-${expected}`) {
613
- throw new Error(`Expected a ${expected} value on the stack`);
614
- }
615
- return result;
616
- }
617
- if (result.kind !== expected) {
618
- throw new Error(`Expected a ${expected} value on the stack`);
619
- }
620
- return result;
621
- }
622
- popBool() {
623
- const result = this.pop();
624
- return this.checkedResult(result, 'Bool');
625
- }
626
- popI256() {
627
- const result = this.pop();
628
- return this.checkedResult(result, 'I256');
629
- }
630
- popU256() {
631
- const result = this.pop();
632
- return this.checkedResult(result, 'U256');
633
- }
634
- popByteVec() {
635
- const result = this.pop();
636
- return this.checkedResult(result, 'ByteVec');
637
- }
638
- popAddress() {
639
- const result = this.pop();
640
- return this.checkedResult(result, 'Address');
641
- }
642
- }
643
- class LocalVariables {
644
- constructor() {
645
- this.locals = [];
646
- // TODO
647
- }
648
- get(index) {
649
- const result = this.locals[`${index}`];
650
- if (result === undefined) {
651
- throw new Error(`Local variable at index ${index} is not set`);
652
- }
653
- return result;
654
- }
655
- set(index, val) {
656
- this.locals[`${index}`] = val;
657
- }
658
- checkedResult(result, index, expected) {
659
- if (result.kind.startsWith('Symbol')) {
660
- if (result.kind !== `Symbol-${expected}`) {
661
- throw new Error(`Local variable at index ${index} is not a ${expected}`);
662
- }
663
- return result;
664
- }
665
- if (result.kind !== expected) {
666
- throw new Error(`Local variable at index ${index} is not a ${expected}`);
667
- }
668
- return result;
669
- }
670
- getBool(index) {
671
- const result = this.get(index);
672
- return this.checkedResult(result, index, 'Bool');
673
- }
674
- getI256(index) {
675
- const result = this.get(index);
676
- return this.checkedResult(result, index, 'I256');
677
- }
678
- getU256(index) {
679
- const result = this.get(index);
680
- return this.checkedResult(result, index, 'U256');
681
- }
682
- getByteVec(index) {
683
- const result = this.get(index);
684
- return this.checkedResult(result, index, 'ByteVec');
685
- }
686
- getAddress(index) {
687
- const result = this.get(index);
688
- return this.checkedResult(result, index, 'Address');
689
- }
690
- }
691
- function unimplemented(instrName) {
692
- throw new Error(`Unimplemented instruction: ${instrName}`);
693
- }
694
- function dummyImplementation(instrName) {
695
- console.debug(`Dummy implementation for instruction: ${instrName}`);
696
- }
697
- class ApprovedAccumulator {
698
- constructor() {
699
- this.approvedTokens = [];
700
- this.reset();
701
- }
702
- reset() {
703
- this.approvedTokens = [{ id: ALPH_TOKEN_ID, amount: 0n }];
704
- }
705
- setUnknown() {
706
- this.approvedTokens = 'unknown';
707
- }
708
- getApprovedAttoAlph() {
709
- if (this.approvedTokens === 'unknown') {
710
- return 'unknown';
711
- }
712
- const approvedAttoAlph = this.approvedTokens[0].amount;
713
- return approvedAttoAlph === 'unknown' ? 'unknown' : approvedAttoAlph === 0n ? undefined : approvedAttoAlph;
714
- }
715
- getApprovedTokens() {
716
- if (this.approvedTokens === 'unknown') {
717
- return 'unknown';
718
- }
719
- const allTokens = this.approvedTokens.slice(1);
720
- return allTokens.length === 0 ? undefined : allTokens;
721
- }
722
- addApprovedAttoAlph(amount) {
723
- this.addApprovedToken({ kind: 'ByteVec', value: hexToBinUnsafe(ALPH_TOKEN_ID) }, amount);
724
- }
725
- addApprovedToken(tokenId, amount) {
726
- if (this.approvedTokens === 'unknown') {
727
- return;
728
- }
729
- if (tokenId.kind === 'Symbol-ByteVec') {
730
- this.approvedTokens = 'unknown';
731
- return;
732
- }
733
- const tokenIndex = this.approvedTokens.findIndex((token) => arrayEquals(hexToBinUnsafe(token.id), tokenId.value));
734
- if (tokenIndex === -1) {
735
- this.approvedTokens.push({
736
- id: binToHex(tokenId.value),
737
- amount: amount.kind === 'Symbol-U256' ? 'unknown' : amount.value
738
- });
739
- }
740
- else {
741
- const approved = this.approvedTokens[`${tokenIndex}`];
742
- if (approved.amount === 'unknown') {
743
- return;
744
- }
745
- if (amount.kind === 'Symbol-U256') {
746
- approved.amount = 'unknown';
747
- }
748
- else {
749
- approved.amount += amount.value;
750
- }
751
- }
752
- }
753
- }
754
- //# sourceMappingURL=script-simulator.js.map