@atomiqlabs/sdk 1.0.0-beta5 → 1.0.0-beta6
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/dist/MultichainSwapper.d.ts +2 -0
- package/dist/MultichainSwapper.js +2 -2
- package/dist/chains/solana/SolanaChainInitializer.d.ts +2 -1
- package/dist/chains/solana/SolanaChainInitializer.js +5 -5
- package/package.json +1 -1
- package/src/MultichainSwapper.ts +3 -2
- package/src/chains/solana/SolanaChainInitializer.ts +4 -2
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { BtcToken, SCToken, Swapper, SwapperOptions } from "crosslightning-sdk-base";
|
|
2
2
|
import { SdkSolanaType } from "./chains/solana/SolanaChainInitializer";
|
|
3
3
|
import { SdkChain } from "./chains/ChainInitializer";
|
|
4
|
+
import * as BN from "bn.js";
|
|
4
5
|
import { IStorageManager, StorageObject } from "crosslightning-base";
|
|
5
6
|
type Chains = {
|
|
6
7
|
"SOLANA": SdkSolanaType;
|
|
@@ -17,6 +18,7 @@ export type MultichainSwapperOptions = SwapperOptions & {
|
|
|
17
18
|
};
|
|
18
19
|
} & {
|
|
19
20
|
storageCtor?: <T extends StorageObject>(name: string) => IStorageManager<T>;
|
|
21
|
+
pricingFeeDifferencePPM?: BN;
|
|
20
22
|
};
|
|
21
23
|
export declare class MultichainSwapper extends Swapper<SdkMultichain> {
|
|
22
24
|
constructor(options: MultichainSwapperOptions);
|
|
@@ -11,7 +11,7 @@ const Chains = {
|
|
|
11
11
|
};
|
|
12
12
|
class MultichainSwapper extends crosslightning_sdk_base_1.Swapper {
|
|
13
13
|
constructor(options) {
|
|
14
|
-
var _a, _b, _c, _d;
|
|
14
|
+
var _a, _b, _c, _d, _e;
|
|
15
15
|
(_a = options.bitcoinNetwork) !== null && _a !== void 0 ? _a : (options.bitcoinNetwork = crosslightning_sdk_base_1.BitcoinNetwork.MAINNET);
|
|
16
16
|
(_b = options.storagePrefix) !== null && _b !== void 0 ? _b : (options.storagePrefix = "atomiqsdk-" + options.bitcoinNetwork);
|
|
17
17
|
(_c = options.storageCtor) !== null && _c !== void 0 ? _c : (options.storageCtor = (name) => new crosslightning_sdk_base_1.IndexedDBStorageManager(name));
|
|
@@ -34,7 +34,7 @@ class MultichainSwapper extends crosslightning_sdk_base_1.Swapper {
|
|
|
34
34
|
const ctorChainData = (0, Utils_1.objectMap)(Chains, (value, key) => {
|
|
35
35
|
return value.getCtorData(options, bitcoinRpc, options.bitcoinNetwork);
|
|
36
36
|
});
|
|
37
|
-
super(bitcoinRpc, ctorChainData, crosslightning_sdk_base_1.RedundantSwapPrice.createFromTokenMap(new BN(10000), pricingAssets), options);
|
|
37
|
+
super(bitcoinRpc, ctorChainData, crosslightning_sdk_base_1.RedundantSwapPrice.createFromTokenMap((_e = options.pricingFeeDifferencePPM) !== null && _e !== void 0 ? _e : new BN(10000), pricingAssets), options);
|
|
38
38
|
}
|
|
39
39
|
}
|
|
40
40
|
exports.MultichainSwapper = MultichainSwapper;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { SolanaChainType, SolanaRetryPolicy, StoredDataAccount } from "crosslightning-solana";
|
|
1
|
+
import { SolanaChainType, SolanaFees, SolanaRetryPolicy, StoredDataAccount } from "crosslightning-solana";
|
|
2
2
|
import { IStorageManager } from "crosslightning-base";
|
|
3
3
|
import { SdkChain } from "../ChainInitializer";
|
|
4
4
|
type SolanaSwapperOptions = {
|
|
@@ -8,6 +8,7 @@ type SolanaSwapperOptions = {
|
|
|
8
8
|
btcRelayContract?: string;
|
|
9
9
|
swapContract?: string;
|
|
10
10
|
trustedIntermediary?: string;
|
|
11
|
+
fees?: SolanaFees;
|
|
11
12
|
};
|
|
12
13
|
declare const SolanaAssets: {
|
|
13
14
|
readonly WBTC: {
|
|
@@ -7,18 +7,18 @@ const SolanaChains_1 = require("./SolanaChains");
|
|
|
7
7
|
const SolanaChainEventsBrowser_1 = require("crosslightning-solana/dist/solana/events/SolanaChainEventsBrowser");
|
|
8
8
|
const chainId = "SOLANA";
|
|
9
9
|
function getSolanaCtorData(options, bitcoinRpc, network) {
|
|
10
|
-
var _a, _b, _c, _d;
|
|
10
|
+
var _a, _b, _c, _d, _e;
|
|
11
11
|
const connection = new web3_js_1.Connection(options.chains.SOLANA.rpcUrl);
|
|
12
|
-
const Fees = new crosslightning_solana_1.SolanaFees(connection, 200000,
|
|
13
|
-
const btcRelay = new crosslightning_solana_1.SolanaBtcRelay(connection, bitcoinRpc, (
|
|
14
|
-
const swapContract = new crosslightning_solana_1.SolanaSwapProgram(connection, btcRelay, options.chains.SOLANA.dataAccountStorage || options.storageCtor("solAccounts"), (
|
|
12
|
+
const Fees = (_a = options.chains.SOLANA.fees) !== null && _a !== void 0 ? _a : new crosslightning_solana_1.SolanaFees(connection, 200000, 4, 100);
|
|
13
|
+
const btcRelay = new crosslightning_solana_1.SolanaBtcRelay(connection, bitcoinRpc, (_b = options.chains.SOLANA.btcRelayContract) !== null && _b !== void 0 ? _b : SolanaChains_1.SolanaChains[network].addresses.btcRelayContract, Fees);
|
|
14
|
+
const swapContract = new crosslightning_solana_1.SolanaSwapProgram(connection, btcRelay, options.chains.SOLANA.dataAccountStorage || options.storageCtor("solAccounts"), (_c = options.chains.SOLANA.swapContract) !== null && _c !== void 0 ? _c : SolanaChains_1.SolanaChains[network].addresses.swapContract, (_d = options.chains.SOLANA.retryPolicy) !== null && _d !== void 0 ? _d : { transactionResendInterval: 1000 }, Fees);
|
|
15
15
|
const chainEvents = new SolanaChainEventsBrowser_1.SolanaChainEventsBrowser(connection, swapContract);
|
|
16
16
|
return {
|
|
17
17
|
btcRelay,
|
|
18
18
|
swapContract,
|
|
19
19
|
chainEvents,
|
|
20
20
|
swapDataConstructor: crosslightning_solana_1.SolanaSwapData,
|
|
21
|
-
defaultTrustedIntermediaryUrl: (
|
|
21
|
+
defaultTrustedIntermediaryUrl: (_e = options.chains.SOLANA.trustedIntermediary) !== null && _e !== void 0 ? _e : SolanaChains_1.SolanaChains[network].trustedSwapForGasUrl,
|
|
22
22
|
//These are defined here to keep the data from old SolLightning-sdk, not needed for other chains
|
|
23
23
|
storage: {
|
|
24
24
|
toBtc: options.storageCtor("SOLv4-" + options.bitcoinNetwork + "-Swaps-ToBTC"),
|
package/package.json
CHANGED
package/src/MultichainSwapper.ts
CHANGED
|
@@ -33,7 +33,8 @@ export type MultichainSwapperOptions = SwapperOptions & {
|
|
|
33
33
|
[C in keyof Chains]: Chains[C]["Options"]
|
|
34
34
|
}
|
|
35
35
|
} & {
|
|
36
|
-
storageCtor?: <T extends StorageObject>(name: string) => IStorageManager<T
|
|
36
|
+
storageCtor?: <T extends StorageObject>(name: string) => IStorageManager<T>,
|
|
37
|
+
pricingFeeDifferencePPM?: BN
|
|
37
38
|
};
|
|
38
39
|
|
|
39
40
|
export class MultichainSwapper extends Swapper<SdkMultichain> {
|
|
@@ -70,7 +71,7 @@ export class MultichainSwapper extends Swapper<SdkMultichain> {
|
|
|
70
71
|
return value.getCtorData(options, bitcoinRpc, options.bitcoinNetwork);
|
|
71
72
|
});
|
|
72
73
|
|
|
73
|
-
super(bitcoinRpc, ctorChainData, RedundantSwapPrice.createFromTokenMap<SdkMultichain>(new BN(10000), pricingAssets), options);
|
|
74
|
+
super(bitcoinRpc, ctorChainData, RedundantSwapPrice.createFromTokenMap<SdkMultichain>(options.pricingFeeDifferencePPM ?? new BN(10000), pricingAssets), options);
|
|
74
75
|
}
|
|
75
76
|
|
|
76
77
|
}
|
|
@@ -26,13 +26,15 @@ type SolanaSwapperOptions = {
|
|
|
26
26
|
btcRelayContract?: string,
|
|
27
27
|
swapContract?: string,
|
|
28
28
|
|
|
29
|
-
trustedIntermediary?: string
|
|
29
|
+
trustedIntermediary?: string,
|
|
30
|
+
|
|
31
|
+
fees?: SolanaFees
|
|
30
32
|
};
|
|
31
33
|
|
|
32
34
|
function getSolanaCtorData(options: MultichainSwapperOptions, bitcoinRpc: BitcoinRpc<any>, network: BitcoinNetwork): CtorChainData<SolanaChainType> {
|
|
33
35
|
const connection = new Connection(options.chains.SOLANA.rpcUrl);
|
|
34
36
|
|
|
35
|
-
const Fees = new SolanaFees(connection, 200000,
|
|
37
|
+
const Fees = options.chains.SOLANA.fees ?? new SolanaFees(connection, 200000, 4, 100);
|
|
36
38
|
const btcRelay = new SolanaBtcRelay(connection, bitcoinRpc, options.chains.SOLANA.btcRelayContract ?? SolanaChains[network].addresses.btcRelayContract, Fees);
|
|
37
39
|
const swapContract = new SolanaSwapProgram(
|
|
38
40
|
connection,
|