@decibeltrade/sdk 0.1.1

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 (294) hide show
  1. package/.turbo/turbo-build.log +4 -0
  2. package/.turbo/turbo-lint$colon$check.log +5 -0
  3. package/.turbo/turbo-lint.log +5 -0
  4. package/decibel_transactions.md +1049 -0
  5. package/dist/abi/abi-manager.d.ts +13 -0
  6. package/dist/abi/abi-manager.d.ts.map +1 -0
  7. package/dist/abi/abi-manager.js +21 -0
  8. package/dist/abi/abis.json +1322 -0
  9. package/dist/abi/bytecode-manager.d.ts +57 -0
  10. package/dist/abi/bytecode-manager.d.ts.map +1 -0
  11. package/dist/abi/bytecode-manager.js +62 -0
  12. package/dist/abi/bytecode.json +24 -0
  13. package/dist/abi/fetch-abis.d.ts +7 -0
  14. package/dist/abi/fetch-abis.d.ts.map +1 -0
  15. package/dist/abi/fetch-abis.js +132 -0
  16. package/dist/abi/fetch-bytecode.d.ts +24 -0
  17. package/dist/abi/fetch-bytecode.d.ts.map +1 -0
  18. package/dist/abi/fetch-bytecode.js +123 -0
  19. package/dist/abi/generate-abis.d.ts +6 -0
  20. package/dist/abi/generate-abis.d.ts.map +1 -0
  21. package/dist/abi/generate-abis.js +170 -0
  22. package/dist/abi/json/netna.json +1323 -0
  23. package/dist/abi/json/testnet.json +1315 -0
  24. package/dist/abi/types.d.ts +22 -0
  25. package/dist/abi/types.d.ts.map +1 -0
  26. package/dist/abi/types.js +2 -0
  27. package/dist/admin.d.ts +29 -0
  28. package/dist/admin.d.ts.map +1 -0
  29. package/dist/admin.js +203 -0
  30. package/dist/base.d.ts +42 -0
  31. package/dist/base.d.ts.map +1 -0
  32. package/dist/base.js +176 -0
  33. package/dist/constants.d.ts +41 -0
  34. package/dist/constants.d.ts.map +1 -0
  35. package/dist/constants.js +78 -0
  36. package/dist/fee-pay.d.ts +11 -0
  37. package/dist/fee-pay.d.ts.map +1 -0
  38. package/dist/fee-pay.js +30 -0
  39. package/dist/gas/gas-price-manager.d.ts +35 -0
  40. package/dist/gas/gas-price-manager.d.ts.map +1 -0
  41. package/dist/gas/gas-price-manager.js +93 -0
  42. package/dist/gas-price-manager.d.ts +31 -0
  43. package/dist/gas-price-manager.d.ts.map +1 -0
  44. package/dist/gas-price-manager.js +84 -0
  45. package/dist/index.d.ts +11 -0
  46. package/dist/index.d.ts.map +1 -0
  47. package/dist/index.js +26 -0
  48. package/dist/order-event.types.d.ts +55 -0
  49. package/dist/order-event.types.d.ts.map +1 -0
  50. package/dist/order-event.types.js +3 -0
  51. package/dist/order-status.d.ts +43 -0
  52. package/dist/order-status.d.ts.map +1 -0
  53. package/dist/order-status.js +86 -0
  54. package/dist/read/account-overview/account-overview.reader.d.ts +37 -0
  55. package/dist/read/account-overview/account-overview.reader.d.ts.map +1 -0
  56. package/dist/read/account-overview/account-overview.reader.js +35 -0
  57. package/dist/read/account-overview/account-overview.types.d.ts +52 -0
  58. package/dist/read/account-overview/account-overview.types.d.ts.map +1 -0
  59. package/dist/read/account-overview/account-overview.types.js +36 -0
  60. package/dist/read/api-wallets/api-wallets.reader.d.ts +17 -0
  61. package/dist/read/api-wallets/api-wallets.reader.d.ts.map +1 -0
  62. package/dist/read/api-wallets/api-wallets.reader.js +27 -0
  63. package/dist/read/api-wallets/api-wallets.types.d.ts +17 -0
  64. package/dist/read/api-wallets/api-wallets.types.d.ts.map +1 -0
  65. package/dist/read/api-wallets/api-wallets.types.js +13 -0
  66. package/dist/read/base-reader.d.ts +22 -0
  67. package/dist/read/base-reader.d.ts.map +1 -0
  68. package/dist/read/base-reader.js +29 -0
  69. package/dist/read/candlesticks/candlesticks.reader.d.ts +31 -0
  70. package/dist/read/candlesticks/candlesticks.reader.d.ts.map +1 -0
  71. package/dist/read/candlesticks/candlesticks.reader.js +43 -0
  72. package/dist/read/candlesticks/candlesticks.types.d.ts +45 -0
  73. package/dist/read/candlesticks/candlesticks.types.d.ts.map +1 -0
  74. package/dist/read/candlesticks/candlesticks.types.js +36 -0
  75. package/dist/read/delegations/delegations.reader.d.ts +15 -0
  76. package/dist/read/delegations/delegations.reader.d.ts.map +1 -0
  77. package/dist/read/delegations/delegations.reader.js +23 -0
  78. package/dist/read/delegations/delegations.types.d.ts +17 -0
  79. package/dist/read/delegations/delegations.types.d.ts.map +1 -0
  80. package/dist/read/delegations/delegations.types.js +13 -0
  81. package/dist/read/index.d.ts +105 -0
  82. package/dist/read/index.d.ts.map +1 -0
  83. package/dist/read/index.js +244 -0
  84. package/dist/read/leaderboard/leaderboard.reader.d.ts +21 -0
  85. package/dist/read/leaderboard/leaderboard.reader.d.ts.map +1 -0
  86. package/dist/read/leaderboard/leaderboard.reader.js +22 -0
  87. package/dist/read/leaderboard/leaderboard.types.d.ts +27 -0
  88. package/dist/read/leaderboard/leaderboard.types.d.ts.map +1 -0
  89. package/dist/read/leaderboard/leaderboard.types.js +14 -0
  90. package/dist/read/market-contexts/market-contexts.reader.d.ts +22 -0
  91. package/dist/read/market-contexts/market-contexts.reader.d.ts.map +1 -0
  92. package/dist/read/market-contexts/market-contexts.reader.js +27 -0
  93. package/dist/read/market-contexts/market-contexts.types.d.ts +26 -0
  94. package/dist/read/market-contexts/market-contexts.types.d.ts.map +1 -0
  95. package/dist/read/market-contexts/market-contexts.types.js +19 -0
  96. package/dist/read/market-depth/market-depth.reader.d.ts +30 -0
  97. package/dist/read/market-depth/market-depth.reader.d.ts.map +1 -0
  98. package/dist/read/market-depth/market-depth.reader.js +46 -0
  99. package/dist/read/market-depth/market-depth.types.d.ts +20 -0
  100. package/dist/read/market-depth/market-depth.types.d.ts.map +1 -0
  101. package/dist/read/market-depth/market-depth.types.js +16 -0
  102. package/dist/read/market-prices/market-prices.reader.d.ts +44 -0
  103. package/dist/read/market-prices/market-prices.reader.d.ts.map +1 -0
  104. package/dist/read/market-prices/market-prices.reader.js +51 -0
  105. package/dist/read/market-prices/market-prices.types.d.ts +48 -0
  106. package/dist/read/market-prices/market-prices.types.d.ts.map +1 -0
  107. package/dist/read/market-prices/market-prices.types.js +26 -0
  108. package/dist/read/market-trades/market-trades.reader.d.ts +33 -0
  109. package/dist/read/market-trades/market-trades.reader.d.ts.map +1 -0
  110. package/dist/read/market-trades/market-trades.reader.js +39 -0
  111. package/dist/read/market-trades/market-trades.types.d.ts +52 -0
  112. package/dist/read/market-trades/market-trades.types.d.ts.map +1 -0
  113. package/dist/read/market-trades/market-trades.types.js +23 -0
  114. package/dist/read/markets/markets.reader.d.ts +38 -0
  115. package/dist/read/markets/markets.reader.d.ts.map +1 -0
  116. package/dist/read/markets/markets.reader.js +80 -0
  117. package/dist/read/markets/markets.types.d.ts +82 -0
  118. package/dist/read/markets/markets.types.d.ts.map +1 -0
  119. package/dist/read/markets/markets.types.js +46 -0
  120. package/dist/read/pagination.types.d.ts +14 -0
  121. package/dist/read/pagination.types.d.ts.map +1 -0
  122. package/dist/read/pagination.types.js +12 -0
  123. package/dist/read/portfolio-chart/portfolio-chart.reader.d.ts +14 -0
  124. package/dist/read/portfolio-chart/portfolio-chart.reader.d.ts.map +1 -0
  125. package/dist/read/portfolio-chart/portfolio-chart.reader.js +21 -0
  126. package/dist/read/portfolio-chart/portfolio-chart.types.d.ts +14 -0
  127. package/dist/read/portfolio-chart/portfolio-chart.types.d.ts.map +1 -0
  128. package/dist/read/portfolio-chart/portfolio-chart.types.js +12 -0
  129. package/dist/read/public-vaults/public-vaults.reader.d.ts +38 -0
  130. package/dist/read/public-vaults/public-vaults.reader.d.ts.map +1 -0
  131. package/dist/read/public-vaults/public-vaults.reader.js +31 -0
  132. package/dist/read/public-vaults/public-vaults.types.d.ts +62 -0
  133. package/dist/read/public-vaults/public-vaults.types.d.ts.map +1 -0
  134. package/dist/read/public-vaults/public-vaults.types.js +33 -0
  135. package/dist/read/types.d.ts +178 -0
  136. package/dist/read/types.d.ts.map +1 -0
  137. package/dist/read/types.js +87 -0
  138. package/dist/read/user-active-twaps/user-active-twaps.reader.d.ts +31 -0
  139. package/dist/read/user-active-twaps/user-active-twaps.reader.d.ts.map +1 -0
  140. package/dist/read/user-active-twaps/user-active-twaps.reader.js +31 -0
  141. package/dist/read/user-active-twaps/user-active-twaps.types.d.ts +49 -0
  142. package/dist/read/user-active-twaps/user-active-twaps.types.d.ts.map +1 -0
  143. package/dist/read/user-active-twaps/user-active-twaps.types.js +25 -0
  144. package/dist/read/user-bulk-orders/user-bulk-orders.reader.d.ts +31 -0
  145. package/dist/read/user-bulk-orders/user-bulk-orders.reader.d.ts.map +1 -0
  146. package/dist/read/user-bulk-orders/user-bulk-orders.reader.js +32 -0
  147. package/dist/read/user-bulk-orders/user-bulk-orders.types.d.ts +46 -0
  148. package/dist/read/user-bulk-orders/user-bulk-orders.types.d.ts.map +1 -0
  149. package/dist/read/user-bulk-orders/user-bulk-orders.types.js +24 -0
  150. package/dist/read/user-funding-history/user-funding-history.reader.d.ts +28 -0
  151. package/dist/read/user-funding-history/user-funding-history.reader.d.ts.map +1 -0
  152. package/dist/read/user-funding-history/user-funding-history.reader.js +32 -0
  153. package/dist/read/user-funding-history/user-funding-history.types.d.ts +37 -0
  154. package/dist/read/user-funding-history/user-funding-history.types.d.ts.map +1 -0
  155. package/dist/read/user-funding-history/user-funding-history.types.js +21 -0
  156. package/dist/read/user-notifications/user-notifications.reader.d.ts +13 -0
  157. package/dist/read/user-notifications/user-notifications.reader.d.ts.map +1 -0
  158. package/dist/read/user-notifications/user-notifications.reader.js +19 -0
  159. package/dist/read/user-notifications/user-notifications.types.d.ts +49 -0
  160. package/dist/read/user-notifications/user-notifications.types.d.ts.map +1 -0
  161. package/dist/read/user-notifications/user-notifications.types.js +18 -0
  162. package/dist/read/user-open-orders/user-open-orders.reader.d.ts +40 -0
  163. package/dist/read/user-open-orders/user-open-orders.reader.d.ts.map +1 -0
  164. package/dist/read/user-open-orders/user-open-orders.reader.js +31 -0
  165. package/dist/read/user-open-orders/user-open-orders.types.d.ts +76 -0
  166. package/dist/read/user-open-orders/user-open-orders.types.d.ts.map +1 -0
  167. package/dist/read/user-open-orders/user-open-orders.types.js +34 -0
  168. package/dist/read/user-order-history/user-order-history.reader.d.ts +40 -0
  169. package/dist/read/user-order-history/user-order-history.reader.d.ts.map +1 -0
  170. package/dist/read/user-order-history/user-order-history.reader.js +28 -0
  171. package/dist/read/user-order-history/user-order-history.types.d.ts +85 -0
  172. package/dist/read/user-order-history/user-order-history.types.d.ts.map +1 -0
  173. package/dist/read/user-order-history/user-order-history.types.js +37 -0
  174. package/dist/read/user-positions/user-positions.reader.d.ts +37 -0
  175. package/dist/read/user-positions/user-positions.reader.d.ts.map +1 -0
  176. package/dist/read/user-positions/user-positions.reader.js +41 -0
  177. package/dist/read/user-positions/user-positions.types.d.ts +2590 -0
  178. package/dist/read/user-positions/user-positions.types.d.ts.map +1 -0
  179. package/dist/read/user-positions/user-positions.types.js +31 -0
  180. package/dist/read/user-subaccounts/user-subaccounts.reader.d.ts +18 -0
  181. package/dist/read/user-subaccounts/user-subaccounts.reader.d.ts.map +1 -0
  182. package/dist/read/user-subaccounts/user-subaccounts.reader.js +28 -0
  183. package/dist/read/user-subaccounts/user-subaccounts.types.d.ts +21 -0
  184. package/dist/read/user-subaccounts/user-subaccounts.types.d.ts.map +1 -0
  185. package/dist/read/user-subaccounts/user-subaccounts.types.js +15 -0
  186. package/dist/read/user-trade-history/user-trade-history.reader.d.ts +33 -0
  187. package/dist/read/user-trade-history/user-trade-history.reader.d.ts.map +1 -0
  188. package/dist/read/user-trade-history/user-trade-history.reader.js +32 -0
  189. package/dist/read/user-trade-history/user-trade-history.types.d.ts +52 -0
  190. package/dist/read/user-trade-history/user-trade-history.types.d.ts.map +1 -0
  191. package/dist/read/user-trade-history/user-trade-history.types.js +26 -0
  192. package/dist/read/user-vaults/user-vaults.reader.d.ts +26 -0
  193. package/dist/read/user-vaults/user-vaults.reader.d.ts.map +1 -0
  194. package/dist/read/user-vaults/user-vaults.reader.js +32 -0
  195. package/dist/read/user-vaults/user-vaults.types.d.ts +39 -0
  196. package/dist/read/user-vaults/user-vaults.types.d.ts.map +1 -0
  197. package/dist/read/user-vaults/user-vaults.types.js +21 -0
  198. package/dist/read/vault/vault.reader.d.ts +95 -0
  199. package/dist/read/vault/vault.reader.d.ts.map +1 -0
  200. package/dist/read/vault/vault.reader.js +168 -0
  201. package/dist/read/vault/vault.types.d.ts +49 -0
  202. package/dist/read/vault/vault.types.d.ts.map +1 -0
  203. package/dist/read/vault/vault.types.js +45 -0
  204. package/dist/read/vaults/vaults.reader.d.ts +72 -0
  205. package/dist/read/vaults/vaults.reader.d.ts.map +1 -0
  206. package/dist/read/vaults/vaults.reader.js +63 -0
  207. package/dist/read/vaults/vaults.types.d.ts +140 -0
  208. package/dist/read/vaults/vaults.types.d.ts.map +1 -0
  209. package/dist/read/vaults/vaults.types.js +71 -0
  210. package/dist/read/ws-subscription.d.ts +21 -0
  211. package/dist/read/ws-subscription.d.ts.map +1 -0
  212. package/dist/read/ws-subscription.js +170 -0
  213. package/dist/subaccount-types.d.ts +24 -0
  214. package/dist/subaccount-types.d.ts.map +1 -0
  215. package/dist/subaccount-types.js +11 -0
  216. package/dist/transaction-builder.d.ts +14 -0
  217. package/dist/transaction-builder.d.ts.map +1 -0
  218. package/dist/transaction-builder.js +40 -0
  219. package/dist/tsconfig.tsbuildinfo +1 -0
  220. package/dist/utils.d.ts +56 -0
  221. package/dist/utils.d.ts.map +1 -0
  222. package/dist/utils.js +164 -0
  223. package/dist/vault-types.d.ts +43 -0
  224. package/dist/vault-types.d.ts.map +1 -0
  225. package/dist/vault-types.js +11 -0
  226. package/dist/write.d.ts +271 -0
  227. package/dist/write.d.ts.map +1 -0
  228. package/dist/write.js +485 -0
  229. package/eslint.config.mjs +25 -0
  230. package/package.json +39 -0
  231. package/readme.md +257 -0
  232. package/sdk_reference.md +876 -0
  233. package/src/abi/generate-abis.ts +164 -0
  234. package/src/abi/json/netna.json +1323 -0
  235. package/src/abi/json/testnet.json +1315 -0
  236. package/src/abi/types.ts +23 -0
  237. package/src/admin.ts +284 -0
  238. package/src/base.ts +218 -0
  239. package/src/constants.ts +118 -0
  240. package/src/fee-pay.ts +39 -0
  241. package/src/gas/gas-price-manager.ts +115 -0
  242. package/src/index.ts +10 -0
  243. package/src/order-event.types.ts +65 -0
  244. package/src/order-status.ts +89 -0
  245. package/src/read/account-overview/account-overview.reader.ts +43 -0
  246. package/src/read/account-overview/account-overview.types.ts +45 -0
  247. package/src/read/base-reader.ts +41 -0
  248. package/src/read/candlesticks/candlesticks.reader.ts +61 -0
  249. package/src/read/candlesticks/candlesticks.types.ts +46 -0
  250. package/src/read/delegations/delegations.reader.ts +22 -0
  251. package/src/read/delegations/delegations.types.ts +19 -0
  252. package/src/read/index.ts +271 -0
  253. package/src/read/leaderboard/leaderboard.reader.ts +21 -0
  254. package/src/read/leaderboard/leaderboard.types.ts +26 -0
  255. package/src/read/market-contexts/market-contexts.reader.ts +26 -0
  256. package/src/read/market-contexts/market-contexts.types.ts +18 -0
  257. package/src/read/market-depth/market-depth.reader.ts +60 -0
  258. package/src/read/market-depth/market-depth.types.ts +24 -0
  259. package/src/read/market-prices/market-prices.reader.ts +61 -0
  260. package/src/read/market-prices/market-prices.types.ts +38 -0
  261. package/src/read/market-trades/market-trades.reader.ts +46 -0
  262. package/src/read/market-trades/market-trades.types.ts +34 -0
  263. package/src/read/markets/markets.reader.ts +82 -0
  264. package/src/read/markets/markets.types.ts +54 -0
  265. package/src/read/pagination.types.ts +18 -0
  266. package/src/read/portfolio-chart/portfolio-chart.reader.ts +20 -0
  267. package/src/read/portfolio-chart/portfolio-chart.types.ts +21 -0
  268. package/src/read/types.ts +129 -0
  269. package/src/read/user-active-twaps/user-active-twaps.reader.ts +36 -0
  270. package/src/read/user-active-twaps/user-active-twaps.types.ts +33 -0
  271. package/src/read/user-bulk-orders/user-bulk-orders.reader.ts +37 -0
  272. package/src/read/user-bulk-orders/user-bulk-orders.types.ts +32 -0
  273. package/src/read/user-funding-history/user-funding-history.reader.ts +38 -0
  274. package/src/read/user-funding-history/user-funding-history.types.ts +29 -0
  275. package/src/read/user-notifications/user-notifications.reader.ts +17 -0
  276. package/src/read/user-notifications/user-notifications.types.ts +61 -0
  277. package/src/read/user-open-orders/user-open-orders.reader.ts +36 -0
  278. package/src/read/user-open-orders/user-open-orders.types.ts +42 -0
  279. package/src/read/user-order-history/user-order-history.reader.ts +34 -0
  280. package/src/read/user-order-history/user-order-history.types.ts +44 -0
  281. package/src/read/user-positions/user-positions.reader.ts +55 -0
  282. package/src/read/user-positions/user-positions.types.ts +43 -0
  283. package/src/read/user-subaccounts/user-subaccounts.reader.ts +30 -0
  284. package/src/read/user-subaccounts/user-subaccounts.types.ts +21 -0
  285. package/src/read/user-trade-history/user-trade-history.reader.ts +38 -0
  286. package/src/read/user-trade-history/user-trade-history.types.ts +33 -0
  287. package/src/read/vaults/vaults.reader.ts +79 -0
  288. package/src/read/vaults/vaults.types.ts +106 -0
  289. package/src/read/ws-subscription.ts +200 -0
  290. package/src/subaccount-types.ts +31 -0
  291. package/src/transaction-builder.ts +75 -0
  292. package/src/utils.ts +255 -0
  293. package/src/write.ts +965 -0
  294. package/tsconfig.json +8 -0
package/readme.md ADDED
@@ -0,0 +1,257 @@
1
+ # @decibeltrade/sdk
2
+
3
+ TypeScript SDK for interacting with Decibel, a fully on-chain trading engine built on Aptos.
4
+
5
+ **📚 [View Full Documentation →](https://docs.decibel.trade)**
6
+
7
+ ## Overview
8
+
9
+ The Decibel TypeScript SDK provides a clean, typed interface to interact with Decibel on Aptos:
10
+
11
+ - **Read operations** (`DecibelReadDex`) — Query markets, depth, prices, trades, positions, orders, subaccounts, vaults
12
+ - **Write operations** (`DecibelWriteDex`) — Place/cancel orders, manage positions and subaccounts, vault operations, delegation
13
+
14
+ ## Installation
15
+
16
+ ```bash
17
+ npm install @decibeltrade/sdk @aptos-labs/ts-sdk zod
18
+ ```
19
+
20
+ ```bash
21
+ yarn add @decibeltrade/sdk @aptos-labs/ts-sdk zod
22
+ ```
23
+
24
+ ```bash
25
+ pnpm add @decibeltrade/sdk @aptos-labs/ts-sdk zod
26
+ ```
27
+
28
+ For TypeScript in Node.js environments, you may also want:
29
+
30
+ ```bash
31
+ npm install -D @types/ws
32
+ ```
33
+
34
+ ## Quick Start
35
+
36
+ ### Read: Market and Account Data
37
+
38
+ ```typescript
39
+ import { DecibelReadDex, NETNA_CONFIG } from "@decibeltrade/sdk";
40
+
41
+ const read = new DecibelReadDex(NETNA_CONFIG, {
42
+ nodeApiKey: process.env.APTOS_NODE_API_KEY, // required
43
+ });
44
+
45
+ // Get all markets
46
+ const markets = await read.markets.getAll();
47
+
48
+ // Get account overview
49
+ const account = await read.accountOverview.getByAddr("0x...account");
50
+
51
+ // Get market prices
52
+ const prices = await read.marketPrices.getAll();
53
+
54
+ // Get order book depth
55
+ const depth = await read.marketDepth.getBySymbol("BTC-PERP", { depth: 10 });
56
+ ```
57
+
58
+ ### Write: Submit Transactions
59
+
60
+ ```typescript
61
+ import { DecibelWriteDex, NETNA_CONFIG } from "@decibeltrade/sdk";
62
+ import { Ed25519Account, Ed25519PrivateKey } from "@aptos-labs/ts-sdk";
63
+
64
+ const account = new Ed25519Account({
65
+ privateKey: new Ed25519PrivateKey(process.env.PRIVATE_KEY!),
66
+ });
67
+
68
+ const write = new DecibelWriteDex(NETNA_CONFIG, account, {
69
+ nodeApiKey: process.env.APTOS_NODE_API_KEY, // optional
70
+ });
71
+
72
+ // Place an order
73
+ const order = await write.placeOrder({
74
+ subaccountAddr: "0x...",
75
+ marketAddr: "0x...",
76
+ price: 5670000000, // 5.67 with 9 decimals
77
+ size: 1000000000, // 1.0 with 9 decimals
78
+ isBuy: true,
79
+ timeInForce: 0, // GoodTillCanceled
80
+ });
81
+ ```
82
+
83
+ ## Documentation
84
+
85
+ ### Getting Started
86
+
87
+ - [SDK Overview](https://docs.decibel.trade/typescript-sdk/overview) - Introduction to the TypeScript SDK
88
+ - [Installation](https://docs.decibel.trade/typescript-sdk/installation) - Install and configure the SDK
89
+ - [Configuration](https://docs.decibel.trade/typescript-sdk/configuration) - Network configuration and presets
90
+
91
+ ### Read SDK
92
+
93
+ - [Read SDK Guide](https://docs.decibel.trade/typescript-sdk/read-sdk) - Query market data and account information
94
+ - Market data (prices, depth, trades, candlesticks)
95
+ - Account overview and positions
96
+ - Order history and open orders
97
+ - Subaccounts and delegations
98
+ - Vault information
99
+
100
+ ### Write SDK
101
+
102
+ - [Write SDK Guide](https://docs.decibel.trade/typescript-sdk/write-sdk) - Build and submit transactions
103
+ - Place and cancel orders
104
+ - TWAP and bulk orders
105
+ - Position management (TP/SL)
106
+ - Subaccount management
107
+ - Vault operations
108
+ - Delegation
109
+
110
+ ### Advanced
111
+
112
+ - [Advanced Usage](https://docs.decibel.trade/typescript-sdk/advanced) - Advanced SDK features and patterns
113
+
114
+ ## Configuration
115
+
116
+ The SDK supports multiple network configurations:
117
+
118
+ ```typescript
119
+ import { NETNA_CONFIG, TESTNET_CONFIG, LOCAL_CONFIG } from "@decibeltrade/sdk";
120
+
121
+ // Netna (devnet)
122
+ const read = new DecibelReadDex(NETNA_CONFIG);
123
+
124
+ // Testnet
125
+ const read = new DecibelReadDex(TESTNET_CONFIG);
126
+
127
+ // Local development
128
+ const read = new DecibelReadDex(LOCAL_CONFIG);
129
+ ```
130
+
131
+ ### Custom Configuration
132
+
133
+ ```typescript
134
+ import { DecibelConfig } from "@decibeltrade/sdk";
135
+ import { Network } from "@aptos-labs/ts-sdk";
136
+
137
+ const customConfig: DecibelConfig = {
138
+ network: Network.CUSTOM,
139
+ fullnodeUrl: "https://api.testnet.aptoslabs.com/v1",
140
+ tradingHttpUrl: "https://api.testnet.aptoslabs.com/decibel",
141
+ tradingWsUrl: "wss://api.testnet.aptoslabs.com/decibel/ws",
142
+ // ... other config options
143
+ };
144
+ ```
145
+
146
+ ## When to Use Which
147
+
148
+ - **Use `DecibelReadDex`** when you need market data, order/position history, or account state. No private keys required.
149
+ - **Use `DecibelWriteDex`** for on-chain actions and trading. In browsers, avoid embedding private keys — prefer session keys or a wallet and pass `accountOverride` for specific calls.
150
+
151
+ ## WebSocket Subscriptions
152
+
153
+ The SDK supports real-time WebSocket subscriptions:
154
+
155
+ ```typescript
156
+ import { DecibelReadDex, NETNA_CONFIG } from "@decibeltrade/sdk";
157
+
158
+ const read = new DecibelReadDex(NETNA_CONFIG);
159
+
160
+ // Subscribe to market prices
161
+ const subscription = read.subscribe("all_market_prices", (data) => {
162
+ console.log("Market prices:", data);
163
+ });
164
+
165
+ // Unsubscribe when done
166
+ subscription.unsubscribe();
167
+ ```
168
+
169
+ ## Examples
170
+
171
+ ### Get Market Data
172
+
173
+ ```typescript
174
+ const markets = await read.markets.getAll();
175
+ const btcMarket = await read.markets.getBySymbol("BTC-PERP");
176
+ const prices = await read.marketPrices.getAll();
177
+ const depth = await read.marketDepth.getBySymbol("BTC-PERP", { depth: 20 });
178
+ ```
179
+
180
+ ### Get Account Information
181
+
182
+ ```typescript
183
+ const account = await read.accountOverview.getByAddr(accountAddress);
184
+ const positions = await read.userPositions.getByAddr(accountAddress);
185
+ const openOrders = await read.userOpenOrders.getByAddr(accountAddress);
186
+ const subaccounts = await read.userSubaccounts.getByAddr(accountAddress);
187
+ ```
188
+
189
+ ### Place an Order
190
+
191
+ ```typescript
192
+ const order = await write.placeOrder({
193
+ subaccountAddr: subaccountAddress,
194
+ marketAddr: marketAddress,
195
+ price: 5670000000, // 5.67 with 9 decimals
196
+ size: 1000000000, // 1.0 with 9 decimals
197
+ isBuy: true,
198
+ timeInForce: 0, // GoodTillCanceled
199
+ isReduceOnly: false,
200
+ });
201
+ ```
202
+
203
+ ### Place a TWAP Order
204
+
205
+ ```typescript
206
+ const twapOrder = await write.placeTwapOrder({
207
+ subaccountAddr: subaccountAddress,
208
+ marketAddr: marketAddress,
209
+ totalSize: 10000000000, // 10.0 with 9 decimals
210
+ duration: 3600, // 1 hour in seconds
211
+ interval: 60, // 1 minute intervals
212
+ isBuy: true,
213
+ });
214
+ ```
215
+
216
+ ## API Reference
217
+
218
+ ### DecibelReadDex
219
+
220
+ - `markets` - Market information and listings
221
+ - `marketPrices` - Real-time and historical prices
222
+ - `marketDepth` - Order book depth
223
+ - `marketTrades` - Recent trades
224
+ - `candlesticks` - OHLCV candlestick data
225
+ - `accountOverview` - Account summary and equity
226
+ - `userPositions` - User positions
227
+ - `userOpenOrders` - Open orders
228
+ - `userOrderHistory` - Order history
229
+ - `userTradeHistory` - Trade history
230
+ - `userSubaccounts` - Subaccount management
231
+ - `userVaults` - Vault positions
232
+ - `vaults` - Public vault information
233
+ - `subscribe()` - WebSocket subscriptions
234
+
235
+ ### DecibelWriteDex
236
+
237
+ - `placeOrder()` - Place a limit or market order
238
+ - `cancelOrder()` - Cancel an order
239
+ - `placeTwapOrder()` - Place a TWAP order
240
+ - `cancelTwapOrder()` - Cancel a TWAP order
241
+ - `placeBulkOrder()` - Place multiple orders
242
+ - `cancelBulkOrder()` - Cancel multiple orders
243
+ - `placeTpSlOrder()` - Place TP/SL orders
244
+ - `updateTpOrder()` - Update take profit order
245
+ - `updateSlOrder()` - Update stop loss order
246
+ - `createSubaccount()` - Create a new subaccount
247
+ - `deposit()` - Deposit funds
248
+ - `withdraw()` - Withdraw funds
249
+ - `delegateTrading()` - Delegate trading permissions
250
+
251
+ ## Resources
252
+
253
+ - 📚 [Full Documentation](https://docs.decibel.trade) - Complete API and transaction documentation
254
+ - 🔌 [REST API](https://docs.decibel.trade/api-reference/user/get-account-overview) - REST API reference
255
+ - 🔌 [WebSocket API](https://docs.decibel.trade/api-reference/websockets/bulkorderfills) - WebSocket API reference
256
+ - 💬 [Discord](https://discord.gg/decibel) - Join our community for support
257
+ - 🌐 [Trading Platform](https://app.decibel.trade) - Access the Decibel trading platform