wowok 2.1.10 → 2.1.13

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 (896) hide show
  1. package/dist/cjs/bcs/bcs.d.ts +199 -199
  2. package/dist/cjs/bcs/bcs.js +273 -318
  3. package/dist/cjs/bcs/bcs.js.map +1 -0
  4. package/dist/cjs/bcs/effects.d.ts +109 -109
  5. package/dist/cjs/bcs/effects.js +205 -230
  6. package/dist/cjs/bcs/effects.js.map +1 -0
  7. package/dist/cjs/bcs/index.d.ts +1 -2584
  8. package/dist/cjs/bcs/index.js +61 -76
  9. package/dist/cjs/bcs/index.js.map +1 -0
  10. package/dist/cjs/bcs/pure.js +38 -58
  11. package/dist/cjs/bcs/pure.js.map +1 -0
  12. package/dist/cjs/bcs/type-tag-serializer.js +102 -114
  13. package/dist/cjs/bcs/type-tag-serializer.js.map +1 -0
  14. package/dist/cjs/bcs/types.js +6 -23
  15. package/dist/cjs/bcs/types.js.map +1 -0
  16. package/dist/cjs/client/index.js +17 -33
  17. package/dist/cjs/client/index.js.map +1 -0
  18. package/dist/cjs/client/network.js +25 -40
  19. package/dist/cjs/client/network.js.map +1 -0
  20. package/dist/cjs/cryptography/index.js +29 -45
  21. package/dist/cjs/cryptography/index.js.map +1 -0
  22. package/dist/cjs/cryptography/intent.d.ts +1 -1
  23. package/dist/cjs/cryptography/intent.js +20 -31
  24. package/dist/cjs/cryptography/intent.js.map +1 -0
  25. package/dist/cjs/cryptography/keypair.js +102 -116
  26. package/dist/cjs/cryptography/keypair.js.map +1 -0
  27. package/dist/cjs/cryptography/mnemonics.js +43 -41
  28. package/dist/cjs/cryptography/mnemonics.js.map +1 -0
  29. package/dist/cjs/cryptography/publickey.js +112 -134
  30. package/dist/cjs/cryptography/publickey.js.map +1 -0
  31. package/dist/cjs/cryptography/signature-scheme.js +24 -43
  32. package/dist/cjs/cryptography/signature-scheme.js.map +1 -0
  33. package/dist/cjs/cryptography/signature.d.ts +2 -24
  34. package/dist/cjs/cryptography/signature.js +50 -67
  35. package/dist/cjs/cryptography/signature.js.map +1 -0
  36. package/dist/cjs/experimental/cache.js +65 -0
  37. package/dist/cjs/experimental/cache.js.map +1 -0
  38. package/dist/cjs/experimental/client.js +27 -0
  39. package/dist/cjs/experimental/client.js.map +1 -0
  40. package/dist/cjs/experimental/core.js +89 -0
  41. package/dist/cjs/experimental/core.js.map +1 -0
  42. package/dist/cjs/experimental/errors.js +32 -0
  43. package/dist/cjs/experimental/errors.js.map +1 -0
  44. package/dist/cjs/experimental/index.js +15 -0
  45. package/dist/cjs/experimental/index.js.map +1 -0
  46. package/dist/cjs/experimental/persistent-storage.js +343 -0
  47. package/dist/cjs/experimental/persistent-storage.js.map +1 -0
  48. package/dist/cjs/experimental/persistent-storage.test.js +200 -0
  49. package/dist/cjs/experimental/persistent-storage.test.js.map +1 -0
  50. package/dist/cjs/experimental/transports/utils.js +104 -0
  51. package/dist/cjs/experimental/transports/utils.js.map +1 -0
  52. package/dist/cjs/experimental/types.js +6 -0
  53. package/dist/cjs/experimental/types.js.map +1 -0
  54. package/dist/cjs/faucet/faucet.js +106 -124
  55. package/dist/cjs/faucet/faucet.js.map +1 -0
  56. package/dist/cjs/faucet/index.js +12 -28
  57. package/dist/cjs/faucet/index.js.map +1 -0
  58. package/dist/cjs/grpc/client.js +47 -62
  59. package/dist/cjs/grpc/client.js.map +1 -0
  60. package/dist/cjs/grpc/core.js +580 -617
  61. package/dist/cjs/grpc/core.js.map +1 -0
  62. package/dist/cjs/grpc/index.js +9 -25
  63. package/dist/cjs/grpc/index.js.map +1 -0
  64. package/dist/cjs/grpc/proto/google/protobuf/any.js +168 -135
  65. package/dist/cjs/grpc/proto/google/protobuf/any.js.map +1 -0
  66. package/dist/cjs/grpc/proto/google/protobuf/duration.js +105 -90
  67. package/dist/cjs/grpc/proto/google/protobuf/duration.js.map +1 -0
  68. package/dist/cjs/grpc/proto/google/protobuf/empty.js +50 -28
  69. package/dist/cjs/grpc/proto/google/protobuf/empty.js.map +1 -0
  70. package/dist/cjs/grpc/proto/google/protobuf/field_mask.js +96 -75
  71. package/dist/cjs/grpc/proto/google/protobuf/field_mask.js.map +1 -0
  72. package/dist/cjs/grpc/proto/google/protobuf/struct.js +266 -215
  73. package/dist/cjs/grpc/proto/google/protobuf/struct.js.map +1 -0
  74. package/dist/cjs/grpc/proto/google/protobuf/timestamp.js +150 -131
  75. package/dist/cjs/grpc/proto/google/protobuf/timestamp.js.map +1 -0
  76. package/dist/cjs/grpc/proto/google/rpc/error_details.js +331 -302
  77. package/dist/cjs/grpc/proto/google/rpc/error_details.js.map +1 -0
  78. package/dist/cjs/grpc/proto/google/rpc/status.js +50 -50
  79. package/dist/cjs/grpc/proto/google/rpc/status.js.map +1 -0
  80. package/dist/cjs/grpc/proto/sui/rpc/v2/argument.js +84 -68
  81. package/dist/cjs/grpc/proto/sui/rpc/v2/argument.js.map +1 -0
  82. package/dist/cjs/grpc/proto/sui/rpc/v2/balance_change.js +45 -50
  83. package/dist/cjs/grpc/proto/sui/rpc/v2/balance_change.js.map +1 -0
  84. package/dist/cjs/grpc/proto/sui/rpc/v2/bcs.js +38 -43
  85. package/dist/cjs/grpc/proto/sui/rpc/v2/bcs.js.map +1 -0
  86. package/dist/cjs/grpc/proto/sui/rpc/v2/checkpoint.js +70 -75
  87. package/dist/cjs/grpc/proto/sui/rpc/v2/checkpoint.js.map +1 -0
  88. package/dist/cjs/grpc/proto/sui/rpc/v2/checkpoint_contents.js +79 -81
  89. package/dist/cjs/grpc/proto/sui/rpc/v2/checkpoint_contents.js.map +1 -0
  90. package/dist/cjs/grpc/proto/sui/rpc/v2/checkpoint_summary.js +183 -166
  91. package/dist/cjs/grpc/proto/sui/rpc/v2/checkpoint_summary.js.map +1 -0
  92. package/dist/cjs/grpc/proto/sui/rpc/v2/effects.js +369 -296
  93. package/dist/cjs/grpc/proto/sui/rpc/v2/effects.js.map +1 -0
  94. package/dist/cjs/grpc/proto/sui/rpc/v2/epoch.js +80 -85
  95. package/dist/cjs/grpc/proto/sui/rpc/v2/epoch.js.map +1 -0
  96. package/dist/cjs/grpc/proto/sui/rpc/v2/error_reason.js +31 -28
  97. package/dist/cjs/grpc/proto/sui/rpc/v2/error_reason.js.map +1 -0
  98. package/dist/cjs/grpc/proto/sui/rpc/v2/event.js +81 -83
  99. package/dist/cjs/grpc/proto/sui/rpc/v2/event.js.map +1 -0
  100. package/dist/cjs/grpc/proto/sui/rpc/v2/executed_transaction.js +80 -85
  101. package/dist/cjs/grpc/proto/sui/rpc/v2/executed_transaction.js.map +1 -0
  102. package/dist/cjs/grpc/proto/sui/rpc/v2/execution_status.js +876 -506
  103. package/dist/cjs/grpc/proto/sui/rpc/v2/execution_status.js.map +1 -0
  104. package/dist/cjs/grpc/proto/sui/rpc/v2/gas_cost_summary.js +56 -61
  105. package/dist/cjs/grpc/proto/sui/rpc/v2/gas_cost_summary.js.map +1 -0
  106. package/dist/cjs/grpc/proto/sui/rpc/v2/input.js +103 -83
  107. package/dist/cjs/grpc/proto/sui/rpc/v2/input.js.map +1 -0
  108. package/dist/cjs/grpc/proto/sui/rpc/v2/jwk.js +76 -78
  109. package/dist/cjs/grpc/proto/sui/rpc/v2/jwk.js.map +1 -0
  110. package/dist/cjs/grpc/proto/sui/rpc/v2/ledger_service.client.js +69 -119
  111. package/dist/cjs/grpc/proto/sui/rpc/v2/ledger_service.client.js.map +1 -0
  112. package/dist/cjs/grpc/proto/sui/rpc/v2/ledger_service.js +392 -350
  113. package/dist/cjs/grpc/proto/sui/rpc/v2/ledger_service.js.map +1 -0
  114. package/dist/cjs/grpc/proto/sui/rpc/v2/move_package.js +599 -473
  115. package/dist/cjs/grpc/proto/sui/rpc/v2/move_package.js.map +1 -0
  116. package/dist/cjs/grpc/proto/sui/rpc/v2/move_package_service.client.js +46 -78
  117. package/dist/cjs/grpc/proto/sui/rpc/v2/move_package_service.client.js.map +1 -0
  118. package/dist/cjs/grpc/proto/sui/rpc/v2/move_package_service.js +242 -224
  119. package/dist/cjs/grpc/proto/sui/rpc/v2/move_package_service.js.map +1 -0
  120. package/dist/cjs/grpc/proto/sui/rpc/v2/name_service.client.js +32 -52
  121. package/dist/cjs/grpc/proto/sui/rpc/v2/name_service.client.js.map +1 -0
  122. package/dist/cjs/grpc/proto/sui/rpc/v2/name_service.js +139 -134
  123. package/dist/cjs/grpc/proto/sui/rpc/v2/name_service.js.map +1 -0
  124. package/dist/cjs/grpc/proto/sui/rpc/v2/object.js +109 -111
  125. package/dist/cjs/grpc/proto/sui/rpc/v2/object.js.map +1 -0
  126. package/dist/cjs/grpc/proto/sui/rpc/v2/object_reference.js +46 -51
  127. package/dist/cjs/grpc/proto/sui/rpc/v2/object_reference.js.map +1 -0
  128. package/dist/cjs/grpc/proto/sui/rpc/v2/owner.js +76 -61
  129. package/dist/cjs/grpc/proto/sui/rpc/v2/owner.js.map +1 -0
  130. package/dist/cjs/grpc/proto/sui/rpc/v2/protocol_config.js +46 -59
  131. package/dist/cjs/grpc/proto/sui/rpc/v2/protocol_config.js.map +1 -0
  132. package/dist/cjs/grpc/proto/sui/rpc/v2/signature.js +568 -522
  133. package/dist/cjs/grpc/proto/sui/rpc/v2/signature.js.map +1 -0
  134. package/dist/cjs/grpc/proto/sui/rpc/v2/signature_scheme.js +54 -32
  135. package/dist/cjs/grpc/proto/sui/rpc/v2/signature_scheme.js.map +1 -0
  136. package/dist/cjs/grpc/proto/sui/rpc/v2/signature_verification_service.client.js +27 -47
  137. package/dist/cjs/grpc/proto/sui/rpc/v2/signature_verification_service.client.js.map +1 -0
  138. package/dist/cjs/grpc/proto/sui/rpc/v2/signature_verification_service.js +83 -86
  139. package/dist/cjs/grpc/proto/sui/rpc/v2/signature_verification_service.js.map +1 -0
  140. package/dist/cjs/grpc/proto/sui/rpc/v2/state_service.client.js +53 -85
  141. package/dist/cjs/grpc/proto/sui/rpc/v2/state_service.client.js.map +1 -0
  142. package/dist/cjs/grpc/proto/sui/rpc/v2/state_service.js +645 -529
  143. package/dist/cjs/grpc/proto/sui/rpc/v2/state_service.js.map +1 -0
  144. package/dist/cjs/grpc/proto/sui/rpc/v2/subscription_service.client.js +37 -51
  145. package/dist/cjs/grpc/proto/sui/rpc/v2/subscription_service.client.js.map +1 -0
  146. package/dist/cjs/grpc/proto/sui/rpc/v2/subscription_service.js +58 -61
  147. package/dist/cjs/grpc/proto/sui/rpc/v2/subscription_service.js.map +1 -0
  148. package/dist/cjs/grpc/proto/sui/rpc/v2/system_state.js +749 -730
  149. package/dist/cjs/grpc/proto/sui/rpc/v2/system_state.js.map +1 -0
  150. package/dist/cjs/grpc/proto/sui/rpc/v2/transaction.js +1218 -975
  151. package/dist/cjs/grpc/proto/sui/rpc/v2/transaction.js.map +1 -0
  152. package/dist/cjs/grpc/proto/sui/rpc/v2/transaction_execution_service.client.js +32 -46
  153. package/dist/cjs/grpc/proto/sui/rpc/v2/transaction_execution_service.client.js.map +1 -0
  154. package/dist/cjs/grpc/proto/sui/rpc/v2/transaction_execution_service.js +186 -167
  155. package/dist/cjs/grpc/proto/sui/rpc/v2/transaction_execution_service.js.map +1 -0
  156. package/dist/cjs/index.js +96 -91
  157. package/dist/cjs/index.js.map +1 -0
  158. package/dist/cjs/jsonRpc/client.js +654 -743
  159. package/dist/cjs/jsonRpc/client.js.map +1 -0
  160. package/dist/cjs/jsonRpc/core.d.ts +7 -7
  161. package/dist/cjs/jsonRpc/core.js +562 -606
  162. package/dist/cjs/jsonRpc/core.js.map +1 -0
  163. package/dist/cjs/jsonRpc/errors.js +38 -56
  164. package/dist/cjs/jsonRpc/errors.js.map +1 -0
  165. package/dist/cjs/jsonRpc/http-transport.js +70 -114
  166. package/dist/cjs/jsonRpc/http-transport.js.map +1 -0
  167. package/dist/cjs/jsonRpc/index.js +14 -30
  168. package/dist/cjs/jsonRpc/index.js.map +1 -0
  169. package/dist/cjs/jsonRpc/json-rpc-resolver.js +286 -290
  170. package/dist/cjs/jsonRpc/json-rpc-resolver.js.map +1 -0
  171. package/dist/cjs/jsonRpc/rpc-websocket-client.js +150 -207
  172. package/dist/cjs/jsonRpc/rpc-websocket-client.js.map +1 -0
  173. package/dist/cjs/jsonRpc/types/chain.js +4 -15
  174. package/dist/cjs/jsonRpc/types/chain.js.map +1 -0
  175. package/dist/cjs/jsonRpc/types/changes.js +4 -15
  176. package/dist/cjs/jsonRpc/types/changes.js.map +1 -0
  177. package/dist/cjs/jsonRpc/types/coins.js +4 -15
  178. package/dist/cjs/jsonRpc/types/coins.js.map +1 -0
  179. package/dist/cjs/jsonRpc/types/common.js +4 -15
  180. package/dist/cjs/jsonRpc/types/common.js.map +1 -0
  181. package/dist/cjs/jsonRpc/types/generated.d.ts +1 -1
  182. package/dist/cjs/jsonRpc/types/generated.js +4 -15
  183. package/dist/cjs/jsonRpc/types/generated.js.map +1 -0
  184. package/dist/cjs/jsonRpc/types/index.js +4 -15
  185. package/dist/cjs/jsonRpc/types/index.js.map +1 -0
  186. package/dist/cjs/jsonRpc/types/params.js +4 -15
  187. package/dist/cjs/jsonRpc/types/params.js.map +1 -0
  188. package/dist/cjs/keypairs/ed25519/ed25519-hd-key.js +54 -69
  189. package/dist/cjs/keypairs/ed25519/ed25519-hd-key.js.map +1 -0
  190. package/dist/cjs/keypairs/ed25519/index.js +10 -26
  191. package/dist/cjs/keypairs/ed25519/index.js.map +1 -0
  192. package/dist/cjs/keypairs/ed25519/keypair.js +134 -159
  193. package/dist/cjs/keypairs/ed25519/keypair.js.map +1 -0
  194. package/dist/cjs/keypairs/ed25519/publickey.js +70 -84
  195. package/dist/cjs/keypairs/ed25519/publickey.js.map +1 -0
  196. package/dist/cjs/keypairs/index.js +21 -19
  197. package/dist/cjs/keypairs/index.js.map +1 -0
  198. package/dist/cjs/keypairs/passkey/index.js +11 -27
  199. package/dist/cjs/keypairs/passkey/index.js.map +1 -0
  200. package/dist/cjs/keypairs/passkey/keypair.js +245 -256
  201. package/dist/cjs/keypairs/passkey/keypair.js.map +1 -0
  202. package/dist/cjs/keypairs/passkey/publickey.js +163 -162
  203. package/dist/cjs/keypairs/passkey/publickey.js.map +1 -0
  204. package/dist/cjs/keypairs/passkey/types.js +4 -15
  205. package/dist/cjs/keypairs/passkey/types.js.map +1 -0
  206. package/dist/cjs/keypairs/secp256k1/index.js +10 -26
  207. package/dist/cjs/keypairs/secp256k1/index.js.map +1 -0
  208. package/dist/cjs/keypairs/secp256k1/keypair.js +129 -151
  209. package/dist/cjs/keypairs/secp256k1/keypair.js.map +1 -0
  210. package/dist/cjs/keypairs/secp256k1/publickey.js +71 -89
  211. package/dist/cjs/keypairs/secp256k1/publickey.js.map +1 -0
  212. package/dist/cjs/keypairs/secp256r1/index.js +10 -26
  213. package/dist/cjs/keypairs/secp256r1/index.js.map +1 -0
  214. package/dist/cjs/keypairs/secp256r1/keypair.js +127 -148
  215. package/dist/cjs/keypairs/secp256r1/keypair.js.map +1 -0
  216. package/dist/cjs/keypairs/secp256r1/publickey.js +72 -90
  217. package/dist/cjs/keypairs/secp256r1/publickey.js.map +1 -0
  218. package/dist/cjs/multisig/index.js +10 -26
  219. package/dist/cjs/multisig/index.js.map +1 -0
  220. package/dist/cjs/multisig/publickey.d.ts +1 -1
  221. package/dist/cjs/multisig/publickey.js +228 -276
  222. package/dist/cjs/multisig/publickey.js.map +1 -0
  223. package/dist/cjs/multisig/signer.js +62 -110
  224. package/dist/cjs/multisig/signer.js.map +1 -0
  225. package/dist/cjs/transactions/Arguments.d.ts +4 -4
  226. package/dist/cjs/transactions/Arguments.js +13 -34
  227. package/dist/cjs/transactions/Arguments.js.map +1 -0
  228. package/dist/cjs/transactions/Commands.js +111 -141
  229. package/dist/cjs/transactions/Commands.js.map +1 -0
  230. package/dist/cjs/transactions/Inputs.js +53 -82
  231. package/dist/cjs/transactions/Inputs.js.map +1 -0
  232. package/dist/cjs/transactions/ObjectCache.d.ts +8 -8
  233. package/dist/cjs/transactions/ObjectCache.js +204 -241
  234. package/dist/cjs/transactions/ObjectCache.js.map +1 -0
  235. package/dist/cjs/transactions/Transaction.d.ts +31 -31
  236. package/dist/cjs/transactions/Transaction.js +628 -719
  237. package/dist/cjs/transactions/Transaction.js.map +1 -0
  238. package/dist/cjs/transactions/TransactionData.d.ts +9 -9
  239. package/dist/cjs/transactions/TransactionData.js +396 -440
  240. package/dist/cjs/transactions/TransactionData.js.map +1 -0
  241. package/dist/cjs/transactions/__tests__/Transaction.test.js +169 -0
  242. package/dist/cjs/transactions/__tests__/Transaction.test.js.map +1 -0
  243. package/dist/cjs/transactions/__tests__/bcs.test.js +202 -0
  244. package/dist/cjs/transactions/__tests__/bcs.test.js.map +1 -0
  245. package/dist/cjs/transactions/data/internal.js +166 -207
  246. package/dist/cjs/transactions/data/internal.js.map +1 -0
  247. package/dist/cjs/transactions/data/v1.js +436 -495
  248. package/dist/cjs/transactions/data/v1.js.map +1 -0
  249. package/dist/cjs/transactions/data/v2.d.ts +5 -5
  250. package/dist/cjs/transactions/data/v2.js +94 -107
  251. package/dist/cjs/transactions/data/v2.js.map +1 -0
  252. package/dist/cjs/transactions/executor/caching.js +71 -113
  253. package/dist/cjs/transactions/executor/caching.js.map +1 -0
  254. package/dist/cjs/transactions/executor/parallel.js +339 -378
  255. package/dist/cjs/transactions/executor/parallel.js.map +1 -0
  256. package/dist/cjs/transactions/executor/queue.js +60 -80
  257. package/dist/cjs/transactions/executor/queue.js.map +1 -0
  258. package/dist/cjs/transactions/executor/serial.d.ts +4 -4
  259. package/dist/cjs/transactions/executor/serial.js +102 -131
  260. package/dist/cjs/transactions/executor/serial.js.map +1 -0
  261. package/dist/cjs/transactions/hash.js +17 -28
  262. package/dist/cjs/transactions/hash.js.map +1 -0
  263. package/dist/cjs/transactions/index.js +33 -49
  264. package/dist/cjs/transactions/index.js.map +1 -0
  265. package/dist/cjs/transactions/intents/CoinWithBalance.js +137 -191
  266. package/dist/cjs/transactions/intents/CoinWithBalance.js.map +1 -0
  267. package/dist/cjs/transactions/object.js +88 -111
  268. package/dist/cjs/transactions/object.js.map +1 -0
  269. package/dist/cjs/transactions/plugins/NamedPackagesPlugin.js +20 -32
  270. package/dist/cjs/transactions/plugins/NamedPackagesPlugin.js.map +1 -0
  271. package/dist/cjs/transactions/pure.js +38 -60
  272. package/dist/cjs/transactions/pure.js.map +1 -0
  273. package/dist/cjs/transactions/resolve.js +62 -88
  274. package/dist/cjs/transactions/resolve.js.map +1 -0
  275. package/dist/cjs/transactions/serializer.js +150 -163
  276. package/dist/cjs/transactions/serializer.js.map +1 -0
  277. package/dist/cjs/transactions/utils.d.ts +1 -1
  278. package/dist/cjs/transactions/utils.js +114 -125
  279. package/dist/cjs/transactions/utils.js.map +1 -0
  280. package/dist/cjs/utils/constants.js +29 -56
  281. package/dist/cjs/utils/constants.js.map +1 -0
  282. package/dist/cjs/utils/derived-objects.js +14 -30
  283. package/dist/cjs/utils/derived-objects.js.map +1 -0
  284. package/dist/cjs/utils/dynamic-fields.js +20 -37
  285. package/dist/cjs/utils/dynamic-fields.js.map +1 -0
  286. package/dist/cjs/utils/format.js +14 -30
  287. package/dist/cjs/utils/format.js.map +1 -0
  288. package/dist/cjs/utils/index.js +50 -64
  289. package/dist/cjs/utils/index.js.map +1 -0
  290. package/dist/cjs/utils/move-registry.js +37 -35
  291. package/dist/cjs/utils/move-registry.js.map +1 -0
  292. package/dist/cjs/utils/sui-types.js +74 -68
  293. package/dist/cjs/utils/sui-types.js.map +1 -0
  294. package/dist/cjs/utils/suins.js +30 -46
  295. package/dist/cjs/utils/suins.js.map +1 -0
  296. package/dist/cjs/verify/index.js +12 -27
  297. package/dist/cjs/verify/index.js.map +1 -0
  298. package/dist/cjs/verify/verify.js +83 -110
  299. package/dist/cjs/verify/verify.js.map +1 -0
  300. package/dist/cjs/version.js +8 -25
  301. package/dist/cjs/version.js.map +1 -0
  302. package/dist/cjs/w/call/allocation.js +323 -413
  303. package/dist/cjs/w/call/allocation.js.map +1 -0
  304. package/dist/cjs/w/call/arb.js +105 -136
  305. package/dist/cjs/w/call/arb.js.map +1 -0
  306. package/dist/cjs/w/call/arbitration.js +1206 -1581
  307. package/dist/cjs/w/call/arbitration.js.map +1 -0
  308. package/dist/cjs/w/call/base.js +303 -333
  309. package/dist/cjs/w/call/base.js.map +1 -0
  310. package/dist/cjs/w/call/contact.js +335 -452
  311. package/dist/cjs/w/call/contact.js.map +1 -0
  312. package/dist/cjs/w/call/demand.js +690 -844
  313. package/dist/cjs/w/call/demand.js.map +1 -0
  314. package/dist/cjs/w/call/entity.js +167 -201
  315. package/dist/cjs/w/call/entity.js.map +1 -0
  316. package/dist/cjs/w/call/guard-ins.js +4376 -4389
  317. package/dist/cjs/w/call/guard-ins.js.map +1 -0
  318. package/dist/cjs/w/call/guard.js +1078 -1112
  319. package/dist/cjs/w/call/guard.js.map +1 -0
  320. package/dist/cjs/w/call/index.js +69 -70
  321. package/dist/cjs/w/call/index.js.map +1 -0
  322. package/dist/cjs/w/call/machine.js +1105 -1419
  323. package/dist/cjs/w/call/machine.js.map +1 -0
  324. package/dist/cjs/w/call/order.js +314 -454
  325. package/dist/cjs/w/call/order.js.map +1 -0
  326. package/dist/cjs/w/call/passport.js +214 -253
  327. package/dist/cjs/w/call/passport.js.map +1 -0
  328. package/dist/cjs/w/call/payment.js +187 -224
  329. package/dist/cjs/w/call/payment.js.map +1 -0
  330. package/dist/cjs/w/call/permission.js +1183 -1294
  331. package/dist/cjs/w/call/permission.js.map +1 -0
  332. package/dist/cjs/w/call/personal.js +132 -170
  333. package/dist/cjs/w/call/personal.js.map +1 -0
  334. package/dist/cjs/w/call/progress.js +634 -794
  335. package/dist/cjs/w/call/progress.js.map +1 -0
  336. package/dist/cjs/w/call/proof.js +67 -116
  337. package/dist/cjs/w/call/proof.js.map +1 -0
  338. package/dist/cjs/w/call/repository.js +1037 -1251
  339. package/dist/cjs/w/call/repository.js.map +1 -0
  340. package/dist/cjs/w/call/resource.js +111 -131
  341. package/dist/cjs/w/call/resource.js.map +1 -0
  342. package/dist/cjs/w/call/reward.js +675 -853
  343. package/dist/cjs/w/call/reward.js.map +1 -0
  344. package/dist/cjs/w/call/service.js +1879 -2385
  345. package/dist/cjs/w/call/service.js.map +1 -0
  346. package/dist/cjs/w/call/treasury.js +841 -1138
  347. package/dist/cjs/w/call/treasury.js.map +1 -0
  348. package/dist/cjs/w/call/util.js +593 -624
  349. package/dist/cjs/w/call/util.js.map +1 -0
  350. package/dist/cjs/w/common.d.ts +1 -1
  351. package/dist/cjs/w/common.js +548 -518
  352. package/dist/cjs/w/common.js.map +1 -0
  353. package/dist/cjs/w/exception.js +574 -584
  354. package/dist/cjs/w/exception.js.map +1 -0
  355. package/dist/cjs/w/index.js +26 -23
  356. package/dist/cjs/w/index.js.map +1 -0
  357. package/dist/cjs/w/local/account.js +664 -741
  358. package/dist/cjs/w/local/account.js.map +1 -0
  359. package/dist/cjs/w/local/cache.js +180 -166
  360. package/dist/cjs/w/local/cache.js.map +1 -0
  361. package/dist/cjs/w/local/config.js +51 -80
  362. package/dist/cjs/w/local/config.js.map +1 -0
  363. package/dist/cjs/w/local/index.js +225 -290
  364. package/dist/cjs/w/local/index.js.map +1 -0
  365. package/dist/cjs/w/local/local.d.ts +2 -2
  366. package/dist/cjs/w/local/local.js +638 -646
  367. package/dist/cjs/w/local/local.js.map +1 -0
  368. package/dist/cjs/w/local/storage.js +210 -164
  369. package/dist/cjs/w/local/storage.js.map +1 -0
  370. package/dist/cjs/w/local/token.js +158 -175
  371. package/dist/cjs/w/local/token.js.map +1 -0
  372. package/dist/cjs/w/local/util.js +80 -51
  373. package/dist/cjs/w/local/util.js.map +1 -0
  374. package/dist/cjs/w/local/wip.js +1078 -802
  375. package/dist/cjs/w/local/wip.js.map +1 -0
  376. package/dist/cjs/w/messenger/crypto.js +496 -389
  377. package/dist/cjs/w/messenger/crypto.js.map +1 -0
  378. package/dist/cjs/w/messenger/index.js +53 -35
  379. package/dist/cjs/w/messenger/index.js.map +1 -0
  380. package/dist/cjs/w/messenger/messenger-api.js +1159 -1035
  381. package/dist/cjs/w/messenger/messenger-api.js.map +1 -0
  382. package/dist/cjs/w/messenger/messenger-manager.js +954 -1083
  383. package/dist/cjs/w/messenger/messenger-manager.js.map +1 -0
  384. package/dist/cjs/w/messenger/messenger.d.ts +1 -1
  385. package/dist/cjs/w/messenger/messenger.js +1304 -1450
  386. package/dist/cjs/w/messenger/messenger.js.map +1 -0
  387. package/dist/cjs/w/messenger/server.js +390 -512
  388. package/dist/cjs/w/messenger/server.js.map +1 -0
  389. package/dist/cjs/w/messenger/session.js +399 -403
  390. package/dist/cjs/w/messenger/session.js.map +1 -0
  391. package/dist/cjs/w/messenger/storage.js +881 -777
  392. package/dist/cjs/w/messenger/storage.js.map +1 -0
  393. package/dist/cjs/w/messenger/types.d.ts +2 -2
  394. package/dist/cjs/w/messenger/types.js +83 -103
  395. package/dist/cjs/w/messenger/types.js.map +1 -0
  396. package/dist/cjs/w/messenger/utils.js +29 -34
  397. package/dist/cjs/w/messenger/utils.js.map +1 -0
  398. package/dist/cjs/w/query/bult-in.js +101 -110
  399. package/dist/cjs/w/query/bult-in.js.map +1 -0
  400. package/dist/cjs/w/query/event.js +134 -146
  401. package/dist/cjs/w/query/event.js.map +1 -0
  402. package/dist/cjs/w/query/index.js +22 -20
  403. package/dist/cjs/w/query/index.js.map +1 -0
  404. package/dist/cjs/w/query/object.js +1576 -1576
  405. package/dist/cjs/w/query/object.js.map +1 -0
  406. package/dist/cjs/w/query/received.js +66 -88
  407. package/dist/cjs/w/query/received.js.map +1 -0
  408. package/dist/cjs/w/query/util.js +53 -77
  409. package/dist/cjs/w/query/util.js.map +1 -0
  410. package/dist/cjs/w/util.js +589 -675
  411. package/dist/cjs/w/util.js.map +1 -0
  412. package/dist/esm/bcs/bcs.d.ts +199 -199
  413. package/dist/esm/bcs/bcs.js +269 -310
  414. package/dist/esm/bcs/bcs.js.map +1 -0
  415. package/dist/esm/bcs/effects.d.ts +109 -109
  416. package/dist/esm/bcs/effects.js +171 -179
  417. package/dist/esm/bcs/effects.js.map +1 -0
  418. package/dist/esm/bcs/index.d.ts +1 -2584
  419. package/dist/esm/bcs/index.js +51 -94
  420. package/dist/esm/bcs/index.js.map +1 -0
  421. package/dist/esm/bcs/pure.js +35 -38
  422. package/dist/esm/bcs/pure.js.map +1 -0
  423. package/dist/esm/bcs/type-tag-serializer.js +98 -95
  424. package/dist/esm/bcs/type-tag-serializer.js.map +1 -0
  425. package/dist/esm/bcs/types.js +5 -5
  426. package/dist/esm/bcs/types.js.map +1 -0
  427. package/dist/esm/client/index.js +7 -23
  428. package/dist/esm/client/index.js.map +1 -0
  429. package/dist/esm/client/network.js +23 -22
  430. package/dist/esm/client/network.js.map +1 -0
  431. package/dist/esm/cryptography/index.js +9 -46
  432. package/dist/esm/cryptography/index.js.map +1 -0
  433. package/dist/esm/cryptography/intent.d.ts +1 -1
  434. package/dist/esm/cryptography/intent.js +18 -12
  435. package/dist/esm/cryptography/intent.js.map +1 -0
  436. package/dist/esm/cryptography/keypair.js +95 -99
  437. package/dist/esm/cryptography/keypair.js.map +1 -0
  438. package/dist/esm/cryptography/mnemonics.js +40 -24
  439. package/dist/esm/cryptography/mnemonics.js.map +1 -0
  440. package/dist/esm/cryptography/publickey.js +104 -115
  441. package/dist/esm/cryptography/publickey.js.map +1 -0
  442. package/dist/esm/cryptography/signature-scheme.js +22 -24
  443. package/dist/esm/cryptography/signature-scheme.js.map +1 -0
  444. package/dist/esm/cryptography/signature.d.ts +2 -24
  445. package/dist/esm/cryptography/signature.js +44 -48
  446. package/dist/esm/cryptography/signature.js.map +1 -0
  447. package/dist/esm/experimental/cache.js +61 -0
  448. package/dist/esm/experimental/cache.js.map +1 -0
  449. package/dist/esm/experimental/client.js +23 -0
  450. package/dist/esm/experimental/client.js.map +1 -0
  451. package/dist/esm/experimental/core.js +85 -0
  452. package/dist/esm/experimental/core.js.map +1 -0
  453. package/dist/esm/experimental/errors.js +27 -0
  454. package/dist/esm/experimental/errors.js.map +1 -0
  455. package/dist/esm/experimental/index.js +8 -0
  456. package/dist/esm/experimental/index.js.map +1 -0
  457. package/dist/esm/experimental/persistent-storage.js +337 -0
  458. package/dist/esm/experimental/persistent-storage.js.map +1 -0
  459. package/dist/esm/experimental/persistent-storage.test.js +198 -0
  460. package/dist/esm/experimental/persistent-storage.test.js.map +1 -0
  461. package/dist/esm/experimental/transports/utils.js +100 -0
  462. package/dist/esm/experimental/transports/utils.js.map +1 -0
  463. package/dist/esm/experimental/types.js +5 -0
  464. package/dist/esm/experimental/types.js.map +1 -0
  465. package/dist/esm/faucet/faucet.js +104 -111
  466. package/dist/esm/faucet/faucet.js.map +1 -0
  467. package/dist/esm/faucet/index.js +4 -16
  468. package/dist/esm/faucet/index.js.map +1 -0
  469. package/dist/esm/grpc/client.js +34 -34
  470. package/dist/esm/grpc/client.js.map +1 -0
  471. package/dist/esm/grpc/core.js +570 -601
  472. package/dist/esm/grpc/core.js.map +1 -0
  473. package/dist/esm/grpc/index.js +5 -6
  474. package/dist/esm/grpc/index.js.map +1 -0
  475. package/dist/esm/grpc/proto/google/protobuf/any.js +161 -111
  476. package/dist/esm/grpc/proto/google/protobuf/any.js.map +1 -0
  477. package/dist/esm/grpc/proto/google/protobuf/duration.js +99 -67
  478. package/dist/esm/grpc/proto/google/protobuf/duration.js.map +1 -0
  479. package/dist/esm/grpc/proto/google/protobuf/empty.js +46 -7
  480. package/dist/esm/grpc/proto/google/protobuf/empty.js.map +1 -0
  481. package/dist/esm/grpc/proto/google/protobuf/field_mask.js +90 -52
  482. package/dist/esm/grpc/proto/google/protobuf/field_mask.js.map +1 -0
  483. package/dist/esm/grpc/proto/google/protobuf/struct.js +258 -190
  484. package/dist/esm/grpc/proto/google/protobuf/struct.js.map +1 -0
  485. package/dist/esm/grpc/proto/google/protobuf/timestamp.js +144 -108
  486. package/dist/esm/grpc/proto/google/protobuf/timestamp.js.map +1 -0
  487. package/dist/esm/grpc/proto/google/rpc/error_details.js +313 -267
  488. package/dist/esm/grpc/proto/google/rpc/error_details.js.map +1 -0
  489. package/dist/esm/grpc/proto/google/rpc/status.js +45 -28
  490. package/dist/esm/grpc/proto/google/rpc/status.js.map +1 -0
  491. package/dist/esm/grpc/proto/sui/rpc/v2/argument.js +80 -47
  492. package/dist/esm/grpc/proto/sui/rpc/v2/argument.js.map +1 -0
  493. package/dist/esm/grpc/proto/sui/rpc/v2/balance_change.js +41 -29
  494. package/dist/esm/grpc/proto/sui/rpc/v2/balance_change.js.map +1 -0
  495. package/dist/esm/grpc/proto/sui/rpc/v2/bcs.js +34 -22
  496. package/dist/esm/grpc/proto/sui/rpc/v2/bcs.js.map +1 -0
  497. package/dist/esm/grpc/proto/sui/rpc/v2/checkpoint.js +61 -49
  498. package/dist/esm/grpc/proto/sui/rpc/v2/checkpoint.js.map +1 -0
  499. package/dist/esm/grpc/proto/sui/rpc/v2/checkpoint_contents.js +72 -57
  500. package/dist/esm/grpc/proto/sui/rpc/v2/checkpoint_contents.js.map +1 -0
  501. package/dist/esm/grpc/proto/sui/rpc/v2/checkpoint_summary.js +173 -139
  502. package/dist/esm/grpc/proto/sui/rpc/v2/checkpoint_summary.js.map +1 -0
  503. package/dist/esm/grpc/proto/sui/rpc/v2/effects.js +358 -268
  504. package/dist/esm/grpc/proto/sui/rpc/v2/effects.js.map +1 -0
  505. package/dist/esm/grpc/proto/sui/rpc/v2/epoch.js +72 -60
  506. package/dist/esm/grpc/proto/sui/rpc/v2/epoch.js.map +1 -0
  507. package/dist/esm/grpc/proto/sui/rpc/v2/error_reason.js +29 -9
  508. package/dist/esm/grpc/proto/sui/rpc/v2/error_reason.js.map +1 -0
  509. package/dist/esm/grpc/proto/sui/rpc/v2/event.js +74 -59
  510. package/dist/esm/grpc/proto/sui/rpc/v2/event.js.map +1 -0
  511. package/dist/esm/grpc/proto/sui/rpc/v2/executed_transaction.js +69 -57
  512. package/dist/esm/grpc/proto/sui/rpc/v2/executed_transaction.js.map +1 -0
  513. package/dist/esm/grpc/proto/sui/rpc/v2/execution_status.js +861 -474
  514. package/dist/esm/grpc/proto/sui/rpc/v2/execution_status.js.map +1 -0
  515. package/dist/esm/grpc/proto/sui/rpc/v2/gas_cost_summary.js +52 -40
  516. package/dist/esm/grpc/proto/sui/rpc/v2/gas_cost_summary.js.map +1 -0
  517. package/dist/esm/grpc/proto/sui/rpc/v2/input.js +98 -61
  518. package/dist/esm/grpc/proto/sui/rpc/v2/input.js.map +1 -0
  519. package/dist/esm/grpc/proto/sui/rpc/v2/jwk.js +71 -56
  520. package/dist/esm/grpc/proto/sui/rpc/v2/jwk.js.map +1 -0
  521. package/dist/esm/grpc/proto/sui/rpc/v2/ledger_service.client.js +65 -100
  522. package/dist/esm/grpc/proto/sui/rpc/v2/ledger_service.client.js.map +1 -0
  523. package/dist/esm/grpc/proto/sui/rpc/v2/ledger_service.js +365 -306
  524. package/dist/esm/grpc/proto/sui/rpc/v2/ledger_service.js.map +1 -0
  525. package/dist/esm/grpc/proto/sui/rpc/v2/move_package.js +585 -442
  526. package/dist/esm/grpc/proto/sui/rpc/v2/move_package.js.map +1 -0
  527. package/dist/esm/grpc/proto/sui/rpc/v2/move_package_service.client.js +42 -59
  528. package/dist/esm/grpc/proto/sui/rpc/v2/move_package_service.client.js.map +1 -0
  529. package/dist/esm/grpc/proto/sui/rpc/v2/move_package_service.js +226 -191
  530. package/dist/esm/grpc/proto/sui/rpc/v2/move_package_service.js.map +1 -0
  531. package/dist/esm/grpc/proto/sui/rpc/v2/name_service.client.js +28 -33
  532. package/dist/esm/grpc/proto/sui/rpc/v2/name_service.client.js.map +1 -0
  533. package/dist/esm/grpc/proto/sui/rpc/v2/name_service.js +129 -107
  534. package/dist/esm/grpc/proto/sui/rpc/v2/name_service.js.map +1 -0
  535. package/dist/esm/grpc/proto/sui/rpc/v2/object.js +100 -85
  536. package/dist/esm/grpc/proto/sui/rpc/v2/object.js.map +1 -0
  537. package/dist/esm/grpc/proto/sui/rpc/v2/object_reference.js +42 -30
  538. package/dist/esm/grpc/proto/sui/rpc/v2/object_reference.js.map +1 -0
  539. package/dist/esm/grpc/proto/sui/rpc/v2/owner.js +72 -40
  540. package/dist/esm/grpc/proto/sui/rpc/v2/owner.js.map +1 -0
  541. package/dist/esm/grpc/proto/sui/rpc/v2/protocol_config.js +42 -38
  542. package/dist/esm/grpc/proto/sui/rpc/v2/protocol_config.js.map +1 -0
  543. package/dist/esm/grpc/proto/sui/rpc/v2/signature.js +544 -481
  544. package/dist/esm/grpc/proto/sui/rpc/v2/signature.js.map +1 -0
  545. package/dist/esm/grpc/proto/sui/rpc/v2/signature_scheme.js +52 -13
  546. package/dist/esm/grpc/proto/sui/rpc/v2/signature_scheme.js.map +1 -0
  547. package/dist/esm/grpc/proto/sui/rpc/v2/signature_verification_service.client.js +23 -28
  548. package/dist/esm/grpc/proto/sui/rpc/v2/signature_verification_service.client.js.map +1 -0
  549. package/dist/esm/grpc/proto/sui/rpc/v2/signature_verification_service.js +74 -60
  550. package/dist/esm/grpc/proto/sui/rpc/v2/signature_verification_service.js.map +1 -0
  551. package/dist/esm/grpc/proto/sui/rpc/v2/state_service.client.js +49 -66
  552. package/dist/esm/grpc/proto/sui/rpc/v2/state_service.client.js.map +1 -0
  553. package/dist/esm/grpc/proto/sui/rpc/v2/state_service.js +623 -490
  554. package/dist/esm/grpc/proto/sui/rpc/v2/state_service.js.map +1 -0
  555. package/dist/esm/grpc/proto/sui/rpc/v2/subscription_service.client.js +33 -32
  556. package/dist/esm/grpc/proto/sui/rpc/v2/subscription_service.client.js.map +1 -0
  557. package/dist/esm/grpc/proto/sui/rpc/v2/subscription_service.js +50 -36
  558. package/dist/esm/grpc/proto/sui/rpc/v2/subscription_service.js.map +1 -0
  559. package/dist/esm/grpc/proto/sui/rpc/v2/system_state.js +737 -701
  560. package/dist/esm/grpc/proto/sui/rpc/v2/system_state.js.map +1 -0
  561. package/dist/esm/grpc/proto/sui/rpc/v2/transaction.js +1177 -917
  562. package/dist/esm/grpc/proto/sui/rpc/v2/transaction.js.map +1 -0
  563. package/dist/esm/grpc/proto/sui/rpc/v2/transaction_execution_service.client.js +28 -27
  564. package/dist/esm/grpc/proto/sui/rpc/v2/transaction_execution_service.client.js.map +1 -0
  565. package/dist/esm/grpc/proto/sui/rpc/v2/transaction_execution_service.js +169 -133
  566. package/dist/esm/grpc/proto/sui/rpc/v2/transaction_execution_service.js.map +1 -0
  567. package/dist/esm/index.js +21 -107
  568. package/dist/esm/index.js.map +1 -0
  569. package/dist/esm/jsonRpc/client.js +646 -727
  570. package/dist/esm/jsonRpc/client.js.map +1 -0
  571. package/dist/esm/jsonRpc/core.d.ts +7 -7
  572. package/dist/esm/jsonRpc/core.js +550 -581
  573. package/dist/esm/jsonRpc/core.js.map +1 -0
  574. package/dist/esm/jsonRpc/errors.js +36 -41
  575. package/dist/esm/jsonRpc/errors.js.map +1 -0
  576. package/dist/esm/jsonRpc/http-transport.js +65 -93
  577. package/dist/esm/jsonRpc/http-transport.js.map +1 -0
  578. package/dist/esm/jsonRpc/index.js +6 -20
  579. package/dist/esm/jsonRpc/index.js.map +1 -0
  580. package/dist/esm/jsonRpc/json-rpc-resolver.js +281 -276
  581. package/dist/esm/jsonRpc/json-rpc-resolver.js.map +1 -0
  582. package/dist/esm/jsonRpc/rpc-websocket-client.js +147 -189
  583. package/dist/esm/jsonRpc/rpc-websocket-client.js.map +1 -0
  584. package/dist/esm/jsonRpc/types/chain.js +4 -0
  585. package/dist/esm/jsonRpc/types/chain.js.map +1 -0
  586. package/dist/esm/jsonRpc/types/changes.js +4 -0
  587. package/dist/esm/jsonRpc/types/changes.js.map +1 -0
  588. package/dist/esm/jsonRpc/types/coins.js +4 -0
  589. package/dist/esm/jsonRpc/types/coins.js.map +1 -0
  590. package/dist/esm/jsonRpc/types/common.js +4 -0
  591. package/dist/esm/jsonRpc/types/common.js.map +1 -0
  592. package/dist/esm/jsonRpc/types/generated.d.ts +1 -1
  593. package/dist/esm/jsonRpc/types/generated.js +4 -0
  594. package/dist/esm/jsonRpc/types/generated.js.map +1 -0
  595. package/dist/esm/jsonRpc/types/index.js +4 -0
  596. package/dist/esm/jsonRpc/types/index.js.map +1 -0
  597. package/dist/esm/jsonRpc/types/params.js +4 -0
  598. package/dist/esm/jsonRpc/types/params.js.map +1 -0
  599. package/dist/esm/keypairs/ed25519/ed25519-hd-key.js +49 -48
  600. package/dist/esm/keypairs/ed25519/ed25519-hd-key.js.map +1 -0
  601. package/dist/esm/keypairs/ed25519/index.js +5 -10
  602. package/dist/esm/keypairs/ed25519/index.js.map +1 -0
  603. package/dist/esm/keypairs/ed25519/keypair.js +128 -146
  604. package/dist/esm/keypairs/ed25519/keypair.js.map +1 -0
  605. package/dist/esm/keypairs/ed25519/publickey.js +64 -67
  606. package/dist/esm/keypairs/ed25519/publickey.js.map +1 -0
  607. package/dist/esm/keypairs/index.js +3 -0
  608. package/dist/esm/keypairs/index.js.map +1 -0
  609. package/dist/esm/keypairs/passkey/index.js +5 -12
  610. package/dist/esm/keypairs/passkey/index.js.map +1 -0
  611. package/dist/esm/keypairs/passkey/keypair.js +236 -243
  612. package/dist/esm/keypairs/passkey/keypair.js.map +1 -0
  613. package/dist/esm/keypairs/passkey/publickey.js +154 -140
  614. package/dist/esm/keypairs/passkey/publickey.js.map +1 -0
  615. package/dist/esm/keypairs/passkey/types.js +4 -0
  616. package/dist/esm/keypairs/passkey/types.js.map +1 -0
  617. package/dist/esm/keypairs/secp256k1/index.js +5 -10
  618. package/dist/esm/keypairs/secp256k1/index.js.map +1 -0
  619. package/dist/esm/keypairs/secp256k1/keypair.js +120 -134
  620. package/dist/esm/keypairs/secp256k1/keypair.js.map +1 -0
  621. package/dist/esm/keypairs/secp256k1/publickey.js +64 -71
  622. package/dist/esm/keypairs/secp256k1/publickey.js.map +1 -0
  623. package/dist/esm/keypairs/secp256r1/index.js +5 -10
  624. package/dist/esm/keypairs/secp256r1/index.js.map +1 -0
  625. package/dist/esm/keypairs/secp256r1/keypair.js +118 -131
  626. package/dist/esm/keypairs/secp256r1/keypair.js.map +1 -0
  627. package/dist/esm/keypairs/secp256r1/publickey.js +63 -66
  628. package/dist/esm/keypairs/secp256r1/publickey.js.map +1 -0
  629. package/dist/esm/multisig/index.js +5 -10
  630. package/dist/esm/multisig/index.js.map +1 -0
  631. package/dist/esm/multisig/publickey.d.ts +1 -1
  632. package/dist/esm/multisig/publickey.js +216 -253
  633. package/dist/esm/multisig/publickey.js.map +1 -0
  634. package/dist/esm/multisig/signer.js +57 -89
  635. package/dist/esm/multisig/signer.js.map +1 -0
  636. package/dist/esm/transactions/Arguments.d.ts +4 -4
  637. package/dist/esm/transactions/Arguments.js +9 -13
  638. package/dist/esm/transactions/Arguments.js.map +1 -0
  639. package/dist/esm/transactions/Commands.js +105 -118
  640. package/dist/esm/transactions/Commands.js.map +1 -0
  641. package/dist/esm/transactions/Inputs.js +49 -61
  642. package/dist/esm/transactions/Inputs.js.map +1 -0
  643. package/dist/esm/transactions/ObjectCache.d.ts +8 -8
  644. package/dist/esm/transactions/ObjectCache.js +200 -223
  645. package/dist/esm/transactions/ObjectCache.js.map +1 -0
  646. package/dist/esm/transactions/Transaction.d.ts +32 -32
  647. package/dist/esm/transactions/Transaction.js +611 -696
  648. package/dist/esm/transactions/Transaction.js.map +1 -0
  649. package/dist/esm/transactions/TransactionData.d.ts +9 -9
  650. package/dist/esm/transactions/TransactionData.js +386 -415
  651. package/dist/esm/transactions/TransactionData.js.map +1 -0
  652. package/dist/esm/transactions/__tests__/Transaction.test.js +167 -0
  653. package/dist/esm/transactions/__tests__/Transaction.test.js.map +1 -0
  654. package/dist/esm/transactions/__tests__/bcs.test.js +200 -0
  655. package/dist/esm/transactions/__tests__/bcs.test.js.map +1 -0
  656. package/dist/esm/transactions/data/internal.js +158 -205
  657. package/dist/esm/transactions/data/internal.js.map +1 -0
  658. package/dist/esm/transactions/data/v1.js +419 -487
  659. package/dist/esm/transactions/data/v1.js.map +1 -0
  660. package/dist/esm/transactions/data/v2.d.ts +5 -5
  661. package/dist/esm/transactions/data/v2.js +89 -107
  662. package/dist/esm/transactions/data/v2.js.map +1 -0
  663. package/dist/esm/transactions/executor/caching.d.ts +2 -2
  664. package/dist/esm/transactions/executor/caching.js +66 -93
  665. package/dist/esm/transactions/executor/caching.js.map +1 -0
  666. package/dist/esm/transactions/executor/parallel.js +329 -352
  667. package/dist/esm/transactions/executor/parallel.js.map +1 -0
  668. package/dist/esm/transactions/executor/queue.js +58 -64
  669. package/dist/esm/transactions/executor/queue.js.map +1 -0
  670. package/dist/esm/transactions/executor/serial.d.ts +5 -5
  671. package/dist/esm/transactions/executor/serial.js +96 -110
  672. package/dist/esm/transactions/executor/serial.js.map +1 -0
  673. package/dist/esm/transactions/hash.js +15 -9
  674. package/dist/esm/transactions/hash.js.map +1 -0
  675. package/dist/esm/transactions/index.js +15 -41
  676. package/dist/esm/transactions/index.js.map +1 -0
  677. package/dist/esm/transactions/intents/CoinWithBalance.js +127 -165
  678. package/dist/esm/transactions/intents/CoinWithBalance.js.map +1 -0
  679. package/dist/esm/transactions/object.js +86 -92
  680. package/dist/esm/transactions/object.js.map +1 -0
  681. package/dist/esm/transactions/plugins/NamedPackagesPlugin.js +18 -15
  682. package/dist/esm/transactions/plugins/NamedPackagesPlugin.js.map +1 -0
  683. package/dist/esm/transactions/pure.js +34 -39
  684. package/dist/esm/transactions/pure.js.map +1 -0
  685. package/dist/esm/transactions/resolve.js +58 -69
  686. package/dist/esm/transactions/resolve.js.map +1 -0
  687. package/dist/esm/transactions/serializer.js +145 -144
  688. package/dist/esm/transactions/serializer.js.map +1 -0
  689. package/dist/esm/transactions/utils.d.ts +1 -1
  690. package/dist/esm/transactions/utils.js +110 -109
  691. package/dist/esm/transactions/utils.js.map +1 -0
  692. package/dist/esm/utils/constants.js +26 -36
  693. package/dist/esm/utils/constants.js.map +1 -0
  694. package/dist/esm/utils/derived-objects.js +11 -10
  695. package/dist/esm/utils/derived-objects.js.map +1 -0
  696. package/dist/esm/utils/dynamic-fields.js +16 -16
  697. package/dist/esm/utils/dynamic-fields.js.map +1 -0
  698. package/dist/esm/utils/format.js +13 -13
  699. package/dist/esm/utils/format.js.map +1 -0
  700. package/dist/esm/utils/index.js +15 -76
  701. package/dist/esm/utils/index.js.map +1 -0
  702. package/dist/esm/utils/move-registry.js +34 -17
  703. package/dist/esm/utils/move-registry.js.map +1 -0
  704. package/dist/esm/utils/sui-types.js +70 -54
  705. package/dist/esm/utils/sui-types.js.map +1 -0
  706. package/dist/esm/utils/suins.js +29 -29
  707. package/dist/esm/utils/suins.js.map +1 -0
  708. package/dist/esm/verify/index.js +5 -14
  709. package/dist/esm/verify/index.js.map +1 -0
  710. package/dist/esm/verify/verify.js +76 -93
  711. package/dist/esm/verify/verify.js.map +1 -0
  712. package/dist/esm/version.js +6 -6
  713. package/dist/esm/version.js.map +1 -0
  714. package/dist/esm/w/call/allocation.js +307 -402
  715. package/dist/esm/w/call/allocation.js.map +1 -0
  716. package/dist/esm/w/call/arb.js +100 -129
  717. package/dist/esm/w/call/arb.js.map +1 -0
  718. package/dist/esm/w/call/arbitration.js +1170 -1568
  719. package/dist/esm/w/call/arbitration.js.map +1 -0
  720. package/dist/esm/w/call/base.js +288 -315
  721. package/dist/esm/w/call/base.js.map +1 -0
  722. package/dist/esm/w/call/contact.js +318 -442
  723. package/dist/esm/w/call/contact.js.map +1 -0
  724. package/dist/esm/w/call/demand.js +673 -841
  725. package/dist/esm/w/call/demand.js.map +1 -0
  726. package/dist/esm/w/call/entity.js +162 -203
  727. package/dist/esm/w/call/entity.js.map +1 -0
  728. package/dist/esm/w/call/guard-ins.js +4373 -4371
  729. package/dist/esm/w/call/guard-ins.js.map +1 -0
  730. package/dist/esm/w/call/guard.js +1061 -1108
  731. package/dist/esm/w/call/guard.js.map +1 -0
  732. package/dist/esm/w/call/index.js +24 -56
  733. package/dist/esm/w/call/index.js.map +1 -0
  734. package/dist/esm/w/call/machine.js +1086 -1433
  735. package/dist/esm/w/call/machine.js.map +1 -0
  736. package/dist/esm/w/call/order.js +301 -448
  737. package/dist/esm/w/call/order.js.map +1 -0
  738. package/dist/esm/w/call/passport.js +204 -240
  739. package/dist/esm/w/call/passport.js.map +1 -0
  740. package/dist/esm/w/call/payment.js +177 -215
  741. package/dist/esm/w/call/payment.js.map +1 -0
  742. package/dist/esm/w/call/permission.js +1172 -1320
  743. package/dist/esm/w/call/permission.js.map +1 -0
  744. package/dist/esm/w/call/personal.js +121 -156
  745. package/dist/esm/w/call/personal.js.map +1 -0
  746. package/dist/esm/w/call/progress.js +625 -797
  747. package/dist/esm/w/call/progress.js.map +1 -0
  748. package/dist/esm/w/call/proof.js +61 -103
  749. package/dist/esm/w/call/proof.js.map +1 -0
  750. package/dist/esm/w/call/repository.js +1017 -1251
  751. package/dist/esm/w/call/repository.js.map +1 -0
  752. package/dist/esm/w/call/resource.js +108 -124
  753. package/dist/esm/w/call/resource.js.map +1 -0
  754. package/dist/esm/w/call/reward.js +660 -847
  755. package/dist/esm/w/call/reward.js.map +1 -0
  756. package/dist/esm/w/call/service.js +1849 -2400
  757. package/dist/esm/w/call/service.js.map +1 -0
  758. package/dist/esm/w/call/treasury.js +815 -1125
  759. package/dist/esm/w/call/treasury.js.map +1 -0
  760. package/dist/esm/w/call/util.js +553 -576
  761. package/dist/esm/w/call/util.js.map +1 -0
  762. package/dist/esm/w/common.d.ts +1 -1
  763. package/dist/esm/w/common.js +579 -580
  764. package/dist/esm/w/common.js.map +1 -0
  765. package/dist/esm/w/exception.js +570 -573
  766. package/dist/esm/w/exception.js.map +1 -0
  767. package/dist/esm/w/index.js +4 -0
  768. package/dist/esm/w/index.js.map +1 -0
  769. package/dist/esm/w/local/account.js +652 -709
  770. package/dist/esm/w/local/account.js.map +1 -0
  771. package/dist/esm/w/local/cache.js +176 -147
  772. package/dist/esm/w/local/cache.js.map +1 -0
  773. package/dist/esm/w/local/config.js +46 -60
  774. package/dist/esm/w/local/config.js.map +1 -0
  775. package/dist/esm/w/local/index.js +196 -273
  776. package/dist/esm/w/local/index.js.map +1 -0
  777. package/dist/esm/w/local/local.d.ts +2 -2
  778. package/dist/esm/w/local/local.js +631 -626
  779. package/dist/esm/w/local/local.js.map +1 -0
  780. package/dist/esm/w/local/storage.js +168 -136
  781. package/dist/esm/w/local/storage.js.map +1 -0
  782. package/dist/esm/w/local/token.js +149 -151
  783. package/dist/esm/w/local/token.js.map +1 -0
  784. package/dist/esm/w/local/util.js +45 -22
  785. package/dist/esm/w/local/util.js.map +1 -0
  786. package/dist/esm/w/local/wip.js +1038 -781
  787. package/dist/esm/w/local/wip.js.map +1 -0
  788. package/dist/esm/w/messenger/crypto.js +491 -387
  789. package/dist/esm/w/messenger/crypto.js.map +1 -0
  790. package/dist/esm/w/messenger/index.js +27 -24
  791. package/dist/esm/w/messenger/index.js.map +1 -0
  792. package/dist/esm/w/messenger/messenger-api.js +1111 -1017
  793. package/dist/esm/w/messenger/messenger-api.js.map +1 -0
  794. package/dist/esm/w/messenger/messenger-manager.js +944 -1052
  795. package/dist/esm/w/messenger/messenger-manager.js.map +1 -0
  796. package/dist/esm/w/messenger/messenger.d.ts +1 -1
  797. package/dist/esm/w/messenger/messenger.js +1258 -1421
  798. package/dist/esm/w/messenger/messenger.js.map +1 -0
  799. package/dist/esm/w/messenger/server.js +388 -499
  800. package/dist/esm/w/messenger/server.js.map +1 -0
  801. package/dist/esm/w/messenger/session.js +394 -399
  802. package/dist/esm/w/messenger/session.js.map +1 -0
  803. package/dist/esm/w/messenger/storage.js +840 -751
  804. package/dist/esm/w/messenger/storage.js.map +1 -0
  805. package/dist/esm/w/messenger/types.d.ts +2 -2
  806. package/dist/esm/w/messenger/types.js +80 -85
  807. package/dist/esm/w/messenger/types.js.map +1 -0
  808. package/dist/esm/w/messenger/utils.js +28 -16
  809. package/dist/esm/w/messenger/utils.js.map +1 -0
  810. package/dist/esm/w/query/bult-in.js +95 -100
  811. package/dist/esm/w/query/bult-in.js.map +1 -0
  812. package/dist/esm/w/query/event.js +128 -125
  813. package/dist/esm/w/query/event.js.map +1 -0
  814. package/dist/esm/w/query/index.js +3 -0
  815. package/dist/esm/w/query/index.js.map +1 -0
  816. package/dist/esm/w/query/object.js +1560 -1574
  817. package/dist/esm/w/query/object.js.map +1 -0
  818. package/dist/esm/w/query/received.js +57 -63
  819. package/dist/esm/w/query/received.js.map +1 -0
  820. package/dist/esm/w/query/util.js +48 -56
  821. package/dist/esm/w/query/util.js.map +1 -0
  822. package/dist/esm/w/util.js +578 -673
  823. package/dist/esm/w/util.js.map +1 -0
  824. package/package.json +13 -7
  825. package/prebuilds/better-sqlite3-v12.9.0-node-v115-darwin-arm64.node +0 -0
  826. package/prebuilds/better-sqlite3-v12.9.0-node-v115-darwin-x64.node +0 -0
  827. package/prebuilds/better-sqlite3-v12.9.0-node-v115-linux-arm.node +0 -0
  828. package/prebuilds/better-sqlite3-v12.9.0-node-v115-linux-arm64.node +0 -0
  829. package/prebuilds/better-sqlite3-v12.9.0-node-v115-linux-x64.node +0 -0
  830. package/prebuilds/better-sqlite3-v12.9.0-node-v115-win32-arm64.node +0 -0
  831. package/prebuilds/better-sqlite3-v12.9.0-node-v115-win32-x64.node +0 -0
  832. package/prebuilds/better-sqlite3-v12.9.0-node-v127-darwin-arm64.node +0 -0
  833. package/prebuilds/better-sqlite3-v12.9.0-node-v127-darwin-x64.node +0 -0
  834. package/prebuilds/better-sqlite3-v12.9.0-node-v127-linux-arm.node +0 -0
  835. package/prebuilds/better-sqlite3-v12.9.0-node-v127-linux-arm64.node +0 -0
  836. package/prebuilds/better-sqlite3-v12.9.0-node-v127-linux-x64.node +0 -0
  837. package/prebuilds/better-sqlite3-v12.9.0-node-v127-win32-arm64.node +0 -0
  838. package/prebuilds/better-sqlite3-v12.9.0-node-v127-win32-x64.node +0 -0
  839. package/scripts/download-prebuilds.js +234 -0
  840. package/scripts/install-better-sqlite3.js +377 -0
  841. package/dist/cjs/graphql/client.js +0 -98
  842. package/dist/cjs/graphql/core.js +0 -506
  843. package/dist/cjs/graphql/generated/2024.1/tada-env.js +0 -13141
  844. package/dist/cjs/graphql/generated/2024.1/tsconfig.tada.js +0 -11
  845. package/dist/cjs/graphql/generated/2024.4/tada-env.js +0 -13287
  846. package/dist/cjs/graphql/generated/2024.4/tsconfig.tada.js +0 -11
  847. package/dist/cjs/graphql/generated/latest/tada-env.js +0 -12925
  848. package/dist/cjs/graphql/generated/latest/tsconfig.tada.js +0 -11
  849. package/dist/cjs/graphql/generated/queries.js +0 -807
  850. package/dist/cjs/graphql/index.js +0 -25
  851. package/dist/cjs/graphql/schemas/2024.1/index.js +0 -28
  852. package/dist/cjs/graphql/schemas/2024.4/index.js +0 -28
  853. package/dist/cjs/graphql/schemas/latest/index.js +0 -28
  854. package/dist/cjs/graphql/types.js +0 -16
  855. package/dist/cjs/package.json +0 -5
  856. package/dist/cjs/w/local/.eslintrc.js +0 -15
  857. package/dist/cjs/w/messenger/.eslintrc.js +0 -15
  858. package/dist/cjs/zklogin/address.js +0 -93
  859. package/dist/cjs/zklogin/bcs.js +0 -41
  860. package/dist/cjs/zklogin/index.js +0 -45
  861. package/dist/cjs/zklogin/jwt-decode.js +0 -88
  862. package/dist/cjs/zklogin/jwt-utils.js +0 -128
  863. package/dist/cjs/zklogin/nonce.js +0 -60
  864. package/dist/cjs/zklogin/poseidon.js +0 -64
  865. package/dist/cjs/zklogin/publickey.js +0 -281
  866. package/dist/cjs/zklogin/signature.js +0 -57
  867. package/dist/cjs/zklogin/utils.js +0 -98
  868. package/dist/esm/graphql/client.js +0 -79
  869. package/dist/esm/graphql/core.js +0 -505
  870. package/dist/esm/graphql/generated/2024.1/tada-env.js +0 -13121
  871. package/dist/esm/graphql/generated/2024.1/tsconfig.tada.js +0 -16
  872. package/dist/esm/graphql/generated/2024.4/tada-env.js +0 -13267
  873. package/dist/esm/graphql/generated/2024.4/tsconfig.tada.js +0 -16
  874. package/dist/esm/graphql/generated/latest/tada-env.js +0 -12905
  875. package/dist/esm/graphql/generated/latest/tsconfig.tada.js +0 -16
  876. package/dist/esm/graphql/generated/queries.js +0 -788
  877. package/dist/esm/graphql/index.js +0 -8
  878. package/dist/esm/graphql/schemas/2024.1/index.js +0 -8
  879. package/dist/esm/graphql/schemas/2024.4/index.js +0 -8
  880. package/dist/esm/graphql/schemas/latest/index.js +0 -8
  881. package/dist/esm/graphql/types.js +0 -0
  882. package/dist/esm/package.json +0 -5
  883. package/dist/esm/w/local/.eslintrc.js +0 -23
  884. package/dist/esm/w/messenger/.eslintrc.js +0 -23
  885. package/dist/esm/zklogin/address.js +0 -78
  886. package/dist/esm/zklogin/bcs.js +0 -21
  887. package/dist/esm/zklogin/index.js +0 -38
  888. package/dist/esm/zklogin/jwt-decode.js +0 -68
  889. package/dist/esm/zklogin/jwt-utils.js +0 -108
  890. package/dist/esm/zklogin/nonce.js +0 -40
  891. package/dist/esm/zklogin/poseidon.js +0 -61
  892. package/dist/esm/zklogin/publickey.js +0 -265
  893. package/dist/esm/zklogin/signature.js +0 -37
  894. package/dist/esm/zklogin/utils.js +0 -78
  895. package/dist/tsconfig.esm.tsbuildinfo +0 -1
  896. package/dist/tsconfig.tsbuildinfo +0 -1
