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

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 (385) 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 -1
  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 +44 -0
  39. package/packages/algo25/src/index.js.map +1 -1
  40. package/packages/algo25/src/index.mjs +39 -1
  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/msgpack.js +0 -1
  116. package/packages/common/src/msgpack.js.map +1 -1
  117. package/packages/indexer_client/src/apis/api-service.d.ts +1 -1
  118. package/packages/indexer_client/src/apis/api-service.js +12 -12
  119. package/packages/indexer_client/src/apis/api-service.js.map +1 -1
  120. package/packages/indexer_client/src/apis/api-service.mjs +12 -12
  121. package/packages/indexer_client/src/apis/api-service.mjs.map +1 -1
  122. package/packages/indexer_client/src/core/api-error.js +3 -1
  123. package/packages/indexer_client/src/core/api-error.js.map +1 -1
  124. package/packages/indexer_client/src/core/api-error.mjs +3 -1
  125. package/packages/indexer_client/src/core/api-error.mjs.map +1 -1
  126. package/packages/indexer_client/src/core/model-runtime.js +0 -15
  127. package/packages/indexer_client/src/core/model-runtime.js.map +1 -1
  128. package/packages/indexer_client/src/core/model-runtime.mjs +1 -13
  129. package/packages/indexer_client/src/core/model-runtime.mjs.map +1 -1
  130. package/packages/indexer_client/src/models/account-participation.js +4 -4
  131. package/packages/indexer_client/src/models/account-participation.js.map +1 -1
  132. package/packages/indexer_client/src/models/account-participation.mjs +4 -4
  133. package/packages/indexer_client/src/models/account-participation.mjs.map +1 -1
  134. package/packages/indexer_client/src/models/application-state-schema.d.ts +2 -2
  135. package/packages/indexer_client/src/models/application-state-schema.js +2 -2
  136. package/packages/indexer_client/src/models/application-state-schema.js.map +1 -1
  137. package/packages/indexer_client/src/models/application-state-schema.mjs +2 -2
  138. package/packages/indexer_client/src/models/application-state-schema.mjs.map +1 -1
  139. package/packages/indexer_client/src/models/asset-params.js +2 -1
  140. package/packages/indexer_client/src/models/asset-params.js.map +1 -1
  141. package/packages/indexer_client/src/models/asset-params.mjs +2 -1
  142. package/packages/indexer_client/src/models/asset-params.mjs.map +1 -1
  143. package/packages/indexer_client/src/models/block.d.ts +5 -5
  144. package/packages/indexer_client/src/models/block.js +13 -13
  145. package/packages/indexer_client/src/models/block.js.map +1 -1
  146. package/packages/indexer_client/src/models/block.mjs +13 -13
  147. package/packages/indexer_client/src/models/block.mjs.map +1 -1
  148. package/packages/indexer_client/src/models/eval-delta-key-value.d.ts +1 -1
  149. package/packages/indexer_client/src/models/eval-delta-key-value.js +2 -2
  150. package/packages/indexer_client/src/models/eval-delta-key-value.js.map +1 -1
  151. package/packages/indexer_client/src/models/eval-delta-key-value.mjs +2 -2
  152. package/packages/indexer_client/src/models/eval-delta-key-value.mjs.map +1 -1
  153. package/packages/indexer_client/src/models/eval-delta.d.ts +1 -1
  154. package/packages/indexer_client/src/models/eval-delta.js +2 -2
  155. package/packages/indexer_client/src/models/eval-delta.js.map +1 -1
  156. package/packages/indexer_client/src/models/eval-delta.mjs +2 -2
  157. package/packages/indexer_client/src/models/eval-delta.mjs.map +1 -1
  158. package/packages/indexer_client/src/models/hb-proof-fields.js +6 -6
  159. package/packages/indexer_client/src/models/hb-proof-fields.js.map +1 -1
  160. package/packages/indexer_client/src/models/hb-proof-fields.mjs +6 -6
  161. package/packages/indexer_client/src/models/hb-proof-fields.mjs.map +1 -1
  162. package/packages/indexer_client/src/models/participation-updates.d.ts +2 -2
  163. package/packages/indexer_client/src/models/participation-updates.js +2 -2
  164. package/packages/indexer_client/src/models/participation-updates.js.map +1 -1
  165. package/packages/indexer_client/src/models/participation-updates.mjs +2 -2
  166. package/packages/indexer_client/src/models/participation-updates.mjs.map +1 -1
  167. package/packages/indexer_client/src/models/state-proof-verifier.js +2 -2
  168. package/packages/indexer_client/src/models/state-proof-verifier.js.map +1 -1
  169. package/packages/indexer_client/src/models/state-proof-verifier.mjs +2 -2
  170. package/packages/indexer_client/src/models/state-proof-verifier.mjs.map +1 -1
  171. package/packages/indexer_client/src/models/state-schema.d.ts +2 -2
  172. package/packages/indexer_client/src/models/state-schema.js +2 -2
  173. package/packages/indexer_client/src/models/state-schema.js.map +1 -1
  174. package/packages/indexer_client/src/models/state-schema.mjs +2 -2
  175. package/packages/indexer_client/src/models/state-schema.mjs.map +1 -1
  176. package/packages/indexer_client/src/models/teal-key-value.d.ts +1 -1
  177. package/packages/indexer_client/src/models/teal-key-value.js +2 -2
  178. package/packages/indexer_client/src/models/teal-key-value.js.map +1 -1
  179. package/packages/indexer_client/src/models/teal-key-value.mjs +2 -2
  180. package/packages/indexer_client/src/models/teal-key-value.mjs.map +1 -1
  181. package/packages/indexer_client/src/models/transaction-heartbeat.js +2 -1
  182. package/packages/indexer_client/src/models/transaction-heartbeat.js.map +1 -1
  183. package/packages/indexer_client/src/models/transaction-heartbeat.mjs +2 -1
  184. package/packages/indexer_client/src/models/transaction-heartbeat.mjs.map +1 -1
  185. package/packages/indexer_client/src/models/transaction-keyreg.js +4 -4
  186. package/packages/indexer_client/src/models/transaction-keyreg.js.map +1 -1
  187. package/packages/indexer_client/src/models/transaction-keyreg.mjs +4 -4
  188. package/packages/indexer_client/src/models/transaction-keyreg.mjs.map +1 -1
  189. package/packages/indexer_client/src/models/transaction-signature-logicsig.js +2 -1
  190. package/packages/indexer_client/src/models/transaction-signature-logicsig.js.map +1 -1
  191. package/packages/indexer_client/src/models/transaction-signature-logicsig.mjs +2 -1
  192. package/packages/indexer_client/src/models/transaction-signature-logicsig.mjs.map +1 -1
  193. package/packages/indexer_client/src/models/transaction-signature-multisig-subsignature.js +3 -3
  194. package/packages/indexer_client/src/models/transaction-signature-multisig-subsignature.js.map +1 -1
  195. package/packages/indexer_client/src/models/transaction-signature-multisig-subsignature.mjs +3 -3
  196. package/packages/indexer_client/src/models/transaction-signature-multisig-subsignature.mjs.map +1 -1
  197. package/packages/indexer_client/src/models/transaction.d.ts +2 -2
  198. package/packages/indexer_client/src/models/transaction.js +6 -5
  199. package/packages/indexer_client/src/models/transaction.js.map +1 -1
  200. package/packages/indexer_client/src/models/transaction.mjs +6 -5
  201. package/packages/indexer_client/src/models/transaction.mjs.map +1 -1
  202. package/packages/kmd_client/src/apis/api-service.d.ts +5 -5
  203. package/packages/kmd_client/src/apis/api-service.js +32 -32
  204. package/packages/kmd_client/src/apis/api-service.js.map +1 -1
  205. package/packages/kmd_client/src/apis/api-service.mjs +32 -32
  206. package/packages/kmd_client/src/apis/api-service.mjs.map +1 -1
  207. package/packages/kmd_client/src/core/api-error.js +3 -1
  208. package/packages/kmd_client/src/core/api-error.js.map +1 -1
  209. package/packages/kmd_client/src/core/api-error.mjs +3 -1
  210. package/packages/kmd_client/src/core/api-error.mjs.map +1 -1
  211. package/packages/kmd_client/src/core/model-runtime.js +2 -12
  212. package/packages/kmd_client/src/core/model-runtime.js.map +1 -1
  213. package/packages/kmd_client/src/core/model-runtime.mjs +3 -11
  214. package/packages/kmd_client/src/core/model-runtime.mjs.map +1 -1
  215. package/packages/sdk/src/encoding/encoding.js +12 -2
  216. package/packages/sdk/src/encoding/encoding.js.map +1 -1
  217. package/packages/sdk/src/encoding/encoding.mjs +12 -1
  218. package/packages/sdk/src/encoding/encoding.mjs.map +1 -1
  219. package/packages/sdk/src/encoding/schema/map.js +0 -2
  220. package/packages/sdk/src/encoding/schema/map.js.map +1 -1
  221. package/packages/transact/src/logicsig.d.ts +3 -15
  222. package/packages/transact/src/logicsig.js +16 -36
  223. package/packages/transact/src/logicsig.js.map +1 -1
  224. package/packages/transact/src/logicsig.mjs +18 -36
  225. package/packages/transact/src/logicsig.mjs.map +1 -1
  226. package/packages/transact/src/multisig.d.ts +7 -115
  227. package/packages/transact/src/multisig.js +86 -136
  228. package/packages/transact/src/multisig.js.map +1 -1
  229. package/packages/transact/src/multisig.mjs +87 -117
  230. package/packages/transact/src/multisig.mjs.map +1 -1
  231. package/packages/transact/src/transactions/app-call.d.ts +10 -15
  232. package/packages/transact/src/transactions/app-call.js.map +1 -1
  233. package/packages/transact/src/transactions/app-call.mjs.map +1 -1
  234. package/packages/transact/src/transactions/asset-config.d.ts +1 -6
  235. package/packages/transact/src/transactions/asset-config.js.map +1 -1
  236. package/packages/transact/src/transactions/asset-config.mjs.map +1 -1
  237. package/packages/transact/src/transactions/asset-freeze.d.ts +1 -6
  238. package/packages/transact/src/transactions/asset-transfer.d.ts +1 -6
  239. package/packages/transact/src/transactions/key-registration.d.ts +1 -8
  240. package/packages/transact/src/transactions/reference-types-meta.d.ts +26 -0
  241. package/packages/transact/src/transactions/reference-types-meta.js +71 -0
  242. package/packages/transact/src/transactions/reference-types-meta.js.map +1 -0
  243. package/packages/transact/src/transactions/reference-types-meta.mjs +69 -0
  244. package/packages/transact/src/transactions/reference-types-meta.mjs.map +1 -0
  245. package/packages/transact/src/transactions/signed-transaction-meta.js +2 -3
  246. package/packages/transact/src/transactions/signed-transaction-meta.js.map +1 -1
  247. package/packages/transact/src/transactions/signed-transaction-meta.mjs +3 -3
  248. package/packages/transact/src/transactions/signed-transaction-meta.mjs.map +1 -1
  249. package/packages/transact/src/transactions/signed-transaction.d.ts +7 -3
  250. package/packages/transact/src/transactions/signed-transaction.js +1 -1
  251. package/packages/transact/src/transactions/signed-transaction.js.map +1 -1
  252. package/packages/transact/src/transactions/signed-transaction.mjs +1 -2
  253. package/packages/transact/src/transactions/signed-transaction.mjs.map +1 -1
  254. package/packages/transact/src/transactions/transaction-meta.js +29 -23
  255. package/packages/transact/src/transactions/transaction-meta.js.map +1 -1
  256. package/packages/transact/src/transactions/transaction-meta.mjs +29 -23
  257. package/packages/transact/src/transactions/transaction-meta.mjs.map +1 -1
  258. package/packages/transact/src/transactions/transaction.d.ts +5 -1
  259. package/packages/transact/src/transactions/transaction.js +1 -1
  260. package/packages/transact/src/transactions/transaction.js.map +1 -1
  261. package/packages/transact/src/transactions/transaction.mjs +1 -1
  262. package/packages/transact/src/transactions/transaction.mjs.map +1 -1
  263. package/sdk/index.js +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/transact/index.d.ts +11 -10
  272. package/transact/index.js +7 -32
  273. package/transact/index.mjs +7 -10
  274. package/transaction/transaction.js +2 -2
  275. package/transaction/transaction.js.map +1 -1
  276. package/transaction/transaction.mjs +2 -2
  277. package/transaction/transaction.mjs.map +1 -1
  278. package/transactions/app-call.d.ts +5 -4
  279. package/transactions/app-call.js +15 -15
  280. package/transactions/app-call.js.map +1 -1
  281. package/transactions/app-call.mjs +15 -15
  282. package/transactions/app-call.mjs.map +1 -1
  283. package/transactions/asset-config.d.ts +1 -1
  284. package/transactions/asset-config.js +1 -1
  285. package/transactions/asset-config.js.map +1 -1
  286. package/transactions/asset-config.mjs +1 -1
  287. package/transactions/asset-config.mjs.map +1 -1
  288. package/transactions/key-registration.d.ts +1 -1
  289. package/transactions/key-registration.js.map +1 -1
  290. package/transactions/key-registration.mjs.map +1 -1
  291. package/transactions/method-call.d.ts +1 -1
  292. package/transactions/method-call.js +69 -77
  293. package/transactions/method-call.js.map +1 -1
  294. package/transactions/method-call.mjs +69 -77
  295. package/transactions/method-call.mjs.map +1 -1
  296. package/types/account-manager.d.ts +1 -1
  297. package/types/account-manager.js +3 -3
  298. package/types/account-manager.js.map +1 -1
  299. package/types/account-manager.mjs +3 -3
  300. package/types/account-manager.mjs.map +1 -1
  301. package/types/algorand-client-transaction-creator.d.ts +57 -43
  302. package/types/algorand-client-transaction-creator.js +8 -0
  303. package/types/algorand-client-transaction-creator.js.map +1 -1
  304. package/types/algorand-client-transaction-creator.mjs +8 -0
  305. package/types/algorand-client-transaction-creator.mjs.map +1 -1
  306. package/types/algorand-client-transaction-sender.d.ts +62 -48
  307. package/types/algorand-client-transaction-sender.js +8 -1
  308. package/types/algorand-client-transaction-sender.js.map +1 -1
  309. package/types/algorand-client-transaction-sender.mjs +8 -0
  310. package/types/algorand-client-transaction-sender.mjs.map +1 -1
  311. package/types/app-client.d.ts +110 -105
  312. package/types/app-client.js +0 -1
  313. package/types/app-client.js.map +1 -1
  314. package/types/app-client.mjs.map +1 -1
  315. package/types/app-deployer.d.ts +1 -1
  316. package/types/app-deployer.js +2 -2
  317. package/types/app-deployer.js.map +1 -1
  318. package/types/app-deployer.mjs +2 -2
  319. package/types/app-deployer.mjs.map +1 -1
  320. package/types/app-factory.d.ts +44 -41
  321. package/types/app-factory.js.map +1 -1
  322. package/types/app-factory.mjs.map +1 -1
  323. package/types/app-manager.d.ts +3 -1
  324. package/types/app-manager.js +16 -10
  325. package/types/app-manager.js.map +1 -1
  326. package/types/app-manager.mjs +16 -10
  327. package/types/app-manager.mjs.map +1 -1
  328. package/types/app-spec.js +12 -5
  329. package/types/app-spec.js.map +1 -1
  330. package/types/app-spec.mjs +12 -5
  331. package/types/app-spec.mjs.map +1 -1
  332. package/types/app.d.ts +1 -1
  333. package/types/app.js.map +1 -1
  334. package/types/app.mjs.map +1 -1
  335. package/types/asset-manager.js +1 -1
  336. package/types/asset-manager.js.map +1 -1
  337. package/types/asset-manager.mjs +1 -1
  338. package/types/asset-manager.mjs.map +1 -1
  339. package/types/async-event-emitter.d.ts +3 -6
  340. package/types/async-event-emitter.js.map +1 -1
  341. package/types/async-event-emitter.mjs.map +1 -1
  342. package/types/client-manager.d.ts +1 -1
  343. package/types/client-manager.js.map +1 -1
  344. package/types/client-manager.mjs.map +1 -1
  345. package/types/composer.d.ts +9 -1
  346. package/types/composer.js +35 -23
  347. package/types/composer.js.map +1 -1
  348. package/types/composer.mjs +37 -24
  349. package/types/composer.mjs.map +1 -1
  350. package/types/debugging.d.ts +13 -9
  351. package/types/debugging.js.map +1 -1
  352. package/types/debugging.mjs.map +1 -1
  353. package/types/expand.d.ts +2 -9
  354. package/types/kmd-account-manager.d.ts +1 -0
  355. package/types/kmd-account-manager.js +21 -10
  356. package/types/kmd-account-manager.js.map +1 -1
  357. package/types/kmd-account-manager.mjs +22 -11
  358. package/types/kmd-account-manager.mjs.map +1 -1
  359. package/types/lifecycle-events.d.ts +0 -1
  360. package/types/lifecycle-events.js.map +1 -1
  361. package/types/lifecycle-events.mjs.map +1 -1
  362. package/types/testing.d.ts +2 -2
  363. package/types/transaction.d.ts +1 -1
  364. package/_virtual/rolldown_runtime.mjs +0 -13
  365. package/indexer-lookup.js.map +0 -1
  366. package/indexer-lookup.mjs.map +0 -1
  367. package/packages/algod_client/src/core/model-runtime.d.ts +0 -10
  368. package/packages/algod_client/src/models/application-local-reference.d.ts +0 -20
  369. package/packages/algod_client/src/models/application-local-reference.js +0 -23
  370. package/packages/algod_client/src/models/application-local-reference.js.map +0 -1
  371. package/packages/algod_client/src/models/application-local-reference.mjs +0 -23
  372. package/packages/algod_client/src/models/application-local-reference.mjs.map +0 -1
  373. package/packages/algod_client/src/models/asset-holding-reference.d.ts +0 -20
  374. package/packages/algod_client/src/models/asset-holding-reference.js +0 -23
  375. package/packages/algod_client/src/models/asset-holding-reference.js.map +0 -1
  376. package/packages/algod_client/src/models/asset-holding-reference.mjs +0 -23
  377. package/packages/algod_client/src/models/asset-holding-reference.mjs.map +0 -1
  378. package/packages/algod_client/src/models/box-reference.d.ts +0 -17
  379. package/packages/algod_client/src/models/box-reference.js +0 -23
  380. package/packages/algod_client/src/models/box-reference.js.map +0 -1
  381. package/packages/algod_client/src/models/box-reference.mjs +0 -23
  382. package/packages/algod_client/src/models/box-reference.mjs.map +0 -1
  383. package/packages/indexer_client/src/core/model-runtime.d.ts +0 -10
  384. package/packages/kmd_client/src/core/model-runtime.d.ts +0 -10
  385. package/packages/transact/src/transactions/common.d.ts +0 -37
