@bitgo/wasm-utxo 4.4.0 → 4.6.0

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.
@@ -1,151 +1,11 @@
1
1
  /* tslint:disable */
2
2
  /* eslint-disable */
3
3
  export const memory: WebAssembly.Memory;
4
- export const __wbg_wrapdescriptor_free: (a: number, b: number) => void;
5
- export const __wbg_wrapminiscript_free: (a: number, b: number) => void;
6
- export const wrapdescriptor_atDerivationIndex: (a: number, b: number, c: number) => void;
7
- export const wrapdescriptor_descType: (a: number, b: number) => void;
8
- export const wrapdescriptor_encode: (a: number, b: number) => void;
9
- export const wrapdescriptor_fromString: (a: number, b: number, c: number, d: number, e: number) => void;
10
- export const wrapdescriptor_fromStringDetectType: (a: number, b: number, c: number) => void;
11
- export const wrapdescriptor_hasWildcard: (a: number) => number;
12
- export const wrapdescriptor_maxWeightToSatisfy: (a: number, b: number) => void;
13
- export const wrapdescriptor_node: (a: number, b: number) => void;
14
- export const wrapdescriptor_scriptPubkey: (a: number, b: number) => void;
15
- export const wrapdescriptor_toAsmString: (a: number, b: number) => void;
16
- export const wrapdescriptor_toString: (a: number, b: number) => void;
17
- export const wrapminiscript_encode: (a: number, b: number) => void;
18
- export const wrapminiscript_fromBitcoinScript: (a: number, b: number, c: number, d: number, e: number) => void;
19
- export const wrapminiscript_fromString: (a: number, b: number, c: number, d: number, e: number) => void;
20
- export const wrapminiscript_node: (a: number, b: number) => void;
21
- export const wrapminiscript_toAsmString: (a: number, b: number) => void;
22
- export const wrapminiscript_toString: (a: number, b: number) => void;
23
- export const __wbg_addressnamespace_free: (a: number, b: number) => void;
24
- export const __wbg_inscriptionsnamespace_free: (a: number, b: number) => void;
25
- export const __wbg_wasmbip32_free: (a: number, b: number) => void;
26
- export const __wbg_wasmdashtransaction_free: (a: number, b: number) => void;
27
- export const __wbg_wasmecpair_free: (a: number, b: number) => void;
28
- export const __wbg_wasmtransaction_free: (a: number, b: number) => void;
29
- export const __wbg_wasmzcashtransaction_free: (a: number, b: number) => void;
30
- export const __wbg_wrappsbt_free: (a: number, b: number) => void;
31
- export const addressnamespace_from_output_script_with_coin: (a: number, b: number, c: number, d: number, e: number, f: number, g: number) => void;
32
- export const addressnamespace_to_output_script_with_coin: (a: number, b: number, c: number, d: number, e: number) => void;
33
- export const inscriptionsnamespace_create_inscription_reveal_data: (a: number, b: number, c: number, d: number, e: number, f: number, g: number) => void;
34
- export const inscriptionsnamespace_sign_reveal_transaction: (a: number, b: number, c: number, d: number, e: number, f: number, g: number, h: number, i: number, j: bigint) => void;
35
- export const wasmbip32_chain_code: (a: number) => number;
36
- export const wasmbip32_depth: (a: number) => number;
37
- export const wasmbip32_derive: (a: number, b: number, c: number) => void;
38
- export const wasmbip32_derive_hardened: (a: number, b: number, c: number) => void;
39
- export const wasmbip32_derive_path: (a: number, b: number, c: number, d: number) => void;
40
- export const wasmbip32_equals: (a: number, b: number) => number;
41
- export const wasmbip32_fingerprint: (a: number) => number;
42
- export const wasmbip32_from_base58: (a: number, b: number, c: number) => void;
43
- export const wasmbip32_from_bip32_interface: (a: number, b: number) => void;
44
- export const wasmbip32_from_seed: (a: number, b: number, c: number, d: number, e: number) => void;
45
- export const wasmbip32_from_seed_sha256: (a: number, b: number, c: number, d: number, e: number) => void;
46
- export const wasmbip32_from_xprv: (a: number, b: number, c: number) => void;
47
- export const wasmbip32_from_xpub: (a: number, b: number, c: number) => void;
48
- export const wasmbip32_identifier: (a: number) => number;
49
- export const wasmbip32_index: (a: number) => number;
50
- export const wasmbip32_is_neutered: (a: number) => number;
51
- export const wasmbip32_neutered: (a: number) => number;
52
- export const wasmbip32_parent_fingerprint: (a: number) => number;
53
- export const wasmbip32_private_key: (a: number) => number;
54
- export const wasmbip32_public_key: (a: number) => number;
55
- export const wasmbip32_to_base58: (a: number, b: number) => void;
56
- export const wasmbip32_to_wif: (a: number, b: number) => void;
57
- export const wasmdashtransaction_from_bytes: (a: number, b: number, c: number) => void;
58
- export const wasmdashtransaction_get_inputs: (a: number, b: number) => void;
59
- export const wasmdashtransaction_get_outputs: (a: number, b: number) => void;
60
- export const wasmdashtransaction_get_outputs_with_address: (a: number, b: number, c: number, d: number) => void;
61
- export const wasmdashtransaction_get_txid: (a: number, b: number) => void;
62
- export const wasmdashtransaction_input_count: (a: number) => number;
63
- export const wasmdashtransaction_lock_time: (a: number) => number;
64
- export const wasmdashtransaction_output_count: (a: number) => number;
65
- export const wasmdashtransaction_to_bytes: (a: number, b: number) => void;
66
- export const wasmdashtransaction_version: (a: number) => number;
67
- export const wasmecpair_from_private_key: (a: number, b: number, c: number) => void;
68
- export const wasmecpair_from_public_key: (a: number, b: number, c: number) => void;
69
- export const wasmecpair_from_wif: (a: number, b: number, c: number) => void;
70
- export const wasmecpair_from_wif_mainnet: (a: number, b: number, c: number) => void;
71
- export const wasmecpair_from_wif_testnet: (a: number, b: number, c: number) => void;
72
- export const wasmecpair_private_key: (a: number) => number;
73
- export const wasmecpair_public_key: (a: number) => number;
74
- export const wasmecpair_to_wif: (a: number, b: number) => void;
75
- export const wasmecpair_to_wif_mainnet: (a: number, b: number) => void;
76
- export const wasmecpair_to_wif_testnet: (a: number, b: number) => void;
77
- export const wasmtransaction_add_input: (a: number, b: number, c: number, d: number, e: number, f: number) => void;
78
- export const wasmtransaction_add_input_at_index: (a: number, b: number, c: number, d: number, e: number, f: number, g: number) => void;
79
- export const wasmtransaction_add_output: (a: number, b: number, c: number, d: bigint) => number;
80
- export const wasmtransaction_add_output_at_index: (a: number, b: number, c: number, d: number, e: number, f: bigint) => void;
81
- export const wasmtransaction_create: () => number;
82
- export const wasmtransaction_from_bytes: (a: number, b: number, c: number) => void;
83
- export const wasmtransaction_get_inputs: (a: number, b: number) => void;
84
- export const wasmtransaction_get_outputs: (a: number, b: number) => void;
85
- export const wasmtransaction_get_outputs_with_address: (a: number, b: number, c: number, d: number) => void;
86
- export const wasmtransaction_get_txid: (a: number, b: number) => void;
87
- export const wasmtransaction_get_vsize: (a: number) => number;
88
- export const wasmtransaction_to_bytes: (a: number, b: number) => void;
89
- export const wasmzcashtransaction_from_bytes: (a: number, b: number, c: number) => void;
90
- export const wasmzcashtransaction_get_inputs: (a: number, b: number) => void;
91
- export const wasmzcashtransaction_get_outputs: (a: number, b: number) => void;
92
- export const wasmzcashtransaction_get_outputs_with_address: (a: number, b: number, c: number, d: number) => void;
93
- export const wasmzcashtransaction_get_txid: (a: number, b: number) => void;
94
- export const wasmzcashtransaction_to_bytes: (a: number, b: number) => void;
95
- export const wrappsbt_add_input: (a: number, b: number, c: number, d: number, e: number, f: bigint, g: number, h: number, i: number) => void;
96
- export const wrappsbt_add_input_at_index: (a: number, b: number, c: number, d: number, e: number, f: number, g: bigint, h: number, i: number, j: number) => void;
97
- export const wrappsbt_add_output: (a: number, b: number, c: number, d: bigint) => number;
98
- export const wrappsbt_add_output_at_index: (a: number, b: number, c: number, d: number, e: number, f: bigint) => void;
99
- export const wrappsbt_clone: (a: number) => number;
100
- export const wrappsbt_deserialize: (a: number, b: number, c: number) => void;
101
- export const wrappsbt_extract_transaction: (a: number, b: number) => void;
102
- export const wrappsbt_finalize_mut: (a: number, b: number) => void;
103
- export const wrappsbt_get_global_xpubs: (a: number) => number;
104
- export const wrappsbt_get_input_kv: (a: number, b: number, c: number, d: number) => void;
105
- export const wrappsbt_get_inputs: (a: number, b: number) => void;
106
- export const wrappsbt_get_kv: (a: number, b: number, c: number) => void;
107
- export const wrappsbt_get_output_kv: (a: number, b: number, c: number, d: number) => void;
108
- export const wrappsbt_get_outputs: (a: number, b: number) => void;
109
- export const wrappsbt_get_outputs_with_address: (a: number, b: number, c: number, d: number) => void;
110
- export const wrappsbt_get_partial_signatures: (a: number, b: number, c: number) => void;
111
- export const wrappsbt_get_unsigned_tx: (a: number, b: number) => void;
112
- export const wrappsbt_has_partial_signatures: (a: number, b: number, c: number) => void;
113
- export const wrappsbt_input_count: (a: number) => number;
114
- export const wrappsbt_new: (a: number, b: number) => number;
115
- export const wrappsbt_output_count: (a: number) => number;
116
- export const wrappsbt_remove_input: (a: number, b: number, c: number) => void;
117
- export const wrappsbt_remove_output: (a: number, b: number, c: number) => void;
118
- export const wrappsbt_serialize: (a: number, b: number) => void;
119
- export const wrappsbt_set_input_kv: (a: number, b: number, c: number, d: number, e: number, f: number) => void;
120
- export const wrappsbt_set_kv: (a: number, b: number, c: number, d: number, e: number) => void;
121
- export const wrappsbt_set_output_kv: (a: number, b: number, c: number, d: number, e: number, f: number) => void;
122
- export const wrappsbt_sign_all: (a: number, b: number, c: number) => void;
123
- export const wrappsbt_sign_all_with_ecpair: (a: number, b: number, c: number) => void;
124
- export const wrappsbt_sign_with_prv: (a: number, b: number, c: number, d: number) => void;
125
- export const wrappsbt_sign_with_xprv: (a: number, b: number, c: number, d: number) => void;
126
- export const wrappsbt_unsigned_tx_id: (a: number, b: number) => void;
127
- export const wrappsbt_update_input_with_descriptor: (a: number, b: number, c: number, d: number) => void;
128
- export const wrappsbt_update_output_with_descriptor: (a: number, b: number, c: number, d: number) => void;
129
- export const wrappsbt_validate_signature_at_input: (a: number, b: number, c: number, d: number, e: number) => void;
130
- export const wrappsbt_verify_signature_with_key: (a: number, b: number, c: number, d: number) => void;
131
- export const wasmbip32_from_bip32_properties: (a: number, b: number) => void;
132
- export const wasmtransaction_input_count: (a: number) => number;
133
- export const wasmtransaction_output_count: (a: number) => number;
134
- export const wasmzcashtransaction_input_count: (a: number) => number;
135
- export const wasmzcashtransaction_output_count: (a: number) => number;
136
- export const wasmtransaction_lock_time: (a: number) => number;
137
- export const wasmtransaction_version: (a: number) => number;
138
- export const wasmzcashtransaction_lock_time: (a: number) => number;
139
- export const wasmzcashtransaction_version: (a: number) => number;
140
- export const wrappsbt_lock_time: (a: number) => number;
141
- export const wrappsbt_version: (a: number) => number;
142
4
  export const __wbg_bip322namespace_free: (a: number, b: number) => void;