@@ -1,1324 +1,1110 @@
1
1
  "use strict";
2
- var __defProp = Object.defineProperty;
3
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
- var __getOwnPropNames = Object.getOwnPropertyNames;
5
- var __hasOwnProp = Object.prototype.hasOwnProperty;
6
- var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
7
- var __export = (target, all) => {
8
- for (var name in all)
9
- __defProp(target, name, { get: all[name], enumerable: true });
10
- };
11
- var __copyProps = (to, from, except, desc) => {
12
- if (from && typeof from === "object" || typeof from === "function") {
13
- for (let key of __getOwnPropNames(from))
14
- if (!__hasOwnProp.call(to, key) && key !== except)
15
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
16
- }
17
- return to;
18
- };
19
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
20
- var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
21
- var repository_exports = {};
22
- __export(repository_exports, {
23
- CallRepository: () => CallRepository,
24
- MAX_DATA_SIZE: () => MAX_DATA_SIZE,
25
- MAX_ID_COUNT_ONCE: () => MAX_ID_COUNT_ONCE,
26
- MAX_POLICY_COUNT: () => MAX_POLICY_COUNT,
27
- MAX_POLICY_DESCRIPTION_LEN: () => MAX_POLICY_DESCRIPTION_LEN,
28
- MAX_POLICY_GUARD_COUNT: () => MAX_POLICY_GUARD_COUNT,
29
- MAX_REWARD_COUNT: () => MAX_REWARD_COUNT,
30
- create: () => create,
31
- data: () => data,
32
- data_id_from: () => data_id_from,
33
- data_remove: () => data_remove,
34
- description_set: () => description_set,
35
- newRepository: () => newRepository,
36
- policy: () => policy,
37
- policy_add: () => policy_add,
38
- policy_clear: () => policy_clear,
39
- policy_remove: () => policy_remove,
40
- policy_set: () => policy_set,
41
- reward_add: () => reward_add,
42
- reward_clear: () => reward_clear,
43
- reward_remove: () => reward_remove,
44
- um_set: () => um_set
45
- });
46
- module.exports = __toCommonJS(repository_exports);
47
- var import_common = require("../common.js");
48
- var import_exception = require("../exception.js");
49
- var import_util = require("../util.js");
50
- var import_common2 = require("../common.js");
51
- var import_local = require("../local/index.js");
52
- var import_local2 = require("../local/local.js");
53
- var import_base = require("./base.js");
54
- var import_permission = require("./permission.js");
55
- var import_object = require("../query/object.js");
56
- var import_permission2 = require("./permission.js");
57
- var import_util2 = require("../query/util.js");
58
- var import_received = require("../query/received.js");
59
- const MAX_POLICY_DESCRIPTION_LEN = 500;
60
- const MAX_POLICY_COUNT = 50;
61
- const MAX_POLICY_GUARD_COUNT = 10;
62
- const MAX_DATA_SIZE = 40960;
63
- const MAX_ID_COUNT_ONCE = 100;
64
- const MAX_REWARD_COUNT = 20;
65
- class CallRepository extends import_base.CallBase {
66
- constructor(data2) {
67
- super();
68
- __publicField(this, "data");
69
- __publicField(this, "object_address");
70
- __publicField(this, "permission_address");
71
- __publicField(this, "new_permission_description");
72
- this.data = data2;
73
- }
74
- async prepare(env) {
75
- await super.prepare(env);
76
- if (!this.object_address) {
77
- this.object_address = await (0, import_common2.GetObjectExisted)(this.data?.object);
2
+ // Copyright (c) Wowok.
3
+ // SPDX-License-Identifier: Apache-2.0
4
+ Object.defineProperty(exports, "__esModule", { value: true });
5
+ exports.CallRepository = exports.MAX_REWARD_COUNT = exports.MAX_ID_COUNT_ONCE = exports.MAX_DATA_SIZE = exports.MAX_POLICY_GUARD_COUNT = exports.MAX_POLICY_COUNT = exports.MAX_POLICY_DESCRIPTION_LEN = void 0;
6
+ exports.create = create;
7
+ exports.policy = policy;
8
+ exports.data_id_from = data_id_from;
9
+ exports.um_set = um_set;
10
+ exports.data = data;
11
+ exports.newRepository = newRepository;
12
+ exports.description_set = description_set;
13
+ exports.policy_add = policy_add;
14
+ exports.policy_set = policy_set;
15
+ exports.policy_remove = policy_remove;
16
+ exports.policy_clear = policy_clear;
17
+ exports.reward_add = reward_add;
18
+ exports.reward_remove = reward_remove;
19
+ exports.reward_clear = reward_clear;
20
+ exports.data_remove = data_remove;
21
+ const common_js_1 = require("../common.js");
22
+ const exception_js_1 = require("../exception.js");
23
+ const util_js_1 = require("../util.js");
24
+ const common_js_2 = require("../common.js");
25
+ const index_js_1 = require("../local/index.js");
26
+ const local_js_1 = require("../local/local.js");
27
+ const base_js_1 = require("./base.js");
28
+ const permission_js_1 = require("./permission.js");
29
+ const object_js_1 = require("../query/object.js");
30
+ const permission_js_2 = require("./permission.js");
31
+ const util_js_2 = require("../query/util.js");
32
+ const received_js_1 = require("../query/received.js");
33
+ // ================================================
34
+ // 常量定义
35
+ exports.MAX_POLICY_DESCRIPTION_LEN = 500;
36
+ exports.MAX_POLICY_COUNT = 50;
37
+ exports.MAX_POLICY_GUARD_COUNT = 10;
38
+ exports.MAX_DATA_SIZE = 40960; // 10KB
39
+ exports.MAX_ID_COUNT_ONCE = 100;
40
+ exports.MAX_REWARD_COUNT = 20;
41
+ // ================================================
42
+ // 数据操作类 TODO: submission无需提供id或data的情况,支持的不好,现在仍要填充并检查数据有效性
43
+ class CallRepository extends base_js_1.CallBase {
44
+ data;
45
+ object_address = undefined;
46
+ permission_address = undefined;
47
+ new_permission_description = undefined;
48
+ constructor(data) {
49
+ super();
50
+ this.data = data;
78
51
  }
79
- if (this.object_address) {
80
- await this.update_content(
81
- env,
82
- import_object.ObjectType.Repository,
83
- this.object_address
84
- );
85
- if (!this.content)
86
- (0, import_exception.W_ERROR)(
87
- import_exception.WErrors.InvalidParam,
88
- "CallRepository_Data.data.object:" + this.object_address
89
- );
90
- this.permission_address = this.content.permission;
91
- if (!this.permission_address) {
92
- (0, import_exception.W_ERROR)(
93
- import_exception.WErrors.InvalidParam,
94
- "CallRepository_Data.data.object.permission is empty"
95
- );
96
- }
97
- } else {
98
- const n = (0, import_common2.GetObject)(this.data.object);
99
- this.permission_address = await (0, import_common2.GetObjectExisted)(n?.permission);
100
- this.new_permission_description = (0, import_common2.GetObjectDescription)(
101
- n?.permission
102
- );
103
- }
104
- }
105
- async call(env) {
106
- await this.prepare(env);
107
- const perms = [];
108
- const guards = [];
109
- const add_guard = (guard) => {
110
- if (!guards.includes(guard)) {
111
- guards.push(guard);
112
- }
113
- };
114
- const add_perm = (index) => {
115
- if (this.permission_address && !perms.includes(index)) {
116
- perms.push(index);
117
- }
118
- };
119
- if (this.permission_address && !this.object_address) {
120
- add_perm(import_permission.BuiltinPermissionIndex.REPOSITORY_NEW);
121
- }
122
- if (this.permission_address && this.data?.description != null && this.object_address) {
123
- add_perm(import_permission.BuiltinPermissionIndex.REPOSITORY_DESCRIPTION);
124
- }
125
- if (this.permission_address && this.data?.policies != null) {
126
- add_perm(import_permission.BuiltinPermissionIndex.REPOSITORY_POLICY);
52
+ async prepare(env) {
53
+ await super.prepare(env);
54
+ if (!this.object_address) {
55
+ this.object_address = await (0, common_js_2.GetObjectExisted)(this.data?.object);
56
+ }
57
+ if (this.object_address) {
58
+ await this.update_content(env, object_js_1.ObjectType.Repository, this.object_address);
59
+ if (!this.content)
60
+ (0, exception_js_1.W_ERROR)(exception_js_1.WErrors.InvalidParam, "CallRepository_Data.data.object:" + this.object_address);
61
+ this.permission_address = this.content.permission;
62
+ if (!this.permission_address) {
63
+ (0, exception_js_1.W_ERROR)(exception_js_1.WErrors.InvalidParam, "CallRepository_Data.data.object.permission is empty");
64
+ }
65
+ }
66
+ else {
67
+ const n = (0, common_js_2.GetObject)(this.data.object);
68
+ this.permission_address = await (0, common_js_2.GetObjectExisted)(n?.permission);
69
+ this.new_permission_description = (0, common_js_2.GetObjectDescription)(n?.permission);
70
+ }
127
71
  }
128
- if (this.data?.data_add != null) {
129
- if (!this.content) {
130
- (0, import_exception.W_ERROR)(
131
- import_exception.WErrors.InvalidParam,
132
- "CallRepository_Data.data.data_add fail because the Repository content not ready"
133
- );
134
- }
135
- const p = this.content.policies.find(
136
- (p2) => p2.name === this.data.data_add.name
137
- );
138
- if (!p) {
139
- (0, import_exception.W_ERROR)(
140
- import_exception.WErrors.InvalidParam,
141
- `Invalid policy name: ${this.data.data_add.name}`
142
- );
143
- }
144
- if ("items" in this.data.data_add) {
145
- for (const item of this.data.data_add.items) {
146
- for (const keyData of item.data) {
147
- let idAddress;
148
- if (typeof keyData.id === "number" || typeof keyData.id === "bigint" || typeof keyData.id === "string") {
149
- idAddress = (0, import_util.uint2address)(keyData.id);
150
- } else {
151
- const r = await (0, import_local.GetAccountOrMark_Address)(
152
- keyData.id
153
- );
154
- if (!r) {
155
- (0, import_exception.W_ERROR)(
156
- import_exception.WErrors.InvalidParam,
157
- `Invalid id address: ${keyData.id}`
158
- );
159
- }
160
- idAddress = r;
72
+ async call(env) {
73
+ await this.prepare(env); // prepare first.
74
+ const perms = [];
75
+ const guards = [];
76
+ const add_guard = (guard) => {
77
+ if (!guards.includes(guard)) {
78
+ guards.push(guard);
161
79
  }
162
- keyData.id = idAddress;
163
- }
164
- if (item.write_guard) {
165
- const guardAddress = await import_local2.LocalMark.Instance().get_address(
166
- item.write_guard
167
- );
168
- if (guardAddress) {
169
- if (!p.write_guard.find(
170
- (g) => g.guard === guardAddress
171
- )) {
172
- (0, import_exception.W_ERROR)(
173
- import_exception.WErrors.InvalidParam,
174
- `${item.write_guard} (${guardAddress}) is not match in policy ${p.name} with write_guards: ${p.write_guard.map((g) => g.guard).join(", ")}`
175
- );
176
- }
177
- item.write_guard = guardAddress;
178
- add_guard(guardAddress);
179
- } else {
180
- (0, import_exception.W_ERROR)(
181
- import_exception.WErrors.InvalidParam,
182
- `Invalid write_guard address: ${item.write_guard}`
183
- );
80
+ };
81
+ const add_perm = (index) => {
82
+ if (this.permission_address && !perms.includes(index)) {
83
+ perms.push(index);
184
84
  }
185
- }
85
+ };
86
+ if (this.permission_address && !this.object_address) {
87
+ add_perm(permission_js_1.BuiltinPermissionIndex.REPOSITORY_NEW);
186
88
  }
187
- } else if (this.data.data_add.write_guard) {
188
- const guardAddress = await import_local2.LocalMark.Instance().get_address(
189
- this.data.data_add.write_guard
190
- );
191
- if (guardAddress) {
192
- if (!p.write_guard.find((g) => g.guard === guardAddress)) {
193
- (0, import_exception.W_ERROR)(
194
- import_exception.WErrors.InvalidParam,
195
- `Invalid write_guard address: ${this.data.data_add.write_guard} in policy ${p.name}`
196
- );
197
- }
198
- this.data.data_add.write_guard = guardAddress;
199
- add_guard(guardAddress);
200
- } else {
201
- (0, import_exception.W_ERROR)(
202
- import_exception.WErrors.InvalidParam,
203
- `Invalid write_guard address: ${this.data.data_add.write_guard}`
204
- );
89
+ if (this.permission_address &&
90
+ this.data?.description != null &&
91
+ this.object_address) {
92
+ add_perm(permission_js_1.BuiltinPermissionIndex.REPOSITORY_DESCRIPTION);
205
93
  }
206
- }
207
- }
208
- if (this.data?.data_remove != null) {
209
- const p = this.content.policies.find(
210
- (p2) => p2.name === this.data.data_remove.name
211
- );
212
- if (!p) {
213
- (0, import_exception.W_ERROR)(
214
- import_exception.WErrors.InvalidParam,
215
- `Invalid policy name: ${this.data.data_remove.name}`
216
- );
217
- }
218
- if ("items" in this.data.data_remove) {
219
- for (const item of this.data.data_remove.items) {
220
- const idAddresses = [];
221
- for (const id of item.id) {
222
- let idAddress;
223
- if (typeof id === "number" || typeof id === "bigint" || typeof id === "string") {
224
- idAddress = (0, import_util.uint2address)(id);
225
- } else {
226
- const r = await (0, import_local.GetAccountOrMark_Address)(id);
227
- if (!r) {
228
- (0, import_exception.W_ERROR)(
229
- import_exception.WErrors.InvalidParam,
230
- `Invalid id address: ${id}`
231
- );
232
- }
233
- idAddress = r;
94
+ if (this.permission_address && this.data?.policies != null) {
95
+ add_perm(permission_js_1.BuiltinPermissionIndex.REPOSITORY_POLICY);
96
+ }
97
+ // 对id和guard做地址转换和检查
98
+ if (this.data?.data_add != null) {
99
+ if (!this.content) {
100
+ (0, exception_js_1.W_ERROR)(exception_js_1.WErrors.InvalidParam, "CallRepository_Data.data.data_add fail because the Repository content not ready");
101
+ }
102
+ const p = this.content.policies.find((p) => p.name === this.data.data_add.name);
103
+ if (!p) {
104
+ (0, exception_js_1.W_ERROR)(exception_js_1.WErrors.InvalidParam, `Invalid policy name: ${this.data.data_add.name}`);
105
+ }
106
+ // 处理 data_add 中的数据
107
+ if ("items" in this.data.data_add) {
108
+ // 遍历 items 数组
109
+ for (const item of this.data.data_add.items) {
110
+ // 遍历 data 数组,处理 id 字段
111
+ for (const keyData of item.data) {
112
+ // id 转换为地址
113
+ let idAddress;
114
+ if (typeof keyData.id === "number" ||
115
+ typeof keyData.id === "bigint" ||
116
+ typeof keyData.id === "string") {
117
+ idAddress = (0, util_js_1.uint2address)(keyData.id);
118
+ }
119
+ else {
120
+ const r = await (0, index_js_1.GetAccountOrMark_Address)(keyData.id);
121
+ if (!r) {
122
+ (0, exception_js_1.W_ERROR)(exception_js_1.WErrors.InvalidParam, `Invalid id address: ${keyData.id}`);
123
+ }
124
+ idAddress = r;
125
+ }
126
+ keyData.id = idAddress;
127
+ }
128
+ // 处理 write_guard 字段
129
+ if (item.write_guard) {
130
+ // 将 write_guard 转换为地址
131
+ const guardAddress = await local_js_1.LocalMark.Instance().get_address(item.write_guard);
132
+ if (guardAddress) {
133
+ if (!p.write_guard.find((g) => g.guard === guardAddress)) {
134
+ (0, exception_js_1.W_ERROR)(exception_js_1.WErrors.InvalidParam, `${item.write_guard} (${guardAddress}) is not match in policy ${p.name} with write_guards: ${p.write_guard.map((g) => g.guard).join(", ")}`);
135
+ }
136
+ item.write_guard = guardAddress;
137
+ add_guard(guardAddress);
138
+ }
139
+ else {
140
+ (0, exception_js_1.W_ERROR)(exception_js_1.WErrors.InvalidParam, `Invalid write_guard address: ${item.write_guard}`);
141
+ }
142
+ }
143
+ }
234
144
  }
235
- idAddresses.push(idAddress);
236
- }
237
- item.id = idAddresses;
238
- if (item.write_guard) {
239
- const guardAddress = await import_local2.LocalMark.Instance().get_address(
240
- item.write_guard
241
- );
242
- if (guardAddress) {
243
- if (!p.write_guard.find(
244
- (g) => g.guard === guardAddress
245
- )) {
246
- (0, import_exception.W_ERROR)(
247
- import_exception.WErrors.InvalidParam,
248
- `Invalid write_guard address: ${item.write_guard} in policy ${p.name}`
249
- );
250
- }
251
- item.write_guard = guardAddress;
252
- add_guard(guardAddress);
253
- } else {
254
- (0, import_exception.W_ERROR)(
255
- import_exception.WErrors.InvalidParam,
256
- `Invalid write_guard address: ${item.write_guard}`
257
- );
145
+ else if (this.data.data_add.write_guard) {
146
+ // 处理 SignerOrClock 类型的 write_guard
147
+ const guardAddress = await local_js_1.LocalMark.Instance().get_address(this.data.data_add.write_guard);
148
+ if (guardAddress) {
149
+ if (!p.write_guard.find((g) => g.guard === guardAddress)) {
150
+ (0, exception_js_1.W_ERROR)(exception_js_1.WErrors.InvalidParam, `Invalid write_guard address: ${this.data.data_add.write_guard} in policy ${p.name}`);
151
+ }
152
+ this.data.data_add.write_guard = guardAddress;
153
+ add_guard(guardAddress);
154
+ }
155
+ else {
156
+ (0, exception_js_1.W_ERROR)(exception_js_1.WErrors.InvalidParam, `Invalid write_guard address: ${this.data.data_add.write_guard}`);
157
+ }
258
158
  }
259
- }
260
159
  }
261
- } else {
262
- if (this.data.data_remove.write_guard) {
263
- const guardAddress = await import_local2.LocalMark.Instance().get_address(
264
- this.data.data_remove.write_guard
265
- );
266
- if (guardAddress) {
267
- if (!p.write_guard.find(
268
- (g) => g.guard === guardAddress
269
- )) {
270
- (0, import_exception.W_ERROR)(
271
- import_exception.WErrors.InvalidParam,
272
- `Invalid write_guard address: ${this.data.data_remove.write_guard} in policy ${p.name}`
273
- );
160
+ if (this.data?.data_remove != null) {
161
+ const p = this.content.policies.find((p) => p.name === this.data.data_remove.name);
162
+ if (!p) {
163
+ (0, exception_js_1.W_ERROR)(exception_js_1.WErrors.InvalidParam, `Invalid policy name: ${this.data.data_remove.name}`);
164
+ }
165
+ // 处理 data_remove 中的数据
166
+ if ("items" in this.data.data_remove) {
167
+ // 遍历 items 数组
168
+ for (const item of this.data.data_remove.items) {
169
+ // 处理 id 数组,转换每个 id 为地址
170
+ const idAddresses = [];
171
+ for (const id of item.id) {
172
+ let idAddress;
173
+ if (typeof id === "number" ||
174
+ typeof id === "bigint" ||
175
+ typeof id === "string") {
176
+ idAddress = (0, util_js_1.uint2address)(id);
177
+ }
178
+ else {
179
+ const r = await (0, index_js_1.GetAccountOrMark_Address)(id);
180
+ if (!r) {
181
+ (0, exception_js_1.W_ERROR)(exception_js_1.WErrors.InvalidParam, `Invalid id address: ${id}`);
182
+ }
183
+ idAddress = r;
184
+ }
185
+ idAddresses.push(idAddress);
186
+ }
187
+ item.id = idAddresses;
188
+ // 处理 write_guard 字段
189
+ if (item.write_guard) {
190
+ // 将 write_guard 转换为地址
191
+ const guardAddress = await local_js_1.LocalMark.Instance().get_address(item.write_guard);
192
+ if (guardAddress) {
193
+ if (!p.write_guard.find((g) => g.guard === guardAddress)) {
194
+ (0, exception_js_1.W_ERROR)(exception_js_1.WErrors.InvalidParam, `Invalid write_guard address: ${item.write_guard} in policy ${p.name}`);
195
+ }
196
+ item.write_guard = guardAddress;
197
+ add_guard(guardAddress);
198
+ }
199
+ else {
200
+ (0, exception_js_1.W_ERROR)(exception_js_1.WErrors.InvalidParam, `Invalid write_guard address: ${item.write_guard}`);
201
+ }
202
+ }
203
+ }
204
+ }
205
+ else {
206
+ if (this.data.data_remove.write_guard) {
207
+ // 处理 SignerOrClockBase 类型的 write_guard
208
+ const guardAddress = await local_js_1.LocalMark.Instance().get_address(this.data.data_remove.write_guard);
209
+ if (guardAddress) {
210
+ if (!p.write_guard.find((g) => g.guard === guardAddress)) {
211
+ (0, exception_js_1.W_ERROR)(exception_js_1.WErrors.InvalidParam, `Invalid write_guard address: ${this.data.data_remove.write_guard} in policy ${p.name}`);
212
+ }
213
+ this.data.data_remove.write_guard = guardAddress;
214
+ add_guard(guardAddress);
215
+ }
216
+ else {
217
+ (0, exception_js_1.W_ERROR)(exception_js_1.WErrors.InvalidParam, `Invalid write_guard address: ${this.data.data_remove.write_guard}`);
218
+ }
219
+ }
274
220
  }
275
- this.data.data_remove.write_guard = guardAddress;
276
- add_guard(guardAddress);
277
- } else {
278
- (0, import_exception.W_ERROR)(
279
- import_exception.WErrors.InvalidParam,
280
- `Invalid write_guard address: ${this.data.data_remove.write_guard}`
281
- );
282
- }
283
221
  }
284
- }
285
- }
286
- if (this.permission_address && this.data?.rewards != null) {
287
- add_perm(import_permission.BuiltinPermissionIndex.REPOSITORY_REWARD);
288
- }
289
- if (this.permission_address && this.data?.owner_receive != null) {
290
- add_perm(import_permission.BuiltinPermissionIndex.REPOSITORY_OWNER_RECEIVE);
291
- }
292
- if (this.permission_address && this.data?.um !== void 0) {
293
- add_perm(import_permission.BuiltinPermissionIndex.REPOSITORY_UM);
294
- }
295
- if (this.permission_address || guards.length > 0) {
296
- return await this.check_permission_and_call(
297
- env,
298
- this.permission_address,
299
- perms,
300
- guards
301
- );
302
- }
303
- return await this.exec(env);
304
- }
305
- async operate(env, tx, passport, submission) {
306
- let permission = this.permission_address;
307
- let object = this.object_address;
308
- if (!this.object_address) {
309
- if (!permission) {
310
- permission = (0, import_permission.newPermission)(
311
- tx,
312
- this.new_permission_description ?? ""
313
- );
314
- }
315
- if (permission) {
316
- object = newRepository(
317
- tx,
318
- (0, import_common.toTxObject)(tx, permission),
319
- this.data?.description ?? "",
320
- passport
321
- );
322
- }
323
- }
324
- if (!object || !permission) {
325
- (0, import_exception.W_ERROR)(
326
- import_exception.WErrors.InvalidParam,
327
- "CallRepository_Data.data.object:" + this.object_address
328
- );
329
- }
330
- if (this.data?.description != null && this.object_address) {
331
- description_set(
332
- tx,
333
- object,
334
- permission,
335
- this.data.description,
336
- passport
337
- );
222
+ if (this.permission_address && this.data?.rewards != null) {
223
+ add_perm(permission_js_1.BuiltinPermissionIndex.REPOSITORY_REWARD);
224
+ }
225
+ if (this.permission_address && this.data?.owner_receive != null) {
226
+ add_perm(permission_js_1.BuiltinPermissionIndex.REPOSITORY_OWNER_RECEIVE);
227
+ }
228
+ if (this.permission_address && this.data?.um !== undefined) {
229
+ add_perm(permission_js_1.BuiltinPermissionIndex.REPOSITORY_UM);
230
+ }
231
+ if (this.permission_address || guards.length > 0) {
232
+ return await this.check_permission_and_call(env, this.permission_address, perms, guards);
233
+ }
234
+ return await this.exec(env);
338
235
  }
339
- if (this.data?.policies != null) {
340
- if (this.data.policies.op === "set" || this.data.policies.op === "add") {
341
- await Promise.all(
342
- this.data.policies.policy.map(async (p) => {
343
- await Promise.all(
344
- p.write_guard.map(async (g) => {
345
- const r = await import_local2.LocalMark.Instance().get_address(
346
- g.guard
347
- );
348
- if (r) {
349
- g.guard = r;
350
- } else {
351
- (0, import_exception.W_ERROR)(
352
- import_exception.WErrors.InvalidParam,
353
- `Invalid write_guard address: ${g.guard}`
354
- );
236
+ async operate(env, tx, passport, submission) {
237
+ let permission = this.permission_address;
238
+ let object = this.object_address;
239
+ //console.dir(this.data, { depth: null });
240
+ if (!this.object_address) {
241
+ if (!permission) {
242
+ permission = (0, permission_js_1.newPermission)(tx, this.new_permission_description ?? "");
243
+ }
244
+ if (permission) {
245
+ object = newRepository(tx, (0, common_js_1.toTxObject)(tx, permission), this.data?.description ?? "", passport);
246
+ }
247
+ }
248
+ if (!object || !permission) {
249
+ (0, exception_js_1.W_ERROR)(exception_js_1.WErrors.InvalidParam, "CallRepository_Data.data.object:" + this.object_address);
250
+ }
251
+ if (this.data?.description != null && this.object_address) {
252
+ description_set(tx, object, permission, this.data.description, passport);
253
+ }
254
+ if (this.data?.policies != null) {
255
+ if (this.data.policies.op === "set" ||
256
+ this.data.policies.op === "add") {
257
+ // 使用map和Promise.all并行处理,提高效率
258
+ await Promise.all(this.data.policies.policy.map(async (p) => {
259
+ // 处理 write_guard 数组
260
+ await Promise.all(p.write_guard.map(async (g) => {
261
+ const r = await local_js_1.LocalMark.Instance().get_address(g.guard);
262
+ if (r) {
263
+ g.guard = r;
264
+ }
265
+ else {
266
+ (0, exception_js_1.W_ERROR)(exception_js_1.WErrors.InvalidParam, `Invalid write_guard address: ${g.guard}`);
267
+ }
268
+ }));
269
+ // 处理 quote_guard 字段
270
+ if (p.quote_guard &&
271
+ typeof p.quote_guard === "string") {
272
+ const r = await local_js_1.LocalMark.Instance().get_address(p.quote_guard);
273
+ if (r) {
274
+ p.quote_guard = r;
275
+ }
276
+ else {
277
+ (0, exception_js_1.W_ERROR)(exception_js_1.WErrors.InvalidParam, `Invalid quote_guard address: ${p.quote_guard}`);
278
+ }
279
+ }
280
+ }));
281
+ }
282
+ switch (this.data.policies.op) {
283
+ case "set": {
284
+ policy_set(tx, object, permission, this.data.policies.policy, passport);
285
+ break;
286
+ }
287
+ case "add": {
288
+ policy_add(tx, object, permission, this.data.policies.policy, passport);
289
+ break;
290
+ }
291
+ case "remove": {
292
+ policy_remove(tx, object, permission, this.data.policies.policy, passport);
293
+ break;
294
+ }
295
+ case "clear": {
296
+ policy_clear(tx, object, permission, passport);
297
+ break;
355
298
  }
356
- })
357
- );
358
- if (p.quote_guard && typeof p.quote_guard === "string") {
359
- const r = await import_local2.LocalMark.Instance().get_address(
360
- p.quote_guard
361
- );
362
- if (r) {
363
- p.quote_guard = r;
364
- } else {
365
- (0, import_exception.W_ERROR)(
366
- import_exception.WErrors.InvalidParam,
367
- `Invalid quote_guard address: ${p.quote_guard}`
368
- );
369
- }
370
299
  }
371
- })
372
- );
373
- }
374
- switch (this.data.policies.op) {
375
- case "set": {
376
- policy_set(
377
- tx,
378
- object,
379
- permission,
380
- this.data.policies.policy,
381
- passport
382
- );
383
- break;
384
300
  }
385
- case "add": {
386
- policy_add(
387
- tx,
388
- object,
389
- permission,
390
- this.data.policies.policy,
391
- passport
392
- );
393
- break;
301
+ if (this.data?.data_add != null && this.content) {
302
+ // 查找 policy 中的 write_guard
303
+ const policy = this.content.policies.find((p) => p.name === this.data.data_add.name);
304
+ if (!policy) {
305
+ (0, exception_js_1.W_ERROR)(exception_js_1.WErrors.InvalidParam, `policy ${this.data.data_add.name} not found in policies ${this.content.policies.map((p) => p.name)}`);
306
+ }
307
+ if ("items" in this.data.data_add) {
308
+ data(tx, object, policy, this.data.data_add.items, passport);
309
+ }
310
+ else {
311
+ data_id_from(tx, object, policy, this.data.data_add, passport);
312
+ }
394
313
  }
395
- case "remove": {
396
- policy_remove(
397
- tx,
398
- object,
399
- permission,
400
- this.data.policies.policy,
401
- passport
402
- );
403
- break;
314
+ if (this.data?.data_remove != null) {
315
+ // 查找 policy 中的 write_guard
316
+ const policy = this.content.policies.find((p) => p.name === this.data.data_remove.name);
317
+ if (!policy) {
318
+ (0, exception_js_1.W_ERROR)(exception_js_1.WErrors.InvalidParam, `policy ${this.data.data_remove.name} not found in policies ${this.content.policies.map((p) => p.name)}`);
319
+ }
320
+ if ("items" in this.data.data_remove) {
321
+ data_remove(tx, object, policy, { items: this.data.data_remove.items }, passport);
322
+ }
323
+ else {
324
+ data_remove(tx, object, policy, { write_guard: this.data.data_remove.write_guard }, passport);
325
+ }
404
326
  }
405
- case "clear": {
406
- policy_clear(tx, object, permission, passport);
407
- break;
327
+ if (this.data?.rewards != null) {
328
+ switch (this.data.rewards.op) {
329
+ case "set":
330
+ case "add": {
331
+ if (this.data.rewards.objects.length > exports.MAX_REWARD_COUNT) {
332
+ (0, exception_js_1.W_ERROR)(exception_js_1.WErrors.InvalidParam, `rewards count exceeds maximum limit ${exports.MAX_REWARD_COUNT}`);
333
+ }
334
+ if (this.data.rewards.op === "set") {
335
+ reward_clear(tx, object, permission, passport);
336
+ }
337
+ // 无需localmark查询
338
+ const rewards = await (0, util_js_2.queryObjectsWithType)(env, this.data.rewards.objects, object_js_1.ObjectType.Reward, "reward::Reward", false);
339
+ rewards.forEach((reward) => {
340
+ reward_add(tx, object, permission, reward.object, reward.type, passport);
341
+ });
342
+ break;
343
+ }
344
+ case "remove": {
345
+ if (this.data.rewards.objects.length > exports.MAX_REWARD_COUNT) {
346
+ (0, exception_js_1.W_ERROR)(exception_js_1.WErrors.InvalidParam, `rewards count exceeds maximum limit ${exports.MAX_REWARD_COUNT}`);
347
+ }
348
+ const rewardAddrs = await local_js_1.LocalMark.Instance().get_many_address_availables(this.data.rewards.objects);
349
+ reward_remove(tx, object, permission, rewardAddrs, passport);
350
+ break;
351
+ }
352
+ case "clear": {
353
+ reward_clear(tx, object, permission, passport);
354
+ break;
355
+ }
356
+ }
408
357
  }
409
- }
410
- }
411
- if (this.data?.data_add != null && this.content) {
412
- const policy2 = this.content.policies.find(
413
- (p) => p.name === this.data.data_add.name
414
- );
415
- if (!policy2) {
416
- (0, import_exception.W_ERROR)(
417
- import_exception.WErrors.InvalidParam,
418
- `policy ${this.data.data_add.name} not found in policies ${this.content.policies.map((p) => p.name)}`
419
- );
420
- }
421
- if ("items" in this.data.data_add) {
422
- data(tx, object, policy2, this.data.data_add.items, passport);
423
- } else {
424
- data_id_from(
425
- tx,
426
- object,
427
- policy2,
428
- this.data.data_add,
429
- passport
430
- );
431
- }
432
- }
433
- if (this.data?.data_remove != null) {
434
- const policy2 = this.content.policies.find(
435
- (p) => p.name === this.data.data_remove.name
436
- );
437
- if (!policy2) {
438
- (0, import_exception.W_ERROR)(
439
- import_exception.WErrors.InvalidParam,
440
- `policy ${this.data.data_remove.name} not found in policies ${this.content.policies.map((p) => p.name)}`
441
- );
442
- }
443
- if ("items" in this.data.data_remove) {
444
- data_remove(
445
- tx,
446
- object,
447
- policy2,
448
- { items: this.data.data_remove.items },
449
- passport
450
- );
451
- } else {
452
- data_remove(
453
- tx,
454
- object,
455
- policy2,
456
- { write_guard: this.data.data_remove.write_guard },
457
- passport
458
- );
459
- }
460
- }
461
- if (this.data?.rewards != null) {
462
- switch (this.data.rewards.op) {
463
- case "set":
464
- case "add": {
465
- if (this.data.rewards.objects.length > MAX_REWARD_COUNT) {
466
- (0, import_exception.W_ERROR)(
467
- import_exception.WErrors.InvalidParam,
468
- `rewards count exceeds maximum limit ${MAX_REWARD_COUNT}`
469
- );
470
- }
471
- if (this.data.rewards.op === "set") {
472
- reward_clear(tx, object, permission, passport);
473
- }
474
- const rewards = await (0, import_util2.queryObjectsWithType)(
475
- env,
476
- this.data.rewards.objects,
477
- import_object.ObjectType.Reward,
478
- "reward::Reward",
479
- false
480
- );
481
- rewards.forEach((reward) => {
482
- reward_add(
483
- tx,
484
- object,
485
- permission,
486
- reward.object,
487
- reward.type,
488
- passport
489
- );
490
- });
491
- break;
358
+ if (this.data.owner_receive != null && this.object_address) {
359
+ if (this.data.owner_receive === "recently") {
360
+ this.data.owner_receive = await (0, received_js_1.query_received)({
361
+ object: this.object_address,
362
+ all_type: true,
363
+ });
364
+ }
365
+ await (0, util_js_1.owner_receive)(tx, object, permission, this.data.owner_receive, undefined, (name) => `${common_js_1.PackageAddress}::repository::${name}`, passport);
492
366
  }
493
- case "remove": {
494
- if (this.data.rewards.objects.length > MAX_REWARD_COUNT) {
495
- (0, import_exception.W_ERROR)(
496
- import_exception.WErrors.InvalidParam,
497
- `rewards count exceeds maximum limit ${MAX_REWARD_COUNT}`
498
- );
499
- }
500
- const rewardAddrs = await import_local2.LocalMark.Instance().get_many_address_availables(
501
- this.data.rewards.objects
502
- );
503
- reward_remove(
504
- tx,
505
- object,
506
- permission,
507
- rewardAddrs,
508
- passport
509
- );
510
- break;
367
+ // 处理 um
368
+ if (this.data.um !== undefined) {
369
+ let um_address = null;
370
+ if (this.data.um) {
371
+ um_address =
372
+ (await local_js_1.LocalMark.Instance().get_address(this.data.um)) ||
373
+ null;
374
+ if (!um_address) {
375
+ (0, exception_js_1.W_ERROR)(exception_js_1.WErrors.InvalidParam, "CallRepository_Data.data.um:" + this.data.um);
376
+ }
377
+ }
378
+ um_set(tx, object, permission, um_address, passport);
511
379
  }
512
- case "clear": {
513
- reward_clear(tx, object, permission, passport);
514
- break;
380
+ if (!this.permission_address) {
381
+ const p = (0, common_js_2.GetObject)(this.data?.object);
382
+ await this.new_with_mark(env, tx, object_js_1.ObjectType.Permission, (0, permission_js_2.create)(tx, permission), (0, common_js_2.GetObject)(p.permission));
515
383
  }
516
- }
517
- }
518
- if (this.data.owner_receive != null && this.object_address) {
519
- if (this.data.owner_receive === "recently") {
520
- this.data.owner_receive = await (0, import_received.query_received)({
521
- object: this.object_address,
522
- all_type: true
523
- });
524
- }
525
- await (0, import_util.owner_receive)(
526
- tx,
527
- object,
528
- permission,
529
- this.data.owner_receive,
530
- void 0,
531
- (name) => `${import_common.PackageAddress}::repository::${name}`,
532
- passport
533
- );
534
- }
535
- if (this.data.um !== void 0) {
536
- let um_address = null;
537
- if (this.data.um) {
538
- um_address = await import_local2.LocalMark.Instance().get_address(this.data.um) || null;
539
- if (!um_address) {
540
- (0, import_exception.W_ERROR)(
541
- import_exception.WErrors.InvalidParam,
542
- "CallRepository_Data.data.um:" + this.data.um
543
- );
384
+ if (!this.object_address) {
385
+ await this.new_with_mark(env, tx, object_js_1.ObjectType.Repository, create(tx, object), (0, common_js_2.GetObject)(this.data?.object));
544
386
  }
545
- }
546
- um_set(tx, object, permission, um_address, passport);
547
- }
548
- if (!this.permission_address) {
549
- const p = (0, import_common2.GetObject)(this.data?.object);
550
- await this.new_with_mark(
551
- env,
552
- tx,
553
- import_object.ObjectType.Permission,
554
- (0, import_permission2.create)(tx, permission),
555
- (0, import_common2.GetObject)(p.permission)
556
- );
557
387
  }
558
- if (!this.object_address) {
559
- await this.new_with_mark(
560
- env,
561
- tx,
562
- import_object.ObjectType.Repository,
563
- create(tx, object),
564
- (0, import_common2.GetObject)(this.data?.object)
565
- );
566
- }
567
- }
568
388
  }
389
+ exports.CallRepository = CallRepository;
569
390
  function create(tx, repository) {
570
- (0, import_util.validObjects)([repository]);
571
- return tx.moveCall({
572
- target: (0, import_common.repositoryFn)("create"),
573
- arguments: [(0, import_common.toTxObject)(tx, repository)]
574
- });
391
+ (0, util_js_1.validObjects)([repository]);
392
+ return tx.moveCall({
393
+ target: (0, common_js_1.repositoryFn)("create"),
394
+ arguments: [(0, common_js_1.toTxObject)(tx, repository)],
395
+ });
575
396
  }
576
397
  function policy_guard(tx, param) {
577
- (0, import_util.validObjects)([param.guard]);
578
- if (param.id_from_submission != null && !(0, import_common.isValidU8)(param.id_from_submission)) {
579
- (0, import_exception.W_ERROR)(
580
- import_exception.WErrors.IsValidU8,
581
- `Id from submission ${param.id_from_submission} is not valid`
582
- );
583
- }
584
- if (param.data_from_submission != null && !(0, import_common.isValidU8)(param.data_from_submission)) {
585
- (0, import_exception.W_ERROR)(
586
- import_exception.WErrors.IsValidU8,
587
- `Data from submission ${param.data_from_submission} is not valid`
588
- );
589
- }
590
- return tx.moveCall({
591
- target: (0, import_common.repositoryFn)("policy_guard"),
592
- arguments: [
593
- (0, import_common.toTxObject)(tx, param.guard),
594
- tx.pure.option("u8", param.id_from_submission ?? null),
595
- tx.pure.option("u8", param.data_from_submission ?? null)
596
- ]
597
- });
598
- }
599
- function policy(tx, param) {
600
- if (typeof param.name === "string" && !(0, import_common.isValidName)(param.name)) {
601
- (0, import_exception.W_ERROR)(import_exception.WErrors.InvalidParam, `Policy name ${param.name} is not valid`);
602
- }
603
- if (typeof param.description === "string" && !(0, import_common.isValidDescription)(param.description)) {
604
- (0, import_exception.W_ERROR)(
605
- import_exception.WErrors.IsValidDescription,
606
- `Description exceeds maximum length ${import_common.MAX_DESCRIPTION_LENGTH}`
607
- );
608
- }
609
- (0, import_util.validObjects)([
610
- param.quote_guard,
611
- ...param.write_guard.map((guard) => guard.guard)
612
- ]);
613
- const idFrom = (0, import_object.parseIdFrom)(param.id_from);
614
- const obj = tx.moveCall({
615
- target: (0, import_common.repositoryFn)("policy"),
616
- arguments: [
617
- (0, import_common.toTxString)(tx, param.name),
618
- (0, import_common.toTxString)(tx, param.description),
619
- tx.pure.u8(idFrom),
620
- tx.pure.u8(param.value_type)
621
- ]
622
- });
623
- if (param.quote_guard) {
624
- tx.moveCall({
625
- target: (0, import_common.repositoryFn)("policy_quote_guard_set"),
626
- arguments: [obj, (0, import_common.toTxObject)(tx, param.quote_guard)]
627
- });
628
- } else if (param.quote_guard === null) {
629
- tx.moveCall({
630
- target: (0, import_common.repositoryFn)("policy_quote_guard_none"),
631
- arguments: [obj]
632
- });
633
- }
634
- if (param.write_guard.length > 0) {
635
- tx.moveCall({
636
- target: (0, import_common.repositoryFn)("policy_write_guard_set"),
637
- arguments: [
638
- obj,
639
- tx.makeMoveVec({
640
- elements: param.write_guard.map(
641
- (guard) => policy_guard(tx, guard)
642
- ),
643
- type: `${import_common.PackageAddress}::repository::PolicyGuard`
644
- })
645
- ]
398
+ (0, util_js_1.validObjects)([param.guard]);
399
+ if (param.id_from_submission != null &&
400
+ !(0, common_js_1.isValidU8)(param.id_from_submission)) {
401
+ (0, exception_js_1.W_ERROR)(exception_js_1.WErrors.IsValidU8, `Id from submission ${param.id_from_submission} is not valid`);
402
+ }
403
+ if (param.data_from_submission != null &&
404
+ !(0, common_js_1.isValidU8)(param.data_from_submission)) {
405
+ (0, exception_js_1.W_ERROR)(exception_js_1.WErrors.IsValidU8, `Data from submission ${param.data_from_submission} is not valid`);
406
+ }
407
+ return tx.moveCall({
408
+ target: (0, common_js_1.repositoryFn)("policy_guard"),
409
+ arguments: [
410
+ (0, common_js_1.toTxObject)(tx, param.guard),
411
+ tx.pure.option("u8", param.id_from_submission ?? null),
412
+ tx.pure.option("u8", param.data_from_submission ?? null),
413
+ ],
646
414
  });
647
- }
648
- return obj;
649
415
  }
650
- async function data_id_from(tx, repository, policy2, data2, passport) {
651
- const idFrom = (0, import_object.parseIdFrom)(policy2.id_from);
652
- if (idFrom === import_object.IdFrom.None) {
653
- (0, import_exception.W_ERROR)(
654
- import_exception.WErrors.InvalidParam,
655
- `id_from must be set when id_from is IdFrom.None`
656
- );
657
- }
658
- if (data2.write_guard) {
659
- if (!passport) {
660
- (0, import_exception.W_ERROR)(
661
- import_exception.WErrors.InvalidParam,
662
- `passport is required when write_guard is specified`
663
- );
416
+ function policy(tx, param) {
417
+ if (typeof param.name === "string" && !(0, common_js_1.isValidName)(param.name)) {
418
+ (0, exception_js_1.W_ERROR)(exception_js_1.WErrors.InvalidParam, `Policy name ${param.name} is not valid`);
664
419
  }
665
- if (policy2.write_guard.find(
666
- (guard) => guard.guard === data2.write_guard
667
- )) {
668
- const policyValueType1 = (0, import_common.parseValueType)(policy2.value_type);
669
- tx.moveCall({
670
- target: (0, import_common.repositoryFn)("data_when_id_from_set_with_passport"),
671
- arguments: [
672
- (0, import_common.toTxObject)(tx, repository),
673
- (0, import_common.toTxString)(tx, policy2.name),
674
- tx.pure.address(data2.write_guard),
675
- tx.pure.vector(
676
- "u8",
677
- await (0, import_util.valueToBcsBytes)(policyValueType1, data2.data)
678
- ),
679
- tx.object.clock(),
680
- passport
681
- ]
682
- });
683
- } else {
684
- (0, import_exception.W_ERROR)(
685
- import_exception.WErrors.InvalidParam,
686
- `Write guard ${data2.write_guard} is not in policy ${policy2.name}`
687
- );
420
+ if (typeof param.description === "string" &&
421
+ !(0, common_js_1.isValidDescription)(param.description)) {
422
+ (0, exception_js_1.W_ERROR)(exception_js_1.WErrors.IsValidDescription, `Description exceeds maximum length ${common_js_1.MAX_DESCRIPTION_LENGTH}`);
688
423
  }
689
- } else {
690
- if (policy2.write_guard.length === 0) {
691
- const policyValueType2 = (0, import_common.parseValueType)(policy2.value_type);
692
- tx.moveCall({
693
- target: (0, import_common.repositoryFn)("data_when_id_from_set"),
424
+ (0, util_js_1.validObjects)([
425
+ param.quote_guard,
426
+ ...param.write_guard.map((guard) => guard.guard),
427
+ ]);
428
+ const idFrom = (0, object_js_1.parseIdFrom)(param.id_from);
429
+ const obj = tx.moveCall({
430
+ target: (0, common_js_1.repositoryFn)("policy"),
694
431
  arguments: [
695
- (0, import_common.toTxObject)(tx, repository),
696
- (0, import_common.toTxString)(tx, policy2.name),
697
- tx.pure.vector(
698
- "u8",
699
- await (0, import_util.valueToBcsBytes)(policyValueType2, data2.data)
700
- ),
701
- tx.object.clock()
702
- ]
703
- });
704
- } else {
705
- (0, import_exception.W_ERROR)(
706
- import_exception.WErrors.InvalidParam,
707
- `specify write guard in policy ${policy2.write_guard.map((guard) => guard.guard)}`
708
- );
432
+ (0, common_js_1.toTxString)(tx, param.name),
433
+ (0, common_js_1.toTxString)(tx, param.description),
434
+ tx.pure.u8(idFrom),
435
+ tx.pure.u8(param.value_type),
436
+ ],
437
+ });
438
+ if (param.quote_guard) {
439
+ // some
440
+ tx.moveCall({
441
+ target: (0, common_js_1.repositoryFn)("policy_quote_guard_set"),
442
+ arguments: [obj, (0, common_js_1.toTxObject)(tx, param.quote_guard)],
443
+ });
444
+ }
445
+ else if (param.quote_guard === null) {
446
+ //@ null
447
+ tx.moveCall({
448
+ target: (0, common_js_1.repositoryFn)("policy_quote_guard_none"),
449
+ arguments: [obj],
450
+ });
451
+ }
452
+ if (param.write_guard.length > 0) {
453
+ tx.moveCall({
454
+ target: (0, common_js_1.repositoryFn)("policy_write_guard_set"),
455
+ arguments: [
456
+ obj,
457
+ tx.makeMoveVec({
458
+ elements: param.write_guard.map((guard) => policy_guard(tx, guard)),
459
+ type: `${common_js_1.PackageAddress}::repository::PolicyGuard`,
460
+ }),
461
+ ],
462
+ });
709
463
  }
710
- }
464
+ return obj;
711
465
  }
712
- function um_set(tx, repository, permission, um, passport) {
713
- (0, import_util.validObjects)([repository, permission]);
714
- if (um) {
715
- if (passport) {
716
- tx.moveCall({
717
- target: (0, import_common.repositoryFn)(`um_set_with_passport`),
718
- arguments: [
719
- (0, import_common.toTxObject)(tx, repository),
720
- (0, import_common.toTxObject)(tx, permission),
721
- passport,
722
- (0, import_common.toTxObject)(tx, um),
723
- tx.object.mutRegistrar(),
724
- tx.object.clock()
725
- ]
726
- });
727
- } else {
728
- tx.moveCall({
729
- target: (0, import_common.repositoryFn)(`um_set`),
730
- arguments: [
731
- (0, import_common.toTxObject)(tx, repository),
732
- (0, import_common.toTxObject)(tx, permission),
733
- (0, import_common.toTxObject)(tx, um),
734
- tx.object.mutRegistrar(),
735
- tx.object.clock()
736
- ]
737
- });
466
+ async function data_id_from(tx, repository, policy, data, passport) {
467
+ // RepIdData类型
468
+ const idFrom = (0, object_js_1.parseIdFrom)(policy.id_from);
469
+ if (idFrom === object_js_1.IdFrom.None) {
470
+ (0, exception_js_1.W_ERROR)(exception_js_1.WErrors.InvalidParam, `id_from must be set when id_from is IdFrom.None`);
738
471
  }
739
- } else {
740
- if (passport) {
741
- tx.moveCall({
742
- target: (0, import_common.repositoryFn)(`um_none_with_passport`),
743
- arguments: [
744
- (0, import_common.toTxObject)(tx, repository),
745
- (0, import_common.toTxObject)(tx, permission),
746
- passport,
747
- tx.object.mutRegistrar()
748
- ]
749
- });
750
- } else {
751
- tx.moveCall({
752
- target: (0, import_common.repositoryFn)(`um_none`),
753
- arguments: [
754
- (0, import_common.toTxObject)(tx, repository),
755
- (0, import_common.toTxObject)(tx, permission),
756
- tx.object.mutRegistrar()
757
- ]
758
- });
472
+ if (data.write_guard) {
473
+ if (!passport) {
474
+ (0, exception_js_1.W_ERROR)(exception_js_1.WErrors.InvalidParam, `passport is required when write_guard is specified`);
475
+ }
476
+ if (policy.write_guard.find((guard) => guard.guard === data.write_guard)) {
477
+ const policyValueType1 = (0, common_js_1.parseValueType)(policy.value_type);
478
+ tx.moveCall({
479
+ target: (0, common_js_1.repositoryFn)("data_when_id_from_set_with_passport"),
480
+ arguments: [
481
+ (0, common_js_1.toTxObject)(tx, repository),
482
+ (0, common_js_1.toTxString)(tx, policy.name),
483
+ tx.pure.address(data.write_guard),
484
+ tx.pure.vector("u8", await (0, util_js_1.valueToBcsBytes)(policyValueType1, data.data)),
485
+ tx.object.clock(),
486
+ passport,
487
+ ],
488
+ });
489
+ }
490
+ else {
491
+ (0, exception_js_1.W_ERROR)(exception_js_1.WErrors.InvalidParam, `Write guard ${data.write_guard} is not in policy ${policy.name}`);
492
+ }
493
+ }
494
+ else {
495
+ if (policy.write_guard.length === 0) {
496
+ const policyValueType2 = (0, common_js_1.parseValueType)(policy.value_type);
497
+ tx.moveCall({
498
+ target: (0, common_js_1.repositoryFn)("data_when_id_from_set"),
499
+ arguments: [
500
+ (0, common_js_1.toTxObject)(tx, repository),
501
+ (0, common_js_1.toTxString)(tx, policy.name),
502
+ tx.pure.vector("u8", await (0, util_js_1.valueToBcsBytes)(policyValueType2, data.data)),
503
+ tx.object.clock(),
504
+ ],
505
+ });
506
+ }
507
+ else {
508
+ (0, exception_js_1.W_ERROR)(exception_js_1.WErrors.InvalidParam, `specify write guard in policy ${policy.write_guard.map((guard) => guard.guard)}`);
509
+ }
759
510
  }
760
- }
761
511
  }
762
- async function data(tx, repository, policy2, data2, passport) {
763
- (0, import_util.validObjects)([repository]);
764
- if (policy2.id_from !== import_object.IdFrom.None) {
765
- (0, import_exception.W_ERROR)(
766
- import_exception.WErrors.InvalidParam,
767
- `id_from must be IdFrom.None when items is provided`
768
- );
769
- }
770
- const noGuardItems = [];
771
- const regularGuards = [];
772
- const mixedItems = [];
773
- for (const item of data2) {
774
- if (!item.write_guard) {
775
- if (policy2.write_guard.length === 0) {
776
- noGuardItems.push(item);
777
- } else {
778
- (0, import_exception.W_ERROR)(
779
- import_exception.WErrors.InvalidParam,
780
- `specify write guard in policy ${policy2.write_guard.map((guard) => guard.guard)}`
781
- );
782
- }
783
- } else {
784
- const guard = item.write_guard;
785
- const policyGuard = policy2.write_guard.find(
786
- (g) => g.guard === guard
787
- );
788
- if (!policyGuard) {
789
- (0, import_exception.W_ERROR)(
790
- import_exception.WErrors.InvalidParam,
791
- `Guard ${guard} not found in policy ${policy2.write_guard.map((guard2) => guard2.guard)}`
792
- );
793
- }
794
- const hasSubmissionSettings = policyGuard.id_from_submission !== void 0;
795
- if (hasSubmissionSettings) {
796
- if (item.data.length > 0) {
797
- const lastItem = item.data[item.data.length - 1];
798
- const existingIndex = mixedItems.findIndex(
799
- (item2) => item2.guard === guard
800
- );
801
- if (existingIndex >= 0) {
802
- mixedItems[existingIndex] = {
803
- guard,
804
- id: lastItem.id,
805
- data: lastItem.data
806
- };
807
- } else {
808
- mixedItems.push({
809
- guard,
810
- id: lastItem.id,
811
- data: lastItem.data
512
+ function um_set(tx, repository, permission, um, passport) {
513
+ (0, util_js_1.validObjects)([repository, permission]);
514
+ if (um) {
515
+ if (passport) {
516
+ tx.moveCall({
517
+ target: (0, common_js_1.repositoryFn)(`um_set_with_passport`),
518
+ arguments: [
519
+ (0, common_js_1.toTxObject)(tx, repository),
520
+ (0, common_js_1.toTxObject)(tx, permission),
521
+ passport,
522
+ (0, common_js_1.toTxObject)(tx, um),
523
+ tx.object.mutRegistrar(),
524
+ tx.object.clock(),
525
+ ],
812
526
  });
813
- }
814
527
  }
815
- } else {
816
- const existingGuard = regularGuards.find(
817
- (g) => g.guard === guard
818
- );
819
- if (existingGuard) {
820
- existingGuard.items.push(item);
821
- } else {
822
- regularGuards.push({ guard, items: [item] });
528
+ else {
529
+ tx.moveCall({
530
+ target: (0, common_js_1.repositoryFn)(`um_set`),
531
+ arguments: [
532
+ (0, common_js_1.toTxObject)(tx, repository),
533
+ (0, common_js_1.toTxObject)(tx, permission),
534
+ (0, common_js_1.toTxObject)(tx, um),
535
+ tx.object.mutRegistrar(),
536
+ tx.object.clock(),
537
+ ],
538
+ });
823
539
  }
824
- }
825
540
  }
826
- }
827
- if (noGuardItems.length > 0) {
828
- const policyValueType3 = (0, import_common.parseValueType)(policy2.value_type);
829
- const ids = noGuardItems.flatMap(
830
- (item) => item.data.map((keyData) => keyData.id)
831
- );
832
- const dataBytes = await Promise.all(
833
- noGuardItems.flatMap((item) => item.data).map(
834
- async (keyData) => await (0, import_util.valueToBcsBytes)(policyValueType3, keyData.data)
835
- )
836
- );
837
- if (ids.length !== dataBytes.length) {
838
- (0, import_exception.W_ERROR)(
839
- import_exception.WErrors.InvalidParam,
840
- `Id and data arrays must have the same length`
841
- );
541
+ else {
542
+ if (passport) {
543
+ tx.moveCall({
544
+ target: (0, common_js_1.repositoryFn)(`um_none_with_passport`),
545
+ arguments: [
546
+ (0, common_js_1.toTxObject)(tx, repository),
547
+ (0, common_js_1.toTxObject)(tx, permission),
548
+ passport,
549
+ tx.object.mutRegistrar(),
550
+ ],
551
+ });
552
+ }
553
+ else {
554
+ tx.moveCall({
555
+ target: (0, common_js_1.repositoryFn)(`um_none`),
556
+ arguments: [
557
+ (0, common_js_1.toTxObject)(tx, repository),
558
+ (0, common_js_1.toTxObject)(tx, permission),
559
+ tx.object.mutRegistrar(),
560
+ ],
561
+ });
562
+ }
842
563
  }
843
- tx.moveCall({
844
- target: (0, import_common.repositoryFn)("id_data"),
845
- arguments: [
846
- (0, import_common.toTxObject)(tx, repository),
847
- (0, import_common.toTxString)(tx, policy2.name),
848
- tx.pure.vector("address", ids),
849
- tx.makeMoveVec({
850
- elements: dataBytes.map((arr) => tx.pure.vector("u8", arr)),
851
- type: "vector<u8>"
852
- })
853
- ]
854
- });
855
- }
856
- if (mixedItems.length > 0) {
857
- if (!passport) {
858
- (0, import_exception.W_ERROR)(
859
- import_exception.WErrors.InvalidParam,
860
- "Guard specified but no passport provided"
861
- );
564
+ }
565
+ async function data(tx, repository, policy, data, passport) {
566
+ (0, util_js_1.validObjects)([repository]);
567
+ if (policy.id_from !== object_js_1.IdFrom.None) {
568
+ (0, exception_js_1.W_ERROR)(exception_js_1.WErrors.InvalidParam, `id_from must be IdFrom.None when items is provided`);
862
569
  }
863
- const policyValueType4 = (0, import_common.parseValueType)(policy2.value_type);
864
- const ids = mixedItems.map((item) => item.id);
865
- const dataBytes = await Promise.all(
866
- mixedItems.map(
867
- async (item) => await (0, import_util.valueToBcsBytes)(policyValueType4, item.data)
868
- )
869
- );
870
- const guards = mixedItems.map((item) => item.guard);
871
- if (ids.length !== dataBytes.length || ids.length !== guards.length) {
872
- (0, import_exception.W_ERROR)(
873
- import_exception.WErrors.InvalidParam,
874
- `Id, data, and guard arrays must have the same length`
875
- );
570
+ // 优化分组逻辑
571
+ const noGuardItems = [];
572
+ const regularGuards = [];
573
+ const mixedItems = [];
574
+ // 分类处理每个item
575
+ for (const item of data) {
576
+ if (!item.write_guard) {
577
+ if (policy.write_guard.length === 0) {
578
+ // 1. 无guard组
579
+ noGuardItems.push(item);
580
+ }
581
+ else {
582
+ (0, exception_js_1.W_ERROR)(exception_js_1.WErrors.InvalidParam, `specify write guard in policy ${policy.write_guard.map((guard) => guard.guard)}`);
583
+ }
584
+ }
585
+ else {
586
+ const guard = item.write_guard;
587
+ // 查找policy中对应的guard设置
588
+ const policyGuard = policy.write_guard.find((g) => g.guard === guard);
589
+ if (!policyGuard) {
590
+ (0, exception_js_1.W_ERROR)(exception_js_1.WErrors.InvalidParam, `Guard ${guard} not found in policy ${policy.write_guard.map((guard) => guard.guard)}`);
591
+ }
592
+ // 检查guard是否有设置id_from_submission
593
+ const hasSubmissionSettings = policyGuard.id_from_submission !== undefined;
594
+ if (hasSubmissionSettings) {
595
+ // 3. 有submission设置的guard - 取最后一个元素的id和data
596
+ if (item.data.length > 0) {
597
+ const lastItem = item.data[item.data.length - 1];
598
+ // 检查guard是否已存在,如果存在则覆盖
599
+ const existingIndex = mixedItems.findIndex((item) => item.guard === guard);
600
+ if (existingIndex >= 0) {
601
+ // 覆盖已存在的条目
602
+ //@ notice: 前面已将地址转换为了string
603
+ mixedItems[existingIndex] = {
604
+ guard,
605
+ id: lastItem.id,
606
+ data: lastItem.data,
607
+ };
608
+ }
609
+ else {
610
+ // 添加新条目
611
+ mixedItems.push({
612
+ guard,
613
+ id: lastItem.id,
614
+ data: lastItem.data,
615
+ });
616
+ }
617
+ } /* else {
618
+ W_ERROR(
619
+ WErrors.InvalidParam,
620
+ `Guard ${guard} has submission settings but no data provided`,
621
+ );
622
+ } 忽略空数据项*/
623
+ }
624
+ else {
625
+ // 2. 无submission设置的guard - 按guard单独分组
626
+ const existingGuard = regularGuards.find((g) => g.guard === guard);
627
+ if (existingGuard) {
628
+ existingGuard.items.push(item);
629
+ }
630
+ else {
631
+ regularGuards.push({ guard, items: [item] });
632
+ }
633
+ }
634
+ }
876
635
  }
877
- tx.moveCall({
878
- target: (0, import_common.repositoryFn)("id_data_mixed_with_passport"),
879
- arguments: [
880
- (0, import_common.toTxObject)(tx, repository),
881
- (0, import_common.toTxString)(tx, policy2.name),
882
- tx.pure.vector("address", guards),
883
- tx.pure.vector("address", ids),
884
- tx.makeMoveVec({
885
- elements: dataBytes.map((arr) => tx.pure.vector("u8", arr)),
886
- type: "vector<u8>"
887
- }),
888
- (0, import_common.toTxObject)(tx, passport)
889
- ]
890
- });
891
- }
892
- for (const { guard, items } of regularGuards) {
893
- if (!passport) {
894
- (0, import_exception.W_ERROR)(
895
- import_exception.WErrors.InvalidParam,
896
- "Guard specified but no passport provided"
897
- );
636
+ // 处理无guard组
637
+ if (noGuardItems.length > 0) {
638
+ const policyValueType3 = (0, common_js_1.parseValueType)(policy.value_type);
639
+ const ids = noGuardItems.flatMap((item) => item.data.map((keyData) => keyData.id));
640
+ const dataBytes = await Promise.all(noGuardItems
641
+ .flatMap((item) => item.data)
642
+ .map(async (keyData) => await (0, util_js_1.valueToBcsBytes)(policyValueType3, keyData.data)));
643
+ if (ids.length !== dataBytes.length) {
644
+ (0, exception_js_1.W_ERROR)(exception_js_1.WErrors.InvalidParam, `Id and data arrays must have the same length`);
645
+ }
646
+ //@ notice: 前面已将地址转换为了string
647
+ tx.moveCall({
648
+ target: (0, common_js_1.repositoryFn)("id_data"),
649
+ arguments: [
650
+ (0, common_js_1.toTxObject)(tx, repository),
651
+ (0, common_js_1.toTxString)(tx, policy.name),
652
+ tx.pure.vector("address", ids),
653
+ tx.makeMoveVec({
654
+ elements: dataBytes.map((arr) => tx.pure.vector("u8", arr)),
655
+ type: "vector<u8>",
656
+ }),
657
+ ],
658
+ });
898
659
  }
899
- const policyValueType5 = (0, import_common.parseValueType)(policy2.value_type);
900
- const keyDataItems = items.flatMap((item) => item.data);
901
- const ids = keyDataItems.map((keyData) => keyData.id);
902
- const dataBytes = await Promise.all(
903
- keyDataItems.map(
904
- async (keyData) => await (0, import_util.valueToBcsBytes)(policyValueType5, keyData.data)
905
- )
906
- );
907
- if (ids.length !== dataBytes.length) {
908
- (0, import_exception.W_ERROR)(
909
- import_exception.WErrors.InvalidParam,
910
- `Id and data arrays must have the same length for guard ${guard}`
911
- );
660
+ // 处理有submission设置的guard组(合并成一个调用)
661
+ if (mixedItems.length > 0) {
662
+ if (!passport) {
663
+ (0, exception_js_1.W_ERROR)(exception_js_1.WErrors.InvalidParam, "Guard specified but no passport provided");
664
+ }
665
+ // 提取所有ids、data和guards
666
+ const policyValueType4 = (0, common_js_1.parseValueType)(policy.value_type);
667
+ const ids = mixedItems.map((item) => item.id);
668
+ const dataBytes = await Promise.all(mixedItems.map(async (item) => await (0, util_js_1.valueToBcsBytes)(policyValueType4, item.data)));
669
+ const guards = mixedItems.map((item) => item.guard);
670
+ if (ids.length !== dataBytes.length || ids.length !== guards.length) {
671
+ (0, exception_js_1.W_ERROR)(exception_js_1.WErrors.InvalidParam, `Id, data, and guard arrays must have the same length`);
672
+ }
673
+ // 调用id_data_mixed_with_passport
674
+ tx.moveCall({
675
+ target: (0, common_js_1.repositoryFn)("id_data_mixed_with_passport"),
676
+ arguments: [
677
+ (0, common_js_1.toTxObject)(tx, repository),
678
+ (0, common_js_1.toTxString)(tx, policy.name),
679
+ tx.pure.vector("address", guards),
680
+ tx.pure.vector("address", ids),
681
+ tx.makeMoveVec({
682
+ elements: dataBytes.map((arr) => tx.pure.vector("u8", arr)),
683
+ type: "vector<u8>",
684
+ }),
685
+ (0, common_js_1.toTxObject)(tx, passport),
686
+ ],
687
+ });
688
+ }
689
+ // 处理无submission设置的guard组(每个guard单独调用)
690
+ for (const { guard, items } of regularGuards) {
691
+ if (!passport) {
692
+ (0, exception_js_1.W_ERROR)(exception_js_1.WErrors.InvalidParam, "Guard specified but no passport provided");
693
+ }
694
+ const policyValueType5 = (0, common_js_1.parseValueType)(policy.value_type);
695
+ const keyDataItems = items.flatMap((item) => item.data);
696
+ const ids = keyDataItems.map((keyData) => keyData.id);
697
+ const dataBytes = await Promise.all(keyDataItems.map(async (keyData) => await (0, util_js_1.valueToBcsBytes)(policyValueType5, keyData.data)));
698
+ if (ids.length !== dataBytes.length) {
699
+ (0, exception_js_1.W_ERROR)(exception_js_1.WErrors.InvalidParam, `Id and data arrays must have the same length for guard ${guard}`);
700
+ }
701
+ // 调用id_data_with_passport
702
+ tx.moveCall({
703
+ target: (0, common_js_1.repositoryFn)("id_data_with_passport"),
704
+ arguments: [
705
+ (0, common_js_1.toTxObject)(tx, repository),
706
+ (0, common_js_1.toTxString)(tx, policy.name),
707
+ tx.pure.address(guard),
708
+ tx.pure.vector("address", ids),
709
+ tx.makeMoveVec({
710
+ elements: dataBytes.map((arr) => tx.pure.vector("u8", arr)),
711
+ type: "vector<u8>",
712
+ }),
713
+ (0, common_js_1.toTxObject)(tx, passport),
714
+ ],
715
+ });
912
716
  }
913
- tx.moveCall({
914
- target: (0, import_common.repositoryFn)("id_data_with_passport"),
915
- arguments: [
916
- (0, import_common.toTxObject)(tx, repository),
917
- (0, import_common.toTxString)(tx, policy2.name),
918
- tx.pure.address(guard),
919
- tx.pure.vector("address", ids),
920
- tx.makeMoveVec({
921
- elements: dataBytes.map((arr) => tx.pure.vector("u8", arr)),
922
- type: "vector<u8>"
923
- }),
924
- (0, import_common.toTxObject)(tx, passport)
925
- ]
926
- });
927
- }
928
717
  }
718
+ // ================================================
719
+ // 构造函数和设置函数
929
720
  function newRepository(tx, permission, description, passport) {
930
- (0, import_util.validObjects)([permission, passport]);
931
- if (typeof description === "string" && !(0, import_common.isValidDescription)(description)) {
932
- (0, import_exception.W_ERROR)(
933
- import_exception.WErrors.IsValidDescription,
934
- `Description exceeds maximum length ${import_common.MAX_DESCRIPTION_LENGTH}`
935
- );
936
- }
937
- if (passport) {
938
- return tx.moveCall({
939
- target: (0, import_common.repositoryFn)("new_with_passport"),
940
- arguments: [
941
- (0, import_common.toTxObject)(tx, permission),
942
- (0, import_common.toTxObject)(tx, passport),
943
- (0, import_common.toTxString)(tx, description),
944
- tx.object.mutRegistrar(),
945
- tx.object.clock()
946
- ]
947
- });
948
- } else {
949
- return tx.moveCall({
950
- target: (0, import_common.repositoryFn)("new"),
951
- arguments: [
952
- (0, import_common.toTxObject)(tx, permission),
953
- (0, import_common.toTxString)(tx, description),
954
- tx.object.mutRegistrar(),
955
- tx.object.clock()
956
- ]
957
- });
958
- }
721
+ (0, util_js_1.validObjects)([permission, passport]);
722
+ if (typeof description === "string" && !(0, common_js_1.isValidDescription)(description)) {
723
+ (0, exception_js_1.W_ERROR)(exception_js_1.WErrors.IsValidDescription, `Description exceeds maximum length ${common_js_1.MAX_DESCRIPTION_LENGTH}`);
724
+ }
725
+ if (passport) {
726
+ return tx.moveCall({
727
+ target: (0, common_js_1.repositoryFn)("new_with_passport"),
728
+ arguments: [
729
+ (0, common_js_1.toTxObject)(tx, permission),
730
+ (0, common_js_1.toTxObject)(tx, passport),
731
+ (0, common_js_1.toTxString)(tx, description),
732
+ tx.object.mutRegistrar(),
733
+ tx.object.clock(),
734
+ ],
735
+ });
736
+ }
737
+ else {
738
+ return tx.moveCall({
739
+ target: (0, common_js_1.repositoryFn)("new"),
740
+ arguments: [
741
+ (0, common_js_1.toTxObject)(tx, permission),
742
+ (0, common_js_1.toTxString)(tx, description),
743
+ tx.object.mutRegistrar(),
744
+ tx.object.clock(),
745
+ ],
746
+ });
747
+ }
959
748
  }
960
749
  function description_set(tx, repository, permission, description, passport) {
961
- (0, import_util.validObjects)([repository, permission, passport]);
962
- if (typeof description === "string" && !(0, import_common.isValidDescription)(description)) {
963
- (0, import_exception.W_ERROR)(
964
- import_exception.WErrors.IsValidDescription,
965
- `Description exceeds maximum length ${import_common.MAX_DESCRIPTION_LENGTH}`
966
- );
967
- }
968
- if (passport) {
969
- tx.moveCall({
970
- target: (0, import_common.repositoryFn)("description_set_with_passport"),
971
- arguments: [
972
- (0, import_common.toTxObject)(tx, repository),
973
- (0, import_common.toTxObject)(tx, permission),
974
- (0, import_common.toTxObject)(tx, passport),
975
- (0, import_common.toTxString)(tx, description)
976
- ]
977
- });
978
- } else {
979
- tx.moveCall({
980
- target: (0, import_common.repositoryFn)("description_set"),
981
- arguments: [
982
- (0, import_common.toTxObject)(tx, repository),
983
- (0, import_common.toTxObject)(tx, permission),
984
- (0, import_common.toTxString)(tx, description)
985
- ]
986
- });
987
- }
750
+ (0, util_js_1.validObjects)([repository, permission, passport]);
751
+ if (typeof description === "string" && !(0, common_js_1.isValidDescription)(description)) {
752
+ (0, exception_js_1.W_ERROR)(exception_js_1.WErrors.IsValidDescription, `Description exceeds maximum length ${common_js_1.MAX_DESCRIPTION_LENGTH}`);
753
+ }
754
+ if (passport) {
755
+ tx.moveCall({
756
+ target: (0, common_js_1.repositoryFn)("description_set_with_passport"),
757
+ arguments: [
758
+ (0, common_js_1.toTxObject)(tx, repository),
759
+ (0, common_js_1.toTxObject)(tx, permission),
760
+ (0, common_js_1.toTxObject)(tx, passport),
761
+ (0, common_js_1.toTxString)(tx, description),
762
+ ],
763
+ });
764
+ }
765
+ else {
766
+ tx.moveCall({
767
+ target: (0, common_js_1.repositoryFn)("description_set"),
768
+ arguments: [
769
+ (0, common_js_1.toTxObject)(tx, repository),
770
+ (0, common_js_1.toTxObject)(tx, permission),
771
+ (0, common_js_1.toTxString)(tx, description),
772
+ ],
773
+ });
774
+ }
988
775
  }
989
776
  function policy_add(tx, repository, permission, policies, passport) {
990
- if (policies.length === 0) {
991
- return;
992
- }
993
- (0, import_util.validObjects)([repository, permission, passport]);
994
- if (passport) {
995
- tx.moveCall({
996
- target: (0, import_common.repositoryFn)("policy_add_with_passport"),
997
- arguments: [
998
- (0, import_common.toTxObject)(tx, repository),
999
- (0, import_common.toTxObject)(tx, permission),
1000
- (0, import_common.toTxObject)(tx, passport),
1001
- tx.makeMoveVec({
1002
- elements: policies.map((p) => policy(tx, p)),
1003
- type: `${import_common.PackageAddress}::repository::PolicyRule`
1004
- }),
1005
- tx.object.mutRegistrar(),
1006
- tx.object.clock()
1007
- ]
1008
- });
1009
- } else {
1010
- tx.moveCall({
1011
- target: (0, import_common.repositoryFn)("policy_add"),
1012
- arguments: [
1013
- (0, import_common.toTxObject)(tx, repository),
1014
- (0, import_common.toTxObject)(tx, permission),
1015
- tx.makeMoveVec({
1016
- elements: policies.map((p) => policy(tx, p)),
1017
- type: `${import_common.PackageAddress}::repository::PolicyRule`
1018
- }),
1019
- tx.object.mutRegistrar(),
1020
- tx.object.clock()
1021
- ]
1022
- });
1023
- }
777
+ if (policies.length === 0) {
778
+ return;
779
+ }
780
+ (0, util_js_1.validObjects)([repository, permission, passport]);
781
+ if (passport) {
782
+ tx.moveCall({
783
+ target: (0, common_js_1.repositoryFn)("policy_add_with_passport"),
784
+ arguments: [
785
+ (0, common_js_1.toTxObject)(tx, repository),
786
+ (0, common_js_1.toTxObject)(tx, permission),
787
+ (0, common_js_1.toTxObject)(tx, passport),
788
+ tx.makeMoveVec({
789
+ elements: policies.map((p) => policy(tx, p)),
790
+ type: `${common_js_1.PackageAddress}::repository::PolicyRule`,
791
+ }),
792
+ tx.object.mutRegistrar(),
793
+ tx.object.clock(),
794
+ ],
795
+ });
796
+ }
797
+ else {
798
+ tx.moveCall({
799
+ target: (0, common_js_1.repositoryFn)("policy_add"),
800
+ arguments: [
801
+ (0, common_js_1.toTxObject)(tx, repository),
802
+ (0, common_js_1.toTxObject)(tx, permission),
803
+ tx.makeMoveVec({
804
+ elements: policies.map((p) => policy(tx, p)),
805
+ type: `${common_js_1.PackageAddress}::repository::PolicyRule`,
806
+ }),
807
+ tx.object.mutRegistrar(),
808
+ tx.object.clock(),
809
+ ],
810
+ });
811
+ }
1024
812
  }
1025
813
  function policy_set(tx, repository, permission, policies, passport) {
1026
- (0, import_util.validObjects)([repository, permission, passport]);
1027
- if (passport) {
1028
- tx.moveCall({
1029
- target: (0, import_common.repositoryFn)("policy_set_with_passport"),
1030
- arguments: [
1031
- (0, import_common.toTxObject)(tx, repository),
1032
- (0, import_common.toTxObject)(tx, permission),
1033
- (0, import_common.toTxObject)(tx, passport),
1034
- tx.makeMoveVec({
1035
- elements: policies.map((p) => policy(tx, p)),
1036
- type: `${import_common.PackageAddress}::repository::PolicyRule`
1037
- }),
1038
- tx.object.mutRegistrar(),
1039
- tx.object.clock()
1040
- ]
1041
- });
1042
- } else {
1043
- tx.moveCall({
1044
- target: (0, import_common.repositoryFn)("policy_set"),
1045
- arguments: [
1046
- (0, import_common.toTxObject)(tx, repository),
1047
- (0, import_common.toTxObject)(tx, permission),
1048
- tx.makeMoveVec({
1049
- elements: policies.map((p) => policy(tx, p)),
1050
- type: `${import_common.PackageAddress}::repository::PolicyRule`
1051
- }),
1052
- tx.object.mutRegistrar(),
1053
- tx.object.clock()
1054
- ]
1055
- });
1056
- }
814
+ (0, util_js_1.validObjects)([repository, permission, passport]);
815
+ if (passport) {
816
+ tx.moveCall({
817
+ target: (0, common_js_1.repositoryFn)("policy_set_with_passport"),
818
+ arguments: [
819
+ (0, common_js_1.toTxObject)(tx, repository),
820
+ (0, common_js_1.toTxObject)(tx, permission),
821
+ (0, common_js_1.toTxObject)(tx, passport),
822
+ tx.makeMoveVec({
823
+ elements: policies.map((p) => policy(tx, p)),
824
+ type: `${common_js_1.PackageAddress}::repository::PolicyRule`,
825
+ }),
826
+ tx.object.mutRegistrar(),
827
+ tx.object.clock(),
828
+ ],
829
+ });
830
+ }
831
+ else {
832
+ tx.moveCall({
833
+ target: (0, common_js_1.repositoryFn)("policy_set"),
834
+ arguments: [
835
+ (0, common_js_1.toTxObject)(tx, repository),
836
+ (0, common_js_1.toTxObject)(tx, permission),
837
+ tx.makeMoveVec({
838
+ elements: policies.map((p) => policy(tx, p)),
839
+ type: `${common_js_1.PackageAddress}::repository::PolicyRule`,
840
+ }),
841
+ tx.object.mutRegistrar(),
842
+ tx.object.clock(),
843
+ ],
844
+ });
845
+ }
1057
846
  }
1058
847
  function policy_remove(tx, repository, permission, policies, passport) {
1059
- if (policies.length === 0) {
1060
- return;
1061
- }
1062
- (0, import_util.validObjects)([repository, permission, passport]);
1063
- if (passport) {
1064
- tx.moveCall({
1065
- target: (0, import_common.repositoryFn)("policy_remove_with_passport"),
1066
- arguments: [
1067
- (0, import_common.toTxObject)(tx, repository),
1068
- (0, import_common.toTxObject)(tx, permission),
1069
- (0, import_common.toTxObject)(tx, passport),
1070
- tx.pure.vector("string", policies),
1071
- tx.object.mutRegistrar()
1072
- ]
1073
- });
1074
- } else {
1075
- tx.moveCall({
1076
- target: (0, import_common.repositoryFn)("policy_remove"),
1077
- arguments: [
1078
- (0, import_common.toTxObject)(tx, repository),
1079
- (0, import_common.toTxObject)(tx, permission),
1080
- tx.pure.vector("string", policies),
1081
- tx.object.mutRegistrar()
1082
- ]
1083
- });
1084
- }
848
+ if (policies.length === 0) {
849
+ return;
850
+ }
851
+ (0, util_js_1.validObjects)([repository, permission, passport]);
852
+ if (passport) {
853
+ tx.moveCall({
854
+ target: (0, common_js_1.repositoryFn)("policy_remove_with_passport"),
855
+ arguments: [
856
+ (0, common_js_1.toTxObject)(tx, repository),
857
+ (0, common_js_1.toTxObject)(tx, permission),
858
+ (0, common_js_1.toTxObject)(tx, passport),
859
+ tx.pure.vector("string", policies),
860
+ tx.object.mutRegistrar(),
861
+ ],
862
+ });
863
+ }
864
+ else {
865
+ tx.moveCall({
866
+ target: (0, common_js_1.repositoryFn)("policy_remove"),
867
+ arguments: [
868
+ (0, common_js_1.toTxObject)(tx, repository),
869
+ (0, common_js_1.toTxObject)(tx, permission),
870
+ tx.pure.vector("string", policies),
871
+ tx.object.mutRegistrar(),
872
+ ],
873
+ });
874
+ }
1085
875
  }
1086
876
  function policy_clear(tx, repository, permission, passport) {
1087
- (0, import_util.validObjects)([repository, permission, passport]);
1088
- if (passport) {
1089
- tx.moveCall({
1090
- target: (0, import_common.repositoryFn)("policy_clear_with_passport"),
1091
- arguments: [
1092
- (0, import_common.toTxObject)(tx, repository),
1093
- (0, import_common.toTxObject)(tx, permission),
1094
- (0, import_common.toTxObject)(tx, passport)
1095
- ]
1096
- });
1097
- } else {
1098
- tx.moveCall({
1099
- target: (0, import_common.repositoryFn)("policy_clear"),
1100
- arguments: [(0, import_common.toTxObject)(tx, repository), (0, import_common.toTxObject)(tx, permission)]
1101
- });
1102
- }
877
+ (0, util_js_1.validObjects)([repository, permission, passport]);
878
+ if (passport) {
879
+ tx.moveCall({
880
+ target: (0, common_js_1.repositoryFn)("policy_clear_with_passport"),
881
+ arguments: [
882
+ (0, common_js_1.toTxObject)(tx, repository),
883
+ (0, common_js_1.toTxObject)(tx, permission),
884
+ (0, common_js_1.toTxObject)(tx, passport),
885
+ ],
886
+ });
887
+ }
888
+ else {
889
+ tx.moveCall({
890
+ target: (0, common_js_1.repositoryFn)("policy_clear"),
891
+ arguments: [(0, common_js_1.toTxObject)(tx, repository), (0, common_js_1.toTxObject)(tx, permission)],
892
+ });
893
+ }
1103
894
  }
1104
895
  function reward_add(tx, repository, permission, reward, reward_type, passport) {
1105
- (0, import_util.validObjects)([repository, permission, passport, reward]);
1106
- if (!(0, import_common.IsValidArgType)(reward_type)) {
1107
- (0, import_exception.W_ERROR)(
1108
- import_exception.WErrors.IsValidArgType,
1109
- `Reward type ${reward_type} is not valid`
1110
- );
1111
- }
1112
- if (passport) {
1113
- tx.moveCall({
1114
- target: (0, import_common.repositoryFn)("reward_add_with_passport"),
1115
- arguments: [
1116
- (0, import_common.toTxObject)(tx, repository),
1117
- (0, import_common.toTxObject)(tx, permission),
1118
- (0, import_common.toTxObject)(tx, passport),
1119
- tx.object(reward)
1120
- ],
1121
- typeArguments: [reward_type]
1122
- });
1123
- } else {
1124
- tx.moveCall({
1125
- target: (0, import_common.repositoryFn)("reward_add"),
1126
- arguments: [
1127
- (0, import_common.toTxObject)(tx, repository),
1128
- (0, import_common.toTxObject)(tx, permission),
1129
- tx.object(reward)
1130
- ],
1131
- typeArguments: [reward_type]
1132
- });
1133
- }
1134
- }
1135
- function reward_remove(tx, repository, permission, rewards, passport) {
1136
- if (rewards.length === 0) {
1137
- return;
1138
- }
1139
- (0, import_util.validObjects)([repository, permission, passport, ...rewards]);
1140
- if (passport) {
1141
- tx.moveCall({
1142
- target: (0, import_common.repositoryFn)("reward_remove_with_passport"),
1143
- arguments: [
1144
- (0, import_common.toTxObject)(tx, repository),
1145
- (0, import_common.toTxObject)(tx, permission),
1146
- (0, import_common.toTxObject)(tx, passport),
1147
- tx.pure.vector("address", rewards)
1148
- ]
1149
- });
1150
- } else {
1151
- tx.moveCall({
1152
- target: (0, import_common.repositoryFn)("reward_remove"),
1153
- arguments: [
1154
- (0, import_common.toTxObject)(tx, repository),
1155
- (0, import_common.toTxObject)(tx, permission),
1156
- tx.pure.vector("address", rewards)
1157
- ]
1158
- });
1159
- }
1160
- }
1161
- function reward_clear(tx, repository, permission, passport) {
1162
- (0, import_util.validObjects)([repository, permission, passport]);
1163
- if (passport) {
1164
- tx.moveCall({
1165
- target: (0, import_common.repositoryFn)("reward_clear_with_passport"),
1166
- arguments: [
1167
- (0, import_common.toTxObject)(tx, repository),
1168
- (0, import_common.toTxObject)(tx, permission),
1169
- (0, import_common.toTxObject)(tx, passport)
1170
- ]
1171
- });
1172
- } else {
1173
- tx.moveCall({
1174
- target: (0, import_common.repositoryFn)("reward_clear"),
1175
- arguments: [(0, import_common.toTxObject)(tx, repository), (0, import_common.toTxObject)(tx, permission)]
1176
- });
1177
- }
1178
- }
1179
- async function data_remove(tx, repository, policy2, param, passport) {
1180
- (0, import_util.validObjects)([repository]);
1181
- if ("items" in param) {
1182
- if (policy2.id_from !== import_object.IdFrom.None) {
1183
- (0, import_exception.W_ERROR)(
1184
- import_exception.WErrors.InvalidParam,
1185
- `id_from must be IdFrom.None when items is provided`
1186
- );
896
+ (0, util_js_1.validObjects)([repository, permission, passport, reward]);
897
+ if (!(0, common_js_1.IsValidArgType)(reward_type)) {
898
+ (0, exception_js_1.W_ERROR)(exception_js_1.WErrors.IsValidArgType, `Reward type ${reward_type} is not valid`);
1187
899
  }
1188
- const noGuardItems = [];
1189
- const regularGuards = [];
1190
- const mixedItems = [];
1191
- for (const item of param.items) {
1192
- if (!item.write_guard) {
1193
- if (policy2.write_guard.length === 0) {
1194
- noGuardItems.push(...item.id);
1195
- } else {
1196
- (0, import_exception.W_ERROR)(
1197
- import_exception.WErrors.InvalidParam,
1198
- `specify write guard in policy ${policy2.write_guard.map((guard) => guard.guard)}`
1199
- );
1200
- }
1201
- } else {
1202
- const guard = item.write_guard;
1203
- const policyGuard = policy2.write_guard.find(
1204
- (g) => g.guard === guard
1205
- );
1206
- if (!policyGuard) {
1207
- (0, import_exception.W_ERROR)(
1208
- import_exception.WErrors.InvalidParam,
1209
- `Guard ${guard} not found in policy ${policy2.write_guard.map((guard2) => guard2.guard)}`
1210
- );
1211
- }
1212
- const hasSubmissionSettings = policyGuard.id_from_submission !== void 0;
1213
- if (hasSubmissionSettings) {
1214
- mixedItems.push(guard);
1215
- } else {
1216
- const existingGuard = regularGuards.find(
1217
- (g) => g.guard === guard
1218
- );
1219
- if (existingGuard) {
1220
- existingGuard.id.push(...item.id);
1221
- } else {
1222
- regularGuards.push({
1223
- guard,
1224
- id: [...item.id]
1225
- });
1226
- }
1227
- }
1228
- }
900
+ if (passport) {
901
+ tx.moveCall({
902
+ target: (0, common_js_1.repositoryFn)("reward_add_with_passport"),
903
+ arguments: [
904
+ (0, common_js_1.toTxObject)(tx, repository),
905
+ (0, common_js_1.toTxObject)(tx, permission),
906
+ (0, common_js_1.toTxObject)(tx, passport),
907
+ tx.object(reward),
908
+ ],
909
+ typeArguments: [reward_type],
910
+ });
1229
911
  }
1230
- if (noGuardItems.length > 0) {
1231
- if (policy2.write_guard.length !== 0) {
1232
- (0, import_exception.W_ERROR)(
1233
- import_exception.WErrors.InvalidParam,
1234
- `specify write guard in policy ${policy2.write_guard.map((guard) => guard.guard)}`
1235
- );
1236
- }
1237
- const uniqueIds = [...new Set(noGuardItems)];
1238
- tx.moveCall({
1239
- target: (0, import_common.repositoryFn)("id_data_remove"),
1240
- arguments: [
1241
- (0, import_common.toTxObject)(tx, repository),
1242
- (0, import_common.toTxString)(tx, policy2.name),
1243
- tx.pure.vector("address", uniqueIds)
1244
- ]
1245
- });
912
+ else {
913
+ tx.moveCall({
914
+ target: (0, common_js_1.repositoryFn)("reward_add"),
915
+ arguments: [
916
+ (0, common_js_1.toTxObject)(tx, repository),
917
+ (0, common_js_1.toTxObject)(tx, permission),
918
+ tx.object(reward),
919
+ ],
920
+ typeArguments: [reward_type],
921
+ });
1246
922
  }
1247
- if (mixedItems.length > 0) {
1248
- if (!passport) {
1249
- (0, import_exception.W_ERROR)(
1250
- import_exception.WErrors.InvalidParam,
1251
- "Guard specified but no passport provided"
1252
- );
1253
- }
1254
- const uniqueIds = [...new Set(mixedItems)];
1255
- tx.moveCall({
1256
- target: (0, import_common.repositoryFn)("id_data_mixed_remove_with_passport"),
1257
- arguments: [
1258
- (0, import_common.toTxObject)(tx, repository),
1259
- (0, import_common.toTxString)(tx, policy2.name),
1260
- tx.pure.vector("address", uniqueIds),
1261
- (0, import_common.toTxObject)(tx, passport)
1262
- ]
1263
- });
923
+ }
924
+ function reward_remove(tx, repository, permission, rewards, passport) {
925
+ if (rewards.length === 0) {
926
+ return;
1264
927
  }
1265
- for (const { guard, id } of regularGuards) {
1266
- const uniqueIds = [...new Set(id)];
1267
- tx.moveCall({
1268
- target: (0, import_common.repositoryFn)("id_data_remove_with_passport"),
1269
- arguments: [
1270
- (0, import_common.toTxObject)(tx, repository),
1271
- (0, import_common.toTxString)(tx, policy2.name),
1272
- tx.pure.address(guard),
1273
- tx.pure.vector("address", uniqueIds),
1274
- (0, import_common.toTxObject)(tx, passport)
1275
- ]
1276
- });
928
+ (0, util_js_1.validObjects)([repository, permission, passport, ...rewards]);
929
+ if (passport) {
930
+ tx.moveCall({
931
+ target: (0, common_js_1.repositoryFn)("reward_remove_with_passport"),
932
+ arguments: [
933
+ (0, common_js_1.toTxObject)(tx, repository),
934
+ (0, common_js_1.toTxObject)(tx, permission),
935
+ (0, common_js_1.toTxObject)(tx, passport),
936
+ tx.pure.vector("address", rewards),
937
+ ],
938
+ });
1277
939
  }
1278
- } else {
1279
- const guard = param.write_guard;
1280
- if (policy2.id_from === import_object.IdFrom.None) {
1281
- (0, import_exception.W_ERROR)(
1282
- import_exception.WErrors.InvalidParam,
1283
- `id_from must be set when id_from is IdFrom.None`
1284
- );
940
+ else {
941
+ tx.moveCall({
942
+ target: (0, common_js_1.repositoryFn)("reward_remove"),
943
+ arguments: [
944
+ (0, common_js_1.toTxObject)(tx, repository),
945
+ (0, common_js_1.toTxObject)(tx, permission),
946
+ tx.pure.vector("address", rewards),
947
+ ],
948
+ });
1285
949
  }
1286
- if (guard) {
1287
- if (policy2.write_guard.find((g) => g.guard === guard)) {
950
+ }
951
+ function reward_clear(tx, repository, permission, passport) {
952
+ (0, util_js_1.validObjects)([repository, permission, passport]);
953
+ if (passport) {
1288
954
  tx.moveCall({
1289
- target: (0, import_common.repositoryFn)(
1290
- "data_remove_when_id_from_set_with_passport"
1291
- ),
1292
- arguments: [
1293
- (0, import_common.toTxObject)(tx, repository),
1294
- (0, import_common.toTxString)(tx, policy2.name),
1295
- tx.pure.address(guard),
1296
- tx.object.clock(),
1297
- (0, import_common.toTxObject)(tx, passport)
1298
- ]
955
+ target: (0, common_js_1.repositoryFn)("reward_clear_with_passport"),
956
+ arguments: [
957
+ (0, common_js_1.toTxObject)(tx, repository),
958
+ (0, common_js_1.toTxObject)(tx, permission),
959
+ (0, common_js_1.toTxObject)(tx, passport),
960
+ ],
1299
961
  });
1300
- } else {
1301
- (0, import_exception.W_ERROR)(
1302
- import_exception.WErrors.InvalidParam,
1303
- `Write guard ${guard} is not in policy ${policy2.write_guard.map((guard2) => guard2.guard)}`
1304
- );
1305
- }
1306
- } else {
1307
- if (policy2.write_guard.length === 0) {
962
+ }
963
+ else {
1308
964
  tx.moveCall({
1309
- target: (0, import_common.repositoryFn)("data_remove_when_id_from_set"),
1310
- arguments: [
1311
- (0, import_common.toTxObject)(tx, repository),
1312
- (0, import_common.toTxString)(tx, policy2.name),
1313
- tx.object.clock()
1314
- ]
965
+ target: (0, common_js_1.repositoryFn)("reward_clear"),
966
+ arguments: [(0, common_js_1.toTxObject)(tx, repository), (0, common_js_1.toTxObject)(tx, permission)],
1315
967
  });
1316
- } else {
1317
- (0, import_exception.W_ERROR)(
1318
- import_exception.WErrors.InvalidParam,
1319
- `specify write guard in policy ${policy2.write_guard.map((guard2) => guard2.guard)}`
1320
- );
1321
- }
1322
968
  }
1323
- }
1324
969
  }
970
+ async function data_remove(tx, repository, policy, param, passport) {
971
+ (0, util_js_1.validObjects)([repository]);
972
+ // 检查参数类型
973
+ if ("items" in param) {
974
+ if (policy.id_from !== object_js_1.IdFrom.None) {
975
+ (0, exception_js_1.W_ERROR)(exception_js_1.WErrors.InvalidParam, `id_from must be IdFrom.None when items is provided`);
976
+ }
977
+ // 优化分组逻辑
978
+ const noGuardItems = [];
979
+ const regularGuards = [];
980
+ const mixedItems = [];
981
+ // 分类处理每个item
982
+ for (const item of param.items) {
983
+ if (!item.write_guard) {
984
+ // 1. 无guard组
985
+ if (policy.write_guard.length === 0) {
986
+ noGuardItems.push(...item.id);
987
+ }
988
+ else {
989
+ (0, exception_js_1.W_ERROR)(exception_js_1.WErrors.InvalidParam, `specify write guard in policy ${policy.write_guard.map((guard) => guard.guard)}`);
990
+ }
991
+ }
992
+ else {
993
+ const guard = item.write_guard;
994
+ // 查找policy中对应的guard设置
995
+ const policyGuard = policy.write_guard.find((g) => g.guard === guard);
996
+ if (!policyGuard) {
997
+ (0, exception_js_1.W_ERROR)(exception_js_1.WErrors.InvalidParam, `Guard ${guard} not found in policy ${policy.write_guard.map((guard) => guard.guard)}`);
998
+ }
999
+ // 检查guard是否有设置id_from_submission
1000
+ const hasSubmissionSettings = policyGuard.id_from_submission !== undefined;
1001
+ if (hasSubmissionSettings) {
1002
+ // 3. 有submission设置的guard - 取最后一个id和data
1003
+ mixedItems.push(guard);
1004
+ }
1005
+ else {
1006
+ // 2. 无submission设置的guard - 按guard单独分组
1007
+ const existingGuard = regularGuards.find((g) => g.guard === guard);
1008
+ if (existingGuard) {
1009
+ existingGuard.id.push(...item.id);
1010
+ }
1011
+ else {
1012
+ regularGuards.push({
1013
+ guard,
1014
+ id: [...item.id],
1015
+ });
1016
+ }
1017
+ }
1018
+ }
1019
+ }
1020
+ // 处理无guard组
1021
+ if (noGuardItems.length > 0) {
1022
+ if (policy.write_guard.length !== 0) {
1023
+ (0, exception_js_1.W_ERROR)(exception_js_1.WErrors.InvalidParam, `specify write guard in policy ${policy.write_guard.map((guard) => guard.guard)}`);
1024
+ }
1025
+ // 去重处理
1026
+ const uniqueIds = [...new Set(noGuardItems)];
1027
+ // 调用id_data_remove
1028
+ tx.moveCall({
1029
+ target: (0, common_js_1.repositoryFn)("id_data_remove"),
1030
+ arguments: [
1031
+ (0, common_js_1.toTxObject)(tx, repository),
1032
+ (0, common_js_1.toTxString)(tx, policy.name),
1033
+ tx.pure.vector("address", uniqueIds),
1034
+ ],
1035
+ });
1036
+ }
1037
+ // 处理有submission设置的guard组(合并成一个调用)
1038
+ if (mixedItems.length > 0) {
1039
+ if (!passport) {
1040
+ (0, exception_js_1.W_ERROR)(exception_js_1.WErrors.InvalidParam, "Guard specified but no passport provided");
1041
+ }
1042
+ const uniqueIds = [...new Set(mixedItems)];
1043
+ // 调用id_data_mixed_with_passport
1044
+ tx.moveCall({
1045
+ target: (0, common_js_1.repositoryFn)("id_data_mixed_remove_with_passport"),
1046
+ arguments: [
1047
+ (0, common_js_1.toTxObject)(tx, repository),
1048
+ (0, common_js_1.toTxString)(tx, policy.name),
1049
+ tx.pure.vector("address", uniqueIds),
1050
+ (0, common_js_1.toTxObject)(tx, passport),
1051
+ ],
1052
+ });
1053
+ }
1054
+ // 处理无submission设置的guard组(每个guard单独调用)
1055
+ for (const { guard, id } of regularGuards) {
1056
+ const uniqueIds = [...new Set(id)];
1057
+ // 调用id_data_with_passport
1058
+ tx.moveCall({
1059
+ target: (0, common_js_1.repositoryFn)("id_data_remove_with_passport"),
1060
+ arguments: [
1061
+ (0, common_js_1.toTxObject)(tx, repository),
1062
+ (0, common_js_1.toTxString)(tx, policy.name),
1063
+ tx.pure.address(guard),
1064
+ tx.pure.vector("address", uniqueIds),
1065
+ (0, common_js_1.toTxObject)(tx, passport),
1066
+ ],
1067
+ });
1068
+ }
1069
+ }
1070
+ else {
1071
+ const guard = param.write_guard;
1072
+ // RepIdData类型
1073
+ if (policy.id_from === object_js_1.IdFrom.None) {
1074
+ (0, exception_js_1.W_ERROR)(exception_js_1.WErrors.InvalidParam, `id_from must be set when id_from is IdFrom.None`);
1075
+ }
1076
+ if (guard) {
1077
+ if (policy.write_guard.find((g) => g.guard === guard)) {
1078
+ tx.moveCall({
1079
+ target: (0, common_js_1.repositoryFn)("data_remove_when_id_from_set_with_passport"),
1080
+ arguments: [
1081
+ (0, common_js_1.toTxObject)(tx, repository),
1082
+ (0, common_js_1.toTxString)(tx, policy.name),
1083
+ tx.pure.address(guard),
1084
+ tx.object.clock(),
1085
+ (0, common_js_1.toTxObject)(tx, passport),
1086
+ ],
1087
+ });
1088
+ }
1089
+ else {
1090
+ (0, exception_js_1.W_ERROR)(exception_js_1.WErrors.InvalidParam, `Write guard ${guard} is not in policy ${policy.write_guard.map((guard) => guard.guard)}`);
1091
+ }
1092
+ }
1093
+ else {
1094
+ if (policy.write_guard.length === 0) {
1095
+ tx.moveCall({
1096
+ target: (0, common_js_1.repositoryFn)("data_remove_when_id_from_set"),
1097
+ arguments: [
1098
+ (0, common_js_1.toTxObject)(tx, repository),
1099
+ (0, common_js_1.toTxString)(tx, policy.name),
1100
+ tx.object.clock(),
1101
+ ],
1102
+ });
1103
+ }
1104
+ else {
1105
+ (0, exception_js_1.W_ERROR)(exception_js_1.WErrors.InvalidParam, `specify write guard in policy ${policy.write_guard.map((guard) => guard.guard)}`);
1106
+ }
1107
+ }
1108
+ }
1109
+ }
1110
+ //# sourceMappingURL=repository.js.map