NEAR
High-level overview
Introduction
Orderly provides the infrastructure and tools necessary for developers to build their own DeFi dApps by accessing an array of products Orderly offers.
Builders can integrate Swaps, Spot, and Perps for NEAR native assets (BTC, ETH, NEAR, AURORA, WOO, SWEAT, USDT, USDC.e, NEAT) on their projects.
Orderly leverages NEAR’s technology to provide in-dApp Swaps for mass market companies, to power DEXs with deep Spot liquidity for major assets and a CEX-like Perps experience on-chain.
Many products and functionalities are still in development and will be rolled out according to the roadmap
What’s possible
The possibilities are endless when building with Orderly. Developers can tap into any of our products, such as Spot Trading, Perpetual Futures, Lending & Borrowing, and Cross Chain Swaps (many functionalities are still in development and are not available to the public), and create a dApp for their specific needs.
Whether you’re building a DEX, a Swap, or an entirely new product, Orderly provides the tools necessary to power your DeFi platform.
Why build on Orderly
Websites or apps using Orderly are free to tailor the experience to their use case and the unique needs of their target market. Integrating with Orderly will save build time for anyone building on the platform by removing the challenges of creating your own order book and liquidity, so developers can focus on delivering the best user experience possible.
High-level architecture overview
The trading flow on Orderly happens in the following steps:
Connect, Authenticate, and Stake Storage Deposit
- Create Access & Trading Keys for users to interact with the smart contract/matching engine, pay storage deposit, and instantiate a user account in the smart contract
Deposit & Withdraw
- Deposit and withdraw assets to/from the Orderly Asset Manager contract.
Market Data
- Retrieve market data information including the order book and charts
Trade
- View balances, and place, edit, cancel, or view orders
Architecture
Smart Contract (Asset Manager)
The asset manager contract is the main Smart Contract of Orderly which acts as a custodial account to provide the best user experience possible for an on-chain exchange with it’s low fees, fast trade execution, and deep liquidity.The contract stores the following information:
-
NEAR Account ↔︎ Orderly / Trading Key mappings
-
Balance of each account in Orderly
-
Whitelist of permitted assets for the contract
-
Whitelist of permitted trading pairs
The contract has the following usages:
-
Allows users to create an account - i.e. bind their NEAR account_id with specific Orderly trading keys
-
Allows users to deposit whitelisted assets to their Orderly account
-
Allow users to withdraw their assets from their Orderly account
-
Settles executed trades by updating balances of all users on-chain after receiving trade executions
Off-Chain Engine
Currently, the Matching Engine (Orderbook) is off-chain and the smart contract is used as a settlement layer, to offer market-leading trade execution with low latency and minimal fees.The Off-Chain Engine has the following functionalities:
-
Order service
-
Matching engine
-
Trade upload management (uploads executed trades back up to the smart contract)
-
Deposit/Withdrawal management
Connect & Register
In order to register an account and connect a wallet, a user needs two key pairs: Orderly Key Pair (ed25519
), also known as Access Key, and Trading Key Pair (secp256k1
). Orderly Access Key Pair is generated by the wallet and more information can be found here. Trading keys can be generated using this library. Please refer to Authentication for more information on Authentication via WebSocket and RESTful APIs.
NEAR Protocol has a storage staking mechanism when the data is stored on-chain (more info can be found here). Orderly requires the users to stake a small amount of NEAR upon creating a new user account, adding new trading key pairs, and new token balances to prevent Sybil attacks and minimize the number of payable transactions
Deposit & Withdrawal
Deposit flow
Withdrawal flow
Users have to transfer their funds into the Orderly smart contract, known as an Asset Manager, which acts as a custodial account in order to trade. Deposits and withdrawals are initiated through a smart contract. More details can be found on the smart contract API page.
The number of pending withdrawals is limited to 10 per each user
Trading Flow
Trade flow
User trading data can be retrieved via various RESTful and Websocket APIs. Users can also manage orders via REST APIs. More details can be found on the off-chain engine API page.
Market Data
Market data retrieval flow
Market data can be connected via various RESTful and Websocket APIs. More details can be found on the off-chain engine API page.
Some of the market data, such as listed token pairs and listed tokens, can be retrieved through Smart Contract and Off-Chain APIs.
This guide is a WIP. If you have any suggestions or questions please contact us by email
For questions regarding building with us, send us an email or reach out in the discord