143
5
  export const __wbg_bitgopsbt_free: (a: number, b: number) => void;
144
6
  export const __wbg_fixedscriptwalletnamespace_free: (a: number, b: number) => void;
145
- export const __wbg_messagenamespace_free: (a: number, b: number) => void;
146
- export const __wbg_utxolibcompatnamespace_free: (a: number, b: number) => void;
147
- export const __wbg_wasmdimensions_free: (a: number, b: number) => void;
148
- export const __wbg_wasmutxonamespace_free: (a: number, b: number) => void;
7
+ export const __wbg_inscriptionsnamespace_free: (a: number, b: number) => void;
8
+ export const __wbg_wasmbip32_free: (a: number, b: number) => void;
149
9
  export const bip322namespace_add_bip322_input: (a: number, b: number, c: number, d: number, e: number, f: number, g: number, h: number, i: number, j: number, k: number, l: number, m: number) => void;
150
10
  export const bip322namespace_get_bip322_message: (a: number, b: number, c: number) => void;
151
11
  export const bip322namespace_verify_bip322_psbt_input: (a: number, b: number, c: number, d: number, e: number, f: number, g: number, h: number, i: number, j: number) => void;
@@ -169,6 +29,9 @@ export const bitgopsbt_combine_musig2_nonces: (a: number, b: number, c: number)
169
29
  export const bitgopsbt_create_empty: (a: number, b: number, c: number, d: number, e: number, f: number) => void;
