@opcat-labs/cat-sdk 1.0.1

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 (369) hide show
  1. package/README.md +19 -0
  2. package/artifacts/.templates/cat20/cat20.scrypt.map +1 -0
  3. package/artifacts/.templates/cat20/cat20.scrypt.tpl +60 -0
  4. package/artifacts/.templates/cat20/cat20.transformer.json +9 -0
  5. package/artifacts/.templates/cat20/cat20Guard.scrypt.map +1 -0
  6. package/artifacts/.templates/cat20/cat20Guard.scrypt.tpl +117 -0
  7. package/artifacts/.templates/cat20/cat20Guard.transformer.json +9 -0
  8. package/artifacts/.templates/cat20/cat20GuardStateLib.scrypt.map +1 -0
  9. package/artifacts/.templates/cat20/cat20GuardStateLib.scrypt.tpl +36 -0
  10. package/artifacts/.templates/cat20/cat20GuardStateLib.transformer.json +7 -0
  11. package/artifacts/.templates/cat20/cat20StateLib.scrypt.map +1 -0
  12. package/artifacts/.templates/cat20/cat20StateLib.scrypt.tpl +21 -0
  13. package/artifacts/.templates/cat20/cat20StateLib.transformer.json +7 -0
  14. package/artifacts/.templates/cat20/minters/cat20ClosedMinter.scrypt.map +1 -0
  15. package/artifacts/.templates/cat20/minters/cat20ClosedMinter.scrypt.tpl +61 -0
  16. package/artifacts/.templates/cat20/minters/cat20ClosedMinter.transformer.json +9 -0
  17. package/artifacts/.templates/cat20/minters/cat20ClosedMinterMetadata.scrypt.map +1 -0
  18. package/artifacts/.templates/cat20/minters/cat20ClosedMinterMetadata.scrypt.tpl +11 -0
  19. package/artifacts/.templates/cat20/minters/cat20ClosedMinterMetadata.transformer.json +7 -0
  20. package/artifacts/.templates/cat20/minters/cat20OpenMinter.scrypt.map +1 -0
  21. package/artifacts/.templates/cat20/minters/cat20OpenMinter.scrypt.tpl +94 -0
  22. package/artifacts/.templates/cat20/minters/cat20OpenMinter.transformer.json +9 -0
  23. package/artifacts/.templates/cat20/minters/cat20OpenMinterMetadata.scrypt.map +1 -0
  24. package/artifacts/.templates/cat20/minters/cat20OpenMinterMetadata.scrypt.tpl +11 -0
  25. package/artifacts/.templates/cat20/minters/cat20OpenMinterMetadata.transformer.json +7 -0
  26. package/artifacts/.templates/cat20/types.scrypt.map +1 -0
  27. package/artifacts/.templates/cat20/types.scrypt.tpl +45 -0
  28. package/artifacts/.templates/cat20/types.transformer.json +7 -0
  29. package/artifacts/.templates/cat20Incinerator.scrypt.map +1 -0
  30. package/artifacts/.templates/cat20Incinerator.scrypt.tpl +31 -0
  31. package/artifacts/.templates/cat20Incinerator.transformer.json +9 -0
  32. package/artifacts/.templates/constants.scrypt.map +1 -0
  33. package/artifacts/.templates/constants.scrypt.tpl +16 -0
  34. package/artifacts/.templates/constants.transformer.json +7 -0
  35. package/artifacts/.templates/counter.scrypt.map +1 -0
  36. package/artifacts/.templates/counter.scrypt.tpl +36 -0
  37. package/artifacts/.templates/counter.transformer.json +9 -0
  38. package/artifacts/.templates/p2pkh.scrypt.map +1 -0
  39. package/artifacts/.templates/p2pkh.scrypt.tpl +11 -0
  40. package/artifacts/.templates/p2pkh.transformer.json +7 -0
  41. package/artifacts/.templates/types.scrypt.map +1 -0
  42. package/artifacts/.templates/types.scrypt.tpl +6 -0
  43. package/artifacts/.templates/types.transformer.json +7 -0
  44. package/artifacts/.templates/utils/ownerUtils.scrypt.map +1 -0
  45. package/artifacts/.templates/utils/ownerUtils.scrypt.tpl +26 -0
  46. package/artifacts/.templates/utils/ownerUtils.transformer.json +7 -0
  47. package/artifacts/.templates/utils/safeMath.scrypt.map +1 -0
  48. package/artifacts/.templates/utils/safeMath.scrypt.tpl +11 -0
  49. package/artifacts/.templates/utils/safeMath.transformer.json +7 -0
  50. package/artifacts/cat20/cat20.json +477 -0
  51. package/artifacts/cat20/cat20.scrypt +62 -0
  52. package/artifacts/cat20/cat20Guard.json +447 -0
  53. package/artifacts/cat20/cat20Guard.scrypt +119 -0
  54. package/artifacts/cat20/cat20GuardStateLib.json +361 -0
  55. package/artifacts/cat20/cat20GuardStateLib.scrypt +38 -0
  56. package/artifacts/cat20/cat20StateLib.json +373 -0
  57. package/artifacts/cat20/cat20StateLib.scrypt +23 -0
  58. package/artifacts/cat20/minters/cat20ClosedMinter.json +477 -0
  59. package/artifacts/cat20/minters/cat20ClosedMinter.scrypt +63 -0
  60. package/artifacts/cat20/minters/cat20ClosedMinterMetadata.json +173 -0
  61. package/artifacts/cat20/minters/cat20ClosedMinterMetadata.scrypt +13 -0
  62. package/artifacts/cat20/minters/cat20OpenMinter.json +508 -0
  63. package/artifacts/cat20/minters/cat20OpenMinter.scrypt +96 -0
  64. package/artifacts/cat20/minters/cat20OpenMinterMetadata.json +173 -0
  65. package/artifacts/cat20/minters/cat20OpenMinterMetadata.scrypt +13 -0
  66. package/artifacts/cat20/types.json +159 -0
  67. package/artifacts/cat20/types.scrypt +47 -0
  68. package/artifacts/cat20Incinerator.json +396 -0
  69. package/artifacts/cat20Incinerator.scrypt +33 -0
  70. package/artifacts/constants.json +26 -0
  71. package/artifacts/constants.scrypt +18 -0
  72. package/artifacts/counter.json +253 -0
  73. package/artifacts/counter.scrypt +38 -0
  74. package/artifacts/p2pkh.json +229 -0
  75. package/artifacts/p2pkh.scrypt +13 -0
  76. package/artifacts/scrypt-ts-opcat/assets/smart-contract/builtin-libs/backtrace.scrypt +38 -0
  77. package/artifacts/scrypt-ts-opcat/assets/smart-contract/builtin-libs/contextUtils.scrypt +93 -0
  78. package/artifacts/scrypt-ts-opcat/assets/smart-contract/builtin-libs/stateUtils.scrypt +9 -0
  79. package/artifacts/scrypt-ts-opcat/assets/smart-contract/builtin-libs/stdUtils.scrypt +96 -0
  80. package/artifacts/scrypt-ts-opcat/assets/smart-contract/builtin-libs/txHashPreimageUtils.scrypt +20 -0
  81. package/artifacts/scrypt-ts-opcat/assets/smart-contract/builtin-libs/txUtils.scrypt +48 -0
  82. package/artifacts/scrypt-ts-opcat/assets/smart-contract/types/structs.scrypt +50 -0
  83. package/artifacts/types.json +33 -0
  84. package/artifacts/types.scrypt +8 -0
  85. package/artifacts/utils/ownerUtils.json +215 -0
  86. package/artifacts/utils/ownerUtils.scrypt +28 -0
  87. package/artifacts/utils/safeMath.json +215 -0
  88. package/artifacts/utils/safeMath.scrypt +13 -0
  89. package/dist/artifacts/.templates/cat20/cat20.scrypt.map +1 -0
  90. package/dist/artifacts/.templates/cat20/cat20.scrypt.tpl +60 -0
  91. package/dist/artifacts/.templates/cat20/cat20.transformer.json +9 -0
  92. package/dist/artifacts/.templates/cat20/cat20Guard.scrypt.map +1 -0
  93. package/dist/artifacts/.templates/cat20/cat20Guard.scrypt.tpl +117 -0
  94. package/dist/artifacts/.templates/cat20/cat20Guard.transformer.json +9 -0
  95. package/dist/artifacts/.templates/cat20/cat20GuardStateLib.scrypt.map +1 -0
  96. package/dist/artifacts/.templates/cat20/cat20GuardStateLib.scrypt.tpl +36 -0
  97. package/dist/artifacts/.templates/cat20/cat20GuardStateLib.transformer.json +7 -0
  98. package/dist/artifacts/.templates/cat20/cat20StateLib.scrypt.map +1 -0
  99. package/dist/artifacts/.templates/cat20/cat20StateLib.scrypt.tpl +21 -0
  100. package/dist/artifacts/.templates/cat20/cat20StateLib.transformer.json +7 -0
  101. package/dist/artifacts/.templates/cat20/minters/cat20ClosedMinter.scrypt.map +1 -0
  102. package/dist/artifacts/.templates/cat20/minters/cat20ClosedMinter.scrypt.tpl +61 -0
  103. package/dist/artifacts/.templates/cat20/minters/cat20ClosedMinter.transformer.json +9 -0
  104. package/dist/artifacts/.templates/cat20/minters/cat20ClosedMinterMetadata.scrypt.map +1 -0
  105. package/dist/artifacts/.templates/cat20/minters/cat20ClosedMinterMetadata.scrypt.tpl +11 -0
  106. package/dist/artifacts/.templates/cat20/minters/cat20ClosedMinterMetadata.transformer.json +7 -0
  107. package/dist/artifacts/.templates/cat20/minters/cat20OpenMinter.scrypt.map +1 -0
  108. package/dist/artifacts/.templates/cat20/minters/cat20OpenMinter.scrypt.tpl +94 -0
  109. package/dist/artifacts/.templates/cat20/minters/cat20OpenMinter.transformer.json +9 -0
  110. package/dist/artifacts/.templates/cat20/minters/cat20OpenMinterMetadata.scrypt.map +1 -0
  111. package/dist/artifacts/.templates/cat20/minters/cat20OpenMinterMetadata.scrypt.tpl +11 -0
  112. package/dist/artifacts/.templates/cat20/minters/cat20OpenMinterMetadata.transformer.json +7 -0
  113. package/dist/artifacts/.templates/cat20/types.scrypt.map +1 -0
  114. package/dist/artifacts/.templates/cat20/types.scrypt.tpl +45 -0
  115. package/dist/artifacts/.templates/cat20/types.transformer.json +7 -0
  116. package/dist/artifacts/.templates/cat20Incinerator.scrypt.map +1 -0
  117. package/dist/artifacts/.templates/cat20Incinerator.scrypt.tpl +31 -0
  118. package/dist/artifacts/.templates/cat20Incinerator.transformer.json +9 -0
  119. package/dist/artifacts/.templates/constants.scrypt.map +1 -0
  120. package/dist/artifacts/.templates/constants.scrypt.tpl +16 -0
  121. package/dist/artifacts/.templates/constants.transformer.json +7 -0
  122. package/dist/artifacts/.templates/counter.scrypt.map +1 -0
  123. package/dist/artifacts/.templates/counter.scrypt.tpl +36 -0
  124. package/dist/artifacts/.templates/counter.transformer.json +9 -0
  125. package/dist/artifacts/.templates/p2pkh.scrypt.map +1 -0
  126. package/dist/artifacts/.templates/p2pkh.scrypt.tpl +11 -0
  127. package/dist/artifacts/.templates/p2pkh.transformer.json +7 -0
  128. package/dist/artifacts/.templates/types.scrypt.map +1 -0
  129. package/dist/artifacts/.templates/types.scrypt.tpl +6 -0
  130. package/dist/artifacts/.templates/types.transformer.json +7 -0
  131. package/dist/artifacts/.templates/utils/ownerUtils.scrypt.map +1 -0
  132. package/dist/artifacts/.templates/utils/ownerUtils.scrypt.tpl +26 -0
  133. package/dist/artifacts/.templates/utils/ownerUtils.transformer.json +7 -0
  134. package/dist/artifacts/.templates/utils/safeMath.scrypt.map +1 -0
  135. package/dist/artifacts/.templates/utils/safeMath.scrypt.tpl +11 -0
  136. package/dist/artifacts/.templates/utils/safeMath.transformer.json +7 -0
  137. package/dist/artifacts/cat20/cat20.json +477 -0
  138. package/dist/artifacts/cat20/cat20.scrypt +62 -0
  139. package/dist/artifacts/cat20/cat20Guard.json +447 -0
  140. package/dist/artifacts/cat20/cat20Guard.scrypt +119 -0
  141. package/dist/artifacts/cat20/cat20GuardStateLib.json +361 -0
  142. package/dist/artifacts/cat20/cat20GuardStateLib.scrypt +38 -0
  143. package/dist/artifacts/cat20/cat20StateLib.json +373 -0
  144. package/dist/artifacts/cat20/cat20StateLib.scrypt +23 -0
  145. package/dist/artifacts/cat20/minters/cat20ClosedMinter.json +477 -0
  146. package/dist/artifacts/cat20/minters/cat20ClosedMinter.scrypt +63 -0
  147. package/dist/artifacts/cat20/minters/cat20ClosedMinterMetadata.json +173 -0
  148. package/dist/artifacts/cat20/minters/cat20ClosedMinterMetadata.scrypt +13 -0
  149. package/dist/artifacts/cat20/minters/cat20OpenMinter.json +508 -0
  150. package/dist/artifacts/cat20/minters/cat20OpenMinter.scrypt +96 -0
  151. package/dist/artifacts/cat20/minters/cat20OpenMinterMetadata.json +173 -0
  152. package/dist/artifacts/cat20/minters/cat20OpenMinterMetadata.scrypt +13 -0
  153. package/dist/artifacts/cat20/types.json +159 -0
  154. package/dist/artifacts/cat20/types.scrypt +47 -0
  155. package/dist/artifacts/cat20Incinerator.json +396 -0
  156. package/dist/artifacts/cat20Incinerator.scrypt +33 -0
  157. package/dist/artifacts/constants.json +26 -0
  158. package/dist/artifacts/constants.scrypt +18 -0
  159. package/dist/artifacts/counter.json +253 -0
  160. package/dist/artifacts/counter.scrypt +38 -0
  161. package/dist/artifacts/p2pkh.json +229 -0
  162. package/dist/artifacts/p2pkh.scrypt +13 -0
  163. package/dist/artifacts/scrypt-ts-opcat/assets/smart-contract/builtin-libs/backtrace.scrypt +38 -0
  164. package/dist/artifacts/scrypt-ts-opcat/assets/smart-contract/builtin-libs/contextUtils.scrypt +93 -0
  165. package/dist/artifacts/scrypt-ts-opcat/assets/smart-contract/builtin-libs/stateUtils.scrypt +9 -0
  166. package/dist/artifacts/scrypt-ts-opcat/assets/smart-contract/builtin-libs/stdUtils.scrypt +96 -0
  167. package/dist/artifacts/scrypt-ts-opcat/assets/smart-contract/builtin-libs/txHashPreimageUtils.scrypt +20 -0
  168. package/dist/artifacts/scrypt-ts-opcat/assets/smart-contract/builtin-libs/txUtils.scrypt +48 -0
  169. package/dist/artifacts/scrypt-ts-opcat/assets/smart-contract/types/structs.scrypt +50 -0
  170. package/dist/artifacts/types.json +33 -0
  171. package/dist/artifacts/types.scrypt +8 -0
  172. package/dist/artifacts/utils/ownerUtils.json +215 -0
  173. package/dist/artifacts/utils/ownerUtils.scrypt +28 -0
  174. package/dist/artifacts/utils/safeMath.json +215 -0
  175. package/dist/artifacts/utils/safeMath.scrypt +13 -0
  176. package/dist/cjs/contracts/cat20/cat20.js +74 -0
  177. package/dist/cjs/contracts/cat20/cat20.js.map +1 -0
  178. package/dist/cjs/contracts/cat20/cat20Guard.js +169 -0
  179. package/dist/cjs/contracts/cat20/cat20Guard.js.map +1 -0
  180. package/dist/cjs/contracts/cat20/cat20GuardStateLib.js +72 -0
  181. package/dist/cjs/contracts/cat20/cat20GuardStateLib.js.map +1 -0
  182. package/dist/cjs/contracts/cat20/cat20StateLib.js +37 -0
  183. package/dist/cjs/contracts/cat20/cat20StateLib.js.map +1 -0
  184. package/dist/cjs/contracts/cat20/minters/cat20ClosedMinter.js +77 -0
  185. package/dist/cjs/contracts/cat20/minters/cat20ClosedMinter.js.map +1 -0
  186. package/dist/cjs/contracts/cat20/minters/cat20ClosedMinterMetadata.js +18 -0
  187. package/dist/cjs/contracts/cat20/minters/cat20ClosedMinterMetadata.js.map +1 -0
  188. package/dist/cjs/contracts/cat20/minters/cat20OpenMinter.js +138 -0
  189. package/dist/cjs/contracts/cat20/minters/cat20OpenMinter.js.map +1 -0
  190. package/dist/cjs/contracts/cat20/minters/cat20OpenMinterMetadata.js +22 -0
  191. package/dist/cjs/contracts/cat20/minters/cat20OpenMinterMetadata.js.map +1 -0
  192. package/dist/cjs/contracts/cat20/types.js +3 -0
  193. package/dist/cjs/contracts/cat20/types.js.map +1 -0
  194. package/dist/cjs/contracts/cat20Incinerator.js +45 -0
  195. package/dist/cjs/contracts/cat20Incinerator.js.map +1 -0
  196. package/dist/cjs/contracts/constants.js +110 -0
  197. package/dist/cjs/contracts/constants.js.map +1 -0
  198. package/dist/cjs/contracts/counter.js +29 -0
  199. package/dist/cjs/contracts/counter.js.map +1 -0
  200. package/dist/cjs/contracts/index.js +32 -0
  201. package/dist/cjs/contracts/index.js.map +1 -0
  202. package/dist/cjs/contracts/p2pkh.js +35 -0
  203. package/dist/cjs/contracts/p2pkh.js.map +1 -0
  204. package/dist/cjs/contracts/types.js +3 -0
  205. package/dist/cjs/contracts/types.js.map +1 -0
  206. package/dist/cjs/contracts/utils/ownerUtils.js +78 -0
  207. package/dist/cjs/contracts/utils/ownerUtils.js.map +1 -0
  208. package/dist/cjs/contracts/utils/safeMath.js +28 -0
  209. package/dist/cjs/contracts/utils/safeMath.js.map +1 -0
  210. package/dist/cjs/features/cat20/burn/burn.js +91 -0
  211. package/dist/cjs/features/cat20/burn/burn.js.map +1 -0
  212. package/dist/cjs/features/cat20/deploy/openMinter.js +135 -0
  213. package/dist/cjs/features/cat20/deploy/openMinter.js.map +1 -0
  214. package/dist/cjs/features/cat20/incinerate.js +108 -0
  215. package/dist/cjs/features/cat20/incinerate.js.map +1 -0
  216. package/dist/cjs/features/cat20/mint/openMinter.js +37 -0
  217. package/dist/cjs/features/cat20/mint/openMinter.js.map +1 -0
  218. package/dist/cjs/features/cat20/send/contractSend.js +130 -0
  219. package/dist/cjs/features/cat20/send/contractSend.js.map +1 -0
  220. package/dist/cjs/features/cat20/send/singleSend.js +172 -0
  221. package/dist/cjs/features/cat20/send/singleSend.js.map +1 -0
  222. package/dist/cjs/features/index.js +19 -0
  223. package/dist/cjs/features/index.js.map +1 -0
  224. package/dist/cjs/index.js +35 -0
  225. package/dist/cjs/index.js.map +1 -0
  226. package/dist/cjs/lib/index.js +19 -0
  227. package/dist/cjs/lib/index.js.map +1 -0
  228. package/dist/cjs/lib/metadata.js +32 -0
  229. package/dist/cjs/lib/metadata.js.map +1 -0
  230. package/dist/cjs/typeConstants.js +18 -0
  231. package/dist/cjs/typeConstants.js.map +1 -0
  232. package/dist/cjs/utils/check.js +24 -0
  233. package/dist/cjs/utils/check.js.map +1 -0
  234. package/dist/cjs/utils/contractPeripheral.js +189 -0
  235. package/dist/cjs/utils/contractPeripheral.js.map +1 -0
  236. package/dist/cjs/utils/index.js +223 -0
  237. package/dist/cjs/utils/index.js.map +1 -0
  238. package/dist/cjs/utils/loadAllArtifacts.js +39 -0
  239. package/dist/cjs/utils/loadAllArtifacts.js.map +1 -0
  240. package/dist/esm/contracts/cat20/cat20.js +72 -0
  241. package/dist/esm/contracts/cat20/cat20.js.map +1 -0
  242. package/dist/esm/contracts/cat20/cat20Guard.js +165 -0
  243. package/dist/esm/contracts/cat20/cat20Guard.js.map +1 -0
  244. package/dist/esm/contracts/cat20/cat20GuardStateLib.js +68 -0
  245. package/dist/esm/contracts/cat20/cat20GuardStateLib.js.map +1 -0
  246. package/dist/esm/contracts/cat20/cat20StateLib.js +33 -0
  247. package/dist/esm/contracts/cat20/cat20StateLib.js.map +1 -0
  248. package/dist/esm/contracts/cat20/minters/cat20ClosedMinter.js +75 -0
  249. package/dist/esm/contracts/cat20/minters/cat20ClosedMinter.js.map +1 -0
  250. package/dist/esm/contracts/cat20/minters/cat20ClosedMinterMetadata.js +14 -0
  251. package/dist/esm/contracts/cat20/minters/cat20ClosedMinterMetadata.js.map +1 -0
  252. package/dist/esm/contracts/cat20/minters/cat20OpenMinter.js +142 -0
  253. package/dist/esm/contracts/cat20/minters/cat20OpenMinter.js.map +1 -0
  254. package/dist/esm/contracts/cat20/minters/cat20OpenMinterMetadata.js +18 -0
  255. package/dist/esm/contracts/cat20/minters/cat20OpenMinterMetadata.js.map +1 -0
  256. package/dist/esm/contracts/cat20/types.js +2 -0
  257. package/dist/esm/contracts/cat20/types.js.map +1 -0
  258. package/dist/esm/contracts/cat20Incinerator.js +42 -0
  259. package/dist/esm/contracts/cat20Incinerator.js.map +1 -0
  260. package/dist/esm/contracts/constants.js +106 -0
  261. package/dist/esm/contracts/constants.js.map +1 -0
  262. package/dist/esm/contracts/counter.js +25 -0
  263. package/dist/esm/contracts/counter.js.map +1 -0
  264. package/dist/esm/contracts/index.js +16 -0
  265. package/dist/esm/contracts/index.js.map +1 -0
  266. package/dist/esm/contracts/p2pkh.js +32 -0
  267. package/dist/esm/contracts/p2pkh.js.map +1 -0
  268. package/dist/esm/contracts/types.js +2 -0
  269. package/dist/esm/contracts/types.js.map +1 -0
  270. package/dist/esm/contracts/utils/ownerUtils.js +74 -0
  271. package/dist/esm/contracts/utils/ownerUtils.js.map +1 -0
  272. package/dist/esm/contracts/utils/safeMath.js +24 -0
  273. package/dist/esm/contracts/utils/safeMath.js.map +1 -0
  274. package/dist/esm/features/cat20/burn/burn.js +87 -0
  275. package/dist/esm/features/cat20/burn/burn.js.map +1 -0
  276. package/dist/esm/features/cat20/deploy/openMinter.js +130 -0
  277. package/dist/esm/features/cat20/deploy/openMinter.js.map +1 -0
  278. package/dist/esm/features/cat20/incinerate.js +104 -0
  279. package/dist/esm/features/cat20/incinerate.js.map +1 -0
  280. package/dist/esm/features/cat20/mint/openMinter.js +33 -0
  281. package/dist/esm/features/cat20/mint/openMinter.js.map +1 -0
  282. package/dist/esm/features/cat20/send/contractSend.js +126 -0
  283. package/dist/esm/features/cat20/send/contractSend.js.map +1 -0
  284. package/dist/esm/features/cat20/send/singleSend.js +142 -0
  285. package/dist/esm/features/cat20/send/singleSend.js.map +1 -0
  286. package/dist/esm/features/index.js +7 -0
  287. package/dist/esm/features/index.js.map +1 -0
  288. package/dist/esm/index.js +9 -0
  289. package/dist/esm/index.js.map +1 -0
  290. package/dist/esm/lib/index.js +3 -0
  291. package/dist/esm/lib/index.js.map +1 -0
  292. package/dist/esm/lib/metadata.js +28 -0
  293. package/dist/esm/lib/metadata.js.map +1 -0
  294. package/dist/esm/typeConstants.js +15 -0
  295. package/dist/esm/typeConstants.js.map +1 -0
  296. package/dist/esm/utils/check.js +19 -0
  297. package/dist/esm/utils/check.js.map +1 -0
  298. package/dist/esm/utils/contractPeripheral.js +183 -0
  299. package/dist/esm/utils/contractPeripheral.js.map +1 -0
  300. package/dist/esm/utils/index.js +184 -0
  301. package/dist/esm/utils/index.js.map +1 -0
  302. package/dist/esm/utils/loadAllArtifacts.js +32 -0
  303. package/dist/esm/utils/loadAllArtifacts.js.map +1 -0
  304. package/dist/types/contracts/cat20/cat20.d.ts +12 -0
  305. package/dist/types/contracts/cat20/cat20.d.ts.map +1 -0
  306. package/dist/types/contracts/cat20/cat20Guard.d.ts +8 -0
  307. package/dist/types/contracts/cat20/cat20Guard.d.ts.map +1 -0
  308. package/dist/types/contracts/cat20/cat20GuardStateLib.d.ts +13 -0
  309. package/dist/types/contracts/cat20/cat20GuardStateLib.d.ts.map +1 -0
  310. package/dist/types/contracts/cat20/cat20StateLib.d.ts +7 -0
  311. package/dist/types/contracts/cat20/cat20StateLib.d.ts.map +1 -0
  312. package/dist/types/contracts/cat20/minters/cat20ClosedMinter.d.ts +10 -0
  313. package/dist/types/contracts/cat20/minters/cat20ClosedMinter.d.ts.map +1 -0
  314. package/dist/types/contracts/cat20/minters/cat20ClosedMinterMetadata.d.ts +6 -0
  315. package/dist/types/contracts/cat20/minters/cat20ClosedMinterMetadata.d.ts.map +1 -0
  316. package/dist/types/contracts/cat20/minters/cat20OpenMinter.d.ts +16 -0
  317. package/dist/types/contracts/cat20/minters/cat20OpenMinter.d.ts.map +1 -0
  318. package/dist/types/contracts/cat20/minters/cat20OpenMinterMetadata.d.ts +6 -0
  319. package/dist/types/contracts/cat20/minters/cat20OpenMinterMetadata.d.ts.map +1 -0
  320. package/dist/types/contracts/cat20/types.d.ts +58 -0
  321. package/dist/types/contracts/cat20/types.d.ts.map +1 -0
  322. package/dist/types/contracts/cat20Incinerator.d.ts +8 -0
  323. package/dist/types/contracts/cat20Incinerator.d.ts.map +1 -0
  324. package/dist/types/contracts/constants.d.ts +33 -0
  325. package/dist/types/contracts/constants.d.ts.map +1 -0
  326. package/dist/types/contracts/counter.d.ts +8 -0
  327. package/dist/types/contracts/counter.d.ts.map +1 -0
  328. package/dist/types/contracts/index.d.ts +16 -0
  329. package/dist/types/contracts/index.d.ts.map +1 -0
  330. package/dist/types/contracts/p2pkh.d.ts +7 -0
  331. package/dist/types/contracts/p2pkh.d.ts.map +1 -0
  332. package/dist/types/contracts/types.d.ts +9 -0
  333. package/dist/types/contracts/types.d.ts.map +1 -0
  334. package/dist/types/contracts/utils/ownerUtils.d.ts +19 -0
  335. package/dist/types/contracts/utils/ownerUtils.d.ts.map +1 -0
  336. package/dist/types/contracts/utils/safeMath.d.ts +5 -0
  337. package/dist/types/contracts/utils/safeMath.d.ts.map +1 -0
  338. package/dist/types/features/cat20/burn/burn.d.ts +6 -0
  339. package/dist/types/features/cat20/burn/burn.d.ts.map +1 -0
  340. package/dist/types/features/cat20/deploy/openMinter.d.ts +11 -0
  341. package/dist/types/features/cat20/deploy/openMinter.d.ts.map +1 -0
  342. package/dist/types/features/cat20/incinerate.d.ts +6 -0
  343. package/dist/types/features/cat20/incinerate.d.ts.map +1 -0
  344. package/dist/types/features/cat20/mint/openMinter.d.ts +7 -0
  345. package/dist/types/features/cat20/mint/openMinter.d.ts.map +1 -0
  346. package/dist/types/features/cat20/send/contractSend.d.ts +14 -0
  347. package/dist/types/features/cat20/send/contractSend.d.ts.map +1 -0
  348. package/dist/types/features/cat20/send/singleSend.d.ts +33 -0
  349. package/dist/types/features/cat20/send/singleSend.d.ts.map +1 -0
  350. package/dist/types/features/index.d.ts +7 -0
  351. package/dist/types/features/index.d.ts.map +1 -0
  352. package/dist/types/index.d.ts +7 -0
  353. package/dist/types/index.d.ts.map +1 -0
  354. package/dist/types/lib/index.d.ts +2 -0
  355. package/dist/types/lib/index.d.ts.map +1 -0
  356. package/dist/types/lib/metadata.d.ts +18 -0
  357. package/dist/types/lib/metadata.d.ts.map +1 -0
  358. package/dist/types/typeConstants.d.ts +31 -0
  359. package/dist/types/typeConstants.d.ts.map +1 -0
  360. package/dist/types/utils/check.d.ts +3 -0
  361. package/dist/types/utils/check.d.ts.map +1 -0
  362. package/dist/types/utils/contractPeripheral.d.ts +45 -0
  363. package/dist/types/utils/contractPeripheral.d.ts.map +1 -0
  364. package/dist/types/utils/index.d.ts +29 -0
  365. package/dist/types/utils/index.d.ts.map +1 -0
  366. package/dist/types/utils/loadAllArtifacts.d.ts +2 -0
  367. package/dist/types/utils/loadAllArtifacts.d.ts.map +1 -0
  368. package/package.json +76 -0
  369. package/scrypt.index.json +132 -0
