@drift-labs/sdk 2.60.0-beta.3 → 2.60.0-beta.5

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/VERSION CHANGED
@@ -1 +1 @@
1
- 2.60.0-beta.3
1
+ 2.60.0-beta.5
@@ -158,7 +158,7 @@ exports.MainnetSpotMarkets = [
158
158
  mint: new web3_js_1.PublicKey('JUPyiwrYJFskUPiHa7hkeR8VUtAeFoSYbKedZNsDvCN'),
159
159
  precision: new __1.BN(10).pow(numericConstants_1.SIX),
160
160
  precisionExp: numericConstants_1.SIX,
161
- serumMarket: new web3_js_1.PublicKey('FbwncFP5bZjdx8J6yfDDTrCmmMkwieuape1enCvwLG33'),
161
+ phoenixMarket: new web3_js_1.PublicKey('2pspvjWWaf3dNgt3jsgSzFCNvMGPb7t8FrEYvLGjvcCe'),
162
162
  },
163
163
  ];
164
164
  exports.SpotMarkets = {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@drift-labs/sdk",
3
- "version": "2.60.0-beta.3",
3
+ "version": "2.60.0-beta.5",
4
4
  "main": "lib/index.js",
5
5
  "types": "lib/index.d.ts",
6
6
  "author": "crispheaney",
@@ -188,7 +188,9 @@ export const MainnetSpotMarkets: SpotMarketConfig[] = [
188
188
  mint: new PublicKey('JUPyiwrYJFskUPiHa7hkeR8VUtAeFoSYbKedZNsDvCN'),
189
189
  precision: new BN(10).pow(SIX),
190
190
  precisionExp: SIX,
191
- serumMarket: new PublicKey('FbwncFP5bZjdx8J6yfDDTrCmmMkwieuape1enCvwLG33'),
191
+ phoenixMarket: new PublicKey(
192
+ '2pspvjWWaf3dNgt3jsgSzFCNvMGPb7t8FrEYvLGjvcCe'
193
+ ),
192
194
  },
193
195
  ];
194
196
 
