@algorandfoundation/algokit-utils 10.0.0-alpha.2 → 10.0.0-alpha.21

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 (462) hide show
  1. package/_virtual/rolldown_runtime.js +10 -15
  2. package/algo25/index.d.ts +2 -0
  3. package/algo25/index.js +9 -0
  4. package/algo25/index.mjs +3 -0
  5. package/algod-client/index.d.ts +3 -7
  6. package/algod-client/index.js +2 -5
  7. package/algod-client/index.mjs +2 -2
  8. package/index.d.ts +1 -2
  9. package/index.js +0 -7
  10. package/index.mjs +1 -2
  11. package/indexer-client/index.d.ts +2 -2
  12. package/indexer-client/index.js +6 -6
  13. package/indexer-client/index.mjs +2 -2
  14. package/{indexer-lookup.d.ts → indexer-client/indexer-lookup.d.ts} +8 -11
  15. package/{indexer-lookup.mjs → indexer-client/indexer-lookup.js} +6 -10
  16. package/indexer-client/indexer-lookup.js.map +1 -0
  17. package/{indexer-lookup.js → indexer-client/indexer-lookup.mjs} +3 -18
  18. package/indexer-client/indexer-lookup.mjs.map +1 -0
  19. package/kmd-client/index.d.ts +1 -2
  20. package/kmd-client/index.js +0 -5
  21. package/kmd-client/index.mjs +1 -2
  22. package/package.json +1 -6
  23. package/packages/abi/src/abi-method.d.ts +1 -1
  24. package/packages/abi/src/abi-method.js +1 -1
  25. package/packages/abi/src/abi-method.js.map +1 -1
  26. package/packages/abi/src/abi-method.mjs +1 -1
  27. package/packages/abi/src/abi-method.mjs.map +1 -1
  28. package/packages/abi/src/abi-type.d.ts +1 -1
  29. package/packages/abi/src/abi-type.js +4 -2
  30. package/packages/abi/src/abi-type.js.map +1 -1
  31. package/packages/abi/src/abi-type.mjs +4 -2
  32. package/packages/abi/src/abi-type.mjs.map +1 -1
  33. package/packages/abi/src/arc56-contract.js +1 -0
  34. package/packages/abi/src/arc56-contract.js.map +1 -1
  35. package/packages/abi/src/arc56-contract.mjs +1 -0
  36. package/packages/abi/src/arc56-contract.mjs.map +1 -1
  37. package/packages/algo25/src/index.d.ts +40 -0
  38. package/packages/algo25/src/index.js +45 -1
  39. package/packages/algo25/src/index.js.map +1 -1
  40. package/packages/algo25/src/index.mjs +40 -2
  41. package/packages/algo25/src/index.mjs.map +1 -1
  42. package/packages/algod_client/src/apis/api-service.d.ts +44 -44
  43. package/packages/algod_client/src/apis/api-service.js +155 -155
  44. package/packages/algod_client/src/apis/api-service.js.map +1 -1
  45. package/packages/algod_client/src/apis/api-service.mjs +155 -155
  46. package/packages/algod_client/src/apis/api-service.mjs.map +1 -1
  47. package/packages/algod_client/src/core/api-error.js +3 -1
  48. package/packages/algod_client/src/core/api-error.js.map +1 -1
  49. package/packages/algod_client/src/core/api-error.mjs +3 -1
  50. package/packages/algod_client/src/core/api-error.mjs.map +1 -1
  51. package/packages/algod_client/src/core/model-runtime.js +6 -6
  52. package/packages/algod_client/src/core/model-runtime.js.map +1 -1
  53. package/packages/algod_client/src/core/model-runtime.mjs +8 -8
  54. package/packages/algod_client/src/core/model-runtime.mjs.map +1 -1
  55. package/packages/algod_client/src/models/account-participation.js +4 -4
  56. package/packages/algod_client/src/models/account-participation.js.map +1 -1
  57. package/packages/algod_client/src/models/account-participation.mjs +4 -4
  58. package/packages/algod_client/src/models/account-participation.mjs.map +1 -1
  59. package/packages/algod_client/src/models/application-state-schema.d.ts +2 -2
  60. package/packages/algod_client/src/models/application-state-schema.js +2 -2
  61. package/packages/algod_client/src/models/application-state-schema.js.map +1 -1
  62. package/packages/algod_client/src/models/application-state-schema.mjs +2 -2
  63. package/packages/algod_client/src/models/application-state-schema.mjs.map +1 -1
  64. package/packages/algod_client/src/models/asset-params.js +2 -1
  65. package/packages/algod_client/src/models/asset-params.js.map +1 -1
  66. package/packages/algod_client/src/models/asset-params.mjs +2 -1
  67. package/packages/algod_client/src/models/asset-params.mjs.map +1 -1
  68. package/packages/algod_client/src/models/block-response.js +1 -2
  69. package/packages/algod_client/src/models/block-response.js.map +1 -1
  70. package/packages/algod_client/src/models/block-response.mjs +2 -3
  71. package/packages/algod_client/src/models/block-response.mjs.map +1 -1
  72. package/packages/algod_client/src/models/block.d.ts +60 -40
  73. package/packages/algod_client/src/models/block.js +184 -108
  74. package/packages/algod_client/src/models/block.js.map +1 -1
  75. package/packages/algod_client/src/models/block.mjs +184 -108
  76. package/packages/algod_client/src/models/block.mjs.map +1 -1
  77. package/packages/algod_client/src/models/ledger-state-delta.js +1 -1
  78. package/packages/algod_client/src/models/ledger-state-delta.js.map +1 -1
  79. package/packages/algod_client/src/models/ledger-state-delta.mjs +2 -2
  80. package/packages/algod_client/src/models/ledger-state-delta.mjs.map +1 -1
  81. package/packages/algod_client/src/models/simulate-request.js +1 -1
  82. package/packages/algod_client/src/models/simulate-request.mjs +1 -1
  83. package/packages/algod_client/src/models/simulate-response.d.ts +2 -1
  84. package/packages/algod_client/src/models/simulate-response.js +6 -1
  85. package/packages/algod_client/src/models/simulate-response.js.map +1 -1
  86. package/packages/algod_client/src/models/simulate-response.mjs +6 -2
  87. package/packages/algod_client/src/models/simulate-response.mjs.map +1 -1
  88. package/packages/algod_client/src/models/simulate-unnamed-resources-accessed.d.ts +3 -5
  89. package/packages/algod_client/src/models/simulate-unnamed-resources-accessed.js +4 -6
  90. package/packages/algod_client/src/models/simulate-unnamed-resources-accessed.js.map +1 -1
  91. package/packages/algod_client/src/models/simulate-unnamed-resources-accessed.mjs +3 -5
  92. package/packages/algod_client/src/models/simulate-unnamed-resources-accessed.mjs.map +1 -1
  93. package/packages/algod_client/src/models/transaction-parameters-response.js +2 -2
  94. package/packages/algod_client/src/models/transaction-parameters-response.js.map +1 -1
  95. package/packages/algod_client/src/models/transaction-parameters-response.mjs +2 -2
  96. package/packages/algod_client/src/models/transaction-parameters-response.mjs.map +1 -1
  97. package/packages/common/src/address.js +0 -14
  98. package/packages/common/src/address.js.map +1 -1
  99. package/packages/common/src/address.mjs +1 -14
  100. package/packages/common/src/address.mjs.map +1 -1
  101. package/packages/common/src/codecs/composite/map.js +7 -4
  102. package/packages/common/src/codecs/composite/map.js.map +1 -1
  103. package/packages/common/src/codecs/composite/map.mjs +7 -4
  104. package/packages/common/src/codecs/composite/map.mjs.map +1 -1
  105. package/packages/common/src/codecs/composite/record.js +0 -1
  106. package/packages/common/src/codecs/composite/record.js.map +1 -1
  107. package/packages/common/src/codecs/primitives/address.js +0 -1
  108. package/packages/common/src/codecs/primitives/address.js.map +1 -1
  109. package/packages/common/src/codecs/primitives/bytes.js +0 -1
  110. package/packages/common/src/codecs/primitives/bytes.js.map +1 -1
  111. package/packages/common/src/codecs/primitives/fixed-bytes.js +0 -1
  112. package/packages/common/src/codecs/primitives/fixed-bytes.js.map +1 -1
  113. package/packages/common/src/codecs/wire.js +0 -1
  114. package/packages/common/src/codecs/wire.js.map +1 -1
  115. package/packages/common/src/json.mjs +2 -2
  116. package/packages/common/src/json.mjs.map +1 -1
  117. package/packages/common/src/msgpack.js +0 -1
  118. package/packages/common/src/msgpack.js.map +1 -1
  119. package/packages/{sdk/src/logic → common/src}/sourcemap.d.ts +2 -2
  120. package/packages/{sdk/src/logic → common/src}/sourcemap.js +2 -2
  121. package/packages/{sdk/src/logic → common/src}/sourcemap.js.map +1 -1
  122. package/packages/{sdk/src/logic → common/src}/sourcemap.mjs +1 -1
  123. package/packages/{sdk/src/logic → common/src}/sourcemap.mjs.map +1 -1
  124. package/packages/indexer_client/src/apis/api-service.d.ts +1 -1
  125. package/packages/indexer_client/src/apis/api-service.js +12 -12
  126. package/packages/indexer_client/src/apis/api-service.js.map +1 -1
  127. package/packages/indexer_client/src/apis/api-service.mjs +12 -12
  128. package/packages/indexer_client/src/apis/api-service.mjs.map +1 -1
  129. package/packages/indexer_client/src/core/api-error.js +3 -1
  130. package/packages/indexer_client/src/core/api-error.js.map +1 -1
  131. package/packages/indexer_client/src/core/api-error.mjs +3 -1
  132. package/packages/indexer_client/src/core/api-error.mjs.map +1 -1
  133. package/packages/indexer_client/src/core/model-runtime.js +0 -15
  134. package/packages/indexer_client/src/core/model-runtime.js.map +1 -1
  135. package/packages/indexer_client/src/core/model-runtime.mjs +1 -13
  136. package/packages/indexer_client/src/core/model-runtime.mjs.map +1 -1
  137. package/packages/indexer_client/src/models/account-participation.js +4 -4
  138. package/packages/indexer_client/src/models/account-participation.js.map +1 -1
  139. package/packages/indexer_client/src/models/account-participation.mjs +4 -4
  140. package/packages/indexer_client/src/models/account-participation.mjs.map +1 -1
  141. package/packages/indexer_client/src/models/application-state-schema.d.ts +2 -2
  142. package/packages/indexer_client/src/models/application-state-schema.js +2 -2
  143. package/packages/indexer_client/src/models/application-state-schema.js.map +1 -1
  144. package/packages/indexer_client/src/models/application-state-schema.mjs +2 -2
  145. package/packages/indexer_client/src/models/application-state-schema.mjs.map +1 -1
  146. package/packages/indexer_client/src/models/asset-params.js +2 -1
  147. package/packages/indexer_client/src/models/asset-params.js.map +1 -1
  148. package/packages/indexer_client/src/models/asset-params.mjs +2 -1
  149. package/packages/indexer_client/src/models/asset-params.mjs.map +1 -1
  150. package/packages/indexer_client/src/models/block.d.ts +5 -5
  151. package/packages/indexer_client/src/models/block.js +13 -13
  152. package/packages/indexer_client/src/models/block.js.map +1 -1
  153. package/packages/indexer_client/src/models/block.mjs +13 -13
  154. package/packages/indexer_client/src/models/block.mjs.map +1 -1
  155. package/packages/indexer_client/src/models/eval-delta-key-value.d.ts +1 -1
  156. package/packages/indexer_client/src/models/eval-delta-key-value.js +2 -2
  157. package/packages/indexer_client/src/models/eval-delta-key-value.js.map +1 -1
  158. package/packages/indexer_client/src/models/eval-delta-key-value.mjs +2 -2
  159. package/packages/indexer_client/src/models/eval-delta-key-value.mjs.map +1 -1
  160. package/packages/indexer_client/src/models/eval-delta.d.ts +1 -1
  161. package/packages/indexer_client/src/models/eval-delta.js +2 -2
  162. package/packages/indexer_client/src/models/eval-delta.js.map +1 -1
  163. package/packages/indexer_client/src/models/eval-delta.mjs +2 -2
  164. package/packages/indexer_client/src/models/eval-delta.mjs.map +1 -1
  165. package/packages/indexer_client/src/models/hb-proof-fields.js +6 -6
  166. package/packages/indexer_client/src/models/hb-proof-fields.js.map +1 -1
  167. package/packages/indexer_client/src/models/hb-proof-fields.mjs +6 -6
  168. package/packages/indexer_client/src/models/hb-proof-fields.mjs.map +1 -1
  169. package/packages/indexer_client/src/models/participation-updates.d.ts +2 -2
  170. package/packages/indexer_client/src/models/participation-updates.js +2 -2
  171. package/packages/indexer_client/src/models/participation-updates.js.map +1 -1
  172. package/packages/indexer_client/src/models/participation-updates.mjs +2 -2
  173. package/packages/indexer_client/src/models/participation-updates.mjs.map +1 -1
  174. package/packages/indexer_client/src/models/state-proof-verifier.js +2 -2
  175. package/packages/indexer_client/src/models/state-proof-verifier.js.map +1 -1
  176. package/packages/indexer_client/src/models/state-proof-verifier.mjs +2 -2
  177. package/packages/indexer_client/src/models/state-proof-verifier.mjs.map +1 -1
  178. package/packages/indexer_client/src/models/state-schema.d.ts +2 -2
  179. package/packages/indexer_client/src/models/state-schema.js +2 -2
  180. package/packages/indexer_client/src/models/state-schema.js.map +1 -1
  181. package/packages/indexer_client/src/models/state-schema.mjs +2 -2
  182. package/packages/indexer_client/src/models/state-schema.mjs.map +1 -1
  183. package/packages/indexer_client/src/models/teal-key-value.d.ts +1 -1
  184. package/packages/indexer_client/src/models/teal-key-value.js +2 -2
  185. package/packages/indexer_client/src/models/teal-key-value.js.map +1 -1
  186. package/packages/indexer_client/src/models/teal-key-value.mjs +2 -2
  187. package/packages/indexer_client/src/models/teal-key-value.mjs.map +1 -1
  188. package/packages/indexer_client/src/models/transaction-heartbeat.js +2 -1
  189. package/packages/indexer_client/src/models/transaction-heartbeat.js.map +1 -1
  190. package/packages/indexer_client/src/models/transaction-heartbeat.mjs +2 -1
  191. package/packages/indexer_client/src/models/transaction-heartbeat.mjs.map +1 -1
  192. package/packages/indexer_client/src/models/transaction-keyreg.js +4 -4
  193. package/packages/indexer_client/src/models/transaction-keyreg.js.map +1 -1
  194. package/packages/indexer_client/src/models/transaction-keyreg.mjs +4 -4
  195. package/packages/indexer_client/src/models/transaction-keyreg.mjs.map +1 -1
  196. package/packages/indexer_client/src/models/transaction-signature-logicsig.js +2 -1
  197. package/packages/indexer_client/src/models/transaction-signature-logicsig.js.map +1 -1
  198. package/packages/indexer_client/src/models/transaction-signature-logicsig.mjs +2 -1
  199. package/packages/indexer_client/src/models/transaction-signature-logicsig.mjs.map +1 -1
  200. package/packages/indexer_client/src/models/transaction-signature-multisig-subsignature.js +3 -3
  201. package/packages/indexer_client/src/models/transaction-signature-multisig-subsignature.js.map +1 -1
  202. package/packages/indexer_client/src/models/transaction-signature-multisig-subsignature.mjs +3 -3
  203. package/packages/indexer_client/src/models/transaction-signature-multisig-subsignature.mjs.map +1 -1
  204. package/packages/indexer_client/src/models/transaction.d.ts +2 -2
  205. package/packages/indexer_client/src/models/transaction.js +6 -5
  206. package/packages/indexer_client/src/models/transaction.js.map +1 -1
  207. package/packages/indexer_client/src/models/transaction.mjs +6 -5
  208. package/packages/indexer_client/src/models/transaction.mjs.map +1 -1
  209. package/packages/kmd_client/src/apis/api-service.d.ts +5 -5
  210. package/packages/kmd_client/src/apis/api-service.js +32 -32
  211. package/packages/kmd_client/src/apis/api-service.js.map +1 -1
  212. package/packages/kmd_client/src/apis/api-service.mjs +32 -32
  213. package/packages/kmd_client/src/apis/api-service.mjs.map +1 -1
  214. package/packages/kmd_client/src/core/api-error.js +3 -1
  215. package/packages/kmd_client/src/core/api-error.js.map +1 -1
  216. package/packages/kmd_client/src/core/api-error.mjs +3 -1
  217. package/packages/kmd_client/src/core/api-error.mjs.map +1 -1
  218. package/packages/kmd_client/src/core/model-runtime.js +2 -12
  219. package/packages/kmd_client/src/core/model-runtime.js.map +1 -1
  220. package/packages/kmd_client/src/core/model-runtime.mjs +3 -11
  221. package/packages/kmd_client/src/core/model-runtime.mjs.map +1 -1
  222. package/packages/transact/src/logicsig.d.ts +3 -15
  223. package/packages/transact/src/logicsig.js +16 -36
  224. package/packages/transact/src/logicsig.js.map +1 -1
  225. package/packages/transact/src/logicsig.mjs +18 -36
  226. package/packages/transact/src/logicsig.mjs.map +1 -1
  227. package/packages/transact/src/multisig.d.ts +7 -115
  228. package/packages/transact/src/multisig.js +86 -136
  229. package/packages/transact/src/multisig.js.map +1 -1
  230. package/packages/transact/src/multisig.mjs +87 -117
  231. package/packages/transact/src/multisig.mjs.map +1 -1
  232. package/packages/transact/src/transactions/app-call.d.ts +10 -15
  233. package/packages/transact/src/transactions/app-call.js.map +1 -1
  234. package/packages/transact/src/transactions/app-call.mjs.map +1 -1
  235. package/packages/transact/src/transactions/asset-config.d.ts +1 -6
  236. package/packages/transact/src/transactions/asset-config.js.map +1 -1
  237. package/packages/transact/src/transactions/asset-config.mjs.map +1 -1
  238. package/packages/transact/src/transactions/asset-freeze.d.ts +1 -6
  239. package/packages/transact/src/transactions/asset-transfer.d.ts +1 -6
  240. package/packages/transact/src/transactions/key-registration.d.ts +1 -8
  241. package/packages/transact/src/transactions/reference-types-meta.d.ts +26 -0
  242. package/packages/transact/src/transactions/reference-types-meta.js +71 -0
  243. package/packages/transact/src/transactions/reference-types-meta.js.map +1 -0
  244. package/packages/transact/src/transactions/reference-types-meta.mjs +69 -0
  245. package/packages/transact/src/transactions/reference-types-meta.mjs.map +1 -0
  246. package/packages/transact/src/transactions/signed-transaction-meta.js +2 -3
  247. package/packages/transact/src/transactions/signed-transaction-meta.js.map +1 -1
  248. package/packages/transact/src/transactions/signed-transaction-meta.mjs +3 -3
  249. package/packages/transact/src/transactions/signed-transaction-meta.mjs.map +1 -1
  250. package/packages/transact/src/transactions/signed-transaction.d.ts +7 -3
  251. package/packages/transact/src/transactions/signed-transaction.js +1 -1
  252. package/packages/transact/src/transactions/signed-transaction.js.map +1 -1
  253. package/packages/transact/src/transactions/signed-transaction.mjs +1 -2
  254. package/packages/transact/src/transactions/signed-transaction.mjs.map +1 -1
  255. package/packages/transact/src/transactions/transaction-meta.js +29 -23
  256. package/packages/transact/src/transactions/transaction-meta.js.map +1 -1
  257. package/packages/transact/src/transactions/transaction-meta.mjs +29 -23
  258. package/packages/transact/src/transactions/transaction-meta.mjs.map +1 -1
  259. package/packages/transact/src/transactions/transaction.d.ts +5 -1
  260. package/packages/transact/src/transactions/transaction.js +1 -1
  261. package/packages/transact/src/transactions/transaction.js.map +1 -1
  262. package/packages/transact/src/transactions/transaction.mjs +1 -1
  263. package/packages/transact/src/transactions/transaction.mjs.map +1 -1
  264. package/testing/account.js +2 -5
  265. package/testing/account.js.map +1 -1
  266. package/testing/account.mjs +2 -5
  267. package/testing/account.mjs.map +1 -1
  268. package/testing/fixtures/algorand-fixture.d.ts +3 -3
  269. package/testing/fixtures/algorand-fixture.js.map +1 -1
  270. package/testing/fixtures/algorand-fixture.mjs.map +1 -1
  271. package/testing/transaction-logger.js +1 -1
  272. package/testing/transaction-logger.mjs +1 -1
  273. package/transact/index.d.ts +11 -10
  274. package/transact/index.js +7 -32
  275. package/transact/index.mjs +7 -10
  276. package/transaction/transaction.js +2 -2
  277. package/transaction/transaction.js.map +1 -1
  278. package/transaction/transaction.mjs +2 -2
  279. package/transaction/transaction.mjs.map +1 -1
  280. package/transactions/app-call.d.ts +5 -4
  281. package/transactions/app-call.js +16 -16
  282. package/transactions/app-call.js.map +1 -1
  283. package/transactions/app-call.mjs +16 -16
  284. package/transactions/app-call.mjs.map +1 -1
  285. package/transactions/asset-config.d.ts +1 -1
  286. package/transactions/asset-config.js +1 -1
  287. package/transactions/asset-config.js.map +1 -1
  288. package/transactions/asset-config.mjs +1 -1
  289. package/transactions/asset-config.mjs.map +1 -1
  290. package/transactions/key-registration.d.ts +1 -1
  291. package/transactions/key-registration.js.map +1 -1
  292. package/transactions/key-registration.mjs.map +1 -1
  293. package/transactions/method-call.d.ts +1 -1
  294. package/transactions/method-call.js +70 -78
  295. package/transactions/method-call.js.map +1 -1
  296. package/transactions/method-call.mjs +70 -78
  297. package/transactions/method-call.mjs.map +1 -1
  298. package/types/account-manager.d.ts +1 -1
  299. package/types/account-manager.js +5 -5
  300. package/types/account-manager.js.map +1 -1
  301. package/types/account-manager.mjs +5 -5
  302. package/types/account-manager.mjs.map +1 -1
  303. package/types/algorand-client-transaction-creator.d.ts +74 -60
  304. package/types/algorand-client-transaction-creator.js +8 -0
  305. package/types/algorand-client-transaction-creator.js.map +1 -1
  306. package/types/algorand-client-transaction-creator.mjs +8 -0
  307. package/types/algorand-client-transaction-creator.mjs.map +1 -1
  308. package/types/algorand-client-transaction-sender.d.ts +79 -65
  309. package/types/algorand-client-transaction-sender.js +8 -1
  310. package/types/algorand-client-transaction-sender.js.map +1 -1
  311. package/types/algorand-client-transaction-sender.mjs +8 -0
  312. package/types/algorand-client-transaction-sender.mjs.map +1 -1
  313. package/types/amount.js +23 -4
  314. package/types/amount.js.map +1 -1
  315. package/types/amount.mjs +20 -2
  316. package/types/amount.mjs.map +1 -1
  317. package/types/app-client.d.ts +174 -169
  318. package/types/app-client.js +2 -3
  319. package/types/app-client.js.map +1 -1
  320. package/types/app-client.mjs +2 -2
  321. package/types/app-client.mjs.map +1 -1
  322. package/types/app-deployer.d.ts +1 -1
  323. package/types/app-deployer.js +3 -3
  324. package/types/app-deployer.js.map +1 -1
  325. package/types/app-deployer.mjs +3 -3
  326. package/types/app-deployer.mjs.map +1 -1
  327. package/types/app-factory.d.ts +70 -67
  328. package/types/app-factory.js +2 -2
  329. package/types/app-factory.js.map +1 -1
  330. package/types/app-factory.mjs +2 -2
  331. package/types/app-factory.mjs.map +1 -1
  332. package/types/app-manager.d.ts +3 -1
  333. package/types/app-manager.js +17 -11
  334. package/types/app-manager.js.map +1 -1
  335. package/types/app-manager.mjs +17 -11
  336. package/types/app-manager.mjs.map +1 -1
  337. package/types/app-spec.js +12 -5
  338. package/types/app-spec.js.map +1 -1
  339. package/types/app-spec.mjs +12 -5
  340. package/types/app-spec.mjs.map +1 -1
  341. package/types/app.d.ts +2 -2
  342. package/types/app.js.map +1 -1
  343. package/types/app.mjs.map +1 -1
  344. package/types/asset-manager.js +1 -1
  345. package/types/asset-manager.js.map +1 -1
  346. package/types/asset-manager.mjs +1 -1
  347. package/types/asset-manager.mjs.map +1 -1
  348. package/types/async-event-emitter.d.ts +3 -6
  349. package/types/async-event-emitter.js.map +1 -1
  350. package/types/async-event-emitter.mjs.map +1 -1
  351. package/types/client-manager.d.ts +1 -1
  352. package/types/client-manager.js.map +1 -1
  353. package/types/client-manager.mjs.map +1 -1
  354. package/types/composer.d.ts +9 -1
  355. package/types/composer.js +49 -37
  356. package/types/composer.js.map +1 -1
  357. package/types/composer.mjs +40 -27
  358. package/types/composer.mjs.map +1 -1
  359. package/types/debugging.d.ts +13 -9
  360. package/types/debugging.js.map +1 -1
  361. package/types/debugging.mjs.map +1 -1
  362. package/types/expand.d.ts +2 -9
  363. package/types/kmd-account-manager.d.ts +1 -0
  364. package/types/kmd-account-manager.js +22 -11
  365. package/types/kmd-account-manager.js.map +1 -1
  366. package/types/kmd-account-manager.mjs +23 -12
  367. package/types/kmd-account-manager.mjs.map +1 -1
  368. package/types/lifecycle-events.d.ts +0 -1
  369. package/types/lifecycle-events.js.map +1 -1
  370. package/types/lifecycle-events.mjs.map +1 -1
  371. package/types/testing.d.ts +2 -2
  372. package/types/transaction.d.ts +1 -1
  373. package/_virtual/rolldown_runtime.mjs +0 -13
  374. package/indexer-lookup.js.map +0 -1
  375. package/indexer-lookup.mjs.map +0 -1
  376. package/packages/algod_client/src/core/model-runtime.d.ts +0 -10
  377. package/packages/algod_client/src/models/application-local-reference.d.ts +0 -20
  378. package/packages/algod_client/src/models/application-local-reference.js +0 -23
  379. package/packages/algod_client/src/models/application-local-reference.js.map +0 -1
  380. package/packages/algod_client/src/models/application-local-reference.mjs +0 -23
  381. package/packages/algod_client/src/models/application-local-reference.mjs.map +0 -1
  382. package/packages/algod_client/src/models/asset-holding-reference.d.ts +0 -20
  383. package/packages/algod_client/src/models/asset-holding-reference.js +0 -23
  384. package/packages/algod_client/src/models/asset-holding-reference.js.map +0 -1
  385. package/packages/algod_client/src/models/asset-holding-reference.mjs +0 -23
  386. package/packages/algod_client/src/models/asset-holding-reference.mjs.map +0 -1
  387. package/packages/algod_client/src/models/box-reference.d.ts +0 -17
  388. package/packages/algod_client/src/models/box-reference.js +0 -23
  389. package/packages/algod_client/src/models/box-reference.js.map +0 -1
  390. package/packages/algod_client/src/models/box-reference.mjs +0 -23
  391. package/packages/algod_client/src/models/box-reference.mjs.map +0 -1
  392. package/packages/indexer_client/src/core/model-runtime.d.ts +0 -10
  393. package/packages/kmd_client/src/core/model-runtime.d.ts +0 -10
  394. package/packages/sdk/src/convert.d.ts +0 -17
  395. package/packages/sdk/src/convert.js +0 -28
  396. package/packages/sdk/src/convert.js.map +0 -1
  397. package/packages/sdk/src/convert.mjs +0 -25
  398. package/packages/sdk/src/convert.mjs.map +0 -1
  399. package/packages/sdk/src/encoding/binarydata.d.ts +0 -34
  400. package/packages/sdk/src/encoding/binarydata.js +0 -65
  401. package/packages/sdk/src/encoding/binarydata.js.map +0 -1
  402. package/packages/sdk/src/encoding/binarydata.mjs +0 -60
  403. package/packages/sdk/src/encoding/binarydata.mjs.map +0 -1
  404. package/packages/sdk/src/encoding/encoding.d.ts +0 -237
  405. package/packages/sdk/src/encoding/encoding.js +0 -302
  406. package/packages/sdk/src/encoding/encoding.js.map +0 -1
  407. package/packages/sdk/src/encoding/encoding.mjs +0 -287
  408. package/packages/sdk/src/encoding/encoding.mjs.map +0 -1
  409. package/packages/sdk/src/encoding/schema/array.js +0 -35
  410. package/packages/sdk/src/encoding/schema/array.js.map +0 -1
  411. package/packages/sdk/src/encoding/schema/array.mjs +0 -35
  412. package/packages/sdk/src/encoding/schema/array.mjs.map +0 -1
  413. package/packages/sdk/src/encoding/schema/bytearray.js +0 -49
  414. package/packages/sdk/src/encoding/schema/bytearray.js.map +0 -1
  415. package/packages/sdk/src/encoding/schema/bytearray.mjs +0 -49
  416. package/packages/sdk/src/encoding/schema/bytearray.mjs.map +0 -1
  417. package/packages/sdk/src/encoding/schema/map.d.ts +0 -58
  418. package/packages/sdk/src/encoding/schema/map.js +0 -110
  419. package/packages/sdk/src/encoding/schema/map.js.map +0 -1
  420. package/packages/sdk/src/encoding/schema/map.mjs +0 -107
  421. package/packages/sdk/src/encoding/schema/map.mjs.map +0 -1
  422. package/packages/sdk/src/encoding/schema/optional.js +0 -46
  423. package/packages/sdk/src/encoding/schema/optional.js.map +0 -1
  424. package/packages/sdk/src/encoding/schema/optional.mjs +0 -46
  425. package/packages/sdk/src/encoding/schema/optional.mjs.map +0 -1
  426. package/packages/sdk/src/encoding/schema/uint64.js +0 -30
  427. package/packages/sdk/src/encoding/schema/uint64.js.map +0 -1
  428. package/packages/sdk/src/encoding/schema/uint64.mjs +0 -30
  429. package/packages/sdk/src/encoding/schema/uint64.mjs.map +0 -1
  430. package/packages/sdk/src/encoding/uint64.d.ts +0 -34
  431. package/packages/sdk/src/encoding/uint64.js +0 -34
  432. package/packages/sdk/src/encoding/uint64.js.map +0 -1
  433. package/packages/sdk/src/encoding/uint64.mjs +0 -33
  434. package/packages/sdk/src/encoding/uint64.mjs.map +0 -1
  435. package/packages/sdk/src/index.d.ts +0 -44
  436. package/packages/sdk/src/index.js +0 -62
  437. package/packages/sdk/src/index.js.map +0 -1
  438. package/packages/sdk/src/index.mjs +0 -58
  439. package/packages/sdk/src/index.mjs.map +0 -1
  440. package/packages/sdk/src/nacl/naclWrappers.js +0 -14
  441. package/packages/sdk/src/nacl/naclWrappers.js.map +0 -1
  442. package/packages/sdk/src/nacl/naclWrappers.mjs +0 -11
  443. package/packages/sdk/src/nacl/naclWrappers.mjs.map +0 -1
  444. package/packages/sdk/src/types/intDecoding.d.ts +0 -28
  445. package/packages/sdk/src/types/intDecoding.js +0 -32
  446. package/packages/sdk/src/types/intDecoding.js.map +0 -1
  447. package/packages/sdk/src/types/intDecoding.mjs +0 -31
  448. package/packages/sdk/src/types/intDecoding.mjs.map +0 -1
  449. package/packages/sdk/src/types/transactions/encoded.d.ts +0 -40
  450. package/packages/sdk/src/types/transactions/encoded.js +0 -64
  451. package/packages/sdk/src/types/transactions/encoded.js.map +0 -1
  452. package/packages/sdk/src/types/transactions/encoded.mjs +0 -59
  453. package/packages/sdk/src/types/transactions/encoded.mjs.map +0 -1
  454. package/packages/sdk/src/utils/utils.d.ts +0 -64
  455. package/packages/sdk/src/utils/utils.js +0 -140
  456. package/packages/sdk/src/utils/utils.js.map +0 -1
  457. package/packages/sdk/src/utils/utils.mjs +0 -128
  458. package/packages/sdk/src/utils/utils.mjs.map +0 -1
  459. package/packages/transact/src/transactions/common.d.ts +0 -37
  460. package/sdk/index.d.ts +0 -10
  461. package/sdk/index.js +0 -59
  462. package/sdk/index.mjs +0 -11
