@aptos-labs/ts-sdk 1.13.3 → 1.14.0-zeta.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 (601) hide show
  1. package/dist/common/accountAddress-u9wEan9p.d.ts +2149 -0
  2. package/dist/common/chunk-QRI7EC4T.js +24 -0
  3. package/dist/common/chunk-QRI7EC4T.js.map +1 -0
  4. package/dist/common/cli/index.d.ts +94 -1
  5. package/dist/common/cli/index.js +245 -1
  6. package/dist/common/cli/index.js.map +1 -1
  7. package/dist/common/index.d.ts +2699 -4119
  8. package/dist/common/index.js +11786 -374
  9. package/dist/common/index.js.map +1 -1
  10. package/dist/esm/{Ed25519Account--qjfup2u.d.mts → Ed25519Account-9zBaZEnp.d.mts} +76 -9
  11. package/dist/esm/account/Account.d.mts +34 -0
  12. package/dist/esm/account/Account.mjs +56 -0
  13. package/dist/esm/account/Ed25519Account.d.mts +34 -0
  14. package/dist/esm/account/Ed25519Account.mjs +54 -0
  15. package/dist/esm/account/EphemeralKeyPair.d.mts +80 -0
  16. package/dist/esm/account/EphemeralKeyPair.mjs +37 -0
  17. package/dist/esm/account/KeylessAccount.d.mts +145 -0
  18. package/dist/esm/account/KeylessAccount.mjs +57 -0
  19. package/dist/esm/account/MultiKeyAccount.d.mts +138 -0
  20. package/dist/esm/account/MultiKeyAccount.mjs +56 -0
  21. package/dist/esm/account/SingleKeyAccount.d.mts +34 -0
  22. package/dist/esm/account/SingleKeyAccount.mjs +54 -0
  23. package/dist/esm/account/index.d.mts +41 -0
  24. package/dist/esm/account/index.mjs +77 -0
  25. package/dist/esm/api/account.d.mts +13 -1
  26. package/dist/esm/api/account.mjs +76 -1
  27. package/dist/esm/api/ans.d.mts +2 -2
  28. package/dist/esm/api/ans.mjs +87 -1
  29. package/dist/esm/api/aptos.d.mts +15 -8
  30. package/dist/esm/api/aptos.mjs +116 -1
  31. package/dist/esm/api/aptosConfig.d.mts +20 -0
  32. package/dist/esm/api/aptosConfig.mjs +9 -1
  33. package/dist/esm/api/coin.d.mts +7 -7
  34. package/dist/esm/api/coin.mjs +86 -1
  35. package/dist/esm/api/digitalAsset.d.mts +1 -1
  36. package/dist/esm/api/digitalAsset.mjs +87 -1
  37. package/dist/esm/api/event.mjs +54 -1
  38. package/dist/esm/api/faucet.mjs +53 -1
  39. package/dist/esm/api/fungibleAsset.d.mts +5 -5
  40. package/dist/esm/api/fungibleAsset.mjs +87 -1
  41. package/dist/esm/api/general.d.mts +7 -7
  42. package/dist/esm/api/general.mjs +84 -1
  43. package/dist/esm/api/index.d.mts +14 -8
  44. package/dist/esm/api/index.mjs +120 -1
  45. package/dist/esm/api/keyless.d.mts +81 -0
  46. package/dist/esm/api/keyless.mjs +71 -0
  47. package/dist/esm/api/staking.mjs +54 -1
  48. package/dist/esm/api/transaction.d.mts +1 -1
  49. package/dist/esm/api/transaction.mjs +94 -1
  50. package/dist/esm/api/transactionSubmission/build.d.mts +2 -2
  51. package/dist/esm/api/transactionSubmission/build.mjs +85 -1
  52. package/dist/esm/api/transactionSubmission/helpers.mjs +9 -1
  53. package/dist/esm/api/transactionSubmission/management.d.mts +8 -8
  54. package/dist/esm/api/transactionSubmission/management.mjs +89 -1
  55. package/dist/esm/api/transactionSubmission/sign.d.mts +1 -1
  56. package/dist/esm/api/transactionSubmission/sign.mjs +109 -1
  57. package/dist/esm/api/transactionSubmission/sign.mjs.map +1 -1
  58. package/dist/esm/api/transactionSubmission/simulate.d.mts +6 -6
  59. package/dist/esm/api/transactionSubmission/simulate.mjs +86 -1
  60. package/dist/esm/api/transactionSubmission/submit.mjs +86 -1
  61. package/dist/esm/api/utils.mjs +34 -1
  62. package/dist/esm/bcs/consts.mjs +17 -1
  63. package/dist/esm/bcs/deserializer.d.mts +26 -0
  64. package/dist/esm/bcs/deserializer.mjs +8 -1
  65. package/dist/esm/bcs/index.mjs +57 -1
  66. package/dist/esm/bcs/serializable/entryFunctionBytes.mjs +12 -1
  67. package/dist/esm/bcs/serializable/fixedBytes.mjs +11 -1
  68. package/dist/esm/bcs/serializable/movePrimitives.mjs +25 -1
  69. package/dist/esm/bcs/serializable/moveStructs.mjs +18 -1
  70. package/dist/esm/bcs/serializer.d.mts +2 -0
  71. package/dist/esm/bcs/serializer.mjs +18 -1
  72. package/dist/esm/chunk-2JOCR2VL.mjs +32 -0
  73. package/dist/esm/chunk-2JOCR2VL.mjs.map +1 -0
  74. package/dist/esm/chunk-2OQW7BMN.mjs +129 -0
  75. package/dist/esm/{chunk-PZGLV5UQ.mjs.map → chunk-2OQW7BMN.mjs.map} +1 -1
  76. package/dist/esm/chunk-2TJJWII2.mjs +23 -0
  77. package/dist/esm/{chunk-DSTKXJMA.mjs.map → chunk-2TJJWII2.mjs.map} +1 -1
  78. package/dist/esm/chunk-2ZEGJU43.mjs +252 -0
  79. package/dist/esm/chunk-2ZEGJU43.mjs.map +1 -0
  80. package/dist/esm/chunk-4OYYOYSO.mjs +336 -0
  81. package/dist/esm/chunk-4OYYOYSO.mjs.map +1 -0
  82. package/dist/esm/{chunk-S4SEFF4K.mjs → chunk-4PJ5FYGQ.mjs} +302 -27
  83. package/dist/esm/{chunk-S4SEFF4K.mjs.map → chunk-4PJ5FYGQ.mjs.map} +1 -1
  84. package/dist/esm/chunk-55NODGHC.mjs +135 -0
  85. package/dist/esm/chunk-55NODGHC.mjs.map +1 -0
  86. package/dist/esm/chunk-6LRQSBRH.mjs +130 -0
  87. package/dist/esm/chunk-6LRQSBRH.mjs.map +1 -0
  88. package/dist/esm/chunk-6MSZMIFW.mjs +23 -0
  89. package/dist/esm/{chunk-BWFJHFBQ.mjs.map → chunk-6MSZMIFW.mjs.map} +1 -1
  90. package/dist/esm/chunk-76TSTAU4.mjs +120 -0
  91. package/dist/esm/chunk-76TSTAU4.mjs.map +1 -0
  92. package/dist/esm/chunk-7FO3S6IZ.mjs +324 -0
  93. package/dist/esm/{chunk-DMKUAQB7.mjs.map → chunk-7FO3S6IZ.mjs.map} +1 -1
  94. package/dist/esm/chunk-7FUHWL6A.mjs +42 -0
  95. package/dist/esm/{chunk-V3Q2KXJU.mjs.map → chunk-7FUHWL6A.mjs.map} +1 -1
  96. package/dist/esm/chunk-7IDBB4J4.mjs +33 -0
  97. package/dist/esm/{chunk-ZZZZVONX.mjs.map → chunk-7IDBB4J4.mjs.map} +1 -1
  98. package/dist/esm/chunk-7JRMOHBP.mjs +247 -0
  99. package/dist/esm/chunk-7JRMOHBP.mjs.map +1 -0
  100. package/dist/esm/chunk-7REUIYF4.mjs +63 -0
  101. package/dist/esm/chunk-7REUIYF4.mjs.map +1 -0
  102. package/dist/esm/chunk-7Z6DYLCA.mjs +1 -0
  103. package/dist/esm/chunk-7Z6DYLCA.mjs.map +1 -0
  104. package/dist/esm/chunk-AC3OGAL6.mjs +87 -0
  105. package/dist/esm/{chunk-U6Z4FNB7.mjs.map → chunk-AC3OGAL6.mjs.map} +1 -1
  106. package/dist/esm/chunk-AQ4I7VVB.mjs +1 -0
  107. package/dist/esm/chunk-AQ4I7VVB.mjs.map +1 -0
  108. package/dist/esm/chunk-AR7X6GWQ.mjs +356 -0
  109. package/dist/esm/{chunk-FS3NSGBF.mjs.map → chunk-AR7X6GWQ.mjs.map} +1 -1
  110. package/dist/esm/chunk-ASF2VWOX.mjs +142 -0
  111. package/dist/esm/{chunk-G2O323HP.mjs.map → chunk-ASF2VWOX.mjs.map} +1 -1
  112. package/dist/esm/chunk-ATVFVXR6.mjs +43 -0
  113. package/dist/esm/{chunk-VVIG4E7Q.mjs.map → chunk-ATVFVXR6.mjs.map} +1 -1
  114. package/dist/esm/chunk-B5S6DDUD.mjs +120 -0
  115. package/dist/esm/chunk-B5S6DDUD.mjs.map +1 -0
  116. package/dist/esm/chunk-BXMHDQHW.mjs +512 -0
  117. package/dist/esm/chunk-BXMHDQHW.mjs.map +1 -0
  118. package/dist/esm/chunk-CC4DQ6NH.mjs +19 -0
  119. package/dist/esm/{chunk-MACC2BLE.mjs.map → chunk-CC4DQ6NH.mjs.map} +1 -1
  120. package/dist/esm/chunk-CMNJG4NN.mjs +345 -0
  121. package/dist/esm/{chunk-IOSQVDZI.mjs.map → chunk-CMNJG4NN.mjs.map} +1 -1
  122. package/dist/esm/chunk-CTJSZT5V.mjs +87 -0
  123. package/dist/esm/{chunk-UFT7US42.mjs.map → chunk-CTJSZT5V.mjs.map} +1 -1
  124. package/dist/esm/chunk-CX3NAVRD.mjs +205 -0
  125. package/dist/esm/chunk-CX3NAVRD.mjs.map +1 -0
  126. package/dist/esm/chunk-CXUGZXED.mjs +307 -0
  127. package/dist/esm/{chunk-YU3KB3UV.mjs.map → chunk-CXUGZXED.mjs.map} +1 -1
  128. package/dist/esm/chunk-D2BVBXWO.mjs +7 -0
  129. package/dist/esm/{chunk-B7TQGVGL.mjs.map → chunk-D2BVBXWO.mjs.map} +1 -1
  130. package/dist/esm/chunk-DGV7DYU4.mjs +413 -0
  131. package/dist/esm/chunk-DGV7DYU4.mjs.map +1 -0
  132. package/dist/esm/chunk-DIYZRGR6.mjs +242 -0
  133. package/dist/esm/{chunk-O4JRPZZM.mjs.map → chunk-DIYZRGR6.mjs.map} +1 -1
  134. package/dist/esm/chunk-DNPMS2OF.mjs +236 -0
  135. package/dist/esm/{chunk-U43IJHQN.mjs.map → chunk-DNPMS2OF.mjs.map} +1 -1
  136. package/dist/esm/chunk-DVPQGCFT.mjs +74 -0
  137. package/dist/esm/{chunk-O2F53NKI.mjs.map → chunk-DVPQGCFT.mjs.map} +1 -1
  138. package/dist/esm/chunk-EYHRMZPO.mjs +34 -0
  139. package/dist/esm/{chunk-AH44UPM4.mjs.map → chunk-EYHRMZPO.mjs.map} +1 -1
  140. package/dist/esm/chunk-F2ZWA7B7.mjs +412 -0
  141. package/dist/esm/chunk-F2ZWA7B7.mjs.map +1 -0
  142. package/dist/esm/chunk-FDWJNY4U.mjs +22 -0
  143. package/dist/esm/{chunk-R5QUBEH6.mjs.map → chunk-FDWJNY4U.mjs.map} +1 -1
  144. package/dist/esm/chunk-FF4JPDKD.mjs +315 -0
  145. package/dist/esm/chunk-FF4JPDKD.mjs.map +1 -0
  146. package/dist/esm/chunk-FQQW55X7.mjs +288 -0
  147. package/dist/esm/{chunk-52C73T26.mjs.map → chunk-FQQW55X7.mjs.map} +1 -1
  148. package/dist/esm/chunk-FXKSE3ZP.mjs +25 -0
  149. package/dist/esm/{chunk-WFZDFFBM.mjs.map → chunk-FXKSE3ZP.mjs.map} +1 -1
  150. package/dist/esm/chunk-GBEVD2VM.mjs +99 -0
  151. package/dist/esm/chunk-GBEVD2VM.mjs.map +1 -0
  152. package/dist/esm/chunk-GGMTQAQP.mjs +11 -0
  153. package/dist/esm/{chunk-3JPVQHOR.mjs.map → chunk-GGMTQAQP.mjs.map} +1 -1
  154. package/dist/esm/chunk-GSVQ6EUD.mjs +649 -0
  155. package/dist/esm/chunk-GSVQ6EUD.mjs.map +1 -0
  156. package/dist/esm/chunk-HBNSRCZN.mjs +100 -0
  157. package/dist/esm/{chunk-SG4MAOCF.mjs.map → chunk-HBNSRCZN.mjs.map} +1 -1
  158. package/dist/esm/chunk-IC56GQFJ.mjs +127 -0
  159. package/dist/esm/chunk-IC56GQFJ.mjs.map +1 -0
  160. package/dist/esm/chunk-IHNPN5CQ.mjs +256 -0
  161. package/dist/esm/chunk-IHNPN5CQ.mjs.map +1 -0
  162. package/dist/esm/chunk-JHDHNGJ3.mjs +126 -0
  163. package/dist/esm/chunk-JHDHNGJ3.mjs.map +1 -0
  164. package/dist/esm/chunk-JL2JHVS4.mjs +49 -0
  165. package/dist/esm/{chunk-RHBCVCOS.mjs.map → chunk-JL2JHVS4.mjs.map} +1 -1
  166. package/dist/esm/chunk-JV3GSIJW.mjs +268 -0
  167. package/dist/esm/chunk-JV3GSIJW.mjs.map +1 -0
  168. package/dist/esm/chunk-JXCZTOYC.mjs +1 -0
  169. package/dist/esm/chunk-JXCZTOYC.mjs.map +1 -0
  170. package/dist/esm/chunk-KK2BSALW.mjs +32 -0
  171. package/dist/esm/{chunk-TBMAJ6AW.mjs.map → chunk-KK2BSALW.mjs.map} +1 -1
  172. package/dist/esm/chunk-KMXSRHJ6.mjs +93 -0
  173. package/dist/esm/chunk-KMXSRHJ6.mjs.map +1 -0
  174. package/dist/esm/chunk-KVSQ57HU.mjs +45 -0
  175. package/dist/esm/{chunk-NNQJBFRB.mjs.map → chunk-KVSQ57HU.mjs.map} +1 -1
  176. package/dist/esm/chunk-LI2QV6RU.mjs +129 -0
  177. package/dist/esm/chunk-LI2QV6RU.mjs.map +1 -0
  178. package/dist/esm/chunk-LLLQJWRZ.mjs +35 -0
  179. package/dist/esm/{chunk-DPV25ZKR.mjs.map → chunk-LLLQJWRZ.mjs.map} +1 -1
  180. package/dist/esm/chunk-LYK4TQZO.mjs +70 -0
  181. package/dist/esm/chunk-LYK4TQZO.mjs.map +1 -0
  182. package/dist/esm/chunk-LYMY63SO.mjs +124 -0
  183. package/dist/esm/{chunk-W4ZW7QHA.mjs.map → chunk-LYMY63SO.mjs.map} +1 -1
  184. package/dist/esm/chunk-MZZLEY6O.mjs +92 -0
  185. package/dist/esm/chunk-MZZLEY6O.mjs.map +1 -0
  186. package/dist/esm/chunk-N4WKFNQ6.mjs +156 -0
  187. package/dist/esm/chunk-N4WKFNQ6.mjs.map +1 -0
  188. package/dist/esm/chunk-NFJCQRVK.mjs +37 -0
  189. package/dist/esm/chunk-NFJCQRVK.mjs.map +1 -0
  190. package/dist/esm/chunk-NMKCJNQM.mjs +20 -0
  191. package/dist/esm/{chunk-TJDC5PWD.mjs.map → chunk-NMKCJNQM.mjs.map} +1 -1
  192. package/dist/esm/chunk-NW45SCPY.mjs +36 -0
  193. package/dist/esm/{chunk-GSD4OOM3.mjs.map → chunk-NW45SCPY.mjs.map} +1 -1
  194. package/dist/esm/chunk-NXFO2W4G.mjs +84 -0
  195. package/dist/esm/{chunk-QMURTXFM.mjs.map → chunk-NXFO2W4G.mjs.map} +1 -1
  196. package/dist/esm/chunk-NYL77J4X.mjs +97 -0
  197. package/dist/esm/chunk-NYL77J4X.mjs.map +1 -0
  198. package/dist/esm/chunk-O6PSHSN3.mjs +53 -0
  199. package/dist/esm/{chunk-MFKMAAWA.mjs.map → chunk-O6PSHSN3.mjs.map} +1 -1
  200. package/dist/esm/chunk-OR7TEZ25.mjs +16 -0
  201. package/dist/esm/chunk-OR7TEZ25.mjs.map +1 -0
  202. package/dist/esm/chunk-PCLNX6FS.mjs +17 -0
  203. package/dist/esm/{chunk-6FBKUTGF.mjs.map → chunk-PCLNX6FS.mjs.map} +1 -1
  204. package/dist/esm/chunk-PIMQHG2J.mjs +49 -0
  205. package/dist/esm/{chunk-ZYYK3UXP.mjs.map → chunk-PIMQHG2J.mjs.map} +1 -1
  206. package/dist/esm/chunk-PU5AFUX3.mjs +52 -0
  207. package/dist/esm/{chunk-LR65XHSF.mjs.map → chunk-PU5AFUX3.mjs.map} +1 -1
  208. package/dist/esm/chunk-PYLOAMR2.mjs +29 -0
  209. package/dist/esm/{chunk-UML2VQZT.mjs.map → chunk-PYLOAMR2.mjs.map} +1 -1
  210. package/dist/esm/chunk-QBBTUC66.mjs +15 -0
  211. package/dist/esm/{chunk-ROXFCLDT.mjs.map → chunk-QBBTUC66.mjs.map} +1 -1
  212. package/dist/esm/chunk-QFOG4LIN.mjs +319 -0
  213. package/dist/esm/{chunk-DM44OGQH.mjs.map → chunk-QFOG4LIN.mjs.map} +1 -1
  214. package/dist/esm/chunk-QMM2KL6C.mjs +12 -0
  215. package/dist/esm/{chunk-FBPNHF54.mjs.map → chunk-QMM2KL6C.mjs.map} +1 -1
  216. package/dist/esm/chunk-RCQMWXEW.mjs +35 -0
  217. package/dist/esm/{chunk-3WUGR46O.mjs.map → chunk-RCQMWXEW.mjs.map} +1 -1
  218. package/dist/esm/chunk-RFSO3JRG.mjs +1 -0
  219. package/dist/esm/chunk-RFSO3JRG.mjs.map +1 -0
  220. package/dist/esm/chunk-RX4VG2AT.mjs +314 -0
  221. package/dist/esm/{chunk-CNMQNPNV.mjs.map → chunk-RX4VG2AT.mjs.map} +1 -1
  222. package/dist/esm/chunk-SBB4YEPT.mjs +17 -0
  223. package/dist/esm/{chunk-56CNRT2K.mjs.map → chunk-SBB4YEPT.mjs.map} +1 -1
  224. package/dist/esm/chunk-SIJELMDP.mjs +29 -0
  225. package/dist/esm/{chunk-6EMN3BOV.mjs.map → chunk-SIJELMDP.mjs.map} +1 -1
  226. package/dist/esm/chunk-SS3NUM5L.mjs +94 -0
  227. package/dist/esm/{chunk-L54P6EGN.mjs.map → chunk-SS3NUM5L.mjs.map} +1 -1
  228. package/dist/esm/chunk-ST4QXIMI.mjs +37 -0
  229. package/dist/esm/{chunk-5P2S2SZZ.mjs.map → chunk-ST4QXIMI.mjs.map} +1 -1
  230. package/dist/esm/chunk-TBHU6ZW6.mjs +215 -0
  231. package/dist/esm/{chunk-7QJ6YJXP.mjs.map → chunk-TBHU6ZW6.mjs.map} +1 -1
  232. package/dist/esm/chunk-TLNHRJB2.mjs +155 -0
  233. package/dist/esm/chunk-TLNHRJB2.mjs.map +1 -0
  234. package/dist/esm/chunk-U3IUCR2G.mjs +54 -0
  235. package/dist/esm/{chunk-CU67XZNB.mjs.map → chunk-U3IUCR2G.mjs.map} +1 -1
  236. package/dist/esm/chunk-U7QBZ6PP.mjs +400 -0
  237. package/dist/esm/chunk-U7QBZ6PP.mjs.map +1 -0
  238. package/dist/esm/chunk-UEBBLQJ5.mjs +94 -0
  239. package/dist/esm/{chunk-NPFNYP75.mjs.map → chunk-UEBBLQJ5.mjs.map} +1 -1
  240. package/dist/esm/chunk-UKU6A2W2.mjs +232 -0
  241. package/dist/esm/{chunk-XO3HHRJV.mjs.map → chunk-UKU6A2W2.mjs.map} +1 -1
  242. package/dist/esm/chunk-UX5NSZEN.mjs +134 -0
  243. package/dist/esm/chunk-UX5NSZEN.mjs.map +1 -0
  244. package/dist/esm/chunk-VDJBDX3A.mjs +79 -0
  245. package/dist/esm/chunk-VDJBDX3A.mjs.map +1 -0
  246. package/dist/esm/chunk-VJP2VWMF.mjs +58 -0
  247. package/dist/esm/chunk-VJP2VWMF.mjs.map +1 -0
  248. package/dist/esm/chunk-VKJQORON.mjs +93 -0
  249. package/dist/esm/{chunk-734YX27W.mjs.map → chunk-VKJQORON.mjs.map} +1 -1
  250. package/dist/esm/chunk-VPWUODU4.mjs +51 -0
  251. package/dist/esm/{chunk-AU6W5OIH.mjs.map → chunk-VPWUODU4.mjs.map} +1 -1
  252. package/dist/esm/chunk-VZQXLVEP.mjs +197 -0
  253. package/dist/esm/{chunk-V6OS74OS.mjs.map → chunk-VZQXLVEP.mjs.map} +1 -1
  254. package/dist/esm/chunk-W76MGKZB.mjs +33 -0
  255. package/dist/esm/{chunk-CTIN3GTP.mjs.map → chunk-W76MGKZB.mjs.map} +1 -1
  256. package/dist/esm/chunk-WDRH2URB.mjs +91 -0
  257. package/dist/esm/chunk-WDRH2URB.mjs.map +1 -0
  258. package/dist/esm/chunk-WHBWEN6N.mjs +206 -0
  259. package/dist/esm/chunk-WHBWEN6N.mjs.map +1 -0
  260. package/dist/esm/chunk-WK5ZSNE2.mjs +173 -0
  261. package/dist/esm/{chunk-QIAHBEEW.mjs.map → chunk-WK5ZSNE2.mjs.map} +1 -1
  262. package/dist/esm/chunk-WLTBF4DF.mjs +22 -0
  263. package/dist/esm/chunk-WLTBF4DF.mjs.map +1 -0
  264. package/dist/esm/chunk-WVGO4D7K.mjs +254 -0
  265. package/dist/esm/chunk-WVGO4D7K.mjs.map +1 -0
  266. package/dist/esm/chunk-XANFAUBD.mjs +44 -0
  267. package/dist/esm/{chunk-QTRYMRYK.mjs.map → chunk-XANFAUBD.mjs.map} +1 -1
  268. package/dist/esm/chunk-Y2LV3S5W.mjs +410 -0
  269. package/dist/esm/chunk-Y2LV3S5W.mjs.map +1 -0
  270. package/dist/esm/chunk-YV7M4CFP.mjs +137 -0
  271. package/dist/esm/{chunk-AOCNYMMX.mjs.map → chunk-YV7M4CFP.mjs.map} +1 -1
  272. package/dist/esm/chunk-YYOPNUX5.mjs +41 -0
  273. package/dist/esm/chunk-YYOPNUX5.mjs.map +1 -0
  274. package/dist/esm/chunk-ZAHJ7KXB.mjs +81 -0
  275. package/dist/esm/chunk-ZAHJ7KXB.mjs.map +1 -0
  276. package/dist/esm/chunk-ZMFKQUHL.mjs +117 -0
  277. package/dist/esm/{chunk-RIUZPGI5.mjs.map → chunk-ZMFKQUHL.mjs.map} +1 -1
  278. package/dist/esm/cli/index.d.mts +12 -0
  279. package/dist/esm/cli/index.mjs +12 -1
  280. package/dist/esm/cli/localNode.mjs +8 -1
  281. package/dist/esm/cli/move.d.mts +105 -0
  282. package/dist/esm/cli/move.mjs +8 -0
  283. package/dist/esm/cli/move.mjs.map +1 -0
  284. package/dist/esm/client/core.mjs +27 -1
  285. package/dist/esm/client/get.d.mts +2 -1
  286. package/dist/esm/client/get.mjs +32 -1
  287. package/dist/esm/client/index.d.mts +2 -2
  288. package/dist/esm/client/index.mjs +55 -1
  289. package/dist/esm/client/post.d.mts +3 -1
  290. package/dist/esm/client/post.mjs +36 -1
  291. package/dist/esm/client/types.d.mts +5 -1
  292. package/dist/esm/client/types.mjs +7 -1
  293. package/dist/esm/core/account/index.d.mts +5 -14
  294. package/dist/esm/core/account/index.mjs +19 -1
  295. package/dist/esm/core/account/utils/address.mjs +18 -1
  296. package/dist/esm/core/account/utils/index.mjs +19 -1
  297. package/dist/esm/core/accountAddress.mjs +15 -1
  298. package/dist/esm/core/authenticationKey.mjs +14 -1
  299. package/dist/esm/core/common.mjs +7 -1
  300. package/dist/esm/core/crypto/ed25519.mjs +29 -1
  301. package/dist/esm/core/crypto/ephemeral.d.mts +73 -0
  302. package/dist/esm/core/crypto/ephemeral.mjs +29 -0
  303. package/dist/esm/core/crypto/ephemeral.mjs.map +1 -0
  304. package/dist/esm/core/crypto/hdKey.mjs +25 -1
  305. package/dist/esm/core/crypto/index.d.mts +6 -3
  306. package/dist/esm/core/crypto/index.mjs +124 -1
  307. package/dist/esm/core/crypto/keyless.d.mts +232 -0
  308. package/dist/esm/core/crypto/keyless.mjs +56 -0
  309. package/dist/esm/core/crypto/keyless.mjs.map +1 -0
  310. package/dist/esm/core/crypto/multiEd25519.mjs +28 -1
  311. package/dist/esm/core/crypto/multiKey.d.mts +7 -0
  312. package/dist/esm/core/crypto/multiKey.mjs +34 -1
  313. package/dist/esm/core/crypto/poseidon.d.mts +7 -0
  314. package/dist/esm/core/crypto/poseidon.mjs +16 -0
  315. package/dist/esm/core/crypto/poseidon.mjs.map +1 -0
  316. package/dist/esm/core/crypto/privateKey.mjs +1 -1
  317. package/dist/esm/core/crypto/proof.d.mts +21 -0
  318. package/dist/esm/core/crypto/proof.mjs +20 -0
  319. package/dist/esm/core/crypto/proof.mjs.map +1 -0
  320. package/dist/esm/core/crypto/publicKey.mjs +21 -1
  321. package/dist/esm/core/crypto/secp256k1.mjs +27 -1
  322. package/dist/esm/core/crypto/signature.mjs +19 -1
  323. package/dist/esm/core/crypto/singleKey.mjs +33 -1
  324. package/dist/esm/core/crypto/utils.mjs +9 -1
  325. package/dist/esm/core/hex.mjs +10 -1
  326. package/dist/esm/core/index.d.mts +5 -5
  327. package/dist/esm/core/index.mjs +141 -1
  328. package/dist/esm/index.d.mts +15 -8
  329. package/dist/esm/index.mjs +635 -1
  330. package/dist/esm/internal/account.d.mts +13 -1
  331. package/dist/esm/internal/account.mjs +106 -1
  332. package/dist/esm/internal/ans.d.mts +1 -1
  333. package/dist/esm/internal/ans.mjs +120 -1
  334. package/dist/esm/internal/coin.d.mts +7 -7
  335. package/dist/esm/internal/coin.mjs +85 -1
  336. package/dist/esm/internal/digitalAsset.d.mts +2 -2
  337. package/dist/esm/internal/digitalAsset.mjs +127 -1
  338. package/dist/esm/internal/event.d.mts +1 -1
  339. package/dist/esm/internal/event.mjs +55 -1
  340. package/dist/esm/internal/faucet.d.mts +1 -1
  341. package/dist/esm/internal/faucet.mjs +52 -1
  342. package/dist/esm/internal/fungibleAsset.d.mts +5 -5
  343. package/dist/esm/internal/fungibleAsset.mjs +91 -1
  344. package/dist/esm/internal/general.mjs +46 -1
  345. package/dist/esm/internal/keyless.d.mts +68 -0
  346. package/dist/esm/internal/keyless.mjs +74 -0
  347. package/dist/esm/internal/keyless.mjs.map +1 -0
  348. package/dist/esm/internal/staking.d.mts +1 -1
  349. package/dist/esm/internal/staking.mjs +53 -1
  350. package/dist/esm/internal/transaction.mjs +51 -1
  351. package/dist/esm/internal/transactionSubmission.d.mts +1 -1
  352. package/dist/esm/internal/transactionSubmission.mjs +102 -1
  353. package/dist/esm/internal/view.d.mts +7 -7
  354. package/dist/esm/internal/view.mjs +83 -1
  355. package/dist/esm/transactions/authenticator/account.d.mts +3 -4
  356. package/dist/esm/transactions/authenticator/account.mjs +44 -1
  357. package/dist/esm/transactions/authenticator/index.mjs +60 -1
  358. package/dist/esm/transactions/authenticator/transaction.mjs +48 -1
  359. package/dist/esm/transactions/index.d.mts +2 -2
  360. package/dist/esm/transactions/index.mjs +284 -1
  361. package/dist/esm/transactions/instances/chainId.mjs +11 -1
  362. package/dist/esm/transactions/instances/identifier.mjs +11 -1
  363. package/dist/esm/transactions/instances/index.mjs +96 -1
  364. package/dist/esm/transactions/instances/moduleId.d.mts +1 -1
  365. package/dist/esm/transactions/instances/moduleId.mjs +38 -1
  366. package/dist/esm/transactions/instances/multiAgentTransaction.mjs +43 -1
  367. package/dist/esm/transactions/instances/rawTransaction.mjs +48 -1
  368. package/dist/esm/transactions/instances/rotationProofChallenge.mjs +20 -1
  369. package/dist/esm/transactions/instances/signedTransaction.mjs +45 -1
  370. package/dist/esm/transactions/instances/simpleTransaction.mjs +43 -1
  371. package/dist/esm/transactions/instances/transactionArgument.mjs +1 -1
  372. package/dist/esm/transactions/instances/transactionPayload.d.mts +1 -1
  373. package/dist/esm/transactions/instances/transactionPayload.mjs +56 -1
  374. package/dist/esm/transactions/management/accountSequenceNumber.d.mts +13 -1
  375. package/dist/esm/transactions/management/accountSequenceNumber.mjs +74 -1
  376. package/dist/esm/transactions/management/asyncQueue.mjs +9 -1
  377. package/dist/esm/transactions/management/index.d.mts +2 -2
  378. package/dist/esm/transactions/management/index.mjs +95 -1
  379. package/dist/esm/transactions/management/transactionWorker.d.mts +1 -1
  380. package/dist/esm/transactions/management/transactionWorker.mjs +91 -1
  381. package/dist/esm/transactions/transactionBuilder/helpers.d.mts +9 -9
  382. package/dist/esm/transactions/transactionBuilder/helpers.mjs +75 -1
  383. package/dist/esm/transactions/transactionBuilder/index.d.mts +9 -9
  384. package/dist/esm/transactions/transactionBuilder/index.mjs +162 -1
  385. package/dist/esm/transactions/transactionBuilder/remoteAbi.d.mts +6 -6
  386. package/dist/esm/transactions/transactionBuilder/remoteAbi.mjs +85 -1
  387. package/dist/esm/transactions/transactionBuilder/signingMessage.d.mts +72 -0
  388. package/dist/esm/transactions/transactionBuilder/signingMessage.mjs +59 -0
  389. package/dist/esm/transactions/transactionBuilder/signingMessage.mjs.map +1 -0
  390. package/dist/esm/transactions/transactionBuilder/transactionBuilder.d.mts +6 -28
  391. package/dist/esm/transactions/transactionBuilder/transactionBuilder.mjs +98 -1
  392. package/dist/esm/transactions/typeTag/index.mjs +74 -1
  393. package/dist/esm/transactions/typeTag/parser.mjs +43 -1
  394. package/dist/esm/transactions/types.d.mts +6 -6
  395. package/dist/esm/transactions/types.mjs +1 -1
  396. package/dist/esm/types/generated/queries.mjs +57 -1
  397. package/dist/esm/types/generated/types.mjs +809 -1
  398. package/dist/esm/types/generated/types.mjs.map +1 -1
  399. package/dist/esm/types/index.d.mts +19 -3
  400. package/dist/esm/types/index.mjs +68 -1
  401. package/dist/esm/types/indexer.mjs +1 -1
  402. package/dist/esm/types/keyless.d.mts +69 -0
  403. package/dist/esm/types/keyless.mjs +10 -0
  404. package/dist/esm/types/keyless.mjs.map +1 -0
  405. package/dist/esm/utils/apiEndpoints.d.mts +3 -2
  406. package/dist/esm/utils/apiEndpoints.mjs +21 -1
  407. package/dist/esm/utils/const.d.mts +3 -1
  408. package/dist/esm/utils/const.mjs +21 -1
  409. package/dist/esm/utils/helpers.mjs +7 -1
  410. package/dist/esm/utils/index.d.mts +1 -1
  411. package/dist/esm/utils/index.mjs +56 -1
  412. package/dist/esm/utils/memoize.mjs +9 -1
  413. package/dist/esm/utils/normalizeBundle.mjs +19 -1
  414. package/dist/esm/version.d.mts +1 -1
  415. package/dist/esm/version.mjs +7 -1
  416. package/package.json +11 -3
  417. package/src/{core/account → account}/Account.ts +25 -15
  418. package/src/{core/account → account}/Ed25519Account.ts +45 -9
  419. package/src/account/EphemeralKeyPair.ts +161 -0
  420. package/src/account/KeylessAccount.ts +342 -0
  421. package/src/account/MultiKeyAccount.ts +186 -0
  422. package/src/{core/account → account}/SingleKeyAccount.ts +45 -10
  423. package/src/account/index.ts +6 -0
  424. package/src/api/account.ts +2 -1
  425. package/src/api/ans.ts +2 -1
  426. package/src/api/aptos.ts +6 -0
  427. package/src/api/aptosConfig.ts +46 -1
  428. package/src/api/digitalAsset.ts +2 -1
  429. package/src/api/fungibleAsset.ts +2 -1
  430. package/src/api/keyless.ts +48 -0
  431. package/src/api/transaction.ts +2 -1
  432. package/src/api/transactionSubmission/management.ts +1 -1
  433. package/src/api/transactionSubmission/sign.ts +1 -1
  434. package/src/bcs/deserializer.ts +40 -0
  435. package/src/bcs/serializer.ts +18 -0
  436. package/src/cli/index.ts +1 -0
  437. package/src/cli/move.ts +183 -0
  438. package/src/client/core.ts +8 -0
  439. package/src/client/get.ts +6 -0
  440. package/src/client/post.ts +12 -0
  441. package/src/client/types.ts +1 -1
  442. package/src/core/account/index.ts +0 -3
  443. package/src/core/crypto/ephemeral.ts +138 -0
  444. package/src/core/crypto/index.ts +2 -0
  445. package/src/core/crypto/keyless.ts +453 -0
  446. package/src/core/crypto/multiKey.ts +17 -6
  447. package/src/core/crypto/poseidon.ts +134 -0
  448. package/src/core/crypto/proof.ts +16 -0
  449. package/src/core/crypto/singleKey.ts +11 -0
  450. package/src/core/index.ts +0 -1
  451. package/src/index.ts +1 -0
  452. package/src/internal/account.ts +1 -1
  453. package/src/internal/ans.ts +2 -2
  454. package/src/internal/digitalAsset.ts +2 -1
  455. package/src/internal/fungibleAsset.ts +3 -2
  456. package/src/internal/keyless.ts +119 -0
  457. package/src/internal/transactionSubmission.ts +24 -13
  458. package/src/transactions/authenticator/account.ts +6 -11
  459. package/src/transactions/management/accountSequenceNumber.ts +1 -1
  460. package/src/transactions/management/transactionWorker.ts +1 -1
  461. package/src/transactions/transactionBuilder/index.ts +1 -0
  462. package/src/transactions/transactionBuilder/signingMessage.ts +93 -0
  463. package/src/transactions/transactionBuilder/transactionBuilder.ts +2 -75
  464. package/src/types/index.ts +22 -0
  465. package/src/types/keyless.ts +37 -0
  466. package/src/utils/apiEndpoints.ts +14 -6
  467. package/src/utils/const.ts +2 -0
  468. package/src/version.ts +1 -1
  469. package/dist/common/chunk-KSEUZTKY.js +0 -2
  470. package/dist/common/chunk-KSEUZTKY.js.map +0 -1
  471. package/dist/esm/chunk-24IKVZBK.mjs +0 -2
  472. package/dist/esm/chunk-24IKVZBK.mjs.map +0 -1
  473. package/dist/esm/chunk-2HISPUZZ.mjs +0 -2
  474. package/dist/esm/chunk-2HISPUZZ.mjs.map +0 -1
  475. package/dist/esm/chunk-3JPVQHOR.mjs +0 -2
  476. package/dist/esm/chunk-3WUGR46O.mjs +0 -2
  477. package/dist/esm/chunk-52C73T26.mjs +0 -2
  478. package/dist/esm/chunk-56CNRT2K.mjs +0 -2
  479. package/dist/esm/chunk-5P2S2SZZ.mjs +0 -2
  480. package/dist/esm/chunk-6CFRW26C.mjs +0 -2
  481. package/dist/esm/chunk-6CFRW26C.mjs.map +0 -1
  482. package/dist/esm/chunk-6EMN3BOV.mjs +0 -2
  483. package/dist/esm/chunk-6FBKUTGF.mjs +0 -2
  484. package/dist/esm/chunk-6IFMQ5AS.mjs +0 -2
  485. package/dist/esm/chunk-6IFMQ5AS.mjs.map +0 -1
  486. package/dist/esm/chunk-734YX27W.mjs +0 -2
  487. package/dist/esm/chunk-7QJ6YJXP.mjs +0 -2
  488. package/dist/esm/chunk-AD3VLZ7I.mjs +0 -2
  489. package/dist/esm/chunk-AD3VLZ7I.mjs.map +0 -1
  490. package/dist/esm/chunk-AH44UPM4.mjs +0 -2
  491. package/dist/esm/chunk-AOCNYMMX.mjs +0 -2
  492. package/dist/esm/chunk-AU6W5OIH.mjs +0 -2
  493. package/dist/esm/chunk-B3R6G6QP.mjs +0 -2
  494. package/dist/esm/chunk-B3R6G6QP.mjs.map +0 -1
  495. package/dist/esm/chunk-B7TQGVGL.mjs +0 -2
  496. package/dist/esm/chunk-BWFJHFBQ.mjs +0 -2
  497. package/dist/esm/chunk-CNMQNPNV.mjs +0 -2
  498. package/dist/esm/chunk-CTIN3GTP.mjs +0 -2
  499. package/dist/esm/chunk-CU67XZNB.mjs +0 -2
  500. package/dist/esm/chunk-CYNQRMO5.mjs +0 -2
  501. package/dist/esm/chunk-CYNQRMO5.mjs.map +0 -1
  502. package/dist/esm/chunk-DM44OGQH.mjs +0 -2
  503. package/dist/esm/chunk-DMKUAQB7.mjs +0 -2
  504. package/dist/esm/chunk-DPV25ZKR.mjs +0 -2
  505. package/dist/esm/chunk-DSTKXJMA.mjs +0 -2
  506. package/dist/esm/chunk-E7FWVXGX.mjs +0 -1
  507. package/dist/esm/chunk-EOFJFE4T.mjs +0 -2
  508. package/dist/esm/chunk-EOFJFE4T.mjs.map +0 -1
  509. package/dist/esm/chunk-FATWMUXK.mjs +0 -2
  510. package/dist/esm/chunk-FATWMUXK.mjs.map +0 -1
  511. package/dist/esm/chunk-FBPNHF54.mjs +0 -2
  512. package/dist/esm/chunk-FS3NSGBF.mjs +0 -2
  513. package/dist/esm/chunk-FVA2OPG4.mjs +0 -2
  514. package/dist/esm/chunk-G2O323HP.mjs +0 -2
  515. package/dist/esm/chunk-GSD4OOM3.mjs +0 -2
  516. package/dist/esm/chunk-HQ5I4Q3H.mjs +0 -2
  517. package/dist/esm/chunk-HQ5I4Q3H.mjs.map +0 -1
  518. package/dist/esm/chunk-IIPYR7PF.mjs +0 -2
  519. package/dist/esm/chunk-IIPYR7PF.mjs.map +0 -1
  520. package/dist/esm/chunk-IKYIJYBY.mjs +0 -2
  521. package/dist/esm/chunk-IKYIJYBY.mjs.map +0 -1
  522. package/dist/esm/chunk-IOSQVDZI.mjs +0 -2
  523. package/dist/esm/chunk-KVZ4XMZS.mjs +0 -2
  524. package/dist/esm/chunk-KVZ4XMZS.mjs.map +0 -1
  525. package/dist/esm/chunk-L54P6EGN.mjs +0 -2
  526. package/dist/esm/chunk-LR65XHSF.mjs +0 -2
  527. package/dist/esm/chunk-MACC2BLE.mjs +0 -2
  528. package/dist/esm/chunk-MC6G725U.mjs +0 -2
  529. package/dist/esm/chunk-MC6G725U.mjs.map +0 -1
  530. package/dist/esm/chunk-MFKMAAWA.mjs +0 -2
  531. package/dist/esm/chunk-MLWIHWNH.mjs +0 -1
  532. package/dist/esm/chunk-NNQJBFRB.mjs +0 -2
  533. package/dist/esm/chunk-NPFNYP75.mjs +0 -2
  534. package/dist/esm/chunk-O2F53NKI.mjs +0 -2
  535. package/dist/esm/chunk-O4JRPZZM.mjs +0 -2
  536. package/dist/esm/chunk-ODRO4CSA.mjs +0 -2
  537. package/dist/esm/chunk-ODRO4CSA.mjs.map +0 -1
  538. package/dist/esm/chunk-OVJQWQ2N.mjs +0 -2
  539. package/dist/esm/chunk-OVJQWQ2N.mjs.map +0 -1
  540. package/dist/esm/chunk-OWW6SIDP.mjs +0 -2
  541. package/dist/esm/chunk-OWW6SIDP.mjs.map +0 -1
  542. package/dist/esm/chunk-PFIMEXNN.mjs +0 -2
  543. package/dist/esm/chunk-PFIMEXNN.mjs.map +0 -1
  544. package/dist/esm/chunk-PZGLV5UQ.mjs +0 -2
  545. package/dist/esm/chunk-Q3TZGQVC.mjs +0 -2
  546. package/dist/esm/chunk-Q3TZGQVC.mjs.map +0 -1
  547. package/dist/esm/chunk-QIAHBEEW.mjs +0 -2
  548. package/dist/esm/chunk-QMURTXFM.mjs +0 -2
  549. package/dist/esm/chunk-QTRYMRYK.mjs +0 -2
  550. package/dist/esm/chunk-R5QUBEH6.mjs +0 -2
  551. package/dist/esm/chunk-R7G3CLRI.mjs +0 -1
  552. package/dist/esm/chunk-RHBCVCOS.mjs +0 -2
  553. package/dist/esm/chunk-RIUZPGI5.mjs +0 -2
  554. package/dist/esm/chunk-ROXFCLDT.mjs +0 -2
  555. package/dist/esm/chunk-SG4MAOCF.mjs +0 -2
  556. package/dist/esm/chunk-SUAKPNKQ.mjs +0 -2
  557. package/dist/esm/chunk-SUAKPNKQ.mjs.map +0 -1
  558. package/dist/esm/chunk-TBMAJ6AW.mjs +0 -2
  559. package/dist/esm/chunk-TJDC5PWD.mjs +0 -2
  560. package/dist/esm/chunk-TLOPIURC.mjs +0 -2
  561. package/dist/esm/chunk-TLOPIURC.mjs.map +0 -1
  562. package/dist/esm/chunk-U43IJHQN.mjs +0 -2
  563. package/dist/esm/chunk-U6Z4FNB7.mjs +0 -2
  564. package/dist/esm/chunk-UFT7US42.mjs +0 -2
  565. package/dist/esm/chunk-UML2VQZT.mjs +0 -2
  566. package/dist/esm/chunk-UVSRX4SV.mjs +0 -1
  567. package/dist/esm/chunk-V3Q2KXJU.mjs +0 -2
  568. package/dist/esm/chunk-V4SRNEV3.mjs +0 -2
  569. package/dist/esm/chunk-V4SRNEV3.mjs.map +0 -1
  570. package/dist/esm/chunk-V6OS74OS.mjs +0 -2
  571. package/dist/esm/chunk-VVIG4E7Q.mjs +0 -2
  572. package/dist/esm/chunk-W4ZW7QHA.mjs +0 -2
  573. package/dist/esm/chunk-WFZDFFBM.mjs +0 -2
  574. package/dist/esm/chunk-WLF5YQM4.mjs +0 -2
  575. package/dist/esm/chunk-WLF5YQM4.mjs.map +0 -1
  576. package/dist/esm/chunk-XDGQTMDV.mjs +0 -2
  577. package/dist/esm/chunk-XDGQTMDV.mjs.map +0 -1
  578. package/dist/esm/chunk-XO3HHRJV.mjs +0 -2
  579. package/dist/esm/chunk-YFRXBEOC.mjs +0 -2
  580. package/dist/esm/chunk-YFRXBEOC.mjs.map +0 -1
  581. package/dist/esm/chunk-YPTF6MLX.mjs +0 -2
  582. package/dist/esm/chunk-YPTF6MLX.mjs.map +0 -1
  583. package/dist/esm/chunk-YU3KB3UV.mjs +0 -2
  584. package/dist/esm/chunk-Z5YFM2AW.mjs +0 -2
  585. package/dist/esm/chunk-Z5YFM2AW.mjs.map +0 -1
  586. package/dist/esm/chunk-ZYYK3UXP.mjs +0 -2
  587. package/dist/esm/chunk-ZZZZVONX.mjs +0 -2
  588. package/dist/esm/core/account/Account.d.mts +0 -20
  589. package/dist/esm/core/account/Account.mjs +0 -2
  590. package/dist/esm/core/account/Ed25519Account.d.mts +0 -20
  591. package/dist/esm/core/account/Ed25519Account.mjs +0 -2
  592. package/dist/esm/core/account/SingleKeyAccount.d.mts +0 -20
  593. package/dist/esm/core/account/SingleKeyAccount.mjs +0 -2
  594. /package/dist/esm/{core/account → account}/Account.mjs.map +0 -0
  595. /package/dist/esm/{core/account → account}/Ed25519Account.mjs.map +0 -0
  596. /package/dist/esm/{chunk-E7FWVXGX.mjs.map → account/EphemeralKeyPair.mjs.map} +0 -0
  597. /package/dist/esm/{chunk-FVA2OPG4.mjs.map → account/KeylessAccount.mjs.map} +0 -0
  598. /package/dist/esm/{chunk-MLWIHWNH.mjs.map → account/MultiKeyAccount.mjs.map} +0 -0
  599. /package/dist/esm/{core/account → account}/SingleKeyAccount.mjs.map +0 -0
  600. /package/dist/esm/{chunk-R7G3CLRI.mjs.map → account/index.mjs.map} +0 -0
  601. /package/dist/esm/{chunk-UVSRX4SV.mjs.map → api/keyless.mjs.map} +0 -0
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/internal/transactionSubmission.ts"],"sourcesContent":["/**\n * This file contains the underlying implementations for exposed submission API surface in\n * the {@link api/transaction}. By moving the methods out into a separate file,\n * other namespaces and processes can access these methods without depending on the entire\n * transaction namespace and without having a dependency cycle error.\n */\n\nimport { AptosConfig } from \"../api/aptosConfig\";\nimport { MoveVector, U8 } from \"../bcs\";\nimport { AptosApiError, postAptosFullNode } from \"../client\";\nimport { Account, KeylessAccount, MultiKeyAccount } from \"../account\";\nimport { AccountAddress, AccountAddressInput } from \"../core/accountAddress\";\nimport { PrivateKey } from \"../core/crypto\";\nimport { AccountAuthenticator } from \"../transactions/authenticator/account\";\nimport { RotationProofChallenge } from \"../transactions/instances/rotationProofChallenge\";\nimport {\n buildTransaction,\n generateTransactionPayload,\n generateSignedTransactionForSimulation,\n generateSignedTransaction,\n} from \"../transactions/transactionBuilder/transactionBuilder\";\nimport {\n InputGenerateTransactionData,\n AnyRawTransaction,\n InputSimulateTransactionData,\n InputGenerateTransactionOptions,\n InputGenerateTransactionPayloadDataWithRemoteABI,\n InputSubmitTransactionData,\n InputGenerateMultiAgentRawTransactionData,\n InputGenerateSingleSignerRawTransactionData,\n AnyTransactionPayloadInstance,\n EntryFunctionABI,\n} from \"../transactions/types\";\nimport { getInfo } from \"./account\";\nimport { UserTransactionResponse, PendingTransactionResponse, MimeType, HexInput, TransactionResponse } from \"../types\";\nimport { TypeTagU8, TypeTagVector, generateSigningMessageForTransaction } from \"../transactions\";\nimport { SimpleTransaction } from \"../transactions/instances/simpleTransaction\";\nimport { MultiAgentTransaction } from \"../transactions/instances/multiAgentTransaction\";\nimport { KeylessError } from \"../types/keyless\";\n\n/**\n * We are defining function signatures, each with its specific input and output.\n * These are the possible function signature for `generateTransaction` function.\n * When we call `generateTransaction` function with the relevant type properties,\n * Typescript can infer the return type based on the appropriate function overload.\n */\nexport async function generateTransaction(\n args: { aptosConfig: AptosConfig } & InputGenerateSingleSignerRawTransactionData,\n): Promise<SimpleTransaction>;\nexport async function generateTransaction(\n args: { aptosConfig: AptosConfig } & InputGenerateMultiAgentRawTransactionData,\n): Promise<MultiAgentTransaction>;\n/**\n * Generates any transaction by passing in the required arguments\n *\n * @param args.sender The transaction sender's account address as a AccountAddressInput\n * @param args.data EntryFunctionData | ScriptData | MultiSigData\n * @param args.feePayerAddress optional. For a fee payer (aka sponsored) transaction\n * @param args.secondarySignerAddresses optional. For a multi-agent or fee payer (aka sponsored) transactions\n * @param args.options optional. GenerateTransactionOptions type\n *\n * @example\n * For a single signer entry function\n * move function name, move function type arguments, move function arguments\n * `\n * data: {\n * function:\"0x1::aptos_account::transfer\",\n * typeArguments:[]\n * functionArguments :[receiverAddress,10]\n * }\n * `\n *\n * @example\n * For a single signer script function\n * module bytecode, move function type arguments, move function arguments\n * ```\n * data: {\n * bytecode:\"0x001234567\",\n * typeArguments:[],\n * functionArguments :[receiverAddress,10]\n * }\n * ```\n *\n * @return An instance of a RawTransaction, plus optional secondary/fee payer addresses\n * ```\n * {\n * rawTransaction: RawTransaction,\n * secondarySignerAddresses? : Array<AccountAddress>,\n * feePayerAddress?: AccountAddress\n * }\n * ```\n */\nexport async function generateTransaction(\n args: { aptosConfig: AptosConfig } & InputGenerateTransactionData,\n): Promise<AnyRawTransaction> {\n const payload = await buildTransactionPayload(args);\n return buildRawTransaction(args, payload);\n}\n\nexport async function buildTransactionPayload(\n args: { aptosConfig: AptosConfig } & InputGenerateTransactionData,\n): Promise<AnyTransactionPayloadInstance> {\n const { aptosConfig, data } = args;\n // Merge in aptosConfig for remote ABI on non-script payloads\n let generateTransactionPayloadData: InputGenerateTransactionPayloadDataWithRemoteABI;\n let payload: AnyTransactionPayloadInstance;\n\n if (\"bytecode\" in data) {\n // TODO: Add ABI checking later\n payload = await generateTransactionPayload(data);\n } else if (\"multisigAddress\" in data) {\n generateTransactionPayloadData = {\n aptosConfig,\n multisigAddress: data.multisigAddress,\n function: data.function,\n functionArguments: data.functionArguments,\n typeArguments: data.typeArguments,\n abi: data.abi,\n };\n payload = await generateTransactionPayload(generateTransactionPayloadData);\n } else {\n generateTransactionPayloadData = {\n aptosConfig,\n function: data.function,\n functionArguments: data.functionArguments,\n typeArguments: data.typeArguments,\n abi: data.abi,\n };\n payload = await generateTransactionPayload(generateTransactionPayloadData);\n }\n return payload;\n}\n\nexport async function buildRawTransaction(\n args: { aptosConfig: AptosConfig } & InputGenerateTransactionData,\n payload: AnyTransactionPayloadInstance,\n): Promise<AnyRawTransaction> {\n const { aptosConfig, sender, options } = args;\n\n let feePayerAddress;\n if (isFeePayerTransactionInput(args)) {\n feePayerAddress = AccountAddress.ZERO.toString();\n }\n\n if (isMultiAgentTransactionInput(args)) {\n const { secondarySignerAddresses } = args;\n return buildTransaction({\n aptosConfig,\n sender,\n payload,\n options,\n secondarySignerAddresses,\n feePayerAddress,\n });\n }\n\n return buildTransaction({\n aptosConfig,\n sender,\n payload,\n options,\n feePayerAddress,\n });\n}\n\nfunction isFeePayerTransactionInput(data: InputGenerateTransactionData): boolean {\n return data.withFeePayer === true;\n}\n\nfunction isMultiAgentTransactionInput(\n data: InputGenerateTransactionData,\n): data is InputGenerateMultiAgentRawTransactionData {\n return \"secondarySignerAddresses\" in data;\n}\n\n/**\n * Builds a signing message that can be signed by external signers\n *\n * Note: Please prefer using `signTransaction` unless signing outside the SDK\n *\n * @param args.transaction AnyRawTransaction, as generated by `generateTransaction()`\n *\n * @return The message to be signed\n */\nexport function getSigningMessage(args: { transaction: AnyRawTransaction }): Uint8Array {\n const { transaction } = args;\n return generateSigningMessageForTransaction(transaction);\n}\n\n/**\n * Sign a transaction that can later be submitted to chain\n *\n * @param args.signer The signer account to sign the transaction\n * @param args.transaction An instance of a RawTransaction, plus optional secondary/fee payer addresses\n * ```\n * {\n * rawTransaction: RawTransaction,\n * secondarySignerAddresses? : Array<AccountAddress>,\n * feePayerAddress?: AccountAddress\n * }\n * ```\n *\n * @return The signer AccountAuthenticator\n */\nexport function signTransaction(args: { signer: Account; transaction: AnyRawTransaction }): AccountAuthenticator {\n const { signer, transaction } = args;\n return signer.signTransactionWithAuthenticator(transaction);\n}\n\n/**\n * Simulates a transaction before singing it.\n *\n * @param args.signerPublicKey The signer public key\n * @param args.transaction The raw transaction to simulate\n * @param args.secondarySignersPublicKeys optional. For when the transaction is a multi signers transaction\n * @param args.feePayerPublicKey optional. For when the transaction is a fee payer (aka sponsored) transaction\n * @param args.options optional. A config to simulate the transaction with\n */\nexport async function simulateTransaction(\n args: { aptosConfig: AptosConfig } & InputSimulateTransactionData,\n): Promise<Array<UserTransactionResponse>> {\n const { aptosConfig, transaction, signerPublicKey, secondarySignersPublicKeys, feePayerPublicKey, options } = args;\n\n const signedTransaction = generateSignedTransactionForSimulation({\n transaction,\n signerPublicKey,\n secondarySignersPublicKeys,\n feePayerPublicKey,\n options,\n });\n\n const { data } = await postAptosFullNode<Uint8Array, Array<UserTransactionResponse>>({\n aptosConfig,\n body: signedTransaction,\n path: \"transactions/simulate\",\n params: {\n estimate_gas_unit_price: args.options?.estimateGasUnitPrice ?? false,\n estimate_max_gas_amount: args.options?.estimateMaxGasAmount ?? false,\n estimate_prioritized_gas_unit_price: args.options?.estimatePrioritizedGasUnitPrice ?? false,\n },\n originMethod: \"simulateTransaction\",\n contentType: MimeType.BCS_SIGNED_TRANSACTION,\n });\n return data;\n}\n\n/**\n * Submit transaction to chain\n *\n * @param args.transaction A aptos transaction type\n * @param args.senderAuthenticator The account authenticator of the transaction sender\n * @param args.secondarySignerAuthenticators optional. For when the transaction is a multi signers transaction\n *\n * @return PendingTransactionResponse\n */\nexport async function submitTransaction(\n args: {\n aptosConfig: AptosConfig;\n } & InputSubmitTransactionData,\n): Promise<PendingTransactionResponse> {\n const { aptosConfig } = args;\n const signedTransaction = generateSignedTransaction({ ...args });\n const { data } = await postAptosFullNode<Uint8Array, PendingTransactionResponse>({\n aptosConfig,\n body: signedTransaction,\n path: \"transactions\",\n originMethod: \"submitTransaction\",\n contentType: MimeType.BCS_SIGNED_TRANSACTION,\n });\n return data;\n}\n\nexport async function signAndSubmitTransaction(args: {\n aptosConfig: AptosConfig;\n signer: Account;\n transaction: AnyRawTransaction;\n}): Promise<PendingTransactionResponse> {\n const { aptosConfig, signer, transaction } = args;\n // If the signer contains a KeylessAccount, await proof fetching in case the proof\n // was fetched asyncronously.\n if (signer instanceof KeylessAccount || signer instanceof MultiKeyAccount) {\n await signer.waitForProofFetch();\n }\n const authenticator = signTransaction({ signer, transaction });\n try {\n return await submitTransaction({\n aptosConfig,\n transaction,\n senderAuthenticator: authenticator,\n });\n } catch (error) {\n if (error instanceof AptosApiError && signer instanceof KeylessAccount) {\n throw await KeylessError.fromAptosApiError(error, signer);\n }\n throw error;\n }\n}\n\nconst packagePublishAbi: EntryFunctionABI = {\n typeParameters: [],\n parameters: [TypeTagVector.u8(), new TypeTagVector(TypeTagVector.u8())],\n};\n\nexport async function publicPackageTransaction(args: {\n aptosConfig: AptosConfig;\n account: AccountAddressInput;\n metadataBytes: HexInput;\n moduleBytecode: Array<HexInput>;\n options?: InputGenerateTransactionOptions;\n}): Promise<SimpleTransaction> {\n const { aptosConfig, account, metadataBytes, moduleBytecode, options } = args;\n\n const totalByteCode = moduleBytecode.map((bytecode) => MoveVector.U8(bytecode));\n\n return generateTransaction({\n aptosConfig,\n sender: AccountAddress.from(account),\n data: {\n function: \"0x1::code::publish_package_txn\",\n functionArguments: [MoveVector.U8(metadataBytes), new MoveVector(totalByteCode)],\n abi: packagePublishAbi,\n },\n options,\n });\n}\n\nconst rotateAuthKeyAbi: EntryFunctionABI = {\n typeParameters: [],\n parameters: [\n new TypeTagU8(),\n TypeTagVector.u8(),\n new TypeTagU8(),\n TypeTagVector.u8(),\n TypeTagVector.u8(),\n TypeTagVector.u8(),\n ],\n};\n\n/**\n * TODO: Need to refactor and move this function out of transactionSubmission\n */\nexport async function rotateAuthKey(args: {\n aptosConfig: AptosConfig;\n fromAccount: Account;\n toNewPrivateKey: PrivateKey;\n}): Promise<TransactionResponse> {\n const { aptosConfig, fromAccount, toNewPrivateKey } = args;\n const accountInfo = await getInfo({\n aptosConfig,\n accountAddress: fromAccount.accountAddress,\n });\n\n const newAccount = Account.fromPrivateKey({ privateKey: toNewPrivateKey, legacy: true });\n\n const challenge = new RotationProofChallenge({\n sequenceNumber: BigInt(accountInfo.sequence_number),\n originator: fromAccount.accountAddress,\n currentAuthKey: AccountAddress.from(accountInfo.authentication_key),\n newPublicKey: newAccount.publicKey,\n });\n\n // Sign the challenge\n const challengeHex = challenge.bcsToBytes();\n const proofSignedByCurrentPrivateKey = fromAccount.sign(challengeHex);\n const proofSignedByNewPrivateKey = newAccount.sign(challengeHex);\n\n // Generate transaction\n const rawTxn = await generateTransaction({\n aptosConfig,\n sender: fromAccount.accountAddress,\n data: {\n function: \"0x1::account::rotate_authentication_key\",\n functionArguments: [\n new U8(fromAccount.signingScheme), // from scheme\n MoveVector.U8(fromAccount.publicKey.toUint8Array()),\n new U8(newAccount.signingScheme), // to scheme\n MoveVector.U8(newAccount.publicKey.toUint8Array()),\n MoveVector.U8(proofSignedByCurrentPrivateKey.toUint8Array()),\n MoveVector.U8(proofSignedByNewPrivateKey.toUint8Array()),\n ],\n abi: rotateAuthKeyAbi,\n },\n });\n return signAndSubmitTransaction({\n aptosConfig,\n signer: fromAccount,\n transaction: rawTxn,\n });\n}\n"],"mappings":"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","names":[]}
@@ -0,0 +1,126 @@
1
+ import {
2
+ generateSigningMessageForTransaction
3
+ } from "./chunk-VJP2VWMF.mjs";
4
+ import {
5
+ AccountAuthenticatorSingleKey
6
+ } from "./chunk-IC56GQFJ.mjs";
7
+ import {
8
+ AnyPublicKey,
9
+ AnySignature
10
+ } from "./chunk-TLNHRJB2.mjs";
11
+ import {
12
+ Secp256k1PrivateKey
13
+ } from "./chunk-DIYZRGR6.mjs";
14
+ import {
15
+ Ed25519PrivateKey
16
+ } from "./chunk-RX4VG2AT.mjs";
17
+ import {
18
+ AccountAddress
19
+ } from "./chunk-CMNJG4NN.mjs";
20
+
21
+ // src/account/SingleKeyAccount.ts
22
+ var SingleKeyAccount = class _SingleKeyAccount {
23
+ // region Constructors
24
+ constructor(args) {
25
+ this.signingScheme = 2 /* SingleKey */;
26
+ const { privateKey, address } = args;
27
+ this.privateKey = privateKey;
28
+ this.publicKey = new AnyPublicKey(privateKey.publicKey());
29
+ this.accountAddress = address ? AccountAddress.from(address) : this.publicKey.authKey().derivedAddress();
30
+ }
31
+ /**
32
+ * Derives an account from a randomly generated private key.
33
+ * Default generation is using an Ed25519 key
34
+ * @returns Account with the given signature scheme
35
+ */
36
+ static generate(args = {}) {
37
+ const { scheme = 0 /* Ed25519 */ } = args;
38
+ let privateKey;
39
+ switch (scheme) {
40
+ case 0 /* Ed25519 */:
41
+ privateKey = Ed25519PrivateKey.generate();
42
+ break;
43
+ case 2 /* Secp256k1Ecdsa */:
44
+ privateKey = Secp256k1PrivateKey.generate();
45
+ break;
46
+ default:
47
+ throw new Error(`Unsupported signature scheme ${scheme}`);
48
+ }
49
+ return new _SingleKeyAccount({ privateKey });
50
+ }
51
+ /**
52
+ * Derives an account with bip44 path and mnemonics,
53
+ * Default to using an Ed25519 signature scheme.
54
+ *
55
+ * @param args.scheme The signature scheme to derive the private key with
56
+ * @param args.path the BIP44 derive hardened path (e.g. m/44'/637'/0'/0'/0') for Ed25519,
57
+ * or non-hardened path (e.g. m/44'/637'/0'/0/0) for secp256k1
58
+ * Detailed description: {@link https://github.com/bitcoin/bips/blob/master/bip-0044.mediawiki}
59
+ * @param args.mnemonic the mnemonic seed phrase of the account
60
+ */
61
+ static fromDerivationPath(args) {
62
+ const { scheme = 0 /* Ed25519 */, path, mnemonic } = args;
63
+ let privateKey;
64
+ switch (scheme) {
65
+ case 0 /* Ed25519 */:
66
+ privateKey = Ed25519PrivateKey.fromDerivationPath(path, mnemonic);
67
+ break;
68
+ case 2 /* Secp256k1Ecdsa */:
69
+ privateKey = Secp256k1PrivateKey.fromDerivationPath(path, mnemonic);
70
+ break;
71
+ default:
72
+ throw new Error(`Unsupported signature scheme ${scheme}`);
73
+ }
74
+ return new _SingleKeyAccount({ privateKey });
75
+ }
76
+ // endregion
77
+ // region Account
78
+ /**
79
+ * Verify the given message and signature with the public key.
80
+ *
81
+ * @param args.message raw message data in HexInput format
82
+ * @param args.signature signed message Signature
83
+ * @returns
84
+ */
85
+ verifySignature(args) {
86
+ return this.publicKey.verifySignature(args);
87
+ }
88
+ /**
89
+ * Sign a message using the account's private key.
90
+ * @param message the signing message, as binary input
91
+ * @return the AccountAuthenticator containing the signature, together with the account's public key
92
+ */
93
+ signWithAuthenticator(message) {
94
+ return new AccountAuthenticatorSingleKey(this.publicKey, this.sign(message));
95
+ }
96
+ /**
97
+ * Sign a transaction using the account's private key.
98
+ * @param transaction the raw transaction
99
+ * @return the AccountAuthenticator containing the signature of the transaction, together with the account's public key
100
+ */
101
+ signTransactionWithAuthenticator(transaction) {
102
+ return new AccountAuthenticatorSingleKey(this.publicKey, this.signTransaction(transaction));
103
+ }
104
+ /**
105
+ * Sign the given message using the account's private key.
106
+ * @param message in HexInput format
107
+ * @returns Signature
108
+ */
109
+ sign(message) {
110
+ return new AnySignature(this.privateKey.sign(message));
111
+ }
112
+ /**
113
+ * Sign the given transaction using the account's private key.
114
+ * @param transaction the transaction to be signed
115
+ * @returns Signature
116
+ */
117
+ signTransaction(transaction) {
118
+ return this.sign(generateSigningMessageForTransaction(transaction));
119
+ }
120
+ // endregion
121
+ };
122
+
123
+ export {
124
+ SingleKeyAccount
125
+ };
126
+ //# sourceMappingURL=chunk-JHDHNGJ3.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/account/SingleKeyAccount.ts"],"sourcesContent":["import { AccountAuthenticatorSingleKey } from \"../transactions/authenticator/account\";\nimport { type HexInput, SigningScheme, SigningSchemeInput } from \"../types\";\nimport { AccountAddress, AccountAddressInput } from \"../core/accountAddress\";\nimport { AnyPublicKey, AnySignature, Ed25519PrivateKey, PrivateKey, Secp256k1PrivateKey } from \"../core/crypto\";\nimport type { Account } from \"./Account\";\nimport { generateSigningMessageForTransaction } from \"../transactions/transactionBuilder/signingMessage\";\nimport { AnyRawTransaction } from \"../transactions/types\";\n\nexport interface SingleKeySignerConstructorArgs {\n privateKey: PrivateKey;\n address?: AccountAddressInput;\n}\n\nexport interface SingleKeySignerGenerateArgs {\n scheme?: SigningSchemeInput;\n}\n\nexport type SingleKeySignerFromDerivationPathArgs = SingleKeySignerGenerateArgs & {\n path: string;\n mnemonic: string;\n};\n\nexport interface VerifySingleKeySignatureArgs {\n message: HexInput;\n signature: AnySignature;\n}\n\n/**\n * Signer implementation for the SingleKey authentication scheme.\n * This extends a SingleKeyAccount by adding signing capabilities through a valid private key.\n * Currently, the only supported signature schemes are Ed25519 and Secp256k1.\n *\n * Note: Generating a signer instance does not create the account on-chain.\n */\nexport class SingleKeyAccount implements Account {\n /**\n * Private key associated with the account\n */\n readonly privateKey: PrivateKey;\n\n readonly publicKey: AnyPublicKey;\n\n readonly accountAddress: AccountAddress;\n\n readonly signingScheme = SigningScheme.SingleKey;\n\n // region Constructors\n\n constructor(args: SingleKeySignerConstructorArgs) {\n const { privateKey, address } = args;\n this.privateKey = privateKey;\n this.publicKey = new AnyPublicKey(privateKey.publicKey());\n this.accountAddress = address ? AccountAddress.from(address) : this.publicKey.authKey().derivedAddress();\n }\n\n /**\n * Derives an account from a randomly generated private key.\n * Default generation is using an Ed25519 key\n * @returns Account with the given signature scheme\n */\n static generate(args: SingleKeySignerGenerateArgs = {}) {\n const { scheme = SigningSchemeInput.Ed25519 } = args;\n let privateKey: PrivateKey;\n switch (scheme) {\n case SigningSchemeInput.Ed25519:\n privateKey = Ed25519PrivateKey.generate();\n break;\n case SigningSchemeInput.Secp256k1Ecdsa:\n privateKey = Secp256k1PrivateKey.generate();\n break;\n default:\n throw new Error(`Unsupported signature scheme ${scheme}`);\n }\n return new SingleKeyAccount({ privateKey });\n }\n\n /**\n * Derives an account with bip44 path and mnemonics,\n * Default to using an Ed25519 signature scheme.\n *\n * @param args.scheme The signature scheme to derive the private key with\n * @param args.path the BIP44 derive hardened path (e.g. m/44'/637'/0'/0'/0') for Ed25519,\n * or non-hardened path (e.g. m/44'/637'/0'/0/0) for secp256k1\n * Detailed description: {@link https://github.com/bitcoin/bips/blob/master/bip-0044.mediawiki}\n * @param args.mnemonic the mnemonic seed phrase of the account\n */\n static fromDerivationPath(args: SingleKeySignerFromDerivationPathArgs) {\n const { scheme = SigningSchemeInput.Ed25519, path, mnemonic } = args;\n let privateKey: PrivateKey;\n switch (scheme) {\n case SigningSchemeInput.Ed25519:\n privateKey = Ed25519PrivateKey.fromDerivationPath(path, mnemonic);\n break;\n case SigningSchemeInput.Secp256k1Ecdsa:\n privateKey = Secp256k1PrivateKey.fromDerivationPath(path, mnemonic);\n break;\n default:\n throw new Error(`Unsupported signature scheme ${scheme}`);\n }\n return new SingleKeyAccount({ privateKey });\n }\n\n // endregion\n\n // region Account\n\n /**\n * Verify the given message and signature with the public key.\n *\n * @param args.message raw message data in HexInput format\n * @param args.signature signed message Signature\n * @returns\n */\n verifySignature(args: VerifySingleKeySignatureArgs): boolean {\n return this.publicKey.verifySignature(args);\n }\n\n /**\n * Sign a message using the account's private key.\n * @param message the signing message, as binary input\n * @return the AccountAuthenticator containing the signature, together with the account's public key\n */\n signWithAuthenticator(message: HexInput): AccountAuthenticatorSingleKey {\n return new AccountAuthenticatorSingleKey(this.publicKey, this.sign(message));\n }\n\n /**\n * Sign a transaction using the account's private key.\n * @param transaction the raw transaction\n * @return the AccountAuthenticator containing the signature of the transaction, together with the account's public key\n */\n signTransactionWithAuthenticator(transaction: AnyRawTransaction): AccountAuthenticatorSingleKey {\n return new AccountAuthenticatorSingleKey(this.publicKey, this.signTransaction(transaction));\n }\n\n /**\n * Sign the given message using the account's private key.\n * @param message in HexInput format\n * @returns Signature\n */\n sign(message: HexInput): AnySignature {\n return new AnySignature(this.privateKey.sign(message));\n }\n\n /**\n * Sign the given transaction using the account's private key.\n * @param transaction the transaction to be signed\n * @returns Signature\n */\n signTransaction(transaction: AnyRawTransaction): AnySignature {\n return this.sign(generateSigningMessageForTransaction(transaction));\n }\n\n // endregion\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;AAkCO,IAAM,mBAAN,MAAM,kBAAoC;AAAA;AAAA,EAc/C,YAAY,MAAsC;AAJlD,SAAS;AAKP,UAAM,EAAE,YAAY,QAAQ,IAAI;AAChC,SAAK,aAAa;AAClB,SAAK,YAAY,IAAI,aAAa,WAAW,UAAU,CAAC;AACxD,SAAK,iBAAiB,UAAU,eAAe,KAAK,OAAO,IAAI,KAAK,UAAU,QAAQ,EAAE,eAAe;AAAA,EACzG;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,OAAO,SAAS,OAAoC,CAAC,GAAG;AACtD,UAAM,EAAE,yBAAoC,IAAI;AAChD,QAAI;AACJ,YAAQ,QAAQ;AAAA,MACd;AACE,qBAAa,kBAAkB,SAAS;AACxC;AAAA,MACF;AACE,qBAAa,oBAAoB,SAAS;AAC1C;AAAA,MACF;AACE,cAAM,IAAI,MAAM,gCAAgC,MAAM,EAAE;AAAA,IAC5D;AACA,WAAO,IAAI,kBAAiB,EAAE,WAAW,CAAC;AAAA,EAC5C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAYA,OAAO,mBAAmB,MAA6C;AACrE,UAAM,EAAE,0BAAqC,MAAM,SAAS,IAAI;AAChE,QAAI;AACJ,YAAQ,QAAQ;AAAA,MACd;AACE,qBAAa,kBAAkB,mBAAmB,MAAM,QAAQ;AAChE;AAAA,MACF;AACE,qBAAa,oBAAoB,mBAAmB,MAAM,QAAQ;AAClE;AAAA,MACF;AACE,cAAM,IAAI,MAAM,gCAAgC,MAAM,EAAE;AAAA,IAC5D;AACA,WAAO,IAAI,kBAAiB,EAAE,WAAW,CAAC;AAAA,EAC5C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAaA,gBAAgB,MAA6C;AAC3D,WAAO,KAAK,UAAU,gBAAgB,IAAI;AAAA,EAC5C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,sBAAsB,SAAkD;AACtE,WAAO,IAAI,8BAA8B,KAAK,WAAW,KAAK,KAAK,OAAO,CAAC;AAAA,EAC7E;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,iCAAiC,aAA+D;AAC9F,WAAO,IAAI,8BAA8B,KAAK,WAAW,KAAK,gBAAgB,WAAW,CAAC;AAAA,EAC5F;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,KAAK,SAAiC;AACpC,WAAO,IAAI,aAAa,KAAK,WAAW,KAAK,OAAO,CAAC;AAAA,EACvD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,gBAAgB,aAA8C;AAC5D,WAAO,KAAK,KAAK,qCAAqC,WAAW,CAAC;AAAA,EACpE;AAAA;AAGF;","names":[]}
@@ -0,0 +1,49 @@
1
+ import {
2
+ Identifier
3
+ } from "./chunk-2TJJWII2.mjs";
4
+ import {
5
+ AccountAddress
6
+ } from "./chunk-CMNJG4NN.mjs";
7
+ import {
8
+ Serializable
9
+ } from "./chunk-FQQW55X7.mjs";
10
+
11
+ // src/transactions/instances/moduleId.ts
12
+ var ModuleId = class _ModuleId extends Serializable {
13
+ /**
14
+ * Full name of a module.
15
+ * @param address The account address. e.g "0x1"
16
+ * @param name The module name under the "address". e.g "coin"
17
+ */
18
+ constructor(address, name) {
19
+ super();
20
+ this.address = address;
21
+ this.name = name;
22
+ }
23
+ /**
24
+ * Converts a string literal to a ModuleId
25
+ * @param moduleId String literal in format "account_address::module_name", e.g. "0x1::coin"
26
+ * @returns ModuleId
27
+ */
28
+ static fromStr(moduleId) {
29
+ const parts = moduleId.split("::");
30
+ if (parts.length !== 2) {
31
+ throw new Error("Invalid module id.");
32
+ }
33
+ return new _ModuleId(AccountAddress.fromString(parts[0]), new Identifier(parts[1]));
34
+ }
35
+ serialize(serializer) {
36
+ this.address.serialize(serializer);
37
+ this.name.serialize(serializer);
38
+ }
39
+ static deserialize(deserializer) {
40
+ const address = AccountAddress.deserialize(deserializer);
41
+ const name = Identifier.deserialize(deserializer);
42
+ return new _ModuleId(address, name);
43
+ }
44
+ };
45
+
46
+ export {
47
+ ModuleId
48
+ };
49
+ //# sourceMappingURL=chunk-JL2JHVS4.mjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/transactions/instances/moduleId.ts"],"sourcesContent":["// Copyright © Aptos Foundation\n// SPDX-License-Identifier: Apache-2.0\n\nimport { Serializable, Serializer } from \"../../bcs/serializer\";\nimport { Deserializer } from \"../../bcs/deserializer\";\nimport { AccountAddress } from \"../../core\";\nimport { Identifier } from \"./identifier\";\nimport { MoveModuleId } from \"../../types\";\n\n/**\n * Representation of a ModuleId that can serialized and deserialized\n * ModuleId means the module address (e.g \"0x1\") and the module name (e.g \"coin\")\n */\nexport class ModuleId extends Serializable {\n public readonly address: AccountAddress;\n\n public readonly name: Identifier;\n\n /**\n * Full name of a module.\n * @param address The account address. e.g \"0x1\"\n * @param name The module name under the \"address\". e.g \"coin\"\n */\n constructor(address: AccountAddress, name: Identifier) {\n super();\n this.address = address;\n this.name = name;\n }\n\n /**\n * Converts a string literal to a ModuleId\n * @param moduleId String literal in format \"account_address::module_name\", e.g. \"0x1::coin\"\n * @returns ModuleId\n */\n static fromStr(moduleId: MoveModuleId): ModuleId {\n const parts = moduleId.split(\"::\");\n if (parts.length !== 2) {\n throw new Error(\"Invalid module id.\");\n }\n return new ModuleId(AccountAddress.fromString(parts[0]), new Identifier(parts[1]));\n }\n\n serialize(serializer: Serializer): void {\n this.address.serialize(serializer);\n this.name.serialize(serializer);\n }\n\n static deserialize(deserializer: Deserializer): ModuleId {\n const address = AccountAddress.deserialize(deserializer);\n const name = Identifier.deserialize(deserializer);\n return new ModuleId(address, name);\n }\n}\n"],"mappings":"2HAaO,IAAMA,EAAN,MAAMC,UAAiBC,CAAa,CAUzC,YAAYC,EAAyBC,EAAkB,CACrD,MAAM,EACN,KAAK,QAAUD,EACf,KAAK,KAAOC,CACd,CAOA,OAAO,QAAQC,EAAkC,CAC/C,IAAMC,EAAQD,EAAS,MAAM,IAAI,EACjC,GAAIC,EAAM,SAAW,EACnB,MAAM,IAAI,MAAM,oBAAoB,EAEtC,OAAO,IAAIL,EAASM,EAAe,WAAWD,EAAM,CAAC,CAAC,EAAG,IAAIE,EAAWF,EAAM,CAAC,CAAC,CAAC,CACnF,CAEA,UAAUG,EAA8B,CACtC,KAAK,QAAQ,UAAUA,CAAU,EACjC,KAAK,KAAK,UAAUA,CAAU,CAChC,CAEA,OAAO,YAAYC,EAAsC,CACvD,IAAMP,EAAUI,EAAe,YAAYG,CAAY,EACjDN,EAAOI,EAAW,YAAYE,CAAY,EAChD,OAAO,IAAIT,EAASE,EAASC,CAAI,CACnC,CACF","names":["ModuleId","_ModuleId","Serializable","address","name","moduleId","parts","AccountAddress","Identifier","serializer","deserializer"]}
1
+ {"version":3,"sources":["../../src/transactions/instances/moduleId.ts"],"sourcesContent":["// Copyright © Aptos Foundation\n// SPDX-License-Identifier: Apache-2.0\n\nimport { Serializable, Serializer } from \"../../bcs/serializer\";\nimport { Deserializer } from \"../../bcs/deserializer\";\nimport { AccountAddress } from \"../../core\";\nimport { Identifier } from \"./identifier\";\nimport { MoveModuleId } from \"../../types\";\n\n/**\n * Representation of a ModuleId that can serialized and deserialized\n * ModuleId means the module address (e.g \"0x1\") and the module name (e.g \"coin\")\n */\nexport class ModuleId extends Serializable {\n public readonly address: AccountAddress;\n\n public readonly name: Identifier;\n\n /**\n * Full name of a module.\n * @param address The account address. e.g \"0x1\"\n * @param name The module name under the \"address\". e.g \"coin\"\n */\n constructor(address: AccountAddress, name: Identifier) {\n super();\n this.address = address;\n this.name = name;\n }\n\n /**\n * Converts a string literal to a ModuleId\n * @param moduleId String literal in format \"account_address::module_name\", e.g. \"0x1::coin\"\n * @returns ModuleId\n */\n static fromStr(moduleId: MoveModuleId): ModuleId {\n const parts = moduleId.split(\"::\");\n if (parts.length !== 2) {\n throw new Error(\"Invalid module id.\");\n }\n return new ModuleId(AccountAddress.fromString(parts[0]), new Identifier(parts[1]));\n }\n\n serialize(serializer: Serializer): void {\n this.address.serialize(serializer);\n this.name.serialize(serializer);\n }\n\n static deserialize(deserializer: Deserializer): ModuleId {\n const address = AccountAddress.deserialize(deserializer);\n const name = Identifier.deserialize(deserializer);\n return new ModuleId(address, name);\n }\n}\n"],"mappings":";;;;;;;;;;;AAaO,IAAM,WAAN,MAAM,kBAAiB,aAAa;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAUzC,YAAY,SAAyB,MAAkB;AACrD,UAAM;AACN,SAAK,UAAU;AACf,SAAK,OAAO;AAAA,EACd;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,OAAO,QAAQ,UAAkC;AAC/C,UAAM,QAAQ,SAAS,MAAM,IAAI;AACjC,QAAI,MAAM,WAAW,GAAG;AACtB,YAAM,IAAI,MAAM,oBAAoB;AAAA,IACtC;AACA,WAAO,IAAI,UAAS,eAAe,WAAW,MAAM,CAAC,CAAC,GAAG,IAAI,WAAW,MAAM,CAAC,CAAC,CAAC;AAAA,EACnF;AAAA,EAEA,UAAU,YAA8B;AACtC,SAAK,QAAQ,UAAU,UAAU;AACjC,SAAK,KAAK,UAAU,UAAU;AAAA,EAChC;AAAA,EAEA,OAAO,YAAY,cAAsC;AACvD,UAAM,UAAU,eAAe,YAAY,YAAY;AACvD,UAAM,OAAO,WAAW,YAAY,YAAY;AAChD,WAAO,IAAI,UAAS,SAAS,IAAI;AAAA,EACnC;AACF;","names":[]}
@@ -0,0 +1,268 @@
1
+ import {
2
+ EphemeralKeyPair
3
+ } from "./chunk-LI2QV6RU.mjs";
4
+ import {
5
+ deriveTransactionType,
6
+ generateSigningMessageForSerializable
7
+ } from "./chunk-VJP2VWMF.mjs";
8
+ import {
9
+ AccountAuthenticatorSingleKey
10
+ } from "./chunk-IC56GQFJ.mjs";
11
+ import {
12
+ AnyPublicKey,
13
+ AnySignature
14
+ } from "./chunk-TLNHRJB2.mjs";
15
+ import {
16
+ EphemeralCertificate,
17
+ KeylessPublicKey,
18
+ KeylessSignature,
19
+ ZeroKnowledgeSig
20
+ } from "./chunk-4OYYOYSO.mjs";
21
+ import {
22
+ AccountAddress
23
+ } from "./chunk-CMNJG4NN.mjs";
24
+ import {
25
+ Deserializer
26
+ } from "./chunk-7JRMOHBP.mjs";
27
+ import {
28
+ Serializable
29
+ } from "./chunk-FQQW55X7.mjs";
30
+ import {
31
+ Hex
32
+ } from "./chunk-YV7M4CFP.mjs";
33
+
34
+ // src/account/KeylessAccount.ts
35
+ import { jwtDecode } from "jwt-decode";
36
+ import { JwksClient } from "jwks-rsa";
37
+ import { decode } from "base-64";
38
+ import EventEmitter from "eventemitter3";
39
+ var IssuerToJwkEndpoint = {
40
+ "https://accounts.google.com": "https://www.googleapis.com/oauth2/v3/certs"
41
+ };
42
+ var _KeylessAccount = class _KeylessAccount extends Serializable {
43
+ constructor(args) {
44
+ super();
45
+ const { address, ephemeralKeyPair, uidKey, uidVal, aud, pepper, proofOrFetcher, proofFetchCallback, jwt } = args;
46
+ this.ephemeralKeyPair = ephemeralKeyPair;
47
+ this.publicKey = KeylessPublicKey.create(args);
48
+ this.accountAddress = address ? AccountAddress.from(address) : this.publicKey.authKey().derivedAddress();
49
+ this.uidKey = uidKey;
50
+ this.uidVal = uidVal;
51
+ this.aud = aud;
52
+ this.jwt = jwt;
53
+ this.emitter = new EventEmitter();
54
+ this.proofOrPromise = proofOrFetcher;
55
+ if (proofOrFetcher instanceof ZeroKnowledgeSig) {
56
+ this.proof = proofOrFetcher;
57
+ } else {
58
+ if (proofFetchCallback === void 0) {
59
+ throw new Error("Must provide callback for async proof fetch");
60
+ }
61
+ this.emitter.on("proofFetchFinish", async (status) => {
62
+ await proofFetchCallback(status);
63
+ this.emitter.removeAllListeners();
64
+ });
65
+ this.init(proofOrFetcher);
66
+ }
67
+ this.signingScheme = 2 /* SingleKey */;
68
+ const pepperBytes = Hex.fromHexInput(pepper).toUint8Array();
69
+ if (pepperBytes.length !== _KeylessAccount.PEPPER_LENGTH) {
70
+ throw new Error(`Pepper length in bytes should be ${_KeylessAccount.PEPPER_LENGTH}`);
71
+ }
72
+ this.pepper = pepperBytes;
73
+ this.isJwtValid = true;
74
+ }
75
+ /**
76
+ * This initializes the asyncronous proof fetch
77
+ * @return
78
+ */
79
+ async init(promise) {
80
+ try {
81
+ this.proof = await promise;
82
+ this.emitter.emit("proofFetchFinish", { status: "Success" });
83
+ } catch (error) {
84
+ if (error instanceof Error) {
85
+ this.emitter.emit("proofFetchFinish", { status: "Failed", error: error.toString() });
86
+ } else {
87
+ this.emitter.emit("proofFetchFinish", { status: "Failed", error: "Unknown" });
88
+ }
89
+ }
90
+ }
91
+ serialize(serializer) {
92
+ serializer.serializeStr(this.jwt);
93
+ serializer.serializeStr(this.uidKey);
94
+ serializer.serializeFixedBytes(this.pepper);
95
+ this.ephemeralKeyPair.serialize(serializer);
96
+ if (this.proof === void 0) {
97
+ throw new Error("Connot serialize - proof undefined");
98
+ }
99
+ this.proof.serialize(serializer);
100
+ }
101
+ static deserialize(deserializer) {
102
+ const jwt = deserializer.deserializeStr();
103
+ const uidKey = deserializer.deserializeStr();
104
+ const pepper = deserializer.deserializeFixedBytes(31);
105
+ const ephemeralKeyPair = EphemeralKeyPair.deserialize(deserializer);
106
+ const proof = ZeroKnowledgeSig.deserialize(deserializer);
107
+ return _KeylessAccount.fromJWTAndProof({
108
+ proof,
109
+ pepper,
110
+ uidKey,
111
+ jwt,
112
+ ephemeralKeyPair
113
+ });
114
+ }
115
+ /**
116
+ * Checks if the proof is expired. If so the account must be rederived with a new EphemeralKeyPair
117
+ * and JWT token.
118
+ * @return boolean
119
+ */
120
+ isExpired() {
121
+ return this.ephemeralKeyPair.isExpired();
122
+ }
123
+ /**
124
+ * Checks if the the JWK used to verify the token still exists on the issuer's JWK uri.
125
+ * Caches the result.
126
+ * @return boolean
127
+ */
128
+ async checkJwkValidity() {
129
+ if (!this.isJwtValid) {
130
+ return false;
131
+ }
132
+ const jwtHeader = jwtDecode(this.jwt, { header: true });
133
+ const client = new JwksClient({
134
+ jwksUri: IssuerToJwkEndpoint[this.publicKey.iss]
135
+ });
136
+ try {
137
+ await client.getSigningKey(jwtHeader.kid);
138
+ return true;
139
+ } catch (error) {
140
+ this.isJwtValid = false;
141
+ return false;
142
+ }
143
+ }
144
+ /**
145
+ * Sign a message using Keyless.
146
+ * @param message the message to sign, as binary input
147
+ * @return the AccountAuthenticator containing the signature, together with the account's public key
148
+ */
149
+ signWithAuthenticator(message) {
150
+ const signature = new AnySignature(this.sign(message));
151
+ const publicKey = new AnyPublicKey(this.publicKey);
152
+ return new AccountAuthenticatorSingleKey(publicKey, signature);
153
+ }
154
+ /**
155
+ * Sign a transaction using Keyless.
156
+ * @param transaction the raw transaction
157
+ * @return the AccountAuthenticator containing the signature of the transaction, together with the account's public key
158
+ */
159
+ signTransactionWithAuthenticator(transaction) {
160
+ const signature = new AnySignature(this.signTransaction(transaction));
161
+ const publicKey = new AnyPublicKey(this.publicKey);
162
+ return new AccountAuthenticatorSingleKey(publicKey, signature);
163
+ }
164
+ /**
165
+ * Waits for asyncronous proof fetching to finish.
166
+ * @return
167
+ */
168
+ async waitForProofFetch() {
169
+ if (this.proofOrPromise instanceof Promise) {
170
+ await this.proofOrPromise;
171
+ }
172
+ }
173
+ /**
174
+ * Sign the given message using Keyless.
175
+ * @param message in HexInput format
176
+ * @returns Signature
177
+ */
178
+ sign(data) {
179
+ const { expiryDateSecs } = this.ephemeralKeyPair;
180
+ if (this.isExpired()) {
181
+ throw new Error("Ephemeral key pair is expired.");
182
+ }
183
+ if (this.proof === void 0) {
184
+ throw new Error("Proof not found");
185
+ }
186
+ if (!this.isJwtValid) {
187
+ throw new Error("The proof has expired. Please refetch proof");
188
+ }
189
+ const ephemeralPublicKey = this.ephemeralKeyPair.getPublicKey();
190
+ const ephemeralSignature = this.ephemeralKeyPair.sign(data);
191
+ return new KeylessSignature({
192
+ jwtHeader: base64UrlDecode(this.jwt.split(".")[0]),
193
+ ephemeralCertificate: new EphemeralCertificate(this.proof, 0 /* ZkProof */),
194
+ expiryDateSecs,
195
+ ephemeralPublicKey,
196
+ ephemeralSignature
197
+ });
198
+ }
199
+ /**
200
+ * Sign the given transaction with Keyless.
201
+ * Signs the transaction and proof to guard against proof malleability.
202
+ * @param transaction the transaction to be signed
203
+ * @returns KeylessSignature
204
+ */
205
+ signTransaction(transaction) {
206
+ if (this.proof === void 0) {
207
+ throw new Error("Proof not found");
208
+ }
209
+ const raw = deriveTransactionType(transaction);
210
+ const txnAndProof = new TransactionAndProof(raw, this.proof.proof);
211
+ const signMess = generateSigningMessageForSerializable(txnAndProof);
212
+ return this.sign(signMess);
213
+ }
214
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars, class-methods-use-this
215
+ verifySignature(args) {
216
+ throw new Error("Not implemented");
217
+ }
218
+ static fromBytes(bytes) {
219
+ return _KeylessAccount.deserialize(new Deserializer(bytes));
220
+ }
221
+ static fromJWTAndProof(args) {
222
+ const { proof, jwt, ephemeralKeyPair, pepper, proofFetchCallback } = args;
223
+ const uidKey = args.uidKey ?? "sub";
224
+ const jwtPayload = jwtDecode(jwt);
225
+ const iss = jwtPayload.iss;
226
+ if (typeof jwtPayload.aud !== "string") {
227
+ throw new Error("aud was not found or an array of values");
228
+ }
229
+ const aud = jwtPayload.aud;
230
+ const uidVal = jwtPayload[uidKey];
231
+ return new _KeylessAccount({
232
+ proofOrFetcher: proof,
233
+ ephemeralKeyPair,
234
+ iss,
235
+ uidKey,
236
+ uidVal,
237
+ aud,
238
+ pepper,
239
+ jwt,
240
+ proofFetchCallback
241
+ });
242
+ }
243
+ };
244
+ _KeylessAccount.PEPPER_LENGTH = 31;
245
+ var KeylessAccount = _KeylessAccount;
246
+ var TransactionAndProof = class extends Serializable {
247
+ constructor(transaction, proof) {
248
+ super();
249
+ this.transaction = transaction;
250
+ this.proof = proof;
251
+ }
252
+ serialize(serializer) {
253
+ serializer.serializeFixedBytes(this.transaction.bcsToBytes());
254
+ serializer.serializeOption(this.proof);
255
+ }
256
+ };
257
+ function base64UrlDecode(base64Url) {
258
+ const base64 = base64Url.replace(/-/g, "+").replace(/_/g, "/");
259
+ const paddedBase64 = base64 + "==".substring(0, (3 - base64.length % 3) % 3);
260
+ const decodedString = decode(paddedBase64);
261
+ return decodedString;
262
+ }
263
+
264
+ export {
265
+ IssuerToJwkEndpoint,
266
+ KeylessAccount
267
+ };
268
+ //# sourceMappingURL=chunk-JV3GSIJW.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/account/KeylessAccount.ts"],"sourcesContent":["// Copyright © Aptos Foundation\n// SPDX-License-Identifier: Apache-2.0\n\nimport { JwtPayload, jwtDecode } from \"jwt-decode\";\nimport { JwksClient } from \"jwks-rsa\";\nimport { decode } from \"base-64\";\nimport EventEmitter from \"eventemitter3\";\nimport { EphemeralCertificateVariant, HexInput, SigningScheme } from \"../types\";\nimport { AccountAddress } from \"../core/accountAddress\";\nimport {\n AnyPublicKey,\n AnySignature,\n KeylessPublicKey,\n KeylessSignature,\n EphemeralCertificate,\n Signature,\n ZeroKnowledgeSig,\n ZkProof,\n} from \"../core/crypto\";\n\nimport { Account } from \"./Account\";\nimport { EphemeralKeyPair } from \"./EphemeralKeyPair\";\nimport { Hex } from \"../core/hex\";\nimport { AccountAuthenticatorSingleKey } from \"../transactions/authenticator/account\";\nimport { Deserializer, Serializable, Serializer } from \"../bcs\";\nimport {\n deriveTransactionType,\n generateSigningMessageForSerializable,\n} from \"../transactions/transactionBuilder/signingMessage\";\nimport { AnyRawTransaction, AnyRawTransactionInstance } from \"../transactions/types\";\n\nexport const IssuerToJwkEndpoint: Record<string, string> = {\n \"https://accounts.google.com\": \"https://www.googleapis.com/oauth2/v3/certs\",\n};\n\nexport class KeylessAccount extends Serializable implements Account {\n static readonly PEPPER_LENGTH: number = 31;\n\n readonly publicKey: KeylessPublicKey;\n\n readonly ephemeralKeyPair: EphemeralKeyPair;\n\n readonly uidKey: string;\n\n readonly uidVal: string;\n\n readonly aud: string;\n\n readonly pepper: Uint8Array;\n\n readonly accountAddress: AccountAddress;\n\n proof: ZeroKnowledgeSig | undefined;\n\n readonly proofOrPromise: ZeroKnowledgeSig | Promise<ZeroKnowledgeSig>;\n\n readonly signingScheme: SigningScheme;\n\n private jwt: string;\n\n private isJwtValid: boolean;\n\n readonly emitter: EventEmitter<ProofFetchEvents>;\n\n constructor(args: {\n address?: AccountAddress;\n ephemeralKeyPair: EphemeralKeyPair;\n iss: string;\n uidKey: string;\n uidVal: string;\n aud: string;\n pepper: HexInput;\n proofOrFetcher: ZeroKnowledgeSig | Promise<ZeroKnowledgeSig>;\n proofFetchCallback?: ProofFetchCallback;\n jwt: string;\n }) {\n super();\n const { address, ephemeralKeyPair, uidKey, uidVal, aud, pepper, proofOrFetcher, proofFetchCallback, jwt } = args;\n this.ephemeralKeyPair = ephemeralKeyPair;\n this.publicKey = KeylessPublicKey.create(args);\n this.accountAddress = address ? AccountAddress.from(address) : this.publicKey.authKey().derivedAddress();\n this.uidKey = uidKey;\n this.uidVal = uidVal;\n this.aud = aud;\n this.jwt = jwt;\n this.emitter = new EventEmitter<ProofFetchEvents>();\n this.proofOrPromise = proofOrFetcher;\n if (proofOrFetcher instanceof ZeroKnowledgeSig) {\n this.proof = proofOrFetcher;\n } else {\n if (proofFetchCallback === undefined) {\n throw new Error(\"Must provide callback for async proof fetch\");\n }\n this.emitter.on(\"proofFetchFinish\", async (status) => {\n await proofFetchCallback(status);\n this.emitter.removeAllListeners();\n });\n this.init(proofOrFetcher);\n }\n this.signingScheme = SigningScheme.SingleKey;\n const pepperBytes = Hex.fromHexInput(pepper).toUint8Array();\n if (pepperBytes.length !== KeylessAccount.PEPPER_LENGTH) {\n throw new Error(`Pepper length in bytes should be ${KeylessAccount.PEPPER_LENGTH}`);\n }\n this.pepper = pepperBytes;\n this.isJwtValid = true;\n }\n\n /**\n * This initializes the asyncronous proof fetch\n * @return\n */\n async init(promise: Promise<ZeroKnowledgeSig>) {\n try {\n this.proof = await promise;\n this.emitter.emit(\"proofFetchFinish\", { status: \"Success\" });\n } catch (error) {\n if (error instanceof Error) {\n this.emitter.emit(\"proofFetchFinish\", { status: \"Failed\", error: error.toString() });\n } else {\n this.emitter.emit(\"proofFetchFinish\", { status: \"Failed\", error: \"Unknown\" });\n }\n }\n }\n\n serialize(serializer: Serializer): void {\n serializer.serializeStr(this.jwt);\n serializer.serializeStr(this.uidKey);\n serializer.serializeFixedBytes(this.pepper);\n this.ephemeralKeyPair.serialize(serializer);\n if (this.proof === undefined) {\n throw new Error(\"Connot serialize - proof undefined\");\n }\n this.proof.serialize(serializer);\n }\n\n static deserialize(deserializer: Deserializer): KeylessAccount {\n const jwt = deserializer.deserializeStr();\n const uidKey = deserializer.deserializeStr();\n const pepper = deserializer.deserializeFixedBytes(31);\n const ephemeralKeyPair = EphemeralKeyPair.deserialize(deserializer);\n const proof = ZeroKnowledgeSig.deserialize(deserializer);\n return KeylessAccount.fromJWTAndProof({\n proof,\n pepper,\n uidKey,\n jwt,\n ephemeralKeyPair,\n });\n }\n\n /**\n * Checks if the proof is expired. If so the account must be rederived with a new EphemeralKeyPair\n * and JWT token.\n * @return boolean\n */\n isExpired(): boolean {\n return this.ephemeralKeyPair.isExpired();\n }\n\n /**\n * Checks if the the JWK used to verify the token still exists on the issuer's JWK uri.\n * Caches the result.\n * @return boolean\n */\n async checkJwkValidity(): Promise<boolean> {\n if (!this.isJwtValid) {\n return false;\n }\n const jwtHeader = jwtDecode(this.jwt, { header: true });\n const client = new JwksClient({\n jwksUri: IssuerToJwkEndpoint[this.publicKey.iss],\n });\n try {\n await client.getSigningKey(jwtHeader.kid);\n return true;\n } catch (error) {\n this.isJwtValid = false;\n return false;\n }\n }\n\n /**\n * Sign a message using Keyless.\n * @param message the message to sign, as binary input\n * @return the AccountAuthenticator containing the signature, together with the account's public key\n */\n signWithAuthenticator(message: HexInput): AccountAuthenticatorSingleKey {\n const signature = new AnySignature(this.sign(message));\n const publicKey = new AnyPublicKey(this.publicKey);\n return new AccountAuthenticatorSingleKey(publicKey, signature);\n }\n\n /**\n * Sign a transaction using Keyless.\n * @param transaction the raw transaction\n * @return the AccountAuthenticator containing the signature of the transaction, together with the account's public key\n */\n signTransactionWithAuthenticator(transaction: AnyRawTransaction): AccountAuthenticatorSingleKey {\n const signature = new AnySignature(this.signTransaction(transaction));\n const publicKey = new AnyPublicKey(this.publicKey);\n return new AccountAuthenticatorSingleKey(publicKey, signature);\n }\n\n /**\n * Waits for asyncronous proof fetching to finish.\n * @return\n */\n async waitForProofFetch() {\n if (this.proofOrPromise instanceof Promise) {\n await this.proofOrPromise;\n }\n }\n\n /**\n * Sign the given message using Keyless.\n * @param message in HexInput format\n * @returns Signature\n */\n sign(data: HexInput): KeylessSignature {\n const { expiryDateSecs } = this.ephemeralKeyPair;\n if (this.isExpired()) {\n throw new Error(\"Ephemeral key pair is expired.\");\n }\n if (this.proof === undefined) {\n throw new Error(\"Proof not found\");\n }\n if (!this.isJwtValid) {\n throw new Error(\"The proof has expired. Please refetch proof\");\n }\n const ephemeralPublicKey = this.ephemeralKeyPair.getPublicKey();\n const ephemeralSignature = this.ephemeralKeyPair.sign(data);\n\n return new KeylessSignature({\n jwtHeader: base64UrlDecode(this.jwt.split(\".\")[0]),\n ephemeralCertificate: new EphemeralCertificate(this.proof, EphemeralCertificateVariant.ZkProof),\n expiryDateSecs,\n ephemeralPublicKey,\n ephemeralSignature,\n });\n }\n\n /**\n * Sign the given transaction with Keyless.\n * Signs the transaction and proof to guard against proof malleability.\n * @param transaction the transaction to be signed\n * @returns KeylessSignature\n */\n signTransaction(transaction: AnyRawTransaction): KeylessSignature {\n if (this.proof === undefined) {\n throw new Error(\"Proof not found\");\n }\n const raw = deriveTransactionType(transaction);\n const txnAndProof = new TransactionAndProof(raw, this.proof.proof);\n const signMess = generateSigningMessageForSerializable(txnAndProof);\n return this.sign(signMess);\n }\n\n // eslint-disable-next-line @typescript-eslint/no-unused-vars, class-methods-use-this\n verifySignature(args: { message: HexInput; signature: Signature }): boolean {\n throw new Error(\"Not implemented\");\n }\n\n static fromBytes(bytes: Uint8Array): KeylessAccount {\n return KeylessAccount.deserialize(new Deserializer(bytes));\n }\n\n static fromJWTAndProof(args: {\n proof: ZeroKnowledgeSig | Promise<ZeroKnowledgeSig>;\n jwt: string;\n ephemeralKeyPair: EphemeralKeyPair;\n pepper: HexInput;\n uidKey?: string;\n proofFetchCallback?: ProofFetchCallback;\n }): KeylessAccount {\n const { proof, jwt, ephemeralKeyPair, pepper, proofFetchCallback } = args;\n const uidKey = args.uidKey ?? \"sub\";\n\n const jwtPayload = jwtDecode<JwtPayload & { [key: string]: string }>(jwt);\n const iss = jwtPayload.iss!;\n if (typeof jwtPayload.aud !== \"string\") {\n throw new Error(\"aud was not found or an array of values\");\n }\n const aud = jwtPayload.aud!;\n const uidVal = jwtPayload[uidKey];\n return new KeylessAccount({\n proofOrFetcher: proof,\n ephemeralKeyPair,\n iss,\n uidKey,\n uidVal,\n aud,\n pepper,\n jwt,\n proofFetchCallback,\n });\n }\n}\n\nclass TransactionAndProof extends Serializable {\n transaction: AnyRawTransactionInstance;\n\n proof?: ZkProof;\n\n constructor(transaction: AnyRawTransactionInstance, proof?: ZkProof) {\n super();\n this.transaction = transaction;\n this.proof = proof;\n }\n\n serialize(serializer: Serializer): void {\n serializer.serializeFixedBytes(this.transaction.bcsToBytes());\n serializer.serializeOption(this.proof);\n }\n}\n\nfunction base64UrlDecode(base64Url: string): string {\n // Replace base64url-specific characters\n const base64 = base64Url.replace(/-/g, \"+\").replace(/_/g, \"/\");\n // Pad the string with '=' characters if needed\n const paddedBase64 = base64 + \"==\".substring(0, (3 - (base64.length % 3)) % 3);\n // Decode the base64 string using the base-64 library\n const decodedString = decode(paddedBase64);\n return decodedString;\n}\n\nexport type ProofFetchSuccess = {\n status: \"Success\";\n};\n\nexport type ProofFetchFailure = {\n status: \"Failed\";\n error: string;\n};\n\nexport type ProofFetchStatus = ProofFetchSuccess | ProofFetchFailure;\n\nexport type ProofFetchCallback = (status: ProofFetchStatus) => Promise<void>;\n\nexport interface ProofFetchEvents {\n proofFetchFinish: (status: ProofFetchStatus) => void;\n}\n"],"mappings":"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","names":[]}
@@ -0,0 +1 @@
1
+ //# sourceMappingURL=chunk-JXCZTOYC.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
@@ -0,0 +1,32 @@
1
+ import {
2
+ Serializable
3
+ } from "./chunk-FQQW55X7.mjs";
4
+ import {
5
+ Hex
6
+ } from "./chunk-YV7M4CFP.mjs";
7
+
8
+ // src/bcs/serializable/fixedBytes.ts
9
+ var FixedBytes = class _FixedBytes extends Serializable {
10
+ constructor(value) {
11
+ super();
12
+ this.value = Hex.fromHexInput(value).toUint8Array();
13
+ }
14
+ serialize(serializer) {
15
+ serializer.serializeFixedBytes(this.value);
16
+ }
17
+ serializeForEntryFunction(serializer) {
18
+ serializer.serialize(this);
19
+ }
20
+ serializeForScriptFunction(serializer) {
21
+ serializer.serialize(this);
22
+ }
23
+ static deserialize(deserializer, length) {
24
+ const bytes = deserializer.deserializeFixedBytes(length);
25
+ return new _FixedBytes(bytes);
26
+ }
27
+ };
28
+
29
+ export {
30
+ FixedBytes
31
+ };
32
+ //# sourceMappingURL=chunk-KK2BSALW.mjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/bcs/serializable/fixedBytes.ts"],"sourcesContent":["// Copyright © Aptos Foundation\n// SPDX-License-Identifier: Apache-2.0\n\nimport { Serializer, Serializable } from \"../serializer\";\nimport { Deserializer } from \"../deserializer\";\nimport { HexInput } from \"../../types\";\nimport { Hex } from \"../../core/hex\";\nimport { TransactionArgument } from \"../../transactions/instances/transactionArgument\";\n\n/**\n * This class exists to represent a contiguous sequence of already serialized BCS-bytes.\n *\n * It differs from most other Serializable classes in that its internal byte buffer is serialized to BCS\n * bytes exactly as-is, without prepending the length of the bytes.\n *\n * If you want to write your own serialization function and pass the bytes as a transaction argument,\n * you should use this class.\n *\n * This class is also more generally used to represent type-agnostic BCS bytes as a vector<u8>.\n *\n * An example of this is the bytes resulting from entry function arguments that have been serialized\n * for an entry function.\n *\n * @example\n * const yourCustomSerializedBytes = new Uint8Array([1, 2, 3, 4, 5, 6, 7, 8]);\n * const fixedBytes = new FixedBytes(yourCustomSerializedBytes);\n * const payload = await generateTransactionPayload({\n * function: \"0xbeefcafe::your_module::your_function_that_requires_custom_serialization\",\n * functionArguments: [yourCustomBytes],\n * });\n *\n * For example, if you store each of the 32 bytes for an address as a U8 in a MoveVector<U8>, when you\n * serialize that MoveVector<U8>, it will be serialized to 33 bytes. If you solely want to pass around\n * the 32 bytes as a Serializable class that *does not* prepend the length to the BCS-serialized representation,\n * use this class.\n *\n * @params value: HexInput representing a sequence of Uint8 bytes\n * @returns a Serializable FixedBytes instance, which when serialized, does not prepend the length of the bytes\n * @see EntryFunctionBytes\n */\nexport class FixedBytes extends Serializable implements TransactionArgument {\n public value: Uint8Array;\n\n constructor(value: HexInput) {\n super();\n this.value = Hex.fromHexInput(value).toUint8Array();\n }\n\n serialize(serializer: Serializer): void {\n serializer.serializeFixedBytes(this.value);\n }\n\n serializeForEntryFunction(serializer: Serializer): void {\n serializer.serialize(this);\n }\n\n serializeForScriptFunction(serializer: Serializer): void {\n serializer.serialize(this);\n }\n\n static deserialize(deserializer: Deserializer, length: number): FixedBytes {\n const bytes = deserializer.deserializeFixedBytes(length);\n return new FixedBytes(bytes);\n }\n}\n"],"mappings":"kFAwCO,IAAMA,EAAN,MAAMC,UAAmBC,CAA4C,CAG1E,YAAYC,EAAiB,CAC3B,MAAM,EACN,KAAK,MAAQC,EAAI,aAAaD,CAAK,EAAE,aAAa,CACpD,CAEA,UAAUE,EAA8B,CACtCA,EAAW,oBAAoB,KAAK,KAAK,CAC3C,CAEA,0BAA0BA,EAA8B,CACtDA,EAAW,UAAU,IAAI,CAC3B,CAEA,2BAA2BA,EAA8B,CACvDA,EAAW,UAAU,IAAI,CAC3B,CAEA,OAAO,YAAYC,EAA4BC,EAA4B,CACzE,IAAMC,EAAQF,EAAa,sBAAsBC,CAAM,EACvD,OAAO,IAAIN,EAAWO,CAAK,CAC7B,CACF","names":["FixedBytes","_FixedBytes","Serializable","value","Hex","serializer","deserializer","length","bytes"]}
1
+ {"version":3,"sources":["../../src/bcs/serializable/fixedBytes.ts"],"sourcesContent":["// Copyright © Aptos Foundation\n// SPDX-License-Identifier: Apache-2.0\n\nimport { Serializer, Serializable } from \"../serializer\";\nimport { Deserializer } from \"../deserializer\";\nimport { HexInput } from \"../../types\";\nimport { Hex } from \"../../core/hex\";\nimport { TransactionArgument } from \"../../transactions/instances/transactionArgument\";\n\n/**\n * This class exists to represent a contiguous sequence of already serialized BCS-bytes.\n *\n * It differs from most other Serializable classes in that its internal byte buffer is serialized to BCS\n * bytes exactly as-is, without prepending the length of the bytes.\n *\n * If you want to write your own serialization function and pass the bytes as a transaction argument,\n * you should use this class.\n *\n * This class is also more generally used to represent type-agnostic BCS bytes as a vector<u8>.\n *\n * An example of this is the bytes resulting from entry function arguments that have been serialized\n * for an entry function.\n *\n * @example\n * const yourCustomSerializedBytes = new Uint8Array([1, 2, 3, 4, 5, 6, 7, 8]);\n * const fixedBytes = new FixedBytes(yourCustomSerializedBytes);\n * const payload = await generateTransactionPayload({\n * function: \"0xbeefcafe::your_module::your_function_that_requires_custom_serialization\",\n * functionArguments: [yourCustomBytes],\n * });\n *\n * For example, if you store each of the 32 bytes for an address as a U8 in a MoveVector<U8>, when you\n * serialize that MoveVector<U8>, it will be serialized to 33 bytes. If you solely want to pass around\n * the 32 bytes as a Serializable class that *does not* prepend the length to the BCS-serialized representation,\n * use this class.\n *\n * @params value: HexInput representing a sequence of Uint8 bytes\n * @returns a Serializable FixedBytes instance, which when serialized, does not prepend the length of the bytes\n * @see EntryFunctionBytes\n */\nexport class FixedBytes extends Serializable implements TransactionArgument {\n public value: Uint8Array;\n\n constructor(value: HexInput) {\n super();\n this.value = Hex.fromHexInput(value).toUint8Array();\n }\n\n serialize(serializer: Serializer): void {\n serializer.serializeFixedBytes(this.value);\n }\n\n serializeForEntryFunction(serializer: Serializer): void {\n serializer.serialize(this);\n }\n\n serializeForScriptFunction(serializer: Serializer): void {\n serializer.serialize(this);\n }\n\n static deserialize(deserializer: Deserializer, length: number): FixedBytes {\n const bytes = deserializer.deserializeFixedBytes(length);\n return new FixedBytes(bytes);\n }\n}\n"],"mappings":";;;;;;;;AAwCO,IAAM,aAAN,MAAM,oBAAmB,aAA4C;AAAA,EAG1E,YAAY,OAAiB;AAC3B,UAAM;AACN,SAAK,QAAQ,IAAI,aAAa,KAAK,EAAE,aAAa;AAAA,EACpD;AAAA,EAEA,UAAU,YAA8B;AACtC,eAAW,oBAAoB,KAAK,KAAK;AAAA,EAC3C;AAAA,EAEA,0BAA0B,YAA8B;AACtD,eAAW,UAAU,IAAI;AAAA,EAC3B;AAAA,EAEA,2BAA2B,YAA8B;AACvD,eAAW,UAAU,IAAI;AAAA,EAC3B;AAAA,EAEA,OAAO,YAAY,cAA4B,QAA4B;AACzE,UAAM,QAAQ,aAAa,sBAAsB,MAAM;AACvD,WAAO,IAAI,YAAW,KAAK;AAAA,EAC7B;AACF;","names":[]}