Nodejs
Getting started
This package acts as a typescript wrapper on top of the Ston.fi Omniston protocol API and provides RxJS styled observables on top of the WebSocket API connection
Installation
via NPM
via YARN
via PNPM
Create an instance
Create an Omniston instance, specifying the API URL.
The constructor takes the following parameters:
client
ApiClient | undefined
Optional. Provide this if you want to override the default API client. By default, this will be an ApiClient
using ReconnectingTransport
apiUrl
URL | string
Omniston WebSocket API URL.
Get list of supported assets
An AssetsResponse
has the following properties:
assets
AssetInfo[]
List of supported assets
An AssetInfo
has the following properties:
address
Address
Address of smart contract
tags
string[]
Asset tags
symbol
string
Asset symbol
name
string
Displayable name
image_url
string
URL to asset image
decimals
number
Number of decimal places used to represent fractional amounts of an asset
metadata
Record<string, unknown>
Additional metadata, excluding above fields
An Address
has the following properties:
blockchain
Blockchain
Blockchain type (e.g. "TON"
)
address
string
Address of smart contract
Send a quote request
Send a request for quote to swap an asset to another asset.
A QuoteRequest
has the following properties:
settlementMethods
SettlementMethod[]
Supported methods of swap settlement
askAssetAddress
Address
Blockchain-specific address of ask asset
offerAssetAddress
Address
Blockchain-specific address of offer asset
amount
{ offerUnits: string } | { askUnits: string }
Either the amount of offer asset or ask asset
amount.offerUnits
string
The amount of offer asset the trader wants to pay, including all fees, in base asset units
amount.askUnits
string
The amount of ask asset the trader wants to get after all fees, in base asset units
referrerAddress
Address | undefined
The address of referrer that will receive the fees
referrerFeeBps
number | undefined
The amount of fees required by the referrer in basis points (1/10000 or 0.01%)
The server returns Observable<QuoteResponseEvent>
, which is a stream of quote updates.
A QuoteResponseEvent
might be one of the following:
{ type: "quoteUpdated"; quote: Quote; }
{ type: "noQuote"; }
{ type: "unsubscribed"; }
A Quote
has the following properties:
quoteId
string
ID of the quote generated by the platform
resolverId
string
ID of the resolver
resolverName
string
Name of the resolver
offerAssetAddress
Address
Blockchain-specific address of offer asset
askAssetAddress
Address
Blockchain-specific address of ask asset
offerUnits
string
The amount of offer asset the trader must pay, including all fees
askUnits
string
The amount of ask asset the trader will get after all fees
referrerAddress
Address | undefined
The address of referrer that will receive the fees
referrerFeeUnits
string
The amount of fees that the referrer will get (in units of offerAssetAddress
)
protocolFeeUnits
string
The amount of fees charged by the protocol (in units of offerAssetAddress
).
quoteTimestamp
number
The timestamp (UTC seconds) of Quote sent by resolver
tradeStartDeadline
number
Max timestamp (UTC seconds) of start of the trade
params
object | undefined
Various parameters specific to the settlement method. See the source code for more details.
Build a transaction
Now that we have a quote, we should request a server to build a transaction to initiate the trade that the user can verify and sign.
The buildTransfer
method takes a TransactionRequest
object as a parameter, having the following properties:
quote
Quote
The valid quote received from Omniston.requestForQuote
sourceAddress
Address
The address on offerBlockchain
that will send initial transaction to start the trade
destinationAddress
Address
The address on askBlockchain
that will receive result of the trade
maxSlippageBps
number
Max price slippage in basis points (1/10000 or 0.01%)
Sign the transaction
You can send messages
to any library of your choice. Take a look at our transaction sending guide with examples of different popular packages
Listen for trade status updates
After the user has signed and initiated the transaction, we can track the trade status.
The trackTrade
method has the following parameters:
quoteId
string
ID of the quote received from Omniston.requestFromQuote
traderWalletAddress
Address
The address of trader's wallet that initiated transaction
It returns Observable<TrackTradeStatus>
. For the different trade status values, see the source code. We are interested in the trade result enum which can be read from status.tradeSettled?.result?
field. The enum has the following values:
TRADE_RESULT_FULLY_FILLED
The trade has been completed and fully filled.
TRADE_RESULT_PARTIALLY_FILLED
The trade has been partially filled. Something went wrong.
TRADE_RESULT_ABORTED
The trade has been aborted.
TRADE_RESULT_UNKNOWN
UNRECOGNIZED
Last updated