gRPC Integration
Integrate Omniston swaps using gRPC API - high-performance protocol for programmatic token trading on TON
This guide describes how to use the Omniston swap functionality over the gRPC API from a trader's perspective. It parallels Swap overview (WebSocket) but shows the gRPC specifics.
Key Differences from WebSocket API
- Protocol Field For the gRPC API, the - protocolfield in each swap chunk must be a string:- "StonFiV1",- "StonFiV2",- "DeDust", or- "TonCo". In contrast, the WebSocket API uses numeric codes- 1,- 2,- 3, or- 4.
 
- Extra Version Currently, only - extraVersion = 1is supported.
- Steps vs. Chunks - Each SwapStep moves from one asset to another (e.g., TON → USDC). 
- Each step can have multiple SwapChunk objects, but on TON you typically see exactly one chunk per step. 
 
- Method Names In the gRPC API, traders use similar calls to - requestForQuote,- buildTransfer,- trackTrade, etc., but these are exposed via protobuf messages, not JSON-RPC. The underlying fields are the same.
Typical Flow (Traders)
A typical gRPC-based swap flow from a trader's viewpoint is:
- Send a Quote Request Using - Omniston.requestForQuote(or the corresponding gRPC call), providing:- bidAssetAddress,- askAssetAddress
- The desired - amount(either- bidUnitsor- askUnits)
- Optional - referrerAddressand- referrerFeeBps
- settlementMethods=- [SETTLEMENT_METHOD_SWAP]if you want a swap
- settlementParamssuch as- maxPriceSlippageBps,- maxOutgoingMessages(for TON), or- flexibleReferrerFeeflag
 - You receive an Observable (RxJS style in the SDK) or a stream of - QuoteResponseEventmessages over gRPC:- First, you'll receive a - QuoteRequestAckmessage containing the- rfq_id(a SHA-256 hex string) that uniquely identifies your quote request
- Then, the server may update your quote repeatedly if a more favorable price arrives 
 
- Build the Transfer When you have a valid - Quote, call- Omniston.buildTransferwith:- The - quoteyou accepted
- Your - sourceAddress(on- bidBlockchain)
- Your - destinationAddress(on- askBlockchain)
- Optional: - refundAddress- where funds should be returned if the transaction fails (defaults to sender's wallet) The API returns an object with blockchain-specific transaction data (for TON, a list of messages).
 
- Sign/Send the Transaction - On TON, you typically pass these messages to your wallet (e.g., TonConnect, Tonkeeper, etc.). 
- Wait for the transaction to be mined. 
 
- Track the Trade You can then call - Omniston.trackTradeto receive streaming updates about the trade status. This includes whether the trade was filled, partially filled, or aborted.
Important Data Types
- BlockchainA numeric code following SLIP-044. For TON, this is- 607.
- AddressAn object:- { "blockchain": 607, "address": "EQDA3..." }
- ProtocolMust be one of:- "StonFiV1"
- "StonFiV2"
- "DeDust"
- "TonCo"
 
- SettlementMethodFor now, typically- [0]for swap in numerical form, or (in your SDK)- SettlementMethod.SETTLEMENT_METHOD_SWAP.
- QuoteRequestAckAcknowledgment message sent immediately after receiving a quote request:- message QuoteRequestAck { string rfq_id = 1; // SHA-256 hex string uniquely identifying the RFQ }
- SwapStepand- SwapChunk- Each step is a transition from - bidAssetAddressto- askAssetAddress.
- For TON: typically exactly one chunk per step. 
- A chunk includes: - string protocol = 1; // e.g. "StonFiV2" string offer_amount = 2; string ask_amount = 3; uint64 extra_version = 4; // must be 1 bytes extra = 5; // base64-encoded data for your DEX
 
- QuoteThe server provides a- quoteId,- bidUnits,- askUnits,- quoteTimestamp,- tradeStartDeadline, etc. Includes- paramswith settlement info for the chosen method (- SwapSettlementParams).
Rejected Quotes
If you pass extraVersion != 1 (e.g., 3), the quote or the route gets rejected with a message like:
Invalid extra version for step 0: 3Make sure to use extraVersion = 1.
Next Steps
For a complete, low-level definition of the gRPC service (resolver side, plus the underlying messages), see Resolver Integration Guide. For Node.js or TypeScript usage, see omniston-nodejs.md or the omniston-react.md for React apps. Both rely on the same underlying gRPC/WS backend.
If you have any questions or issues, please reach out in our STON.fi Discord.
Last updated