@@ -1,8 +1,8 @@
1
1
  import { Address, getAddress } from "../packages/common/src/address.mjs";
2
+ import { calculateExtraProgramPages } from "../util.mjs";
2
3
  import { OnApplicationComplete } from "../packages/transact/src/transactions/app-call.mjs";
3
4
  import { TransactionType } from "../packages/transact/src/transactions/transaction-type.mjs";
4
5
  import { Transaction } from "../packages/transact/src/transactions/transaction.mjs";
5
- import { calculateExtraProgramPages } from "../util.mjs";
6
6
  import { AppManager } from "../types/app-manager.mjs";
7
7
  import { buildTransactionCommonData } from "./common.mjs";
8
8
  import { ABITupleType, ABIUintType } from "../packages/abi/src/abi-type.mjs";
@@ -82,68 +82,58 @@ const isAbiValue = (x) => {
82
82
  return typeof x === "bigint" || typeof x === "boolean" || typeof x === "number" || typeof x === "string" || x instanceof Uint8Array || x instanceof Address;
83
83
  };
84
84
  /**
85
- * Populate reference arrays from processed ABI method call arguments
85
+ * Prepares method arguments for ABI encoding by building reference arrays and
86
+ * replacing reference-type arguments (account, asset, application) with their indices.
86
87
  */
