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.
- package/dist/cjs/bcs/bcs.d.ts +199 -199
- package/dist/cjs/bcs/bcs.js +273 -318
- package/dist/cjs/bcs/bcs.js.map +1 -0
- package/dist/cjs/bcs/effects.d.ts +109 -109
- package/dist/cjs/bcs/effects.js +205 -230
- package/dist/cjs/bcs/effects.js.map +1 -0
- package/dist/cjs/bcs/index.d.ts +1 -2584
- package/dist/cjs/bcs/index.js +61 -76
- package/dist/cjs/bcs/index.js.map +1 -0
- package/dist/cjs/bcs/pure.js +38 -58
- package/dist/cjs/bcs/pure.js.map +1 -0
- package/dist/cjs/bcs/type-tag-serializer.js +102 -114
- package/dist/cjs/bcs/type-tag-serializer.js.map +1 -0
- package/dist/cjs/bcs/types.js +6 -23
- package/dist/cjs/bcs/types.js.map +1 -0
- package/dist/cjs/client/index.js +17 -33
- package/dist/cjs/client/index.js.map +1 -0
- package/dist/cjs/client/network.js +25 -40
- package/dist/cjs/client/network.js.map +1 -0
- package/dist/cjs/cryptography/index.js +29 -45
- package/dist/cjs/cryptography/index.js.map +1 -0
- package/dist/cjs/cryptography/intent.d.ts +1 -1
- package/dist/cjs/cryptography/intent.js +20 -31
- package/dist/cjs/cryptography/intent.js.map +1 -0
- package/dist/cjs/cryptography/keypair.js +102 -116
- package/dist/cjs/cryptography/keypair.js.map +1 -0
- package/dist/cjs/cryptography/mnemonics.js +43 -41
- package/dist/cjs/cryptography/mnemonics.js.map +1 -0
- package/dist/cjs/cryptography/publickey.js +112 -134
- package/dist/cjs/cryptography/publickey.js.map +1 -0
- package/dist/cjs/cryptography/signature-scheme.js +24 -43
- package/dist/cjs/cryptography/signature-scheme.js.map +1 -0
- package/dist/cjs/cryptography/signature.d.ts +2 -24
- package/dist/cjs/cryptography/signature.js +50 -67
- package/dist/cjs/cryptography/signature.js.map +1 -0
- package/dist/cjs/experimental/cache.js +65 -0
- package/dist/cjs/experimental/cache.js.map +1 -0
- package/dist/cjs/experimental/client.js +27 -0
- package/dist/cjs/experimental/client.js.map +1 -0
- package/dist/cjs/experimental/core.js +89 -0
- package/dist/cjs/experimental/core.js.map +1 -0
- package/dist/cjs/experimental/errors.js +32 -0
- package/dist/cjs/experimental/errors.js.map +1 -0
- package/dist/cjs/experimental/index.js +15 -0
- package/dist/cjs/experimental/index.js.map +1 -0
- package/dist/cjs/experimental/persistent-storage.js +343 -0
- package/dist/cjs/experimental/persistent-storage.js.map +1 -0
- package/dist/cjs/experimental/persistent-storage.test.js +200 -0
- package/dist/cjs/experimental/persistent-storage.test.js.map +1 -0
- package/dist/cjs/experimental/transports/utils.js +104 -0
- package/dist/cjs/experimental/transports/utils.js.map +1 -0
- package/dist/cjs/experimental/types.js +6 -0
- package/dist/cjs/experimental/types.js.map +1 -0
- package/dist/cjs/faucet/faucet.js +106 -124
- package/dist/cjs/faucet/faucet.js.map +1 -0
- package/dist/cjs/faucet/index.js +12 -28
- package/dist/cjs/faucet/index.js.map +1 -0
- package/dist/cjs/grpc/client.js +47 -62
- package/dist/cjs/grpc/client.js.map +1 -0
- package/dist/cjs/grpc/core.js +580 -617
- package/dist/cjs/grpc/core.js.map +1 -0
- package/dist/cjs/grpc/index.js +9 -25
- package/dist/cjs/grpc/index.js.map +1 -0
- package/dist/cjs/grpc/proto/google/protobuf/any.js +168 -135
- package/dist/cjs/grpc/proto/google/protobuf/any.js.map +1 -0
- package/dist/cjs/grpc/proto/google/protobuf/duration.js +105 -90
- package/dist/cjs/grpc/proto/google/protobuf/duration.js.map +1 -0
- package/dist/cjs/grpc/proto/google/protobuf/empty.js +50 -28
- package/dist/cjs/grpc/proto/google/protobuf/empty.js.map +1 -0
- package/dist/cjs/grpc/proto/google/protobuf/field_mask.js +96 -75
- package/dist/cjs/grpc/proto/google/protobuf/field_mask.js.map +1 -0
- package/dist/cjs/grpc/proto/google/protobuf/struct.js +266 -215
- package/dist/cjs/grpc/proto/google/protobuf/struct.js.map +1 -0
- package/dist/cjs/grpc/proto/google/protobuf/timestamp.js +150 -131
- package/dist/cjs/grpc/proto/google/protobuf/timestamp.js.map +1 -0
- package/dist/cjs/grpc/proto/google/rpc/error_details.js +331 -302
- package/dist/cjs/grpc/proto/google/rpc/error_details.js.map +1 -0
- package/dist/cjs/grpc/proto/google/rpc/status.js +50 -50
- package/dist/cjs/grpc/proto/google/rpc/status.js.map +1 -0
- package/dist/cjs/grpc/proto/sui/rpc/v2/argument.js +84 -68
- package/dist/cjs/grpc/proto/sui/rpc/v2/argument.js.map +1 -0
- package/dist/cjs/grpc/proto/sui/rpc/v2/balance_change.js +45 -50
- package/dist/cjs/grpc/proto/sui/rpc/v2/balance_change.js.map +1 -0
- package/dist/cjs/grpc/proto/sui/rpc/v2/bcs.js +38 -43
- package/dist/cjs/grpc/proto/sui/rpc/v2/bcs.js.map +1 -0
- package/dist/cjs/grpc/proto/sui/rpc/v2/checkpoint.js +70 -75
- package/dist/cjs/grpc/proto/sui/rpc/v2/checkpoint.js.map +1 -0
- package/dist/cjs/grpc/proto/sui/rpc/v2/checkpoint_contents.js +79 -81
- package/dist/cjs/grpc/proto/sui/rpc/v2/checkpoint_contents.js.map +1 -0
- package/dist/cjs/grpc/proto/sui/rpc/v2/checkpoint_summary.js +183 -166
- package/dist/cjs/grpc/proto/sui/rpc/v2/checkpoint_summary.js.map +1 -0
- package/dist/cjs/grpc/proto/sui/rpc/v2/effects.js +369 -296
- package/dist/cjs/grpc/proto/sui/rpc/v2/effects.js.map +1 -0
- package/dist/cjs/grpc/proto/sui/rpc/v2/epoch.js +80 -85
- package/dist/cjs/grpc/proto/sui/rpc/v2/epoch.js.map +1 -0
- package/dist/cjs/grpc/proto/sui/rpc/v2/error_reason.js +31 -28
- package/dist/cjs/grpc/proto/sui/rpc/v2/error_reason.js.map +1 -0
- package/dist/cjs/grpc/proto/sui/rpc/v2/event.js +81 -83
- package/dist/cjs/grpc/proto/sui/rpc/v2/event.js.map +1 -0
- package/dist/cjs/grpc/proto/sui/rpc/v2/executed_transaction.js +80 -85
- package/dist/cjs/grpc/proto/sui/rpc/v2/executed_transaction.js.map +1 -0
- package/dist/cjs/grpc/proto/sui/rpc/v2/execution_status.js +876 -506
- package/dist/cjs/grpc/proto/sui/rpc/v2/execution_status.js.map +1 -0
- package/dist/cjs/grpc/proto/sui/rpc/v2/gas_cost_summary.js +56 -61
- package/dist/cjs/grpc/proto/sui/rpc/v2/gas_cost_summary.js.map +1 -0
- package/dist/cjs/grpc/proto/sui/rpc/v2/input.js +103 -83
- package/dist/cjs/grpc/proto/sui/rpc/v2/input.js.map +1 -0
- package/dist/cjs/grpc/proto/sui/rpc/v2/jwk.js +76 -78
- package/dist/cjs/grpc/proto/sui/rpc/v2/jwk.js.map +1 -0
- package/dist/cjs/grpc/proto/sui/rpc/v2/ledger_service.client.js +69 -119
- package/dist/cjs/grpc/proto/sui/rpc/v2/ledger_service.client.js.map +1 -0
- package/dist/cjs/grpc/proto/sui/rpc/v2/ledger_service.js +392 -350
- package/dist/cjs/grpc/proto/sui/rpc/v2/ledger_service.js.map +1 -0
- package/dist/cjs/grpc/proto/sui/rpc/v2/move_package.js +599 -473
- package/dist/cjs/grpc/proto/sui/rpc/v2/move_package.js.map +1 -0
- package/dist/cjs/grpc/proto/sui/rpc/v2/move_package_service.client.js +46 -78
- package/dist/cjs/grpc/proto/sui/rpc/v2/move_package_service.client.js.map +1 -0
- package/dist/cjs/grpc/proto/sui/rpc/v2/move_package_service.js +242 -224
- package/dist/cjs/grpc/proto/sui/rpc/v2/move_package_service.js.map +1 -0
- package/dist/cjs/grpc/proto/sui/rpc/v2/name_service.client.js +32 -52
- package/dist/cjs/grpc/proto/sui/rpc/v2/name_service.client.js.map +1 -0
- package/dist/cjs/grpc/proto/sui/rpc/v2/name_service.js +139 -134
- package/dist/cjs/grpc/proto/sui/rpc/v2/name_service.js.map +1 -0
- package/dist/cjs/grpc/proto/sui/rpc/v2/object.js +109 -111
- package/dist/cjs/grpc/proto/sui/rpc/v2/object.js.map +1 -0
- package/dist/cjs/grpc/proto/sui/rpc/v2/object_reference.js +46 -51
- package/dist/cjs/grpc/proto/sui/rpc/v2/object_reference.js.map +1 -0
- package/dist/cjs/grpc/proto/sui/rpc/v2/owner.js +76 -61
- package/dist/cjs/grpc/proto/sui/rpc/v2/owner.js.map +1 -0
- package/dist/cjs/grpc/proto/sui/rpc/v2/protocol_config.js +46 -59
- package/dist/cjs/grpc/proto/sui/rpc/v2/protocol_config.js.map +1 -0
- package/dist/cjs/grpc/proto/sui/rpc/v2/signature.js +568 -522
- package/dist/cjs/grpc/proto/sui/rpc/v2/signature.js.map +1 -0
- package/dist/cjs/grpc/proto/sui/rpc/v2/signature_scheme.js +54 -32
- package/dist/cjs/grpc/proto/sui/rpc/v2/signature_scheme.js.map +1 -0
- package/dist/cjs/grpc/proto/sui/rpc/v2/signature_verification_service.client.js +27 -47
- package/dist/cjs/grpc/proto/sui/rpc/v2/signature_verification_service.client.js.map +1 -0
- package/dist/cjs/grpc/proto/sui/rpc/v2/signature_verification_service.js +83 -86
- package/dist/cjs/grpc/proto/sui/rpc/v2/signature_verification_service.js.map +1 -0
- package/dist/cjs/grpc/proto/sui/rpc/v2/state_service.client.js +53 -85
- package/dist/cjs/grpc/proto/sui/rpc/v2/state_service.client.js.map +1 -0
- package/dist/cjs/grpc/proto/sui/rpc/v2/state_service.js +645 -529
- package/dist/cjs/grpc/proto/sui/rpc/v2/state_service.js.map +1 -0
- package/dist/cjs/grpc/proto/sui/rpc/v2/subscription_service.client.js +37 -51
- package/dist/cjs/grpc/proto/sui/rpc/v2/subscription_service.client.js.map +1 -0
- package/dist/cjs/grpc/proto/sui/rpc/v2/subscription_service.js +58 -61
- package/dist/cjs/grpc/proto/sui/rpc/v2/subscription_service.js.map +1 -0
- package/dist/cjs/grpc/proto/sui/rpc/v2/system_state.js +749 -730
- package/dist/cjs/grpc/proto/sui/rpc/v2/system_state.js.map +1 -0
- package/dist/cjs/grpc/proto/sui/rpc/v2/transaction.js +1218 -975
- package/dist/cjs/grpc/proto/sui/rpc/v2/transaction.js.map +1 -0
- package/dist/cjs/grpc/proto/sui/rpc/v2/transaction_execution_service.client.js +32 -46
- package/dist/cjs/grpc/proto/sui/rpc/v2/transaction_execution_service.client.js.map +1 -0
- package/dist/cjs/grpc/proto/sui/rpc/v2/transaction_execution_service.js +186 -167
- package/dist/cjs/grpc/proto/sui/rpc/v2/transaction_execution_service.js.map +1 -0
- package/dist/cjs/index.js +96 -91
- package/dist/cjs/index.js.map +1 -0
- package/dist/cjs/jsonRpc/client.js +654 -743
- package/dist/cjs/jsonRpc/client.js.map +1 -0
- package/dist/cjs/jsonRpc/core.d.ts +7 -7
- package/dist/cjs/jsonRpc/core.js +562 -606
- package/dist/cjs/jsonRpc/core.js.map +1 -0
- package/dist/cjs/jsonRpc/errors.js +38 -56
- package/dist/cjs/jsonRpc/errors.js.map +1 -0
- package/dist/cjs/jsonRpc/http-transport.js +70 -114
- package/dist/cjs/jsonRpc/http-transport.js.map +1 -0
- package/dist/cjs/jsonRpc/index.js +14 -30
- package/dist/cjs/jsonRpc/index.js.map +1 -0
- package/dist/cjs/jsonRpc/json-rpc-resolver.js +286 -290
- package/dist/cjs/jsonRpc/json-rpc-resolver.js.map +1 -0
- package/dist/cjs/jsonRpc/rpc-websocket-client.js +150 -207
- package/dist/cjs/jsonRpc/rpc-websocket-client.js.map +1 -0
- package/dist/cjs/jsonRpc/types/chain.js +4 -15
- package/dist/cjs/jsonRpc/types/chain.js.map +1 -0
- package/dist/cjs/jsonRpc/types/changes.js +4 -15
- package/dist/cjs/jsonRpc/types/changes.js.map +1 -0
- package/dist/cjs/jsonRpc/types/coins.js +4 -15
- package/dist/cjs/jsonRpc/types/coins.js.map +1 -0
- package/dist/cjs/jsonRpc/types/common.js +4 -15
- package/dist/cjs/jsonRpc/types/common.js.map +1 -0
- package/dist/cjs/jsonRpc/types/generated.d.ts +1 -1
- package/dist/cjs/jsonRpc/types/generated.js +4 -15
- package/dist/cjs/jsonRpc/types/generated.js.map +1 -0
- package/dist/cjs/jsonRpc/types/index.js +4 -15
- package/dist/cjs/jsonRpc/types/index.js.map +1 -0
- package/dist/cjs/jsonRpc/types/params.js +4 -15
- package/dist/cjs/jsonRpc/types/params.js.map +1 -0
- package/dist/cjs/keypairs/ed25519/ed25519-hd-key.js +54 -69
- package/dist/cjs/keypairs/ed25519/ed25519-hd-key.js.map +1 -0
- package/dist/cjs/keypairs/ed25519/index.js +10 -26
- package/dist/cjs/keypairs/ed25519/index.js.map +1 -0
- package/dist/cjs/keypairs/ed25519/keypair.js +134 -159
- package/dist/cjs/keypairs/ed25519/keypair.js.map +1 -0
- package/dist/cjs/keypairs/ed25519/publickey.js +70 -84
- package/dist/cjs/keypairs/ed25519/publickey.js.map +1 -0
- package/dist/cjs/keypairs/index.js +21 -19
- package/dist/cjs/keypairs/index.js.map +1 -0
- package/dist/cjs/keypairs/passkey/index.js +11 -27
- package/dist/cjs/keypairs/passkey/index.js.map +1 -0
- package/dist/cjs/keypairs/passkey/keypair.js +245 -256
- package/dist/cjs/keypairs/passkey/keypair.js.map +1 -0
- package/dist/cjs/keypairs/passkey/publickey.js +163 -162
- package/dist/cjs/keypairs/passkey/publickey.js.map +1 -0
- package/dist/cjs/keypairs/passkey/types.js +4 -15
- package/dist/cjs/keypairs/passkey/types.js.map +1 -0
- package/dist/cjs/keypairs/secp256k1/index.js +10 -26
- package/dist/cjs/keypairs/secp256k1/index.js.map +1 -0
- package/dist/cjs/keypairs/secp256k1/keypair.js +129 -151
- package/dist/cjs/keypairs/secp256k1/keypair.js.map +1 -0
- package/dist/cjs/keypairs/secp256k1/publickey.js +71 -89
- package/dist/cjs/keypairs/secp256k1/publickey.js.map +1 -0
- package/dist/cjs/keypairs/secp256r1/index.js +10 -26
- package/dist/cjs/keypairs/secp256r1/index.js.map +1 -0
- package/dist/cjs/keypairs/secp256r1/keypair.js +127 -148
- package/dist/cjs/keypairs/secp256r1/keypair.js.map +1 -0
- package/dist/cjs/keypairs/secp256r1/publickey.js +72 -90
- package/dist/cjs/keypairs/secp256r1/publickey.js.map +1 -0
- package/dist/cjs/multisig/index.js +10 -26
- package/dist/cjs/multisig/index.js.map +1 -0
- package/dist/cjs/multisig/publickey.d.ts +1 -1
- package/dist/cjs/multisig/publickey.js +228 -276
- package/dist/cjs/multisig/publickey.js.map +1 -0
- package/dist/cjs/multisig/signer.js +62 -110
- package/dist/cjs/multisig/signer.js.map +1 -0
- package/dist/cjs/transactions/Arguments.d.ts +4 -4
- package/dist/cjs/transactions/Arguments.js +13 -34
- package/dist/cjs/transactions/Arguments.js.map +1 -0
- package/dist/cjs/transactions/Commands.js +111 -141
- package/dist/cjs/transactions/Commands.js.map +1 -0
- package/dist/cjs/transactions/Inputs.js +53 -82
- package/dist/cjs/transactions/Inputs.js.map +1 -0
- package/dist/cjs/transactions/ObjectCache.d.ts +8 -8
- package/dist/cjs/transactions/ObjectCache.js +204 -241
- package/dist/cjs/transactions/ObjectCache.js.map +1 -0
- package/dist/cjs/transactions/Transaction.d.ts +31 -31
- package/dist/cjs/transactions/Transaction.js +628 -719
- package/dist/cjs/transactions/Transaction.js.map +1 -0
- package/dist/cjs/transactions/TransactionData.d.ts +9 -9
- package/dist/cjs/transactions/TransactionData.js +396 -440
- package/dist/cjs/transactions/TransactionData.js.map +1 -0
- package/dist/cjs/transactions/__tests__/Transaction.test.js +169 -0
- package/dist/cjs/transactions/__tests__/Transaction.test.js.map +1 -0
- package/dist/cjs/transactions/__tests__/bcs.test.js +202 -0
- package/dist/cjs/transactions/__tests__/bcs.test.js.map +1 -0
- package/dist/cjs/transactions/data/internal.js +166 -207
- package/dist/cjs/transactions/data/internal.js.map +1 -0
- package/dist/cjs/transactions/data/v1.js +436 -495
- package/dist/cjs/transactions/data/v1.js.map +1 -0
- package/dist/cjs/transactions/data/v2.d.ts +5 -5
- package/dist/cjs/transactions/data/v2.js +94 -107
- package/dist/cjs/transactions/data/v2.js.map +1 -0
- package/dist/cjs/transactions/executor/caching.js +71 -113
- package/dist/cjs/transactions/executor/caching.js.map +1 -0
- package/dist/cjs/transactions/executor/parallel.js +339 -378
- package/dist/cjs/transactions/executor/parallel.js.map +1 -0
- package/dist/cjs/transactions/executor/queue.js +60 -80
- package/dist/cjs/transactions/executor/queue.js.map +1 -0
- package/dist/cjs/transactions/executor/serial.d.ts +4 -4
- package/dist/cjs/transactions/executor/serial.js +102 -131
- package/dist/cjs/transactions/executor/serial.js.map +1 -0
- package/dist/cjs/transactions/hash.js +17 -28
- package/dist/cjs/transactions/hash.js.map +1 -0
- package/dist/cjs/transactions/index.js +33 -49
- package/dist/cjs/transactions/index.js.map +1 -0
- package/dist/cjs/transactions/intents/CoinWithBalance.js +137 -191
- package/dist/cjs/transactions/intents/CoinWithBalance.js.map +1 -0
- package/dist/cjs/transactions/object.js +88 -111
- package/dist/cjs/transactions/object.js.map +1 -0
- package/dist/cjs/transactions/plugins/NamedPackagesPlugin.js +20 -32
- package/dist/cjs/transactions/plugins/NamedPackagesPlugin.js.map +1 -0
- package/dist/cjs/transactions/pure.js +38 -60
- package/dist/cjs/transactions/pure.js.map +1 -0
- package/dist/cjs/transactions/resolve.js +62 -88
- package/dist/cjs/transactions/resolve.js.map +1 -0
- package/dist/cjs/transactions/serializer.js +150 -163
- package/dist/cjs/transactions/serializer.js.map +1 -0
- package/dist/cjs/transactions/utils.d.ts +1 -1
- package/dist/cjs/transactions/utils.js +114 -125
- package/dist/cjs/transactions/utils.js.map +1 -0
- package/dist/cjs/utils/constants.js +29 -56
- package/dist/cjs/utils/constants.js.map +1 -0
- package/dist/cjs/utils/derived-objects.js +14 -30
- package/dist/cjs/utils/derived-objects.js.map +1 -0
- package/dist/cjs/utils/dynamic-fields.js +20 -37
- package/dist/cjs/utils/dynamic-fields.js.map +1 -0
- package/dist/cjs/utils/format.js +14 -30
- package/dist/cjs/utils/format.js.map +1 -0
- package/dist/cjs/utils/index.js +50 -64
- package/dist/cjs/utils/index.js.map +1 -0
- package/dist/cjs/utils/move-registry.js +37 -35
- package/dist/cjs/utils/move-registry.js.map +1 -0
- package/dist/cjs/utils/sui-types.js +74 -68
- package/dist/cjs/utils/sui-types.js.map +1 -0
- package/dist/cjs/utils/suins.js +30 -46
- package/dist/cjs/utils/suins.js.map +1 -0
- package/dist/cjs/verify/index.js +12 -27
- package/dist/cjs/verify/index.js.map +1 -0
- package/dist/cjs/verify/verify.js +83 -110
- package/dist/cjs/verify/verify.js.map +1 -0
- package/dist/cjs/version.js +8 -25
- package/dist/cjs/version.js.map +1 -0
- package/dist/cjs/w/call/allocation.js +323 -413
- package/dist/cjs/w/call/allocation.js.map +1 -0
- package/dist/cjs/w/call/arb.js +105 -136
- package/dist/cjs/w/call/arb.js.map +1 -0
- package/dist/cjs/w/call/arbitration.js +1206 -1581
- package/dist/cjs/w/call/arbitration.js.map +1 -0
- package/dist/cjs/w/call/base.js +303 -333
- package/dist/cjs/w/call/base.js.map +1 -0
- package/dist/cjs/w/call/contact.js +335 -452
- package/dist/cjs/w/call/contact.js.map +1 -0
- package/dist/cjs/w/call/demand.js +690 -844
- package/dist/cjs/w/call/demand.js.map +1 -0
- package/dist/cjs/w/call/entity.js +167 -201
- package/dist/cjs/w/call/entity.js.map +1 -0
- package/dist/cjs/w/call/guard-ins.js +4376 -4389
- package/dist/cjs/w/call/guard-ins.js.map +1 -0
- package/dist/cjs/w/call/guard.js +1078 -1112
- package/dist/cjs/w/call/guard.js.map +1 -0
- package/dist/cjs/w/call/index.js +69 -70
- package/dist/cjs/w/call/index.js.map +1 -0
- package/dist/cjs/w/call/machine.js +1105 -1419
- package/dist/cjs/w/call/machine.js.map +1 -0
- package/dist/cjs/w/call/order.js +314 -454
- package/dist/cjs/w/call/order.js.map +1 -0
- package/dist/cjs/w/call/passport.js +214 -253
- package/dist/cjs/w/call/passport.js.map +1 -0
- package/dist/cjs/w/call/payment.js +187 -224
- package/dist/cjs/w/call/payment.js.map +1 -0
- package/dist/cjs/w/call/permission.js +1183 -1294
- package/dist/cjs/w/call/permission.js.map +1 -0
- package/dist/cjs/w/call/personal.js +132 -170
- package/dist/cjs/w/call/personal.js.map +1 -0
- package/dist/cjs/w/call/progress.js +634 -794
- package/dist/cjs/w/call/progress.js.map +1 -0
- package/dist/cjs/w/call/proof.js +67 -116
- package/dist/cjs/w/call/proof.js.map +1 -0
- package/dist/cjs/w/call/repository.js +1037 -1251
- package/dist/cjs/w/call/repository.js.map +1 -0
- package/dist/cjs/w/call/resource.js +111 -131
- package/dist/cjs/w/call/resource.js.map +1 -0
- package/dist/cjs/w/call/reward.js +675 -853
- package/dist/cjs/w/call/reward.js.map +1 -0
- package/dist/cjs/w/call/service.js +1879 -2385
- package/dist/cjs/w/call/service.js.map +1 -0
- package/dist/cjs/w/call/treasury.js +841 -1138
- package/dist/cjs/w/call/treasury.js.map +1 -0
- package/dist/cjs/w/call/util.js +593 -624
- package/dist/cjs/w/call/util.js.map +1 -0
- package/dist/cjs/w/common.d.ts +1 -1
- package/dist/cjs/w/common.js +548 -518
- package/dist/cjs/w/common.js.map +1 -0
- package/dist/cjs/w/exception.js +574 -584
- package/dist/cjs/w/exception.js.map +1 -0
- package/dist/cjs/w/index.js +26 -23
- package/dist/cjs/w/index.js.map +1 -0
- package/dist/cjs/w/local/account.js +664 -741
- package/dist/cjs/w/local/account.js.map +1 -0
- package/dist/cjs/w/local/cache.js +180 -166
- package/dist/cjs/w/local/cache.js.map +1 -0
- package/dist/cjs/w/local/config.js +51 -80
- package/dist/cjs/w/local/config.js.map +1 -0
- package/dist/cjs/w/local/index.js +225 -290
- package/dist/cjs/w/local/index.js.map +1 -0
- package/dist/cjs/w/local/local.d.ts +2 -2
- package/dist/cjs/w/local/local.js +638 -646
- package/dist/cjs/w/local/local.js.map +1 -0
- package/dist/cjs/w/local/storage.js +210 -164
- package/dist/cjs/w/local/storage.js.map +1 -0
- package/dist/cjs/w/local/token.js +158 -175
- package/dist/cjs/w/local/token.js.map +1 -0
- package/dist/cjs/w/local/util.js +80 -51
- package/dist/cjs/w/local/util.js.map +1 -0
- package/dist/cjs/w/local/wip.js +1078 -802
- package/dist/cjs/w/local/wip.js.map +1 -0
- package/dist/cjs/w/messenger/crypto.js +496 -389
- package/dist/cjs/w/messenger/crypto.js.map +1 -0
- package/dist/cjs/w/messenger/index.js +53 -35
- package/dist/cjs/w/messenger/index.js.map +1 -0
- package/dist/cjs/w/messenger/messenger-api.js +1159 -1035
- package/dist/cjs/w/messenger/messenger-api.js.map +1 -0
- package/dist/cjs/w/messenger/messenger-manager.js +954 -1083
- package/dist/cjs/w/messenger/messenger-manager.js.map +1 -0
- package/dist/cjs/w/messenger/messenger.d.ts +1 -1
- package/dist/cjs/w/messenger/messenger.js +1304 -1450
- package/dist/cjs/w/messenger/messenger.js.map +1 -0
- package/dist/cjs/w/messenger/server.js +390 -512
- package/dist/cjs/w/messenger/server.js.map +1 -0
- package/dist/cjs/w/messenger/session.js +399 -403
- package/dist/cjs/w/messenger/session.js.map +1 -0
- package/dist/cjs/w/messenger/storage.js +881 -777
- package/dist/cjs/w/messenger/storage.js.map +1 -0
- package/dist/cjs/w/messenger/types.d.ts +2 -2
- package/dist/cjs/w/messenger/types.js +83 -103
- package/dist/cjs/w/messenger/types.js.map +1 -0
- package/dist/cjs/w/messenger/utils.js +29 -34
- package/dist/cjs/w/messenger/utils.js.map +1 -0
- package/dist/cjs/w/query/bult-in.js +101 -110
- package/dist/cjs/w/query/bult-in.js.map +1 -0
- package/dist/cjs/w/query/event.js +134 -146
- package/dist/cjs/w/query/event.js.map +1 -0
- package/dist/cjs/w/query/index.js +22 -20
- package/dist/cjs/w/query/index.js.map +1 -0
- package/dist/cjs/w/query/object.js +1576 -1576
- package/dist/cjs/w/query/object.js.map +1 -0
- package/dist/cjs/w/query/received.js +66 -88
- package/dist/cjs/w/query/received.js.map +1 -0
- package/dist/cjs/w/query/util.js +53 -77
- package/dist/cjs/w/query/util.js.map +1 -0
- package/dist/cjs/w/util.js +589 -675
- package/dist/cjs/w/util.js.map +1 -0
- package/dist/esm/bcs/bcs.d.ts +199 -199
- package/dist/esm/bcs/bcs.js +269 -310
- package/dist/esm/bcs/bcs.js.map +1 -0
- package/dist/esm/bcs/effects.d.ts +109 -109
- package/dist/esm/bcs/effects.js +171 -179
- package/dist/esm/bcs/effects.js.map +1 -0
- package/dist/esm/bcs/index.d.ts +1 -2584
- package/dist/esm/bcs/index.js +51 -94
- package/dist/esm/bcs/index.js.map +1 -0
- package/dist/esm/bcs/pure.js +35 -38
- package/dist/esm/bcs/pure.js.map +1 -0
- package/dist/esm/bcs/type-tag-serializer.js +98 -95
- package/dist/esm/bcs/type-tag-serializer.js.map +1 -0
- package/dist/esm/bcs/types.js +5 -5
- package/dist/esm/bcs/types.js.map +1 -0
- package/dist/esm/client/index.js +7 -23
- package/dist/esm/client/index.js.map +1 -0
- package/dist/esm/client/network.js +23 -22
- package/dist/esm/client/network.js.map +1 -0
- package/dist/esm/cryptography/index.js +9 -46
- package/dist/esm/cryptography/index.js.map +1 -0
- package/dist/esm/cryptography/intent.d.ts +1 -1
- package/dist/esm/cryptography/intent.js +18 -12
- package/dist/esm/cryptography/intent.js.map +1 -0
- package/dist/esm/cryptography/keypair.js +95 -99
- package/dist/esm/cryptography/keypair.js.map +1 -0
- package/dist/esm/cryptography/mnemonics.js +40 -24
- package/dist/esm/cryptography/mnemonics.js.map +1 -0
- package/dist/esm/cryptography/publickey.js +104 -115
- package/dist/esm/cryptography/publickey.js.map +1 -0
- package/dist/esm/cryptography/signature-scheme.js +22 -24
- package/dist/esm/cryptography/signature-scheme.js.map +1 -0
- package/dist/esm/cryptography/signature.d.ts +2 -24
- package/dist/esm/cryptography/signature.js +44 -48
- package/dist/esm/cryptography/signature.js.map +1 -0
- package/dist/esm/experimental/cache.js +61 -0
- package/dist/esm/experimental/cache.js.map +1 -0
- package/dist/esm/experimental/client.js +23 -0
- package/dist/esm/experimental/client.js.map +1 -0
- package/dist/esm/experimental/core.js +85 -0
- package/dist/esm/experimental/core.js.map +1 -0
- package/dist/esm/experimental/errors.js +27 -0
- package/dist/esm/experimental/errors.js.map +1 -0
- package/dist/esm/experimental/index.js +8 -0
- package/dist/esm/experimental/index.js.map +1 -0
- package/dist/esm/experimental/persistent-storage.js +337 -0
- package/dist/esm/experimental/persistent-storage.js.map +1 -0
- package/dist/esm/experimental/persistent-storage.test.js +198 -0
- package/dist/esm/experimental/persistent-storage.test.js.map +1 -0
- package/dist/esm/experimental/transports/utils.js +100 -0
- package/dist/esm/experimental/transports/utils.js.map +1 -0
- package/dist/esm/experimental/types.js +5 -0
- package/dist/esm/experimental/types.js.map +1 -0
- package/dist/esm/faucet/faucet.js +104 -111
- package/dist/esm/faucet/faucet.js.map +1 -0
- package/dist/esm/faucet/index.js +4 -16
- package/dist/esm/faucet/index.js.map +1 -0
- package/dist/esm/grpc/client.js +34 -34
- package/dist/esm/grpc/client.js.map +1 -0
- package/dist/esm/grpc/core.js +570 -601
- package/dist/esm/grpc/core.js.map +1 -0
- package/dist/esm/grpc/index.js +5 -6
- package/dist/esm/grpc/index.js.map +1 -0
- package/dist/esm/grpc/proto/google/protobuf/any.js +161 -111
- package/dist/esm/grpc/proto/google/protobuf/any.js.map +1 -0
- package/dist/esm/grpc/proto/google/protobuf/duration.js +99 -67
- package/dist/esm/grpc/proto/google/protobuf/duration.js.map +1 -0
- package/dist/esm/grpc/proto/google/protobuf/empty.js +46 -7
- package/dist/esm/grpc/proto/google/protobuf/empty.js.map +1 -0
- package/dist/esm/grpc/proto/google/protobuf/field_mask.js +90 -52
- package/dist/esm/grpc/proto/google/protobuf/field_mask.js.map +1 -0
- package/dist/esm/grpc/proto/google/protobuf/struct.js +258 -190
- package/dist/esm/grpc/proto/google/protobuf/struct.js.map +1 -0
- package/dist/esm/grpc/proto/google/protobuf/timestamp.js +144 -108
- package/dist/esm/grpc/proto/google/protobuf/timestamp.js.map +1 -0
- package/dist/esm/grpc/proto/google/rpc/error_details.js +313 -267
- package/dist/esm/grpc/proto/google/rpc/error_details.js.map +1 -0
- package/dist/esm/grpc/proto/google/rpc/status.js +45 -28
- package/dist/esm/grpc/proto/google/rpc/status.js.map +1 -0
- package/dist/esm/grpc/proto/sui/rpc/v2/argument.js +80 -47
- package/dist/esm/grpc/proto/sui/rpc/v2/argument.js.map +1 -0
- package/dist/esm/grpc/proto/sui/rpc/v2/balance_change.js +41 -29
- package/dist/esm/grpc/proto/sui/rpc/v2/balance_change.js.map +1 -0
- package/dist/esm/grpc/proto/sui/rpc/v2/bcs.js +34 -22
- package/dist/esm/grpc/proto/sui/rpc/v2/bcs.js.map +1 -0
- package/dist/esm/grpc/proto/sui/rpc/v2/checkpoint.js +61 -49
- package/dist/esm/grpc/proto/sui/rpc/v2/checkpoint.js.map +1 -0
- package/dist/esm/grpc/proto/sui/rpc/v2/checkpoint_contents.js +72 -57
- package/dist/esm/grpc/proto/sui/rpc/v2/checkpoint_contents.js.map +1 -0
- package/dist/esm/grpc/proto/sui/rpc/v2/checkpoint_summary.js +173 -139
- package/dist/esm/grpc/proto/sui/rpc/v2/checkpoint_summary.js.map +1 -0
- package/dist/esm/grpc/proto/sui/rpc/v2/effects.js +358 -268
- package/dist/esm/grpc/proto/sui/rpc/v2/effects.js.map +1 -0
- package/dist/esm/grpc/proto/sui/rpc/v2/epoch.js +72 -60
- package/dist/esm/grpc/proto/sui/rpc/v2/epoch.js.map +1 -0
- package/dist/esm/grpc/proto/sui/rpc/v2/error_reason.js +29 -9
- package/dist/esm/grpc/proto/sui/rpc/v2/error_reason.js.map +1 -0
- package/dist/esm/grpc/proto/sui/rpc/v2/event.js +74 -59
- package/dist/esm/grpc/proto/sui/rpc/v2/event.js.map +1 -0
- package/dist/esm/grpc/proto/sui/rpc/v2/executed_transaction.js +69 -57
- package/dist/esm/grpc/proto/sui/rpc/v2/executed_transaction.js.map +1 -0
- package/dist/esm/grpc/proto/sui/rpc/v2/execution_status.js +861 -474
- package/dist/esm/grpc/proto/sui/rpc/v2/execution_status.js.map +1 -0
- package/dist/esm/grpc/proto/sui/rpc/v2/gas_cost_summary.js +52 -40
- package/dist/esm/grpc/proto/sui/rpc/v2/gas_cost_summary.js.map +1 -0
- package/dist/esm/grpc/proto/sui/rpc/v2/input.js +98 -61
- package/dist/esm/grpc/proto/sui/rpc/v2/input.js.map +1 -0
- package/dist/esm/grpc/proto/sui/rpc/v2/jwk.js +71 -56
- package/dist/esm/grpc/proto/sui/rpc/v2/jwk.js.map +1 -0
- package/dist/esm/grpc/proto/sui/rpc/v2/ledger_service.client.js +65 -100
- package/dist/esm/grpc/proto/sui/rpc/v2/ledger_service.client.js.map +1 -0
- package/dist/esm/grpc/proto/sui/rpc/v2/ledger_service.js +365 -306
- package/dist/esm/grpc/proto/sui/rpc/v2/ledger_service.js.map +1 -0
- package/dist/esm/grpc/proto/sui/rpc/v2/move_package.js +585 -442
- package/dist/esm/grpc/proto/sui/rpc/v2/move_package.js.map +1 -0
- package/dist/esm/grpc/proto/sui/rpc/v2/move_package_service.client.js +42 -59
- package/dist/esm/grpc/proto/sui/rpc/v2/move_package_service.client.js.map +1 -0
- package/dist/esm/grpc/proto/sui/rpc/v2/move_package_service.js +226 -191
- package/dist/esm/grpc/proto/sui/rpc/v2/move_package_service.js.map +1 -0
- package/dist/esm/grpc/proto/sui/rpc/v2/name_service.client.js +28 -33
- package/dist/esm/grpc/proto/sui/rpc/v2/name_service.client.js.map +1 -0
- package/dist/esm/grpc/proto/sui/rpc/v2/name_service.js +129 -107
- package/dist/esm/grpc/proto/sui/rpc/v2/name_service.js.map +1 -0
- package/dist/esm/grpc/proto/sui/rpc/v2/object.js +100 -85
- package/dist/esm/grpc/proto/sui/rpc/v2/object.js.map +1 -0
- package/dist/esm/grpc/proto/sui/rpc/v2/object_reference.js +42 -30
- package/dist/esm/grpc/proto/sui/rpc/v2/object_reference.js.map +1 -0
- package/dist/esm/grpc/proto/sui/rpc/v2/owner.js +72 -40
- package/dist/esm/grpc/proto/sui/rpc/v2/owner.js.map +1 -0
- package/dist/esm/grpc/proto/sui/rpc/v2/protocol_config.js +42 -38
- package/dist/esm/grpc/proto/sui/rpc/v2/protocol_config.js.map +1 -0
- package/dist/esm/grpc/proto/sui/rpc/v2/signature.js +544 -481
- package/dist/esm/grpc/proto/sui/rpc/v2/signature.js.map +1 -0
- package/dist/esm/grpc/proto/sui/rpc/v2/signature_scheme.js +52 -13
- package/dist/esm/grpc/proto/sui/rpc/v2/signature_scheme.js.map +1 -0
- package/dist/esm/grpc/proto/sui/rpc/v2/signature_verification_service.client.js +23 -28
- package/dist/esm/grpc/proto/sui/rpc/v2/signature_verification_service.client.js.map +1 -0
- package/dist/esm/grpc/proto/sui/rpc/v2/signature_verification_service.js +74 -60
- package/dist/esm/grpc/proto/sui/rpc/v2/signature_verification_service.js.map +1 -0
- package/dist/esm/grpc/proto/sui/rpc/v2/state_service.client.js +49 -66
- package/dist/esm/grpc/proto/sui/rpc/v2/state_service.client.js.map +1 -0
- package/dist/esm/grpc/proto/sui/rpc/v2/state_service.js +623 -490
- package/dist/esm/grpc/proto/sui/rpc/v2/state_service.js.map +1 -0
- package/dist/esm/grpc/proto/sui/rpc/v2/subscription_service.client.js +33 -32
- package/dist/esm/grpc/proto/sui/rpc/v2/subscription_service.client.js.map +1 -0
- package/dist/esm/grpc/proto/sui/rpc/v2/subscription_service.js +50 -36
- package/dist/esm/grpc/proto/sui/rpc/v2/subscription_service.js.map +1 -0
- package/dist/esm/grpc/proto/sui/rpc/v2/system_state.js +737 -701
- package/dist/esm/grpc/proto/sui/rpc/v2/system_state.js.map +1 -0
- package/dist/esm/grpc/proto/sui/rpc/v2/transaction.js +1177 -917
- package/dist/esm/grpc/proto/sui/rpc/v2/transaction.js.map +1 -0
- package/dist/esm/grpc/proto/sui/rpc/v2/transaction_execution_service.client.js +28 -27
- package/dist/esm/grpc/proto/sui/rpc/v2/transaction_execution_service.client.js.map +1 -0
- package/dist/esm/grpc/proto/sui/rpc/v2/transaction_execution_service.js +169 -133
- package/dist/esm/grpc/proto/sui/rpc/v2/transaction_execution_service.js.map +1 -0
- package/dist/esm/index.js +21 -107
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/jsonRpc/client.js +646 -727
- package/dist/esm/jsonRpc/client.js.map +1 -0
- package/dist/esm/jsonRpc/core.d.ts +7 -7
- package/dist/esm/jsonRpc/core.js +550 -581
- package/dist/esm/jsonRpc/core.js.map +1 -0
- package/dist/esm/jsonRpc/errors.js +36 -41
- package/dist/esm/jsonRpc/errors.js.map +1 -0
- package/dist/esm/jsonRpc/http-transport.js +65 -93
- package/dist/esm/jsonRpc/http-transport.js.map +1 -0
- package/dist/esm/jsonRpc/index.js +6 -20
- package/dist/esm/jsonRpc/index.js.map +1 -0
- package/dist/esm/jsonRpc/json-rpc-resolver.js +281 -276
- package/dist/esm/jsonRpc/json-rpc-resolver.js.map +1 -0
- package/dist/esm/jsonRpc/rpc-websocket-client.js +147 -189
- package/dist/esm/jsonRpc/rpc-websocket-client.js.map +1 -0
- package/dist/esm/jsonRpc/types/chain.js +4 -0
- package/dist/esm/jsonRpc/types/chain.js.map +1 -0
- package/dist/esm/jsonRpc/types/changes.js +4 -0
- package/dist/esm/jsonRpc/types/changes.js.map +1 -0
- package/dist/esm/jsonRpc/types/coins.js +4 -0
- package/dist/esm/jsonRpc/types/coins.js.map +1 -0
- package/dist/esm/jsonRpc/types/common.js +4 -0
- package/dist/esm/jsonRpc/types/common.js.map +1 -0
- package/dist/esm/jsonRpc/types/generated.d.ts +1 -1
- package/dist/esm/jsonRpc/types/generated.js +4 -0
- package/dist/esm/jsonRpc/types/generated.js.map +1 -0
- package/dist/esm/jsonRpc/types/index.js +4 -0
- package/dist/esm/jsonRpc/types/index.js.map +1 -0
- package/dist/esm/jsonRpc/types/params.js +4 -0
- package/dist/esm/jsonRpc/types/params.js.map +1 -0
- package/dist/esm/keypairs/ed25519/ed25519-hd-key.js +49 -48
- package/dist/esm/keypairs/ed25519/ed25519-hd-key.js.map +1 -0
- package/dist/esm/keypairs/ed25519/index.js +5 -10
- package/dist/esm/keypairs/ed25519/index.js.map +1 -0
- package/dist/esm/keypairs/ed25519/keypair.js +128 -146
- package/dist/esm/keypairs/ed25519/keypair.js.map +1 -0
- package/dist/esm/keypairs/ed25519/publickey.js +64 -67
- package/dist/esm/keypairs/ed25519/publickey.js.map +1 -0
- package/dist/esm/keypairs/index.js +3 -0
- package/dist/esm/keypairs/index.js.map +1 -0
- package/dist/esm/keypairs/passkey/index.js +5 -12
- package/dist/esm/keypairs/passkey/index.js.map +1 -0
- package/dist/esm/keypairs/passkey/keypair.js +236 -243
- package/dist/esm/keypairs/passkey/keypair.js.map +1 -0
- package/dist/esm/keypairs/passkey/publickey.js +154 -140
- package/dist/esm/keypairs/passkey/publickey.js.map +1 -0
- package/dist/esm/keypairs/passkey/types.js +4 -0
- package/dist/esm/keypairs/passkey/types.js.map +1 -0
- package/dist/esm/keypairs/secp256k1/index.js +5 -10
- package/dist/esm/keypairs/secp256k1/index.js.map +1 -0
- package/dist/esm/keypairs/secp256k1/keypair.js +120 -134
- package/dist/esm/keypairs/secp256k1/keypair.js.map +1 -0
- package/dist/esm/keypairs/secp256k1/publickey.js +64 -71
- package/dist/esm/keypairs/secp256k1/publickey.js.map +1 -0
- package/dist/esm/keypairs/secp256r1/index.js +5 -10
- package/dist/esm/keypairs/secp256r1/index.js.map +1 -0
- package/dist/esm/keypairs/secp256r1/keypair.js +118 -131
- package/dist/esm/keypairs/secp256r1/keypair.js.map +1 -0
- package/dist/esm/keypairs/secp256r1/publickey.js +63 -66
- package/dist/esm/keypairs/secp256r1/publickey.js.map +1 -0
- package/dist/esm/multisig/index.js +5 -10
- package/dist/esm/multisig/index.js.map +1 -0
- package/dist/esm/multisig/publickey.d.ts +1 -1
- package/dist/esm/multisig/publickey.js +216 -253
- package/dist/esm/multisig/publickey.js.map +1 -0
- package/dist/esm/multisig/signer.js +57 -89
- package/dist/esm/multisig/signer.js.map +1 -0
- package/dist/esm/transactions/Arguments.d.ts +4 -4
- package/dist/esm/transactions/Arguments.js +9 -13
- package/dist/esm/transactions/Arguments.js.map +1 -0
- package/dist/esm/transactions/Commands.js +105 -118
- package/dist/esm/transactions/Commands.js.map +1 -0
- package/dist/esm/transactions/Inputs.js +49 -61
- package/dist/esm/transactions/Inputs.js.map +1 -0
- package/dist/esm/transactions/ObjectCache.d.ts +8 -8
- package/dist/esm/transactions/ObjectCache.js +200 -223
- package/dist/esm/transactions/ObjectCache.js.map +1 -0
- package/dist/esm/transactions/Transaction.d.ts +32 -32
- package/dist/esm/transactions/Transaction.js +611 -696
- package/dist/esm/transactions/Transaction.js.map +1 -0
- package/dist/esm/transactions/TransactionData.d.ts +9 -9
- package/dist/esm/transactions/TransactionData.js +386 -415
- package/dist/esm/transactions/TransactionData.js.map +1 -0
- package/dist/esm/transactions/__tests__/Transaction.test.js +167 -0
- package/dist/esm/transactions/__tests__/Transaction.test.js.map +1 -0
- package/dist/esm/transactions/__tests__/bcs.test.js +200 -0
- package/dist/esm/transactions/__tests__/bcs.test.js.map +1 -0
- package/dist/esm/transactions/data/internal.js +158 -205
- package/dist/esm/transactions/data/internal.js.map +1 -0
- package/dist/esm/transactions/data/v1.js +419 -487
- package/dist/esm/transactions/data/v1.js.map +1 -0
- package/dist/esm/transactions/data/v2.d.ts +5 -5
- package/dist/esm/transactions/data/v2.js +89 -107
- package/dist/esm/transactions/data/v2.js.map +1 -0
- package/dist/esm/transactions/executor/caching.d.ts +2 -2
- package/dist/esm/transactions/executor/caching.js +66 -93
- package/dist/esm/transactions/executor/caching.js.map +1 -0
- package/dist/esm/transactions/executor/parallel.js +329 -352
- package/dist/esm/transactions/executor/parallel.js.map +1 -0
- package/dist/esm/transactions/executor/queue.js +58 -64
- package/dist/esm/transactions/executor/queue.js.map +1 -0
- package/dist/esm/transactions/executor/serial.d.ts +5 -5
- package/dist/esm/transactions/executor/serial.js +96 -110
- package/dist/esm/transactions/executor/serial.js.map +1 -0
- package/dist/esm/transactions/hash.js +15 -9
- package/dist/esm/transactions/hash.js.map +1 -0
- package/dist/esm/transactions/index.js +15 -41
- package/dist/esm/transactions/index.js.map +1 -0
- package/dist/esm/transactions/intents/CoinWithBalance.js +127 -165
- package/dist/esm/transactions/intents/CoinWithBalance.js.map +1 -0
- package/dist/esm/transactions/object.js +86 -92
- package/dist/esm/transactions/object.js.map +1 -0
- package/dist/esm/transactions/plugins/NamedPackagesPlugin.js +18 -15
- package/dist/esm/transactions/plugins/NamedPackagesPlugin.js.map +1 -0
- package/dist/esm/transactions/pure.js +34 -39
- package/dist/esm/transactions/pure.js.map +1 -0
- package/dist/esm/transactions/resolve.js +58 -69
- package/dist/esm/transactions/resolve.js.map +1 -0
- package/dist/esm/transactions/serializer.js +145 -144
- package/dist/esm/transactions/serializer.js.map +1 -0
- package/dist/esm/transactions/utils.d.ts +1 -1
- package/dist/esm/transactions/utils.js +110 -109
- package/dist/esm/transactions/utils.js.map +1 -0
- package/dist/esm/utils/constants.js +26 -36
- package/dist/esm/utils/constants.js.map +1 -0
- package/dist/esm/utils/derived-objects.js +11 -10
- package/dist/esm/utils/derived-objects.js.map +1 -0
- package/dist/esm/utils/dynamic-fields.js +16 -16
- package/dist/esm/utils/dynamic-fields.js.map +1 -0
- package/dist/esm/utils/format.js +13 -13
- package/dist/esm/utils/format.js.map +1 -0
- package/dist/esm/utils/index.js +15 -76
- package/dist/esm/utils/index.js.map +1 -0
- package/dist/esm/utils/move-registry.js +34 -17
- package/dist/esm/utils/move-registry.js.map +1 -0
- package/dist/esm/utils/sui-types.js +70 -54
- package/dist/esm/utils/sui-types.js.map +1 -0
- package/dist/esm/utils/suins.js +29 -29
- package/dist/esm/utils/suins.js.map +1 -0
- package/dist/esm/verify/index.js +5 -14
- package/dist/esm/verify/index.js.map +1 -0
- package/dist/esm/verify/verify.js +76 -93
- package/dist/esm/verify/verify.js.map +1 -0
- package/dist/esm/version.js +6 -6
- package/dist/esm/version.js.map +1 -0
- package/dist/esm/w/call/allocation.js +307 -402
- package/dist/esm/w/call/allocation.js.map +1 -0
- package/dist/esm/w/call/arb.js +100 -129
- package/dist/esm/w/call/arb.js.map +1 -0
- package/dist/esm/w/call/arbitration.js +1170 -1568
- package/dist/esm/w/call/arbitration.js.map +1 -0
- package/dist/esm/w/call/base.js +288 -315
- package/dist/esm/w/call/base.js.map +1 -0
- package/dist/esm/w/call/contact.js +318 -442
- package/dist/esm/w/call/contact.js.map +1 -0
- package/dist/esm/w/call/demand.js +673 -841
- package/dist/esm/w/call/demand.js.map +1 -0
- package/dist/esm/w/call/entity.js +162 -203
- package/dist/esm/w/call/entity.js.map +1 -0
- package/dist/esm/w/call/guard-ins.js +4373 -4371
- package/dist/esm/w/call/guard-ins.js.map +1 -0
- package/dist/esm/w/call/guard.js +1061 -1108
- package/dist/esm/w/call/guard.js.map +1 -0
- package/dist/esm/w/call/index.js +24 -56
- package/dist/esm/w/call/index.js.map +1 -0
- package/dist/esm/w/call/machine.js +1086 -1433
- package/dist/esm/w/call/machine.js.map +1 -0
- package/dist/esm/w/call/order.js +301 -448
- package/dist/esm/w/call/order.js.map +1 -0
- package/dist/esm/w/call/passport.js +204 -240
- package/dist/esm/w/call/passport.js.map +1 -0
- package/dist/esm/w/call/payment.js +177 -215
- package/dist/esm/w/call/payment.js.map +1 -0
- package/dist/esm/w/call/permission.js +1172 -1320
- package/dist/esm/w/call/permission.js.map +1 -0
- package/dist/esm/w/call/personal.js +121 -156
- package/dist/esm/w/call/personal.js.map +1 -0
- package/dist/esm/w/call/progress.js +625 -797
- package/dist/esm/w/call/progress.js.map +1 -0
- package/dist/esm/w/call/proof.js +61 -103
- package/dist/esm/w/call/proof.js.map +1 -0
- package/dist/esm/w/call/repository.js +1017 -1251
- package/dist/esm/w/call/repository.js.map +1 -0
- package/dist/esm/w/call/resource.js +108 -124
- package/dist/esm/w/call/resource.js.map +1 -0
- package/dist/esm/w/call/reward.js +660 -847
- package/dist/esm/w/call/reward.js.map +1 -0
- package/dist/esm/w/call/service.js +1849 -2400
- package/dist/esm/w/call/service.js.map +1 -0
- package/dist/esm/w/call/treasury.js +815 -1125
- package/dist/esm/w/call/treasury.js.map +1 -0
- package/dist/esm/w/call/util.js +553 -576
- package/dist/esm/w/call/util.js.map +1 -0
- package/dist/esm/w/common.d.ts +1 -1
- package/dist/esm/w/common.js +579 -580
- package/dist/esm/w/common.js.map +1 -0
- package/dist/esm/w/exception.js +570 -573
- package/dist/esm/w/exception.js.map +1 -0
- package/dist/esm/w/index.js +4 -0
- package/dist/esm/w/index.js.map +1 -0
- package/dist/esm/w/local/account.js +652 -709
- package/dist/esm/w/local/account.js.map +1 -0
- package/dist/esm/w/local/cache.js +176 -147
- package/dist/esm/w/local/cache.js.map +1 -0
- package/dist/esm/w/local/config.js +46 -60
- package/dist/esm/w/local/config.js.map +1 -0
- package/dist/esm/w/local/index.js +196 -273
- package/dist/esm/w/local/index.js.map +1 -0
- package/dist/esm/w/local/local.d.ts +2 -2
- package/dist/esm/w/local/local.js +631 -626
- package/dist/esm/w/local/local.js.map +1 -0
- package/dist/esm/w/local/storage.js +168 -136
- package/dist/esm/w/local/storage.js.map +1 -0
- package/dist/esm/w/local/token.js +149 -151
- package/dist/esm/w/local/token.js.map +1 -0
- package/dist/esm/w/local/util.js +45 -22
- package/dist/esm/w/local/util.js.map +1 -0
- package/dist/esm/w/local/wip.js +1038 -781
- package/dist/esm/w/local/wip.js.map +1 -0
- package/dist/esm/w/messenger/crypto.js +491 -387
- package/dist/esm/w/messenger/crypto.js.map +1 -0
- package/dist/esm/w/messenger/index.js +27 -24
- package/dist/esm/w/messenger/index.js.map +1 -0
- package/dist/esm/w/messenger/messenger-api.js +1111 -1017
- package/dist/esm/w/messenger/messenger-api.js.map +1 -0
- package/dist/esm/w/messenger/messenger-manager.js +944 -1052
- package/dist/esm/w/messenger/messenger-manager.js.map +1 -0
- package/dist/esm/w/messenger/messenger.d.ts +1 -1
- package/dist/esm/w/messenger/messenger.js +1258 -1421
- package/dist/esm/w/messenger/messenger.js.map +1 -0
- package/dist/esm/w/messenger/server.js +388 -499
- package/dist/esm/w/messenger/server.js.map +1 -0
- package/dist/esm/w/messenger/session.js +394 -399
- package/dist/esm/w/messenger/session.js.map +1 -0
- package/dist/esm/w/messenger/storage.js +840 -751
- package/dist/esm/w/messenger/storage.js.map +1 -0
- package/dist/esm/w/messenger/types.d.ts +2 -2
- package/dist/esm/w/messenger/types.js +80 -85
- package/dist/esm/w/messenger/types.js.map +1 -0
- package/dist/esm/w/messenger/utils.js +28 -16
- package/dist/esm/w/messenger/utils.js.map +1 -0
- package/dist/esm/w/query/bult-in.js +95 -100
- package/dist/esm/w/query/bult-in.js.map +1 -0
- package/dist/esm/w/query/event.js +128 -125
- package/dist/esm/w/query/event.js.map +1 -0
- package/dist/esm/w/query/index.js +3 -0
- package/dist/esm/w/query/index.js.map +1 -0
- package/dist/esm/w/query/object.js +1560 -1574
- package/dist/esm/w/query/object.js.map +1 -0
- package/dist/esm/w/query/received.js +57 -63
- package/dist/esm/w/query/received.js.map +1 -0
- package/dist/esm/w/query/util.js +48 -56
- package/dist/esm/w/query/util.js.map +1 -0
- package/dist/esm/w/util.js +578 -673
- package/dist/esm/w/util.js.map +1 -0
- package/package.json +13 -7
- package/prebuilds/better-sqlite3-v12.9.0-node-v115-darwin-arm64.node +0 -0
- package/prebuilds/better-sqlite3-v12.9.0-node-v115-darwin-x64.node +0 -0
- package/prebuilds/better-sqlite3-v12.9.0-node-v115-linux-arm.node +0 -0
- package/prebuilds/better-sqlite3-v12.9.0-node-v115-linux-arm64.node +0 -0
- package/prebuilds/better-sqlite3-v12.9.0-node-v115-linux-x64.node +0 -0
- package/prebuilds/better-sqlite3-v12.9.0-node-v115-win32-arm64.node +0 -0
- package/prebuilds/better-sqlite3-v12.9.0-node-v115-win32-x64.node +0 -0
- package/prebuilds/better-sqlite3-v12.9.0-node-v127-darwin-arm64.node +0 -0
- package/prebuilds/better-sqlite3-v12.9.0-node-v127-darwin-x64.node +0 -0
- package/prebuilds/better-sqlite3-v12.9.0-node-v127-linux-arm.node +0 -0
- package/prebuilds/better-sqlite3-v12.9.0-node-v127-linux-arm64.node +0 -0
- package/prebuilds/better-sqlite3-v12.9.0-node-v127-linux-x64.node +0 -0
- package/prebuilds/better-sqlite3-v12.9.0-node-v127-win32-arm64.node +0 -0
- package/prebuilds/better-sqlite3-v12.9.0-node-v127-win32-x64.node +0 -0
- package/scripts/download-prebuilds.js +234 -0
- package/scripts/install-better-sqlite3.js +377 -0
- package/dist/cjs/graphql/client.js +0 -98
- package/dist/cjs/graphql/core.js +0 -506
- package/dist/cjs/graphql/generated/2024.1/tada-env.js +0 -13141
- package/dist/cjs/graphql/generated/2024.1/tsconfig.tada.js +0 -11
- package/dist/cjs/graphql/generated/2024.4/tada-env.js +0 -13287
- package/dist/cjs/graphql/generated/2024.4/tsconfig.tada.js +0 -11
- package/dist/cjs/graphql/generated/latest/tada-env.js +0 -12925
- package/dist/cjs/graphql/generated/latest/tsconfig.tada.js +0 -11
- package/dist/cjs/graphql/generated/queries.js +0 -807
- package/dist/cjs/graphql/index.js +0 -25
- package/dist/cjs/graphql/schemas/2024.1/index.js +0 -28
- package/dist/cjs/graphql/schemas/2024.4/index.js +0 -28
- package/dist/cjs/graphql/schemas/latest/index.js +0 -28
- package/dist/cjs/graphql/types.js +0 -16
- package/dist/cjs/package.json +0 -5
- package/dist/cjs/w/local/.eslintrc.js +0 -15
- package/dist/cjs/w/messenger/.eslintrc.js +0 -15
- package/dist/cjs/zklogin/address.js +0 -93
- package/dist/cjs/zklogin/bcs.js +0 -41
- package/dist/cjs/zklogin/index.js +0 -45
- package/dist/cjs/zklogin/jwt-decode.js +0 -88
- package/dist/cjs/zklogin/jwt-utils.js +0 -128
- package/dist/cjs/zklogin/nonce.js +0 -60
- package/dist/cjs/zklogin/poseidon.js +0 -64
- package/dist/cjs/zklogin/publickey.js +0 -281
- package/dist/cjs/zklogin/signature.js +0 -57
- package/dist/cjs/zklogin/utils.js +0 -98
- package/dist/esm/graphql/client.js +0 -79
- package/dist/esm/graphql/core.js +0 -505
- package/dist/esm/graphql/generated/2024.1/tada-env.js +0 -13121
- package/dist/esm/graphql/generated/2024.1/tsconfig.tada.js +0 -16
- package/dist/esm/graphql/generated/2024.4/tada-env.js +0 -13267
- package/dist/esm/graphql/generated/2024.4/tsconfig.tada.js +0 -16
- package/dist/esm/graphql/generated/latest/tada-env.js +0 -12905
- package/dist/esm/graphql/generated/latest/tsconfig.tada.js +0 -16
- package/dist/esm/graphql/generated/queries.js +0 -788
- package/dist/esm/graphql/index.js +0 -8
- package/dist/esm/graphql/schemas/2024.1/index.js +0 -8
- package/dist/esm/graphql/schemas/2024.4/index.js +0 -8
- package/dist/esm/graphql/schemas/latest/index.js +0 -8
- package/dist/esm/graphql/types.js +0 -0
- package/dist/esm/package.json +0 -5
- package/dist/esm/w/local/.eslintrc.js +0 -23
- package/dist/esm/w/messenger/.eslintrc.js +0 -23
- package/dist/esm/zklogin/address.js +0 -78
- package/dist/esm/zklogin/bcs.js +0 -21
- package/dist/esm/zklogin/index.js +0 -38
- package/dist/esm/zklogin/jwt-decode.js +0 -68
- package/dist/esm/zklogin/jwt-utils.js +0 -108
- package/dist/esm/zklogin/nonce.js +0 -40
- package/dist/esm/zklogin/poseidon.js +0 -61
- package/dist/esm/zklogin/publickey.js +0 -265
- package/dist/esm/zklogin/signature.js +0 -37
- package/dist/esm/zklogin/utils.js +0 -78
- package/dist/tsconfig.esm.tsbuildinfo +0 -1
- package/dist/tsconfig.tsbuildinfo +0 -1
|
@@ -1,669 +1,819 @@
|
|
|
1
|
+
// Copyright (c) Wowok.
|
|
2
|
+
// SPDX-License-Identifier: Apache-2.0
|
|
1
3
|
import { MessengerManager } from "./messenger-manager.js";
|
|
2
4
|
import { Account } from "../local/account.js";
|
|
3
5
|
import { W_ERROR, WErrors } from "../exception.js";
|
|
4
6
|
import { isValidWowAddress } from "../../utils/sui-types.js";
|
|
5
7
|
import { LocalMark } from "../local/local.js";
|
|
6
8
|
import { MessageStorage } from "./storage.js";
|
|
7
|
-
import {
|
|
8
|
-
MessengerError,
|
|
9
|
-
MessengerErrorCode,
|
|
10
|
-
CHAIN_PROOF_TYPE
|
|
11
|
-
} from "./types.js";
|
|
9
|
+
import { MessengerError, MessengerErrorCode, CHAIN_PROOF_TYPE, } from "./types.js";
|
|
12
10
|
import { createHash } from "crypto";
|
|
13
11
|
import * as fs from "fs";
|
|
14
12
|
import * as path from "path";
|
|
15
13
|
import { isValidU64 } from "../common.js";
|
|
16
|
-
import {
|
|
17
|
-
verifySingleMerkleRoot,
|
|
18
|
-
hashPlaintext,
|
|
19
|
-
verifyEd25519Signature
|
|
20
|
-
} from "./crypto.js";
|
|
14
|
+
import { verifySingleMerkleRoot, hashPlaintext, verifyEd25519Signature, } from "./crypto.js";
|
|
21
15
|
import { canonicalizeJson } from "./utils.js";
|
|
22
|
-
import {
|
|
23
|
-
GetAccountOrMark_Address,
|
|
24
|
-
GetManyAccountOrMark_Address
|
|
25
|
-
} from "../local/index.js";
|
|
16
|
+
import { GetAccountOrMark_Address, GetManyAccountOrMark_Address, } from "../local/index.js";
|
|
26
17
|
import { query_objects } from "../query/object.js";
|
|
27
18
|
import { Messenger } from "./messenger.js";
|
|
28
19
|
let managerInstance = null;
|
|
29
20
|
let isInitialized = false;
|
|
30
21
|
let backgroundTimer = null;
|
|
22
|
+
/**
|
|
23
|
+
* 自动检查并注册所有设置了 messenger name 的账号
|
|
24
|
+
* 如果账号已注册(identity 已存在),则跳过
|
|
25
|
+
*/
|
|
31
26
|
async function autoRegisterMessengerAccounts() {
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
27
|
+
const accounts = await Account.Instance().list_messenger_accounts();
|
|
28
|
+
for (const account of accounts) {
|
|
29
|
+
if (!account.address || !account.m) {
|
|
30
|
+
continue;
|
|
31
|
+
}
|
|
32
|
+
const messenger = new Messenger(account.address);
|
|
33
|
+
await messenger.initialize();
|
|
36
34
|
}
|
|
37
|
-
const messenger = new Messenger(account.address);
|
|
38
|
-
await messenger.initialize();
|
|
39
|
-
}
|
|
40
35
|
}
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
36
|
+
/**
|
|
37
|
+
* 获取 MessengerManager 实例(单例)
|
|
38
|
+
* 首次调用时会自动启动后台服务
|
|
39
|
+
*/
|
|
40
|
+
export function getMessengerManager() {
|
|
41
|
+
if (!managerInstance) {
|
|
42
|
+
managerInstance = new MessengerManager();
|
|
43
|
+
}
|
|
44
|
+
if (!isInitialized) {
|
|
45
|
+
isInitialized = true;
|
|
46
|
+
// 启动时先自动检查并注册账号
|
|
47
|
+
autoRegisterMessengerAccounts().catch((err) => {
|
|
48
|
+
console.error("Failed to auto-register messenger accounts:", err);
|
|
49
|
+
});
|
|
50
|
+
managerInstance.start().catch((err) => {
|
|
51
|
+
console.error("Failed to auto-start messenger manager:", err);
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
return managerInstance;
|
|
55
55
|
}
|
|
56
|
+
/**
|
|
57
|
+
* 后台检查任务:1 分钟执行一次
|
|
58
|
+
* 1. 检查 SSE 连接状态,未连接则尝试连接
|
|
59
|
+
* 2. SSE 失败时回退到轮询
|
|
60
|
+
* 3. 检查并注册所有设置了 messenger name 的账号
|
|
61
|
+
*/
|
|
56
62
|
async function backgroundCheck() {
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
63
|
+
try {
|
|
64
|
+
const manager = getMessengerManager();
|
|
65
|
+
await manager.start();
|
|
66
|
+
}
|
|
67
|
+
catch (err) {
|
|
68
|
+
console.error("Background check failed:", err);
|
|
69
|
+
}
|
|
70
|
+
// 每次后台检查时也检查并注册账号
|
|
71
|
+
await autoRegisterMessengerAccounts();
|
|
64
72
|
}
|
|
73
|
+
/**
|
|
74
|
+
* 启动后台定时器(1 分钟执行一次)
|
|
75
|
+
*/
|
|
65
76
|
function startBackgroundTimer() {
|
|
66
|
-
if (backgroundTimer) {
|
|
67
|
-
clearInterval(backgroundTimer);
|
|
68
|
-
}
|
|
69
|
-
backgroundTimer = setInterval(() => {
|
|
70
|
-
backgroundCheck().catch(() => {
|
|
71
|
-
});
|
|
72
|
-
}, 60 * 1e3);
|
|
73
|
-
backgroundCheck().catch(() => {
|
|
74
|
-
});
|
|
75
|
-
}
|
|
76
|
-
function registerCleanupHandler() {
|
|
77
|
-
const cleanup = () => {
|
|
78
77
|
if (backgroundTimer) {
|
|
79
|
-
|
|
80
|
-
backgroundTimer = null;
|
|
78
|
+
clearInterval(backgroundTimer);
|
|
81
79
|
}
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
}
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
80
|
+
backgroundTimer = setInterval(() => {
|
|
81
|
+
backgroundCheck().catch(() => { });
|
|
82
|
+
}, 60 * 1000);
|
|
83
|
+
backgroundCheck().catch(() => { });
|
|
84
|
+
}
|
|
85
|
+
/**
|
|
86
|
+
* 进程退出时自动清理
|
|
87
|
+
*/
|
|
88
|
+
function registerCleanupHandler() {
|
|
89
|
+
const cleanup = () => {
|
|
90
|
+
if (backgroundTimer) {
|
|
91
|
+
clearInterval(backgroundTimer);
|
|
92
|
+
backgroundTimer = null;
|
|
93
|
+
}
|
|
94
|
+
if (managerInstance) {
|
|
95
|
+
managerInstance.stop();
|
|
96
|
+
}
|
|
97
|
+
};
|
|
98
|
+
process.on("exit", cleanup);
|
|
99
|
+
process.on("SIGINT", () => {
|
|
100
|
+
cleanup();
|
|
101
|
+
process.exit();
|
|
102
|
+
});
|
|
103
|
+
process.on("SIGTERM", () => {
|
|
104
|
+
cleanup();
|
|
105
|
+
process.exit();
|
|
106
|
+
});
|
|
95
107
|
}
|
|
96
108
|
registerCleanupHandler();
|
|
97
109
|
startBackgroundTimer();
|
|
98
|
-
async function watch_conversations(account) {
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
);
|
|
105
|
-
}
|
|
106
|
-
const manager = getMessengerManager();
|
|
107
|
-
return manager.get_conversations(address);
|
|
110
|
+
export async function watch_conversations(account) {
|
|
111
|
+
const address = await Account.Instance().get_address(account);
|
|
112
|
+
if (!address) {
|
|
113
|
+
W_ERROR(WErrors.AccountNotFound, `watch_conversations.account ${account}`);
|
|
114
|
+
}
|
|
115
|
+
const manager = getMessengerManager();
|
|
116
|
+
return manager.get_conversations(address);
|
|
108
117
|
}
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
);
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
if (!options.guardAddress || !options.passportAddress) {
|
|
127
|
-
W_ERROR(
|
|
128
|
-
WErrors.AccountNotFound,
|
|
129
|
-
`send_message.guardAddress or passportAddress not found`
|
|
130
|
-
);
|
|
118
|
+
/**
|
|
119
|
+
* 发送消息
|
|
120
|
+
*
|
|
121
|
+
* @param from 发送者地址
|
|
122
|
+
* @param to 接收者地址
|
|
123
|
+
* @param content 消息内容
|
|
124
|
+
* @param options 可选配置
|
|
125
|
+
* @returns SendMessageResult
|
|
126
|
+
*/
|
|
127
|
+
export async function send_message(from, to, content, options) {
|
|
128
|
+
const fromAddress = await Account.Instance().get_address(from);
|
|
129
|
+
if (!fromAddress) {
|
|
130
|
+
W_ERROR(WErrors.AccountNotFound, `send_message.from ${from}`);
|
|
131
|
+
}
|
|
132
|
+
const t = await GetAccountOrMark_Address(to);
|
|
133
|
+
if (!t) {
|
|
134
|
+
W_ERROR(WErrors.AccountNotFound, `send_message.to ${to} is not a valid account/address`);
|
|
131
135
|
}
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
136
|
+
if (options?.guardAddress != null && options?.passportAddress != null) {
|
|
137
|
+
[options.guardAddress, options.passportAddress] =
|
|
138
|
+
await LocalMark.Instance().get_many_address([
|
|
139
|
+
options.guardAddress,
|
|
140
|
+
options.passportAddress,
|
|
141
|
+
]);
|
|
142
|
+
if (!options.guardAddress || !options.passportAddress) {
|
|
143
|
+
W_ERROR(WErrors.AccountNotFound, `send_message.guardAddress or passportAddress not found`);
|
|
144
|
+
}
|
|
145
|
+
}
|
|
146
|
+
const manager = getMessengerManager();
|
|
147
|
+
return manager.send(fromAddress, t, content, options);
|
|
135
148
|
}
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
WErrors.AccountNotFound,
|
|
156
|
-
|
|
157
|
-
|
|
149
|
+
/**
|
|
150
|
+
* 发送文件(ZIP 格式)
|
|
151
|
+
*
|
|
152
|
+
* 支持发送本地文件,经过 ZIP 压缩后发送给对方
|
|
153
|
+
* 支持 Guard 验证,如果提供 guardAddress 和 passportAddress,消息将进入 Guard 验证流程
|
|
154
|
+
*
|
|
155
|
+
* @param from 发送者账号或地址
|
|
156
|
+
* @param to 接收者地址
|
|
157
|
+
* @param filePath 本地文件路径
|
|
158
|
+
* @param options 可选配置
|
|
159
|
+
* @returns SendMessageResult
|
|
160
|
+
*/
|
|
161
|
+
export async function send_file(from, to, filePath, options) {
|
|
162
|
+
const fromAddress = await Account.Instance().get_address(from);
|
|
163
|
+
if (!fromAddress) {
|
|
164
|
+
W_ERROR(WErrors.AccountNotFound, `send_file.from ${from}`);
|
|
165
|
+
}
|
|
166
|
+
const t = await GetAccountOrMark_Address(to);
|
|
167
|
+
if (!t) {
|
|
168
|
+
W_ERROR(WErrors.AccountNotFound, `send_file.to ${to} is not a valid account/address`);
|
|
169
|
+
}
|
|
170
|
+
if (options?.guardAddress != null && options?.passportAddress != null) {
|
|
171
|
+
[options.guardAddress, options.passportAddress] =
|
|
172
|
+
await LocalMark.Instance().get_many_address([
|
|
173
|
+
options.guardAddress,
|
|
174
|
+
options.passportAddress,
|
|
175
|
+
]);
|
|
176
|
+
if (!options.guardAddress || !options.passportAddress) {
|
|
177
|
+
W_ERROR(WErrors.AccountNotFound, `send_file.guardAddress or passportAddress not found`);
|
|
178
|
+
}
|
|
158
179
|
}
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
return manager.send_file(fromAddress, t, filePath, options);
|
|
180
|
+
const manager = getMessengerManager();
|
|
181
|
+
return manager.send_file(fromAddress, t, filePath, options);
|
|
162
182
|
}
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
filter
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
183
|
+
/**
|
|
184
|
+
* 查询消息
|
|
185
|
+
*
|
|
186
|
+
* @param filter 过滤条件
|
|
187
|
+
* @returns Message 数组
|
|
188
|
+
*/
|
|
189
|
+
export async function watch_messages(filter) {
|
|
190
|
+
if (filter?.account) {
|
|
191
|
+
filter.account = await Account.Instance().get_address(filter.account);
|
|
192
|
+
}
|
|
193
|
+
if (filter?.customListFilter?.includeAddresses != null) {
|
|
194
|
+
filter.customListFilter.includeAddresses = (await Account.Instance().get_many_address(filter.customListFilter.includeAddresses)).filter((v) => v != null);
|
|
195
|
+
}
|
|
196
|
+
if (filter?.customListFilter?.excludeAddresses != null) {
|
|
197
|
+
filter.customListFilter.excludeAddresses = (await Account.Instance().get_many_address(filter.customListFilter.excludeAddresses)).filter((v) => v != null);
|
|
198
|
+
}
|
|
199
|
+
const manager = getMessengerManager();
|
|
200
|
+
return manager.watch(filter);
|
|
179
201
|
}
|
|
202
|
+
/**
|
|
203
|
+
* 解压 ZIP 消息到指定目录
|
|
204
|
+
*
|
|
205
|
+
* @param message 包含 ZIP 数据的消息对象
|
|
206
|
+
* @param outputDir 输出目录路径
|
|
207
|
+
* @returns 解压后的文件路径
|
|
208
|
+
*/
|
|
180
209
|
async function extract_zip_message(message, outputDir) {
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
MessengerErrorCode.INVALID_MESSAGE_TYPE,
|
|
184
|
-
"Message is not a ZIP archive"
|
|
185
|
-
);
|
|
186
|
-
}
|
|
187
|
-
if (!message.plaintext) {
|
|
188
|
-
throw new MessengerError(
|
|
189
|
-
MessengerErrorCode.MESSAGE_NOT_DECRYPTED,
|
|
190
|
-
"Message plaintext not available"
|
|
191
|
-
);
|
|
192
|
-
}
|
|
193
|
-
const zipBase64 = message.plaintext;
|
|
194
|
-
const zipData = Buffer.from(zipBase64, "base64");
|
|
195
|
-
if (message.zipMetadata?.fileHash) {
|
|
196
|
-
const actualHash = createHash("sha256").update(zipData).digest("hex");
|
|
197
|
-
const expectedHash = message.zipMetadata.fileHash.replace("0x", "");
|
|
198
|
-
if (actualHash !== expectedHash) {
|
|
199
|
-
throw new MessengerError(
|
|
200
|
-
MessengerErrorCode.HASH_MISMATCH,
|
|
201
|
-
`ZIP file hash mismatch: expected ${expectedHash}, got ${actualHash}`
|
|
202
|
-
);
|
|
210
|
+
if (!message.zipMetadata) {
|
|
211
|
+
throw new MessengerError(MessengerErrorCode.INVALID_MESSAGE_TYPE, "Message is not a ZIP archive");
|
|
203
212
|
}
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
const zip = await JSZip.loadAsync(zipData);
|
|
207
|
-
if (!fs.existsSync(outputDir)) {
|
|
208
|
-
fs.mkdirSync(outputDir, { recursive: true });
|
|
209
|
-
}
|
|
210
|
-
const savedPaths = [];
|
|
211
|
-
for (const [fileName, file] of Object.entries(zip.files)) {
|
|
212
|
-
const zipFile = file;
|
|
213
|
-
if (!zipFile.dir) {
|
|
214
|
-
const content = await zipFile.async("nodebuffer");
|
|
215
|
-
const outputPath = path.join(outputDir, fileName);
|
|
216
|
-
fs.writeFileSync(outputPath, content);
|
|
217
|
-
savedPaths.push(outputPath);
|
|
213
|
+
if (!message.plaintext) {
|
|
214
|
+
throw new MessengerError(MessengerErrorCode.MESSAGE_NOT_DECRYPTED, "Message plaintext not available");
|
|
218
215
|
}
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
const
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
const
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
}
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
const
|
|
216
|
+
// 1. 解码 base64 ZIP 数据
|
|
217
|
+
const zipBase64 = message.plaintext;
|
|
218
|
+
const zipData = Buffer.from(zipBase64, "base64");
|
|
219
|
+
// 2. 验证文件哈希
|
|
220
|
+
if (message.zipMetadata?.fileHash) {
|
|
221
|
+
const actualHash = createHash("sha256").update(zipData).digest("hex");
|
|
222
|
+
const expectedHash = message.zipMetadata.fileHash.replace("0x", "");
|
|
223
|
+
if (actualHash !== expectedHash) {
|
|
224
|
+
throw new MessengerError(MessengerErrorCode.HASH_MISMATCH, `ZIP file hash mismatch: expected ${expectedHash}, got ${actualHash}`);
|
|
225
|
+
}
|
|
226
|
+
}
|
|
227
|
+
// 3. 解压 ZIP 文件
|
|
228
|
+
const JSZip = (await import("jszip")).default;
|
|
229
|
+
const zip = await JSZip.loadAsync(zipData);
|
|
230
|
+
// 4. 确保输出目录存在
|
|
231
|
+
if (!fs.existsSync(outputDir)) {
|
|
232
|
+
fs.mkdirSync(outputDir, { recursive: true });
|
|
233
|
+
}
|
|
234
|
+
// 5. 保存文件
|
|
235
|
+
const savedPaths = [];
|
|
236
|
+
for (const [fileName, file] of Object.entries(zip.files)) {
|
|
237
|
+
const zipFile = file;
|
|
238
|
+
if (!zipFile.dir) {
|
|
239
|
+
const content = await zipFile.async("nodebuffer");
|
|
240
|
+
const outputPath = path.join(outputDir, fileName);
|
|
241
|
+
fs.writeFileSync(outputPath, content);
|
|
242
|
+
savedPaths.push(outputPath);
|
|
243
|
+
}
|
|
244
|
+
}
|
|
245
|
+
// 6. 更新消息元数据
|
|
246
|
+
if (savedPaths.length > 0 && message.zipMetadata) {
|
|
247
|
+
const updatedMetadata = {
|
|
248
|
+
fileName: message.zipMetadata.fileName,
|
|
249
|
+
fileSize: message.zipMetadata.fileSize,
|
|
250
|
+
fileHash: message.zipMetadata.fileHash,
|
|
251
|
+
contentType: message.zipMetadata.contentType,
|
|
252
|
+
localCachePath: savedPaths[0],
|
|
253
|
+
downloadedAt: Date.now(),
|
|
254
|
+
};
|
|
255
|
+
message.zipMetadata = updatedMetadata;
|
|
256
|
+
// 根据消息方向确定用户地址
|
|
257
|
+
const userAddress = message.direction === "sent"
|
|
258
|
+
? message.fromAddress
|
|
259
|
+
: message.toAddress;
|
|
251
260
|
const messageStorage = new MessageStorage(userAddress);
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
261
|
+
messageStorage.saveMessage(message);
|
|
262
|
+
}
|
|
263
|
+
return savedPaths[0] || "";
|
|
264
|
+
}
|
|
265
|
+
/**
|
|
266
|
+
* 批量解压多个 ZIP 消息到指定目录
|
|
267
|
+
*
|
|
268
|
+
* @param messages 包含 ZIP 数据的消息数组,或消息 ID 数组
|
|
269
|
+
* @param outputDir 输出目录路径
|
|
270
|
+
* @param userAddress 用户地址(当传入消息ID数组时需要)
|
|
271
|
+
* @returns 解压后的文件路径数组
|
|
272
|
+
*/
|
|
273
|
+
export async function extract_zip_messages(account, messages, outputDir) {
|
|
274
|
+
const results = [];
|
|
275
|
+
const userAddress = await Account.Instance().get_address(account);
|
|
276
|
+
if (!userAddress) {
|
|
277
|
+
throw new MessengerError(MessengerErrorCode.INVALID_INPUT, "account is required when extracting by message IDs");
|
|
278
|
+
}
|
|
279
|
+
// 判断是 Message 数组还是 messageId 数组
|
|
280
|
+
const isMessageIds = messages.length > 0 && typeof messages[0] === "string";
|
|
281
|
+
for (const item of messages) {
|
|
282
|
+
try {
|
|
283
|
+
let message;
|
|
284
|
+
if (isMessageIds) {
|
|
285
|
+
const messageId = item;
|
|
286
|
+
const messageStorage = new MessageStorage(userAddress);
|
|
287
|
+
const storedMessage = messageStorage.getMessageById(messageId);
|
|
288
|
+
if (!storedMessage) {
|
|
289
|
+
console.error(`Message not found: ${messageId}`);
|
|
290
|
+
continue;
|
|
291
|
+
}
|
|
292
|
+
message = storedMessage;
|
|
293
|
+
}
|
|
294
|
+
else {
|
|
295
|
+
message = item;
|
|
296
|
+
}
|
|
297
|
+
// 检查是否为 ZIP 消息
|
|
298
|
+
if (!message.zipMetadata) {
|
|
299
|
+
console.error(`Message ${message.messageId} is not a ZIP archive`);
|
|
300
|
+
continue;
|
|
301
|
+
}
|
|
302
|
+
const filePath = await extract_zip_message(message, outputDir);
|
|
303
|
+
results.push(filePath);
|
|
304
|
+
}
|
|
305
|
+
catch (e) {
|
|
306
|
+
const id = isMessageIds
|
|
307
|
+
? item
|
|
308
|
+
: item.messageId;
|
|
309
|
+
console.error(`Failed to extract message ${id}:`, e);
|
|
256
310
|
}
|
|
257
|
-
message = storedMessage;
|
|
258
|
-
} else {
|
|
259
|
-
message = item;
|
|
260
|
-
}
|
|
261
|
-
if (!message.zipMetadata) {
|
|
262
|
-
console.error(
|
|
263
|
-
`Message ${message.messageId} is not a ZIP archive`
|
|
264
|
-
);
|
|
265
|
-
continue;
|
|
266
|
-
}
|
|
267
|
-
const filePath = await extract_zip_message(message, outputDir);
|
|
268
|
-
results.push(filePath);
|
|
269
|
-
} catch (e) {
|
|
270
|
-
const id = isMessageIds ? item : item.messageId;
|
|
271
|
-
console.error(`Failed to extract message ${id}:`, e);
|
|
272
311
|
}
|
|
273
|
-
|
|
274
|
-
return results;
|
|
312
|
+
return results;
|
|
275
313
|
}
|
|
276
|
-
async function generate_wts(params) {
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
WErrors.AccountNotFound,
|
|
281
|
-
`generate_wts.myAccount ${params.myAccount}`
|
|
282
|
-
);
|
|
283
|
-
}
|
|
284
|
-
if (!isValidWowAddress(params.peerAccount)) {
|
|
285
|
-
const t = await Account.Instance().get_address(params.peerAccount);
|
|
286
|
-
if (!t) {
|
|
287
|
-
W_ERROR(
|
|
288
|
-
WErrors.AccountNotFound,
|
|
289
|
-
`generate_wts.peerAccount ${params.peerAccount}`
|
|
290
|
-
);
|
|
314
|
+
export async function generate_wts(params) {
|
|
315
|
+
const myAddress = await Account.Instance().get_address(params.myAccount);
|
|
316
|
+
if (!myAddress) {
|
|
317
|
+
W_ERROR(WErrors.AccountNotFound, `generate_wts.myAccount ${params.myAccount}`);
|
|
291
318
|
}
|
|
292
|
-
params.peerAccount
|
|
293
|
-
|
|
294
|
-
|
|
319
|
+
if (!isValidWowAddress(params.peerAccount)) {
|
|
320
|
+
const t = await Account.Instance().get_address(params.peerAccount);
|
|
321
|
+
if (!t) {
|
|
322
|
+
W_ERROR(WErrors.AccountNotFound, `generate_wts.peerAccount ${params.peerAccount}`);
|
|
323
|
+
}
|
|
324
|
+
params.peerAccount = t;
|
|
325
|
+
}
|
|
326
|
+
return getMessengerManager().generate_wts(params);
|
|
295
327
|
}
|
|
328
|
+
/**
|
|
329
|
+
* 加载 WTS 文件
|
|
330
|
+
*
|
|
331
|
+
* @param filePath WTS 文件路径
|
|
332
|
+
* @returns WtsFile 对象
|
|
333
|
+
*/
|
|
296
334
|
function load_wts(filePath) {
|
|
297
|
-
|
|
298
|
-
|
|
335
|
+
const content = fs.readFileSync(filePath, "utf-8");
|
|
336
|
+
return JSON.parse(content);
|
|
299
337
|
}
|
|
338
|
+
/**
|
|
339
|
+
* 保存 WTS 文件
|
|
340
|
+
*
|
|
341
|
+
* @param wtsFile WTS 文件对象
|
|
342
|
+
* @param filePath 保存路径
|
|
343
|
+
*/
|
|
300
344
|
function save_wts(wtsFile, filePath) {
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
}
|
|
305
|
-
fs.writeFileSync(filePath, JSON.stringify(wtsFile, null, 2), "utf-8");
|
|
306
|
-
}
|
|
307
|
-
async function verify_wts(wtsFilePath) {
|
|
308
|
-
try {
|
|
309
|
-
const wtsFile = load_wts(wtsFilePath);
|
|
310
|
-
if (!wtsFile.wts || !wtsFile.payload || !wtsFile.meta) {
|
|
311
|
-
return { valid: false, error: "Invalid WTS file structure" };
|
|
312
|
-
}
|
|
313
|
-
if (wtsFile.meta.type !== "wts") {
|
|
314
|
-
return {
|
|
315
|
-
valid: false,
|
|
316
|
-
error: `Invalid meta.type: ${wtsFile.meta.type}`
|
|
317
|
-
};
|
|
318
|
-
}
|
|
319
|
-
const { payload, meta } = wtsFile;
|
|
320
|
-
for (const msg of payload.messages) {
|
|
321
|
-
const result = verifySingleMerkleRoot(
|
|
322
|
-
msg.prevRoot,
|
|
323
|
-
msg.merkleRoot,
|
|
324
|
-
msg.plaintextHash,
|
|
325
|
-
msg.timestamp,
|
|
326
|
-
msg.leafIndex
|
|
327
|
-
);
|
|
328
|
-
if (!result.valid) {
|
|
329
|
-
return {
|
|
330
|
-
valid: false,
|
|
331
|
-
error: `${result.error} at leafIndex ${msg.leafIndex}`
|
|
332
|
-
};
|
|
333
|
-
}
|
|
345
|
+
const dir = path.dirname(filePath);
|
|
346
|
+
if (!fs.existsSync(dir)) {
|
|
347
|
+
fs.mkdirSync(dir, { recursive: true });
|
|
334
348
|
}
|
|
335
|
-
|
|
336
|
-
|
|
337
|
-
|
|
338
|
-
|
|
339
|
-
|
|
340
|
-
|
|
341
|
-
|
|
342
|
-
|
|
343
|
-
|
|
349
|
+
fs.writeFileSync(filePath, JSON.stringify(wtsFile, null, 2), "utf-8");
|
|
350
|
+
}
|
|
351
|
+
/**
|
|
352
|
+
* 验证 WTS 文件
|
|
353
|
+
*
|
|
354
|
+
* 验证内容包括:
|
|
355
|
+
* 1. 文件结构完整性
|
|
356
|
+
* 2. Merkle 链连续性
|
|
357
|
+
* 3. 消息哈希格式
|
|
358
|
+
* 4. Payload 哈希匹配
|
|
359
|
+
* 5. 数字签名(如果存在)
|
|
360
|
+
*
|
|
361
|
+
* @param wtsFilePath WTS 文件路径(本地或网络文件)
|
|
362
|
+
* @returns 验证结果
|
|
363
|
+
*/
|
|
364
|
+
export async function verify_wts(wtsFilePath) {
|
|
365
|
+
try {
|
|
366
|
+
// 1. 加载 WTS 文件
|
|
367
|
+
const wtsFile = load_wts(wtsFilePath);
|
|
368
|
+
// 2. 验证基本结构
|
|
369
|
+
if (!wtsFile.wts || !wtsFile.payload || !wtsFile.meta) {
|
|
370
|
+
return { valid: false, error: "Invalid WTS file structure" };
|
|
344
371
|
}
|
|
345
|
-
if (
|
|
346
|
-
const computedHash2 = hashPlaintext(
|
|
347
|
-
msg.plaintext,
|
|
348
|
-
msg.clientTimestamp,
|
|
349
|
-
msg.guardAddress,
|
|
350
|
-
msg.passportAddress,
|
|
351
|
-
msg.lastReceivedLeafIndex
|
|
352
|
-
);
|
|
353
|
-
if (computedHash2.toLowerCase() !== msg.plaintextHash.toLowerCase()) {
|
|
372
|
+
if (wtsFile.meta.type !== "wts") {
|
|
354
373
|
return {
|
|
355
|
-
|
|
356
|
-
|
|
374
|
+
valid: false,
|
|
375
|
+
error: `Invalid meta.type: ${wtsFile.meta.type}`,
|
|
357
376
|
};
|
|
358
|
-
}
|
|
359
377
|
}
|
|
360
|
-
|
|
361
|
-
|
|
362
|
-
|
|
363
|
-
|
|
364
|
-
|
|
365
|
-
|
|
366
|
-
|
|
367
|
-
|
|
368
|
-
|
|
369
|
-
|
|
370
|
-
|
|
371
|
-
error: `Message ${i}: Missing merkleRoot for signature verification`
|
|
372
|
-
};
|
|
378
|
+
const { payload, meta } = wtsFile;
|
|
379
|
+
// 2. 验证每个消息的 Merkle Root 计算(不验证跨消息链连续性)
|
|
380
|
+
// 因为消息可能来自不同的 Merkle Tree(不同会话方向)
|
|
381
|
+
for (const msg of payload.messages) {
|
|
382
|
+
const result = verifySingleMerkleRoot(msg.prevRoot, msg.merkleRoot, msg.plaintextHash, msg.timestamp, msg.leafIndex);
|
|
383
|
+
if (!result.valid) {
|
|
384
|
+
return {
|
|
385
|
+
valid: false,
|
|
386
|
+
error: `${result.error} at leafIndex ${msg.leafIndex}`,
|
|
387
|
+
};
|
|
388
|
+
}
|
|
373
389
|
}
|
|
374
|
-
|
|
375
|
-
|
|
376
|
-
|
|
377
|
-
|
|
378
|
-
|
|
390
|
+
// 3. 验证每个消息的 plaintextHash 和服务器签名(如果提供了明文)
|
|
391
|
+
for (let i = 0; i < payload.messages.length; i++) {
|
|
392
|
+
const msg = payload.messages[i];
|
|
393
|
+
// 判断是否为非文本消息(ZIP/WTS/WIP)
|
|
394
|
+
const isNonTextMsg = !!msg.zipMetadata;
|
|
395
|
+
// 对于非文本消息,跳过 plaintextHash 格式验证(它们使用不同的哈希格式)
|
|
396
|
+
if (!isNonTextMsg) {
|
|
397
|
+
// 验证普通消息的 plaintextHash 格式
|
|
398
|
+
if (!msg.plaintextHash.startsWith("0x") ||
|
|
399
|
+
msg.plaintextHash.length !== 66) {
|
|
400
|
+
return {
|
|
401
|
+
valid: false,
|
|
402
|
+
error: `Message ${i}: Invalid plaintextHash format`,
|
|
403
|
+
};
|
|
404
|
+
}
|
|
405
|
+
// 如果提供了明文,验证 plaintextHash
|
|
406
|
+
if (msg.plaintext) {
|
|
407
|
+
const computedHash = hashPlaintext(msg.plaintext, msg.clientTimestamp, msg.guardAddress, msg.passportAddress, msg.lastReceivedLeafIndex);
|
|
408
|
+
if (computedHash.toLowerCase() !==
|
|
409
|
+
msg.plaintextHash.toLowerCase()) {
|
|
410
|
+
return {
|
|
411
|
+
valid: false,
|
|
412
|
+
error: `Message ${i}: Plaintext hash mismatch`,
|
|
413
|
+
};
|
|
414
|
+
}
|
|
415
|
+
}
|
|
416
|
+
}
|
|
417
|
+
// 验证服务器签名(如果提供了签名和公钥)
|
|
418
|
+
if (msg.serverSignature && msg.serverPublicKey) {
|
|
419
|
+
// 检查必需的字段
|
|
420
|
+
if (!msg.timestamp) {
|
|
421
|
+
return {
|
|
422
|
+
valid: false,
|
|
423
|
+
error: `Message ${i}: Missing timestamp for signature verification`,
|
|
424
|
+
};
|
|
425
|
+
}
|
|
426
|
+
if (!msg.merkleRoot) {
|
|
427
|
+
return {
|
|
428
|
+
valid: false,
|
|
429
|
+
error: `Message ${i}: Missing merkleRoot for signature verification`,
|
|
430
|
+
};
|
|
431
|
+
}
|
|
432
|
+
if (!msg.prevRoot) {
|
|
433
|
+
return {
|
|
434
|
+
valid: false,
|
|
435
|
+
error: `Message ${i}: Missing prevRoot for signature verification`,
|
|
436
|
+
};
|
|
437
|
+
}
|
|
438
|
+
const signData = `${msg.prevRoot}:${msg.merkleRoot}:${msg.timestamp}:${msg.serverPublicKey}`;
|
|
439
|
+
const signatureValid = verifyEd25519Signature(msg.serverPublicKey, signData, msg.serverSignature);
|
|
440
|
+
if (!signatureValid) {
|
|
441
|
+
return {
|
|
442
|
+
valid: false,
|
|
443
|
+
error: `Message ${i}: Server signature verification failed`,
|
|
444
|
+
};
|
|
445
|
+
}
|
|
446
|
+
}
|
|
379
447
|
}
|
|
380
|
-
|
|
381
|
-
const
|
|
382
|
-
|
|
383
|
-
|
|
384
|
-
|
|
448
|
+
// 4. 验证 payload 哈希
|
|
449
|
+
const { sha256 } = await import("@noble/hashes/sha256");
|
|
450
|
+
const { bytesToHex } = await import("@noble/hashes/utils");
|
|
451
|
+
const canonicalPayload = canonicalizeJson(payload);
|
|
452
|
+
const computedHash = "sha256:" +
|
|
453
|
+
bytesToHex(sha256(new TextEncoder().encode(canonicalPayload)));
|
|
454
|
+
// DEBUG: 打印调试信息
|
|
455
|
+
/*console.log("=== WTS Hash Verification Debug ===");
|
|
456
|
+
console.log("Stored hash:", meta.hash);
|
|
457
|
+
console.log("Computed hash:", computedHash);
|
|
458
|
+
console.log(
|
|
459
|
+
"Canonical payload:",
|
|
460
|
+
canonicalPayload.substring(0, 500) + "...",
|
|
385
461
|
);
|
|
386
|
-
|
|
387
|
-
|
|
388
|
-
|
|
389
|
-
|
|
390
|
-
|
|
462
|
+
console.log("Payload keys:", Object.keys(payload));
|
|
463
|
+
console.log("Messages count:", payload.messages.length);
|
|
464
|
+
if (payload.messages.length > 0) {
|
|
465
|
+
console.log(
|
|
466
|
+
"First message keys:",
|
|
467
|
+
Object.keys(payload.messages[0]),
|
|
468
|
+
);
|
|
469
|
+
console.log(
|
|
470
|
+
"First message:",
|
|
471
|
+
JSON.stringify(payload.messages[0], null, 2).substring(0, 500),
|
|
472
|
+
);
|
|
473
|
+
}*/
|
|
474
|
+
if (computedHash !== meta.hash) {
|
|
475
|
+
return {
|
|
476
|
+
valid: false,
|
|
477
|
+
error: "Hash mismatch - content has been tampered",
|
|
478
|
+
hashValid: false,
|
|
479
|
+
hasSignature: !!meta.signature,
|
|
480
|
+
};
|
|
391
481
|
}
|
|
392
|
-
|
|
393
|
-
|
|
394
|
-
|
|
395
|
-
|
|
396
|
-
|
|
397
|
-
|
|
398
|
-
|
|
399
|
-
|
|
400
|
-
|
|
401
|
-
|
|
402
|
-
|
|
403
|
-
|
|
404
|
-
|
|
405
|
-
|
|
406
|
-
|
|
407
|
-
|
|
408
|
-
|
|
409
|
-
|
|
410
|
-
|
|
411
|
-
|
|
412
|
-
|
|
413
|
-
|
|
414
|
-
|
|
415
|
-
|
|
416
|
-
|
|
417
|
-
|
|
418
|
-
|
|
419
|
-
|
|
420
|
-
|
|
421
|
-
|
|
422
|
-
|
|
423
|
-
|
|
424
|
-
|
|
425
|
-
|
|
426
|
-
|
|
482
|
+
// 5. 验证数字签名(如果存在)
|
|
483
|
+
const signatures = [];
|
|
484
|
+
let signatureValid;
|
|
485
|
+
if (meta.signature) {
|
|
486
|
+
const { Ed25519PublicKey } = await import("../../keypairs/ed25519/publickey.js");
|
|
487
|
+
// 支持多签名验证
|
|
488
|
+
const sigArray = Array.isArray(meta.signature)
|
|
489
|
+
? meta.signature
|
|
490
|
+
: [meta.signature];
|
|
491
|
+
let allValid = true;
|
|
492
|
+
for (const sig of sigArray) {
|
|
493
|
+
let pkToUse;
|
|
494
|
+
const pk = sig.publicKey;
|
|
495
|
+
if (pk.startsWith("0x")) {
|
|
496
|
+
// 16进制格式,转换为base64
|
|
497
|
+
const buffer = Buffer.from(pk.slice(2), "hex");
|
|
498
|
+
if (buffer.length === 33) {
|
|
499
|
+
pkToUse = buffer.slice(1).toString("base64");
|
|
500
|
+
}
|
|
501
|
+
else if (buffer.length === 32) {
|
|
502
|
+
pkToUse = buffer.toString("base64");
|
|
503
|
+
}
|
|
504
|
+
else {
|
|
505
|
+
// 尝试推导地址
|
|
506
|
+
let address;
|
|
507
|
+
try {
|
|
508
|
+
const pubKey = new Ed25519PublicKey(pk.slice(2));
|
|
509
|
+
address = pubKey.toWAddress();
|
|
510
|
+
}
|
|
511
|
+
catch {
|
|
512
|
+
// 推导失败不影响
|
|
513
|
+
}
|
|
514
|
+
signatures.push({
|
|
515
|
+
publicKey: pk,
|
|
516
|
+
address,
|
|
517
|
+
valid: false,
|
|
518
|
+
});
|
|
519
|
+
allValid = false;
|
|
520
|
+
continue;
|
|
521
|
+
}
|
|
522
|
+
}
|
|
523
|
+
else {
|
|
524
|
+
// 假设是base64格式,但需要确保是32字节
|
|
525
|
+
try {
|
|
526
|
+
const buffer = Buffer.from(pk, "base64");
|
|
527
|
+
if (buffer.length === 33) {
|
|
528
|
+
pkToUse = buffer.slice(1).toString("base64");
|
|
529
|
+
}
|
|
530
|
+
else if (buffer.length === 32) {
|
|
531
|
+
pkToUse = buffer.toString("base64");
|
|
532
|
+
}
|
|
533
|
+
else {
|
|
534
|
+
// 尝试推导地址
|
|
535
|
+
let address;
|
|
536
|
+
try {
|
|
537
|
+
const pubKey = new Ed25519PublicKey(pk);
|
|
538
|
+
address = pubKey.toWAddress();
|
|
539
|
+
}
|
|
540
|
+
catch {
|
|
541
|
+
// 推导失败不影响
|
|
542
|
+
}
|
|
543
|
+
signatures.push({
|
|
544
|
+
publicKey: pk,
|
|
545
|
+
address,
|
|
546
|
+
valid: false,
|
|
547
|
+
});
|
|
548
|
+
allValid = false;
|
|
549
|
+
continue;
|
|
550
|
+
}
|
|
551
|
+
}
|
|
552
|
+
catch {
|
|
553
|
+
// 如果解码失败,直接使用原始值
|
|
554
|
+
pkToUse = pk;
|
|
555
|
+
}
|
|
556
|
+
}
|
|
557
|
+
try {
|
|
558
|
+
const pubKey = new Ed25519PublicKey(pkToUse);
|
|
559
|
+
const signatureBytes = Uint8Array.from(Buffer.from(sig.value, "base64"));
|
|
560
|
+
const signValid = await pubKey.verify(new TextEncoder().encode(meta.hash), signatureBytes);
|
|
561
|
+
// 通过公钥推导地址
|
|
562
|
+
let address;
|
|
563
|
+
try {
|
|
564
|
+
address = pubKey.toWAddress();
|
|
565
|
+
}
|
|
566
|
+
catch {
|
|
567
|
+
// 推导失败不影响验证
|
|
568
|
+
}
|
|
569
|
+
signatures.push({
|
|
570
|
+
publicKey: pk,
|
|
571
|
+
address,
|
|
572
|
+
valid: signValid,
|
|
573
|
+
});
|
|
574
|
+
if (!signValid) {
|
|
575
|
+
allValid = false;
|
|
576
|
+
}
|
|
577
|
+
}
|
|
578
|
+
catch {
|
|
579
|
+
// 尝试推导地址
|
|
580
|
+
let address;
|
|
581
|
+
try {
|
|
582
|
+
const pubKey = new Ed25519PublicKey(pkToUse);
|
|
583
|
+
address = pubKey.toWAddress();
|
|
584
|
+
}
|
|
585
|
+
catch {
|
|
586
|
+
// 推导失败不影响
|
|
587
|
+
}
|
|
588
|
+
signatures.push({ publicKey: pk, address, valid: false });
|
|
589
|
+
allValid = false;
|
|
590
|
+
}
|
|
427
591
|
}
|
|
428
|
-
|
|
429
|
-
|
|
430
|
-
|
|
431
|
-
|
|
432
|
-
|
|
433
|
-
|
|
434
|
-
|
|
435
|
-
|
|
436
|
-
|
|
437
|
-
|
|
438
|
-
|
|
439
|
-
|
|
440
|
-
|
|
441
|
-
|
|
442
|
-
pkToUse = buffer.toString("base64");
|
|
443
|
-
} else {
|
|
444
|
-
let address;
|
|
445
|
-
try {
|
|
446
|
-
const pubKey = new Ed25519PublicKey(pk);
|
|
447
|
-
address = pubKey.toWAddress();
|
|
448
|
-
} catch {
|
|
449
|
-
}
|
|
450
|
-
signatures.push({
|
|
451
|
-
publicKey: pk,
|
|
452
|
-
address,
|
|
453
|
-
valid: false
|
|
454
|
-
});
|
|
455
|
-
allValid = false;
|
|
456
|
-
continue;
|
|
592
|
+
signatureValid = allValid;
|
|
593
|
+
if (!signatureValid) {
|
|
594
|
+
// 收集失败的地址
|
|
595
|
+
const failedAddresses = signatures
|
|
596
|
+
.filter((s) => !s.valid && s.address)
|
|
597
|
+
.map((s) => s.address);
|
|
598
|
+
return {
|
|
599
|
+
valid: false,
|
|
600
|
+
error: `Signatures from the following addresses are invalid: ${failedAddresses.join(", ")}`,
|
|
601
|
+
hashValid: true,
|
|
602
|
+
hasSignature: true,
|
|
603
|
+
signatureValid: false,
|
|
604
|
+
signatures,
|
|
605
|
+
};
|
|
457
606
|
}
|
|
458
|
-
} catch {
|
|
459
|
-
pkToUse = pk;
|
|
460
|
-
}
|
|
461
|
-
}
|
|
462
|
-
try {
|
|
463
|
-
const pubKey = new Ed25519PublicKey(pkToUse);
|
|
464
|
-
const signatureBytes = Uint8Array.from(
|
|
465
|
-
Buffer.from(sig.value, "base64")
|
|
466
|
-
);
|
|
467
|
-
const signValid = await pubKey.verify(
|
|
468
|
-
new TextEncoder().encode(meta.hash),
|
|
469
|
-
signatureBytes
|
|
470
|
-
);
|
|
471
|
-
let address;
|
|
472
|
-
try {
|
|
473
|
-
address = pubKey.toWAddress();
|
|
474
|
-
} catch {
|
|
475
|
-
}
|
|
476
|
-
signatures.push({
|
|
477
|
-
publicKey: pk,
|
|
478
|
-
address,
|
|
479
|
-
valid: signValid
|
|
480
|
-
});
|
|
481
|
-
if (!signValid) {
|
|
482
|
-
allValid = false;
|
|
483
|
-
}
|
|
484
|
-
} catch {
|
|
485
|
-
let address;
|
|
486
|
-
try {
|
|
487
|
-
const pubKey = new Ed25519PublicKey(pkToUse);
|
|
488
|
-
address = pubKey.toWAddress();
|
|
489
|
-
} catch {
|
|
490
|
-
}
|
|
491
|
-
signatures.push({ publicKey: pk, address, valid: false });
|
|
492
|
-
allValid = false;
|
|
493
607
|
}
|
|
494
|
-
}
|
|
495
|
-
signatureValid = allValid;
|
|
496
|
-
if (!signatureValid) {
|
|
497
|
-
const failedAddresses = signatures.filter((s) => !s.valid && s.address).map((s) => s.address);
|
|
498
608
|
return {
|
|
499
|
-
|
|
500
|
-
|
|
501
|
-
|
|
502
|
-
|
|
503
|
-
|
|
504
|
-
|
|
609
|
+
valid: true,
|
|
610
|
+
hashValid: true,
|
|
611
|
+
hasSignature: !!meta.signature,
|
|
612
|
+
signatureValid,
|
|
613
|
+
signatures: signatures.length > 0 ? signatures : undefined,
|
|
614
|
+
};
|
|
615
|
+
}
|
|
616
|
+
catch (error) {
|
|
617
|
+
return {
|
|
618
|
+
valid: false,
|
|
619
|
+
error: `Verification error: ${error}`,
|
|
620
|
+
hashValid: false,
|
|
621
|
+
hasSignature: false,
|
|
505
622
|
};
|
|
506
|
-
}
|
|
507
623
|
}
|
|
508
|
-
return {
|
|
509
|
-
valid: true,
|
|
510
|
-
hashValid: true,
|
|
511
|
-
hasSignature: !!meta.signature,
|
|
512
|
-
signatureValid,
|
|
513
|
-
signatures: signatures.length > 0 ? signatures : void 0
|
|
514
|
-
};
|
|
515
|
-
} catch (error) {
|
|
516
|
-
return {
|
|
517
|
-
valid: false,
|
|
518
|
-
error: `Verification error: ${error}`,
|
|
519
|
-
hashValid: false,
|
|
520
|
-
hasSignature: false
|
|
521
|
-
};
|
|
522
|
-
}
|
|
523
624
|
}
|
|
524
|
-
|
|
525
|
-
|
|
526
|
-
|
|
527
|
-
|
|
528
|
-
|
|
529
|
-
|
|
530
|
-
|
|
531
|
-
|
|
532
|
-
|
|
533
|
-
|
|
534
|
-
|
|
535
|
-
|
|
536
|
-
|
|
537
|
-
|
|
538
|
-
|
|
539
|
-
wtsFile.meta.hash
|
|
540
|
-
);
|
|
541
|
-
let publicKeyBase64;
|
|
542
|
-
const pk = signResult.publicKey;
|
|
543
|
-
if (pk.startsWith("0x")) {
|
|
544
|
-
const buffer = Buffer.from(pk.slice(2), "hex");
|
|
545
|
-
if (buffer.length === 33) {
|
|
546
|
-
publicKeyBase64 = buffer.slice(1).toString("base64");
|
|
547
|
-
} else if (buffer.length === 32) {
|
|
548
|
-
publicKeyBase64 = buffer.toString("base64");
|
|
549
|
-
} else {
|
|
550
|
-
throw new MessengerError(
|
|
551
|
-
MessengerErrorCode.INVALID_INPUT,
|
|
552
|
-
`Invalid public key length: ${buffer.length}, expected 32 or 33 bytes`
|
|
553
|
-
);
|
|
625
|
+
/**
|
|
626
|
+
* 使用账号签名 WTS 文件
|
|
627
|
+
*
|
|
628
|
+
* 此函数会自动加载 WTS 文件、验证格式、签名并保存。
|
|
629
|
+
*
|
|
630
|
+
* @param wtsFilePath WTS 文件路径(本地或网络文件)
|
|
631
|
+
* @param account 签名账号
|
|
632
|
+
* @param outputPath 输出文件路径(可选,默认覆盖原文件)
|
|
633
|
+
* @returns 签名后的 WTS 文件路径
|
|
634
|
+
*/
|
|
635
|
+
export async function sign_wts(wtsFilePath, account, outputPath) {
|
|
636
|
+
// 1. 验证 WTS 文件格式(内部会加载文件)
|
|
637
|
+
const verifyResult = await verify_wts(wtsFilePath);
|
|
638
|
+
if (!verifyResult.valid) {
|
|
639
|
+
throw new MessengerError(MessengerErrorCode.INVALID_INPUT, `WTS file verification failed: ${verifyResult.error}`);
|
|
554
640
|
}
|
|
555
|
-
|
|
556
|
-
|
|
557
|
-
|
|
558
|
-
|
|
559
|
-
|
|
560
|
-
|
|
561
|
-
),
|
|
562
|
-
publicKey: publicKeyBase64,
|
|
563
|
-
algorithm: "Ed25519",
|
|
564
|
-
address: signResult.address
|
|
565
|
-
};
|
|
566
|
-
let signatures;
|
|
567
|
-
if (wtsFile.meta.signature) {
|
|
568
|
-
const existingSigs = Array.isArray(wtsFile.meta.signature) ? [...wtsFile.meta.signature] : [wtsFile.meta.signature];
|
|
569
|
-
const existingIndex = existingSigs.findIndex(
|
|
570
|
-
(sig) => sig.publicKey === publicKeyBase64
|
|
571
|
-
);
|
|
572
|
-
if (existingIndex >= 0) {
|
|
573
|
-
existingSigs[existingIndex] = newSignature;
|
|
574
|
-
signatures = existingSigs;
|
|
575
|
-
} else {
|
|
576
|
-
signatures = [...existingSigs, newSignature];
|
|
641
|
+
// 2. 加载 WTS 文件
|
|
642
|
+
const wtsFile = load_wts(wtsFilePath);
|
|
643
|
+
// 3. 获取签名者地址
|
|
644
|
+
const address = await Account.Instance().get_address(account);
|
|
645
|
+
if (!address) {
|
|
646
|
+
W_ERROR(WErrors.AccountNotFound, `sign_wts.account ${account}`);
|
|
577
647
|
}
|
|
578
|
-
|
|
579
|
-
|
|
580
|
-
|
|
581
|
-
|
|
582
|
-
|
|
583
|
-
|
|
584
|
-
|
|
585
|
-
|
|
648
|
+
// 4. 使用 Account 签名(同时获取公钥)
|
|
649
|
+
const signResult = await Account.Instance().signData(address, wtsFile.meta.hash);
|
|
650
|
+
// 6. 转换公钥格式为 base64 (32字节)
|
|
651
|
+
let publicKeyBase64;
|
|
652
|
+
const pk = signResult.publicKey;
|
|
653
|
+
if (pk.startsWith("0x")) {
|
|
654
|
+
const buffer = Buffer.from(pk.slice(2), "hex");
|
|
655
|
+
if (buffer.length === 33) {
|
|
656
|
+
// 去掉第一个字节(通常是压缩标志)
|
|
657
|
+
publicKeyBase64 = buffer.slice(1).toString("base64");
|
|
658
|
+
}
|
|
659
|
+
else if (buffer.length === 32) {
|
|
660
|
+
publicKeyBase64 = buffer.toString("base64");
|
|
661
|
+
}
|
|
662
|
+
else {
|
|
663
|
+
throw new MessengerError(MessengerErrorCode.INVALID_INPUT, `Invalid public key length: ${buffer.length}, expected 32 or 33 bytes`);
|
|
664
|
+
}
|
|
586
665
|
}
|
|
587
|
-
|
|
588
|
-
|
|
589
|
-
|
|
590
|
-
savePath = outputPath;
|
|
591
|
-
} else {
|
|
592
|
-
const dir = path.dirname(wtsFilePath);
|
|
593
|
-
const ext = path.extname(wtsFilePath);
|
|
594
|
-
const baseName = path.basename(wtsFilePath, ext);
|
|
595
|
-
savePath = path.join(dir, `signed_${baseName}${ext}`);
|
|
596
|
-
}
|
|
597
|
-
save_wts(signedWtsFile, savePath);
|
|
598
|
-
return savePath;
|
|
599
|
-
}
|
|
600
|
-
async function wts2html(wtsPath, options = {}) {
|
|
601
|
-
const fs2 = await import("fs");
|
|
602
|
-
const path2 = await import("path");
|
|
603
|
-
const stats = fs2.statSync(wtsPath);
|
|
604
|
-
if (stats.isDirectory()) {
|
|
605
|
-
const files = fs2.readdirSync(wtsPath);
|
|
606
|
-
const wtsFiles = files.filter((f) => f.endsWith(".wts"));
|
|
607
|
-
if (wtsFiles.length === 0) {
|
|
608
|
-
throw new MessengerError(
|
|
609
|
-
MessengerErrorCode.INVALID_INPUT,
|
|
610
|
-
`No .wts files found in directory: ${wtsPath}`
|
|
611
|
-
);
|
|
666
|
+
else {
|
|
667
|
+
// 假设已经是 base64 格式
|
|
668
|
+
publicKeyBase64 = pk;
|
|
612
669
|
}
|
|
613
|
-
|
|
614
|
-
|
|
615
|
-
|
|
616
|
-
|
|
617
|
-
|
|
618
|
-
|
|
619
|
-
|
|
620
|
-
|
|
621
|
-
|
|
622
|
-
|
|
623
|
-
|
|
624
|
-
|
|
670
|
+
// 7. 构建新签名
|
|
671
|
+
const newSignature = {
|
|
672
|
+
value: Buffer.from(signResult.signature.slice(2), "hex").toString("base64"),
|
|
673
|
+
publicKey: publicKeyBase64,
|
|
674
|
+
algorithm: "Ed25519",
|
|
675
|
+
address: signResult.address,
|
|
676
|
+
};
|
|
677
|
+
// 8. 处理多签名:相同公钥只能有一个签名(替换已有签名)
|
|
678
|
+
let signatures;
|
|
679
|
+
if (wtsFile.meta.signature) {
|
|
680
|
+
// 将已有签名转换为数组
|
|
681
|
+
const existingSigs = Array.isArray(wtsFile.meta.signature)
|
|
682
|
+
? [...wtsFile.meta.signature]
|
|
683
|
+
: [wtsFile.meta.signature];
|
|
684
|
+
// 检查是否已存在相同公钥的签名
|
|
685
|
+
const existingIndex = existingSigs.findIndex((sig) => sig.publicKey === publicKeyBase64);
|
|
686
|
+
if (existingIndex >= 0) {
|
|
687
|
+
// 替换已有签名
|
|
688
|
+
existingSigs[existingIndex] = newSignature;
|
|
689
|
+
signatures = existingSigs;
|
|
690
|
+
}
|
|
691
|
+
else {
|
|
692
|
+
// 追加新签名
|
|
693
|
+
signatures = [...existingSigs, newSignature];
|
|
694
|
+
}
|
|
625
695
|
}
|
|
626
|
-
|
|
627
|
-
|
|
628
|
-
|
|
696
|
+
else {
|
|
697
|
+
signatures = [newSignature];
|
|
698
|
+
}
|
|
699
|
+
// 9. 添加签名到 meta
|
|
700
|
+
const signedWtsFile = {
|
|
701
|
+
...wtsFile,
|
|
702
|
+
meta: {
|
|
703
|
+
...wtsFile.meta,
|
|
704
|
+
signature: signatures,
|
|
705
|
+
},
|
|
706
|
+
};
|
|
707
|
+
// 8. 确定保存路径
|
|
708
|
+
let savePath;
|
|
709
|
+
if (outputPath) {
|
|
710
|
+
savePath = outputPath;
|
|
711
|
+
}
|
|
712
|
+
else {
|
|
713
|
+
// 在原文件名前添加 signed_ 前缀
|
|
714
|
+
const dir = path.dirname(wtsFilePath);
|
|
715
|
+
const ext = path.extname(wtsFilePath);
|
|
716
|
+
const baseName = path.basename(wtsFilePath, ext);
|
|
717
|
+
savePath = path.join(dir, `signed_${baseName}${ext}`);
|
|
718
|
+
}
|
|
719
|
+
save_wts(signedWtsFile, savePath);
|
|
720
|
+
return savePath;
|
|
629
721
|
}
|
|
630
|
-
async function
|
|
631
|
-
|
|
632
|
-
|
|
633
|
-
|
|
634
|
-
|
|
635
|
-
|
|
636
|
-
|
|
637
|
-
|
|
638
|
-
|
|
639
|
-
|
|
640
|
-
|
|
641
|
-
|
|
642
|
-
|
|
643
|
-
|
|
644
|
-
|
|
645
|
-
|
|
646
|
-
|
|
647
|
-
|
|
648
|
-
|
|
722
|
+
export async function wts2html(wtsPath, options = {}) {
|
|
723
|
+
const fs = await import("fs");
|
|
724
|
+
const path = await import("path");
|
|
725
|
+
// 检查是文件还是文件夹
|
|
726
|
+
const stats = fs.statSync(wtsPath);
|
|
727
|
+
if (stats.isDirectory()) {
|
|
728
|
+
// 处理文件夹中的所有 .wts 文件
|
|
729
|
+
const files = fs.readdirSync(wtsPath);
|
|
730
|
+
const wtsFiles = files.filter((f) => f.endsWith(".wts"));
|
|
731
|
+
if (wtsFiles.length === 0) {
|
|
732
|
+
throw new MessengerError(MessengerErrorCode.INVALID_INPUT, `No .wts files found in directory: ${wtsPath}`);
|
|
733
|
+
}
|
|
734
|
+
const results = [];
|
|
735
|
+
for (const file of wtsFiles) {
|
|
736
|
+
const filePath = path.join(wtsPath, file);
|
|
737
|
+
const html = await convertWtsToHtml(filePath, options);
|
|
738
|
+
// 生成输出文件名
|
|
739
|
+
const outputFileName = file.replace(".wts", ".html");
|
|
740
|
+
const outputFilePath = options.outputPath
|
|
741
|
+
? path.join(options.outputPath, outputFileName)
|
|
742
|
+
: path.join(wtsPath, outputFileName);
|
|
743
|
+
// 确保输出目录存在
|
|
744
|
+
const outputDir = path.dirname(outputFilePath);
|
|
745
|
+
if (!fs.existsSync(outputDir)) {
|
|
746
|
+
fs.mkdirSync(outputDir, { recursive: true });
|
|
747
|
+
}
|
|
748
|
+
fs.writeFileSync(outputFilePath, html, "utf-8");
|
|
749
|
+
results.push(outputFilePath);
|
|
750
|
+
}
|
|
751
|
+
return results;
|
|
649
752
|
}
|
|
650
|
-
|
|
651
|
-
|
|
652
|
-
|
|
653
|
-
|
|
654
|
-
|
|
655
|
-
|
|
656
|
-
|
|
657
|
-
|
|
658
|
-
|
|
659
|
-
|
|
660
|
-
|
|
661
|
-
const
|
|
662
|
-
|
|
663
|
-
|
|
753
|
+
// 处理单个文件
|
|
754
|
+
return convertWtsToHtml(wtsPath, options);
|
|
755
|
+
}
|
|
756
|
+
/**
|
|
757
|
+
* 将单个 WTS 文件转换为 HTML
|
|
758
|
+
*/
|
|
759
|
+
async function convertWtsToHtml(wtsFilePath, options = {}) {
|
|
760
|
+
const fs = await import("fs");
|
|
761
|
+
const path = await import("path");
|
|
762
|
+
const { title = "WTS Document", theme = "light" } = options;
|
|
763
|
+
// 1. 验证文件
|
|
764
|
+
const verifyResult = await verify_wts(wtsFilePath);
|
|
765
|
+
// 2. 加载 WTS 文件
|
|
766
|
+
const wtsFile = load_wts(wtsFilePath);
|
|
767
|
+
const { payload, meta } = wtsFile;
|
|
768
|
+
const bgColor = theme === "dark" ? "#1a1a1a" : "#ffffff";
|
|
769
|
+
const textColor = theme === "dark" ? "#e0e0e0" : "#333333";
|
|
770
|
+
const borderColor = theme === "dark" ? "#444444" : "#e0e0e0";
|
|
771
|
+
const escapeHtml = (text) => {
|
|
772
|
+
return text
|
|
773
|
+
.replace(/&/g, "&")
|
|
774
|
+
.replace(/</g, "<")
|
|
775
|
+
.replace(/>/g, ">")
|
|
776
|
+
.replace(/"/g, """)
|
|
777
|
+
.replace(/'/g, "'");
|
|
778
|
+
};
|
|
779
|
+
// 判断是否为非文本消息(ZIP/WTS/WIP)
|
|
780
|
+
const isNonTextMessage = (msg) => {
|
|
781
|
+
return !!msg.zipMetadata;
|
|
782
|
+
};
|
|
783
|
+
// 获取文件类型标签
|
|
784
|
+
const getFileTypeLabel = (msg) => {
|
|
785
|
+
// 首先检查 contentType
|
|
786
|
+
if (msg.zipMetadata?.contentType) {
|
|
787
|
+
return msg.zipMetadata.contentType.toUpperCase();
|
|
788
|
+
}
|
|
789
|
+
// 根据文件名推断类型
|
|
790
|
+
const fileName = msg.zipMetadata?.fileName || "";
|
|
791
|
+
if (fileName.endsWith(".wts"))
|
|
792
|
+
return "WTS";
|
|
793
|
+
if (fileName.endsWith(".wip"))
|
|
794
|
+
return "WIP";
|
|
795
|
+
if (fileName.endsWith(".zip"))
|
|
796
|
+
return "ZIP";
|
|
797
|
+
if (fileName.endsWith(".json"))
|
|
798
|
+
return "JSON";
|
|
799
|
+
if (fileName.endsWith(".txt"))
|
|
800
|
+
return "TXT";
|
|
801
|
+
// 根据 zipMetadata 推断
|
|
802
|
+
if (msg.zipMetadata)
|
|
803
|
+
return "ZIP";
|
|
804
|
+
return "FILE";
|
|
805
|
+
};
|
|
806
|
+
// 生成保存按钮的 HTML
|
|
807
|
+
const generateSaveButton = (msg, index) => {
|
|
808
|
+
const fileType = getFileTypeLabel(msg);
|
|
809
|
+
const fileName = msg.zipMetadata?.fileName ||
|
|
810
|
+
`message_${index}.${fileType.toLowerCase()}`;
|
|
811
|
+
// 对于非文本消息,plaintext 是 base64 编码的文件内容
|
|
812
|
+
const fileData = msg.plaintext || "";
|
|
813
|
+
return `
|
|
664
814
|
<div style="margin: 12px 0; padding: 16px; background: ${theme === "dark" ? "#2a3f2a" : "#e8f5e9"}; border: 1px solid ${theme === "dark" ? "#4caf50" : "#81c784"}; border-radius: 8px; text-align: center;">
|
|
665
815
|
<div style="font-size: 14px; color: ${theme === "dark" ? "#81c784" : "#2e7d32"}; margin-bottom: 8px;">
|
|
666
|
-
|
|
816
|
+
📎 ${fileType} File
|
|
667
817
|
${msg.zipMetadata ? `<span style="font-size: 12px; color: #666;">(${formatFileSize(msg.zipMetadata.fileSize)})</span>` : ""}
|
|
668
818
|
</div>
|
|
669
819
|
<button
|
|
@@ -672,13 +822,13 @@ async function convertWtsToHtml(wtsFilePath, options = {}) {
|
|
|
672
822
|
onmouseover="this.style.background='#45a049'"
|
|
673
823
|
onmouseout="this.style.background='#4caf50'"
|
|
674
824
|
>
|
|
675
|
-
|
|
825
|
+
💾 Save ${escapeHtml(fileName)}
|
|
676
826
|
</button>
|
|
677
827
|
</div>
|
|
678
828
|
<script>
|
|
679
829
|
function saveFile${index}() {
|
|
680
830
|
try {
|
|
681
|
-
// Base64
|
|
831
|
+
// Base64 解码
|
|
682
832
|
const base64Data = "${escapeHtml(fileData)}";
|
|
683
833
|
const byteCharacters = atob(base64Data);
|
|
684
834
|
const byteNumbers = new Array(byteCharacters.length);
|
|
@@ -687,7 +837,7 @@ async function convertWtsToHtml(wtsFilePath, options = {}) {
|
|
|
687
837
|
}
|
|
688
838
|
const byteArray = new Uint8Array(byteNumbers);
|
|
689
839
|
|
|
690
|
-
//
|
|
840
|
+
// 根据文件类型设置 MIME 类型
|
|
691
841
|
let mimeType = "application/octet-stream";
|
|
692
842
|
const fileName = "${escapeHtml(fileName)}";
|
|
693
843
|
if (fileName.endsWith('.json')) mimeType = "application/json";
|
|
@@ -704,26 +854,34 @@ async function convertWtsToHtml(wtsFilePath, options = {}) {
|
|
|
704
854
|
document.body.removeChild(a);
|
|
705
855
|
URL.revokeObjectURL(url);
|
|
706
856
|
} catch (e) {
|
|
707
|
-
alert('
|
|
857
|
+
alert('保存文件失败: ' + e.message);
|
|
708
858
|
}
|
|
709
859
|
}
|
|
710
|
-
|
|
860
|
+
</script>
|
|
711
861
|
`;
|
|
712
|
-
|
|
713
|
-
|
|
714
|
-
|
|
715
|
-
|
|
716
|
-
|
|
717
|
-
|
|
718
|
-
|
|
719
|
-
|
|
720
|
-
|
|
862
|
+
};
|
|
863
|
+
// 格式化文件大小
|
|
864
|
+
const formatFileSize = (bytes) => {
|
|
865
|
+
if (bytes < 1024)
|
|
866
|
+
return bytes + " B";
|
|
867
|
+
if (bytes < 1024 * 1024)
|
|
868
|
+
return (bytes / 1024).toFixed(1) + " KB";
|
|
869
|
+
return (bytes / (1024 * 1024)).toFixed(1) + " MB";
|
|
870
|
+
};
|
|
871
|
+
const messagesHtml = payload.messages
|
|
872
|
+
.map((msg, index) => {
|
|
873
|
+
const isNonText = isNonTextMessage(msg);
|
|
874
|
+
return `
|
|
721
875
|
<div style="margin: 16px 0; padding: 16px; border: 1px solid ${borderColor}; border-radius: 8px; background: ${theme === "dark" ? "#2a2a2a" : "#f9f9f9"};">
|
|
722
876
|
<div style="display: flex; justify-content: space-between; margin-bottom: 8px; font-size: 12px; color: #666;">
|
|
723
877
|
<span>From: ${escapeHtml(msg.from.slice(0, 20))}... To: ${escapeHtml(msg.to.slice(0, 20))}...</span>
|
|
724
878
|
<span>${new Date(msg.timestamp).toLocaleString()}</span>
|
|
725
879
|
</div>
|
|
726
|
-
${isNonText
|
|
880
|
+
${isNonText
|
|
881
|
+
? generateSaveButton(msg, index)
|
|
882
|
+
: msg.plaintext
|
|
883
|
+
? `<div style="margin: 12px 0; padding: 12px; background: ${theme === "dark" ? "#333333" : "#ffffff"}; border: 1px solid ${borderColor}; border-radius: 4px; font-size: 14px; line-height: 1.6; max-height: calc(1.6em * 6); overflow-y: auto; white-space: pre-wrap; word-break: break-word;">${escapeHtml(msg.plaintext)}</div>`
|
|
884
|
+
: ""}
|
|
727
885
|
<div style="margin: 8px 0; font-size: 11px; color: #666;">
|
|
728
886
|
<div>Plaintext Hash: ${escapeHtml(msg.plaintextHash)}</div>
|
|
729
887
|
${msg.arkConfirmed ? `<div>ARK Confirmed: ${escapeHtml(msg.arkConfirmed.recipient)} at ${new Date(msg.arkConfirmed.timestamp).toLocaleString()}</div>` : ""}
|
|
@@ -737,9 +895,11 @@ async function convertWtsToHtml(wtsFilePath, options = {}) {
|
|
|
737
895
|
</div>
|
|
738
896
|
</div>
|
|
739
897
|
`;
|
|
740
|
-
|
|
741
|
-
|
|
742
|
-
|
|
898
|
+
})
|
|
899
|
+
.join("");
|
|
900
|
+
// 签名信息不再在 HTML 中显示(根据安全设计)
|
|
901
|
+
const signatureHtml = "";
|
|
902
|
+
const html = `<!DOCTYPE html>
|
|
743
903
|
<html lang="en">
|
|
744
904
|
<head>
|
|
745
905
|
<meta charset="UTF-8">
|
|
@@ -783,25 +943,29 @@ async function convertWtsToHtml(wtsFilePath, options = {}) {
|
|
|
783
943
|
</div>
|
|
784
944
|
<div style="font-size: 14px; color: #666; margin-top: 4px;">
|
|
785
945
|
${new Date(meta.startTime).toLocaleDateString()} - ${new Date(meta.endTime).toLocaleDateString()}
|
|
786
|
-
${verifyResult.valid
|
|
946
|
+
${verifyResult.valid
|
|
947
|
+
? `<span style="color: #4caf50; margin-left: 8px;">✓ The accuracy, sequentiality, and integrity of the messages are verified without tampering</span>`
|
|
948
|
+
: `<span style="color: #ff9800; margin-left: 8px;">⚠ ${verifyResult.error || "Hash mismatch - content has been tampered"}</span>`}
|
|
787
949
|
</div>
|
|
788
950
|
<div class="meta">
|
|
789
951
|
<div>Session: ${escapeHtml(payload.session.id)}</div>
|
|
790
952
|
<div>Participants: ${payload.session.participants.map((p) => escapeHtml(p.slice(0, 20)) + "...").join(", ")}</div>
|
|
791
953
|
<div>Messages: ${meta.messageCount} | Time: ${new Date(meta.startTime).toLocaleString()} - ${new Date(meta.endTime).toLocaleString()}</div>
|
|
792
954
|
<div style="word-break: break-all;">Merkle Root: ${escapeHtml(meta.merkleRoot)}</div>
|
|
793
|
-
${verifyResult.signatures && verifyResult.signatures.length > 0
|
|
955
|
+
${verifyResult.signatures && verifyResult.signatures.length > 0
|
|
956
|
+
? `
|
|
794
957
|
<div style="margin-top: 8px; padding: 8px; background: ${theme === "dark" ? "#2a3f2a" : "#e8f5e9"}; border-radius: 4px;">
|
|
795
|
-
<div style="font-size: 11px; color: ${theme === "dark" ? "#81c784" : "#2e7d32"}; margin-bottom: 4px;"
|
|
796
|
-
${verifyResult.signatures
|
|
797
|
-
|
|
958
|
+
<div style="font-size: 11px; color: ${theme === "dark" ? "#81c784" : "#2e7d32"}; margin-bottom: 4px;">✓ Signature Verification (${verifyResult.signatures.length} signature${verifyResult.signatures.length > 1 ? "s" : ""})</div>
|
|
959
|
+
${verifyResult.signatures
|
|
960
|
+
.map((s, idx) => `
|
|
798
961
|
<div style="font-size: 10px; color: ${textColor}; margin-left: 8px;">
|
|
799
|
-
${idx + 1}. ${s.address ? escapeHtml(s.address.slice(0, 20)) + "..." : "Unknown"}: ${s.valid ? '<span style="color: #4caf50;"
|
|
962
|
+
${idx + 1}. ${s.address ? escapeHtml(s.address.slice(0, 20)) + "..." : "Unknown"}: ${s.valid ? '<span style="color: #4caf50;">✓ Valid</span>' : '<span style="color: #f44336;">✗ Invalid</span>'}
|
|
800
963
|
</div>
|
|
801
|
-
`
|
|
802
|
-
|
|
964
|
+
`)
|
|
965
|
+
.join("")}
|
|
803
966
|
</div>
|
|
804
|
-
`
|
|
967
|
+
`
|
|
968
|
+
: ""}
|
|
805
969
|
</div>
|
|
806
970
|
</div>
|
|
807
971
|
<div class="messages">
|
|
@@ -810,419 +974,349 @@ async function convertWtsToHtml(wtsFilePath, options = {}) {
|
|
|
810
974
|
${signatureHtml}
|
|
811
975
|
</body>
|
|
812
976
|
</html>`;
|
|
813
|
-
|
|
814
|
-
|
|
815
|
-
|
|
816
|
-
|
|
817
|
-
|
|
818
|
-
|
|
819
|
-
|
|
820
|
-
|
|
821
|
-
return html;
|
|
822
|
-
}
|
|
823
|
-
async function proof_message(account, messageId, network) {
|
|
824
|
-
const address = await Account.Instance().get_address(account);
|
|
825
|
-
if (!address) {
|
|
826
|
-
W_ERROR(WErrors.AccountNotFound, `proof_message.account ${account}`);
|
|
827
|
-
}
|
|
828
|
-
const messageStorage = new MessageStorage(address);
|
|
829
|
-
const message = messageStorage.getMessageById(messageId);
|
|
830
|
-
if (!message) {
|
|
831
|
-
throw new MessengerError(
|
|
832
|
-
MessengerErrorCode.INVALID_INPUT,
|
|
833
|
-
`Message not found: ${messageId}`
|
|
834
|
-
);
|
|
835
|
-
}
|
|
836
|
-
if (message.fromAddress.toLowerCase() !== address.toLowerCase() && message.toAddress.toLowerCase() !== address.toLowerCase()) {
|
|
837
|
-
throw new MessengerError(
|
|
838
|
-
MessengerErrorCode.INVALID_INPUT,
|
|
839
|
-
`Message does not belong to account ${address}`
|
|
840
|
-
);
|
|
841
|
-
}
|
|
842
|
-
if (!message.serverSignature) {
|
|
843
|
-
throw new MessengerError(
|
|
844
|
-
MessengerErrorCode.INVALID_PROOF,
|
|
845
|
-
`Message does not have server signature`
|
|
846
|
-
);
|
|
847
|
-
}
|
|
848
|
-
if (!message.serverPublicKey) {
|
|
849
|
-
throw new MessengerError(
|
|
850
|
-
MessengerErrorCode.INVALID_PROOF,
|
|
851
|
-
`Message does not have server public key`
|
|
852
|
-
);
|
|
853
|
-
}
|
|
854
|
-
if (!message.plaintext) {
|
|
855
|
-
throw new MessengerError(
|
|
856
|
-
MessengerErrorCode.INVALID_PROOF,
|
|
857
|
-
`Message does not have plaintext`
|
|
858
|
-
);
|
|
859
|
-
}
|
|
860
|
-
const { verifyMessage } = await import("./crypto.js");
|
|
861
|
-
const verifyParams = {
|
|
862
|
-
messageId: message.messageId,
|
|
863
|
-
plaintext: message.plaintext,
|
|
864
|
-
plaintextHash: message.plaintextHash,
|
|
865
|
-
createdAt: message.createdAt,
|
|
866
|
-
guardAddress: message.guardAddress,
|
|
867
|
-
passportAddress: message.passportAddress,
|
|
868
|
-
serverSignature: message.serverSignature,
|
|
869
|
-
serverPublicKey: message.serverPublicKey
|
|
870
|
-
};
|
|
871
|
-
if (message.newRoot && message.leafIndex !== void 0) {
|
|
872
|
-
if (!message.serverTimestamp) {
|
|
873
|
-
throw new MessengerError(
|
|
874
|
-
MessengerErrorCode.INVALID_PROOF,
|
|
875
|
-
`Message ${message.messageId} missing server timestamp for verification`
|
|
876
|
-
);
|
|
977
|
+
// 如果指定了输出路径,保存到文件
|
|
978
|
+
if (options.outputPath) {
|
|
979
|
+
const dir = path.dirname(options.outputPath);
|
|
980
|
+
if (!fs.existsSync(dir)) {
|
|
981
|
+
fs.mkdirSync(dir, { recursive: true });
|
|
982
|
+
}
|
|
983
|
+
fs.writeFileSync(options.outputPath, html, "utf-8");
|
|
984
|
+
return options.outputPath;
|
|
877
985
|
}
|
|
878
|
-
|
|
879
|
-
newRoot: message.newRoot,
|
|
880
|
-
prevRoot: message.prevRoot,
|
|
881
|
-
leafIndex: message.leafIndex,
|
|
882
|
-
serverTimestamp: message.serverTimestamp
|
|
883
|
-
// 必须使用服务器时间戳
|
|
884
|
-
// 注意:proofSiblings 和 proofIndices 从服务器拉取时不提供
|
|
885
|
-
// verifyMessage 会跳过 Merkle Proof 验证,只验证 Root 计算
|
|
886
|
-
};
|
|
887
|
-
}
|
|
888
|
-
const verifyResult = verifyMessage(verifyParams);
|
|
889
|
-
if (!verifyResult.valid) {
|
|
890
|
-
throw new MessengerError(
|
|
891
|
-
MessengerErrorCode.INVALID_PROOF,
|
|
892
|
-
`Message verification failed: ${verifyResult.error}`
|
|
893
|
-
);
|
|
894
|
-
}
|
|
895
|
-
if (!message.serverPublicKey) {
|
|
896
|
-
throw new MessengerError(
|
|
897
|
-
MessengerErrorCode.INVALID_PROOF,
|
|
898
|
-
`Message does not have server public key`
|
|
899
|
-
);
|
|
900
|
-
}
|
|
901
|
-
const { CallProof } = await import("../call/proof.js");
|
|
902
|
-
const callProof = new CallProof({
|
|
903
|
-
proof: message.newRoot,
|
|
904
|
-
// 证明root存在
|
|
905
|
-
server_pubkey: message.serverPublicKey,
|
|
906
|
-
server_signature: message.serverSignature,
|
|
907
|
-
proof_type: CHAIN_PROOF_TYPE,
|
|
908
|
-
// 消息证明类型
|
|
909
|
-
description: `Message proof for ${messageId}`,
|
|
910
|
-
item_count: message.leafIndex ?? 1,
|
|
911
|
-
about_address: message.fromAddress.toLowerCase() === address.toLowerCase() ? message.toAddress : message.fromAddress
|
|
912
|
-
});
|
|
913
|
-
const env = {
|
|
914
|
-
network,
|
|
915
|
-
account: address
|
|
916
|
-
};
|
|
917
|
-
const result = await callProof.call(env);
|
|
918
|
-
const { ResponseData: extractResponseData } = await import("../call/base.js");
|
|
919
|
-
const responseData = extractResponseData(result);
|
|
920
|
-
const proofResult = responseData.find((item) => item.type === "Proof");
|
|
921
|
-
if (!proofResult || !proofResult.object) {
|
|
922
|
-
throw new MessengerError(
|
|
923
|
-
MessengerErrorCode.INVALID_PROOF,
|
|
924
|
-
`Failed to get proof address from transaction result`
|
|
925
|
-
);
|
|
926
|
-
}
|
|
927
|
-
message.proof = proofResult.object;
|
|
928
|
-
messageStorage.saveMessage(message);
|
|
929
|
-
return { proofAddress: proofResult.object };
|
|
986
|
+
return html;
|
|
930
987
|
}
|
|
931
|
-
|
|
932
|
-
|
|
933
|
-
|
|
934
|
-
|
|
935
|
-
|
|
936
|
-
|
|
937
|
-
|
|
938
|
-
|
|
939
|
-
|
|
940
|
-
|
|
941
|
-
|
|
942
|
-
|
|
943
|
-
|
|
944
|
-
|
|
945
|
-
|
|
946
|
-
|
|
947
|
-
let addresses = await GetManyAccountOrMark_Address(request.users);
|
|
948
|
-
if (addresses.length === 0) {
|
|
949
|
-
W_ERROR(
|
|
950
|
-
WErrors.InvalidParam,
|
|
951
|
-
`blacklist.add.users ${request.users} have not valid addresses`
|
|
952
|
-
);
|
|
953
|
-
}
|
|
954
|
-
addresses = [...new Set(addresses.map((a) => a.toLowerCase()))];
|
|
955
|
-
if (addresses.length > MAX_BLACKLIST_SIZE_ONCE) {
|
|
956
|
-
W_ERROR(
|
|
957
|
-
WErrors.InvalidParam,
|
|
958
|
-
`blacklist.add.users ${request.users} have too many addresses, max ${MAX_BLACKLIST_SIZE_ONCE}`
|
|
959
|
-
);
|
|
960
|
-
}
|
|
961
|
-
const result = await manager.addToBlacklist(acc, addresses);
|
|
962
|
-
return { op: "add", result };
|
|
988
|
+
/**
|
|
989
|
+
* 提交消息链上证明
|
|
990
|
+
*
|
|
991
|
+
* 将消息的 Merkle 证明提交到链上,创建不可篡改的证明记录。
|
|
992
|
+
* 此函数会先验证消息的完整性和合法性。
|
|
993
|
+
*
|
|
994
|
+
* @param account 账号名称或地址
|
|
995
|
+
* @param messageId 消息ID
|
|
996
|
+
* @param env 调用环境(包含网络、签名账号等)
|
|
997
|
+
* @returns 证明对象地址
|
|
998
|
+
*/
|
|
999
|
+
export async function proof_message(account, messageId, network) {
|
|
1000
|
+
// 1. 解析账号地址
|
|
1001
|
+
const address = await Account.Instance().get_address(account);
|
|
1002
|
+
if (!address) {
|
|
1003
|
+
W_ERROR(WErrors.AccountNotFound, `proof_message.account ${account}`);
|
|
963
1004
|
}
|
|
964
|
-
|
|
965
|
-
|
|
966
|
-
|
|
967
|
-
|
|
968
|
-
|
|
969
|
-
`blacklist.remove.users ${request.users} have not valid addresses`
|
|
970
|
-
);
|
|
971
|
-
}
|
|
972
|
-
addresses = [...new Set(addresses.map((a) => a.toLowerCase()))];
|
|
973
|
-
if (addresses.length > MAX_BLACKLIST_SIZE_ONCE) {
|
|
974
|
-
W_ERROR(
|
|
975
|
-
WErrors.InvalidParam,
|
|
976
|
-
`blacklist.remove.users ${request.users} have too many addresses, max ${MAX_BLACKLIST_SIZE_ONCE}`
|
|
977
|
-
);
|
|
978
|
-
}
|
|
979
|
-
const result = await manager.removeFromBlacklist(acc, addresses);
|
|
980
|
-
return { op: "remove", result };
|
|
1005
|
+
// 2. 获取消息
|
|
1006
|
+
const messageStorage = new MessageStorage(address);
|
|
1007
|
+
const message = messageStorage.getMessageById(messageId);
|
|
1008
|
+
if (!message) {
|
|
1009
|
+
throw new MessengerError(MessengerErrorCode.INVALID_INPUT, `Message not found: ${messageId}`);
|
|
981
1010
|
}
|
|
982
|
-
|
|
983
|
-
|
|
984
|
-
|
|
1011
|
+
// 3. 验证消息属于该账号
|
|
1012
|
+
if (message.fromAddress.toLowerCase() !== address.toLowerCase() &&
|
|
1013
|
+
message.toAddress.toLowerCase() !== address.toLowerCase()) {
|
|
1014
|
+
throw new MessengerError(MessengerErrorCode.INVALID_INPUT, `Message does not belong to account ${address}`);
|
|
985
1015
|
}
|
|
986
|
-
|
|
987
|
-
|
|
988
|
-
|
|
1016
|
+
// 4. 验证服务器签名存在
|
|
1017
|
+
if (!message.serverSignature) {
|
|
1018
|
+
throw new MessengerError(MessengerErrorCode.INVALID_PROOF, `Message does not have server signature`);
|
|
989
1019
|
}
|
|
990
|
-
|
|
991
|
-
|
|
992
|
-
if (addresses.length === 0) {
|
|
993
|
-
W_ERROR(
|
|
994
|
-
WErrors.InvalidParam,
|
|
995
|
-
`blacklist.exist.users ${request.users} have not valid addresses`
|
|
996
|
-
);
|
|
997
|
-
}
|
|
998
|
-
addresses = [...new Set(addresses.map((a) => a.toLowerCase()))];
|
|
999
|
-
if (addresses.length > MAX_BLACKLIST_SIZE_ONCE) {
|
|
1000
|
-
W_ERROR(
|
|
1001
|
-
WErrors.InvalidParam,
|
|
1002
|
-
`blacklist.exist.users ${request.users} have too many addresses, max ${MAX_BLACKLIST_SIZE_ONCE}`
|
|
1003
|
-
);
|
|
1004
|
-
}
|
|
1005
|
-
const result = await manager.existInBlacklist(acc, addresses);
|
|
1006
|
-
return { op: "exist", result };
|
|
1020
|
+
if (!message.serverPublicKey) {
|
|
1021
|
+
throw new MessengerError(MessengerErrorCode.INVALID_PROOF, `Message does not have server public key`);
|
|
1007
1022
|
}
|
|
1008
|
-
|
|
1009
|
-
|
|
1010
|
-
MessengerErrorCode.
|
|
1011
|
-
`blacklist.unknown op: ${request}`
|
|
1012
|
-
);
|
|
1013
|
-
}
|
|
1014
|
-
}
|
|
1015
|
-
async function friendslist(request) {
|
|
1016
|
-
const acc = await Account.Instance().get_address(request.account);
|
|
1017
|
-
if (!acc) {
|
|
1018
|
-
W_ERROR(
|
|
1019
|
-
WErrors.AccountNotFound,
|
|
1020
|
-
`friendslist.account ${request.account}`
|
|
1021
|
-
);
|
|
1022
|
-
}
|
|
1023
|
-
const manager = getMessengerManager();
|
|
1024
|
-
switch (request.op) {
|
|
1025
|
-
case "add": {
|
|
1026
|
-
let addresses = await GetManyAccountOrMark_Address(request.users);
|
|
1027
|
-
if (addresses.length === 0) {
|
|
1028
|
-
W_ERROR(
|
|
1029
|
-
WErrors.InvalidParam,
|
|
1030
|
-
`friendslist.add.users ${request.users} have not valid addresses`
|
|
1031
|
-
);
|
|
1032
|
-
}
|
|
1033
|
-
addresses = [...new Set(addresses.map((a) => a.toLowerCase()))];
|
|
1034
|
-
const result = await manager.addToFriendsList(acc, addresses);
|
|
1035
|
-
return { op: "add", result };
|
|
1023
|
+
// 5. 使用 verifyMessage 验证消息完整性(包含服务器签名验证)
|
|
1024
|
+
if (!message.plaintext) {
|
|
1025
|
+
throw new MessengerError(MessengerErrorCode.INVALID_PROOF, `Message does not have plaintext`);
|
|
1036
1026
|
}
|
|
1037
|
-
|
|
1038
|
-
|
|
1039
|
-
|
|
1040
|
-
|
|
1041
|
-
|
|
1042
|
-
|
|
1043
|
-
|
|
1044
|
-
|
|
1045
|
-
|
|
1046
|
-
|
|
1047
|
-
|
|
1048
|
-
|
|
1049
|
-
|
|
1050
|
-
|
|
1051
|
-
|
|
1052
|
-
|
|
1053
|
-
|
|
1027
|
+
const { verifyMessage } = await import("./crypto.js");
|
|
1028
|
+
// 构造验证参数
|
|
1029
|
+
const verifyParams = {
|
|
1030
|
+
messageId: message.messageId,
|
|
1031
|
+
plaintext: message.plaintext,
|
|
1032
|
+
plaintextHash: message.plaintextHash,
|
|
1033
|
+
createdAt: message.createdAt,
|
|
1034
|
+
guardAddress: message.guardAddress,
|
|
1035
|
+
passportAddress: message.passportAddress,
|
|
1036
|
+
serverSignature: message.serverSignature,
|
|
1037
|
+
serverPublicKey: message.serverPublicKey,
|
|
1038
|
+
};
|
|
1039
|
+
// 如果消息有完整的 Merkle 证明数据,则添加 merkleMetadata
|
|
1040
|
+
if (message.newRoot && message.leafIndex !== undefined) {
|
|
1041
|
+
// 检查服务器时间戳是否存在
|
|
1042
|
+
if (!message.serverTimestamp) {
|
|
1043
|
+
throw new MessengerError(MessengerErrorCode.INVALID_PROOF, `Message ${message.messageId} missing server timestamp for verification`);
|
|
1044
|
+
}
|
|
1045
|
+
verifyParams.merkleMetadata = {
|
|
1046
|
+
newRoot: message.newRoot,
|
|
1047
|
+
prevRoot: message.prevRoot,
|
|
1048
|
+
leafIndex: message.leafIndex,
|
|
1049
|
+
serverTimestamp: message.serverTimestamp, // 必须使用服务器时间戳
|
|
1050
|
+
// 注意:proofSiblings 和 proofIndices 从服务器拉取时不提供
|
|
1051
|
+
// verifyMessage 会跳过 Merkle Proof 验证,只验证 Root 计算
|
|
1052
|
+
};
|
|
1054
1053
|
}
|
|
1055
|
-
|
|
1056
|
-
|
|
1057
|
-
|
|
1054
|
+
const verifyResult = verifyMessage(verifyParams);
|
|
1055
|
+
if (!verifyResult.valid) {
|
|
1056
|
+
throw new MessengerError(MessengerErrorCode.INVALID_PROOF, `Message verification failed: ${verifyResult.error}`);
|
|
1058
1057
|
}
|
|
1059
|
-
|
|
1060
|
-
|
|
1061
|
-
|
|
1058
|
+
// 6. 从消息中获取服务器公钥
|
|
1059
|
+
if (!message.serverPublicKey) {
|
|
1060
|
+
throw new MessengerError(MessengerErrorCode.INVALID_PROOF, `Message does not have server public key`);
|
|
1062
1061
|
}
|
|
1063
|
-
|
|
1064
|
-
|
|
1065
|
-
|
|
1066
|
-
|
|
1067
|
-
|
|
1068
|
-
|
|
1069
|
-
|
|
1070
|
-
|
|
1071
|
-
|
|
1072
|
-
|
|
1073
|
-
|
|
1074
|
-
|
|
1075
|
-
|
|
1076
|
-
|
|
1077
|
-
|
|
1078
|
-
|
|
1079
|
-
|
|
1062
|
+
// 7. 创建链上证明
|
|
1063
|
+
const { CallProof } = await import("../call/proof.js");
|
|
1064
|
+
const callProof = new CallProof({
|
|
1065
|
+
proof: message.newRoot, // 证明root存在
|
|
1066
|
+
server_pubkey: message.serverPublicKey,
|
|
1067
|
+
server_signature: message.serverSignature,
|
|
1068
|
+
proof_type: CHAIN_PROOF_TYPE, // 消息证明类型
|
|
1069
|
+
description: `Message proof for ${messageId}`,
|
|
1070
|
+
item_count: message.leafIndex ?? 1,
|
|
1071
|
+
about_address: message.fromAddress.toLowerCase() === address.toLowerCase()
|
|
1072
|
+
? message.toAddress
|
|
1073
|
+
: message.fromAddress,
|
|
1074
|
+
});
|
|
1075
|
+
// 8. 构造调用环境并执行
|
|
1076
|
+
const env = {
|
|
1077
|
+
network,
|
|
1078
|
+
account: address,
|
|
1079
|
+
};
|
|
1080
|
+
const result = await callProof.call(env);
|
|
1081
|
+
// 9. 使用 ResponseData 提取 Proof 对象地址
|
|
1082
|
+
const { ResponseData: extractResponseData } = await import("../call/base.js");
|
|
1083
|
+
const responseData = extractResponseData(result);
|
|
1084
|
+
// 查找 Proof 类型的对象
|
|
1085
|
+
const proofResult = responseData.find((item) => item.type === "Proof");
|
|
1086
|
+
if (!proofResult || !proofResult.object) {
|
|
1087
|
+
throw new MessengerError(MessengerErrorCode.INVALID_PROOF, `Failed to get proof address from transaction result`);
|
|
1080
1088
|
}
|
|
1081
|
-
|
|
1082
|
-
|
|
1083
|
-
|
|
1084
|
-
`friendslist.unknown op: ${request}`
|
|
1085
|
-
);
|
|
1086
|
-
}
|
|
1089
|
+
message.proof = proofResult.object;
|
|
1090
|
+
messageStorage.saveMessage(message);
|
|
1091
|
+
return { proofAddress: proofResult.object };
|
|
1087
1092
|
}
|
|
1088
|
-
|
|
1089
|
-
|
|
1090
|
-
|
|
1091
|
-
|
|
1092
|
-
|
|
1093
|
-
|
|
1094
|
-
|
|
1095
|
-
|
|
1096
|
-
|
|
1097
|
-
|
|
1098
|
-
|
|
1099
|
-
|
|
1100
|
-
|
|
1101
|
-
|
|
1102
|
-
|
|
1103
|
-
|
|
1104
|
-
|
|
1105
|
-
|
|
1106
|
-
|
|
1107
|
-
|
|
1108
|
-
|
|
1109
|
-
|
|
1110
|
-
|
|
1111
|
-
|
|
1112
|
-
|
|
1113
|
-
|
|
1114
|
-
|
|
1115
|
-
|
|
1116
|
-
|
|
1117
|
-
if (!isValidU64(g.passportValiditySeconds) || g.passportValiditySeconds < MIN_PASSPORT_VALIDITY || g.passportValiditySeconds > MAX_PASSPORT_VALIDITY) {
|
|
1118
|
-
W_ERROR(
|
|
1119
|
-
WErrors.InvalidParam,
|
|
1120
|
-
`Guard ${g.guard}: passport validity ${g.passportValiditySeconds} must be between ${MIN_PASSPORT_VALIDITY} and ${MAX_PASSPORT_VALIDITY} seconds`
|
|
1121
|
-
);
|
|
1093
|
+
const MIN_PASSPORT_VALIDITY = 10; // 10 seconds
|
|
1094
|
+
const MAX_PASSPORT_VALIDITY = 10 * 365 * 24 * 60 * 60; // 10 years in seconds
|
|
1095
|
+
const MAX_BLACKLIST_SIZE_ONCE = 100;
|
|
1096
|
+
const MAX_FRIENDS_SIZE_ONCE = 100;
|
|
1097
|
+
const MAX_GUARDS_SIZE_ONCE = 10;
|
|
1098
|
+
/**
|
|
1099
|
+
* 黑名单管理 - 统一入口
|
|
1100
|
+
* @param request 操作请求
|
|
1101
|
+
* @returns 操作结果
|
|
1102
|
+
*/
|
|
1103
|
+
export async function blacklist(request) {
|
|
1104
|
+
const acc = await Account.Instance().get_address(request.account);
|
|
1105
|
+
if (!acc) {
|
|
1106
|
+
W_ERROR(WErrors.AccountNotFound, `blacklist.account ${request.account}`);
|
|
1107
|
+
}
|
|
1108
|
+
const manager = getMessengerManager();
|
|
1109
|
+
switch (request.op) {
|
|
1110
|
+
case "add": {
|
|
1111
|
+
let addresses = await GetManyAccountOrMark_Address(request.users);
|
|
1112
|
+
if (addresses.length === 0) {
|
|
1113
|
+
W_ERROR(WErrors.InvalidParam, `blacklist.add.users ${request.users} have not valid addresses`);
|
|
1114
|
+
}
|
|
1115
|
+
// 去重
|
|
1116
|
+
addresses = [...new Set(addresses.map((a) => a.toLowerCase()))];
|
|
1117
|
+
if (addresses.length > MAX_BLACKLIST_SIZE_ONCE) {
|
|
1118
|
+
W_ERROR(WErrors.InvalidParam, `blacklist.add.users ${request.users} have too many addresses, max ${MAX_BLACKLIST_SIZE_ONCE}`);
|
|
1119
|
+
}
|
|
1120
|
+
const result = await manager.addToBlacklist(acc, addresses);
|
|
1121
|
+
return { op: "add", result };
|
|
1122
1122
|
}
|
|
1123
|
-
|
|
1124
|
-
|
|
1125
|
-
|
|
1126
|
-
|
|
1127
|
-
|
|
1128
|
-
|
|
1129
|
-
|
|
1130
|
-
|
|
1131
|
-
|
|
1132
|
-
|
|
1133
|
-
|
|
1123
|
+
case "remove": {
|
|
1124
|
+
let addresses = await GetManyAccountOrMark_Address(request.users);
|
|
1125
|
+
if (addresses.length === 0) {
|
|
1126
|
+
W_ERROR(WErrors.InvalidParam, `blacklist.remove.users ${request.users} have not valid addresses`);
|
|
1127
|
+
}
|
|
1128
|
+
// 去重
|
|
1129
|
+
addresses = [...new Set(addresses.map((a) => a.toLowerCase()))];
|
|
1130
|
+
if (addresses.length > MAX_BLACKLIST_SIZE_ONCE) {
|
|
1131
|
+
W_ERROR(WErrors.InvalidParam, `blacklist.remove.users ${request.users} have too many addresses, max ${MAX_BLACKLIST_SIZE_ONCE}`);
|
|
1132
|
+
}
|
|
1133
|
+
const result = await manager.removeFromBlacklist(acc, addresses);
|
|
1134
|
+
return { op: "remove", result };
|
|
1134
1135
|
}
|
|
1135
|
-
|
|
1136
|
-
|
|
1137
|
-
|
|
1138
|
-
);
|
|
1139
|
-
}
|
|
1140
|
-
const objs = await query_objects({
|
|
1141
|
-
objects: addresses,
|
|
1142
|
-
no_cache: false,
|
|
1143
|
-
network: manager.getConfig().network
|
|
1144
|
-
});
|
|
1145
|
-
if (!objs || !objs.objects || objs.objects.length === 0) {
|
|
1146
|
-
W_ERROR(
|
|
1147
|
-
WErrors.InvalidParam,
|
|
1148
|
-
`Guard not found: ${guards.map((g) => g.guard).join(", ")}`
|
|
1149
|
-
);
|
|
1150
|
-
}
|
|
1151
|
-
objs.objects.forEach((obj) => {
|
|
1152
|
-
if (obj.type !== "Guard") {
|
|
1153
|
-
W_ERROR(
|
|
1154
|
-
WErrors.InvalidParam,
|
|
1155
|
-
`Guard ${obj.object} is not a Guard`
|
|
1156
|
-
);
|
|
1136
|
+
case "clear": {
|
|
1137
|
+
const result = await manager.clearBlacklist(acc);
|
|
1138
|
+
return { op: "clear", result };
|
|
1157
1139
|
}
|
|
1158
|
-
|
|
1159
|
-
|
|
1160
|
-
|
|
1161
|
-
|
|
1162
|
-
|
|
1163
|
-
|
|
1164
|
-
|
|
1140
|
+
case "get": {
|
|
1141
|
+
const result = await manager.getBlacklist(acc);
|
|
1142
|
+
return { op: "get", result };
|
|
1143
|
+
}
|
|
1144
|
+
case "exist": {
|
|
1145
|
+
let addresses = await GetManyAccountOrMark_Address(request.users);
|
|
1146
|
+
if (addresses.length === 0) {
|
|
1147
|
+
W_ERROR(WErrors.InvalidParam, `blacklist.exist.users ${request.users} have not valid addresses`);
|
|
1148
|
+
}
|
|
1149
|
+
// 去重
|
|
1150
|
+
addresses = [...new Set(addresses.map((a) => a.toLowerCase()))];
|
|
1151
|
+
if (addresses.length > MAX_BLACKLIST_SIZE_ONCE) {
|
|
1152
|
+
W_ERROR(WErrors.InvalidParam, `blacklist.exist.users ${request.users} have too many addresses, max ${MAX_BLACKLIST_SIZE_ONCE}`);
|
|
1153
|
+
}
|
|
1154
|
+
const result = await manager.existInBlacklist(acc, addresses);
|
|
1155
|
+
return { op: "exist", result };
|
|
1156
|
+
}
|
|
1157
|
+
default:
|
|
1158
|
+
throw new MessengerError(MessengerErrorCode.INVALID_INPUT, `blacklist.unknown op: ${request}`);
|
|
1165
1159
|
}
|
|
1166
|
-
|
|
1167
|
-
|
|
1168
|
-
|
|
1169
|
-
|
|
1170
|
-
|
|
1171
|
-
|
|
1172
|
-
|
|
1173
|
-
|
|
1174
|
-
|
|
1175
|
-
|
|
1176
|
-
|
|
1177
|
-
|
|
1178
|
-
|
|
1179
|
-
|
|
1180
|
-
|
|
1181
|
-
|
|
1182
|
-
|
|
1183
|
-
|
|
1184
|
-
|
|
1185
|
-
|
|
1186
|
-
|
|
1187
|
-
|
|
1188
|
-
missingGuards.push(g);
|
|
1189
|
-
}
|
|
1160
|
+
}
|
|
1161
|
+
/**
|
|
1162
|
+
* 好友列表管理 - 统一入口
|
|
1163
|
+
* @param request 操作请求
|
|
1164
|
+
* @returns 操作结果
|
|
1165
|
+
*/
|
|
1166
|
+
export async function friendslist(request) {
|
|
1167
|
+
const acc = await Account.Instance().get_address(request.account);
|
|
1168
|
+
if (!acc) {
|
|
1169
|
+
W_ERROR(WErrors.AccountNotFound, `friendslist.account ${request.account}`);
|
|
1170
|
+
}
|
|
1171
|
+
const manager = getMessengerManager();
|
|
1172
|
+
switch (request.op) {
|
|
1173
|
+
case "add": {
|
|
1174
|
+
let addresses = await GetManyAccountOrMark_Address(request.users);
|
|
1175
|
+
if (addresses.length === 0) {
|
|
1176
|
+
W_ERROR(WErrors.InvalidParam, `friendslist.add.users ${request.users} have not valid addresses`);
|
|
1177
|
+
}
|
|
1178
|
+
// 去重
|
|
1179
|
+
addresses = [...new Set(addresses.map((a) => a.toLowerCase()))];
|
|
1180
|
+
const result = await manager.addToFriendsList(acc, addresses);
|
|
1181
|
+
return { op: "add", result };
|
|
1190
1182
|
}
|
|
1191
|
-
|
|
1192
|
-
|
|
1193
|
-
|
|
1194
|
-
|
|
1195
|
-
|
|
1196
|
-
|
|
1197
|
-
|
|
1198
|
-
|
|
1199
|
-
|
|
1200
|
-
|
|
1183
|
+
case "remove": {
|
|
1184
|
+
let addresses = await GetManyAccountOrMark_Address(request.users);
|
|
1185
|
+
if (addresses.length === 0) {
|
|
1186
|
+
W_ERROR(WErrors.InvalidParam, `friendslist.remove.users ${request.users} have not valid addresses`);
|
|
1187
|
+
}
|
|
1188
|
+
// 去重
|
|
1189
|
+
addresses = [...new Set(addresses.map((a) => a.toLowerCase()))];
|
|
1190
|
+
if (addresses.length > MAX_FRIENDS_SIZE_ONCE) {
|
|
1191
|
+
W_ERROR(WErrors.InvalidParam, `friendslist.remove.users ${request.users} have too many addresses, max ${MAX_FRIENDS_SIZE_ONCE}`);
|
|
1192
|
+
}
|
|
1193
|
+
const result = await manager.removeFromFriendsList(acc, addresses);
|
|
1194
|
+
return { op: "remove", result };
|
|
1195
|
+
}
|
|
1196
|
+
case "clear": {
|
|
1197
|
+
const result = await manager.clearFriendsList(acc);
|
|
1198
|
+
return { op: "clear", result };
|
|
1199
|
+
}
|
|
1200
|
+
case "get": {
|
|
1201
|
+
const result = await manager.getFriendsList(acc);
|
|
1202
|
+
return { op: "get", result };
|
|
1203
|
+
}
|
|
1204
|
+
case "exist": {
|
|
1205
|
+
let addresses = await GetManyAccountOrMark_Address(request.users);
|
|
1206
|
+
if (addresses.length === 0) {
|
|
1207
|
+
W_ERROR(WErrors.InvalidParam, `friendslist.exist.users ${request.users} have not valid addresses`);
|
|
1208
|
+
}
|
|
1209
|
+
// 去重
|
|
1210
|
+
addresses = [...new Set(addresses.map((a) => a.toLowerCase()))];
|
|
1211
|
+
if (addresses.length > MAX_FRIENDS_SIZE_ONCE) {
|
|
1212
|
+
W_ERROR(WErrors.InvalidParam, `friendslist.exist.users ${request.users} have too many addresses, max ${MAX_FRIENDS_SIZE_ONCE}`);
|
|
1213
|
+
}
|
|
1214
|
+
const result = await manager.existInFriendsList(acc, addresses);
|
|
1215
|
+
return { op: "exist", result };
|
|
1216
|
+
}
|
|
1217
|
+
default:
|
|
1218
|
+
throw new MessengerError(MessengerErrorCode.INVALID_INPUT, `friendslist.unknown op: ${request}`);
|
|
1219
|
+
}
|
|
1220
|
+
}
|
|
1221
|
+
/**
|
|
1222
|
+
* Guard 列表管理 - 统一入口
|
|
1223
|
+
* @param request 操作请求
|
|
1224
|
+
* @returns 操作结果
|
|
1225
|
+
*/
|
|
1226
|
+
export async function guardlist(request) {
|
|
1227
|
+
const acc = await Account.Instance().get_address(request.account);
|
|
1228
|
+
if (!acc) {
|
|
1229
|
+
W_ERROR(WErrors.AccountNotFound, `guardlist.account ${request.account}`);
|
|
1201
1230
|
}
|
|
1202
|
-
|
|
1203
|
-
|
|
1204
|
-
|
|
1231
|
+
const manager = getMessengerManager();
|
|
1232
|
+
switch (request.op) {
|
|
1233
|
+
case "add": {
|
|
1234
|
+
// 按 guard 字段去重,保留最后一个
|
|
1235
|
+
const uniqueGuardsMap = new Map();
|
|
1236
|
+
for (const g of request.guards) {
|
|
1237
|
+
uniqueGuardsMap.set(g.guard.toLowerCase(), g);
|
|
1238
|
+
}
|
|
1239
|
+
const guards = Array.from(uniqueGuardsMap.values());
|
|
1240
|
+
if (guards.length === 0) {
|
|
1241
|
+
W_ERROR(WErrors.InvalidParam, `guardlist.add.guards ${request.guards} have not valid guards`);
|
|
1242
|
+
}
|
|
1243
|
+
// 去重
|
|
1244
|
+
if (guards.length > MAX_GUARDS_SIZE_ONCE) {
|
|
1245
|
+
W_ERROR(WErrors.InvalidParam, `guardlist.add.guards ${request.guards} have too many guards, max ${MAX_GUARDS_SIZE_ONCE}`);
|
|
1246
|
+
}
|
|
1247
|
+
// Validate TTL range
|
|
1248
|
+
for (const g of guards) {
|
|
1249
|
+
if (!isValidU64(g.passportValiditySeconds) ||
|
|
1250
|
+
g.passportValiditySeconds < MIN_PASSPORT_VALIDITY ||
|
|
1251
|
+
g.passportValiditySeconds > MAX_PASSPORT_VALIDITY) {
|
|
1252
|
+
W_ERROR(WErrors.InvalidParam, `Guard ${g.guard}: passport validity ${g.passportValiditySeconds} must be between ${MIN_PASSPORT_VALIDITY} and ${MAX_PASSPORT_VALIDITY} seconds`);
|
|
1253
|
+
}
|
|
1254
|
+
}
|
|
1255
|
+
const addresses = await LocalMark.Instance().get_many_address(guards.map((g) => g.guard));
|
|
1256
|
+
// Validate all addresses were found
|
|
1257
|
+
if (addresses.length !== guards.length) {
|
|
1258
|
+
const foundAddresses = new Set(addresses);
|
|
1259
|
+
const missingGuards = [];
|
|
1260
|
+
for (const g of guards) {
|
|
1261
|
+
if (!foundAddresses.has(g.guard) &&
|
|
1262
|
+
!g.guard.startsWith("0x")) {
|
|
1263
|
+
missingGuards.push(g.guard);
|
|
1264
|
+
}
|
|
1265
|
+
}
|
|
1266
|
+
W_ERROR(WErrors.InvalidParam, `Guard not found: ${missingGuards.join(", ")}`);
|
|
1267
|
+
}
|
|
1268
|
+
// 通过查询检查是不是guard地址
|
|
1269
|
+
const objs = await query_objects({
|
|
1270
|
+
objects: addresses,
|
|
1271
|
+
no_cache: false,
|
|
1272
|
+
network: manager.getConfig().network,
|
|
1273
|
+
});
|
|
1274
|
+
if (!objs || !objs.objects || objs.objects.length === 0) {
|
|
1275
|
+
W_ERROR(WErrors.InvalidParam, `Guard not found: ${guards.map((g) => g.guard).join(", ")}`);
|
|
1276
|
+
}
|
|
1277
|
+
objs.objects.forEach((obj) => {
|
|
1278
|
+
if (obj.type !== "Guard") {
|
|
1279
|
+
W_ERROR(WErrors.InvalidParam, `Guard ${obj.object} is not a Guard`);
|
|
1280
|
+
}
|
|
1281
|
+
});
|
|
1282
|
+
const guardListItems = guards.map((g, index) => ({
|
|
1283
|
+
guardAddress: addresses[index],
|
|
1284
|
+
passportValiditySeconds: g.passportValiditySeconds,
|
|
1285
|
+
}));
|
|
1286
|
+
const result = await manager.addToGuardList(acc, guardListItems);
|
|
1287
|
+
return { op: "add", result };
|
|
1288
|
+
}
|
|
1289
|
+
case "remove": {
|
|
1290
|
+
const guards = [
|
|
1291
|
+
...new Set(request.guards.map((g) => g.toLowerCase())),
|
|
1292
|
+
];
|
|
1293
|
+
if (guards.length === 0) {
|
|
1294
|
+
W_ERROR(WErrors.InvalidParam, `guardlist.remove.guards ${request.guards} have not valid guards`);
|
|
1295
|
+
}
|
|
1296
|
+
// 去重
|
|
1297
|
+
if (guards.length > MAX_GUARDS_SIZE_ONCE) {
|
|
1298
|
+
W_ERROR(WErrors.InvalidParam, `guardlist.remove.guards ${request.guards} have too many guards, max ${MAX_GUARDS_SIZE_ONCE}`);
|
|
1299
|
+
}
|
|
1300
|
+
const addresses = await LocalMark.Instance().get_many_address(guards);
|
|
1301
|
+
if (addresses.length !== guards.length) {
|
|
1302
|
+
const foundAddresses = new Set(addresses);
|
|
1303
|
+
const missingGuards = [];
|
|
1304
|
+
for (const g of guards) {
|
|
1305
|
+
if (!foundAddresses.has(g) && !g.startsWith("0x")) {
|
|
1306
|
+
missingGuards.push(g);
|
|
1307
|
+
}
|
|
1308
|
+
}
|
|
1309
|
+
W_ERROR(WErrors.InvalidParam, `Guard not found: ${missingGuards.join(", ")}`);
|
|
1310
|
+
}
|
|
1311
|
+
const result = await manager.removeFromGuardList(acc, addresses);
|
|
1312
|
+
return { op: "remove", result };
|
|
1313
|
+
}
|
|
1314
|
+
case "get": {
|
|
1315
|
+
const result = await manager.getGuardList(acc);
|
|
1316
|
+
return { op: "get", result };
|
|
1317
|
+
}
|
|
1318
|
+
default:
|
|
1319
|
+
throw new MessengerError(MessengerErrorCode.INVALID_INPUT, `guardlist.unknown op: ${request}`);
|
|
1205
1320
|
}
|
|
1206
|
-
default:
|
|
1207
|
-
throw new MessengerError(
|
|
1208
|
-
MessengerErrorCode.INVALID_INPUT,
|
|
1209
|
-
`guardlist.unknown op: ${request}`
|
|
1210
|
-
);
|
|
1211
|
-
}
|
|
1212
1321
|
}
|
|
1213
|
-
|
|
1214
|
-
blacklist,
|
|
1215
|
-
extract_zip_messages,
|
|
1216
|
-
friendslist,
|
|
1217
|
-
generate_wts,
|
|
1218
|
-
getMessengerManager,
|
|
1219
|
-
guardlist,
|
|
1220
|
-
proof_message,
|
|
1221
|
-
send_file,
|
|
1222
|
-
send_message,
|
|
1223
|
-
sign_wts,
|
|
1224
|
-
verify_wts,
|
|
1225
|
-
watch_conversations,
|
|
1226
|
-
watch_messages,
|
|
1227
|
-
wts2html
|
|
1228
|
-
};
|
|
1322
|
+
//# sourceMappingURL=messenger-api.js.map
|