@bsv/wallet-toolbox-mobile 2.1.25 → 2.1.27
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/out/src/Wallet.d.ts +46 -2
- package/out/src/Wallet.d.ts.map +1 -1
- package/out/src/Wallet.js +65 -4
- package/out/src/Wallet.js.map +1 -1
- package/out/src/mockchain/MockChainMigrations.d.ts.map +1 -1
- package/out/src/mockchain/MockChainStorage.js +3 -3
- package/out/src/mockchain/MockChainStorage.js.map +1 -1
- package/out/src/mockchain/MockMiner.js +1 -1
- package/out/src/mockchain/MockMiner.js.map +1 -1
- package/out/src/mockchain/MockServices.js +14 -13
- package/out/src/mockchain/MockServices.js.map +1 -1
- package/out/src/monitor/Monitor.js +8 -6
- package/out/src/monitor/Monitor.js.map +1 -1
- package/out/src/sdk/PrivilegedKeyManager.d.ts.map +1 -1
- package/out/src/sdk/PrivilegedKeyManager.js +6 -3
- package/out/src/sdk/PrivilegedKeyManager.js.map +1 -1
- package/out/src/sdk/WalletError.d.ts.map +1 -1
- package/out/src/sdk/WalletError.js +19 -18
- package/out/src/sdk/WalletError.js.map +1 -1
- package/out/src/sdk/WalletErrorFromJson.js +1 -1
- package/out/src/sdk/WalletErrorFromJson.js.map +1 -1
- package/out/src/sdk/WalletStorage.interfaces.d.ts +59 -59
- package/out/src/sdk/WalletStorage.interfaces.d.ts.map +1 -1
- package/out/src/services/ServiceCollection.d.ts.map +1 -1
- package/out/src/services/ServiceCollection.js +3 -4
- package/out/src/services/ServiceCollection.js.map +1 -1
- package/out/src/services/Services.d.ts.map +1 -1
- package/out/src/services/Services.js +27 -25
- package/out/src/services/Services.js.map +1 -1
- package/out/src/storage/StorageProvider.d.ts.map +1 -1
- package/out/src/storage/StorageProvider.js +35 -31
- package/out/src/storage/StorageProvider.js.map +1 -1
- package/out/src/storage/StorageReader.js +7 -7
- package/out/src/storage/StorageReader.js.map +1 -1
- package/out/src/storage/StorageReaderWriter.d.ts +0 -1
- package/out/src/storage/StorageReaderWriter.d.ts.map +1 -1
- package/out/src/storage/StorageReaderWriter.js +0 -3
- package/out/src/storage/StorageReaderWriter.js.map +1 -1
- package/out/src/storage/StorageSyncReader.js +1 -1
- package/out/src/storage/StorageSyncReader.js.map +1 -1
- package/out/src/storage/WalletStorageManager.d.ts.map +1 -1
- package/out/src/storage/WalletStorageManager.js +22 -21
- package/out/src/storage/WalletStorageManager.js.map +1 -1
- package/out/src/storage/index.mobile.d.ts +3 -0
- package/out/src/storage/index.mobile.d.ts.map +1 -1
- package/out/src/storage/index.mobile.js +3 -0
- package/out/src/storage/index.mobile.js.map +1 -1
- package/out/src/storage/methods/ListActionsSpecOp.d.ts +23 -0
- package/out/src/storage/methods/ListActionsSpecOp.d.ts.map +1 -0
- package/out/src/storage/methods/ListActionsSpecOp.js +66 -0
- package/out/src/storage/methods/ListActionsSpecOp.js.map +1 -0
- package/out/src/storage/methods/ListOutputsSpecOp.d.ts +40 -0
- package/out/src/storage/methods/ListOutputsSpecOp.d.ts.map +1 -0
- package/out/src/storage/methods/ListOutputsSpecOp.js +139 -0
- package/out/src/storage/methods/ListOutputsSpecOp.js.map +1 -0
- package/out/src/storage/portable/index.d.ts +55 -0
- package/out/src/storage/portable/index.d.ts.map +1 -0
- package/out/src/storage/portable/index.js +830 -0
- package/out/src/storage/portable/index.js.map +1 -0
- package/out/src/storage/storageProviderHelpers.js +2 -2
- package/out/src/storage/storageProviderHelpers.js.map +1 -1
- package/out/src/utility/ScriptTemplateBRC29.d.ts.map +1 -1
- package/out/src/utility/ScriptTemplateBRC29.js +3 -2
- package/out/src/utility/ScriptTemplateBRC29.js.map +1 -1
- package/out/src/utility/brc114ActionTimeLabels.js +1 -1
- package/out/src/utility/brc114ActionTimeLabels.js.map +1 -1
- package/out/src/utility/identityUtils.d.ts +12 -6
- package/out/src/utility/identityUtils.d.ts.map +1 -1
- package/out/src/utility/identityUtils.js +83 -35
- package/out/src/utility/identityUtils.js.map +1 -1
- package/out/src/utility/index.client.d.ts +1 -0
- package/out/src/utility/index.client.d.ts.map +1 -1
- package/out/src/utility/index.client.js +1 -0
- package/out/src/utility/index.client.js.map +1 -1
- package/out/src/utility/stampLog.js +3 -3
- package/out/src/utility/stampLog.js.map +1 -1
- package/out/src/utility/utilityHelpers.d.ts.map +1 -1
- package/out/src/utility/utilityHelpers.js +2 -2
- package/out/src/utility/utilityHelpers.js.map +1 -1
- package/out/src/wab-client/WABClient.d.ts +2 -2
- package/out/src/wab-client/WABClient.d.ts.map +1 -1
- package/package.json +1 -1
|
@@ -0,0 +1,139 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getListOutputsSpecOp = getListOutputsSpecOp;
|
|
4
|
+
const types_1 = require("../../sdk/types");
|
|
5
|
+
const utilityHelpers_1 = require("../../utility/utilityHelpers");
|
|
6
|
+
const WERR_errors_1 = require("../../sdk/WERR_errors");
|
|
7
|
+
const INVALID_CHANGE_MAX_CONCURRENCY = 12;
|
|
8
|
+
async function runWithConcurrency(values, maxConcurrency, worker) {
|
|
9
|
+
const active = [];
|
|
10
|
+
for (const value of values) {
|
|
11
|
+
const task = worker(value).finally(() => {
|
|
12
|
+
const i = active.indexOf(task);
|
|
13
|
+
if (i >= 0)
|
|
14
|
+
active.splice(i, 1);
|
|
15
|
+
});
|
|
16
|
+
active.push(task);
|
|
17
|
+
if (active.length >= maxConcurrency) {
|
|
18
|
+
await Promise.race(active);
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
await Promise.all(active);
|
|
22
|
+
}
|
|
23
|
+
const getBasketToSpecOp = () => {
|
|
24
|
+
return {
|
|
25
|
+
[types_1.specOpWalletBalance]: {
|
|
26
|
+
name: 'totalOutputsIsWalletBalance',
|
|
27
|
+
useBasket: 'default',
|
|
28
|
+
ignoreLimit: true,
|
|
29
|
+
totalOutputsIsSumOfSatoshis: true,
|
|
30
|
+
resultFromOutputs: async (s, auth, vargs, specOpTags, outputs) => {
|
|
31
|
+
let totalOutputs = 0;
|
|
32
|
+
for (const o of outputs)
|
|
33
|
+
totalOutputs += o.satoshis;
|
|
34
|
+
return { totalOutputs, outputs: [] };
|
|
35
|
+
}
|
|
36
|
+
},
|
|
37
|
+
[types_1.specOpInvalidChange]: {
|
|
38
|
+
name: 'invalidChangeOutputs',
|
|
39
|
+
useBasket: 'default',
|
|
40
|
+
ignoreLimit: true,
|
|
41
|
+
includeOutputScripts: true,
|
|
42
|
+
includeSpent: false,
|
|
43
|
+
tagsToIntercept: ['release', 'all'],
|
|
44
|
+
filterOutputs: async (s, auth, vargs, specOpTags, outputs) => {
|
|
45
|
+
const invalidOutputIds = new Set();
|
|
46
|
+
const services = s.getServices();
|
|
47
|
+
await runWithConcurrency(outputs, INVALID_CHANGE_MAX_CONCURRENCY, async (o) => {
|
|
48
|
+
if (!o.basketId)
|
|
49
|
+
return; // only care about outputs assigned to baskets.
|
|
50
|
+
await s.validateOutputScript(o);
|
|
51
|
+
let ok = false;
|
|
52
|
+
if ((o.lockingScript != null) && o.lockingScript.length > 0) {
|
|
53
|
+
ok = await services.isUtxo(o);
|
|
54
|
+
}
|
|
55
|
+
else {
|
|
56
|
+
ok = undefined;
|
|
57
|
+
}
|
|
58
|
+
if (ok === false) {
|
|
59
|
+
invalidOutputIds.add(o.outputId);
|
|
60
|
+
}
|
|
61
|
+
});
|
|
62
|
+
const filteredOutputs = outputs.filter(o => invalidOutputIds.has(o.outputId));
|
|
63
|
+
if (specOpTags.includes('release')) {
|
|
64
|
+
await runWithConcurrency(filteredOutputs, INVALID_CHANGE_MAX_CONCURRENCY, async (o) => {
|
|
65
|
+
await s.updateOutput(o.outputId, { spendable: false });
|
|
66
|
+
o.spendable = false;
|
|
67
|
+
});
|
|
68
|
+
}
|
|
69
|
+
return filteredOutputs;
|
|
70
|
+
}
|
|
71
|
+
},
|
|
72
|
+
[types_1.specOpSetWalletChangeParams]: {
|
|
73
|
+
name: 'setWalletChangeParams',
|
|
74
|
+
tagsParamsCount: 2,
|
|
75
|
+
resultFromTags: async (s, auth, vargs, specOpTags) => {
|
|
76
|
+
if (specOpTags.length !== 2) {
|
|
77
|
+
throw new WERR_errors_1.WERR_INVALID_PARAMETER('numberOfDesiredUTXOs and minimumDesiredUTXOValue', 'valid');
|
|
78
|
+
}
|
|
79
|
+
const numberOfDesiredUTXOs = (0, utilityHelpers_1.verifyInteger)(Number(specOpTags[0]));
|
|
80
|
+
const minimumDesiredUTXOValue = (0, utilityHelpers_1.verifyInteger)(Number(specOpTags[1]));
|
|
81
|
+
const basket = (0, utilityHelpers_1.verifyOne)(await s.findOutputBaskets({
|
|
82
|
+
partial: { userId: (0, utilityHelpers_1.verifyId)(auth.userId), name: 'default' }
|
|
83
|
+
}));
|
|
84
|
+
await s.updateOutputBasket(basket.basketId, {
|
|
85
|
+
numberOfDesiredUTXOs,
|
|
86
|
+
minimumDesiredUTXOValue
|
|
87
|
+
});
|
|
88
|
+
return { totalOutputs: 0, outputs: [] };
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
};
|
|
92
|
+
};
|
|
93
|
+
const getTagToSpecOp = () => {
|
|
94
|
+
return {
|
|
95
|
+
[types_1.specOpWalletBalance]: {
|
|
96
|
+
name: 'totalOutputsIsWalletBalance',
|
|
97
|
+
useBasket: 'default',
|
|
98
|
+
ignoreLimit: true,
|
|
99
|
+
totalOutputsIsSumOfSatoshis: true,
|
|
100
|
+
resultFromOutputs: async (s, auth, vargs, specOpTags, outputs) => {
|
|
101
|
+
let totalOutputs = 0;
|
|
102
|
+
for (const o of outputs)
|
|
103
|
+
totalOutputs += o.satoshis;
|
|
104
|
+
return { totalOutputs, outputs: [] };
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
};
|
|
108
|
+
};
|
|
109
|
+
let _basketSpecOps;
|
|
110
|
+
let _tagSpecOps;
|
|
111
|
+
/**
|
|
112
|
+
* Check basket and tags arguments passed to listOutputs to determine if they trigger a special operation execution mode.
|
|
113
|
+
* @param basket
|
|
114
|
+
* @param tags
|
|
115
|
+
* @returns
|
|
116
|
+
*/
|
|
117
|
+
function getListOutputsSpecOp(basket, tags) {
|
|
118
|
+
let specOp;
|
|
119
|
+
if (basket) {
|
|
120
|
+
_basketSpecOps !== null && _basketSpecOps !== void 0 ? _basketSpecOps : (_basketSpecOps = getBasketToSpecOp());
|
|
121
|
+
specOp = _basketSpecOps[basket];
|
|
122
|
+
if (specOp) {
|
|
123
|
+
return { specOp, basket: specOp.useBasket, tags: tags || [] };
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
if (tags) {
|
|
127
|
+
_tagSpecOps !== null && _tagSpecOps !== void 0 ? _tagSpecOps : (_tagSpecOps = getTagToSpecOp());
|
|
128
|
+
for (const tag of tags) {
|
|
129
|
+
specOp = _tagSpecOps[tag];
|
|
130
|
+
if (specOp) {
|
|
131
|
+
if (!basket && specOp.useBasket)
|
|
132
|
+
basket = specOp.useBasket;
|
|
133
|
+
return { specOp, basket, tags: tags.filter(t => t !== tag) };
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
return { specOp: undefined, basket, tags };
|
|
138
|
+
}
|
|
139
|
+
//# sourceMappingURL=ListOutputsSpecOp.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ListOutputsSpecOp.js","sourceRoot":"","sources":["../../../../../src/storage/methods/ListOutputsSpecOp.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import { StorageProvider } from '../StorageProvider';
|
|
2
|
+
type JsonPrimitive = string | number | boolean;
|
|
3
|
+
type JsonValue = JsonPrimitive | JsonValue[] | {
|
|
4
|
+
[key: string]: JsonValue;
|
|
5
|
+
};
|
|
6
|
+
type PortableRow = Record<string, JsonValue>;
|
|
7
|
+
export interface BRC38Tables {
|
|
8
|
+
provenTxs: PortableRow[];
|
|
9
|
+
provenTxReqs: PortableRow[];
|
|
10
|
+
outputBaskets: PortableRow[];
|
|
11
|
+
transactions: PortableRow[];
|
|
12
|
+
commissions: PortableRow[];
|
|
13
|
+
outputs: PortableRow[];
|
|
14
|
+
outputTags: PortableRow[];
|
|
15
|
+
outputTagMaps: PortableRow[];
|
|
16
|
+
txLabels: PortableRow[];
|
|
17
|
+
txLabelMaps: PortableRow[];
|
|
18
|
+
certificates: PortableRow[];
|
|
19
|
+
certificateFields: PortableRow[];
|
|
20
|
+
syncStates: PortableRow[];
|
|
21
|
+
}
|
|
22
|
+
export interface BRC38WalletData {
|
|
23
|
+
brc: 38;
|
|
24
|
+
title: 'User Wallet Data Format';
|
|
25
|
+
formatVersion: 1;
|
|
26
|
+
exportedAt: string;
|
|
27
|
+
sourceStorage: PortableRow;
|
|
28
|
+
user: PortableRow;
|
|
29
|
+
tables: BRC38Tables;
|
|
30
|
+
}
|
|
31
|
+
export interface BRC38ImportOptions {
|
|
32
|
+
mode: 'merge' | 'restore';
|
|
33
|
+
}
|
|
34
|
+
export interface BRC38ImportResult {
|
|
35
|
+
mode: 'merge' | 'restore';
|
|
36
|
+
identityKey: string;
|
|
37
|
+
userId: number;
|
|
38
|
+
inserts: number;
|
|
39
|
+
updates: number;
|
|
40
|
+
}
|
|
41
|
+
export interface BRC39Options {
|
|
42
|
+
iterations?: number;
|
|
43
|
+
memoryKiB?: number;
|
|
44
|
+
parallelism?: number;
|
|
45
|
+
}
|
|
46
|
+
export declare function exportBRC38(storage: StorageProvider, identityKey: string): Promise<BRC38WalletData>;
|
|
47
|
+
export declare function exportBRC38Json(storage: StorageProvider, identityKey: string): Promise<string>;
|
|
48
|
+
export declare function parseBRC38Json(json: string): BRC38WalletData;
|
|
49
|
+
export declare function importBRC38(storage: StorageProvider, documentOrJson: BRC38WalletData | string, options: BRC38ImportOptions): Promise<BRC38ImportResult>;
|
|
50
|
+
export declare function exportBRC39(storage: StorageProvider, identityKey: string, password: string, options?: BRC39Options): Promise<number[]>;
|
|
51
|
+
export declare function importBRC39(storage: StorageProvider, bytes: number[] | Uint8Array, password: string, options: BRC38ImportOptions): Promise<BRC38ImportResult>;
|
|
52
|
+
export declare function encryptBRC39(documentOrJson: BRC38WalletData | string, password: string, options?: BRC39Options): Promise<number[]>;
|
|
53
|
+
export declare function decryptBRC39(bytes: number[] | Uint8Array, password: string): Promise<BRC38WalletData>;
|
|
54
|
+
export {};
|
|
55
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/storage/portable/index.ts"],"names":[],"mappings":"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"}
|