@drift-labs/sdk 2.97.0-beta.22 → 2.97.0-beta.23

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.
Files changed (735) hide show
  1. package/VERSION +1 -1
  2. package/bun.lockb +0 -0
  3. package/lib/{accounts → browser/accounts}/bulkAccountLoader.d.ts +1 -0
  4. package/lib/browser/accounts/grpcAccountSubscriber.d.ts +16 -0
  5. package/lib/browser/accounts/grpcAccountSubscriber.js +154 -0
  6. package/lib/browser/accounts/grpcDriftClientAccountSubscriber.d.ts +12 -0
  7. package/lib/browser/accounts/grpcDriftClientAccountSubscriber.js +97 -0
  8. package/lib/browser/accounts/grpcInsuranceFundStakeAccountSubscriber.d.ts +10 -0
  9. package/lib/browser/accounts/grpcInsuranceFundStakeAccountSubscriber.js +30 -0
  10. package/lib/browser/accounts/grpcProgramAccountSubscriber.d.ts +18 -0
  11. package/lib/browser/accounts/grpcProgramAccountSubscriber.js +171 -0
  12. package/lib/browser/accounts/grpcUserAccountSubscriber.d.ts +10 -0
  13. package/lib/browser/accounts/grpcUserAccountSubscriber.js +28 -0
  14. package/lib/browser/accounts/grpcUserStatsAccountSubscriber.d.ts +10 -0
  15. package/lib/browser/accounts/grpcUserStatsAccountSubscriber.js +28 -0
  16. package/lib/{accounts → browser/accounts}/types.d.ts +8 -0
  17. package/lib/{accounts → browser/accounts}/webSocketAccountSubscriber.d.ts +2 -1
  18. package/lib/{accounts → browser/accounts}/webSocketDriftClientAccountSubscriber.d.ts +3 -3
  19. package/lib/{accounts → browser/accounts}/webSocketProgramAccountSubscriber.d.ts +2 -1
  20. package/lib/browser/auctionSubscriber/auctionSubscriberGrpc.d.ts +15 -0
  21. package/lib/browser/auctionSubscriber/auctionSubscriberGrpc.js +32 -0
  22. package/lib/{auctionSubscriber → browser/auctionSubscriber}/index.d.ts +1 -0
  23. package/lib/browser/auctionSubscriber/index.js +19 -0
  24. package/lib/{auctionSubscriber → browser/auctionSubscriber}/types.d.ts +2 -0
  25. package/lib/{bankrun → browser/bankrun}/bankrunConnection.d.ts +1 -0
  26. package/lib/{decode → browser/decode}/phoenix.d.ts +1 -0
  27. package/lib/{decode → browser/decode}/user.d.ts +1 -0
  28. package/lib/{dlob → browser/dlob}/DLOBOrders.d.ts +1 -0
  29. package/lib/{driftClient.d.ts → browser/driftClient.d.ts} +1 -0
  30. package/lib/{driftClient.js → browser/driftClient.js} +36 -15
  31. package/lib/{driftClientConfig.d.ts → browser/driftClientConfig.d.ts} +6 -1
  32. package/lib/browser/isomorphic/grpc.browser.d.ts +1 -0
  33. package/lib/browser/isomorphic/grpc.browser.js +8 -0
  34. package/lib/browser/isomorphic/grpc.d.ts +1 -0
  35. package/lib/browser/isomorphic/grpc.js +8 -0
  36. package/lib/browser/isomorphic/grpc.node.d.ts +5 -0
  37. package/lib/{math → browser/math}/oracles.d.ts +1 -0
  38. package/lib/{oracles → browser/oracles}/prelaunchOracleClient.d.ts +1 -0
  39. package/lib/{oracles → browser/oracles}/pythClient.d.ts +1 -0
  40. package/lib/{oracles → browser/oracles}/pythPullClient.d.ts +1 -0
  41. package/lib/{oracles → browser/oracles}/quoteAssetOracleClient.d.ts +1 -0
  42. package/lib/{oracles → browser/oracles}/switchboardClient.d.ts +1 -0
  43. package/lib/{oracles → browser/oracles}/switchboardOnDemandClient.d.ts +1 -0
  44. package/lib/{oracles → browser/oracles}/types.d.ts +1 -0
  45. package/lib/{orderSubscriber → browser/orderSubscriber}/OrderSubscriber.d.ts +3 -1
  46. package/lib/{orderSubscriber → browser/orderSubscriber}/OrderSubscriber.js +18 -4
  47. package/lib/browser/orderSubscriber/grpcSubscription.d.ts +22 -0
  48. package/lib/browser/orderSubscriber/grpcSubscription.js +66 -0
  49. package/lib/{orderSubscriber → browser/orderSubscriber}/types.d.ts +9 -0
  50. package/lib/{token → browser/token}/index.d.ts +1 -0
  51. package/lib/{tx → browser/tx}/baseTxSender.d.ts +1 -0
  52. package/lib/{tx → browser/tx}/fastSingleTxSender.d.ts +1 -0
  53. package/lib/{tx → browser/tx}/forwardOnlyTxSender.d.ts +1 -0
  54. package/lib/{tx → browser/tx}/retryTxSender.d.ts +1 -0
  55. package/lib/{tx → browser/tx}/types.d.ts +1 -0
  56. package/lib/{tx → browser/tx}/whileValidTxSender.d.ts +1 -0
  57. package/lib/{user.js → browser/user.js} +11 -4
  58. package/lib/{userConfig.d.ts → browser/userConfig.d.ts} +6 -1
  59. package/lib/{userMap → browser/userMap}/WebsocketSubscription.d.ts +1 -0
  60. package/lib/browser/userMap/grpcSubscription.d.ts +24 -0
  61. package/lib/browser/userMap/grpcSubscription.js +40 -0
  62. package/lib/{userMap → browser/userMap}/userMap.js +17 -1
  63. package/lib/{userMap → browser/userMap}/userMapConfig.d.ts +6 -0
  64. package/lib/{userStats.js → browser/userStats.js} +11 -4
  65. package/lib/{userStatsConfig.d.ts → browser/userStatsConfig.d.ts} +6 -0
  66. package/lib/node/accounts/basicUserAccountSubscriber.d.ts +27 -0
  67. package/lib/node/accounts/basicUserAccountSubscriber.js +38 -0
  68. package/lib/node/accounts/bulkAccountLoader.d.ts +37 -0
  69. package/lib/node/accounts/bulkAccountLoader.js +222 -0
  70. package/lib/node/accounts/bulkUserStatsSubscription.d.ts +7 -0
  71. package/lib/node/accounts/bulkUserStatsSubscription.js +21 -0
  72. package/lib/node/accounts/bulkUserSubscription.d.ts +7 -0
  73. package/lib/node/accounts/bulkUserSubscription.js +21 -0
  74. package/lib/node/accounts/fetch.d.ts +6 -0
  75. package/lib/node/accounts/fetch.js +30 -0
  76. package/lib/node/accounts/grpcAccountSubscriber.d.ts +16 -0
  77. package/lib/node/accounts/grpcAccountSubscriber.js +154 -0
  78. package/lib/node/accounts/grpcDriftClientAccountSubscriber.d.ts +12 -0
  79. package/lib/node/accounts/grpcDriftClientAccountSubscriber.js +97 -0
  80. package/lib/node/accounts/grpcInsuranceFundStakeAccountSubscriber.d.ts +10 -0
  81. package/lib/node/accounts/grpcInsuranceFundStakeAccountSubscriber.js +30 -0
  82. package/lib/node/accounts/grpcProgramAccountSubscriber.d.ts +18 -0
  83. package/lib/node/accounts/grpcProgramAccountSubscriber.js +171 -0
  84. package/lib/node/accounts/grpcUserAccountSubscriber.d.ts +10 -0
  85. package/lib/node/accounts/grpcUserAccountSubscriber.js +28 -0
  86. package/lib/node/accounts/grpcUserStatsAccountSubscriber.d.ts +10 -0
  87. package/lib/node/accounts/grpcUserStatsAccountSubscriber.js +28 -0
  88. package/lib/node/accounts/oneShotUserAccountSubscriber.d.ts +18 -0
  89. package/lib/node/accounts/oneShotUserAccountSubscriber.js +48 -0
  90. package/lib/node/accounts/pollingDriftClientAccountSubscriber.d.ts +69 -0
  91. package/lib/node/accounts/pollingDriftClientAccountSubscriber.js +415 -0
  92. package/lib/node/accounts/pollingInsuranceFundStakeAccountSubscriber.d.ts +29 -0
  93. package/lib/node/accounts/pollingInsuranceFundStakeAccountSubscriber.js +110 -0
  94. package/lib/node/accounts/pollingOracleAccountSubscriber.d.ts +27 -0
  95. package/lib/node/accounts/pollingOracleAccountSubscriber.js +78 -0
  96. package/lib/node/accounts/pollingTokenAccountSubscriber.d.ts +26 -0
  97. package/lib/node/accounts/pollingTokenAccountSubscriber.js +78 -0
  98. package/lib/node/accounts/pollingUserAccountSubscriber.d.ts +29 -0
  99. package/lib/node/accounts/pollingUserAccountSubscriber.js +102 -0
  100. package/lib/node/accounts/pollingUserStatsAccountSubscriber.d.ts +27 -0
  101. package/lib/node/accounts/pollingUserStatsAccountSubscriber.js +94 -0
  102. package/lib/node/accounts/testBulkAccountLoader.d.ts +4 -0
  103. package/lib/node/accounts/testBulkAccountLoader.js +45 -0
  104. package/lib/node/accounts/types.d.ts +155 -0
  105. package/lib/node/accounts/types.js +16 -0
  106. package/lib/node/accounts/utils.d.ts +8 -0
  107. package/lib/node/accounts/utils.js +39 -0
  108. package/lib/node/accounts/webSocketAccountSubscriber.d.ts +29 -0
  109. package/lib/node/accounts/webSocketAccountSubscriber.js +149 -0
  110. package/lib/node/accounts/webSocketDriftClientAccountSubscriber.d.ts +66 -0
  111. package/lib/node/accounts/webSocketDriftClientAccountSubscriber.js +352 -0
  112. package/lib/node/accounts/webSocketInsuranceFundStakeAccountSubscriber.d.ts +23 -0
  113. package/lib/node/accounts/webSocketInsuranceFundStakeAccountSubscriber.js +67 -0
  114. package/lib/node/accounts/webSocketProgramAccountSubscriber.d.ts +34 -0
  115. package/lib/node/accounts/webSocketProgramAccountSubscriber.js +127 -0
  116. package/lib/node/accounts/webSocketUserAccountSubscriber.d.ts +23 -0
  117. package/lib/node/accounts/webSocketUserAccountSubscriber.js +61 -0
  118. package/lib/node/accounts/webSocketUserStatsAccountSubsriber.d.ts +22 -0
  119. package/lib/node/accounts/webSocketUserStatsAccountSubsriber.js +52 -0
  120. package/lib/node/addresses/marketAddresses.d.ts +2 -0
  121. package/lib/node/addresses/marketAddresses.js +15 -0
  122. package/lib/node/addresses/pda.d.ts +30 -0
  123. package/lib/node/addresses/pda.js +193 -0
  124. package/lib/node/adminClient.d.ts +202 -0
  125. package/lib/node/adminClient.js +1826 -0
  126. package/lib/node/assert/assert.d.ts +1 -0
  127. package/lib/node/assert/assert.js +9 -0
  128. package/lib/node/auctionSubscriber/auctionSubscriber.d.ts +14 -0
  129. package/lib/node/auctionSubscriber/auctionSubscriber.js +32 -0
  130. package/lib/node/auctionSubscriber/auctionSubscriberGrpc.d.ts +15 -0
  131. package/lib/node/auctionSubscriber/auctionSubscriberGrpc.js +32 -0
  132. package/lib/node/auctionSubscriber/index.d.ts +3 -0
  133. package/lib/node/auctionSubscriber/index.js +19 -0
  134. package/lib/node/auctionSubscriber/types.d.ts +14 -0
  135. package/lib/node/auctionSubscriber/types.js +2 -0
  136. package/lib/node/bankrun/bankrunConnection.d.ts +74 -0
  137. package/lib/node/bankrun/bankrunConnection.js +318 -0
  138. package/lib/node/blockhashSubscriber/BlockhashSubscriber.d.ts +27 -0
  139. package/lib/node/blockhashSubscriber/BlockhashSubscriber.js +89 -0
  140. package/lib/node/blockhashSubscriber/index.d.ts +1 -0
  141. package/lib/node/blockhashSubscriber/index.js +17 -0
  142. package/lib/node/blockhashSubscriber/types.d.ts +7 -0
  143. package/lib/node/blockhashSubscriber/types.js +2 -0
  144. package/lib/node/clock/clockSubscriber.d.ts +31 -0
  145. package/lib/node/clock/clockSubscriber.js +80 -0
  146. package/lib/node/config.d.ts +58 -0
  147. package/lib/node/config.js +126 -0
  148. package/lib/node/constants/numericConstants.d.ts +71 -0
  149. package/lib/node/constants/numericConstants.js +75 -0
  150. package/lib/node/constants/perpMarkets.d.ts +19 -0
  151. package/lib/node/constants/perpMarkets.js +868 -0
  152. package/lib/node/constants/spotMarkets.d.ts +23 -0
  153. package/lib/node/constants/spotMarkets.js +361 -0
  154. package/lib/node/constants/txConstants.d.ts +1 -0
  155. package/lib/node/constants/txConstants.js +4 -0
  156. package/lib/node/decode/phoenix.d.ts +7 -0
  157. package/lib/node/decode/phoenix.js +159 -0
  158. package/lib/node/decode/user.d.ts +4 -0
  159. package/lib/node/decode/user.js +339 -0
  160. package/lib/node/dlob/DLOB.d.ts +166 -0
  161. package/lib/node/dlob/DLOB.js +1142 -0
  162. package/lib/node/dlob/DLOBApiClient.d.ts +14 -0
  163. package/lib/node/dlob/DLOBApiClient.js +34 -0
  164. package/lib/node/dlob/DLOBNode.d.ts +57 -0
  165. package/lib/node/dlob/DLOBNode.js +86 -0
  166. package/lib/node/dlob/DLOBOrders.d.ts +17 -0
  167. package/lib/node/dlob/DLOBOrders.js +40 -0
  168. package/lib/node/dlob/DLOBSubscriber.d.ts +54 -0
  169. package/lib/node/dlob/DLOBSubscriber.js +139 -0
  170. package/lib/node/dlob/NodeList.d.ts +27 -0
  171. package/lib/node/dlob/NodeList.js +141 -0
  172. package/lib/node/dlob/dlobIdl.json +248 -0
  173. package/lib/node/dlob/orderBookLevels.d.ts +72 -0
  174. package/lib/node/dlob/orderBookLevels.js +438 -0
  175. package/lib/node/dlob/types.d.ts +18 -0
  176. package/lib/node/dlob/types.js +2 -0
  177. package/lib/node/driftClient.d.ts +820 -0
  178. package/lib/node/driftClient.js +4487 -0
  179. package/lib/node/driftClientConfig.d.ts +49 -0
  180. package/lib/node/driftClientConfig.js +2 -0
  181. package/lib/node/events/eventList.d.ts +22 -0
  182. package/lib/node/events/eventList.js +80 -0
  183. package/lib/node/events/eventSubscriber.d.ts +46 -0
  184. package/lib/node/events/eventSubscriber.js +223 -0
  185. package/lib/node/events/eventsServerLogProvider.d.ts +21 -0
  186. package/lib/node/events/eventsServerLogProvider.js +121 -0
  187. package/lib/node/events/fetchLogs.d.ts +25 -0
  188. package/lib/node/events/fetchLogs.js +99 -0
  189. package/lib/node/events/parse.d.ts +6 -0
  190. package/lib/node/events/parse.js +106 -0
  191. package/lib/node/events/pollingLogProvider.d.ts +17 -0
  192. package/lib/node/events/pollingLogProvider.js +58 -0
  193. package/lib/node/events/sort.d.ts +2 -0
  194. package/lib/node/events/sort.js +24 -0
  195. package/lib/node/events/txEventCache.d.ts +24 -0
  196. package/lib/node/events/txEventCache.js +71 -0
  197. package/lib/node/events/types.d.ts +77 -0
  198. package/lib/node/events/types.js +30 -0
  199. package/lib/node/events/webSocketLogProvider.d.ts +24 -0
  200. package/lib/node/events/webSocketLogProvider.js +96 -0
  201. package/lib/node/factory/bigNum.d.ts +122 -0
  202. package/lib/node/factory/bigNum.js +457 -0
  203. package/lib/node/factory/oracleClient.d.ts +5 -0
  204. package/lib/node/factory/oracleClient.js +52 -0
  205. package/lib/node/idl/drift.json +13651 -0
  206. package/lib/node/idl/openbook.json +3854 -0
  207. package/lib/node/idl/pyth_solana_receiver.json +628 -0
  208. package/lib/node/idl/switchboard.json +8354 -0
  209. package/lib/node/idl/switchboard_on_demand_30.json +4541 -0
  210. package/lib/node/idl/token_faucet.json +142 -0
  211. package/lib/node/index.d.ts +112 -0
  212. package/lib/node/index.js +134 -0
  213. package/lib/node/isomorphic/grpc.browser.d.ts +1 -0
  214. package/lib/node/isomorphic/grpc.d.ts +1 -0
  215. package/lib/node/isomorphic/grpc.js +17 -0
  216. package/lib/node/isomorphic/grpc.node.d.ts +5 -0
  217. package/lib/node/isomorphic/grpc.node.js +17 -0
  218. package/lib/node/jupiter/jupiterClient.d.ts +296 -0
  219. package/lib/node/jupiter/jupiterClient.js +178 -0
  220. package/lib/node/keypair.d.ts +2 -0
  221. package/lib/node/keypair.js +28 -0
  222. package/lib/node/marinade/index.d.ts +12 -0
  223. package/lib/node/marinade/index.js +36 -0
  224. package/lib/node/marinade/types.d.ts +1963 -0
  225. package/lib/node/marinade/types.js +1965 -0
  226. package/lib/node/math/amm.d.ts +98 -0
  227. package/lib/node/math/amm.js +626 -0
  228. package/lib/node/math/auction.d.ts +23 -0
  229. package/lib/node/math/auction.js +127 -0
  230. package/lib/node/math/bankruptcy.d.ts +2 -0
  231. package/lib/node/math/bankruptcy.js +31 -0
  232. package/lib/node/math/conversion.d.ts +2 -0
  233. package/lib/node/math/conversion.js +11 -0
  234. package/lib/node/math/exchangeStatus.d.ts +6 -0
  235. package/lib/node/math/exchangeStatus.js +77 -0
  236. package/lib/node/math/fuel.d.ts +6 -0
  237. package/lib/node/math/fuel.js +55 -0
  238. package/lib/node/math/funding.d.ts +34 -0
  239. package/lib/node/math/funding.js +209 -0
  240. package/lib/node/math/insurance.d.ts +7 -0
  241. package/lib/node/math/insurance.js +73 -0
  242. package/lib/node/math/margin.d.ts +39 -0
  243. package/lib/node/math/margin.js +184 -0
  244. package/lib/node/math/market.d.ts +39 -0
  245. package/lib/node/math/market.js +163 -0
  246. package/lib/node/math/oracles.d.ts +14 -0
  247. package/lib/node/math/oracles.js +134 -0
  248. package/lib/node/math/orders.d.ts +23 -0
  249. package/lib/node/math/orders.js +216 -0
  250. package/lib/node/math/position.d.ts +54 -0
  251. package/lib/node/math/position.js +198 -0
  252. package/lib/node/math/repeg.d.ts +22 -0
  253. package/lib/node/math/repeg.js +164 -0
  254. package/lib/node/math/spotBalance.d.ts +83 -0
  255. package/lib/node/math/spotBalance.js +373 -0
  256. package/lib/node/math/spotMarket.d.ts +11 -0
  257. package/lib/node/math/spotMarket.js +49 -0
  258. package/lib/node/math/spotPosition.d.ts +19 -0
  259. package/lib/node/math/spotPosition.js +78 -0
  260. package/lib/node/math/state.d.ts +5 -0
  261. package/lib/node/math/state.js +30 -0
  262. package/lib/node/math/superStake.d.ts +167 -0
  263. package/lib/node/math/superStake.js +306 -0
  264. package/lib/node/math/tiers.d.ts +4 -0
  265. package/lib/node/math/tiers.js +52 -0
  266. package/lib/node/math/trade.d.ts +117 -0
  267. package/lib/node/math/trade.js +637 -0
  268. package/lib/node/math/utils.d.ts +23 -0
  269. package/lib/node/math/utils.js +112 -0
  270. package/lib/node/memcmp.d.ts +7 -0
  271. package/lib/node/memcmp.js +63 -0
  272. package/lib/node/openbook/openbookV2FulfillmentConfigMap.d.ts +10 -0
  273. package/lib/node/openbook/openbookV2FulfillmentConfigMap.js +17 -0
  274. package/lib/node/openbook/openbookV2Subscriber.d.ts +36 -0
  275. package/lib/node/openbook/openbookV2Subscriber.js +104 -0
  276. package/lib/node/oracles/oracleClientCache.d.ts +9 -0
  277. package/lib/node/oracles/oracleClientCache.js +19 -0
  278. package/lib/node/oracles/prelaunchOracleClient.d.ts +12 -0
  279. package/lib/node/oracles/prelaunchOracleClient.js +24 -0
  280. package/lib/node/oracles/pythClient.d.ts +15 -0
  281. package/lib/node/oracles/pythClient.js +52 -0
  282. package/lib/node/oracles/pythPullClient.d.ts +19 -0
  283. package/lib/node/oracles/pythPullClient.js +60 -0
  284. package/lib/node/oracles/quoteAssetOracleClient.d.ts +10 -0
  285. package/lib/node/oracles/quoteAssetOracleClient.js +21 -0
  286. package/lib/node/oracles/strictOraclePrice.d.ts +9 -0
  287. package/lib/node/oracles/strictOraclePrice.js +17 -0
  288. package/lib/node/oracles/switchboardClient.d.ts +12 -0
  289. package/lib/node/oracles/switchboardClient.js +40 -0
  290. package/lib/node/oracles/switchboardOnDemandClient.d.ts +12 -0
  291. package/lib/node/oracles/switchboardOnDemandClient.js +32 -0
  292. package/lib/node/oracles/types.d.ts +23 -0
  293. package/lib/node/oracles/types.js +2 -0
  294. package/lib/node/orderParams.d.ts +29 -0
  295. package/lib/node/orderParams.js +44 -0
  296. package/lib/node/orderSubscriber/OrderSubscriber.d.ts +42 -0
  297. package/lib/node/orderSubscriber/OrderSubscriber.js +179 -0
  298. package/lib/node/orderSubscriber/PollingSubscription.d.ts +12 -0
  299. package/lib/node/orderSubscriber/PollingSubscription.js +23 -0
  300. package/lib/node/orderSubscriber/WebsocketSubscription.d.ts +23 -0
  301. package/lib/node/orderSubscriber/WebsocketSubscription.js +67 -0
  302. package/lib/node/orderSubscriber/grpcSubscription.d.ts +22 -0
  303. package/lib/node/orderSubscriber/grpcSubscription.js +66 -0
  304. package/lib/node/orderSubscriber/index.d.ts +2 -0
  305. package/lib/{auctionSubscriber → node/orderSubscriber}/index.js +1 -1
  306. package/lib/node/orderSubscriber/types.d.ts +34 -0
  307. package/lib/node/orderSubscriber/types.js +2 -0
  308. package/lib/node/phoenix/phoenixFulfillmentConfigMap.d.ts +10 -0
  309. package/lib/node/phoenix/phoenixFulfillmentConfigMap.js +17 -0
  310. package/lib/node/phoenix/phoenixSubscriber.d.ts +41 -0
  311. package/lib/node/phoenix/phoenixSubscriber.js +152 -0
  312. package/lib/node/priorityFee/averageOverSlotsStrategy.d.ts +5 -0
  313. package/lib/node/priorityFee/averageOverSlotsStrategy.js +16 -0
  314. package/lib/node/priorityFee/averageStrategy.d.ts +5 -0
  315. package/lib/node/priorityFee/averageStrategy.js +11 -0
  316. package/lib/node/priorityFee/driftPriorityFeeMethod.d.ts +13 -0
  317. package/lib/node/priorityFee/driftPriorityFeeMethod.js +26 -0
  318. package/lib/node/priorityFee/ewmaStrategy.d.ts +11 -0
  319. package/lib/node/priorityFee/ewmaStrategy.js +33 -0
  320. package/lib/node/priorityFee/heliusPriorityFeeMethod.d.ts +20 -0
  321. package/lib/node/priorityFee/heliusPriorityFeeMethod.js +46 -0
  322. package/lib/node/priorityFee/index.d.ts +11 -0
  323. package/lib/node/priorityFee/index.js +27 -0
  324. package/lib/node/priorityFee/maxOverSlotsStrategy.d.ts +5 -0
  325. package/lib/node/priorityFee/maxOverSlotsStrategy.js +17 -0
  326. package/lib/node/priorityFee/maxStrategy.d.ts +7 -0
  327. package/lib/node/priorityFee/maxStrategy.js +9 -0
  328. package/lib/node/priorityFee/priorityFeeSubscriber.d.ts +46 -0
  329. package/lib/node/priorityFee/priorityFeeSubscriber.js +188 -0
  330. package/lib/node/priorityFee/priorityFeeSubscriberMap.d.ts +48 -0
  331. package/lib/node/priorityFee/priorityFeeSubscriberMap.js +88 -0
  332. package/lib/node/priorityFee/solanaPriorityFeeMethod.d.ts +6 -0
  333. package/lib/node/priorityFee/solanaPriorityFeeMethod.js +21 -0
  334. package/lib/node/priorityFee/types.d.ts +31 -0
  335. package/lib/node/priorityFee/types.js +10 -0
  336. package/lib/node/serum/serumFulfillmentConfigMap.d.ts +10 -0
  337. package/lib/node/serum/serumFulfillmentConfigMap.js +17 -0
  338. package/lib/node/serum/serumSubscriber.d.ts +32 -0
  339. package/lib/node/serum/serumSubscriber.js +107 -0
  340. package/lib/node/serum/types.d.ts +13 -0
  341. package/lib/node/serum/types.js +2 -0
  342. package/lib/node/slot/SlotSubscriber.d.ts +27 -0
  343. package/lib/node/slot/SlotSubscriber.js +71 -0
  344. package/lib/node/testClient.d.ts +8 -0
  345. package/lib/node/testClient.js +23 -0
  346. package/lib/node/token/index.d.ts +5 -0
  347. package/lib/node/token/index.js +15 -0
  348. package/lib/node/tokenFaucet.d.ts +41 -0
  349. package/lib/node/tokenFaucet.js +188 -0
  350. package/lib/node/tx/baseTxSender.d.ts +55 -0
  351. package/lib/node/tx/baseTxSender.js +288 -0
  352. package/lib/node/tx/blockhashFetcher/baseBlockhashFetcher.d.ts +8 -0
  353. package/lib/node/tx/blockhashFetcher/baseBlockhashFetcher.js +13 -0
  354. package/lib/node/tx/blockhashFetcher/cachedBlockhashFetcher.d.ts +28 -0
  355. package/lib/node/tx/blockhashFetcher/cachedBlockhashFetcher.js +73 -0
  356. package/lib/node/tx/blockhashFetcher/types.d.ts +4 -0
  357. package/lib/node/tx/blockhashFetcher/types.js +2 -0
  358. package/lib/node/tx/fastSingleTxSender.d.ts +40 -0
  359. package/lib/node/tx/fastSingleTxSender.js +85 -0
  360. package/lib/node/tx/forwardOnlyTxSender.d.ts +36 -0
  361. package/lib/node/tx/forwardOnlyTxSender.js +91 -0
  362. package/lib/node/tx/priorityFeeCalculator.d.ts +44 -0
  363. package/lib/node/tx/priorityFeeCalculator.js +85 -0
  364. package/lib/node/tx/reportTransactionError.d.ts +20 -0
  365. package/lib/node/tx/reportTransactionError.js +103 -0
  366. package/lib/node/tx/retryTxSender.d.ts +36 -0
  367. package/lib/node/tx/retryTxSender.js +85 -0
  368. package/lib/node/tx/txHandler.d.ts +154 -0
  369. package/lib/node/tx/txHandler.js +453 -0
  370. package/lib/node/tx/txParamProcessor.d.ts +25 -0
  371. package/lib/node/tx/txParamProcessor.js +88 -0
  372. package/lib/node/tx/types.d.ts +29 -0
  373. package/lib/node/tx/types.js +20 -0
  374. package/lib/node/tx/utils.d.ts +2 -0
  375. package/lib/node/tx/utils.js +10 -0
  376. package/lib/node/tx/whileValidTxSender.d.ts +43 -0
  377. package/lib/node/tx/whileValidTxSender.js +165 -0
  378. package/lib/node/types.d.ts +1351 -0
  379. package/lib/node/types.js +347 -0
  380. package/lib/node/user.d.ts +411 -0
  381. package/lib/node/user.js +2161 -0
  382. package/lib/node/userConfig.d.ts +26 -0
  383. package/lib/node/userConfig.js +2 -0
  384. package/lib/node/userMap/PollingSubscription.d.ts +16 -0
  385. package/lib/node/userMap/PollingSubscription.js +30 -0
  386. package/lib/node/userMap/WebsocketSubscription.d.ts +25 -0
  387. package/lib/node/userMap/WebsocketSubscription.js +41 -0
  388. package/lib/node/userMap/grpcSubscription.d.ts +24 -0
  389. package/lib/node/userMap/grpcSubscription.js +40 -0
  390. package/lib/node/userMap/userMap.d.ts +88 -0
  391. package/lib/node/userMap/userMap.js +455 -0
  392. package/lib/node/userMap/userMapConfig.d.ts +37 -0
  393. package/lib/node/userMap/userMapConfig.js +2 -0
  394. package/lib/node/userMap/userStatsMap.d.ts +46 -0
  395. package/lib/node/userMap/userStatsMap.js +165 -0
  396. package/lib/node/userName.d.ts +5 -0
  397. package/lib/node/userName.js +21 -0
  398. package/lib/node/userStats.d.ts +19 -0
  399. package/lib/node/userStats.js +65 -0
  400. package/lib/node/userStatsConfig.d.ts +25 -0
  401. package/lib/node/userStatsConfig.js +2 -0
  402. package/lib/node/util/TransactionConfirmationManager.d.ts +16 -0
  403. package/lib/node/util/TransactionConfirmationManager.js +174 -0
  404. package/lib/node/util/chainClock.d.ts +17 -0
  405. package/lib/node/util/chainClock.js +29 -0
  406. package/lib/node/util/computeUnits.d.ts +8 -0
  407. package/lib/node/util/computeUnits.js +46 -0
  408. package/lib/node/util/promiseTimeout.d.ts +1 -0
  409. package/lib/node/util/promiseTimeout.js +14 -0
  410. package/lib/node/util/pythPullOracleUtils.d.ts +2 -0
  411. package/lib/node/util/pythPullOracleUtils.js +15 -0
  412. package/lib/node/util/tps.d.ts +2 -0
  413. package/lib/node/util/tps.js +16 -0
  414. package/lib/node/wallet.d.ts +11 -0
  415. package/lib/node/wallet.js +32 -0
  416. package/package.json +7 -4
  417. package/scripts/postbuild.js +61 -0
  418. package/src/accounts/grpcAccountSubscriber.ts +160 -0
  419. package/src/accounts/grpcDriftClientAccountSubscriber.ts +197 -0
  420. package/src/accounts/grpcInsuranceFundStakeAccountSubscriber.ts +56 -0
  421. package/src/accounts/grpcProgramAccountSubscriber.ts +190 -0
  422. package/src/accounts/grpcUserAccountSubscriber.ts +48 -0
  423. package/src/accounts/grpcUserStatsAccountSubscriber.ts +50 -0
  424. package/src/accounts/types.ts +8 -0
  425. package/src/accounts/webSocketAccountSubscriber.ts +1 -1
  426. package/src/accounts/webSocketDriftClientAccountSubscriber.ts +3 -3
  427. package/src/accounts/webSocketProgramAccountSubscriber.ts +1 -1
  428. package/src/auctionSubscriber/auctionSubscriberGrpc.ts +70 -0
  429. package/src/auctionSubscriber/index.ts +1 -0
  430. package/src/auctionSubscriber/types.ts +2 -0
  431. package/src/driftClient.ts +28 -0
  432. package/src/driftClientConfig.ts +7 -1
  433. package/src/isomorphic/README.md +19 -0
  434. package/src/isomorphic/grpc.browser.ts +4 -0
  435. package/src/isomorphic/grpc.node.ts +23 -0
  436. package/src/isomorphic/grpc.ts +1 -0
  437. package/src/orderSubscriber/OrderSubscriber.ts +14 -1
  438. package/src/orderSubscriber/grpcSubscription.ts +121 -0
  439. package/src/orderSubscriber/types.ts +10 -0
  440. package/src/user.ts +11 -0
  441. package/src/userConfig.ts +7 -1
  442. package/src/userMap/grpcSubscription.ts +78 -0
  443. package/src/userMap/userMap.ts +21 -2
  444. package/src/userMap/userMapConfig.ts +7 -0
  445. package/src/userStats.ts +11 -0
  446. package/src/userStatsConfig.ts +7 -0
  447. package/tsconfig.browser.json +13 -0
  448. package/tsconfig.json +1 -1
  449. /package/lib/{accounts → browser/accounts}/basicUserAccountSubscriber.d.ts +0 -0
  450. /package/lib/{accounts → browser/accounts}/basicUserAccountSubscriber.js +0 -0
  451. /package/lib/{accounts → browser/accounts}/bulkAccountLoader.js +0 -0
  452. /package/lib/{accounts → browser/accounts}/bulkUserStatsSubscription.d.ts +0 -0
  453. /package/lib/{accounts → browser/accounts}/bulkUserStatsSubscription.js +0 -0
  454. /package/lib/{accounts → browser/accounts}/bulkUserSubscription.d.ts +0 -0
  455. /package/lib/{accounts → browser/accounts}/bulkUserSubscription.js +0 -0
  456. /package/lib/{accounts → browser/accounts}/fetch.d.ts +0 -0
  457. /package/lib/{accounts → browser/accounts}/fetch.js +0 -0
  458. /package/lib/{accounts → browser/accounts}/oneShotUserAccountSubscriber.d.ts +0 -0
  459. /package/lib/{accounts → browser/accounts}/oneShotUserAccountSubscriber.js +0 -0
  460. /package/lib/{accounts → browser/accounts}/pollingDriftClientAccountSubscriber.d.ts +0 -0
  461. /package/lib/{accounts → browser/accounts}/pollingDriftClientAccountSubscriber.js +0 -0
  462. /package/lib/{accounts → browser/accounts}/pollingInsuranceFundStakeAccountSubscriber.d.ts +0 -0
  463. /package/lib/{accounts → browser/accounts}/pollingInsuranceFundStakeAccountSubscriber.js +0 -0
  464. /package/lib/{accounts → browser/accounts}/pollingOracleAccountSubscriber.d.ts +0 -0
  465. /package/lib/{accounts → browser/accounts}/pollingOracleAccountSubscriber.js +0 -0
  466. /package/lib/{accounts → browser/accounts}/pollingTokenAccountSubscriber.d.ts +0 -0
  467. /package/lib/{accounts → browser/accounts}/pollingTokenAccountSubscriber.js +0 -0
  468. /package/lib/{accounts → browser/accounts}/pollingUserAccountSubscriber.d.ts +0 -0
  469. /package/lib/{accounts → browser/accounts}/pollingUserAccountSubscriber.js +0 -0
  470. /package/lib/{accounts → browser/accounts}/pollingUserStatsAccountSubscriber.d.ts +0 -0
  471. /package/lib/{accounts → browser/accounts}/pollingUserStatsAccountSubscriber.js +0 -0
  472. /package/lib/{accounts → browser/accounts}/testBulkAccountLoader.d.ts +0 -0
  473. /package/lib/{accounts → browser/accounts}/testBulkAccountLoader.js +0 -0
  474. /package/lib/{accounts → browser/accounts}/types.js +0 -0
  475. /package/lib/{accounts → browser/accounts}/utils.d.ts +0 -0
  476. /package/lib/{accounts → browser/accounts}/utils.js +0 -0
  477. /package/lib/{accounts → browser/accounts}/webSocketAccountSubscriber.js +0 -0
  478. /package/lib/{accounts → browser/accounts}/webSocketDriftClientAccountSubscriber.js +0 -0
  479. /package/lib/{accounts → browser/accounts}/webSocketInsuranceFundStakeAccountSubscriber.d.ts +0 -0
  480. /package/lib/{accounts → browser/accounts}/webSocketInsuranceFundStakeAccountSubscriber.js +0 -0
  481. /package/lib/{accounts → browser/accounts}/webSocketProgramAccountSubscriber.js +0 -0
  482. /package/lib/{accounts → browser/accounts}/webSocketUserAccountSubscriber.d.ts +0 -0
  483. /package/lib/{accounts → browser/accounts}/webSocketUserAccountSubscriber.js +0 -0
  484. /package/lib/{accounts → browser/accounts}/webSocketUserStatsAccountSubsriber.d.ts +0 -0
  485. /package/lib/{accounts → browser/accounts}/webSocketUserStatsAccountSubsriber.js +0 -0
  486. /package/lib/{addresses → browser/addresses}/marketAddresses.d.ts +0 -0
  487. /package/lib/{addresses → browser/addresses}/marketAddresses.js +0 -0
  488. /package/lib/{addresses → browser/addresses}/pda.d.ts +0 -0
  489. /package/lib/{addresses → browser/addresses}/pda.js +0 -0
  490. /package/lib/{adminClient.d.ts → browser/adminClient.d.ts} +0 -0
  491. /package/lib/{adminClient.js → browser/adminClient.js} +0 -0
  492. /package/lib/{assert → browser/assert}/assert.d.ts +0 -0
  493. /package/lib/{assert → browser/assert}/assert.js +0 -0
  494. /package/lib/{auctionSubscriber → browser/auctionSubscriber}/auctionSubscriber.d.ts +0 -0
  495. /package/lib/{auctionSubscriber → browser/auctionSubscriber}/auctionSubscriber.js +0 -0
  496. /package/lib/{auctionSubscriber → browser/auctionSubscriber}/types.js +0 -0
  497. /package/lib/{bankrun → browser/bankrun}/bankrunConnection.js +0 -0
  498. /package/lib/{blockhashSubscriber → browser/blockhashSubscriber}/BlockhashSubscriber.d.ts +0 -0
  499. /package/lib/{blockhashSubscriber → browser/blockhashSubscriber}/BlockhashSubscriber.js +0 -0
  500. /package/lib/{blockhashSubscriber → browser/blockhashSubscriber}/index.d.ts +0 -0
  501. /package/lib/{blockhashSubscriber → browser/blockhashSubscriber}/index.js +0 -0
  502. /package/lib/{blockhashSubscriber → browser/blockhashSubscriber}/types.d.ts +0 -0
  503. /package/lib/{blockhashSubscriber → browser/blockhashSubscriber}/types.js +0 -0
  504. /package/lib/{clock → browser/clock}/clockSubscriber.d.ts +0 -0
  505. /package/lib/{clock → browser/clock}/clockSubscriber.js +0 -0
  506. /package/lib/{config.d.ts → browser/config.d.ts} +0 -0
  507. /package/lib/{config.js → browser/config.js} +0 -0
  508. /package/lib/{constants → browser/constants}/numericConstants.d.ts +0 -0
  509. /package/lib/{constants → browser/constants}/numericConstants.js +0 -0
  510. /package/lib/{constants → browser/constants}/perpMarkets.d.ts +0 -0
  511. /package/lib/{constants → browser/constants}/perpMarkets.js +0 -0
  512. /package/lib/{constants → browser/constants}/spotMarkets.d.ts +0 -0
  513. /package/lib/{constants → browser/constants}/spotMarkets.js +0 -0
  514. /package/lib/{constants → browser/constants}/txConstants.d.ts +0 -0
  515. /package/lib/{constants → browser/constants}/txConstants.js +0 -0
  516. /package/lib/{decode → browser/decode}/phoenix.js +0 -0
  517. /package/lib/{decode → browser/decode}/user.js +0 -0
  518. /package/lib/{dlob → browser/dlob}/DLOB.d.ts +0 -0
  519. /package/lib/{dlob → browser/dlob}/DLOB.js +0 -0
  520. /package/lib/{dlob → browser/dlob}/DLOBApiClient.d.ts +0 -0
  521. /package/lib/{dlob → browser/dlob}/DLOBApiClient.js +0 -0
  522. /package/lib/{dlob → browser/dlob}/DLOBNode.d.ts +0 -0
  523. /package/lib/{dlob → browser/dlob}/DLOBNode.js +0 -0
  524. /package/lib/{dlob → browser/dlob}/DLOBOrders.js +0 -0
  525. /package/lib/{dlob → browser/dlob}/DLOBSubscriber.d.ts +0 -0
  526. /package/lib/{dlob → browser/dlob}/DLOBSubscriber.js +0 -0
  527. /package/lib/{dlob → browser/dlob}/NodeList.d.ts +0 -0
  528. /package/lib/{dlob → browser/dlob}/NodeList.js +0 -0
  529. /package/lib/{dlob → browser/dlob}/dlobIdl.json +0 -0
  530. /package/lib/{dlob → browser/dlob}/orderBookLevels.d.ts +0 -0
  531. /package/lib/{dlob → browser/dlob}/orderBookLevels.js +0 -0
  532. /package/lib/{dlob → browser/dlob}/types.d.ts +0 -0
  533. /package/lib/{dlob → browser/dlob}/types.js +0 -0
  534. /package/lib/{driftClientConfig.js → browser/driftClientConfig.js} +0 -0
  535. /package/lib/{events → browser/events}/eventList.d.ts +0 -0
  536. /package/lib/{events → browser/events}/eventList.js +0 -0
  537. /package/lib/{events → browser/events}/eventSubscriber.d.ts +0 -0
  538. /package/lib/{events → browser/events}/eventSubscriber.js +0 -0
  539. /package/lib/{events → browser/events}/eventsServerLogProvider.d.ts +0 -0
  540. /package/lib/{events → browser/events}/eventsServerLogProvider.js +0 -0
  541. /package/lib/{events → browser/events}/fetchLogs.d.ts +0 -0
  542. /package/lib/{events → browser/events}/fetchLogs.js +0 -0
  543. /package/lib/{events → browser/events}/parse.d.ts +0 -0
  544. /package/lib/{events → browser/events}/parse.js +0 -0
  545. /package/lib/{events → browser/events}/pollingLogProvider.d.ts +0 -0
  546. /package/lib/{events → browser/events}/pollingLogProvider.js +0 -0
  547. /package/lib/{events → browser/events}/sort.d.ts +0 -0
  548. /package/lib/{events → browser/events}/sort.js +0 -0
  549. /package/lib/{events → browser/events}/txEventCache.d.ts +0 -0
  550. /package/lib/{events → browser/events}/txEventCache.js +0 -0
  551. /package/lib/{events → browser/events}/types.d.ts +0 -0
  552. /package/lib/{events → browser/events}/types.js +0 -0
  553. /package/lib/{events → browser/events}/webSocketLogProvider.d.ts +0 -0
  554. /package/lib/{events → browser/events}/webSocketLogProvider.js +0 -0
  555. /package/lib/{factory → browser/factory}/bigNum.d.ts +0 -0
  556. /package/lib/{factory → browser/factory}/bigNum.js +0 -0
  557. /package/lib/{factory → browser/factory}/oracleClient.d.ts +0 -0
  558. /package/lib/{factory → browser/factory}/oracleClient.js +0 -0
  559. /package/lib/{idl → browser/idl}/drift.json +0 -0
  560. /package/lib/{idl → browser/idl}/openbook.json +0 -0
  561. /package/lib/{idl → browser/idl}/pyth_solana_receiver.json +0 -0
  562. /package/lib/{idl → browser/idl}/switchboard.json +0 -0
  563. /package/lib/{idl → browser/idl}/switchboard_on_demand_30.json +0 -0
  564. /package/lib/{idl → browser/idl}/token_faucet.json +0 -0
  565. /package/lib/{index.d.ts → browser/index.d.ts} +0 -0
  566. /package/lib/{index.js → browser/index.js} +0 -0
  567. /package/lib/{jupiter → browser/jupiter}/jupiterClient.d.ts +0 -0
  568. /package/lib/{jupiter → browser/jupiter}/jupiterClient.js +0 -0
  569. /package/lib/{keypair.d.ts → browser/keypair.d.ts} +0 -0
  570. /package/lib/{keypair.js → browser/keypair.js} +0 -0
  571. /package/lib/{marinade → browser/marinade}/index.d.ts +0 -0
  572. /package/lib/{marinade → browser/marinade}/index.js +0 -0
  573. /package/lib/{marinade → browser/marinade}/types.d.ts +0 -0
  574. /package/lib/{marinade → browser/marinade}/types.js +0 -0
  575. /package/lib/{math → browser/math}/amm.d.ts +0 -0
  576. /package/lib/{math → browser/math}/amm.js +0 -0
  577. /package/lib/{math → browser/math}/auction.d.ts +0 -0
  578. /package/lib/{math → browser/math}/auction.js +0 -0
  579. /package/lib/{math → browser/math}/bankruptcy.d.ts +0 -0
  580. /package/lib/{math → browser/math}/bankruptcy.js +0 -0
  581. /package/lib/{math → browser/math}/conversion.d.ts +0 -0
  582. /package/lib/{math → browser/math}/conversion.js +0 -0
  583. /package/lib/{math → browser/math}/exchangeStatus.d.ts +0 -0
  584. /package/lib/{math → browser/math}/exchangeStatus.js +0 -0
  585. /package/lib/{math → browser/math}/fuel.d.ts +0 -0
  586. /package/lib/{math → browser/math}/fuel.js +0 -0
  587. /package/lib/{math → browser/math}/funding.d.ts +0 -0
  588. /package/lib/{math → browser/math}/funding.js +0 -0
  589. /package/lib/{math → browser/math}/insurance.d.ts +0 -0
  590. /package/lib/{math → browser/math}/insurance.js +0 -0
  591. /package/lib/{math → browser/math}/margin.d.ts +0 -0
  592. /package/lib/{math → browser/math}/margin.js +0 -0
  593. /package/lib/{math → browser/math}/market.d.ts +0 -0
  594. /package/lib/{math → browser/math}/market.js +0 -0
  595. /package/lib/{math → browser/math}/oracles.js +0 -0
  596. /package/lib/{math → browser/math}/orders.d.ts +0 -0
  597. /package/lib/{math → browser/math}/orders.js +0 -0
  598. /package/lib/{math → browser/math}/position.d.ts +0 -0
  599. /package/lib/{math → browser/math}/position.js +0 -0
  600. /package/lib/{math → browser/math}/repeg.d.ts +0 -0
  601. /package/lib/{math → browser/math}/repeg.js +0 -0
  602. /package/lib/{math → browser/math}/spotBalance.d.ts +0 -0
  603. /package/lib/{math → browser/math}/spotBalance.js +0 -0
  604. /package/lib/{math → browser/math}/spotMarket.d.ts +0 -0
  605. /package/lib/{math → browser/math}/spotMarket.js +0 -0
  606. /package/lib/{math → browser/math}/spotPosition.d.ts +0 -0
  607. /package/lib/{math → browser/math}/spotPosition.js +0 -0
  608. /package/lib/{math → browser/math}/state.d.ts +0 -0
  609. /package/lib/{math → browser/math}/state.js +0 -0
  610. /package/lib/{math → browser/math}/superStake.d.ts +0 -0
  611. /package/lib/{math → browser/math}/superStake.js +0 -0
  612. /package/lib/{math → browser/math}/tiers.d.ts +0 -0
  613. /package/lib/{math → browser/math}/tiers.js +0 -0
  614. /package/lib/{math → browser/math}/trade.d.ts +0 -0
  615. /package/lib/{math → browser/math}/trade.js +0 -0
  616. /package/lib/{math → browser/math}/utils.d.ts +0 -0
  617. /package/lib/{math → browser/math}/utils.js +0 -0
  618. /package/lib/{memcmp.d.ts → browser/memcmp.d.ts} +0 -0
  619. /package/lib/{memcmp.js → browser/memcmp.js} +0 -0
  620. /package/lib/{openbook → browser/openbook}/openbookV2FulfillmentConfigMap.d.ts +0 -0
  621. /package/lib/{openbook → browser/openbook}/openbookV2FulfillmentConfigMap.js +0 -0
  622. /package/lib/{openbook → browser/openbook}/openbookV2Subscriber.d.ts +0 -0
  623. /package/lib/{openbook → browser/openbook}/openbookV2Subscriber.js +0 -0
  624. /package/lib/{oracles → browser/oracles}/oracleClientCache.d.ts +0 -0
  625. /package/lib/{oracles → browser/oracles}/oracleClientCache.js +0 -0
  626. /package/lib/{oracles → browser/oracles}/prelaunchOracleClient.js +0 -0
  627. /package/lib/{oracles → browser/oracles}/pythClient.js +0 -0
  628. /package/lib/{oracles → browser/oracles}/pythPullClient.js +0 -0
  629. /package/lib/{oracles → browser/oracles}/quoteAssetOracleClient.js +0 -0
  630. /package/lib/{oracles → browser/oracles}/strictOraclePrice.d.ts +0 -0
  631. /package/lib/{oracles → browser/oracles}/strictOraclePrice.js +0 -0
  632. /package/lib/{oracles → browser/oracles}/switchboardClient.js +0 -0
  633. /package/lib/{oracles → browser/oracles}/switchboardOnDemandClient.js +0 -0
  634. /package/lib/{oracles → browser/oracles}/types.js +0 -0
  635. /package/lib/{orderParams.d.ts → browser/orderParams.d.ts} +0 -0
  636. /package/lib/{orderParams.js → browser/orderParams.js} +0 -0
  637. /package/lib/{orderSubscriber → browser/orderSubscriber}/PollingSubscription.d.ts +0 -0
  638. /package/lib/{orderSubscriber → browser/orderSubscriber}/PollingSubscription.js +0 -0
  639. /package/lib/{orderSubscriber → browser/orderSubscriber}/WebsocketSubscription.d.ts +0 -0
  640. /package/lib/{orderSubscriber → browser/orderSubscriber}/WebsocketSubscription.js +0 -0
  641. /package/lib/{orderSubscriber → browser/orderSubscriber}/index.d.ts +0 -0
  642. /package/lib/{orderSubscriber → browser/orderSubscriber}/index.js +0 -0
  643. /package/lib/{orderSubscriber → browser/orderSubscriber}/types.js +0 -0
  644. /package/lib/{phoenix → browser/phoenix}/phoenixFulfillmentConfigMap.d.ts +0 -0
  645. /package/lib/{phoenix → browser/phoenix}/phoenixFulfillmentConfigMap.js +0 -0
  646. /package/lib/{phoenix → browser/phoenix}/phoenixSubscriber.d.ts +0 -0
  647. /package/lib/{phoenix → browser/phoenix}/phoenixSubscriber.js +0 -0
  648. /package/lib/{priorityFee → browser/priorityFee}/averageOverSlotsStrategy.d.ts +0 -0
  649. /package/lib/{priorityFee → browser/priorityFee}/averageOverSlotsStrategy.js +0 -0
  650. /package/lib/{priorityFee → browser/priorityFee}/averageStrategy.d.ts +0 -0
  651. /package/lib/{priorityFee → browser/priorityFee}/averageStrategy.js +0 -0
  652. /package/lib/{priorityFee → browser/priorityFee}/driftPriorityFeeMethod.d.ts +0 -0
  653. /package/lib/{priorityFee → browser/priorityFee}/driftPriorityFeeMethod.js +0 -0
  654. /package/lib/{priorityFee → browser/priorityFee}/ewmaStrategy.d.ts +0 -0
  655. /package/lib/{priorityFee → browser/priorityFee}/ewmaStrategy.js +0 -0
  656. /package/lib/{priorityFee → browser/priorityFee}/heliusPriorityFeeMethod.d.ts +0 -0
  657. /package/lib/{priorityFee → browser/priorityFee}/heliusPriorityFeeMethod.js +0 -0
  658. /package/lib/{priorityFee → browser/priorityFee}/index.d.ts +0 -0
  659. /package/lib/{priorityFee → browser/priorityFee}/index.js +0 -0
  660. /package/lib/{priorityFee → browser/priorityFee}/maxOverSlotsStrategy.d.ts +0 -0
  661. /package/lib/{priorityFee → browser/priorityFee}/maxOverSlotsStrategy.js +0 -0
  662. /package/lib/{priorityFee → browser/priorityFee}/maxStrategy.d.ts +0 -0
  663. /package/lib/{priorityFee → browser/priorityFee}/maxStrategy.js +0 -0
  664. /package/lib/{priorityFee → browser/priorityFee}/priorityFeeSubscriber.d.ts +0 -0
  665. /package/lib/{priorityFee → browser/priorityFee}/priorityFeeSubscriber.js +0 -0
  666. /package/lib/{priorityFee → browser/priorityFee}/priorityFeeSubscriberMap.d.ts +0 -0
  667. /package/lib/{priorityFee → browser/priorityFee}/priorityFeeSubscriberMap.js +0 -0
  668. /package/lib/{priorityFee → browser/priorityFee}/solanaPriorityFeeMethod.d.ts +0 -0
  669. /package/lib/{priorityFee → browser/priorityFee}/solanaPriorityFeeMethod.js +0 -0
  670. /package/lib/{priorityFee → browser/priorityFee}/types.d.ts +0 -0
  671. /package/lib/{priorityFee → browser/priorityFee}/types.js +0 -0
  672. /package/lib/{serum → browser/serum}/serumFulfillmentConfigMap.d.ts +0 -0
  673. /package/lib/{serum → browser/serum}/serumFulfillmentConfigMap.js +0 -0
  674. /package/lib/{serum → browser/serum}/serumSubscriber.d.ts +0 -0
  675. /package/lib/{serum → browser/serum}/serumSubscriber.js +0 -0
  676. /package/lib/{serum → browser/serum}/types.d.ts +0 -0
  677. /package/lib/{serum → browser/serum}/types.js +0 -0
  678. /package/lib/{slot → browser/slot}/SlotSubscriber.d.ts +0 -0
  679. /package/lib/{slot → browser/slot}/SlotSubscriber.js +0 -0
  680. /package/lib/{testClient.d.ts → browser/testClient.d.ts} +0 -0
  681. /package/lib/{testClient.js → browser/testClient.js} +0 -0
  682. /package/lib/{token → browser/token}/index.js +0 -0
  683. /package/lib/{tokenFaucet.d.ts → browser/tokenFaucet.d.ts} +0 -0
  684. /package/lib/{tokenFaucet.js → browser/tokenFaucet.js} +0 -0
  685. /package/lib/{tx → browser/tx}/baseTxSender.js +0 -0
  686. /package/lib/{tx → browser/tx}/blockhashFetcher/baseBlockhashFetcher.d.ts +0 -0
  687. /package/lib/{tx → browser/tx}/blockhashFetcher/baseBlockhashFetcher.js +0 -0
  688. /package/lib/{tx → browser/tx}/blockhashFetcher/cachedBlockhashFetcher.d.ts +0 -0
  689. /package/lib/{tx → browser/tx}/blockhashFetcher/cachedBlockhashFetcher.js +0 -0
  690. /package/lib/{tx → browser/tx}/blockhashFetcher/types.d.ts +0 -0
  691. /package/lib/{tx → browser/tx}/blockhashFetcher/types.js +0 -0
  692. /package/lib/{tx → browser/tx}/fastSingleTxSender.js +0 -0
  693. /package/lib/{tx → browser/tx}/forwardOnlyTxSender.js +0 -0
  694. /package/lib/{tx → browser/tx}/priorityFeeCalculator.d.ts +0 -0
  695. /package/lib/{tx → browser/tx}/priorityFeeCalculator.js +0 -0
  696. /package/lib/{tx → browser/tx}/reportTransactionError.d.ts +0 -0
  697. /package/lib/{tx → browser/tx}/reportTransactionError.js +0 -0
  698. /package/lib/{tx → browser/tx}/retryTxSender.js +0 -0
  699. /package/lib/{tx → browser/tx}/txHandler.d.ts +0 -0
  700. /package/lib/{tx → browser/tx}/txHandler.js +0 -0
  701. /package/lib/{tx → browser/tx}/txParamProcessor.d.ts +0 -0
  702. /package/lib/{tx → browser/tx}/txParamProcessor.js +0 -0
  703. /package/lib/{tx → browser/tx}/types.js +0 -0
  704. /package/lib/{tx → browser/tx}/utils.d.ts +0 -0
  705. /package/lib/{tx → browser/tx}/utils.js +0 -0
  706. /package/lib/{tx → browser/tx}/whileValidTxSender.js +0 -0
  707. /package/lib/{types.d.ts → browser/types.d.ts} +0 -0
  708. /package/lib/{types.js → browser/types.js} +0 -0
  709. /package/lib/{user.d.ts → browser/user.d.ts} +0 -0
  710. /package/lib/{userConfig.js → browser/userConfig.js} +0 -0
  711. /package/lib/{userMap → browser/userMap}/PollingSubscription.d.ts +0 -0
  712. /package/lib/{userMap → browser/userMap}/PollingSubscription.js +0 -0
  713. /package/lib/{userMap → browser/userMap}/WebsocketSubscription.js +0 -0
  714. /package/lib/{userMap → browser/userMap}/userMap.d.ts +0 -0
  715. /package/lib/{userMap → browser/userMap}/userMapConfig.js +0 -0
  716. /package/lib/{userMap → browser/userMap}/userStatsMap.d.ts +0 -0
  717. /package/lib/{userMap → browser/userMap}/userStatsMap.js +0 -0
  718. /package/lib/{userName.d.ts → browser/userName.d.ts} +0 -0
  719. /package/lib/{userName.js → browser/userName.js} +0 -0
  720. /package/lib/{userStats.d.ts → browser/userStats.d.ts} +0 -0
  721. /package/lib/{userStatsConfig.js → browser/userStatsConfig.js} +0 -0
  722. /package/lib/{util → browser/util}/TransactionConfirmationManager.d.ts +0 -0
  723. /package/lib/{util → browser/util}/TransactionConfirmationManager.js +0 -0
  724. /package/lib/{util → browser/util}/chainClock.d.ts +0 -0
  725. /package/lib/{util → browser/util}/chainClock.js +0 -0
  726. /package/lib/{util → browser/util}/computeUnits.d.ts +0 -0
  727. /package/lib/{util → browser/util}/computeUnits.js +0 -0
  728. /package/lib/{util → browser/util}/promiseTimeout.d.ts +0 -0
  729. /package/lib/{util → browser/util}/promiseTimeout.js +0 -0
  730. /package/lib/{util → browser/util}/pythPullOracleUtils.d.ts +0 -0
  731. /package/lib/{util → browser/util}/pythPullOracleUtils.js +0 -0
  732. /package/lib/{util → browser/util}/tps.d.ts +0 -0
  733. /package/lib/{util → browser/util}/tps.js +0 -0
  734. /package/lib/{wallet.d.ts → browser/wallet.d.ts} +0 -0
  735. /package/lib/{wallet.js → browser/wallet.js} +0 -0