package/README.md ADDED
@@ -0,0 +1,19 @@
1
+ # Opcat20
2
+
3
+ ## Build
4
+
5
+ ```sh
6
+ npm run build
7
+ ```
8
+
9
+ ## Testing Locally
10
+
11
+ ```sh
12
+ npm run test
13
+ ```
14
+
15
+ ## Run Tests on the Bitcoin Testnet
16
+
17
+ ```sh
18
+ npm run test:testnet
19
+ ```
@@ -0,0 +1 @@
1
+ [[],[],[],[],[],[],[],[],[],[],[],[],[[9,0,22,13]],[[2,0,24,20],[8,0,24,2]],[[2,0,27,19],[8,0,27,2]],[[2,0,29,2],[14,0,29,32],[20,0,29,14],[38,0,29,61],[44,0,29,44]],[[4,0,31,4],[8,0,31,9],[26,0,31,4],[28,0,31,28]],[[4,0,32,4],[8,0,32,9],[25,0,32,4],[27,0,32,27]],[],[[2,0,36,2],[18,0,36,9],[25,0,37,16],[44,0,37,4],[56,0,39,16],[77,0,39,4],[89,0,40,21],[93,0,40,4],[110,0,42,19],[124,0,42,4]],[],[],[],[],[],[],[],[],[],[],[],[],[],[],[],[],[[31,0,44,27],[46,0,44,42],[50,0,44,47]],[[4,0,47,4],[8,0,47,9],[20,0,48,6],[107,0,51,6]],[[4,0,56,4],[7,0,56,8],[32,0,56,23],[44,0,56,8],[47,0,56,37]],[[8,0,58,6],[37,0,59,19],[48,0,59,8],[81,0,60,42],[91,0,60,53],[111,0,60,42],[113,0,60,74],[119,0,60,102],[129,0,60,113],[149,0,60,102],[151,0,60,134],[154,0,60,101],[156,0,60,140]],[],[[8,0,64,6],[18,0,64,17],[34,0,64,32],[44,0,64,43],[78,0,64,66]],[[8,0,65,6],[16,0,65,18],[24,0,65,13],[25,0,65,27],[35,0,65,38],[45,0,65,47],[55,0,65,58],[66,0,65,13]],[],[],[],[[11,0,70,2],[22,0,71,16],[43,0,71,4],[55,0,72,23],[61,0,72,4],[80,0,73,26],[84,0,73,4],[106,0,74,24],[110,0,74,4],[130,0,75,23],[136,0,75,4],[155,0,76,26],[161,0,76,4]],[[4,0,80,4],[12,0,80,11],[24,0,80,24],[44,0,80,43],[63,0,80,62],[83,0,80,11],[86,0,80,85],[90,0,80,90]],[[4,0,81,4],[12,0,81,11],[24,0,81,24],[42,0,81,41],[64,0,81,63],[84,0,81,11],[87,0,81,86],[105,0,81,105],[116,0,81,115]],[[4,0,87,6],[8,0,86,10],[27,0,87,6],[37,0,87,17],[57,0,87,36],[58,0,87,43]],[[4,0,88,4],[12,0,89,6],[22,0,89,17],[41,0,89,35],[42,0,89,42],[61,0,89,6],[64,0,90,6]],[],[],[],[],[],[],[],[],[]]
@@ -0,0 +1,60 @@
1
+ import "./types.scrypt.tpl";
2
+ import "../types.scrypt.tpl";
3
+ import "@opcat-labs/scrypt-ts-opcat/assets/.templates/smart-contract/types/structs.scrypt.tpl";
4
+ import "../utils/ownerUtils.scrypt.tpl";
5
+ import "@opcat-labs/scrypt-ts-opcat/assets/.templates/smart-contract/builtin-libs/contextUtils.scrypt.tpl";
6
+ import "./cat20GuardStateLib.scrypt.tpl";
7
+ import "@opcat-labs/scrypt-ts-opcat/assets/.templates/smart-contract/builtin-libs/stdUtils.scrypt.tpl";
8
+ import "@opcat-labs/scrypt-ts-opcat/assets/.templates/smart-contract/builtin-libs/txUtils.scrypt.tpl";
9
+ import "@opcat-labs/scrypt-ts-opcat/assets/.templates/smart-contract/builtin-libs/backtrace.scrypt.tpl";
10
+ import "@opcat-labs/scrypt-ts-opcat/assets/.templates/smart-contract/builtin-libs/stateUtils.scrypt.tpl";
11
+
12
+
13
+ contract CAT20 {
14
+ bytes minterScriptHash;
15
+ bytes guardScriptHash;
16
+ constructor(bytes minterScriptHash, bytes guardScriptHash) {
17
+ this.minterScriptHash = minterScriptHash;
18
+ this.guardScriptHash = guardScriptHash;
19
+ }
20
+ public function unlock(ContractUnlockArgs unlockArgs, CAT20GuardConstState guardState, int guardInputIndex, BacktraceInfo backtraceInfo, SHPreimage __scrypt_ts_shPreimage, CAT20State __scrypt_ts_curState, bytes __scrypt_ts_prevouts, bytes __scrypt_ts_spentAmounts, bytes __scrypt_ts_spentDataHashes, bytes __scrypt_ts_spentScriptHashes, TxHashPreimage __scrypt_ts_prevTxHashPreimage) {
21
+ require(Tx.checkPreimageSigHashType(ContextUtils.serializeSHPreimage(__scrypt_ts_shPreimage), SigHash.ALL));
22
+
23
+ int __scrypt_ts_inputCount = ContextUtils.checkSpentAmounts(__scrypt_ts_spentAmounts, __scrypt_ts_shPreimage.hashSpentAmounts);
24
+
25
+ Outpoint __scrypt_ts_prevout = ContextUtils.checkPrevouts(__scrypt_ts_prevouts, __scrypt_ts_shPreimage.hashPrevouts, __scrypt_ts_shPreimage.inputIndex, __scrypt_ts_inputCount);
26
+
27
+ ContextUtils.checkSpentScripts(__scrypt_ts_spentScriptHashes, __scrypt_ts_shPreimage.hashSpentScriptHashes, __scrypt_ts_inputCount);
28
+
29
+ ContextUtils.checkSpentDataHashes(__scrypt_ts_spentDataHashes, __scrypt_ts_shPreimage.hashSpentDataHashes, __scrypt_ts_inputCount);
30
+
31
+ CAT20State __scrypt_ts_nextState = __scrypt_ts_curState;
32
+
33
+ StateUtils.checkInputState(__scrypt_ts_shPreimage.inputIndex, CAT20.stateHash(__scrypt_ts_curState), __scrypt_ts_spentDataHashes);
34
+
35
+ Backtrace.checkPrevTxHashPreimage(__scrypt_ts_prevTxHashPreimage, __scrypt_ts_prevouts, __scrypt_ts_shPreimage.inputIndex);
36
+
37
+ Backtrace.verifyFromScript(backtraceInfo, this.minterScriptHash, __scrypt_ts_spentScriptHashes[__scrypt_ts_shPreimage.inputIndex * 32 : (__scrypt_ts_shPreimage.inputIndex + 1) * 32], __scrypt_ts_prevTxHashPreimage.inputList);
38
+ this.checkGuard(guardState, __scrypt_ts_shPreimage.spentScriptHash, __scrypt_ts_shPreimage.inputIndex, guardInputIndex, __scrypt_ts_spentScriptHashes, __scrypt_ts_spentDataHashes);
39
+ if(len(__scrypt_ts_nextState.ownerAddr) == 32) {
40
+ require(__scrypt_ts_nextState.ownerAddr == __scrypt_ts_spentScriptHashes[unlockArgs.contractInputIndex * 32 : (unlockArgs.contractInputIndex + 1) * 32]);
41
+ } else {
42
+ OwnerUtils.checkUserOwner(unlockArgs.userPubKey, __scrypt_ts_nextState.ownerAddr);
43
+ require(checkSig(unlockArgs.userSig, unlockArgs.userPubKey));
44
+ }
45
+ require(true);
46
+ }
47
+ function checkGuard(CAT20GuardConstState guardState, bytes t_cat20ScriptHash, int t_cat20InputIndexVal, int guardInputIndexVal, bytes t_spentScriptsCtx, bytes t_spentDataHashesCtx) : bool {
48
+ require(ContextUtils.getSpentScriptHash(t_spentScriptsCtx, guardInputIndexVal) == this.guardScriptHash);
49
+ require(ContextUtils.getSpentDataHash(t_spentDataHashesCtx, guardInputIndexVal) == CAT20GuardStateLib.stateHash(guardState));
50
+ int tokenScriptIndex = guardState.tokenScriptIndexes[(t_cat20InputIndexVal)];
51
+ require(guardState.tokenScriptHashes[(tokenScriptIndex)] == t_cat20ScriptHash);
52
+ return true;
53
+ }
54
+ static function serializeState(CAT20State __scrypt_ts_curState): bytes {
55
+ return num2bin(len(__scrypt_ts_curState.tag), 2) + __scrypt_ts_curState.tag + num2bin(len(__scrypt_ts_curState.ownerAddr), 2) + __scrypt_ts_curState.ownerAddr + num2bin(len(pack(__scrypt_ts_curState.amount)), 2) + pack(__scrypt_ts_curState.amount) + hash160(hash160(__scrypt_ts_curState.tag) + hash160(__scrypt_ts_curState.ownerAddr) + hash160(pack(__scrypt_ts_curState.amount)));
56
+ }
57
+ static function stateHash(CAT20State __scrypt_ts_curState): bytes {
58
+ return sha256(num2bin(len(__scrypt_ts_curState.tag), 2) + __scrypt_ts_curState.tag + num2bin(len(__scrypt_ts_curState.ownerAddr), 2) + __scrypt_ts_curState.ownerAddr + num2bin(len(pack(__scrypt_ts_curState.amount)), 2) + pack(__scrypt_ts_curState.amount) + hash160(hash160(__scrypt_ts_curState.tag) + hash160(__scrypt_ts_curState.ownerAddr) + hash160(pack(__scrypt_ts_curState.amount))));
59
+ }
60
+ }
@@ -0,0 +1,9 @@
1
+ {
2
+ "success": true,
3
+ "errors": [],
4
+ "scryptfile": "cat20/cat20.scrypt.tpl",
5
+ "sourceMapFile": "cat20/cat20.scrypt.map",
6
+ "ctxMethods": [
7
+ "unlock"
8
+ ]
9
+ }
@@ -0,0 +1 @@
1
+ [[],[],[],[],[],[],[],[],[],[],[],[],[[9,0,27,13]],[],[[2,0,29,4],[18,0,29,11],[25,0,30,25],[30,0,30,25],[34,0,30,8],[51,0,34,33],[56,0,34,33],[60,0,34,8],[85,0,38,22],[88,0,38,22],[92,0,38,8],[106,0,44,32],[109,0,44,32],[113,0,44,8],[137,0,49,24],[140,0,49,24],[144,0,49,8],[160,0,53,21],[170,0,53,21],[174,0,53,8],[187,0,55,21],[191,0,55,8]],[],[],[],[],[],[],[],[],[],[],[],[],[[4,0,59,8],[22,0,59,27]],[[4,0,62,30],[8,0,62,12],[26,0,62,30]],[[4,0,63,39],[9,0,63,39],[13,0,63,14],[40,0,67,16],[52,0,67,29],[87,0,68,16],[99,0,68,29],[134,0,69,16],[146,0,69,29],[181,0,70,16],[193,0,70,29]],[[15,0,72,17]],[[8,0,73,12],[32,0,73,27],[51,0,73,45],[54,0,73,16],[57,0,73,51],[81,0,73,75]],[[10,0,74,16],[25,0,74,16]],[],[],[[15,0,78,17]],[[8,0,79,12],[11,0,79,16],[13,0,79,16],[15,0,79,20],[16,0,79,27]],[[10,0,80,16],[39,0,80,34],[58,0,80,52],[61,0,80,23],[64,0,80,58],[88,0,80,82]],[[10,0,81,16],[18,0,82,20],[43,0,82,35],[62,0,82,53],[66,0,82,20],[69,0,82,60]],[],[[10,0,85,16],[39,0,85,34],[58,0,85,52],[61,0,85,23],[64,0,85,58],[88,0,85,82]],[],[],[[4,0,88,8],[12,0,88,15],[28,0,88,15],[30,0,88,33]],[[4,0,94,31],[7,0,94,31],[11,0,94,14],[28,0,94,31],[35,0,94,36],[38,0,94,40]],[[4,0,95,34],[8,0,95,12],[30,0,95,34],[31,0,95,35]],[[4,0,96,27],[8,0,96,14]],[[15,0,97,17]],[[8,0,98,37],[12,0,98,18],[52,0,98,48],[72,0,98,67],[73,0,98,74]],[[8,0,99,12],[11,0,99,16],[13,0,99,16],[15,0,99,20]],[[10,0,100,16],[18,0,100,23],[35,0,100,23],[37,0,100,42]],[[10,0,101,16],[13,0,101,20],[30,0,101,20],[33,0,101,40],[34,0,101,41]],[[12,0,104,24],[18,0,103,26],[57,0,104,35],[76,0,104,53],[77,0,104,60]],[[12,0,105,20],[20,0,105,27],[36,0,105,27],[39,0,105,46],[51,0,105,59],[102,0,105,106],[103,0,105,113]],[[12,0,106,20],[25,0,106,34],[37,0,106,45],[49,0,106,57]],[[12,0,107,20],[20,0,107,27],[32,0,107,40],[79,0,107,83],[80,0,107,90],[84,0,107,27],[87,0,107,97],[100,0,107,111],[111,0,107,121],[123,0,107,133]],[[12,0,108,20],[27,0,108,35],[28,0,108,42],[47,0,108,20],[49,0,108,63],[57,0,108,72],[62,0,109,24],[77,0,109,39],[78,0,109,46],[98,0,110,24],[110,0,110,36],[112,0,110,39]],[[12,0,112,20],[32,0,112,20],[34,0,113,24],[51,0,113,24],[53,0,113,43],[75,0,114,30],[94,0,115,30]],[],[],[[10,0,118,16],[39,0,118,34],[59,0,118,53],[62,0,118,23],[65,0,118,59],[66,0,118,60]],[],[],[[4,0,124,8],[12,0,125,12],[32,0,125,12],[35,0,125,35],[37,0,125,12],[40,0,125,41],[60,0,125,41],[63,0,125,64],[79,0,125,64],[81,0,125,82]],[[4,0,130,8],[12,0,130,15],[24,0,130,15],[27,0,130,30],[29,0,130,15],[32,0,130,36],[44,0,130,36],[47,0,130,51]],[[4,0,131,32],[7,0,131,32],[11,0,131,14],[29,0,131,32],[36,0,131,37],[39,0,131,41]],[[4,0,132,22],[10,0,132,12],[20,0,132,35]],[[15,0,133,17]],[[8,0,134,12],[11,0,134,16],[13,0,134,16],[15,0,134,20]],[[10,0,135,46],[16,0,135,22],[40,0,135,46],[64,0,135,70]],[[10,0,136,16],[18,0,136,23],[22,0,136,27],[45,0,136,23],[47,0,136,52]],[[10,0,137,45],[14,0,137,22],[37,0,137,45],[60,0,137,68]],[[10,0,138,16],[18,0,138,23],[39,0,138,23],[41,0,138,46]],[[10,0,139,16],[13,0,139,20],[34,0,139,20],[37,0,139,44],[38,0,139,45]],[[12,0,141,40],[16,0,141,26],[30,0,141,40],[43,0,141,53]],[[12,0,142,20],[20,0,142,27],[32,0,142,27],[34,0,142,41]],[[12,0,143,20],[28,0,143,36],[29,0,143,43],[52,0,143,20],[54,0,143,68],[62,0,143,77],[67,0,144,24],[83,0,144,40],[84,0,144,47],[108,0,145,24]],[[12,0,147,43],[18,0,147,26],[35,0,147,43],[48,0,147,57],[59,0,147,67],[60,0,148,29],[72,0,148,42],[90,0,149,35],[113,0,150,32]],[[12,0,152,20],[20,0,152,27],[36,0,152,43],[39,0,152,27],[42,0,152,49]],[[12,0,154,24],[18,0,153,26],[57,0,154,35],[76,0,154,53],[77,0,154,60]],[[12,0,155,20],[20,0,155,20],[23,0,155,31],[30,0,155,39],[47,0,156,24],[64,0,157,24],[79,0,157,39],[83,0,158,24]],[],[[12,0,162,20],[20,0,162,27],[33,0,162,40],[36,0,162,27],[39,0,162,46]],[[23,0,164,29]],[[14,0,165,24],[22,0,165,31],[44,0,165,31],[68,0,165,67],[87,0,165,85]],[],[[12,0,167,20],[20,0,167,20],[23,0,167,31],[30,0,167,39],[47,0,168,24],[70,0,169,24],[85,0,169,39],[89,0,170,24],[105,0,170,40]],[],[],[[10,0,174,16],[18,0,174,23],[22,0,174,27],[46,0,174,51],[50,0,174,23],[53,0,174,58]],[[10,0,175,16],[18,0,175,23],[41,0,175,46],[44,0,175,23],[47,0,175,52],[48,0,175,53]],[[10,0,176,16],[18,0,176,23],[31,0,176,36],[34,0,176,23],[37,0,176,42]],[[10,0,177,16],[18,0,177,23],[34,0,177,39],[37,0,177,23],[40,0,177,58]],[[10,0,178,16],[18,0,178,23],[33,0,178,38],[36,0,178,23],[39,0,178,44]],[],[],[[15,0,183,17]],[[8,0,184,12],[16,0,184,19],[31,0,184,34],[34,0,184,19],[58,0,184,51],[72,0,184,64]],[[8,0,185,12],[16,0,186,16],[31,0,186,31],[34,0,186,16],[37,0,187,16],[45,0,187,25],[50,0,187,29],[66,0,187,45],[91,0,187,60],[109,0,187,77]],[[8,0,189,12],[11,0,189,16],[13,0,189,16],[15,0,189,20],[16,0,189,27]],[[10,0,190,16],[18,0,190,23],[33,0,190,38],[36,0,190,23],[38,0,190,43]],[],[[10,0,192,16],[18,0,192,23],[33,0,192,38],[36,0,192,23],[39,0,192,44]],[[10,0,193,16],[18,0,193,23],[34,0,193,39],[37,0,193,23],[40,0,193,45]],[[10,0,195,16],[39,0,195,34],[53,0,195,47],[56,0,195,23],[59,0,195,53]],[[10,0,196,16],[39,0,196,34],[57,0,196,51],[60,0,196,23],[63,0,196,57]],[],[],[[4,0,201,8],[20,0,201,33]],[],[],[],[],[],[],[],[]]
@@ -0,0 +1,117 @@
1
+ import "./types.scrypt.tpl";
2
+ import "./cat20GuardStateLib.scrypt.tpl";
3
+ import "../constants.scrypt.tpl";
4
+ import "@opcat-labs/scrypt-ts-opcat/assets/.templates/smart-contract/builtin-libs/contextUtils.scrypt.tpl";
5
+ import "./cat20StateLib.scrypt.tpl";
6
+ import "../utils/safeMath.scrypt.tpl";
7
+ import "@opcat-labs/scrypt-ts-opcat/assets/.templates/smart-contract/builtin-libs/txUtils.scrypt.tpl";
8
+ import "@opcat-labs/scrypt-ts-opcat/assets/.templates/smart-contract/builtin-libs/stdUtils.scrypt.tpl";
9
+ import "@opcat-labs/scrypt-ts-opcat/assets/.templates/smart-contract/types/structs.scrypt.tpl";
10
+ import "@opcat-labs/scrypt-ts-opcat/assets/.templates/smart-contract/builtin-libs/stateUtils.scrypt.tpl";
11
+
12
+
13
+ contract CAT20Guard {
14
+ constructor(){}
15
+ public function unlock(bytes[6] nextStateHashes, bytes[6] ownerAddrOrScriptHashes, int[6] outputTokens, int[6] tokenScriptHashIndexes, int[6] outputSatoshis, CAT20State[6] cat20States, int outputCount, SHPreimage __scrypt_ts_shPreimage, CAT20GuardConstState __scrypt_ts_curState, bytes __scrypt_ts_spentAmounts, bytes __scrypt_ts_spentDataHashes, bytes __scrypt_ts_spentScriptHashes) {
16
+ require(Tx.checkPreimageSigHashType(ContextUtils.serializeSHPreimage(__scrypt_ts_shPreimage), SigHash.ALL));
17
+
18
+ int __scrypt_ts_inputCount = ContextUtils.checkSpentAmounts(__scrypt_ts_spentAmounts, __scrypt_ts_shPreimage.hashSpentAmounts);
19
+
20
+ ContextUtils.checkSpentScripts(__scrypt_ts_spentScriptHashes, __scrypt_ts_shPreimage.hashSpentScriptHashes, __scrypt_ts_inputCount);
21
+
22
+ ContextUtils.checkSpentDataHashes(__scrypt_ts_spentDataHashes, __scrypt_ts_shPreimage.hashSpentDataHashes, __scrypt_ts_inputCount);
23
+
24
+ CAT20GuardConstState __scrypt_ts_nextState = __scrypt_ts_curState;
25
+
26
+ StateUtils.checkInputState(__scrypt_ts_shPreimage.inputIndex, CAT20Guard.stateHash(__scrypt_ts_curState), __scrypt_ts_spentDataHashes);
27
+
28
+ CAT20GuardStateLib.formalCheckState(__scrypt_ts_nextState);
29
+ int inputTokenTypes = 0;
30
+ bytes[4] tokenScriptPlaceholders = [ConstantsLib.TOKEN_SCRIPT_HASH_PLACEHOLDER_FF, ConstantsLib.TOKEN_SCRIPT_HASH_PLACEHOLDER_FE, ConstantsLib.TOKEN_SCRIPT_HASH_PLACEHOLDER_FD, ConstantsLib.TOKEN_SCRIPT_HASH_PLACEHOLDER_FC];
31
+ loop (4) : i {
32
+ if(__scrypt_ts_nextState.tokenScriptHashes[i] != tokenScriptPlaceholders[i]) {
33
+ inputTokenTypes++;
34
+ }
35
+ }
36
+ loop (4) : i {
37
+ if(i < (inputTokenTypes)) {
38
+ require(__scrypt_ts_nextState.tokenScriptHashes[i] != tokenScriptPlaceholders[i]);
39
+ require(len(__scrypt_ts_nextState.tokenScriptHashes[i]) == 32);
40
+ } else {
41
+ require(__scrypt_ts_nextState.tokenScriptHashes[i] == tokenScriptPlaceholders[i]);
42
+ }
43
+ }
44
+ require(inputTokenTypes > 0);
45
+ int[4] sumInputTokens = repeat(0, 4);
46
+ int tokenScriptIndexMax = -1;
47
+ int inputCount = __scrypt_ts_inputCount;
48
+ loop (6) : i {
49
+ int tokenScriptIndex = __scrypt_ts_nextState.tokenScriptIndexes[(i)];
50
+ if(i < inputCount) {
51
+ require(tokenScriptIndex < inputTokenTypes);
52
+ if(tokenScriptIndex != -1) {
53
+ bytes tokenScriptHash = __scrypt_ts_nextState.tokenScriptHashes[(tokenScriptIndex)];
54
+ require(tokenScriptHash == ContextUtils.getSpentScriptHash(__scrypt_ts_spentScriptHashes, (i)));
55
+ CAT20StateLib.checkState(cat20States[i]);
56
+ require(ContextUtils.getSpentDataHash(__scrypt_ts_spentDataHashes, (i)) == CAT20StateLib.stateHash(cat20States[i]));
57
+ sumInputTokens[(tokenScriptIndex)] = SafeMath.add(sumInputTokens[(tokenScriptIndex)], cat20States[i].amount);
58
+ tokenScriptIndexMax = tokenScriptIndex > tokenScriptIndexMax ? tokenScriptIndex : tokenScriptIndexMax;
59
+ }
60
+ } else {
61
+ require(__scrypt_ts_nextState.tokenScriptIndexes[i] == -1);
62
+ }
63
+ }
64
+ require(tokenScriptIndexMax >= 0 && tokenScriptIndexMax == inputTokenTypes - 1);
65
+ require(outputCount >= 0 && outputCount <= 6);
66
+ int[4] sumOutputTokens = repeat(0, 4);
67
+ bytes outputs = b'';
68
+ loop (6) : i {
69
+ if(i < outputCount) {
70
+ bytes ownerAddrOrScriptHash = ownerAddrOrScriptHashes[i];
71
+ require(len(ownerAddrOrScriptHash) > 0);
72
+ int tokenScriptHashIndex = tokenScriptHashIndexes[i];
73
+ require(tokenScriptHashIndex < inputTokenTypes);
74
+ if(tokenScriptHashIndex != -1) {
75
+ int tokenAmount = outputTokens[i];
76
+ require(tokenAmount > 0);
77
+ sumOutputTokens[(tokenScriptHashIndex)] = SafeMath.add(sumOutputTokens[(tokenScriptHashIndex)], tokenAmount);
78
+ bytes tokenStateHash = CAT20StateLib.stateHash({ConstantsLib.OPCAT_CAT20_TAG, ownerAddrOrScriptHash, tokenAmount});
79
+ require(nextStateHashes[i] == tokenStateHash);
80
+ bytes tokenScriptHash = __scrypt_ts_nextState.tokenScriptHashes[(tokenScriptHashIndex)];
81
+ outputs += TxUtils.buildDataOutput(tokenScriptHash, outputSatoshis[i], tokenStateHash);
82
+ } else {
83
+ require(outputTokens[i] == 0);
84
+ loop (4) : j {
85
+ require(ownerAddrOrScriptHash != __scrypt_ts_nextState.tokenScriptHashes[j]);
86
+ }
87
+ outputs += TxUtils.buildDataOutput(ownerAddrOrScriptHash, outputSatoshis[i], nextStateHashes[i]);
88
+ }
89
+ } else {
90
+ require(len(ownerAddrOrScriptHashes[i]) == 0);
91
+ require(tokenScriptHashIndexes[i] == -1);
92
+ require(outputTokens[i] == 0);
93
+ require(nextStateHashes[i] == b'');
94
+ require(outputSatoshis[i] == 0);
95
+ }
96
+ }
97
+ loop (4) : i {
98
+ require(sumInputTokens[i] == __scrypt_ts_nextState.tokenAmounts[i]);
99
+ require(sumInputTokens[i] == SafeMath.add(sumOutputTokens[i], __scrypt_ts_nextState.tokenBurnAmounts[i]));
100
+ if(i < (inputTokenTypes)) {
101
+ require(sumInputTokens[i] > 0);
102
+ } else {
103
+ require(sumInputTokens[i] == 0);
104
+ require(sumOutputTokens[i] == 0);
105
+ require(__scrypt_ts_nextState.tokenAmounts[i] == 0);
106
+ require(__scrypt_ts_nextState.tokenBurnAmounts[i] == 0);
107
+ }
108
+ }
109
+ require(hash256(outputs) == __scrypt_ts_shPreimage.hashOutputs);
110
+ }
111
+ static function serializeState(CAT20GuardConstState __scrypt_ts_curState): bytes {
112
+ return num2bin(len(__scrypt_ts_curState.tokenScriptHashes[0]), 2) + __scrypt_ts_curState.tokenScriptHashes[0] + num2bin(len(__scrypt_ts_curState.tokenScriptHashes[1]), 2) + __scrypt_ts_curState.tokenScriptHashes[1] + num2bin(len(__scrypt_ts_curState.tokenScriptHashes[2]), 2) + __scrypt_ts_curState.tokenScriptHashes[2] + num2bin(len(__scrypt_ts_curState.tokenScriptHashes[3]), 2) + __scrypt_ts_curState.tokenScriptHashes[3] + num2bin(len(pack(__scrypt_ts_curState.tokenAmounts[0])), 2) + pack(__scrypt_ts_curState.tokenAmounts[0]) + num2bin(len(pack(__scrypt_ts_curState.tokenAmounts[1])), 2) + pack(__scrypt_ts_curState.tokenAmounts[1]) + num2bin(len(pack(__scrypt_ts_curState.tokenAmounts[2])), 2) + pack(__scrypt_ts_curState.tokenAmounts[2]) + num2bin(len(pack(__scrypt_ts_curState.tokenAmounts[3])), 2) + pack(__scrypt_ts_curState.tokenAmounts[3]) + num2bin(len(pack(__scrypt_ts_curState.tokenBurnAmounts[0])), 2) + pack(__scrypt_ts_curState.tokenBurnAmounts[0]) + num2bin(len(pack(__scrypt_ts_curState.tokenBurnAmounts[1])), 2) + pack(__scrypt_ts_curState.tokenBurnAmounts[1]) + num2bin(len(pack(__scrypt_ts_curState.tokenBurnAmounts[2])), 2) + pack(__scrypt_ts_curState.tokenBurnAmounts[2]) + num2bin(len(pack(__scrypt_ts_curState.tokenBurnAmounts[3])), 2) + pack(__scrypt_ts_curState.tokenBurnAmounts[3]) + num2bin(len(pack(__scrypt_ts_curState.tokenScriptIndexes[0])), 2) + pack(__scrypt_ts_curState.tokenScriptIndexes[0]) + num2bin(len(pack(__scrypt_ts_curState.tokenScriptIndexes[1])), 2) + pack(__scrypt_ts_curState.tokenScriptIndexes[1]) + num2bin(len(pack(__scrypt_ts_curState.tokenScriptIndexes[2])), 2) + pack(__scrypt_ts_curState.tokenScriptIndexes[2]) + num2bin(len(pack(__scrypt_ts_curState.tokenScriptIndexes[3])), 2) + pack(__scrypt_ts_curState.tokenScriptIndexes[3]) + num2bin(len(pack(__scrypt_ts_curState.tokenScriptIndexes[4])), 2) + pack(__scrypt_ts_curState.tokenScriptIndexes[4]) + num2bin(len(pack(__scrypt_ts_curState.tokenScriptIndexes[5])), 2) + pack(__scrypt_ts_curState.tokenScriptIndexes[5]) + hash160(hash160(__scrypt_ts_curState.tokenScriptHashes[0]) + hash160(__scrypt_ts_curState.tokenScriptHashes[1]) + hash160(__scrypt_ts_curState.tokenScriptHashes[2]) + hash160(__scrypt_ts_curState.tokenScriptHashes[3]) + hash160(pack(__scrypt_ts_curState.tokenAmounts[0])) + hash160(pack(__scrypt_ts_curState.tokenAmounts[1])) + hash160(pack(__scrypt_ts_curState.tokenAmounts[2])) + hash160(pack(__scrypt_ts_curState.tokenAmounts[3])) + hash160(pack(__scrypt_ts_curState.tokenBurnAmounts[0])) + hash160(pack(__scrypt_ts_curState.tokenBurnAmounts[1])) + hash160(pack(__scrypt_ts_curState.tokenBurnAmounts[2])) + hash160(pack(__scrypt_ts_curState.tokenBurnAmounts[3])) + hash160(pack(__scrypt_ts_curState.tokenScriptIndexes[0])) + hash160(pack(__scrypt_ts_curState.tokenScriptIndexes[1])) + hash160(pack(__scrypt_ts_curState.tokenScriptIndexes[2])) + hash160(pack(__scrypt_ts_curState.tokenScriptIndexes[3])) + hash160(pack(__scrypt_ts_curState.tokenScriptIndexes[4])) + hash160(pack(__scrypt_ts_curState.tokenScriptIndexes[5])));
113
+ }
114
+ static function stateHash(CAT20GuardConstState __scrypt_ts_curState): bytes {
115
+ return sha256(num2bin(len(__scrypt_ts_curState.tokenScriptHashes[0]), 2) + __scrypt_ts_curState.tokenScriptHashes[0] + num2bin(len(__scrypt_ts_curState.tokenScriptHashes[1]), 2) + __scrypt_ts_curState.tokenScriptHashes[1] + num2bin(len(__scrypt_ts_curState.tokenScriptHashes[2]), 2) + __scrypt_ts_curState.tokenScriptHashes[2] + num2bin(len(__scrypt_ts_curState.tokenScriptHashes[3]), 2) + __scrypt_ts_curState.tokenScriptHashes[3] + num2bin(len(pack(__scrypt_ts_curState.tokenAmounts[0])), 2) + pack(__scrypt_ts_curState.tokenAmounts[0]) + num2bin(len(pack(__scrypt_ts_curState.tokenAmounts[1])), 2) + pack(__scrypt_ts_curState.tokenAmounts[1]) + num2bin(len(pack(__scrypt_ts_curState.tokenAmounts[2])), 2) + pack(__scrypt_ts_curState.tokenAmounts[2]) + num2bin(len(pack(__scrypt_ts_curState.tokenAmounts[3])), 2) + pack(__scrypt_ts_curState.tokenAmounts[3]) + num2bin(len(pack(__scrypt_ts_curState.tokenBurnAmounts[0])), 2) + pack(__scrypt_ts_curState.tokenBurnAmounts[0]) + num2bin(len(pack(__scrypt_ts_curState.tokenBurnAmounts[1])), 2) + pack(__scrypt_ts_curState.tokenBurnAmounts[1]) + num2bin(len(pack(__scrypt_ts_curState.tokenBurnAmounts[2])), 2) + pack(__scrypt_ts_curState.tokenBurnAmounts[2]) + num2bin(len(pack(__scrypt_ts_curState.tokenBurnAmounts[3])), 2) + pack(__scrypt_ts_curState.tokenBurnAmounts[3]) + num2bin(len(pack(__scrypt_ts_curState.tokenScriptIndexes[0])), 2) + pack(__scrypt_ts_curState.tokenScriptIndexes[0]) + num2bin(len(pack(__scrypt_ts_curState.tokenScriptIndexes[1])), 2) + pack(__scrypt_ts_curState.tokenScriptIndexes[1]) + num2bin(len(pack(__scrypt_ts_curState.tokenScriptIndexes[2])), 2) + pack(__scrypt_ts_curState.tokenScriptIndexes[2]) + num2bin(len(pack(__scrypt_ts_curState.tokenScriptIndexes[3])), 2) + pack(__scrypt_ts_curState.tokenScriptIndexes[3]) + num2bin(len(pack(__scrypt_ts_curState.tokenScriptIndexes[4])), 2) + pack(__scrypt_ts_curState.tokenScriptIndexes[4]) + num2bin(len(pack(__scrypt_ts_curState.tokenScriptIndexes[5])), 2) + pack(__scrypt_ts_curState.tokenScriptIndexes[5]) + hash160(hash160(__scrypt_ts_curState.tokenScriptHashes[0]) + hash160(__scrypt_ts_curState.tokenScriptHashes[1]) + hash160(__scrypt_ts_curState.tokenScriptHashes[2]) + hash160(__scrypt_ts_curState.tokenScriptHashes[3]) + hash160(pack(__scrypt_ts_curState.tokenAmounts[0])) + hash160(pack(__scrypt_ts_curState.tokenAmounts[1])) + hash160(pack(__scrypt_ts_curState.tokenAmounts[2])) + hash160(pack(__scrypt_ts_curState.tokenAmounts[3])) + hash160(pack(__scrypt_ts_curState.tokenBurnAmounts[0])) + hash160(pack(__scrypt_ts_curState.tokenBurnAmounts[1])) + hash160(pack(__scrypt_ts_curState.tokenBurnAmounts[2])) + hash160(pack(__scrypt_ts_curState.tokenBurnAmounts[3])) + hash160(pack(__scrypt_ts_curState.tokenScriptIndexes[0])) + hash160(pack(__scrypt_ts_curState.tokenScriptIndexes[1])) + hash160(pack(__scrypt_ts_curState.tokenScriptIndexes[2])) + hash160(pack(__scrypt_ts_curState.tokenScriptIndexes[3])) + hash160(pack(__scrypt_ts_curState.tokenScriptIndexes[4])) + hash160(pack(__scrypt_ts_curState.tokenScriptIndexes[5]))));
116
+ }
117
+ }
@@ -0,0 +1,9 @@
1
+ {
2
+ "success": true,
3
+ "errors": [],
4
+ "scryptfile": "cat20/cat20Guard.scrypt.tpl",
5
+ "sourceMapFile": "cat20/cat20Guard.scrypt.map",
6
+ "ctxMethods": [
7
+ "unlock"
8
+ ]
9
+ }
@@ -0,0 +1 @@
1
+ [[],[],[],[],[],[[8,0,5,13]],[[2,0,8,2],[18,0,8,9],[35,0,8,34],[56,0,8,26],[66,0,8,57]],[[4,0,9,4],[22,0,9,23],[45,0,9,45],[51,0,9,52]],[[15,0,11,13]],[[8,0,12,24],[12,0,12,12],[24,0,12,24],[28,0,12,28],[34,0,12,35],[53,0,12,53]],[[8,0,13,6],[16,0,13,13],[26,0,13,13],[29,0,13,26]],[[8,0,15,6],[16,0,15,13],[22,0,15,20],[36,0,15,33],[39,0,15,13],[42,0,15,39]],[[8,0,16,6],[16,0,16,13],[22,0,16,20],[40,0,16,37],[43,0,16,13],[46,0,16,43]],[],[[15,0,19,13]],[[8,0,21,26],[12,0,21,12],[26,0,21,26],[32,0,21,33],[52,0,21,52]],[[8,0,22,6],[16,0,22,13],[28,0,22,13],[31,0,22,28],[32,0,22,29],[34,0,22,13],[37,0,22,34],[49,0,22,34],[51,0,22,48]],[],[[4,0,25,4],[11,0,25,24]],[],[[2,0,34,2],[18,0,34,9],[40,0,35,18],[45,0,35,18],[49,0,35,4]],[[4,0,38,4],[12,0,38,11],[25,0,38,24],[28,0,38,11],[31,0,38,30],[44,0,38,43]],[[4,0,39,4],[12,0,39,11],[25,0,39,24],[28,0,39,11],[31,0,39,30],[44,0,39,43]],[[4,0,40,4],[12,0,40,11],[25,0,40,24],[28,0,40,11],[31,0,40,30],[44,0,40,43]],[[4,0,41,4],[12,0,41,11],[25,0,41,24],[28,0,41,11],[31,0,41,30],[44,0,41,43]],[[4,0,42,4],[12,0,42,11],[25,0,42,24],[28,0,42,11],[31,0,42,30],[44,0,42,43]],[[4,0,43,4],[12,0,43,11],[25,0,43,24],[28,0,43,11],[31,0,43,30],[44,0,43,43]],[],[],[],[],[],[],[],[],[]]
@@ -0,0 +1,36 @@
1
+ import "./types.scrypt.tpl";
2
+ import "@opcat-labs/scrypt-ts-opcat/assets/.templates/smart-contract/builtin-libs/txUtils.scrypt.tpl";
3
+ import "@opcat-labs/scrypt-ts-opcat/assets/.templates/smart-contract/builtin-libs/contextUtils.scrypt.tpl";
4
+
5
+
6
+ library CAT20GuardStateLib {
7
+ static function formalCheckState(CAT20GuardConstState _state) : bytes {
8
+ CAT20GuardStateLib.checkTokenScriptsUniq(_state.tokenScriptHashes);
9
+ loop (4) : i {
10
+ int scriptLen = len(_state.tokenScriptHashes[i]);
11
+ require(scriptLen == 32);
12
+ require(_state.tokenAmounts[i] >= 0);
13
+ require(_state.tokenBurnAmounts[i] >= 0);
14
+ }
15
+ loop (6) : i {
16
+ int scriptIndex = _state.tokenScriptIndexes[i];
17
+ require(scriptIndex >= -1 && scriptIndex < 4);
18
+ }
19
+ return b'';
20
+ }
21
+ static function checkTokenScriptsUniq(bytes[4] tokenScripts) : bool {
22
+ require(tokenScripts[0] != tokenScripts[1]);
23
+ require(tokenScripts[0] != tokenScripts[2]);
24
+ require(tokenScripts[0] != tokenScripts[3]);
25
+ require(tokenScripts[1] != tokenScripts[2]);
26
+ require(tokenScripts[1] != tokenScripts[3]);
27
+ require(tokenScripts[2] != tokenScripts[3]);
28
+ return true;
29
+ }
30
+ static function serializeState(CAT20GuardConstState __scrypt_ts_curState): bytes {
31
+ return num2bin(len(__scrypt_ts_curState.tokenScriptHashes[0]), 2) + __scrypt_ts_curState.tokenScriptHashes[0] + num2bin(len(__scrypt_ts_curState.tokenScriptHashes[1]), 2) + __scrypt_ts_curState.tokenScriptHashes[1] + num2bin(len(__scrypt_ts_curState.tokenScriptHashes[2]), 2) + __scrypt_ts_curState.tokenScriptHashes[2] + num2bin(len(__scrypt_ts_curState.tokenScriptHashes[3]), 2) + __scrypt_ts_curState.tokenScriptHashes[3] + num2bin(len(pack(__scrypt_ts_curState.tokenAmounts[0])), 2) + pack(__scrypt_ts_curState.tokenAmounts[0]) + num2bin(len(pack(__scrypt_ts_curState.tokenAmounts[1])), 2) + pack(__scrypt_ts_curState.tokenAmounts[1]) + num2bin(len(pack(__scrypt_ts_curState.tokenAmounts[2])), 2) + pack(__scrypt_ts_curState.tokenAmounts[2]) + num2bin(len(pack(__scrypt_ts_curState.tokenAmounts[3])), 2) + pack(__scrypt_ts_curState.tokenAmounts[3]) + num2bin(len(pack(__scrypt_ts_curState.tokenBurnAmounts[0])), 2) + pack(__scrypt_ts_curState.tokenBurnAmounts[0]) + num2bin(len(pack(__scrypt_ts_curState.tokenBurnAmounts[1])), 2) + pack(__scrypt_ts_curState.tokenBurnAmounts[1]) + num2bin(len(pack(__scrypt_ts_curState.tokenBurnAmounts[2])), 2) + pack(__scrypt_ts_curState.tokenBurnAmounts[2]) + num2bin(len(pack(__scrypt_ts_curState.tokenBurnAmounts[3])), 2) + pack(__scrypt_ts_curState.tokenBurnAmounts[3]) + num2bin(len(pack(__scrypt_ts_curState.tokenScriptIndexes[0])), 2) + pack(__scrypt_ts_curState.tokenScriptIndexes[0]) + num2bin(len(pack(__scrypt_ts_curState.tokenScriptIndexes[1])), 2) + pack(__scrypt_ts_curState.tokenScriptIndexes[1]) + num2bin(len(pack(__scrypt_ts_curState.tokenScriptIndexes[2])), 2) + pack(__scrypt_ts_curState.tokenScriptIndexes[2]) + num2bin(len(pack(__scrypt_ts_curState.tokenScriptIndexes[3])), 2) + pack(__scrypt_ts_curState.tokenScriptIndexes[3]) + num2bin(len(pack(__scrypt_ts_curState.tokenScriptIndexes[4])), 2) + pack(__scrypt_ts_curState.tokenScriptIndexes[4]) + num2bin(len(pack(__scrypt_ts_curState.tokenScriptIndexes[5])), 2) + pack(__scrypt_ts_curState.tokenScriptIndexes[5]) + hash160(hash160(__scrypt_ts_curState.tokenScriptHashes[0]) + hash160(__scrypt_ts_curState.tokenScriptHashes[1]) + hash160(__scrypt_ts_curState.tokenScriptHashes[2]) + hash160(__scrypt_ts_curState.tokenScriptHashes[3]) + hash160(pack(__scrypt_ts_curState.tokenAmounts[0])) + hash160(pack(__scrypt_ts_curState.tokenAmounts[1])) + hash160(pack(__scrypt_ts_curState.tokenAmounts[2])) + hash160(pack(__scrypt_ts_curState.tokenAmounts[3])) + hash160(pack(__scrypt_ts_curState.tokenBurnAmounts[0])) + hash160(pack(__scrypt_ts_curState.tokenBurnAmounts[1])) + hash160(pack(__scrypt_ts_curState.tokenBurnAmounts[2])) + hash160(pack(__scrypt_ts_curState.tokenBurnAmounts[3])) + hash160(pack(__scrypt_ts_curState.tokenScriptIndexes[0])) + hash160(pack(__scrypt_ts_curState.tokenScriptIndexes[1])) + hash160(pack(__scrypt_ts_curState.tokenScriptIndexes[2])) + hash160(pack(__scrypt_ts_curState.tokenScriptIndexes[3])) + hash160(pack(__scrypt_ts_curState.tokenScriptIndexes[4])) + hash160(pack(__scrypt_ts_curState.tokenScriptIndexes[5])));
32
+ }
33
+ static function stateHash(CAT20GuardConstState __scrypt_ts_curState): bytes {
34
+ return sha256(num2bin(len(__scrypt_ts_curState.tokenScriptHashes[0]), 2) + __scrypt_ts_curState.tokenScriptHashes[0] + num2bin(len(__scrypt_ts_curState.tokenScriptHashes[1]), 2) + __scrypt_ts_curState.tokenScriptHashes[1] + num2bin(len(__scrypt_ts_curState.tokenScriptHashes[2]), 2) + __scrypt_ts_curState.tokenScriptHashes[2] + num2bin(len(__scrypt_ts_curState.tokenScriptHashes[3]), 2) + __scrypt_ts_curState.tokenScriptHashes[3] + num2bin(len(pack(__scrypt_ts_curState.tokenAmounts[0])), 2) + pack(__scrypt_ts_curState.tokenAmounts[0]) + num2bin(len(pack(__scrypt_ts_curState.tokenAmounts[1])), 2) + pack(__scrypt_ts_curState.tokenAmounts[1]) + num2bin(len(pack(__scrypt_ts_curState.tokenAmounts[2])), 2) + pack(__scrypt_ts_curState.tokenAmounts[2]) + num2bin(len(pack(__scrypt_ts_curState.tokenAmounts[3])), 2) + pack(__scrypt_ts_curState.tokenAmounts[3]) + num2bin(len(pack(__scrypt_ts_curState.tokenBurnAmounts[0])), 2) + pack(__scrypt_ts_curState.tokenBurnAmounts[0]) + num2bin(len(pack(__scrypt_ts_curState.tokenBurnAmounts[1])), 2) + pack(__scrypt_ts_curState.tokenBurnAmounts[1]) + num2bin(len(pack(__scrypt_ts_curState.tokenBurnAmounts[2])), 2) + pack(__scrypt_ts_curState.tokenBurnAmounts[2]) + num2bin(len(pack(__scrypt_ts_curState.tokenBurnAmounts[3])), 2) + pack(__scrypt_ts_curState.tokenBurnAmounts[3]) + num2bin(len(pack(__scrypt_ts_curState.tokenScriptIndexes[0])), 2) + pack(__scrypt_ts_curState.tokenScriptIndexes[0]) + num2bin(len(pack(__scrypt_ts_curState.tokenScriptIndexes[1])), 2) + pack(__scrypt_ts_curState.tokenScriptIndexes[1]) + num2bin(len(pack(__scrypt_ts_curState.tokenScriptIndexes[2])), 2) + pack(__scrypt_ts_curState.tokenScriptIndexes[2]) + num2bin(len(pack(__scrypt_ts_curState.tokenScriptIndexes[3])), 2) + pack(__scrypt_ts_curState.tokenScriptIndexes[3]) + num2bin(len(pack(__scrypt_ts_curState.tokenScriptIndexes[4])), 2) + pack(__scrypt_ts_curState.tokenScriptIndexes[4]) + num2bin(len(pack(__scrypt_ts_curState.tokenScriptIndexes[5])), 2) + pack(__scrypt_ts_curState.tokenScriptIndexes[5]) + hash160(hash160(__scrypt_ts_curState.tokenScriptHashes[0]) + hash160(__scrypt_ts_curState.tokenScriptHashes[1]) + hash160(__scrypt_ts_curState.tokenScriptHashes[2]) + hash160(__scrypt_ts_curState.tokenScriptHashes[3]) + hash160(pack(__scrypt_ts_curState.tokenAmounts[0])) + hash160(pack(__scrypt_ts_curState.tokenAmounts[1])) + hash160(pack(__scrypt_ts_curState.tokenAmounts[2])) + hash160(pack(__scrypt_ts_curState.tokenAmounts[3])) + hash160(pack(__scrypt_ts_curState.tokenBurnAmounts[0])) + hash160(pack(__scrypt_ts_curState.tokenBurnAmounts[1])) + hash160(pack(__scrypt_ts_curState.tokenBurnAmounts[2])) + hash160(pack(__scrypt_ts_curState.tokenBurnAmounts[3])) + hash160(pack(__scrypt_ts_curState.tokenScriptIndexes[0])) + hash160(pack(__scrypt_ts_curState.tokenScriptIndexes[1])) + hash160(pack(__scrypt_ts_curState.tokenScriptIndexes[2])) + hash160(pack(__scrypt_ts_curState.tokenScriptIndexes[3])) + hash160(pack(__scrypt_ts_curState.tokenScriptIndexes[4])) + hash160(pack(__scrypt_ts_curState.tokenScriptIndexes[5]))));
35
+ }
36
+ }
@@ -0,0 +1,7 @@
1
+ {
2
+ "success": true,
3
+ "errors": [],
4
+ "scryptfile": "cat20/cat20GuardStateLib.scrypt.tpl",
5
+ "sourceMapFile": "cat20/cat20GuardStateLib.scrypt.map",
6
+ "ctxMethods": []
7
+ }
@@ -0,0 +1 @@
1
+ [[],[],[],[],[],[],[],[[8,0,5,13]],[[2,0,7,4],[18,0,7,11],[29,0,7,30],[40,0,7,22]],[[4,0,8,8],[14,0,8,19],[30,0,8,34],[36,0,8,41]],[[4,0,9,8],[12,0,9,15],[18,0,9,22],[26,0,9,15],[28,0,9,31]],[[4,0,10,8],[12,0,10,15],[18,0,10,22],[23,0,10,15],[26,0,10,29],[38,0,10,42]],[],[],[],[],[],[],[],[],[]]
@@ -0,0 +1,21 @@
1
+ import "./types.scrypt.tpl";
2
+ import "../utils/ownerUtils.scrypt.tpl";
3
+ import "../constants.scrypt.tpl";
4
+ import "@opcat-labs/scrypt-ts-opcat/assets/.templates/smart-contract/builtin-libs/txUtils.scrypt.tpl";
5
+ import "@opcat-labs/scrypt-ts-opcat/assets/.templates/smart-contract/builtin-libs/contextUtils.scrypt.tpl";
6
+
7
+
8
+ library CAT20StateLib {
9
+ static function checkState(CAT20State _state) : bool {
10
+ OwnerUtils.checkOwnerAddr(_state.ownerAddr);
11
+ require(_state.amount > 0);
12
+ require(_state.tag == ConstantsLib.OPCAT_CAT20_TAG);
13
+ return true;
14
+ }
15
+ static function serializeState(CAT20State __scrypt_ts_curState): bytes {
16
+ return num2bin(len(__scrypt_ts_curState.tag), 2) + __scrypt_ts_curState.tag + num2bin(len(__scrypt_ts_curState.ownerAddr), 2) + __scrypt_ts_curState.ownerAddr + num2bin(len(pack(__scrypt_ts_curState.amount)), 2) + pack(__scrypt_ts_curState.amount) + hash160(hash160(__scrypt_ts_curState.tag) + hash160(__scrypt_ts_curState.ownerAddr) + hash160(pack(__scrypt_ts_curState.amount)));
17
+ }
18
+ static function stateHash(CAT20State __scrypt_ts_curState): bytes {
19
+ return sha256(num2bin(len(__scrypt_ts_curState.tag), 2) + __scrypt_ts_curState.tag + num2bin(len(__scrypt_ts_curState.ownerAddr), 2) + __scrypt_ts_curState.ownerAddr + num2bin(len(pack(__scrypt_ts_curState.amount)), 2) + pack(__scrypt_ts_curState.amount) + hash160(hash160(__scrypt_ts_curState.tag) + hash160(__scrypt_ts_curState.ownerAddr) + hash160(pack(__scrypt_ts_curState.amount))));
20
+ }
21
+ }
@@ -0,0 +1,7 @@
1
+ {
2
+ "success": true,
3
+ "errors": [],
4
+ "scryptfile": "cat20/cat20StateLib.scrypt.tpl",
5
+ "sourceMapFile": "cat20/cat20StateLib.scrypt.map",
6
+ "ctxMethods": []
7
+ }
@@ -0,0 +1 @@
1
+ [[],[],[],[],[],[],[],[],[],[],[],[[9,0,6,13]],[[2,0,8,17],[8,0,8,2]],[[2,0,11,19],[8,0,11,2]],[[2,0,13,2],[14,0,13,28],[20,0,13,14],[34,0,13,57],[40,0,13,40]],[[4,0,15,4],[8,0,15,9],[23,0,15,4],[25,0,15,25]],[[4,0,16,4],[8,0,16,9],[25,0,16,4],[27,0,16,27]],[],[[2,0,20,2],[18,0,20,9],[23,0,22,15],[34,0,22,4],[45,0,23,18],[52,0,23,4],[66,0,24,15],[70,0,24,4],[81,0,27,20],[85,0,27,4],[101,0,29,19],[105,0,29,4],[120,0,31,19],[134,0,31,4]],[],[],[],[],[],[],[],[],[],[],[],[],[],[],[],[],[[4,0,35,25],[10,0,35,10]],[[33,0,37,6],[48,0,38,6],[52,0,38,11]],[[4,0,42,4],[14,0,42,15],[30,0,42,30],[44,0,42,44],[48,0,42,49]],[[4,0,43,4],[12,0,43,16],[20,0,43,11],[21,0,43,25],[32,0,43,36],[44,0,43,11]],[[4,0,45,4],[21,0,45,22]],[[4,0,49,23],[10,0,49,8],[25,0,49,36]],[[4,0,50,4],[7,0,50,8],[22,0,50,8],[24,0,50,25],[31,0,50,33]],[[8,0,51,6],[21,0,51,6],[23,0,51,21],[30,0,51,29],[47,0,52,8],[61,0,53,8]],[],[[4,0,58,4],[17,0,58,18],[29,0,58,29]],[[4,0,59,27],[10,0,59,10],[27,0,59,27],[40,0,59,41],[51,0,59,51]],[[4,0,60,24],[10,0,60,10],[24,0,60,24],[31,0,60,32],[69,0,61,17],[87,0,62,6],[102,0,63,6]],[[4,0,67,4],[20,0,67,29],[33,0,67,29],[35,0,67,44],[47,0,67,29]],[],[],[[2,0,72,2],[18,0,72,9],[29,0,72,28],[52,0,72,20]],[[4,0,73,4],[12,0,73,11],[16,0,73,15],[22,0,73,22],[40,0,73,11],[43,0,73,42]],[],[],[],[],[],[],[],[],[]]
@@ -0,0 +1,61 @@
1
+ import "../types.scrypt.tpl";
2
+ import "@opcat-labs/scrypt-ts-opcat/assets/.templates/smart-contract/types/structs.scrypt.tpl";
3
+ import "../../utils/ownerUtils.scrypt.tpl";
4
+ import "@opcat-labs/scrypt-ts-opcat/assets/.templates/smart-contract/builtin-libs/txUtils.scrypt.tpl";
5
+ import "../cat20StateLib.scrypt.tpl";
6
+ import "@opcat-labs/scrypt-ts-opcat/assets/.templates/smart-contract/builtin-libs/stdUtils.scrypt.tpl";
7
+ import "@opcat-labs/scrypt-ts-opcat/assets/.templates/smart-contract/builtin-libs/backtrace.scrypt.tpl";
8
+ import "@opcat-labs/scrypt-ts-opcat/assets/.templates/smart-contract/builtin-libs/contextUtils.scrypt.tpl";
9
+ import "@opcat-labs/scrypt-ts-opcat/assets/.templates/smart-contract/builtin-libs/stateUtils.scrypt.tpl";
10
+
11
+
12
+ contract CAT20ClosedMinter {
13
+ bytes issuerAddress;
14
+ bytes genesisOutpoint;
15
+ constructor(bytes ownerAddress, bytes genesisOutpoint) {
16
+ this.issuerAddress = ownerAddress;
17
+ this.genesisOutpoint = genesisOutpoint;
18
+ }
19
+ public function mint(CAT20State tokenMint, PubKey issuerPubKey, Sig issuerSig, int minterSatoshis, int tokenSatoshis, BacktraceInfo backtraceInfo, SHPreimage __scrypt_ts_shPreimage, TxOut __scrypt_ts_changeInfo, CAT20ClosedMinterState __scrypt_ts_curState, bytes __scrypt_ts_prevouts, bytes __scrypt_ts_spentAmounts, bytes __scrypt_ts_spentDataHashes, bytes __scrypt_ts_spentScriptHashes, TxHashPreimage __scrypt_ts_prevTxHashPreimage) {
20
+ require(Tx.checkPreimageSigHashType(ContextUtils.serializeSHPreimage(__scrypt_ts_shPreimage), SigHash.ALL));
21
+
22
+ int __scrypt_ts_inputCount = ContextUtils.checkSpentAmounts(__scrypt_ts_spentAmounts, __scrypt_ts_shPreimage.hashSpentAmounts);
23
+
24
+ Outpoint __scrypt_ts_prevout = ContextUtils.checkPrevouts(__scrypt_ts_prevouts, __scrypt_ts_shPreimage.hashPrevouts, __scrypt_ts_shPreimage.inputIndex, __scrypt_ts_inputCount);
25
+
26
+ ContextUtils.checkSpentScripts(__scrypt_ts_spentScriptHashes, __scrypt_ts_shPreimage.hashSpentScriptHashes, __scrypt_ts_inputCount);
27
+
28
+ ContextUtils.checkSpentDataHashes(__scrypt_ts_spentDataHashes, __scrypt_ts_shPreimage.hashSpentDataHashes, __scrypt_ts_inputCount);
29
+
30
+ CAT20ClosedMinterState __scrypt_ts_nextState = __scrypt_ts_curState;
31
+
32
+ StateUtils.checkInputState(__scrypt_ts_shPreimage.inputIndex, CAT20ClosedMinter.stateHash(__scrypt_ts_curState), __scrypt_ts_spentDataHashes);
33
+
34
+ Backtrace.checkPrevTxHashPreimage(__scrypt_ts_prevTxHashPreimage, __scrypt_ts_prevouts, __scrypt_ts_shPreimage.inputIndex);
35
+
36
+ bytes minterScript = __scrypt_ts_shPreimage.spentScriptHash;
37
+ Backtrace.verifyFromOutpoint(backtraceInfo, this.genesisOutpoint, __scrypt_ts_spentScriptHashes[__scrypt_ts_shPreimage.inputIndex * 32 : (__scrypt_ts_shPreimage.inputIndex + 1) * 32], __scrypt_ts_prevTxHashPreimage.inputList);
38
+ OwnerUtils.checkUserOwner(issuerPubKey, this.issuerAddress);
39
+ require(checkSig(issuerSig, issuerPubKey));
40
+ CAT20ClosedMinter.checkState(__scrypt_ts_nextState);
41
+ bytes minterOutput = b'';
42
+ if(minterSatoshis > TxUtils.ZERO_SATS) {
43
+ minterOutput = TxUtils.buildDataOutput(minterScript, minterSatoshis, __scrypt_ts_shPreimage.spentDataHash);
44
+ }
45
+ CAT20StateLib.checkState(tokenMint);
46
+ bytes tokenStateHash = CAT20StateLib.stateHash(tokenMint);
47
+ bytes tokenOutput = TxUtils.buildDataOutput(__scrypt_ts_nextState.tokenScriptHash, tokenSatoshis, tokenStateHash);
48
+ require(hash256(minterOutput + tokenOutput +
49
+ (__scrypt_ts_changeInfo.satoshis > 0 ? TxUtils.buildOutput(__scrypt_ts_changeInfo.scriptHash, __scrypt_ts_changeInfo.satoshis) : b'')) == __scrypt_ts_shPreimage.hashOutputs);
50
+ }
51
+ static function checkState(CAT20ClosedMinterState _state) : bool {
52
+ require(len(_state.tokenScriptHash) == 32);
53
+ return true;
54
+ }
55
+ static function serializeState(CAT20ClosedMinterState __scrypt_ts_curState): bytes {
56
+ return num2bin(len(__scrypt_ts_curState.tag), 2) + __scrypt_ts_curState.tag + num2bin(len(__scrypt_ts_curState.tokenScriptHash), 2) + __scrypt_ts_curState.tokenScriptHash + hash160(hash160(__scrypt_ts_curState.tag) + hash160(__scrypt_ts_curState.tokenScriptHash));
57
+ }
58
+ static function stateHash(CAT20ClosedMinterState __scrypt_ts_curState): bytes {
59
+ return sha256(num2bin(len(__scrypt_ts_curState.tag), 2) + __scrypt_ts_curState.tag + num2bin(len(__scrypt_ts_curState.tokenScriptHash), 2) + __scrypt_ts_curState.tokenScriptHash + hash160(hash160(__scrypt_ts_curState.tag) + hash160(__scrypt_ts_curState.tokenScriptHash)));
60
+ }
61
+ }
@@ -0,0 +1,9 @@
1
+ {
2
+ "success": true,
3
+ "errors": [],
4
+ "scryptfile": "cat20/minters/cat20ClosedMinter.scrypt.tpl",
5
+ "sourceMapFile": "cat20/minters/cat20ClosedMinter.scrypt.map",
6
+ "ctxMethods": [
7
+ "mint"
8
+ ]
9
+ }
@@ -0,0 +1 @@
1
+ [[],[],[],[[8,0,5,13]],[],[],[],[],[],[],[]]
@@ -0,0 +1,11 @@
1
+ import "../types.scrypt.tpl";
2
+
3
+
4
+ library CAT20ClosedMinterMetadata {
5
+ static function serializeState(ClosedMinterCAT20Meta __scrypt_ts_curState): bytes {
6
+ return num2bin(len(__scrypt_ts_curState.tag), 2) + __scrypt_ts_curState.tag + num2bin(len(__scrypt_ts_curState.name), 2) + __scrypt_ts_curState.name + num2bin(len(__scrypt_ts_curState.symbol), 2) + __scrypt_ts_curState.symbol + num2bin(len(pack(__scrypt_ts_curState.decimals)), 2) + pack(__scrypt_ts_curState.decimals) + num2bin(len(__scrypt_ts_curState.minterMd5), 2) + __scrypt_ts_curState.minterMd5 + hash160(hash160(__scrypt_ts_curState.tag) + hash160(__scrypt_ts_curState.name) + hash160(__scrypt_ts_curState.symbol) + hash160(pack(__scrypt_ts_curState.decimals)) + hash160(__scrypt_ts_curState.minterMd5));
7
+ }
8
+ static function stateHash(ClosedMinterCAT20Meta __scrypt_ts_curState): bytes {
9
+ return sha256(num2bin(len(__scrypt_ts_curState.tag), 2) + __scrypt_ts_curState.tag + num2bin(len(__scrypt_ts_curState.name), 2) + __scrypt_ts_curState.name + num2bin(len(__scrypt_ts_curState.symbol), 2) + __scrypt_ts_curState.symbol + num2bin(len(pack(__scrypt_ts_curState.decimals)), 2) + pack(__scrypt_ts_curState.decimals) + num2bin(len(__scrypt_ts_curState.minterMd5), 2) + __scrypt_ts_curState.minterMd5 + hash160(hash160(__scrypt_ts_curState.tag) + hash160(__scrypt_ts_curState.name) + hash160(__scrypt_ts_curState.symbol) + hash160(pack(__scrypt_ts_curState.decimals)) + hash160(__scrypt_ts_curState.minterMd5)));
10
+ }
11
+ }
@@ -0,0 +1,7 @@
1
+ {
2
+ "success": true,
3
+ "errors": [],
4
+ "scryptfile": "cat20/minters/cat20ClosedMinterMetadata.scrypt.tpl",
5
+ "sourceMapFile": "cat20/minters/cat20ClosedMinterMetadata.scrypt.map",
6
+ "ctxMethods": []
7
+ }
@@ -0,0 +1 @@
1
+ [[],[],[],[],[],[],[],[],[],[],[],[],[],[],[[9,0,31,13]],[[2,0,33,19],[8,0,33,2]],[[2,0,37,12],[6,0,37,2]],[[2,0,41,11],[6,0,41,2]],[[2,0,44,16],[6,0,44,2]],[[2,0,47,9],[6,0,47,2]],[[2,0,50,16],[8,0,50,2]],[[2,0,52,2],[14,0,53,21],[20,0,53,4],[37,0,54,14],[41,0,54,4],[51,0,55,13],[55,0,55,4],[64,0,56,18],[68,0,56,4],[82,0,57,11],[86,0,57,4],[93,0,58,17],[99,0,58,4]],[[4,0,61,4],[8,0,61,9],[25,0,61,4],[27,0,61,27]],[[4,0,62,4],[8,0,62,9],[18,0,62,4],[20,0,62,20]],[[4,0,65,4],[8,0,65,9],[17,0,65,4],[19,0,65,19]],[[4,0,66,4],[8,0,66,9],[22,0,66,4],[24,0,66,24]],[[4,0,67,4],[8,0,67,9],[15,0,67,4],[17,0,67,17]],[[4,0,68,4],[8,0,68,9],[22,0,68,4],[24,0,68,24]],[],[[2,0,72,2],[18,0,72,9],[23,0,74,15],[34,0,74,4],[45,0,75,25],[48,0,75,25],[52,0,75,4],[73,0,77,20],[80,0,77,4],[96,0,78,17],[100,0,78,4],[113,0,80,20],[117,0,80,4],[133,0,82,19],[137,0,82,4],[152,0,84,19],[166,0,84,4],[181,0,85,14],[201,0,85,4]],[],[],[],[],[],[],[],[],[],[],[],[],[],[],[],[],[[33,0,88,29],[48,0,88,44],[52,0,88,49]],[[4,0,91,4],[7,0,91,8],[29,0,91,20]],[[8,0,92,6],[16,0,92,13],[24,0,92,22],[33,0,92,13],[36,0,92,33],[40,0,92,38]],[[8,0,93,6],[16,0,93,13],[24,0,93,22],[38,0,93,13],[41,0,93,38],[45,0,93,43]],[[8,0,94,6],[16,0,94,13],[24,0,94,22],[31,0,94,13],[34,0,94,31],[38,0,94,36]],[[8,0,96,6],[16,0,96,13],[20,0,96,18],[29,0,96,13],[32,0,96,29],[36,0,96,34],[50,0,96,29],[52,0,96,49],[56,0,96,54]],[[8,0,97,6],[16,0,97,13],[24,0,97,22],[29,0,97,13],[32,0,97,29],[36,0,97,34],[46,0,97,29],[48,0,97,45],[52,0,97,50]],[[8,0,99,27],[14,0,99,12],[29,0,99,27],[52,0,99,51],[63,0,99,61]],[[8,0,100,29],[14,0,100,12],[31,0,100,29],[50,0,100,49],[71,0,100,69],[84,0,100,83],[105,0,100,103],[118,0,100,117],[130,0,100,129]],[[8,0,101,6],[16,0,102,8],[29,0,102,8],[32,0,104,10],[47,0,105,10],[52,0,106,10],[55,0,106,10],[57,0,106,35]],[],[[4,0,114,24],[10,0,114,8],[26,0,114,37]],[[4,0,115,32],[8,0,115,8],[32,0,115,32]],[[15,0,116,13]],[[8,0,117,29],[12,0,117,12],[29,0,117,29],[49,0,117,49]],[[8,0,118,6],[11,0,118,10],[26,0,118,10],[28,0,118,27]],[[10,0,119,8],[32,0,119,8],[35,0,119,33]],[[10,0,120,8],[24,0,120,8],[27,0,120,25],[34,0,120,33],[91,0,122,10],[107,0,123,10],[114,0,123,17],[129,0,123,33],[145,0,123,48],[146,0,124,17],[158,0,124,30],[198,0,125,40],[216,0,126,29]],[],[],[[4,0,134,27],[11,0,134,10],[28,0,134,27],[35,0,134,34],[48,0,134,48],[64,0,134,63]],[[4,0,135,24],[10,0,135,10],[24,0,135,24],[31,0,135,32],[69,0,136,17],[87,0,137,6],[102,0,138,6]],[[4,0,140,4],[7,0,140,8],[29,0,140,20],[46,0,140,8],[49,0,140,39],[53,0,140,44],[62,0,140,39],[64,0,140,54]],[[8,0,142,6],[16,0,142,13],[20,0,142,18],[30,0,142,13],[54,0,142,41],[70,0,142,30],[72,0,142,58],[76,0,142,63]],[[8,0,144,6],[18,0,144,17],[34,0,144,32],[50,0,144,48],[54,0,144,53]],[[8,0,145,6],[16,0,145,18],[24,0,145,13],[25,0,145,27],[38,0,145,40],[52,0,145,13]],[[8,0,147,6],[16,0,147,13],[38,0,147,13],[62,0,147,49]],[[8,0,148,6],[16,0,148,13],[25,0,148,23],[33,0,148,13],[36,0,148,33],[40,0,148,38]],[],[[8,0,151,6],[11,0,151,10],[33,0,151,22]],[[10,0,153,8],[18,0,153,15],[22,0,153,20],[32,0,153,15],[56,0,153,43]],[[10,0,154,8],[18,0,154,15],[22,0,154,20],[36,0,154,15],[39,0,154,36]],[[10,0,155,8],[18,0,155,15],[22,0,155,20],[31,0,155,15],[34,0,155,31]],[],[[8,0,157,6],[16,0,157,13],[38,0,157,13],[62,0,157,49],[78,0,157,38],[80,0,157,66]],[[8,0,158,6],[16,0,158,13],[25,0,158,23],[33,0,158,13],[36,0,158,33],[40,0,158,38]],[],[[4,0,162,25],[10,0,162,10]],[],[[4,0,165,4],[20,0,165,29],[34,0,165,29],[36,0,165,45],[48,0,165,29],[50,0,165,59]],[],[],[],[],[],[],[],[]]
@@ -0,0 +1,94 @@
1
+ import "../types.scrypt.tpl";
2
+ import "@opcat-labs/scrypt-ts-opcat/assets/.templates/smart-contract/types/structs.scrypt.tpl";
3
+ import "./cat20OpenMinterMetadata.scrypt.tpl";
4
+ import "@opcat-labs/scrypt-ts-opcat/assets/.templates/smart-contract/builtin-libs/txHashPreimageUtils.scrypt.tpl";
5
+ import "@opcat-labs/scrypt-ts-opcat/assets/.templates/smart-contract/builtin-libs/txUtils.scrypt.tpl";
6
+ import "../../constants.scrypt.tpl";
7
+ import "../cat20StateLib.scrypt.tpl";
8
+ import "../../utils/ownerUtils.scrypt.tpl";
9
+ import "@opcat-labs/scrypt-ts-opcat/assets/.templates/smart-contract/builtin-libs/stdUtils.scrypt.tpl";
10
+ import "@opcat-labs/scrypt-ts-opcat/assets/.templates/smart-contract/builtin-libs/backtrace.scrypt.tpl";
11
+ import "@opcat-labs/scrypt-ts-opcat/assets/.templates/smart-contract/builtin-libs/contextUtils.scrypt.tpl";
12
+ import "@opcat-labs/scrypt-ts-opcat/assets/.templates/smart-contract/builtin-libs/stateUtils.scrypt.tpl";
13
+
14
+
15
+ contract CAT20OpenMinter {
16
+ bytes genesisOutpoint;
17
+ int maxCount;
18
+ int premine;
19
+ int premineCount;
20
+ int limit;
21
+ bytes preminerAddr;
22
+ constructor(bytes genesisOutpoint, int maxCount, int premine, int premineCount, int limit, bytes premineAddr) {
23
+ this.genesisOutpoint = genesisOutpoint;
24
+ this.maxCount = maxCount;
25
+ this.premine = premine;
26
+ this.premineCount = premineCount;
27
+ this.limit = limit;
28
+ this.preminerAddr = premineAddr;
29
+ }
30
+ public function mint(CAT20State tokenMint, int[2] nextRemainingCounts, PubKey preminerPubKey, Sig preminerSig, int minterSatoshis, int tokenSatoshis, BacktraceInfo backtraceInfo, OpenMinterCAT20Meta metadata, SHPreimage __scrypt_ts_shPreimage, TxOut __scrypt_ts_changeInfo, CAT20OpenMinterState __scrypt_ts_curState, bytes __scrypt_ts_prevouts, bytes __scrypt_ts_spentAmounts, bytes __scrypt_ts_spentDataHashes, bytes __scrypt_ts_spentScriptHashes, TxHashPreimage __scrypt_ts_prevTxHashPreimage) {
31
+ require(Tx.checkPreimageSigHashType(ContextUtils.serializeSHPreimage(__scrypt_ts_shPreimage), SigHash.ALL));
32
+
33
+ int __scrypt_ts_inputCount = ContextUtils.checkSpentAmounts(__scrypt_ts_spentAmounts, __scrypt_ts_shPreimage.hashSpentAmounts);
34
+
35
+ Outpoint __scrypt_ts_prevout = ContextUtils.checkPrevouts(__scrypt_ts_prevouts, __scrypt_ts_shPreimage.hashPrevouts, __scrypt_ts_shPreimage.inputIndex, __scrypt_ts_inputCount);
36
+
37
+ ContextUtils.checkSpentScripts(__scrypt_ts_spentScriptHashes, __scrypt_ts_shPreimage.hashSpentScriptHashes, __scrypt_ts_inputCount);
38
+
39
+ ContextUtils.checkSpentDataHashes(__scrypt_ts_spentDataHashes, __scrypt_ts_shPreimage.hashSpentDataHashes, __scrypt_ts_inputCount);
40
+
41
+ CAT20OpenMinterState __scrypt_ts_nextState = __scrypt_ts_curState;
42
+
43
+ StateUtils.checkInputState(__scrypt_ts_shPreimage.inputIndex, CAT20OpenMinter.stateHash(__scrypt_ts_curState), __scrypt_ts_spentDataHashes);
44
+
45
+ Backtrace.checkPrevTxHashPreimage(__scrypt_ts_prevTxHashPreimage, __scrypt_ts_prevouts, __scrypt_ts_shPreimage.inputIndex);
46
+
47
+ Backtrace.verifyFromOutpoint(backtraceInfo, this.genesisOutpoint, __scrypt_ts_spentScriptHashes[__scrypt_ts_shPreimage.inputIndex * 32 : (__scrypt_ts_shPreimage.inputIndex + 1) * 32], __scrypt_ts_prevTxHashPreimage.inputList);
48
+ if(!__scrypt_ts_nextState.hasMintedBefore) {
49
+ require(metadata.premine == this.premine);
50
+ require(metadata.preminerAddr == this.preminerAddr);
51
+ require(metadata.limit == this.limit);
52
+ require(this.premine == this.premineCount * this.limit);
53
+ require(metadata.max == this.maxCount * this.limit);
54
+ bytes metadataHash = CAT20OpenMinterMetadata.stateHash(metadata);
55
+ bytes metadataOutput = TxHashPreimageUtils.getOutputByteString(backtraceInfo.prevPrevTxPreimage, backtraceInfo.prevTxInput.prevOutputIndex);
56
+ require(metadataHash == metadataOutput[40 : 40 + 32]);
57
+ }
58
+ bytes minterOutputs = b'';
59
+ int sumNextRemainingCount = 0;
60
+ loop (2) : i {
61
+ int remainingCount = nextRemainingCounts[i];
62
+ if(remainingCount > 0) {
63
+ sumNextRemainingCount += remainingCount;
64
+ minterOutputs += TxUtils.buildDataOutput(__scrypt_ts_shPreimage.spentScriptHash, minterSatoshis, sha256(CAT20OpenMinter.serializeState({ConstantsLib.OPCAT_MINTER_TAG, __scrypt_ts_nextState.tokenScriptHash, true, remainingCount})));
65
+ }
66
+ }
67
+ Sha256 tokenStateHash = sha256(CAT20StateLib.serializeState(tokenMint));
68
+ bytes tokenOutput = TxUtils.buildDataOutput(__scrypt_ts_nextState.tokenScriptHash, tokenSatoshis, tokenStateHash);
69
+ if(!__scrypt_ts_nextState.hasMintedBefore && this.premine > 0) {
70
+ require(this.maxCount == __scrypt_ts_nextState.remainingCount + this.premineCount);
71
+ OwnerUtils.checkUserOwner(preminerPubKey, this.preminerAddr);
72
+ require(checkSig(preminerSig, preminerPubKey));
73
+ require(sumNextRemainingCount == __scrypt_ts_nextState.remainingCount);
74
+ require(tokenMint.amount == this.premine);
75
+ } else {
76
+ if(!__scrypt_ts_nextState.hasMintedBefore) {
77
+ require(this.maxCount == __scrypt_ts_nextState.remainingCount);
78
+ require(this.premineCount == 0);
79
+ require(this.premine == 0);
80
+ }
81
+ require(sumNextRemainingCount == __scrypt_ts_nextState.remainingCount - 1);
82
+ require(tokenMint.amount == this.limit);
83
+ }
84
+ bytes changeOutput =
85
+ (__scrypt_ts_changeInfo.satoshis > 0 ? TxUtils.buildOutput(__scrypt_ts_changeInfo.scriptHash, __scrypt_ts_changeInfo.satoshis) : b'');
86
+ require(hash256(minterOutputs + tokenOutput + changeOutput) == __scrypt_ts_shPreimage.hashOutputs);
87
+ }
88
+ static function serializeState(CAT20OpenMinterState __scrypt_ts_curState): bytes {
89
+ return num2bin(len(__scrypt_ts_curState.tag), 2) + __scrypt_ts_curState.tag + num2bin(len(__scrypt_ts_curState.tokenScriptHash), 2) + __scrypt_ts_curState.tokenScriptHash + num2bin(len((__scrypt_ts_curState.hasMintedBefore ? b'01' : b'')), 2) + (__scrypt_ts_curState.hasMintedBefore ? b'01' : b'') + num2bin(len(pack(__scrypt_ts_curState.remainingCount)), 2) + pack(__scrypt_ts_curState.remainingCount) + hash160(hash160(__scrypt_ts_curState.tag) + hash160(__scrypt_ts_curState.tokenScriptHash) + hash160(__scrypt_ts_curState.hasMintedBefore ? b'01' : b'') + hash160(pack(__scrypt_ts_curState.remainingCount)));
90
+ }
91
+ static function stateHash(CAT20OpenMinterState __scrypt_ts_curState): bytes {
92
+ return sha256(num2bin(len(__scrypt_ts_curState.tag), 2) + __scrypt_ts_curState.tag + num2bin(len(__scrypt_ts_curState.tokenScriptHash), 2) + __scrypt_ts_curState.tokenScriptHash + num2bin(len((__scrypt_ts_curState.hasMintedBefore ? b'01' : b'')), 2) + (__scrypt_ts_curState.hasMintedBefore ? b'01' : b'') + num2bin(len(pack(__scrypt_ts_curState.remainingCount)), 2) + pack(__scrypt_ts_curState.remainingCount) + hash160(hash160(__scrypt_ts_curState.tag) + hash160(__scrypt_ts_curState.tokenScriptHash) + hash160(__scrypt_ts_curState.hasMintedBefore ? b'01' : b'') + hash160(pack(__scrypt_ts_curState.remainingCount))));
93
+ }
94
+ }
@@ -0,0 +1,9 @@
1
+ {
2
+ "success": true,
3
+ "errors": [],
4
+ "scryptfile": "cat20/minters/cat20OpenMinter.scrypt.tpl",
5
+ "sourceMapFile": "cat20/minters/cat20OpenMinter.scrypt.map",
6
+ "ctxMethods": [
7
+ "mint"
8
+ ]
9
+ }
@@ -0,0 +1 @@
1
+ [[],[],[],[[8,0,5,13]],[],[],[],[],[],[],[]]
@@ -0,0 +1,11 @@
1
+ import "../types.scrypt.tpl";
2
+
3
+
4
+ library CAT20OpenMinterMetadata {
5
+ static function serializeState(OpenMinterCAT20Meta __scrypt_ts_curState): bytes {
6
+ return num2bin(len(__scrypt_ts_curState.tag), 2) + __scrypt_ts_curState.tag + num2bin(len(__scrypt_ts_curState.name), 2) + __scrypt_ts_curState.name + num2bin(len(__scrypt_ts_curState.symbol), 2) + __scrypt_ts_curState.symbol + num2bin(len(pack(__scrypt_ts_curState.decimals)), 2) + pack(__scrypt_ts_curState.decimals) + num2bin(len(__scrypt_ts_curState.minterMd5), 2) + __scrypt_ts_curState.minterMd5 + num2bin(len(pack(__scrypt_ts_curState.max)), 2) + pack(__scrypt_ts_curState.max) + num2bin(len(pack(__scrypt_ts_curState.limit)), 2) + pack(__scrypt_ts_curState.limit) + num2bin(len(pack(__scrypt_ts_curState.premine)), 2) + pack(__scrypt_ts_curState.premine) + num2bin(len(__scrypt_ts_curState.preminerAddr), 2) + __scrypt_ts_curState.preminerAddr + hash160(hash160(__scrypt_ts_curState.tag) + hash160(__scrypt_ts_curState.name) + hash160(__scrypt_ts_curState.symbol) + hash160(pack(__scrypt_ts_curState.decimals)) + hash160(__scrypt_ts_curState.minterMd5) + hash160(pack(__scrypt_ts_curState.max)) + hash160(pack(__scrypt_ts_curState.limit)) + hash160(pack(__scrypt_ts_curState.premine)) + hash160(__scrypt_ts_curState.preminerAddr));
7
+ }
8
+ static function stateHash(OpenMinterCAT20Meta __scrypt_ts_curState): bytes {
9
+ return sha256(num2bin(len(__scrypt_ts_curState.tag), 2) + __scrypt_ts_curState.tag + num2bin(len(__scrypt_ts_curState.name), 2) + __scrypt_ts_curState.name + num2bin(len(__scrypt_ts_curState.symbol), 2) + __scrypt_ts_curState.symbol + num2bin(len(pack(__scrypt_ts_curState.decimals)), 2) + pack(__scrypt_ts_curState.decimals) + num2bin(len(__scrypt_ts_curState.minterMd5), 2) + __scrypt_ts_curState.minterMd5 + num2bin(len(pack(__scrypt_ts_curState.max)), 2) + pack(__scrypt_ts_curState.max) + num2bin(len(pack(__scrypt_ts_curState.limit)), 2) + pack(__scrypt_ts_curState.limit) + num2bin(len(pack(__scrypt_ts_curState.premine)), 2) + pack(__scrypt_ts_curState.premine) + num2bin(len(__scrypt_ts_curState.preminerAddr), 2) + __scrypt_ts_curState.preminerAddr + hash160(hash160(__scrypt_ts_curState.tag) + hash160(__scrypt_ts_curState.name) + hash160(__scrypt_ts_curState.symbol) + hash160(pack(__scrypt_ts_curState.decimals)) + hash160(__scrypt_ts_curState.minterMd5) + hash160(pack(__scrypt_ts_curState.max)) + hash160(pack(__scrypt_ts_curState.limit)) + hash160(pack(__scrypt_ts_curState.premine)) + hash160(__scrypt_ts_curState.preminerAddr)));
10
+ }
11
+ }
@@ -0,0 +1,7 @@
1
+ {
2
+ "success": true,
3
+ "errors": [],
4
+ "scryptfile": "cat20/minters/cat20OpenMinterMetadata.scrypt.tpl",
5
+ "sourceMapFile": "cat20/minters/cat20OpenMinterMetadata.scrypt.map",
6
+ "ctxMethods": []
7
+ }
@@ -0,0 +1 @@
1
+ [[],[[7,0,30,35]],[[2,0,36,21],[7,0,36,21],[11,0,36,2]],[[2,0,42,16],[5,0,42,16],[9,0,42,2]],[[2,0,47,20],[5,0,47,20],[9,0,47,2]],[[2,0,62,22],[5,0,62,22],[9,0,62,2]],[],[],[[7,0,8,25]],[[2,0,9,7],[8,0,9,2]],[[2,0,11,13],[8,0,11,2]],[[2,0,13,10],[6,0,13,2]],[],[],[[7,0,120,0]],[[2,0,121,7],[8,0,121,2]],[[2,0,124,19],[8,0,124,2]],[],[],[[7,0,81,0]],[[2,0,82,7],[8,0,82,2]],[[2,0,83,8],[8,0,83,2]],[[2,0,84,10],[8,0,84,2]],[[2,0,85,12],[6,0,85,2]],[[2,0,86,13],[8,0,86,2]],[],[],[[7,0,89,0]],[[2,0,90,7],[8,0,90,2]],[[2,0,92,8],[8,0,92,2]],[[2,0,94,10],[8,0,94,2]],[[2,0,96,12],[6,0,96,2]],[[2,0,98,13],[8,0,98,2]],[[2,0,101,7],[6,0,101,2]],[[2,0,103,9],[6,0,103,2]],[[2,0,105,11],[6,0,105,2]],[[2,0,107,16],[8,0,107,2]],[],[],[[7,0,110,0]],[[2,0,111,7],[8,0,111,2]],[[2,0,113,19],[8,0,113,2]],[[2,0,115,19],[7,0,115,2]],[[2,0,117,18],[6,0,117,2]],[]]