— イベントの送信方法について理解する

Usage

イベントの種類

KARTE では目的に応じて view identify track の3つのイベント送信メソッドを提供しています。

画面の表示イベントを送信する

ある画面の表示(閲覧)したことをイベントとして送信する場合は、view メソッドを利用します。

第1引数には、画面を一意に識別するための識別子(view_name)を指定します。
第2引数には、画面名(タイトル)を指定します。

このメソッドを利用して送信するイベントは view イベントと呼ばれます。

🚧

viewイベントの注意点

viewイベントへのview_nameの付与は必須です。付与されない場合KARTEにviewイベントは送信されません。

※viewイベントへのtitleは実装観点での必須項目ではありませんが、運用観点(KARTE管理画面用での視認性のため)で、特別な理由がない限りは付与を推奨しています。

Tracker.view("signup", title: "会員登録")
[KRTTracker view:@"signup" title:@"会員登録"];

なお画面の表示イベントの送信は、track メソッドの第1引数にviewを指定して行うことも可能です。
下記コードは、上記コードと同等の意味合いとなります。

Tracker.track("view", values: [
  "view_name": "signup",
  "title": "会員登録"
])
[KRTTracker track:@"view" values:@{
  @"view_name": @"signup",
  @"title": @"会員登録"
}];

view メソッドの仕様については、リファレンス をご覧ください。

👍

Viewメソッドの実装位置

viewDidAppear(_:) に実装することを推奨します。

ユーザーの情報を送信する

ユーザーに紐付く情報(ユーザーIDや名前、年齢等)を送信する場合は、identify メソッドを利用します。

第1引数には、ユーザーのIDを指定します。
第2引数には、ユーザーに紐付ける情報を指定します。

このメソッドを利用して送信するイベントは identify イベントと呼ばれます。

🚧

identifyイベントの注意点

identifyイベントへのuser_idの付与は必須です。付与されない場合KARTEにidentifyイベントは送信されません。
user_idの確定前にユーザーに紐づく情報を送信する場合 attributeイベント を使用してください。
なお、 attributeイベント には個人情報を含めないよう十分にご注意ください。
詳細は個人情報関連イベントの特別な仕様についてを参照ください。

Tracker.identify(
  "karte_taro", 
  ["name": "カルテ太郎"]
)
[KRTTracker identify:@"ユーザーID" :@{
    @"name": @"KARTE太郎"
}];

なお identify イベントの送信は、track メソッドの第1引数にidentifyを指定して行うことも可能です。
下記コードは、上記コードと同等の意味合いとなります。

Tracker.track("identify", values: [
  "user_id": "karte_taro",
  "name": "カルテ太郎"
])
[KRTTracker track:@"identify" values:@{
  @"user_id": @"karte_taro",
  @"name": @"カルテ太郎"
}];

identify メソッドの仕様については、リファレンス をご覧ください。

任意の行動イベントを送信する

画面の表示やユーザー情報以外の行動情報について送信する場合は、track メソッドを利用します。

第1引数には、行動を表すイベント名を指定します。
第2引数には、行動に紐付く情報を任意で指定します。

このメソッドを利用して送信するイベントはカスタムイベントと呼ばれます。

Tracker.track("favorite", values: [
  "id": "P00003",
  "name": "ミネラルウォーター(500ml)",
  "price": 100
])
[KRTTracker track:@"favorite" values:@{
  @"id": @"P00003",
  @"name": @"ミネラルウォーター(500ml)",
  @"price": @(100)
}];

track メソッドの仕様については、リファレンス をご覧ください。

📘

イベント名の制限と予約済みのイベント名

イベント名には制限があります。
詳細については、 イベント名の制限 をご覧ください。

また一部のイベント名は予約されており、KARTE上で特別な扱いを受けます。
詳細については、定義済みイベント をご覧ください。

イベントに付与可能な値の型

各イベントの送信メソッドには、任意で Dictionary を渡すことが可能です。
これによりイベントに様々なフィールドを紐付けて送信することが可能になります。

なお Dictionary の Key および Value には制限があります。

Keyとして利用可能な型

String または NSString 型の値のみ利用可能です。

📘

フィールド名の制限

フィールド名には制限があります。
詳細については、フィールド名の制限 をご覧ください。

Valueとして利用可能な型

下記表に記載の型のみ利用可能です。
なお日付型は内部的に浮動小数点型に変換された上で送信されます。

種別
文字列String NSString
整数(符号あり)Int Int8 Int16 Int32 Int64 NSNumber
整数(符号なし)UInt UInt8 UInt16 UInt32 UInt64 NSNumber
浮動小数点数Double Float CGFlaot NSNumber
真偽値Bool NSNumber
日付Date NSDate
辞書Dictionary NSDictionary
配列Array NSArray