Skip to content
This repository has been archived by the owner on May 17, 2022. It is now read-only.

D.3 Manage Users

Hadi Tavakoli edited this page Sep 26, 2018 · 3 revisions

Get the currently signed-in user

Before trying to access any user information, you must first check if FirebaseUser.isAvailable returns true. While remembering that, you can extract all user information like below:

trace("displayName = " +		FirebaseUser.displayName);
trace("email = " +  			FirebaseUser.email);
trace("photoUrl = " + 			FirebaseUser.photoUrl);
trace("phoneNumber = " + 		FirebaseUser.phoneNumber);
trace("providerId = " + 		FirebaseUser.providerId);
trace("userId = " + 			FirebaseUser.userId);
trace("isEmailVerified = " +		FirebaseUser.isEmailVerified);

if(FirebaseUser.metadata)
{
	trace("creationTime = " + 	new Date(FirebaseUser.metadata.creationTime).toLocaleString());
	trace("lastSignInTime = " + 	new Date(FirebaseUser.metadata.lastSignInTime).toLocaleString());
}

var userInfoOnProviders:UserInfo;
for (var i:int = 0; i < FirebaseUser.providersData.length; i++)
{
	userInfoOnProviders = FirebaseUser.providersData[i];
	trace("-------------")
	trace("providerId = " + 		userInfoOnProviders.providerId);
	trace("displayName = " + 		userInfoOnProviders.displayName);
	trace("email = " +   			userInfoOnProviders.email);
	trace("photoUrl = " + 			userInfoOnProviders.photoUrl);
	trace("phoneNumber = " + 		userInfoOnProviders.phoneNumber);
	trace("userId = " + 			userInfoOnProviders.userId);
	trace("-------------")
}

To make sure you have the latest user information, you must listen to AuthEvents.AUTH_STATE_CHANGED to know about auth changes. Moreover, there are times when you need to use FirebaseUser.reload(); to get the latest information. when the reload method is called, the following two events will be dispatched: FirebaseUserEvents.RELOAD_USER_INFO and AuthEvents.AUTH_STATE_CHANGED.

Update a user's profile

You can update a user's basic profile information—the user's display name and profile photo URL—with the FirebaseUser.updateProfile method. For example:

FirebaseUser.listener.addEventListener(FirebaseUserEvents.PROFILE_UPDATE_RESULT, onProfileUpdate);
if (FirebaseUser.isAvailable) FirebaseUser.updateProfile("Jane Q. User", "https://example.com/jane-q-user/profile.jpg");

function onProfileUpdate(e:FirebaseUserEvents):void
{
	if(e.result == Auth.RESULT_SUCCESS)
	{
		trace("onProfileUpdate successful")
	}
	else
	{
		trace("onProfileUpdate: " + e.msg);
	}
}

Set a user's email address

You can set a user's email address with the updateEmail method. For example:

FirebaseUser.listener.addEventListener(FirebaseUserEvents.EMAIL_UPDATE_RESULT, onEmailUpdate);
if (FirebaseUser.isAvailable) FirebaseUser.updateEmail("[email protected]");

function onEmailUpdate(e:FirebaseUserEvents):void
{
	// when this happens, you have to call FirebaseUser.reauthenticate to resolve it. and then try your operation again.
	if (e.result == Auth.RESULT_AUTH_RECENT_LOGIN_REQUIRED)
	{
		// create a new authProvider object first
		var authProvider:AuthProvider = new AuthProvider();
		
		// decide what kind of credential this authProvider instance will hold
		authProvider.setEmailPassAuthProvider("[email protected]", "123456");
		
		// and finally feed FirebaseUser.reauthenticate with the parsed credential info from the authProvider instance.
		FirebaseUser.reauthenticate(authProvider.getCredential());
	}
	else if(e.result == Auth.RESULT_SUCCESS)
	{
		trace("onEmailUpdate successful");
	}
	else
	{
		trace("onEmailUpdate: " + e.msg);
	}
}

Send a user a verification email

You can send an address verification email to a user with the sendEmailVerification method. For example:

if (!FirebaseUser.isEmailVerified)
{
	FirebaseUser.listener.addEventListener(FirebaseUserEvents.SEND_EMAIL_VERIFICATION_RESULT, onSendEmailVerification);
	FirebaseUser.sendEmailVerification();
}