@@ -1,115 +1,9 @@
1
1
  import { Address } from "../../common/src/address.js";
2
2
  import { Transaction } from "./transactions/transaction.js";
3
- import { MultisigSignature } from "./transactions/signed-transaction.js";
3
+ import { MultisigSignature, SignedTransaction } from "./transactions/signed-transaction.js";
4
4
  import { AddressWithDelegatedLsigSigner, AddressWithTransactionSigner, TransactionSigner } from "./signer.js";
5
5
 
6
6
  //#region packages/transact/src/multisig.d.ts
7
-
8
- /**
9
- * Creates an empty multisignature signature from a list of participant public keys.
10
- */
11
- declare function newMultisigSignature(version: number, threshold: number, participants: Uint8Array[]): MultisigSignature;
12
- /**
13
- * Returns the list of participant public keys from a multisignature signature.
14
- */
15
- declare function participantsFromMultisigSignature(multisigSignature: MultisigSignature): Uint8Array[];
16
- /**
17
- * Returns the address of the multisignature account.
18
- */
19
- declare function addressFromMultisigSignature(multisigSignature: MultisigSignature): Address;
20
- /**
21
- * Applies a subsignature for a participant to a multisignature signature, replacing any existing signature.
22
- *
23
- * This method applies the signature to ALL instances of the given public key (to support weighted multisig).
24
- * Since ed25519 signatures are deterministic, there's only one valid signature for a given message and public key.
25
- */
26
- declare function applyMultisigSubsignature(multisigSignature: MultisigSignature, participant: Uint8Array, signature: Uint8Array): MultisigSignature;
27
- /**
28
- * Merges two multisignature signatures, replacing signatures in the first with those from the second where present.
29
- * For each participant, the resulting signature will be taken from the second multisig if present, otherwise from the first.
30
- */
31
- declare function mergeMultisignatures(multisigSignatureA: MultisigSignature, multisigSignatureB: MultisigSignature): MultisigSignature;
32
- declare const MULTISIG_MERGE_LESSTHANTWO_ERROR_MSG = "Not enough multisig transactions to merge. Need at least two";
33
- declare const MULTISIG_MERGE_MISMATCH_ERROR_MSG = "Cannot merge txs. txIDs differ";
34
- declare const MULTISIG_MERGE_MISMATCH_AUTH_ADDR_MSG = "Cannot merge txs. Auth addrs differ";
35
- declare const MULTISIG_MERGE_WRONG_PREIMAGE_ERROR_MSG = "Cannot merge txs. Multisig preimages differ";
36
- declare const MULTISIG_MERGE_SIG_MISMATCH_ERROR_MSG = "Cannot merge txs. subsigs are mismatched.";
37
- declare const MULTISIG_NO_MUTATE_ERROR_MSG = "Cannot mutate a multisig field as it would invalidate all existing signatures.";
38
- declare const MULTISIG_USE_PARTIAL_SIGN_ERROR_MSG = "Cannot sign a multisig transaction using `signTxn`. Use `partialSignTxn` instead.";
39
- declare const MULTISIG_SIGNATURE_LENGTH_ERROR_MSG = "Cannot add multisig signature. Signature is not of the correct length.";
40
- /**
41
- * creates a raw, multisig transaction blob without any signatures.
42
- * @param txn - the actual transaction.
43
- * @param version - multisig version
44
- * @param threshold - multisig threshold
45
- * @param pks - ordered list of public keys in this multisig
46
- * @returns encoded multisig blob
47
- */
48
- declare function createMultisigTransaction(txn: Transaction, {
49
- version,
50
- threshold,
51
- addrs
52
- }: MultisigMetadata): Uint8Array;
53
- /**
54
- * takes a list of multisig transaction blobs, and merges them.
55
- * @param multisigTxnBlobs - a list of blobs representing encoded multisig txns
56
- * @returns typed array msg-pack encoded multisig txn
57
- */
58
- declare function mergeMultisigTransactions(multisigTxnBlobs: Uint8Array[]): Uint8Array;
59
- /**
60
- * Takes a multisig transaction blob, and appends a given raw signature to it.
61
- * This makes it possible to compile a multisig signature using only raw signatures from external methods.
62
- * @param multisigTxnBlob - an encoded multisig txn. Supports non-payment txn types.
63
- * @param version - multisig version
64
- * @param threshold - multisig threshold
65
- * @param addrs - a list of Algorand addresses representing possible signers for this multisig. Order is important.
66
- * @param signerAddr - address of the signer
67
- * @param signature - raw multisig signature
68
- * @returns object containing txID, and blob representing encoded multisig txn
69
- */
70
- declare function appendSignRawMultisigSignature(multisigTxnBlob: Uint8Array, {
71
- version,
72
- threshold,
73
- addrs
74
- }: MultisigMetadata, signerAddr: string | Address, signature: Uint8Array): {
75
- txID: string;
76
- blob: Uint8Array;
77
- };
78
- /**
79
- * Takes multisig parameters and returns a 32 byte typed array public key,
80
- * representing an address that identifies the "exact group, version, and public keys" that are required for signing.
81
- * Hash("MultisigAddr" || version uint8 || threshold uint8 || PK1 || PK2 || ...)
82
- * Encoding this output yields a human readable address.
83
- * @param version - multisig version
84
- * @param threshold - multisig threshold
85
- * @param pks - array of typed array public keys
86
- */
87
- declare function addressFromMultisigPreImg({
88
- version,
89
- threshold,
90
- pks
91
- }: Omit<MultisigMetadata, 'addrs'> & {
92
- pks: Uint8Array[];
93
- }): Address;
94
- /**
95
- * Takes multisig parameters and returns a human readable Algorand address.
96
- * This is equivalent to fromMultisigPreImg, but interfaces with encoded addresses.
97
- * @param version - multisig version
98
- * @param threshold - multisig threshold
99
- * @param addrs - array of encoded addresses
100
- */
101
- declare function addressFromMultisigPreImgAddrs({
102
- version,
103
- threshold,
104
- addrs
105
- }: MultisigMetadata): Address;
106
- /**
107
- * Takes multisig metadata (preimage) and returns the corresponding human readable Algorand address.
108
- * @param version - multisig version
109
- * @param threshold - multisig threshold
110
- * @param addrs - list of Algorand addresses
111
- */
112
- declare const multisigAddress: typeof addressFromMultisigPreImgAddrs;
113
7
  interface MultisigMetadata {
114
8
  /**
115
9
  * Multisig version
@@ -139,15 +33,13 @@ declare class MultisigAccount implements AddressWithTransactionSigner {
139
33
  get addr(): Readonly<Address>;
140
34
  /** The transaction signer for the multisig account */
141
35
  get signer(): TransactionSigner;
36
+ static fromSignature(signature: MultisigSignature): MultisigAccount;
142
37
  constructor(multisigParams: MultisigMetadata, subSigners: (AddressWithTransactionSigner & AddressWithDelegatedLsigSigner)[]);
38
+ createMultisigTransaction(txn: Transaction): SignedTransaction;
39
+ createMultisigSignature(): MultisigSignature;
40
+ applySignatureToTxn(txn: SignedTransaction, pubkey: Uint8Array, signature: Uint8Array): void;
41
+ applySignature(msigSignature: MultisigSignature, pubkey: Uint8Array, signature: Uint8Array): MultisigSignature;
143
42
  }
