@atomiqlabs/lp-lib 14.0.0-dev.13 → 14.0.0-dev.16
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/LICENSE +201 -201
- package/dist/fees/IBtcFeeEstimator.d.ts +3 -3
- package/dist/fees/IBtcFeeEstimator.js +2 -2
- package/dist/index.d.ts +42 -42
- package/dist/index.js +58 -58
- package/dist/info/InfoHandler.d.ts +17 -17
- package/dist/info/InfoHandler.js +61 -61
- package/dist/plugins/IPlugin.d.ts +143 -143
- package/dist/plugins/IPlugin.js +34 -34
- package/dist/plugins/PluginManager.d.ts +112 -112
- package/dist/plugins/PluginManager.js +259 -259
- package/dist/prices/BinanceSwapPrice.d.ts +26 -26
- package/dist/prices/BinanceSwapPrice.js +92 -92
- package/dist/prices/CoinGeckoSwapPrice.d.ts +30 -30
- package/dist/prices/CoinGeckoSwapPrice.js +64 -64
- package/dist/prices/ISwapPrice.d.ts +43 -43
- package/dist/prices/ISwapPrice.js +55 -55
- package/dist/prices/OKXSwapPrice.d.ts +26 -26
- package/dist/prices/OKXSwapPrice.js +92 -92
- package/dist/storage/IIntermediaryStorage.d.ts +18 -18
- package/dist/storage/IIntermediaryStorage.js +2 -2
- package/dist/storagemanager/IntermediaryStorageManager.d.ts +19 -19
- package/dist/storagemanager/IntermediaryStorageManager.js +111 -111
- package/dist/storagemanager/StorageManager.d.ts +13 -13
- package/dist/storagemanager/StorageManager.js +64 -64
- package/dist/swaps/SwapHandler.d.ts +153 -153
- package/dist/swaps/SwapHandler.js +160 -160
- package/dist/swaps/SwapHandlerSwap.d.ts +79 -79
- package/dist/swaps/SwapHandlerSwap.js +78 -78
- package/dist/swaps/assertions/AmountAssertions.d.ts +28 -28
- package/dist/swaps/assertions/AmountAssertions.js +72 -72
- package/dist/swaps/assertions/FromBtcAmountAssertions.d.ts +76 -76
- package/dist/swaps/assertions/FromBtcAmountAssertions.js +180 -172
- package/dist/swaps/assertions/LightningAssertions.d.ts +44 -44
- package/dist/swaps/assertions/LightningAssertions.js +86 -86
- package/dist/swaps/assertions/ToBtcAmountAssertions.d.ts +53 -53
- package/dist/swaps/assertions/ToBtcAmountAssertions.js +150 -150
- package/dist/swaps/escrow/EscrowHandler.d.ts +51 -51
- package/dist/swaps/escrow/EscrowHandler.js +158 -158
- package/dist/swaps/escrow/EscrowHandlerSwap.d.ts +35 -35
- package/dist/swaps/escrow/EscrowHandlerSwap.js +69 -69
- package/dist/swaps/escrow/FromBtcBaseSwap.d.ts +14 -14
- package/dist/swaps/escrow/FromBtcBaseSwap.js +32 -32
- package/dist/swaps/escrow/FromBtcBaseSwapHandler.d.ts +102 -102
- package/dist/swaps/escrow/FromBtcBaseSwapHandler.js +210 -210
- package/dist/swaps/escrow/ToBtcBaseSwap.d.ts +36 -36
- package/dist/swaps/escrow/ToBtcBaseSwap.js +67 -67
- package/dist/swaps/escrow/ToBtcBaseSwapHandler.d.ts +53 -53
- package/dist/swaps/escrow/ToBtcBaseSwapHandler.js +81 -81
- package/dist/swaps/escrow/frombtc_abstract/FromBtcAbs.d.ts +83 -83
- package/dist/swaps/escrow/frombtc_abstract/FromBtcAbs.js +318 -318
- package/dist/swaps/escrow/frombtc_abstract/FromBtcSwapAbs.d.ts +21 -21
- package/dist/swaps/escrow/frombtc_abstract/FromBtcSwapAbs.js +50 -50
- package/dist/swaps/escrow/frombtcln_abstract/FromBtcLnAbs.d.ts +107 -107
- package/dist/swaps/escrow/frombtcln_abstract/FromBtcLnAbs.js +675 -675
- package/dist/swaps/escrow/frombtcln_abstract/FromBtcLnSwapAbs.d.ts +33 -33
- package/dist/swaps/escrow/frombtcln_abstract/FromBtcLnSwapAbs.js +91 -91
- package/dist/swaps/escrow/frombtcln_autoinit/FromBtcLnAuto.d.ts +104 -104
- package/dist/swaps/escrow/frombtcln_autoinit/FromBtcLnAuto.js +659 -659
- package/dist/swaps/escrow/frombtcln_autoinit/FromBtcLnAutoSwap.d.ts +55 -55
- package/dist/swaps/escrow/frombtcln_autoinit/FromBtcLnAutoSwap.js +120 -120
- package/dist/swaps/escrow/tobtc_abstract/ToBtcAbs.d.ts +171 -171
- package/dist/swaps/escrow/tobtc_abstract/ToBtcAbs.js +706 -706
- package/dist/swaps/escrow/tobtc_abstract/ToBtcSwapAbs.d.ts +26 -26
- package/dist/swaps/escrow/tobtc_abstract/ToBtcSwapAbs.js +62 -62
- package/dist/swaps/escrow/tobtcln_abstract/ToBtcLnAbs.d.ts +177 -177
- package/dist/swaps/escrow/tobtcln_abstract/ToBtcLnAbs.js +861 -861
- package/dist/swaps/escrow/tobtcln_abstract/ToBtcLnSwapAbs.d.ts +23 -23
- package/dist/swaps/escrow/tobtcln_abstract/ToBtcLnSwapAbs.js +56 -56
- package/dist/swaps/spv_vault_swap/SpvVault.d.ts +41 -41
- package/dist/swaps/spv_vault_swap/SpvVault.js +111 -111
- package/dist/swaps/spv_vault_swap/SpvVaultSwap.d.ts +67 -67
- package/dist/swaps/spv_vault_swap/SpvVaultSwap.js +158 -158
- package/dist/swaps/spv_vault_swap/SpvVaultSwapHandler.d.ts +68 -68
- package/dist/swaps/spv_vault_swap/SpvVaultSwapHandler.js +491 -491
- package/dist/swaps/spv_vault_swap/SpvVaults.d.ts +52 -52
- package/dist/swaps/spv_vault_swap/SpvVaults.js +364 -364
- package/dist/swaps/trusted/frombtc_trusted/FromBtcTrusted.d.ts +51 -51
- package/dist/swaps/trusted/frombtc_trusted/FromBtcTrusted.js +650 -650
- package/dist/swaps/trusted/frombtc_trusted/FromBtcTrustedSwap.d.ts +52 -52
- package/dist/swaps/trusted/frombtc_trusted/FromBtcTrustedSwap.js +118 -118
- package/dist/swaps/trusted/frombtcln_trusted/FromBtcLnTrusted.d.ts +76 -76
- package/dist/swaps/trusted/frombtcln_trusted/FromBtcLnTrusted.js +494 -494
- package/dist/swaps/trusted/frombtcln_trusted/FromBtcLnTrustedSwap.d.ts +34 -34
- package/dist/swaps/trusted/frombtcln_trusted/FromBtcLnTrustedSwap.js +81 -81
- package/dist/utils/Utils.d.ts +29 -29
- package/dist/utils/Utils.js +89 -89
- package/dist/utils/paramcoders/IParamReader.d.ts +5 -5
- package/dist/utils/paramcoders/IParamReader.js +2 -2
- package/dist/utils/paramcoders/IParamWriter.d.ts +4 -4
- package/dist/utils/paramcoders/IParamWriter.js +2 -2
- package/dist/utils/paramcoders/LegacyParamEncoder.d.ts +10 -10
- package/dist/utils/paramcoders/LegacyParamEncoder.js +22 -22
- package/dist/utils/paramcoders/ParamDecoder.d.ts +25 -25
- package/dist/utils/paramcoders/ParamDecoder.js +222 -222
- package/dist/utils/paramcoders/ParamEncoder.d.ts +9 -9
- package/dist/utils/paramcoders/ParamEncoder.js +22 -22
- package/dist/utils/paramcoders/SchemaVerifier.d.ts +21 -21
- package/dist/utils/paramcoders/SchemaVerifier.js +84 -84
- package/dist/utils/paramcoders/server/ServerParamDecoder.d.ts +8 -8
- package/dist/utils/paramcoders/server/ServerParamDecoder.js +107 -107
- package/dist/utils/paramcoders/server/ServerParamEncoder.d.ts +11 -11
- package/dist/utils/paramcoders/server/ServerParamEncoder.js +65 -65
- package/dist/wallets/IBitcoinWallet.d.ts +67 -67
- package/dist/wallets/IBitcoinWallet.js +2 -2
- package/dist/wallets/ILightningWallet.d.ts +117 -117
- package/dist/wallets/ILightningWallet.js +37 -37
- package/dist/wallets/ISpvVaultSigner.d.ts +7 -7
- package/dist/wallets/ISpvVaultSigner.js +2 -2
- package/package.json +36 -36
- package/src/fees/IBtcFeeEstimator.ts +6 -6
- package/src/index.ts +53 -53
- package/src/info/InfoHandler.ts +106 -106
- package/src/plugins/IPlugin.ts +168 -168
- package/src/plugins/PluginManager.ts +336 -336
- package/src/prices/BinanceSwapPrice.ts +113 -113
- package/src/prices/CoinGeckoSwapPrice.ts +87 -87
- package/src/prices/ISwapPrice.ts +88 -88
- package/src/prices/OKXSwapPrice.ts +113 -113
- package/src/storage/IIntermediaryStorage.ts +19 -19
- package/src/storagemanager/IntermediaryStorageManager.ts +118 -118
- package/src/storagemanager/StorageManager.ts +78 -78
- package/src/swaps/SwapHandler.ts +277 -277
- package/src/swaps/SwapHandlerSwap.ts +141 -141
- package/src/swaps/assertions/AmountAssertions.ts +76 -76
- package/src/swaps/assertions/FromBtcAmountAssertions.ts +246 -238
- package/src/swaps/assertions/LightningAssertions.ts +103 -103
- package/src/swaps/assertions/ToBtcAmountAssertions.ts +203 -203
- package/src/swaps/escrow/EscrowHandler.ts +179 -179
- package/src/swaps/escrow/EscrowHandlerSwap.ts +86 -86
- package/src/swaps/escrow/FromBtcBaseSwap.ts +38 -38
- package/src/swaps/escrow/FromBtcBaseSwapHandler.ts +286 -286
- package/src/swaps/escrow/ToBtcBaseSwap.ts +85 -85
- package/src/swaps/escrow/ToBtcBaseSwapHandler.ts +129 -129
- package/src/swaps/escrow/frombtc_abstract/FromBtcAbs.ts +452 -452
- package/src/swaps/escrow/frombtc_abstract/FromBtcSwapAbs.ts +61 -61
- package/src/swaps/escrow/frombtcln_abstract/FromBtcLnAbs.ts +856 -856
- package/src/swaps/escrow/frombtcln_abstract/FromBtcLnSwapAbs.ts +141 -141
- package/src/swaps/escrow/frombtcln_autoinit/FromBtcLnAuto.ts +822 -822
- package/src/swaps/escrow/frombtcln_autoinit/FromBtcLnAutoSwap.ts +196 -196
- package/src/swaps/escrow/tobtc_abstract/ToBtcAbs.ts +879 -879
- package/src/swaps/escrow/tobtc_abstract/ToBtcSwapAbs.ts +102 -102
- package/src/swaps/escrow/tobtcln_abstract/ToBtcLnAbs.ts +1110 -1110
- package/src/swaps/escrow/tobtcln_abstract/ToBtcLnSwapAbs.ts +77 -77
- package/src/swaps/spv_vault_swap/SpvVault.ts +143 -143
- package/src/swaps/spv_vault_swap/SpvVaultSwap.ts +225 -225
- package/src/swaps/spv_vault_swap/SpvVaultSwapHandler.ts +627 -627
- package/src/swaps/spv_vault_swap/SpvVaults.ts +435 -435
- package/src/swaps/trusted/frombtc_trusted/FromBtcTrusted.ts +747 -747
- package/src/swaps/trusted/frombtc_trusted/FromBtcTrustedSwap.ts +185 -185
- package/src/swaps/trusted/frombtcln_trusted/FromBtcLnTrusted.ts +590 -590
- package/src/swaps/trusted/frombtcln_trusted/FromBtcLnTrustedSwap.ts +121 -121
- package/src/utils/Utils.ts +104 -104
- package/src/utils/paramcoders/IParamReader.ts +7 -7
- package/src/utils/paramcoders/IParamWriter.ts +8 -8
- package/src/utils/paramcoders/LegacyParamEncoder.ts +27 -27
- package/src/utils/paramcoders/ParamDecoder.ts +218 -218
- package/src/utils/paramcoders/ParamEncoder.ts +29 -29
- package/src/utils/paramcoders/SchemaVerifier.ts +96 -96
- package/src/utils/paramcoders/server/ServerParamDecoder.ts +118 -118
- package/src/utils/paramcoders/server/ServerParamEncoder.ts +75 -75
- package/src/wallets/IBitcoinWallet.ts +68 -68
- package/src/wallets/ILightningWallet.ts +178 -178
- package/src/wallets/ISpvVaultSigner.ts +10 -10
|
@@ -1,92 +1,92 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.OKXSwapPrice = void 0;
|
|
4
|
-
const ISwapPrice_1 = require("./ISwapPrice");
|
|
5
|
-
const CACHE_DURATION = 15000;
|
|
6
|
-
class OKXSwapPrice extends ISwapPrice_1.ISwapPrice {
|
|
7
|
-
constructor(url, coins) {
|
|
8
|
-
const coinsMap = {};
|
|
9
|
-
for (let pair in coins) {
|
|
10
|
-
const chains = coins[pair];
|
|
11
|
-
for (let chainId in chains) {
|
|
12
|
-
const tokenData = chains[chainId];
|
|
13
|
-
if (coinsMap[chainId] == null)
|
|
14
|
-
coinsMap[chainId] = {};
|
|
15
|
-
coinsMap[chainId][tokenData.address] = {
|
|
16
|
-
pair,
|
|
17
|
-
decimals: tokenData.decimals
|
|
18
|
-
};
|
|
19
|
-
}
|
|
20
|
-
}
|
|
21
|
-
super(coinsMap);
|
|
22
|
-
this.cache = {};
|
|
23
|
-
this.url = url || "https://www.okx.com/api/v5";
|
|
24
|
-
}
|
|
25
|
-
async fetchPrice(pair) {
|
|
26
|
-
const response = await fetch(this.url + "/market/index-tickers?instId=" + pair, {
|
|
27
|
-
method: "GET"
|
|
28
|
-
});
|
|
29
|
-
if (response.status !== 200) {
|
|
30
|
-
let resp;
|
|
31
|
-
try {
|
|
32
|
-
resp = await response.text();
|
|
33
|
-
}
|
|
34
|
-
catch (e) {
|
|
35
|
-
throw new Error(response.statusText);
|
|
36
|
-
}
|
|
37
|
-
throw new Error(resp);
|
|
38
|
-
}
|
|
39
|
-
let jsonBody = await response.json();
|
|
40
|
-
return parseFloat(jsonBody.data[0].idxPx);
|
|
41
|
-
}
|
|
42
|
-
async getPrice(tokenData) {
|
|
43
|
-
const pair = tokenData.pair;
|
|
44
|
-
if (pair.startsWith("$fixed-")) {
|
|
45
|
-
const amt = parseFloat(pair.substring(7));
|
|
46
|
-
return BigInt(Math.floor(amt * 1000000));
|
|
47
|
-
}
|
|
48
|
-
const arr = pair.split(";");
|
|
49
|
-
const promises = [];
|
|
50
|
-
const cachedValue = this.cache[pair];
|
|
51
|
-
if (cachedValue == null || cachedValue.expiry < Date.now()) {
|
|
52
|
-
let resultPrice = 1;
|
|
53
|
-
for (let pair of arr) {
|
|
54
|
-
let invert = false;
|
|
55
|
-
if (pair.startsWith("!")) {
|
|
56
|
-
invert = true;
|
|
57
|
-
pair = pair.substring(1);
|
|
58
|
-
}
|
|
59
|
-
const cachedValue = this.cache[pair];
|
|
60
|
-
if (cachedValue == null || cachedValue.expiry < Date.now()) {
|
|
61
|
-
promises.push(this.fetchPrice(pair).then(price => {
|
|
62
|
-
this.cache[pair] = {
|
|
63
|
-
price,
|
|
64
|
-
expiry: Date.now() + CACHE_DURATION
|
|
65
|
-
};
|
|
66
|
-
if (invert) {
|
|
67
|
-
resultPrice /= price;
|
|
68
|
-
}
|
|
69
|
-
else {
|
|
70
|
-
resultPrice *= price;
|
|
71
|
-
}
|
|
72
|
-
}));
|
|
73
|
-
}
|
|
74
|
-
else {
|
|
75
|
-
if (invert) {
|
|
76
|
-
resultPrice /= cachedValue.price;
|
|
77
|
-
}
|
|
78
|
-
else {
|
|
79
|
-
resultPrice *= cachedValue.price;
|
|
80
|
-
}
|
|
81
|
-
}
|
|
82
|
-
}
|
|
83
|
-
await Promise.all(promises);
|
|
84
|
-
this.cache[pair] = {
|
|
85
|
-
price: resultPrice,
|
|
86
|
-
expiry: Date.now() + CACHE_DURATION
|
|
87
|
-
};
|
|
88
|
-
}
|
|
89
|
-
return BigInt(Math.floor(this.cache[pair].price * 100000000000000));
|
|
90
|
-
}
|
|
91
|
-
}
|
|
92
|
-
exports.OKXSwapPrice = OKXSwapPrice;
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.OKXSwapPrice = void 0;
|
|
4
|
+
const ISwapPrice_1 = require("./ISwapPrice");
|
|
5
|
+
const CACHE_DURATION = 15000;
|
|
6
|
+
class OKXSwapPrice extends ISwapPrice_1.ISwapPrice {
|
|
7
|
+
constructor(url, coins) {
|
|
8
|
+
const coinsMap = {};
|
|
9
|
+
for (let pair in coins) {
|
|
10
|
+
const chains = coins[pair];
|
|
11
|
+
for (let chainId in chains) {
|
|
12
|
+
const tokenData = chains[chainId];
|
|
13
|
+
if (coinsMap[chainId] == null)
|
|
14
|
+
coinsMap[chainId] = {};
|
|
15
|
+
coinsMap[chainId][tokenData.address] = {
|
|
16
|
+
pair,
|
|
17
|
+
decimals: tokenData.decimals
|
|
18
|
+
};
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
super(coinsMap);
|
|
22
|
+
this.cache = {};
|
|
23
|
+
this.url = url || "https://www.okx.com/api/v5";
|
|
24
|
+
}
|
|
25
|
+
async fetchPrice(pair) {
|
|
26
|
+
const response = await fetch(this.url + "/market/index-tickers?instId=" + pair, {
|
|
27
|
+
method: "GET"
|
|
28
|
+
});
|
|
29
|
+
if (response.status !== 200) {
|
|
30
|
+
let resp;
|
|
31
|
+
try {
|
|
32
|
+
resp = await response.text();
|
|
33
|
+
}
|
|
34
|
+
catch (e) {
|
|
35
|
+
throw new Error(response.statusText);
|
|
36
|
+
}
|
|
37
|
+
throw new Error(resp);
|
|
38
|
+
}
|
|
39
|
+
let jsonBody = await response.json();
|
|
40
|
+
return parseFloat(jsonBody.data[0].idxPx);
|
|
41
|
+
}
|
|
42
|
+
async getPrice(tokenData) {
|
|
43
|
+
const pair = tokenData.pair;
|
|
44
|
+
if (pair.startsWith("$fixed-")) {
|
|
45
|
+
const amt = parseFloat(pair.substring(7));
|
|
46
|
+
return BigInt(Math.floor(amt * 1000000));
|
|
47
|
+
}
|
|
48
|
+
const arr = pair.split(";");
|
|
49
|
+
const promises = [];
|
|
50
|
+
const cachedValue = this.cache[pair];
|
|
51
|
+
if (cachedValue == null || cachedValue.expiry < Date.now()) {
|
|
52
|
+
let resultPrice = 1;
|
|
53
|
+
for (let pair of arr) {
|
|
54
|
+
let invert = false;
|
|
55
|
+
if (pair.startsWith("!")) {
|
|
56
|
+
invert = true;
|
|
57
|
+
pair = pair.substring(1);
|
|
58
|
+
}
|
|
59
|
+
const cachedValue = this.cache[pair];
|
|
60
|
+
if (cachedValue == null || cachedValue.expiry < Date.now()) {
|
|
61
|
+
promises.push(this.fetchPrice(pair).then(price => {
|
|
62
|
+
this.cache[pair] = {
|
|
63
|
+
price,
|
|
64
|
+
expiry: Date.now() + CACHE_DURATION
|
|
65
|
+
};
|
|
66
|
+
if (invert) {
|
|
67
|
+
resultPrice /= price;
|
|
68
|
+
}
|
|
69
|
+
else {
|
|
70
|
+
resultPrice *= price;
|
|
71
|
+
}
|
|
72
|
+
}));
|
|
73
|
+
}
|
|
74
|
+
else {
|
|
75
|
+
if (invert) {
|
|
76
|
+
resultPrice /= cachedValue.price;
|
|
77
|
+
}
|
|
78
|
+
else {
|
|
79
|
+
resultPrice *= cachedValue.price;
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
await Promise.all(promises);
|
|
84
|
+
this.cache[pair] = {
|
|
85
|
+
price: resultPrice,
|
|
86
|
+
expiry: Date.now() + CACHE_DURATION
|
|
87
|
+
};
|
|
88
|
+
}
|
|
89
|
+
return BigInt(Math.floor(this.cache[pair].price * 100000000000000));
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
exports.OKXSwapPrice = OKXSwapPrice;
|
|
@@ -1,18 +1,18 @@
|
|
|
1
|
-
import { StorageObject } from "@atomiqlabs/base";
|
|
2
|
-
export type StorageQueryParam = {
|
|
3
|
-
key: string;
|
|
4
|
-
value?: any;
|
|
5
|
-
values?: any[];
|
|
6
|
-
};
|
|
7
|
-
export interface IIntermediaryStorage<T extends StorageObject> {
|
|
8
|
-
init(): Promise<void>;
|
|
9
|
-
query(params: StorageQueryParam[]): Promise<{
|
|
10
|
-
hash: string;
|
|
11
|
-
sequence: bigint;
|
|
12
|
-
obj: T;
|
|
13
|
-
}[]>;
|
|
14
|
-
getData(hash: string, sequence: bigint | null): Promise<T>;
|
|
15
|
-
saveData(hash: string, sequence: bigint | null, object: T): Promise<void>;
|
|
16
|
-
removeData(hash: string, sequence: bigint | null): Promise<void>;
|
|
17
|
-
loadData(type: new (data: any) => T): Promise<void>;
|
|
18
|
-
}
|
|
1
|
+
import { StorageObject } from "@atomiqlabs/base";
|
|
2
|
+
export type StorageQueryParam = {
|
|
3
|
+
key: string;
|
|
4
|
+
value?: any;
|
|
5
|
+
values?: any[];
|
|
6
|
+
};
|
|
7
|
+
export interface IIntermediaryStorage<T extends StorageObject> {
|
|
8
|
+
init(): Promise<void>;
|
|
9
|
+
query(params: StorageQueryParam[]): Promise<{
|
|
10
|
+
hash: string;
|
|
11
|
+
sequence: bigint;
|
|
12
|
+
obj: T;
|
|
13
|
+
}[]>;
|
|
14
|
+
getData(hash: string, sequence: bigint | null): Promise<T>;
|
|
15
|
+
saveData(hash: string, sequence: bigint | null, object: T): Promise<void>;
|
|
16
|
+
removeData(hash: string, sequence: bigint | null): Promise<void>;
|
|
17
|
+
loadData(type: new (data: any) => T): Promise<void>;
|
|
18
|
+
}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
@@ -1,19 +1,19 @@
|
|
|
1
|
-
import { StorageObject } from "@atomiqlabs/base";
|
|
2
|
-
import { IIntermediaryStorage, StorageQueryParam } from "../storage/IIntermediaryStorage";
|
|
3
|
-
export declare class IntermediaryStorageManager<T extends StorageObject> implements IIntermediaryStorage<T> {
|
|
4
|
-
private readonly directory;
|
|
5
|
-
private type;
|
|
6
|
-
private data;
|
|
7
|
-
private logger;
|
|
8
|
-
constructor(directory: string);
|
|
9
|
-
init(): Promise<void>;
|
|
10
|
-
query(params: StorageQueryParam[]): Promise<{
|
|
11
|
-
hash: string;
|
|
12
|
-
sequence: bigint;
|
|
13
|
-
obj: T;
|
|
14
|
-
}[]>;
|
|
15
|
-
getData(paymentHash: string, sequence: bigint | null): Promise<T>;
|
|
16
|
-
saveData(hash: string, sequence: bigint | null, object: T): Promise<void>;
|
|
17
|
-
removeData(hash: string, sequence: bigint | null): Promise<void>;
|
|
18
|
-
loadData(type: new (data: any) => T): Promise<void>;
|
|
19
|
-
}
|
|
1
|
+
import { StorageObject } from "@atomiqlabs/base";
|
|
2
|
+
import { IIntermediaryStorage, StorageQueryParam } from "../storage/IIntermediaryStorage";
|
|
3
|
+
export declare class IntermediaryStorageManager<T extends StorageObject> implements IIntermediaryStorage<T> {
|
|
4
|
+
private readonly directory;
|
|
5
|
+
private type;
|
|
6
|
+
private data;
|
|
7
|
+
private logger;
|
|
8
|
+
constructor(directory: string);
|
|
9
|
+
init(): Promise<void>;
|
|
10
|
+
query(params: StorageQueryParam[]): Promise<{
|
|
11
|
+
hash: string;
|
|
12
|
+
sequence: bigint;
|
|
13
|
+
obj: T;
|
|
14
|
+
}[]>;
|
|
15
|
+
getData(paymentHash: string, sequence: bigint | null): Promise<T>;
|
|
16
|
+
saveData(hash: string, sequence: bigint | null, object: T): Promise<void>;
|
|
17
|
+
removeData(hash: string, sequence: bigint | null): Promise<void>;
|
|
18
|
+
loadData(type: new (data: any) => T): Promise<void>;
|
|
19
|
+
}
|
|
@@ -1,111 +1,111 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.IntermediaryStorageManager = void 0;
|
|
4
|
-
const fs = require("fs/promises");
|
|
5
|
-
const fsSync = require("fs");
|
|
6
|
-
const Utils_1 = require("../utils/Utils");
|
|
7
|
-
class IntermediaryStorageManager {
|
|
8
|
-
constructor(directory) {
|
|
9
|
-
this.data = {};
|
|
10
|
-
this.directory = directory;
|
|
11
|
-
this.logger = (0, Utils_1.getLogger)("IntermediaryStorageManager(" + directory + "): ");
|
|
12
|
-
}
|
|
13
|
-
async init() {
|
|
14
|
-
try {
|
|
15
|
-
await fs.mkdir(this.directory);
|
|
16
|
-
}
|
|
17
|
-
catch (e) { }
|
|
18
|
-
}
|
|
19
|
-
query(params) {
|
|
20
|
-
return Promise.resolve(Object.keys(this.data).filter((key) => {
|
|
21
|
-
const val = this.data[key];
|
|
22
|
-
for (let param of params) {
|
|
23
|
-
if (param.value != null) {
|
|
24
|
-
if (typeof param.value === "object") {
|
|
25
|
-
if (param.value.eq != null && !param.value.eq(val[param.key]))
|
|
26
|
-
return false;
|
|
27
|
-
if (param.value.equals != null && !param.value.equals(val[param.key]))
|
|
28
|
-
return false;
|
|
29
|
-
}
|
|
30
|
-
else {
|
|
31
|
-
if (param.value !== val[param.key])
|
|
32
|
-
return false;
|
|
33
|
-
}
|
|
34
|
-
}
|
|
35
|
-
else if (param.values != null) {
|
|
36
|
-
let hasSome = false;
|
|
37
|
-
for (let expectedValue of param.values) {
|
|
38
|
-
if (typeof expectedValue === "object") {
|
|
39
|
-
if (expectedValue.eq != null && !expectedValue.eq(val[param.key]))
|
|
40
|
-
hasSome = true;
|
|
41
|
-
if (expectedValue.equals != null && !expectedValue.equals(val[param.key]))
|
|
42
|
-
hasSome = true;
|
|
43
|
-
}
|
|
44
|
-
else {
|
|
45
|
-
if (expectedValue === val[param.key])
|
|
46
|
-
hasSome = true;
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
if (!hasSome)
|
|
50
|
-
return false;
|
|
51
|
-
}
|
|
52
|
-
}
|
|
53
|
-
return true;
|
|
54
|
-
}).map(key => {
|
|
55
|
-
const [hash, sequenceStr] = key.split("_");
|
|
56
|
-
const sequence = BigInt("0x" + sequenceStr);
|
|
57
|
-
return {
|
|
58
|
-
obj: this.data[key],
|
|
59
|
-
hash,
|
|
60
|
-
sequence
|
|
61
|
-
};
|
|
62
|
-
}));
|
|
63
|
-
}
|
|
64
|
-
getData(paymentHash, sequence) {
|
|
65
|
-
return Promise.resolve(this.data[paymentHash + "_" + (sequence || 0n).toString(16).padStart(16, "0")]);
|
|
66
|
-
}
|
|
67
|
-
async saveData(hash, sequence, object) {
|
|
68
|
-
const _sequence = (sequence || 0n).toString(16).padStart(16, "0");
|
|
69
|
-
try {
|
|
70
|
-
await fs.mkdir(this.directory);
|
|
71
|
-
}
|
|
72
|
-
catch (e) { }
|
|
73
|
-
this.data[hash + "_" + _sequence] = object;
|
|
74
|
-
const cpy = object.serialize();
|
|
75
|
-
await fs.writeFile(this.directory + "/" + hash + "_" + _sequence + ".json", JSON.stringify(cpy));
|
|
76
|
-
}
|
|
77
|
-
async removeData(hash, sequence) {
|
|
78
|
-
const identifier = hash + "_" + (sequence || 0n).toString(16).padStart(16, "0");
|
|
79
|
-
try {
|
|
80
|
-
if (this.data[identifier] != null)
|
|
81
|
-
delete this.data[identifier];
|
|
82
|
-
await fs.rm(this.directory + "/" + identifier + ".json");
|
|
83
|
-
}
|
|
84
|
-
catch (e) {
|
|
85
|
-
this.logger.error("removeData(): Error when removing data: ", e);
|
|
86
|
-
}
|
|
87
|
-
}
|
|
88
|
-
async loadData(type) {
|
|
89
|
-
this.type = type;
|
|
90
|
-
if (!fsSync.existsSync(this.directory)) {
|
|
91
|
-
this.logger.debug("loadData(): Data directory not found!");
|
|
92
|
-
return;
|
|
93
|
-
}
|
|
94
|
-
let files;
|
|
95
|
-
try {
|
|
96
|
-
files = await fs.readdir(this.directory);
|
|
97
|
-
}
|
|
98
|
-
catch (e) {
|
|
99
|
-
this.logger.error("loadData(): Error when checking directory: ", e);
|
|
100
|
-
return;
|
|
101
|
-
}
|
|
102
|
-
for (let file of files) {
|
|
103
|
-
const indentifier = file.split(".")[0];
|
|
104
|
-
const result = await fs.readFile(this.directory + "/" + file);
|
|
105
|
-
const obj = JSON.parse(result.toString());
|
|
106
|
-
const parsed = new type(obj);
|
|
107
|
-
this.data[indentifier] = parsed;
|
|
108
|
-
}
|
|
109
|
-
}
|
|
110
|
-
}
|
|
111
|
-
exports.IntermediaryStorageManager = IntermediaryStorageManager;
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.IntermediaryStorageManager = void 0;
|
|
4
|
+
const fs = require("fs/promises");
|
|
5
|
+
const fsSync = require("fs");
|
|
6
|
+
const Utils_1 = require("../utils/Utils");
|
|
7
|
+
class IntermediaryStorageManager {
|
|
8
|
+
constructor(directory) {
|
|
9
|
+
this.data = {};
|
|
10
|
+
this.directory = directory;
|
|
11
|
+
this.logger = (0, Utils_1.getLogger)("IntermediaryStorageManager(" + directory + "): ");
|
|
12
|
+
}
|
|
13
|
+
async init() {
|
|
14
|
+
try {
|
|
15
|
+
await fs.mkdir(this.directory);
|
|
16
|
+
}
|
|
17
|
+
catch (e) { }
|
|
18
|
+
}
|
|
19
|
+
query(params) {
|
|
20
|
+
return Promise.resolve(Object.keys(this.data).filter((key) => {
|
|
21
|
+
const val = this.data[key];
|
|
22
|
+
for (let param of params) {
|
|
23
|
+
if (param.value != null) {
|
|
24
|
+
if (typeof param.value === "object") {
|
|
25
|
+
if (param.value.eq != null && !param.value.eq(val[param.key]))
|
|
26
|
+
return false;
|
|
27
|
+
if (param.value.equals != null && !param.value.equals(val[param.key]))
|
|
28
|
+
return false;
|
|
29
|
+
}
|
|
30
|
+
else {
|
|
31
|
+
if (param.value !== val[param.key])
|
|
32
|
+
return false;
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
else if (param.values != null) {
|
|
36
|
+
let hasSome = false;
|
|
37
|
+
for (let expectedValue of param.values) {
|
|
38
|
+
if (typeof expectedValue === "object") {
|
|
39
|
+
if (expectedValue.eq != null && !expectedValue.eq(val[param.key]))
|
|
40
|
+
hasSome = true;
|
|
41
|
+
if (expectedValue.equals != null && !expectedValue.equals(val[param.key]))
|
|
42
|
+
hasSome = true;
|
|
43
|
+
}
|
|
44
|
+
else {
|
|
45
|
+
if (expectedValue === val[param.key])
|
|
46
|
+
hasSome = true;
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
if (!hasSome)
|
|
50
|
+
return false;
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
return true;
|
|
54
|
+
}).map(key => {
|
|
55
|
+
const [hash, sequenceStr] = key.split("_");
|
|
56
|
+
const sequence = BigInt("0x" + sequenceStr);
|
|
57
|
+
return {
|
|
58
|
+
obj: this.data[key],
|
|
59
|
+
hash,
|
|
60
|
+
sequence
|
|
61
|
+
};
|
|
62
|
+
}));
|
|
63
|
+
}
|
|
64
|
+
getData(paymentHash, sequence) {
|
|
65
|
+
return Promise.resolve(this.data[paymentHash + "_" + (sequence || 0n).toString(16).padStart(16, "0")]);
|
|
66
|
+
}
|
|
67
|
+
async saveData(hash, sequence, object) {
|
|
68
|
+
const _sequence = (sequence || 0n).toString(16).padStart(16, "0");
|
|
69
|
+
try {
|
|
70
|
+
await fs.mkdir(this.directory);
|
|
71
|
+
}
|
|
72
|
+
catch (e) { }
|
|
73
|
+
this.data[hash + "_" + _sequence] = object;
|
|
74
|
+
const cpy = object.serialize();
|
|
75
|
+
await fs.writeFile(this.directory + "/" + hash + "_" + _sequence + ".json", JSON.stringify(cpy));
|
|
76
|
+
}
|
|
77
|
+
async removeData(hash, sequence) {
|
|
78
|
+
const identifier = hash + "_" + (sequence || 0n).toString(16).padStart(16, "0");
|
|
79
|
+
try {
|
|
80
|
+
if (this.data[identifier] != null)
|
|
81
|
+
delete this.data[identifier];
|
|
82
|
+
await fs.rm(this.directory + "/" + identifier + ".json");
|
|
83
|
+
}
|
|
84
|
+
catch (e) {
|
|
85
|
+
this.logger.error("removeData(): Error when removing data: ", e);
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
async loadData(type) {
|
|
89
|
+
this.type = type;
|
|
90
|
+
if (!fsSync.existsSync(this.directory)) {
|
|
91
|
+
this.logger.debug("loadData(): Data directory not found!");
|
|
92
|
+
return;
|
|
93
|
+
}
|
|
94
|
+
let files;
|
|
95
|
+
try {
|
|
96
|
+
files = await fs.readdir(this.directory);
|
|
97
|
+
}
|
|
98
|
+
catch (e) {
|
|
99
|
+
this.logger.error("loadData(): Error when checking directory: ", e);
|
|
100
|
+
return;
|
|
101
|
+
}
|
|
102
|
+
for (let file of files) {
|
|
103
|
+
const indentifier = file.split(".")[0];
|
|
104
|
+
const result = await fs.readFile(this.directory + "/" + file);
|
|
105
|
+
const obj = JSON.parse(result.toString());
|
|
106
|
+
const parsed = new type(obj);
|
|
107
|
+
this.data[indentifier] = parsed;
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
exports.IntermediaryStorageManager = IntermediaryStorageManager;
|
|
@@ -1,13 +1,13 @@
|
|
|
1
|
-
import { StorageObject, IStorageManager } from "@atomiqlabs/base";
|
|
2
|
-
export declare class StorageManager<T extends StorageObject> implements IStorageManager<T> {
|
|
3
|
-
private readonly directory;
|
|
4
|
-
data: {
|
|
5
|
-
[key: string]: T;
|
|
6
|
-
};
|
|
7
|
-
private logger;
|
|
8
|
-
constructor(directory: string);
|
|
9
|
-
init(): Promise<void>;
|
|
10
|
-
saveData(hash: string, object: T): Promise<void>;
|
|
11
|
-
removeData(hash: string): Promise<void>;
|
|
12
|
-
loadData(type: new (data: any) => T): Promise<T[]>;
|
|
13
|
-
}
|
|
1
|
+
import { StorageObject, IStorageManager } from "@atomiqlabs/base";
|
|
2
|
+
export declare class StorageManager<T extends StorageObject> implements IStorageManager<T> {
|
|
3
|
+
private readonly directory;
|
|
4
|
+
data: {
|
|
5
|
+
[key: string]: T;
|
|
6
|
+
};
|
|
7
|
+
private logger;
|
|
8
|
+
constructor(directory: string);
|
|
9
|
+
init(): Promise<void>;
|
|
10
|
+
saveData(hash: string, object: T): Promise<void>;
|
|
11
|
+
removeData(hash: string): Promise<void>;
|
|
12
|
+
loadData(type: new (data: any) => T): Promise<T[]>;
|
|
13
|
+
}
|
|
@@ -1,64 +1,64 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.StorageManager = void 0;
|
|
4
|
-
const fs = require("fs/promises");
|
|
5
|
-
const Utils_1 = require("../utils/Utils");
|
|
6
|
-
const fsSync = require("fs");
|
|
7
|
-
class StorageManager {
|
|
8
|
-
constructor(directory) {
|
|
9
|
-
this.data = {};
|
|
10
|
-
this.directory = directory;
|
|
11
|
-
this.logger = (0, Utils_1.getLogger)("StorageManager(" + directory + "): ");
|
|
12
|
-
}
|
|
13
|
-
async init() {
|
|
14
|
-
try {
|
|
15
|
-
await fs.mkdir(this.directory);
|
|
16
|
-
}
|
|
17
|
-
catch (e) { }
|
|
18
|
-
}
|
|
19
|
-
async saveData(hash, object) {
|
|
20
|
-
try {
|
|
21
|
-
await fs.mkdir(this.directory);
|
|
22
|
-
}
|
|
23
|
-
catch (e) { }
|
|
24
|
-
this.data[hash] = object;
|
|
25
|
-
const cpy = object.serialize();
|
|
26
|
-
await fs.writeFile(this.directory + "/" + hash + ".json", JSON.stringify(cpy));
|
|
27
|
-
}
|
|
28
|
-
async removeData(hash) {
|
|
29
|
-
const paymentHash = hash;
|
|
30
|
-
try {
|
|
31
|
-
if (this.data[paymentHash] != null)
|
|
32
|
-
delete this.data[paymentHash];
|
|
33
|
-
await fs.rm(this.directory + "/" + paymentHash + ".json");
|
|
34
|
-
}
|
|
35
|
-
catch (e) {
|
|
36
|
-
this.logger.error("removeData(): Error when removing data: ", e);
|
|
37
|
-
}
|
|
38
|
-
}
|
|
39
|
-
async loadData(type) {
|
|
40
|
-
if (!fsSync.existsSync(this.directory)) {
|
|
41
|
-
this.logger.debug("loadData(): Data directory not found!");
|
|
42
|
-
return;
|
|
43
|
-
}
|
|
44
|
-
let files;
|
|
45
|
-
try {
|
|
46
|
-
files = await fs.readdir(this.directory);
|
|
47
|
-
}
|
|
48
|
-
catch (e) {
|
|
49
|
-
this.logger.error("loadData(): Error when checking directory: ", e);
|
|
50
|
-
return [];
|
|
51
|
-
}
|
|
52
|
-
const arr = [];
|
|
53
|
-
for (let file of files) {
|
|
54
|
-
const paymentHash = file.split(".")[0];
|
|
55
|
-
const result = await fs.readFile(this.directory + "/" + file);
|
|
56
|
-
const obj = JSON.parse(result.toString());
|
|
57
|
-
const parsed = new type(obj);
|
|
58
|
-
arr.push(parsed);
|
|
59
|
-
this.data[paymentHash] = parsed;
|
|
60
|
-
}
|
|
61
|
-
return arr;
|
|
62
|
-
}
|
|
63
|
-
}
|
|
64
|
-
exports.StorageManager = StorageManager;
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.StorageManager = void 0;
|
|
4
|
+
const fs = require("fs/promises");
|
|
5
|
+
const Utils_1 = require("../utils/Utils");
|
|
6
|
+
const fsSync = require("fs");
|
|
7
|
+
class StorageManager {
|
|
8
|
+
constructor(directory) {
|
|
9
|
+
this.data = {};
|
|
10
|
+
this.directory = directory;
|
|
11
|
+
this.logger = (0, Utils_1.getLogger)("StorageManager(" + directory + "): ");
|
|
12
|
+
}
|
|
13
|
+
async init() {
|
|
14
|
+
try {
|
|
15
|
+
await fs.mkdir(this.directory);
|
|
16
|
+
}
|
|
17
|
+
catch (e) { }
|
|
18
|
+
}
|
|
19
|
+
async saveData(hash, object) {
|
|
20
|
+
try {
|
|
21
|
+
await fs.mkdir(this.directory);
|
|
22
|
+
}
|
|
23
|
+
catch (e) { }
|
|
24
|
+
this.data[hash] = object;
|
|
25
|
+
const cpy = object.serialize();
|
|
26
|
+
await fs.writeFile(this.directory + "/" + hash + ".json", JSON.stringify(cpy));
|
|
27
|
+
}
|
|
28
|
+
async removeData(hash) {
|
|
29
|
+
const paymentHash = hash;
|
|
30
|
+
try {
|
|
31
|
+
if (this.data[paymentHash] != null)
|
|
32
|
+
delete this.data[paymentHash];
|
|
33
|
+
await fs.rm(this.directory + "/" + paymentHash + ".json");
|
|
34
|
+
}
|
|
35
|
+
catch (e) {
|
|
36
|
+
this.logger.error("removeData(): Error when removing data: ", e);
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
async loadData(type) {
|
|
40
|
+
if (!fsSync.existsSync(this.directory)) {
|
|
41
|
+
this.logger.debug("loadData(): Data directory not found!");
|
|
42
|
+
return;
|
|
43
|
+
}
|
|
44
|
+
let files;
|
|
45
|
+
try {
|
|
46
|
+
files = await fs.readdir(this.directory);
|
|
47
|
+
}
|
|
48
|
+
catch (e) {
|
|
49
|
+
this.logger.error("loadData(): Error when checking directory: ", e);
|
|
50
|
+
return [];
|
|
51
|
+
}
|
|
52
|
+
const arr = [];
|
|
53
|
+
for (let file of files) {
|
|
54
|
+
const paymentHash = file.split(".")[0];
|
|
55
|
+
const result = await fs.readFile(this.directory + "/" + file);
|
|
56
|
+
const obj = JSON.parse(result.toString());
|
|
57
|
+
const parsed = new type(obj);
|
|
58
|
+
arr.push(parsed);
|
|
59
|
+
this.data[paymentHash] = parsed;
|
|
60
|
+
}
|
|
61
|
+
return arr;
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
exports.StorageManager = StorageManager;
|