アプリ拡張
アプリ拡張について学びます。
今日の拡張
今日の拡張は、デバイスの「今日」画面に表示されるウィジェットです。これらのアプリ拡張は、OSによって非常に限られたリソースが許可されており、メモリや処理能力を多く消費すると終了される可能性があります。
Today Extension内でSwiftライブラリを通常通り使用しますが、メモリの使用量を抑えるために、データを送信するためにCollect moduleのみを使用することをお勧めします。Tag Management moduleはリソースを大量に消費し、ウィジェットが終了する原因となる可能性があります。
選択したオプションに関係なく、ウィジェットが期待通りに動作することを確認するために、十分にテストを行うことが重要です。ウィジェットにTealiumモジュールを少なく埋め込むことで、パフォーマンスが向上し、メモリの使用量が少なくなります。
watchOS拡張と独立したアプリ
すでにTealiumがインストールされているiOSプロジェクトにwatchOSターゲットを追加する場合は、必要なモジュール、TealiumHelper
をWatch Extensionターゲットに追加し、必要なトラッキングコールを行います。Tag ManagementモジュールはWKWebView
への依存性のため、watchOSではサポートされていません。CollectモジュールはwatchOSでのデータ収集の唯一のサポートされている方法です。
あるいは、WatchConnectivty
フレームワークのWCSession
APIを使用して、トラッキングコールを送信するたびにホストiOSアプリにメッセージを送信することもできます。これにより、Tag Managementモジュールを使用している場合にイベントを追跡することができますが、独立したwatchOSアプリではオプションになりません。
アプリ拡張のVisitor 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をconfigオブジェクトに渡す
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(例えばメールアドレス)を使用しないでください。
最終更新日 :: 2024年March月29日