@@ -0,0 +1,1142 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.DLOB = void 0;
4
+ const NodeList_1 = require("./NodeList");
5
+ const __1 = require("..");
6
+ const web3_js_1 = require("@solana/web3.js");
7
+ const exchangeStatus_1 = require("../math/exchangeStatus");
8
+ const orderBookLevels_1 = require("./orderBookLevels");
9
+ const SUPPORTED_ORDER_TYPES = [
10
+ 'market',
11
+ 'limit',
12
+ 'triggerMarket',
13
+ 'triggerLimit',
14
+ 'oracle',
15
+ ];
16
+ class DLOB {
17
+ constructor() {
18
+ this.openOrders = new Map();
19
+ this.orderLists = new Map();
20
+ this.maxSlotForRestingLimitOrders = 0;
21
+ this.initialized = false;
22
+ this.init();
23
+ }
24
+ init() {
25
+ this.openOrders.set('perp', new Set());
26
+ this.openOrders.set('spot', new Set());
27
+ this.orderLists.set('perp', new Map());
28
+ this.orderLists.set('spot', new Map());
29
+ }
30
+ clear() {
31
+ for (const marketType of this.openOrders.keys()) {
32
+ this.openOrders.get(marketType).clear();
33
+ }
34
+ this.openOrders.clear();
35
+ for (const marketType of this.orderLists.keys()) {
36
+ for (const marketIndex of this.orderLists.get(marketType).keys()) {
37
+ const marketNodeLists = this.orderLists
38
+ .get(marketType)
39
+ .get(marketIndex);
40
+ for (const side of Object.keys(marketNodeLists)) {
41
+ for (const orderType of Object.keys(marketNodeLists[side])) {
42
+ marketNodeLists[side][orderType].clear();
43
+ }
44
+ }
45
+ }
46
+ }
47
+ this.orderLists.clear();
48
+ this.maxSlotForRestingLimitOrders = 0;
49
+ this.init();
50
+ }
51
+ /**
52
+ * initializes a new DLOB instance
53
+ *
54
+ * @returns a promise that resolves when the DLOB is initialized
55
+ */
56
+ async initFromUserMap(userMap, slot) {
57
+ if (this.initialized) {
58
+ return false;
59
+ }
60
+ // initialize the dlob with the user map
61
+ for (const user of userMap.values()) {
62
+ const userAccount = user.getUserAccount();
63
+ const userAccountPubkey = user.getUserAccountPublicKey();
64
+ const userAccountPubkeyString = userAccountPubkey.toString();
65
+ for (const order of userAccount.orders) {
66
+ this.insertOrder(order, userAccountPubkeyString, slot);
67
+ }
68
+ }
69
+ this.initialized = true;
70
+ return true;
71
+ }
72
+ initFromOrders(dlobOrders, slot) {
73
+ if (this.initialized) {
74
+ return false;
75
+ }
76
+ for (const { user, order } of dlobOrders) {
77
+ this.insertOrder(order, user.toString(), slot);
78
+ }
79
+ this.initialized = true;
80
+ return true;
81
+ }
82
+ handleOrderRecord(record, slot) {
83
+ this.insertOrder(record.order, record.user.toString(), slot);
84
+ }
85
+ handleOrderActionRecord(record, slot) {
86
+ if ((0, __1.isOneOfVariant)(record.action, ['place', 'expire'])) {
87
+ return;
88
+ }
89
+ if ((0, __1.isVariant)(record.action, 'trigger')) {
90
+ if (record.taker !== null) {
91
+ const takerOrder = this.getOrder(record.takerOrderId, record.taker);
92
+ if (takerOrder) {
93
+ this.trigger(takerOrder, record.taker, slot);
94
+ }
95
+ }
96
+ if (record.maker !== null) {
97
+ const makerOrder = this.getOrder(record.makerOrderId, record.maker);
98
+ if (makerOrder) {
99
+ this.trigger(makerOrder, record.maker, slot);
100
+ }
101
+ }
102
+ }
103
+ else if ((0, __1.isVariant)(record.action, 'fill')) {
104
+ if (record.taker !== null) {
105
+ const takerOrder = this.getOrder(record.takerOrderId, record.taker);
106
+ if (takerOrder) {
107
+ this.updateOrder(takerOrder, record.taker, slot, record.takerOrderCumulativeBaseAssetAmountFilled);
108
+ }
109
+ }
110
+ if (record.maker !== null) {
111
+ const makerOrder = this.getOrder(record.makerOrderId, record.maker);
112
+ if (makerOrder) {
113
+ this.updateOrder(makerOrder, record.maker, slot, record.makerOrderCumulativeBaseAssetAmountFilled);
114
+ }
115
+ }
116
+ }
117
+ else if ((0, __1.isVariant)(record.action, 'cancel')) {
118
+ if (record.taker !== null) {
119
+ const takerOrder = this.getOrder(record.takerOrderId, record.taker);
120
+ if (takerOrder) {
121
+ this.delete(takerOrder, record.taker, slot);
122
+ }
123
+ }
124
+ if (record.maker !== null) {
125
+ const makerOrder = this.getOrder(record.makerOrderId, record.maker);
126
+ if (makerOrder) {
127
+ this.delete(makerOrder, record.maker, slot);
128
+ }
129
+ }
130
+ }
131
+ }
132
+ insertOrder(order, userAccount, slot, onInsert) {
133
+ var _a;
134
+ if ((0, __1.isVariant)(order.status, 'init')) {
135
+ return;
136
+ }
137
+ if (!(0, __1.isOneOfVariant)(order.orderType, SUPPORTED_ORDER_TYPES)) {
138
+ return;
139
+ }
140
+ const marketType = (0, __1.getVariant)(order.marketType);
141
+ if (!this.orderLists.get(marketType).has(order.marketIndex)) {
142
+ this.addOrderList(marketType, order.marketIndex);
143
+ }
144
+ if ((0, __1.isVariant)(order.status, 'open')) {
145
+ this.openOrders
146
+ .get(marketType)
147
+ .add((0, NodeList_1.getOrderSignature)(order.orderId, userAccount));
148
+ }
149
+ (_a = this.getListForOrder(order, slot)) === null || _a === void 0 ? void 0 : _a.insert(order, marketType, userAccount);
150
+ if (onInsert) {
151
+ onInsert();
152
+ }
153
+ }
154
+ addOrderList(marketType, marketIndex) {
155
+ this.orderLists.get(marketType).set(marketIndex, {
156
+ restingLimit: {
157
+ ask: new NodeList_1.NodeList('restingLimit', 'asc'),
158
+ bid: new NodeList_1.NodeList('restingLimit', 'desc'),
159
+ },
160
+ floatingLimit: {
161
+ ask: new NodeList_1.NodeList('floatingLimit', 'asc'),
162
+ bid: new NodeList_1.NodeList('floatingLimit', 'desc'),
163
+ },
164
+ takingLimit: {
165
+ ask: new NodeList_1.NodeList('takingLimit', 'asc'),
166
+ bid: new NodeList_1.NodeList('takingLimit', 'asc'), // always sort ascending for market orders
167
+ },
168
+ market: {
169
+ ask: new NodeList_1.NodeList('market', 'asc'),
170
+ bid: new NodeList_1.NodeList('market', 'asc'), // always sort ascending for market orders
171
+ },
172
+ trigger: {
173
+ above: new NodeList_1.NodeList('trigger', 'asc'),
174
+ below: new NodeList_1.NodeList('trigger', 'desc'),
175
+ },
176
+ });
177
+ }
178
+ updateOrder(order, userAccount, slot, cumulativeBaseAssetAmountFilled, onUpdate) {
179
+ var _a;
180
+ this.updateRestingLimitOrders(slot);
181
+ if (order.baseAssetAmount.eq(cumulativeBaseAssetAmountFilled)) {
182
+ this.delete(order, userAccount, slot);
183
+ return;
184
+ }
185
+ if (order.baseAssetAmountFilled.eq(cumulativeBaseAssetAmountFilled)) {
186
+ return;
187
+ }
188
+ const newOrder = {
189
+ ...order,
190
+ };
191
+ newOrder.baseAssetAmountFilled = cumulativeBaseAssetAmountFilled;
192
+ (_a = this.getListForOrder(order, slot)) === null || _a === void 0 ? void 0 : _a.update(newOrder, userAccount.toString());
193
+ if (onUpdate) {
194
+ onUpdate();
195
+ }
196
+ }
197
+ trigger(order, userAccount, slot, onTrigger) {
198
+ var _a;
199
+ if ((0, __1.isVariant)(order.status, 'init')) {
200
+ return;
201
+ }
202
+ this.updateRestingLimitOrders(slot);
203
+ if ((0, __1.isTriggered)(order)) {
204
+ return;
205
+ }
206
+ const marketType = (0, __1.getVariant)(order.marketType);
207
+ const triggerList = this.orderLists.get(marketType).get(order.marketIndex)
208
+ .trigger[(0, __1.isVariant)(order.triggerCondition, 'above') ? 'above' : 'below'];
209
+ triggerList.remove(order, userAccount.toString());
210
+ (_a = this.getListForOrder(order, slot)) === null || _a === void 0 ? void 0 : _a.insert(order, marketType, userAccount.toString());
211
+ if (onTrigger) {
212
+ onTrigger();
213
+ }
214
+ }
215
+ delete(order, userAccount, slot, onDelete) {
216
+ var _a;
217
+ if ((0, __1.isVariant)(order.status, 'init')) {
218
+ return;
219
+ }
220
+ this.updateRestingLimitOrders(slot);
221
+ (_a = this.getListForOrder(order, slot)) === null || _a === void 0 ? void 0 : _a.remove(order, userAccount.toString());
222
+ if (onDelete) {
223
+ onDelete();
224
+ }
225
+ }
226
+ getListForOrder(order, slot) {
227
+ const isInactiveTriggerOrder = (0, __1.mustBeTriggered)(order) && !(0, __1.isTriggered)(order);
228
+ let type;
229
+ if (isInactiveTriggerOrder) {
230
+ type = 'trigger';
231
+ }
232
+ else if ((0, __1.isOneOfVariant)(order.orderType, ['market', 'triggerMarket', 'oracle'])) {
233
+ type = 'market';
234
+ }
235
+ else if (order.oraclePriceOffset !== 0) {
236
+ type = 'floatingLimit';
237
+ }
238
+ else {
239
+ const isResting = (0, __1.isRestingLimitOrder)(order, slot);
240
+ type = isResting ? 'restingLimit' : 'takingLimit';
241
+ }
242
+ let subType;
243
+ if (isInactiveTriggerOrder) {
244
+ subType = (0, __1.isVariant)(order.triggerCondition, 'above') ? 'above' : 'below';
245
+ }
246
+ else {
247
+ subType = (0, __1.isVariant)(order.direction, 'long') ? 'bid' : 'ask';
248
+ }
249
+ const marketType = (0, __1.getVariant)(order.marketType);
250
+ if (!this.orderLists.has(marketType)) {
251
+ return undefined;
252
+ }
253
+ return this.orderLists.get(marketType).get(order.marketIndex)[type][subType];
254
+ }
255
+ updateRestingLimitOrders(slot) {
256
+ if (slot <= this.maxSlotForRestingLimitOrders) {
257
+ return;
258
+ }
259
+ this.maxSlotForRestingLimitOrders = slot;
260
+ this.updateRestingLimitOrdersForMarketType(slot, 'perp');
261
+ this.updateRestingLimitOrdersForMarketType(slot, 'spot');
262
+ }
263
+ updateRestingLimitOrdersForMarketType(slot, marketTypeStr) {
264
+ for (const [_, nodeLists] of this.orderLists.get(marketTypeStr)) {
265
+ const nodesToUpdate = [];
266
+ for (const node of nodeLists.takingLimit.ask.getGenerator()) {
267
+ if (!(0, __1.isRestingLimitOrder)(node.order, slot)) {
268
+ continue;
269
+ }
270
+ nodesToUpdate.push({
271
+ side: 'ask',
272
+ node,
273
+ });
274
+ }
275
+ for (const node of nodeLists.takingLimit.bid.getGenerator()) {
276
+ if (!(0, __1.isRestingLimitOrder)(node.order, slot)) {
277
+ continue;
278
+ }
279
+ nodesToUpdate.push({
280
+ side: 'bid',
281
+ node,
282
+ });
283
+ }
284
+ for (const nodeToUpdate of nodesToUpdate) {
285
+ const { side, node } = nodeToUpdate;
286
+ nodeLists.takingLimit[side].remove(node.order, node.userAccount);
287
+ nodeLists.restingLimit[side].insert(node.order, marketTypeStr, node.userAccount);
288
+ }
289
+ }
290
+ }
291
+ getOrder(orderId, userAccount) {
292
+ const orderSignature = (0, NodeList_1.getOrderSignature)(orderId, userAccount.toString());
293
+ for (const nodeList of this.getNodeLists()) {
294
+ const node = nodeList.get(orderSignature);
295
+ if (node) {
296
+ return node.order;
297
+ }
298
+ }
299
+ return undefined;
300
+ }
301
+ findNodesToFill(marketIndex, fallbackBid, fallbackAsk, slot, ts, marketType, oraclePriceData, stateAccount, marketAccount) {
302
+ if ((0, exchangeStatus_1.fillPaused)(stateAccount, marketAccount)) {
303
+ return [];
304
+ }
305
+ const isAmmPaused = (0, exchangeStatus_1.ammPaused)(stateAccount, marketAccount);
306
+ const minAuctionDuration = (0, __1.isVariant)(marketType, 'perp')
307
+ ? stateAccount.minPerpAuctionDuration
308
+ : 0;
309
+ const { makerRebateNumerator, makerRebateDenominator } = this.getMakerRebate(marketType, stateAccount, marketAccount);
310
+ const restingLimitOrderNodesToFill = this.findRestingLimitOrderNodesToFill(marketIndex, slot, marketType, oraclePriceData, isAmmPaused, minAuctionDuration, makerRebateNumerator, makerRebateDenominator, fallbackAsk, fallbackBid);
311
+ const takingOrderNodesToFill = this.findTakingNodesToFill(marketIndex, slot, marketType, oraclePriceData, isAmmPaused, minAuctionDuration, fallbackAsk, fallbackBid);
312
+ // get expired market nodes
313
+ const expiredNodesToFill = this.findExpiredNodesToFill(marketIndex, ts, marketType);
314
+ return this.mergeNodesToFill(restingLimitOrderNodesToFill, takingOrderNodesToFill).concat(expiredNodesToFill);
315
+ }
316
+ getMakerRebate(marketType, stateAccount, marketAccount) {
317
+ let makerRebateNumerator;
318
+ let makerRebateDenominator;
319
+ if ((0, __1.isVariant)(marketType, 'perp')) {
320
+ makerRebateNumerator =
321
+ stateAccount.perpFeeStructure.feeTiers[0].makerRebateNumerator;
322
+ makerRebateDenominator =
323
+ stateAccount.perpFeeStructure.feeTiers[0].makerRebateDenominator;
324
+ }
325
+ else {
326
+ makerRebateNumerator =
327
+ stateAccount.spotFeeStructure.feeTiers[0].makerRebateNumerator;
328
+ makerRebateDenominator =
329
+ stateAccount.spotFeeStructure.feeTiers[0].makerRebateDenominator;
330
+ }
331
+ // @ts-ignore
332
+ const feeAdjustment = marketAccount.feeAdjustment || 0;
333
+ if (feeAdjustment !== 0) {
334
+ makerRebateNumerator += (makerRebateNumerator * feeAdjustment) / 100;
335
+ }
336
+ return { makerRebateNumerator, makerRebateDenominator };
337
+ }
338
+ mergeNodesToFill(restingLimitOrderNodesToFill, takingOrderNodesToFill) {
339
+ const mergedNodesToFill = new Map();
340
+ const mergeNodesToFillHelper = (nodesToFillArray) => {
341
+ nodesToFillArray.forEach((nodeToFill) => {
342
+ const nodeSignature = (0, NodeList_1.getOrderSignature)(nodeToFill.node.order.orderId, nodeToFill.node.userAccount);
343
+ if (!mergedNodesToFill.has(nodeSignature)) {
344
+ mergedNodesToFill.set(nodeSignature, {
345
+ node: nodeToFill.node,
346
+ makerNodes: [],
347
+ });
348
+ }
349
+ if (nodeToFill.makerNodes) {
350
+ mergedNodesToFill
351
+ .get(nodeSignature)
352
+ .makerNodes.push(...nodeToFill.makerNodes);
353
+ }
354
+ });
355
+ };
356
+ mergeNodesToFillHelper(restingLimitOrderNodesToFill);
357
+ mergeNodesToFillHelper(takingOrderNodesToFill);
358
+ return Array.from(mergedNodesToFill.values());
359
+ }
360
+ findRestingLimitOrderNodesToFill(marketIndex, slot, marketType, oraclePriceData, isAmmPaused, minAuctionDuration, makerRebateNumerator, makerRebateDenominator, fallbackAsk, fallbackBid) {
361
+ const nodesToFill = new Array();
362
+ const crossingNodes = this.findCrossingRestingLimitOrders(marketIndex, slot, marketType, oraclePriceData);
363
+ for (const crossingNode of crossingNodes) {
364
+ nodesToFill.push(crossingNode);
365
+ }
366
+ if (fallbackBid && !isAmmPaused) {
367
+ const askGenerator = this.getRestingLimitAsks(marketIndex, slot, marketType, oraclePriceData);
368
+ const fallbackBidWithBuffer = fallbackBid.sub(fallbackBid.muln(makerRebateNumerator).divn(makerRebateDenominator));
369
+ const asksCrossingFallback = this.findNodesCrossingFallbackLiquidity(marketType, slot, oraclePriceData, askGenerator, (askPrice) => {
370
+ return askPrice.lte(fallbackBidWithBuffer);
371
+ }, minAuctionDuration);
372
+ for (const askCrossingFallback of asksCrossingFallback) {
373
+ nodesToFill.push(askCrossingFallback);
374
+ }
375
+ }
376
+ if (fallbackAsk && !isAmmPaused) {
377
+ const bidGenerator = this.getRestingLimitBids(marketIndex, slot, marketType, oraclePriceData);
378
+ const fallbackAskWithBuffer = fallbackAsk.add(fallbackAsk.muln(makerRebateNumerator).divn(makerRebateDenominator));
379
+ const bidsCrossingFallback = this.findNodesCrossingFallbackLiquidity(marketType, slot, oraclePriceData, bidGenerator, (bidPrice) => {
380
+ return bidPrice.gte(fallbackAskWithBuffer);
381
+ }, minAuctionDuration);
382
+ for (const bidCrossingFallback of bidsCrossingFallback) {
383
+ nodesToFill.push(bidCrossingFallback);
384
+ }
385
+ }
386
+ return nodesToFill;
387
+ }
388
+ findTakingNodesToFill(marketIndex, slot, marketType, oraclePriceData, isAmmPaused, minAuctionDuration, fallbackAsk, fallbackBid) {
389
+ const nodesToFill = new Array();
390
+ let takingOrderGenerator = this.getTakingAsks(marketIndex, marketType, slot, oraclePriceData);
391
+ const takingAsksCrossingBids = this.findTakingNodesCrossingMakerNodes(marketIndex, slot, marketType, oraclePriceData, takingOrderGenerator, this.getRestingLimitBids.bind(this), (takerPrice, makerPrice) => {
392
+ if ((0, __1.isVariant)(marketType, 'spot')) {
393
+ if (takerPrice === undefined) {
394
+ return false;
395
+ }
396
+ if (fallbackBid && makerPrice.lt(fallbackBid)) {
397
+ return false;
398
+ }
399
+ }
400
+ return takerPrice === undefined || takerPrice.lte(makerPrice);
401
+ });
402
+ for (const takingAskCrossingBid of takingAsksCrossingBids) {
403
+ nodesToFill.push(takingAskCrossingBid);
404
+ }
405
+ if (fallbackBid && !isAmmPaused) {
406
+ takingOrderGenerator = this.getTakingAsks(marketIndex, marketType, slot, oraclePriceData);
407
+ const takingAsksCrossingFallback = this.findNodesCrossingFallbackLiquidity(marketType, slot, oraclePriceData, takingOrderGenerator, (takerPrice) => {
408
+ return takerPrice === undefined || takerPrice.lte(fallbackBid);
409
+ }, minAuctionDuration);
410
+ for (const takingAskCrossingFallback of takingAsksCrossingFallback) {
411
+ nodesToFill.push(takingAskCrossingFallback);
412
+ }
413
+ }
414
+ takingOrderGenerator = this.getTakingBids(marketIndex, marketType, slot, oraclePriceData);
415
+ const takingBidsToFill = this.findTakingNodesCrossingMakerNodes(marketIndex, slot, marketType, oraclePriceData, takingOrderGenerator, this.getRestingLimitAsks.bind(this), (takerPrice, makerPrice) => {
416
+ if ((0, __1.isVariant)(marketType, 'spot')) {
417
+ if (takerPrice === undefined) {
418
+ return false;
419
+ }
420
+ if (fallbackAsk && makerPrice.gt(fallbackAsk)) {
421
+ return false;
422
+ }
423
+ }
424
+ return takerPrice === undefined || takerPrice.gte(makerPrice);
425
+ });
426
+ for (const takingBidToFill of takingBidsToFill) {
427
+ nodesToFill.push(takingBidToFill);
428
+ }
429
+ if (fallbackAsk && !isAmmPaused) {
430
+ takingOrderGenerator = this.getTakingBids(marketIndex, marketType, slot, oraclePriceData);
431
+ const takingBidsCrossingFallback = this.findNodesCrossingFallbackLiquidity(marketType, slot, oraclePriceData, takingOrderGenerator, (takerPrice) => {
432
+ return takerPrice === undefined || takerPrice.gte(fallbackAsk);
433
+ }, minAuctionDuration);
434
+ for (const marketBidCrossingFallback of takingBidsCrossingFallback) {
435
+ nodesToFill.push(marketBidCrossingFallback);
436
+ }
437
+ }
438
+ return nodesToFill;
439
+ }
440
+ findTakingNodesCrossingMakerNodes(marketIndex, slot, marketType, oraclePriceData, takerNodeGenerator, makerNodeGeneratorFn, doesCross) {
441
+ const nodesToFill = new Array();
442
+ for (const takerNode of takerNodeGenerator) {
443
+ const makerNodeGenerator = makerNodeGeneratorFn(marketIndex, slot, marketType, oraclePriceData);
444
+ for (const makerNode of makerNodeGenerator) {
445
+ // Can't match orders from the same user
446
+ const sameUser = takerNode.userAccount === makerNode.userAccount;
447
+ if (sameUser) {
448
+ continue;
449
+ }
450
+ const makerPrice = makerNode.getPrice(oraclePriceData, slot);
451
+ const takerPrice = takerNode.getPrice(oraclePriceData, slot);
452
+ const ordersCross = doesCross(takerPrice, makerPrice);
453
+ if (!ordersCross) {
454
+ // market orders aren't sorted by price, they are sorted by time, so we need to traverse
455
+ // through all of em
456
+ break;
457
+ }
458
+ nodesToFill.push({
459
+ node: takerNode,
460
+ makerNodes: [makerNode],
461
+ });
462
+ const makerOrder = makerNode.order;
463
+ const takerOrder = takerNode.order;
464
+ const makerBaseRemaining = makerOrder.baseAssetAmount.sub(makerOrder.baseAssetAmountFilled);
465
+ const takerBaseRemaining = takerOrder.baseAssetAmount.sub(takerOrder.baseAssetAmountFilled);
466
+ const baseFilled = __1.BN.min(makerBaseRemaining, takerBaseRemaining);
467
+ const newMakerOrder = { ...makerOrder };
468
+ newMakerOrder.baseAssetAmountFilled =
469
+ makerOrder.baseAssetAmountFilled.add(baseFilled);
470
+ this.getListForOrder(newMakerOrder, slot).update(newMakerOrder, makerNode.userAccount);
471
+ const newTakerOrder = { ...takerOrder };
472
+ newTakerOrder.baseAssetAmountFilled =
473
+ takerOrder.baseAssetAmountFilled.add(baseFilled);
474
+ this.getListForOrder(newTakerOrder, slot).update(newTakerOrder, takerNode.userAccount);
475
+ if (newTakerOrder.baseAssetAmountFilled.eq(takerOrder.baseAssetAmount)) {
476
+ break;
477
+ }
478
+ }
479
+ }
480
+ return nodesToFill;
481
+ }
482
+ findNodesCrossingFallbackLiquidity(marketType, slot, oraclePriceData, nodeGenerator, doesCross, minAuctionDuration) {
483
+ var _a;
484
+ const nodesToFill = new Array();
485
+ let nextNode = nodeGenerator.next();
486
+ while (!nextNode.done) {
487
+ const node = nextNode.value;
488
+ if ((0, __1.isVariant)(marketType, 'spot') && ((_a = node.order) === null || _a === void 0 ? void 0 : _a.postOnly)) {
489
+ nextNode = nodeGenerator.next();
490
+ continue;
491
+ }
492
+ const nodePrice = (0, __1.getLimitPrice)(node.order, oraclePriceData, slot);
493
+ // order crosses if there is no limit price or it crosses fallback price
494
+ const crosses = doesCross(nodePrice);
495
+ // fallback is available if auction is complete or it's a spot order
496
+ const fallbackAvailable = (0, __1.isVariant)(marketType, 'spot') ||
497
+ (0, __1.isFallbackAvailableLiquiditySource)(node.order, minAuctionDuration, slot);
498
+ if (crosses && fallbackAvailable) {
499
+ nodesToFill.push({
500
+ node: node,
501
+ makerNodes: [], // filled by fallback
502
+ });
503
+ }
504
+ nextNode = nodeGenerator.next();
505
+ }
506
+ return nodesToFill;
507
+ }
508
+ findExpiredNodesToFill(marketIndex, ts, marketType) {
509
+ const nodesToFill = new Array();
510
+ const marketTypeStr = (0, __1.getVariant)(marketType);
511
+ const nodeLists = this.orderLists.get(marketTypeStr).get(marketIndex);
512
+ if (!nodeLists) {
513
+ return nodesToFill;
514
+ }
515
+ // All bids/asks that can expire
516
+ // dont try to expire limit orders with tif as its inefficient use of blockspace
517
+ const bidGenerators = [
518
+ nodeLists.takingLimit.bid.getGenerator(),
519
+ nodeLists.restingLimit.bid.getGenerator(),
520
+ nodeLists.floatingLimit.bid.getGenerator(),
521
+ nodeLists.market.bid.getGenerator(),
522
+ ];
523
+ const askGenerators = [
524
+ nodeLists.takingLimit.ask.getGenerator(),
525
+ nodeLists.restingLimit.ask.getGenerator(),
526
+ nodeLists.floatingLimit.ask.getGenerator(),
527
+ nodeLists.market.ask.getGenerator(),
528
+ ];
529
+ for (const bidGenerator of bidGenerators) {
530
+ for (const bid of bidGenerator) {
531
+ if ((0, __1.isOrderExpired)(bid.order, ts, true, 25)) {
532
+ nodesToFill.push({
533
+ node: bid,
534
+ makerNodes: [],
535
+ });
536
+ }
537
+ }
538
+ }
539
+ for (const askGenerator of askGenerators) {
540
+ for (const ask of askGenerator) {
541
+ if ((0, __1.isOrderExpired)(ask.order, ts, true, 25)) {
542
+ nodesToFill.push({
543
+ node: ask,
544
+ makerNodes: [],
545
+ });
546
+ }
547
+ }
548
+ }
549
+ return nodesToFill;
550
+ }
551
+ findJitAuctionNodesToFill(marketIndex, slot, oraclePriceData, marketType) {
552
+ const nodesToFill = new Array();
553
+ // Then see if there are orders still in JIT auction
554
+ for (const marketBid of this.getTakingBids(marketIndex, marketType, slot, oraclePriceData)) {
555
+ nodesToFill.push({
556
+ node: marketBid,
557
+ makerNodes: [],
558
+ });
559
+ }
560
+ for (const marketAsk of this.getTakingAsks(marketIndex, marketType, slot, oraclePriceData)) {
561
+ nodesToFill.push({
562
+ node: marketAsk,
563
+ makerNodes: [],
564
+ });
565
+ }
566
+ return nodesToFill;
567
+ }
568
+ *getTakingBids(marketIndex, marketType, slot, oraclePriceData, filterFcn) {
569
+ const marketTypeStr = (0, __1.getVariant)(marketType);
570
+ const orderLists = this.orderLists.get(marketTypeStr).get(marketIndex);
571
+ if (!orderLists) {
572
+ return;
573
+ }
574
+ this.updateRestingLimitOrders(slot);
575
+ const generatorList = [
576
+ orderLists.market.bid.getGenerator(),
577
+ orderLists.takingLimit.bid.getGenerator(),
578
+ ];
579
+ yield* this.getBestNode(generatorList, oraclePriceData, slot, (bestNode, currentNode) => {
580
+ return bestNode.order.slot.lt(currentNode.order.slot);
581
+ }, filterFcn);
582
+ }
583
+ *getTakingAsks(marketIndex, marketType, slot, oraclePriceData, filterFcn) {
584
+ const marketTypeStr = (0, __1.getVariant)(marketType);
585
+ const orderLists = this.orderLists.get(marketTypeStr).get(marketIndex);
586
+ if (!orderLists) {
587
+ return;
588
+ }
589
+ this.updateRestingLimitOrders(slot);
590
+ const generatorList = [
591
+ orderLists.market.ask.getGenerator(),
592
+ orderLists.takingLimit.ask.getGenerator(),
593
+ ];
594
+ yield* this.getBestNode(generatorList, oraclePriceData, slot, (bestNode, currentNode) => {
595
+ return bestNode.order.slot.lt(currentNode.order.slot);
596
+ }, filterFcn);
597
+ }
598
+ *getBestNode(generatorList, oraclePriceData, slot, compareFcn, filterFcn) {
599
+ const generators = generatorList.map((generator) => {
600
+ return {
601
+ next: generator.next(),
602
+ generator,
603
+ };
604
+ });
605
+ let sideExhausted = false;
606
+ while (!sideExhausted) {
607
+ const bestGenerator = generators.reduce((bestGenerator, currentGenerator) => {
608
+ if (currentGenerator.next.done) {
609
+ return bestGenerator;
610
+ }
611
+ if (bestGenerator.next.done) {
612
+ return currentGenerator;
613
+ }
614
+ const bestValue = bestGenerator.next.value;
615
+ const currentValue = currentGenerator.next.value;
616
+ return compareFcn(bestValue, currentValue, slot, oraclePriceData)
617
+ ? bestGenerator
618
+ : currentGenerator;
619
+ });
620
+ if (!bestGenerator.next.done) {
621
+ // skip this node if it's already completely filled
622
+ if (bestGenerator.next.value.isBaseFilled()) {
623
+ bestGenerator.next = bestGenerator.generator.next();
624
+ continue;
625
+ }
626
+ if (filterFcn && !filterFcn(bestGenerator.next.value)) {
627
+ bestGenerator.next = bestGenerator.generator.next();
628
+ continue;
629
+ }
630
+ yield bestGenerator.next.value;
631
+ bestGenerator.next = bestGenerator.generator.next();
632
+ }
633
+ else {
634
+ sideExhausted = true;
635
+ }
636
+ }
637
+ }
638
+ *getRestingLimitAsks(marketIndex, slot, marketType, oraclePriceData, filterFcn) {
639
+ if ((0, __1.isVariant)(marketType, 'spot') && !oraclePriceData) {
640
+ throw new Error('Must provide OraclePriceData to get spot asks');
641
+ }
642
+ this.updateRestingLimitOrders(slot);
643
+ const marketTypeStr = (0, __1.getVariant)(marketType);
644
+ const nodeLists = this.orderLists.get(marketTypeStr).get(marketIndex);
645
+ if (!nodeLists) {
646
+ return;
647
+ }
648
+ const generatorList = [
649
+ nodeLists.restingLimit.ask.getGenerator(),
650
+ nodeLists.floatingLimit.ask.getGenerator(),
651
+ ];
652
+ yield* this.getBestNode(generatorList, oraclePriceData, slot, (bestNode, currentNode, slot, oraclePriceData) => {
653
+ return bestNode
654
+ .getPrice(oraclePriceData, slot)
655
+ .lt(currentNode.getPrice(oraclePriceData, slot));
656
+ }, filterFcn);
657
+ }
658
+ *getRestingLimitBids(marketIndex, slot, marketType, oraclePriceData, filterFcn) {
659
+ if ((0, __1.isVariant)(marketType, 'spot') && !oraclePriceData) {
660
+ throw new Error('Must provide OraclePriceData to get spot bids');
661
+ }
662
+ this.updateRestingLimitOrders(slot);
663
+ const marketTypeStr = (0, __1.getVariant)(marketType);
664
+ const nodeLists = this.orderLists.get(marketTypeStr).get(marketIndex);
665
+ if (!nodeLists) {
666
+ return;
667
+ }
668
+ const generatorList = [
669
+ nodeLists.restingLimit.bid.getGenerator(),
670
+ nodeLists.floatingLimit.bid.getGenerator(),
671
+ ];
672
+ yield* this.getBestNode(generatorList, oraclePriceData, slot, (bestNode, currentNode, slot, oraclePriceData) => {
673
+ return bestNode
674
+ .getPrice(oraclePriceData, slot)
675
+ .gt(currentNode.getPrice(oraclePriceData, slot));
676
+ }, filterFcn);
677
+ }
678
+ *getAsks(marketIndex, fallbackAsk, slot, marketType, oraclePriceData, filterFcn) {
679
+ if ((0, __1.isVariant)(marketType, 'spot') && !oraclePriceData) {
680
+ throw new Error('Must provide OraclePriceData to get spot asks');
681
+ }
682
+ const generatorList = [
683
+ this.getTakingAsks(marketIndex, marketType, slot, oraclePriceData),
684
+ this.getRestingLimitAsks(marketIndex, slot, marketType, oraclePriceData),
685
+ ];
686
+ const marketTypeStr = (0, __1.getVariant)(marketType);
687
+ if (marketTypeStr === 'perp' && fallbackAsk) {
688
+ generatorList.push((0, NodeList_1.getVammNodeGenerator)(fallbackAsk));
689
+ }
690
+ yield* this.getBestNode(generatorList, oraclePriceData, slot, (bestNode, currentNode, slot, oraclePriceData) => {
691
+ const bestNodeTaking = bestNode.order
692
+ ? (0, __1.isTakingOrder)(bestNode.order, slot)
693
+ : false;
694
+ const currentNodeTaking = currentNode.order
695
+ ? (0, __1.isTakingOrder)(currentNode.order, slot)
696
+ : false;
697
+ if (bestNodeTaking && currentNodeTaking) {
698
+ return bestNode.order.slot.lt(currentNode.order.slot);
699
+ }
700
+ if (bestNodeTaking) {
701
+ return true;
702
+ }
703
+ if (currentNodeTaking) {
704
+ return false;
705
+ }
706
+ return bestNode
707
+ .getPrice(oraclePriceData, slot)
708
+ .lt(currentNode.getPrice(oraclePriceData, slot));
709
+ }, filterFcn);
710
+ }
711
+ *getBids(marketIndex, fallbackBid, slot, marketType, oraclePriceData, filterFcn) {
712
+ if ((0, __1.isVariant)(marketType, 'spot') && !oraclePriceData) {
713
+ throw new Error('Must provide OraclePriceData to get spot bids');
714
+ }
715
+ const generatorList = [
716
+ this.getTakingBids(marketIndex, marketType, slot, oraclePriceData),
717
+ this.getRestingLimitBids(marketIndex, slot, marketType, oraclePriceData),
718
+ ];
719
+ const marketTypeStr = (0, __1.getVariant)(marketType);
720
+ if (marketTypeStr === 'perp' && fallbackBid) {
721
+ generatorList.push((0, NodeList_1.getVammNodeGenerator)(fallbackBid));
722
+ }
723
+ yield* this.getBestNode(generatorList, oraclePriceData, slot, (bestNode, currentNode, slot, oraclePriceData) => {
724
+ const bestNodeTaking = bestNode.order
725
+ ? (0, __1.isTakingOrder)(bestNode.order, slot)
726
+ : false;
727
+ const currentNodeTaking = currentNode.order
728
+ ? (0, __1.isTakingOrder)(currentNode.order, slot)
729
+ : false;
730
+ if (bestNodeTaking && currentNodeTaking) {
731
+ return bestNode.order.slot.lt(currentNode.order.slot);
732
+ }
733
+ if (bestNodeTaking) {
734
+ return true;
735
+ }
736
+ if (currentNodeTaking) {
737
+ return false;
738
+ }
739
+ return bestNode
740
+ .getPrice(oraclePriceData, slot)
741
+ .gt(currentNode.getPrice(oraclePriceData, slot));
742
+ }, filterFcn);
743
+ }
744
+ findCrossingRestingLimitOrders(marketIndex, slot, marketType, oraclePriceData) {
745
+ const nodesToFill = new Array();
746
+ for (const askNode of this.getRestingLimitAsks(marketIndex, slot, marketType, oraclePriceData)) {
747
+ const bidGenerator = this.getRestingLimitBids(marketIndex, slot, marketType, oraclePriceData);
748
+ for (const bidNode of bidGenerator) {
749
+ const bidPrice = bidNode.getPrice(oraclePriceData, slot);
750
+ const askPrice = askNode.getPrice(oraclePriceData, slot);
751
+ // orders don't cross
752
+ if (bidPrice.lt(askPrice)) {
753
+ break;
754
+ }
755
+ const bidOrder = bidNode.order;
756
+ const askOrder = askNode.order;
757
+ // Can't match orders from the same user
758
+ const sameUser = bidNode.userAccount === askNode.userAccount;
759
+ if (sameUser) {
760
+ continue;
761
+ }
762
+ const makerAndTaker = this.determineMakerAndTaker(askNode, bidNode);
763
+ // unable to match maker and taker due to post only or slot
764
+ if (!makerAndTaker) {
765
+ continue;
766
+ }
767
+ const { takerNode, makerNode } = makerAndTaker;
768
+ const bidBaseRemaining = bidOrder.baseAssetAmount.sub(bidOrder.baseAssetAmountFilled);
769
+ const askBaseRemaining = askOrder.baseAssetAmount.sub(askOrder.baseAssetAmountFilled);
770
+ const baseFilled = __1.BN.min(bidBaseRemaining, askBaseRemaining);
771
+ const newBidOrder = { ...bidOrder };
772
+ newBidOrder.baseAssetAmountFilled =
773
+ bidOrder.baseAssetAmountFilled.add(baseFilled);
774
+ this.getListForOrder(newBidOrder, slot).update(newBidOrder, bidNode.userAccount);
775
+ // ask completely filled
776
+ const newAskOrder = { ...askOrder };
777
+ newAskOrder.baseAssetAmountFilled =
778
+ askOrder.baseAssetAmountFilled.add(baseFilled);
779
+ this.getListForOrder(newAskOrder, slot).update(newAskOrder, askNode.userAccount);
780
+ nodesToFill.push({
781
+ node: takerNode,
782
+ makerNodes: [makerNode],
783
+ });
784
+ if (newAskOrder.baseAssetAmount.eq(newAskOrder.baseAssetAmountFilled)) {
785
+ break;
786
+ }
787
+ }
788
+ }
789
+ return nodesToFill;
790
+ }
791
+ determineMakerAndTaker(askNode, bidNode) {
792
+ const askSlot = askNode.order.slot.add(new __1.BN(askNode.order.auctionDuration));
793
+ const bidSlot = bidNode.order.slot.add(new __1.BN(bidNode.order.auctionDuration));
794
+ if (bidNode.order.postOnly && askNode.order.postOnly) {
795
+ return undefined;
796
+ }
797
+ else if (bidNode.order.postOnly) {
798
+ return {
799
+ takerNode: askNode,
800
+ makerNode: bidNode,
801
+ };
802
+ }
803
+ else if (askNode.order.postOnly) {
804
+ return {
805
+ takerNode: bidNode,
806
+ makerNode: askNode,
807
+ };
808
+ }
809
+ else if (askSlot.lte(bidSlot)) {
810
+ return {
811
+ takerNode: bidNode,
812
+ makerNode: askNode,
813
+ };
814
+ }
815
+ else {
816
+ return {
817
+ takerNode: askNode,
818
+ makerNode: bidNode,
819
+ };
820
+ }
821
+ }
822
+ getBestAsk(marketIndex, slot, marketType, oraclePriceData) {
823
+ const bestAsk = this.getRestingLimitAsks(marketIndex, slot, marketType, oraclePriceData).next().value;
824
+ if (bestAsk) {
825
+ return bestAsk.getPrice(oraclePriceData, slot);
826
+ }
827
+ return undefined;
828
+ }
829
+ getBestBid(marketIndex, slot, marketType, oraclePriceData) {
830
+ const bestBid = this.getRestingLimitBids(marketIndex, slot, marketType, oraclePriceData).next().value;
831
+ if (bestBid) {
832
+ return bestBid.getPrice(oraclePriceData, slot);
833
+ }
834
+ return undefined;
835
+ }
836
+ *getStopLosses(marketIndex, marketType, direction) {
837
+ const marketTypeStr = (0, __1.getVariant)(marketType);
838
+ const marketNodeLists = this.orderLists.get(marketTypeStr).get(marketIndex);
839
+ if ((0, __1.isVariant)(direction, 'long') && marketNodeLists.trigger.below) {
840
+ for (const node of marketNodeLists.trigger.below.getGenerator()) {
841
+ if ((0, __1.isVariant)(node.order.direction, 'short')) {
842
+ yield node;
843
+ }
844
+ }
845
+ }
846
+ else if ((0, __1.isVariant)(direction, 'short') && marketNodeLists.trigger.above) {
847
+ for (const node of marketNodeLists.trigger.above.getGenerator()) {
848
+ if ((0, __1.isVariant)(node.order.direction, 'long')) {
849
+ yield node;
850
+ }
851
+ }
852
+ }
853
+ }
854
+ *getStopLossMarkets(marketIndex, marketType, direction) {
855
+ for (const node of this.getStopLosses(marketIndex, marketType, direction)) {
856
+ if ((0, __1.isVariant)(node.order.orderType, 'triggerMarket')) {
857
+ yield node;
858
+ }
859
+ }
860
+ }
861
+ *getStopLossLimits(marketIndex, marketType, direction) {
862
+ for (const node of this.getStopLosses(marketIndex, marketType, direction)) {
863
+ if ((0, __1.isVariant)(node.order.orderType, 'triggerLimit')) {
864
+ yield node;
865
+ }
866
+ }
867
+ }
868
+ *getTakeProfits(marketIndex, marketType, direction) {
869
+ const marketTypeStr = (0, __1.getVariant)(marketType);
870
+ const marketNodeLists = this.orderLists.get(marketTypeStr).get(marketIndex);
871
+ if ((0, __1.isVariant)(direction, 'long') && marketNodeLists.trigger.above) {
872
+ for (const node of marketNodeLists.trigger.above.getGenerator()) {
873
+ if ((0, __1.isVariant)(node.order.direction, 'short')) {
874
+ yield node;
875
+ }
876
+ }
877
+ }
878
+ else if ((0, __1.isVariant)(direction, 'short') && marketNodeLists.trigger.below) {
879
+ for (const node of marketNodeLists.trigger.below.getGenerator()) {
880
+ if ((0, __1.isVariant)(node.order.direction, 'long')) {
881
+ yield node;
882
+ }
883
+ }
884
+ }
885
+ }
886
+ *getTakeProfitMarkets(marketIndex, marketType, direction) {
887
+ for (const node of this.getTakeProfits(marketIndex, marketType, direction)) {
888
+ if ((0, __1.isVariant)(node.order.orderType, 'triggerMarket')) {
889
+ yield node;
890
+ }
891
+ }
892
+ }
893
+ *getTakeProfitLimits(marketIndex, marketType, direction) {
894
+ for (const node of this.getTakeProfits(marketIndex, marketType, direction)) {
895
+ if ((0, __1.isVariant)(node.order.orderType, 'triggerLimit')) {
896
+ yield node;
897
+ }
898
+ }
899
+ }
900
+ findNodesToTrigger(marketIndex, slot, oraclePrice, marketType, stateAccount) {
901
+ if ((0, exchangeStatus_1.exchangePaused)(stateAccount)) {
902
+ return [];
903
+ }
904
+ const nodesToTrigger = [];
905
+ const marketTypeStr = (0, __1.getVariant)(marketType);
906
+ const marketNodeLists = this.orderLists.get(marketTypeStr).get(marketIndex);
907
+ const triggerAboveList = marketNodeLists
908
+ ? marketNodeLists.trigger.above
909
+ : undefined;
910
+ if (triggerAboveList) {
911
+ for (const node of triggerAboveList.getGenerator()) {
912
+ if (oraclePrice.gt(node.order.triggerPrice)) {
913
+ nodesToTrigger.push({
914
+ node: node,
915
+ });
916
+ }
917
+ else {
918
+ break;
919
+ }
920
+ }
921
+ }
922
+ const triggerBelowList = marketNodeLists
923
+ ? marketNodeLists.trigger.below
924
+ : undefined;
925
+ if (triggerBelowList) {
926
+ for (const node of triggerBelowList.getGenerator()) {
927
+ if (oraclePrice.lt(node.order.triggerPrice)) {
928
+ nodesToTrigger.push({
929
+ node: node,
930
+ });
931
+ }
932
+ else {
933
+ break;
934
+ }
935
+ }
936
+ }
937
+ return nodesToTrigger;
938
+ }
939
+ printTop(driftClient, slotSubscriber, marketIndex, marketType) {
940
+ if ((0, __1.isVariant)(marketType, 'perp')) {
941
+ const slot = slotSubscriber.getSlot();
942
+ const oraclePriceData = driftClient.getOracleDataForPerpMarket(marketIndex);
943
+ const bestAsk = this.getBestAsk(marketIndex, slot, marketType, oraclePriceData);
944
+ const bestBid = this.getBestBid(marketIndex, slot, marketType, oraclePriceData);
945
+ const mid = bestAsk.add(bestBid).div(new __1.BN(2));
946
+ const bidSpread = ((0, __1.convertToNumber)(bestBid, __1.PRICE_PRECISION) /
947
+ (0, __1.convertToNumber)(oraclePriceData.price, __1.PRICE_PRECISION) -
948
+ 1) *
949
+ 100.0;
950
+ const askSpread = ((0, __1.convertToNumber)(bestAsk, __1.PRICE_PRECISION) /
951
+ (0, __1.convertToNumber)(oraclePriceData.price, __1.PRICE_PRECISION) -
952
+ 1) *
953
+ 100.0;
954
+ const name = (0, __1.decodeName)(driftClient.getPerpMarketAccount(marketIndex).name);
955
+ console.log(`Market ${name} Orders`);
956
+ console.log(` Ask`, (0, __1.convertToNumber)(bestAsk, __1.PRICE_PRECISION).toFixed(3), `(${askSpread.toFixed(4)}%)`);
957
+ console.log(` Mid`, (0, __1.convertToNumber)(mid, __1.PRICE_PRECISION).toFixed(3));
958
+ console.log(` Bid`, (0, __1.convertToNumber)(bestBid, __1.PRICE_PRECISION).toFixed(3), `(${bidSpread.toFixed(4)}%)`);
959
+ }
960
+ else if ((0, __1.isVariant)(marketType, 'spot')) {
961
+ const slot = slotSubscriber.getSlot();
962
+ const oraclePriceData = driftClient.getOracleDataForPerpMarket(marketIndex);
963
+ const bestAsk = this.getBestAsk(marketIndex, slot, marketType, oraclePriceData);
964
+ const bestBid = this.getBestBid(marketIndex, slot, marketType, oraclePriceData);
965
+ const mid = bestAsk.add(bestBid).div(new __1.BN(2));
966
+ const bidSpread = ((0, __1.convertToNumber)(bestBid, __1.PRICE_PRECISION) /
967
+ (0, __1.convertToNumber)(oraclePriceData.price, __1.PRICE_PRECISION) -
968
+ 1) *
969
+ 100.0;
970
+ const askSpread = ((0, __1.convertToNumber)(bestAsk, __1.PRICE_PRECISION) /
971
+ (0, __1.convertToNumber)(oraclePriceData.price, __1.PRICE_PRECISION) -
972
+ 1) *
973
+ 100.0;
974
+ const name = (0, __1.decodeName)(driftClient.getSpotMarketAccount(marketIndex).name);
975
+ console.log(`Market ${name} Orders`);
976
+ console.log(` Ask`, (0, __1.convertToNumber)(bestAsk, __1.PRICE_PRECISION).toFixed(3), `(${askSpread.toFixed(4)}%)`);
977
+ console.log(` Mid`, (0, __1.convertToNumber)(mid, __1.PRICE_PRECISION).toFixed(3));
978
+ console.log(` Bid`, (0, __1.convertToNumber)(bestBid, __1.PRICE_PRECISION).toFixed(3), `(${bidSpread.toFixed(4)}%)`);
979
+ }
980
+ }
981
+ getDLOBOrders() {
982
+ const dlobOrders = [];
983
+ for (const nodeList of this.getNodeLists()) {
984
+ for (const node of nodeList.getGenerator()) {
985
+ dlobOrders.push({
986
+ user: new web3_js_1.PublicKey(node.userAccount),
987
+ order: node.order,
988
+ });
989
+ }
990
+ }
991
+ return dlobOrders;
992
+ }
993
+ *getNodeLists() {
994
+ for (const [_, nodeLists] of this.orderLists.get('perp')) {
995
+ yield nodeLists.restingLimit.bid;
996
+ yield nodeLists.restingLimit.ask;
997
+ yield nodeLists.takingLimit.bid;
998
+ yield nodeLists.takingLimit.ask;
999
+ yield nodeLists.market.bid;
1000
+ yield nodeLists.market.ask;
1001
+ yield nodeLists.floatingLimit.bid;
1002
+ yield nodeLists.floatingLimit.ask;
1003
+ yield nodeLists.trigger.above;
1004
+ yield nodeLists.trigger.below;
1005
+ }
1006
+ for (const [_, nodeLists] of this.orderLists.get('spot')) {
1007
+ yield nodeLists.restingLimit.bid;
1008
+ yield nodeLists.restingLimit.ask;
1009
+ yield nodeLists.takingLimit.bid;
1010
+ yield nodeLists.takingLimit.ask;
1011
+ yield nodeLists.market.bid;
1012
+ yield nodeLists.market.ask;
1013
+ yield nodeLists.floatingLimit.bid;
1014
+ yield nodeLists.floatingLimit.ask;
1015
+ yield nodeLists.trigger.above;
1016
+ yield nodeLists.trigger.below;
1017
+ }
1018
+ }
1019
+ /**
1020
+ * Get an L2 view of the order book for a given market.
1021
+ *
1022
+ * @param marketIndex
1023
+ * @param marketType
1024
+ * @param slot
1025
+ * @param oraclePriceData
1026
+ * @param depth how many levels of the order book to return
1027
+ * @param fallbackL2Generators L2 generators for fallback liquidity e.g. vAMM {@link getVammL2Generator}, openbook {@link SerumSubscriber}
1028
+ */
1029
+ getL2({ marketIndex, marketType, slot, oraclePriceData, depth, fallbackL2Generators = [], }) {
1030
+ const makerAskL2LevelGenerator = (0, orderBookLevels_1.getL2GeneratorFromDLOBNodes)(this.getRestingLimitAsks(marketIndex, slot, marketType, oraclePriceData), oraclePriceData, slot);
1031
+ const fallbackAskGenerators = fallbackL2Generators.map((fallbackL2Generator) => {
1032
+ return fallbackL2Generator.getL2Asks();
1033
+ });
1034
+ const askL2LevelGenerator = (0, orderBookLevels_1.mergeL2LevelGenerators)([makerAskL2LevelGenerator, ...fallbackAskGenerators], (a, b) => {
1035
+ return a.price.lt(b.price);
1036
+ });
1037
+ const asks = (0, orderBookLevels_1.createL2Levels)(askL2LevelGenerator, depth);
1038
+ const makerBidGenerator = (0, orderBookLevels_1.getL2GeneratorFromDLOBNodes)(this.getRestingLimitBids(marketIndex, slot, marketType, oraclePriceData), oraclePriceData, slot);
1039
+ const fallbackBidGenerators = fallbackL2Generators.map((fallbackOrders) => {
1040
+ return fallbackOrders.getL2Bids();
1041
+ });
1042
+ const bidL2LevelGenerator = (0, orderBookLevels_1.mergeL2LevelGenerators)([makerBidGenerator, ...fallbackBidGenerators], (a, b) => {
1043
+ return a.price.gt(b.price);
1044
+ });
1045
+ const bids = (0, orderBookLevels_1.createL2Levels)(bidL2LevelGenerator, depth);
1046
+ return {
1047
+ bids,
1048
+ asks,
1049
+ slot,
1050
+ };
1051
+ }
1052
+ /**
1053
+ * Get an L3 view of the order book for a given market. Does not include fallback liquidity sources
1054
+ *
1055
+ * @param marketIndex
1056
+ * @param marketType
1057
+ * @param slot
1058
+ * @param oraclePriceData
1059
+ */
1060
+ getL3({ marketIndex, marketType, slot, oraclePriceData, }) {
1061
+ const bids = [];
1062
+ const asks = [];
1063
+ const restingAsks = this.getRestingLimitAsks(marketIndex, slot, marketType, oraclePriceData);
1064
+ for (const ask of restingAsks) {
1065
+ asks.push({
1066
+ price: ask.getPrice(oraclePriceData, slot),
1067
+ size: ask.order.baseAssetAmount.sub(ask.order.baseAssetAmountFilled),
1068
+ maker: new web3_js_1.PublicKey(ask.userAccount),
1069
+ orderId: ask.order.orderId,
1070
+ });
1071
+ }
1072
+ const restingBids = this.getRestingLimitBids(marketIndex, slot, marketType, oraclePriceData);
1073
+ for (const bid of restingBids) {
1074
+ bids.push({
1075
+ price: bid.getPrice(oraclePriceData, slot),
1076
+ size: bid.order.baseAssetAmount.sub(bid.order.baseAssetAmountFilled),
1077
+ maker: new web3_js_1.PublicKey(bid.userAccount),
1078
+ orderId: bid.order.orderId,
1079
+ });
1080
+ }
1081
+ return {
1082
+ bids,
1083
+ asks,
1084
+ slot,
1085
+ };
1086
+ }
1087
+ estimateFillExactBaseAmountInForSide(baseAmountIn, oraclePriceData, slot, dlobSide) {
1088
+ let runningSumQuote = __1.ZERO;
1089
+ let runningSumBase = __1.ZERO;
1090
+ for (const side of dlobSide) {
1091
+ const price = side.getPrice(oraclePriceData, slot); //side.order.quoteAssetAmount.div(side.order.baseAssetAmount);
1092
+ const baseAmountRemaining = side.order.baseAssetAmount.sub(side.order.baseAssetAmountFilled);
1093
+ if (runningSumBase.add(baseAmountRemaining).gt(baseAmountIn)) {
1094
+ const remainingBase = baseAmountIn.sub(runningSumBase);
1095
+ runningSumBase = runningSumBase.add(remainingBase);
1096
+ runningSumQuote = runningSumQuote.add(remainingBase.mul(price));
1097
+ break;
1098
+ }
1099
+ else {
1100
+ runningSumBase = runningSumBase.add(baseAmountRemaining);
1101
+ runningSumQuote = runningSumQuote.add(baseAmountRemaining.mul(price));
1102
+ }
1103
+ }
1104
+ return runningSumQuote
1105
+ .mul(__1.QUOTE_PRECISION)
1106
+ .div(__1.BASE_PRECISION.mul(__1.PRICE_PRECISION));
1107
+ }
1108
+ /**
1109
+ *
1110
+ * @param param.marketIndex the index of the market
1111
+ * @param param.marketType the type of the market
1112
+ * @param param.baseAmount the base amount in to estimate
1113
+ * @param param.orderDirection the direction of the trade
1114
+ * @param param.slot current slot for estimating dlob node price
1115
+ * @param param.oraclePriceData the oracle price data
1116
+ * @returns the estimated quote amount filled: QUOTE_PRECISION
1117
+ */
1118
+ estimateFillWithExactBaseAmount({ marketIndex, marketType, baseAmount, orderDirection, slot, oraclePriceData, }) {
1119
+ if ((0, __1.isVariant)(orderDirection, 'long')) {
1120
+ return this.estimateFillExactBaseAmountInForSide(baseAmount, oraclePriceData, slot, this.getRestingLimitAsks(marketIndex, slot, marketType, oraclePriceData));
1121
+ }
1122
+ else if ((0, __1.isVariant)(orderDirection, 'short')) {
1123
+ return this.estimateFillExactBaseAmountInForSide(baseAmount, oraclePriceData, slot, this.getRestingLimitBids(marketIndex, slot, marketType, oraclePriceData));
1124
+ }
1125
+ }
1126
+ getBestMakers({ marketIndex, marketType, direction, slot, oraclePriceData, numMakers, }) {
1127
+ const makers = new Map();
1128
+ const generator = (0, __1.isVariant)(direction, 'long')
1129
+ ? this.getRestingLimitBids(marketIndex, slot, marketType, oraclePriceData)
1130
+ : this.getRestingLimitAsks(marketIndex, slot, marketType, oraclePriceData);
1131
+ for (const node of generator) {
1132
+ if (!makers.has(node.userAccount.toString())) {
1133
+ makers.set(node.userAccount.toString(), new web3_js_1.PublicKey(node.userAccount));
1134
+ }
1135
+ if (makers.size === numMakers) {
1136
+ break;
1137
+ }
1138
+ }
1139
+ return Array.from(makers.values());
1140
+ }
1141
+ }
1142
+ exports.DLOB = DLOB;