@atomiqlabs/sdk 7.0.8 → 7.0.10

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.
@@ -1,52 +1,52 @@
1
- import { ChainData, BitcoinNetwork, BitcoinRpc, BaseTokenType, ChainType, StorageObject, IStorageManager, Messenger } from "@atomiqlabs/base";
2
- import { BtcToken, CustomPriceFunction, MempoolApi, MempoolBitcoinRpc, SCToken, Swapper, SwapperOptions } from "@atomiqlabs/sdk-lib";
3
- type ChainInitializer<O, C extends ChainType, T extends BaseTokenType> = {
4
- chainId: ChainType["ChainId"];
5
- chainType: ChainType;
6
- initializer: (options: O, bitcoinRelay: BitcoinRpc<any>, network: BitcoinNetwork, storageCtor: <T extends StorageObject>(name: string) => IStorageManager<T>) => ChainData<C>;
7
- tokens: T;
8
- options: O;
9
- };
10
- type TokensDict<T extends ChainInitializer<any, any, any>> = {
11
- [K in T["chainId"]]: {
12
- [val in keyof T["tokens"]]: SCToken<K>;
13
- };
14
- };
15
- type GetAllTokens<T extends readonly ChainInitializer<any, any, any>[]> = (T extends readonly [infer First extends ChainInitializer<any, any, any>, ...infer Rest extends ChainInitializer<any, any, any>[]] ? TokensDict<First> & GetAllTokens<Rest> : unknown);
16
- export type TokenResolverDict<T extends ChainInitializer<any, any, any>> = {
17
- [K in T["chainId"]]: {
18
- getToken: (address: string) => SCToken<K>;
19
- };
20
- };
21
- type GetAllTokenResolvers<T extends readonly ChainInitializer<any, any, any>[]> = (T extends readonly [infer First extends ChainInitializer<any, any, any>, ...infer Rest extends ChainInitializer<any, any, any>[]] ? TokenResolverDict<First> & GetAllTokenResolvers<Rest> : unknown);
22
- type OptionsDict<T extends ChainInitializer<any, any, any>> = {
23
- [K in T["chainId"]]: T["options"];
24
- };
25
- type GetAllOptions<T extends readonly ChainInitializer<any, any, any>[]> = (T extends readonly [infer First extends ChainInitializer<any, any, any>, ...infer Rest extends ChainInitializer<any, any, any>[]] ? OptionsDict<First> & GetAllOptions<Rest> : unknown);
26
- type ChainTypeDict<T extends ChainInitializer<any, any, any>> = {
27
- [K in T["chainId"]]: T["chainType"];
28
- };
29
- type ToMultichain<T extends readonly ChainInitializer<any, any, any>[]> = (T extends readonly [infer First extends ChainInitializer<any, any, any>, ...infer Rest extends ChainInitializer<any, any, any>[]] ? ChainTypeDict<First> & ToMultichain<Rest> : {});
30
- export type MultichainSwapperOptions<T extends readonly ChainInitializer<any, any, any>[]> = SwapperOptions & {
31
- chains: GetAllOptions<T>;
32
- } & {
33
- chainStorageCtor?: <T extends StorageObject>(name: string) => IStorageManager<T>;
34
- pricingFeeDifferencePPM?: bigint;
35
- mempoolApi?: MempoolApi | MempoolBitcoinRpc | string | string[];
36
- messenger?: Messenger;
37
- getPriceFn?: CustomPriceFunction;
38
- };
39
- export declare class SwapperFactory<T extends readonly ChainInitializer<any, any, any>[]> {
40
- readonly initializers: T;
41
- Tokens: GetAllTokens<T> & {
42
- BITCOIN: {
43
- BTC: BtcToken<false>;
44
- BTCLN: BtcToken<true>;
45
- };
46
- };
47
- TokenResolver: GetAllTokenResolvers<T>;
48
- constructor(initializers: T);
49
- newSwapper(options: MultichainSwapperOptions<T>): Swapper<ToMultichain<T>>;
50
- newSwapperInitialized(options: MultichainSwapperOptions<T>): Promise<Swapper<ToMultichain<T>>>;
51
- }
52
- export {};
1
+ import { ChainData, BitcoinNetwork, BitcoinRpc, BaseTokenType, ChainType, StorageObject, IStorageManager, Messenger } from "@atomiqlabs/base";
2
+ import { BtcToken, CustomPriceFunction, MempoolApi, MempoolBitcoinRpc, SCToken, Swapper, SwapperOptions } from "@atomiqlabs/sdk-lib";
3
+ type ChainInitializer<O, C extends ChainType, T extends BaseTokenType> = {
4
+ chainId: ChainType["ChainId"];
5
+ chainType: ChainType;
6
+ initializer: (options: O, bitcoinRelay: BitcoinRpc<any>, network: BitcoinNetwork, storageCtor: <T extends StorageObject>(name: string) => IStorageManager<T>) => ChainData<C>;
7
+ tokens: T;
8
+ options: O;
9
+ };
10
+ type TokensDict<T extends ChainInitializer<any, any, any>> = {
11
+ [K in T["chainId"]]: {
12
+ [val in keyof T["tokens"]]: SCToken<K>;
13
+ };
14
+ };
15
+ type GetAllTokens<T extends readonly ChainInitializer<any, any, any>[]> = (T extends readonly [infer First extends ChainInitializer<any, any, any>, ...infer Rest extends ChainInitializer<any, any, any>[]] ? TokensDict<First> & GetAllTokens<Rest> : unknown);
16
+ export type TokenResolverDict<T extends ChainInitializer<any, any, any>> = {
17
+ [K in T["chainId"]]: {
18
+ getToken: (address: string) => SCToken<K>;
19
+ };
20
+ };
21
+ type GetAllTokenResolvers<T extends readonly ChainInitializer<any, any, any>[]> = (T extends readonly [infer First extends ChainInitializer<any, any, any>, ...infer Rest extends ChainInitializer<any, any, any>[]] ? TokenResolverDict<First> & GetAllTokenResolvers<Rest> : unknown);
22
+ type OptionsDict<T extends ChainInitializer<any, any, any>> = {
23
+ [K in T["chainId"]]: T["options"];
24
+ };
25
+ type GetAllOptions<T extends readonly ChainInitializer<any, any, any>[]> = (T extends readonly [infer First extends ChainInitializer<any, any, any>, ...infer Rest extends ChainInitializer<any, any, any>[]] ? OptionsDict<First> & GetAllOptions<Rest> : unknown);
26
+ type ChainTypeDict<T extends ChainInitializer<any, any, any>> = {
27
+ [K in T["chainId"]]: T["chainType"];
28
+ };
29
+ type ToMultichain<T extends readonly ChainInitializer<any, any, any>[]> = (T extends readonly [infer First extends ChainInitializer<any, any, any>, ...infer Rest extends ChainInitializer<any, any, any>[]] ? ChainTypeDict<First> & ToMultichain<Rest> : {});
30
+ export type MultichainSwapperOptions<T extends readonly ChainInitializer<any, any, any>[]> = SwapperOptions & {
31
+ chains: GetAllOptions<T>;
32
+ } & {
33
+ chainStorageCtor?: <T extends StorageObject>(name: string) => IStorageManager<T>;
34
+ pricingFeeDifferencePPM?: bigint;
35
+ mempoolApi?: MempoolApi | MempoolBitcoinRpc | string | string[];
36
+ messenger?: Messenger;
37
+ getPriceFn?: CustomPriceFunction;
38
+ };
39
+ export declare class SwapperFactory<T extends readonly ChainInitializer<any, any, any>[]> {
40
+ readonly initializers: T;
41
+ Tokens: GetAllTokens<T> & {
42
+ BITCOIN: {
43
+ BTC: BtcToken<false>;
44
+ BTCLN: BtcToken<true>;
45
+ };
46
+ };
47
+ TokenResolver: GetAllTokenResolvers<T>;
48
+ constructor(initializers: T);
49
+ newSwapper(options: MultichainSwapperOptions<T>): Swapper<ToMultichain<T>>;
50
+ newSwapperInitialized(options: MultichainSwapperOptions<T>): Promise<Swapper<ToMultichain<T>>>;
51
+ }
52
+ export {};
@@ -1,118 +1,118 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.SwapperFactory = void 0;
4
- const base_1 = require("@atomiqlabs/base");
5
- const sdk_lib_1 = require("@atomiqlabs/sdk-lib");
6
- const SmartChainAssets_1 = require("./SmartChainAssets");
7
- const LocalStorageManager_1 = require("./storage/LocalStorageManager");
8
- const messenger_nostr_1 = require("@atomiqlabs/messenger-nostr");
9
- const registries = {
10
- [base_1.BitcoinNetwork.MAINNET]: "https://api.github.com/repos/adambor/SolLightning-registry/contents/registry-mainnet.json?ref=main",
11
- [base_1.BitcoinNetwork.TESTNET]: "https://api.github.com/repos/adambor/SolLightning-registry/contents/registry.json?ref=main",
12
- [base_1.BitcoinNetwork.TESTNET4]: "https://api.github.com/repos/adambor/SolLightning-registry/contents/registry-testnet4.json?ref=main"
13
- };
14
- const trustedIntermediaries = {
15
- [base_1.BitcoinNetwork.MAINNET]: "https://node3.gethopa.com:34100",
16
- [base_1.BitcoinNetwork.TESTNET]: "https://node3.gethopa.com:24100"
17
- };
18
- const mempoolUrls = {
19
- [base_1.BitcoinNetwork.MAINNET]: [
20
- "https://mempool.space/api/",
21
- "https://mempool.holdings/api/",
22
- "https://mempool.fra.mempool.space/api/",
23
- "https://mempool.va1.mempool.space/api/",
24
- "https://mempool.tk7.mempool.space/api/"
25
- ],
26
- [base_1.BitcoinNetwork.TESTNET]: [
27
- "https://mempool.space/testnet/api/",
28
- "https://mempool.holdings/testnet/api/",
29
- "https://mempool.fra.mempool.space/testnet/api/",
30
- "https://mempool.va1.mempool.space/testnet/api/",
31
- "https://mempool.tk7.mempool.space/testnet/api/"
32
- ],
33
- [base_1.BitcoinNetwork.TESTNET4]: [
34
- "https://mempool.space/testnet4/api/",
35
- "https://mempool.holdings/testnet4/api/",
36
- "https://mempool.fra.mempool.space/testnet4/api/",
37
- "https://mempool.va1.mempool.space/testnet4/api/",
38
- "https://mempool.tk7.mempool.space/testnet4/api/"
39
- ]
40
- };
41
- const nostrUrls = [
42
- "wss://relay.damus.io", "wss://nostr.einundzwanzig.space", "wss://relay01.lnfi.network/", "wss://relay.puresignal.news/", "wss://relay.fountain.fm/", "wss://sendit.nosflare.com/"
43
- ];
44
- class SwapperFactory {
45
- constructor(initializers) {
46
- this.initializers = initializers;
47
- this.Tokens = {
48
- BITCOIN: sdk_lib_1.BitcoinTokens
49
- };
50
- this.TokenResolver = {};
51
- this.initializers = initializers;
52
- initializers.forEach(initializer => {
53
- const addressMap = {};
54
- this.Tokens[initializer.chainId] = {};
55
- for (let ticker in initializer.tokens) {
56
- const assetData = initializer.tokens[ticker];
57
- this.Tokens[initializer.chainId][ticker] = addressMap[assetData.address] = {
58
- chain: "SC",
59
- chainId: initializer.chainId,
60
- address: assetData.address,
61
- name: SmartChainAssets_1.SmartChainAssets[ticker]?.name ?? ticker,
62
- decimals: assetData.decimals,
63
- displayDecimals: assetData.displayDecimals,
64
- ticker
65
- };
66
- }
67
- this.TokenResolver[initializer.chainId] = {
68
- getToken: (address) => addressMap[address]
69
- };
70
- });
71
- }
72
- newSwapper(options) {
73
- options.bitcoinNetwork ?? (options.bitcoinNetwork = base_1.BitcoinNetwork.MAINNET);
74
- options.storagePrefix ?? (options.storagePrefix = "atomiqsdk-" + options.bitcoinNetwork + "-");
75
- options.messenger ?? (options.messenger = new messenger_nostr_1.NostrMessenger(options.bitcoinNetwork, nostrUrls));
76
- options.defaultTrustedIntermediaryUrl ?? (options.defaultTrustedIntermediaryUrl = trustedIntermediaries[options.bitcoinNetwork]);
77
- options.registryUrl ?? (options.registryUrl = registries[options.bitcoinNetwork]);
78
- const mempoolApi = options.mempoolApi ?? new sdk_lib_1.MempoolBitcoinRpc(mempoolUrls[options.bitcoinNetwork]);
79
- const bitcoinRpc = mempoolApi instanceof sdk_lib_1.MempoolBitcoinRpc ? mempoolApi : new sdk_lib_1.MempoolBitcoinRpc(mempoolApi);
80
- const pricingAssets = [];
81
- Object.keys(SmartChainAssets_1.SmartChainAssets).forEach((ticker) => {
82
- const chains = {};
83
- for (let { tokens, chainId } of this.initializers) {
84
- if (tokens[ticker] != null)
85
- chains[chainId] = tokens[ticker];
86
- }
87
- const assetData = SmartChainAssets_1.SmartChainAssets[ticker];
88
- pricingAssets.push({
89
- ...assetData.pricing,
90
- chains,
91
- ticker,
92
- name: assetData.name
93
- });
94
- });
95
- options.chainStorageCtor ?? (options.chainStorageCtor = (name) => new LocalStorageManager_1.LocalStorageManager(name));
96
- const chains = {};
97
- for (let { initializer, chainId } of this.initializers) {
98
- if (options.chains[chainId] == null)
99
- continue;
100
- chains[chainId] = initializer(options.chains[chainId], bitcoinRpc, options.bitcoinNetwork, options.chainStorageCtor);
101
- }
102
- const swapPricing = options.getPriceFn != null ?
103
- new sdk_lib_1.SingleSwapPrice(options.pricingFeeDifferencePPM ?? 10000n, new sdk_lib_1.CustomPriceProvider(pricingAssets.map(val => {
104
- return {
105
- coinId: val.ticker,
106
- chains: val.chains
107
- };
108
- }), options.getPriceFn)) :
109
- sdk_lib_1.RedundantSwapPrice.createFromTokenMap(options.pricingFeeDifferencePPM ?? 10000n, pricingAssets);
110
- return new sdk_lib_1.Swapper(bitcoinRpc, chains, swapPricing, pricingAssets, options.messenger, options);
111
- }
112
- async newSwapperInitialized(options) {
113
- const swapper = this.newSwapper(options);
114
- await swapper.init();
115
- return swapper;
116
- }
117
- }
118
- exports.SwapperFactory = SwapperFactory;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.SwapperFactory = void 0;
4
+ const base_1 = require("@atomiqlabs/base");
5
+ const sdk_lib_1 = require("@atomiqlabs/sdk-lib");
6
+ const SmartChainAssets_1 = require("./SmartChainAssets");
7
+ const LocalStorageManager_1 = require("./storage/LocalStorageManager");
8
+ const messenger_nostr_1 = require("@atomiqlabs/messenger-nostr");
9
+ const registries = {
10
+ [base_1.BitcoinNetwork.MAINNET]: "https://api.github.com/repos/adambor/SolLightning-registry/contents/registry-mainnet.json?ref=main",
11
+ [base_1.BitcoinNetwork.TESTNET]: "https://api.github.com/repos/adambor/SolLightning-registry/contents/registry.json?ref=main",
12
+ [base_1.BitcoinNetwork.TESTNET4]: "https://api.github.com/repos/adambor/SolLightning-registry/contents/registry-testnet4.json?ref=main"
13
+ };
14
+ const trustedIntermediaries = {
15
+ [base_1.BitcoinNetwork.MAINNET]: "https://node3.gethopa.com:34100",
16
+ [base_1.BitcoinNetwork.TESTNET]: "https://node3.gethopa.com:24100"
17
+ };
18
+ const mempoolUrls = {
19
+ [base_1.BitcoinNetwork.MAINNET]: [
20
+ "https://mempool.space/api/",
21
+ "https://mempool.holdings/api/",
22
+ "https://mempool.fra.mempool.space/api/",
23
+ "https://mempool.va1.mempool.space/api/",
24
+ "https://mempool.tk7.mempool.space/api/"
25
+ ],
26
+ [base_1.BitcoinNetwork.TESTNET]: [
27
+ "https://mempool.space/testnet/api/",
28
+ "https://mempool.holdings/testnet/api/",
29
+ "https://mempool.fra.mempool.space/testnet/api/",
30
+ "https://mempool.va1.mempool.space/testnet/api/",
31
+ "https://mempool.tk7.mempool.space/testnet/api/"
32
+ ],
33
+ [base_1.BitcoinNetwork.TESTNET4]: [
34
+ "https://mempool.space/testnet4/api/",
35
+ "https://mempool.holdings/testnet4/api/",
36
+ "https://mempool.fra.mempool.space/testnet4/api/",
37
+ "https://mempool.va1.mempool.space/testnet4/api/",
38
+ "https://mempool.tk7.mempool.space/testnet4/api/"
39
+ ]
40
+ };
41
+ const nostrUrls = [
42
+ "wss://relay.damus.io", "wss://nostr.einundzwanzig.space", "wss://relay01.lnfi.network/", "wss://relay.puresignal.news/", "wss://relay.fountain.fm/", "wss://sendit.nosflare.com/"
43
+ ];
44
+ class SwapperFactory {
45
+ constructor(initializers) {
46
+ this.initializers = initializers;
47
+ this.Tokens = {
48
+ BITCOIN: sdk_lib_1.BitcoinTokens
49
+ };
50
+ this.TokenResolver = {};
51
+ this.initializers = initializers;
52
+ initializers.forEach(initializer => {
53
+ const addressMap = {};
54
+ this.Tokens[initializer.chainId] = {};
55
+ for (let ticker in initializer.tokens) {
56
+ const assetData = initializer.tokens[ticker];
57
+ this.Tokens[initializer.chainId][ticker] = addressMap[assetData.address] = {
58
+ chain: "SC",
59
+ chainId: initializer.chainId,
60
+ address: assetData.address,
61
+ name: SmartChainAssets_1.SmartChainAssets[ticker]?.name ?? ticker,
62
+ decimals: assetData.decimals,
63
+ displayDecimals: assetData.displayDecimals,
64
+ ticker
65
+ };
66
+ }
67
+ this.TokenResolver[initializer.chainId] = {
68
+ getToken: (address) => addressMap[address]
69
+ };
70
+ });
71
+ }
72
+ newSwapper(options) {
73
+ options.bitcoinNetwork ?? (options.bitcoinNetwork = base_1.BitcoinNetwork.MAINNET);
74
+ options.storagePrefix ?? (options.storagePrefix = "atomiqsdk-" + options.bitcoinNetwork + "-");
75
+ options.messenger ?? (options.messenger = new messenger_nostr_1.NostrMessenger(options.bitcoinNetwork, nostrUrls));
76
+ options.defaultTrustedIntermediaryUrl ?? (options.defaultTrustedIntermediaryUrl = trustedIntermediaries[options.bitcoinNetwork]);
77
+ options.registryUrl ?? (options.registryUrl = registries[options.bitcoinNetwork]);
78
+ const mempoolApi = options.mempoolApi ?? new sdk_lib_1.MempoolBitcoinRpc(mempoolUrls[options.bitcoinNetwork]);
79
+ const bitcoinRpc = mempoolApi instanceof sdk_lib_1.MempoolBitcoinRpc ? mempoolApi : new sdk_lib_1.MempoolBitcoinRpc(mempoolApi);
80
+ const pricingAssets = [];
81
+ Object.keys(SmartChainAssets_1.SmartChainAssets).forEach((ticker) => {
82
+ const chains = {};
83
+ for (let { tokens, chainId } of this.initializers) {
84
+ if (tokens[ticker] != null)
85
+ chains[chainId] = tokens[ticker];
86
+ }
87
+ const assetData = SmartChainAssets_1.SmartChainAssets[ticker];
88
+ pricingAssets.push({
89
+ ...assetData.pricing,
90
+ chains,
91
+ ticker,
92
+ name: assetData.name
93
+ });
94
+ });
95
+ options.chainStorageCtor ?? (options.chainStorageCtor = (name) => new LocalStorageManager_1.LocalStorageManager(name));
96
+ const chains = {};
97
+ for (let { initializer, chainId } of this.initializers) {
98
+ if (options.chains[chainId] == null)
99
+ continue;
100
+ chains[chainId] = initializer(options.chains[chainId], bitcoinRpc, options.bitcoinNetwork, options.chainStorageCtor);
101
+ }
102
+ const swapPricing = options.getPriceFn != null ?
103
+ new sdk_lib_1.SingleSwapPrice(options.pricingFeeDifferencePPM ?? 10000n, new sdk_lib_1.CustomPriceProvider(pricingAssets.map(val => {
104
+ return {
105
+ coinId: val.ticker,
106
+ chains: val.chains
107
+ };
108
+ }), options.getPriceFn)) :
109
+ sdk_lib_1.RedundantSwapPrice.createFromTokenMap(options.pricingFeeDifferencePPM ?? 10000n, pricingAssets);
110
+ return new sdk_lib_1.Swapper(bitcoinRpc, chains, swapPricing, pricingAssets, options.messenger, options);
111
+ }
112
+ async newSwapperInitialized(options) {
113
+ const swapper = this.newSwapper(options);
114
+ await swapper.init();
115
+ return swapper;
116
+ }
117
+ }
118
+ exports.SwapperFactory = SwapperFactory;
package/dist/Utils.d.ts CHANGED
@@ -1,11 +1,11 @@
1
- import { Token } from "@atomiqlabs/sdk-lib";
2
- export declare function toHumanReadableString(amount: bigint, currencySpec: Token): string;
3
- export declare function fromHumanReadableString(amount: string, currencySpec: Token): bigint;
4
- /**
5
- * Returns an abort signal that aborts after a specified timeout in milliseconds
6
- *
7
- * @param timeout Milliseconds to wait
8
- * @param abortReason Abort with this abort reason
9
- * @param abortSignal Abort signal to extend
10
- */
11
- export declare function timeoutSignal(timeout: number, abortReason?: any, abortSignal?: AbortSignal): AbortSignal;
1
+ import { Token } from "@atomiqlabs/sdk-lib";
2
+ export declare function toHumanReadableString(amount: bigint, currencySpec: Token): string;
3
+ export declare function fromHumanReadableString(amount: string, currencySpec: Token): bigint;
4
+ /**
5
+ * Returns an abort signal that aborts after a specified timeout in milliseconds
6
+ *
7
+ * @param timeout Milliseconds to wait
8
+ * @param abortReason Abort with this abort reason
9
+ * @param abortSignal Abort signal to extend
10
+ */
11
+ export declare function timeoutSignal(timeout: number, abortReason?: any, abortSignal?: AbortSignal): AbortSignal;
package/dist/Utils.js CHANGED
@@ -1,37 +1,37 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.timeoutSignal = exports.fromHumanReadableString = exports.toHumanReadableString = void 0;
4
- const sdk_lib_1 = require("@atomiqlabs/sdk-lib");
5
- function toHumanReadableString(amount, currencySpec) {
6
- if (amount == null)
7
- return null;
8
- return (0, sdk_lib_1.toDecimal)(amount, currencySpec.decimals, undefined, currencySpec.displayDecimals);
9
- }
10
- exports.toHumanReadableString = toHumanReadableString;
11
- function fromHumanReadableString(amount, currencySpec) {
12
- if (amount === "" || amount == null)
13
- return null;
14
- return (0, sdk_lib_1.fromDecimal)(amount, currencySpec.decimals);
15
- }
16
- exports.fromHumanReadableString = fromHumanReadableString;
17
- /**
18
- * Returns an abort signal that aborts after a specified timeout in milliseconds
19
- *
20
- * @param timeout Milliseconds to wait
21
- * @param abortReason Abort with this abort reason
22
- * @param abortSignal Abort signal to extend
23
- */
24
- function timeoutSignal(timeout, abortReason, abortSignal) {
25
- if (timeout == null)
26
- return abortSignal;
27
- const abortController = new AbortController();
28
- const timeoutHandle = setTimeout(() => abortController.abort(abortReason || new Error("Timed out")), timeout);
29
- if (abortSignal != null) {
30
- abortSignal.addEventListener("abort", () => {
31
- clearTimeout(timeoutHandle);
32
- abortController.abort(abortSignal.reason);
33
- });
34
- }
35
- return abortController.signal;
36
- }
37
- exports.timeoutSignal = timeoutSignal;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.timeoutSignal = exports.fromHumanReadableString = exports.toHumanReadableString = void 0;
4
+ const sdk_lib_1 = require("@atomiqlabs/sdk-lib");
5
+ function toHumanReadableString(amount, currencySpec) {
6
+ if (amount == null)
7
+ return null;
8
+ return (0, sdk_lib_1.toDecimal)(amount, currencySpec.decimals, undefined, currencySpec.displayDecimals);
9
+ }
10
+ exports.toHumanReadableString = toHumanReadableString;
11
+ function fromHumanReadableString(amount, currencySpec) {
12
+ if (amount === "" || amount == null)
13
+ return null;
14
+ return (0, sdk_lib_1.fromDecimal)(amount, currencySpec.decimals);
15
+ }
16
+ exports.fromHumanReadableString = fromHumanReadableString;
17
+ /**
18
+ * Returns an abort signal that aborts after a specified timeout in milliseconds
19
+ *
20
+ * @param timeout Milliseconds to wait
21
+ * @param abortReason Abort with this abort reason
22
+ * @param abortSignal Abort signal to extend
23
+ */
24
+ function timeoutSignal(timeout, abortReason, abortSignal) {
25
+ if (timeout == null)
26
+ return abortSignal;
27
+ const abortController = new AbortController();
28
+ const timeoutHandle = setTimeout(() => abortController.abort(abortReason || new Error("Timed out")), timeout);
29
+ if (abortSignal != null) {
30
+ abortSignal.addEventListener("abort", () => {
31
+ clearTimeout(timeoutHandle);
32
+ abortController.abort(abortSignal.reason);
33
+ });
34
+ }
35
+ return abortController.signal;
36
+ }
37
+ exports.timeoutSignal = timeoutSignal;
@@ -1,15 +1,15 @@
1
- import { StorageObject, IStorageManager } from "@atomiqlabs/base";
2
- /**
3
- * StorageManager using local filesystem to persists data, creates a new file for every save object
4
- */
5
- export declare class FileSystemStorageManager<T extends StorageObject> implements IStorageManager<T> {
6
- private readonly directory;
7
- data: {
8
- [key: string]: T;
9
- };
10
- constructor(directory: string);
11
- init(): Promise<void>;
12
- saveData(hash: string, object: T): Promise<void>;
13
- removeData(hash: string): Promise<void>;
14
- loadData(type: new (data: any) => T): Promise<T[]>;
15
- }
1
+ import { StorageObject, IStorageManager } from "@atomiqlabs/base";
2
+ /**
3
+ * StorageManager using local filesystem to persists data, creates a new file for every save object
4
+ */
5
+ export declare class FileSystemStorageManager<T extends StorageObject> implements IStorageManager<T> {
6
+ private readonly directory;
7
+ data: {
8
+ [key: string]: T;
9
+ };
10
+ constructor(directory: string);
11
+ init(): Promise<void>;
12
+ saveData(hash: string, object: T): Promise<void>;
13
+ removeData(hash: string): Promise<void>;
14
+ loadData(type: new (data: any) => T): Promise<T[]>;
15
+ }
@@ -1,60 +1,60 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.FileSystemStorageManager = void 0;
4
- const fs = require("fs/promises");
5
- /**
6
- * StorageManager using local filesystem to persists data, creates a new file for every save object
7
- */
8
- class FileSystemStorageManager {
9
- constructor(directory) {
10
- this.data = {};
11
- this.directory = 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
- console.error("FileSystemStorageManager: removeData(): Error: ", e);
37
- }
38
- }
39
- async loadData(type) {
40
- let files;
41
- try {
42
- files = await fs.readdir(this.directory);
43
- }
44
- catch (e) {
45
- console.error("FileSystemStorageManager: loadData(): Error: ", e);
46
- return [];
47
- }
48
- const arr = [];
49
- for (let file of files) {
50
- const paymentHash = file.split(".")[0];
51
- const result = await fs.readFile(this.directory + "/" + file);
52
- const obj = JSON.parse(result.toString());
53
- const parsed = new type(obj);
54
- arr.push(parsed);
55
- this.data[paymentHash] = parsed;
56
- }
57
- return arr;
58
- }
59
- }
60
- exports.FileSystemStorageManager = FileSystemStorageManager;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.FileSystemStorageManager = void 0;
4
+ const fs = require("fs/promises");
5
+ /**
6
+ * StorageManager using local filesystem to persists data, creates a new file for every save object
7
+ */
8
+ class FileSystemStorageManager {
9
+ constructor(directory) {
10
+ this.data = {};
11
+ this.directory = 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
+ console.error("FileSystemStorageManager: removeData(): Error: ", e);
37
+ }
38
+ }
39
+ async loadData(type) {
40
+ let files;
41
+ try {
42
+ files = await fs.readdir(this.directory);
43
+ }
44
+ catch (e) {
45
+ console.error("FileSystemStorageManager: loadData(): Error: ", e);
46
+ return [];
47
+ }
48
+ const arr = [];
49
+ for (let file of files) {
50
+ const paymentHash = file.split(".")[0];
51
+ const result = await fs.readFile(this.directory + "/" + file);
52
+ const obj = JSON.parse(result.toString());
53
+ const parsed = new type(obj);
54
+ arr.push(parsed);
55
+ this.data[paymentHash] = parsed;
56
+ }
57
+ return arr;
58
+ }
59
+ }
60
+ exports.FileSystemStorageManager = FileSystemStorageManager;
@@ -1 +1 @@
1
- export * from "./FileSystemStorageManager";
1
+ export * from "./FileSystemStorageManager";
@@ -1,17 +1,17 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
- for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
- };
16
- Object.defineProperty(exports, "__esModule", { value: true });
17
- __exportStar(require("./FileSystemStorageManager"), exports);
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./FileSystemStorageManager"), exports);