@drift-labs/sdk 2.162.0-beta.2 → 2.163.0-beta.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.
- package/.prettierignore +1 -0
- package/.yarn/install-state.gz +0 -0
- package/README.md +2 -2
- package/VERSION +1 -1
- package/bun.lock +47 -79
- package/lib/browser/accounts/fetch.d.ts +6 -6
- package/lib/browser/accounts/fetch.js +4 -4
- package/lib/browser/accounts/grpcAccountSubscriber.d.ts +2 -2
- package/lib/browser/accounts/grpcDriftClientAccountSubscriber.d.ts +2 -2
- package/lib/browser/accounts/grpcDriftClientAccountSubscriberV2.d.ts +3 -3
- package/lib/browser/accounts/grpcDriftClientAccountSubscriberV2.js +2 -2
- package/lib/browser/accounts/grpcInsuranceFundStakeAccountSubscriber.d.ts +2 -2
- package/lib/browser/accounts/grpcMultiAccountSubscriber.d.ts +2 -2
- package/lib/browser/accounts/grpcMultiUserAccountSubscriber.d.ts +2 -2
- package/lib/browser/accounts/grpcProgramAccountSubscriber.d.ts +2 -2
- package/lib/browser/accounts/grpcUserAccountSubscriber.d.ts +2 -2
- package/lib/browser/accounts/grpcUserStatsAccountSubscriber.d.ts +2 -2
- package/lib/browser/accounts/laserProgramAccountSubscriber.d.ts +2 -2
- package/lib/browser/accounts/oneShotUserAccountSubscriber.d.ts +3 -3
- package/lib/browser/accounts/oneShotUserStatsAccountSubscriber.d.ts +3 -3
- package/lib/browser/accounts/pollingDriftClientAccountSubscriber.d.ts +3 -3
- package/lib/browser/accounts/pollingDriftClientAccountSubscriber.js +2 -2
- package/lib/browser/accounts/pollingInsuranceFundStakeAccountSubscriber.d.ts +3 -3
- package/lib/browser/accounts/pollingInsuranceFundStakeAccountSubscriber.js +1 -1
- package/lib/browser/accounts/pollingOracleAccountSubscriber.d.ts +2 -2
- package/lib/browser/accounts/pollingTokenAccountSubscriber.d.ts +2 -2
- package/lib/browser/accounts/pollingUserAccountSubscriber.js +2 -2
- package/lib/browser/accounts/pollingUserStatsAccountSubscriber.d.ts +3 -3
- package/lib/browser/accounts/pollingUserStatsAccountSubscriber.js +1 -1
- package/lib/browser/accounts/testBulkAccountLoader.js +3 -5
- package/lib/browser/accounts/types.d.ts +11 -14
- package/lib/browser/accounts/webSocketAccountSubscriber.d.ts +3 -3
- package/lib/browser/accounts/webSocketAccountSubscriber.js +1 -2
- package/lib/browser/accounts/webSocketAccountSubscriberV2.d.ts +3 -3
- package/lib/browser/accounts/webSocketDriftClientAccountSubscriber.d.ts +5 -5
- package/lib/browser/accounts/webSocketDriftClientAccountSubscriber.js +2 -2
- package/lib/browser/accounts/webSocketDriftClientAccountSubscriberV2.d.ts +3 -3
- package/lib/browser/accounts/webSocketDriftClientAccountSubscriberV2.js +2 -2
- package/lib/browser/accounts/webSocketInsuranceFundStakeAccountSubscriber.d.ts +3 -3
- package/lib/browser/accounts/webSocketProgramAccountSubscriber.d.ts +3 -3
- package/lib/browser/accounts/webSocketProgramAccountSubscriberV2.d.ts +3 -3
- package/lib/browser/accounts/webSocketProgramAccountsSubscriberV2.d.ts +3 -3
- package/lib/browser/accounts/webSocketUserAccountSubscriber.d.ts +3 -3
- package/lib/browser/accounts/webSocketUserStatsAccountSubsriber.d.ts +3 -3
- package/lib/browser/accounts/websocketProgramUserAccountSubscriber.d.ts +2 -2
- package/lib/browser/addresses/pda.d.ts +6 -2
- package/lib/browser/addresses/pda.js +7 -12
- package/lib/browser/adminClient.d.ts +11 -9
- package/lib/browser/adminClient.js +30 -72
- package/lib/browser/auctionSubscriber/auctionSubscriber.js +1 -1
- package/lib/browser/auctionSubscriber/auctionSubscriberGrpc.js +1 -1
- package/lib/browser/config.d.ts +7 -3
- package/lib/browser/config.js +9 -7
- package/lib/browser/constants/index.d.ts +5 -0
- package/lib/browser/constants/index.js +5 -0
- package/lib/browser/constants/numericConstants.d.ts +1 -1
- package/lib/browser/constants/numericConstants.js +3 -3
- package/lib/browser/constants/perpMarkets.js +3 -412
- package/lib/browser/constants/spotMarkets.js +7 -91
- package/lib/browser/constituentMap/constituentMap.js +2 -2
- package/lib/browser/constituentMap/pollingConstituentAccountSubscriber.d.ts +3 -3
- package/lib/browser/constituentMap/webSocketConstituentAccountSubscriber.d.ts +3 -3
- package/lib/browser/constituentMap/webSocketConstituentAccountSubscriber.js +1 -1
- package/lib/browser/decode/customCoder.d.ts +7 -9
- package/lib/browser/decode/customCoder.js +17 -28
- package/lib/browser/decode/user.js +7 -25
- package/lib/browser/dlob/DLOB.d.ts +12 -0
- package/lib/browser/dlob/DLOB.js +12 -0
- package/lib/browser/dlob/orderBookLevels.js +1 -1
- package/lib/browser/driftClient.d.ts +32 -59
- package/lib/browser/driftClient.js +85 -562
- package/lib/browser/driftClientConfig.d.ts +7 -0
- package/lib/browser/events/eventSubscriber.d.ts +8 -0
- package/lib/browser/events/eventSubscriber.js +5 -2
- package/lib/browser/events/parse.d.ts +1 -1
- package/lib/browser/factory/oracleClient.d.ts +2 -2
- package/lib/browser/factory/oracleClient.js +9 -21
- package/lib/browser/idl/drift.d.ts +21406 -0
- package/lib/browser/idl/drift.js +2 -0
- package/lib/browser/idl/drift.json +20850 -15287
- package/lib/browser/idl/pyth.d.ts +97 -0
- package/lib/browser/idl/pyth.js +2 -0
- package/lib/browser/idl/token_faucet.d.ts +197 -0
- package/lib/browser/idl/token_faucet.js +2 -0
- package/lib/browser/idl/token_faucet.json +148 -61
- package/lib/browser/index.d.ts +13 -6
- package/lib/browser/index.js +12 -5
- package/lib/browser/marinade/index.d.ts +1 -1
- package/lib/browser/marinade/index.js +2 -2
- package/lib/browser/math/amm.d.ts +4 -5
- package/lib/browser/math/amm.js +8 -35
- package/lib/browser/math/funding.js +6 -1
- package/lib/browser/math/margin.d.ts +3 -4
- package/lib/browser/math/margin.js +16 -47
- package/lib/browser/math/market.d.ts +2 -2
- package/lib/browser/math/market.js +10 -42
- package/lib/browser/math/oracles.js +14 -19
- package/lib/browser/math/position.js +1 -1
- package/lib/browser/math/trade.js +4 -4
- package/lib/browser/memcmp.js +8 -8
- package/lib/browser/openbook/openbookV2Subscriber.d.ts +1 -1
- package/lib/browser/openbook/openbookV2Subscriber.js +3 -3
- package/lib/browser/oracles/oracleClientCache.d.ts +2 -2
- package/lib/browser/oracles/prelaunchOracleClient.d.ts +2 -2
- package/lib/browser/oracles/prelaunchOracleClient.js +1 -1
- package/lib/browser/oracles/pythLazerClient.js +3 -5
- package/lib/browser/oracles/types.d.ts +6 -0
- package/lib/browser/orderParams.d.ts +0 -1
- package/lib/browser/orderParams.js +1 -5
- package/lib/browser/orderSubscriber/OrderSubscriber.js +3 -4
- package/lib/browser/orderSubscriber/WebsocketSubscription.js +1 -1
- package/lib/browser/orderSubscriber/grpcSubscription.js +2 -2
- package/lib/browser/orderSubscriber/index.d.ts +5 -0
- package/lib/browser/orderSubscriber/index.js +5 -0
- package/lib/browser/priorityFee/index.d.ts +5 -0
- package/lib/browser/priorityFee/index.js +5 -0
- package/lib/browser/pyth/index.d.ts +2 -2
- package/lib/browser/pyth/types.d.ts +1 -1
- package/lib/browser/swift/grpcSignedMsgUserAccountSubscriber.js +1 -1
- package/lib/browser/swift/index.d.ts +7 -0
- package/lib/browser/swift/index.js +7 -0
- package/lib/browser/swift/signedMsgUserAccountSubscriber.js +4 -3
- package/lib/browser/tokenFaucet.d.ts +2 -2
- package/lib/browser/tokenFaucet.js +4 -4
- package/lib/browser/tx/txHandler.d.ts +12 -0
- package/lib/browser/tx/txHandler.js +12 -0
- package/lib/browser/types.d.ts +19 -31
- package/lib/browser/types.js +6 -11
- package/lib/browser/user.d.ts +27 -18
- package/lib/browser/user.js +64 -100
- package/lib/browser/userMap/WebsocketSubscription.js +1 -1
- package/lib/browser/userMap/grpcSubscription.js +1 -1
- package/lib/browser/userMap/revenueShareEscrowMap.js +4 -4
- package/lib/browser/userMap/userMap.js +4 -5
- package/lib/browser/userMap/userStatsMap.js +2 -3
- package/lib/browser/userStats.d.ts +5 -0
- package/lib/node/accounts/fetch.d.ts +6 -6
- package/lib/node/accounts/fetch.d.ts.map +1 -1
- package/lib/node/accounts/fetch.js +4 -4
- package/lib/node/accounts/grpcAccountSubscriber.d.ts +2 -2
- package/lib/node/accounts/grpcAccountSubscriber.d.ts.map +1 -1
- package/lib/node/accounts/grpcDriftClientAccountSubscriber.d.ts +2 -2
- package/lib/node/accounts/grpcDriftClientAccountSubscriber.d.ts.map +1 -1
- package/lib/node/accounts/grpcDriftClientAccountSubscriberV2.d.ts +3 -3
- package/lib/node/accounts/grpcDriftClientAccountSubscriberV2.d.ts.map +1 -1
- package/lib/node/accounts/grpcDriftClientAccountSubscriberV2.js +2 -2
- package/lib/node/accounts/grpcInsuranceFundStakeAccountSubscriber.d.ts +2 -2
- package/lib/node/accounts/grpcInsuranceFundStakeAccountSubscriber.d.ts.map +1 -1
- package/lib/node/accounts/grpcMultiAccountSubscriber.d.ts +2 -2
- package/lib/node/accounts/grpcMultiAccountSubscriber.d.ts.map +1 -1
- package/lib/node/accounts/grpcMultiUserAccountSubscriber.d.ts +2 -2
- package/lib/node/accounts/grpcMultiUserAccountSubscriber.d.ts.map +1 -1
- package/lib/node/accounts/grpcProgramAccountSubscriber.d.ts +2 -2
- package/lib/node/accounts/grpcProgramAccountSubscriber.d.ts.map +1 -1
- package/lib/node/accounts/grpcUserAccountSubscriber.d.ts +2 -2
- package/lib/node/accounts/grpcUserAccountSubscriber.d.ts.map +1 -1
- package/lib/node/accounts/grpcUserStatsAccountSubscriber.d.ts +2 -2
- package/lib/node/accounts/grpcUserStatsAccountSubscriber.d.ts.map +1 -1
- package/lib/node/accounts/laserProgramAccountSubscriber.d.ts +2 -2
- package/lib/node/accounts/laserProgramAccountSubscriber.d.ts.map +1 -1
- package/lib/node/accounts/oneShotUserAccountSubscriber.d.ts +3 -3
- package/lib/node/accounts/oneShotUserAccountSubscriber.d.ts.map +1 -1
- package/lib/node/accounts/oneShotUserStatsAccountSubscriber.d.ts +3 -3
- package/lib/node/accounts/oneShotUserStatsAccountSubscriber.d.ts.map +1 -1
- package/lib/node/accounts/pollingDriftClientAccountSubscriber.d.ts +3 -3
- package/lib/node/accounts/pollingDriftClientAccountSubscriber.d.ts.map +1 -1
- package/lib/node/accounts/pollingDriftClientAccountSubscriber.js +2 -2
- package/lib/node/accounts/pollingInsuranceFundStakeAccountSubscriber.d.ts +3 -3
- package/lib/node/accounts/pollingInsuranceFundStakeAccountSubscriber.d.ts.map +1 -1
- package/lib/node/accounts/pollingInsuranceFundStakeAccountSubscriber.js +1 -1
- package/lib/node/accounts/pollingOracleAccountSubscriber.d.ts +2 -2
- package/lib/node/accounts/pollingOracleAccountSubscriber.d.ts.map +1 -1
- package/lib/node/accounts/pollingTokenAccountSubscriber.d.ts +2 -2
- package/lib/node/accounts/pollingTokenAccountSubscriber.d.ts.map +1 -1
- package/lib/node/accounts/pollingUserAccountSubscriber.js +2 -2
- package/lib/node/accounts/pollingUserStatsAccountSubscriber.d.ts +3 -3
- package/lib/node/accounts/pollingUserStatsAccountSubscriber.d.ts.map +1 -1
- package/lib/node/accounts/pollingUserStatsAccountSubscriber.js +1 -1
- package/lib/node/accounts/testBulkAccountLoader.d.ts.map +1 -1
- package/lib/node/accounts/testBulkAccountLoader.js +3 -5
- package/lib/node/accounts/types.d.ts +11 -14
- package/lib/node/accounts/types.d.ts.map +1 -1
- package/lib/node/accounts/webSocketAccountSubscriber.d.ts +3 -3
- package/lib/node/accounts/webSocketAccountSubscriber.d.ts.map +1 -1
- package/lib/node/accounts/webSocketAccountSubscriber.js +1 -2
- package/lib/node/accounts/webSocketAccountSubscriberV2.d.ts +3 -3
- package/lib/node/accounts/webSocketAccountSubscriberV2.d.ts.map +1 -1
- package/lib/node/accounts/webSocketDriftClientAccountSubscriber.d.ts +5 -5
- package/lib/node/accounts/webSocketDriftClientAccountSubscriber.d.ts.map +1 -1
- package/lib/node/accounts/webSocketDriftClientAccountSubscriber.js +2 -2
- package/lib/node/accounts/webSocketDriftClientAccountSubscriberV2.d.ts +3 -3
- package/lib/node/accounts/webSocketDriftClientAccountSubscriberV2.d.ts.map +1 -1
- package/lib/node/accounts/webSocketDriftClientAccountSubscriberV2.js +2 -2
- package/lib/node/accounts/webSocketInsuranceFundStakeAccountSubscriber.d.ts +3 -3
- package/lib/node/accounts/webSocketInsuranceFundStakeAccountSubscriber.d.ts.map +1 -1
- package/lib/node/accounts/webSocketProgramAccountSubscriber.d.ts +3 -3
- package/lib/node/accounts/webSocketProgramAccountSubscriber.d.ts.map +1 -1
- package/lib/node/accounts/webSocketProgramAccountSubscriberV2.d.ts +3 -3
- package/lib/node/accounts/webSocketProgramAccountSubscriberV2.d.ts.map +1 -1
- package/lib/node/accounts/webSocketProgramAccountsSubscriberV2.d.ts +3 -3
- package/lib/node/accounts/webSocketProgramAccountsSubscriberV2.d.ts.map +1 -1
- package/lib/node/accounts/webSocketUserAccountSubscriber.d.ts +3 -3
- package/lib/node/accounts/webSocketUserAccountSubscriber.d.ts.map +1 -1
- package/lib/node/accounts/webSocketUserStatsAccountSubsriber.d.ts +3 -3
- package/lib/node/accounts/webSocketUserStatsAccountSubsriber.d.ts.map +1 -1
- package/lib/node/accounts/websocketProgramUserAccountSubscriber.d.ts +2 -2
- package/lib/node/accounts/websocketProgramUserAccountSubscriber.d.ts.map +1 -1
- package/lib/node/addresses/pda.d.ts +6 -2
- package/lib/node/addresses/pda.d.ts.map +1 -1
- package/lib/node/addresses/pda.js +7 -12
- package/lib/node/adminClient.d.ts +11 -9
- package/lib/node/adminClient.d.ts.map +1 -1
- package/lib/node/adminClient.js +30 -72
- package/lib/node/auctionSubscriber/auctionSubscriber.d.ts.map +1 -1
- package/lib/node/auctionSubscriber/auctionSubscriber.js +1 -1
- package/lib/node/auctionSubscriber/auctionSubscriberGrpc.d.ts.map +1 -1
- package/lib/node/auctionSubscriber/auctionSubscriberGrpc.js +1 -1
- package/lib/node/config.d.ts +7 -3
- package/lib/node/config.d.ts.map +1 -1
- package/lib/node/config.js +9 -7
- package/lib/node/constants/index.d.ts +5 -0
- package/lib/node/constants/index.d.ts.map +1 -1
- package/lib/node/constants/index.js +5 -0
- package/lib/node/constants/numericConstants.d.ts +1 -1
- package/lib/node/constants/numericConstants.d.ts.map +1 -1
- package/lib/node/constants/numericConstants.js +3 -3
- package/lib/node/constants/perpMarkets.d.ts.map +1 -1
- package/lib/node/constants/perpMarkets.js +3 -412
- package/lib/node/constants/spotMarkets.d.ts.map +1 -1
- package/lib/node/constants/spotMarkets.js +7 -91
- package/lib/node/constituentMap/constituentMap.d.ts.map +1 -1
- package/lib/node/constituentMap/constituentMap.js +2 -2
- package/lib/node/constituentMap/pollingConstituentAccountSubscriber.d.ts +3 -3
- package/lib/node/constituentMap/pollingConstituentAccountSubscriber.d.ts.map +1 -1
- package/lib/node/constituentMap/webSocketConstituentAccountSubscriber.d.ts +3 -3
- package/lib/node/constituentMap/webSocketConstituentAccountSubscriber.d.ts.map +1 -1
- package/lib/node/constituentMap/webSocketConstituentAccountSubscriber.js +1 -1
- package/lib/node/decode/customCoder.d.ts +7 -9
- package/lib/node/decode/customCoder.d.ts.map +1 -1
- package/lib/node/decode/customCoder.js +17 -28
- package/lib/node/decode/user.d.ts.map +1 -1
- package/lib/node/decode/user.js +7 -25
- package/lib/node/dlob/DLOB.d.ts +12 -0
- package/lib/node/dlob/DLOB.d.ts.map +1 -1
- package/lib/node/dlob/DLOB.js +12 -0
- package/lib/node/dlob/orderBookLevels.d.ts.map +1 -1
- package/lib/node/dlob/orderBookLevels.js +1 -1
- package/lib/node/driftClient.d.ts +32 -59
- package/lib/node/driftClient.d.ts.map +1 -1
- package/lib/node/driftClient.js +85 -562
- package/lib/node/driftClientConfig.d.ts +7 -0
- package/lib/node/driftClientConfig.d.ts.map +1 -1
- package/lib/node/events/eventSubscriber.d.ts +8 -0
- package/lib/node/events/eventSubscriber.d.ts.map +1 -1
- package/lib/node/events/eventSubscriber.js +5 -2
- package/lib/node/events/parse.d.ts +1 -1
- package/lib/node/events/parse.d.ts.map +1 -1
- package/lib/node/factory/oracleClient.d.ts +2 -2
- package/lib/node/factory/oracleClient.d.ts.map +1 -1
- package/lib/node/factory/oracleClient.js +9 -21
- package/lib/node/idl/drift.d.ts +21407 -0
- package/lib/node/idl/drift.d.ts.map +1 -0
- package/lib/node/idl/drift.js +2 -0
- package/lib/node/idl/drift.json +20850 -15287
- package/lib/node/idl/pyth.d.ts +98 -0
- package/lib/node/idl/pyth.d.ts.map +1 -0
- package/lib/node/idl/pyth.js +2 -0
- package/lib/node/idl/token_faucet.d.ts +198 -0
- package/lib/node/idl/token_faucet.d.ts.map +1 -0
- package/lib/node/idl/token_faucet.js +2 -0
- package/lib/node/idl/token_faucet.json +148 -61
- package/lib/node/index.d.ts +13 -6
- package/lib/node/index.d.ts.map +1 -1
- package/lib/node/index.js +12 -5
- package/lib/node/marinade/index.d.ts +1 -1
- package/lib/node/marinade/index.d.ts.map +1 -1
- package/lib/node/marinade/index.js +2 -2
- package/lib/node/math/amm.d.ts +4 -5
- package/lib/node/math/amm.d.ts.map +1 -1
- package/lib/node/math/amm.js +8 -35
- package/lib/node/math/funding.d.ts.map +1 -1
- package/lib/node/math/funding.js +6 -1
- package/lib/node/math/margin.d.ts +3 -4
- package/lib/node/math/margin.d.ts.map +1 -1
- package/lib/node/math/margin.js +16 -47
- package/lib/node/math/market.d.ts +2 -2
- package/lib/node/math/market.d.ts.map +1 -1
- package/lib/node/math/market.js +10 -42
- package/lib/node/math/oracles.d.ts.map +1 -1
- package/lib/node/math/oracles.js +14 -19
- package/lib/node/math/position.d.ts.map +1 -1
- package/lib/node/math/position.js +1 -1
- package/lib/node/math/trade.d.ts.map +1 -1
- package/lib/node/math/trade.js +4 -4
- package/lib/node/memcmp.js +8 -8
- package/lib/node/openbook/openbookV2Subscriber.d.ts +1 -1
- package/lib/node/openbook/openbookV2Subscriber.d.ts.map +1 -1
- package/lib/node/openbook/openbookV2Subscriber.js +3 -3
- package/lib/node/oracles/oracleClientCache.d.ts +2 -2
- package/lib/node/oracles/oracleClientCache.d.ts.map +1 -1
- package/lib/node/oracles/prelaunchOracleClient.d.ts +2 -2
- package/lib/node/oracles/prelaunchOracleClient.d.ts.map +1 -1
- package/lib/node/oracles/prelaunchOracleClient.js +1 -1
- package/lib/node/oracles/pythLazerClient.d.ts.map +1 -1
- package/lib/node/oracles/pythLazerClient.js +3 -5
- package/lib/node/oracles/types.d.ts +6 -0
- package/lib/node/oracles/types.d.ts.map +1 -1
- package/lib/node/orderParams.d.ts +0 -1
- package/lib/node/orderParams.d.ts.map +1 -1
- package/lib/node/orderParams.js +1 -5
- package/lib/node/orderSubscriber/OrderSubscriber.d.ts.map +1 -1
- package/lib/node/orderSubscriber/OrderSubscriber.js +3 -4
- package/lib/node/orderSubscriber/WebsocketSubscription.js +1 -1
- package/lib/node/orderSubscriber/grpcSubscription.js +2 -2
- package/lib/node/orderSubscriber/index.d.ts +5 -0
- package/lib/node/orderSubscriber/index.d.ts.map +1 -1
- package/lib/node/orderSubscriber/index.js +5 -0
- package/lib/node/priorityFee/index.d.ts +5 -0
- package/lib/node/priorityFee/index.d.ts.map +1 -1
- package/lib/node/priorityFee/index.js +5 -0
- package/lib/node/pyth/index.d.ts +2 -2
- package/lib/node/pyth/index.d.ts.map +1 -1
- package/lib/node/pyth/types.d.ts +1 -1
- package/lib/node/pyth/types.d.ts.map +1 -1
- package/lib/node/swift/grpcSignedMsgUserAccountSubscriber.js +1 -1
- package/lib/node/swift/index.d.ts +7 -0
- package/lib/node/swift/index.d.ts.map +1 -1
- package/lib/node/swift/index.js +7 -0
- package/lib/node/swift/signedMsgUserAccountSubscriber.d.ts.map +1 -1
- package/lib/node/swift/signedMsgUserAccountSubscriber.js +4 -3
- package/lib/node/tokenFaucet.d.ts +2 -2
- package/lib/node/tokenFaucet.d.ts.map +1 -1
- package/lib/node/tokenFaucet.js +4 -4
- package/lib/node/tx/txHandler.d.ts +12 -0
- package/lib/node/tx/txHandler.d.ts.map +1 -1
- package/lib/node/tx/txHandler.js +12 -0
- package/lib/node/types.d.ts +19 -31
- package/lib/node/types.d.ts.map +1 -1
- package/lib/node/types.js +6 -11
- package/lib/node/user.d.ts +27 -18
- package/lib/node/user.d.ts.map +1 -1
- package/lib/node/user.js +64 -100
- package/lib/node/userMap/WebsocketSubscription.js +1 -1
- package/lib/node/userMap/grpcSubscription.js +1 -1
- package/lib/node/userMap/revenueShareEscrowMap.d.ts.map +1 -1
- package/lib/node/userMap/revenueShareEscrowMap.js +4 -4
- package/lib/node/userMap/userMap.d.ts.map +1 -1
- package/lib/node/userMap/userMap.js +4 -5
- package/lib/node/userMap/userStatsMap.d.ts.map +1 -1
- package/lib/node/userMap/userStatsMap.js +2 -3
- package/lib/node/userStats.d.ts +5 -0
- package/lib/node/userStats.d.ts.map +1 -1
- package/package.json +5 -7
- package/src/accounts/fetch.ts +18 -17
- package/src/accounts/grpcAccountSubscriber.ts +3 -3
- package/src/accounts/grpcDriftClientAccountSubscriber.ts +2 -3
- package/src/accounts/grpcDriftClientAccountSubscriberV2.ts +5 -6
- package/src/accounts/grpcInsuranceFundStakeAccountSubscriber.ts +2 -2
- package/src/accounts/grpcMultiAccountSubscriber.ts +4 -4
- package/src/accounts/grpcMultiUserAccountSubscriber.ts +4 -4
- package/src/accounts/grpcProgramAccountSubscriber.ts +3 -3
- package/src/accounts/grpcUserAccountSubscriber.ts +2 -2
- package/src/accounts/grpcUserStatsAccountSubscriber.ts +2 -2
- package/src/accounts/laserProgramAccountSubscriber.ts +3 -3
- package/src/accounts/oneShotUserAccountSubscriber.ts +6 -7
- package/src/accounts/oneShotUserStatsAccountSubscriber.ts +10 -9
- package/src/accounts/pollingDriftClientAccountSubscriber.ts +12 -11
- package/src/accounts/pollingInsuranceFundStakeAccountSubscriber.ts +11 -10
- package/src/accounts/pollingOracleAccountSubscriber.ts +2 -2
- package/src/accounts/pollingTokenAccountSubscriber.ts +2 -2
- package/src/accounts/pollingUserAccountSubscriber.ts +2 -2
- package/src/accounts/pollingUserStatsAccountSubscriber.ts +14 -14
- package/src/accounts/testBulkAccountLoader.ts +3 -5
- package/src/accounts/types.ts +10 -25
- package/src/accounts/webSocketAccountSubscriber.ts +5 -5
- package/src/accounts/webSocketAccountSubscriberV2.ts +4 -3
- package/src/accounts/webSocketDriftClientAccountSubscriber.ts +9 -10
- package/src/accounts/webSocketDriftClientAccountSubscriberV2.ts +13 -10
- package/src/accounts/webSocketInsuranceFundStakeAccountSubscriber.ts +3 -3
- package/src/accounts/webSocketProgramAccountSubscriber.ts +4 -3
- package/src/accounts/webSocketProgramAccountSubscriberV2.ts +4 -3
- package/src/accounts/webSocketProgramAccountsSubscriberV2.ts +4 -3
- package/src/accounts/webSocketUserAccountSubscriber.ts +3 -3
- package/src/accounts/webSocketUserStatsAccountSubsriber.ts +3 -3
- package/src/accounts/websocketProgramUserAccountSubscriber.ts +4 -4
- package/src/addresses/pda.ts +6 -22
- package/src/adminClient.ts +154 -239
- package/src/auctionSubscriber/auctionSubscriber.ts +5 -3
- package/src/auctionSubscriber/auctionSubscriberGrpc.ts +5 -3
- package/src/config.ts +24 -16
- package/src/constants/index.ts +5 -0
- package/src/constants/numericConstants.ts +2 -3
- package/src/constants/perpMarkets.ts +3 -445
- package/src/constants/spotMarkets.ts +7 -102
- package/src/constituentMap/constituentMap.ts +5 -6
- package/src/constituentMap/pollingConstituentAccountSubscriber.ts +3 -3
- package/src/constituentMap/webSocketConstituentAccountSubscriber.ts +6 -6
- package/src/decode/customCoder.ts +26 -35
- package/src/decode/user.ts +7 -25
- package/src/dlob/DLOB.ts +12 -0
- package/src/dlob/orderBookLevels.ts +0 -1
- package/src/driftClient.ts +245 -1091
- package/src/driftClientConfig.ts +7 -0
- package/src/events/eventSubscriber.ts +14 -2
- package/src/events/parse.ts +2 -2
- package/src/factory/oracleClient.ts +17 -28
- package/src/idl/drift.json +20850 -15287
- package/src/idl/drift.ts +21406 -0
- package/src/idl/pyth.ts +97 -0
- package/src/idl/token_faucet.json +148 -61
- package/src/idl/token_faucet.ts +197 -0
- package/src/index.ts +13 -12
- package/src/margin/README.md +0 -1
- package/src/marinade/index.ts +2 -2
- package/src/math/amm.ts +2 -48
- package/src/math/funding.ts +8 -3
- package/src/math/margin.ts +12 -67
- package/src/math/market.ts +15 -69
- package/src/math/oracles.ts +14 -30
- package/src/math/position.ts +0 -1
- package/src/math/trade.ts +0 -4
- package/src/memcmp.ts +1 -1
- package/src/openbook/openbookV2Subscriber.ts +1 -1
- package/src/oracles/oracleClientCache.ts +2 -2
- package/src/oracles/prelaunchOracleClient.ts +9 -8
- package/src/oracles/pythLazerClient.ts +10 -12
- package/src/oracles/types.ts +6 -0
- package/src/orderParams.ts +0 -5
- package/src/orderSubscriber/OrderSubscriber.ts +7 -6
- package/src/orderSubscriber/WebsocketSubscription.ts +1 -1
- package/src/orderSubscriber/grpcSubscription.ts +2 -2
- package/src/orderSubscriber/index.ts +5 -0
- package/src/priorityFee/index.ts +5 -0
- package/src/pyth/index.ts +4 -4
- package/src/pyth/types.ts +1 -1
- package/src/swift/grpcSignedMsgUserAccountSubscriber.ts +1 -1
- package/src/swift/index.ts +7 -0
- package/src/swift/signedMsgUserAccountSubscriber.ts +7 -4
- package/src/tokenFaucet.ts +8 -4
- package/src/tx/txHandler.ts +12 -0
- package/src/types.ts +16 -20
- package/src/user.ts +66 -144
- package/src/userMap/WebsocketSubscription.ts +1 -1
- package/src/userMap/grpcSubscription.ts +1 -1
- package/src/userMap/revenueShareEscrowMap.ts +24 -20
- package/src/userMap/userMap.ts +8 -7
- package/src/userMap/userStatsMap.ts +6 -5
- package/src/userStats.ts +5 -0
- package/tests/accounts/customizedCadenceBulkAccountLoader.test.ts +5 -4
- package/tests/amm/test.ts +45 -64
- package/tests/ci/verifyConstants.ts +23 -26
- package/tests/decode/test.ts +2 -4
- package/tests/dlob/helpers.ts +8 -15
- package/tests/user/helpers.ts +0 -2
- package/tests/user/marginCalculations.test.ts +2 -3
- package/tests/user/test.ts +18 -15
- package/lib/browser/accounts/pollingHighLeverageModeConfigAccountSubscriber.d.ts +0 -29
- package/lib/browser/accounts/pollingHighLeverageModeConfigAccountSubscriber.js +0 -111
- package/lib/browser/accounts/webSocketHighLeverageModeConfigAccountSubscriber.d.ts +0 -23
- package/lib/browser/accounts/webSocketHighLeverageModeConfigAccountSubscriber.js +0 -69
- package/lib/browser/idl/pyth_solana_receiver.json +0 -628
- package/lib/browser/idl/switchboard.json +0 -8354
- package/lib/browser/idl/switchboard_on_demand_30.json +0 -5849
- package/lib/browser/oracles/pythPullClient.d.ts +0 -19
- package/lib/browser/oracles/pythPullClient.js +0 -65
- package/lib/browser/oracles/switchboardClient.d.ts +0 -12
- package/lib/browser/oracles/switchboardClient.js +0 -40
- package/lib/browser/oracles/switchboardOnDemandClient.d.ts +0 -12
- package/lib/browser/oracles/switchboardOnDemandClient.js +0 -33
- package/lib/browser/util/pythOracleUtils.d.ts +0 -2
- package/lib/browser/util/pythOracleUtils.js +0 -15
- package/lib/node/accounts/pollingHighLeverageModeConfigAccountSubscriber.d.ts +0 -30
- package/lib/node/accounts/pollingHighLeverageModeConfigAccountSubscriber.d.ts.map +0 -1
- package/lib/node/accounts/pollingHighLeverageModeConfigAccountSubscriber.js +0 -111
- package/lib/node/accounts/webSocketHighLeverageModeConfigAccountSubscriber.d.ts +0 -24
- package/lib/node/accounts/webSocketHighLeverageModeConfigAccountSubscriber.d.ts.map +0 -1
- package/lib/node/accounts/webSocketHighLeverageModeConfigAccountSubscriber.js +0 -69
- package/lib/node/idl/pyth_solana_receiver.json +0 -628
- package/lib/node/idl/switchboard.json +0 -8354
- package/lib/node/idl/switchboard_on_demand_30.json +0 -5849
- package/lib/node/oracles/pythPullClient.d.ts +0 -20
- package/lib/node/oracles/pythPullClient.d.ts.map +0 -1
- package/lib/node/oracles/pythPullClient.js +0 -65
- package/lib/node/oracles/switchboardClient.d.ts +0 -13
- package/lib/node/oracles/switchboardClient.d.ts.map +0 -1
- package/lib/node/oracles/switchboardClient.js +0 -40
- package/lib/node/oracles/switchboardOnDemandClient.d.ts +0 -13
- package/lib/node/oracles/switchboardOnDemandClient.d.ts.map +0 -1
- package/lib/node/oracles/switchboardOnDemandClient.js +0 -33
- package/lib/node/util/pythOracleUtils.d.ts +0 -3
- package/lib/node/util/pythOracleUtils.d.ts.map +0 -1
- package/lib/node/util/pythOracleUtils.js +0 -15
- package/src/accounts/pollingHighLeverageModeConfigAccountSubscriber.ts +0 -189
- package/src/accounts/webSocketHighLeverageModeConfigAccountSubscriber.ts +0 -131
- package/src/idl/switchboard.json +0 -8354
- package/src/idl/switchboard_on_demand_30.json +0 -5849
- package/src/oracles/pythPullClient.ts +0 -112
- package/src/oracles/switchboardClient.ts +0 -77
- package/src/oracles/switchboardOnDemandClient.ts +0 -64
- package/src/util/pythOracleUtils.ts +0 -11
|
@@ -227,8 +227,8 @@ describe('User margin calculations', () => {
|
|
|
227
227
|
DEFAULT_ORACLES
|
|
228
228
|
);
|
|
229
229
|
|
|
230
|
-
assert(mockUser.getFreeCollateral('Initial',
|
|
231
|
-
assert(mockUser.getFreeCollateral('Initial',
|
|
230
|
+
assert(mockUser.getFreeCollateral('Initial', 0).gt(ZERO));
|
|
231
|
+
assert(mockUser.getFreeCollateral('Initial', 5).eq(ZERO));
|
|
232
232
|
});
|
|
233
233
|
});
|
|
234
234
|
|
|
@@ -312,7 +312,6 @@ describe('User margin calculations', () => {
|
|
|
312
312
|
'Maintenance',
|
|
313
313
|
false,
|
|
314
314
|
ZERO,
|
|
315
|
-
false,
|
|
316
315
|
'Isolated'
|
|
317
316
|
);
|
|
318
317
|
assert(liqPrice.gte(ZERO));
|
package/tests/user/test.ts
CHANGED
|
@@ -8,6 +8,7 @@ import {
|
|
|
8
8
|
SpotMarketAccount,
|
|
9
9
|
PRICE_PRECISION,
|
|
10
10
|
OraclePriceData,
|
|
11
|
+
MMOraclePriceData,
|
|
11
12
|
BASE_PRECISION,
|
|
12
13
|
QUOTE_PRECISION,
|
|
13
14
|
calculatePositionPNL,
|
|
@@ -96,12 +97,21 @@ async function makeMockUser(
|
|
|
96
97
|
return getMockOracle(oracle).data;
|
|
97
98
|
}
|
|
98
99
|
|
|
100
|
+
function getMMOracleDataForPerpMarket(
|
|
101
|
+
marketIndex: number
|
|
102
|
+
): MMOraclePriceData {
|
|
103
|
+
const oracle = getMockPerpMarket(marketIndex).amm.oracle;
|
|
104
|
+
return getMockOracle(oracle).data as unknown as MMOraclePriceData;
|
|
105
|
+
}
|
|
106
|
+
|
|
99
107
|
mockUser.getUserAccount = getMockUserAccount;
|
|
100
108
|
mockUser.driftClient.getPerpMarketAccount = getMockPerpMarket;
|
|
101
109
|
mockUser.driftClient.getSpotMarketAccount = getMockSpotMarket;
|
|
102
110
|
mockUser.driftClient.getOraclePriceDataAndSlot = getMockOracle;
|
|
103
111
|
mockUser.driftClient.getOracleDataForPerpMarket = getOracleDataForPerpMarket;
|
|
104
112
|
mockUser.driftClient.getOracleDataForSpotMarket = getOracleDataForSpotMarket;
|
|
113
|
+
mockUser.driftClient.getMMOracleDataForPerpMarket =
|
|
114
|
+
getMMOracleDataForPerpMarket;
|
|
105
115
|
return mockUser;
|
|
106
116
|
}
|
|
107
117
|
|
|
@@ -306,10 +316,10 @@ describe('User Tests', () => {
|
|
|
306
316
|
'getMaxLeverageForPerp:',
|
|
307
317
|
mockUser.getMaxLeverageForPerp(0).toString()
|
|
308
318
|
);
|
|
309
|
-
assert(mockUser.getMaxLeverageForPerp(0).eq(new BN('
|
|
319
|
+
assert(mockUser.getMaxLeverageForPerp(0).eq(new BN('37358'))); // ~3.7x
|
|
310
320
|
assert(
|
|
311
|
-
mockUser.getMaxLeverageForPerp(0, 'Maintenance').eq(new BN('
|
|
312
|
-
); //
|
|
321
|
+
mockUser.getMaxLeverageForPerp(0, 'Maintenance').eq(new BN('37358'))
|
|
322
|
+
); // same (marginCategory unused)
|
|
313
323
|
});
|
|
314
324
|
|
|
315
325
|
it('worst case token amount', async () => {
|
|
@@ -499,10 +509,7 @@ describe('User Tests', () => {
|
|
|
499
509
|
const strictOraclePrice = new StrictOraclePrice(PRICE_PRECISION.muln(25));
|
|
500
510
|
const tokenAmount = new BN(100).mul(LAMPORTS_PRECISION);
|
|
501
511
|
|
|
502
|
-
for (const ratio of [
|
|
503
|
-
MARGIN_PRECISION.toNumber() * 2,
|
|
504
|
-
89478485,
|
|
505
|
-
]) {
|
|
512
|
+
for (const ratio of [MARGIN_PRECISION.toNumber() * 2, 89478485]) {
|
|
506
513
|
const assetValue = getSpotAssetValue(
|
|
507
514
|
tokenAmount,
|
|
508
515
|
strictOraclePrice,
|
|
@@ -551,7 +558,7 @@ describe('User Tests', () => {
|
|
|
551
558
|
let mLev = mockUser.getMaxLeverageForPerp(0, 'Maintenance').toNumber();
|
|
552
559
|
console.log(iLev, mLev);
|
|
553
560
|
assert(iLev == 5000);
|
|
554
|
-
assert(mLev ==
|
|
561
|
+
assert(mLev == 5000);
|
|
555
562
|
|
|
556
563
|
myMockUserAccount.maxMarginRatio = MARGIN_PRECISION.div(
|
|
557
564
|
new BN(2)
|
|
@@ -569,7 +576,7 @@ describe('User Tests', () => {
|
|
|
569
576
|
console.log(iLev, mLev);
|
|
570
577
|
|
|
571
578
|
assert(iLev == 2000);
|
|
572
|
-
assert(mLev ==
|
|
579
|
+
assert(mLev == 2000);
|
|
573
580
|
});
|
|
574
581
|
|
|
575
582
|
it('getTotalIsolatedPositionDeposits sums isolated USDC deposits', async () => {
|
|
@@ -727,8 +734,7 @@ describe('User Tests', () => {
|
|
|
727
734
|
myMockUserAccount.perpPositions[0].marketIndex = 0;
|
|
728
735
|
myMockUserAccount.perpPositions[0].baseAssetAmount = BASE_PRECISION;
|
|
729
736
|
myMockUserAccount.perpPositions[0].quoteAssetAmount = QUOTE_PRECISION.neg();
|
|
730
|
-
myMockUserAccount.perpPositions[0].quoteEntryAmount =
|
|
731
|
-
QUOTE_PRECISION.neg();
|
|
737
|
+
myMockUserAccount.perpPositions[0].quoteEntryAmount = QUOTE_PRECISION.neg();
|
|
732
738
|
myMockUserAccount.perpPositions[0].quoteBreakEvenAmount =
|
|
733
739
|
QUOTE_PRECISION.neg();
|
|
734
740
|
myMockUserAccount.perpPositions[0].isolatedPositionScaledBalance = new BN(
|
|
@@ -813,10 +819,7 @@ describe('User Tests', () => {
|
|
|
813
819
|
[1, 1, 1, 1, 1, 1, 1, 1]
|
|
814
820
|
);
|
|
815
821
|
|
|
816
|
-
const { spotAssetValue } = mockUser.getLeverageComponents(
|
|
817
|
-
true,
|
|
818
|
-
'Initial'
|
|
819
|
-
);
|
|
822
|
+
const { spotAssetValue } = mockUser.getLeverageComponents(true, 'Initial');
|
|
820
823
|
// Cross spot asset only: 200 USDC. Isolated collateral is handled separately.
|
|
821
824
|
assert(spotAssetValue.eq(new BN(200).mul(QUOTE_PRECISION)));
|
|
822
825
|
});
|
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
/// <reference types="node" />
|
|
2
|
-
import { DataAndSlot, HighLeverageModeConfigAccountEvents, HighLeverageModeConfigAccountSubscriber } from './types';
|
|
3
|
-
import { Program } from '@coral-xyz/anchor';
|
|
4
|
-
import StrictEventEmitter from 'strict-event-emitter-types';
|
|
5
|
-
import { EventEmitter } from 'events';
|
|
6
|
-
import { PublicKey } from '@solana/web3.js';
|
|
7
|
-
import { BulkAccountLoader } from './bulkAccountLoader';
|
|
8
|
-
import { HighLeverageModeConfig } from '../types';
|
|
9
|
-
export declare class PollingHighLeverageModeConfigAccountSubscriber implements HighLeverageModeConfigAccountSubscriber {
|
|
10
|
-
isSubscribed: boolean;
|
|
11
|
-
program: Program;
|
|
12
|
-
eventEmitter: StrictEventEmitter<EventEmitter, HighLeverageModeConfigAccountEvents>;
|
|
13
|
-
highLeverageModeConfigAccountPublicKey: PublicKey;
|
|
14
|
-
accountLoader: BulkAccountLoader;
|
|
15
|
-
callbackId?: string;
|
|
16
|
-
errorCallbackId?: string;
|
|
17
|
-
highLeverageModeConfigAccountAndSlot?: DataAndSlot<HighLeverageModeConfig>;
|
|
18
|
-
constructor(program: Program, publicKey: PublicKey, accountLoader: BulkAccountLoader);
|
|
19
|
-
subscribe(highLeverageModeConfig?: HighLeverageModeConfig): Promise<boolean>;
|
|
20
|
-
addToAccountLoader(): Promise<void>;
|
|
21
|
-
fetchIfUnloaded(): Promise<void>;
|
|
22
|
-
fetch(): Promise<void>;
|
|
23
|
-
doesAccountExist(): boolean;
|
|
24
|
-
unsubscribe(): Promise<void>;
|
|
25
|
-
assertIsSubscribed(): void;
|
|
26
|
-
getHighLeverageModeConfigAccountAndSlot(): DataAndSlot<HighLeverageModeConfig>;
|
|
27
|
-
didSubscriptionSucceed(): boolean;
|
|
28
|
-
updateData(highLeverageModeConfig: HighLeverageModeConfig, slot: number): void;
|
|
29
|
-
}
|
|
@@ -1,111 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.PollingHighLeverageModeConfigAccountSubscriber = void 0;
|
|
4
|
-
const types_1 = require("./types");
|
|
5
|
-
const events_1 = require("events");
|
|
6
|
-
class PollingHighLeverageModeConfigAccountSubscriber {
|
|
7
|
-
constructor(program, publicKey, accountLoader) {
|
|
8
|
-
this.isSubscribed = false;
|
|
9
|
-
this.program = program;
|
|
10
|
-
this.highLeverageModeConfigAccountPublicKey = publicKey;
|
|
11
|
-
this.accountLoader = accountLoader;
|
|
12
|
-
this.eventEmitter = new events_1.EventEmitter();
|
|
13
|
-
}
|
|
14
|
-
async subscribe(highLeverageModeConfig) {
|
|
15
|
-
if (this.isSubscribed) {
|
|
16
|
-
return true;
|
|
17
|
-
}
|
|
18
|
-
if (highLeverageModeConfig) {
|
|
19
|
-
this.highLeverageModeConfigAccountAndSlot = {
|
|
20
|
-
data: highLeverageModeConfig,
|
|
21
|
-
slot: undefined,
|
|
22
|
-
};
|
|
23
|
-
}
|
|
24
|
-
await this.addToAccountLoader();
|
|
25
|
-
await this.fetchIfUnloaded();
|
|
26
|
-
if (this.doesAccountExist()) {
|
|
27
|
-
this.eventEmitter.emit('update');
|
|
28
|
-
}
|
|
29
|
-
this.isSubscribed = true;
|
|
30
|
-
return true;
|
|
31
|
-
}
|
|
32
|
-
async addToAccountLoader() {
|
|
33
|
-
if (this.callbackId) {
|
|
34
|
-
return;
|
|
35
|
-
}
|
|
36
|
-
this.callbackId = await this.accountLoader.addAccount(this.highLeverageModeConfigAccountPublicKey, (buffer, slot) => {
|
|
37
|
-
if (!buffer) {
|
|
38
|
-
return;
|
|
39
|
-
}
|
|
40
|
-
if (this.highLeverageModeConfigAccountAndSlot &&
|
|
41
|
-
this.highLeverageModeConfigAccountAndSlot.slot > slot) {
|
|
42
|
-
return;
|
|
43
|
-
}
|
|
44
|
-
const account = this.program.account.user.coder.accounts.decode('HighLeverageModeConfig', buffer);
|
|
45
|
-
this.highLeverageModeConfigAccountAndSlot = { data: account, slot };
|
|
46
|
-
this.eventEmitter.emit('highLeverageModeConfigAccountUpdate', account);
|
|
47
|
-
this.eventEmitter.emit('update');
|
|
48
|
-
});
|
|
49
|
-
this.errorCallbackId = this.accountLoader.addErrorCallbacks((error) => {
|
|
50
|
-
this.eventEmitter.emit('error', error);
|
|
51
|
-
});
|
|
52
|
-
}
|
|
53
|
-
async fetchIfUnloaded() {
|
|
54
|
-
if (this.highLeverageModeConfigAccountAndSlot === undefined) {
|
|
55
|
-
await this.fetch();
|
|
56
|
-
}
|
|
57
|
-
}
|
|
58
|
-
async fetch() {
|
|
59
|
-
var _a, _b;
|
|
60
|
-
try {
|
|
61
|
-
const dataAndContext = await this.program.account.highLeverageModeConfig.fetchAndContext(this.highLeverageModeConfigAccountPublicKey, this.accountLoader.commitment);
|
|
62
|
-
if (dataAndContext.context.slot >
|
|
63
|
-
((_b = (_a = this.highLeverageModeConfigAccountAndSlot) === null || _a === void 0 ? void 0 : _a.slot) !== null && _b !== void 0 ? _b : 0)) {
|
|
64
|
-
this.highLeverageModeConfigAccountAndSlot = {
|
|
65
|
-
data: dataAndContext.data,
|
|
66
|
-
slot: dataAndContext.context.slot,
|
|
67
|
-
};
|
|
68
|
-
}
|
|
69
|
-
}
|
|
70
|
-
catch (e) {
|
|
71
|
-
console.log(`PollingHighLeverageModeConfigAccountSubscriber.fetch() HighLeverageModeConfig does not exist: ${e.message}`);
|
|
72
|
-
}
|
|
73
|
-
}
|
|
74
|
-
doesAccountExist() {
|
|
75
|
-
return this.highLeverageModeConfigAccountAndSlot !== undefined;
|
|
76
|
-
}
|
|
77
|
-
async unsubscribe() {
|
|
78
|
-
if (!this.isSubscribed) {
|
|
79
|
-
return;
|
|
80
|
-
}
|
|
81
|
-
this.accountLoader.removeAccount(this.highLeverageModeConfigAccountPublicKey, this.callbackId);
|
|
82
|
-
this.callbackId = undefined;
|
|
83
|
-
this.accountLoader.removeErrorCallbacks(this.errorCallbackId);
|
|
84
|
-
this.errorCallbackId = undefined;
|
|
85
|
-
this.isSubscribed = false;
|
|
86
|
-
}
|
|
87
|
-
assertIsSubscribed() {
|
|
88
|
-
if (!this.isSubscribed) {
|
|
89
|
-
throw new types_1.NotSubscribedError('You must call `subscribe` before using this function');
|
|
90
|
-
}
|
|
91
|
-
}
|
|
92
|
-
getHighLeverageModeConfigAccountAndSlot() {
|
|
93
|
-
this.assertIsSubscribed();
|
|
94
|
-
return this.highLeverageModeConfigAccountAndSlot;
|
|
95
|
-
}
|
|
96
|
-
didSubscriptionSucceed() {
|
|
97
|
-
return !!this.highLeverageModeConfigAccountAndSlot;
|
|
98
|
-
}
|
|
99
|
-
updateData(highLeverageModeConfig, slot) {
|
|
100
|
-
if (!this.highLeverageModeConfigAccountAndSlot ||
|
|
101
|
-
this.highLeverageModeConfigAccountAndSlot.slot < slot) {
|
|
102
|
-
this.highLeverageModeConfigAccountAndSlot = {
|
|
103
|
-
data: highLeverageModeConfig,
|
|
104
|
-
slot,
|
|
105
|
-
};
|
|
106
|
-
this.eventEmitter.emit('highLeverageModeConfigAccountUpdate', highLeverageModeConfig);
|
|
107
|
-
this.eventEmitter.emit('update');
|
|
108
|
-
}
|
|
109
|
-
}
|
|
110
|
-
}
|
|
111
|
-
exports.PollingHighLeverageModeConfigAccountSubscriber = PollingHighLeverageModeConfigAccountSubscriber;
|
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
/// <reference types="node" />
|
|
2
|
-
import { DataAndSlot, AccountSubscriber, HighLeverageModeConfigAccountEvents, HighLeverageModeConfigAccountSubscriber } from './types';
|
|
3
|
-
import { Program } from '@coral-xyz/anchor';
|
|
4
|
-
import StrictEventEmitter from 'strict-event-emitter-types';
|
|
5
|
-
import { EventEmitter } from 'events';
|
|
6
|
-
import { Commitment, PublicKey } from '@solana/web3.js';
|
|
7
|
-
import { HighLeverageModeConfig } from '../types';
|
|
8
|
-
export declare class WebSocketHighLeverageModeConfigAccountSubscriber implements HighLeverageModeConfigAccountSubscriber {
|
|
9
|
-
isSubscribed: boolean;
|
|
10
|
-
resubTimeoutMs?: number;
|
|
11
|
-
commitment?: Commitment;
|
|
12
|
-
program: Program;
|
|
13
|
-
eventEmitter: StrictEventEmitter<EventEmitter, HighLeverageModeConfigAccountEvents>;
|
|
14
|
-
highLeverageModeConfigAccountPublicKey: PublicKey;
|
|
15
|
-
highLeverageModeConfigDataAccountSubscriber: AccountSubscriber<HighLeverageModeConfig>;
|
|
16
|
-
constructor(program: Program, highLeverageModeConfigAccountPublicKey: PublicKey, resubTimeoutMs?: number, commitment?: Commitment);
|
|
17
|
-
subscribe(highLeverageModeConfigAccount?: HighLeverageModeConfig): Promise<boolean>;
|
|
18
|
-
fetch(): Promise<void>;
|
|
19
|
-
unsubscribe(): Promise<void>;
|
|
20
|
-
assertIsSubscribed(): void;
|
|
21
|
-
getHighLeverageModeConfigAccountAndSlot(): DataAndSlot<HighLeverageModeConfig>;
|
|
22
|
-
updateData(highLeverageModeConfig: HighLeverageModeConfig, slot: number): void;
|
|
23
|
-
}
|
|
@@ -1,69 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.WebSocketHighLeverageModeConfigAccountSubscriber = void 0;
|
|
4
|
-
const types_1 = require("./types");
|
|
5
|
-
const events_1 = require("events");
|
|
6
|
-
const webSocketAccountSubscriber_1 = require("./webSocketAccountSubscriber");
|
|
7
|
-
class WebSocketHighLeverageModeConfigAccountSubscriber {
|
|
8
|
-
constructor(program, highLeverageModeConfigAccountPublicKey, resubTimeoutMs, commitment) {
|
|
9
|
-
this.isSubscribed = false;
|
|
10
|
-
this.program = program;
|
|
11
|
-
this.highLeverageModeConfigAccountPublicKey =
|
|
12
|
-
highLeverageModeConfigAccountPublicKey;
|
|
13
|
-
this.eventEmitter = new events_1.EventEmitter();
|
|
14
|
-
this.resubTimeoutMs = resubTimeoutMs;
|
|
15
|
-
this.commitment = commitment;
|
|
16
|
-
}
|
|
17
|
-
async subscribe(highLeverageModeConfigAccount) {
|
|
18
|
-
if (this.isSubscribed) {
|
|
19
|
-
return true;
|
|
20
|
-
}
|
|
21
|
-
this.highLeverageModeConfigDataAccountSubscriber =
|
|
22
|
-
new webSocketAccountSubscriber_1.WebSocketAccountSubscriber('highLeverageModeConfig', this.program, this.highLeverageModeConfigAccountPublicKey, undefined, {
|
|
23
|
-
resubTimeoutMs: this.resubTimeoutMs,
|
|
24
|
-
}, this.commitment);
|
|
25
|
-
if (highLeverageModeConfigAccount) {
|
|
26
|
-
this.highLeverageModeConfigDataAccountSubscriber.setData(highLeverageModeConfigAccount);
|
|
27
|
-
}
|
|
28
|
-
await this.highLeverageModeConfigDataAccountSubscriber.subscribe((data) => {
|
|
29
|
-
this.eventEmitter.emit('highLeverageModeConfigAccountUpdate', data);
|
|
30
|
-
this.eventEmitter.emit('update');
|
|
31
|
-
});
|
|
32
|
-
this.eventEmitter.emit('update');
|
|
33
|
-
this.isSubscribed = true;
|
|
34
|
-
return true;
|
|
35
|
-
}
|
|
36
|
-
async fetch() {
|
|
37
|
-
await Promise.all([
|
|
38
|
-
this.highLeverageModeConfigDataAccountSubscriber.fetch(),
|
|
39
|
-
]);
|
|
40
|
-
}
|
|
41
|
-
async unsubscribe() {
|
|
42
|
-
if (!this.isSubscribed) {
|
|
43
|
-
return;
|
|
44
|
-
}
|
|
45
|
-
await Promise.all([
|
|
46
|
-
this.highLeverageModeConfigDataAccountSubscriber.unsubscribe(),
|
|
47
|
-
]);
|
|
48
|
-
this.isSubscribed = false;
|
|
49
|
-
}
|
|
50
|
-
assertIsSubscribed() {
|
|
51
|
-
if (!this.isSubscribed) {
|
|
52
|
-
throw new types_1.NotSubscribedError('You must call `subscribe` before using this function');
|
|
53
|
-
}
|
|
54
|
-
}
|
|
55
|
-
getHighLeverageModeConfigAccountAndSlot() {
|
|
56
|
-
this.assertIsSubscribed();
|
|
57
|
-
return this.highLeverageModeConfigDataAccountSubscriber.dataAndSlot;
|
|
58
|
-
}
|
|
59
|
-
updateData(highLeverageModeConfig, slot) {
|
|
60
|
-
var _a;
|
|
61
|
-
const currentDataSlot = ((_a = this.highLeverageModeConfigDataAccountSubscriber.dataAndSlot) === null || _a === void 0 ? void 0 : _a.slot) || 0;
|
|
62
|
-
if (currentDataSlot <= slot) {
|
|
63
|
-
this.highLeverageModeConfigDataAccountSubscriber.setData(highLeverageModeConfig, slot);
|
|
64
|
-
this.eventEmitter.emit('highLeverageModeConfigAccountUpdate', highLeverageModeConfig);
|
|
65
|
-
this.eventEmitter.emit('update');
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
}
|
|
69
|
-
exports.WebSocketHighLeverageModeConfigAccountSubscriber = WebSocketHighLeverageModeConfigAccountSubscriber;
|