@@ -1,66 +0,0 @@
1
- import { Connection, PublicKey } from '@solana/web3.js';
2
- import {
3
- BASE_PRECISION,
4
- L2Level,
5
- PRICE_PRECISION,
6
- PhoenixSubscriber,
7
- } from '../src';
8
- import { PROGRAM_ID } from '@ellipsis-labs/phoenix-sdk';
9
-
10
- export async function listenToBook(): Promise<void> {
11
- const connection = new Connection('https://api.mainnet-beta.solana.com');
12
-
13
- for (const market of [
14
- '4DoNfFBfF7UokCC2FQzriy7yHK6DY6NVdYpuekQ5pRgg', // SOL/USDC
15
- 'Ew3vFDdtdGrknJAVVfraxCA37uNJtimXYPY4QjnfhFHH', // ETH/USDC
16
- '2sTMN9A1D1qeZLF95XQgJCUPiKe5DiV52jLfZGqMP46m', // PYTH/USDC
17
- 'BRLLmdtPGuuFn3BU6orYw4KHaohAEptBToi3dwRUnHQZ', // JTO/USDC
18
- ]) {
19
- const phoenixSubscriber = new PhoenixSubscriber({
20
- connection,
21
- programId: PROGRAM_ID,
22
- marketAddress: new PublicKey(market),
23
- accountSubscription: {
24
- type: 'websocket',
25
- },
26
- });
27
-
28
- await phoenixSubscriber.subscribe();
29
-
30
- const bids = phoenixSubscriber.getL2Levels('bids');
31
- const asks = phoenixSubscriber.getL2Levels('asks');
32
- let bid: L2Level | null = null;
33
- for (const b of bids) {
34
- bid = b;
35
- break;
36
- }
37
- let ask: L2Level | null = null;
38
- for (const a of asks) {
39
- ask = a;
40
- break;
41
- }
42
-
43
- console.log('market', market);
44
- console.log(
45
- (bid?.size.toNumber() || 0) / BASE_PRECISION.toNumber(),
46
- (bid?.price.toNumber() || 0) / PRICE_PRECISION.toNumber(),
47
- '@',
48
- (ask?.price.toNumber() || (1 << 53) - 1) / PRICE_PRECISION.toNumber(),
49
- (ask?.size.toNumber() || 0) / BASE_PRECISION.toNumber()
50
- );
51
- console.log();
52
-
53
- await phoenixSubscriber.unsubscribe();
54
- }
55
- }
56
-
57
- (async function () {
58
- try {
59
- await listenToBook();
60
- } catch (err) {
61
- console.log('Error: ', err);
62
- process.exit(1);
63
- }
64
-
65
- process.exit(0);
66
- })();
@@ -1 +0,0 @@
1
- export {};
@@ -1,59 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- const anchor_1 = require("@coral-xyz/anchor");
4
- const __1 = require("..");
5
- const web3_js_1 = require("@solana/web3.js");
6
- const __2 = require("..");
7
- const env = 'mainnet-beta';
8
- const main = async () => {
9
- // Initialize Drift SDK
10
- const sdkConfig = (0, __2.initialize)({ env });
11
- // Set up the Wallet and Provider
12
- const privateKey = process.env.BOT_PRIVATE_KEY; // stored as an array string
13
- const keypair = web3_js_1.Keypair.fromSecretKey(Uint8Array.from(JSON.parse(privateKey)));
14
- const wallet = new __1.Wallet(keypair);
15
- // Set up the Connection
16
- const rpcAddress = process.env.RPC_ADDRESS; // can use: https://api.devnet.solana.com for devnet; https://api.mainnet-beta.solana.com for mainnet;
17
- const connection = new web3_js_1.Connection(rpcAddress);
18
- // Set up the Provider
19
- const provider = new anchor_1.AnchorProvider(connection,
20
- // @ts-ignore
21
- wallet, anchor_1.AnchorProvider.defaultOptions());
22
- // Set up the Drift Clearing House
23
- const driftPublicKey = new web3_js_1.PublicKey(sdkConfig.DRIFT_PROGRAM_ID);
24
- const bulkAccountLoader = new __2.BulkAccountLoader(connection, 'confirmed', 1000);
25
- const driftClient = new __2.DriftClient({
26
- connection,
27
- wallet: provider.wallet,
28
- programID: driftPublicKey,
29
- ...(0, __2.getMarketsAndOraclesForSubscription)(env),
30
- accountSubscription: {
31
- type: 'polling',
32
- accountLoader: bulkAccountLoader,
33
- },
34
- });
35
- console.log('Subscribing drift client...');
36
- await driftClient.subscribe();
37
- console.log('Loading user map...');
38
- const userMap = new __1.UserMap({
39
- driftClient,
40
- subscriptionConfig: {
41
- type: 'websocket',
42
- commitment: 'processed',
43
- },
44
- skipInitialLoad: false,
45
- includeIdle: false,
46
- });
47
- // fetches all users and subscribes for updates
48
- await userMap.subscribe();
49
- console.log('Loading dlob from user map...');
50
- const slot = await driftClient.connection.getSlot();
51
- const dlob = await userMap.getDLOB(slot);
52
- console.log('number of orders', dlob.getDLOBOrders().length);
53
- dlob.clear();
54
- console.log('Unsubscribing users...');
55
- await userMap.unsubscribe();
56
- console.log('Unsubscribing drift client...');
57
- await driftClient.unsubscribe();
58
- };
59
- main();
@@ -1,2 +0,0 @@
1
- import { PublicKey } from '@solana/web3.js';
2
- export declare const getTokenAddress: (mintAddress: string, userPubKey: string) => Promise<PublicKey>;
@@ -1,83 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.getTokenAddress = void 0;
4
- const anchor_1 = require("@coral-xyz/anchor");
5
- const __1 = require("..");
6
- const spl_token_1 = require("@solana/spl-token");
7
- const web3_js_1 = require("@solana/web3.js");
8
- const __2 = require("..");
9
- const spotMarkets_1 = require("../constants/spotMarkets");
10
- const getTokenAddress = (mintAddress, userPubKey) => {
11
- return (0, spl_token_1.getAssociatedTokenAddress)(new web3_js_1.PublicKey(mintAddress), new web3_js_1.PublicKey(userPubKey));
12
- };
13
- exports.getTokenAddress = getTokenAddress;
14
- const env = 'devnet';
15
- const main = async () => {
16
- // Initialize Drift SDK
17
- const sdkConfig = (0, __2.initialize)({ env });
18
- // Set up the Wallet and Provider
19
- const privateKey = process.env.BOT_PRIVATE_KEY; // stored as an array string
20
- const keypair = web3_js_1.Keypair.fromSecretKey(Uint8Array.from(JSON.parse(privateKey)));
21
- const wallet = new __1.Wallet(keypair);
22
- // Set up the Connection
23
- const rpcAddress = process.env.RPC_ADDRESS; // can use: https://api.devnet.solana.com for devnet; https://api.mainnet-beta.solana.com for mainnet;
24
- const connection = new web3_js_1.Connection(rpcAddress);
25
- // Set up the Provider
26
- const provider = new anchor_1.AnchorProvider(connection,
27
- // @ts-ignore
28
- wallet, anchor_1.AnchorProvider.defaultOptions());
29
- // Check SOL Balance
30
- const lamportsBalance = await connection.getBalance(wallet.publicKey);
31
- console.log('SOL balance:', lamportsBalance / 10 ** 9);
32
- // Misc. other things to set up
33
- const usdcTokenAddress = await (0, exports.getTokenAddress)(sdkConfig.USDC_MINT_ADDRESS, wallet.publicKey.toString());
34
- // Set up the Drift Clearing House
35
- const driftPublicKey = new web3_js_1.PublicKey(sdkConfig.DRIFT_PROGRAM_ID);
36
- const bulkAccountLoader = new __2.BulkAccountLoader(connection, 'confirmed', 1000);
37
- const driftClient = new __2.DriftClient({
38
- connection,
39
- wallet: provider.wallet,
40
- programID: driftPublicKey,
41
- ...(0, __2.getMarketsAndOraclesForSubscription)(env),
42
- accountSubscription: {
43
- type: 'polling',
44
- accountLoader: bulkAccountLoader,
45
- },
46
- });
47
- await driftClient.subscribe();
48
- // Set up user client
49
- const user = new __2.User({
50
- driftClient: driftClient,
51
- userAccountPublicKey: await driftClient.getUserAccountPublicKey(),
52
- accountSubscription: {
53
- type: 'polling',
54
- accountLoader: bulkAccountLoader,
55
- },
56
- });
57
- //// Check if user account exists for the current wallet
58
- const userAccountExists = await user.exists();
59
- if (!userAccountExists) {
60
- //// Create a Clearing House account by Depositing some USDC ($10,000 in this case)
61
- const depositAmount = new anchor_1.BN(10000).mul(__2.QUOTE_PRECISION);
62
- await driftClient.initializeUserAccountAndDepositCollateral(depositAmount, await (0, exports.getTokenAddress)(usdcTokenAddress.toString(), wallet.publicKey.toString()), spotMarkets_1.SpotMarkets['devnet'][0].marketIndex);
63
- }
64
- await user.subscribe();
65
- // Get current price
66
- const solMarketInfo = sdkConfig.PERP_MARKETS.find((market) => market.baseAssetSymbol === 'SOL');
67
- const marketIndex = solMarketInfo.marketIndex;
68
- const [bid, ask] = (0, __1.calculateBidAskPrice)(driftClient.getPerpMarketAccount(marketIndex).amm, driftClient.getOracleDataForPerpMarket(marketIndex));
69
- const formattedBidPrice = (0, __2.convertToNumber)(bid, __2.PRICE_PRECISION);
70
- const formattedAskPrice = (0, __2.convertToNumber)(ask, __2.PRICE_PRECISION);
71
- console.log(`Current amm bid and ask price are $${formattedBidPrice} and $${formattedAskPrice}`);
72
- // Estimate the slippage for a $5000 LONG trade
73
- const solMarketAccount = driftClient.getPerpMarketAccount(solMarketInfo.marketIndex);
74
- const slippage = (0, __2.convertToNumber)((0, __2.calculateTradeSlippage)(__2.PositionDirection.LONG, new anchor_1.BN(1).mul(__1.BASE_PRECISION), solMarketAccount, 'base', driftClient.getOracleDataForPerpMarket(solMarketInfo.marketIndex))[0], __2.PRICE_PRECISION);
75
- console.log(`Slippage for a 1 SOL-PERP would be $${slippage}`);
76
- await driftClient.placePerpOrder((0, __1.getMarketOrderParams)({
77
- baseAssetAmount: new anchor_1.BN(1).mul(__1.BASE_PRECISION),
78
- direction: __2.PositionDirection.LONG,
79
- marketIndex: solMarketAccount.marketIndex,
80
- }));
81
- console.log(`Placed a 1 SOL-PERP LONG order`);
82
- };
83
- main();
@@ -1,86 +0,0 @@
1
- import { AnchorProvider } from '@coral-xyz/anchor';
2
- import { UserMap, Wallet } from '..';
3
- import { Connection, Keypair, PublicKey } from '@solana/web3.js';
4
- import {
5
- DriftClient,
6
- initialize,
7
- BulkAccountLoader,
8
- getMarketsAndOraclesForSubscription,
9
- } from '..';
10
-
11
- const env = 'mainnet-beta';
12
-
13
- const main = async () => {
14
- // Initialize Drift SDK
15
- const sdkConfig = initialize({ env });
16
-
17
- // Set up the Wallet and Provider
18
- const privateKey = process.env.BOT_PRIVATE_KEY; // stored as an array string
19
- const keypair = Keypair.fromSecretKey(
20
- Uint8Array.from(JSON.parse(privateKey))
21
- );
22
- const wallet = new Wallet(keypair);
23
-
24
- // Set up the Connection
25
- const rpcAddress = process.env.RPC_ADDRESS; // can use: https://api.devnet.solana.com for devnet; https://api.mainnet-beta.solana.com for mainnet;
26
- const connection = new Connection(rpcAddress);
27
-
28
- // Set up the Provider
29
- const provider = new AnchorProvider(
30
- connection,
31
- // @ts-ignore
32
- wallet,
33
- AnchorProvider.defaultOptions()
34
- );
35
-
36
- // Set up the Drift Clearing House
37
- const driftPublicKey = new PublicKey(sdkConfig.DRIFT_PROGRAM_ID);
38
- const bulkAccountLoader = new BulkAccountLoader(
39
- connection,
40
- 'confirmed',
41
- 1000
42
- );
43
- const driftClient = new DriftClient({
44
- connection,
45
- wallet: provider.wallet,
46
- programID: driftPublicKey,
47
- ...getMarketsAndOraclesForSubscription(env),
48
- accountSubscription: {
49
- type: 'polling',
50
- accountLoader: bulkAccountLoader,
51
- },
52
- });
53
-
54
- console.log('Subscribing drift client...');
55
- await driftClient.subscribe();
56
-
57
- console.log('Loading user map...');
58
- const userMap = new UserMap({
59
- driftClient,
60
- subscriptionConfig: {
61
- type: 'websocket',
62
- commitment: 'processed',
63
- },
64
- skipInitialLoad: false,
65
- includeIdle: false,
66
- });
67
-
68
- // fetches all users and subscribes for updates
69
- await userMap.subscribe();
70
-
71
- console.log('Loading dlob from user map...');
72
- const slot = await driftClient.connection.getSlot();
73
- const dlob = await userMap.getDLOB(slot);
74
-
75
- console.log('number of orders', dlob.getDLOBOrders().length);
76
-
77
- dlob.clear();
78
-
79
- console.log('Unsubscribing users...');
80
- await userMap.unsubscribe();
81
-
82
- console.log('Unsubscribing drift client...');
83
- await driftClient.unsubscribe();
84
- };
85
-
86
- main();
@@ -1,162 +0,0 @@
1
- import { AnchorProvider, BN } from '@coral-xyz/anchor';
2
- import {
3
- BASE_PRECISION,
4
- calculateBidAskPrice,
5
- getMarketOrderParams,
6
- Wallet,
7
- } from '..';
8
- import { getAssociatedTokenAddress } from '@solana/spl-token';
9
- import { Connection, Keypair, PublicKey } from '@solana/web3.js';
10
- import {
11
- DriftClient,
12
- User,
13
- initialize,
14
- PositionDirection,
15
- convertToNumber,
16
- calculateTradeSlippage,
17
- BulkAccountLoader,
18
- getMarketsAndOraclesForSubscription,
19
- PRICE_PRECISION,
20
- QUOTE_PRECISION,
21
- } from '..';
22
- import { SpotMarkets } from '../constants/spotMarkets';
23
-
24
- export const getTokenAddress = (
25
- mintAddress: string,
26
- userPubKey: string
27
- ): Promise<PublicKey> => {
28
- return getAssociatedTokenAddress(
29
- new PublicKey(mintAddress),
30
- new PublicKey(userPubKey)
31
- );
32
- };
33
-
34
- const env = 'devnet';
35
-
36
- const main = async () => {
37
- // Initialize Drift SDK
38
- const sdkConfig = initialize({ env });
39
-
40
- // Set up the Wallet and Provider
41
- const privateKey = process.env.BOT_PRIVATE_KEY; // stored as an array string
42
- const keypair = Keypair.fromSecretKey(
43
- Uint8Array.from(JSON.parse(privateKey))
44
- );
45
- const wallet = new Wallet(keypair);
46
-
47
- // Set up the Connection
48
- const rpcAddress = process.env.RPC_ADDRESS; // can use: https://api.devnet.solana.com for devnet; https://api.mainnet-beta.solana.com for mainnet;
49
- const connection = new Connection(rpcAddress);
50
-
51
- // Set up the Provider
52
- const provider = new AnchorProvider(
53
- connection,
54
- // @ts-ignore
55
- wallet,
56
- AnchorProvider.defaultOptions()
57
- );
58
-
59
- // Check SOL Balance
60
- const lamportsBalance = await connection.getBalance(wallet.publicKey);
61
- console.log('SOL balance:', lamportsBalance / 10 ** 9);
62
-
63
- // Misc. other things to set up
64
- const usdcTokenAddress = await getTokenAddress(
65
- sdkConfig.USDC_MINT_ADDRESS,
66
- wallet.publicKey.toString()
67
- );
68
-
69
- // Set up the Drift Clearing House
70
- const driftPublicKey = new PublicKey(sdkConfig.DRIFT_PROGRAM_ID);
71
- const bulkAccountLoader = new BulkAccountLoader(
72
- connection,
73
- 'confirmed',
74
- 1000
75
- );
76
- const driftClient = new DriftClient({
77
- connection,
78
- wallet: provider.wallet,
79
- programID: driftPublicKey,
80
- ...getMarketsAndOraclesForSubscription(env),
81
- accountSubscription: {
82
- type: 'polling',
83
- accountLoader: bulkAccountLoader,
84
- },
85
- });
86
- await driftClient.subscribe();
87
-
88
- // Set up user client
89
- const user = new User({
90
- driftClient: driftClient,
91
- userAccountPublicKey: await driftClient.getUserAccountPublicKey(),
92
- accountSubscription: {
93
- type: 'polling',
94
- accountLoader: bulkAccountLoader,
95
- },
96
- });
97
-
98
- //// Check if user account exists for the current wallet
99
- const userAccountExists = await user.exists();
100
-
101
- if (!userAccountExists) {
102
- //// Create a Clearing House account by Depositing some USDC ($10,000 in this case)
103
- const depositAmount = new BN(10000).mul(QUOTE_PRECISION);
104
- await driftClient.initializeUserAccountAndDepositCollateral(
105
- depositAmount,
106
- await getTokenAddress(
107
- usdcTokenAddress.toString(),
108
- wallet.publicKey.toString()
109
- ),
110
- SpotMarkets['devnet'][0].marketIndex
111
- );
112
- }
113
-
114
- await user.subscribe();
115
-
116
- // Get current price
117
- const solMarketInfo = sdkConfig.PERP_MARKETS.find(
118
- (market) => market.baseAssetSymbol === 'SOL'
119
- );
120
-
121
- const marketIndex = solMarketInfo.marketIndex;
122
- const [bid, ask] = calculateBidAskPrice(
123
- driftClient.getPerpMarketAccount(marketIndex).amm,
124
- driftClient.getOracleDataForPerpMarket(marketIndex)
125
- );
126
-
127
- const formattedBidPrice = convertToNumber(bid, PRICE_PRECISION);
128
- const formattedAskPrice = convertToNumber(ask, PRICE_PRECISION);
129
-
130
- console.log(
131
- `Current amm bid and ask price are $${formattedBidPrice} and $${formattedAskPrice}`
132
- );
133
-
134
- // Estimate the slippage for a $5000 LONG trade
135
- const solMarketAccount = driftClient.getPerpMarketAccount(
136
- solMarketInfo.marketIndex
137
- );
138
-
139
- const slippage = convertToNumber(
140
- calculateTradeSlippage(
141
- PositionDirection.LONG,
142
- new BN(1).mul(BASE_PRECISION),
143
- solMarketAccount,
144
- 'base',
145
- driftClient.getOracleDataForPerpMarket(solMarketInfo.marketIndex)
146
- )[0],
147
- PRICE_PRECISION
148
- );
149
-
150
- console.log(`Slippage for a 1 SOL-PERP would be $${slippage}`);
151
-
152
- await driftClient.placePerpOrder(
153
- getMarketOrderParams({
154
- baseAssetAmount: new BN(1).mul(BASE_PRECISION),
155
- direction: PositionDirection.LONG,
156
- marketIndex: solMarketAccount.marketIndex,
157
- })
158
- );
159
- console.log(`Placed a 1 SOL-PERP LONG order`);
160
- };
161
-
162
- main();