# Webhook

webhookにサブスクライブすることで、easyPoints APIを経由してイベントの通知を受け取ることができます。本ドキュメントでは、利用可能なトピック、Webhookのレスポンス要件、リトライポリシー、Webhookの検証方法、そしてWebhook APIエンドポイントをについて説明いたします。

# Webhookへの応答

Webhookが正常に受信された際には、受信後5秒以内にステータスコード200を返すことを確認してください。それ以外の場合、Webhookは再送信・リトライを行います。

# Webhookのリトライポリシー

Webhookの正常な受信が確認できなかった場合、最大20回までの再送信・リトライが行われます。Webhookの再送信は指数バックオフアルゴリズムと少量のジッターで行われ、20回目のリトライは、理論上初回の送信の12日後に行われます。

# Webhookの検証

WebhookAPIでは、Bearer Token認証が使用されます。トークンは、HS256ハッシュアルゴリズムで暗号化されたAPIシークレットキーで生成されます。シークレットキーを生成する方法は、APIアクセスセクションを参照ください。

以下は、Node.jsを使用してWebhookを検証する例です:

const jwt = require('jsonwebtoken');
const token = req.headers.authorization.split(' ')[1];

try {
  const decoded = jwt.verify(token, secretKey);
  // ...
} catch (error) {
  // 無効または期限切れのトークンを処理する
}

# 利用可能なトピック

現在は2つのWebhookトピックにサブスクライブ可能です:

  • point_allotment/cascade
  • point_balance/update

# point_allotment/cascade

このWebhookは、顧客のポイント残高にポイントが割り当てられたときにトリガーされます。

# ペイロード

フィールド タイプ 説明
allotted_at Datetime ポイントが割り当てられた日時(ISO8601フォーマット)
customer Object 関連する顧客に関する情報
customer.shopify_id Number 顧客のShopify ID
point_value Number 割り当てられたポイントの値
type String ポイントの種類(例:"fulfillment")
uid String ポイント割り当てイベントの一意の識別子

例:

{
  "allotted_at": "2023-01-02T12:00:00.000000",
  "customer": {
    "shopify_id": 7370359931169
  },
  "point_value": 1,
  "type": "fulfillment",
  "uid": "96304480-7203-11ee-b8cd-0a6257f44932"
}

# point_balance/update

このWebhookは、顧客のポイント残高が更新されるたびにトリガーされます。

このイベントは以下の場合にトリガーされます:

  • 顧客アカウントがアクティブになる
  • ポイントを獲得または使用する
  • 保有ポイントの有効期限が更新される
  • 顧客の名前または誕生日が変更される
  • 顧客がストアのマーケティングに登録する

なお、ストアの有効期限設定の変更時にもポイント残高の有効期限フィールドは変更されますが、その場合ポイント残高の更新Webhookはトリガーされません。

# ペイロード

フィールド タイプ 説明
accepts_marketing Boolean 顧客がShopifyのマーケティングを受け入れるかどうかを示します
account_enabled Boolean 顧客のアカウントが有効かどうかを示します
balance Integer 顧客の現在のポイント残高
birthday Date 顧客の誕生日(ISO8601形式)
customer Object 関連する顧客に関する情報
customer.shopify_id Integer 顧客のShopify ID
name String 顧客の名前
point_expiration_date Datetime ポイントが期限切れになる日時(ISO8601形式)
uid String ポイント残高の一意の識別子

例:

{
  "accepts_marketing": false,
  "account_enabled": true,
  "balance": 100,
  "birthday": "2000-01-01",
  "customer": {
    "shopify_id": 123456789
  },
  "name": "John Doe",
  "point_expiration_date": "2023-01-01T23:59:59+09:00",
  "uid": "f85478b0-70ba-11ee-95f2-0a6257f44932"
}

# ポイント残高/エクスポート

ポイント残高ルートからAPI経由のCSVエクスポートリクエストがあった際に起動します。

# ペイロード

フィールド タイプ 定義
url String ファイルのホストurl。注意: urlは1時間の間のみアクセス可能です。

