Tutorial: Measure iOS Ads conversions


Introduction: Measure iOS Ads conversions

Step 1: Implement a sign-in experience

Step 2: Integrate Google Analytics
Step 3: Initiate on-device conversion measurement using Google Analytics
Step 4: Troubleshoot and handle common issues


The first step is to implement a sign-in experience to allow users to provide their email addresses or phone number.

The authentication system that you use must provide an email address or phone number associated with the user.The following steps outline the process for securely collecting sign-in information using Firebase Authentication , but you can skip this step if you already have an authentication system that collects user emails or phone numbers and continue to Step 2: Integrate Google Analytics .

Make sure you have the prerequisites for this tutorial

  • Your own app that can run on iOS 12 or higher

  • Your app registered as a Firebase App that's linked to Google Analytics and Ads

  • Your preferred IDE

Set up an authentication system

You can use Firebase Authentication to allow users to sign in to your app using one or more sign-in methods, including email address, phone number, password sign-in, and federated identity providers (like Google, Facebook or Twitter). Please review Get started with Firebase Authentication .

Integrate Firebase Authentication with a custom authentication system

Alternatively, you can integrate Firebase Authentication with a custom authentication system by modifying your authentication server to produce custom signed tokens when a user successfully signs in. Your app receives this token and uses it to authenticate with Firebase. Please review Get started with a custom authentication system .

Get the authenticated user's email address or phone number

After you've set up an authentication system with Firebase Authentication , you can get the currently signed-in user.

The recommended way to get the current user is by setting a listener on the Auth object:

Swift

 handle 
  
 = 
  
 Auth 
 . 
 auth 
 (). 
 addStateDidChangeListener 
  
 { 
  
 auth 
 , 
  
 user 
  
 in 
  
 // Get the user's email address 
  
 let 
  
 email 
  
 = 
  
 user 
 . 
 email 
  
 // or get their phone number 
  
 let 
  
 phoneNumber 
  
 = 
  
 user 
 . 
 phoneNumber 
  
 // ... 
 } 

Objective-C

 self 
 . 
 handle 
  
 = 
  
 [[ 
 FIRAuth 
  
 auth 
 ] 
  
 addAuthStateDidChangeListener 
 : 
 ^ 
 ( 
 FIRAuth 
  
 * 
 _Nonnull 
  
 auth 
 , 
  
 FIRUser 
  
 * 
 _Nullable 
  
 user 
 ) 
  
 { 
  
 // Get the user's email address 
  
 NSString 
  
 * 
 email 
  
 = 
  
 user 
 . 
 email 
 ; 
  
 // or get their phone number 
  
 NSString 
  
 * 
 phoneNumber 
  
 = 
  
 user 
 . 
 phoneNumber 
 ; 
  
 // ... 
  
 }]; 

Unity

 Firebase 
 . 
 Auth 
 . 
 FirebaseAuth 
  
 auth 
 ; 
 Firebase 
 . 
 Auth 
 . 
 FirebaseUser 
  
 user 
 ; 
 // Handle initialization of the necessary firebase modules: 
 void 
  
 InitializeFirebase 
 () 
  
 { 
  
 auth 
  
 = 
  
 Firebase 
 . 
 Auth 
 . 
 FirebaseAuth 
 . 
 DefaultInstance 
 ; 
  
 auth 
 . 
 StateChanged 
  
 += 
  
 AuthStateChanged 
 ; 
  
 AuthStateChanged 
 ( 
 this 
 , 
  
 null 
 ); 
 } 
 // Track state changes of the auth object. 
 void 
  
 AuthStateChanged 
 ( 
 object 
  
 sender 
 , 
  
 System 
 . 
 EventArgs 
  
 eventArgs 
 ) 
  
 { 
  
 if 
  
 ( 
 auth 
 . 
 CurrentUser 
  
 != 
  
 user 
 ) 
  
 { 
  
 bool 
  
 signedIn 
  
 = 
  
 user 
  
 != 
  
 auth 
 . 
 CurrentUser 
  
 && 
  
 auth 
 . 
 CurrentUser 
  
 != 
  
 null 
 ; 
  
 user 
  
 = 
  
 auth 
 . 
 CurrentUser 
 ; 
  
 if 
  
 ( 
 signedIn 
 ) 
  
 { 
  
 // Get the user's email address 
  
 string 
  
 email 
  
 = 
  
 user 
 . 
 Email 
 ; 
  
 // or get their phone number 
  
 string 
  
 phoneNumber 
  
 = 
  
 user 
 . 
 PhoneNumber 
 ; 
  
 // ... 
  
 } 
  
 } 
 } 
 // Handle removing subscription and reference to the Auth instance. 
 // Automatically called by a Monobehaviour after Destroy is called on it. 
 void 
  
 OnDestroy 
 () 
  
 { 
  
 auth 
 . 
 StateChanged 
  
 -= 
  
 AuthStateChanged 
 ; 
  
 auth 
  
 = 
  
 null 
 ; 
 } 




Introduction Step 2 : Integrate Google Analytics



Create a Mobile Website
View Site in Mobile | Classic
Share by: