@meshsdk/wallet 2.0.0-beta.3 → 2.0.0-beta.4
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/README.md +157 -128
- package/dist/index.cjs +10 -0
- package/dist/index.d.cts +13 -0
- package/dist/index.d.ts +13 -0
- package/dist/index.js +10 -0
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -1,48 +1,112 @@
|
|
|
1
|
-
#
|
|
1
|
+
# @meshsdk/wallet
|
|
2
2
|
|
|
3
|
-
|
|
3
|
+
Cardano wallet library for signing transactions, managing keys, and interacting with browser wallets. Provides both headless (server-side / Node.js) and browser wallet support with a CIP-30 compatible interface.
|
|
4
4
|
|
|
5
|
-
|
|
5
|
+
```bash
|
|
6
|
+
npm install @meshsdk/wallet
|
|
7
|
+
```
|
|
8
|
+
|
|
9
|
+
> **Migrating from v1 (`MeshWallet` or `BrowserWallet`)?** This version has breaking changes. See:
|
|
10
|
+
> - [`mesh-wallet-migration.md`](./mesh-wallet-migration.md) — for `MeshWallet` to `MeshCardanoHeadlessWallet`
|
|
11
|
+
> - [`browser-wallet-migration.md`](./browser-wallet-migration.md) — for `BrowserWallet` to `MeshCardanoBrowserWallet`
|
|
12
|
+
|
|
13
|
+
---
|
|
14
|
+
|
|
15
|
+
## Table of Contents
|
|
16
|
+
|
|
17
|
+
- [Architecture Overview](#architecture-overview)
|
|
18
|
+
- [Exported Classes](#exported-classes)
|
|
19
|
+
- [Headless Wallet (Server-Side)](#headless-wallet-server-side)
|
|
20
|
+
- [Browser Wallet (Client-Side)](#browser-wallet-client-side)
|
|
21
|
+
- [Low-Level Components](#low-level-components)
|
|
22
|
+
- [CIP-30 Compatibility](#cip-30-compatibility)
|
|
23
|
+
- [CardanoHeadlessWallet vs MeshCardanoHeadlessWallet](#cardanoheadlesswallet-vs-meshcardanoheadlesswallet)
|
|
24
|
+
- [Migration from v1](#migration-from-v1)
|
|
25
|
+
|
|
26
|
+
---
|
|
6
27
|
|
|
7
|
-
|
|
28
|
+
## Architecture Overview
|
|
8
29
|
|
|
9
|
-
|
|
30
|
+
This package uses a two-tier class hierarchy for both headless and browser wallets:
|
|
10
31
|
|
|
11
|
-
|
|
32
|
+
- **Base classes** (`CardanoHeadlessWallet`, `CardanoBrowserWallet`) implement the CIP-30 interface strictly — all methods return raw hex/CBOR exactly as CIP-30 specifies.
|
|
33
|
+
- **Mesh classes** (`MeshCardanoHeadlessWallet`, `MeshCardanoBrowserWallet`) extend the base classes with convenience methods (`*Bech32()`, `*Mesh()`, `signTxReturnFullTx()`) that return human-friendly formats.
|
|
12
34
|
|
|
13
|
-
|
|
35
|
+
**For most use cases, use the Mesh classes.** The base classes are for advanced users who need raw CIP-30 output.
|
|
14
36
|
|
|
15
|
-
|
|
37
|
+
---
|
|
38
|
+
|
|
39
|
+
## Exported Classes
|
|
40
|
+
|
|
41
|
+
| Class | Purpose | Use When |
|
|
42
|
+
|-------|---------|----------|
|
|
43
|
+
| `MeshCardanoHeadlessWallet` | Full-featured headless wallet with convenience methods | Server-side signing, backend transaction building, testing |
|
|
44
|
+
| `CardanoHeadlessWallet` | CIP-30 strict headless wallet (raw hex/CBOR returns) | You need raw CIP-30 output without conversion |
|
|
45
|
+
| `MeshCardanoBrowserWallet` | Full-featured browser wallet wrapper with convenience methods | dApp frontend integration with browser wallets (Eternl, Nami, etc.) |
|
|
46
|
+
| `CardanoBrowserWallet` | CIP-30 strict browser wallet wrapper (raw hex/CBOR returns) | You need raw CIP-30 passthrough from browser wallets |
|
|
47
|
+
| `InMemoryBip32` | BIP32 key derivation from mnemonic (keys stored in memory) | Deriving payment/stake/DRep keys from a mnemonic |
|
|
48
|
+
| `BaseSigner` | Ed25519 signer from raw private keys | Signing with raw private keys (normal or extended) |
|
|
49
|
+
| `CardanoAddress` | Cardano address construction and utilities | Building addresses from credentials |
|
|
50
|
+
| `ICardanoWallet` | Interface definition for Cardano wallets | Type-checking and implementing custom wallets |
|
|
51
|
+
|
|
52
|
+
---
|
|
53
|
+
|
|
54
|
+
## Headless Wallet (Server-Side)
|
|
55
|
+
|
|
56
|
+
### Create from Mnemonic
|
|
16
57
|
|
|
17
58
|
```typescript
|
|
59
|
+
import { MeshCardanoHeadlessWallet, AddressType } from "@meshsdk/wallet";
|
|
60
|
+
|
|
18
61
|
const wallet = await MeshCardanoHeadlessWallet.fromMnemonic({
|
|
19
|
-
mnemonic:
|
|
20
|
-
"globe cupboard camera aim congress cradle decorate enter fringe dove margin witness police coral junk genius harbor fire evolve climb rather broccoli post snack".split(
|
|
21
|
-
" "
|
|
22
|
-
),
|
|
62
|
+
mnemonic: "globe cupboard camera ...".split(" "),
|
|
23
63
|
networkId: 0,
|
|
24
64
|
walletAddressType: AddressType.Base,
|
|
25
65
|
fetcher: fetcher,
|
|
26
66
|
});
|
|
67
|
+
```
|
|
68
|
+
|
|
69
|
+
The `fetcher` is needed for signing transactions — the wallet uses it to look up input information to determine which keys need to sign. Without a fetcher, signing will not work.
|
|
70
|
+
|
|
71
|
+
### Create from Raw Private Key
|
|
27
72
|
|
|
28
|
-
|
|
73
|
+
```typescript
|
|
74
|
+
import { MeshCardanoHeadlessWallet, AddressType, BaseSigner } from "@meshsdk/wallet";
|
|
75
|
+
|
|
76
|
+
const paymentSigner = BaseSigner.fromNormalKeyHex(
|
|
77
|
+
"d4ffb1e83d44b66849b4f16183cbf2ba1358c491cfeb39f0b66b5f811a88f182"
|
|
78
|
+
);
|
|
79
|
+
|
|
80
|
+
const wallet = await MeshCardanoHeadlessWallet.fromCredentialSources({
|
|
81
|
+
networkId: 0,
|
|
82
|
+
walletAddressType: AddressType.Enterprise,
|
|
83
|
+
paymentCredentialSource: {
|
|
84
|
+
type: "signer",
|
|
85
|
+
signer: paymentSigner,
|
|
86
|
+
},
|
|
87
|
+
});
|
|
29
88
|
```
|
|
30
89
|
|
|
31
|
-
|
|
90
|
+
### Sign a Transaction
|
|
32
91
|
|
|
33
|
-
|
|
92
|
+
```typescript
|
|
93
|
+
// Returns the full signed transaction (ready to submit)
|
|
94
|
+
const signedTx = await wallet.signTxReturnFullTx(unsignedTxHex);
|
|
34
95
|
|
|
35
|
-
|
|
96
|
+
// Returns only the witness set CBOR (for partial signing workflows)
|
|
97
|
+
const witnessSet = await wallet.signTx(unsignedTxHex);
|
|
98
|
+
```
|
|
36
99
|
|
|
37
|
-
|
|
100
|
+
### Custom Derivation Paths
|
|
38
101
|
|
|
39
|
-
|
|
102
|
+
Use `InMemoryBip32` directly for custom key derivation:
|
|
40
103
|
|
|
41
104
|
```typescript
|
|
105
|
+
import { InMemoryBip32 } from "@meshsdk/wallet";
|
|
106
|
+
|
|
107
|
+
const HARDENED_OFFSET = 0x80000000;
|
|
42
108
|
const bip32 = await InMemoryBip32.fromMnemonic(
|
|
43
|
-
"globe cupboard camera
|
|
44
|
-
" "
|
|
45
|
-
)
|
|
109
|
+
"globe cupboard camera ...".split(" ")
|
|
46
110
|
);
|
|
47
111
|
|
|
48
112
|
const paymentSigner = await bip32.getSigner([
|
|
@@ -50,150 +114,115 @@ const paymentSigner = await bip32.getSigner([
|
|
|
50
114
|
1815 + HARDENED_OFFSET,
|
|
51
115
|
0 + HARDENED_OFFSET,
|
|
52
116
|
0,
|
|
53
|
-
|
|
117
|
+
5, // key index 5
|
|
54
118
|
]);
|
|
119
|
+
```
|
|
55
120
|
|
|
56
|
-
|
|
121
|
+
### Blind Signing with CardanoSigner
|
|
122
|
+
|
|
123
|
+
For signing without wallet-level input resolution:
|
|
124
|
+
|
|
125
|
+
```typescript
|
|
126
|
+
import { CardanoSigner } from "@meshsdk/wallet";
|
|
127
|
+
|
|
128
|
+
// Returns witness set CBOR
|
|
129
|
+
const txWitnessSet = CardanoSigner.signTx(txHex, [paymentSigner]);
|
|
130
|
+
|
|
131
|
+
// Returns full signed transaction CBOR
|
|
132
|
+
const signedTx = CardanoSigner.signTx(txHex, [paymentSigner], true);
|
|
57
133
|
```
|
|
58
134
|
|
|
59
|
-
|
|
135
|
+
---
|
|
60
136
|
|
|
61
|
-
|
|
137
|
+
## Browser Wallet (Client-Side)
|
|
62
138
|
|
|
63
|
-
|
|
139
|
+
### Enable a Browser Wallet
|
|
64
140
|
|
|
65
141
|
```typescript
|
|
66
|
-
|
|
142
|
+
import { MeshCardanoBrowserWallet } from "@meshsdk/wallet";
|
|
143
|
+
|
|
144
|
+
const wallet = await MeshCardanoBrowserWallet.enable("eternl");
|
|
67
145
|
```
|
|
68
146
|
|
|
69
|
-
|
|
147
|
+
### List Installed Wallets
|
|
70
148
|
|
|
71
149
|
```typescript
|
|
72
|
-
const
|
|
150
|
+
const wallets = MeshCardanoBrowserWallet.getInstalledWallets();
|
|
151
|
+
// Returns: Array<{ id, name, icon, version }>
|
|
73
152
|
```
|
|
74
153
|
|
|
75
|
-
|
|
154
|
+
### Common Operations
|
|
76
155
|
|
|
77
|
-
|
|
156
|
+
```typescript
|
|
157
|
+
const balance = await wallet.getBalanceMesh(); // Asset[]
|
|
158
|
+
const address = await wallet.getChangeAddressBech32(); // bech32 string
|
|
159
|
+
const utxos = await wallet.getUtxosMesh(); // UTxO[]
|
|
160
|
+
const collateral = await wallet.getCollateralMesh(); // UTxO[]
|
|
161
|
+
const networkId = await wallet.getNetworkId(); // number
|
|
162
|
+
const rewards = await wallet.getRewardAddressesBech32(); // string[]
|
|
163
|
+
|
|
164
|
+
// Sign and get the full transaction back (ready to submit)
|
|
165
|
+
const signedTx = await wallet.signTxReturnFullTx(unsignedTxHex, partialSign);
|
|
166
|
+
|
|
167
|
+
// Sign data
|
|
168
|
+
const signature = await wallet.signData(addressBech32, hexPayload);
|
|
169
|
+
```
|
|
78
170
|
|
|
79
|
-
|
|
171
|
+
---
|
|
80
172
|
|
|
81
|
-
|
|
173
|
+
## Low-Level Components
|
|
82
174
|
|
|
83
|
-
|
|
84
|
-
const paymentSigner = await bip32.getSigner([
|
|
85
|
-
1852 + HARDENED_OFFSET,
|
|
86
|
-
1815 + HARDENED_OFFSET,
|
|
87
|
-
0 + HARDENED_OFFSET,
|
|
88
|
-
0,
|
|
89
|
-
5,
|
|
90
|
-
]);
|
|
175
|
+
### InMemoryBip32
|
|
91
176
|
|
|
92
|
-
|
|
93
|
-
networkId: 0,
|
|
94
|
-
walletAddressType: AddressType.Enterprise,
|
|
95
|
-
paymentCredentialSource: {
|
|
96
|
-
type: "signer",
|
|
97
|
-
signer: paymentSigner,
|
|
98
|
-
},
|
|
99
|
-
});
|
|
100
|
-
```
|
|
177
|
+
Derives Ed25519 signing keys from a BIP39 mnemonic. Keys are held in memory. You can implement your own `Bip32` class (e.g., HSM-backed) as long as it satisfies the same interface.
|
|
101
178
|
|
|
102
|
-
|
|
179
|
+
### BaseSigner
|
|
103
180
|
|
|
104
|
-
|
|
181
|
+
Creates signers from raw Ed25519 private keys:
|
|
105
182
|
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
"d4ffb1e83d44b66849b4f16183cbf2ba1358c491cfeb39f0b66b5f811a88f182"
|
|
109
|
-
);
|
|
183
|
+
- `BaseSigner.fromNormalKeyHex(hex)` — from a 32-byte normal private key
|
|
184
|
+
- `BaseSigner.fromExtendedKeyHex(hex)` — from a 64-byte extended private key
|
|
110
185
|
|
|
111
|
-
|
|
112
|
-
networkId: 0,
|
|
113
|
-
walletAddressType: AddressType.Enterprise,
|
|
114
|
-
paymentCredentialSource: {
|
|
115
|
-
type: "signer",
|
|
116
|
-
signer: paymentSigner,
|
|
117
|
-
},
|
|
118
|
-
});
|
|
119
|
-
```
|
|
186
|
+
### CardanoSigner
|
|
120
187
|
|
|
121
|
-
|
|
188
|
+
Signs Cardano transactions given an array of `ISigner` instances. Can return either a witness set or the full signed transaction.
|
|
122
189
|
|
|
123
|
-
|
|
190
|
+
---
|
|
124
191
|
|
|
125
|
-
|
|
192
|
+
## CIP-30 Compatibility
|
|
126
193
|
|
|
127
|
-
`MeshCardanoHeadlessWallet`
|
|
194
|
+
Both `MeshCardanoHeadlessWallet` and `MeshCardanoBrowserWallet` provide CIP-30 compatible methods: `getBalance`, `getChangeAddress`, `getNetworkId`, `getCollateral`, `getUtxos`, `getRewardAddresses`, `signTx`, `signData`, `submitTx`.
|
|
128
195
|
|
|
129
|
-
|
|
196
|
+
**Important caveat for headless wallets:** The headless wallet simulates CIP-30 using a data provider (e.g., Blockfrost). It does not perform key derivation across multiple indices — it only derives keys at index 0 on all derivation paths (payment, stake, DRep). This means `getBalance` or `getUtxos` may return different results than a real browser wallet using the same mnemonic, since real wallets index multiple key derivations.
|
|
130
197
|
|
|
131
|
-
|
|
198
|
+
---
|
|
132
199
|
|
|
133
|
-
|
|
200
|
+
## CardanoHeadlessWallet vs MeshCardanoHeadlessWallet
|
|
134
201
|
|
|
135
|
-
|
|
136
|
-
const meshCardanoHeadlessWallet = await MeshCardanoHeadlessWallet.fromMnemonic({
|
|
137
|
-
networkId: 0,
|
|
138
|
-
walletAddressType: AddressType.Base,
|
|
139
|
-
mnemonic: mnemonic,
|
|
140
|
-
fetcher: fetcher,
|
|
141
|
-
});
|
|
202
|
+
`CardanoHeadlessWallet` adheres strictly to CIP-30 return types — everything comes back as CBOR hex, which requires a serialization library to parse.
|
|
142
203
|
|
|
143
|
-
|
|
144
|
-
const meshCardanoHeadlessWalletChangeAddress = await meshCardanoHeadlessWallet.getChangeAddress();
|
|
145
|
-
const meshCardanoHeadlessWalletNetworkId = await meshCardanoHeadlessWallet.getNetworkId();
|
|
146
|
-
const meshCardanoHeadlessWalletCollateral = await meshCardanoHeadlessWallet.getCollateral();
|
|
147
|
-
const meshCardanoHeadlessWalletUtxos = await meshCardanoHeadlessWallet.getUtxos();
|
|
148
|
-
const meshCardanoHeadlessWalletRewardAddresses = await meshCardanoHeadlessWallet.getRewardAddresses();
|
|
204
|
+
`MeshCardanoHeadlessWallet` extends it with convenience methods:
|
|
149
205
|
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
)
|
|
154
|
-
|
|
155
|
-
|
|
206
|
+
| Need | Base method (hex/CBOR) | Mesh method (parsed) |
|
|
207
|
+
|------|----------------------|---------------------|
|
|
208
|
+
| Balance | `getBalance()` → CBOR hex | `getBalanceMesh()` → `Asset[]` |
|
|
209
|
+
| Address | `getChangeAddress()` → hex | `getChangeAddressBech32()` → bech32 |
|
|
210
|
+
| UTxOs | `getUtxos()` → CBOR hex[] | `getUtxosMesh()` → `UTxO[]` |
|
|
211
|
+
| Sign tx | `signTx()` → witness set | `signTxReturnFullTx()` → full signed tx |
|
|
156
212
|
|
|
157
|
-
|
|
213
|
+
The same pattern applies to `CardanoBrowserWallet` vs `MeshCardanoBrowserWallet`.
|
|
158
214
|
|
|
159
|
-
|
|
215
|
+
---
|
|
160
216
|
|
|
161
|
-
|
|
217
|
+
## Migration from v1
|
|
162
218
|
|
|
163
|
-
|
|
164
|
-
const browserWallet = await CardanoBrowserWallet.enable("eternl");
|
|
165
|
-
|
|
166
|
-
const browserBalance = await browserWallet.getBalance();
|
|
167
|
-
const browserChangeAddress = await browserWallet.getChangeAddress();
|
|
168
|
-
const browserCollateral = await browserWallet.getCollateral();
|
|
169
|
-
const browserUtxos = await browserWallet.getUtxos();
|
|
170
|
-
const browserNetworkId = await browserWallet.getNetworkId();
|
|
171
|
-
const browserRewardAddresses = await browserWallet.getRewardAddresses();
|
|
172
|
-
|
|
173
|
-
const browserSignedData = await browserWallet.signData(
|
|
174
|
-
meshCardanoHeadlessWalletChangeAddress,
|
|
175
|
-
"abc"
|
|
176
|
-
);
|
|
177
|
-
const signature = await browserWallet.signTx(transactionHex, true);
|
|
178
|
-
```
|
|
219
|
+
This package (`@meshsdk/wallet` v2) has breaking changes from the previous `MeshWallet` and `BrowserWallet` classes.
|
|
179
220
|
|
|
180
|
-
|
|
221
|
+
**Do not attempt to upgrade without reading the migration guides.** Key breaking changes include renamed classes, swapped method parameters, changed return types, and removed methods. Many changes compile without errors but fail silently at runtime.
|
|
181
222
|
|
|
182
|
-
|
|
223
|
+
| Migrating from | Migrating to | Guide |
|
|
224
|
+
|----------------|-------------|-------|
|
|
225
|
+
| `MeshWallet` (from `@meshsdk/wallet` or `@meshsdk/core`) | `MeshCardanoHeadlessWallet` | [`mesh-wallet-migration.md`](./mesh-wallet-migration.md) |
|
|
226
|
+
| `BrowserWallet` (from `@meshsdk/wallet` or `@meshsdk/core`) | `MeshCardanoBrowserWallet` | [`browser-wallet-migration.md`](./browser-wallet-migration.md) |
|
|
183
227
|
|
|
184
|
-
|
|
185
|
-
const meshCardanoBrowserWallet = await MeshCardanoBrowserWallet.enable("eternl");
|
|
186
|
-
|
|
187
|
-
const browserBalance = await meshCardanoBrowserWallet.getBalanceMesh();
|
|
188
|
-
const browserChangeAddress = await meshCardanoBrowserWallet.getChangeAddressBech32();
|
|
189
|
-
const browserCollateral = await meshCardanoBrowserWallet.getCollateralMesh();
|
|
190
|
-
const browserUtxos = await meshCardanoBrowserWallet.getUtxosMesh();
|
|
191
|
-
const browserNetworkId = await meshCardanoBrowserWallet.getNetworkId();
|
|
192
|
-
const browserRewardAddresses =
|
|
193
|
-
await meshCardanoBrowserWallet.getRewardAddressesBech32();
|
|
194
|
-
|
|
195
|
-
const signedTx = await meshCardanoBrowserWallet.signTxReturnFullTx(
|
|
196
|
-
transactionHex,
|
|
197
|
-
true
|
|
198
|
-
);
|
|
199
|
-
```
|
|
228
|
+
The migration guides are written for both human developers and LLM agents — they contain deterministic SEARCH/REPLACE patterns that can be applied file-by-file.
|
package/dist/index.cjs
CHANGED
|
@@ -24426,6 +24426,9 @@ var CardanoBrowserWallet = class _CardanoBrowserWallet {
|
|
|
24426
24426
|
constructor(walletInstance) {
|
|
24427
24427
|
this.walletInstance = walletInstance;
|
|
24428
24428
|
}
|
|
24429
|
+
async getExtensions() {
|
|
24430
|
+
return this.walletInstance.getExtensions();
|
|
24431
|
+
}
|
|
24429
24432
|
async getNetworkId() {
|
|
24430
24433
|
return this.walletInstance.getNetworkId();
|
|
24431
24434
|
}
|
|
@@ -25433,6 +25436,13 @@ var CardanoHeadlessWallet = class _CardanoHeadlessWallet {
|
|
|
25433
25436
|
}
|
|
25434
25437
|
return await this.submitter.submitTx(tx);
|
|
25435
25438
|
}
|
|
25439
|
+
/**
|
|
25440
|
+
* Get the list of extensions enabled for this wallet.
|
|
25441
|
+
* @returns {Promise<{ cip: number }[]>} A promise that resolves to an array of enabled extensions
|
|
25442
|
+
*/
|
|
25443
|
+
async getExtensions() {
|
|
25444
|
+
return [];
|
|
25445
|
+
}
|
|
25436
25446
|
/**
|
|
25437
25447
|
* Get the network ID.
|
|
25438
25448
|
* @returns {number} The network ID
|
package/dist/index.d.cts
CHANGED
|
@@ -107,6 +107,9 @@ declare class CardanoAddress {
|
|
|
107
107
|
}
|
|
108
108
|
|
|
109
109
|
interface ICardanoWallet {
|
|
110
|
+
getExtensions(): Promise<{
|
|
111
|
+
cip: number;
|
|
112
|
+
}[]>;
|
|
110
113
|
getNetworkId(): Promise<number>;
|
|
111
114
|
getUtxos(): Promise<string[]>;
|
|
112
115
|
getCollateral(): Promise<string[]>;
|
|
@@ -147,6 +150,9 @@ type Extension = {
|
|
|
147
150
|
declare class CardanoBrowserWallet implements ICardanoWallet {
|
|
148
151
|
walletInstance: ICardanoWallet;
|
|
149
152
|
constructor(walletInstance: ICardanoWallet);
|
|
153
|
+
getExtensions(): Promise<{
|
|
154
|
+
cip: number;
|
|
155
|
+
}[]>;
|
|
150
156
|
getNetworkId(): Promise<number>;
|
|
151
157
|
getUtxos(): Promise<string[]>;
|
|
152
158
|
getCollateral(): Promise<string[]>;
|
|
@@ -300,6 +306,13 @@ declare class CardanoHeadlessWallet implements ICardanoWallet {
|
|
|
300
306
|
* @returns {Promise<string>} A promise that resolves to the transaction ID
|
|
301
307
|
*/
|
|
302
308
|
submitTx(tx: string): Promise<string>;
|
|
309
|
+
/**
|
|
310
|
+
* Get the list of extensions enabled for this wallet.
|
|
311
|
+
* @returns {Promise<{ cip: number }[]>} A promise that resolves to an array of enabled extensions
|
|
312
|
+
*/
|
|
313
|
+
getExtensions(): Promise<{
|
|
314
|
+
cip: number;
|
|
315
|
+
}[]>;
|
|
303
316
|
/**
|
|
304
317
|
* Get the network ID.
|
|
305
318
|
* @returns {number} The network ID
|
package/dist/index.d.ts
CHANGED
|
@@ -107,6 +107,9 @@ declare class CardanoAddress {
|
|
|
107
107
|
}
|
|
108
108
|
|
|
109
109
|
interface ICardanoWallet {
|
|
110
|
+
getExtensions(): Promise<{
|
|
111
|
+
cip: number;
|
|
112
|
+
}[]>;
|
|
110
113
|
getNetworkId(): Promise<number>;
|
|
111
114
|
getUtxos(): Promise<string[]>;
|
|
112
115
|
getCollateral(): Promise<string[]>;
|
|
@@ -147,6 +150,9 @@ type Extension = {
|
|
|
147
150
|
declare class CardanoBrowserWallet implements ICardanoWallet {
|
|
148
151
|
walletInstance: ICardanoWallet;
|
|
149
152
|
constructor(walletInstance: ICardanoWallet);
|
|
153
|
+
getExtensions(): Promise<{
|
|
154
|
+
cip: number;
|
|
155
|
+
}[]>;
|
|
150
156
|
getNetworkId(): Promise<number>;
|
|
151
157
|
getUtxos(): Promise<string[]>;
|
|
152
158
|
getCollateral(): Promise<string[]>;
|
|
@@ -300,6 +306,13 @@ declare class CardanoHeadlessWallet implements ICardanoWallet {
|
|
|
300
306
|
* @returns {Promise<string>} A promise that resolves to the transaction ID
|
|
301
307
|
*/
|
|
302
308
|
submitTx(tx: string): Promise<string>;
|
|
309
|
+
/**
|
|
310
|
+
* Get the list of extensions enabled for this wallet.
|
|
311
|
+
* @returns {Promise<{ cip: number }[]>} A promise that resolves to an array of enabled extensions
|
|
312
|
+
*/
|
|
313
|
+
getExtensions(): Promise<{
|
|
314
|
+
cip: number;
|
|
315
|
+
}[]>;
|
|
303
316
|
/**
|
|
304
317
|
* Get the network ID.
|
|
305
318
|
* @returns {number} The network ID
|
package/dist/index.js
CHANGED
|
@@ -24421,6 +24421,9 @@ var CardanoBrowserWallet = class _CardanoBrowserWallet {
|
|
|
24421
24421
|
constructor(walletInstance) {
|
|
24422
24422
|
this.walletInstance = walletInstance;
|
|
24423
24423
|
}
|
|
24424
|
+
async getExtensions() {
|
|
24425
|
+
return this.walletInstance.getExtensions();
|
|
24426
|
+
}
|
|
24424
24427
|
async getNetworkId() {
|
|
24425
24428
|
return this.walletInstance.getNetworkId();
|
|
24426
24429
|
}
|
|
@@ -25445,6 +25448,13 @@ var CardanoHeadlessWallet = class _CardanoHeadlessWallet {
|
|
|
25445
25448
|
}
|
|
25446
25449
|
return await this.submitter.submitTx(tx);
|
|
25447
25450
|
}
|
|
25451
|
+
/**
|
|
25452
|
+
* Get the list of extensions enabled for this wallet.
|
|
25453
|
+
* @returns {Promise<{ cip: number }[]>} A promise that resolves to an array of enabled extensions
|
|
25454
|
+
*/
|
|
25455
|
+
async getExtensions() {
|
|
25456
|
+
return [];
|
|
25457
|
+
}
|
|
25448
25458
|
/**
|
|
25449
25459
|
* Get the network ID.
|
|
25450
25460
|
* @returns {number} The network ID
|