function onSendEmailVerification(e:FirebaseUserEvents):void
{
	if(e.result == Auth.RESULT_SUCCESS)
	{
		trace("onSendEmailVerification successful");
	}
	else
	{
		trace("onSendEmailVerification: " + e.msg);
	}
}

You can customize the email template that is used in Authentication section of the Firebase console, on the Email Templates page. See Email Templates in Firebase Help Center.

It is also possible to pass state via a continue URL to redirect back to the app when sending a verification email. Notice that if you are going to use ActionCodeSettings, you must have added the Firebase DynamicLinks ANE to your project first.

// make sure you have whitelisted your domain in your firebase console/Authentication section, before trying this.
var settings:ActionCodeSettings = new ActionCodeSettings("https://example.com/");
settings.handleCodeInApp = true;

FirebaseUser.sendEmailVerification(settings);

Additionally you can localize the verification email by updating the language code on the Auth instance before sending the email. For example:

Auth.languageCode = "fr";

// To apply the default app language instead of explicitly setting it.
Auth.useAppLanguage();

Set a user's password

You can set a user's password with the updatePassword method. For example:

FirebaseUser.listener.addEventListener(FirebaseUserEvents.PASSWORD_UPDATE_RESULT, onPasswordUpdate);
if (FirebaseUser.isAvailable) FirebaseUser.updatePassword("newPass");

function onPasswordUpdate(e:FirebaseUserEvents):void
{
	// when this happens, you have to call FirebaseUser.reauthenticate to resolve it. and then try your operation again.
	if (e.result == Auth.RESULT_AUTH_RECENT_LOGIN_REQUIRED)
	{
		// create a new authProvider object first
		var authProvider:AuthProvider = new AuthProvider();
		
		// decide what kind of credential this authProvider instance will hold
		authProvider.setEmailPassAuthProvider("[email protected]", "123456");
		
		// and finally feed FirebaseUser.reauthenticate with the parsed credential info from the authProvider instance.
		FirebaseUser.reauthenticate(authProvider.getCredential());
	}
	else if(e.result == Auth.RESULT_SUCCESS)
	{
		trace("onPasswordUpdate successful");
	}
	else
	{
		trace("onPasswordUpdate: " + e.msg);
	}
}

Send a password reset email

You can send a password reset email to a user with the Auth.sendPasswordResetEmail method. For example:

Auth.listener.addEventListener(AuthEvents.SEND_PASSWORD_RESET_EMAIL_RESULT, onPassResetResult);
Auth.sendPasswordResetEmail("[email protected]");

function onPassResetResult(e:AuthEvents):void
{
	if(e.result == Auth.RESULT_SUCCESS)
	{
		trace("onPassResetResult successfully");
	}
	else
	{
		trace("onPassResetResult: " + e.msg);
	}
}

You can customize the email template that is used in Authentication section of the Firebase console, on the Email Templates page. See Email Templates in Firebase Help Center.

It is also possible to pass state via a continue URL to redirect back to the app when sending a password reset email. Notice that if you are going to use ActionCodeSettings, you must have added the Firebase DynamicLinks ANE to your project first.

// make sure you have whitelisted your domain in your firebase console/Authentication section, before trying this.
var settings:ActionCodeSettings = new ActionCodeSettings("https://example.com/");
settings.handleCodeInApp = true;

Auth.sendPasswordResetEmail("[email protected]", settings);

Additionally you can localize the verification email by updating the language code on the Auth instance before sending the email. For example:

Auth.languageCode = "fr";

// To apply the default app language instead of explicitly setting it.
Auth.useAppLanguage();

You can also send password reset emails from the Firebase console.

Delete a user

You can delete a user account with the deleteUser method. For example:

FirebaseUser.listener.addEventListener(FirebaseUserEvents.DELETE_USER_RESULT, onDeleteUser);
FirebaseUser.deleteUser();