170
30
  export const bitgopsbt_create_empty_zcash: (a: number, b: number, c: number, d: number, e: number, f: number, g: number, h: number, i: number) => void;
171
31
  export const bitgopsbt_create_empty_zcash_at_height: (a: number, b: number, c: number, d: number, e: number, f: number, g: number, h: number, i: number) => void;
32
+ export const bitgopsbt_delete_input_kv: (a: number, b: number, c: number, d: number) => void;
33
+ export const bitgopsbt_delete_kv: (a: number, b: number, c: number) => void;
34
+ export const bitgopsbt_delete_output_kv: (a: number, b: number, c: number, d: number) => void;
172
35
  export const bitgopsbt_expiry_height: (a: number) => number;
173
36
  export const bitgopsbt_extract_bitcoin_transaction: (a: number, b: number) => void;
174
37
  export const bitgopsbt_extract_dash_transaction: (a: number, b: number) => void;
@@ -177,7 +40,10 @@ export const bitgopsbt_extract_transaction: (a: number, b: number) => void;
177
40
  export const bitgopsbt_extract_zcash_transaction: (a: number, b: number) => void;
178
41
  export const bitgopsbt_finalize_all_inputs: (a: number, b: number) => void;
179
42
  export const bitgopsbt_from_bytes: (a: number, b: number, c: number, d: number, e: number) => void;
180
- export const bitgopsbt_from_half_signed_legacy_transaction: (a: number, b: number, c: number, d: number, e: number, f: number, g: number) => void;
43
+ export const bitgopsbt_from_half_signed_legacy_transaction: (a: number, b: number, c: number, d: number, e: number, f: number) => void;
44
+ export const bitgopsbt_from_half_signed_legacy_transaction_dash: (a: number, b: number, c: number, d: number, e: number, f: number) => void;
45
+ export const bitgopsbt_from_half_signed_legacy_transaction_zcash_with_block_height: (a: number, b: number, c: number, d: number, e: number, f: number, g: number) => void;
46
+ export const bitgopsbt_from_half_signed_legacy_transaction_zcash_with_branch_id: (a: number, b: number, c: number, d: number, e: number, f: number, g: number) => void;
181
47
  export const bitgopsbt_generate_musig2_nonces: (a: number, b: number, c: number, d: number, e: number) => void;
182
48
  export const bitgopsbt_get_global_xpubs: (a: number) => number;
183
49
  export const bitgopsbt_get_input_kv: (a: number, b: number, c: number, d: number) => void;
