Skip to content

ユーザーをマージする

post

/users/merge

このエンドポイントを使用して、あるユーザーを別のユーザーにマージする。

マージはリクエストごとに50個まで指定できます。このエンドポイントは非同期である。

前提条件

このエンドポイントを使用するには、users.merge 権限を持つ API キーが必要です。

レート制限

Request body

1
2
Content-Type: application/json
Authorization: Bearer YOUR_REST_API_KEY
1
2
3
{
  "merge_updates" : (required, array of objects)
}

リクエストパラメーター

パラメーター required データ型 説明
merge_updates required 配列 オブジェクトの配列。各オブジェクトには identifier_to_merge オブジェクトと identifier_to_keep オブジェクトが含まれている必要があり、それぞれが external_iduser_aliasphone_number、または email のいずれかでユーザーを参照する必要があります。

マージ動作

以下に説明する動作は、Snowflakeを使用していないBrazeの全機能に当てはまる。メッセージング履歴]タブ、[セグメント拡張]、[クエリビルダー]、および[カレント]では、ユーザーのマージが反映されない。

このエンドポイントは、以下のフィールドがターゲット・ユーザーに見つからない場合、それらをマージする:

  • メール
  • 性別
  • 生年月日
  • 電話番号
  • タイムゾーン
  • 市区町村
  • 言語
  • デバイス情報
  • セッション数 (両方のプロファイルのセッションの合計)
  • 初回セッションの日付 (Braze は2つの日付のうち早い方を選択します)
  • 最終セッションの日付 (Braze は2つの日付のうち遅い方の日付を選択します)
  • カスタム属性(ターゲットプロファイル上の既存のカスタム属性は保持され、ターゲットプロファイル上に存在しなかったカスタム属性も含まれる)
  • カスタム・イベントと購入イベントのデータ
  • Y日間にX回」のセグメンテーション(X<=50、Y<=30)のためのカスタムイベントと購入イベントのプロパティ。
  • セグメント可能なカスタム・イベントのサマリー
    • イベント数(両プロファイルの合計)
    • イベントが最初に発生した日(Brazeは2つの日付のうち早い方を選ぶ)
    • イベントが最後に発生した日(Brazeは2つの日付のうち遅い方を選ぶ)
  • アプリ内購入の合計(セント単位)(両方のプロファイルの合計)
  • 購入総数 (両方のプロファイルの合計)
  • 初回購入日 (Braze は2つの日付のうち早い方を選択します)
  • 最終購入日 (Braze は2つの日付のうち遅い方を選択します)
  • アプリの概要
  • Last_X_atフィールド(Brazeは、孤児となったプロファイルフィールドがより新しいものであれば、フィールドを更新する)
  • キャンペーンのインタラクションデータ(Brazeは最新の日付フィールドを選ぶ)
  • ワークフローのサマリー(Brazeは最新の日付フィールドを選ぶ)
  • メッセージとメッセージのエンゲージメント履歴

セッションデータは、両方のユーザープロファイルにアプリが存在する場合にのみマージされる。

カスタムイベント日と購入イベント日の動作

これらの統合されたフィールドは、「Y日以内にXイベント」フィルターを更新する。購入イベントの場合、これらのフィルターには、「Y日間の購入回数」と「過去Y日間の使用金額」が含まれる。

電子メールまたは電話番号でユーザーをマージする

識別子として email または phone_number が指定された場合、識別子にはさらに prioritization の値が必要になります。prioritization は、複数のユーザーが見つかった場合に、どのユーザーをマージするかを指定する配列でなければならない。prioritization は順序付き配列である。つまり、優先順位付けから複数のユーザーがマッチした場合、マージは行われない。

配列に使用できる値は、identifiedunidentifiedmost_recently_updated です。most_recently_updated は、最も最近更新されたユーザーを優先することを意味します。

優先配列には、一度に以下のオプションのうち1つしか存在できません。

  • identified を持つユーザーを優先することである。 external_id
  • unidentified のないユーザーを優先することである。 external_id

リクエスト例

基本リクエスト

これはリクエストのパターンを示す基本的なリクエストボディである。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
curl --location --request POST 'https://rest.iad-01.braze.com/users/merge' \
--header 'Content-Type: application/json' \
--header 'Authorization: Bearer YOUR_REST_API_KEY' \
--data-raw '{
{
  "merge_updates": [
    {
      "identifier_to_merge": {
        "external_id": "old-user1"
      },
      "identifier_to_keep": {
        "external_id": "current-user1"
      }
    },
    {
      "identifier_to_merge": {
        "email": "user1@braze.com",
        "prioritization": ["unidentified", "most_recently_updated"]
      },
      "identifier_to_keep":  {
        "email": "user2@braze.com",
        "prioritization": ["identified", "most_recently_updated"]
      }
    },
    {
      "identifier_to_merge": {
        "user_alias": {
          "alias_name": "old-user2@example.com",
          "alias_label": "email"
        }
      },
      "identifier_to_keep": {
        "user_alias": {
          "alias_name": "current-user2@example.com",
          "alias_label": "email"
        }
      }
    }
  ]
}'

