TealiumConfig
主なTealiumクラスの構成オプションを構成するクラス。個々のモジュールは、有効になっている場合、TealiumConfigクラスの拡張を提供します。
クラス: TealiumConfig
以下は、iOS(Swift)のTealiumConfig
クラスの一般的に使用されるメソッドとプロパティをまとめたものです。
メソッド/プロパティ | 説明 |
---|---|
addRemoteCommand() |
後で実行するためのリモートコマンドを追加します |
adobeVisitorAuthState |
訪問の現在の認証状態を構成します。 |
adobeVisitorCustomVisitorId |
初期化時に既知の場合、既知の訪問IDをAdobe ECIDに構成します。将来ECIDが変更された場合は、linkECIDToKnownIdentifier を呼び出して訪問IDを更新します。 |
adobeVisitorDataProviderId |
Adobeから提供されるデータプロバイダIDを構成します。これは、既知のIDにECIDをリンクする際に必要です。 |
adobeVisitorExistingEcid |
新しいECIDを要求する代わりに、以前のインストールから既存のECIDを使用するように構成します。例えば、Adobe SDKなど。 |
adobeVisitorOrgId |
@ 部分を含むAdobe Org IDを含む文字列。 |
adobeVisitorRetries |
要求が失敗する前に許可される無効な訪問IDの再試行の数。これにより、ECIDなしでトラッキングコールが送信されます。 |
appDelegateProxyEnabled |
Tealium AppDelegateプロキシを有効化(デフォルト)または無効化します |
autoTrackingBlocklistFilename |
ローカルブロックリストファイルの名前を構成します。 |
autoTrackingBlocklistURL |
リモートブロックリストファイルのURLを構成します。 |
autoTrackingCollectorDelegate |
自動的に追跡されたビューの実行を行うグローバルデリゲートを構成します。 |
batchingBypassKeys |
バッチングがバイパスされる(個々のイベントとして送信される)イベント名のリストを構成します |
batchingEnabled |
イベントバッチングを有効化または無効化(デフォルト)します |
batchSize |
一つのバッチリクエストに組み合わせるイベントの量を構成します(最大:10) |
connectivityRefreshEnabled |
有効化(デフォルト)されている場合、接続モジュールは指定した間隔で接続をチェックします |
connectivityRefreshInterval |
デフォルトの接続更新間隔を秒単位で構成します |
consentExpiry |
ユーザーの同意選択の有効期限を構成します |
consentLoggingEnabled |
同意ログ機能を有効化または無効化します |
consentPolicy |
同意ポリシーを構成します(デフォルトはGDPR) |
deepLinkTrackingEnabled |
ディープリンクの自動追跡を有効化または無効化します |
desiredAccuracy |
アプリが受け取りたい位置データの精度 |
diskStorageDirectory |
ディスク保存に使用するディレクトリを構成します。デフォルトは.caches 。 |
dispatchAfter |
キューがフラッシュされるイベントの数を構成します |
dispatchExpiration |
バッチの有効期限を日数で構成します。デバイスが長期間オフラインの場合、古いイベントは削除されます |
dispatchQueueLimit |
キューに入れるイベントの最大数を構成します。この数に達し、キューがフラッシュされていない場合、最も古いイベントが削除されます。 |
dispatchListeners |
トラッキングコールがディスパッチされる直前にリッスンするカスタムDispatchListener を追加するオプションを提供します |
dispatchValidators |
イベントをディスパッチ、キュー、またはドロップするかどうかを制御するカスタムDispatchValidator を追加するオプションを提供します |
enableBackgroundLocation |
アプリがバックグラウンドで実行されている間に位置情報の更新を有効にします |
existingVisitorId |
既存の訪問IDを構成します。これはアプリ拡張機能の第一者IDとして使用されます |
geofenceFileName |
ローカルジオフェンスJSONファイルアセットの名前を構成します。ファイル拡張子は含めないでください。 |
geofenceTrackingEnabled |
ジオフェンス追跡を有効化または無効化します |
geofenceUrl |
ホストされたJSONファイルのURLを構成します |
hostedDataLayerExpiry |
ホストされたデータレイヤーデータに有効期限を構成します |
hostedDataLayerKeys |
データレイヤーIDを検索する際にホストされたデータレイヤーモジュールが使用するイベントマッピングを構成します |
isCollectEnabled |
Collectディスパッチャを無効にするオプションを提供します |
lifecycleAutoTrackingEnabled |
ライフサイクルの自動追跡を有効化または無効化します。デフォルトはtrue です。false に構成されていて、ライフサイクルの起動/スリープ/ウェイクイベントが必要な場合、LifecycleModule の公開メソッドを使用して手動で呼び出す必要があります |
logger |
現在のTealiumLogger を置き換えるTealiumLoggerProtocol に準拠したカスタムロガーを構成します |
logLevel |
ログレベルプロパティを構成します。これはログに記録される情報の量を制御します |
logType |
新しいログタイプを構成します |
memoryReportingEnabled |
DeviceDataモジュールのメモリレポートを有効化または無効化します |
minimumFreeDiskSpace |
ディスク保存が有効になるための最小限の空きディスクスペースをメガバイトで構成します |
minutesBetweenRefresh |
パブリッシュ構成をどのくらいの頻度で取得するかを決定します |
onConsentExpiration |
同意選択が期限切れになったときに実行するコールバック |
overrideCollectProfile |
Tealium Collectプロファイルを上書きして、データを別のTealiumプロファイルに送信します |
overrideCollectURL |
Tealium Collect URLを上書きして、データを別のエンドポイントに送信します |
overrideCollectBatchURL |
Tealium Collect Batch URLを上書きして、データを別のエンドポイントに送信します |
overrideCollectDomain |
Tealium Collectドメイン名を上書きして、データを別のエンドポイントに送信します |
overrideConsentCategoriesKey |
同意カテゴリイベント属性の名前を上書きします。これを使用して、サーバーサイドの同意のカスタム強制をサポートします。(デフォルト:consent_categories ) |
publishSettingsProfile |
パブリッシュ構成プロファイルを上書きします |
publishSettingsURL |
パブリッシュ構成URLを上書きします |
remoteAPIEnabled |
remote_api イベントを有効化または無効化します。DispatchQueueモジュールが使用中の場合、RemoteCommandsモジュールが必要です。 |
remoteCommands |
すべての登録済みリモートコマンドの配列を返します |
remoteHTTPCommandDisabled |
true の場合、組み込みのリモートHTTPコマンドを無効にします |
rootView |
WKWebView がアタッチされる現在のUIView を構成します |
searchAdsEnabled |
アトリビューションモジュールのApple Search Ads APIを有効または無効にします |
sendCrashDataOnCrashDetected |
クラッシュが検出されたときにクラッシュイベントを送信し、そのイベントにのみクラッシュデータを追加します |
sendDeepLinkEvent |
ディープリンクが受信されるたびに、関連データとともにdeep_link イベントを送信します |
sessionCountingEnabled |
Tealium iQアカウントのセッションカウントを無効にします。TealiumのJavaScriptファイルを自己ホスティングしている場合に使用します |
shouldAddCookieObserver |
WKWebView のクッキーオブザーバーを追加するかどうかを決定します |
shouldUseRemotePublishSettings |
モバイルパブリッシュ構成を構成します(デフォルト:有効) |
skAdAttributionEnabled |
SKAdNetworkフレームワークの使用を有効にします |
skAdConversionKeys |
SKAdNetwork.updateConversionValue() メソッドを呼び出すイベントと値を定義します |
tagManagementOverrideURL |
タグ管理モジュールで使用されるデフォルトのURLを上書きします |
TealiumConfig() |
TealiumConfig オブジェクトのコンストラクタ |
timedEventTriggers |
タイムドイベントの自動トラッキング用のTimedEventTrigger オブジェクトのリスト |
updateDistance |
位置情報の更新が受信される距離間隔(メートル)を構成します |
useHighAccuracy |
位置情報の精度を低精度(デフォルト)または高精度に構成します |
visitorIdentityKey |
顧客識別子を表すデータレイヤーキーを指定する構成キーです。訪問の切り替えを有効にするために使用できます。 |
webviewProcessPool |
アプリがTealiumタグ管理のwebview以外に他のwebviewを含む場合、クッキーの同期問題を防ぎます |
webviewConfig |
カスタムWKWebviewConfiguration オブジェクトを渡すことを許可します。これはTealiumタグ管理のwebviewで使用されます |
addRemoteCommand()
後で実行するためのリモートコマンドを追加します。
addRemoteCommand(command)
パラメータ | タイプ | 説明 |
---|---|---|
command |
RemoteCommand |
追加されるTealiumRemoteCommand のインスタンス |
以下の例は、Tealiumの初期化の前に配置され、リモートコマンドの追加方法を示しています:
#if os(iOS)
let remoteCommand = RemoteCommand(commandId: "test",
description: "test") { response in
print("Remote Command 'test' executed")
}
config.addRemoteCommand(remoteCommand)
#endif
adobeVisitorAuthState
訪問の現在の認証状態を構成します。
例:
config.adobeVisitorAuthState = .authenticated
config.adobeVisitorAuthState = .loggedOut
config.adobeVisitorAuthState = .unknown
adobeVisitorCustomVisitorId
初期化時に既知の訪問IDが分かっている場合、そのIDをAdobe ECIDに構成します。将来ECIDが変更された場合は、訪問IDを更新するためにlinkECIDToKnownIdentifier
を呼び出します。
config.adobeVisitorCustomVisitorId = "20381482060927465156359999806251989655"
adobeVisitorDataProviderId
Adobeから提供されるデータプロバイダIDを構成します。これは、ECIDを既知のIDにリンクする際に必要です。
config.adobeVisitorDataProviderId = "01"
adobeVisitorExistingEcid
既存のECIDを使用して構成します。これは、新しいECIDを要求する代わりに、以前のインストールからのECIDを使用します。例えば、Adobe SDKなどです。
例:
config.adobeVisitorExistingEcid = "20381482060927465156359999806251989655"
adobeVisitorOrgId
Adobe Org IDを含む文字列を構成します。Org IDが提供されていない場合、モジュールは初期化されず、訪問IDは取得されません。Adobe ECIDなしでトラッキングコールが通常通り続行されます。
config.adobeVisitorOrgId = STRING_VALUE
例:
config.adobeVisitorOrgId = "1A2A111A111150AA0A110A12@AdobeOrg"
adobeVisitorRetries
リクエストが失敗する前に許される無効な訪問IDの再試行回数を構成します。これにより、ECIDなしでトラッキングコールが送信されます。
例:
config.adobeVisitorRetries = 5
appDelegateProxyEnabled
AppDelegateプロキシを有効にして、自動的にディープリンクトラッキングを行い、ディープリンクからTealiumトレースセッションを開始します。このプロパティはデフォルトで有効になっており、true
に構成されています。無効にするには、プロパティをfalse
に構成します。
config.appDelegateProxyEnabled = false
autoTrackingBlocklistFilename
AutoTracking Moduleと共に使用します。
自動トラッキングから省略するビューのリストを含むブロックリストファイルの名前を構成します。ファイルはAndroidのassets
ディレクトリに存在する必要があります。
config.autoTrackingBlocklistFilename = "autotracking-blocklist.json"
autoTrackingBlocklistURL
AutoTracking Moduleと共に使用します。
自動トラッキングから省略するビューのリストを含むJSON形式のブロックリストファイルへのURLを構成します。
config.autoTrackingBlocklistUrl = "https://example.com/autotracking-blocklist.json"
autoTrackingCollectorDelegate
AutoTracking Moduleと共に使用します。
TealiumConfig
オブジェクトに構成されたグローバルデリゲートで、AutoTrackingモジュールによってトラッキングされたビューに対して実行されます。このデリゲートを編集して、特定のビューに含めるデータをカスタマイズします。
config.autoTrackingCollectorDelegate = myCollectorDelegate
batchingBypassKeys
バッチングをバイパスする(個々のイベントとして送信する)イベント名のリストを構成します。
config.batchingBypassKeys = ["home_screen"]
batchingEnabled
イベントのバッチングを有効または無効にします。デフォルトでは無効になっています。
config.batchingEnabled = true
batchSize
単一のバッチリクエストに組み合わせるイベントの数を構成します。最大は10です。
config.batchSize = 8
Collectors
Collectorsは、デバイスから補足情報を収集し、それをデータレイヤーに追加してTealium Customer Data Hubに送信するモジュールです。一部のコレクターはコアライブラリに含まれていますが、他のコレクターはオプションで、別のモジュールとしてインストールされます。
以下の表は、利用可能なコレクターを一覧にしたものです。デフォルトのコレクターは、コレクター名の隣に*
が付いています。
コレクター名 | TealiumConfig リファレンス |
---|---|
AdobeVisitor |
Collectors.AdobeVisitor |
AppData * |
Collectors.AppData |
Connectivity * |
Collectors.Connectivity |
Device |
Collectors.Device |
Lifecycle |
Collectors.Lifecycle |
これらのモジュールは、TealiumConfig
のcollectors
プロパティを使用して有効または無効にします。
以下の例は、使用しているコレクターのリストに追加する方法を示しています:
config.collectors = [Collectors.AdobeVisitor]
connectivityRefreshEnabled
有効にすると(デフォルト)、接続モジュールは指定した間隔(setConnectivityRefreshInterval
で制御)で接続をチェックします。接続が再開されるとすぐに、キューに入れられたディスパッチが送信されます。
config.connectivityRefreshEnabled = true
connectivityRefreshInterval
デフォルトの接続更新間隔を秒単位で構成します。TealiumConfigインスタンスで構成されていない場合のデフォルトは30秒です。
config.connectivityRefreshInterval = 30
consentExpiry
ユーザーの同意選択の有効期限を構成します。Tealiumを初期化するときにこのプロパティを構成します。同意選択のデフォルトの有効期限は以下の通りです:
- CCPA:395日
- GDPR:365日
以下は、同意の有効期限を90日に構成します。
config.consentExpiry = (90, .days)
consentLoggingEnabled
Consent Logging機能を有効にし、すべての同意ステータスの変更を監査目的でTealium Customer Data Hubに送信します。
config.consentLoggingEnabled = true
consentPolicy
同意ポリシーを構成します。Consent Managerは、このプロパティが構成されている場合にのみ有効になります。
config.consentPolicy = .ccpa
deepLinkTrackingEnabled
Facebookや他のソースからのアプリへのリンク、QRトレースなどの標準的なディープリンクの自動トラッキングを有効または無効にします。デフォルトでは有効になっています。
config.deepLinkTrackingEnabled = true
desiredAccuracy
アプリが受け取りたい位置データの精度。
config.desiredAccuracy = .best
利用可能なdesiredAccuracy
オプションは以下の通りです:
desiredAccuracy オプション |
説明 |
---|---|
.bestForNavigation |
常に正確な位置情報が必要なナビゲーションアプリで使用する精度レベル |
.best |
非常に高い精度だが、ナビゲーションアプリに必要な精度レベルは必要ない |
.nearestTenMeters |
最寄りの10メートルまでの精度 |
.nearestHundredMeters |
最寄りの100メートルまでの精度 |
.reduced |
1-20キロメートル以内の精度 |
.withinOneKilometer |
最寄りの1キロメートルまでの精度 |
.withinThreeKilometers |
最寄りの3キロメートルまでの精度 |
Appleのdesired accuracy constantsについて詳しく学びましょう。
diskStorageDirectory
ディスク保存に使用するディレクトリを構成します。デフォルトは.caches
です。
config.diskStorageDirectory = .documents
dispatchListeners
トラッキングコールがディスパッチされる直前にリッスンするカスタムDispatchListener
を追加するオプションを提供します。
config.dispatchListeners = [self]
dispatchValidators
ディスパッチ、キュー、またはイベントのドロップを制御するカスタムDispatchValidator
を追加するオプションを提供します。
config.dispatchValidators = [self]
dispatchAfter
キューを自動的にフラッシュするイベントの数。
config.dispatchAfter = 20
dispatchExpiration
ディスパッチの有効期限を日数で構成します。デバイスが長期間オフラインの場合、古いイベントは削除されます。
config.dispatchExpiration = 5
dispatchQueueLimit
イベントキューに保存するイベントの最大数を構成します。この数に達し、キューがフラッシュされていない場合、最も古いイベントが削除されます。
config.dispatchQueueLimit = 50
enableBackgroundLocation
アプリがバックグラウンドで実行されている間に位置更新が行われるようにします。
config.enableBackgroundLocation = true
existingVisitorId
既存の訪問IDを構成します。これはアプリ拡張機能での第一者IDとして使用されます。
config.existingVisitorId = id
geofenceFileName
ローカルのジオフェンスファイルアセットの名前を構成します。ファイル拡張子は含めないでください。
config.geofenceFileName = <String>
タイプ | 説明 | 例 |
---|---|---|
String |
JSONファイル名 | geofences |
geofenceTrackingEnabled
ジオフェンストラッキングを無効化または有効化します。
config.geofenceTrackingEnabled = false
タイプ | 説明 | 例 |
---|---|---|
Bool |
ジオフェンシングが有効化されるべきかどうかを示すブール値 | false |
geofenceUrl
ホストされたジオフェンスファイルのURLを構成します。
config.geofenceUrl = <String (url)>
タイプ | 説明 | 例 |
---|---|---|
String |
ジオフェンスファイルのURL | https://example.com/.../geofences.json |
hostedDataLayerExpiry
ホストされたデータレイヤーデータの有効期限を構成します。このプロパティが構成されていない場合、ホストされたデータレイヤーアイテムはデフォルトで7日間持続し、この期間が経過すると再ダウンロードされます。
config.hostedDataLayerExpiry = (1, unit: .minutes)
有効期限を短く構成すると、ネットワークリクエストが増えるため、モバイルデバイスのバッテリー寿命が短くなります。
hostedDataLayerKeys
ホストされたデータレイヤーモジュールがデータレイヤーIDを取得する際に使用するホストされたデータレイヤーキー(ルックアップ変数)を構成します。
config.hostedDataLayerKeys = ["product_view" : "product_id"]
isCollectEnabled
collect dispatcherを無効にするオプションを提供します。主にリモートパブリッシュ構成の使用を目的としています。
config.isCollectEnabled = false
lifecycleAutoTrackingEnabled
ライフサイクルの自動トラッキングを有効または無効にします。デフォルトはtrue
です。false
に構成されていて、ライフサイクルの起動/スリープ/ウェイクイベントが必要な場合、LifecycleModule
の公開メソッドを使用して手動で呼び出す必要があります。
config.lifecycleTrackingEnabled = false
logger
現在のTealiumLogger
を置き換える、TealiumLoggerProtocol
に準拠したカスタムロガーを構成します。
以下の例は、構成オブジェクトにカスタムロガーを構成する方法を示しています:
class CustomLogger: TealiumLoggerProtocol {
// ... TealiumLoggerProtocolに準拠
// および独自のカスタムメソッド
}
class TealiumHelper {
let config = TealiumConfig(...)
var tealium: Tealium?
let customLogger = CustomLogger()
// ...
private init() {
config.logger = customLogger
// ...
tealium = Tealium(config: config)
}
}
logLevel
ログレベルプロパティを構成します。これは、ログに記録される情報の量を制御します。以下の値のいずれかに構成します:
ログレベル | ログ活動の説明 |
---|---|
.debug |
アプリケーションのデバッグに使用されるデバッグレベルのイベント(開発環境での使用を推奨) |
.info |
アプリケーションの進行状況を強調する情報イベント |
.error |
クリティカルエラーや失敗などのエラーイベント |
.fault |
システムレベルやマルチプロセスエラーなどの重大なイベント |
.silent |
ログなし |
config.logLevel = .debug
開発ログはXcodeコンソールまたはMac Consoleアプリで表示します。iOSデバイスを接続してConsoleアプリで製品ログを表示します。
logType
新しいロガータイプを構成します。デフォルトは.os
またはOSLog
です。
以下の例は、ログレベルをprint
に構成する方法を示しています:
config.logType = .print
memoryReportingEnabled
DeviceDataモジュールのメモリレポートを有効または無効にします(デフォルト:無効)。
config.memoryReportingEnabled = true
minimumFreeDiskSpace
ディスク保存が有効になるための最小の空きディスクスペースをメガバイトで構成します
config.minimumFreeDiskSpace = 25
minutesBetweenRefresh
パブリッシュ構成をどのくらいの頻度で取得するかを決定します。
config.minutesBetweenRefresh = 15
onConsentExpiration
同意選択が期限切れになったときに実行するコールバック。
config.onConsentExpiration = {
// 同意モーダルを表示
}
overrideCollectProfile
Tealium Collectプロファイルを上書きして、データを別のTealiumプロファイルに送信します。
config.overrideCollectProfile = "main"
overrideCollectURL
Tealium Collect URLを上書きして、データを別のエンドポイントに送信します。イベントバッチング機能を使用している場合は、overrideCollectBatchURLプロパティも上書きします。
config.overrideCollectURL = url
プロパティ値 | タイプ | 説明 |
---|---|---|
url |
String |
上書きするURL |
デフォルトのURLは次のとおりです:
https://collect.tealiumiq.com/event/
このプロパティは、カスタムホスト名を構成するため、または特定の地域のホスト名を構成するために使用されます。次の例では、Tealium Collectの基本URLをEU Central地域内に保持するように構成しています:
let url = "https://collect-eu-central-1.tealiumiq.com/event/"
config.overrideCollectURL = url
overrideCollectBatchURL
Tealium CollectのバッチURLを上書きして、データを別のエンドポイントに送信します。
config.overrideCollectBatchURL = url
プロパティ値 | タイプ | 説明 |
---|---|---|
url |
String |
上書きするURL |
イベントバッチングを使用した場合のデフォルトのURLは次のとおりです:
https://collect.tealiumiq.com/bulk-event/
このメソッドは、カスタムホスト名を構成するため、または特定の地域のホスト名を構成するために通常使用されます。次の例では、Tealium Collectの基本URLをEU Central地域内に保持するように構成しています:
let url = "https://collect-eu-central-1.tealiumiq.com/bulk-event/"
config.overrideCollectBatchURL = url
overrideCollectDomain
デフォルトのCollectドメインを上書きします。値をプロトコルを除いたホスト名(例:my-company.com
)に構成します。このプロパティはバッチと単一イベントの両方のディスパッチに使用します。overrideCollectURL
またはoverrideCollectBatchURL
が入力されている場合、このプロパティが優先されます。
config.overrideCollectDomain = "my-company.com"
overrideConsentCategoriesKey
同意イベントで送信される同意カテゴリ属性の名前を上書きします。これを使用して、サーバーサイドの同意のカスタム強制をサポートします。デフォルト値はconsent_categories
です。
config.overrideConsentCategoriesKey = "consent_categories_granted"
デフォルトの同意イベント:
{
"tealium_event" : "grant_partial_consent",
"policy" : "gdpr",
"consent_categories" : ["Affiliates", "Social"]
}
上書きを含む同意イベント:
{
"tealium_event" : "grant_partial_consent",
"policy" : "gdpr",
"consent_categories_granted" : ["Affiliates", "Social"]
}
サーバーサイドの同意管理の自動強制を無効にするについて詳しく学びましょう。
publishSettingsProfile
パブリッシュ構成プロファイルを上書きします。
config.publishSettingsProfile = "main"
publishSettingsURL
パブリッシュ構成URLを上書きします。
config.publishSettingsURL = "https://www.example.com/custom/publish/settings.html"
remoteAPIEnabled
remote_api
イベントを有効または無効にします。DispatchQueueモジュールが使用中の場合、RemoteCommandsモジュールが必要です。デフォルトはfalse
です。
config.remoteAPIEnabled = true
remoteCommands
すべての登録済みリモートコマンドの配列を返します。
次の例は、すべての登録済みリモートコマンドの配列を取得する方法を示しています:
let remoteCommands = config.remoteCommands
remoteHTTPCommandDisabled
組み込みのリモートHTTPコマンドを無効にします(Swift Module: RemoteCommandsを参照)。
config.remoteHTTPCommandDisabled = true
rootView
WKWebView
が接続される現在のUIView
を構成します。プッシュ通知などの複雑なビュー階層がある場合、自動検出が失敗する可能性があるため、この構成が必要です。
let view = self.view
config.rootView = view
searchAdsEnabled
AttributionモジュールのApple Search Ads APIを有効または無効にします(デフォルト:無効)。
config.searchAdsEnabled = true
sendCrashDataOnCrashDetected
クラッシュが検出されたときにクラッシュイベントを送信し、そのイベントにのみクラッシュデータを追加します(デフォルト:false)。
config.sendCrashDataOnCrashDetected = true
sendDeepLinkEvent
ディープリンクが受信されるたびに関連データとともにdeep_link
イベントを送信します(デフォルト:false)。
config.sendDeepLinkEvent = true
sessionCountingEnabled
Tealium iQアカウントのセッションカウントを無効にします。TealiumのJavaScriptファイルを自己ホスティングしている場合に使用します(デフォルト:true)。
config.sessionCountingEnabled = false
shouldAddCookieObserver
true
(デフォルト)に構成されている場合、このメソッドはすべてのクッキーを正常に移行するためにWKWebView
クッキーオブザーバーを追加するかどうかを決定します。false
に構成されている場合、複数のクッキーオブザーバーが存在する場合はそのうちの1つだけが呼び出され、これにより一部のクッキーが移行しない可能性があります。
config.shouldAddCookieObserver = false
shouldAddCookieObserver
プロパティは、クッキー同期中に自分のクッキーオブザーバーを使用することを許可します。これには、クッキーを構成した後にメインスレッドでクッキーを取得するためのクッキーオブザーバーが必要です。この問題はWKWebView
のバグによって引き起こされ、自分のオブザーバーが呼び出されないようにします。
shouldUseRemotePublishSettings
Mobile Publish Settings(バージョン1.9.0+)を有効(デフォルト)または無効に構成します。
config.shouldUseRemotePublishSettings = false
Mobile Publish Settingsはデフォルトで有効になっており、使用しない場合は無効にする必要があります。iQ Tag ManagementでMobile Publish Settingsを構成するか、Swiftのインストールでconfig.shouldUseRemotePublishSettings = false
を使用して機能を無効にします。これを行わないと、初期化に失敗し、トラッキングが防止されます。
skAdAttributionEnabled
AttributionモジュールのApple SKAdNetwork APIを有効または無効にします(デフォルト:無効)。
config.skAdAttributionEnabled = true
skAdConversionKeys
SKAdNetwork.updateConversionValue()
メソッドを呼び出すイベントと、変換値として使用するキーを定義する辞書。
config.skAdConversionKeys = ["purchase": "number_of_coins"]
この場合、以下のイベントはSKAdNetwork.updateConversionValue(40)
に等しくなります:
tealium?.track("purchase", dataLayer: ["number_of_coins": 40])
tagManagementOverrideURL
Tag Managementモジュールで使用されるデフォルトのURLを上書きします。これは、TealiumのJavaScriptファイルを自己ホスティングしている場合に必要です。
次の例は、Tag Managementモジュールで使用されるデフォルトのURLを上書きする方法を示しています。
let url = "https://tags.mycdn.com/utag/myaccount/myprofile/myenv/mobile.html"
config.tagManagementOverrideURL = url
TealiumConfig()
TealiumConfig
オブジェクトのコンストラクタ。このオブジェクトは、ライブラリを特定のアカウントに対して初期化するために必要です。
TealiumConfig(account:String, profile:String, environment:String, dataSource:String)
パラメータ | タイプ | 説明 | 例 |
---|---|---|---|
account |
String |
Tealiumアカウント名 | companyXYZ |
profile |
String |
Tealiumプロファイル名 | main |
environment |
String |
Tealium環境名 | [dev , qa , prod ] |
datasource |
String |
(オプション) CDHからのTealiumデータソースキー | abc123 |
timedEventTriggers
タイムドイベントを自動的に追跡するためのTimedEventTrigger
オブジェクトのリスト。
config.timedEventTriggers = [TimedEventTrigger(start: "START_EVENT",
stop: "STOP_EVENT",
name: "TIMED_EVENT_NAME")]
以下はTimedEventTrigger
パラメータです:
パラメータ | タイプ | 説明 |
---|---|---|
start |
String |
タイムドイベントを開始するTealiumEvent の名前 |
stop |
String |
タイムドイベントを停止するTealiumEvent の名前 |
name |
String? |
(オプション) タイムドイベントの名前 (デフォルト: "START_EVENT::STOP_EVENT" ) |
updateDistance
位置情報の更新を受け取る距離間隔(メートル)を構成します。
このメソッドは、useHighAccuracy
がtrue
に構成されている場合にのみ使用してください。
config.updateDistance = <Double>
タイプ | 説明 | 例 |
---|---|---|
Double |
位置情報の更新を受け取る距離間隔(メートル) | 150.0 |
使用例:
func start() {
let config = TealiumConfig(account: "ACCOUNT",
profile: "NAME",
environment: "ENVIRONMENT",
datasource: "DATASOURCE")
// Tealium Location module config methods
config.useHighAccuracy = true
config.updateDistance = 150.0
}
useHighAccuracy
位置精度を低精度(デフォルト)または高精度に構成します。
このプロパティはデフォルトで無効になっており、位置精度を低精度に構成します。位置情報が有効なデバイスが500メートル以上移動すると、これは大きな位置変更とみなされ、位置更新が発生します。この構成では、位置更新には通常5分以上かかります。
Appleのsignificant-change location serviceについて詳しく学びましょう。
有効にすると、プロパティはデータ精度の位置を可能な限り最高精度に構成します。初期イベントはできるだけ早く配信され、その後、位置を決定し、データが利用可能になると必要に応じて追加のイベントを配信します。
Appleの位置データの精度について詳しく学びましょう。
高精度を使用すると、位置更新の頻度が高いため、デバイスのバッテリー消費が低精度よりも大きくなります。
config.useHighAccuracy = <Bool>
タイプ | 説明 | 例 |
---|---|---|
Boolean |
位置データの精度を構成します | true |
使用例:
func start() {
let config = TealiumConfig(account: "ACCOUNT",
profile: "NAME",
environment: "ENVIRONMENT",
datasource: "DATASOURCE")
// Tealium Location module config methods
config.useHighAccuracy = true
config.updateDistance = 150.0
}
visitorIdentityKey
データレイヤー内の指定されたvisitorIdentityKey
で訪問の切り替えを有効にします。
例:
func start() {
let customerIdentifierKey = "customer_id"
let config = TealiumConfig(account: "ACCOUNT",
profile: "NAME",
environment: "ENVIRONMENT",
datasource: "DATASOURCE")
config.visitorIdentityKey = customerIdentifierKey
// use the same customerIdentifierKey for storing a specific customer identifier in the data layer
}
webviewProcessPool
アプリがTealium Tag Management webview以外の他のwebviewを含む場合、クッキー同期の問題を防ぎます。アプリでwebviewを使用する場合、シングルトンのWKProcessPool
インスタンスを作成し、Tealiumをインスタンス化する前に構成します。
例:
let processPool = MyApp.wkProcessPool
config.webviewProcessPool = processPool
webviewConfig
カスタムのWKWebviewConfiguration
オブジェクトを渡すことを許可します。これはTealium Tag Management webviewに使用されます。webviewProcessPool
オプションの代わりにこのオプションを使用する場合、カスタマイズ可能なWKWebviewConfiguration
のprocessPool
プロパティを介してシングルトンのWKProcessPool
を構成します。
WKWebView
に対する将来のAPI変更が必要になる場合、このオプションを使用することを推奨します。
例:
let processPool = MyApp.wkProcessPool
let configuration = WKWebViewConfiguration()
configuration.processPool = processPool
config.webviewConfig = configuration
最終更新日 :: 2025年January月16日