@@ -224,12 +90,101 @@ export const fixedscriptwalletnamespace_output_script_with_network_str: (a: numb
224
90
  export const fixedscriptwalletnamespace_p2sh_p2pk_output_script: (a: number, b: number, c: number) => void;
225
91
  export const fixedscriptwalletnamespace_supports_script_type: (a: number, b: number, c: number, d: number, e: number) => void;
226
92
  export const fixedscriptwalletnamespace_to_wallet_keys: (a: number, b: number, c: number, d: number, e: number) => void;
227
- export const isInspectEnabled: () => number;
93
+ export const inscriptionsnamespace_create_inscription_reveal_data: (a: number, b: number, c: number, d: number, e: number, f: number, g: number) => void;
94
+ export const inscriptionsnamespace_sign_reveal_transaction: (a: number, b: number, c: number, d: number, e: number, f: number, g: number, h: number, i: number, j: bigint) => void;
95
+ export const wasmbip32_chain_code: (a: number) => number;
96
+ export const wasmbip32_depth: (a: number) => number;
97
+ export const wasmbip32_derive: (a: number, b: number, c: number) => void;
98
+ export const wasmbip32_derive_hardened: (a: number, b: number, c: number) => void;
99
+ export const wasmbip32_derive_path: (a: number, b: number, c: number, d: number) => void;
100
+ export const wasmbip32_equals: (a: number, b: number) => number;
101
+ export const wasmbip32_fingerprint: (a: number) => number;
102
+ export const wasmbip32_from_base58: (a: number, b: number, c: number) => void;
103
+ export const wasmbip32_from_bip32_interface: (a: number, b: number) => void;
104
+ export const wasmbip32_from_seed: (a: number, b: number, c: number, d: number, e: number) => void;
105
+ export const wasmbip32_from_seed_sha256: (a: number, b: number, c: number, d: number, e: number) => void;
106
+ export const wasmbip32_from_xprv: (a: number, b: number, c: number) => void;
107
+ export const wasmbip32_from_xpub: (a: number, b: number, c: number) => void;
108
+ export const wasmbip32_identifier: (a: number) => number;
109
+ export const wasmbip32_index: (a: number) => number;
110
+ export const wasmbip32_is_neutered: (a: number) => number;
111
+ export const wasmbip32_neutered: (a: number) => number;
112
+ export const wasmbip32_parent_fingerprint: (a: number) => number;
113
+ export const wasmbip32_private_key: (a: number) => number;
114
+ export const wasmbip32_public_key: (a: number) => number;
115
+ export const wasmbip32_to_base58: (a: number, b: number) => void;
116
+ export const wasmbip32_to_wif: (a: number, b: number) => void;
117
+ export const wasmbip32_from_bip32_properties: (a: number, b: number) => void;
118
+ export const bitgopsbt_sign_wallet_input: (a: number, b: number, c: number, d: number) => void;
119
+ export const bitgopsbt_sign_all_with_xpriv: (a: number, b: number, c: number) => void;
120
+ export const bitgopsbt_sign_replay_protection_inputs: (a: number, b: number, c: number) => void;
121
+ export const __wbg_wrapdescriptor_free: (a: number, b: number) => void;
122
+ export const __wbg_wrapminiscript_free: (a: number, b: number) => void;
123
+ export const wrapdescriptor_atDerivationIndex: (a: number, b: number, c: number) => void;
124
+ export const wrapdescriptor_descType: (a: number, b: number) => void;
125
+ export const wrapdescriptor_encode: (a: number, b: number) => void;
126
+ export const wrapdescriptor_fromString: (a: number, b: number, c: number, d: number, e: number) => void;
127
+ export const wrapdescriptor_fromStringDetectType: (a: number, b: number, c: number) => void;
128
+ export const wrapdescriptor_hasWildcard: (a: number) => number;
129
+ export const wrapdescriptor_maxWeightToSatisfy: (a: number, b: number) => void;
130
+ export const wrapdescriptor_node: (a: number, b: number) => void;
131
+ export const wrapdescriptor_scriptPubkey: (a: number, b: number) => void;
132
+ export const wrapdescriptor_toAsmString: (a: number, b: number) => void;
133
+ export const wrapdescriptor_toString: (a: number, b: number) => void;
134
+ export const wrapminiscript_encode: (a: number, b: number) => void;
135
+ export const wrapminiscript_fromBitcoinScript: (a: number, b: number, c: number, d: number, e: number) => void;
136
+ export const wrapminiscript_fromString: (a: number, b: number, c: number, d: number, e: number) => void;
137
+ export const wrapminiscript_node: (a: number, b: number) => void;
138
+ export const wrapminiscript_toAsmString: (a: number, b: number) => void;
139
+ export const wrapminiscript_toString: (a: number, b: number) => void;
140
+ export const __wbg_messagenamespace_free: (a: number, b: number) => void;
141
+ export const __wbg_wasmecpair_free: (a: number, b: number) => void;
142
+ export const __wbg_wasmreplayprotection_free: (a: number, b: number) => void;
143
+ export const __wbg_wasmrootwalletkeys_free: (a: number, b: number) => void;
228
144
  export const messagenamespace_sign_message: (a: number, b: number, c: number, d: number) => void;
229
145
  export const messagenamespace_verify_message: (a: number, b: number, c: number, d: number, e: number, f: number) => void;
146
+ export const wasmecpair_from_private_key: (a: number, b: number, c: number) => void;
147
+ export const wasmecpair_from_public_key: (a: number, b: number, c: number) => void;
148
+ export const wasmecpair_from_wif: (a: number, b: number, c: number) => void;
149
+ export const wasmecpair_from_wif_mainnet: (a: number, b: number, c: number) => void;
150
+ export const wasmecpair_from_wif_testnet: (a: number, b: number, c: number) => void;
151
+ export const wasmecpair_private_key: (a: number) => number;
152
+ export const wasmecpair_public_key: (a: number) => number;
153
+ export const wasmecpair_to_wif: (a: number, b: number) => void;
154
+ export const wasmecpair_to_wif_mainnet: (a: number, b: number) => void;
155
+ export const wasmecpair_to_wif_testnet: (a: number, b: number) => void;
156
+ export const wasmreplayprotection_from_addresses: (a: number, b: number, c: number, d: number, e: number) => void;
157
+ export const wasmreplayprotection_from_output_scripts: (a: number, b: number) => number;
158
+ export const wasmreplayprotection_from_public_keys: (a: number, b: number, c: number) => void;
159
+ export const wasmrootwalletkeys_backup_key: (a: number) => number;
160
+ export const wasmrootwalletkeys_bitgo_key: (a: number) => number;
161
+ export const wasmrootwalletkeys_new: (a: number, b: number, c: number, d: number) => void;
162
+ export const wasmrootwalletkeys_user_key: (a: number) => number;
163
+ export const wasmrootwalletkeys_with_derivation_prefixes: (a: number, b: number, c: number, d: number, e: number, f: number, g: number, h: number, i: number, j: number) => void;
164
+ export const __wbg_addressnamespace_free: (a: number, b: number) => void;
165
+ export const __wbg_utxolibcompatnamespace_free: (a: number, b: number) => void;
166
+ export const __wbg_wasmdashtransaction_free: (a: number, b: number) => void;
167
+ export const __wbg_wasmdimensions_free: (a: number, b: number) => void;
168
+ export const __wbg_wasmtransaction_free: (a: number, b: number) => void;
169
+ export const __wbg_wasmutxonamespace_free: (a: number, b: number) => void;
170
+ export const __wbg_wasmzcashtransaction_free: (a: number, b: number) => void;
171
+ export const __wbg_wrappsbt_free: (a: number, b: number) => void;
172
+ export const addressnamespace_from_output_script_with_coin: (a: number, b: number, c: number, d: number, e: number, f: number, g: number) => void;
173
+ export const addressnamespace_to_output_script_with_coin: (a: number, b: number, c: number, d: number, e: number) => void;
174
+ export const isInspectEnabled: () => number;
230
175
  export const parsePsbtRawToJson: (a: number, b: number, c: number, d: number, e: number) => void;
231
176
  export const utxolibcompatnamespace_from_output_script: (a: number, b: number, c: number, d: number, e: number, f: number) => void;
232
177
  export const utxolibcompatnamespace_to_output_script: (a: number, b: number, c: number, d: number, e: number, f: number) => void;
178
+ export const wasmdashtransaction_from_bytes: (a: number, b: number, c: number) => void;
179
+ export const wasmdashtransaction_get_inputs: (a: number, b: number) => void;
180
+ export const wasmdashtransaction_get_outputs: (a: number, b: number) => void;
181
+ export const wasmdashtransaction_get_outputs_with_address: (a: number, b: number, c: number, d: number) => void;
182
+ export const wasmdashtransaction_get_txid: (a: number, b: number) => void;
183
+ export const wasmdashtransaction_input_count: (a: number) => number;
184
+ export const wasmdashtransaction_lock_time: (a: number) => number;
185
+ export const wasmdashtransaction_output_count: (a: number) => number;
186
+ export const wasmdashtransaction_to_bytes: (a: number, b: number) => void;
187
+ export const wasmdashtransaction_version: (a: number) => number;
233
188
  export const wasmdimensions_empty: () => number;
234
189
  export const wasmdimensions_from_input: (a: number, b: number, c: number, d: number, e: number, f: number, g: number) => void;
235
190
  export const wasmdimensions_from_input_script_type: (a: number, b: number, c: number, d: number) => void;
@@ -245,22 +200,76 @@ export const wasmdimensions_get_weight: (a: number, b: number, c: number) => num
245
200
  export const wasmdimensions_has_segwit: (a: number) => number;
246
201
  export const wasmdimensions_plus: (a: number, b: number) => number;
247
202
  export const wasmdimensions_times: (a: number, b: number) => number;
203
+ export const wasmtransaction_add_input: (a: number, b: number, c: number, d: number, e: number, f: number) => void;
204
+ export const wasmtransaction_add_input_at_index: (a: number, b: number, c: number, d: number, e: number, f: number, g: number) => void;
205
+ export const wasmtransaction_add_output: (a: number, b: number, c: number, d: bigint) => number;
206
+ export const wasmtransaction_add_output_at_index: (a: number, b: number, c: number, d: number, e: number, f: bigint) => void;
207
+ export const wasmtransaction_create: () => number;
208
+ export const wasmtransaction_from_bytes: (a: number, b: number, c: number) => void;
209
+ export const wasmtransaction_get_inputs: (a: number, b: number) => void;
210
+ export const wasmtransaction_get_outputs: (a: number, b: number) => void;
211
+ export const wasmtransaction_get_outputs_with_address: (a: number, b: number, c: number, d: number) => void;
212
+ export const wasmtransaction_get_txid: (a: number, b: number) => void;
213
+ export const wasmtransaction_get_vsize: (a: number) => number;
214
+ export const wasmtransaction_to_bytes: (a: number, b: number) => void;
248
215
  export const wasmutxonamespace_get_wasm_utxo_version: (a: number) => void;
249
- export const bitgopsbt_sign_all_with_xpriv: (a: number, b: number, c: number) => void;
216
+ export const wasmzcashtransaction_from_bytes: (a: number, b: number, c: number) => void;
217
+ export const wasmzcashtransaction_get_inputs: (a: number, b: number) => void;
218
+ export const wasmzcashtransaction_get_outputs: (a: number, b: number) => void;
219
+ export const wasmzcashtransaction_get_outputs_with_address: (a: number, b: number, c: number, d: number) => void;
220
+ export const wasmzcashtransaction_get_txid: (a: number, b: number) => void;
221
+ export const wasmzcashtransaction_to_bytes: (a: number, b: number) => void;
222
+ export const wrappsbt_add_input: (a: number, b: number, c: number, d: number, e: number, f: bigint, g: number, h: number, i: number) => void;
223
+ export const wrappsbt_add_input_at_index: (a: number, b: number, c: number, d: number, e: number, f: number, g: bigint, h: number, i: number, j: number) => void;
224
+ export const wrappsbt_add_output: (a: number, b: number, c: number, d: bigint) => number;
225
+ export const wrappsbt_add_output_at_index: (a: number, b: number, c: number, d: number, e: number, f: bigint) => void;
226
+ export const wrappsbt_clone: (a: number) => number;
227
+ export const wrappsbt_delete_input_kv: (a: number, b: number, c: number, d: number) => void;
228
+ export const wrappsbt_delete_kv: (a: number, b: number, c: number) => void;
229
+ export const wrappsbt_delete_output_kv: (a: number, b: number, c: number, d: number) => void;
230
+ export const wrappsbt_deserialize: (a: number, b: number, c: number) => void;
231
+ export const wrappsbt_extract_transaction: (a: number, b: number) => void;
232
+ export const wrappsbt_finalize_mut: (a: number, b: number) => void;
233
+ export const wrappsbt_get_global_xpubs: (a: number) => number;
234
+ export const wrappsbt_get_input_kv: (a: number, b: number, c: number, d: number) => void;
235
+ export const wrappsbt_get_inputs: (a: number, b: number) => void;
236
+ export const wrappsbt_get_kv: (a: number, b: number, c: number) => void;
237
+ export const wrappsbt_get_output_kv: (a: number, b: number, c: number, d: number) => void;
238
+ export const wrappsbt_get_outputs: (a: number, b: number) => void;
239
+ export const wrappsbt_get_outputs_with_address: (a: number, b: number, c: number, d: number) => void;
240
+ export const wrappsbt_get_partial_signatures: (a: number, b: number, c: number) => void;
241
+ export const wrappsbt_get_unsigned_tx: (a: number, b: number) => void;
242
+ export const wrappsbt_has_partial_signatures: (a: number, b: number, c: number) => void;
243
+ export const wrappsbt_input_count: (a: number) => number;
244
+ export const wrappsbt_new: (a: number, b: number) => number;
245
+ export const wrappsbt_output_count: (a: number) => number;
246
+ export const wrappsbt_remove_input: (a: number, b: number, c: number) => void;
247
+ export const wrappsbt_remove_output: (a: number, b: number, c: number) => void;
248
+ export const wrappsbt_serialize: (a: number, b: number) => void;
249
+ export const wrappsbt_set_input_kv: (a: number, b: number, c: number, d: number, e: number, f: number) => void;
250
+ export const wrappsbt_set_kv: (a: number, b: number, c: number, d: number, e: number) => void;
251
+ export const wrappsbt_set_output_kv: (a: number, b: number, c: number, d: number, e: number, f: number) => void;
252
+ export const wrappsbt_sign_all: (a: number, b: number, c: number) => void;
253
+ export const wrappsbt_sign_all_with_ecpair: (a: number, b: number, c: number) => void;
254
+ export const wrappsbt_sign_with_prv: (a: number, b: number, c: number, d: number) => void;
255
+ export const wrappsbt_sign_with_xprv: (a: number, b: number, c: number, d: number) => void;
256
+ export const wrappsbt_unsigned_tx_id: (a: number, b: number) => void;
257
+ export const wrappsbt_update_input_with_descriptor: (a: number, b: number, c: number, d: number) => void;
258
+ export const wrappsbt_update_output_with_descriptor: (a: number, b: number, c: number, d: number) => void;
259
+ export const wrappsbt_validate_signature_at_input: (a: number, b: number, c: number, d: number, e: number) => void;
260
+ export const wrappsbt_verify_signature_with_key: (a: number, b: number, c: number, d: number) => void;
261
+ export const wasmtransaction_input_count: (a: number) => number;
262
+ export const wasmtransaction_output_count: (a: number) => number;
263
+ export const wasmzcashtransaction_input_count: (a: number) => number;
264
+ export const wasmzcashtransaction_output_count: (a: number) => number;
250
265
  export const parsePsbtToJson: (a: number, b: number, c: number, d: number, e: number) => void;
251
266
  export const parseTxToJson: (a: number, b: number, c: number, d: number, e: number) => void;
252
- export const bitgopsbt_sign_wallet_input: (a: number, b: number, c: number, d: number) => void;
253
- export const bitgopsbt_sign_replay_protection_inputs: (a: number, b: number, c: number) => void;
254
- export const __wbg_wasmreplayprotection_free: (a: number, b: number) => void;
255
- export const __wbg_wasmrootwalletkeys_free: (a: number, b: number) => void;
256
- export const wasmreplayprotection_from_addresses: (a: number, b: number, c: number, d: number, e: number) => void;
257
- export const wasmreplayprotection_from_output_scripts: (a: number, b: number) => number;
258
- export const wasmreplayprotection_from_public_keys: (a: number, b: number, c: number) => void;
259
- export const wasmrootwalletkeys_backup_key: (a: number) => number;
260
- export const wasmrootwalletkeys_bitgo_key: (a: number) => number;
261
- export const wasmrootwalletkeys_new: (a: number, b: number, c: number, d: number) => void;
262
- export const wasmrootwalletkeys_user_key: (a: number) => number;
263
- export const wasmrootwalletkeys_with_derivation_prefixes: (a: number, b: number, c: number, d: number, e: number, f: number, g: number, h: number, i: number, j: number) => void;
267
+ export const wasmtransaction_lock_time: (a: number) => number;
268
+ export const wasmtransaction_version: (a: number) => number;
269
+ export const wasmzcashtransaction_lock_time: (a: number) => number;
270
+ export const wasmzcashtransaction_version: (a: number) => number;
271
+ export const wrappsbt_lock_time: (a: number) => number;
272
+ export const wrappsbt_version: (a: number) => number;
264
273
  export const rustsecp256k1_v0_10_0_context_create: (a: number) => number;
265
274
  export const rustsecp256k1_v0_10_0_context_destroy: (a: number) => void;
266
275
  export const rustsecp256k1_v0_10_0_default_error_callback_fn: (a: number, b: number) => void;
@@ -8,7 +8,7 @@ import { type ECPairArg } from "../ecpair.js";
8
8
  import type { UtxolibName } from "../utxolibCompat.js";
9
9
  import type { CoinName } from "../coinName.js";
10
10
  import type { InputScriptType } from "./scriptType.js";
11
- import { type ITransaction } from "../transaction.js";
11
+ import { Transaction, DashTransaction, type ITransaction } from "../transaction.js";
12
12
  export type { InputScriptType };
13
13
  export type NetworkName = UtxolibName | CoinName;
14
14
  export type ScriptId = {
@@ -151,12 +151,17 @@ export declare class BitGoPsbt extends PsbtBase<WasmBitGoPsbt> implements IPsbtW
151
151
  * with proper wallet metadata (bip32Derivation, scripts, witnessUtxo).
152
152
  * Only supports p2sh, p2shP2wsh, and p2wsh inputs (not taproot).
153
153
  *
154
- * @param txBytes - The serialized half-signed legacy transaction
154
+ * Supports both Bitcoin-like coins (BTC, LTC, DOGE) and Dash (DASH).
155
+ * Zcash is NOT supported; use ZcashBitGoPsbt.fromHalfSignedLegacyTransaction instead.
156
+ *
157
+ * @param txBytesOrTx - Transaction bytes or decoded transaction instance (Bitcoin-like or Dash)
155
158
  * @param network - Network name
156
159
  * @param walletKeys - The wallet's root keys
157
160
  * @param unspents - Chain, index, and value for each input
161
+ * @param _options - Reserved for future use and signature compatibility with subclasses
162
+ * @throws Error if transaction is Zcash (use ZcashBitGoPsbt.fromHalfSignedLegacyTransaction instead)
158
163
  */
159
- static fromHalfSignedLegacyTransaction(txBytes: Uint8Array, network: NetworkName, walletKeys: WalletKeysArg, unspents: HydrationUnspent[]): BitGoPsbt;
164
+ static fromHalfSignedLegacyTransaction(txBytesOrTx: Uint8Array | Transaction | DashTransaction, network: NetworkName, walletKeys: WalletKeysArg, unspents: HydrationUnspent[], _options?: unknown): BitGoPsbt;
160
165
  /**
161
166
  * Add an input to the PSBT
162
167
  *
@@ -4,6 +4,7 @@ import { RootWalletKeys } from "./RootWalletKeys.js";
4
4
  import { ReplayProtection } from "./ReplayProtection.js";
5
5
  import { BIP32, isBIP32Arg } from "../bip32.js";
6
6
  import { ECPair } from "../ecpair.js";
7
+ import { toCoinName } from "../coinName.js";
7
8
  import { Transaction, DashTransaction, ZcashTransaction, } from "../transaction.js";
8
9
  export class BitGoPsbt extends PsbtBase {
9
10
  constructor(wasm) {
@@ -60,14 +61,32 @@ export class BitGoPsbt extends PsbtBase {
60
61
  * with proper wallet metadata (bip32Derivation, scripts, witnessUtxo).
61
62
  * Only supports p2sh, p2shP2wsh, and p2wsh inputs (not taproot).
62
63
  *
63
- * @param txBytes - The serialized half-signed legacy transaction
64
+ * Supports both Bitcoin-like coins (BTC, LTC, DOGE) and Dash (DASH).
65
+ * Zcash is NOT supported; use ZcashBitGoPsbt.fromHalfSignedLegacyTransaction instead.
66
+ *
67
+ * @param txBytesOrTx - Transaction bytes or decoded transaction instance (Bitcoin-like or Dash)
64
68
  * @param network - Network name
65
69
  * @param walletKeys - The wallet's root keys
66
70
  * @param unspents - Chain, index, and value for each input
71
+ * @param _options - Reserved for future use and signature compatibility with subclasses
72
+ * @throws Error if transaction is Zcash (use ZcashBitGoPsbt.fromHalfSignedLegacyTransaction instead)
67
73
  */
68
- static fromHalfSignedLegacyTransaction(txBytes, network, walletKeys, unspents) {
74
+ static fromHalfSignedLegacyTransaction(txBytesOrTx, network, walletKeys, unspents,
75
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
76
+ _options) {
69
77
  const keys = RootWalletKeys.from(walletKeys);
70
- const wasm = WasmBitGoPsbt.from_half_signed_legacy_transaction(txBytes, network, keys.wasm, unspents);
78
+ // Parse bytes to Transaction if needed
79
+ const tx = txBytesOrTx instanceof Uint8Array
80
+ ? Transaction.fromBytes(txBytesOrTx, toCoinName(network))
81
+ : txBytesOrTx;
82
+ // Validate that this is not a Zcash transaction
83
+ if (tx instanceof ZcashTransaction) {
84
+ throw new Error("Use ZcashBitGoPsbt.fromHalfSignedLegacyTransaction() for Zcash transactions");
85
+ }
86
+ // Pass WASM transaction directly to avoid serialization round-trip
87
+ const wasm = tx instanceof DashTransaction
88
+ ? WasmBitGoPsbt.from_half_signed_legacy_transaction_dash(tx.wasm, network, keys.wasm, unspents)
89
+ : WasmBitGoPsbt.from_half_signed_legacy_transaction(tx.wasm, network, keys.wasm, unspents);
71
90
  return new BitGoPsbt(wasm);
72
91
  }
73
92
  addInputAtIndex(index, txidOrOptions, voutOrScript, value, script, sequence) {
@@ -1,6 +1,6 @@
1
1
  import { type WalletKeysArg } from "./RootWalletKeys.js";
2
- import { BitGoPsbt, type CreateEmptyOptions } from "./BitGoPsbt.js";
3
- import { ZcashTransaction } from "../transaction.js";
2
+ import { BitGoPsbt, type CreateEmptyOptions, type HydrationUnspent } from "./BitGoPsbt.js";
3
+ import { ZcashTransaction, type ITransaction } from "../transaction.js";
4
4
  /** Zcash network names */
5
5
  export type ZcashNetworkName = "zcash" | "zcashTest" | "zec" | "tzec";
6
6
  /** Options for creating an empty Zcash PSBT (preferred method using block height) */
@@ -101,6 +101,51 @@ export declare class ZcashBitGoPsbt extends BitGoPsbt {
101
101
  * @returns A ZcashBitGoPsbt instance
102
102
  */
103
103
  static fromBytes(bytes: Uint8Array, network: ZcashNetworkName): ZcashBitGoPsbt;
104
+ /**
105
+ * Reconstruct a Zcash PSBT from a half-signed legacy transaction
106
+ *
107
+ * This is the inverse of `getHalfSignedLegacyFormat()` for Zcash. It decodes the Zcash wire
108
+ * format (which includes version_group_id, expiry_height, and sapling fields), extracts
109
+ * partial signatures, and reconstructs a proper Zcash PSBT with consensus metadata.
110
+ *
111
+ * Supports two modes for determining consensus_branch_id:
112
+ * - **Recommended**: Pass `blockHeight` to auto-determine consensus_branch_id via network upgrade activation heights
113
+ * - **Advanced**: Pass `consensusBranchId` directly if you already know it (e.g., 0xC2D6D0B4 for NU5)
114
+ *
115
+ * @param txBytesOrTx - Either serialized Zcash transaction bytes or a decoded ZcashTransaction instance
116
+ * @param network - Zcash network name ("zcash", "zcashTest", "zec", "tzec")
117
+ * @param walletKeys - The wallet's root keys
118
+ * @param unspents - Chain, index, and value for each input
119
+ * @param options - Either `{ blockHeight: number }` or `{ consensusBranchId: number }`
120
+ * @returns A ZcashBitGoPsbt instance
121
+ *
122
+ * @example
123
+ * ```typescript
124
+ * // Round-trip with block height (recommended)
125
+ * const legacyBytes = psbt.getHalfSignedLegacyFormat();
126
+ * const reconstructed = ZcashBitGoPsbt.fromHalfSignedLegacyTransaction(
127
+ * legacyBytes,
128
+ * "zec",
129
+ * walletKeys,
130
+ * unspents,
131
+ * { blockHeight: 1687105 } // NU5 activation height
132
+ * );
133
+ *
134
+ * // Or with explicit consensus branch ID
135
+ * const reconstructed = ZcashBitGoPsbt.fromHalfSignedLegacyTransaction(
136
+ * legacyBytes,
137
+ * "zec",
138
+ * walletKeys,
139
+ * unspents,
140
+ * { consensusBranchId: 0xC2D6D0B4 } // NU5 branch ID
141
+ * );
142
+ * ```
143
+ */
144
+ static fromHalfSignedLegacyTransaction(txBytesOrTx: Uint8Array | ITransaction, network: ZcashNetworkName, walletKeys: WalletKeysArg, unspents: HydrationUnspent[], options: {
145
+ blockHeight: number;
146
+ } | {
147
+ consensusBranchId: number;
148
+ }): ZcashBitGoPsbt;
104
149
  /**
105
150
  * Get the Zcash version group ID
106
151
  * @returns The version group ID (e.g., 0x892F2085 for Sapling)
@@ -93,6 +93,60 @@ export class ZcashBitGoPsbt extends BitGoPsbt {
93
93
  const wasm = WasmBitGoPsbt.from_bytes(bytes, network);
94
94
  return new ZcashBitGoPsbt(wasm);
95
95
  }
96
+ /**
97
+ * Reconstruct a Zcash PSBT from a half-signed legacy transaction
98
+ *
99
+ * This is the inverse of `getHalfSignedLegacyFormat()` for Zcash. It decodes the Zcash wire
100
+ * format (which includes version_group_id, expiry_height, and sapling fields), extracts
101
+ * partial signatures, and reconstructs a proper Zcash PSBT with consensus metadata.
102
+ *
103
+ * Supports two modes for determining consensus_branch_id:
104
+ * - **Recommended**: Pass `blockHeight` to auto-determine consensus_branch_id via network upgrade activation heights
105
+ * - **Advanced**: Pass `consensusBranchId` directly if you already know it (e.g., 0xC2D6D0B4 for NU5)
106
+ *
107
+ * @param txBytesOrTx - Either serialized Zcash transaction bytes or a decoded ZcashTransaction instance
108
+ * @param network - Zcash network name ("zcash", "zcashTest", "zec", "tzec")
109
+ * @param walletKeys - The wallet's root keys
110
+ * @param unspents - Chain, index, and value for each input
111
+ * @param options - Either `{ blockHeight: number }` or `{ consensusBranchId: number }`
112
+ * @returns A ZcashBitGoPsbt instance
113
+ *
114
+ * @example
115
+ * ```typescript
116
+ * // Round-trip with block height (recommended)
117
+ * const legacyBytes = psbt.getHalfSignedLegacyFormat();
118
+ * const reconstructed = ZcashBitGoPsbt.fromHalfSignedLegacyTransaction(
119
+ * legacyBytes,
120
+ * "zec",
121
+ * walletKeys,
122
+ * unspents,
123
+ * { blockHeight: 1687105 } // NU5 activation height
124
+ * );
125
+ *
126
+ * // Or with explicit consensus branch ID
127
+ * const reconstructed = ZcashBitGoPsbt.fromHalfSignedLegacyTransaction(
128
+ * legacyBytes,
129
+ * "zec",
130
+ * walletKeys,
131
+ * unspents,
132
+ * { consensusBranchId: 0xC2D6D0B4 } // NU5 branch ID
133
+ * );
134
+ * ```
135
+ */
136
+ static fromHalfSignedLegacyTransaction(txBytesOrTx, network, walletKeys, unspents, options) {
137
+ const keys = RootWalletKeys.from(walletKeys);
138
+ const tx = txBytesOrTx instanceof Uint8Array
139
+ ? ZcashTransaction.fromBytes(txBytesOrTx)
140
+ : txBytesOrTx;
141
+ if ("blockHeight" in options) {
142
+ const wasm = WasmBitGoPsbt.from_half_signed_legacy_transaction_zcash_with_block_height(tx.wasm, network, keys.wasm, unspents, options.blockHeight);
143
+ return new ZcashBitGoPsbt(wasm);
144
+ }
145
+ else {
146
+ const wasm = WasmBitGoPsbt.from_half_signed_legacy_transaction_zcash_with_branch_id(tx.wasm, network, keys.wasm, unspents, options.consensusBranchId);
147
+ return new ZcashBitGoPsbt(wasm);
148
+ }
149
+ }
96
150
  // --- Zcash-specific getters ---
97
151
  /**
98
152
  * Get the Zcash version group ID
@@ -12,10 +12,13 @@ export interface IPsbt extends ITransactionCommon<PsbtInputData, PsbtOutputData>
12
12
  removeOutput(index: number): void;
13
13
  setKV(key: PsbtKvKey, value: Uint8Array): void;
14
14
  getKV(key: PsbtKvKey): Uint8Array | undefined;
15
+ deleteKV(key: PsbtKvKey): void;
15
16
  setInputKV(index: number, key: PsbtKvKey, value: Uint8Array): void;
16
17
  getInputKV(index: number, key: PsbtKvKey): Uint8Array | undefined;
18
+ deleteInputKV(index: number, key: PsbtKvKey): void;
17
19
  setOutputKV(index: number, key: PsbtKvKey, value: Uint8Array): void;
18
20
  getOutputKV(index: number, key: PsbtKvKey): Uint8Array | undefined;
21
+ deleteOutputKV(index: number, key: PsbtKvKey): void;
19
22
  }
20
23
  /** Extended PSBT with address resolution (no coin parameter needed) */
21
24
  export interface IPsbtWithAddress extends IPsbt {
@@ -15,10 +15,13 @@ interface WasmPsbtBase {
15
15
  remove_output(index: number): void;
16
16
  set_kv(key: unknown, value: Uint8Array): void;
17
17
  get_kv(key: unknown): Uint8Array | null | undefined;
18
+ delete_kv(key: unknown): void;
18
19
  set_input_kv(index: number, key: unknown, value: Uint8Array): void;
19
20
  get_input_kv(index: number, key: unknown): Uint8Array | null | undefined;
21
+ delete_input_kv(index: number, key: unknown): void;
20
22
  set_output_kv(index: number, key: unknown, value: Uint8Array): void;
21
23
  get_output_kv(index: number, key: unknown): Uint8Array | null | undefined;
24
+ delete_output_kv(index: number, key: unknown): void;
22
25
  }
23
26
  export declare abstract class PsbtBase<W extends WasmPsbtBase> {
24
27
  protected _wasm: W;
@@ -40,5 +43,8 @@ export declare abstract class PsbtBase<W extends WasmPsbtBase> {
40
43
  getInputKV(index: number, key: PsbtKvKey): Uint8Array | undefined;
41
44
  setOutputKV(index: number, key: PsbtKvKey, value: Uint8Array): void;
42
45
  getOutputKV(index: number, key: PsbtKvKey): Uint8Array | undefined;
46
+ deleteKV(key: PsbtKvKey): void;
47
+ deleteInputKV(index: number, key: PsbtKvKey): void;
48
+ deleteOutputKV(index: number, key: PsbtKvKey): void;
43
49
  }
44
50
  export {};
@@ -55,4 +55,13 @@ export class PsbtBase {
55
55
  getOutputKV(index, key) {
56
56
  return this._wasm.get_output_kv(index, key) ?? undefined;
57
57
  }
58
+ deleteKV(key) {
59
+ this._wasm.delete_kv(key);
60
+ }
61
+ deleteInputKV(index, key) {
62
+ this._wasm.delete_input_kv(index, key);
63
+ }
64
+ deleteOutputKV(index, key) {
65
+ this._wasm.delete_output_kv(index, key);
66
+ }
58
67
  }