Gluon
Last updated
Last updated
Gluon is an order‑book Layer‑2 blockchain built with and secured by Sunrise, a next-generation L1 combining data availability and liquidity. The base layer for Interliquid Networks. The rollup implements Sunrise's Proof‑of‑Liquidity (PoL) and leverages IBC for seamless asset movement.
Order‑book DEX
Deterministic matching logic, price‑time priority, and on‑chain settlement.
Web2‑style onboarding
OAuth registration abstracts private‑key management; user keys never leave the client device.
Off‑chain matching
High‑throughput matching engine batches trades before finalising them on chain.
Double‑signature model
All funding transactions require both user and operator signatures, preventing unilateral withdrawals.
IBC deposits/withdraws
Native IBC channels connect Gluon to external Cosmos‑SDK chains for trust‑minimised transfers.
Source code:
Sunrise Rollkit adapter:
Modules used: x/order
, x/perp
, x/customauth
(see protobuf definitions).
Gluon introduces a CustomAuth flow that pairs a web‑generated ECDSA key with an on‑chain account:
OAuth sign‑up → server deterministically derives user address.
Device pairing → browser generates an AES key and an ECDSA key; the latter is AES‑encrypted and stored server‑side.
Verification key is submitted on chain (pairing transaction).
The sign-up process is intentionally simple and user-friendly:
Users can sign up using familiar OAuth providers (Google, GitHub, etc.)
The application automatically derives a Sunrise address for the user
No manual wallet setup or seed phrase management required
This streamlined process ensures users can start trading quickly without blockchain complexity.
The device pairing process implements several security measures:
Generates unique encryption keys for each device
Keeps sensitive ECDSA keys encrypted and secure
Establishes a verification mechanism for future transactions
This multi-step process ensures secure key management while maintaining user control.
The off-chain order creation process enables high-performance trading:
Orders are signed locally using the user's encrypted key
Signatures are verified before being accepted
Orders remain off-chain until batched for matching
This approach allows for sub-second order placement while maintaining security.
The cancellation process ensures order integrity:
Cancellations are recorded on-chain for transparency
Prevents replay attacks of old signatures
Provides immutable proof of cancellation
This on-chain record is crucial for maintaining order book integrity.
The withdrawal process implements multiple security layers:
Requires dual signatures from both user and operator
Implements a 24-hour security delay for new key pairs
Uses IBC for trust-minimized cross-chain transfers
This multi-layered approach ensures secure and reliable asset transfers across chains.
No external wallets (e.g., MetaMask) are required; keys remain client‑side and are revocable on‑chain.
Orders reside off‑chain until batched in the first matching transaction, enabling sub‑second UX.
An on‑chain record prevents operators from replaying stale user signatures.
A 24‑hour latency between key‑pairing and fund movements mitigates operator‑key compromise.
The order subsystem is defined in gluon/order/*
. Core types:
The BaseOrder
message defines the fundamental structure for all orders in the system:
Each order is associated with a specific user address and trading pair
Orders can be either limit orders (with a specified price) or market orders
The expiry timestamp prevents replay attacks and ensures order freshness
Amount and price are stored as strings to handle arbitrary precision
The OrderDirection
enum provides a type-safe way to specify order sides:
Uses standard protobuf enum conventions with an UNSPECIFIED default
Clearly distinguishes between buy and sell orders
Helps prevent order-side related bugs through compile-time checking