— イベント送信の仕様について
Specification
本ドキュメントでは、イベントを送信するまでに行われる処理、具体的にはイベントのバッファリングの仕組みについて説明します。
イベントのバッファリングについて
発生したイベントは直接KARTEに送られず、一度SDK内部で一定時間バッファリングされた後に、一つのリクエストにまとめられてKARTEに送られます。
具体的には、あるイベントが発生して 100ms
以内に、他のイベントが発生するかどうかでリクエストが行われるかどうか決まります。
他のイベントが発生した場合は、新たに発生したイベントを起点に100ms以内にイベントが発生するかどうかの確認が行われます。
一方他のイベントが発生しなかった場合は、それまでに発生したイベントを一つのリクエストにまとめて送信します。
イベントのバッファリングにおける制約
基本的には上記項目に記載した通り、時間経過に基づいてイベントのバッファリング・リクエストが行われますが、いくつかの例外的な制約が設けられており、その制約に該当する場合は即座にリクエストが行われます。
例外的な制約は、以下の通りです。
- 複数の画面に跨がるリクエストは作成できない
- 複数のシーンに跨がるリクエストは作成できない
- 複数のユーザーに跨がるリクエストは作成できない
- 1つのリクエストに含まれるイベントの数は10個までとする
複数の画面に跨がるリクエストとは?
画面Aで発生したイベントと画面Bで発生したイベントは同じリクエストとして送信されることはありません。
これはアプリ内メッセージの表示制御を適切に機能させるために行っているものになります。
イベントがどの画面で発生したのかを認識するためにSDKでは画面の境界を認識する機能があります。
詳細については下記ドキュメントをご覧ください。
複数のシーンに跨がるリクエストとは?
異なるシーンから同時に発生したイベントは同じリクエストとして送信されることはありません。
これはアプリ内メッセージを適切なシーンに表示させるために行っているものになります。
シーンとは
1つのアプリケーションプロセス上でマルチウィンドウを実現するために iOS13 で導入された概念です。
これにより iPadOS では SplitView などの機能が提供されるようになりました。
複数のユーザーに跨がるリクエストとは?
異なるユーザーから同時に発生したイベントは同じリクエストとして送信されることはありません。
この制約に基づきリクエストが分割されるのは、基本的にビジターIDのリセットを行った時に限ります。
Updated 10 months ago