未確認ユーザーをマージする

以下のリクエストは、電子メールアドレス “john.smith@braze.com” を持つ、直近に更新された未確認ユーザーを、external_id “john “を持つユーザーにマージします。most_recently_updated を使用して、クエリを1人のみの未確認ユーザーに絞り込みます。そのため、このメールアドレスを持つ未確認のユーザーが2人いた場合、external_id “john “のユーザーにマージされるのは1人だけである。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
curl --location --request POST 'https://rest.iad-01.braze.com/users/merge' \
--header 'Content-Type: application/json' \
--header 'Authorization: Bearer YOUR_REST_API_KEY' \
--data-raw '{
{
  "merge_updates": [
    {
      "identifier_to_merge": {
        "email": "john.smith@braze.com",
        "prioritization": ["unidentified", "most_recently_updated"]
      },
      "identifier_to_keep": {
        "external_id": "john"
      }
    }
  ]
}'

未確認ユーザーを識別されたユーザーにマージする

この次の例は、電子メールアドレス “john.smith@braze.com” を持つ、最も最近更新された未確認ユーザーを、電子メールアドレス “john.smith@braze.com” を持つ、最も最近更新された識別されたユーザーにマージします。most_recently_updated を使用して、クエリを1人のみのユーザーに絞り込みます (identifier_to_merge の場合は未確認ユーザー1人、identifier_to_keep の場合は識別されたユーザー1人)。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
curl --location --request POST 'https://rest.iad-01.braze.com/users/merge' \
--header 'Content-Type: application/json' \
--header 'Authorization: Bearer YOUR_REST_API_KEY' \
--data-raw '{
{
  "merge_updates": [
    {
      "identifier_to_merge": {
        "email": "john.smith@braze.com",
        "prioritization": ["unidentified", "most_recently_updated"]
      },
      "identifier_to_keep": {
        "email": "john.smith@braze.com",
        "prioritization": ["identified", "most_recently_updated"]
      }
    }
  ]
}'

most_recently_updated の優先順位付けを含めずに、未確認ユーザーをマージする

メールアドレス”john.smith@braze.com”を持つ正体不明のユーザーが2人いる場合、このリクエスト例では、そのメールアドレスを持つ正体不明のユーザーが2人いるため、どのユーザーもマージしない。このリクエストは、メールアドレス”john.smith@braze.com”を持つ未確認ユーザーが1人しかいない場合にのみ機能する。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
curl --location --request POST 'https://rest.iad-01.braze.com/users/merge' \
--header 'Content-Type: application/json' \
--header 'Authorization: Bearer YOUR_REST_API_KEY' \
--data-raw '{
{
  "merge_updates": [
    {
      "identifier_to_merge": {
        "email": "john.smith@braze.com",
        "prioritization": ["unidentified"]
      },
      "identifier_to_keep": {
        "external_id": "john"
      }
    }
  ]
}'

応答

このエンドポイントには、202400 の2つのステータスコード応答があります。

成功応答の例

ステータスコード 202 は、次の応答本文を返す可能性があります。

1
2
3
{
  "message": "success"
}

エラー応答例

ステータスコード 400 は、次の応答本文を返す可能性があります。遭遇する可能性のあるエラーの詳細については、「トラブルシューティング」を参照のこと。

1
2
3
{
  "message": "'merge_updates' must be an array of objects"
}

トラブルシューティング

以下の表は、起こりうるエラーメッセージの一覧である。

エラー トラブルシューティング
'merge_updates' must be an array of objects merge_updates がオブジェクトの配列であることを確認する。
a single request may not contain more than 50 merge updates 1回のリクエストで指定できるマージ更新は50件までです。
identifiers must be objects with an 'external_id' property that is a string, 'user_alias' property that is an object, or 'email' property that is a string リクエストの識別子をチェックする。
'merge_updates' must only have 'identifier_to_merge' and 'identifier_to_keep' merge_updatesidentifier_to_mergeidentifier_to_keep という2つのオブジェクトしか含まれていないことを確認します。
「このページはどの程度役に立ちましたか?」
New Stuff!