docs.unity3d.com
Search Results for

    Show / Hide Table of Contents

    Enum AuthenticationState

    Indicates the current authentication state in an application's lifetime.

    Namespace: Unity.Cloud.Identity
    Assembly: Unity.Cloud.Identity.dll
    Syntax
    public enum AuthenticationState
    Examples
    public class AuthenticationStateExample : MonoBehaviour
    {
        // Register the CompositeAuthenticator as an IAuthenticationStateProvider
        IAuthenticationStateProvider m_AuthenticationStateProvider => m_CompositeAuthenticator;
        CompositeAuthenticator m_CompositeAuthenticator;
    
        void Awake()
        {
            // Build a CompositeAuthenticator supporting different runtime authentication flow
            var playerSettings = UnityCloudPlayerSettings.Instance;
            var httpClient = new UnityHttpClient();
            var serviceHostResolver = UnityRuntimeServiceHostResolverFactory.Create();
    
            var compositeAuthenticatorSettings = new CompositeAuthenticatorSettingsBuilder(httpClient, PlatformSupportFactory.GetAuthenticationPlatformSupport(), serviceHostResolver, playerSettings)
                .AddDefaultBrowserAuthenticatedAccessTokenProvider(playerSettings)
                .AddDefaultPkceAuthenticator(playerSettings)
                .Build();
    
            m_CompositeAuthenticator = new CompositeAuthenticator(compositeAuthenticatorSettings);
    
            // Listen from AuthenticationStateChanged event
            m_AuthenticationStateProvider.AuthenticationStateChanged += OnAuthenticationStateChanged;
        }
    
        async Task Start()
        {
            // Initialize the CompositeAuthenticator to get its initial AuthenticationState
            await m_CompositeAuthenticator.InitializeAsync();
    
            // After initialize, Update UI with current state
            ApplyAuthenticationState(m_AuthenticationStateProvider.AuthenticationState);
        }
    
        void OnDisable()
        {
            m_AuthenticationStateProvider.AuthenticationStateChanged -= OnAuthenticationStateChanged;
        }
    
        void OnAuthenticationStateChanged(AuthenticationState state)
        {
            ApplyAuthenticationState(state);
        }
    
        void ApplyAuthenticationState(AuthenticationState newAuthenticationState)
        {
            switch (newAuthenticationState)
            {
                case AuthenticationState.AwaitingInitialization:
                    // Awaiting initial AuthenticationState at startup.
                    break;
                case AuthenticationState.AwaitingLogin:
                    // A manual login is pending completion
                    break;
                case AuthenticationState.LoggedIn:
                    // An access token is ready to use on Cloud Services
                    break;
                case AuthenticationState.AwaitingLogout:
                    // A manual logout is pending completion
                    break;
                case AuthenticationState.LoggedOut:
                    // No access token available
                    break;
            }
        }
    }

    Fields

    Name Description
    AwaitingInitialization

    Indicates the application is waiting for the completion of the initialization.

    AwaitingLogin

    Indicates the application is waiting for the completion of a login operation.

    AwaitingLogout

    Indicates the application is waiting for the completion of a logout operation.

    LoggedIn

    Indicates when an authenticated user is logged in.

    LoggedOut

    Indicates no authenticated user is available.

    In This Article
    Back to top
    Copyright © 2025 Unity Technologies — Trademarks and terms of use
    • Legal
    • Privacy Policy
    • Cookie Policy
    • Do Not Sell or Share My Personal Information
    • Your Privacy Choices (Cookie Settings)