87
- function populateMethodArgsIntoReferenceArrays(sender, appId, method, methodArgs, accountReferences, appReferences, assetReferences) {
88
- const accounts = accountReferences ?? [];
89
- const assets = assetReferences ?? [];
90
- const apps = appReferences ?? [];
91
- methodArgs.forEach((arg, i) => {
92
- const argType = method.args[i].type;
93
- if (argTypeIsReference(argType)) switch (argType) {
94
- case "account":
95
- if (typeof arg === "string" && arg !== sender.toString() && !accounts.some((a) => a.toString() === arg)) accounts.push(getAddress(arg));
96
- break;
97
- case "asset":
98
- if (typeof arg === "bigint" && !assets.includes(arg)) assets.push(arg);
99
- break;
100
- case "application":
101
- if (typeof arg === "bigint" && arg !== appId && !apps.includes(arg)) apps.push(arg);
102
- break;
103
- }
104
- });
88
+ function prepareArgsForEncoding(sender, appId, method, methodArgs, accountReferences, appReferences, assetReferences) {
89
+ const accounts = [...accountReferences ?? []];
90
+ const assets = [...assetReferences ?? []];
91
+ const apps = [...appReferences ?? []];
105
92
  return {
106
93
  accountReferences: accounts,
107
94
  appReferences: apps,
108
- assetReferences: assets
109
- };
110
- }
111
- /**
112
- * Calculate array index for ABI reference values
113
- */
114
- function calculateMethodArgReferenceArrayIndex(refValue, referenceType, sender, appId, accountReferences, appReferences, assetReferences) {
115
- switch (referenceType) {
116
- case "account":
117
- if (typeof refValue === "string") {
118
- if (refValue === sender.toString()) return 0;
119
- const index = accountReferences.findIndex((a) => a.toString() === refValue);
120
- if (index === -1) throw new Error(`Account ${refValue} not found in reference array`);
121
- return index + 1;
95
+ assetReferences: assets,
96
+ updatedArgs: methodArgs.map((arg, i) => {
97
+ const argType = method.args[i].type;
98
+ if (!argTypeIsReference(argType)) return arg;
99
+ switch (argType) {
100
+ case "account": {
101
+ let addr;
102
+ if (typeof arg === "string") addr = getAddress(arg);
103
+ else if (arg instanceof Uint8Array) addr = new Address(arg);
104
+ else throw new Error("Invalid value for account");
105
+ if (sender.equals(addr)) return 0;
106
+ const existing = accounts.findIndex((a) => a.equals(addr)) + 1;
107
+ if (existing) return existing;
108
+ accounts.push(addr);
109
+ return accounts.length;
110
+ }
111
+ case "asset": {
112
+ if (typeof arg !== "bigint") throw new Error("Invalid value for asset");
113
+ const existing = assets.findIndex((a) => a === arg);
114
+ if (existing === -1) {
115
+ assets.push(arg);
116
+ return assets.length - 1;
117
+ }
118
+ return existing;
119
+ }
120
+ case "application": {
121
+ if (typeof arg !== "bigint") throw new Error("Invalid value for application");
122
+ if (arg === appId) return 0;
123
+ const existing = apps.findIndex((a) => a === arg) + 1;
124
+ if (existing) return existing;
125
+ apps.push(arg);
126
+ return apps.length;
127
+ }
122
128
  }
123
- throw new Error("Account reference must be a string");
124
- case "asset":
125
- if (typeof refValue === "bigint") {
126
- const index = assetReferences.indexOf(refValue);
127
- if (index === -1) throw new Error(`Asset ${refValue} not found in reference array`);
128
- return index;
129
- }
130
- throw new Error("Asset reference must be a bigint");
131
- case "application":
132
- if (typeof refValue === "bigint") {
133
- if (refValue === appId) return 0;
134
- const index = appReferences.indexOf(refValue);
135
- if (index === -1) throw new Error(`Application ${refValue} not found in reference array`);
136
- return index + 1;
137
- }
138
- throw new Error("Application reference must be a bigint");
139
- default: throw new Error(`Unknown reference type: ${referenceType}`);
140
- }
129
+ })
130
+ };
141
131
  }
142
132
  /**
143
133
  * Encode ABI method arguments with tuple packing support
144
134
  * Ports the logic from the Rust encode_method_arguments function
145
135
  */
146
- function encodeMethodArguments(method, args, sender, appId, accountReferences, appReferences, assetReferences) {
136
+ function encodeMethodArguments(method, args) {
147
137
  const encodedArgs = new Array();
148
138
  encodedArgs.push(method.getSelector());
149
139
  const abiTypes = new Array();
@@ -153,10 +143,9 @@ function encodeMethodArguments(method, args, sender, appId, accountReferences, a
153
143
  const argValue = args[i];
154
144
  if (argTypeIsTransaction(methodArg.type)) {} else if (argTypeIsReference(methodArg.type)) {
155
145
  const referenceType = methodArg.type;
156
- if (typeof argValue === "string" || typeof argValue === "bigint") {
157
- const foreignIndex = calculateMethodArgReferenceArrayIndex(argValue, referenceType, sender, appId, accountReferences, appReferences, assetReferences);
146
+ if (typeof argValue === "number") {
158
147
  abiTypes.push(new ABIUintType(8));
159
- abiValues.push(foreignIndex);
148
+ abiValues.push(argValue);
160
149
  } else throw new Error(`Invalid reference value for ${referenceType}: ${argValue}`);
161
150
  } else if (argValue !== void 0) {
162
151
  abiTypes.push(methodArg.type);
@@ -198,12 +187,12 @@ function encodeArgsWithTuplePacking(abiTypes, abiValues) {
198
187
  return encodedArgs;
199
188
  }
200
189
  /**
201
- * Common method call building logic
190
+ * Builds encoded ABI method arguments and resolves reference arrays
202
191
  */
203
- function buildMethodCallCommon(params, commonData) {
204
- const { accountReferences, appReferences, assetReferences } = populateMethodArgsIntoReferenceArrays(commonData.sender, params.appId, params.method, params.args ?? [], params.accountReferences, params.appReferences, params.assetReferences);
192
+ function buildMethodCallArgsAndReferences(params) {
193
+ const { accountReferences, appReferences, assetReferences, updatedArgs } = prepareArgsForEncoding(params.sender, params.appId, params.method, params.args ?? [], params.accountReferences, params.appReferences, params.assetReferences);
205
194
  return {
206
- args: encodeMethodArguments(params.method, params.args, commonData.sender, params.appId, accountReferences, appReferences, assetReferences),
195
+ args: encodeMethodArguments(params.method, updatedArgs),
207
196
  accountReferences,
208
197
  appReferences,
209
198
  assetReferences
@@ -223,14 +212,15 @@ const buildAppCreateMethodCall = async (params, appManager, suggestedParams, def
223
212
  } : void 0;
224
213
  const extraProgramPages = params.extraProgramPages !== void 0 ? params.extraProgramPages : calculateExtraProgramPages(approvalProgram, clearStateProgram);
225
214
  const accountReferences = params.accountReferences?.map((a) => getAddress(a));
226
- const common = buildMethodCallCommon({
215
+ const argsAndReferences = buildMethodCallArgsAndReferences({
216
+ sender: commonData.sender,
227
217
  appId: 0n,
228
218
  method: params.method,
229
219
  args: params.args ?? [],
230
220
  accountReferences,
231
221
  appReferences: params.appReferences,
232
222
  assetReferences: params.assetReferences
233
- }, commonData);
223
+ });
234
224
  const hasAccessReferences = params.accessReferences && params.accessReferences.length > 0;
235
225
  return new Transaction({
236
226
  ...commonData,
@@ -243,11 +233,11 @@ const buildAppCreateMethodCall = async (params, appManager, suggestedParams, def
243
233
  globalStateSchema,
244
234
  localStateSchema,
245
235
  extraProgramPages,
246
- args: common.args,
236
+ args: argsAndReferences.args,
247
237
  ...hasAccessReferences ? { accessReferences: params.accessReferences } : {
248
- accountReferences: params.accountReferences?.map((a) => getAddress(a)),
249
- appReferences: params.appReferences,
250
- assetReferences: params.assetReferences,
238
+ accountReferences: argsAndReferences.accountReferences,
239
+ appReferences: argsAndReferences.appReferences,
240
+ assetReferences: argsAndReferences.assetReferences,
251
241
  boxReferences: params.boxReferences?.map(AppManager.getBoxReference)
252
242
  },
253
243
  rejectVersion: params.rejectVersion
@@ -259,14 +249,15 @@ const buildAppUpdateMethodCall = async (params, appManager, suggestedParams, def
259
249
  const approvalProgram = typeof params.approvalProgram === "string" ? (await appManager.compileTeal(params.approvalProgram)).compiledBase64ToBytes : params.approvalProgram;
260
250
  const clearStateProgram = typeof params.clearStateProgram === "string" ? (await appManager.compileTeal(params.clearStateProgram)).compiledBase64ToBytes : params.clearStateProgram;
261
251
  const accountReferences = params.accountReferences?.map((a) => getAddress(a));
262
- const common = buildMethodCallCommon({
252
+ const argsAndReferences = buildMethodCallArgsAndReferences({
253
+ sender: commonData.sender,
263
254
  appId: params.appId,
264
255
  method: params.method,
265
256
  args: params.args ?? [],
266
257
  accountReferences,
267
258
  appReferences: params.appReferences,
268
259
  assetReferences: params.assetReferences
269
- }, commonData);
260
+ });
270
261
  const hasAccessReferences = params.accessReferences && params.accessReferences.length > 0;
271
262
  return new Transaction({
272
263
  ...commonData,
@@ -276,11 +267,11 @@ const buildAppUpdateMethodCall = async (params, appManager, suggestedParams, def
276
267
  onComplete: OnApplicationComplete.UpdateApplication,
277
268
  approvalProgram,
278
269
  clearStateProgram,
279
- args: common.args,
270
+ args: argsAndReferences.args,
280
271
  ...hasAccessReferences ? { accessReferences: params.accessReferences } : {
281
- accountReferences: params.accountReferences?.map((a) => getAddress(a)),
282
- appReferences: params.appReferences,
283
- assetReferences: params.assetReferences,
272
+ accountReferences: argsAndReferences.accountReferences,
273
+ appReferences: argsAndReferences.appReferences,
274
+ assetReferences: argsAndReferences.assetReferences,
284
275
  boxReferences: params.boxReferences?.map(AppManager.getBoxReference)
285
276
  },
286
277
  rejectVersion: params.rejectVersion
@@ -290,14 +281,15 @@ const buildAppUpdateMethodCall = async (params, appManager, suggestedParams, def
290
281
  const buildAppCallMethodCall = async (params, suggestedParams, defaultValidityWindow) => {
291
282
  const commonData = buildTransactionCommonData(params, suggestedParams, defaultValidityWindow);
292
283
  const accountReferences = params.accountReferences?.map((a) => getAddress(a));
293
- const common = buildMethodCallCommon({
284
+ const argsAndReferences = buildMethodCallArgsAndReferences({
285
+ sender: commonData.sender,
294
286
  appId: params.appId,
295
287
  method: params.method,
296
288
  args: params.args ?? [],
297
289
  accountReferences,
298
290
  appReferences: params.appReferences,
299
291
  assetReferences: params.assetReferences
300
- }, commonData);
292
+ });
301
293
  const hasAccessReferences = params.accessReferences && params.accessReferences.length > 0;
302
294
  return new Transaction({
303
295
  ...commonData,
@@ -305,11 +297,11 @@ const buildAppCallMethodCall = async (params, suggestedParams, defaultValidityWi
305
297
  appCall: {
306
298
  appId: params.appId,
307
299
  onComplete: params.onComplete ?? OnApplicationComplete.NoOp,
308
- args: common.args,
300
+ args: argsAndReferences.args,
309
301
  ...hasAccessReferences ? { accessReferences: params.accessReferences } : {
310
- accountReferences: params.accountReferences?.map((a) => getAddress(a)),
311
- appReferences: params.appReferences,
312
- assetReferences: params.assetReferences,
302
+ accountReferences: argsAndReferences.accountReferences,
303
+ appReferences: argsAndReferences.appReferences,
304
+ assetReferences: argsAndReferences.assetReferences,
313
305
  boxReferences: params.boxReferences?.map(AppManager.getBoxReference)
314
306
  },
315
307
  rejectVersion: params.rejectVersion
@@ -1 +1 @@
1
- {"version":3,"file":"method-call.mjs","names":["encodedArgs: Uint8Array[]"],"sources":["../../src/transactions/method-call.ts"],"sourcesContent":["import {\n ABIMethod,\n ABIReferenceType,\n ABITupleType,\n ABIType,\n ABIUintType,\n ABIValue,\n argTypeIsReference,\n argTypeIsTransaction,\n} from '@algorandfoundation/algokit-abi'\nimport { SuggestedParams } from '@algorandfoundation/algokit-algod-client'\nimport { Address, getAddress } from '@algorandfoundation/algokit-common'\nimport { OnApplicationComplete, Transaction, TransactionSigner, TransactionType } from '@algorandfoundation/algokit-transact'\nimport { TransactionWithSigner } from '../transaction'\nimport { AlgoAmount } from '../types/amount'\nimport { AppManager } from '../types/app-manager'\nimport { Expand } from '../types/expand'\nimport { calculateExtraProgramPages } from '../util'\nimport { AppCreateParams, AppDeleteParams, AppMethodCallParams, AppUpdateParams } from './app-call'\nimport { TransactionCommonData, buildTransactionCommonData } from './common'\n\nconst ARGS_TUPLE_PACKING_THRESHOLD = 14 // 14+ args trigger tuple packing, excluding the method selector\n\n/** Parameters to define an ABI method call create transaction. */\nexport type AppCreateMethodCall = Expand<AppMethodCall<AppCreateParams>>\n/** Parameters to define an ABI method call update transaction. */\nexport type AppUpdateMethodCall = Expand<AppMethodCall<AppUpdateParams>>\n/** Parameters to define an ABI method call delete transaction. */\nexport type AppDeleteMethodCall = Expand<AppMethodCall<AppDeleteParams>>\n/** Parameters to define an ABI method call transaction. */\nexport type AppCallMethodCall = Expand<AppMethodCall<AppMethodCallParams>>\n\nexport type ProcessedAppCreateMethodCall = Expand<\n Omit<AppCreateMethodCall, 'args'> & {\n args?: (ABIValue | undefined)[]\n }\n>\n\nexport type ProcessedAppUpdateMethodCall = Expand<\n Omit<AppUpdateMethodCall, 'args'> & {\n args?: (ABIValue | undefined)[]\n }\n>\n\nexport type ProcessedAppCallMethodCall = Expand<\n Omit<AppCallMethodCall, 'args'> & {\n args?: (ABIValue | undefined)[]\n }\n>\n\n/** Types that can be used to define a transaction argument for an ABI call transaction. */\nexport type AppMethodCallTransactionArgument =\n // The following should match the partial `args` types from `AppMethodCall<T>` below\n | TransactionWithSigner\n | Transaction\n | Promise<Transaction>\n | AppMethodCall<AppCreateParams>\n | AppMethodCall<AppUpdateParams>\n | AppMethodCall<AppMethodCallParams>\n\n/** Parameters to define an ABI method call. */\nexport type AppMethodCall<T> = Expand<Omit<T, 'args'>> & {\n /** The ABI method to call */\n method: ABIMethod\n /** Arguments to the ABI method, either:\n * * An ABI value\n * * A transaction with explicit signer\n * * A transaction (where the signer will be automatically assigned)\n * * An unawaited transaction (e.g. from algorand.createTransaction.{transactionType}())\n * * Another method call (via method call params object)\n * * undefined (this represents a placeholder transaction argument that is fulfilled by another method call argument)\n */\n args?: (\n | ABIValue\n // The following should match the above `AppMethodCallTransactionArgument` type above\n | TransactionWithSigner\n | Transaction\n | Promise<Transaction>\n | AppMethodCall<AppCreateParams>\n | AppMethodCall<AppUpdateParams>\n | AppMethodCall<AppMethodCallParams>\n | undefined\n )[]\n}\n\ntype AppMethodCallArgs = AppMethodCall<unknown>['args']\ntype AppMethodCallArg = NonNullable<AppMethodCallArgs>[number]\n\nexport type AsyncTransactionParams = {\n txn: Promise<Transaction>\n signer?: TransactionSigner\n maxFee?: AlgoAmount\n}\n\nexport type TransactionParams = {\n txn: Transaction\n signer?: TransactionSigner\n maxFee?: AlgoAmount\n}\n\ntype ExtractedMethodCallTransactionArg =\n | { data: TransactionParams; type: 'txn' }\n | {\n data: AsyncTransactionParams\n type: 'asyncTxn'\n }\n | { data: ProcessedAppCallMethodCall | ProcessedAppCreateMethodCall | ProcessedAppUpdateMethodCall; type: 'methodCall' }\n\nexport function extractComposerTransactionsFromAppMethodCallParams(\n params: AppCallMethodCall | AppCreateMethodCall | AppUpdateMethodCall | AppDeleteMethodCall,\n parentSigner?: TransactionSigner,\n): ExtractedMethodCallTransactionArg[] {\n const composerTransactions = new Array<ExtractedMethodCallTransactionArg>()\n const methodCallArgs = params.args\n if (!methodCallArgs) return []\n\n // Extract signer from params, falling back to parentSigner\n const currentSigner = params.signer ? ('signer' in params.signer ? params.signer.signer : params.signer) : parentSigner\n\n for (let i = 0; i < methodCallArgs.length; i++) {\n const arg = methodCallArgs[i]\n\n if (arg === undefined) {\n // is a transaction or default value placeholder, do nothing\n continue\n }\n if (isAbiValue(arg)) {\n // if is ABI value, also ignore\n continue\n }\n\n if (isTransactionWithSignerArg(arg)) {\n composerTransactions.push({\n data: {\n txn: arg.txn,\n signer: arg.signer,\n },\n type: 'txn',\n })\n\n continue\n }\n if (isAppCallMethodCallArg(arg)) {\n // Recursively extract nested method call transactions, passing the nested call itself and current signer as parent\n const nestedComposerTransactions = extractComposerTransactionsFromAppMethodCallParams(arg, currentSigner)\n composerTransactions.push(...nestedComposerTransactions)\n composerTransactions.push({\n data: {\n ...arg,\n signer: arg.signer ?? currentSigner,\n args: processAppMethodCallArgs(arg.args),\n },\n type: 'methodCall',\n } satisfies ExtractedMethodCallTransactionArg)\n\n continue\n }\n if (arg instanceof Promise) {\n composerTransactions.push({\n data: {\n txn: arg,\n signer: currentSigner,\n },\n type: 'asyncTxn',\n })\n continue\n }\n\n composerTransactions.push({\n data: {\n txn: Promise.resolve(arg),\n signer: currentSigner,\n },\n type: 'asyncTxn',\n })\n }\n\n return composerTransactions\n}\n\nexport function processAppMethodCallArgs(args: AppMethodCallArg[] | undefined): (ABIValue | undefined)[] | undefined {\n if (args === undefined) return undefined\n\n return args.map((arg) => {\n if (arg === undefined) {\n // Handle explicit placeholders (either transaction or default value)\n return undefined\n } else if (!isAbiValue(arg)) {\n // If the arg is not an ABIValue, it's must be a transaction, set to undefined\n // transaction arguments should be flattened out and added into the composer during the add process\n return undefined\n }\n return arg\n })\n}\n\nfunction isTransactionWithSignerArg(arg: AppMethodCallArg): arg is TransactionWithSigner {\n return typeof arg === 'object' && arg !== undefined && 'txn' in arg && 'signer' in arg\n}\n\nfunction isAppCallMethodCallArg(\n arg: AppMethodCallArg,\n): arg is AppMethodCall<AppCreateParams> | AppMethodCall<AppUpdateParams> | AppMethodCall<AppMethodCallParams> {\n return typeof arg === 'object' && arg !== undefined && 'method' in arg\n}\n\nconst isAbiValue = (x: unknown): x is ABIValue => {\n if (Array.isArray(x)) return x.length == 0 || x.every(isAbiValue)\n\n // If x is a POJO literal\n if (Object.getPrototypeOf(x) === Object.getPrototypeOf({})) {\n return Object.values(x as object).every(isAbiValue)\n }\n\n return (\n typeof x === 'bigint' ||\n typeof x === 'boolean' ||\n typeof x === 'number' ||\n typeof x === 'string' ||\n x instanceof Uint8Array ||\n x instanceof Address\n )\n}\n\n/**\n * Populate reference arrays from processed ABI method call arguments\n */\nfunction populateMethodArgsIntoReferenceArrays(\n sender: Address,\n appId: bigint,\n method: ABIMethod,\n methodArgs: AppMethodCallArg[],\n accountReferences?: Address[],\n appReferences?: bigint[],\n assetReferences?: bigint[],\n): { accountReferences: Address[]; appReferences: bigint[]; assetReferences: bigint[] } {\n const accounts = accountReferences ?? []\n const assets = assetReferences ?? []\n const apps = appReferences ?? []\n\n methodArgs.forEach((arg, i) => {\n const argType = method.args[i].type\n if (argTypeIsReference(argType)) {\n switch (argType) {\n case 'account':\n if (typeof arg === 'string' && arg !== sender.toString() && !accounts.some((a) => a.toString() === arg)) {\n accounts.push(getAddress(arg))\n }\n break\n case 'asset':\n if (typeof arg === 'bigint' && !assets.includes(arg)) {\n assets.push(arg)\n }\n break\n case 'application':\n if (typeof arg === 'bigint' && arg !== appId && !apps.includes(arg)) {\n apps.push(arg)\n }\n break\n }\n }\n })\n\n return { accountReferences: accounts, appReferences: apps, assetReferences: assets }\n}\n\n/**\n * Calculate array index for ABI reference values\n */\nfunction calculateMethodArgReferenceArrayIndex(\n refValue: string | bigint,\n referenceType: ABIReferenceType,\n sender: Address,\n appId: bigint,\n accountReferences: Address[],\n appReferences: bigint[],\n assetReferences: bigint[],\n): number {\n switch (referenceType) {\n case 'account':\n if (typeof refValue === 'string') {\n // If address is the same as sender, use index 0\n if (refValue === sender.toString()) return 0\n const index = accountReferences.findIndex((a) => a.toString() === refValue)\n if (index === -1) throw new Error(`Account ${refValue} not found in reference array`)\n return index + 1\n }\n throw new Error('Account reference must be a string')\n case 'asset':\n if (typeof refValue === 'bigint') {\n const index = assetReferences.indexOf(refValue)\n if (index === -1) throw new Error(`Asset ${refValue} not found in reference array`)\n return index\n }\n throw new Error('Asset reference must be a bigint')\n case 'application':\n if (typeof refValue === 'bigint') {\n // If app ID is the same as the current app, use index 0\n if (refValue === appId) return 0\n const index = appReferences.indexOf(refValue)\n if (index === -1) throw new Error(`Application ${refValue} not found in reference array`)\n return index + 1\n }\n throw new Error('Application reference must be a bigint')\n default:\n throw new Error(`Unknown reference type: ${referenceType}`)\n }\n}\n\n/**\n * Encode ABI method arguments with tuple packing support\n * Ports the logic from the Rust encode_method_arguments function\n */\nfunction encodeMethodArguments(\n method: ABIMethod,\n args: (ABIValue | undefined)[],\n sender: Address,\n appId: bigint,\n accountReferences: Address[],\n appReferences: bigint[],\n assetReferences: bigint[],\n): Uint8Array[] {\n const encodedArgs = new Array<Uint8Array>()\n\n // Insert method selector at the front\n encodedArgs.push(method.getSelector())\n\n // Get ABI types for non-transaction arguments\n const abiTypes = new Array<ABIType>()\n const abiValues = new Array<ABIValue>()\n\n // Process each method argument\n for (let i = 0; i < method.args.length; i++) {\n const methodArg = method.args[i]\n const argValue = args[i]\n\n if (argTypeIsTransaction(methodArg.type)) {\n // Transaction arguments are not ABI encoded - they're handled separately\n } else if (argTypeIsReference(methodArg.type)) {\n // Reference types are encoded as uint8 indexes\n const referenceType = methodArg.type\n if (typeof argValue === 'string' || typeof argValue === 'bigint') {\n const foreignIndex = calculateMethodArgReferenceArrayIndex(\n argValue,\n referenceType,\n sender,\n appId,\n accountReferences,\n appReferences,\n assetReferences,\n )\n\n abiTypes.push(new ABIUintType(8))\n abiValues.push(foreignIndex)\n } else {\n throw new Error(`Invalid reference value for ${referenceType}: ${argValue}`)\n }\n } else if (argValue !== undefined) {\n // Regular ABI value\n abiTypes.push(methodArg.type)\n // it's safe to cast to ABIValue here because the abiType must be ABIValue\n abiValues.push(argValue as ABIValue)\n }\n\n // Skip undefined values (transaction placeholders)\n }\n\n if (abiValues.length !== abiTypes.length) {\n throw new Error('Mismatch in length of non-transaction arguments')\n }\n\n // Apply ARC-4 tuple packing for methods with more than 14 arguments\n // 14 instead of 15 in the ARC-4 because the first argument (method selector) is added separately\n if (abiTypes.length > ARGS_TUPLE_PACKING_THRESHOLD) {\n encodedArgs.push(...encodeArgsWithTuplePacking(abiTypes, abiValues))\n } else {\n encodedArgs.push(...encodeArgsIndividually(abiTypes, abiValues))\n }\n\n return encodedArgs\n}\n\n/**\n * Encode individual ABI values\n */\nfunction encodeArgsIndividually(abiTypes: ABIType[], abiValues: ABIValue[]): Uint8Array[] {\n const encodedArgs: Uint8Array[] = []\n\n for (let i = 0; i < abiTypes.length; i++) {\n const abiType = abiTypes[i]\n const abiValue = abiValues[i]\n const encoded = abiType.encode(abiValue)\n encodedArgs.push(encoded)\n }\n\n return encodedArgs\n}\n\n/**\n * Encode ABI values with tuple packing for methods with many arguments\n */\nfunction encodeArgsWithTuplePacking(abiTypes: ABIType[], abiValues: ABIValue[]): Uint8Array[] {\n const encodedArgs: Uint8Array[] = []\n\n // Encode first 14 arguments individually\n const first14AbiTypes = abiTypes.slice(0, ARGS_TUPLE_PACKING_THRESHOLD)\n const first14AbiValues = abiValues.slice(0, ARGS_TUPLE_PACKING_THRESHOLD)\n encodedArgs.push(...encodeArgsIndividually(first14AbiTypes, first14AbiValues))\n\n // Pack remaining arguments into tuple at position 15\n const remainingAbiTypes = abiTypes.slice(ARGS_TUPLE_PACKING_THRESHOLD)\n const remainingAbiValues = abiValues.slice(ARGS_TUPLE_PACKING_THRESHOLD)\n\n if (remainingAbiTypes.length > 0) {\n const tupleType = new ABITupleType(remainingAbiTypes)\n const tupleValue = remainingAbiValues\n const tupleEncoded = tupleType.encode(tupleValue)\n encodedArgs.push(tupleEncoded)\n }\n\n return encodedArgs\n}\n\n/**\n * Common method call building logic\n */\nfunction buildMethodCallCommon(\n params: {\n appId: bigint\n method: ABIMethod\n args: (ABIValue | undefined)[]\n accountReferences?: Address[]\n appReferences?: bigint[]\n assetReferences?: bigint[]\n },\n commonData: TransactionCommonData,\n): { args: Uint8Array[]; accountReferences: Address[]; appReferences: bigint[]; assetReferences: bigint[] } {\n const { accountReferences, appReferences, assetReferences } = populateMethodArgsIntoReferenceArrays(\n commonData.sender,\n params.appId,\n params.method,\n params.args ?? [],\n params.accountReferences,\n params.appReferences,\n params.assetReferences,\n )\n\n const encodedArgs = encodeMethodArguments(\n params.method,\n params.args,\n commonData.sender,\n params.appId,\n accountReferences,\n appReferences,\n assetReferences,\n )\n\n return {\n args: encodedArgs,\n accountReferences,\n appReferences,\n assetReferences,\n }\n}\n\nexport const buildAppCreateMethodCall = async (\n params: ProcessedAppCreateMethodCall,\n appManager: AppManager,\n suggestedParams: SuggestedParams,\n defaultValidityWindow: bigint,\n): Promise<Transaction> => {\n const commonData = buildTransactionCommonData(params, suggestedParams, defaultValidityWindow)\n const approvalProgram =\n typeof params.approvalProgram === 'string'\n ? (await appManager.compileTeal(params.approvalProgram)).compiledBase64ToBytes\n : params.approvalProgram\n const clearStateProgram =\n typeof params.clearStateProgram === 'string'\n ? (await appManager.compileTeal(params.clearStateProgram)).compiledBase64ToBytes\n : params.clearStateProgram\n const globalStateSchema =\n params.schema?.globalByteSlices !== undefined || params.schema?.globalInts !== undefined\n ? {\n numByteSlices: params.schema?.globalByteSlices ?? 0,\n numUints: params.schema?.globalInts ?? 0,\n }\n : undefined\n const localStateSchema =\n params.schema?.localByteSlices !== undefined || params.schema?.localInts !== undefined\n ? {\n numByteSlices: params.schema?.localByteSlices ?? 0,\n numUints: params.schema?.localInts ?? 0,\n }\n : undefined\n const extraProgramPages =\n params.extraProgramPages !== undefined ? params.extraProgramPages : calculateExtraProgramPages(approvalProgram!, clearStateProgram!)\n const accountReferences = params.accountReferences?.map((a) => getAddress(a))\n const common = buildMethodCallCommon(\n {\n appId: 0n,\n method: params.method,\n args: params.args ?? [],\n accountReferences: accountReferences,\n appReferences: params.appReferences,\n assetReferences: params.assetReferences,\n },\n commonData,\n )\n\n // If accessReferences is provided, we should not pass legacy foreign arrays\n const hasAccessReferences = params.accessReferences && params.accessReferences.length > 0\n\n return new Transaction({\n ...commonData,\n type: TransactionType.AppCall,\n appCall: {\n appId: 0n,\n onComplete: params.onComplete ?? OnApplicationComplete.NoOp,\n approvalProgram: approvalProgram,\n clearStateProgram: clearStateProgram,\n globalStateSchema: globalStateSchema,\n localStateSchema: localStateSchema,\n extraProgramPages: extraProgramPages,\n args: common.args,\n ...(hasAccessReferences\n ? { accessReferences: params.accessReferences }\n : {\n accountReferences: params.accountReferences?.map((a) => getAddress(a)),\n appReferences: params.appReferences,\n assetReferences: params.assetReferences,\n boxReferences: params.boxReferences?.map(AppManager.getBoxReference),\n }),\n rejectVersion: params.rejectVersion,\n },\n })\n}\n\nexport const buildAppUpdateMethodCall = async (\n params: ProcessedAppUpdateMethodCall,\n appManager: AppManager,\n suggestedParams: SuggestedParams,\n defaultValidityWindow: bigint,\n): Promise<Transaction> => {\n const commonData = buildTransactionCommonData(params, suggestedParams, defaultValidityWindow)\n const approvalProgram =\n typeof params.approvalProgram === 'string'\n ? (await appManager.compileTeal(params.approvalProgram)).compiledBase64ToBytes\n : params.approvalProgram\n const clearStateProgram =\n typeof params.clearStateProgram === 'string'\n ? (await appManager.compileTeal(params.clearStateProgram)).compiledBase64ToBytes\n : params.clearStateProgram\n const accountReferences = params.accountReferences?.map((a) => getAddress(a))\n const common = buildMethodCallCommon(\n {\n appId: params.appId,\n method: params.method,\n args: params.args ?? [],\n accountReferences: accountReferences,\n appReferences: params.appReferences,\n assetReferences: params.assetReferences,\n },\n commonData,\n )\n\n // If accessReferences is provided, we should not pass legacy foreign arrays\n const hasAccessReferences = params.accessReferences && params.accessReferences.length > 0\n\n return new Transaction({\n ...commonData,\n type: TransactionType.AppCall,\n appCall: {\n appId: params.appId,\n onComplete: OnApplicationComplete.UpdateApplication,\n approvalProgram: approvalProgram,\n clearStateProgram: clearStateProgram,\n args: common.args,\n ...(hasAccessReferences\n ? { accessReferences: params.accessReferences }\n : {\n accountReferences: params.accountReferences?.map((a) => getAddress(a)),\n appReferences: params.appReferences,\n assetReferences: params.assetReferences,\n boxReferences: params.boxReferences?.map(AppManager.getBoxReference),\n }),\n rejectVersion: params.rejectVersion,\n },\n })\n}\n\nexport const buildAppCallMethodCall = async (\n params: ProcessedAppCallMethodCall,\n suggestedParams: SuggestedParams,\n defaultValidityWindow: bigint,\n): Promise<Transaction> => {\n const commonData = buildTransactionCommonData(params, suggestedParams, defaultValidityWindow)\n const accountReferences = params.accountReferences?.map((a) => getAddress(a))\n const common = buildMethodCallCommon(\n {\n appId: params.appId,\n method: params.method,\n args: params.args ?? [],\n accountReferences: accountReferences,\n appReferences: params.appReferences,\n assetReferences: params.assetReferences,\n },\n commonData,\n )\n\n // If accessReferences is provided, we should not pass legacy foreign arrays\n const hasAccessReferences = params.accessReferences && params.accessReferences.length > 0\n\n return new Transaction({\n ...commonData,\n type: TransactionType.AppCall,\n appCall: {\n appId: params.appId,\n onComplete: params.onComplete ?? OnApplicationComplete.NoOp,\n args: common.args,\n ...(hasAccessReferences\n ? { accessReferences: params.accessReferences }\n : {\n accountReferences: params.accountReferences?.map((a) => getAddress(a)),\n appReferences: params.appReferences,\n assetReferences: params.assetReferences,\n boxReferences: params.boxReferences?.map(AppManager.getBoxReference),\n }),\n rejectVersion: params.rejectVersion,\n },\n })\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"method-call.mjs","names":["addr: Address","encodedArgs: Uint8Array[]"],"sources":["../../src/transactions/method-call.ts"],"sourcesContent":["import {\n ABIMethod,\n ABITupleType,\n ABIType,\n ABIUintType,\n ABIValue,\n argTypeIsReference,\n argTypeIsTransaction,\n} from '@algorandfoundation/algokit-abi'\nimport { SuggestedParams } from '@algorandfoundation/algokit-algod-client'\nimport { Address, Expand, getAddress } from '@algorandfoundation/algokit-common'\nimport { OnApplicationComplete, Transaction, TransactionSigner, TransactionType } from '@algorandfoundation/algokit-transact'\nimport { TransactionWithSigner } from '../transaction'\nimport { AlgoAmount } from '../types/amount'\nimport { AppManager } from '../types/app-manager'\nimport { calculateExtraProgramPages } from '../util'\nimport { AppCreateParams, AppDeleteParams, AppMethodCallParams, AppUpdateParams } from './app-call'\nimport { buildTransactionCommonData } from './common'\n\nconst ARGS_TUPLE_PACKING_THRESHOLD = 14 // 14+ args trigger tuple packing, excluding the method selector\n\n/** Parameters to define an ABI method call create transaction. */\nexport type AppCreateMethodCall = Expand<AppMethodCall<AppCreateParams>>\n/** Parameters to define an ABI method call update transaction. */\nexport type AppUpdateMethodCall = Expand<AppMethodCall<AppUpdateParams>>\n/** Parameters to define an ABI method call delete transaction. */\nexport type AppDeleteMethodCall = Expand<AppMethodCall<AppDeleteParams>>\n/** Parameters to define an ABI method call transaction. */\nexport type AppCallMethodCall = Expand<AppMethodCall<AppMethodCallParams>>\n\nexport type ProcessedAppCreateMethodCall = Expand<\n Omit<AppCreateMethodCall, 'args'> & {\n args?: (ABIValue | undefined)[]\n }\n>\n\nexport type ProcessedAppUpdateMethodCall = Expand<\n Omit<AppUpdateMethodCall, 'args'> & {\n args?: (ABIValue | undefined)[]\n }\n>\n\nexport type ProcessedAppCallMethodCall = Expand<\n Omit<AppCallMethodCall, 'args'> & {\n args?: (ABIValue | undefined)[]\n }\n>\n\n/** Types that can be used to define a transaction argument for an ABI call transaction. */\nexport type AppMethodCallTransactionArgument =\n // The following should match the partial `args` types from `AppMethodCall<T>` below\n | TransactionWithSigner\n | Transaction\n | Promise<Transaction>\n | AppMethodCall<AppCreateParams>\n | AppMethodCall<AppUpdateParams>\n | AppMethodCall<AppMethodCallParams>\n\n/** Parameters to define an ABI method call. */\nexport type AppMethodCall<T> = Expand<Omit<T, 'args'>> & {\n /** The ABI method to call */\n method: ABIMethod\n /** Arguments to the ABI method, either:\n * * An ABI value\n * * A transaction with explicit signer\n * * A transaction (where the signer will be automatically assigned)\n * * An unawaited transaction (e.g. from algorand.createTransaction.{transactionType}())\n * * Another method call (via method call params object)\n * * undefined (this represents a placeholder transaction argument that is fulfilled by another method call argument)\n */\n args?: (\n | ABIValue\n // The following should match the above `AppMethodCallTransactionArgument` type above\n | TransactionWithSigner\n | Transaction\n | Promise<Transaction>\n | AppMethodCall<AppCreateParams>\n | AppMethodCall<AppUpdateParams>\n | AppMethodCall<AppMethodCallParams>\n | undefined\n )[]\n}\n\ntype AppMethodCallArgs = AppMethodCall<unknown>['args']\ntype AppMethodCallArg = NonNullable<AppMethodCallArgs>[number]\n\nexport type AsyncTransactionParams = {\n txn: Promise<Transaction>\n signer?: TransactionSigner\n maxFee?: AlgoAmount\n}\n\nexport type TransactionParams = {\n txn: Transaction\n signer?: TransactionSigner\n maxFee?: AlgoAmount\n}\n\ntype ExtractedMethodCallTransactionArg =\n | { data: TransactionParams; type: 'txn' }\n | {\n data: AsyncTransactionParams\n type: 'asyncTxn'\n }\n | { data: ProcessedAppCallMethodCall | ProcessedAppCreateMethodCall | ProcessedAppUpdateMethodCall; type: 'methodCall' }\n\nexport function extractComposerTransactionsFromAppMethodCallParams(\n params: AppCallMethodCall | AppCreateMethodCall | AppUpdateMethodCall | AppDeleteMethodCall,\n parentSigner?: TransactionSigner,\n): ExtractedMethodCallTransactionArg[] {\n const composerTransactions = new Array<ExtractedMethodCallTransactionArg>()\n const methodCallArgs = params.args\n if (!methodCallArgs) return []\n\n // Extract signer from params, falling back to parentSigner\n const currentSigner = params.signer ? ('signer' in params.signer ? params.signer.signer : params.signer) : parentSigner\n\n for (let i = 0; i < methodCallArgs.length; i++) {\n const arg = methodCallArgs[i]\n\n if (arg === undefined) {\n // is a transaction or default value placeholder, do nothing\n continue\n }\n if (isAbiValue(arg)) {\n // if is ABI value, also ignore\n continue\n }\n\n if (isTransactionWithSignerArg(arg)) {\n composerTransactions.push({\n data: {\n txn: arg.txn,\n signer: arg.signer,\n },\n type: 'txn',\n })\n\n continue\n }\n if (isAppCallMethodCallArg(arg)) {\n // Recursively extract nested method call transactions, passing the nested call itself and current signer as parent\n const nestedComposerTransactions = extractComposerTransactionsFromAppMethodCallParams(arg, currentSigner)\n composerTransactions.push(...nestedComposerTransactions)\n composerTransactions.push({\n data: {\n ...arg,\n signer: arg.signer ?? currentSigner,\n args: processAppMethodCallArgs(arg.args),\n },\n type: 'methodCall',\n } satisfies ExtractedMethodCallTransactionArg)\n\n continue\n }\n if (arg instanceof Promise) {\n composerTransactions.push({\n data: {\n txn: arg,\n signer: currentSigner,\n },\n type: 'asyncTxn',\n })\n continue\n }\n\n composerTransactions.push({\n data: {\n txn: Promise.resolve(arg),\n signer: currentSigner,\n },\n type: 'asyncTxn',\n })\n }\n\n return composerTransactions\n}\n\nexport function processAppMethodCallArgs(args: AppMethodCallArg[] | undefined): (ABIValue | undefined)[] | undefined {\n if (args === undefined) return undefined\n\n return args.map((arg) => {\n if (arg === undefined) {\n // Handle explicit placeholders (either transaction or default value)\n return undefined\n } else if (!isAbiValue(arg)) {\n // If the arg is not an ABIValue, it's must be a transaction, set to undefined\n // transaction arguments should be flattened out and added into the composer during the add process\n return undefined\n }\n return arg\n })\n}\n\nfunction isTransactionWithSignerArg(arg: AppMethodCallArg): arg is TransactionWithSigner {\n return typeof arg === 'object' && arg !== undefined && 'txn' in arg && 'signer' in arg\n}\n\nfunction isAppCallMethodCallArg(\n arg: AppMethodCallArg,\n): arg is AppMethodCall<AppCreateParams> | AppMethodCall<AppUpdateParams> | AppMethodCall<AppMethodCallParams> {\n return typeof arg === 'object' && arg !== undefined && 'method' in arg\n}\n\nconst isAbiValue = (x: unknown): x is ABIValue => {\n if (Array.isArray(x)) return x.length == 0 || x.every(isAbiValue)\n\n // If x is a POJO literal\n if (Object.getPrototypeOf(x) === Object.getPrototypeOf({})) {\n return Object.values(x as object).every(isAbiValue)\n }\n\n return (\n typeof x === 'bigint' ||\n typeof x === 'boolean' ||\n typeof x === 'number' ||\n typeof x === 'string' ||\n x instanceof Uint8Array ||\n x instanceof Address\n )\n}\n\n/**\n * Prepares method arguments for ABI encoding by building reference arrays and\n * replacing reference-type arguments (account, asset, application) with their indices.\n */\nfunction prepareArgsForEncoding(\n sender: Address,\n appId: bigint,\n method: ABIMethod,\n methodArgs: (ABIValue | undefined)[],\n accountReferences?: Address[],\n appReferences?: bigint[],\n assetReferences?: bigint[],\n): { accountReferences: Address[]; appReferences: bigint[]; assetReferences: bigint[]; updatedArgs: (ABIValue | undefined)[] } {\n const accounts = [...(accountReferences ?? [])]\n const assets = [...(assetReferences ?? [])]\n const apps = [...(appReferences ?? [])]\n\n const updatedArgs = methodArgs.map((arg, i) => {\n const argType = method.args[i].type\n if (!argTypeIsReference(argType)) {\n return arg\n }\n switch (argType) {\n case 'account': {\n let addr: Address\n if (typeof arg === 'string') {\n addr = getAddress(arg)\n } else if (arg instanceof Uint8Array) {\n addr = new Address(arg)\n } else {\n throw new Error('Invalid value for account')\n }\n\n if (sender.equals(addr)) {\n return 0\n }\n\n const existing = accounts.findIndex((a) => a.equals(addr)) + 1\n if (existing) return existing\n\n accounts.push(addr)\n return accounts.length\n }\n case 'asset': {\n if (typeof arg !== 'bigint') {\n throw new Error('Invalid value for asset')\n }\n\n const existing = assets.findIndex((a) => a === arg)\n if (existing === -1) {\n assets.push(arg)\n return assets.length - 1\n }\n\n return existing\n }\n case 'application': {\n if (typeof arg !== 'bigint') {\n throw new Error('Invalid value for application')\n }\n\n if (arg === appId) return 0\n\n const existing = apps.findIndex((a) => a === arg) + 1\n if (existing) return existing\n\n apps.push(arg)\n return apps.length\n }\n }\n })\n\n return { accountReferences: accounts, appReferences: apps, assetReferences: assets, updatedArgs }\n}\n\n/**\n * Encode ABI method arguments with tuple packing support\n * Ports the logic from the Rust encode_method_arguments function\n */\nfunction encodeMethodArguments(method: ABIMethod, args: (ABIValue | undefined)[]): Uint8Array[] {\n const encodedArgs = new Array<Uint8Array>()\n\n // Insert method selector at the front\n encodedArgs.push(method.getSelector())\n\n // Get ABI types for non-transaction arguments\n const abiTypes = new Array<ABIType>()\n const abiValues = new Array<ABIValue>()\n\n // Process each method argument\n for (let i = 0; i < method.args.length; i++) {\n const methodArg = method.args[i]\n const argValue = args[i]\n\n if (argTypeIsTransaction(methodArg.type)) {\n // Transaction arguments are not ABI encoded - they're handled separately\n } else if (argTypeIsReference(methodArg.type)) {\n // Reference types are encoded as uint8 indexes\n const referenceType = methodArg.type\n if (typeof argValue === 'number') {\n abiTypes.push(new ABIUintType(8))\n abiValues.push(argValue)\n } else {\n throw new Error(`Invalid reference value for ${referenceType}: ${argValue}`)\n }\n } else if (argValue !== undefined) {\n // Regular ABI value\n abiTypes.push(methodArg.type)\n // it's safe to cast to ABIValue here because the abiType must be ABIValue\n abiValues.push(argValue as ABIValue)\n }\n\n // Skip undefined values (transaction placeholders)\n }\n\n if (abiValues.length !== abiTypes.length) {\n throw new Error('Mismatch in length of non-transaction arguments')\n }\n\n // Apply ARC-4 tuple packing for methods with more than 14 arguments\n // 14 instead of 15 in the ARC-4 because the first argument (method selector) is added separately\n if (abiTypes.length > ARGS_TUPLE_PACKING_THRESHOLD) {\n encodedArgs.push(...encodeArgsWithTuplePacking(abiTypes, abiValues))\n } else {\n encodedArgs.push(...encodeArgsIndividually(abiTypes, abiValues))\n }\n\n return encodedArgs\n}\n\n/**\n * Encode individual ABI values\n */\nfunction encodeArgsIndividually(abiTypes: ABIType[], abiValues: ABIValue[]): Uint8Array[] {\n const encodedArgs: Uint8Array[] = []\n\n for (let i = 0; i < abiTypes.length; i++) {\n const abiType = abiTypes[i]\n const abiValue = abiValues[i]\n const encoded = abiType.encode(abiValue)\n encodedArgs.push(encoded)\n }\n\n return encodedArgs\n}\n\n/**\n * Encode ABI values with tuple packing for methods with many arguments\n */\nfunction encodeArgsWithTuplePacking(abiTypes: ABIType[], abiValues: ABIValue[]): Uint8Array[] {\n const encodedArgs: Uint8Array[] = []\n\n // Encode first 14 arguments individually\n const first14AbiTypes = abiTypes.slice(0, ARGS_TUPLE_PACKING_THRESHOLD)\n const first14AbiValues = abiValues.slice(0, ARGS_TUPLE_PACKING_THRESHOLD)\n encodedArgs.push(...encodeArgsIndividually(first14AbiTypes, first14AbiValues))\n\n // Pack remaining arguments into tuple at position 15\n const remainingAbiTypes = abiTypes.slice(ARGS_TUPLE_PACKING_THRESHOLD)\n const remainingAbiValues = abiValues.slice(ARGS_TUPLE_PACKING_THRESHOLD)\n\n if (remainingAbiTypes.length > 0) {\n const tupleType = new ABITupleType(remainingAbiTypes)\n const tupleValue = remainingAbiValues\n const tupleEncoded = tupleType.encode(tupleValue)\n encodedArgs.push(tupleEncoded)\n }\n\n return encodedArgs\n}\n\n/**\n * Builds encoded ABI method arguments and resolves reference arrays\n */\nfunction buildMethodCallArgsAndReferences(params: {\n sender: Address\n appId: bigint\n method: ABIMethod\n args: (ABIValue | undefined)[]\n accountReferences?: Address[]\n appReferences?: bigint[]\n assetReferences?: bigint[]\n}): { args: Uint8Array[]; accountReferences: Address[]; appReferences: bigint[]; assetReferences: bigint[] } {\n const { accountReferences, appReferences, assetReferences, updatedArgs } = prepareArgsForEncoding(\n params.sender,\n params.appId,\n params.method,\n params.args ?? [],\n params.accountReferences,\n params.appReferences,\n params.assetReferences,\n )\n\n const encodedArgs = encodeMethodArguments(params.method, updatedArgs)\n\n return {\n args: encodedArgs,\n accountReferences,\n appReferences,\n assetReferences,\n }\n}\n\nexport const buildAppCreateMethodCall = async (\n params: ProcessedAppCreateMethodCall,\n appManager: AppManager,\n suggestedParams: SuggestedParams,\n defaultValidityWindow: bigint,\n): Promise<Transaction> => {\n const commonData = buildTransactionCommonData(params, suggestedParams, defaultValidityWindow)\n const approvalProgram =\n typeof params.approvalProgram === 'string'\n ? (await appManager.compileTeal(params.approvalProgram)).compiledBase64ToBytes\n : params.approvalProgram\n const clearStateProgram =\n typeof params.clearStateProgram === 'string'\n ? (await appManager.compileTeal(params.clearStateProgram)).compiledBase64ToBytes\n : params.clearStateProgram\n const globalStateSchema =\n params.schema?.globalByteSlices !== undefined || params.schema?.globalInts !== undefined\n ? {\n numByteSlices: params.schema?.globalByteSlices ?? 0,\n numUints: params.schema?.globalInts ?? 0,\n }\n : undefined\n const localStateSchema =\n params.schema?.localByteSlices !== undefined || params.schema?.localInts !== undefined\n ? {\n numByteSlices: params.schema?.localByteSlices ?? 0,\n numUints: params.schema?.localInts ?? 0,\n }\n : undefined\n const extraProgramPages =\n params.extraProgramPages !== undefined ? params.extraProgramPages : calculateExtraProgramPages(approvalProgram!, clearStateProgram!)\n const accountReferences = params.accountReferences?.map((a) => getAddress(a))\n const argsAndReferences = buildMethodCallArgsAndReferences({\n sender: commonData.sender,\n appId: 0n,\n method: params.method,\n args: params.args ?? [],\n accountReferences: accountReferences,\n appReferences: params.appReferences,\n assetReferences: params.assetReferences,\n })\n\n // If accessReferences is provided, we should not pass legacy foreign arrays\n const hasAccessReferences = params.accessReferences && params.accessReferences.length > 0\n\n return new Transaction({\n ...commonData,\n type: TransactionType.AppCall,\n appCall: {\n appId: 0n,\n onComplete: params.onComplete ?? OnApplicationComplete.NoOp,\n approvalProgram: approvalProgram,\n clearStateProgram: clearStateProgram,\n globalStateSchema: globalStateSchema,\n localStateSchema: localStateSchema,\n extraProgramPages: extraProgramPages,\n args: argsAndReferences.args,\n ...(hasAccessReferences\n ? { accessReferences: params.accessReferences }\n : {\n accountReferences: argsAndReferences.accountReferences,\n appReferences: argsAndReferences.appReferences,\n assetReferences: argsAndReferences.assetReferences,\n boxReferences: params.boxReferences?.map(AppManager.getBoxReference),\n }),\n rejectVersion: params.rejectVersion,\n },\n })\n}\n\nexport const buildAppUpdateMethodCall = async (\n params: ProcessedAppUpdateMethodCall,\n appManager: AppManager,\n suggestedParams: SuggestedParams,\n defaultValidityWindow: bigint,\n): Promise<Transaction> => {\n const commonData = buildTransactionCommonData(params, suggestedParams, defaultValidityWindow)\n const approvalProgram =\n typeof params.approvalProgram === 'string'\n ? (await appManager.compileTeal(params.approvalProgram)).compiledBase64ToBytes\n : params.approvalProgram\n const clearStateProgram =\n typeof params.clearStateProgram === 'string'\n ? (await appManager.compileTeal(params.clearStateProgram)).compiledBase64ToBytes\n : params.clearStateProgram\n const accountReferences = params.accountReferences?.map((a) => getAddress(a))\n const argsAndReferences = buildMethodCallArgsAndReferences({\n sender: commonData.sender,\n appId: params.appId,\n method: params.method,\n args: params.args ?? [],\n accountReferences: accountReferences,\n appReferences: params.appReferences,\n assetReferences: params.assetReferences,\n })\n\n // If accessReferences is provided, we should not pass legacy foreign arrays\n const hasAccessReferences = params.accessReferences && params.accessReferences.length > 0\n\n return new Transaction({\n ...commonData,\n type: TransactionType.AppCall,\n appCall: {\n appId: params.appId,\n onComplete: OnApplicationComplete.UpdateApplication,\n approvalProgram: approvalProgram,\n clearStateProgram: clearStateProgram,\n args: argsAndReferences.args,\n ...(hasAccessReferences\n ? { accessReferences: params.accessReferences }\n : {\n accountReferences: argsAndReferences.accountReferences,\n appReferences: argsAndReferences.appReferences,\n assetReferences: argsAndReferences.assetReferences,\n boxReferences: params.boxReferences?.map(AppManager.getBoxReference),\n }),\n rejectVersion: params.rejectVersion,\n },\n })\n}\n\nexport const buildAppCallMethodCall = async (\n params: ProcessedAppCallMethodCall,\n suggestedParams: SuggestedParams,\n defaultValidityWindow: bigint,\n): Promise<Transaction> => {\n const commonData = buildTransactionCommonData(params, suggestedParams, defaultValidityWindow)\n const accountReferences = params.accountReferences?.map((a) => getAddress(a))\n const argsAndReferences = buildMethodCallArgsAndReferences({\n sender: commonData.sender,\n appId: params.appId,\n method: params.method,\n args: params.args ?? [],\n accountReferences: accountReferences,\n appReferences: params.appReferences,\n assetReferences: params.assetReferences,\n })\n\n // If accessReferences is provided, we should not pass legacy foreign arrays\n const hasAccessReferences = params.accessReferences && params.accessReferences.length > 0\n\n return new Transaction({\n ...commonData,\n type: TransactionType.AppCall,\n appCall: {\n appId: params.appId,\n onComplete: params.onComplete ?? OnApplicationComplete.NoOp,\n args: argsAndReferences.args,\n ...(hasAccessReferences\n ? { accessReferences: params.accessReferences }\n : {\n accountReferences: argsAndReferences.accountReferences,\n appReferences: argsAndReferences.appReferences,\n assetReferences: argsAndReferences.assetReferences,\n boxReferences: params.boxReferences?.map(AppManager.getBoxReference),\n }),\n rejectVersion: params.rejectVersion,\n },\n })\n}\n"],"mappings":"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"}
@@ -73,7 +73,7 @@ declare class AccountManager {
73
73
  setDefaultSigner(signer: TransactionSigner | AddressWithTransactionSigner): AccountManager;
74
74
  /**
75
75
  * Records the given account (that can sign) against the address of the provided account for later
76
- * retrieval and returns a `AddressWithSigner` along with the original account in an `account` property.
76
+ * retrieval and returns a `AddressWithTransactionSigner` along with the original account in an `account` property.
77
77
  */
78
78
  private signerAccount;
79
79
  /**
@@ -1,12 +1,12 @@
1
1
  const require_rolldown_runtime = require('../_virtual/rolldown_runtime.js');
2
2
  const require_address = require('../packages/common/src/address.js');
3
- const require_signer = require('../packages/transact/src/signer.js');
4
- const require_multisig = require('../packages/transact/src/multisig.js');
5
- const require_logicsig = require('../packages/transact/src/logicsig.js');
6
3
  const require_amount = require('./amount.js');
7
4
  const require_config = require('../config.js');
8
5
  const require_util = require('../util.js');
9
6
  const require_index = require('../packages/algo25/src/index.js');
7
+ const require_signer = require('../packages/transact/src/signer.js');
8
+ const require_logicsig = require('../packages/transact/src/logicsig.js');
9
+ const require_multisig = require('../packages/transact/src/multisig.js');
10
10
  const require_account = require('./account.js');
11
11
  const require_composer = require('./composer.js');
12
12
  const require_kmd_account_manager = require('./kmd-account-manager.js');
@@ -85,7 +85,7 @@ var AccountManager = class {
85
85
  }
86
86
  /**
87
87
  * Records the given account (that can sign) against the address of the provided account for later
88
- * retrieval and returns a `AddressWithSigner` along with the original account in an `account` property.
88
+ * retrieval and returns a `AddressWithTransactionSigner` along with the original account in an `account` property.
89
89
  */
90
90
  signerAccount(account) {
91
91
  const signer = getAccountTransactionSigner(account);
@@ -214,7 +214,7 @@ var AccountManager = class {
214
214
  */
215
215
  async getInformation(sender) {
216
216
  const senderAddress = require_address.getAddress(sender).toString();
217
- const { round, lastHeartbeat = void 0, lastProposed = void 0, address,...account } = await this._clientManager.algod.accountInformation(senderAddress);
217
+ const { round, lastHeartbeat = void 0, lastProposed = void 0, address, ...account } = await this._clientManager.algod.accountInformation(senderAddress);
218
218
  return {
219
219
  ...account,
220
220
  authAddr: account.authAddr,
@@ -1 +1 @@
1
- {"version":3,"file":"account-manager.js","names":["memoize","KmdAccountManager","TransactionComposer","acc: AddressWithTransactionSigner","Address","getAddress","AlgoAmount","seedFromMnemonic","nacl","generateAddressWithSigners","getOptionalAddress","MultisigAccount","LogicSigAccount","DISPENSER_ACCOUNT","calculateFundAmount"],"sources":["../../src/types/account-manager.ts"],"sourcesContent":["import { seedFromMnemonic } from '@algorandfoundation/algokit-algo25'\nimport { SuggestedParams } from '@algorandfoundation/algokit-algod-client'\nimport { Address, ReadableAddress, getAddress, getOptionalAddress } from '@algorandfoundation/algokit-common'\nimport {\n AddressWithSigners,\n AddressWithTransactionSigner,\n LogicSigAccount,\n MultisigAccount,\n MultisigMetadata,\n TransactionSigner,\n generateAddressWithSigners,\n} from '@algorandfoundation/algokit-transact'\nimport nacl from 'tweetnacl'\nimport { Config } from '../config'\nimport { calculateFundAmount, memoize } from '../util'\nimport { AccountInformation, DISPENSER_ACCOUNT } from './account'\nimport { AlgoAmount } from './amount'\nimport { ClientManager } from './client-manager'\nimport { CommonTransactionParams, TransactionComposer } from './composer'\nimport { TestNetDispenserApiClient } from './dispenser-client'\nimport { KmdAccountManager } from './kmd-account-manager'\nimport { SendParams, SendSingleTransactionResult } from './transaction'\n\n/** Result from performing an ensureFunded call. */\nexport interface EnsureFundedResult {\n /** The transaction ID of the transaction that funded the account. */\n transactionId: string\n /** The amount that was sent to the account. */\n amountFunded: AlgoAmount\n}\n\n/**\n * Returns a `TransactionSigner` for the given account that can sign a transaction.\n * This function has memoization, so will return the same transaction signer for a given account.\n * @param account An account that can sign a transaction\n * @returns A transaction signer\n * @example\n * ```typescript\n * const signer = getAccountTransactionSigner(account)\n * ```\n */\nexport const getAccountTransactionSigner = memoize(function (\n account: AddressWithTransactionSigner | LogicSigAccount | MultisigAccount,\n): TransactionSigner {\n return account.signer\n})\n\n/** Creates and keeps track of signing accounts that can sign transactions for a sending address. */\nexport class AccountManager {\n private _clientManager: ClientManager\n private _kmdAccountManager: KmdAccountManager\n private _accounts: { [address: string]: AddressWithTransactionSigner } = {}\n private _defaultSigner?: TransactionSigner\n\n /**\n * Create a new account manager.\n * @param clientManager The ClientManager client to use for algod and kmd clients\n * @example Create a new account manager\n * ```typescript\n * const accountManager = new AccountManager(clientManager)\n * ```\n */\n constructor(clientManager: ClientManager) {\n this._clientManager = clientManager\n this._kmdAccountManager = new KmdAccountManager(clientManager)\n }\n\n private _getComposer(getSuggestedParams?: () => Promise<SuggestedParams>) {\n return new TransactionComposer({\n algod: this._clientManager.algod,\n getSigner: this.getSigner.bind(this),\n getSuggestedParams: getSuggestedParams ?? (() => this._clientManager.algod.suggestedParams()),\n })\n }\n\n /**\n * KMD account manager that allows you to easily get and create accounts using KMD.\n * @returns The `KmdAccountManager` instance.\n * @example\n * ```typescript\n * const kmdManager = accountManager.kmd;\n * ```\n */\n public get kmd() {\n return this._kmdAccountManager\n }\n\n /**\n * Sets the default signer to use if no other signer is specified.\n *\n * If this isn't set an a transaction needs signing for a given sender\n * then an error will be thrown from `getSigner` / `getAccount`.\n * @param signer The signer to use, either a `TransactionSigner` or a `AddressWithSigner`\n * @example\n * ```typescript\n * const signer = accountManager.random() // Can be anything that returns a `TransactionSigner` or `AddressWithSigner`\n * accountManager.setDefaultSigner(signer)\n *\n * // When signing a transaction, if there is no signer registered for the sender then the default signer will be used\n * const signer = accountManager.getSigner(\"SENDERADDRESS\")\n * ```\n * @returns The `AccountManager` so method calls can be chained\n */\n public setDefaultSigner(signer: TransactionSigner | AddressWithTransactionSigner): AccountManager {\n this._defaultSigner = 'signer' in signer ? signer.signer : signer\n return this\n }\n\n /**\n * Records the given account (that can sign) against the address of the provided account for later\n * retrieval and returns a `AddressWithSigner` along with the original account in an `account` property.\n */\n\n private signerAccount<T extends AddressWithTransactionSigner | LogicSigAccount | MultisigAccount>(\n account: T,\n ): Address &\n AddressWithTransactionSigner & {\n /* The underlying account that specified this address. */ account: T\n } {\n const signer = getAccountTransactionSigner(account)\n const acc: AddressWithTransactionSigner = {\n addr: account.addr,\n signer: signer,\n }\n this._accounts[acc.addr.toString()] = acc\n\n const addressWithAccount = Address.fromString(acc.addr.toString()) as Address & AddressWithTransactionSigner & { account: T }\n addressWithAccount.account = account\n addressWithAccount.addr = acc.addr\n addressWithAccount.signer = signer\n return addressWithAccount\n }\n\n /**\n * Tracks the given account for later signing.\n *\n * Note: If you are generating accounts via the various methods on `AccountManager`\n * (like `random`, `fromMnemonic`, `logicsig`, etc.) then they automatically get tracked.\n * @param account The account to register, which can be a `AddressWithSigner` or\n * a `algosdk.Account`, `algosdk.LogicSigAccount`, `SigningAccount` or `MultisigAccount`\n * @example\n * ```typescript\n * const accountManager = new AccountManager(clientManager)\n * .setSignerFromAccount(algosdk.generateAccount())\n * .setSignerFromAccount(new algosdk.LogicSigAccount(program, args))\n * .setSignerFromAccount(new SigningAccount(mnemonic, sender))\n * .setSignerFromAccount(new MultisigAccount({version: 1, threshold: 1, addrs: [\"ADDRESS1...\", \"ADDRESS2...\"]}, [account1, account2]))\n * .setSignerFromAccount({addr: \"SENDERADDRESS\", signer: transactionSigner})\n * ```\n * @returns The `AccountManager` instance for method chaining\n */\n public setSignerFromAccount(account: AddressWithTransactionSigner | LogicSigAccount | MultisigAccount) {\n this.signerAccount(account)\n return this\n }\n\n /**\n * Tracks the given `TransactionSigner` against the given sender address for later signing.\n * @param sender The sender address to use this signer for\n * @param signer The `TransactionSigner` to sign transactions with for the given sender\n * @example\n * ```typescript\n * const accountManager = new AccountManager(clientManager)\n * .setSigner(\"SENDERADDRESS\", transactionSigner)\n * ```\n * @returns The `AccountManager` instance for method chaining\n */\n public setSigner(sender: string | Address, signer: TransactionSigner) {\n this._accounts[getAddress(sender).toString()] = { addr: getAddress(sender), signer }\n return this\n }\n\n /**\n * Takes all registered signers from the given `AccountManager` and adds them to this `AccountManager`.\n *\n * This is useful for situations where you have multiple contexts you are building accounts in such as unit tests.\n * @param anotherAccountManager Another account manager with signers registered\n * @param overwriteExisting Whether or not to overwrite any signers that have the same sender address with the ones in the other account manager or not (default: true)\n * @returns The `AccountManager` instance for method chaining\n * @example\n * ```typescript\n * accountManager2.setSigners(accountManager1);\n * ```\n */\n public setSigners(anotherAccountManager: AccountManager, overwriteExisting = true) {\n this._accounts = overwriteExisting\n ? { ...this._accounts, ...anotherAccountManager._accounts }\n : { ...anotherAccountManager._accounts, ...this._accounts }\n return this\n }\n\n /**\n * Returns the `TransactionSigner` for the given sender address, ready to sign a transaction for that sender.\n *\n * If no signer has been registered for that address then the default signer is used if registered and\n * if not then an error is thrown.\n *\n * @param sender The sender address\n * @example\n * ```typescript\n * const signer = accountManager.getSigner(\"SENDERADDRESS\")\n * ```\n * @returns The `TransactionSigner` or throws an error if not found and no default signer is set\n */\n public getSigner(sender: ReadableAddress): TransactionSigner {\n const signer = this._accounts[getAddress(sender).toString()]?.signer ?? this._defaultSigner\n if (!signer) throw new Error(`No signer found for address ${sender}`)\n return signer\n }\n\n /**\n * Returns the `AddressWithSigner` for the given sender address.\n *\n * If no signer has been registered for that address then an error is thrown.\n * @param sender The sender address\n * @example\n * ```typescript\n * const sender = accountManager.random()\n * // ...\n * // Returns the `AddressWithSigner` for `sender` that has previously been registered\n * const account = accountManager.getAccount(sender)\n * ```\n * @returns The `AddressWithSigner` or throws an error if not found\n */\n public getAccount(sender: ReadableAddress): AddressWithTransactionSigner {\n const account = this._accounts[getAddress(sender).toString()]\n if (!account) throw new Error(`No signer found for address ${sender}`)\n return account\n }\n\n /**\n * Returns the given sender account's current status, balance and spendable amounts.\n *\n * [Response data schema details](https://dev.algorand.co/reference/rest-apis/algod/#accountinformation)\n * @example\n * ```typescript\n * const address = \"XBYLS2E6YI6XXL5BWCAMOA4GTWHXWENZMX5UHXMRNWWUQ7BXCY5WC5TEPA\";\n * const accountInfo = await accountManager.getInformation(address);\n * ```\n *\n * @param sender The account / address to look up\n * @returns The account information\n */\n public async getInformation(sender: ReadableAddress): Promise<AccountInformation> {\n const senderAddress = getAddress(sender).toString()\n const {\n round,\n lastHeartbeat = undefined,\n lastProposed = undefined,\n address,\n ...account\n } = await this._clientManager.algod.accountInformation(senderAddress)\n\n return {\n ...account,\n authAddr: account.authAddr,\n address,\n balance: AlgoAmount.MicroAlgo(Number(account.amount)),\n amountWithoutPendingRewards: AlgoAmount.MicroAlgo(Number(account.amountWithoutPendingRewards)),\n minBalance: AlgoAmount.MicroAlgo(Number(account.minBalance)),\n pendingRewards: AlgoAmount.MicroAlgo(Number(account.pendingRewards)),\n rewards: AlgoAmount.MicroAlgo(Number(account.rewards)),\n validAsOfRound: BigInt(round),\n totalAppsOptedIn: Number(account.totalAppsOptedIn),\n totalAssetsOptedIn: Number(account.totalAssetsOptedIn),\n totalCreatedApps: Number(account.totalCreatedApps),\n totalCreatedAssets: Number(account.totalCreatedAssets),\n appsTotalExtraPages: account.appsTotalExtraPages !== undefined ? Number(account.appsTotalExtraPages) : undefined,\n rewardBase: account.rewardBase !== undefined ? Number(account.rewardBase) : undefined,\n totalBoxBytes: account.totalBoxBytes !== undefined ? Number(account.totalBoxBytes) : undefined,\n totalBoxes: account.totalBoxes !== undefined ? Number(account.totalBoxes) : undefined,\n lastHeartbeatRound: lastHeartbeat !== undefined ? BigInt(lastHeartbeat) : undefined,\n lastProposedRound: lastProposed !== undefined ? BigInt(lastProposed) : undefined,\n }\n }\n\n /**\n * Tracks and returns an Algorand account with secret key loaded (i.e. that can sign transactions) by taking the mnemonic secret.\n *\n * @example\n * ```typescript\n * const account = accountManager.fromMnemonic(\"mnemonic secret ...\")\n * const rekeyedAccount = accountManager.fromMnemonic(\"mnemonic secret ...\", \"SENDERADDRESS...\")\n * ```\n * @param mnemonicSecret The mnemonic secret representing the private key of an account; **Note: Be careful how the mnemonic is handled**,\n * never commit it into source control and ideally load it from the environment (ideally via a secret storage service) rather than the file system.\n * @param sender The optional sender address to use this signer for (aka a rekeyed account)\n * @returns The account\n */\n public fromMnemonic(mnemonicSecret: string, sender?: string | Address): AddressWithTransactionSigner {\n const seed = seedFromMnemonic(mnemonicSecret)\n\n const keypair = nacl.sign.keyPair.fromSeed(seed)\n\n const addrWithSigners = generateAddressWithSigners({\n ed25519Pubkey: keypair.publicKey,\n sendingAddress: getOptionalAddress(sender),\n rawEd25519Signer: async (bytesToSign: Uint8Array): Promise<Uint8Array> => {\n return nacl.sign.detached(bytesToSign, keypair.secretKey)\n },\n })\n\n return this.signerAccount(addrWithSigners)\n }\n\n /**\n * Tracks and returns an Algorand account that is a rekeyed version of the given account to a new sender.\n *\n * @example\n * ```typescript\n * const account = accountManager.fromMnemonic(\"mnemonic secret ...\")\n * const rekeyedAccount = accountManager.rekeyed(account, \"SENDERADDRESS...\")\n * ```\n * @param account The account to use as the signer for this new rekeyed account\n * @param sender The sender address to use as the new sender\n * @returns The account\n */\n public rekeyed(sender: string | Address, account: AddressWithTransactionSigner) {\n return this.signerAccount({ addr: getAddress(sender), signer: account.signer })\n }\n\n /**\n * Tracks and returns an Algorand account with private key loaded by convention from environment variables based on the given name identifier.\n *\n * Note: This function expects to run in a Node.js environment.\n *\n * ## Convention:\n * * **Non-LocalNet:** will load process.env['\\{NAME\\}_MNEMONIC'] as a mnemonic secret; **Note: Be careful how the mnemonic is handled**,\n * never commit it into source control and ideally load it via a secret storage service rather than the file system.\n * If process.env['\\{NAME\\}_SENDER'] is defined then it will use that for the sender address (i.e. to support rekeyed accounts)\n * * **LocalNet:** will load the account from a KMD wallet called \\{NAME\\} and if that wallet doesn't exist it will create it and fund the account for you\n *\n * This allows you to write code that will work seamlessly in production and local development (LocalNet) without manual config locally (including when you reset the LocalNet).\n *\n * @example Default\n *\n * If you have a mnemonic secret loaded into `process.env.MY_ACCOUNT_MNEMONIC` then you can call the following to get that private key loaded into an account object:\n * ```typescript\n * const account = await accountManager.fromEnvironment('MY_ACCOUNT')\n * ```\n *\n * If that code runs against LocalNet then a wallet called `MY_ACCOUNT` will automatically be created with an account that is automatically funded with 1000 (default) ALGO from the default LocalNet dispenser.\n * If not running against LocalNet then it will use proces.env.MY_ACCOUNT_MNEMONIC as the private key and (if present) process.env.MY_ACCOUNT_SENDER as the sender address.\n *\n * @param name The name identifier of the account\n * @param fundWith The optional amount to fund the account with when it gets created (when targeting LocalNet), if not specified then 1000 ALGO will be funded from the dispenser account\n * @returns The account\n */\n public async fromEnvironment(name: string, fundWith?: AlgoAmount) {\n if (!process || !process.env) {\n throw new Error('Attempt to get account with private key from a non Node.js context; this is not supported!')\n }\n\n const accountMnemonic = process.env[`${name.toUpperCase()}_MNEMONIC`]\n const sender = process.env[`${name.toUpperCase()}_SENDER`]\n\n if (accountMnemonic) {\n return this.fromMnemonic(accountMnemonic, sender)\n }\n\n if (await this._clientManager.isLocalNet()) {\n const account = await this._kmdAccountManager.getOrCreateWalletAccount(name, fundWith)\n return this.signerAccount(account)\n }\n\n throw new Error(`Missing environment variable ${name.toUpperCase()}_MNEMONIC when looking for account ${name}`)\n }\n\n /**\n * Tracks and returns an Algorand account with private key loaded from the given KMD wallet (identified by name).\n *\n * @param name The name of the wallet to retrieve an account from\n * @param predicate An optional filter to use to find the account (otherwise it will return a random account from the wallet)\n * @param sender The optional sender address to use this signer for (aka a rekeyed account)\n * @example Get default funded account in a LocalNet\n *\n * ```typescript\n * const defaultDispenserAccount = await accountManager.fromKmd('unencrypted-default-wallet',\n * a => a.status !== 'Offline' && a.amount > 1_000_000_000\n * )\n * ```\n * @returns The account\n */\n public async fromKmd(\n name: string,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n predicate?: (account: Record<string, any>) => boolean,\n sender?: string | Address,\n ) {\n const account = await this._kmdAccountManager.getWalletAccount(name, predicate, sender)\n if (!account) throw new Error(`Unable to find KMD account ${name}${predicate ? ' with predicate' : ''}`)\n return this.signerAccount(account)\n }\n\n /**\n * Tracks and returns an account that supports partial or full multisig signing.\n *\n * @example\n * ```typescript\n * const account = accountManager.multisig({version: 1, threshold: 1, addrs: [\"ADDRESS1...\", \"ADDRESS2...\"]},\n * [(await accountManager.fromEnvironment('ACCOUNT1')).account])\n * ```\n * @param multisigParams The parameters that define the multisig account\n * @param subSigners The signers that are currently present\n * @returns A multisig account wrapper\n */\n public multisig(multisigParams: MultisigMetadata, subSigners: AddressWithSigners[]) {\n return this.signerAccount(new MultisigAccount(multisigParams, subSigners))\n }\n\n /**\n * Tracks and returns an account that represents a logic signature.\n *\n * @example\n * ```typescript\n * const account = accountManager.logicsig(program, [new Uint8Array(3, ...)])\n * ```\n * @param program The bytes that make up the compiled logic signature\n * @param args The (binary) arguments to pass into the logic signature\n * @returns A logic signature account wrapper\n */\n public logicsig(program: Uint8Array, args?: Array<Uint8Array>) {\n return this.signerAccount(new LogicSigAccount(program, args))\n }\n\n /**\n * Tracks and returns a new, random Algorand account with secret key loaded.\n *\n * @example\n * ```typescript\n * const account = accountManager.random()\n * ```\n * @returns The account\n */\n public random() {\n const keypair = nacl.sign.keyPair()\n const rawSigner = async (bytesToSign: Uint8Array): Promise<Uint8Array> => {\n return nacl.sign.detached(bytesToSign, keypair.secretKey)\n }\n\n return this.signerAccount(generateAddressWithSigners({ ed25519Pubkey: keypair.publicKey, rawEd25519Signer: rawSigner }))\n }\n\n /**\n * Returns an account (with private key loaded) that can act as a dispenser from\n * environment variables, or against default LocalNet if no environment variables present.\n *\n * Note: requires a Node.js environment to execute.\n *\n * If present, it will load the account mnemonic stored in process.env.DISPENSER_MNEMONIC and optionally\n * process.env.DISPENSER_SENDER if it's a rekeyed account.\n *\n * @example\n * ```typescript\n * const account = await accountManager.dispenserFromEnvironment()\n * ```\n *\n * @returns The account\n */\n public async dispenserFromEnvironment() {\n if (!process || !process.env) {\n throw new Error('Attempt to get dispenser from environment from a non Node.js context; this is not supported!')\n }\n\n return process.env[`${DISPENSER_ACCOUNT.toUpperCase()}_MNEMONIC`]\n ? await this.fromEnvironment(DISPENSER_ACCOUNT)\n : await this.localNetDispenser()\n }\n\n /**\n * Returns an Algorand account with private key loaded for the default LocalNet dispenser account (that can be used to fund other accounts).\n *\n * @example\n * ```typescript\n * const account = await accountManager.localNetDispenser()\n * ```\n * @returns The account\n */\n public async localNetDispenser() {\n const dispenser = await this._kmdAccountManager.getLocalNetDispenserAccount()\n return this.signerAccount(dispenser)\n }\n\n /**\n * Rekey an account to a new address.\n *\n * **Note:** Please be careful with this function and be sure to read the [official rekey guidance](https://dev.algorand.co/concepts/accounts/rekeying).\n *\n * @param account The account to rekey\n * @param rekeyTo The account address or signing account of the account that will be used to authorise transactions for the rekeyed account going forward.\n * If a signing account is provided that will now be tracked as the signer for `account` in this `AccountManager`\n * @param options Any parameters to control the transaction or execution of the transaction\n *\n * @example Basic example (with string addresses)\n * ```typescript\n * await accountManager.rekeyAccount({account: \"ACCOUNTADDRESS\", rekeyTo: \"NEWADDRESS\"})\n * ```\n * @example Basic example (with signer accounts)\n * ```typescript\n * await accountManager.rekeyAccount({account: account1, rekeyTo: newSignerAccount})\n * ```\n * @example Advanced example\n * ```typescript\n * await accountManager.rekeyAccount({\n * account: \"ACCOUNTADDRESS\",\n * rekeyTo: \"NEWADDRESS\",\n * lease: 'lease',\n * note: 'note',\n * firstValidRound: 1000n,\n * validityWindow: 10,\n * extraFee: (1000).microAlgo(),\n * staticFee: (1000).microAlgo(),\n * // Max fee doesn't make sense with extraFee AND staticFee\n * // already specified, but here for completeness\n * maxFee: (3000).microAlgo(),\n * maxRoundsToWaitForConfirmation: 5,\n * suppressLog: true,\n * })\n * ```\n * @returns The result of the transaction and the transaction that was sent\n */\n async rekeyAccount(\n account: string | Address,\n rekeyTo: string | Address | AddressWithTransactionSigner,\n options?: Omit<CommonTransactionParams, 'sender'> & SendParams,\n ): Promise<SendSingleTransactionResult> {\n const result = await this._getComposer()\n .addPayment({\n ...options,\n sender: getAddress(account),\n receiver: getAddress(account),\n amount: AlgoAmount.MicroAlgo(0),\n rekeyTo: getAddress(rekeyTo),\n })\n .send(options)\n\n // If the rekey is a signing account set it as the signer for this account\n if (typeof rekeyTo === 'object' && 'addr' in rekeyTo) {\n this.rekeyed(account, rekeyTo)\n }\n\n Config.getLogger(options?.suppressLog).info(`Rekeyed ${account} to ${rekeyTo} via transaction ${result.txIds.at(-1)}`)\n\n return { ...result, transaction: result.transactions.at(-1)!, confirmation: result.confirmations.at(-1)! }\n }\n\n private async _getEnsureFundedAmount(sender: Address, minSpendingBalance: AlgoAmount, minFundingIncrement?: AlgoAmount) {\n const accountInfo = await this.getInformation(sender)\n const currentSpendingBalance = accountInfo.balance.microAlgo - accountInfo.minBalance.microAlgo\n\n const amountFunded = calculateFundAmount(minSpendingBalance.microAlgo, currentSpendingBalance, minFundingIncrement?.microAlgo ?? 0n)\n\n return amountFunded === null ? undefined : AlgoAmount.MicroAlgo(amountFunded)\n }\n\n /**\n * Funds a given account using a dispenser account as a funding source such that\n * the given account has a certain amount of Algo free to spend (accounting for\n * Algo locked in minimum balance requirement).\n *\n * https://dev.algorand.co/concepts/smart-contracts/costs-constraints#mbr\n *\n * @param accountToFund The account to fund\n * @param dispenserAccount The account to use as a dispenser funding source\n * @param minSpendingBalance The minimum balance of Algo that the account should have available to spend (i.e. on top of minimum balance requirement)\n * @param options Optional parameters to control the funding increment, transaction or execution of the transaction\n * @example Example using AlgorandClient\n * ```typescript\n * // Basic example\n * await accountManager.ensureFunded(\"ACCOUNTADDRESS\", \"DISPENSERADDRESS\", algokit.algo(1))\n * // With configuration\n * await accountManager.ensureFunded(\"ACCOUNTADDRESS\", \"DISPENSERADDRESS\", algokit.algo(1),\n * { minFundingIncrement: algokit.algo(2), fee: (1000).microAlgo(), suppressLog: true }\n * )\n * ```\n * @returns\n * - The result of executing the dispensing transaction and the `amountFunded` if funds were needed.\n * - `undefined` if no funds were needed.\n */\n async ensureFunded(\n accountToFund: string | Address,\n dispenserAccount: string | Address,\n minSpendingBalance: AlgoAmount,\n options?: {\n minFundingIncrement?: AlgoAmount\n } & SendParams &\n Omit<CommonTransactionParams, 'sender'>,\n ): Promise<(SendSingleTransactionResult & EnsureFundedResult) | undefined> {\n const addressToFund = getAddress(accountToFund)\n\n const amountFunded = await this._getEnsureFundedAmount(addressToFund, minSpendingBalance, options?.minFundingIncrement)\n if (!amountFunded) return undefined\n\n const result = await this._getComposer()\n .addPayment({\n ...options,\n sender: getAddress(dispenserAccount),\n receiver: addressToFund,\n amount: amountFunded,\n })\n .send(options)\n\n return {\n ...result,\n transaction: result.transactions[0],\n confirmation: result.confirmations[0],\n transactionId: result.txIds[0],\n amountFunded: amountFunded,\n }\n }\n\n /**\n * Funds a given account using a dispenser account retrieved from the environment,\n * per the `dispenserFromEnvironment` method, as a funding source such that\n * the given account has a certain amount of Algo free to spend (accounting for\n * Algo locked in minimum balance requirement).\n *\n * **Note:** requires a Node.js environment to execute.\n *\n * The dispenser account is retrieved from the account mnemonic stored in\n * process.env.DISPENSER_MNEMONIC and optionally process.env.DISPENSER_SENDER\n * if it's a rekeyed account, or against default LocalNet if no environment variables present.\n *\n * https://dev.algorand.co/concepts/smart-contracts/costs-constraints#mbr\n *\n * @param accountToFund The account to fund\n * @param minSpendingBalance The minimum balance of Algo that the account should have available to spend (i.e. on top of minimum balance requirement)\n * @param options Optional parameters to control the funding increment, transaction or execution of the transaction\n * @example Example using AlgorandClient\n * ```typescript\n * // Basic example\n * await accountManager.ensureFundedFromEnvironment(\"ACCOUNTADDRESS\", algokit.algo(1))\n * // With configuration\n * await accountManager.ensureFundedFromEnvironment(\"ACCOUNTADDRESS\", algokit.algo(1),\n * { minFundingIncrement: algokit.algo(2), fee: (1000).microAlgo(), suppressLog: true }\n * )\n * ```\n * @returns\n * - The result of executing the dispensing transaction and the `amountFunded` if funds were needed.\n * - `undefined` if no funds were needed.\n */\n async ensureFundedFromEnvironment(\n accountToFund: string | Address,\n minSpendingBalance: AlgoAmount,\n options?: {\n minFundingIncrement?: AlgoAmount\n } & SendParams &\n Omit<CommonTransactionParams, 'sender'>,\n ): Promise<(SendSingleTransactionResult & EnsureFundedResult) | undefined> {\n const addressToFund = getAddress(accountToFund)\n const dispenserAccount = await this.dispenserFromEnvironment()\n\n const amountFunded = await this._getEnsureFundedAmount(addressToFund, minSpendingBalance, options?.minFundingIncrement)\n if (!amountFunded) return undefined\n\n const result = await this._getComposer()\n .addPayment({\n ...options,\n sender: dispenserAccount,\n receiver: addressToFund,\n amount: amountFunded,\n })\n .send(options)\n\n return {\n ...result,\n transaction: result.transactions[0],\n confirmation: result.confirmations[0],\n transactionId: result.txIds[0],\n amountFunded: amountFunded,\n }\n }\n\n /**\n * Funds a given account using the TestNet Dispenser API as a funding source such that\n * the account has a certain amount of Algo free to spend (accounting for Algo locked\n * in minimum balance requirement).\n *\n * https://dev.algorand.co/concepts/smart-contracts/costs-constraints#mbr\n *\n * @param accountToFund The account to fund\n * @param dispenserClient The TestNet dispenser funding client\n * @param minSpendingBalance The minimum balance of Algo that the account should have available to spend (i.e. on top of minimum balance requirement)\n * @param options Optional parameters to control the funding increment, transaction or execution of the transaction\n * @example Example using AlgorandClient\n * ```typescript\n * // Basic example\n * await accountManager.ensureFundedFromTestNetDispenserApi(\"ACCOUNTADDRESS\", algorand.client.getTestNetDispenserFromEnvironment(), algokit.algo(1))\n * // With configuration\n * await accountManager.ensureFundedFromTestNetDispenserApi(\"ACCOUNTADDRESS\", algorand.client.getTestNetDispenserFromEnvironment(), algokit.algo(1),\n * { minFundingIncrement: algokit.algo(2) }\n * )\n * ```\n * @returns\n * - The result of executing the dispensing transaction and the `amountFunded` if funds were needed.\n * - `undefined` if no funds were needed.\n */\n async ensureFundedFromTestNetDispenserApi(\n accountToFund: string | Address,\n dispenserClient: TestNetDispenserApiClient,\n minSpendingBalance: AlgoAmount,\n options?: {\n minFundingIncrement?: AlgoAmount\n },\n ): Promise<EnsureFundedResult | undefined> {\n if (!(await this._clientManager.isTestNet())) {\n throw new Error('Attempt to fund using TestNet dispenser API on non TestNet network.')\n }\n\n const addressToFund = getAddress(accountToFund)\n\n const amountFunded = await this._getEnsureFundedAmount(addressToFund, minSpendingBalance, options?.minFundingIncrement)\n if (!amountFunded) return undefined\n\n const result = await dispenserClient.fund(addressToFund, amountFunded.microAlgo)\n return {\n amountFunded: AlgoAmount.MicroAlgo(result.amount),\n transactionId: result.txId,\n }\n }\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"account-manager.js","names":["memoize","KmdAccountManager","TransactionComposer","acc: AddressWithTransactionSigner","Address","getAddress","AlgoAmount","seedFromMnemonic","nacl","generateAddressWithSigners","getOptionalAddress","MultisigAccount","LogicSigAccount","DISPENSER_ACCOUNT","calculateFundAmount"],"sources":["../../src/types/account-manager.ts"],"sourcesContent":["import { seedFromMnemonic } from '@algorandfoundation/algokit-algo25'\nimport { SuggestedParams } from '@algorandfoundation/algokit-algod-client'\nimport { Address, ReadableAddress, getAddress, getOptionalAddress } from '@algorandfoundation/algokit-common'\nimport {\n AddressWithSigners,\n AddressWithTransactionSigner,\n LogicSigAccount,\n MultisigAccount,\n MultisigMetadata,\n TransactionSigner,\n generateAddressWithSigners,\n} from '@algorandfoundation/algokit-transact'\nimport nacl from 'tweetnacl'\nimport { Config } from '../config'\nimport { calculateFundAmount, memoize } from '../util'\nimport { AccountInformation, DISPENSER_ACCOUNT } from './account'\nimport { AlgoAmount } from './amount'\nimport { ClientManager } from './client-manager'\nimport { CommonTransactionParams, TransactionComposer } from './composer'\nimport { TestNetDispenserApiClient } from './dispenser-client'\nimport { KmdAccountManager } from './kmd-account-manager'\nimport { SendParams, SendSingleTransactionResult } from './transaction'\n\n/** Result from performing an ensureFunded call. */\nexport interface EnsureFundedResult {\n /** The transaction ID of the transaction that funded the account. */\n transactionId: string\n /** The amount that was sent to the account. */\n amountFunded: AlgoAmount\n}\n\n/**\n * Returns a `TransactionSigner` for the given account that can sign a transaction.\n * This function has memoization, so will return the same transaction signer for a given account.\n * @param account An account that can sign a transaction\n * @returns A transaction signer\n * @example\n * ```typescript\n * const signer = getAccountTransactionSigner(account)\n * ```\n */\nexport const getAccountTransactionSigner = memoize(function (\n account: AddressWithTransactionSigner | LogicSigAccount | MultisigAccount,\n): TransactionSigner {\n return account.signer\n})\n\n/** Creates and keeps track of signing accounts that can sign transactions for a sending address. */\nexport class AccountManager {\n private _clientManager: ClientManager\n private _kmdAccountManager: KmdAccountManager\n private _accounts: { [address: string]: AddressWithTransactionSigner } = {}\n private _defaultSigner?: TransactionSigner\n\n /**\n * Create a new account manager.\n * @param clientManager The ClientManager client to use for algod and kmd clients\n * @example Create a new account manager\n * ```typescript\n * const accountManager = new AccountManager(clientManager)\n * ```\n */\n constructor(clientManager: ClientManager) {\n this._clientManager = clientManager\n this._kmdAccountManager = new KmdAccountManager(clientManager)\n }\n\n private _getComposer(getSuggestedParams?: () => Promise<SuggestedParams>) {\n return new TransactionComposer({\n algod: this._clientManager.algod,\n getSigner: this.getSigner.bind(this),\n getSuggestedParams: getSuggestedParams ?? (() => this._clientManager.algod.suggestedParams()),\n })\n }\n\n /**\n * KMD account manager that allows you to easily get and create accounts using KMD.\n * @returns The `KmdAccountManager` instance.\n * @example\n * ```typescript\n * const kmdManager = accountManager.kmd;\n * ```\n */\n public get kmd() {\n return this._kmdAccountManager\n }\n\n /**\n * Sets the default signer to use if no other signer is specified.\n *\n * If this isn't set an a transaction needs signing for a given sender\n * then an error will be thrown from `getSigner` / `getAccount`.\n * @param signer The signer to use, either a `TransactionSigner` or a `AddressWithSigner`\n * @example\n * ```typescript\n * const signer = accountManager.random() // Can be anything that returns a `TransactionSigner` or `AddressWithSigner`\n * accountManager.setDefaultSigner(signer)\n *\n * // When signing a transaction, if there is no signer registered for the sender then the default signer will be used\n * const signer = accountManager.getSigner(\"SENDERADDRESS\")\n * ```\n * @returns The `AccountManager` so method calls can be chained\n */\n public setDefaultSigner(signer: TransactionSigner | AddressWithTransactionSigner): AccountManager {\n this._defaultSigner = 'signer' in signer ? signer.signer : signer\n return this\n }\n\n /**\n * Records the given account (that can sign) against the address of the provided account for later\n * retrieval and returns a `AddressWithTransactionSigner` along with the original account in an `account` property.\n */\n private signerAccount<T extends AddressWithTransactionSigner | LogicSigAccount | MultisigAccount>(\n account: T,\n ): Address &\n AddressWithTransactionSigner & {\n /* The underlying account that specified this address. */ account: T\n } {\n const signer = getAccountTransactionSigner(account)\n const acc: AddressWithTransactionSigner = {\n addr: account.addr,\n signer: signer,\n }\n this._accounts[acc.addr.toString()] = acc\n\n const addressWithAccount = Address.fromString(acc.addr.toString()) as Address & AddressWithTransactionSigner & { account: T }\n addressWithAccount.account = account\n addressWithAccount.addr = acc.addr\n addressWithAccount.signer = signer\n return addressWithAccount\n }\n\n /**\n * Tracks the given account for later signing.\n *\n * Note: If you are generating accounts via the various methods on `AccountManager`\n * (like `random`, `fromMnemonic`, `logicsig`, etc.) then they automatically get tracked.\n * @param account The account to register, which can be a `AddressWithSigner` or\n * a `algosdk.Account`, `algosdk.LogicSigAccount`, `SigningAccount` or `MultisigAccount`\n * @example\n * ```typescript\n * const accountManager = new AccountManager(clientManager)\n * .setSignerFromAccount(algosdk.generateAccount())\n * .setSignerFromAccount(new algosdk.LogicSigAccount(program, args))\n * .setSignerFromAccount(new SigningAccount(mnemonic, sender))\n * .setSignerFromAccount(new MultisigAccount({version: 1, threshold: 1, addrs: [\"ADDRESS1...\", \"ADDRESS2...\"]}, [account1, account2]))\n * .setSignerFromAccount({addr: \"SENDERADDRESS\", signer: transactionSigner})\n * ```\n * @returns The `AccountManager` instance for method chaining\n */\n public setSignerFromAccount(account: AddressWithTransactionSigner | LogicSigAccount | MultisigAccount) {\n this.signerAccount(account)\n return this\n }\n\n /**\n * Tracks the given `TransactionSigner` against the given sender address for later signing.\n * @param sender The sender address to use this signer for\n * @param signer The `TransactionSigner` to sign transactions with for the given sender\n * @example\n * ```typescript\n * const accountManager = new AccountManager(clientManager)\n * .setSigner(\"SENDERADDRESS\", transactionSigner)\n * ```\n * @returns The `AccountManager` instance for method chaining\n */\n public setSigner(sender: string | Address, signer: TransactionSigner) {\n this._accounts[getAddress(sender).toString()] = { addr: getAddress(sender), signer }\n return this\n }\n\n /**\n * Takes all registered signers from the given `AccountManager` and adds them to this `AccountManager`.\n *\n * This is useful for situations where you have multiple contexts you are building accounts in such as unit tests.\n * @param anotherAccountManager Another account manager with signers registered\n * @param overwriteExisting Whether or not to overwrite any signers that have the same sender address with the ones in the other account manager or not (default: true)\n * @returns The `AccountManager` instance for method chaining\n * @example\n * ```typescript\n * accountManager2.setSigners(accountManager1);\n * ```\n */\n public setSigners(anotherAccountManager: AccountManager, overwriteExisting = true) {\n this._accounts = overwriteExisting\n ? { ...this._accounts, ...anotherAccountManager._accounts }\n : { ...anotherAccountManager._accounts, ...this._accounts }\n return this\n }\n\n /**\n * Returns the `TransactionSigner` for the given sender address, ready to sign a transaction for that sender.\n *\n * If no signer has been registered for that address then the default signer is used if registered and\n * if not then an error is thrown.\n *\n * @param sender The sender address\n * @example\n * ```typescript\n * const signer = accountManager.getSigner(\"SENDERADDRESS\")\n * ```\n * @returns The `TransactionSigner` or throws an error if not found and no default signer is set\n */\n public getSigner(sender: ReadableAddress): TransactionSigner {\n const signer = this._accounts[getAddress(sender).toString()]?.signer ?? this._defaultSigner\n if (!signer) throw new Error(`No signer found for address ${sender}`)\n return signer\n }\n\n /**\n * Returns the `AddressWithSigner` for the given sender address.\n *\n * If no signer has been registered for that address then an error is thrown.\n * @param sender The sender address\n * @example\n * ```typescript\n * const sender = accountManager.random()\n * // ...\n * // Returns the `AddressWithSigner` for `sender` that has previously been registered\n * const account = accountManager.getAccount(sender)\n * ```\n * @returns The `AddressWithSigner` or throws an error if not found\n */\n public getAccount(sender: ReadableAddress): AddressWithTransactionSigner {\n const account = this._accounts[getAddress(sender).toString()]\n if (!account) throw new Error(`No signer found for address ${sender}`)\n return account\n }\n\n /**\n * Returns the given sender account's current status, balance and spendable amounts.\n *\n * [Response data schema details](https://dev.algorand.co/reference/rest-apis/algod/#accountinformation)\n * @example\n * ```typescript\n * const address = \"XBYLS2E6YI6XXL5BWCAMOA4GTWHXWENZMX5UHXMRNWWUQ7BXCY5WC5TEPA\";\n * const accountInfo = await accountManager.getInformation(address);\n * ```\n *\n * @param sender The account / address to look up\n * @returns The account information\n */\n public async getInformation(sender: ReadableAddress): Promise<AccountInformation> {\n const senderAddress = getAddress(sender).toString()\n const {\n round,\n lastHeartbeat = undefined,\n lastProposed = undefined,\n address,\n ...account\n } = await this._clientManager.algod.accountInformation(senderAddress)\n\n return {\n ...account,\n authAddr: account.authAddr,\n address,\n balance: AlgoAmount.MicroAlgo(Number(account.amount)),\n amountWithoutPendingRewards: AlgoAmount.MicroAlgo(Number(account.amountWithoutPendingRewards)),\n minBalance: AlgoAmount.MicroAlgo(Number(account.minBalance)),\n pendingRewards: AlgoAmount.MicroAlgo(Number(account.pendingRewards)),\n rewards: AlgoAmount.MicroAlgo(Number(account.rewards)),\n validAsOfRound: BigInt(round),\n totalAppsOptedIn: Number(account.totalAppsOptedIn),\n totalAssetsOptedIn: Number(account.totalAssetsOptedIn),\n totalCreatedApps: Number(account.totalCreatedApps),\n totalCreatedAssets: Number(account.totalCreatedAssets),\n appsTotalExtraPages: account.appsTotalExtraPages !== undefined ? Number(account.appsTotalExtraPages) : undefined,\n rewardBase: account.rewardBase !== undefined ? Number(account.rewardBase) : undefined,\n totalBoxBytes: account.totalBoxBytes !== undefined ? Number(account.totalBoxBytes) : undefined,\n totalBoxes: account.totalBoxes !== undefined ? Number(account.totalBoxes) : undefined,\n lastHeartbeatRound: lastHeartbeat !== undefined ? BigInt(lastHeartbeat) : undefined,\n lastProposedRound: lastProposed !== undefined ? BigInt(lastProposed) : undefined,\n }\n }\n\n /**\n * Tracks and returns an Algorand account with secret key loaded (i.e. that can sign transactions) by taking the mnemonic secret.\n *\n * @example\n * ```typescript\n * const account = accountManager.fromMnemonic(\"mnemonic secret ...\")\n * const rekeyedAccount = accountManager.fromMnemonic(\"mnemonic secret ...\", \"SENDERADDRESS...\")\n * ```\n * @param mnemonicSecret The mnemonic secret representing the private key of an account; **Note: Be careful how the mnemonic is handled**,\n * never commit it into source control and ideally load it from the environment (ideally via a secret storage service) rather than the file system.\n * @param sender The optional sender address to use this signer for (aka a rekeyed account)\n * @returns The account\n */\n public fromMnemonic(mnemonicSecret: string, sender?: string | Address): AddressWithTransactionSigner {\n const seed = seedFromMnemonic(mnemonicSecret)\n\n const keypair = nacl.sign.keyPair.fromSeed(seed)\n\n const addrWithSigners = generateAddressWithSigners({\n ed25519Pubkey: keypair.publicKey,\n sendingAddress: getOptionalAddress(sender),\n rawEd25519Signer: async (bytesToSign: Uint8Array): Promise<Uint8Array> => {\n return nacl.sign.detached(bytesToSign, keypair.secretKey)\n },\n })\n\n return this.signerAccount(addrWithSigners)\n }\n\n /**\n * Tracks and returns an Algorand account that is a rekeyed version of the given account to a new sender.\n *\n * @example\n * ```typescript\n * const account = accountManager.fromMnemonic(\"mnemonic secret ...\")\n * const rekeyedAccount = accountManager.rekeyed(account, \"SENDERADDRESS...\")\n * ```\n * @param account The account to use as the signer for this new rekeyed account\n * @param sender The sender address to use as the new sender\n * @returns The account\n */\n public rekeyed(sender: string | Address, account: AddressWithTransactionSigner) {\n return this.signerAccount({ addr: getAddress(sender), signer: account.signer })\n }\n\n /**\n * Tracks and returns an Algorand account with private key loaded by convention from environment variables based on the given name identifier.\n *\n * Note: This function expects to run in a Node.js environment.\n *\n * ## Convention:\n * * **Non-LocalNet:** will load process.env['\\{NAME\\}_MNEMONIC'] as a mnemonic secret; **Note: Be careful how the mnemonic is handled**,\n * never commit it into source control and ideally load it via a secret storage service rather than the file system.\n * If process.env['\\{NAME\\}_SENDER'] is defined then it will use that for the sender address (i.e. to support rekeyed accounts)\n * * **LocalNet:** will load the account from a KMD wallet called \\{NAME\\} and if that wallet doesn't exist it will create it and fund the account for you\n *\n * This allows you to write code that will work seamlessly in production and local development (LocalNet) without manual config locally (including when you reset the LocalNet).\n *\n * @example Default\n *\n * If you have a mnemonic secret loaded into `process.env.MY_ACCOUNT_MNEMONIC` then you can call the following to get that private key loaded into an account object:\n * ```typescript\n * const account = await accountManager.fromEnvironment('MY_ACCOUNT')\n * ```\n *\n * If that code runs against LocalNet then a wallet called `MY_ACCOUNT` will automatically be created with an account that is automatically funded with 1000 (default) ALGO from the default LocalNet dispenser.\n * If not running against LocalNet then it will use proces.env.MY_ACCOUNT_MNEMONIC as the private key and (if present) process.env.MY_ACCOUNT_SENDER as the sender address.\n *\n * @param name The name identifier of the account\n * @param fundWith The optional amount to fund the account with when it gets created (when targeting LocalNet), if not specified then 1000 ALGO will be funded from the dispenser account\n * @returns The account\n */\n public async fromEnvironment(name: string, fundWith?: AlgoAmount) {\n if (!process || !process.env) {\n throw new Error('Attempt to get account with private key from a non Node.js context; this is not supported!')\n }\n\n const accountMnemonic = process.env[`${name.toUpperCase()}_MNEMONIC`]\n const sender = process.env[`${name.toUpperCase()}_SENDER`]\n\n if (accountMnemonic) {\n return this.fromMnemonic(accountMnemonic, sender)\n }\n\n if (await this._clientManager.isLocalNet()) {\n const account = await this._kmdAccountManager.getOrCreateWalletAccount(name, fundWith)\n return this.signerAccount(account)\n }\n\n throw new Error(`Missing environment variable ${name.toUpperCase()}_MNEMONIC when looking for account ${name}`)\n }\n\n /**\n * Tracks and returns an Algorand account with private key loaded from the given KMD wallet (identified by name).\n *\n * @param name The name of the wallet to retrieve an account from\n * @param predicate An optional filter to use to find the account (otherwise it will return a random account from the wallet)\n * @param sender The optional sender address to use this signer for (aka a rekeyed account)\n * @example Get default funded account in a LocalNet\n *\n * ```typescript\n * const defaultDispenserAccount = await accountManager.fromKmd('unencrypted-default-wallet',\n * a => a.status !== 'Offline' && a.amount > 1_000_000_000\n * )\n * ```\n * @returns The account\n */\n public async fromKmd(\n name: string,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n predicate?: (account: Record<string, any>) => boolean,\n sender?: string | Address,\n ) {\n const account = await this._kmdAccountManager.getWalletAccount(name, predicate, sender)\n if (!account) throw new Error(`Unable to find KMD account ${name}${predicate ? ' with predicate' : ''}`)\n return this.signerAccount(account)\n }\n\n /**\n * Tracks and returns an account that supports partial or full multisig signing.\n *\n * @example\n * ```typescript\n * const account = accountManager.multisig({version: 1, threshold: 1, addrs: [\"ADDRESS1...\", \"ADDRESS2...\"]},\n * [(await accountManager.fromEnvironment('ACCOUNT1')).account])\n * ```\n * @param multisigParams The parameters that define the multisig account\n * @param subSigners The signers that are currently present\n * @returns A multisig account wrapper\n */\n public multisig(multisigParams: MultisigMetadata, subSigners: AddressWithSigners[]) {\n return this.signerAccount(new MultisigAccount(multisigParams, subSigners))\n }\n\n /**\n * Tracks and returns an account that represents a logic signature.\n *\n * @example\n * ```typescript\n * const account = accountManager.logicsig(program, [new Uint8Array(3, ...)])\n * ```\n * @param program The bytes that make up the compiled logic signature\n * @param args The (binary) arguments to pass into the logic signature\n * @returns A logic signature account wrapper\n */\n public logicsig(program: Uint8Array, args?: Array<Uint8Array>) {\n return this.signerAccount(new LogicSigAccount(program, args))\n }\n\n /**\n * Tracks and returns a new, random Algorand account with secret key loaded.\n *\n * @example\n * ```typescript\n * const account = accountManager.random()\n * ```\n * @returns The account\n */\n public random() {\n const keypair = nacl.sign.keyPair()\n const rawSigner = async (bytesToSign: Uint8Array): Promise<Uint8Array> => {\n return nacl.sign.detached(bytesToSign, keypair.secretKey)\n }\n\n return this.signerAccount(generateAddressWithSigners({ ed25519Pubkey: keypair.publicKey, rawEd25519Signer: rawSigner }))\n }\n\n /**\n * Returns an account (with private key loaded) that can act as a dispenser from\n * environment variables, or against default LocalNet if no environment variables present.\n *\n * Note: requires a Node.js environment to execute.\n *\n * If present, it will load the account mnemonic stored in process.env.DISPENSER_MNEMONIC and optionally\n * process.env.DISPENSER_SENDER if it's a rekeyed account.\n *\n * @example\n * ```typescript\n * const account = await accountManager.dispenserFromEnvironment()\n * ```\n *\n * @returns The account\n */\n public async dispenserFromEnvironment() {\n if (!process || !process.env) {\n throw new Error('Attempt to get dispenser from environment from a non Node.js context; this is not supported!')\n }\n\n return process.env[`${DISPENSER_ACCOUNT.toUpperCase()}_MNEMONIC`]\n ? await this.fromEnvironment(DISPENSER_ACCOUNT)\n : await this.localNetDispenser()\n }\n\n /**\n * Returns an Algorand account with private key loaded for the default LocalNet dispenser account (that can be used to fund other accounts).\n *\n * @example\n * ```typescript\n * const account = await accountManager.localNetDispenser()\n * ```\n * @returns The account\n */\n public async localNetDispenser() {\n const dispenser = await this._kmdAccountManager.getLocalNetDispenserAccount()\n return this.signerAccount(dispenser)\n }\n\n /**\n * Rekey an account to a new address.\n *\n * **Note:** Please be careful with this function and be sure to read the [official rekey guidance](https://dev.algorand.co/concepts/accounts/rekeying).\n *\n * @param account The account to rekey\n * @param rekeyTo The account address or signing account of the account that will be used to authorise transactions for the rekeyed account going forward.\n * If a signing account is provided that will now be tracked as the signer for `account` in this `AccountManager`\n * @param options Any parameters to control the transaction or execution of the transaction\n *\n * @example Basic example (with string addresses)\n * ```typescript\n * await accountManager.rekeyAccount({account: \"ACCOUNTADDRESS\", rekeyTo: \"NEWADDRESS\"})\n * ```\n * @example Basic example (with signer accounts)\n * ```typescript\n * await accountManager.rekeyAccount({account: account1, rekeyTo: newSignerAccount})\n * ```\n * @example Advanced example\n * ```typescript\n * await accountManager.rekeyAccount({\n * account: \"ACCOUNTADDRESS\",\n * rekeyTo: \"NEWADDRESS\",\n * lease: 'lease',\n * note: 'note',\n * firstValidRound: 1000n,\n * validityWindow: 10,\n * extraFee: (1000).microAlgo(),\n * staticFee: (1000).microAlgo(),\n * // Max fee doesn't make sense with extraFee AND staticFee\n * // already specified, but here for completeness\n * maxFee: (3000).microAlgo(),\n * maxRoundsToWaitForConfirmation: 5,\n * suppressLog: true,\n * })\n * ```\n * @returns The result of the transaction and the transaction that was sent\n */\n async rekeyAccount(\n account: string | Address,\n rekeyTo: string | Address | AddressWithTransactionSigner,\n options?: Omit<CommonTransactionParams, 'sender'> & SendParams,\n ): Promise<SendSingleTransactionResult> {\n const result = await this._getComposer()\n .addPayment({\n ...options,\n sender: getAddress(account),\n receiver: getAddress(account),\n amount: AlgoAmount.MicroAlgo(0),\n rekeyTo: getAddress(rekeyTo),\n })\n .send(options)\n\n // If the rekey is a signing account set it as the signer for this account\n if (typeof rekeyTo === 'object' && 'addr' in rekeyTo) {\n this.rekeyed(account, rekeyTo)\n }\n\n Config.getLogger(options?.suppressLog).info(`Rekeyed ${account} to ${rekeyTo} via transaction ${result.txIds.at(-1)}`)\n\n return { ...result, transaction: result.transactions.at(-1)!, confirmation: result.confirmations.at(-1)! }\n }\n\n private async _getEnsureFundedAmount(sender: Address, minSpendingBalance: AlgoAmount, minFundingIncrement?: AlgoAmount) {\n const accountInfo = await this.getInformation(sender)\n const currentSpendingBalance = accountInfo.balance.microAlgo - accountInfo.minBalance.microAlgo\n\n const amountFunded = calculateFundAmount(minSpendingBalance.microAlgo, currentSpendingBalance, minFundingIncrement?.microAlgo ?? 0n)\n\n return amountFunded === null ? undefined : AlgoAmount.MicroAlgo(amountFunded)\n }\n\n /**\n * Funds a given account using a dispenser account as a funding source such that\n * the given account has a certain amount of Algo free to spend (accounting for\n * Algo locked in minimum balance requirement).\n *\n * https://dev.algorand.co/concepts/smart-contracts/costs-constraints#mbr\n *\n * @param accountToFund The account to fund\n * @param dispenserAccount The account to use as a dispenser funding source\n * @param minSpendingBalance The minimum balance of Algo that the account should have available to spend (i.e. on top of minimum balance requirement)\n * @param options Optional parameters to control the funding increment, transaction or execution of the transaction\n * @example Example using AlgorandClient\n * ```typescript\n * // Basic example\n * await accountManager.ensureFunded(\"ACCOUNTADDRESS\", \"DISPENSERADDRESS\", algokit.algo(1))\n * // With configuration\n * await accountManager.ensureFunded(\"ACCOUNTADDRESS\", \"DISPENSERADDRESS\", algokit.algo(1),\n * { minFundingIncrement: algokit.algo(2), fee: (1000).microAlgo(), suppressLog: true }\n * )\n * ```\n * @returns\n * - The result of executing the dispensing transaction and the `amountFunded` if funds were needed.\n * - `undefined` if no funds were needed.\n */\n async ensureFunded(\n accountToFund: string | Address,\n dispenserAccount: string | Address,\n minSpendingBalance: AlgoAmount,\n options?: {\n minFundingIncrement?: AlgoAmount\n } & SendParams &\n Omit<CommonTransactionParams, 'sender'>,\n ): Promise<(SendSingleTransactionResult & EnsureFundedResult) | undefined> {\n const addressToFund = getAddress(accountToFund)\n\n const amountFunded = await this._getEnsureFundedAmount(addressToFund, minSpendingBalance, options?.minFundingIncrement)\n if (!amountFunded) return undefined\n\n const result = await this._getComposer()\n .addPayment({\n ...options,\n sender: getAddress(dispenserAccount),\n receiver: addressToFund,\n amount: amountFunded,\n })\n .send(options)\n\n return {\n ...result,\n transaction: result.transactions[0],\n confirmation: result.confirmations[0],\n transactionId: result.txIds[0],\n amountFunded: amountFunded,\n }\n }\n\n /**\n * Funds a given account using a dispenser account retrieved from the environment,\n * per the `dispenserFromEnvironment` method, as a funding source such that\n * the given account has a certain amount of Algo free to spend (accounting for\n * Algo locked in minimum balance requirement).\n *\n * **Note:** requires a Node.js environment to execute.\n *\n * The dispenser account is retrieved from the account mnemonic stored in\n * process.env.DISPENSER_MNEMONIC and optionally process.env.DISPENSER_SENDER\n * if it's a rekeyed account, or against default LocalNet if no environment variables present.\n *\n * https://dev.algorand.co/concepts/smart-contracts/costs-constraints#mbr\n *\n * @param accountToFund The account to fund\n * @param minSpendingBalance The minimum balance of Algo that the account should have available to spend (i.e. on top of minimum balance requirement)\n * @param options Optional parameters to control the funding increment, transaction or execution of the transaction\n * @example Example using AlgorandClient\n * ```typescript\n * // Basic example\n * await accountManager.ensureFundedFromEnvironment(\"ACCOUNTADDRESS\", algokit.algo(1))\n * // With configuration\n * await accountManager.ensureFundedFromEnvironment(\"ACCOUNTADDRESS\", algokit.algo(1),\n * { minFundingIncrement: algokit.algo(2), fee: (1000).microAlgo(), suppressLog: true }\n * )\n * ```\n * @returns\n * - The result of executing the dispensing transaction and the `amountFunded` if funds were needed.\n * - `undefined` if no funds were needed.\n */\n async ensureFundedFromEnvironment(\n accountToFund: string | Address,\n minSpendingBalance: AlgoAmount,\n options?: {\n minFundingIncrement?: AlgoAmount\n } & SendParams &\n Omit<CommonTransactionParams, 'sender'>,\n ): Promise<(SendSingleTransactionResult & EnsureFundedResult) | undefined> {\n const addressToFund = getAddress(accountToFund)\n const dispenserAccount = await this.dispenserFromEnvironment()\n\n const amountFunded = await this._getEnsureFundedAmount(addressToFund, minSpendingBalance, options?.minFundingIncrement)\n if (!amountFunded) return undefined\n\n const result = await this._getComposer()\n .addPayment({\n ...options,\n sender: dispenserAccount,\n receiver: addressToFund,\n amount: amountFunded,\n })\n .send(options)\n\n return {\n ...result,\n transaction: result.transactions[0],\n confirmation: result.confirmations[0],\n transactionId: result.txIds[0],\n amountFunded: amountFunded,\n }\n }\n\n /**\n * Funds a given account using the TestNet Dispenser API as a funding source such that\n * the account has a certain amount of Algo free to spend (accounting for Algo locked\n * in minimum balance requirement).\n *\n * https://dev.algorand.co/concepts/smart-contracts/costs-constraints#mbr\n *\n * @param accountToFund The account to fund\n * @param dispenserClient The TestNet dispenser funding client\n * @param minSpendingBalance The minimum balance of Algo that the account should have available to spend (i.e. on top of minimum balance requirement)\n * @param options Optional parameters to control the funding increment, transaction or execution of the transaction\n * @example Example using AlgorandClient\n * ```typescript\n * // Basic example\n * await accountManager.ensureFundedFromTestNetDispenserApi(\"ACCOUNTADDRESS\", algorand.client.getTestNetDispenserFromEnvironment(), algokit.algo(1))\n * // With configuration\n * await accountManager.ensureFundedFromTestNetDispenserApi(\"ACCOUNTADDRESS\", algorand.client.getTestNetDispenserFromEnvironment(), algokit.algo(1),\n * { minFundingIncrement: algokit.algo(2) }\n * )\n * ```\n * @returns\n * - The result of executing the dispensing transaction and the `amountFunded` if funds were needed.\n * - `undefined` if no funds were needed.\n */\n async ensureFundedFromTestNetDispenserApi(\n accountToFund: string | Address,\n dispenserClient: TestNetDispenserApiClient,\n minSpendingBalance: AlgoAmount,\n options?: {\n minFundingIncrement?: AlgoAmount\n },\n ): Promise<EnsureFundedResult | undefined> {\n if (!(await this._clientManager.isTestNet())) {\n throw new Error('Attempt to fund using TestNet dispenser API on non TestNet network.')\n }\n\n const addressToFund = getAddress(accountToFund)\n\n const amountFunded = await this._getEnsureFundedAmount(addressToFund, minSpendingBalance, options?.minFundingIncrement)\n if (!amountFunded) return undefined\n\n const result = await dispenserClient.fund(addressToFund, amountFunded.microAlgo)\n return {\n amountFunded: AlgoAmount.MicroAlgo(result.amount),\n transactionId: result.txId,\n }\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAyCA,MAAa,8BAA8BA,qBAAQ,SACjD,SACmB;AACnB,QAAO,QAAQ;EACf;;AAGF,IAAa,iBAAb,MAA4B;CAC1B,AAAQ;CACR,AAAQ;CACR,AAAQ,YAAiE,EAAE;CAC3E,AAAQ;;;;;;;;;CAUR,YAAY,eAA8B;AACxC,OAAK,iBAAiB;AACtB,OAAK,qBAAqB,IAAIC,8CAAkB,cAAc;;CAGhE,AAAQ,aAAa,oBAAqD;AACxE,SAAO,IAAIC,qCAAoB;GAC7B,OAAO,KAAK,eAAe;GAC3B,WAAW,KAAK,UAAU,KAAK,KAAK;GACpC,oBAAoB,6BAA6B,KAAK,eAAe,MAAM,iBAAiB;GAC7F,CAAC;;;;;;;;;;CAWJ,IAAW,MAAM;AACf,SAAO,KAAK;;;;;;;;;;;;;;;;;;CAmBd,AAAO,iBAAiB,QAA0E;AAChG,OAAK,iBAAiB,YAAY,SAAS,OAAO,SAAS;AAC3D,SAAO;;;;;;CAOT,AAAQ,cACN,SAIE;EACF,MAAM,SAAS,4BAA4B,QAAQ;EACnD,MAAMC,MAAoC;GACxC,MAAM,QAAQ;GACN;GACT;AACD,OAAK,UAAU,IAAI,KAAK,UAAU,IAAI;EAEtC,MAAM,qBAAqBC,wBAAQ,WAAW,IAAI,KAAK,UAAU,CAAC;AAClE,qBAAmB,UAAU;AAC7B,qBAAmB,OAAO,IAAI;AAC9B,qBAAmB,SAAS;AAC5B,SAAO;;;;;;;;;;;;;;;;;;;;CAqBT,AAAO,qBAAqB,SAA2E;AACrG,OAAK,cAAc,QAAQ;AAC3B,SAAO;;;;;;;;;;;;;CAcT,AAAO,UAAU,QAA0B,QAA2B;AACpE,OAAK,UAAUC,2BAAW,OAAO,CAAC,UAAU,IAAI;GAAE,MAAMA,2BAAW,OAAO;GAAE;GAAQ;AACpF,SAAO;;;;;;;;;;;;;;CAeT,AAAO,WAAW,uBAAuC,oBAAoB,MAAM;AACjF,OAAK,YAAY,oBACb;GAAE,GAAG,KAAK;GAAW,GAAG,sBAAsB;GAAW,GACzD;GAAE,GAAG,sBAAsB;GAAW,GAAG,KAAK;GAAW;AAC7D,SAAO;;;;;;;;;;;;;;;CAgBT,AAAO,UAAU,QAA4C;EAC3D,MAAM,SAAS,KAAK,UAAUA,2BAAW,OAAO,CAAC,UAAU,GAAG,UAAU,KAAK;AAC7E,MAAI,CAAC,OAAQ,OAAM,IAAI,MAAM,+BAA+B,SAAS;AACrE,SAAO;;;;;;;;;;;;;;;;CAiBT,AAAO,WAAW,QAAuD;EACvE,MAAM,UAAU,KAAK,UAAUA,2BAAW,OAAO,CAAC,UAAU;AAC5D,MAAI,CAAC,QAAS,OAAM,IAAI,MAAM,+BAA+B,SAAS;AACtE,SAAO;;;;;;;;;;;;;;;CAgBT,MAAa,eAAe,QAAsD;EAChF,MAAM,gBAAgBA,2BAAW,OAAO,CAAC,UAAU;EACnD,MAAM,EACJ,OACA,gBAAgB,QAChB,eAAe,QACf,SACA,GAAG,YACD,MAAM,KAAK,eAAe,MAAM,mBAAmB,cAAc;AAErE,SAAO;GACL,GAAG;GACH,UAAU,QAAQ;GAClB;GACA,SAASC,0BAAW,UAAU,OAAO,QAAQ,OAAO,CAAC;GACrD,6BAA6BA,0BAAW,UAAU,OAAO,QAAQ,4BAA4B,CAAC;GAC9F,YAAYA,0BAAW,UAAU,OAAO,QAAQ,WAAW,CAAC;GAC5D,gBAAgBA,0BAAW,UAAU,OAAO,QAAQ,eAAe,CAAC;GACpE,SAASA,0BAAW,UAAU,OAAO,QAAQ,QAAQ,CAAC;GACtD,gBAAgB,OAAO,MAAM;GAC7B,kBAAkB,OAAO,QAAQ,iBAAiB;GAClD,oBAAoB,OAAO,QAAQ,mBAAmB;GACtD,kBAAkB,OAAO,QAAQ,iBAAiB;GAClD,oBAAoB,OAAO,QAAQ,mBAAmB;GACtD,qBAAqB,QAAQ,wBAAwB,SAAY,OAAO,QAAQ,oBAAoB,GAAG;GACvG,YAAY,QAAQ,eAAe,SAAY,OAAO,QAAQ,WAAW,GAAG;GAC5E,eAAe,QAAQ,kBAAkB,SAAY,OAAO,QAAQ,cAAc,GAAG;GACrF,YAAY,QAAQ,eAAe,SAAY,OAAO,QAAQ,WAAW,GAAG;GAC5E,oBAAoB,kBAAkB,SAAY,OAAO,cAAc,GAAG;GAC1E,mBAAmB,iBAAiB,SAAY,OAAO,aAAa,GAAG;GACxE;;;;;;;;;;;;;;;CAgBH,AAAO,aAAa,gBAAwB,QAAyD;EACnG,MAAM,OAAOC,+BAAiB,eAAe;EAE7C,MAAM,UAAUC,kBAAK,KAAK,QAAQ,SAAS,KAAK;EAEhD,MAAM,kBAAkBC,0CAA2B;GACjD,eAAe,QAAQ;GACvB,gBAAgBC,mCAAmB,OAAO;GAC1C,kBAAkB,OAAO,gBAAiD;AACxE,WAAOF,kBAAK,KAAK,SAAS,aAAa,QAAQ,UAAU;;GAE5D,CAAC;AAEF,SAAO,KAAK,cAAc,gBAAgB;;;;;;;;;;;;;;CAe5C,AAAO,QAAQ,QAA0B,SAAuC;AAC9E,SAAO,KAAK,cAAc;GAAE,MAAMH,2BAAW,OAAO;GAAE,QAAQ,QAAQ;GAAQ,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA8BjF,MAAa,gBAAgB,MAAc,UAAuB;AAChE,MAAI,CAAC,WAAW,CAAC,QAAQ,IACvB,OAAM,IAAI,MAAM,6FAA6F;EAG/G,MAAM,kBAAkB,QAAQ,IAAI,GAAG,KAAK,aAAa,CAAC;EAC1D,MAAM,SAAS,QAAQ,IAAI,GAAG,KAAK,aAAa,CAAC;AAEjD,MAAI,gBACF,QAAO,KAAK,aAAa,iBAAiB,OAAO;AAGnD,MAAI,MAAM,KAAK,eAAe,YAAY,EAAE;GAC1C,MAAM,UAAU,MAAM,KAAK,mBAAmB,yBAAyB,MAAM,SAAS;AACtF,UAAO,KAAK,cAAc,QAAQ;;AAGpC,QAAM,IAAI,MAAM,gCAAgC,KAAK,aAAa,CAAC,qCAAqC,OAAO;;;;;;;;;;;;;;;;;CAkBjH,MAAa,QACX,MAEA,WACA,QACA;EACA,MAAM,UAAU,MAAM,KAAK,mBAAmB,iBAAiB,MAAM,WAAW,OAAO;AACvF,MAAI,CAAC,QAAS,OAAM,IAAI,MAAM,8BAA8B,OAAO,YAAY,oBAAoB,KAAK;AACxG,SAAO,KAAK,cAAc,QAAQ;;;;;;;;;;;;;;CAepC,AAAO,SAAS,gBAAkC,YAAkC;AAClF,SAAO,KAAK,cAAc,IAAIM,iCAAgB,gBAAgB,WAAW,CAAC;;;;;;;;;;;;;CAc5E,AAAO,SAAS,SAAqB,MAA0B;AAC7D,SAAO,KAAK,cAAc,IAAIC,iCAAgB,SAAS,KAAK,CAAC;;;;;;;;;;;CAY/D,AAAO,SAAS;EACd,MAAM,UAAUJ,kBAAK,KAAK,SAAS;EACnC,MAAM,YAAY,OAAO,gBAAiD;AACxE,UAAOA,kBAAK,KAAK,SAAS,aAAa,QAAQ,UAAU;;AAG3D,SAAO,KAAK,cAAcC,0CAA2B;GAAE,eAAe,QAAQ;GAAW,kBAAkB;GAAW,CAAC,CAAC;;;;;;;;;;;;;;;;;;CAmB1H,MAAa,2BAA2B;AACtC,MAAI,CAAC,WAAW,CAAC,QAAQ,IACvB,OAAM,IAAI,MAAM,+FAA+F;AAGjH,SAAO,QAAQ,IAAI,GAAGI,kCAAkB,aAAa,CAAC,cAClD,MAAM,KAAK,gBAAgBA,kCAAkB,GAC7C,MAAM,KAAK,mBAAmB;;;;;;;;;;;CAYpC,MAAa,oBAAoB;EAC/B,MAAM,YAAY,MAAM,KAAK,mBAAmB,6BAA6B;AAC7E,SAAO,KAAK,cAAc,UAAU;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAyCtC,MAAM,aACJ,SACA,SACA,SACsC;EACtC,MAAM,SAAS,MAAM,KAAK,cAAc,CACrC,WAAW;GACV,GAAG;GACH,QAAQR,2BAAW,QAAQ;GAC3B,UAAUA,2BAAW,QAAQ;GAC7B,QAAQC,0BAAW,UAAU,EAAE;GAC/B,SAASD,2BAAW,QAAQ;GAC7B,CAAC,CACD,KAAK,QAAQ;AAGhB,MAAI,OAAO,YAAY,YAAY,UAAU,QAC3C,MAAK,QAAQ,SAAS,QAAQ;AAGhC,wBAAO,UAAU,SAAS,YAAY,CAAC,KAAK,WAAW,QAAQ,MAAM,QAAQ,mBAAmB,OAAO,MAAM,GAAG,GAAG,GAAG;AAEtH,SAAO;GAAE,GAAG;GAAQ,aAAa,OAAO,aAAa,GAAG,GAAG;GAAG,cAAc,OAAO,cAAc,GAAG,GAAG;GAAG;;CAG5G,MAAc,uBAAuB,QAAiB,oBAAgC,qBAAkC;EACtH,MAAM,cAAc,MAAM,KAAK,eAAe,OAAO;EACrD,MAAM,yBAAyB,YAAY,QAAQ,YAAY,YAAY,WAAW;EAEtF,MAAM,eAAeS,iCAAoB,mBAAmB,WAAW,wBAAwB,qBAAqB,aAAa,GAAG;AAEpI,SAAO,iBAAiB,OAAO,SAAYR,0BAAW,UAAU,aAAa;;;;;;;;;;;;;;;;;;;;;;;;;;CA2B/E,MAAM,aACJ,eACA,kBACA,oBACA,SAIyE;EACzE,MAAM,gBAAgBD,2BAAW,cAAc;EAE/C,MAAM,eAAe,MAAM,KAAK,uBAAuB,eAAe,oBAAoB,SAAS,oBAAoB;AACvH,MAAI,CAAC,aAAc,QAAO;EAE1B,MAAM,SAAS,MAAM,KAAK,cAAc,CACrC,WAAW;GACV,GAAG;GACH,QAAQA,2BAAW,iBAAiB;GACpC,UAAU;GACV,QAAQ;GACT,CAAC,CACD,KAAK,QAAQ;AAEhB,SAAO;GACL,GAAG;GACH,aAAa,OAAO,aAAa;GACjC,cAAc,OAAO,cAAc;GACnC,eAAe,OAAO,MAAM;GACd;GACf;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAiCH,MAAM,4BACJ,eACA,oBACA,SAIyE;EACzE,MAAM,gBAAgBA,2BAAW,cAAc;EAC/C,MAAM,mBAAmB,MAAM,KAAK,0BAA0B;EAE9D,MAAM,eAAe,MAAM,KAAK,uBAAuB,eAAe,oBAAoB,SAAS,oBAAoB;AACvH,MAAI,CAAC,aAAc,QAAO;EAE1B,MAAM,SAAS,MAAM,KAAK,cAAc,CACrC,WAAW;GACV,GAAG;GACH,QAAQ;GACR,UAAU;GACV,QAAQ;GACT,CAAC,CACD,KAAK,QAAQ;AAEhB,SAAO;GACL,GAAG;GACH,aAAa,OAAO,aAAa;GACjC,cAAc,OAAO,cAAc;GACnC,eAAe,OAAO,MAAM;GACd;GACf;;;;;;;;;;;;;;;;;;;;;;;;;;CA2BH,MAAM,oCACJ,eACA,iBACA,oBACA,SAGyC;AACzC,MAAI,CAAE,MAAM,KAAK,eAAe,WAAW,CACzC,OAAM,IAAI,MAAM,sEAAsE;EAGxF,MAAM,gBAAgBA,2BAAW,cAAc;EAE/C,MAAM,eAAe,MAAM,KAAK,uBAAuB,eAAe,oBAAoB,SAAS,oBAAoB;AACvH,MAAI,CAAC,aAAc,QAAO;EAE1B,MAAM,SAAS,MAAM,gBAAgB,KAAK,eAAe,aAAa,UAAU;AAChF,SAAO;GACL,cAAcC,0BAAW,UAAU,OAAO,OAAO;GACjD,eAAe,OAAO;GACvB"}