インテグレーションAPI

POSTローンチ作成

Last updated February 19, 2026

新しい Genesis トークンローンチのためのオンチェーントランザクションを構築します。ローンチ登録を呼び出す前に、署名して送信する必要がある未署名トランザクションを返します。

SDK の使用を推奨

ほとんどのインテグレーターには、SDK の createAndRegisterLaunch の使用を推奨します。この関数はトランザクションの作成、署名、送信、ローンチの登録を1回の呼び出しで処理します。このエンドポイントは、SDK を使用せずに直接 HTTP アクセスが必要な場合にのみ使用してください。

Genesis プログラムの全機能セットは metaplex.com ではまだサポートされていないため、Create API(または SDK)を使用してプログラムでローンチを構築することを推奨します。API を通じて作成されたメインネットのローンチは、登録後に metaplex.com に表示されます。

エンドポイント

POST /v1/launches/create

リクエストボディ

フィールド必須説明
walletstringはい作成者のウォレット公開鍵
launchobjectはいローンチの完全な設定(下記参照)

ローンチ設定

launch オブジェクトはトークンとローンチのセットアップ全体を記述します:

フィールド必須説明
namestringはいトークン名、1〜32文字
symbolstringはいトークンシンボル、1〜10文字
imagestringはいトークン画像 URL(Irys ゲートウェイ)
descriptionstringいいえトークンの説明、最大250文字
decimalsnumberいいえトークンのデシマル(デフォルトは6)
supplynumberいいえトークンの総供給量(デフォルトは1,000,000,000)
networkstringいいえ'solana-mainnet'(デフォルト)または 'solana-devnet'
quoteMintstringいいえクォートトークンのミントアドレス(デフォルトはラップド SOL)
typestringはい'project'
finalizebooleanいいえローンチをファイナライズするかどうか(デフォルトは true
allocationsarrayはいアロケーション設定の配列
externalLinksobjectいいえウェブサイト、Twitter、Telegram のリンク
publicKeystringはい作成者のウォレット公開鍵(トップレベルの wallet フィールドと一致する必要があります)

アロケーションタイプ

allocations 配列の各アロケーションには type フィールドがあります:

  • launchpoolV2 — 比例配分プール
  • raydiumV2 — Raydium LP アロケーション
  • unlockedV2 — 受取先へのロック解除済みトークン
  • lockedV2 — Streamflow によるロック付きトークン
  • presaleV2 — 固定価格プレセール

SDK の buildCreateLaunchPayload 関数は、簡略化された CreateLaunchInput をこの完全なペイロード形式に変換します。詳細は API クライアントのドキュメントを参照してください。

リクエスト例

curl -X POST https://api.metaplex.com/v1/launches/create \
-H "Content-Type: application/json" \
-d '{
"wallet": "YourWalletPublicKey...",
"launch": {
"name": "My Token",
"symbol": "MTK",
"image": "https://gateway.irys.xyz/...",
"decimals": 6,
"supply": 1000000000,
"network": "solana-devnet",
"quoteMint": "So11111111111111111111111111111111111111112",
"type": "project",
"finalize": true,
"publicKey": "YourWalletPublicKey...",
"allocations": [...]
}
}'

成功レスポンス

{
"success": true,
"transactions": [
"base64-encoded-transaction-1...",
"base64-encoded-transaction-2..."
],
"blockhash": {
"blockhash": "...",
"lastValidBlockHeight": 123456789
},
"mintAddress": "MintPublicKey...",
"genesisAccount": "GenesisAccountPDA..."
}
フィールド説明
successboolean成功時は true
transactionsstring[]Base64 エンコードされたシリアライズ済みトランザクション
blockhashobjectトランザクション確認用のブロックハッシュ
mintAddressstringトークンミントの公開鍵
genesisAccountstringGenesis アカウント PDA の公開鍵

エラーレスポンス

{
"success": false,
"error": "Validation failed",
"details": [...]
}
フィールド説明
successbooleanエラー時は false
errorstringエラーメッセージ
detailsarray?バリデーションエラーの詳細(該当する場合)

エラーコード

コード説明
400無効な入力またはバリデーション失敗
500内部サーバーエラー

推奨:SDK の使用

このエンドポイントを直接呼び出す代わりに、createAndRegisterLaunch を使用することを推奨します。この関数はトランザクションの作成、署名、送信、登録のフロー全体を1回の呼び出しで処理します:

createAndRegisterLaunch.ts
1import {
2 createAndRegisterLaunch,
3 CreateLaunchInput,
4 genesis,
5} from '@metaplex-foundation/genesis'
6import { createUmi } from '@metaplex-foundation/umi-bundle-defaults'
7import { keypairIdentity } from '@metaplex-foundation/umi'
8
9const umi = createUmi('https://api.mainnet-beta.solana.com')
10 .use(genesis())
11
12// Use keypairIdentity to set a wallet when running server-side:
13// umi.use(keypairIdentity(myKeypair))
14
15const input: CreateLaunchInput = {
16 wallet: umi.identity.publicKey,
17 token: {
18 name: 'My Token',
19 symbol: 'MTK',
20 image: 'https://gateway.irys.xyz/...',
21 },
22 launchType: 'project',
23 launch: {
24 launchpool: {
25 tokenAllocation: 500_000_000,
26 depositStartTime: new Date(Date.now() + 48 * 60 * 60 * 1000),
27 raiseGoal: 200,
28 raydiumLiquidityBps: 5000,
29 fundsRecipient: umi.identity.publicKey,
30 },
31 },
32}
33
34const result = await createAndRegisterLaunch(umi, {}, input)
35console.log(`Launch live at: ${result.launch.link}`)

SDK の全ドキュメント(3つの統合モードを含む)については、API クライアントを参照してください。