API trading on OKX — Capabilities and benefits of API v5 upgrade
An overview of API trading and OKX’s latest API interface
Typically, trading requires the use of an exchange platform for screening stocks or digital assets like Bitcoin. A trader finds an asset to trade, observes the price quote, chart and the order book, and then places a market, limit or stop order via the interface.
This, in itself, is a major advancement over the stock trading systems of the past but is still not the most efficient process, particularly for high-frequency trading. The needs of advanced traders today are met by automated or algorithmic trading systems, which allow traders to program their strategies and set them to execute and adapt to market conditions without continuous human input.
API, or an application programming interface, is at the core of such automated trading systems and is essentially a set of programming code that allows software platforms to share data and communicate effectively in real-time.
Algo trading firms and professional traders are the main users of API trading, while retail traders can also make use of API connections for their portfolio-management apps or trading via third-party software.
In order to meet the needs of its users, OKX offers advanced API functionality and continues to upgrade it. In this article, we will provide a brief introduction to API trading on OKX as well as an overview of the new OKX API v5 upgrade.
API trading basics
There are three essential tools when it comes to API trading:
- API keys
- API documentation
- Connection interfaces
API keys are unique identifiers that authenticate traders and developers who access the exchange’s API. In simple terms, API keys, consisting of a public key and a secret key, work much like a username and password combination.
The API documentation contains technical information on how to use and integrate an API — essentially acting as a reference manual for developers and traders alike.
There are two main types of APIs — REST and WebSocket. REST stands for Representational State Transfer and is the most common web service that supports a variety of formats under HTTP — such as JSON and XML. WebSocket is a new HTML5 protocol that enables efficient data transmission between client and server. This is particularly useful for developers intending to program and connect scripts, bots or other software with an exchange.
API trading on OKX
OKX offers three categories of API trading: account, trading and market trends. In the account and trading modules, users can place orders, enquire about order status and account information. In addition, OKX users can access historical price data of trading pairs via the publicly available market data API.
OKX supports both REST and WebSocket API for its users in API v3, and traders can use the API for five trading products, including spot, margin, futures, perpetual swaps and options.
While API v3 is accessible to both retail and institutional traders, in a bid to continue improving user experience, OKX has been working on an upgrade to its API system to improve capital efficiency, error-reporting mechanisms and much more.
OKX API v5
To offer a more seamless trading experience for users, OKX has launched its new API v5, which is currently available for all Unified Account users. Being a significant upgrade from v3 (v4 was skipped because “4” is considered an unlucky number in various East Asian regions), v5 makes key improvements in the following areas:
- Enhanced efficiency in capital allocation
- Simultaneous support multiple trading products
- Order operation in both REST and WebSocket API
- A unified JSON format for error reporting
- More flexible WebSocket subscription and pushing in regular intervals
In this article, we compare the functionality of both API v3 and v5 and how API trading is improved in the new version.
Functional upgrades in v5
The functionality upgrades of API v5 apply to all API users. These pertain to account fund usage, support for multiple business lines and more.
Account funds usage
In API v3, there is a corresponding account for each business line. This means that users need to transfer their funds from one trading product to another. The frequent transfer of funds is time-consuming and reduces capital efficiency for users. Moreover, the fund transfer between different trading product accounts is limited to once per second.
Traders can leverage greater capital efficiency when using API v5. Similar to OKX’s Unified Account, traders using API v5 will be able to utilize their funds in one account. In addition, the profits and losses of various positions in v5 are also consolidated according to the user’s account mode — thereby improving capital efficiency.
Unified API across products
Unlike API v3, the endpoints in API v5, such as those for placing orders and retrieving positions, are unified across products. The same request and response data models are used across all instrument types in the same API, which means we no longer need to model each of the product APIs separately.
Order operations
Order operations include placing new orders, order amendments and order cancellations. While only the REST API in v3 supports order operations, the new API v5 allows both REST and WebSocket APIs to support order operations.
Scenario-based upgrades
Scenario-based upgrades refer to upgrades in a specific function or format. This includes order mode upgrades and format upgrades of time function and REST response function.
Order placement mode
API v3 supports only opening and closing positions — and if users hold both long and short positions in the same derivative contract, these positions are viewed separately and cannot be offset against each other.
In conjunction with Unified Accounts, API v5 includes a new net mode for users. This means that various long and short positions in the same trading pair or instrument can be offset against each other, and users can view the net positions.
WebSocket subscription function
The subscription function enables users to fetch data. Compared to API v3, API v5 enables users to subscribe to multiple trading pairs simultaneously.
Moreover, API v5 pushes in regular intervals for Account and Position channels, which is more user-friendly for risk management.
Format of REST response
Response refers to the data returned to users when they attempt to retrieve information. There are two REST response formats in API v3 — normal return format and error reporting format. These two formats are incompatible in the same interface, causing inconvenience to users. On the contrary, API v5 follows a unified JSON format for REST response.
Private liquidation order
In API v3, users cannot view the status of private liquidation orders directly. They need to do so by connecting endpoints from the REST API.
The order channel of API v5 supports private liquidation orders. Users can view the status directly, and the “Category” field indicates whether the order is a partial or a full liquidation one.
Number of opened contracts
When users in API v3 want to view the number of opened contracts, they need to send requests to the WebSocket account channel to view it.
Reading the number of opened contracts is more straightforward in API v5, as users can obtain such information through the “Get maximum number of contracts” interface in the REST API.
Sub-account module
API v5 offers this module to support:
- Management of API Keys for sub-accounts, including creation, deletion and resetting functionalities.
- Querying account balances of sub-accounts.
- Fund transfers between two sub-accounts directly.
Format of time
API v3 adopts the ISO8601 time format, referring to the UTC time zones. However, this time format may not be compatible across all programming languages. This requires additional functionality for time zone conversion.
API v5 adopts a more universal time format: the Unix Epoch, which does not take time zones into account. API v5 also has relevant resources in the library, allowing easy time format conversion for developers.
Market order of spot trading
When spot trading with API v5, users can choose the unit of size when placing market orders according to their needs. In contrast, API v3 users can only use the quote currency as the buying market order unit and the base currency as the selling market order unit.
The launch of API v5
As of March 31, API v5 is available to all Unified Account users. Since API v3 will be discontinued shortly after v5 has been fully rolled out, we encourage users to upgrade their API to v5 for better functionalities and a more seamless trading experience.
For more technical details regarding the new API v5, please refer to our guide here.
Follow OKX
Telegram API community: t.me/OKXAPI
Telegram: t.me/OKXOfficial_English
Twitter: twitter.com/OKX
Facebook: facebook.com/okxofficial
LinkedIn: linkedin.com/company/okxofficial
Reddit: reddit.com/r/OKX/
Instagram: instagram.com/okx_official
© 2024 OKX。 本文可以全文复制或分发,或使用不超过 100 字的摘录,前提是此类使用仅限非商业用途。对全文的复制或分发必须明确注明:“本文版权所有 © 2024 OKX,经许可使用。” 允许的摘录必须标明文章标题并注明出处,例如“文章标题,作者姓名 (如适用) ,© 2024 OKX”。不允许对本文进行任何衍生作品或其他用途。
相关信息:数字资产交易服务由 OKX Australia Pty Ltd (ABN 22 636 269 040) 提供;关于衍生品和杠杆交易的信息由 OKX Australia Financial Pty Ltd (ABN 14 145 724 509,AFSL 379035) 提供,仅适用于《2001年公司法》(Cth) 下定义的大额客户;其他产品和服务由提供这些产品和服务的相关 OKX 实体提供 (请参阅服务条款)。
本文所含信息仅为一般性信息,不应视为投资建议、个人推荐或购买任何加密货币或相关产品的要约或招揽。在做出决策前,您应自行进行研究并寻求专业建议,确保理解相关产品的风险。过去的表现并不代表未来的结果,切勿承担超过您能够承受的损失风险。如需了解更多信息,请阅读我们的服务条款和风险披露和免责声明。
本内容翻译与英文版本不一致时,以英文版本为准。