例:

{
  "url": "https://loyalty.slrs.io/FILENAME_URL_HERE"
}

# Webhook API

Webhookサブスクリプションを取得、作成、および削除するためのAPIエンドポイントです。

# ベースルート

/api/shopify/webhooks

# Webhookサブスクリプションの取得

# ルート

以下のGETルートを使用して、ストアのすべてのWebhookを取得します:

GET /api/shopify/webhooks

# 結果

次のフィールドが返される場合があります:

キー タイプ 定義
activated_at Datetime Webhookサブスクリプションがアクティブになった日時(ISO8601形式)
active Boolean Webhookサブスクリプションがアクティブかどうかを示します
callback_url String Webhookが送信されるURL
shop_uid String あなたのストアのユニークID
topic String WebhookサブスクライブされているeasyPointsイベント
uid String WebhookサブスクリプションのユニークID

例:

GET "https://loyalty.slrs.io/api/shopify/webhooks"
{
    "data": [
        {
            "activated_at": "2023-01-01T00:00:00Z",
            "active": true,
            "callback_url": "https://your_callback_url.com/1",
            "shop_uid": "e378ad94-70ba-11ee-9c58-0a6257f44932",
            "topic": "point_allotment/cascade",
            "uid": "c2fb2e64-70c1-11ee-a2eb-0a6257f44932"
        },
        {
            "activated_at": "2023-01-01T00:00:00Z",
            "active": true,
            "callback_url": "https://your_callback_url.com/2",
            "shop_uid": "e378ad94-70ba-11ee-9c58-0a6257f44932",
            "topic": "point_balance/update",
            "uid": "03d78626-70c2-11ee-a398-0a6257f44932"
        }
    ]
}

# Webhookサブスクリプションの作成

# ルート

以下のPOSTルートを使用して、Webhookを作成します:

POST /api/shopify/webhooks

# 送信するフィールド

Webhookサブスクリプションを作成するには、次のフィールドを送信する必要があります:

キー タイプ 必須 定義
topic String ✔️ 利用可能なWebhookトピック
callback_url String ✔️ Webhookを送信するURL

利用可能なWebhookトピックのリストについては、利用可能なトピックセクションを参照してください。

# 結果

次のフィールドが返される場合があります:

キー タイプ 定義
activated_at Datetime Webhookサブスクリプションがアクティブになった日時(ISO8601形式)
active Boolean Webhookサブスクリプションがアクティブかどうかを示します
callback_url String Webhookが送信されるURL
topic String WebhookサブスクライブされているeasyPointsイベント
uid String WebhookサブスクリプションのユニークID

例:

POST "https://loyalty.slrs.io/api/shopify/Webhooks"
{
  "topic": "point_allotment/cascade",
  "callback_url": "https://your_callback_url.com"
}
{
    "status": 200,
    "data": {
      "activated_at": "2023-01-01T00:00:00Z",
      "active": true,
      "callback_url": "https://your_callback_url.com",
      "topic": "point_allotment/cascade",
      "uid": "03d78626-70c2-11ee-a398-0a6257f44932"
    }
}

WARNING

すでにサブスクライブされているトピックのWebhookサブスクリプションを作成しても、既存のサブスクリプションは更新または置換されません。既存のWebhookサブスクリプションを書き換えるにはには、まずそのトピックの元のWebhookサブスクリプションを削除する必要があります。

# Webhookサブスクリプションの削除

# ルート

以下のDELETEルートを使用して、Webhookを削除します:

DELETE /api/shopify/webhooks

# 送信するフィールド

Webhookサブスクリプションを削除するには、次のフィールドを送信する必要があります:

キー タイプ 必須 定義
topic String ✔️ 利用可能なWebhookトピック

利用可能なWebhookトピックのリストについては、上記の利用可能なトピックセクションを参照してください。

# 結果

例:

DELETE "https://loyalty.slrs.io/api/shopify/Webhooks"
{
  "topic": "point_allotment/cascade"
}
{
    "status": 200
}