Documentation Index
Fetch the complete documentation index at: https://docs.raydium.io/llms.txt
Use this file to discover all available pages before exploring further.
Halaman ini diterjemahkan secara otomatis oleh AI. Versi bahasa Inggris adalah acuan resmi.Lihat versi bahasa Inggris →
Dukungan tingkat program
| Program | Mint Token-2022 base/quote? | Mode |
|---|---|---|
| CPMM | Ya — gated | Daftar izin ekstensi ketat + daftar whitelist 4 mint statis. |
| CLMM | Ya — gated | Daftar izin ekstensi ketat + daftar whitelist 6 mint statis + registri per-mint admin + deteksi Superstate. |
| AMM v4 | Tidak | Program mendahului Token-2022; kedua mint harus SPL Token klasik. |
| Stable AMM | Tidak | Batasan sama dengan AMM v4. |
| Farm v6 | Ya, sebagian | Mint reward dapat berupa Token-2022 (tunduk pada daftar izin yang sama saat farm membungkus LP CPMM/CLMM); mint LP stake pengguna mewarisi dari pool yang dibungkus. |
| LaunchLab | Ya, dikelola program | Mint base dapat berupa Token-2022, tetapi hanya melalui instruksi initialize_with_token_2022 khusus; program itu sendiri membuat mint dengan MetadataPointer (selalu) dan secara opsional TransferFeeConfig (rate ≤ 5%). Mint Token-2022 yang sudah ada dengan ekstensi sembarangan tidak dapat digunakan sebagai base. |
| Burn & Earn | Cerminkan program pool | Mewarisi gating CPMM / CLMM. |
- CPMM:
is_supported_mintdiraydium-cp-swap/programs/cp-swap/src/utils/token.rs:178, dipanggil dariInitialize. - CLMM:
is_supported_mintdiraydium-clmm/programs/amm/src/util/token.rs:280, dipanggil dariCreatePool. - LaunchLab:
initialize_with_token_2022diraydium-launchpad/programs/launchpad/src/instructions/initialize_with_token_2022.rs(sumber tidak tersedia untuk umum).
Daftar izin ekstensi CPMM dan CLMM
Setelah shortcut daftar whitelist statis (dijelaskan di bawah), program mengulangi ekstensi mint dan menolak mint jika membawa ekstensi apa pun selain lima ini:| Ekstensi | Alasan diizinkan |
|---|---|
TransferFeeConfig | Matematika pool mengurangkan biaya masuk; program Token-2022 menangani biaya keluar. Lihat algorithms/token-2022-transfer-fees. |
MetadataPointer | Dekoratif — menunjuk ke metadata on-chain. |
TokenMetadata | Dekoratif — metadata inline. |
InterestBearingConfig | Pool melihat jumlah pokok; pengali UI hanya dekorator dan saldo yang mendasar dipertahankan. |
ScaledUiAmount | Bentuk sama dengan interest-bearing — faktor skala hanya berlaku pada tampilan UI. |
TransferHook, NonTransferable, ConfidentialTransferMint, PermanentDelegate, MintCloseAuthority, DefaultAccountState, GroupPointer, GroupMemberPointer, MemberPointer, Pausable, dll. — menyebabkan is_supported_mint mengembalikan false dan pembuatan pool kembali.
Baris-baris relevan (CPMM, bentuk identik di CLMM):
cp-swap/src/utils/token.rs:190–200
Jalur bypass
Mint Token-2022 yang tidak sesuai daftar izin masih dapat diterima melalui salah satu dari tiga bypass eksplisit. Mereka dicoba secara berurutan, sebelum iterasi ekstensi berjalan.1. Daftar whitelist mint statis
Array konstantaMINT_WHITELIST dari string base58 dikode keras di setiap program. Jika alamat mint cocok, fungsi mengembalikan true segera dan tidak ada pengecekan ekstensi yang dilakukan.
| Program | Mint yang di-whitelist |
|---|---|
| CPMM | HVbpJAQGNpkgBaYBZQBR1t7yFdvaYVp2vCQQfKKEN4tM, Crn4x1Y2HUKko7ox2EZMT6N2t2ZyH7eKtwkBGVnhEq1g, FrBfWJ4qE5sCzKm3k3JaAtqZcXUh4LvJygDeketsrsH4, 2b1kV6DkPAnxd5ixfnxCpjxmKwqjjaYmCZfHsFu24GXo |
| CLMM | Empat yang sama, ditambah DAUcJBg4jSpVoEzASxYzdqHMUN8vuTpQyG2TvDcCHfZg, AUSD1jCcCyPLybk1YnvPWsHQSrZ46dxwoMniN4N2UEB9 |
2. Registri per-mint — CLMM saja
CLMM juga berkonsultasi dengan PDASupportMintAssociated pada seed [b"support_mint", mint]. Jika PDA itu ada untuk mint, itu diterima terlepas dari set ekstensinya.
PDA dibuat oleh CreateSupportMintAssociated (admin/create_support_mint_associated.rs). Instruksi gated ke dua penanda:
crate::admin::ID— otoritas admin Raydium standar.crate::create_support_mint_associated_owner::ID— otoritas khusus untuk tujuan ini:RayVyjyJQz9vAi126A4sGexKnSU1XeZaHTRcM1mZMPY(mainnet),rayf3nEbb3bnfN6RDGFpqPbjc5uUa3tRUzu6UVYrRx5(devnet).
3. Deteksi Superstate — CLMM saja
CLMM memiliki jalur ketiga khusus untuk aset yang ditokenkan Superstate, yang menggunakan ekstensiScaledUiConfig yang versi spl-token-2022 yang ditautkan ke dalam program CLMM tidak dapat unpacked. Daripada upgrade dependency, CLMM mendeteksi token Superstate berdasarkan bentuk otoritasnya:
raydium-clmm/programs/amm/src/util/token.rs:485
Mint lulus cabang ini jika keempat kondisi terpenuhi:
- Program pemiliknya adalah program Token-2022.
- Otoritas pembekuannya sama dengan
superstate_allowlist::ID. Mainnet:2Yq4T3mPNfjtEyTxSbRjRKqLf1pwbTasuCQrWe6QpM7x. Devnet:3TRuL3MFvzHaUfQAb6EsSAbQhWdhmYrKxEiViVkdQfXu. - Ekstensi
DefaultAccountStatediatur keFrozen. - Delegate permanen juga
superstate_allowlist::ID.
Apa yang bypass tidak mengesampingkan
Bypass melewati daftar izin ekstensi, tetapi program masih menerapkan:- Mint dimiliki oleh
TokenatauToken-2022. Program token khusus ditolak hulu. - Vault pool dibuat dengan ekstensi ATA yang tepat untuk pool Token-2022 (
ImmutableOwner, dll.). - Semua transfer melalui
transfer_checked— mint pemegang biaya mendarat jumlah yang tepat di vault.
TransferHook tidak mendapatkan pengecekan waktu swap; hook hanya akan berjalan pada setiap transfer dan bisa batu swap. Whitelisting karenanya adalah tindakan kepercayaan tinggi.
Semantik “Blocked”
Ketikais_supported_mint mengembalikan false, pembuatan pool kembali dengan ErrorCode::NotSupportMint (CPMM) / ErrorCode::NotSupportMint (CLMM). Lihat reference/error-codes untuk kode numerik.
Pool yang ada tidak bisa secara retroaktif gagal pengecekan ini — gate hanya berjalan saat pembuatan. Ekstensi mint tidak dapat diubah untuk kategori yang Raydium tolak (transfer hook, non-transferable, confidential transfer tidak dapat ditambahkan pasca-pembuatan), jadi pengecekan statis sudah cukup.
Mengapa setiap ekstensi yang dikecualikan dikecualikan
- TransferHook — menjalankan program khusus pada setiap transfer, dengan konsumsi CU sembarang, kondisi kegagalan sembarang, dan kemampuan untuk masuk kembali ke program pemanggil. Tidak ada sandbox aman. Beberapa DEX mempertahankan daftar izin hook; Raydium tidak.
- NonTransferable —
Transferselalu gagal. Pool tidak dapat mengambil alih. - ConfidentialTransfer — jumlah transfer dienkripsi; kurva tidak dapat harga swap.
- PermanentDelegate — pemegangnya dapat menyapu akun token apa pun, termasuk vault pool. Hanya diizinkan melalui daftar whitelist statis untuk penerbit tepercaya (misalnya, stablecoin yang diatur).
- MintCloseAuthority — mint dapat ditutup; pool yang ada menjadi tidak dapat digunakan. Dilarang secara default.
- DefaultAccountState (Frozen) — ATA pool akan mendarat di status
Frozendan memerlukan thawing per akun. Hanya diizinkan melalui deteksi Superstate, yang mengasumsikan penerbit thaws akun institusional saat enrollment. - Group/Member pointers — tidak secara aktif berbahaya, tetapi tidak ditinjau. Dilarang secara default untuk menjaga permukaan tetap sempit.
Akuntansi transfer-fee
Untuk mint membawaTransferFeeConfig, setiap swap, deposit, dan withdraw memindahkan lebih sedikit dari jumlah nominal. SDK melayani kedua belahan kalkulasi:
amountIn + token2022FeeInsebagai “Anda mengirim”amountOut - token2022FeeOutsebagai “Anda menerima”feeAmountsebagai pool fee (LP + protokol), yang terpisah dari biaya transfer Token-2022
amountIn → amountOut meremehkan biaya.
Cap maximumFee
Biaya transfer Token-2022 dibatasi per transfer. Untuk mint 1 % dengan cap 10.000-token, transfer 100.000.000-token hanya membayar 10.000 dalam biaya. computeSwapAmount SDK menerapkan cap; pemanggil program langsung harus mereplikanya.
Transisi epoch
Otoritas mint dapat menjadwalkan perubahan tingkat biaya yang diaktifkan di epoch berikutnya. Selama jendela transisi, dua config (older, newer) hidup di mint sekaligus dan TransferChecked memilih berdasarkan epoch saat ini. CPMM SwapV2 dan CLMM SwapV2 keduanya melewatkan akun mint penuh di accounts, jadi program membaca config yang tepat tanpa lookup tambahan.
Jika Anda mengutip lebih dari satu epoch sebelumnya melalui Trade API atau SDK, biaya yang dieksekusi dapat berbeda dari biaya yang dikutip — dibatasi oleh maximum_fee_basis_points config yang lebih lama.
Interest-bearing dan ScaledUiAmount
Pool memegang jumlah pokok; “jumlah UI” adalah pokok dikalikan dengan faktor skala yang bergantung waktu atau yang ditetapkan admin. Matematika swap beroperasi pada pokok:pool.token0Vault.amount sebagai pokok.
Definisi “pool Token-2022”
Pool adalah pool Token-2022 jika salah satu mint memilikiprogramId == TokenzQdB.... API melayani ini:
programId untuk dispatch, dan hasTransferFee untuk menampilkan peringatan UI.
Helper SDK
Kesalahan integrasi umum
- Pre-flighting hanya ID program. Mint dapat berupa Token-2022 dan tidak didukung. Berjalan di daftar ekstensi terhadap daftar izin (dan daftar whitelist statis) sebelum mengizinkan pembuatan pool.
- Mempercayai kutipan SDK ketika mint tidak diterima sama sekali. API kutipan tidak menolak untuk mengutip — pembuatan pool adalah yang kembali. Konfirmasi semantik
is_supported_mintoff-chain sebelum mengekspos pembuatan pool di UI Anda. - Mengutip tanpa potongan rambut transfer-fee. Mint transfer-fee 1% di kedua sisi pool CPMM 0,25% memiliki biaya efektif sekitar 2,25%, bukan 0,25%. Gunakan kutipan SDK atau kutipan Trade API — jangan pernah hitung biaya secara manual dari tingkat biaya pool saja.
- Memanggil instruksi
Swaplegacy pada pool Token-2022.Swapmendahului Token-2022. GunakanSwapV2kapan pun salah satu mint adalah Token-2022. - Auto-listing mint Token-2022 baru. Dompet dan agregator harus memeriksa
TransferHookdanNonTransferablesebelum melayani mint kepada pengguna; keduanya bermusuhan dengan Raydium.
Pekerjaan masa depan
Item roadmap ekosistem Solana dan protokol yang akan mengubah matriks ini:- Program transfer-hook yang di-whitelist pada tingkat Solana (konvensi ekosistem berkembang).
- AMM yang kompatibel confidential-transfer (tahap penelitian).
- Registri per-mint CPMM yang lebih luas (paritas dengan CLMM).
- Upgrade dependency sehingga dekoding
ScaledUiConfigCLMM berfungsi tanpa heuristik Superstate.
Pointer
algorithms/token-2022-transfer-fees— matematika biaya dalam swap.products/cpmm/instructions—SwapV2,Initialize.products/clmm/instructions—SwapV2,CreatePool,CreateSupportMintAssociated.reference/error-codes— kode numerikNotSupportMintper program.
raydium-cp-swap/programs/cp-swap/src/utils/token.rs—MINT_WHITELIST,is_supported_mint.raydium-clmm/programs/amm/src/util/token.rs—MINT_WHITELIST,superstate_allowlist,is_superstate_token,is_supported_mint.raydium-clmm/programs/amm/src/instructions/admin/create_support_mint_associated.rs— instruksi registri per-mint.raydium-launchpad/programs/launchpad/src/instructions/initialize_with_token_2022.rs— pembuatan mint base Token-2022 LaunchLab.


