| Before | After | |
|---|---|---|
| Rent (avg. DeFi pool) | ~$2 | ~$0.02 |
What Changes
| Area | Change |
|---|---|
| State struct | Derive LightAccount and add a compression_info: Option<CompressionInfo> field |
| Accounts | Derive LightAccounts and add #[light_account] on init accounts |
| Program module | Add #[light_program] on top of #[program] |
| Instructions (swap, deposit, withdraw, …) | No changes |
You can find a complete rent-free AMM reference implementation here.
Step 1: Dependencies
Step 2: State Struct
Addcompression_info field and derive LightAccount:
Step 3: Program
Add#[light_program] above #[program]:
Step 4: Accounts Struct
DeriveLightAccounts on your Accounts struct and add #[light_account(...)] next to #[account(...)].
- PDAs
- Token Account
- Associated Token Account (ATA)
- Mint
Full Accounts Struct
Full Accounts Struct
We also need to add
light_token_interface_config, rent_sponsor, and light_token_cpi_authority.Step 5: Instructions
Replacespl_token with light_token instructions as you need. The API is a superset of SPL-token so switching is straightforward.
Examples include: MintToCpi, TransferCpi, TransferInterfaceCpi,
CreateTokenAccountCpi, and CreateTokenAtaCpi.
Example: Initialize
Example: Initialize
Client SDK
To make it easy for clients to integrate with your program, implement theLightProgramInterface trait in your program’s SDK crate.
For a detailed example of how clients use this trait, check out the Router Integration page.
Example: Trait Implementation
Example: Trait Implementation
| Resource | Link |
|---|---|
| Trait Implementation Example | CpSwapSdk |
Testing
Example: Integration Test
Example: Integration Test
| Resource | Link |
|---|---|
| Test example | program.rs |
How it works
The SDK pays the rent-exemption cost. After extended inactivity, cold accounts auto-compress. Your program only ever interacts with hot accounts. Clients can safely load cold accounts back into the onchain Solana account space when needed viacreate_load_instructions.
Under the hood, clients use AccountInterface - a superset of Solana’s
Account that unifies hot and cold state. See Router Integration
for details.
| Hot (active) | Cold (inactive) | |
|---|---|---|
| Storage | On-chain | Compressed |
| Latency/CU | No change | +load instruction |
| Your program code | No change | No change |
Existing programs
If you want to migrate your program to rent-free accounts and would like hands-on support, join our tech Discord, or email us.FAQ
How does it prevent re-init attacks?
How does it prevent re-init attacks?
When creating an
account for the first time, the SDK provides a proof that the account doesn’t
exist in the cold address space. The SVM already verifies this for the onchain
space. Both address spaces are checked before creation, preventing re-init
attacks, even if the account is currently cold.
Who triggers compression?
Who triggers compression?
Miners (Forester nodes) compress accounts that have been inactive for an extended period of time (when their virtual rent balance drops below threshold).
In practice, having to load cold accounts should be rare. The common path (hot) has no extra overhead and does not increase CU or txn size.
How is the SDK able to sponsor rent exemption?
How is the SDK able to sponsor rent exemption?
When accounts compress after extended inactivity, the on-chain rent-exemption is released back
to the rent sponsor. This creates a revolving lifecycle: active “hot” accounts hold a
rent-exempt lamports balance, inactive “cold” accounts release it back. The
rent sponsor must be derived from the program owner. For all mint, ATA, and
token accounts, the Light Token Program is the rent sponsor. For your own program-owned PDAs, the SDK derives a rent sponsor address automatically.
Do rent-free accounts increase CU?
Do rent-free accounts increase CU?
Hot path (e.g. swap, deposit, withdraw): No. Active accounts do not add CU overhead to your instructions.First time init + loading cold accounts: Yes, adds up to 15k-400k CU,
depending on number and type of accounts being initialized or loaded.