アプリ拡張機能
アプリ拡張機能について学びましょう。
今日の拡張機能
今日の拡張機能は、デバイスの「今日」画面に表示されるウィジェットです。これらのアプリ拡張機能はOSによって非常に限られたリソースが許可されており、メモリや処理能力を多く消費すると終了される可能性があります。
Today Extension内でSwiftライブラリを通常通り使用しますが、メモリの使用量を低く保つために、データ送信にはCollectモジュールのみを使用することをお勧めします。Tag Managementモジュールはリソースを多く消費するため、ウィジェットが終了する可能性があります。
選択したオプションに関わらず、ウィジェットが期待通りに動作することを徹底的にテストし、確認することが重要です。ウィジェットに組み込むTealiumモジュールを少なくすることで、パフォーマンスが向上し、メモリの使用量が低くなります。
watchOS拡張機能と独立したアプリ
TealiumがインストールされているiOSプロジェクトにwatchOSターゲットを追加する場合は、必要なモジュールとTealiumHelper
をWatch Extensionターゲットに追加し、必要なトラッキングコールを行います。Tag ManagementモジュールはWKWebView
に依存しているため、watchOSではサポートされていません。watchOSでのデータ収集にサポートされている唯一の方法はCollectモジュールです。
または、WatchConnectivty
フレームワークのWCSession
APIを使用して、トラッキングコールを送信したいたびにホストiOSアプリにメッセージを送ることができます。これにより、Tag Managementモジュールを使用している場合にイベントを追跡できますが、独立したwatchOSアプリではオプションになりません。
アプリ拡張機能での訪問ID
アプリ拡張機能は、ホストiOSアプリ(利用可能な場合)と共有されない独自のサンドボックス化されたデータ保存を持っています。そのため、デフォルトではアプリが初めて起動されたときに新しい永続的な訪問IDが生成されます。
iOSアプリ、Todayウィジェット、watchOS拡張機能を持つ場合、同じ訪問に対して3つの異なる訪問IDが発生する問題があります。これは、訪問のスティッチングを使用しており、すでにアプリユーザーの既知の訪問IDがある場合には問題になりません。この状況を避けるためには、アプリとその拡張機能間で訪問IDを同期させることが必要です。これは、Tealiumを初期化する際にアプリ拡張機能のTealiumConfig
オブジェクトに現在のTealium第一者訪問IDを渡すことで行われます。IDは保存され、アプリの将来の起動時に再生成されることなく使用されます。
class TealiumHelper {
var tealium: Tealium?
// ...
// iOSアプリのTealium Swiftライブラリから現在の訪問IDを返す
func getVisitorId() -> String? {
return self.tealium.visitorId
}
// アプリ拡張機能で、iOSアプリから取得したIDを構成オブジェクトに渡す
private func initTealium(existingVisitorId id: String) {
let config = TealiumConfig(account: "ACCOUNT",
profile: "PROFILE",
environment: "ENVIRONMENT",
datasource: "DATASOURCE")
// 既存のIDはアプリ拡張機能で第一者IDとして使用される
config.existingVisitorId = id
self.tealium = Tealium(config: config)
}
}
代わりに、訪問IDを中央で生成し、初期化時に各Tealiumインスタンスに渡すことをお勧めします。UUIDの使用が推奨されます。
最初の訪問IDに単純なID(例:メールアドレス)を使用しないでください。
最終更新日 :: 2025年July月30日