144
- /**
145
- * Decodes MsgPack bytes into a multi signature.
146
- *
147
- * @param encodedMultiSignature - The MsgPack encoded multi signature
148
- * @returns The decoded MultisigSignature or an error if decoding fails.
149
- */
150
- declare function decodeMultiSignature(encodedMultiSignature: Uint8Array): MultisigSignature;
151
43
  //#endregion
152
- export { MULTISIG_MERGE_LESSTHANTWO_ERROR_MSG, MULTISIG_MERGE_MISMATCH_AUTH_ADDR_MSG, MULTISIG_MERGE_MISMATCH_ERROR_MSG, MULTISIG_MERGE_SIG_MISMATCH_ERROR_MSG, MULTISIG_MERGE_WRONG_PREIMAGE_ERROR_MSG, MULTISIG_NO_MUTATE_ERROR_MSG, MULTISIG_SIGNATURE_LENGTH_ERROR_MSG, MULTISIG_USE_PARTIAL_SIGN_ERROR_MSG, MultisigAccount, MultisigMetadata, addressFromMultisigPreImg, addressFromMultisigPreImgAddrs, addressFromMultisigSignature, appendSignRawMultisigSignature, applyMultisigSubsignature, createMultisigTransaction, decodeMultiSignature, mergeMultisigTransactions, mergeMultisignatures, multisigAddress, newMultisigSignature, participantsFromMultisigSignature };
44
+ export { MultisigAccount, MultisigMetadata };
153
45
  //# sourceMappingURL=multisig.d.ts.map
@@ -2,42 +2,11 @@ const require_array = require('../../common/src/array.js');
2
2
  const require_constants = require('../../common/src/constants.js');
3
3
  const require_address = require('../../common/src/address.js');
4
4
  const require_crypto = require('../../common/src/crypto.js');
5
- const require_msgpack = require('../../common/src/msgpack.js');
6
- const require_signed_transaction_meta = require('./transactions/signed-transaction-meta.js');
7
5
  const require_signed_transaction = require('./transactions/signed-transaction.js');
8
6
 
9
7
  //#region packages/transact/src/multisig.ts
10
- /**
11
- * Creates an empty multisignature signature from a list of participant public keys.
12
- */
13
- function newMultisigSignature(version, threshold, participants) {
14
- if (version === 0) throw new Error("Version cannot be zero");
15
- if (participants.length === 0) throw new Error("Participants cannot be empty");
16
- if (threshold === 0 || threshold > participants.length) throw new Error("Threshold must be greater than zero and less than or equal to the number of participants");
17
- return {
18
- version,
19
- threshold,
20
- subsignatures: participants.map((publicKey) => ({ publicKey }))
21
- };
22
- }
23
- /**
24
- * Returns the list of participant public keys from a multisignature signature.
25
- */
26
- function participantsFromMultisigSignature(multisigSignature) {
27
- return multisigSignature.subsignatures.map((subsig) => subsig.publicKey);
28
- }
29
8
  const toPublicKeys = (addrs) => addrs.map((addr) => require_address.getAddress(addr).publicKey);
30
9
  /**
31
- * Returns the address of the multisignature account.
32
- */
33
- function addressFromMultisigSignature(multisigSignature) {
34
- return addressFromMultisigPreImg({
35
- version: multisigSignature.version,
36
- threshold: multisigSignature.threshold,
37
- pks: multisigSignature.subsignatures.map((subsig) => subsig.publicKey)
38
- });
39
- }
40
- /**
41
10
  * Applies a subsignature for a participant to a multisignature signature, replacing any existing signature.
42
11
  *
43
12
  * This method applies the signature to ALL instances of the given public key (to support weighted multisig).
@@ -45,12 +14,12 @@ function addressFromMultisigSignature(multisigSignature) {
45
14
  */