function onDeleteUser(e:FirebaseUserEvents):void
{
	// when this happens, you have to call FirebaseUser.reauthenticate to resolve it. and then try your operation again.
	if (e.result == Auth.RESULT_AUTH_RECENT_LOGIN_REQUIRED)
	{
		// create a new authProvider object first
		var authProvider:AuthProvider = new AuthProvider();
		
		// decide what kind of credential this authProvider instance will hold
		authProvider.setEmailPassAuthProvider("[email protected]", "123456");
		
		// and finally feed FirebaseUser.reauthenticate with the parsed credential info from the authProvider instance.
		FirebaseUser.reauthenticate(authProvider.getCredential());
	}
	else if(e.result == Auth.RESULT_SUCCESS)
	{
		trace("onDeleteUser successful");
	}
	else
	{
		trace("onDeleteUser: " + e.msg);
	}
}

You can also delete users from the Authentication section of the Firebase console, on the Users page.

Re-authenticate a user

Some security-sensitive actions—such as deleting an account, setting a primary email address, and changing a password—require that the user has recently signed in. If you perform one of these actions, and the user signed in too long ago, the action fails. When this happens, re-authenticate the user by getting new sign-in credentials from the user and passing the credentials to reauthenticate. For example:

// Get auth credentials from the user for re-authentication. The example below shows
// email and password credentials but there are multiple possible providers,
// such as GoogleAuthProvider or FacebookAuthProvider.

FirebaseUser.listener.addEventListener(FirebaseUserEvents.REAUTHENTICATE_RESULT, onReauthenticate);

// create a new authProvider object first
var authProvider:AuthProvider = new AuthProvider();

// decide what kind of credential this authProvider instance will hold
authProvider.setEmailPassAuthProvider(email, "123456");

// and finally feed FirebaseUser.reauthenticate with the parsed credential info from the authProvider instance.
FirebaseUser.reauthenticate(authProvider.getCredential());

function onReauthenticate(e:FirebaseUserEvents):void
{
	trace("onReauthenticate result=" + e.result, "     msg=" + e.msg);
}

Import user accounts

Read Here: https://firebase.google.com/docs/auth/ios/manage-users#import_user_accounts

Introduction to Firebase ANEs collection for Adobe Air apps


Get Started with Firebase Core in AIR

  1. Prerequisites
  2. Add Firebase to your app
  3. Add the Firebase SDK
  4. Init Firebase Core
  5. Available ANEs
  6. Managing Firebase iid

Get Started with Analytics

  1. Add Analytics ANE
  2. Init Analytics ANE
  3. Log Events
  4. Set User Properties

Get Started with Crashlytics

  1. Add Crashlytics ANE
  2. Test Your Implementation
  3. Customize Crash Reports
  4. Upload .dSYM for iOS apps

Get Started with DynamicLinks

  1. Add DynamicLinks ANE
  2. Init DynamicLinks ANE
  3. Create DynamicLinks
  4. Receive DynamicLinks
  5. View Analytics

Get Started with Authentication

  1. Add Authentication
  2. Init Authentication
  3. Manage Users
  4. Phone Number
  5. Custom Auth
  6. Anonymous Auth
  7. State in Email Actions
  8. Email Link Authentication

Get Started with FCM + OneSignal

  1. Add FCM ANE
  2. Init FCM ANE
  3. Send Your 1st Message
  4. Send Msg to Topics
  5. Understanding FCM Messages
  6. init OneSignal

Get Started with Firestore

  1. Add Firestore
  2. Init Firestore
  3. Add Data
  4. Transactions & Batches
  5. Delete Data
  6. Manage the Console
  7. Get Data
  8. Get Realtime Updates
  9. Simple and Compound
  10. Order and Limit Data
  11. Paginate Data
  12. Manage Indexes
  13. Secure Data
  14. Offline Data
  15. Where to Go From Here

Get Started with Realtime Database

  1. Add Realtime Database
  2. Init Realtime Database
  3. Structure Your Database
  4. Save Data
  5. Retrieve Data
  6. Enable Offline Capabilities

Get Started with Remote Config

  1. Parameters and Conditions
  2. Add Remote Config
  3. Init Remote Config

Get Started with Performance

  1. Add Performance ANE
  2. Init & Start Monitoring

Get Started with Storage

  1. Add Storage ANE
  2. Init Storage ANE
  3. Upload Files to Storage
  4. Download Files to Air
  5. Use File Metadata
  6. Delete Files

Get Started with Functions

  1. Write & Deploy Functions
  2. Add Functions ANE
  3. Init Functions
Clone this wiki locally