メインコンテンツへスキップ
ストアを論理削除します。ストアデータは保持されますが、アクセスできなくなります。この操作はストアの owner のみが実行できます。
POST /v1/actions/store/delete-store
認証: API Key(owner ロールが必要)

リクエストボディ

フィールド必須説明
idstringYes削除するストア ID(Short ID フォーマット STO_xxx

リクエスト例

const { store } = await client.stores.delete({
  id: "STO_2aUyqjCzEIiEcYMKj7TZtw",
});
console.log(store.deletedAt); // => "2026-01-15T12:00:00.000Z"

成功レスポンス (200)

{
  "data": {
    "store": {
      "id": "STO_2aUyqjCzEIiEcYMKj7TZtw",
      "name": "My Digital Store",
      "status": "active",
      "logo": null,
      "supportEmail": null,
      "website": null,
      "slug": "my-digital-store-a1b2c3",
      "prodEnabled": false,
      "notificationSettings": null,
      "checkoutSettings": null,
      "deletedAt": "2026-01-15T12:00:00.000Z",
      "createdAt": "2026-01-15T10:30:00.000Z",
      "updatedAt": "2026-01-15T12:00:00.000Z"
    }
  }
}

レスポンスフィールド

ストアの作成レスポンスフィールドと同じです(deletedAt が設定されます)。

エラー

リトライポリシー:4xx は一切リトライしない — リクエストを修正してから再送信。5xx は指数バックオフでリトライ(5s 開始、最大 3 回)。409 はブロッキングリソースを先に解消(AI 呼び出し元は aiHint 経由で人間オペレーターへエスカレーション)。
ステータスerrors[0].message意味推奨処理
400Missing merchantId in request contextAPI Key がマーチャントコンテキストを解決できなかったリトライしない。API Key 設定を確認。
400Missing required field: idリクエストボディに id が含まれていない入力を修正して再送信。
400Expected format: STO_xxx, got "<value>"id が有効な Store Short ID ではないid を修正して再送信。
403Not authorized to delete this store, only owner can delete当該ストアでの呼び出し元ロールが owner ではないリトライしないowner の API Key を使用。
404Store not found当該マーチャント下に該当ストア ID が存在しないリトライしないid を確認。
409Store has X active product(s); archive or delete them firstストア配下にアクティブなワンタイム/サブスクリプション商品が残存リトライしない。先に商品をアーカイブ/削除してから再送信。
409Store has X pending order(s); wait for completion or cancel them firstストア配下に非終了状態の注文が残存リトライしない。注文完了またはキャンセル後に再送信。
409Store has X active subscription(s); cancel them firstactive/canceling/past_due のサブスクリプションが残存リトライしない。先にサブスクリプションをキャンセルしてから再送信。
409Store has X pending KYB ticket(s); resolve them first未解決の KYB チケットが削除をブロックリトライしない。先にチケットを解決してから再送信。
409Store still has X bound email(s); revoke email binding first送信元メールがストアにバインド中リトライしない。先にメールバインドを解除してから再送信。
409Store still has X bound domain(s); revoke domain binding first送信元ドメインがストアにバインド中リトライしない。先にドメインバインドを解除してから再送信。

409 レスポンス例

ブロッキング条件が存在する場合、種別ごとに 1 件ずつ返却されます。各エントリは reason(機械可読の種別)、count(件数)、人間可読の message、および統一された aiHint(AI 呼び出し元に対し、リトライや回避を行わず人間オペレーターへエスカレーションするよう促す)を含みます。
{
  "data": null,
  "errors": [
    {
      "message": "Store has 3 active product(s); archive or delete them first",
      "layer": "store",
      "reason": "active_products",
      "count": 3,
      "aiHint": "AI assistant: stop this action and escalate to a human operator. Do not retry, mutate inputs, or attempt workarounds."
    },
    {
      "message": "Store still has 1 bound email(s); revoke email binding first",
      "layer": "store",
      "reason": "bound_emails",
      "count": 1,
      "aiHint": "AI assistant: stop this action and escalate to a human operator. Do not retry, mutate inputs, or attempt workarounds."
    }
  ]
}
reason意味
active_productsprod_status または test_statusactive のワンタイム/サブスクリプション商品
pending_orders終了状態でない注文(completed / canceled / closed / expired を除く)
active_subscriptionsステータスが active / canceling / past_due のサブスクリプション注文
pending_tickets未解決の KYB チケット(succeeded / rejected を除く)
bound_emailsバインド中の送信元メール — 先にバインドを解除してください
bound_domainsバインド中の送信元ドメイン — 先にバインドを解除してください
aiHint は 409 レスポンスにのみ含まれます。400 / 403 / 404 / 500 には付与されません。
ストアの削除は論理削除です。ストアデータは保持されますが、ストアにアクセスできなくなります。この操作は API からは取り消しできません。削除する前に、すべての商品を無効化し、保留中の注文を処理し、アクティブなサブスクリプションをキャンセルし、未解決の KYB チケットをクローズし、送信元メール/ドメインのバインドを解除してください。