@arkade-os/sdk 0.4.35 → 0.4.37
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/adapters/expo.cjs +4 -4
- package/dist/adapters/expo.js +2 -2
- package/dist/adapters/indexedDB.cjs +3 -3
- package/dist/adapters/indexedDB.js +2 -2
- package/dist/{asyncStorageTaskQueue-CpC027t_.d.cts → asyncStorageTaskQueue-BhBGByYL.d.cts} +2 -2
- package/dist/{asyncStorageTaskQueue-GT8fmPUG.d.ts → asyncStorageTaskQueue-Da-ZSm36.d.ts} +2 -2
- package/dist/{chunk-OURFR4UR.js → chunk-HRD64JRO.js} +3 -3
- package/dist/{chunk-OURFR4UR.js.map → chunk-HRD64JRO.js.map} +1 -1
- package/dist/{chunk-NOR7XOKN.js → chunk-IW3PO5S5.js} +6 -7
- package/dist/chunk-IW3PO5S5.js.map +1 -0
- package/dist/{chunk-H2LX2KKY.cjs → chunk-MIYDTURH.cjs} +81 -82
- package/dist/chunk-MIYDTURH.cjs.map +1 -0
- package/dist/{chunk-X2EQLK4O.cjs → chunk-SPRQOO5F.cjs} +21 -21
- package/dist/{chunk-X2EQLK4O.cjs.map → chunk-SPRQOO5F.cjs.map} +1 -1
- package/dist/{chunk-3JR77WQ4.js → chunk-T5KOXHPT.js} +21 -21
- package/dist/{chunk-3JR77WQ4.js.map → chunk-T5KOXHPT.js.map} +1 -1
- package/dist/{chunk-XQS2HW4Q.js → chunk-VE5PDCGK.js} +3 -3
- package/dist/{chunk-XQS2HW4Q.js.map → chunk-VE5PDCGK.js.map} +1 -1
- package/dist/{chunk-VYS3KGRI.cjs → chunk-XTA64TQF.cjs} +11 -11
- package/dist/{chunk-VYS3KGRI.cjs.map → chunk-XTA64TQF.cjs.map} +1 -1
- package/dist/{chunk-FM7T7JVL.cjs → chunk-YFEN24OW.cjs} +7 -7
- package/dist/{chunk-FM7T7JVL.cjs.map → chunk-YFEN24OW.cjs.map} +1 -1
- package/dist/index.cjs +119 -111
- package/dist/index.d.cts +17 -4
- package/dist/index.d.ts +17 -4
- package/dist/index.js +2 -2
- package/dist/repositories/realm/index.cjs +11 -11
- package/dist/repositories/realm/index.js +2 -2
- package/dist/repositories/sqlite/index.cjs +11 -11
- package/dist/repositories/sqlite/index.js +2 -2
- package/dist/{taskRunner-DCyp6Gea.d.cts → taskRunner-D7ytRcrz.d.cts} +1 -1
- package/dist/{taskRunner-DnxtObeq.d.ts → taskRunner-Dh1DKYD4.d.ts} +1 -1
- package/dist/wallet/expo/background.cjs +12 -12
- package/dist/wallet/expo/background.d.cts +2 -2
- package/dist/wallet/expo/background.d.ts +2 -2
- package/dist/wallet/expo/background.js +4 -4
- package/dist/wallet/expo/index.cjs +11 -11
- package/dist/wallet/expo/index.d.cts +1 -1
- package/dist/wallet/expo/index.d.ts +1 -1
- package/dist/wallet/expo/index.js +3 -3
- package/dist/worker/expo/index.cjs +7 -7
- package/dist/worker/expo/index.d.cts +3 -3
- package/dist/worker/expo/index.d.ts +3 -3
- package/dist/worker/expo/index.js +3 -3
- package/package.json +1 -1
- package/dist/chunk-H2LX2KKY.cjs.map +0 -1
- package/dist/chunk-NOR7XOKN.js.map +0 -1
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
-
var
|
|
3
|
+
var chunkSPRQOO5F_cjs = require('./chunk-SPRQOO5F.cjs');
|
|
4
4
|
var chunkGUTKJMSF_cjs = require('./chunk-GUTKJMSF.cjs');
|
|
5
5
|
var chunkCMPJR3HS_cjs = require('./chunk-CMPJR3HS.cjs');
|
|
6
6
|
var utils_js = require('@scure/btc-signer/utils.js');
|
|
@@ -181,7 +181,7 @@ var TreeSignerSession = class _TreeSignerSession {
|
|
|
181
181
|
noncesByPubkey.set(base.hex.encode(myPublicKey.subarray(1)), myNonce);
|
|
182
182
|
const tx = this.graph.find(txid);
|
|
183
183
|
if (!tx) throw new Error(`missing tx for txid ${txid}`);
|
|
184
|
-
const cosigners =
|
|
184
|
+
const cosigners = chunkSPRQOO5F_cjs.getArkPsbtFields(tx.root, 0, chunkSPRQOO5F_cjs.CosignerPublicKey).map(
|
|
185
185
|
(c) => base.hex.encode(c.key.subarray(1))
|
|
186
186
|
// xonly pubkey
|
|
187
187
|
);
|
|
@@ -233,7 +233,7 @@ var TreeSignerSession = class _TreeSignerSession {
|
|
|
233
233
|
if (!aggNonce) throw new Error("missing aggregate nonce");
|
|
234
234
|
const prevoutAmounts = [];
|
|
235
235
|
const prevoutScripts = [];
|
|
236
|
-
const cosigners =
|
|
236
|
+
const cosigners = chunkSPRQOO5F_cjs.getArkPsbtFields(g.root, 0, chunkSPRQOO5F_cjs.CosignerPublicKey).map((c) => c.key);
|
|
237
237
|
const { finalKey } = aggregateKeys(cosigners, true, {
|
|
238
238
|
taprootTweak: this.scriptRoot
|
|
239
239
|
});
|
|
@@ -980,14 +980,14 @@ var RestDelegateProvider = class {
|
|
|
980
980
|
*/
|
|
981
981
|
async delegate(intent, forfeitTxs, options) {
|
|
982
982
|
const url = `${this.url}/v1/delegate`;
|
|
983
|
-
const response = await
|
|
983
|
+
const response = await chunkSPRQOO5F_cjs.baseFetch(url, {
|
|
984
984
|
method: "POST",
|
|
985
985
|
headers: {
|
|
986
986
|
"Content-Type": "application/json"
|
|
987
987
|
},
|
|
988
988
|
body: JSON.stringify({
|
|
989
989
|
intent: {
|
|
990
|
-
message:
|
|
990
|
+
message: chunkSPRQOO5F_cjs.Intent.encodeMessage(intent.message),
|
|
991
991
|
proof: intent.proof
|
|
992
992
|
},
|
|
993
993
|
forfeit_txs: forfeitTxs,
|
|
@@ -1007,7 +1007,7 @@ var RestDelegateProvider = class {
|
|
|
1007
1007
|
*/
|
|
1008
1008
|
async getDelegateInfo() {
|
|
1009
1009
|
const url = `${this.url}/v1/delegator/info`;
|
|
1010
|
-
const response = await
|
|
1010
|
+
const response = await chunkSPRQOO5F_cjs.baseFetch(url);
|
|
1011
1011
|
if (!response.ok) {
|
|
1012
1012
|
const errorText2 = await response.text();
|
|
1013
1013
|
throw new Error(`Failed to get delegate info: ${errorText2}`);
|
|
@@ -1042,14 +1042,14 @@ var EsploraProvider = class {
|
|
|
1042
1042
|
pollingInterval;
|
|
1043
1043
|
forcePolling;
|
|
1044
1044
|
async getCoins(address) {
|
|
1045
|
-
const response = await
|
|
1045
|
+
const response = await chunkSPRQOO5F_cjs.baseFetch(`${this.baseUrl}/address/${address}/utxo`);
|
|
1046
1046
|
if (!response.ok) {
|
|
1047
1047
|
throw new Error(`Failed to fetch UTXOs: ${response.statusText}`);
|
|
1048
1048
|
}
|
|
1049
1049
|
return response.json();
|
|
1050
1050
|
}
|
|
1051
1051
|
async getFeeRate() {
|
|
1052
|
-
const response = await
|
|
1052
|
+
const response = await chunkSPRQOO5F_cjs.baseFetch(`${this.baseUrl}/fee-estimates`);
|
|
1053
1053
|
if (response.status === 404) {
|
|
1054
1054
|
return void 0;
|
|
1055
1055
|
}
|
|
@@ -1070,7 +1070,7 @@ var EsploraProvider = class {
|
|
|
1070
1070
|
}
|
|
1071
1071
|
}
|
|
1072
1072
|
async getTxOutspends(txid) {
|
|
1073
|
-
const response = await
|
|
1073
|
+
const response = await chunkSPRQOO5F_cjs.baseFetch(`${this.baseUrl}/tx/${txid}/outspends`);
|
|
1074
1074
|
if (!response.ok) {
|
|
1075
1075
|
const error = await response.text();
|
|
1076
1076
|
throw new Error(`Failed to get transaction outspends: ${error}`);
|
|
@@ -1078,7 +1078,7 @@ var EsploraProvider = class {
|
|
|
1078
1078
|
return response.json();
|
|
1079
1079
|
}
|
|
1080
1080
|
async getTransactions(address) {
|
|
1081
|
-
const response = await
|
|
1081
|
+
const response = await chunkSPRQOO5F_cjs.baseFetch(`${this.baseUrl}/address/${address}/txs`);
|
|
1082
1082
|
if (!response.ok) {
|
|
1083
1083
|
const error = await response.text();
|
|
1084
1084
|
throw new Error(`Failed to get transactions: ${error}`);
|
|
@@ -1086,7 +1086,7 @@ var EsploraProvider = class {
|
|
|
1086
1086
|
return response.json();
|
|
1087
1087
|
}
|
|
1088
1088
|
async getTxStatus(txid) {
|
|
1089
|
-
const txresponse = await
|
|
1089
|
+
const txresponse = await chunkSPRQOO5F_cjs.baseFetch(`${this.baseUrl}/tx/${txid}`);
|
|
1090
1090
|
if (!txresponse.ok) {
|
|
1091
1091
|
throw new Error(txresponse.statusText);
|
|
1092
1092
|
}
|
|
@@ -1094,7 +1094,7 @@ var EsploraProvider = class {
|
|
|
1094
1094
|
if (!tx.status.confirmed) {
|
|
1095
1095
|
return { confirmed: false };
|
|
1096
1096
|
}
|
|
1097
|
-
const response = await
|
|
1097
|
+
const response = await chunkSPRQOO5F_cjs.baseFetch(`${this.baseUrl}/tx/${txid}/status`);
|
|
1098
1098
|
if (!response.ok) {
|
|
1099
1099
|
throw new Error(`Failed to get transaction status: ${response.statusText}`);
|
|
1100
1100
|
}
|
|
@@ -1178,7 +1178,7 @@ var EsploraProvider = class {
|
|
|
1178
1178
|
return stopFunc;
|
|
1179
1179
|
}
|
|
1180
1180
|
async getChainTip() {
|
|
1181
|
-
const tipBlocks = await
|
|
1181
|
+
const tipBlocks = await chunkSPRQOO5F_cjs.baseFetch(`${this.baseUrl}/blocks`);
|
|
1182
1182
|
if (!tipBlocks.ok) {
|
|
1183
1183
|
throw new Error(`Failed to get chain tip: ${tipBlocks.statusText}`);
|
|
1184
1184
|
}
|
|
@@ -1197,7 +1197,7 @@ var EsploraProvider = class {
|
|
|
1197
1197
|
};
|
|
1198
1198
|
}
|
|
1199
1199
|
async broadcastPackage(parent, child) {
|
|
1200
|
-
const response = await
|
|
1200
|
+
const response = await chunkSPRQOO5F_cjs.baseFetch(`${this.baseUrl}/txs/package`, {
|
|
1201
1201
|
method: "POST",
|
|
1202
1202
|
headers: {
|
|
1203
1203
|
"Content-Type": "application/json"
|
|
@@ -1211,7 +1211,7 @@ var EsploraProvider = class {
|
|
|
1211
1211
|
return response.json();
|
|
1212
1212
|
}
|
|
1213
1213
|
async broadcastTx(tx) {
|
|
1214
|
-
const response = await
|
|
1214
|
+
const response = await chunkSPRQOO5F_cjs.baseFetch(`${this.baseUrl}/tx`, {
|
|
1215
1215
|
method: "POST",
|
|
1216
1216
|
headers: {
|
|
1217
1217
|
"Content-Type": "text/plain"
|
|
@@ -1280,7 +1280,7 @@ function buildForfeitTx(inputs, forfeitPkScript, txLocktime) {
|
|
|
1280
1280
|
);
|
|
1281
1281
|
}
|
|
1282
1282
|
function buildForfeitTxWithOutput(inputs, output, txLocktime) {
|
|
1283
|
-
const tx = new
|
|
1283
|
+
const tx = new chunkSPRQOO5F_cjs.Transaction({
|
|
1284
1284
|
version: 3,
|
|
1285
1285
|
lockTime: txLocktime
|
|
1286
1286
|
});
|
|
@@ -1356,7 +1356,7 @@ function validateVtxoTxGraph(graph, roundTransaction, sweepTapTreeRoot) {
|
|
|
1356
1356
|
if (previousScriptKey.length !== 32) {
|
|
1357
1357
|
throw new Error(`parent output ${childIndex} has invalid script`);
|
|
1358
1358
|
}
|
|
1359
|
-
const cosigners =
|
|
1359
|
+
const cosigners = chunkSPRQOO5F_cjs.getArkPsbtFields(child.root, 0, chunkSPRQOO5F_cjs.CosignerPublicKey);
|
|
1360
1360
|
if (cosigners.length === 0) {
|
|
1361
1361
|
throw ErrMissingCosignersPublicKeys;
|
|
1362
1362
|
}
|
|
@@ -1456,7 +1456,7 @@ var Extension = class _Extension {
|
|
|
1456
1456
|
`expected magic prefix ${base.hex.encode(ARKADE_MAGIC)}, got ${base.hex.encode(payload.slice(0, Math.min(payload.length, ARKADE_MAGIC.length)))}`
|
|
1457
1457
|
);
|
|
1458
1458
|
}
|
|
1459
|
-
const reader = new
|
|
1459
|
+
const reader = new chunkSPRQOO5F_cjs.BufferReader(payload.slice(ARKADE_MAGIC.length));
|
|
1460
1460
|
const packets = [];
|
|
1461
1461
|
while (reader.remaining() > 0) {
|
|
1462
1462
|
const packetType = reader.readByte();
|
|
@@ -1530,7 +1530,7 @@ var Extension = class _Extension {
|
|
|
1530
1530
|
*/
|
|
1531
1531
|
getAssetPacket() {
|
|
1532
1532
|
for (const p of this.packets) {
|
|
1533
|
-
if (p instanceof
|
|
1533
|
+
if (p instanceof chunkSPRQOO5F_cjs.Packet) {
|
|
1534
1534
|
return p;
|
|
1535
1535
|
}
|
|
1536
1536
|
}
|
|
@@ -1538,8 +1538,8 @@ var Extension = class _Extension {
|
|
|
1538
1538
|
}
|
|
1539
1539
|
};
|
|
1540
1540
|
function parsePacket(packetType, data) {
|
|
1541
|
-
if (packetType ===
|
|
1542
|
-
return
|
|
1541
|
+
if (packetType === chunkSPRQOO5F_cjs.Packet.PACKET_TYPE) {
|
|
1542
|
+
return chunkSPRQOO5F_cjs.Packet.fromBytes(data);
|
|
1543
1543
|
}
|
|
1544
1544
|
return new UnknownPacket(packetType, data);
|
|
1545
1545
|
}
|
|
@@ -1730,7 +1730,7 @@ function createAssetPacket(assetInputs, receivers, changeReceiver) {
|
|
|
1730
1730
|
const existing = inputsByAssetId.get(asset.assetId);
|
|
1731
1731
|
inputsByAssetId.set(asset.assetId, [
|
|
1732
1732
|
...existing ?? [],
|
|
1733
|
-
|
|
1733
|
+
chunkSPRQOO5F_cjs.AssetInput.create(inputIndex, asset.amount)
|
|
1734
1734
|
]);
|
|
1735
1735
|
}
|
|
1736
1736
|
}
|
|
@@ -1742,7 +1742,7 @@ function createAssetPacket(assetInputs, receivers, changeReceiver) {
|
|
|
1742
1742
|
const existing = outputsByAssetId.get(asset.assetId);
|
|
1743
1743
|
outputsByAssetId.set(asset.assetId, [
|
|
1744
1744
|
...existing ?? [],
|
|
1745
|
-
|
|
1745
|
+
chunkSPRQOO5F_cjs.AssetOutput.create(outputIndex, asset.amount)
|
|
1746
1746
|
]);
|
|
1747
1747
|
}
|
|
1748
1748
|
}
|
|
@@ -1753,7 +1753,7 @@ function createAssetPacket(assetInputs, receivers, changeReceiver) {
|
|
|
1753
1753
|
const existing = outputsByAssetId.get(asset.assetId);
|
|
1754
1754
|
outputsByAssetId.set(asset.assetId, [
|
|
1755
1755
|
...existing ?? [],
|
|
1756
|
-
|
|
1756
|
+
chunkSPRQOO5F_cjs.AssetOutput.create(outputIndex, asset.amount)
|
|
1757
1757
|
]);
|
|
1758
1758
|
}
|
|
1759
1759
|
}
|
|
@@ -1762,11 +1762,11 @@ function createAssetPacket(assetInputs, receivers, changeReceiver) {
|
|
|
1762
1762
|
for (const assetIdStr of allAssetIds) {
|
|
1763
1763
|
const inputs = inputsByAssetId.get(assetIdStr);
|
|
1764
1764
|
const outputs = outputsByAssetId.get(assetIdStr);
|
|
1765
|
-
const assetId =
|
|
1766
|
-
const group =
|
|
1765
|
+
const assetId = chunkSPRQOO5F_cjs.AssetId.fromString(assetIdStr);
|
|
1766
|
+
const group = chunkSPRQOO5F_cjs.AssetGroup.create(assetId, null, inputs ?? [], outputs ?? [], []);
|
|
1767
1767
|
groups.push(group);
|
|
1768
1768
|
}
|
|
1769
|
-
return
|
|
1769
|
+
return chunkSPRQOO5F_cjs.Packet.create(groups);
|
|
1770
1770
|
}
|
|
1771
1771
|
function selectCoinsWithAsset(coins, assetId, requiredAmount) {
|
|
1772
1772
|
const coinsWithAsset = coins.filter((coin) => coin.assets?.some((a) => a.assetId === assetId));
|
|
@@ -1883,7 +1883,7 @@ function buildVirtualTx(inputs, outputs) {
|
|
|
1883
1883
|
}
|
|
1884
1884
|
}
|
|
1885
1885
|
}
|
|
1886
|
-
const tx = new
|
|
1886
|
+
const tx = new chunkSPRQOO5F_cjs.Transaction({
|
|
1887
1887
|
version: 3,
|
|
1888
1888
|
lockTime: Number(lockTime)
|
|
1889
1889
|
});
|
|
@@ -1898,7 +1898,7 @@ function buildVirtualTx(inputs, outputs) {
|
|
|
1898
1898
|
},
|
|
1899
1899
|
tapLeafScript: [input.tapLeafScript]
|
|
1900
1900
|
});
|
|
1901
|
-
|
|
1901
|
+
chunkSPRQOO5F_cjs.setArkPsbtField(tx, i, chunkSPRQOO5F_cjs.VtxoTaprootTree, input.tapTree);
|
|
1902
1902
|
}
|
|
1903
1903
|
for (const output of outputs) {
|
|
1904
1904
|
tx.addOutput(output);
|
|
@@ -3006,7 +3006,7 @@ var VtxoManager = class _VtxoManager {
|
|
|
3006
3006
|
`Sweep not economical: output ${outputAmount} sats after ${fee} sats fee is below dust (${dustAmount} sats)`
|
|
3007
3007
|
);
|
|
3008
3008
|
}
|
|
3009
|
-
const tx = new
|
|
3009
|
+
const tx = new chunkSPRQOO5F_cjs.Transaction();
|
|
3010
3010
|
for (const utxo of expiredUtxos) {
|
|
3011
3011
|
const utxoScript = chunkCMPJR3HS_cjs.VtxoScript.decode(utxo.tapTree);
|
|
3012
3012
|
const utxoExitLeaf = utxoScript.leaves.find(
|
|
@@ -3644,7 +3644,7 @@ var VtxoManager = class _VtxoManager {
|
|
|
3644
3644
|
* or doesn't carry the metadata.
|
|
3645
3645
|
*/
|
|
3646
3646
|
extractSpentOutpoint(error) {
|
|
3647
|
-
const ark =
|
|
3647
|
+
const ark = chunkSPRQOO5F_cjs.maybeArkError(error);
|
|
3648
3648
|
if (!ark || ark.name !== "VTXO_ALREADY_SPENT") return void 0;
|
|
3649
3649
|
const raw = ark.metadata?.vtxo_outpoint;
|
|
3650
3650
|
if (typeof raw !== "string") return void 0;
|
|
@@ -4555,7 +4555,7 @@ var AssetManager = class extends ReadonlyAssetManager {
|
|
|
4555
4555
|
const virtualCoins = await this.wallet.getVtxos({
|
|
4556
4556
|
withRecoverable: false
|
|
4557
4557
|
});
|
|
4558
|
-
const controlAssetRef = params.controlAssetId ?
|
|
4558
|
+
const controlAssetRef = params.controlAssetId ? chunkSPRQOO5F_cjs.AssetRef.fromId(chunkSPRQOO5F_cjs.AssetId.fromString(params.controlAssetId)) : null;
|
|
4559
4559
|
const coinSelection = selectVirtualCoins(virtualCoins, Number(this.wallet.dustAmount));
|
|
4560
4560
|
let totalBtcSelected = 0n;
|
|
4561
4561
|
const assetChanges = /* @__PURE__ */ new Map();
|
|
@@ -4568,8 +4568,8 @@ var AssetManager = class extends ReadonlyAssetManager {
|
|
|
4568
4568
|
}
|
|
4569
4569
|
}
|
|
4570
4570
|
const groups = [];
|
|
4571
|
-
const issuedAssetOutput =
|
|
4572
|
-
const issuedAssetGroup =
|
|
4571
|
+
const issuedAssetOutput = chunkSPRQOO5F_cjs.AssetOutput.create(0, params.amount);
|
|
4572
|
+
const issuedAssetGroup = chunkSPRQOO5F_cjs.AssetGroup.create(
|
|
4573
4573
|
null,
|
|
4574
4574
|
controlAssetRef,
|
|
4575
4575
|
[],
|
|
@@ -4584,15 +4584,15 @@ var AssetManager = class extends ReadonlyAssetManager {
|
|
|
4584
4584
|
for (const [inputIndex, assets] of assetInputs) {
|
|
4585
4585
|
for (const asset of assets) {
|
|
4586
4586
|
if (asset.assetId !== assetId) continue;
|
|
4587
|
-
changeInputs.push(
|
|
4587
|
+
changeInputs.push(chunkSPRQOO5F_cjs.AssetInput.create(inputIndex, asset.amount));
|
|
4588
4588
|
}
|
|
4589
4589
|
}
|
|
4590
4590
|
groups.push(
|
|
4591
|
-
|
|
4592
|
-
|
|
4591
|
+
chunkSPRQOO5F_cjs.AssetGroup.create(
|
|
4592
|
+
chunkSPRQOO5F_cjs.AssetId.fromString(assetId),
|
|
4593
4593
|
null,
|
|
4594
4594
|
changeInputs,
|
|
4595
|
-
[
|
|
4595
|
+
[chunkSPRQOO5F_cjs.AssetOutput.create(0, amount)],
|
|
4596
4596
|
[]
|
|
4597
4597
|
)
|
|
4598
4598
|
);
|
|
@@ -4605,7 +4605,7 @@ var AssetManager = class extends ReadonlyAssetManager {
|
|
|
4605
4605
|
script: outputAddress.pkScript,
|
|
4606
4606
|
amount: BigInt(totalBtcSelected)
|
|
4607
4607
|
},
|
|
4608
|
-
Extension.create([
|
|
4608
|
+
Extension.create([chunkSPRQOO5F_cjs.Packet.create(groups)]).txOut()
|
|
4609
4609
|
];
|
|
4610
4610
|
const { arkTxid } = await this.wallet.buildAndSubmitOffchainTx(
|
|
4611
4611
|
coinSelection.inputs,
|
|
@@ -4613,7 +4613,7 @@ var AssetManager = class extends ReadonlyAssetManager {
|
|
|
4613
4613
|
);
|
|
4614
4614
|
return {
|
|
4615
4615
|
arkTxId: arkTxid,
|
|
4616
|
-
assetId:
|
|
4616
|
+
assetId: chunkSPRQOO5F_cjs.AssetId.create(arkTxid, 0).toString()
|
|
4617
4617
|
};
|
|
4618
4618
|
}
|
|
4619
4619
|
/**
|
|
@@ -4685,16 +4685,16 @@ var AssetManager = class extends ReadonlyAssetManager {
|
|
|
4685
4685
|
for (const [inputIndex, assets] of assetInputs) {
|
|
4686
4686
|
for (const asset of assets) {
|
|
4687
4687
|
if (asset.assetId !== params.assetId) continue;
|
|
4688
|
-
reissueInputs.push(
|
|
4688
|
+
reissueInputs.push(chunkSPRQOO5F_cjs.AssetInput.create(inputIndex, asset.amount));
|
|
4689
4689
|
}
|
|
4690
4690
|
}
|
|
4691
4691
|
const totalAssetAmount = assetToReissueAmount + params.amount;
|
|
4692
|
-
const reissueAssetIdObj =
|
|
4693
|
-
const reissueAssetGroup =
|
|
4692
|
+
const reissueAssetIdObj = chunkSPRQOO5F_cjs.AssetId.fromString(params.assetId);
|
|
4693
|
+
const reissueAssetGroup = chunkSPRQOO5F_cjs.AssetGroup.create(
|
|
4694
4694
|
reissueAssetIdObj,
|
|
4695
4695
|
null,
|
|
4696
4696
|
reissueInputs,
|
|
4697
|
-
[
|
|
4697
|
+
[chunkSPRQOO5F_cjs.AssetOutput.create(0, totalAssetAmount)],
|
|
4698
4698
|
[]
|
|
4699
4699
|
);
|
|
4700
4700
|
const groups = [reissueAssetGroup];
|
|
@@ -4703,15 +4703,15 @@ var AssetManager = class extends ReadonlyAssetManager {
|
|
|
4703
4703
|
for (const [inputIndex, assets] of assetInputs) {
|
|
4704
4704
|
for (const asset of assets) {
|
|
4705
4705
|
if (asset.assetId !== assetId) continue;
|
|
4706
|
-
changeInputs.push(
|
|
4706
|
+
changeInputs.push(chunkSPRQOO5F_cjs.AssetInput.create(inputIndex, asset.amount));
|
|
4707
4707
|
}
|
|
4708
4708
|
}
|
|
4709
4709
|
groups.push(
|
|
4710
|
-
|
|
4711
|
-
|
|
4710
|
+
chunkSPRQOO5F_cjs.AssetGroup.create(
|
|
4711
|
+
chunkSPRQOO5F_cjs.AssetId.fromString(assetId),
|
|
4712
4712
|
null,
|
|
4713
4713
|
changeInputs,
|
|
4714
|
-
[
|
|
4714
|
+
[chunkSPRQOO5F_cjs.AssetOutput.create(0, amount)],
|
|
4715
4715
|
[]
|
|
4716
4716
|
)
|
|
4717
4717
|
);
|
|
@@ -4723,7 +4723,7 @@ var AssetManager = class extends ReadonlyAssetManager {
|
|
|
4723
4723
|
script: outputAddress.pkScript,
|
|
4724
4724
|
amount: BigInt(totalBtcSelected)
|
|
4725
4725
|
},
|
|
4726
|
-
Extension.create([
|
|
4726
|
+
Extension.create([chunkSPRQOO5F_cjs.Packet.create(groups)]).txOut()
|
|
4727
4727
|
];
|
|
4728
4728
|
const { arkTxid } = await this.wallet.buildAndSubmitOffchainTx(selectedCoins, outputs);
|
|
4729
4729
|
return arkTxid;
|
|
@@ -4790,15 +4790,15 @@ var AssetManager = class extends ReadonlyAssetManager {
|
|
|
4790
4790
|
for (const [inputIndex, assets] of assetInputs) {
|
|
4791
4791
|
for (const asset of assets) {
|
|
4792
4792
|
if (asset.assetId !== assetId) continue;
|
|
4793
|
-
changeInputs.push(
|
|
4793
|
+
changeInputs.push(chunkSPRQOO5F_cjs.AssetInput.create(inputIndex, asset.amount));
|
|
4794
4794
|
}
|
|
4795
4795
|
}
|
|
4796
4796
|
groups.push(
|
|
4797
|
-
|
|
4798
|
-
|
|
4797
|
+
chunkSPRQOO5F_cjs.AssetGroup.create(
|
|
4798
|
+
chunkSPRQOO5F_cjs.AssetId.fromString(assetId),
|
|
4799
4799
|
null,
|
|
4800
4800
|
changeInputs,
|
|
4801
|
-
amount > 0n ? [
|
|
4801
|
+
amount > 0n ? [chunkSPRQOO5F_cjs.AssetOutput.create(0, amount)] : [],
|
|
4802
4802
|
[]
|
|
4803
4803
|
)
|
|
4804
4804
|
);
|
|
@@ -4810,7 +4810,7 @@ var AssetManager = class extends ReadonlyAssetManager {
|
|
|
4810
4810
|
script: outputAddress.pkScript,
|
|
4811
4811
|
amount: BigInt(totalBtcSelected)
|
|
4812
4812
|
},
|
|
4813
|
-
Extension.create([
|
|
4813
|
+
Extension.create([chunkSPRQOO5F_cjs.Packet.create(groups)]).txOut()
|
|
4814
4814
|
];
|
|
4815
4815
|
const { arkTxid } = await this.wallet.buildAndSubmitOffchainTx(selectedCoins, outputs);
|
|
4816
4816
|
return arkTxid;
|
|
@@ -4835,7 +4835,7 @@ function castMetadata(metadata) {
|
|
|
4835
4835
|
} else {
|
|
4836
4836
|
throw new Error("Invalid metadata value type");
|
|
4837
4837
|
}
|
|
4838
|
-
md.push(
|
|
4838
|
+
md.push(chunkSPRQOO5F_cjs.Metadata.create(textEncoder.encode(key), valueBytes));
|
|
4839
4839
|
}
|
|
4840
4840
|
return md;
|
|
4841
4841
|
}
|
|
@@ -5120,7 +5120,7 @@ async function makeSignedDelegateIntent(identity, coins, outputs, onchainOutputs
|
|
|
5120
5120
|
expire_at: 0,
|
|
5121
5121
|
cosigners_public_keys: cosignerPubKeys
|
|
5122
5122
|
};
|
|
5123
|
-
const proof =
|
|
5123
|
+
const proof = chunkSPRQOO5F_cjs.Intent.create(message, coins, outputs);
|
|
5124
5124
|
const signedProof = await identity.sign(proof);
|
|
5125
5125
|
return {
|
|
5126
5126
|
proof: base.base64.encode(signedProof.toPSBT()),
|
|
@@ -6863,7 +6863,7 @@ var ContractWatcher = class {
|
|
|
6863
6863
|
this.connectionState = "connected";
|
|
6864
6864
|
this.reconnectAttempts = 0;
|
|
6865
6865
|
this.listenLoop().catch((e) => {
|
|
6866
|
-
if (
|
|
6866
|
+
if (chunkSPRQOO5F_cjs.isEventSourceError(e)) {
|
|
6867
6867
|
console.debug("ContractWatcher subscription disconnected; reconnecting");
|
|
6868
6868
|
} else {
|
|
6869
6869
|
console.error(e);
|
|
@@ -8442,7 +8442,7 @@ async function resolveDescriptorProvider(config, walletRepository) {
|
|
|
8442
8442
|
var MissingSigningDescriptorError = class extends Error {
|
|
8443
8443
|
constructor(contractScript, contractType) {
|
|
8444
8444
|
super(
|
|
8445
|
-
`Cannot sign input for ${contractType} contract ${contractScript}: metadata.signingDescriptor is missing.
|
|
8445
|
+
`Cannot sign input for ${contractType} contract ${contractScript}: metadata.signingDescriptor is missing. Possible causes: this wallet was rotated on an earlier build that did not persist signing descriptors, or the contract belongs to a different identity. Manually set metadata.signingDescriptor on the contract record, or restore from a pre-rotation snapshot or delete the contract.`
|
|
8446
8446
|
);
|
|
8447
8447
|
this.contractScript = contractScript;
|
|
8448
8448
|
this.contractType = contractType;
|
|
@@ -8470,9 +8470,8 @@ var InputSignerRouter = class {
|
|
|
8470
8470
|
* here) so the routing rules never live in two places.
|
|
8471
8471
|
*
|
|
8472
8472
|
* Throws {@link MissingSigningDescriptorError} for a non-baseline
|
|
8473
|
-
* default/delegate contract whose `metadata.signingDescriptor` is
|
|
8474
|
-
* missing
|
|
8475
|
-
* here moves the failure earlier, before any PSBT is mutated.
|
|
8473
|
+
* default/delegate/boarding contract whose `metadata.signingDescriptor` is
|
|
8474
|
+
* missing.
|
|
8476
8475
|
*/
|
|
8477
8476
|
async classify(jobs) {
|
|
8478
8477
|
const identityIndexes = [];
|
|
@@ -8820,7 +8819,7 @@ var ReadonlyWallet = class _ReadonlyWallet {
|
|
|
8820
8819
|
*/
|
|
8821
8820
|
static async setupWalletConfig(config, pubKey) {
|
|
8822
8821
|
const arkadeServerUrl = getArkadeServerUrl(config);
|
|
8823
|
-
const arkProvider = config.arkProvider || new
|
|
8822
|
+
const arkProvider = config.arkProvider || new chunkSPRQOO5F_cjs.RestArkProvider(arkadeServerUrl);
|
|
8824
8823
|
let indexerProvider = config.indexerProvider;
|
|
8825
8824
|
if (!indexerProvider) {
|
|
8826
8825
|
let indexerUrl = config.indexerUrl;
|
|
@@ -8837,7 +8836,7 @@ var ReadonlyWallet = class _ReadonlyWallet {
|
|
|
8837
8836
|
indexerUrl = arkadeServerUrl;
|
|
8838
8837
|
}
|
|
8839
8838
|
}
|
|
8840
|
-
indexerProvider = new
|
|
8839
|
+
indexerProvider = new chunkSPRQOO5F_cjs.RestIndexerProvider(indexerUrl);
|
|
8841
8840
|
}
|
|
8842
8841
|
const info = await arkProvider.getInfo();
|
|
8843
8842
|
const network = chunkCMPJR3HS_cjs.getNetwork(info.network);
|
|
@@ -10745,7 +10744,7 @@ var Wallet2 = class _Wallet extends ReadonlyWallet {
|
|
|
10745
10744
|
try {
|
|
10746
10745
|
return await this.arkProvider.registerIntent(intent);
|
|
10747
10746
|
} catch (error) {
|
|
10748
|
-
if (error instanceof
|
|
10747
|
+
if (error instanceof chunkSPRQOO5F_cjs.ArkError && error.code === 0 && error.message.includes("duplicated input")) {
|
|
10749
10748
|
const deleteIntent = await this.makeDeleteIntentSignature(inputs);
|
|
10750
10749
|
await this.arkProvider.deleteIntent(deleteIntent);
|
|
10751
10750
|
return this.arkProvider.registerIntent(intent);
|
|
@@ -10761,7 +10760,7 @@ var Wallet2 = class _Wallet extends ReadonlyWallet {
|
|
|
10761
10760
|
expire_at: 0,
|
|
10762
10761
|
cosigners_public_keys: cosignerPubKeys
|
|
10763
10762
|
};
|
|
10764
|
-
const proof =
|
|
10763
|
+
const proof = chunkSPRQOO5F_cjs.Intent.create(message, coins, outputs);
|
|
10765
10764
|
const signedProof = await this._signerRouter.sign(proof, intentProofJobs(coins));
|
|
10766
10765
|
return {
|
|
10767
10766
|
proof: base.base64.encode(signedProof.toPSBT()),
|
|
@@ -10773,7 +10772,7 @@ var Wallet2 = class _Wallet extends ReadonlyWallet {
|
|
|
10773
10772
|
type: "delete",
|
|
10774
10773
|
expire_at: 0
|
|
10775
10774
|
};
|
|
10776
|
-
const proof =
|
|
10775
|
+
const proof = chunkSPRQOO5F_cjs.Intent.create(message, coins, []);
|
|
10777
10776
|
const signedProof = await this._signerRouter.sign(proof, intentProofJobs(coins));
|
|
10778
10777
|
return {
|
|
10779
10778
|
proof: base.base64.encode(signedProof.toPSBT()),
|
|
@@ -10785,7 +10784,7 @@ var Wallet2 = class _Wallet extends ReadonlyWallet {
|
|
|
10785
10784
|
type: "get-pending-tx",
|
|
10786
10785
|
expire_at: 0
|
|
10787
10786
|
};
|
|
10788
|
-
const proof =
|
|
10787
|
+
const proof = chunkSPRQOO5F_cjs.Intent.create(message, coins, []);
|
|
10789
10788
|
const signedProof = await this._signerRouter.sign(proof, intentProofJobs(coins));
|
|
10790
10789
|
return {
|
|
10791
10790
|
proof: base.base64.encode(signedProof.toPSBT()),
|
|
@@ -11690,7 +11689,7 @@ var MessageBus = class {
|
|
|
11690
11689
|
this.initialized = true;
|
|
11691
11690
|
}
|
|
11692
11691
|
async buildServices(config) {
|
|
11693
|
-
const arkProvider = new
|
|
11692
|
+
const arkProvider = new chunkSPRQOO5F_cjs.RestArkProvider(config.arkServer.url);
|
|
11694
11693
|
const storage = {
|
|
11695
11694
|
walletRepository: this.walletRepository,
|
|
11696
11695
|
contractRepository: this.contractRepository
|
|
@@ -12841,7 +12840,7 @@ var WalletMessageHandler = class {
|
|
|
12841
12840
|
// Wallet methods
|
|
12842
12841
|
async handleInitWallet({ payload }) {
|
|
12843
12842
|
const { arkServerUrl } = payload;
|
|
12844
|
-
this.indexerProvider = new
|
|
12843
|
+
this.indexerProvider = new chunkSPRQOO5F_cjs.RestIndexerProvider(arkServerUrl);
|
|
12845
12844
|
await this.onWalletInitialized();
|
|
12846
12845
|
}
|
|
12847
12846
|
async handleGetBalance() {
|
|
@@ -14632,7 +14631,7 @@ var OnchainWallet = class _OnchainWallet {
|
|
|
14632
14631
|
if (!inputs) {
|
|
14633
14632
|
throw new Error("Fee estimation failed");
|
|
14634
14633
|
}
|
|
14635
|
-
let tx = new
|
|
14634
|
+
let tx = new chunkSPRQOO5F_cjs.Transaction();
|
|
14636
14635
|
for (const input of inputs) {
|
|
14637
14636
|
tx.addInput({
|
|
14638
14637
|
txid: input.txid,
|
|
@@ -14663,7 +14662,7 @@ var OnchainWallet = class _OnchainWallet {
|
|
|
14663
14662
|
*/
|
|
14664
14663
|
async bumpP2A(parent) {
|
|
14665
14664
|
const parentVsize = parent.vsize;
|
|
14666
|
-
let child = new
|
|
14665
|
+
let child = new chunkSPRQOO5F_cjs.Transaction({
|
|
14667
14666
|
version: 3,
|
|
14668
14667
|
allowLegacyWitnessUtxo: true
|
|
14669
14668
|
});
|
|
@@ -15426,7 +15425,7 @@ exports.BIP322 = void 0;
|
|
|
15426
15425
|
async function sign2(message, identity, network) {
|
|
15427
15426
|
const xOnlyPubKey = await identity.xOnlyPublicKey();
|
|
15428
15427
|
const payment = btcSigner.p2tr(xOnlyPubKey, void 0, network);
|
|
15429
|
-
const toSpend =
|
|
15428
|
+
const toSpend = chunkSPRQOO5F_cjs.craftToSpendTx(message, payment.script, TAG_BIP322);
|
|
15430
15429
|
const toSign = craftBIP322ToSignP2TR(toSpend, payment.script, xOnlyPubKey);
|
|
15431
15430
|
const signed = await identity.sign(toSign, [0]);
|
|
15432
15431
|
signed.finalizeIdx(0);
|
|
@@ -15484,7 +15483,7 @@ function verifyP2TR(message, witnessItems, pkScript, pubkey) {
|
|
|
15484
15483
|
if (sighashType !== btcSigner.SigHash.DEFAULT && sighashType !== btcSigner.SigHash.ALL) {
|
|
15485
15484
|
return false;
|
|
15486
15485
|
}
|
|
15487
|
-
const toSpend =
|
|
15486
|
+
const toSpend = chunkSPRQOO5F_cjs.craftToSpendTx(message, pkScript, TAG_BIP322);
|
|
15488
15487
|
const toSign = craftBIP322ToSignP2TR(toSpend, pkScript, pubkey);
|
|
15489
15488
|
const sighash = toSign.preimageWitnessV1(0, [pkScript], sighashType, [0n]);
|
|
15490
15489
|
const rawSig = sig.length === 65 ? sig.subarray(0, 64) : sig;
|
|
@@ -15505,7 +15504,7 @@ function verifyP2WPKH(message, witnessItems, pkScript, addressHash) {
|
|
|
15505
15504
|
}
|
|
15506
15505
|
const sighashType = sigWithHash[sigWithHash.length - 1];
|
|
15507
15506
|
const derSig = sigWithHash.subarray(0, sigWithHash.length - 1);
|
|
15508
|
-
const toSpend =
|
|
15507
|
+
const toSpend = chunkSPRQOO5F_cjs.craftToSpendTx(message, pkScript, TAG_BIP322);
|
|
15509
15508
|
const toSign = craftBIP322ToSignSimple(toSpend, pkScript);
|
|
15510
15509
|
const scriptCode = btcSigner.OutScript.encode({ type: "pkh", hash: addressHash });
|
|
15511
15510
|
const sighash = toSign.preimageWitnessV0(0, scriptCode, sighashType, 0n);
|
|
@@ -15558,7 +15557,7 @@ function encodeCompactSize(n) {
|
|
|
15558
15557
|
return buf;
|
|
15559
15558
|
}
|
|
15560
15559
|
function craftBIP322ToSignP2TR(toSpend, pkScript, tapInternalKey) {
|
|
15561
|
-
const tx = new
|
|
15560
|
+
const tx = new chunkSPRQOO5F_cjs.Transaction({ version: 0 });
|
|
15562
15561
|
tx.addInput({
|
|
15563
15562
|
txid: toSpend.id,
|
|
15564
15563
|
index: 0,
|
|
@@ -15572,12 +15571,12 @@ function craftBIP322ToSignP2TR(toSpend, pkScript, tapInternalKey) {
|
|
|
15572
15571
|
});
|
|
15573
15572
|
tx.addOutput({
|
|
15574
15573
|
amount: 0n,
|
|
15575
|
-
script:
|
|
15574
|
+
script: chunkSPRQOO5F_cjs.OP_RETURN_EMPTY_PKSCRIPT
|
|
15576
15575
|
});
|
|
15577
15576
|
return tx;
|
|
15578
15577
|
}
|
|
15579
15578
|
function craftBIP322ToSignSimple(toSpend, pkScript) {
|
|
15580
|
-
const tx = new
|
|
15579
|
+
const tx = new chunkSPRQOO5F_cjs.Transaction({ version: 0 });
|
|
15581
15580
|
tx.addInput({
|
|
15582
15581
|
txid: toSpend.id,
|
|
15583
15582
|
index: 0,
|
|
@@ -15589,7 +15588,7 @@ function craftBIP322ToSignSimple(toSpend, pkScript) {
|
|
|
15589
15588
|
});
|
|
15590
15589
|
tx.addOutput({
|
|
15591
15590
|
amount: 0n,
|
|
15592
|
-
script:
|
|
15591
|
+
script: chunkSPRQOO5F_cjs.OP_RETURN_EMPTY_PKSCRIPT
|
|
15593
15592
|
});
|
|
15594
15593
|
return tx;
|
|
15595
15594
|
}
|
|
@@ -15650,7 +15649,7 @@ exports.Unroll = void 0;
|
|
|
15650
15649
|
if (virtualTxs.txs.length === 0) {
|
|
15651
15650
|
throw new Error(`Tx ${nextTxToBroadcast.txid} not found`);
|
|
15652
15651
|
}
|
|
15653
|
-
const tx =
|
|
15652
|
+
const tx = chunkSPRQOO5F_cjs.Transaction.fromPSBT(base.base64.decode(virtualTxs.txs[0]));
|
|
15654
15653
|
if (nextTxToBroadcast.type === "INDEXER_CHAINED_TX_TYPE_TREE" /* TREE */) {
|
|
15655
15654
|
const input = tx.getInput(0);
|
|
15656
15655
|
if (!input) {
|
|
@@ -15750,7 +15749,7 @@ async function prepareUnrollTransaction(wallet, vtxoTxIds, outputAddress) {
|
|
|
15750
15749
|
btcSigner.TaprootControlBlock.encode(spendingLeaf[0]).length
|
|
15751
15750
|
);
|
|
15752
15751
|
}
|
|
15753
|
-
const tx = new
|
|
15752
|
+
const tx = new chunkSPRQOO5F_cjs.Transaction({ version: 2 });
|
|
15754
15753
|
for (const input of inputs) {
|
|
15755
15754
|
tx.addInput(input);
|
|
15756
15755
|
}
|
|
@@ -15969,5 +15968,5 @@ exports.validateVtxoTxGraph = validateVtxoTxGraph;
|
|
|
15969
15968
|
exports.verifyTapscriptSignatures = verifyTapscriptSignatures;
|
|
15970
15969
|
exports.waitForIncomingFunds = waitForIncomingFunds;
|
|
15971
15970
|
exports.warnAndFilterVtxosForScript = warnAndFilterVtxosForScript;
|
|
15972
|
-
//# sourceMappingURL=chunk-
|
|
15973
|
-
//# sourceMappingURL=chunk-
|
|
15971
|
+
//# sourceMappingURL=chunk-MIYDTURH.cjs.map
|
|
15972
|
+
//# sourceMappingURL=chunk-MIYDTURH.cjs.map
|