pending ステータスの注文のみキャンセル可能です。
キャンセル動作
| 現在のステータス | アクション | 結果ステータス |
|---|---|---|
pending | 即時キャンセル | canceled |
completed | 拒否 | 変更なし(終端状態) |
canceled | 拒否 | 変更なし(終端状態) |
- pending: 注文は即時キャンセルされ、ステータスは
canceledになります - 基盤の PSP checkout session は自動的に期限切れになり、PSP キャンセル API を別途呼び出す必要はありません
completedとcanceledは終端状態で、再度キャンセルすることはできません
リクエストボディ
| フィールド | 型 | 必須 | 説明 |
|---|---|---|---|
orderId | string | Yes | ワンタイム注文 ID(Short ID フォーマット ORD_xxx) |
リクエスト例
成功レスポンス (200)
レスポンスフィールド
| フィールド | 型 | 説明 |
|---|---|---|
orderId | string | 注文 ID(Short ID) |
status | string | 新しい注文ステータス(成功時は常に canceled) |
エラー
リトライポリシー:4xx は一切リトライしない — リクエストを修正してから再送信。5xx は指数バックオフでリトライ(5s 開始、最大 3 回)。
| ステータス | errors[0].message | 意味 | 推奨処理 |
|---|---|---|---|
| 400 | Missing required field: orderId | リクエストボディに orderId が含まれていない | リクエストボディを修正してから再送信 |
| 400 | Expected format: ORD_xxx, got "..." | orderId Short ID のデコード失敗 | orderId のフォーマットを修正してから再送信 |
| 400 | Order cannot be canceled, current status: X | 注文ステータスが pending ではない(completed や canceled など) | 注文はキャンセル不可 |
| 401 | Authentication failed | Session token が無効、期限切れ、または不正な形式 | Issue Session Token で再発行 |
| 403 | Order does not belong to user | 所有権チェック失敗 | 呼び出し元が注文を所有しているか確認 |
| 404 | Order not found | 注文が存在しない | order ID を確認 |
| 500 | Internal server error | サーバ側の予期しない障害 | 指数バックオフでリトライ(5s 開始、最大 3 回) |