@d8x/perpetuals-sdk 0.1.12 → 0.2.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/dist/cjs/abi/testnet/IPerpetualManager.json +5215 -0
- package/dist/cjs/abi/testnet/LimitOrderBook.json +1075 -0
- package/dist/cjs/abi/zkevmTestnet/IPerpetualManager.json +5215 -0
- package/dist/cjs/abi/zkevmTestnet/LimitOrderBook.json +1075 -0
- package/dist/cjs/abi/zkevmTestnet/LimitOrderBookFactory.json +135 -0
- package/dist/cjs/accountTrade.js +441 -0
- package/dist/cjs/accountTrade.js.map +1 -0
- package/dist/{src → cjs}/brokerTool.js +31 -84
- package/dist/cjs/brokerTool.js.map +1 -0
- package/dist/cjs/config/defaultConfig.json +47 -0
- package/dist/cjs/config/mockSwap.json +4 -0
- package/dist/cjs/config/priceFeedConfig.json +104 -0
- package/dist/cjs/config/symbolList.json +13 -0
- package/dist/cjs/d8XMath.js.map +1 -0
- package/dist/cjs/index.js +29 -0
- package/dist/cjs/index.js.map +1 -0
- package/dist/cjs/liquidatorTool.js +287 -0
- package/dist/cjs/liquidatorTool.js.map +1 -0
- package/dist/{src → cjs}/liquidityProviderTool.js +12 -65
- package/dist/cjs/liquidityProviderTool.js.map +1 -0
- package/dist/{src → cjs}/marketData.js +52 -134
- package/dist/cjs/marketData.js.map +1 -0
- package/dist/{src → cjs}/nodeSDKTypes.d.ts +5 -5
- package/dist/cjs/nodeSDKTypes.js +64 -0
- package/dist/cjs/nodeSDKTypes.js.map +1 -0
- package/dist/{src → cjs}/orderReferrerTool.d.ts +12 -5
- package/dist/{src → cjs}/orderReferrerTool.js +114 -112
- package/dist/cjs/orderReferrerTool.js.map +1 -0
- package/dist/{src → cjs}/perpetualDataHandler.d.ts +1 -1
- package/dist/{src → cjs}/perpetualDataHandler.js +47 -109
- package/dist/cjs/perpetualDataHandler.js.map +1 -0
- package/dist/{src → cjs}/perpetualEventHandler.d.ts +3 -3
- package/dist/{src → cjs}/perpetualEventHandler.js +12 -74
- package/dist/cjs/perpetualEventHandler.js.map +1 -0
- package/dist/cjs/priceFeeds.js +466 -0
- package/dist/cjs/priceFeeds.js.map +1 -0
- package/dist/{src → cjs}/traderDigests.js +7 -43
- package/dist/cjs/traderDigests.js.map +1 -0
- package/dist/{src → cjs}/traderInterface.js +13 -66
- package/dist/cjs/traderInterface.js.map +1 -0
- package/dist/{src → cjs}/triangulator.js +2 -17
- package/dist/cjs/triangulator.js.map +1 -0
- package/dist/{src → cjs}/utils.js +3 -29
- package/dist/cjs/utils.js.map +1 -0
- package/dist/cjs/version.d.ts +1 -0
- package/dist/{src → cjs}/version.js +1 -1
- package/dist/cjs/version.js.map +1 -0
- package/dist/{src → cjs}/writeAccessHandler.js +12 -65
- package/dist/cjs/writeAccessHandler.js.map +1 -0
- package/dist/esm/abi/ERC20.json +288 -0
- package/dist/esm/abi/MockTokenSwap.json +186 -0
- package/dist/{abi/testnet → esm/abi/central-park}/IPerpetualManager.json +404 -214
- package/dist/{abi/testnet → esm/abi/central-park}/LimitOrderBook.json +197 -15
- package/dist/esm/abi/central-park/LimitOrderBookFactory.json +135 -0
- package/dist/esm/abi/testnet/IPerpetualManager.json +5215 -0
- package/dist/esm/abi/testnet/LimitOrderBook.json +1075 -0
- package/dist/esm/abi/testnet/LimitOrderBookFactory.json +135 -0
- package/dist/esm/abi/zkevmTestnet/IPerpetualManager.json +5215 -0
- package/dist/esm/abi/zkevmTestnet/LimitOrderBook.json +1075 -0
- package/dist/esm/abi/zkevmTestnet/LimitOrderBookFactory.json +135 -0
- package/dist/esm/accountTrade.d.ts +221 -0
- package/dist/{src → esm}/accountTrade.js +22 -93
- package/dist/esm/accountTrade.js.map +1 -0
- package/dist/esm/brokerTool.d.ts +318 -0
- package/dist/esm/brokerTool.js +572 -0
- package/dist/esm/brokerTool.js.map +1 -0
- package/dist/esm/config/defaultConfig.json +47 -0
- package/dist/esm/config/mockSwap.json +4 -0
- package/dist/esm/config/priceFeedConfig.json +104 -0
- package/dist/esm/config/symbolList.json +13 -0
- package/dist/esm/d8XMath.d.ts +122 -0
- package/dist/esm/d8XMath.js +247 -0
- package/dist/esm/d8XMath.js.map +1 -0
- package/{src/index.ts → dist/esm/index.d.ts} +1 -15
- package/dist/esm/index.js +16 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/liquidatorTool.d.ts +158 -0
- package/dist/{src → esm}/liquidatorTool.js +10 -65
- package/dist/esm/liquidatorTool.js.map +1 -0
- package/dist/esm/liquidityProviderTool.d.ts +126 -0
- package/dist/esm/liquidityProviderTool.js +218 -0
- package/dist/esm/liquidityProviderTool.js.map +1 -0
- package/dist/esm/marketData.d.ts +309 -0
- package/dist/esm/marketData.js +1007 -0
- package/dist/esm/marketData.js.map +1 -0
- package/dist/esm/nodeSDKTypes.d.ts +266 -0
- package/dist/esm/nodeSDKTypes.js +60 -0
- package/dist/esm/nodeSDKTypes.js.map +1 -0
- package/dist/esm/orderReferrerTool.d.ts +196 -0
- package/dist/esm/orderReferrerTool.js +491 -0
- package/dist/esm/orderReferrerTool.js.map +1 -0
- package/dist/esm/perpetualDataHandler.d.ts +220 -0
- package/dist/esm/perpetualDataHandler.js +1060 -0
- package/dist/esm/perpetualDataHandler.js.map +1 -0
- package/dist/esm/perpetualEventHandler.d.ts +179 -0
- package/dist/esm/perpetualEventHandler.js +435 -0
- package/dist/esm/perpetualEventHandler.js.map +1 -0
- package/dist/esm/priceFeeds.d.ts +115 -0
- package/dist/{src → esm}/priceFeeds.js +16 -83
- package/dist/esm/priceFeeds.js.map +1 -0
- package/dist/esm/traderDigests.d.ts +21 -0
- package/dist/esm/traderDigests.js +80 -0
- package/dist/esm/traderDigests.js.map +1 -0
- package/dist/esm/traderInterface.d.ts +79 -0
- package/dist/esm/traderInterface.js +196 -0
- package/dist/esm/traderInterface.js.map +1 -0
- package/dist/esm/triangulator.d.ts +27 -0
- package/dist/esm/triangulator.js +110 -0
- package/dist/esm/triangulator.js.map +1 -0
- package/dist/esm/utils.d.ts +59 -0
- package/dist/esm/utils.js +138 -0
- package/dist/esm/utils.js.map +1 -0
- package/dist/esm/version.d.ts +1 -0
- package/dist/esm/version.js +2 -0
- package/dist/esm/version.js.map +1 -0
- package/dist/esm/writeAccessHandler.d.ts +50 -0
- package/dist/esm/writeAccessHandler.js +157 -0
- package/dist/esm/writeAccessHandler.js.map +1 -0
- package/package.json +16 -26
- package/dist/bundle.js +0 -36793
- package/dist/config/defaultConfig.json +0 -47
- package/dist/config/mockSwap.json +0 -4
- package/dist/config/priceFeedConfig.json +0 -104
- package/dist/config/symbolList.json +0 -13
- package/dist/src/index.js +0 -45
- package/dist/src/nodeSDKTypes.js +0 -115
- package/dist/src/version.d.ts +0 -1
- package/module.d.ts +0 -1
- package/src/accountTrade.ts +0 -392
- package/src/brokerTool.ts +0 -507
- package/src/d8XMath.ts +0 -319
- package/src/liquidatorTool.ts +0 -258
- package/src/liquidityProviderTool.ts +0 -186
- package/src/marketData.ts +0 -946
- package/src/nodeSDKTypes.ts +0 -293
- package/src/orderReferrerTool.ts +0 -389
- package/src/perpetualDataHandler.ts +0 -1061
- package/src/perpetualEventHandler.ts +0 -455
- package/src/priceFeeds.ts +0 -381
- package/src/traderDigests.ts +0 -91
- package/src/traderInterface.ts +0 -159
- package/src/triangulator.ts +0 -105
- package/src/utils.ts +0 -134
- package/src/version.ts +0 -1
- package/src/writeAccessHandler.ts +0 -127
- /package/dist/{abi → cjs/abi}/ERC20.json +0 -0
- /package/dist/{abi → cjs/abi}/MockTokenSwap.json +0 -0
- /package/dist/{abi → cjs/abi}/central-park/IPerpetualManager.json +0 -0
- /package/dist/{abi → cjs/abi}/central-park/LimitOrderBook.json +0 -0
- /package/dist/{abi → cjs/abi}/central-park/LimitOrderBookFactory.json +0 -0
- /package/dist/{abi → cjs/abi}/testnet/LimitOrderBookFactory.json +0 -0
- /package/dist/{src → cjs}/accountTrade.d.ts +0 -0
- /package/dist/{src → cjs}/brokerTool.d.ts +0 -0
- /package/dist/{src → cjs}/d8XMath.d.ts +0 -0
- /package/dist/{src → cjs}/d8XMath.js +0 -0
- /package/dist/{src → cjs}/index.d.ts +0 -0
- /package/dist/{src → cjs}/liquidatorTool.d.ts +0 -0
- /package/dist/{src → cjs}/liquidityProviderTool.d.ts +0 -0
- /package/dist/{src → cjs}/marketData.d.ts +0 -0
- /package/dist/{src → cjs}/priceFeeds.d.ts +0 -0
- /package/dist/{src → cjs}/traderDigests.d.ts +0 -0
- /package/dist/{src → cjs}/traderInterface.d.ts +0 -0
- /package/dist/{src → cjs}/triangulator.d.ts +0 -0
- /package/dist/{src → cjs}/utils.d.ts +0 -0
- /package/dist/{src → cjs}/writeAccessHandler.d.ts +0 -0
package/src/brokerTool.ts
DELETED
|
@@ -1,507 +0,0 @@
|
|
|
1
|
-
import WriteAccessHandler from "./writeAccessHandler";
|
|
2
|
-
import { NodeSDKConfig, Order, PerpetualStaticInfo } from "./nodeSDKTypes";
|
|
3
|
-
import PerpetualDataHandler from "./perpetualDataHandler";
|
|
4
|
-
import { ABK64x64ToFloat } from "./d8XMath";
|
|
5
|
-
import { BigNumber, ethers } from "ethers";
|
|
6
|
-
import AccountTrade from "./accountTrade";
|
|
7
|
-
import { Buffer } from "buffer";
|
|
8
|
-
/**
|
|
9
|
-
* Functions for brokers to determine fees, deposit lots, and sign-up traders.
|
|
10
|
-
* This class requires a private key and executes smart-contract interactions that
|
|
11
|
-
* require gas-payments.
|
|
12
|
-
* @extends WriteAccessHandler
|
|
13
|
-
*/
|
|
14
|
-
export default class BrokerTool extends WriteAccessHandler {
|
|
15
|
-
/**
|
|
16
|
-
* Constructor
|
|
17
|
-
* @param {NodeSDKConfig} config Configuration object, see PerpetualDataHandler.
|
|
18
|
-
* readSDKConfig.
|
|
19
|
-
* @param {string} privateKey Private key of a broker.
|
|
20
|
-
* @example
|
|
21
|
-
* import { BrokerTool, PerpetualDataHandler } from '@d8x/perpetuals-sdk';
|
|
22
|
-
* async function main() {
|
|
23
|
-
* console.log(BrokerTool);
|
|
24
|
-
* // load configuration for testnet
|
|
25
|
-
* const config = PerpetualDataHandler.readSDKConfig("testnet");
|
|
26
|
-
* // BrokerTool (authentication required, PK is an environment variable with a private key)
|
|
27
|
-
* const pk: string = <string>process.env.PK;
|
|
28
|
-
* let brokTool = new BrokerTool(config, pk);
|
|
29
|
-
* // Create a proxy instance to access the blockchain
|
|
30
|
-
* await brokTool.createProxyInstance();
|
|
31
|
-
* }
|
|
32
|
-
* main();
|
|
33
|
-
*
|
|
34
|
-
*/
|
|
35
|
-
public constructor(config: NodeSDKConfig, privateKey: string) {
|
|
36
|
-
super(config, privateKey);
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
// Fee getters
|
|
40
|
-
|
|
41
|
-
/**
|
|
42
|
-
* Determine the exchange fee based on lots, traded volume, and D8X balance of this broker.
|
|
43
|
-
* This is the final exchange fee that this broker can offer to traders that trade through him.
|
|
44
|
-
* @param {string} poolSymbolName Pool symbol name (e.g. MATIC, USDC, etc).
|
|
45
|
-
* @example
|
|
46
|
-
* import { BrokerTool, PerpetualDataHandler } from '@d8x/perpetuals-sdk';
|
|
47
|
-
* async function main() {
|
|
48
|
-
* console.log(BrokerTool);
|
|
49
|
-
* // setup (authentication required, PK is an environment variable with a private key)
|
|
50
|
-
* const config = PerpetualDataHandler.readSDKConfig("testnet");
|
|
51
|
-
* const pk: string = <string>process.env.PK;
|
|
52
|
-
* let brokTool = new BrokerTool(config, pk);
|
|
53
|
-
* await brokTool.createProxyInstance();
|
|
54
|
-
* // get broker induced fee
|
|
55
|
-
* let brokFee = await brokTool.getBrokerInducedFee("MATIC");
|
|
56
|
-
* console.log(brokFee);
|
|
57
|
-
* }
|
|
58
|
-
* main();
|
|
59
|
-
*
|
|
60
|
-
* @returns {number} Exchange fee for this broker, in decimals (i.e. 0.1% is 0.001)
|
|
61
|
-
*/
|
|
62
|
-
public async getBrokerInducedFee(poolSymbolName: string): Promise<number | undefined> {
|
|
63
|
-
if (this.proxyContract == null || this.signer == null) {
|
|
64
|
-
throw Error("no proxy contract or wallet initialized. Use createProxyInstance().");
|
|
65
|
-
}
|
|
66
|
-
let poolId = PerpetualDataHandler._getPoolIdFromSymbol(poolSymbolName, this.poolStaticInfos);
|
|
67
|
-
let feeTbps = await this.proxyContract.getBrokerInducedFee(poolId, this.traderAddr);
|
|
68
|
-
let fee = feeTbps / 100_000;
|
|
69
|
-
if (fee == 0.65535) {
|
|
70
|
-
return undefined;
|
|
71
|
-
}
|
|
72
|
-
return fee;
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
/**
|
|
76
|
-
* Determine the exchange fee based on lots purchased by this broker.
|
|
77
|
-
* The final exchange fee that this broker can offer to traders that trade through him is equal to
|
|
78
|
-
* maximum(brokerTool.getFeeForBrokerDesignation(poolSymbolName), brokerTool.getFeeForBrokerVolume(poolSymbolName), brokerTool.getFeeForBrokerStake())
|
|
79
|
-
* @param {string} poolSymbolName Pool symbol name (e.g. MATIC, USDC, etc).
|
|
80
|
-
* @param {number=} lots Optional, designation to use if different from this broker's.
|
|
81
|
-
* @example
|
|
82
|
-
* import { BrokerTool, PerpetualDataHandler } from '@d8x/perpetuals-sdk';
|
|
83
|
-
* async function main() {
|
|
84
|
-
* console.log(BrokerTool);
|
|
85
|
-
* // setup (authentication required, PK is an environment variable with a private key)
|
|
86
|
-
* const config = PerpetualDataHandler.readSDKConfig("testnet");
|
|
87
|
-
* const pk: string = <string>process.env.PK;
|
|
88
|
-
* let brokTool = new BrokerTool(config, pk);
|
|
89
|
-
* await brokTool.createProxyInstance();
|
|
90
|
-
* // get broker fee induced by lots
|
|
91
|
-
* let brokFeeLots = await brokTool.getFeeForBrokerDesignation("MATIC");
|
|
92
|
-
* console.log(brokFeeLots);
|
|
93
|
-
* }
|
|
94
|
-
* main();
|
|
95
|
-
*
|
|
96
|
-
* @returns {number} Fee based solely on this broker's designation, in decimals (i.e. 0.1% is 0.001).
|
|
97
|
-
*/
|
|
98
|
-
public async getFeeForBrokerDesignation(poolSymbolName: string, lots?: number): Promise<number> {
|
|
99
|
-
if (this.proxyContract == null || this.signer == null) {
|
|
100
|
-
throw Error("no proxy contract or wallet initialized. Use createProxyInstance().");
|
|
101
|
-
}
|
|
102
|
-
// check if designation should be taken from the caller or as a parameter
|
|
103
|
-
let brokerDesignation: number;
|
|
104
|
-
if (typeof lots == "undefined") {
|
|
105
|
-
brokerDesignation = await this.getBrokerDesignation(poolSymbolName);
|
|
106
|
-
brokerDesignation = brokerDesignation > 0 ? brokerDesignation : 0;
|
|
107
|
-
} else {
|
|
108
|
-
brokerDesignation = lots;
|
|
109
|
-
}
|
|
110
|
-
let feeTbps = await this.proxyContract.getFeeForBrokerDesignation(brokerDesignation);
|
|
111
|
-
return feeTbps / 100_000;
|
|
112
|
-
}
|
|
113
|
-
|
|
114
|
-
/**
|
|
115
|
-
* Determine the exchange fee based on volume traded under this broker.
|
|
116
|
-
* The final exchange fee that this broker can offer to traders that trade through him is equal to
|
|
117
|
-
* maximum(brokerTool.getFeeForBrokerDesignation(poolSymbolName), brokerTool.getFeeForBrokerVolume(poolSymbolName), brokerTool.getFeeForBrokerStake())
|
|
118
|
-
* @param {string} poolSymbolName Pool symbol name (e.g. MATIC, USDC, etc).
|
|
119
|
-
* @example
|
|
120
|
-
* import { BrokerTool, PerpetualDataHandler } from '@d8x/perpetuals-sdk';
|
|
121
|
-
* async function main() {
|
|
122
|
-
* console.log(BrokerTool);
|
|
123
|
-
* // setup (authentication required, PK is an environment variable with a private key)
|
|
124
|
-
* const config = PerpetualDataHandler.readSDKConfig("testnet");
|
|
125
|
-
* const pk: string = <string>process.env.PK;
|
|
126
|
-
* let brokTool = new BrokerTool(config, pk);
|
|
127
|
-
* await brokTool.createProxyInstance();
|
|
128
|
-
* // get broker fee induced by volume
|
|
129
|
-
* let brokFeeVol = await brokTool.getFeeForBrokerVolume("MATIC");
|
|
130
|
-
* console.log(brokFeeVol);
|
|
131
|
-
* }
|
|
132
|
-
* main();
|
|
133
|
-
*
|
|
134
|
-
* @returns {number} Fee based solely on a broker's traded volume in the corresponding pool, in decimals (i.e. 0.1% is 0.001).
|
|
135
|
-
*/
|
|
136
|
-
public async getFeeForBrokerVolume(poolSymbolName: string): Promise<number> {
|
|
137
|
-
if (this.proxyContract == null || this.signer == null) {
|
|
138
|
-
throw Error("no proxy contract or wallet initialized. Use createProxyInstance().");
|
|
139
|
-
}
|
|
140
|
-
let poolId = PerpetualDataHandler._getPoolIdFromSymbol(poolSymbolName, this.poolStaticInfos);
|
|
141
|
-
let feeTbps = await this.proxyContract.getFeeForBrokerVolume(poolId, this.traderAddr);
|
|
142
|
-
return feeTbps / 100_000;
|
|
143
|
-
}
|
|
144
|
-
|
|
145
|
-
/**
|
|
146
|
-
* Determine the exchange fee based on the current D8X balance in a broker's wallet.
|
|
147
|
-
* The final exchange fee that this broker can offer to traders that trade through him is equal to
|
|
148
|
-
* maximum(brokerTool.getFeeForBrokerDesignation(symbol, lots), brokerTool.getFeeForBrokerVolume(symbol), brokerTool.getFeeForBrokerStake)
|
|
149
|
-
* @param {string=} brokerAddr Address of the broker in question, if different from the one calling this function.
|
|
150
|
-
* @example
|
|
151
|
-
* import { BrokerTool, PerpetualDataHandler } from '@d8x/perpetuals-sdk';
|
|
152
|
-
* async function main() {
|
|
153
|
-
* console.log(BrokerTool);
|
|
154
|
-
* // setup (authentication required, PK is an environment variable with a private key)
|
|
155
|
-
* const config = PerpetualDataHandler.readSDKConfig("testnet");
|
|
156
|
-
* const pk: string = <string>process.env.PK;
|
|
157
|
-
* let brokTool = new BrokerTool(config, pk);
|
|
158
|
-
* await brokTool.createProxyInstance();
|
|
159
|
-
* // get broker fee induced by staked d8x
|
|
160
|
-
* let brokFeeStake = await brokTool.getFeeForBrokerStake("0xAb5801a7D398351b8bE11C439e05C5B3259aeC9B");
|
|
161
|
-
* console.log(brokFeeStake);
|
|
162
|
-
* }
|
|
163
|
-
* main();
|
|
164
|
-
*
|
|
165
|
-
* @returns {number} Fee based solely on a broker's D8X balance, in decimals (i.e. 0.1% is 0.001).
|
|
166
|
-
*/
|
|
167
|
-
public async getFeeForBrokerStake(brokerAddr?: string): Promise<number> {
|
|
168
|
-
if (this.proxyContract == null || this.signer == null) {
|
|
169
|
-
throw Error("no proxy contract or wallet initialized. Use createProxyInstance().");
|
|
170
|
-
}
|
|
171
|
-
if (typeof brokerAddr == "undefined") {
|
|
172
|
-
brokerAddr = this.traderAddr;
|
|
173
|
-
}
|
|
174
|
-
let feeTbps = await this.proxyContract.getFeeForBrokerStake(brokerAddr);
|
|
175
|
-
return feeTbps / 100_000;
|
|
176
|
-
}
|
|
177
|
-
|
|
178
|
-
/**
|
|
179
|
-
* Determine exchange fee based on an order and a trader.
|
|
180
|
-
* This is the fee charged by the exchange only, excluding the broker fee,
|
|
181
|
-
* and it takes into account whether the order given here has been signed by a broker or not.
|
|
182
|
-
* Use this, for instance, to verify that the fee to be charged for a given order is as expected,
|
|
183
|
-
* before and after signing it with brokerTool.signOrder.
|
|
184
|
-
* This fee is equal or lower than the broker induced fee, provided the order is properly signed.
|
|
185
|
-
* @param {Order} order Order structure. As a minimum the structure needs to
|
|
186
|
-
* specify symbol, side, type and quantity.
|
|
187
|
-
* @param {string} traderAddr Address of the trader for whom to determine the fee.
|
|
188
|
-
* @example
|
|
189
|
-
* import { BrokerTool, PerpetualDataHandler, Order } from '@d8x/perpetuals-sdk';
|
|
190
|
-
* async function main() {
|
|
191
|
-
* console.log(BrokerTool);
|
|
192
|
-
* // setup (authentication required, PK is an environment variable with a private key)
|
|
193
|
-
* const config = PerpetualDataHandler.readSDKConfig("testnet");
|
|
194
|
-
* const pk: string = <string>process.env.PK;
|
|
195
|
-
* let brokTool = new BrokerTool(config, pk);
|
|
196
|
-
* await brokTool.createProxyInstance();
|
|
197
|
-
* // get exchange fee based on an order and trader
|
|
198
|
-
* let order: Order = {
|
|
199
|
-
* symbol: "MATIC-USD-MATIC",
|
|
200
|
-
* side: "BUY",
|
|
201
|
-
* type: "MARKET",
|
|
202
|
-
* quantity: 100,
|
|
203
|
-
* timestamp: Date.now()
|
|
204
|
-
* };
|
|
205
|
-
* let exchFee = await brokTool.determineExchangeFee(order,
|
|
206
|
-
* "0xAb5801a7D398351b8bE11C439e05C5B3259aeC9B");
|
|
207
|
-
* console.log(exchFee);
|
|
208
|
-
* }
|
|
209
|
-
* main();
|
|
210
|
-
*
|
|
211
|
-
* @returns {number} Fee in decimals (i.e. 0.1% is 0.001).
|
|
212
|
-
*/
|
|
213
|
-
public async determineExchangeFee(order: Order, traderAddr: string): Promise<number> {
|
|
214
|
-
if (this.proxyContract == null || this.signer == null) {
|
|
215
|
-
throw Error("no proxy contract or wallet initialized. Use createProxyInstance().");
|
|
216
|
-
}
|
|
217
|
-
let scOrder = AccountTrade.toSmartContractOrder(order, traderAddr, this.symbolToPerpStaticInfo);
|
|
218
|
-
let feeTbps = await this.proxyContract.determineExchangeFee(scOrder);
|
|
219
|
-
return feeTbps / 100_000;
|
|
220
|
-
}
|
|
221
|
-
|
|
222
|
-
// Volume
|
|
223
|
-
|
|
224
|
-
/**
|
|
225
|
-
* Exponentially weighted EMA of the total trading volume of all trades performed under this broker.
|
|
226
|
-
* The weights are chosen so that in average this coincides with the 30 day volume.
|
|
227
|
-
* @param {string} poolSymbolName Pool symbol name (e.g. MATIC, USDC, etc).
|
|
228
|
-
* @example
|
|
229
|
-
* import { BrokerTool, PerpetualDataHandler } from '@d8x/perpetuals-sdk';
|
|
230
|
-
* async function main() {
|
|
231
|
-
* console.log(BrokerTool);
|
|
232
|
-
* // setup (authentication required, PK is an environment variable with a private key)
|
|
233
|
-
* const config = PerpetualDataHandler.readSDKConfig("testnet");
|
|
234
|
-
* const pk: string = <string>process.env.PK;
|
|
235
|
-
* let brokTool = new BrokerTool(config, pk);
|
|
236
|
-
* await brokTool.createProxyInstance();
|
|
237
|
-
* // get 30 day volume for broker
|
|
238
|
-
* let brokVolume = await brokTool.getCurrentBrokerVolume("MATIC");
|
|
239
|
-
* console.log(brokVolume);
|
|
240
|
-
* }
|
|
241
|
-
* main();
|
|
242
|
-
*
|
|
243
|
-
* @returns {number} Current trading volume for this broker, in USD.
|
|
244
|
-
*/
|
|
245
|
-
public async getCurrentBrokerVolume(poolSymbolName: string): Promise<number> {
|
|
246
|
-
if (this.proxyContract == null || this.signer == null) {
|
|
247
|
-
throw Error("no proxy contract or wallet initialized. Use createProxyInstance().");
|
|
248
|
-
}
|
|
249
|
-
let poolId = PerpetualDataHandler._getPoolIdFromSymbol(poolSymbolName, this.poolStaticInfos);
|
|
250
|
-
let volume = await this.proxyContract.getCurrentBrokerVolume(poolId, this.traderAddr);
|
|
251
|
-
return ABK64x64ToFloat(volume);
|
|
252
|
-
}
|
|
253
|
-
|
|
254
|
-
// Lots
|
|
255
|
-
|
|
256
|
-
/**
|
|
257
|
-
* Total amount of collateral currency a broker has to deposit into the default fund to purchase one lot.
|
|
258
|
-
* This is equivalent to the price of a lot expressed in a given pool's currency (e.g. MATIC, USDC, etc).
|
|
259
|
-
* @param {string} poolSymbolName Pool symbol name (e.g. MATIC, USDC, etc).
|
|
260
|
-
* @example
|
|
261
|
-
* import { BrokerTool, PerpetualDataHandler } from '@d8x/perpetuals-sdk';
|
|
262
|
-
* async function main() {
|
|
263
|
-
* console.log(BrokerTool);
|
|
264
|
-
* // setup (authentication required, PK is an environment variable with a private key)
|
|
265
|
-
* const config = PerpetualDataHandler.readSDKConfig("testnet");
|
|
266
|
-
* const pk: string = <string>process.env.PK;
|
|
267
|
-
* let brokTool = new BrokerTool(config, pk);
|
|
268
|
-
* await brokTool.createProxyInstance();
|
|
269
|
-
* // get lot price
|
|
270
|
-
* let brokLotSize = await brokTool.getLotSize("MATIC");
|
|
271
|
-
* console.log(brokLotSize);
|
|
272
|
-
* }
|
|
273
|
-
* main();
|
|
274
|
-
*
|
|
275
|
-
* @returns {number} Broker lot size in a given pool's currency, e.g. in MATIC for poolSymbolName MATIC.
|
|
276
|
-
*/
|
|
277
|
-
public async getLotSize(poolSymbolName: string): Promise<number> {
|
|
278
|
-
if (this.proxyContract == null) {
|
|
279
|
-
throw Error("no proxy contract initialized. Use createProxyInstance().");
|
|
280
|
-
}
|
|
281
|
-
let poolId = PerpetualDataHandler._getPoolIdFromSymbol(poolSymbolName, this.poolStaticInfos);
|
|
282
|
-
let pool = await this.proxyContract.getLiquidityPool(poolId);
|
|
283
|
-
let lot = ABK64x64ToFloat(pool.fBrokerCollateralLotSize);
|
|
284
|
-
return lot;
|
|
285
|
-
}
|
|
286
|
-
|
|
287
|
-
/**
|
|
288
|
-
* Provides information on how many lots a broker purchased for a given pool.
|
|
289
|
-
* This is relevant to determine the broker's fee tier.
|
|
290
|
-
* @param {string} poolSymbolName Pool symbol name (e.g. MATIC, USDC, etc).
|
|
291
|
-
* @example
|
|
292
|
-
* import { BrokerTool, PerpetualDataHandler } from '@d8x/perpetuals-sdk';
|
|
293
|
-
* async function main() {
|
|
294
|
-
* console.log(BrokerTool);
|
|
295
|
-
* // setup (authentication required, PK is an environment variable with a private key)
|
|
296
|
-
* const config = PerpetualDataHandler.readSDKConfig("testnet");
|
|
297
|
-
* const pk: string = <string>process.env.PK;
|
|
298
|
-
* let brokTool = new BrokerTool(config, pk);
|
|
299
|
-
* await brokTool.createProxyInstance();
|
|
300
|
-
* // get broker designation
|
|
301
|
-
* let brokDesignation = await brokTool.getBrokerDesignation("MATIC");
|
|
302
|
-
* console.log(brokDesignation);
|
|
303
|
-
* }
|
|
304
|
-
* main();
|
|
305
|
-
*
|
|
306
|
-
* @returns {number} Number of lots purchased by this broker.
|
|
307
|
-
*/
|
|
308
|
-
public async getBrokerDesignation(poolSymbolName: string): Promise<number> {
|
|
309
|
-
if (this.proxyContract == null || this.signer == null) {
|
|
310
|
-
throw Error("no proxy contract or wallet initialized. Use createProxyInstance().");
|
|
311
|
-
}
|
|
312
|
-
let poolId = PerpetualDataHandler._getPoolIdFromSymbol(poolSymbolName, this.poolStaticInfos);
|
|
313
|
-
let designation = await this.proxyContract.getBrokerDesignation(poolId, this.traderAddr);
|
|
314
|
-
return designation;
|
|
315
|
-
}
|
|
316
|
-
|
|
317
|
-
/**
|
|
318
|
-
* Deposit lots to the default fund of a given pool.
|
|
319
|
-
* @param {string} poolSymbolName Pool symbol name (e.g. MATIC, USDC, etc).
|
|
320
|
-
* @param {number} lots Number of lots to deposit into this pool.
|
|
321
|
-
* @example
|
|
322
|
-
* import { BrokerTool, PerpetualDataHandler } from '@d8x/perpetuals-sdk';
|
|
323
|
-
* async function main() {
|
|
324
|
-
* console.log(BrokerTool);
|
|
325
|
-
* // setup (authentication required, PK is an environment variable with a private key)
|
|
326
|
-
* const config = PerpetualDataHandler.readSDKConfig("testnet");
|
|
327
|
-
* const pk: string = <string>process.env.PK;
|
|
328
|
-
* let brokTool = new BrokerTool(config, pk);
|
|
329
|
-
* await brokTool.createProxyInstance();
|
|
330
|
-
* // deposit to default fund
|
|
331
|
-
* await brokTool.setAllowance("MATIC");
|
|
332
|
-
* let respDeposit = await brokTool.brokerDepositToDefaultFund("MATIC",1);
|
|
333
|
-
* console.log(respDeposit);
|
|
334
|
-
* }
|
|
335
|
-
* main();
|
|
336
|
-
*
|
|
337
|
-
* @returns {ethers.ContractTransaction} ContractTransaction object.
|
|
338
|
-
*/
|
|
339
|
-
public async brokerDepositToDefaultFund(poolSymbolName: string, lots: number): Promise<ethers.ContractTransaction> {
|
|
340
|
-
if (this.proxyContract == null || this.signer == null) {
|
|
341
|
-
throw Error("no proxy contract or wallet initialized. Use createProxyInstance().");
|
|
342
|
-
}
|
|
343
|
-
let poolId = PerpetualDataHandler._getPoolIdFromSymbol(poolSymbolName, this.poolStaticInfos);
|
|
344
|
-
let tx = await this.proxyContract.brokerDepositToDefaultFund(poolId, lots, { gasLimit: this.gasLimit });
|
|
345
|
-
return tx;
|
|
346
|
-
}
|
|
347
|
-
|
|
348
|
-
// Signatures
|
|
349
|
-
|
|
350
|
-
/**
|
|
351
|
-
* Adds this broker's signature to an order. An order signed by a broker is considered
|
|
352
|
-
* to be routed through this broker and benefits from the broker's fee conditions.
|
|
353
|
-
* @param {Order} order Order to sign. It must contain valid broker fee, broker address, and order deadline.
|
|
354
|
-
* @param {string} traderAddr Address of trader submitting the order.
|
|
355
|
-
* @example
|
|
356
|
-
* import { BrokerTool, PerpetualDataHandler } from '@d8x/perpetuals-sdk';
|
|
357
|
-
* async function main() {
|
|
358
|
-
* console.log(BrokerTool);
|
|
359
|
-
* // setup (authentication required, PK is an environment variable with a private key)
|
|
360
|
-
* const config = PerpetualDataHandler.readSDKConfig("testnet");
|
|
361
|
-
* const pk: string = <string>process.env.PK;
|
|
362
|
-
* let brokTool = new BrokerTool(config, pk);
|
|
363
|
-
* await brokTool.createProxyInstance();
|
|
364
|
-
* // sign order
|
|
365
|
-
* let order = {symbol: "ETH-USD-MATIC",
|
|
366
|
-
* side: "BUY",
|
|
367
|
-
* type: "MARKET",
|
|
368
|
-
* quantity: 1,
|
|
369
|
-
* timestamp: Date.now()
|
|
370
|
-
* };
|
|
371
|
-
* let signedOrder = await brokTool.signOrder(order, "0xAb5801a7D398351b8bE11C439e05C5B3259aeC9B",
|
|
372
|
-
* 0.0001, 1669723339);
|
|
373
|
-
* console.log(signedOrder);
|
|
374
|
-
* // execute order
|
|
375
|
-
* let orderTransaction = await accTrade.order(signedOrder);
|
|
376
|
-
* console.log(orderTransaction.hash);
|
|
377
|
-
* }
|
|
378
|
-
* main();
|
|
379
|
-
*
|
|
380
|
-
* @returns {Order} An order signed by this broker, which can be submitted directly with AccountTrade.order.
|
|
381
|
-
*/
|
|
382
|
-
public async signOrder(order: Order, traderAddr: string): Promise<Order> {
|
|
383
|
-
if (this.proxyContract == null || this.signer == null) {
|
|
384
|
-
throw Error("no proxy contract or wallet initialized. Use createProxyInstance().");
|
|
385
|
-
}
|
|
386
|
-
order.brokerAddr = this.traderAddr;
|
|
387
|
-
order.brokerSignature = await BrokerTool._signOrder(
|
|
388
|
-
order.symbol,
|
|
389
|
-
order.brokerFeeTbps!,
|
|
390
|
-
traderAddr,
|
|
391
|
-
BigNumber.from(order.deadline),
|
|
392
|
-
this.signer,
|
|
393
|
-
this.chainId,
|
|
394
|
-
this.proxyAddr,
|
|
395
|
-
this.symbolToPerpStaticInfo
|
|
396
|
-
);
|
|
397
|
-
return order;
|
|
398
|
-
}
|
|
399
|
-
|
|
400
|
-
/**
|
|
401
|
-
* Creates a signature that a trader can use to place orders with this broker.
|
|
402
|
-
* This signature can be used to pass on to a trader who wishes to trade via this SDK or directly on the blockchain.
|
|
403
|
-
* @param {string} traderAddr Address of the trader signing up with this broker.
|
|
404
|
-
* @param {string} symbol Perpetual that this trader will be trading, of the form ETH-USD-MATIC.
|
|
405
|
-
* @param {number} brokerFee Broker fee for this trader, in decimals (i.e. 0.1% is 0.001).
|
|
406
|
-
* @param {number} deadline Deadline for the order to be executed.
|
|
407
|
-
* @returns {string} Broker signature approving this trader's fee, symbol, and deadline.
|
|
408
|
-
* @ignore
|
|
409
|
-
*/
|
|
410
|
-
public async createSignatureForTrader(
|
|
411
|
-
traderAddr: string,
|
|
412
|
-
symbol: string,
|
|
413
|
-
brokerFee: number,
|
|
414
|
-
deadline: number
|
|
415
|
-
): Promise<string> {
|
|
416
|
-
if (this.proxyContract == null || this.signer == null) {
|
|
417
|
-
throw Error("no proxy contract or wallet initialized. Use createProxyInstance().");
|
|
418
|
-
}
|
|
419
|
-
let iDeadline = BigNumber.from(deadline);
|
|
420
|
-
let brokerFeeTbps = 100_000 * brokerFee;
|
|
421
|
-
return await BrokerTool._signOrder(
|
|
422
|
-
symbol,
|
|
423
|
-
brokerFeeTbps,
|
|
424
|
-
traderAddr,
|
|
425
|
-
iDeadline,
|
|
426
|
-
this.signer,
|
|
427
|
-
this.chainId,
|
|
428
|
-
this.proxyAddr,
|
|
429
|
-
this.symbolToPerpStaticInfo
|
|
430
|
-
);
|
|
431
|
-
}
|
|
432
|
-
|
|
433
|
-
private static async _signOrder(
|
|
434
|
-
symbol: string,
|
|
435
|
-
brokerFeeTbps: number,
|
|
436
|
-
traderAddr: string,
|
|
437
|
-
iDeadline: BigNumber,
|
|
438
|
-
signer: ethers.Signer,
|
|
439
|
-
chainId: number,
|
|
440
|
-
proxyAddress: string,
|
|
441
|
-
symbolToPerpStaticInfo: Map<string, PerpetualStaticInfo>
|
|
442
|
-
): Promise<string> {
|
|
443
|
-
const NAME = "Perpetual Trade Manager";
|
|
444
|
-
const DOMAIN_TYPEHASH = ethers.utils.keccak256(
|
|
445
|
-
Buffer.from("EIP712Domain(string name,uint256 chainId,address verifyingContract)")
|
|
446
|
-
);
|
|
447
|
-
let abiCoder = ethers.utils.defaultAbiCoder;
|
|
448
|
-
let domainSeparator = ethers.utils.keccak256(
|
|
449
|
-
abiCoder.encode(
|
|
450
|
-
["bytes32", "bytes32", "uint256", "address"],
|
|
451
|
-
[DOMAIN_TYPEHASH, ethers.utils.keccak256(Buffer.from(NAME)), chainId, proxyAddress]
|
|
452
|
-
)
|
|
453
|
-
);
|
|
454
|
-
//
|
|
455
|
-
const TRADE_BROKER_TYPEHASH = ethers.utils.keccak256(
|
|
456
|
-
Buffer.from("Order(uint24 iPerpetualId,uint16 brokerFeeTbps,address traderAddr,uint64 iDeadline)")
|
|
457
|
-
);
|
|
458
|
-
let iPerpetualId = PerpetualDataHandler.symbolToPerpetualId(symbol, symbolToPerpStaticInfo);
|
|
459
|
-
let structHash = ethers.utils.keccak256(
|
|
460
|
-
abiCoder.encode(
|
|
461
|
-
["bytes32", "uint24", "uint16", "address", "uint64"],
|
|
462
|
-
[TRADE_BROKER_TYPEHASH, iPerpetualId, brokerFeeTbps, traderAddr, iDeadline]
|
|
463
|
-
)
|
|
464
|
-
);
|
|
465
|
-
|
|
466
|
-
let digest = ethers.utils.keccak256(abiCoder.encode(["bytes32", "bytes32"], [domainSeparator, structHash]));
|
|
467
|
-
let digestBuffer = Buffer.from(digest.substring(2, digest.length), "hex");
|
|
468
|
-
return await signer.signMessage(digestBuffer);
|
|
469
|
-
}
|
|
470
|
-
|
|
471
|
-
// Transfer ownership
|
|
472
|
-
|
|
473
|
-
/**
|
|
474
|
-
* Transfer ownership of a broker's status to a new wallet. This function transfers the values related to
|
|
475
|
-
* (i) trading volume and (ii) deposited lots to newAddress. The broker needs in addition to manually transfer
|
|
476
|
-
* his D8X holdings to newAddress. Until this transfer is completed, the broker will not have his current designation reflected at newAddress.
|
|
477
|
-
* @param {string} poolSymbolName Pool symbol name (e.g. MATIC, USDC, etc).
|
|
478
|
-
* @param {string} newAddress The address this broker wants to use from now on.
|
|
479
|
-
* @example
|
|
480
|
-
* import { BrokerTool, PerpetualDataHandler } from '@d8x/perpetuals-sdk';
|
|
481
|
-
* async function main() {
|
|
482
|
-
* console.log(BrokerTool);
|
|
483
|
-
* // setup (authentication required, PK is an environment variable with a private key)
|
|
484
|
-
* const config = PerpetualDataHandler.readSDKConfig("testnet");
|
|
485
|
-
* const pk: string = <string>process.env.PK;
|
|
486
|
-
* let brokTool = new BrokerTool(config, pk);
|
|
487
|
-
* await brokTool.createProxyInstance();
|
|
488
|
-
* // transfer ownership
|
|
489
|
-
* let respTransferOwnership = await brokTool.transferOwnership("MATIC", "0xAb5801a7D398351b8bE11C439e05C5B3259aeC9B");
|
|
490
|
-
* console.log(respTransferOwnership);
|
|
491
|
-
* }
|
|
492
|
-
* main();
|
|
493
|
-
*
|
|
494
|
-
* @returns {ethers.providers.TransactionResponse} ethers transaction object
|
|
495
|
-
*/
|
|
496
|
-
public async transferOwnership(
|
|
497
|
-
poolSymbolName: string,
|
|
498
|
-
newAddress: string
|
|
499
|
-
): Promise<ethers.providers.TransactionResponse> {
|
|
500
|
-
if (this.proxyContract == null) {
|
|
501
|
-
throw Error("no proxy contract or wallet initialized. Use createProxyInstance().");
|
|
502
|
-
}
|
|
503
|
-
let poolId = PerpetualDataHandler._getPoolIdFromSymbol(poolSymbolName, this.poolStaticInfos);
|
|
504
|
-
let tx = await this.proxyContract.transferBrokerOwnership(poolId, newAddress, { gasLimit: this.gasLimit });
|
|
505
|
-
return tx;
|
|
506
|
-
}
|
|
507
|
-
}
|