46
15
  function applyMultisigSubsignature(multisigSignature, participant, signature) {
47
16
  let found = false;
48
- const newSubsignatures = multisigSignature.subsignatures.map((subsig) => {
17
+ const newSubsignatures = multisigSignature.subsigs.map((subsig) => {
49
18
  if (require_array.arrayEqual(subsig.publicKey, participant)) {
50
19
  found = true;
51
20
  return {
52
21
  ...subsig,
53
- signature
22
+ sig: signature
54
23
  };
55
24
  }
56
25
  return subsig;
@@ -58,30 +27,7 @@ function applyMultisigSubsignature(multisigSignature, participant, signature) {
58
27
  if (!found) throw new Error("Public key not found in multisig signature");
59
28
  return {
60
29
  ...multisigSignature,
61
- subsignatures: newSubsignatures
62
- };
63
- }
64
- /**
65
- * Merges two multisignature signatures, replacing signatures in the first with those from the second where present.
66
- * For each participant, the resulting signature will be taken from the second multisig if present, otherwise from the first.
67
- */
68
- function mergeMultisignatures(multisigSignatureA, multisigSignatureB) {
69
- if (multisigSignatureA.version !== multisigSignatureB.version) throw new Error("Cannot merge multisig signatures with different versions");
70
- if (multisigSignatureA.threshold !== multisigSignatureB.threshold) throw new Error("Cannot merge multisig signatures with different thresholds");
71
- const participantsA = participantsFromMultisigSignature(multisigSignatureA);
72
- const participantsB = participantsFromMultisigSignature(multisigSignatureB);
73
- if (!(participantsA.length === participantsB.length && participantsA.every((pk, i) => require_array.arrayEqual(pk, participantsB[i])))) throw new Error("Cannot merge multisig signatures with different participants");
74
- const mergedSubsignatures = multisigSignatureA.subsignatures.map((s1, index) => {
75
- const s2 = multisigSignatureB.subsignatures[index];
76
- return {
77
- publicKey: s1.publicKey,
78
- signature: s2.signature || s1.signature
79
- };
80
- });
81
- return {
82
- version: multisigSignatureA.version,
83
- threshold: multisigSignatureA.threshold,
84
- subsignatures: mergedSubsignatures
30
+ subsigs: newSubsignatures
85
31
  };
86
32
  }
87
33
  const MULTISIG_PREIMG2ADDR_PREFIX = new Uint8Array([
@@ -107,8 +53,6 @@ const MULTISIG_MERGE_MISMATCH_ERROR_MSG = "Cannot merge txs. txIDs differ";
107
53
  const MULTISIG_MERGE_MISMATCH_AUTH_ADDR_MSG = "Cannot merge txs. Auth addrs differ";
108
54
  const MULTISIG_MERGE_WRONG_PREIMAGE_ERROR_MSG = "Cannot merge txs. Multisig preimages differ";
109
55
  const MULTISIG_MERGE_SIG_MISMATCH_ERROR_MSG = "Cannot merge txs. subsigs are mismatched.";
110
- const MULTISIG_NO_MUTATE_ERROR_MSG = "Cannot mutate a multisig field as it would invalidate all existing signatures.";
111
- const MULTISIG_USE_PARTIAL_SIGN_ERROR_MSG = "Cannot sign a multisig transaction using `signTxn`. Use `partialSignTxn` instead.";
112
56
  const MULTISIG_SIGNATURE_LENGTH_ERROR_MSG = "Cannot add multisig signature. Signature is not of the correct length.";
113
57
  const MULTISIG_KEY_NOT_EXIST_ERROR_MSG = "Key does not exist";
114
58
  /**
@@ -124,23 +68,23 @@ function createMultisigTransaction(txn, { version, threshold, addrs }) {
124
68
  const msig = {
125
69
  version,
126
70
  threshold,
127
- subsignatures: pks.map((pk) => ({
71
+ subsigs: pks.map((pk) => ({
128
72
  publicKey: pk,
129
- signature: void 0
73
+ sig: void 0
130
74
  }))
131
75
  };
132
76
  const msigAddr = addressFromMultisigPreImg({
133
77
  version,
134
78
  threshold,
135
- pks
79
+ publicKeys: pks
136
80
  });
137
81
  let authAddress;
138
82
  if (!msigAddr.equals(txn.sender)) authAddress = msigAddr;
139
- return require_signed_transaction.encodeSignedTransaction({
83
+ return {
140
84
  txn,
141
85
  msig,
142
86
  authAddress
143
- });
87
+ };
144
88
  }
145
89
  /**
146
90
  * creates a multisig transaction blob with an included signature.
@@ -152,31 +96,31 @@ function createMultisigTransaction(txn, { version, threshold, addrs }) {
152
96
  * @param pks - ordered list of public keys in this multisig
153
97
  * @returns encoded multisig blob
154
98
  */
155
- function createMultisigTransactionWithSignature(txn, { rawSig, myPk }, { version, threshold, pks }) {
156
- const signedTxn = require_signed_transaction.decodeSignedTransaction(createMultisigTransaction(txn, {
99
+ function createMultisigTransactionWithSignature(txn, { rawSig, myPk }, { version, threshold, publicKeys }) {
100
+ const signedTxn = createMultisigTransaction(txn, {
157
101
  version,
158
102
  threshold,
159
- addrs: pks.map((pk) => new require_address.Address(pk))
160
- }));
103
+ addrs: publicKeys.map((pk) => new require_address.Address(pk))
104
+ });
161
105
  let keyExist = false;
162
- const updatedSubsigs = signedTxn.msig.subsignatures.map((subsig) => {
106
+ const updatedSubsigs = signedTxn.msig.subsigs.map((subsig) => {
163
107
  if (require_array.arrayEqual(subsig.publicKey, myPk)) {
164
108
  keyExist = true;
165
109
  return {
166
110
  ...subsig,
167
- signature: rawSig
111
+ sig: rawSig
168
112
  };
169
113
  }
170
114
  return subsig;
171
115
  });
172
116
  if (!keyExist) throw new Error(MULTISIG_KEY_NOT_EXIST_ERROR_MSG);
173
- return require_signed_transaction.encodeSignedTransaction({
117
+ return {
174
118
  ...signedTxn,
175
119
  msig: {
176
120
  ...signedTxn.msig,
177
- subsignatures: updatedSubsigs
121
+ subsigs: updatedSubsigs
178
122
  }
179
- });
123
+ };
180
124
  }
181
125
  /**
182
126
  * takes a list of multisig transaction blobs, and merges them.
@@ -185,44 +129,44 @@ function createMultisigTransactionWithSignature(txn, { rawSig, myPk }, { version
185
129
  */
186
130
  function mergeMultisigTransactions(multisigTxnBlobs) {
187
131
  if (multisigTxnBlobs.length < 2) throw new Error(MULTISIG_MERGE_LESSTHANTWO_ERROR_MSG);
188
- const refSigTx = require_signed_transaction.decodeSignedTransaction(multisigTxnBlobs[0]);
132
+ const refSigTx = multisigTxnBlobs[0];
189
133
  if (!refSigTx.msig) throw new Error("Invalid multisig transaction, multisig structure missing at index 0");
190
134
  const refTxID = refSigTx.txn.txId();
191
135
  const refAuthAddr = refSigTx.authAddress;
192
136
  const refMsigAddr = addressFromMultisigPreImg({
193
137
  version: refSigTx.msig.version,
194
138
  threshold: refSigTx.msig.threshold,
195
- pks: refSigTx.msig.subsignatures.map((subsig) => subsig.publicKey)
139
+ publicKeys: refSigTx.msig.subsigs.map((subsig) => subsig.publicKey)
196
140
  });
197
- const newSubsigs = refSigTx.msig.subsignatures.map((sig) => ({ ...sig }));
141
+ const newSubsigs = refSigTx.msig.subsigs.map((sig) => ({ ...sig }));
198
142
  for (let i = 1; i < multisigTxnBlobs.length; i++) {
199
- const unisig = require_signed_transaction.decodeSignedTransaction(multisigTxnBlobs[i]);
143
+ const unisig = multisigTxnBlobs[i];
200
144
  if (!unisig.msig) throw new Error(`Invalid multisig transaction, multisig structure missing at index ${i}`);
201
145
  if (unisig.txn.txId() !== refTxID) throw new Error(MULTISIG_MERGE_MISMATCH_ERROR_MSG);
202
146
  if (refAuthAddr !== unisig.authAddress) throw new Error(MULTISIG_MERGE_MISMATCH_AUTH_ADDR_MSG);
203
- if (unisig.msig.subsignatures.length !== refSigTx.msig.subsignatures.length) throw new Error(MULTISIG_MERGE_WRONG_PREIMAGE_ERROR_MSG);
147
+ if (unisig.msig.subsigs.length !== refSigTx.msig.subsigs.length) throw new Error(MULTISIG_MERGE_WRONG_PREIMAGE_ERROR_MSG);
204
148
  const msgigAddr = addressFromMultisigPreImg({
205
149
  version: unisig.msig.version,
206
150
  threshold: unisig.msig.threshold,
207
- pks: unisig.msig.subsignatures.map((subsig) => subsig.publicKey)
151
+ publicKeys: unisig.msig.subsigs.map((subsig) => subsig.publicKey)
208
152
  });
209
153
  if (refMsigAddr.toString() !== msgigAddr.toString()) throw new Error(MULTISIG_MERGE_WRONG_PREIMAGE_ERROR_MSG);
210
- unisig.msig.subsignatures.forEach((uniSubsig, index) => {
211
- if (!uniSubsig.signature) return;
154
+ unisig.msig.subsigs.forEach((uniSubsig, index) => {
155
+ if (!uniSubsig.sig) return;
212
156
  const current = newSubsigs[index];
213
- if (current.signature && !require_array.arrayEqual(uniSubsig.signature, current.signature)) throw new Error(MULTISIG_MERGE_SIG_MISMATCH_ERROR_MSG);
214
- current.signature = uniSubsig.signature;
157
+ if (current.sig && !require_array.arrayEqual(uniSubsig.sig, current.sig)) throw new Error(MULTISIG_MERGE_SIG_MISMATCH_ERROR_MSG);
158
+ current.sig = uniSubsig.sig;
215
159
  });
216
160
  }
217
- return require_signed_transaction.encodeSignedTransaction({
161
+ return {
218
162
  txn: refSigTx.txn,
219
163
  msig: {
220
164
  version: refSigTx.msig.version,
221
165
  threshold: refSigTx.msig.threshold,
222
- subsignatures: newSubsigs
166
+ subsigs: newSubsigs
223
167
  },
224
168
  authAddress: refAuthAddr
225
- });
169
+ };
226
170
  }
227
171
  /**
228
172
  * Partially signs this transaction with an external raw multisig signature and returns
@@ -251,18 +195,13 @@ function partialSignWithMultisigSignature(transaction, metadata, signerAddr, sig
251
195
  * @param signature - raw multisig signature
252
196
  * @returns object containing txID, and blob representing encoded multisig txn
253
197
  */
254
- function appendSignRawMultisigSignature(multisigTxnBlob, { version, threshold, addrs }, signerAddr, signature) {
255
- const pks = toPublicKeys(addrs);
256
- const multisigTxObj = require_signed_transaction.decodeSignedTransaction(multisigTxnBlob);
257
- const partialSignedBlob = partialSignWithMultisigSignature(multisigTxObj.txn, {
198
+ function appendSignRawMultisigSignature(multisigTxn, { version, threshold, addrs }, signerAddr, signature) {
199
+ const publicKeys = toPublicKeys(addrs);
200
+ return mergeMultisigTransactions([multisigTxn, partialSignWithMultisigSignature(multisigTxn.txn, {
258
201
  version,
259
202
  threshold,
260
- pks
261
- }, signerAddr, signature);
262
- return {
263
- txID: multisigTxObj.txn.txId(),
264
- blob: mergeMultisigTransactions([multisigTxnBlob, partialSignedBlob])
265
- };
203
+ publicKeys
204
+ }, signerAddr, signature)]);
266
205
  }
267
206
  /**
268
207
  * Takes multisig parameters and returns a 32 byte typed array public key,
@@ -273,18 +212,18 @@ function appendSignRawMultisigSignature(multisigTxnBlob, { version, threshold, a
273
212
  * @param threshold - multisig threshold
274
213
  * @param pks - array of typed array public keys
275
214
  */
276
- function addressFromMultisigPreImg({ version, threshold, pks }) {
215
+ function addressFromMultisigPreImg({ version, threshold, publicKeys }) {
277
216
  if (version > 255 || version < 0) throw new Error(`${INVALID_MSIG_VERSION_ERROR_MSG}: ${version}`);
278
- if (threshold === 0 || pks.length === 0 || threshold > pks.length || threshold > 255) throw new Error(INVALID_MSIG_THRESHOLD_ERROR_MSG);
217
+ if (threshold === 0 || publicKeys.length === 0 || threshold > publicKeys.length || threshold > 255) throw new Error(INVALID_MSIG_THRESHOLD_ERROR_MSG);
279
218
  const pkLen = require_address.ALGORAND_ADDRESS_BYTE_LENGTH - require_address.ALGORAND_CHECKSUM_BYTE_LENGTH;
280
219
  if (pkLen !== require_constants.PUBLIC_KEY_BYTE_LENGTH) throw new Error(UNEXPECTED_PK_LEN_ERROR_MSG);
281
- const merged = new Uint8Array(MULTISIG_PREIMG2ADDR_PREFIX.length + 2 + pkLen * pks.length);
220
+ const merged = new Uint8Array(MULTISIG_PREIMG2ADDR_PREFIX.length + 2 + pkLen * publicKeys.length);
282
221
  merged.set(MULTISIG_PREIMG2ADDR_PREFIX, 0);
283
222
  merged.set([version], MULTISIG_PREIMG2ADDR_PREFIX.length);
284
223
  merged.set([threshold], MULTISIG_PREIMG2ADDR_PREFIX.length + 1);
285
- for (let i = 0; i < pks.length; i++) {
286
- if (pks[i].length !== pkLen) throw new Error(INVALID_MSIG_PK_ERROR_MSG);
287
- merged.set(pks[i], MULTISIG_PREIMG2ADDR_PREFIX.length + 2 + i * pkLen);
224
+ for (let i = 0; i < publicKeys.length; i++) {
225
+ if (publicKeys[i].length !== pkLen) throw new Error(INVALID_MSIG_PK_ERROR_MSG);
226
+ merged.set(publicKeys[i], MULTISIG_PREIMG2ADDR_PREFIX.length + 2 + i * pkLen);
288
227
  }
289
228
  return new require_address.Address(Uint8Array.from(require_crypto.hash(merged)));
290
229
  }
@@ -299,7 +238,7 @@ function addressFromMultisigPreImgAddrs({ version, threshold, addrs }) {
299
238
  return addressFromMultisigPreImg({
300
239
  version,
301
240
  threshold,
302
- pks: toPublicKeys(addrs)
241
+ publicKeys: toPublicKeys(addrs)
303
242
  });
304
243
  }
305
244
  /**
@@ -310,7 +249,7 @@ function addressFromMultisigPreImgAddrs({ version, threshold, addrs }) {
310
249
  */
311
250
  const multisigAddress = addressFromMultisigPreImgAddrs;
312
251
  /** Account wrapper that supports partial or full multisig signing. */
313
- var MultisigAccount = class {
252
+ var MultisigAccount = class MultisigAccount {
314
253
  _params;
315
254
  _subSigners;
316
255
  _addr;
@@ -331,6 +270,13 @@ var MultisigAccount = class {
331
270
  get signer() {
332
271
  return this._signer;
333
272
  }
273
+ static fromSignature(signature) {
274
+ return new MultisigAccount({
275
+ version: signature.version,
276
+ threshold: signature.threshold,
277
+ addrs: signature.subsigs.map((subsig) => new require_address.Address(subsig.publicKey))
278
+ }, []);
279
+ }
334
280
  constructor(multisigParams, subSigners) {
335
281
  this._params = multisigParams;
336
282
  this._subSigners = subSigners;
@@ -344,45 +290,49 @@ var MultisigAccount = class {
344
290
  const stxn = (await subSigner.signer([txn], [0]))[0];
345
291
  const sig = require_signed_transaction.decodeSignedTransaction(stxn).sig;
346
292
  if (!sig) throw new Error(`Signer for address ${subSigner.addr.toString()} did not produce a valid signature when signing ${txn.txId()} for multisig account ${this._addr.toString()}`);
347
- signedMsigTxn = appendSignRawMultisigSignature(signedMsigTxn, this._params, subSigner.addr, sig).blob;
293
+ signedMsigTxn = appendSignRawMultisigSignature(signedMsigTxn, this._params, subSigner.addr, sig);
348
294
  }
349
295
  signedMsigTxns.push(signedMsigTxn);
350
296
  }
351
- return signedMsigTxns;
297
+ return signedMsigTxns.map(require_signed_transaction.encodeSignedTransaction);
298
+ };
299
+ }
300
+ createMultisigTransaction(txn) {
301
+ return createMultisigTransaction(txn, this._params);
302
+ }
303
+ createMultisigSignature() {
304
+ const subsignatures = toPublicKeys(this._params.addrs).map((pk) => ({
305
+ publicKey: pk,
306
+ signature: void 0
307
+ }));
308
+ return {
309
+ version: this._params.version,
310
+ threshold: this._params.threshold,
311
+ subsigs: subsignatures
352
312
  };
353
313
  }
314
+ applySignatureToTxn(txn, pubkey, signature) {
315
+ if (!txn.msig) txn.msig = this.createMultisigTransaction(txn.txn).msig;
316
+ txn.msig = applyMultisigSubsignature(txn.msig, pubkey, signature);
317
+ }
318
+ applySignature(msigSignature, pubkey, signature) {
319
+ if (msigSignature.version !== this._params.version || msigSignature.threshold !== this._params.threshold) {
320
+ const thisParams = {
321
+ version: this._params.version,
322
+ threshold: this._params.threshold,
323
+ participants: this._params.addrs.map((addr) => addr.toString())
324
+ };
325
+ const givenParams = {
326
+ version: msigSignature.version,
327
+ threshold: msigSignature.threshold,
328
+ participants: msigSignature.subsigs.map((subsig) => new require_address.Address(subsig.publicKey).toString())
329
+ };
330
+ throw new Error(`Multisig signature parameters do not match expected multisig parameters. Multisig params: ${JSON.stringify(thisParams)}, signature: ${JSON.stringify(givenParams)}`);
331
+ }
332
+ return applyMultisigSubsignature(msigSignature, pubkey, signature);
333
+ }
354
334
  };
355
- /**
356
- * Decodes MsgPack bytes into a multi signature.
357
- *
358
- * @param encodedMultiSignature - The MsgPack encoded multi signature
359
- * @returns The decoded MultisigSignature or an error if decoding fails.
360
- */
361
- function decodeMultiSignature(encodedMultiSignature) {
362
- const decodedData = require_msgpack.decodeMsgpack(encodedMultiSignature);
363
- return require_signed_transaction_meta.multiSignatureCodec.decode(decodedData, "msgpack");
364
- }
365
335
 
366
336
  //#endregion
367
- exports.MULTISIG_MERGE_LESSTHANTWO_ERROR_MSG = MULTISIG_MERGE_LESSTHANTWO_ERROR_MSG;
368
- exports.MULTISIG_MERGE_MISMATCH_AUTH_ADDR_MSG = MULTISIG_MERGE_MISMATCH_AUTH_ADDR_MSG;
369
- exports.MULTISIG_MERGE_MISMATCH_ERROR_MSG = MULTISIG_MERGE_MISMATCH_ERROR_MSG;
370
- exports.MULTISIG_MERGE_SIG_MISMATCH_ERROR_MSG = MULTISIG_MERGE_SIG_MISMATCH_ERROR_MSG;
371
- exports.MULTISIG_MERGE_WRONG_PREIMAGE_ERROR_MSG = MULTISIG_MERGE_WRONG_PREIMAGE_ERROR_MSG;
372
- exports.MULTISIG_NO_MUTATE_ERROR_MSG = MULTISIG_NO_MUTATE_ERROR_MSG;
373
- exports.MULTISIG_SIGNATURE_LENGTH_ERROR_MSG = MULTISIG_SIGNATURE_LENGTH_ERROR_MSG;
374
- exports.MULTISIG_USE_PARTIAL_SIGN_ERROR_MSG = MULTISIG_USE_PARTIAL_SIGN_ERROR_MSG;
375
337
  exports.MultisigAccount = MultisigAccount;
376
- exports.addressFromMultisigPreImg = addressFromMultisigPreImg;
377
- exports.addressFromMultisigPreImgAddrs = addressFromMultisigPreImgAddrs;
378
- exports.addressFromMultisigSignature = addressFromMultisigSignature;
379
- exports.appendSignRawMultisigSignature = appendSignRawMultisigSignature;
380
- exports.applyMultisigSubsignature = applyMultisigSubsignature;
381
- exports.createMultisigTransaction = createMultisigTransaction;
382
- exports.decodeMultiSignature = decodeMultiSignature;
383
- exports.mergeMultisigTransactions = mergeMultisigTransactions;
384
- exports.mergeMultisignatures = mergeMultisignatures;
385
- exports.multisigAddress = multisigAddress;
386
- exports.newMultisigSignature = newMultisigSignature;
387
- exports.participantsFromMultisigSignature = participantsFromMultisigSignature;
388
338
  //# sourceMappingURL=multisig.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"multisig.js","names":["getAddress","arrayEqual","mergedSubsignatures: MultisigSubsignature[]","msig: MultisigSignature","authAddress: Address | undefined","encodeSignedTransaction","decodeSignedTransaction","Address","newSubsigs: MultisigSubsignature[]","SIGNATURE_BYTE_LENGTH","ALGORAND_ADDRESS_BYTE_LENGTH","ALGORAND_CHECKSUM_BYTE_LENGTH","PUBLIC_KEY_BYTE_LENGTH","hash","multisigAddress: typeof addressFromMultisigPreImgAddrs","signedMsigTxns: Uint8Array[]","decodeMsgpack","multiSignatureCodec"],"sources":["../../../../packages/transact/src/multisig.ts"],"sourcesContent":["import {\n Address,\n ALGORAND_ADDRESS_BYTE_LENGTH,\n ALGORAND_CHECKSUM_BYTE_LENGTH,\n arrayEqual,\n decodeMsgpack,\n getAddress,\n hash,\n PUBLIC_KEY_BYTE_LENGTH,\n SIGNATURE_BYTE_LENGTH,\n} from '@algorandfoundation/algokit-common'\nimport { AddressWithDelegatedLsigSigner, AddressWithTransactionSigner, TransactionSigner } from './signer'\nimport {\n decodeSignedTransaction,\n encodeSignedTransaction,\n MultisigSignature,\n MultisigSubsignature,\n SignedTransaction,\n} from './transactions/signed-transaction'\nimport { multiSignatureCodec } from './transactions/signed-transaction-meta'\nimport { Transaction } from './transactions/transaction'\n\n/**\n * Creates an empty multisignature signature from a list of participant public keys.\n */\nexport function newMultisigSignature(version: number, threshold: number, participants: Uint8Array[]): MultisigSignature {\n if (version === 0) {\n throw new Error('Version cannot be zero')\n }\n if (participants.length === 0) {\n throw new Error('Participants cannot be empty')\n }\n if (threshold === 0 || threshold > participants.length) {\n throw new Error('Threshold must be greater than zero and less than or equal to the number of participants')\n }\n\n return {\n version,\n threshold,\n subsignatures: participants.map((publicKey) => ({ publicKey })),\n }\n}\n\n/**\n * Returns the list of participant public keys from a multisignature signature.\n */\nexport function participantsFromMultisigSignature(multisigSignature: MultisigSignature): Uint8Array[] {\n return multisigSignature.subsignatures.map((subsig) => subsig.publicKey)\n}\n\nconst toPublicKeys = (addrs: Array<string | Address>): Uint8Array[] => addrs.map((addr) => getAddress(addr).publicKey)\n\n/**\n * Returns the address of the multisignature account.\n */\nexport function addressFromMultisigSignature(multisigSignature: MultisigSignature): Address {\n return addressFromMultisigPreImg({\n version: multisigSignature.version,\n threshold: multisigSignature.threshold,\n pks: multisigSignature.subsignatures.map((subsig) => subsig.publicKey),\n })\n}\n\n/**\n * Applies a subsignature for a participant to a multisignature signature, replacing any existing signature.\n *\n * This method applies the signature to ALL instances of the given public key (to support weighted multisig).\n * Since ed25519 signatures are deterministic, there's only one valid signature for a given message and public key.\n */\nexport function applyMultisigSubsignature(\n multisigSignature: MultisigSignature,\n participant: Uint8Array,\n signature: Uint8Array,\n): MultisigSignature {\n let found = false\n const newSubsignatures = multisigSignature.subsignatures.map((subsig) => {\n if (arrayEqual(subsig.publicKey, participant)) {\n found = true\n return { ...subsig, signature }\n }\n return subsig\n })\n\n if (!found) {\n throw new Error('Public key not found in multisig signature')\n }\n\n return {\n ...multisigSignature,\n subsignatures: newSubsignatures,\n }\n}\n\n/**\n * Merges two multisignature signatures, replacing signatures in the first with those from the second where present.\n * For each participant, the resulting signature will be taken from the second multisig if present, otherwise from the first.\n */\nexport function mergeMultisignatures(multisigSignatureA: MultisigSignature, multisigSignatureB: MultisigSignature): MultisigSignature {\n if (multisigSignatureA.version !== multisigSignatureB.version) {\n throw new Error('Cannot merge multisig signatures with different versions')\n }\n if (multisigSignatureA.threshold !== multisigSignatureB.threshold) {\n throw new Error('Cannot merge multisig signatures with different thresholds')\n }\n\n // Check participants match exactly (same public keys in same order)\n const participantsA = participantsFromMultisigSignature(multisigSignatureA)\n const participantsB = participantsFromMultisigSignature(multisigSignatureB)\n const participantsMatch =\n participantsA.length === participantsB.length && participantsA.every((pk, i) => arrayEqual(pk, participantsB[i]))\n if (!participantsMatch) {\n throw new Error('Cannot merge multisig signatures with different participants')\n }\n\n const mergedSubsignatures: MultisigSubsignature[] = multisigSignatureA.subsignatures.map((s1, index) => {\n const s2 = multisigSignatureB.subsignatures[index]\n return {\n publicKey: s1.publicKey,\n signature: s2.signature || s1.signature, // Prefer s2, fall back to s1\n }\n })\n\n return {\n version: multisigSignatureA.version,\n threshold: multisigSignatureA.threshold,\n subsignatures: mergedSubsignatures,\n }\n}\n\n// Convert \"MultisigAddr\" UTF-8 to byte array\nconst MULTISIG_PREIMG2ADDR_PREFIX = new Uint8Array([77, 117, 108, 116, 105, 115, 105, 103, 65, 100, 100, 114])\n\nconst INVALID_MSIG_VERSION_ERROR_MSG = 'invalid multisig version'\nconst INVALID_MSIG_THRESHOLD_ERROR_MSG = 'bad multisig threshold'\nconst INVALID_MSIG_PK_ERROR_MSG = 'bad multisig public key - wrong length'\nconst UNEXPECTED_PK_LEN_ERROR_MSG = 'nacl public key length is not 32 bytes'\n\nexport const MULTISIG_MERGE_LESSTHANTWO_ERROR_MSG = 'Not enough multisig transactions to merge. Need at least two'\nexport const MULTISIG_MERGE_MISMATCH_ERROR_MSG = 'Cannot merge txs. txIDs differ'\nexport const MULTISIG_MERGE_MISMATCH_AUTH_ADDR_MSG = 'Cannot merge txs. Auth addrs differ'\nexport const MULTISIG_MERGE_WRONG_PREIMAGE_ERROR_MSG = 'Cannot merge txs. Multisig preimages differ'\nexport const MULTISIG_MERGE_SIG_MISMATCH_ERROR_MSG = 'Cannot merge txs. subsigs are mismatched.'\nexport const MULTISIG_NO_MUTATE_ERROR_MSG = 'Cannot mutate a multisig field as it would invalidate all existing signatures.'\nexport const MULTISIG_USE_PARTIAL_SIGN_ERROR_MSG = 'Cannot sign a multisig transaction using `signTxn`. Use `partialSignTxn` instead.'\nexport const MULTISIG_SIGNATURE_LENGTH_ERROR_MSG = 'Cannot add multisig signature. Signature is not of the correct length.'\nconst MULTISIG_KEY_NOT_EXIST_ERROR_MSG = 'Key does not exist'\n\n/**\n * creates a raw, multisig transaction blob without any signatures.\n * @param txn - the actual transaction.\n * @param version - multisig version\n * @param threshold - multisig threshold\n * @param pks - ordered list of public keys in this multisig\n * @returns encoded multisig blob\n */\nexport function createMultisigTransaction(txn: Transaction, { version, threshold, addrs }: MultisigMetadata) {\n // construct the appendable multisigned transaction format\n const pks = toPublicKeys(addrs)\n const subsignatures: MultisigSubsignature[] = pks.map((pk) => ({\n publicKey: pk,\n signature: undefined,\n }))\n\n const msig: MultisigSignature = {\n version,\n threshold,\n subsignatures,\n }\n\n // if the address of this multisig is different from the transaction sender,\n // we need to add the auth-addr field\n const msigAddr = addressFromMultisigPreImg({\n version,\n threshold,\n pks,\n })\n let authAddress: Address | undefined\n if (!msigAddr.equals(txn.sender)) {\n authAddress = msigAddr\n }\n\n const signedTxn: SignedTransaction = {\n txn: txn,\n msig: msig,\n authAddress,\n }\n\n return encodeSignedTransaction(signedTxn)\n}\n\ninterface MultisigOptions {\n rawSig: Uint8Array\n myPk: Uint8Array\n}\n\ninterface MultisigMetadataWithPks extends Omit<MultisigMetadata, 'addrs'> {\n pks: Uint8Array[]\n}\n\n/**\n * creates a multisig transaction blob with an included signature.\n * @param txn - the actual transaction to sign.\n * @param rawSig - a Uint8Array raw signature of that transaction\n * @param myPk - a public key that corresponds with rawSig\n * @param version - multisig version\n * @param threshold - multisig threshold\n * @param pks - ordered list of public keys in this multisig\n * @returns encoded multisig blob\n */\nfunction createMultisigTransactionWithSignature(\n txn: Transaction,\n { rawSig, myPk }: MultisigOptions,\n { version, threshold, pks }: MultisigMetadataWithPks,\n): Uint8Array {\n // Create an empty encoded multisig transaction\n const encodedMsig = createMultisigTransaction(txn, {\n version,\n threshold,\n addrs: pks.map((pk) => new Address(pk)),\n })\n // note: this is not signed yet, but will be shortly\n const signedTxn = decodeSignedTransaction(encodedMsig)\n\n let keyExist = false\n\n // append the multisig signature to the corresponding public key in the multisig blob\n const updatedSubsigs = signedTxn.msig!.subsignatures.map((subsig) => {\n if (arrayEqual(subsig.publicKey, myPk)) {\n keyExist = true\n return { ...subsig, signature: rawSig }\n }\n return subsig\n })\n\n if (!keyExist) {\n throw new Error(MULTISIG_KEY_NOT_EXIST_ERROR_MSG)\n }\n\n const updatedSignedTxn: SignedTransaction = {\n ...signedTxn,\n msig: {\n ...signedTxn.msig!,\n subsignatures: updatedSubsigs,\n },\n }\n\n return encodeSignedTransaction(updatedSignedTxn)\n}\n\n/**\n * takes a list of multisig transaction blobs, and merges them.\n * @param multisigTxnBlobs - a list of blobs representing encoded multisig txns\n * @returns typed array msg-pack encoded multisig txn\n */\nexport function mergeMultisigTransactions(multisigTxnBlobs: Uint8Array[]) {\n if (multisigTxnBlobs.length < 2) {\n throw new Error(MULTISIG_MERGE_LESSTHANTWO_ERROR_MSG)\n }\n const refSigTx = decodeSignedTransaction(multisigTxnBlobs[0])\n if (!refSigTx.msig) {\n throw new Error('Invalid multisig transaction, multisig structure missing at index 0')\n }\n const refTxID = refSigTx.txn.txId()\n const refAuthAddr = refSigTx.authAddress\n const refPreImage = {\n version: refSigTx.msig.version,\n threshold: refSigTx.msig.threshold,\n pks: refSigTx.msig.subsignatures.map((subsig) => subsig.publicKey),\n }\n const refMsigAddr = addressFromMultisigPreImg(refPreImage)\n\n const newSubsigs: MultisigSubsignature[] = refSigTx.msig.subsignatures.map((sig) => ({ ...sig }))\n for (let i = 1; i < multisigTxnBlobs.length; i++) {\n const unisig = decodeSignedTransaction(multisigTxnBlobs[i])\n if (!unisig.msig) {\n throw new Error(`Invalid multisig transaction, multisig structure missing at index ${i}`)\n }\n\n if (unisig.txn.txId() !== refTxID) {\n throw new Error(MULTISIG_MERGE_MISMATCH_ERROR_MSG)\n }\n\n const authAddr = unisig.authAddress\n if (refAuthAddr !== authAddr) {\n throw new Error(MULTISIG_MERGE_MISMATCH_AUTH_ADDR_MSG)\n }\n\n // check multisig has same preimage as reference\n if (unisig.msig.subsignatures.length !== refSigTx.msig.subsignatures.length) {\n throw new Error(MULTISIG_MERGE_WRONG_PREIMAGE_ERROR_MSG)\n }\n const preimg: MultisigMetadataWithPks = {\n version: unisig.msig.version,\n threshold: unisig.msig.threshold,\n pks: unisig.msig.subsignatures.map((subsig) => subsig.publicKey),\n }\n const msgigAddr = addressFromMultisigPreImg(preimg)\n if (refMsigAddr.toString() !== msgigAddr.toString()) {\n throw new Error(MULTISIG_MERGE_WRONG_PREIMAGE_ERROR_MSG)\n }\n\n // now, we can merge\n unisig.msig.subsignatures.forEach((uniSubsig, index) => {\n if (!uniSubsig.signature) return\n const current = newSubsigs[index]\n if (current.signature && !arrayEqual(uniSubsig.signature, current.signature)) {\n // mismatch\n throw new Error(MULTISIG_MERGE_SIG_MISMATCH_ERROR_MSG)\n }\n current.signature = uniSubsig.signature\n })\n }\n\n const msig: MultisigSignature = {\n version: refSigTx.msig.version,\n threshold: refSigTx.msig.threshold,\n subsignatures: newSubsigs,\n }\n\n const signedTxn: SignedTransaction = {\n txn: refSigTx.txn,\n msig: msig,\n authAddress: refAuthAddr,\n }\n\n return encodeSignedTransaction(signedTxn)\n}\n\n/**\n * Partially signs this transaction with an external raw multisig signature and returns\n * a partially-signed multisig transaction, encoded with msgpack as a typed array.\n * @param transaction - The transaction to sign\n * @param metadata - multisig metadata\n * @param signerAddr - address of the signer\n * @param signature - raw multisig signature\n * @returns an encoded, partially signed multisig transaction.\n */\nfunction partialSignWithMultisigSignature(\n transaction: Transaction,\n metadata: MultisigMetadataWithPks,\n signerAddr: string | Address,\n signature: Uint8Array,\n) {\n if (signature.length != SIGNATURE_BYTE_LENGTH) {\n throw new Error(MULTISIG_SIGNATURE_LENGTH_ERROR_MSG)\n }\n const signerAddressObj = typeof signerAddr === 'string' ? Address.fromString(signerAddr) : signerAddr\n return createMultisigTransactionWithSignature(\n transaction,\n {\n rawSig: signature,\n myPk: signerAddressObj.publicKey,\n },\n metadata,\n )\n}\n\n/**\n * Takes a multisig transaction blob, and appends a given raw signature to it.\n * This makes it possible to compile a multisig signature using only raw signatures from external methods.\n * @param multisigTxnBlob - an encoded multisig txn. Supports non-payment txn types.\n * @param version - multisig version\n * @param threshold - multisig threshold\n * @param addrs - a list of Algorand addresses representing possible signers for this multisig. Order is important.\n * @param signerAddr - address of the signer\n * @param signature - raw multisig signature\n * @returns object containing txID, and blob representing encoded multisig txn\n */\nexport function appendSignRawMultisigSignature(\n multisigTxnBlob: Uint8Array,\n { version, threshold, addrs }: MultisigMetadata,\n signerAddr: string | Address,\n signature: Uint8Array,\n) {\n const pks = toPublicKeys(addrs)\n // obtain underlying txn, sign it, and merge it\n const multisigTxObj = decodeSignedTransaction(multisigTxnBlob)\n const partialSignedBlob = partialSignWithMultisigSignature(multisigTxObj.txn, { version, threshold, pks }, signerAddr, signature)\n return {\n txID: multisigTxObj.txn.txId(),\n blob: mergeMultisigTransactions([multisigTxnBlob, partialSignedBlob]),\n }\n}\n\n/**\n * Takes multisig parameters and returns a 32 byte typed array public key,\n * representing an address that identifies the \"exact group, version, and public keys\" that are required for signing.\n * Hash(\"MultisigAddr\" || version uint8 || threshold uint8 || PK1 || PK2 || ...)\n * Encoding this output yields a human readable address.\n * @param version - multisig version\n * @param threshold - multisig threshold\n * @param pks - array of typed array public keys\n */\nexport function addressFromMultisigPreImg({\n version,\n threshold,\n pks,\n}: Omit<MultisigMetadata, 'addrs'> & {\n pks: Uint8Array[]\n}): Address {\n if (version > 255 || version < 0) {\n // ^ a tad redundant, but in case in the future version != 1, still check for uint8\n throw new Error(`${INVALID_MSIG_VERSION_ERROR_MSG}: ${version}`)\n }\n if (threshold === 0 || pks.length === 0 || threshold > pks.length || threshold > 255) {\n throw new Error(INVALID_MSIG_THRESHOLD_ERROR_MSG)\n }\n const pkLen = ALGORAND_ADDRESS_BYTE_LENGTH - ALGORAND_CHECKSUM_BYTE_LENGTH\n if (pkLen !== PUBLIC_KEY_BYTE_LENGTH) {\n throw new Error(UNEXPECTED_PK_LEN_ERROR_MSG)\n }\n const merged = new Uint8Array(MULTISIG_PREIMG2ADDR_PREFIX.length + 2 + pkLen * pks.length)\n merged.set(MULTISIG_PREIMG2ADDR_PREFIX, 0)\n merged.set([version], MULTISIG_PREIMG2ADDR_PREFIX.length)\n merged.set([threshold], MULTISIG_PREIMG2ADDR_PREFIX.length + 1)\n for (let i = 0; i < pks.length; i++) {\n if (pks[i].length !== pkLen) {\n throw new Error(INVALID_MSIG_PK_ERROR_MSG)\n }\n merged.set(pks[i], MULTISIG_PREIMG2ADDR_PREFIX.length + 2 + i * pkLen)\n }\n return new Address(Uint8Array.from(hash(merged)))\n}\n\n/**\n * Takes multisig parameters and returns a human readable Algorand address.\n * This is equivalent to fromMultisigPreImg, but interfaces with encoded addresses.\n * @param version - multisig version\n * @param threshold - multisig threshold\n * @param addrs - array of encoded addresses\n */\nexport function addressFromMultisigPreImgAddrs({ version, threshold, addrs }: MultisigMetadata): Address {\n return addressFromMultisigPreImg({\n version,\n threshold,\n pks: toPublicKeys(addrs),\n })\n}\n\n/**\n * Takes multisig metadata (preimage) and returns the corresponding human readable Algorand address.\n * @param version - multisig version\n * @param threshold - multisig threshold\n * @param addrs - list of Algorand addresses\n */\nexport const multisigAddress: typeof addressFromMultisigPreImgAddrs = addressFromMultisigPreImgAddrs\n\nexport interface MultisigMetadata {\n /**\n * Multisig version\n */\n version: number\n\n /**\n * Multisig threshold value. Authorization requires a subset of signatures,\n * equal to or greater than the threshold value.\n */\n threshold: number\n\n /**\n * A list of Algorand addresses representing possible signers for this multisig. Order is important.\n */\n addrs: Array<Address>\n}\n\n/** Account wrapper that supports partial or full multisig signing. */\nexport class MultisigAccount implements AddressWithTransactionSigner {\n _params: MultisigMetadata\n _subSigners: (AddressWithTransactionSigner & AddressWithDelegatedLsigSigner)[]\n _addr: Address\n _signer: TransactionSigner\n\n /** The parameters for the multisig account */\n get params(): Readonly<MultisigMetadata> {\n return this._params\n }\n\n /** The list of accounts that are present to sign transactions or lsigs */\n get subSigners() {\n return this._subSigners\n }\n\n /** The address of the multisig account */\n get addr(): Readonly<Address> {\n return this._addr\n }\n\n /** The transaction signer for the multisig account */\n get signer(): TransactionSigner {\n return this._signer\n }\n\n constructor(multisigParams: MultisigMetadata, subSigners: (AddressWithTransactionSigner & AddressWithDelegatedLsigSigner)[]) {\n this._params = multisigParams\n this._subSigners = subSigners\n this._addr = multisigAddress(multisigParams)\n this._signer = async (txns: Transaction[], indexesToSign: number[]): Promise<Uint8Array[]> => {\n const txnsToSign = txns.filter((_, index) => indexesToSign.includes(index))\n const signedMsigTxns: Uint8Array[] = []\n\n for (const txn of txnsToSign) {\n let signedMsigTxn = createMultisigTransaction(txn, this._params)\n\n for (const subSigner of this.subSigners) {\n const stxn = (await subSigner.signer([txn], [0]))[0]\n const sig = decodeSignedTransaction(stxn).sig\n\n if (!sig) {\n throw new Error(\n `Signer for address ${subSigner.addr.toString()} did not produce a valid signature when signing ${txn.txId()} for multisig account ${this._addr.toString()}`,\n )\n }\n\n signedMsigTxn = appendSignRawMultisigSignature(signedMsigTxn, this._params, subSigner.addr, sig).blob\n }\n\n signedMsigTxns.push(signedMsigTxn)\n }\n\n return signedMsigTxns\n }\n }\n}\n/**\n * Decodes MsgPack bytes into a multi signature.\n *\n * @param encodedMultiSignature - The MsgPack encoded multi signature\n * @returns The decoded MultisigSignature or an error if decoding fails.\n */\nexport function decodeMultiSignature(encodedMultiSignature: Uint8Array): MultisigSignature {\n const decodedData = decodeMsgpack(encodedMultiSignature)\n return multiSignatureCodec.decode(decodedData, 'msgpack')\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"multisig.js","names":["getAddress","arrayEqual","msig: MultisigSignature","authAddress: Address | undefined","Address","newSubsigs: MultisigSubsignature[]","SIGNATURE_BYTE_LENGTH","ALGORAND_ADDRESS_BYTE_LENGTH","ALGORAND_CHECKSUM_BYTE_LENGTH","PUBLIC_KEY_BYTE_LENGTH","hash","multisigAddress: typeof addressFromMultisigPreImgAddrs","signedMsigTxns: SignedTransaction[]","decodeSignedTransaction","encodeSignedTransaction","subsignatures: MultisigSubsignature[]"],"sources":["../../../../packages/transact/src/multisig.ts"],"sourcesContent":["import {\n Address,\n ALGORAND_ADDRESS_BYTE_LENGTH,\n ALGORAND_CHECKSUM_BYTE_LENGTH,\n arrayEqual,\n getAddress,\n hash,\n PUBLIC_KEY_BYTE_LENGTH,\n SIGNATURE_BYTE_LENGTH,\n} from '@algorandfoundation/algokit-common'\nimport { AddressWithDelegatedLsigSigner, AddressWithTransactionSigner, TransactionSigner } from './signer'\nimport {\n decodeSignedTransaction,\n encodeSignedTransaction,\n MultisigSignature,\n MultisigSubsignature,\n SignedTransaction,\n} from './transactions/signed-transaction'\nimport { Transaction } from './transactions/transaction'\n\nconst toPublicKeys = (addrs: Array<string | Address>): Uint8Array[] => addrs.map((addr) => getAddress(addr).publicKey)\n\n/**\n * Applies a subsignature for a participant to a multisignature signature, replacing any existing signature.\n *\n * This method applies the signature to ALL instances of the given public key (to support weighted multisig).\n * Since ed25519 signatures are deterministic, there's only one valid signature for a given message and public key.\n */\nfunction applyMultisigSubsignature(\n multisigSignature: MultisigSignature,\n participant: Uint8Array,\n signature: Uint8Array,\n): MultisigSignature {\n let found = false\n const newSubsignatures = multisigSignature.subsigs.map((subsig) => {\n if (arrayEqual(subsig.publicKey, participant)) {\n found = true\n return { ...subsig, sig: signature } satisfies MultisigSubsignature\n }\n return subsig\n })\n\n if (!found) {\n throw new Error('Public key not found in multisig signature')\n }\n\n return {\n ...multisigSignature,\n subsigs: newSubsignatures,\n }\n}\n\n// Convert \"MultisigAddr\" UTF-8 to byte array\nconst MULTISIG_PREIMG2ADDR_PREFIX = new Uint8Array([77, 117, 108, 116, 105, 115, 105, 103, 65, 100, 100, 114])\n\nconst INVALID_MSIG_VERSION_ERROR_MSG = 'invalid multisig version'\nconst INVALID_MSIG_THRESHOLD_ERROR_MSG = 'bad multisig threshold'\nconst INVALID_MSIG_PK_ERROR_MSG = 'bad multisig public key - wrong length'\nconst UNEXPECTED_PK_LEN_ERROR_MSG = 'nacl public key length is not 32 bytes'\n\nconst MULTISIG_MERGE_LESSTHANTWO_ERROR_MSG = 'Not enough multisig transactions to merge. Need at least two'\nconst MULTISIG_MERGE_MISMATCH_ERROR_MSG = 'Cannot merge txs. txIDs differ'\nconst MULTISIG_MERGE_MISMATCH_AUTH_ADDR_MSG = 'Cannot merge txs. Auth addrs differ'\nconst MULTISIG_MERGE_WRONG_PREIMAGE_ERROR_MSG = 'Cannot merge txs. Multisig preimages differ'\nconst MULTISIG_MERGE_SIG_MISMATCH_ERROR_MSG = 'Cannot merge txs. subsigs are mismatched.'\nconst MULTISIG_SIGNATURE_LENGTH_ERROR_MSG = 'Cannot add multisig signature. Signature is not of the correct length.'\nconst MULTISIG_KEY_NOT_EXIST_ERROR_MSG = 'Key does not exist'\n\n/**\n * creates a raw, multisig transaction blob without any signatures.\n * @param txn - the actual transaction.\n * @param version - multisig version\n * @param threshold - multisig threshold\n * @param pks - ordered list of public keys in this multisig\n * @returns encoded multisig blob\n */\nfunction createMultisigTransaction(txn: Transaction, { version, threshold, addrs }: MultisigMetadata) {\n // construct the appendable multisigned transaction format\n const pks = toPublicKeys(addrs)\n const subsignatures = pks.map(\n (pk) =>\n ({\n publicKey: pk,\n sig: undefined,\n }) satisfies MultisigSubsignature,\n )\n\n const msig: MultisigSignature = {\n version,\n threshold,\n subsigs: subsignatures,\n }\n\n // if the address of this multisig is different from the transaction sender,\n // we need to add the auth-addr field\n const msigAddr = addressFromMultisigPreImg({\n version,\n threshold,\n publicKeys: pks,\n })\n let authAddress: Address | undefined\n if (!msigAddr.equals(txn.sender)) {\n authAddress = msigAddr\n }\n\n const signedTxn: SignedTransaction = {\n txn: txn,\n msig: msig,\n authAddress,\n }\n\n return signedTxn\n}\n\ninterface MultisigOptions {\n rawSig: Uint8Array\n myPk: Uint8Array\n}\n\ninterface MultisigMetadataWithPublicKeys extends Omit<MultisigMetadata, 'addrs'> {\n publicKeys: Uint8Array[]\n}\n\n/**\n * creates a multisig transaction blob with an included signature.\n * @param txn - the actual transaction to sign.\n * @param rawSig - a Uint8Array raw signature of that transaction\n * @param myPk - a public key that corresponds with rawSig\n * @param version - multisig version\n * @param threshold - multisig threshold\n * @param pks - ordered list of public keys in this multisig\n * @returns encoded multisig blob\n */\nfunction createMultisigTransactionWithSignature(\n txn: Transaction,\n { rawSig, myPk }: MultisigOptions,\n { version, threshold, publicKeys }: MultisigMetadataWithPublicKeys,\n): SignedTransaction {\n // Create an empty encoded multisig transaction\n const signedTxn = createMultisigTransaction(txn, {\n version,\n threshold,\n addrs: publicKeys.map((pk) => new Address(pk)),\n })\n\n let keyExist = false\n\n // append the multisig signature to the corresponding public key in the multisig blob\n const updatedSubsigs = signedTxn.msig!.subsigs.map((subsig) => {\n if (arrayEqual(subsig.publicKey, myPk)) {\n keyExist = true\n return { ...subsig, sig: rawSig }\n }\n return subsig\n })\n\n if (!keyExist) {\n throw new Error(MULTISIG_KEY_NOT_EXIST_ERROR_MSG)\n }\n\n const updatedSignedTxn: SignedTransaction = {\n ...signedTxn,\n msig: {\n ...signedTxn.msig!,\n subsigs: updatedSubsigs,\n },\n }\n\n return updatedSignedTxn\n}\n\n/**\n * takes a list of multisig transaction blobs, and merges them.\n * @param multisigTxnBlobs - a list of blobs representing encoded multisig txns\n * @returns typed array msg-pack encoded multisig txn\n */\nfunction mergeMultisigTransactions(multisigTxnBlobs: SignedTransaction[]): SignedTransaction {\n if (multisigTxnBlobs.length < 2) {\n throw new Error(MULTISIG_MERGE_LESSTHANTWO_ERROR_MSG)\n }\n const refSigTx = multisigTxnBlobs[0]\n if (!refSigTx.msig) {\n throw new Error('Invalid multisig transaction, multisig structure missing at index 0')\n }\n const refTxID = refSigTx.txn.txId()\n const refAuthAddr = refSigTx.authAddress\n const refPreImage = {\n version: refSigTx.msig.version,\n threshold: refSigTx.msig.threshold,\n publicKeys: refSigTx.msig.subsigs.map((subsig) => subsig.publicKey),\n }\n const refMsigAddr = addressFromMultisigPreImg(refPreImage)\n\n const newSubsigs: MultisigSubsignature[] = refSigTx.msig.subsigs.map((sig) => ({ ...sig }))\n for (let i = 1; i < multisigTxnBlobs.length; i++) {\n const unisig = multisigTxnBlobs[i]\n if (!unisig.msig) {\n throw new Error(`Invalid multisig transaction, multisig structure missing at index ${i}`)\n }\n\n if (unisig.txn.txId() !== refTxID) {\n throw new Error(MULTISIG_MERGE_MISMATCH_ERROR_MSG)\n }\n\n const authAddr = unisig.authAddress\n if (refAuthAddr !== authAddr) {\n throw new Error(MULTISIG_MERGE_MISMATCH_AUTH_ADDR_MSG)\n }\n\n // check multisig has same preimage as reference\n if (unisig.msig.subsigs.length !== refSigTx.msig.subsigs.length) {\n throw new Error(MULTISIG_MERGE_WRONG_PREIMAGE_ERROR_MSG)\n }\n const preimg: MultisigMetadataWithPublicKeys = {\n version: unisig.msig.version,\n threshold: unisig.msig.threshold,\n publicKeys: unisig.msig.subsigs.map((subsig) => subsig.publicKey),\n }\n const msgigAddr = addressFromMultisigPreImg(preimg)\n if (refMsigAddr.toString() !== msgigAddr.toString()) {\n throw new Error(MULTISIG_MERGE_WRONG_PREIMAGE_ERROR_MSG)\n }\n\n // now, we can merge\n unisig.msig.subsigs.forEach((uniSubsig, index) => {\n if (!uniSubsig.sig) return\n const current = newSubsigs[index]\n if (current.sig && !arrayEqual(uniSubsig.sig, current.sig)) {\n // mismatch\n throw new Error(MULTISIG_MERGE_SIG_MISMATCH_ERROR_MSG)\n }\n current.sig = uniSubsig.sig\n })\n }\n\n const msig: MultisigSignature = {\n version: refSigTx.msig.version,\n threshold: refSigTx.msig.threshold,\n subsigs: newSubsigs,\n }\n\n const signedTxn: SignedTransaction = {\n txn: refSigTx.txn,\n msig: msig,\n authAddress: refAuthAddr,\n }\n\n return signedTxn\n}\n\n/**\n * Partially signs this transaction with an external raw multisig signature and returns\n * a partially-signed multisig transaction, encoded with msgpack as a typed array.\n * @param transaction - The transaction to sign\n * @param metadata - multisig metadata\n * @param signerAddr - address of the signer\n * @param signature - raw multisig signature\n * @returns an encoded, partially signed multisig transaction.\n */\nfunction partialSignWithMultisigSignature(\n transaction: Transaction,\n metadata: MultisigMetadataWithPublicKeys,\n signerAddr: string | Address,\n signature: Uint8Array,\n) {\n if (signature.length != SIGNATURE_BYTE_LENGTH) {\n throw new Error(MULTISIG_SIGNATURE_LENGTH_ERROR_MSG)\n }\n const signerAddressObj = typeof signerAddr === 'string' ? Address.fromString(signerAddr) : signerAddr\n return createMultisigTransactionWithSignature(\n transaction,\n {\n rawSig: signature,\n myPk: signerAddressObj.publicKey,\n },\n metadata,\n )\n}\n\n/**\n * Takes a multisig transaction blob, and appends a given raw signature to it.\n * This makes it possible to compile a multisig signature using only raw signatures from external methods.\n * @param multisigTxnBlob - an encoded multisig txn. Supports non-payment txn types.\n * @param version - multisig version\n * @param threshold - multisig threshold\n * @param addrs - a list of Algorand addresses representing possible signers for this multisig. Order is important.\n * @param signerAddr - address of the signer\n * @param signature - raw multisig signature\n * @returns object containing txID, and blob representing encoded multisig txn\n */\nfunction appendSignRawMultisigSignature(\n multisigTxn: SignedTransaction,\n { version, threshold, addrs }: MultisigMetadata,\n signerAddr: string | Address,\n signature: Uint8Array,\n): SignedTransaction {\n const publicKeys = toPublicKeys(addrs)\n // obtain underlying txn, sign it, and merge it\n const partialSigned = partialSignWithMultisigSignature(multisigTxn.txn, { version, threshold, publicKeys }, signerAddr, signature)\n return mergeMultisigTransactions([multisigTxn, partialSigned])\n}\n\n/**\n * Takes multisig parameters and returns a 32 byte typed array public key,\n * representing an address that identifies the \"exact group, version, and public keys\" that are required for signing.\n * Hash(\"MultisigAddr\" || version uint8 || threshold uint8 || PK1 || PK2 || ...)\n * Encoding this output yields a human readable address.\n * @param version - multisig version\n * @param threshold - multisig threshold\n * @param pks - array of typed array public keys\n */\nfunction addressFromMultisigPreImg({\n version,\n threshold,\n publicKeys,\n}: Omit<MultisigMetadata, 'addrs'> & {\n publicKeys: Uint8Array[]\n}): Address {\n if (version > 255 || version < 0) {\n // ^ a tad redundant, but in case in the future version != 1, still check for uint8\n throw new Error(`${INVALID_MSIG_VERSION_ERROR_MSG}: ${version}`)\n }\n if (threshold === 0 || publicKeys.length === 0 || threshold > publicKeys.length || threshold > 255) {\n throw new Error(INVALID_MSIG_THRESHOLD_ERROR_MSG)\n }\n const pkLen = ALGORAND_ADDRESS_BYTE_LENGTH - ALGORAND_CHECKSUM_BYTE_LENGTH\n if (pkLen !== PUBLIC_KEY_BYTE_LENGTH) {\n throw new Error(UNEXPECTED_PK_LEN_ERROR_MSG)\n }\n const merged = new Uint8Array(MULTISIG_PREIMG2ADDR_PREFIX.length + 2 + pkLen * publicKeys.length)\n merged.set(MULTISIG_PREIMG2ADDR_PREFIX, 0)\n merged.set([version], MULTISIG_PREIMG2ADDR_PREFIX.length)\n merged.set([threshold], MULTISIG_PREIMG2ADDR_PREFIX.length + 1)\n for (let i = 0; i < publicKeys.length; i++) {\n if (publicKeys[i].length !== pkLen) {\n throw new Error(INVALID_MSIG_PK_ERROR_MSG)\n }\n merged.set(publicKeys[i], MULTISIG_PREIMG2ADDR_PREFIX.length + 2 + i * pkLen)\n }\n return new Address(Uint8Array.from(hash(merged)))\n}\n\n/**\n * Takes multisig parameters and returns a human readable Algorand address.\n * This is equivalent to fromMultisigPreImg, but interfaces with encoded addresses.\n * @param version - multisig version\n * @param threshold - multisig threshold\n * @param addrs - array of encoded addresses\n */\nfunction addressFromMultisigPreImgAddrs({ version, threshold, addrs }: MultisigMetadata): Address {\n return addressFromMultisigPreImg({\n version,\n threshold,\n publicKeys: toPublicKeys(addrs),\n })\n}\n\n/**\n * Takes multisig metadata (preimage) and returns the corresponding human readable Algorand address.\n * @param version - multisig version\n * @param threshold - multisig threshold\n * @param addrs - list of Algorand addresses\n */\nconst multisigAddress: typeof addressFromMultisigPreImgAddrs = addressFromMultisigPreImgAddrs\n\nexport interface MultisigMetadata {\n /**\n * Multisig version\n */\n version: number\n\n /**\n * Multisig threshold value. Authorization requires a subset of signatures,\n * equal to or greater than the threshold value.\n */\n threshold: number\n\n /**\n * A list of Algorand addresses representing possible signers for this multisig. Order is important.\n */\n addrs: Array<Address>\n}\n\n/** Account wrapper that supports partial or full multisig signing. */\nexport class MultisigAccount implements AddressWithTransactionSigner {\n _params: MultisigMetadata\n _subSigners: (AddressWithTransactionSigner & AddressWithDelegatedLsigSigner)[]\n _addr: Address\n _signer: TransactionSigner\n\n /** The parameters for the multisig account */\n get params(): Readonly<MultisigMetadata> {\n return this._params\n }\n\n /** The list of accounts that are present to sign transactions or lsigs */\n get subSigners() {\n return this._subSigners\n }\n\n /** The address of the multisig account */\n get addr(): Readonly<Address> {\n return this._addr\n }\n\n /** The transaction signer for the multisig account */\n get signer(): TransactionSigner {\n return this._signer\n }\n\n static fromSignature(signature: MultisigSignature): MultisigAccount {\n const params: MultisigMetadata = {\n version: signature.version,\n threshold: signature.threshold,\n addrs: signature.subsigs.map((subsig) => new Address(subsig.publicKey)),\n }\n\n return new MultisigAccount(params, [])\n }\n\n constructor(multisigParams: MultisigMetadata, subSigners: (AddressWithTransactionSigner & AddressWithDelegatedLsigSigner)[]) {\n this._params = multisigParams\n this._subSigners = subSigners\n this._addr = multisigAddress(multisigParams)\n this._signer = async (txns: Transaction[], indexesToSign: number[]): Promise<Uint8Array[]> => {\n const txnsToSign = txns.filter((_, index) => indexesToSign.includes(index))\n const signedMsigTxns: SignedTransaction[] = []\n\n for (const txn of txnsToSign) {\n let signedMsigTxn = createMultisigTransaction(txn, this._params)\n\n for (const subSigner of this.subSigners) {\n const stxn = (await subSigner.signer([txn], [0]))[0]\n const sig = decodeSignedTransaction(stxn).sig\n\n if (!sig) {\n throw new Error(\n `Signer for address ${subSigner.addr.toString()} did not produce a valid signature when signing ${txn.txId()} for multisig account ${this._addr.toString()}`,\n )\n }\n\n signedMsigTxn = appendSignRawMultisigSignature(signedMsigTxn, this._params, subSigner.addr, sig)\n }\n\n signedMsigTxns.push(signedMsigTxn)\n }\n\n return signedMsigTxns.map(encodeSignedTransaction)\n }\n }\n\n createMultisigTransaction(txn: Transaction): SignedTransaction {\n return createMultisigTransaction(txn, this._params)\n }\n\n createMultisigSignature(): MultisigSignature {\n const pks = toPublicKeys(this._params.addrs)\n const subsignatures: MultisigSubsignature[] = pks.map((pk) => ({\n publicKey: pk,\n signature: undefined,\n }))\n\n return {\n version: this._params.version,\n threshold: this._params.threshold,\n subsigs: subsignatures,\n }\n }\n\n applySignatureToTxn(txn: SignedTransaction, pubkey: Uint8Array, signature: Uint8Array): void {\n if (!txn.msig) {\n const createdTxn = this.createMultisigTransaction(txn.txn)\n txn.msig = createdTxn.msig\n }\n\n txn.msig = applyMultisigSubsignature(txn.msig!, pubkey, signature)\n }\n\n applySignature(msigSignature: MultisigSignature, pubkey: Uint8Array, signature: Uint8Array): MultisigSignature {\n if (msigSignature.version !== this._params.version || msigSignature.threshold !== this._params.threshold) {\n const thisParams = {\n version: this._params.version,\n threshold: this._params.threshold,\n participants: this._params.addrs.map((addr) => addr.toString()),\n }\n\n const givenParams = {\n version: msigSignature.version,\n threshold: msigSignature.threshold,\n participants: msigSignature.subsigs.map((subsig) => new Address(subsig.publicKey).toString()),\n }\n\n throw new Error(\n `Multisig signature parameters do not match expected multisig parameters. Multisig params: ${JSON.stringify(thisParams)}, signature: ${JSON.stringify(givenParams)}`,\n )\n }\n\n return applyMultisigSubsignature(msigSignature, pubkey, signature)\n }\n}\n"],"mappings":"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"}