@atomiqlabs/sdk 1.0.0-beta4 → 1.0.0-beta41
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 +4 -8
- package/dist/MultichainSwapper.js +13 -16
- package/dist/chains/solana/SolanaChainInitializer.d.ts +4 -2
- package/dist/chains/solana/SolanaChainInitializer.js +8 -6
- package/package.json +32 -32
- package/src/MultichainSwapper.ts +40 -33
- package/src/chains/solana/SolanaChainInitializer.ts +8 -4
|
@@ -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,16 +18,14 @@ 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);
|
|
23
25
|
}
|
|
24
26
|
export declare const Tokens: {
|
|
25
27
|
[C in keyof Chains]: {
|
|
26
|
-
[T in keyof Chains[C]["Assets"]]: SCToken<
|
|
27
|
-
name: string;
|
|
28
|
-
decimals: number;
|
|
29
|
-
};
|
|
28
|
+
[T in keyof Chains[C]["Assets"]]: SCToken<C>;
|
|
30
29
|
};
|
|
31
30
|
} & {
|
|
32
31
|
BITCOIN: {
|
|
@@ -36,10 +35,7 @@ export declare const Tokens: {
|
|
|
36
35
|
};
|
|
37
36
|
export declare const TokenResolver: {
|
|
38
37
|
[C in keyof Chains]: {
|
|
39
|
-
getToken(address: string):
|
|
40
|
-
ticker: string;
|
|
41
|
-
name: string;
|
|
42
|
-
};
|
|
38
|
+
getToken(address: string): SCToken<C>;
|
|
43
39
|
};
|
|
44
40
|
};
|
|
45
41
|
export {};
|
|
@@ -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));
|
|
@@ -29,12 +29,14 @@ class MultichainSwapper extends crosslightning_sdk_base_1.Swapper {
|
|
|
29
29
|
if (Chains[chainId].assets[ticker] != null)
|
|
30
30
|
chains[chainId] = Chains[chainId].assets[ticker];
|
|
31
31
|
}
|
|
32
|
-
|
|
32
|
+
const assetData = SmartChainAssets_1.SmartChainAssets[ticker];
|
|
33
|
+
pricingAssets.push(Object.assign(Object.assign({}, assetData.pricing), { chains,
|
|
34
|
+
ticker, name: assetData.name }));
|
|
33
35
|
});
|
|
34
36
|
const ctorChainData = (0, Utils_1.objectMap)(Chains, (value, key) => {
|
|
35
37
|
return value.getCtorData(options, bitcoinRpc, options.bitcoinNetwork);
|
|
36
38
|
});
|
|
37
|
-
super(bitcoinRpc, ctorChainData, crosslightning_sdk_base_1.RedundantSwapPrice.createFromTokenMap(new BN(10000), pricingAssets), options);
|
|
39
|
+
super(bitcoinRpc, ctorChainData, crosslightning_sdk_base_1.RedundantSwapPrice.createFromTokenMap((_e = options.pricingFeeDifferencePPM) !== null && _e !== void 0 ? _e : new BN(10000), pricingAssets), pricingAssets, options);
|
|
38
40
|
}
|
|
39
41
|
}
|
|
40
42
|
exports.MultichainSwapper = MultichainSwapper;
|
|
@@ -45,23 +47,18 @@ exports.Tokens = Object.assign(Object.assign({}, (0, Utils_1.objectMap)(Chains,
|
|
|
45
47
|
chainId: value.chainIdentifier,
|
|
46
48
|
address: assetData.address,
|
|
47
49
|
name: SmartChainAssets_1.SmartChainAssets[ticker].name,
|
|
48
|
-
decimals: assetData.decimals
|
|
50
|
+
decimals: assetData.decimals,
|
|
51
|
+
ticker
|
|
49
52
|
};
|
|
50
53
|
});
|
|
51
|
-
})), { BITCOIN:
|
|
52
|
-
|
|
53
|
-
chain: "BTC",
|
|
54
|
-
lightning: false
|
|
55
|
-
},
|
|
56
|
-
BTCLN: {
|
|
57
|
-
chain: "BTC",
|
|
58
|
-
lightning: true
|
|
59
|
-
}
|
|
60
|
-
} });
|
|
61
|
-
exports.TokenResolver = (0, Utils_1.objectMap)(Chains, (value, key) => {
|
|
54
|
+
})), { BITCOIN: crosslightning_sdk_base_1.BitcoinTokens });
|
|
55
|
+
exports.TokenResolver = Object.assign({}, (0, Utils_1.objectMap)(Chains, (value, key) => {
|
|
62
56
|
const addressMap = {};
|
|
63
57
|
for (let ticker in value.assets) {
|
|
64
58
|
addressMap[value.assets[ticker].address] = {
|
|
59
|
+
chain: "SC",
|
|
60
|
+
chainId: value.chainIdentifier,
|
|
61
|
+
address: value.assets[ticker].address,
|
|
65
62
|
ticker,
|
|
66
63
|
name: SmartChainAssets_1.SmartChainAssets[ticker].name,
|
|
67
64
|
decimals: value.assets[ticker].decimals
|
|
@@ -70,4 +67,4 @@ exports.TokenResolver = (0, Utils_1.objectMap)(Chains, (value, key) => {
|
|
|
70
67
|
return {
|
|
71
68
|
getToken: (address) => addressMap[address]
|
|
72
69
|
};
|
|
73
|
-
});
|
|
70
|
+
}));
|
|
@@ -1,13 +1,15 @@
|
|
|
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
|
+
import { Connection } from "@solana/web3.js";
|
|
3
4
|
import { SdkChain } from "../ChainInitializer";
|
|
4
5
|
type SolanaSwapperOptions = {
|
|
5
|
-
rpcUrl: string;
|
|
6
|
+
rpcUrl: string | Connection;
|
|
6
7
|
dataAccountStorage?: IStorageManager<StoredDataAccount>;
|
|
7
8
|
retryPolicy?: SolanaRetryPolicy;
|
|
8
9
|
btcRelayContract?: string;
|
|
9
10
|
swapContract?: string;
|
|
10
11
|
trustedIntermediary?: string;
|
|
12
|
+
fees?: SolanaFees;
|
|
11
13
|
};
|
|
12
14
|
declare const SolanaAssets: {
|
|
13
15
|
readonly WBTC: {
|
|
@@ -7,18 +7,20 @@ 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;
|
|
11
|
-
const connection =
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
const
|
|
10
|
+
var _a, _b, _c, _d, _e;
|
|
11
|
+
const connection = typeof (options.chains.SOLANA.rpcUrl) === "string" ?
|
|
12
|
+
new web3_js_1.Connection(options.chains.SOLANA.rpcUrl) :
|
|
13
|
+
options.chains.SOLANA.rpcUrl;
|
|
14
|
+
const Fees = (_a = options.chains.SOLANA.fees) !== null && _a !== void 0 ? _a : new crosslightning_solana_1.SolanaFees(connection, 200000, 4, 100);
|
|
15
|
+
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);
|
|
16
|
+
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
17
|
const chainEvents = new SolanaChainEventsBrowser_1.SolanaChainEventsBrowser(connection, swapContract);
|
|
16
18
|
return {
|
|
17
19
|
btcRelay,
|
|
18
20
|
swapContract,
|
|
19
21
|
chainEvents,
|
|
20
22
|
swapDataConstructor: crosslightning_solana_1.SolanaSwapData,
|
|
21
|
-
defaultTrustedIntermediaryUrl: (
|
|
23
|
+
defaultTrustedIntermediaryUrl: (_e = options.chains.SOLANA.trustedIntermediary) !== null && _e !== void 0 ? _e : SolanaChains_1.SolanaChains[network].trustedSwapForGasUrl,
|
|
22
24
|
//These are defined here to keep the data from old SolLightning-sdk, not needed for other chains
|
|
23
25
|
storage: {
|
|
24
26
|
toBtc: options.storageCtor("SOLv4-" + options.bitcoinNetwork + "-Swaps-ToBTC"),
|
package/package.json
CHANGED
|
@@ -1,32 +1,32 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "@atomiqlabs/sdk",
|
|
3
|
-
"version": "1.0.0-
|
|
4
|
-
"description": "atomiq labs SDK for cross-chain swaps between smart chains and bitcoin",
|
|
5
|
-
"main": "./dist/index.js",
|
|
6
|
-
"types:": "./dist/index.d.ts",
|
|
7
|
-
"scripts": {
|
|
8
|
-
"test": "echo \"Error: no test specified\" && exit 1"
|
|
9
|
-
},
|
|
10
|
-
"files": [
|
|
11
|
-
"/dist",
|
|
12
|
-
"/src"
|
|
13
|
-
],
|
|
14
|
-
"keywords": [
|
|
15
|
-
"Bitcoin",
|
|
16
|
-
"Cross-chain",
|
|
17
|
-
"Cryptocurrency",
|
|
18
|
-
"Bridge",
|
|
19
|
-
"Trustless"
|
|
20
|
-
],
|
|
21
|
-
"author": "adambor",
|
|
22
|
-
"license": "ISC",
|
|
23
|
-
"dependencies": {
|
|
24
|
-
"crosslightning-base": "7.0.0-beta1",
|
|
25
|
-
"crosslightning-sdk-base": "10.0.5-
|
|
26
|
-
"crosslightning-solana": "7.0.0-beta4"
|
|
27
|
-
},
|
|
28
|
-
"devDependencies": {
|
|
29
|
-
"@types/bn.js": "5.1.5",
|
|
30
|
-
"typescript": "4.9.5"
|
|
31
|
-
}
|
|
32
|
-
}
|
|
1
|
+
{
|
|
2
|
+
"name": "@atomiqlabs/sdk",
|
|
3
|
+
"version": "1.0.0-beta41",
|
|
4
|
+
"description": "atomiq labs SDK for cross-chain swaps between smart chains and bitcoin",
|
|
5
|
+
"main": "./dist/index.js",
|
|
6
|
+
"types:": "./dist/index.d.ts",
|
|
7
|
+
"scripts": {
|
|
8
|
+
"test": "echo \"Error: no test specified\" && exit 1"
|
|
9
|
+
},
|
|
10
|
+
"files": [
|
|
11
|
+
"/dist",
|
|
12
|
+
"/src"
|
|
13
|
+
],
|
|
14
|
+
"keywords": [
|
|
15
|
+
"Bitcoin",
|
|
16
|
+
"Cross-chain",
|
|
17
|
+
"Cryptocurrency",
|
|
18
|
+
"Bridge",
|
|
19
|
+
"Trustless"
|
|
20
|
+
],
|
|
21
|
+
"author": "adambor",
|
|
22
|
+
"license": "ISC",
|
|
23
|
+
"dependencies": {
|
|
24
|
+
"crosslightning-base": "7.0.0-beta1",
|
|
25
|
+
"crosslightning-sdk-base": "10.0.5-beta44",
|
|
26
|
+
"crosslightning-solana": "7.0.0-beta4"
|
|
27
|
+
},
|
|
28
|
+
"devDependencies": {
|
|
29
|
+
"@types/bn.js": "5.1.5",
|
|
30
|
+
"typescript": "4.9.5"
|
|
31
|
+
}
|
|
32
|
+
}
|
package/src/MultichainSwapper.ts
CHANGED
|
@@ -1,13 +1,13 @@
|
|
|
1
1
|
import {
|
|
2
|
-
BitcoinNetwork,
|
|
3
|
-
BtcToken, IndexedDBStorageManager,
|
|
2
|
+
BitcoinNetwork, BitcoinTokens,
|
|
3
|
+
BtcToken, IndexedDBStorageManager, isToken,
|
|
4
4
|
MempoolApi,
|
|
5
5
|
MempoolBitcoinRpc,
|
|
6
6
|
RedundantSwapPrice,
|
|
7
7
|
RedundantSwapPriceAssets,
|
|
8
8
|
SCToken,
|
|
9
9
|
Swapper,
|
|
10
|
-
SwapperOptions
|
|
10
|
+
SwapperOptions, Token
|
|
11
11
|
} from "crosslightning-sdk-base";
|
|
12
12
|
import {objectMap} from "crosslightning-sdk-base/dist/utils/Utils";
|
|
13
13
|
import {SdkSolana, SdkSolanaType} from "./chains/solana/SolanaChainInitializer";
|
|
@@ -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> {
|
|
@@ -54,15 +55,18 @@ export class MultichainSwapper extends Swapper<SdkMultichain> {
|
|
|
54
55
|
);
|
|
55
56
|
const bitcoinRpc = new MempoolBitcoinRpc(mempoolApi);
|
|
56
57
|
|
|
57
|
-
const pricingAssets: RedundantSwapPriceAssets<SdkMultichain> = [];
|
|
58
|
+
const pricingAssets: (RedundantSwapPriceAssets<SdkMultichain>[number] & {ticker: string, name: string})[] = [];
|
|
58
59
|
Object.keys(SmartChainAssets).forEach((ticker) => {
|
|
59
60
|
const chains: any = {};
|
|
60
61
|
for(let chainId in Chains) {
|
|
61
62
|
if(Chains[chainId].assets[ticker]!=null) chains[chainId] = Chains[chainId].assets[ticker];
|
|
62
63
|
}
|
|
64
|
+
const assetData = SmartChainAssets[ticker];
|
|
63
65
|
pricingAssets.push({
|
|
64
|
-
...
|
|
65
|
-
chains
|
|
66
|
+
...assetData.pricing,
|
|
67
|
+
chains,
|
|
68
|
+
ticker,
|
|
69
|
+
name: assetData.name
|
|
66
70
|
})
|
|
67
71
|
});
|
|
68
72
|
|
|
@@ -70,14 +74,20 @@ export class MultichainSwapper extends Swapper<SdkMultichain> {
|
|
|
70
74
|
return value.getCtorData(options, bitcoinRpc, options.bitcoinNetwork);
|
|
71
75
|
});
|
|
72
76
|
|
|
73
|
-
super(
|
|
77
|
+
super(
|
|
78
|
+
bitcoinRpc,
|
|
79
|
+
ctorChainData,
|
|
80
|
+
RedundantSwapPrice.createFromTokenMap<SdkMultichain>(options.pricingFeeDifferencePPM ?? new BN(10000), pricingAssets),
|
|
81
|
+
pricingAssets,
|
|
82
|
+
options
|
|
83
|
+
);
|
|
74
84
|
}
|
|
75
85
|
|
|
76
86
|
}
|
|
77
87
|
|
|
78
88
|
export const Tokens: {
|
|
79
89
|
[C in keyof Chains]: {
|
|
80
|
-
[T in keyof Chains[C]["Assets"]]: SCToken<
|
|
90
|
+
[T in keyof Chains[C]["Assets"]]: SCToken<C>
|
|
81
91
|
}
|
|
82
92
|
} & {
|
|
83
93
|
BITCOIN: {
|
|
@@ -92,36 +102,33 @@ export const Tokens: {
|
|
|
92
102
|
chainId: value.chainIdentifier,
|
|
93
103
|
address: assetData.address,
|
|
94
104
|
name: SmartChainAssets[ticker].name,
|
|
95
|
-
decimals: assetData.decimals
|
|
105
|
+
decimals: assetData.decimals,
|
|
106
|
+
ticker
|
|
96
107
|
}
|
|
97
108
|
});
|
|
98
109
|
}),
|
|
99
|
-
BITCOIN:
|
|
100
|
-
BTC: {
|
|
101
|
-
chain: "BTC",
|
|
102
|
-
lightning: false
|
|
103
|
-
},
|
|
104
|
-
BTCLN: {
|
|
105
|
-
chain: "BTC",
|
|
106
|
-
lightning: true
|
|
107
|
-
}
|
|
108
|
-
}
|
|
110
|
+
BITCOIN: BitcoinTokens
|
|
109
111
|
};
|
|
110
112
|
|
|
111
113
|
export const TokenResolver: {
|
|
112
114
|
[C in keyof Chains]: {
|
|
113
|
-
getToken(address: string):
|
|
115
|
+
getToken(address: string): SCToken<C>
|
|
114
116
|
}
|
|
115
|
-
} =
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
ticker
|
|
120
|
-
|
|
121
|
-
|
|
117
|
+
} = {
|
|
118
|
+
...objectMap(Chains, (value, key) => {
|
|
119
|
+
const addressMap: {[tokenAddress: string]: SCToken} = {};
|
|
120
|
+
for(let ticker in value.assets) {
|
|
121
|
+
addressMap[value.assets[ticker].address] = {
|
|
122
|
+
chain: "SC",
|
|
123
|
+
chainId: value.chainIdentifier,
|
|
124
|
+
address: value.assets[ticker].address,
|
|
125
|
+
ticker,
|
|
126
|
+
name: SmartChainAssets[ticker].name,
|
|
127
|
+
decimals: value.assets[ticker].decimals
|
|
128
|
+
}
|
|
122
129
|
}
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
}
|
|
127
|
-
}
|
|
130
|
+
return {
|
|
131
|
+
getToken: (address: string) => addressMap[address]
|
|
132
|
+
};
|
|
133
|
+
})
|
|
134
|
+
};
|
|
@@ -19,20 +19,24 @@ import {MultichainSwapperOptions} from "../../MultichainSwapper";
|
|
|
19
19
|
const chainId = "SOLANA" as const;
|
|
20
20
|
|
|
21
21
|
type SolanaSwapperOptions = {
|
|
22
|
-
rpcUrl: string,
|
|
22
|
+
rpcUrl: string | Connection,
|
|
23
23
|
dataAccountStorage?: IStorageManager<StoredDataAccount>,
|
|
24
24
|
retryPolicy?: SolanaRetryPolicy,
|
|
25
25
|
|
|
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
|
-
const connection =
|
|
35
|
+
const connection = typeof(options.chains.SOLANA.rpcUrl)==="string" ?
|
|
36
|
+
new Connection(options.chains.SOLANA.rpcUrl) :
|
|
37
|
+
options.chains.SOLANA.rpcUrl;
|
|
34
38
|
|
|
35
|
-
const Fees = new SolanaFees(connection, 200000,
|
|
39
|
+
const Fees = options.chains.SOLANA.fees ?? new SolanaFees(connection, 200000, 4, 100);
|
|
36
40
|
const btcRelay = new SolanaBtcRelay(connection, bitcoinRpc, options.chains.SOLANA.btcRelayContract ?? SolanaChains[network].addresses.btcRelayContract, Fees);
|
|
37
41
|
const swapContract = new SolanaSwapProgram(
|
|
38
42
|
connection,
|