Saltar para o conteúdo principal

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.

Esta página foi traduzida automaticamente por IA. A versão em inglês é a fonte oficial.Ver versão em inglês →
Informações da versão.
  • SDK: @raydium-io/raydium-sdk-v2@0.2.42-alpha
  • Cluster: Solana mainnet-beta
  • Program ID: veja reference/program-addresses
  • Última verificação: 2026-04
Fixe a versão do SDK no seu package.json. A interface de curva de ligação evoluiu entre versões menores.

Configuração

As demonstrações aqui espelham arquivos em raydium-sdk-V2-demo/src/launchpad. A inicialização segue o config.ts.template do repositório de demonstração:
import { Connection, Keypair, clusterApiUrl, PublicKey } from "@solana/web3.js";
import { Raydium, TxVersion } from "@raydium-io/raydium-sdk-v2";
import BN from "bn.js";
import fs from "node:fs";

const connection = new Connection(process.env.RPC_URL ?? clusterApiUrl("mainnet-beta"));
const owner = Keypair.fromSecretKey(
  new Uint8Array(JSON.parse(fs.readFileSync(process.env.KEYPAIR!, "utf8"))),
);
const raydium = await Raydium.load({
  owner,
  connection,
  cluster: "mainnet",
  disableFeatureCheck: true,
  blockhashCommitment: "finalized",
});
export const txVersion = TxVersion.V0;

Criar um lançamento

Fonte: src/launchpad/createMint.ts (e createBonkMintApi.ts para a variante Bonk orientada por API)
import { NATIVE_MINT } from "@solana/spl-token";

const { execute, extInfo } = await raydium.launchpad.createLaunchpad({
  programId: /* LaunchLab program ID from reference/program-addresses */,
  // Token metadata for the new base mint:
  name:   "Example Token",
  symbol: "EXMPL",
  uri:    "https://example.com/metadata.json",
  decimals: 6,

  // Curve params:
  curveType: 0,                                      // 0 = quadratic
  supply:    new BN(1_000_000_000).mul(new BN(10).pow(new BN(6))), // 1B base (6 dec)
  graduationFractionBps: 8000,                       // 80% → graduation
  initialK:  new BN("40"),                           // curve shape parameter

  // Quote side:
  quoteMint: NATIVE_MINT,                            // WSOL
  openTime:  new BN(Math.floor(Date.now() / 1000) + 60),  // opens in 1min

  // Fee policy:
  fees: {
    buyNumerator:   new BN(100),                     // 1.00%
    buyDenominator: new BN(10_000),
    sellNumerator:  new BN(100),
    sellDenominator: new BN(10_000),
    lpShare:         new BN(60),
    creatorShare:    new BN(20),
    protocolShare:   new BN(20),
    totalShare:      new BN(100),
  },

  postGraduationLpPolicy: "burn",                    // "burn" | "lock" | "toCreator"

  txVersion: TxVersion.V0,
});

const { txId } = await execute({ sendAndConfirm: true });
console.log("Launch:", extInfo.launchState.toBase58());
console.log("Base mint:", extInfo.baseMint.toBase58());
console.log("Create tx:", txId);
Notas:
  • initialK é o fator de escala para a curva quadrática. Ajuste-o para mirar um preço CPMM de abertura específico na graduação. Veja products/launchlab/bonding-curve para a derivação.
  • O SDK lida com a criação da mint base, o PDA de metadados e ambos os vaults em uma única transação. Pode exceder 1232 bytes se o URI de metadados for longo; nesse caso, o SDK divide em duas transações.
  • Após Initialize, o lançamento não é comercializável até openTime. Defina openTime um ou dois minutos à frente para dar menos chances aos front-runners de pegar a primeira compra.

Buscar estado do lançamento

const launchId = new PublicKey("<LAUNCH_STATE>");

const launch = await raydium.launchpad.getLaunchById({ launchId });
console.log("Status:", ["Active","Graduated","Cancelled"][launch.status]);
console.log("Base sold:", launch.baseSold.toString(),
            "/", launch.baseSupplyMax.toString());
console.log("Quote collected:", launch.quoteReserveReal.toString(),
            "target:", launch.quoteReserveTarget.toString());
if (launch.status === 1) {
  console.log("Post-graduation CPMM pool:", launch.cpmmPoolState.toBase58());
}
getLaunchById retorna o LaunchState decodificado mais a fração computada “progresso em relação à graduação” como um Decimal.

Comprar — entrada exata de quote

Fonte: src/launchpad/buy.ts
const quoteIn        = new BN(1).mul(new BN(10).pow(new BN(9)));  // 1 SOL
const minimumBaseOut = new BN(0);  // accept any; tighten for production

// Preview the quote off-chain so your UI can show expected base_out:
const preview = raydium.launchpad.computeBuyBase({
  launchState: launch,
  quoteIn,
});
console.log("Expected base_out:", preview.baseOut.toString(),
            "price impact:", preview.priceImpact.toString());

const { execute } = await raydium.launchpad.buyExactIn({
  launchInfo: launch,
  quoteIn,
  minimumBaseOut,
  txVersion: TxVersion.V0,
});

const { txId } = await execute({ sendAndConfirm: true });
console.log("Buy tx:", txId);
computeBuyBase espelha o solver Newton on-chain (curva quadrática) ou o inverso CPMM de forma fechada (curve_type 1). Use-o para preencher o campo “Você recebe” da UI.

Comprar — saída exata de base

const baseOut         = new BN(1_000_000).mul(new BN(10).pow(new BN(6)));  // 1M base
const maximumQuoteIn  = new BN(2).mul(new BN(10).pow(new BN(9)));          // cap at 2 SOL

const { execute } = await raydium.launchpad.buyExactOut({
  launchInfo: launch,
  baseOut,
  maximumQuoteIn,
  txVersion: TxVersion.V0,
});

await execute({ sendAndConfirm: true });
Útil para UIs “comprar exatamente X tokens”. Rejeita com ExceededSlippage se a curva se moveu o suficiente para que o requisito de quote agora exceda maximumQuoteIn.

Vender

Fonte: src/launchpad/sell.ts
const baseIn           = new BN(500_000).mul(new BN(10).pow(new BN(6)));  // 0.5M base
const minimumQuoteOut  = new BN(0);

const { execute } = await raydium.launchpad.sellExactIn({
  launchInfo: launch,
  baseIn,
  minimumQuoteOut,
  txVersion: TxVersion.V0,
});

await execute({ sendAndConfirm: true });
O caminho de venda da curva é simétrico ao caminho de compra: reduzir base_sold por baseIn retorna quote_out igual à área integrada sob a curva entre base_sold − baseIn e base_sold, menos a taxa de venda.

Graduação automática na compra que cruza o limiar

O SDK encadeia uma instrução Graduate dentro da transação buy* quando detecta que o estado pós-compra cruzará o limiar:
const { execute, willGraduate } = await raydium.launchpad.buyExactIn({
  launchInfo: launch,
  quoteIn: new BN(100).mul(new BN(10).pow(new BN(9))),    // large buy
  minimumBaseOut: new BN(0),
  txVersion: TxVersion.V0,
  autoGraduate: true,                                      // default
});

if (willGraduate) {
  console.log("This buy will trigger graduation.");
}

const { txId } = await execute({ sendAndConfirm: true });
Como Graduate é sem permissão, qualquer pessoa (incluindo um bot MEV) pode correr para fazer o primeiro Graduate após o limiar ser cruzado — típicamente segundos depois, não minutos. O primeiro a chegar apenas paga o aluguel das contas do pool CPMM; não recebem nenhum outro benefício.

Graduate manual

Se autoGraduate estava desativado ou a transação de cruzamento de limiar falhou, você pode disparar a graduação separadamente:
const { execute } = await raydium.launchpad.graduate({
  launchInfo: launch,
  txVersion: TxVersion.V0,
});

await execute({ sendAndConfirm: true });
Reverte com NotAtThreshold se quote_reserve_real < quote_reserve_target no tempo de envio. Seguro para retry — uma segunda tentativa de Graduate após sucesso reverte com NotActive.

Coletar taxas do criador

Fonte: src/launchpad/claimCreatorFee.ts (single mint) e collectAllCreatorFees.ts (em lote)
const { execute } = await raydium.launchpad.collectCreatorFees({
  launchInfo: launch,
  txVersion: TxVersion.V0,
});

await execute({ sendAndConfirm: true });
Transfere o valor do contador de taxa de criador acumulado para o ATA do criador na mint de quote. Pode ser chamado pré- ou pós-graduação; use-o periodicamente em vez de esperar por um saldo enorme se acumular.

Rastrear um lançamento através de seu ciclo de vida

Juntando tudo, um script de monitoramento pode parecer com:
async function watch(launchId: PublicKey) {
  while (true) {
    const launch = await raydium.launchpad.getLaunchById({ launchId });
    const progress =
      Number(launch.quoteReserveReal) /
      Number(launch.quoteReserveTarget);

    console.log(
      `status=${["Active","Graduated","Cancelled"][launch.status]}`,
      `progress=${(progress * 100).toFixed(2)}%`,
      `num_buys=${launch.stateData.numBuys}`,
    );

    if (launch.status === 1) {
      console.log("Graduated to CPMM pool:", launch.cpmmPoolState.toBase58());
      break;
    }
    await new Promise(r => setTimeout(r, 10_000));
  }
}

CPI Rust

Chamar LaunchLab a partir do seu próprio programa Anchor é raro (a maioria das integrações de lançamento são apenas do lado TS). Se você fizer, o programa fornece uma crate Anchor raydium_launchlab com cpi::accounts::Buy, cpi::accounts::Sell, etc. — o padrão espelha os exemplos de CPI do CPMM / CLMM. Veja sdk-api/rust-cpi para um template generalizado uma vez que este site seja preenchido.

Armadilhas

  • Arredondamento de split de taxa off-by-one. Se total_share não for exatamente lp_share + creator_share + protocol_share, Initialize reverte com InvalidFeeShares. Defina totalShare igual à soma.
  • Usar uma mint de quote não permitida. launch_config.allowed_quote_mints é uma lista fixa; passar qualquer outra mint reverte. Verifique com raydium.launchpad.getConfig() primeiro.
  • Tamanho de metadados. Strings uri longas empurram o CPI da Metaplex sobre o orçamento. Mantenha uri abaixo de ~200 caracteres — a maioria dos metadados JSON hospedados em CDN cabe facilmente.
  • Corrida de graduação. Bots automatizados monitoram quote_reserve_real e antecipam Graduate dentro de um slot ou dois do cruzamento do limiar. Isso é inócuo — custa apenas aluguel — mas significa que sua UI deve tratar transições de status como eventos rápidos.

Próximos passos

Fontes: