@atomiqlabs/lp-lib 13.0.0-beta.9 → 13.0.0
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 +40 -40
- package/dist/index.js +56 -56
- 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 +18 -18
- package/dist/storagemanager/IntermediaryStorageManager.js +104 -104
- package/dist/storagemanager/StorageManager.d.ts +12 -12
- package/dist/storagemanager/StorageManager.js +57 -57
- package/dist/swaps/SwapHandler.d.ts +156 -156
- package/dist/swaps/SwapHandler.js +163 -163
- 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 +172 -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 +101 -101
- package/dist/swaps/escrow/FromBtcBaseSwapHandler.js +207 -207
- 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 +648 -648
- package/dist/swaps/escrow/frombtcln_abstract/FromBtcLnSwapAbs.d.ts +32 -32
- package/dist/swaps/escrow/frombtcln_abstract/FromBtcLnSwapAbs.js +88 -88
- package/dist/swaps/escrow/tobtc_abstract/ToBtcAbs.d.ts +171 -171
- package/dist/swaps/escrow/tobtc_abstract/ToBtcAbs.js +702 -702
- 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 +857 -857
- 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 +488 -478
- package/dist/swaps/spv_vault_swap/SpvVaults.d.ts +57 -57
- package/dist/swaps/spv_vault_swap/SpvVaults.js +369 -369
- 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 +495 -495
- 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 +88 -88
- 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 +105 -105
- 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/dist/wallets/ISpvVaultWallet.d.ts +42 -42
- package/dist/wallets/ISpvVaultWallet.js +2 -2
- package/package.json +36 -36
- package/src/fees/IBtcFeeEstimator.ts +6 -6
- package/src/index.ts +51 -51
- 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 +109 -109
- package/src/storagemanager/StorageManager.ts +68 -68
- package/src/swaps/SwapHandler.ts +280 -280
- package/src/swaps/SwapHandlerSwap.ts +141 -141
- package/src/swaps/assertions/AmountAssertions.ts +76 -76
- package/src/swaps/assertions/FromBtcAmountAssertions.ts +238 -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 +283 -283
- 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 +828 -828
- package/src/swaps/escrow/frombtcln_abstract/FromBtcLnSwapAbs.ts +137 -137
- package/src/swaps/escrow/tobtc_abstract/ToBtcAbs.ts +876 -876
- package/src/swaps/escrow/tobtc_abstract/ToBtcSwapAbs.ts +102 -102
- package/src/swaps/escrow/tobtcln_abstract/ToBtcLnAbs.ts +1107 -1107
- 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 +624 -613
- package/src/swaps/spv_vault_swap/SpvVaults.ts +440 -440
- 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 +592 -592
- package/src/swaps/trusted/frombtcln_trusted/FromBtcLnTrustedSwap.ts +121 -121
- package/src/utils/Utils.ts +102 -102
- 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 +115 -115
- 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,109 +1,109 @@
|
|
|
1
|
-
import {StorageObject} from "@atomiqlabs/base";
|
|
2
|
-
import * as fs from "fs/promises";
|
|
3
|
-
import {IIntermediaryStorage, StorageQueryParam} from "../storage/IIntermediaryStorage";
|
|
4
|
-
|
|
5
|
-
export class IntermediaryStorageManager<T extends StorageObject> implements IIntermediaryStorage<T> {
|
|
6
|
-
|
|
7
|
-
private readonly directory: string;
|
|
8
|
-
private type: new(data: any) => T;
|
|
9
|
-
private data: {
|
|
10
|
-
[key: string]: T
|
|
11
|
-
} = {};
|
|
12
|
-
|
|
13
|
-
constructor(directory: string) {
|
|
14
|
-
this.directory = directory;
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
async init(): Promise<void> {
|
|
18
|
-
try {
|
|
19
|
-
await fs.mkdir(this.directory)
|
|
20
|
-
} catch (e) {}
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
query(params: StorageQueryParam[]): Promise<{hash: string, sequence: bigint, obj: T}[]> {
|
|
24
|
-
return Promise.resolve(Object.keys(this.data).filter((key) => {
|
|
25
|
-
const val = this.data[key];
|
|
26
|
-
for(let param of params) {
|
|
27
|
-
if(param.value!=null) {
|
|
28
|
-
if(typeof param.value === "object") {
|
|
29
|
-
if(param.value.eq!=null && !param.value.eq(val[param.key])) return false;
|
|
30
|
-
if(param.value.equals!=null && !param.value.equals(val[param.key])) return false;
|
|
31
|
-
} else {
|
|
32
|
-
if(param.value!==val[param.key]) return false;
|
|
33
|
-
}
|
|
34
|
-
} else if(param.values!=null) {
|
|
35
|
-
let hasSome = false;
|
|
36
|
-
for(let expectedValue of param.values) {
|
|
37
|
-
if(typeof expectedValue === "object") {
|
|
38
|
-
if(expectedValue.eq!=null && !expectedValue.eq(val[param.key])) hasSome = true;
|
|
39
|
-
if(expectedValue.equals!=null && !expectedValue.equals(val[param.key])) hasSome = true;
|
|
40
|
-
} else {
|
|
41
|
-
if(expectedValue===val[param.key]) hasSome = true;
|
|
42
|
-
}
|
|
43
|
-
}
|
|
44
|
-
if(!hasSome) return false;
|
|
45
|
-
}
|
|
46
|
-
}
|
|
47
|
-
return true;
|
|
48
|
-
}).map(key => {
|
|
49
|
-
const [hash, sequenceStr] = key.split("_");
|
|
50
|
-
const sequence = BigInt("0x"+sequenceStr);
|
|
51
|
-
return {
|
|
52
|
-
obj: this.data[key],
|
|
53
|
-
hash,
|
|
54
|
-
sequence
|
|
55
|
-
}
|
|
56
|
-
}));
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
getData(paymentHash: string, sequence: bigint | null): Promise<T> {
|
|
60
|
-
return Promise.resolve(this.data[paymentHash+"_"+(sequence || 0n).toString(16).padStart(16, "0")]);
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
async saveData(hash: string, sequence: bigint | null, object: T): Promise<void> {
|
|
64
|
-
|
|
65
|
-
const _sequence = (sequence || 0n).toString(16).padStart(16, "0");
|
|
66
|
-
|
|
67
|
-
try {
|
|
68
|
-
await fs.mkdir(this.directory)
|
|
69
|
-
} catch (e) {}
|
|
70
|
-
|
|
71
|
-
this.data[hash+"_"+_sequence] = object;
|
|
72
|
-
|
|
73
|
-
const cpy = object.serialize();
|
|
74
|
-
|
|
75
|
-
await fs.writeFile(this.directory+"/"+hash+"_"+_sequence+".json", JSON.stringify(cpy));
|
|
76
|
-
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
async removeData(hash: string, sequence: bigint | null): Promise<void> {
|
|
80
|
-
const identifier = hash+"_"+(sequence || 0n).toString(16).padStart(16, "0");
|
|
81
|
-
try {
|
|
82
|
-
if(this.data[identifier]!=null) delete this.data[identifier];
|
|
83
|
-
await fs.rm(this.directory+"/"+identifier+".json");
|
|
84
|
-
} catch (e) {
|
|
85
|
-
console.error(e);
|
|
86
|
-
}
|
|
87
|
-
}
|
|
88
|
-
|
|
89
|
-
async loadData(type: new(data: any) => T): Promise<void> {
|
|
90
|
-
this.type = type;
|
|
91
|
-
|
|
92
|
-
let files: string[];
|
|
93
|
-
try {
|
|
94
|
-
files = await fs.readdir(this.directory);
|
|
95
|
-
} catch (e) {
|
|
96
|
-
console.error(e);
|
|
97
|
-
return;
|
|
98
|
-
}
|
|
99
|
-
|
|
100
|
-
for(let file of files) {
|
|
101
|
-
const indentifier = file.split(".")[0];
|
|
102
|
-
const result = await fs.readFile(this.directory+"/"+file);
|
|
103
|
-
const obj = JSON.parse(result.toString());
|
|
104
|
-
const parsed = new type(obj);
|
|
105
|
-
this.data[indentifier] = parsed;
|
|
106
|
-
}
|
|
107
|
-
}
|
|
108
|
-
|
|
109
|
-
}
|
|
1
|
+
import {StorageObject} from "@atomiqlabs/base";
|
|
2
|
+
import * as fs from "fs/promises";
|
|
3
|
+
import {IIntermediaryStorage, StorageQueryParam} from "../storage/IIntermediaryStorage";
|
|
4
|
+
|
|
5
|
+
export class IntermediaryStorageManager<T extends StorageObject> implements IIntermediaryStorage<T> {
|
|
6
|
+
|
|
7
|
+
private readonly directory: string;
|
|
8
|
+
private type: new(data: any) => T;
|
|
9
|
+
private data: {
|
|
10
|
+
[key: string]: T
|
|
11
|
+
} = {};
|
|
12
|
+
|
|
13
|
+
constructor(directory: string) {
|
|
14
|
+
this.directory = directory;
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
async init(): Promise<void> {
|
|
18
|
+
try {
|
|
19
|
+
await fs.mkdir(this.directory)
|
|
20
|
+
} catch (e) {}
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
query(params: StorageQueryParam[]): Promise<{hash: string, sequence: bigint, obj: T}[]> {
|
|
24
|
+
return Promise.resolve(Object.keys(this.data).filter((key) => {
|
|
25
|
+
const val = this.data[key];
|
|
26
|
+
for(let param of params) {
|
|
27
|
+
if(param.value!=null) {
|
|
28
|
+
if(typeof param.value === "object") {
|
|
29
|
+
if(param.value.eq!=null && !param.value.eq(val[param.key])) return false;
|
|
30
|
+
if(param.value.equals!=null && !param.value.equals(val[param.key])) return false;
|
|
31
|
+
} else {
|
|
32
|
+
if(param.value!==val[param.key]) return false;
|
|
33
|
+
}
|
|
34
|
+
} else if(param.values!=null) {
|
|
35
|
+
let hasSome = false;
|
|
36
|
+
for(let expectedValue of param.values) {
|
|
37
|
+
if(typeof expectedValue === "object") {
|
|
38
|
+
if(expectedValue.eq!=null && !expectedValue.eq(val[param.key])) hasSome = true;
|
|
39
|
+
if(expectedValue.equals!=null && !expectedValue.equals(val[param.key])) hasSome = true;
|
|
40
|
+
} else {
|
|
41
|
+
if(expectedValue===val[param.key]) hasSome = true;
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
if(!hasSome) return false;
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
return true;
|
|
48
|
+
}).map(key => {
|
|
49
|
+
const [hash, sequenceStr] = key.split("_");
|
|
50
|
+
const sequence = BigInt("0x"+sequenceStr);
|
|
51
|
+
return {
|
|
52
|
+
obj: this.data[key],
|
|
53
|
+
hash,
|
|
54
|
+
sequence
|
|
55
|
+
}
|
|
56
|
+
}));
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
getData(paymentHash: string, sequence: bigint | null): Promise<T> {
|
|
60
|
+
return Promise.resolve(this.data[paymentHash+"_"+(sequence || 0n).toString(16).padStart(16, "0")]);
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
async saveData(hash: string, sequence: bigint | null, object: T): Promise<void> {
|
|
64
|
+
|
|
65
|
+
const _sequence = (sequence || 0n).toString(16).padStart(16, "0");
|
|
66
|
+
|
|
67
|
+
try {
|
|
68
|
+
await fs.mkdir(this.directory)
|
|
69
|
+
} catch (e) {}
|
|
70
|
+
|
|
71
|
+
this.data[hash+"_"+_sequence] = object;
|
|
72
|
+
|
|
73
|
+
const cpy = object.serialize();
|
|
74
|
+
|
|
75
|
+
await fs.writeFile(this.directory+"/"+hash+"_"+_sequence+".json", JSON.stringify(cpy));
|
|
76
|
+
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
async removeData(hash: string, sequence: bigint | null): Promise<void> {
|
|
80
|
+
const identifier = hash+"_"+(sequence || 0n).toString(16).padStart(16, "0");
|
|
81
|
+
try {
|
|
82
|
+
if(this.data[identifier]!=null) delete this.data[identifier];
|
|
83
|
+
await fs.rm(this.directory+"/"+identifier+".json");
|
|
84
|
+
} catch (e) {
|
|
85
|
+
console.error(e);
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
async loadData(type: new(data: any) => T): Promise<void> {
|
|
90
|
+
this.type = type;
|
|
91
|
+
|
|
92
|
+
let files: string[];
|
|
93
|
+
try {
|
|
94
|
+
files = await fs.readdir(this.directory);
|
|
95
|
+
} catch (e) {
|
|
96
|
+
console.error(e);
|
|
97
|
+
return;
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
for(let file of files) {
|
|
101
|
+
const indentifier = file.split(".")[0];
|
|
102
|
+
const result = await fs.readFile(this.directory+"/"+file);
|
|
103
|
+
const obj = JSON.parse(result.toString());
|
|
104
|
+
const parsed = new type(obj);
|
|
105
|
+
this.data[indentifier] = parsed;
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
}
|
|
@@ -1,68 +1,68 @@
|
|
|
1
|
-
import {StorageObject, IStorageManager} from "@atomiqlabs/base";
|
|
2
|
-
import * as fs from "fs/promises";
|
|
3
|
-
|
|
4
|
-
export class StorageManager<T extends StorageObject> implements IStorageManager<T> {
|
|
5
|
-
|
|
6
|
-
private readonly directory: string;
|
|
7
|
-
data: {
|
|
8
|
-
[key: string]: T
|
|
9
|
-
} = {};
|
|
10
|
-
|
|
11
|
-
constructor(directory: string) {
|
|
12
|
-
this.directory = directory;
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
async init(): Promise<void> {
|
|
16
|
-
try {
|
|
17
|
-
await fs.mkdir(this.directory)
|
|
18
|
-
} catch (e) {}
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
async saveData(hash: string, object: T): Promise<void> {
|
|
22
|
-
|
|
23
|
-
try {
|
|
24
|
-
await fs.mkdir(this.directory)
|
|
25
|
-
} catch (e) {}
|
|
26
|
-
|
|
27
|
-
this.data[hash] = object;
|
|
28
|
-
|
|
29
|
-
const cpy = object.serialize();
|
|
30
|
-
|
|
31
|
-
await fs.writeFile(this.directory+"/"+hash+".json", JSON.stringify(cpy));
|
|
32
|
-
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
async removeData(hash: string): Promise<void> {
|
|
36
|
-
const paymentHash = hash;
|
|
37
|
-
try {
|
|
38
|
-
if(this.data[paymentHash]!=null) delete this.data[paymentHash];
|
|
39
|
-
await fs.rm(this.directory+"/"+paymentHash+".json");
|
|
40
|
-
} catch (e) {
|
|
41
|
-
console.error(e);
|
|
42
|
-
}
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
async loadData(type: new(data: any) => T): Promise<T[]> {
|
|
46
|
-
let files;
|
|
47
|
-
try {
|
|
48
|
-
files = await fs.readdir(this.directory);
|
|
49
|
-
} catch (e) {
|
|
50
|
-
console.error(e);
|
|
51
|
-
return [];
|
|
52
|
-
}
|
|
53
|
-
|
|
54
|
-
const arr = [];
|
|
55
|
-
|
|
56
|
-
for(let file of files) {
|
|
57
|
-
const paymentHash = file.split(".")[0];
|
|
58
|
-
const result = await fs.readFile(this.directory+"/"+file);
|
|
59
|
-
const obj = JSON.parse(result.toString());
|
|
60
|
-
const parsed = new type(obj);
|
|
61
|
-
arr.push(parsed);
|
|
62
|
-
this.data[paymentHash] = parsed;
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
return arr;
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
}
|
|
1
|
+
import {StorageObject, IStorageManager} from "@atomiqlabs/base";
|
|
2
|
+
import * as fs from "fs/promises";
|
|
3
|
+
|
|
4
|
+
export class StorageManager<T extends StorageObject> implements IStorageManager<T> {
|
|
5
|
+
|
|
6
|
+
private readonly directory: string;
|
|
7
|
+
data: {
|
|
8
|
+
[key: string]: T
|
|
9
|
+
} = {};
|
|
10
|
+
|
|
11
|
+
constructor(directory: string) {
|
|
12
|
+
this.directory = directory;
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
async init(): Promise<void> {
|
|
16
|
+
try {
|
|
17
|
+
await fs.mkdir(this.directory)
|
|
18
|
+
} catch (e) {}
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
async saveData(hash: string, object: T): Promise<void> {
|
|
22
|
+
|
|
23
|
+
try {
|
|
24
|
+
await fs.mkdir(this.directory)
|
|
25
|
+
} catch (e) {}
|
|
26
|
+
|
|
27
|
+
this.data[hash] = object;
|
|
28
|
+
|
|
29
|
+
const cpy = object.serialize();
|
|
30
|
+
|
|
31
|
+
await fs.writeFile(this.directory+"/"+hash+".json", JSON.stringify(cpy));
|
|
32
|
+
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
async removeData(hash: string): Promise<void> {
|
|
36
|
+
const paymentHash = hash;
|
|
37
|
+
try {
|
|
38
|
+
if(this.data[paymentHash]!=null) delete this.data[paymentHash];
|
|
39
|
+
await fs.rm(this.directory+"/"+paymentHash+".json");
|
|
40
|
+
} catch (e) {
|
|
41
|
+
console.error(e);
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
async loadData(type: new(data: any) => T): Promise<T[]> {
|
|
46
|
+
let files;
|
|
47
|
+
try {
|
|
48
|
+
files = await fs.readdir(this.directory);
|
|
49
|
+
} catch (e) {
|
|
50
|
+
console.error(e);
|
|
51
|
+
return [];
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
const arr = [];
|
|
55
|
+
|
|
56
|
+
for(let file of files) {
|
|
57
|
+
const paymentHash = file.split(".")[0];
|
|
58
|
+
const result = await fs.readFile(this.directory+"/"+file);
|
|
59
|
+
const obj = JSON.parse(result.toString());
|
|
60
|
+
const parsed = new type(obj);
|
|
61
|
+
arr.push(parsed);
|
|
62
|
+
this.data[paymentHash] = parsed;
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
return arr;
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
}
|