React Native SDKの呼び出し順序
adapty.activate() が完了してから、他のAdapty SDKメソッドを呼び出す必要があります。解決されるまで、SDKは状態を持ちません。activate() の前または並行して発行された呼び出しは、#2002 notActivated で失敗します。
アプリがユーザーを認証し、起動後にカスタマーユーザーIDを取得する場合は、その時点で adapty.identify() を呼び出してください。identify が解決されるまで、ユーザーアクションメソッドを呼び出さないでください。並行して実行される呼び出しは #3006 profileWasChanged で失敗するか、アクティベーション時に作成された匿名プロファイルに対して実行されます。これが起こると、アトリビューション、appsflyer_id などのMMP ID、インストールの所有権が識別済みプロファイルに常に転送されるとは限りません。アプリがユーザーを認証しない場合は、identify をスキップして匿名プロファイルで作業を続けてください。
MMP・アナリティクスSDK(AppsFlyer、Adjust、Branch、PostHog)も同じルールに従います。先に初期化してUID コールバックを待ってから adapty.activate を呼び出してください。そうしないと、MMP IDが短命の匿名プロファイルに紐付けられ、識別済みプロファイルに常に転送されるとは限りません。AppsFlyerの詳細については、AppsFlyer を参照してください。
正しい順序
どのパスを取るかは、カスタマーユーザーIDをいつ知るか、MMP・アナリティクスSDKを使用するかどうかの2点によって決まります。
- ステップ2と5: すべてのアプリで必須です。SDKをアクティベートしてから、SDKメソッドを呼び出します。
- ステップ1と3: MMP・アナリティクスSDK(AppsFlyer、Adjust、Branch、PostHog)を統合する場合のみ必要です。
- ステップ4: アプリがユーザーを認証し、起動後にカスタマーユーザーIDを収集する場合のみ必要です。
アプリ起動時にカスタマーユーザーIDがわかっている場合は、activate() に直接渡してください(ステップ2a)。このパスでは匿名プロファイルが作成されないため、ステップ4は不要です。
| ステップ | 呼び出し | タイミング | 備考 |
|---|---|---|---|
| 1 | MMP・アナリティクスSDKを初期化する(AppsFlyer、Adjust、PostHog、Branch) | アプリ起動時、最初に | MMPのUIDコールバック(例: getAppsFlyerUID)を待ちます。 |
| 2a | adapty.activate('YOUR_PUBLIC_SDK_KEY', { customerUserId: 'YOUR_USER_ID' }) | アプリ起動時、ステップ1の後、カスタマーユーザーIDがある場合 | 推奨。匿名プロファイルは一切作成されません。 |
| 2b | adapty.activate('YOUR_PUBLIC_SDK_KEY') (customerUserId なし) | アプリ起動時、ステップ1の後、カスタマーユーザーIDがない場合(または収集しない場合) | Adaptyが匿名プロファイルを作成します。 |
| 3 | 各MMPに対して adapty.updateAttribution(data, source, networkUserId) | ステップ2の後、ユーザーアクション呼び出しの前 | MMP IDを正しいプロファイルに紐付けるために必要です。 |
| 4 | await adapty.identify('YOUR_USER_ID') | ステップ3の後(MMPなしの場合はステップ2の後)、ステップ5の前 — 認証ありのパス2bのみ | 必ず await を使用してください。identify 中の並行呼び出しは #3006 profileWasChanged を発生させます。 |
| 5 | getPaywall、getPaywallProducts、restorePurchases、makePurchase、updateAttribution、updateProfile | identify を呼び出す場合はステップ4の後、それ以外はステップ3の後(MMPなしの場合はステップ2の後) | これらの呼び出しには安定したプロファイルが必要です。 |
これらのステップをスキップすると、リピートユーザーのプレミアムアクセス喪失、プロファイルへの appsflyer_id の欠落、誤ったオーディエンスに対してペイウォールが返されるといった問題が発生します。
Web2appおよびウェブファネルからのインストール
ユーザーがウェブチェックアウト(Stripe、Paddle)で購入し、その後ネイティブアプリをインストールした場合、デバイス最初の activate() が新しい匿名プロファイルを作成します。このプロファイルはウェブプロファイルとリンクされません。アプリ起動前にカスタマーユーザーIDを解決できる場合(認証フローやインストールリファラーから)、activate() に直接渡してください。そうでない場合、identify('YOUR_USER_ID') を呼び出してから restorePurchases を呼び出すまで、ウェブ購入はデバイス上で表示されません。
各ウェブチェックアウトで送信するメタデータについては、以下を参照してください: