このエンドポイントは customer session token も受け付けます — Customer Session エンドポイント を参照。Customer トークンで呼び出す場合、買い手の身元はトークンから取得され、リクエストボディの
buyerIdentity フィールドは上書きされます。資格判定ルール
資格は、買い手がこの製品(または同じ製品グループ内の製品)に対して既にトライアル記録を持っているかどうかに基づきます:- トライアル記録なし →
isEligible: true、trialDaysは製品設定のトライアル日数 - トライアル記録あり →
isEligible: false、trialDaysはnull
buyerIdentity が空の場合、新規買い手として扱われ、常に isEligible: true を返します。
リクエストボディ
| フィールド | 型 | 必須 | 説明 |
|---|---|---|---|
checkoutSessionId | string | Yes | Checkout Session 作成で返された session ID(サブスクリプション製品である必要があります) |
buyerIdentity | string | 条件付き | 買い手のメールアドレス。Customer モードではトークンから取得(必須);visitor モードでは任意 — 省略するとレコード照会なしで完全なトライアルを返します |
リクエスト例
成功レスポンス (200) — 対象
成功レスポンス (200) — 対象外
レスポンスフィールド
| フィールド | 型 | 説明 |
|---|---|---|
isEligible | boolean | 買い手がトライアル対象かどうか(トライアル記録なし = true) |
trialDays | number | null | 対象の場合はトライアル日数;対象外の場合は null |
エラー
リトライポリシー:4xx は一切リトライしない — リクエストを修正してから再送信。5xx は指数バックオフでリトライ(5s 開始、最大 3 回)。
| ステータス | errors[0].message | 意味 | 推奨処理 |
|---|---|---|---|
| 400 | Invalid JSON body | リクエストボディが有効な JSON ではない | ボディを修正してから再送信 |
| 400 | Missing required field: checkoutSessionId | checkoutSessionId が提供されていない | ボディを修正してから再送信 |
| 400 | Session product type mismatch: expected subscription | Session がワンタイム製品で作成されている | サブスクリプション checkout session を作成してリトライ |
| 401 | Unauthorized | Store Slug または session token が無効 | 認証ヘッダーを確認 |
| 404 | Session not found | Checkout session が存在しないか期限切れ | 新しい checkout session を作成してリトライ |
| 404 | Session does not belong to this store | Session が別のストアのもの | 呼び出し元のストアに属する session を使用 |
| 500 | Internal server error | サーバ側の予期しない障害 | 指数バックオフでリトライ(5s 開始、最大 3 回) |