@atomiqlabs/lp-lib 14.0.0-dev.21 → 14.0.0-dev.24
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 -180
- 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 +111 -111
- package/dist/swaps/escrow/frombtcln_autoinit/FromBtcLnAuto.js +684 -684
- 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 +863 -863
- package/dist/swaps/escrow/tobtcln_abstract/ToBtcLnSwapAbs.d.ts +24 -24
- package/dist/swaps/escrow/tobtcln_abstract/ToBtcLnSwapAbs.js +58 -58
- package/dist/swaps/spv_vault_swap/SpvVault.d.ts +40 -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 +492 -492
- package/dist/swaps/spv_vault_swap/SpvVaults.d.ts +52 -52
- package/dist/swaps/spv_vault_swap/SpvVaults.js +394 -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/BitcoinUtils.d.ts +2 -2
- package/dist/utils/BitcoinUtils.js +45 -45
- 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 -246
- 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 +850 -850
- 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 +1112 -1112
- package/src/swaps/escrow/tobtcln_abstract/ToBtcLnSwapAbs.ts +80 -80
- 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 +628 -628
- package/src/swaps/spv_vault_swap/SpvVaults.ts +469 -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/BitcoinUtils.ts +42 -42
- 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,113 +1,113 @@
|
|
|
1
|
-
import {ISwapPrice} from "./ISwapPrice";
|
|
2
|
-
|
|
3
|
-
const CACHE_DURATION = 15000;
|
|
4
|
-
|
|
5
|
-
export type OKXPriceData = {
|
|
6
|
-
[pair: string]: {
|
|
7
|
-
[chainId: string]: {
|
|
8
|
-
address: string,
|
|
9
|
-
decimals: number
|
|
10
|
-
}
|
|
11
|
-
}
|
|
12
|
-
};
|
|
13
|
-
|
|
14
|
-
export class OKXSwapPrice extends ISwapPrice<{ pair: string, decimals: number }> {
|
|
15
|
-
|
|
16
|
-
url: string;
|
|
17
|
-
cache: {
|
|
18
|
-
[pair: string]: {
|
|
19
|
-
price: number,
|
|
20
|
-
expiry: number
|
|
21
|
-
}
|
|
22
|
-
} = {};
|
|
23
|
-
|
|
24
|
-
constructor(url: string, coins: OKXPriceData) {
|
|
25
|
-
const coinsMap = {};
|
|
26
|
-
for(let pair in coins) {
|
|
27
|
-
const chains = coins[pair];
|
|
28
|
-
for(let chainId in chains) {
|
|
29
|
-
const tokenData = chains[chainId];
|
|
30
|
-
if(coinsMap[chainId]==null) coinsMap[chainId] = {};
|
|
31
|
-
coinsMap[chainId][tokenData.address] = {
|
|
32
|
-
pair,
|
|
33
|
-
decimals: tokenData.decimals
|
|
34
|
-
}
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
super(coinsMap);
|
|
38
|
-
this.url = url || "https://www.okx.com/api/v5";
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
async fetchPrice(pair: string) {
|
|
42
|
-
const response: Response = await fetch(this.url+"/market/index-tickers?instId=" + pair, {
|
|
43
|
-
method: "GET"
|
|
44
|
-
});
|
|
45
|
-
|
|
46
|
-
if (response.status !== 200) {
|
|
47
|
-
let resp: string;
|
|
48
|
-
try {
|
|
49
|
-
resp = await response.text();
|
|
50
|
-
} catch (e) {
|
|
51
|
-
throw new Error(response.statusText);
|
|
52
|
-
}
|
|
53
|
-
throw new Error(resp);
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
let jsonBody: any = await response.json();
|
|
57
|
-
|
|
58
|
-
return parseFloat(jsonBody.data[0].idxPx);
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
async getPrice(tokenData: {pair: string}): Promise<bigint> {
|
|
62
|
-
const pair = tokenData.pair;
|
|
63
|
-
if(pair.startsWith("$fixed-")) {
|
|
64
|
-
const amt: number = parseFloat(pair.substring(7));
|
|
65
|
-
return BigInt(Math.floor(amt*1000000));
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
const arr = pair.split(";");
|
|
69
|
-
|
|
70
|
-
const promises = [];
|
|
71
|
-
const cachedValue = this.cache[pair];
|
|
72
|
-
if(cachedValue==null || cachedValue.expiry<Date.now()) {
|
|
73
|
-
let resultPrice = 1;
|
|
74
|
-
for (let pair of arr) {
|
|
75
|
-
let invert = false
|
|
76
|
-
if (pair.startsWith("!")) {
|
|
77
|
-
invert = true;
|
|
78
|
-
pair = pair.substring(1);
|
|
79
|
-
}
|
|
80
|
-
const cachedValue = this.cache[pair];
|
|
81
|
-
if (cachedValue == null || cachedValue.expiry < Date.now()) {
|
|
82
|
-
promises.push(this.fetchPrice(pair).then(price => {
|
|
83
|
-
this.cache[pair] = {
|
|
84
|
-
price,
|
|
85
|
-
expiry: Date.now() + CACHE_DURATION
|
|
86
|
-
};
|
|
87
|
-
|
|
88
|
-
if (invert) {
|
|
89
|
-
resultPrice /= price;
|
|
90
|
-
} else {
|
|
91
|
-
resultPrice *= price;
|
|
92
|
-
}
|
|
93
|
-
}));
|
|
94
|
-
} else {
|
|
95
|
-
if (invert) {
|
|
96
|
-
resultPrice /= cachedValue.price;
|
|
97
|
-
} else {
|
|
98
|
-
resultPrice *= cachedValue.price;
|
|
99
|
-
}
|
|
100
|
-
}
|
|
101
|
-
}
|
|
102
|
-
|
|
103
|
-
await Promise.all(promises);
|
|
104
|
-
|
|
105
|
-
this.cache[pair] = {
|
|
106
|
-
price: resultPrice,
|
|
107
|
-
expiry: Date.now() + CACHE_DURATION
|
|
108
|
-
};
|
|
109
|
-
}
|
|
110
|
-
|
|
111
|
-
return BigInt(Math.floor(this.cache[pair].price*100000000000000));
|
|
112
|
-
}
|
|
113
|
-
}
|
|
1
|
+
import {ISwapPrice} from "./ISwapPrice";
|
|
2
|
+
|
|
3
|
+
const CACHE_DURATION = 15000;
|
|
4
|
+
|
|
5
|
+
export type OKXPriceData = {
|
|
6
|
+
[pair: string]: {
|
|
7
|
+
[chainId: string]: {
|
|
8
|
+
address: string,
|
|
9
|
+
decimals: number
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
};
|
|
13
|
+
|
|
14
|
+
export class OKXSwapPrice extends ISwapPrice<{ pair: string, decimals: number }> {
|
|
15
|
+
|
|
16
|
+
url: string;
|
|
17
|
+
cache: {
|
|
18
|
+
[pair: string]: {
|
|
19
|
+
price: number,
|
|
20
|
+
expiry: number
|
|
21
|
+
}
|
|
22
|
+
} = {};
|
|
23
|
+
|
|
24
|
+
constructor(url: string, coins: OKXPriceData) {
|
|
25
|
+
const coinsMap = {};
|
|
26
|
+
for(let pair in coins) {
|
|
27
|
+
const chains = coins[pair];
|
|
28
|
+
for(let chainId in chains) {
|
|
29
|
+
const tokenData = chains[chainId];
|
|
30
|
+
if(coinsMap[chainId]==null) coinsMap[chainId] = {};
|
|
31
|
+
coinsMap[chainId][tokenData.address] = {
|
|
32
|
+
pair,
|
|
33
|
+
decimals: tokenData.decimals
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
super(coinsMap);
|
|
38
|
+
this.url = url || "https://www.okx.com/api/v5";
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
async fetchPrice(pair: string) {
|
|
42
|
+
const response: Response = await fetch(this.url+"/market/index-tickers?instId=" + pair, {
|
|
43
|
+
method: "GET"
|
|
44
|
+
});
|
|
45
|
+
|
|
46
|
+
if (response.status !== 200) {
|
|
47
|
+
let resp: string;
|
|
48
|
+
try {
|
|
49
|
+
resp = await response.text();
|
|
50
|
+
} catch (e) {
|
|
51
|
+
throw new Error(response.statusText);
|
|
52
|
+
}
|
|
53
|
+
throw new Error(resp);
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
let jsonBody: any = await response.json();
|
|
57
|
+
|
|
58
|
+
return parseFloat(jsonBody.data[0].idxPx);
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
async getPrice(tokenData: {pair: string}): Promise<bigint> {
|
|
62
|
+
const pair = tokenData.pair;
|
|
63
|
+
if(pair.startsWith("$fixed-")) {
|
|
64
|
+
const amt: number = parseFloat(pair.substring(7));
|
|
65
|
+
return BigInt(Math.floor(amt*1000000));
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
const arr = pair.split(";");
|
|
69
|
+
|
|
70
|
+
const promises = [];
|
|
71
|
+
const cachedValue = this.cache[pair];
|
|
72
|
+
if(cachedValue==null || cachedValue.expiry<Date.now()) {
|
|
73
|
+
let resultPrice = 1;
|
|
74
|
+
for (let pair of arr) {
|
|
75
|
+
let invert = false
|
|
76
|
+
if (pair.startsWith("!")) {
|
|
77
|
+
invert = true;
|
|
78
|
+
pair = pair.substring(1);
|
|
79
|
+
}
|
|
80
|
+
const cachedValue = this.cache[pair];
|
|
81
|
+
if (cachedValue == null || cachedValue.expiry < Date.now()) {
|
|
82
|
+
promises.push(this.fetchPrice(pair).then(price => {
|
|
83
|
+
this.cache[pair] = {
|
|
84
|
+
price,
|
|
85
|
+
expiry: Date.now() + CACHE_DURATION
|
|
86
|
+
};
|
|
87
|
+
|
|
88
|
+
if (invert) {
|
|
89
|
+
resultPrice /= price;
|
|
90
|
+
} else {
|
|
91
|
+
resultPrice *= price;
|
|
92
|
+
}
|
|
93
|
+
}));
|
|
94
|
+
} else {
|
|
95
|
+
if (invert) {
|
|
96
|
+
resultPrice /= cachedValue.price;
|
|
97
|
+
} else {
|
|
98
|
+
resultPrice *= cachedValue.price;
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
await Promise.all(promises);
|
|
104
|
+
|
|
105
|
+
this.cache[pair] = {
|
|
106
|
+
price: resultPrice,
|
|
107
|
+
expiry: Date.now() + CACHE_DURATION
|
|
108
|
+
};
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
return BigInt(Math.floor(this.cache[pair].price*100000000000000));
|
|
112
|
+
}
|
|
113
|
+
}
|
|
@@ -1,20 +1,20 @@
|
|
|
1
|
-
import {StorageObject} from "@atomiqlabs/base";
|
|
2
|
-
|
|
3
|
-
export type StorageQueryParam = {
|
|
4
|
-
key: string,
|
|
5
|
-
value?: any,
|
|
6
|
-
values?: any[]
|
|
7
|
-
}
|
|
8
|
-
|
|
9
|
-
export interface IIntermediaryStorage<T extends StorageObject> {
|
|
10
|
-
|
|
11
|
-
init(): Promise<void>;
|
|
12
|
-
|
|
13
|
-
query(params: StorageQueryParam[]): Promise<{hash: string, sequence: bigint, obj: T}[]>;
|
|
14
|
-
|
|
15
|
-
getData(hash: 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
|
+
|
|
3
|
+
export type StorageQueryParam = {
|
|
4
|
+
key: string,
|
|
5
|
+
value?: any,
|
|
6
|
+
values?: any[]
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
export interface IIntermediaryStorage<T extends StorageObject> {
|
|
10
|
+
|
|
11
|
+
init(): Promise<void>;
|
|
12
|
+
|
|
13
|
+
query(params: StorageQueryParam[]): Promise<{hash: string, sequence: bigint, obj: T}[]>;
|
|
14
|
+
|
|
15
|
+
getData(hash: 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
|
+
|
|
20
20
|
}
|
|
@@ -1,118 +1,118 @@
|
|
|
1
|
-
import {StorageObject} from "@atomiqlabs/base";
|
|
2
|
-
import * as fs from "fs/promises";
|
|
3
|
-
import * as fsSync from "fs";
|
|
4
|
-
import {IIntermediaryStorage, StorageQueryParam} from "../storage/IIntermediaryStorage";
|
|
5
|
-
import {getLogger, LoggerType} from "../utils/Utils";
|
|
6
|
-
|
|
7
|
-
export class IntermediaryStorageManager<T extends StorageObject> implements IIntermediaryStorage<T> {
|
|
8
|
-
|
|
9
|
-
private readonly directory: string;
|
|
10
|
-
private type: new(data: any) => T;
|
|
11
|
-
private data: {
|
|
12
|
-
[key: string]: T
|
|
13
|
-
} = {};
|
|
14
|
-
private logger: LoggerType;
|
|
15
|
-
|
|
16
|
-
constructor(directory: string) {
|
|
17
|
-
this.directory = directory;
|
|
18
|
-
this.logger = getLogger("IntermediaryStorageManager("+directory+"): ");
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
async init(): Promise<void> {
|
|
22
|
-
try {
|
|
23
|
-
await fs.mkdir(this.directory)
|
|
24
|
-
} catch (e) {}
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
query(params: StorageQueryParam[]): Promise<{hash: string, sequence: bigint, obj: T}[]> {
|
|
28
|
-
return Promise.resolve(Object.keys(this.data).filter((key) => {
|
|
29
|
-
const val = this.data[key];
|
|
30
|
-
for(let param of params) {
|
|
31
|
-
if(param.value!=null) {
|
|
32
|
-
if(typeof param.value === "object") {
|
|
33
|
-
if(param.value.eq!=null && !param.value.eq(val[param.key])) return false;
|
|
34
|
-
if(param.value.equals!=null && !param.value.equals(val[param.key])) return false;
|
|
35
|
-
} else {
|
|
36
|
-
if(param.value!==val[param.key]) return false;
|
|
37
|
-
}
|
|
38
|
-
} else if(param.values!=null) {
|
|
39
|
-
let hasSome = false;
|
|
40
|
-
for(let expectedValue of param.values) {
|
|
41
|
-
if(typeof expectedValue === "object") {
|
|
42
|
-
if(expectedValue.eq!=null && !expectedValue.eq(val[param.key])) hasSome = true;
|
|
43
|
-
if(expectedValue.equals!=null && !expectedValue.equals(val[param.key])) hasSome = true;
|
|
44
|
-
} else {
|
|
45
|
-
if(expectedValue===val[param.key]) hasSome = true;
|
|
46
|
-
}
|
|
47
|
-
}
|
|
48
|
-
if(!hasSome) return false;
|
|
49
|
-
}
|
|
50
|
-
}
|
|
51
|
-
return true;
|
|
52
|
-
}).map(key => {
|
|
53
|
-
const [hash, sequenceStr] = key.split("_");
|
|
54
|
-
const sequence = BigInt("0x"+sequenceStr);
|
|
55
|
-
return {
|
|
56
|
-
obj: this.data[key],
|
|
57
|
-
hash,
|
|
58
|
-
sequence
|
|
59
|
-
}
|
|
60
|
-
}));
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
getData(paymentHash: string, sequence: bigint | null): Promise<T> {
|
|
64
|
-
return Promise.resolve(this.data[paymentHash+"_"+(sequence || 0n).toString(16).padStart(16, "0")]);
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
async saveData(hash: string, sequence: bigint | null, object: T): Promise<void> {
|
|
68
|
-
|
|
69
|
-
const _sequence = (sequence || 0n).toString(16).padStart(16, "0");
|
|
70
|
-
|
|
71
|
-
try {
|
|
72
|
-
await fs.mkdir(this.directory)
|
|
73
|
-
} catch (e) {}
|
|
74
|
-
|
|
75
|
-
this.data[hash+"_"+_sequence] = object;
|
|
76
|
-
|
|
77
|
-
const cpy = object.serialize();
|
|
78
|
-
|
|
79
|
-
await fs.writeFile(this.directory+"/"+hash+"_"+_sequence+".json", JSON.stringify(cpy));
|
|
80
|
-
|
|
81
|
-
}
|
|
82
|
-
|
|
83
|
-
async removeData(hash: string, sequence: bigint | null): Promise<void> {
|
|
84
|
-
const identifier = hash+"_"+(sequence || 0n).toString(16).padStart(16, "0");
|
|
85
|
-
try {
|
|
86
|
-
if(this.data[identifier]!=null) delete this.data[identifier];
|
|
87
|
-
await fs.rm(this.directory+"/"+identifier+".json");
|
|
88
|
-
} catch (e) {
|
|
89
|
-
this.logger.error("removeData(): Error when removing data: ", e);
|
|
90
|
-
}
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
async loadData(type: new(data: any) => T): Promise<void> {
|
|
94
|
-
this.type = type;
|
|
95
|
-
|
|
96
|
-
if(!fsSync.existsSync(this.directory)) {
|
|
97
|
-
this.logger.debug("loadData(): Data directory not found!");
|
|
98
|
-
return;
|
|
99
|
-
}
|
|
100
|
-
|
|
101
|
-
let files: string[];
|
|
102
|
-
try {
|
|
103
|
-
files = await fs.readdir(this.directory);
|
|
104
|
-
} catch (e) {
|
|
105
|
-
this.logger.error("loadData(): Error when checking directory: ", e);
|
|
106
|
-
return;
|
|
107
|
-
}
|
|
108
|
-
|
|
109
|
-
for(let file of files) {
|
|
110
|
-
const indentifier = file.split(".")[0];
|
|
111
|
-
const result = await fs.readFile(this.directory+"/"+file);
|
|
112
|
-
const obj = JSON.parse(result.toString());
|
|
113
|
-
const parsed = new type(obj);
|
|
114
|
-
this.data[indentifier] = parsed;
|
|
115
|
-
}
|
|
116
|
-
}
|
|
117
|
-
|
|
118
|
-
}
|
|
1
|
+
import {StorageObject} from "@atomiqlabs/base";
|
|
2
|
+
import * as fs from "fs/promises";
|
|
3
|
+
import * as fsSync from "fs";
|
|
4
|
+
import {IIntermediaryStorage, StorageQueryParam} from "../storage/IIntermediaryStorage";
|
|
5
|
+
import {getLogger, LoggerType} from "../utils/Utils";
|
|
6
|
+
|
|
7
|
+
export class IntermediaryStorageManager<T extends StorageObject> implements IIntermediaryStorage<T> {
|
|
8
|
+
|
|
9
|
+
private readonly directory: string;
|
|
10
|
+
private type: new(data: any) => T;
|
|
11
|
+
private data: {
|
|
12
|
+
[key: string]: T
|
|
13
|
+
} = {};
|
|
14
|
+
private logger: LoggerType;
|
|
15
|
+
|
|
16
|
+
constructor(directory: string) {
|
|
17
|
+
this.directory = directory;
|
|
18
|
+
this.logger = getLogger("IntermediaryStorageManager("+directory+"): ");
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
async init(): Promise<void> {
|
|
22
|
+
try {
|
|
23
|
+
await fs.mkdir(this.directory)
|
|
24
|
+
} catch (e) {}
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
query(params: StorageQueryParam[]): Promise<{hash: string, sequence: bigint, obj: T}[]> {
|
|
28
|
+
return Promise.resolve(Object.keys(this.data).filter((key) => {
|
|
29
|
+
const val = this.data[key];
|
|
30
|
+
for(let param of params) {
|
|
31
|
+
if(param.value!=null) {
|
|
32
|
+
if(typeof param.value === "object") {
|
|
33
|
+
if(param.value.eq!=null && !param.value.eq(val[param.key])) return false;
|
|
34
|
+
if(param.value.equals!=null && !param.value.equals(val[param.key])) return false;
|
|
35
|
+
} else {
|
|
36
|
+
if(param.value!==val[param.key]) return false;
|
|
37
|
+
}
|
|
38
|
+
} else if(param.values!=null) {
|
|
39
|
+
let hasSome = false;
|
|
40
|
+
for(let expectedValue of param.values) {
|
|
41
|
+
if(typeof expectedValue === "object") {
|
|
42
|
+
if(expectedValue.eq!=null && !expectedValue.eq(val[param.key])) hasSome = true;
|
|
43
|
+
if(expectedValue.equals!=null && !expectedValue.equals(val[param.key])) hasSome = true;
|
|
44
|
+
} else {
|
|
45
|
+
if(expectedValue===val[param.key]) hasSome = true;
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
if(!hasSome) return false;
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
return true;
|
|
52
|
+
}).map(key => {
|
|
53
|
+
const [hash, sequenceStr] = key.split("_");
|
|
54
|
+
const sequence = BigInt("0x"+sequenceStr);
|
|
55
|
+
return {
|
|
56
|
+
obj: this.data[key],
|
|
57
|
+
hash,
|
|
58
|
+
sequence
|
|
59
|
+
}
|
|
60
|
+
}));
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
getData(paymentHash: string, sequence: bigint | null): Promise<T> {
|
|
64
|
+
return Promise.resolve(this.data[paymentHash+"_"+(sequence || 0n).toString(16).padStart(16, "0")]);
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
async saveData(hash: string, sequence: bigint | null, object: T): Promise<void> {
|
|
68
|
+
|
|
69
|
+
const _sequence = (sequence || 0n).toString(16).padStart(16, "0");
|
|
70
|
+
|
|
71
|
+
try {
|
|
72
|
+
await fs.mkdir(this.directory)
|
|
73
|
+
} catch (e) {}
|
|
74
|
+
|
|
75
|
+
this.data[hash+"_"+_sequence] = object;
|
|
76
|
+
|
|
77
|
+
const cpy = object.serialize();
|
|
78
|
+
|
|
79
|
+
await fs.writeFile(this.directory+"/"+hash+"_"+_sequence+".json", JSON.stringify(cpy));
|
|
80
|
+
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
async removeData(hash: string, sequence: bigint | null): Promise<void> {
|
|
84
|
+
const identifier = hash+"_"+(sequence || 0n).toString(16).padStart(16, "0");
|
|
85
|
+
try {
|
|
86
|
+
if(this.data[identifier]!=null) delete this.data[identifier];
|
|
87
|
+
await fs.rm(this.directory+"/"+identifier+".json");
|
|
88
|
+
} catch (e) {
|
|
89
|
+
this.logger.error("removeData(): Error when removing data: ", e);
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
async loadData(type: new(data: any) => T): Promise<void> {
|
|
94
|
+
this.type = type;
|
|
95
|
+
|
|
96
|
+
if(!fsSync.existsSync(this.directory)) {
|
|
97
|
+
this.logger.debug("loadData(): Data directory not found!");
|
|
98
|
+
return;
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
let files: string[];
|
|
102
|
+
try {
|
|
103
|
+
files = await fs.readdir(this.directory);
|
|
104
|
+
} catch (e) {
|
|
105
|
+
this.logger.error("loadData(): Error when checking directory: ", e);
|
|
106
|
+
return;
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
for(let file of files) {
|
|
110
|
+
const indentifier = file.split(".")[0];
|
|
111
|
+
const result = await fs.readFile(this.directory+"/"+file);
|
|
112
|
+
const obj = JSON.parse(result.toString());
|
|
113
|
+
const parsed = new type(obj);
|
|
114
|
+
this.data[indentifier] = parsed;
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
}
|
|
@@ -1,78 +1,78 @@
|
|
|
1
|
-
import {StorageObject, IStorageManager} from "@atomiqlabs/base";
|
|
2
|
-
import * as fs from "fs/promises";
|
|
3
|
-
import {getLogger, LoggerType} from "../utils/Utils";
|
|
4
|
-
import * as fsSync from "fs";
|
|
5
|
-
|
|
6
|
-
export class StorageManager<T extends StorageObject> implements IStorageManager<T> {
|
|
7
|
-
|
|
8
|
-
private readonly directory: string;
|
|
9
|
-
data: {
|
|
10
|
-
[key: string]: T
|
|
11
|
-
} = {};
|
|
12
|
-
|
|
13
|
-
private logger: LoggerType;
|
|
14
|
-
|
|
15
|
-
constructor(directory: string) {
|
|
16
|
-
this.directory = directory;
|
|
17
|
-
this.logger = getLogger("StorageManager("+directory+"): ");
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
async init(): Promise<void> {
|
|
21
|
-
try {
|
|
22
|
-
await fs.mkdir(this.directory)
|
|
23
|
-
} catch (e) {}
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
async saveData(hash: string, object: T): Promise<void> {
|
|
27
|
-
|
|
28
|
-
try {
|
|
29
|
-
await fs.mkdir(this.directory)
|
|
30
|
-
} catch (e) {}
|
|
31
|
-
|
|
32
|
-
this.data[hash] = object;
|
|
33
|
-
|
|
34
|
-
const cpy = object.serialize();
|
|
35
|
-
|
|
36
|
-
await fs.writeFile(this.directory+"/"+hash+".json", JSON.stringify(cpy));
|
|
37
|
-
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
async removeData(hash: string): Promise<void> {
|
|
41
|
-
const paymentHash = hash;
|
|
42
|
-
try {
|
|
43
|
-
if(this.data[paymentHash]!=null) delete this.data[paymentHash];
|
|
44
|
-
await fs.rm(this.directory+"/"+paymentHash+".json");
|
|
45
|
-
} catch (e) {
|
|
46
|
-
this.logger.error("removeData(): Error when removing data: ", e);
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
async loadData(type: new(data: any) => T): Promise<T[]> {
|
|
51
|
-
if(!fsSync.existsSync(this.directory)) {
|
|
52
|
-
this.logger.debug("loadData(): Data directory not found!");
|
|
53
|
-
return;
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
let files;
|
|
57
|
-
try {
|
|
58
|
-
files = await fs.readdir(this.directory);
|
|
59
|
-
} catch (e) {
|
|
60
|
-
this.logger.error("loadData(): Error when checking directory: ", e);
|
|
61
|
-
return [];
|
|
62
|
-
}
|
|
63
|
-
|
|
64
|
-
const arr = [];
|
|
65
|
-
|
|
66
|
-
for(let file of files) {
|
|
67
|
-
const paymentHash = file.split(".")[0];
|
|
68
|
-
const result = await fs.readFile(this.directory+"/"+file);
|
|
69
|
-
const obj = JSON.parse(result.toString());
|
|
70
|
-
const parsed = new type(obj);
|
|
71
|
-
arr.push(parsed);
|
|
72
|
-
this.data[paymentHash] = parsed;
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
return arr;
|
|
76
|
-
}
|
|
77
|
-
|
|
78
|
-
}
|
|
1
|
+
import {StorageObject, IStorageManager} from "@atomiqlabs/base";
|
|
2
|
+
import * as fs from "fs/promises";
|
|
3
|
+
import {getLogger, LoggerType} from "../utils/Utils";
|
|
4
|
+
import * as fsSync from "fs";
|
|
5
|
+
|
|
6
|
+
export class StorageManager<T extends StorageObject> implements IStorageManager<T> {
|
|
7
|
+
|
|
8
|
+
private readonly directory: string;
|
|
9
|
+
data: {
|
|
10
|
+
[key: string]: T
|
|
11
|
+
} = {};
|
|
12
|
+
|
|
13
|
+
private logger: LoggerType;
|
|
14
|
+
|
|
15
|
+
constructor(directory: string) {
|
|
16
|
+
this.directory = directory;
|
|
17
|
+
this.logger = getLogger("StorageManager("+directory+"): ");
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
async init(): Promise<void> {
|
|
21
|
+
try {
|
|
22
|
+
await fs.mkdir(this.directory)
|
|
23
|
+
} catch (e) {}
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
async saveData(hash: string, object: T): Promise<void> {
|
|
27
|
+
|
|
28
|
+
try {
|
|
29
|
+
await fs.mkdir(this.directory)
|
|
30
|
+
} catch (e) {}
|
|
31
|
+
|
|
32
|
+
this.data[hash] = object;
|
|
33
|
+
|
|
34
|
+
const cpy = object.serialize();
|
|
35
|
+
|
|
36
|
+
await fs.writeFile(this.directory+"/"+hash+".json", JSON.stringify(cpy));
|
|
37
|
+
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
async removeData(hash: string): Promise<void> {
|
|
41
|
+
const paymentHash = hash;
|
|
42
|
+
try {
|
|
43
|
+
if(this.data[paymentHash]!=null) delete this.data[paymentHash];
|
|
44
|
+
await fs.rm(this.directory+"/"+paymentHash+".json");
|
|
45
|
+
} catch (e) {
|
|
46
|
+
this.logger.error("removeData(): Error when removing data: ", e);
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
async loadData(type: new(data: any) => T): Promise<T[]> {
|
|
51
|
+
if(!fsSync.existsSync(this.directory)) {
|
|
52
|
+
this.logger.debug("loadData(): Data directory not found!");
|
|
53
|
+
return;
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
let files;
|
|
57
|
+
try {
|
|
58
|
+
files = await fs.readdir(this.directory);
|
|
59
|
+
} catch (e) {
|
|
60
|
+
this.logger.error("loadData(): Error when checking directory: ", e);
|
|
61
|
+
return [];
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
const arr = [];
|
|
65
|
+
|
|
66
|
+
for(let file of files) {
|
|
67
|
+
const paymentHash = file.split(".")[0];
|
|
68
|
+
const result = await fs.readFile(this.directory+"/"+file);
|
|
69
|
+
const obj = JSON.parse(result.toString());
|
|
70
|
+
const parsed = new type(obj);
|
|
71
|
+
arr.push(parsed);
|
|
72
|
+
this.data[paymentHash] = parsed;
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
return arr;
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
}
|