diff --git a/android/core-auth-direct/src/main/java/io/asgardeo/android/core_auth_direct/provider/provider_managers/authentication/AuthenticationProviderManager.kt b/android/core-auth-direct/src/main/java/io/asgardeo/android/core_auth_direct/provider/provider_managers/authentication/AuthenticationProviderManager.kt index d5445f6..5075500 100644 --- a/android/core-auth-direct/src/main/java/io/asgardeo/android/core_auth_direct/provider/provider_managers/authentication/AuthenticationProviderManager.kt +++ b/android/core-auth-direct/src/main/java/io/asgardeo/android/core_auth_direct/provider/provider_managers/authentication/AuthenticationProviderManager.kt @@ -25,7 +25,7 @@ import androidx.activity.result.ActivityResultLauncher import androidx.annotation.RequiresApi import io.asgardeo.android.core_auth_direct.models.autheniticator.Authenticator import io.asgardeo.android.core_auth_direct.models.state.AuthenticationState -import kotlinx.coroutines.flow.SharedFlow +import kotlinx.coroutines.flow.StateFlow /** * Authentication provider manager that is used to manage the authentication process. @@ -42,9 +42,9 @@ internal interface AuthenticationProviderManager { /** * Get authentication state flow of the authentication state which is exposed to the outside. * - * @return authentication state flow [SharedFlow] + * @return authentication state flow [StateFlow] */ - fun getAuthenticationStateFlow(): SharedFlow + fun getAuthenticationStateFlow(): StateFlow /** * Check whether the user is logged in or not. diff --git a/android/core-auth-direct/src/main/java/io/asgardeo/android/core_auth_direct/provider/provider_managers/authentication/impl/AuthenticationProviderManagerImpl.kt b/android/core-auth-direct/src/main/java/io/asgardeo/android/core_auth_direct/provider/provider_managers/authentication/impl/AuthenticationProviderManagerImpl.kt index 125ce12..fc33307 100644 --- a/android/core-auth-direct/src/main/java/io/asgardeo/android/core_auth_direct/provider/provider_managers/authentication/impl/AuthenticationProviderManagerImpl.kt +++ b/android/core-auth-direct/src/main/java/io/asgardeo/android/core_auth_direct/provider/provider_managers/authentication/impl/AuthenticationProviderManagerImpl.kt @@ -35,7 +35,7 @@ import io.asgardeo.android.core_auth_direct.models.state.AuthenticationState import io.asgardeo.android.core_auth_direct.provider.provider_managers.authenticate_handler.AuthenticateHandlerProviderManager import io.asgardeo.android.core_auth_direct.provider.provider_managers.authentication.AuthenticationProviderManager import io.asgardeo.android.core_auth_direct.provider.provider_managers.authentication_state.AuthenticationStateProviderManager -import kotlinx.coroutines.flow.SharedFlow +import kotlinx.coroutines.flow.StateFlow import java.lang.ref.WeakReference /** @@ -110,9 +110,9 @@ internal class AuthenticationProviderManagerImpl private constructor( /** * Get authentication state flow of the authentication state which is exposed to the outside. * - * @return authentication state flow [SharedFlow] + * @return authentication state flow [StateFlow] */ - override fun getAuthenticationStateFlow(): SharedFlow = + override fun getAuthenticationStateFlow(): StateFlow = authenticationStateProviderManager.getAuthenticationStateFlow() /** diff --git a/android/core-auth-direct/src/main/java/io/asgardeo/android/core_auth_direct/provider/provider_managers/authentication_state/AuthenticationStateProviderManager.kt b/android/core-auth-direct/src/main/java/io/asgardeo/android/core_auth_direct/provider/provider_managers/authentication_state/AuthenticationStateProviderManager.kt index a3f84b6..8c2e950 100644 --- a/android/core-auth-direct/src/main/java/io/asgardeo/android/core_auth_direct/provider/provider_managers/authentication_state/AuthenticationStateProviderManager.kt +++ b/android/core-auth-direct/src/main/java/io/asgardeo/android/core_auth_direct/provider/provider_managers/authentication_state/AuthenticationStateProviderManager.kt @@ -22,7 +22,7 @@ import android.content.Context import io.asgardeo.android.core_auth_direct.models.autheniticator.Authenticator import io.asgardeo.android.core_auth_direct.models.authentication_flow.AuthenticationFlow import io.asgardeo.android.core_auth_direct.models.state.AuthenticationState -import kotlinx.coroutines.flow.SharedFlow +import kotlinx.coroutines.flow.StateFlow /** * Authentication state provider manager that is used to manage the authentication state. @@ -37,9 +37,9 @@ interface AuthenticationStateProviderManager { /** * Get authentication state flow * - * @return authentication state flow [SharedFlow] + * @return authentication state flow [StateFlow] */ - fun getAuthenticationStateFlow(): SharedFlow + fun getAuthenticationStateFlow(): StateFlow /** * Emit the authentication state. diff --git a/android/core-auth-direct/src/main/java/io/asgardeo/android/core_auth_direct/provider/provider_managers/authentication_state/impl/AuthenticationStateProviderManagerImpl.kt b/android/core-auth-direct/src/main/java/io/asgardeo/android/core_auth_direct/provider/provider_managers/authentication_state/impl/AuthenticationStateProviderManagerImpl.kt index a0fa89f..4f05d48 100644 --- a/android/core-auth-direct/src/main/java/io/asgardeo/android/core_auth_direct/provider/provider_managers/authentication_state/impl/AuthenticationStateProviderManagerImpl.kt +++ b/android/core-auth-direct/src/main/java/io/asgardeo/android/core_auth_direct/provider/provider_managers/authentication_state/impl/AuthenticationStateProviderManagerImpl.kt @@ -29,7 +29,6 @@ import io.asgardeo.android.core_auth_direct.models.state.AuthenticationState import io.asgardeo.android.core_auth_direct.models.state.TokenState import io.asgardeo.android.core_auth_direct.provider.provider_managers.authentication_state.AuthenticationStateProviderManager import kotlinx.coroutines.flow.MutableStateFlow -import kotlinx.coroutines.flow.SharedFlow import kotlinx.coroutines.flow.StateFlow import java.lang.ref.WeakReference @@ -92,9 +91,9 @@ internal class AuthenticationStateProviderManagerImpl private constructor( /** * Get authentication state flow * - * @return authentication state flow [SharedFlow] + * @return authentication state flow [StateFlow] */ - override fun getAuthenticationStateFlow(): SharedFlow = + override fun getAuthenticationStateFlow(): StateFlow = authenticationStateFlow /** diff --git a/android/core-auth-direct/src/main/java/io/asgardeo/android/core_auth_direct/provider/providers/authentication/AuthenticationProvider.kt b/android/core-auth-direct/src/main/java/io/asgardeo/android/core_auth_direct/provider/providers/authentication/AuthenticationProvider.kt index 4cf5f7e..82a2ebf 100644 --- a/android/core-auth-direct/src/main/java/io/asgardeo/android/core_auth_direct/provider/providers/authentication/AuthenticationProvider.kt +++ b/android/core-auth-direct/src/main/java/io/asgardeo/android/core_auth_direct/provider/providers/authentication/AuthenticationProvider.kt @@ -26,7 +26,7 @@ import androidx.annotation.RequiresApi import io.asgardeo.android.core_auth_direct.models.autheniticator.Authenticator import io.asgardeo.android.core_auth_direct.models.state.AuthenticationState import io.asgardeo.android.core_auth_direct.provider.providers.authentication.impl.AuthenticationProviderImpl -import kotlinx.coroutines.flow.SharedFlow +import kotlinx.coroutines.flow.StateFlow /** * Interface for the authentication provider to be implemented by the application. @@ -37,9 +37,9 @@ interface AuthenticationProvider { /** * Get authentication state flow * - * @return authentication state flow [SharedFlow] + * @return authentication state flow [StateFlow] */ - fun getAuthenticationStateFlow(): SharedFlow + fun getAuthenticationStateFlow(): StateFlow /** * Check whether the user is logged in or not. diff --git a/android/core-auth-direct/src/main/java/io/asgardeo/android/core_auth_direct/provider/providers/authentication/impl/AuthenticationProviderImpl.kt b/android/core-auth-direct/src/main/java/io/asgardeo/android/core_auth_direct/provider/providers/authentication/impl/AuthenticationProviderImpl.kt index 32ea1e7..4d57eda 100644 --- a/android/core-auth-direct/src/main/java/io/asgardeo/android/core_auth_direct/provider/providers/authentication/impl/AuthenticationProviderImpl.kt +++ b/android/core-auth-direct/src/main/java/io/asgardeo/android/core_auth_direct/provider/providers/authentication/impl/AuthenticationProviderImpl.kt @@ -28,7 +28,7 @@ import io.asgardeo.android.core_auth_direct.models.state.AuthenticationState import io.asgardeo.android.core_auth_direct.provider.provider_managers.authentication.AuthenticationProviderManager import io.asgardeo.android.core_auth_direct.provider.provider_managers.user.UserProviderManager import io.asgardeo.android.core_auth_direct.provider.providers.authentication.AuthenticationProvider -import kotlinx.coroutines.flow.SharedFlow +import kotlinx.coroutines.flow.StateFlow import java.lang.ref.WeakReference /** @@ -89,9 +89,9 @@ internal class AuthenticationProviderImpl private constructor( /** * Get authentication state flow * - * @return authentication state flow [SharedFlow] + * @return authentication state flow [StateFlow] */ - override fun getAuthenticationStateFlow(): SharedFlow = + override fun getAuthenticationStateFlow(): StateFlow = authenticationProviderManager.getAuthenticationStateFlow() /** diff --git a/docs/website/android/start.md b/docs/website/android/start.md index c1e9f28..6781b57 100644 --- a/docs/website/android/start.md +++ b/docs/website/android/start.md @@ -25,7 +25,7 @@ AuthenticationCoreConfig( discoveryEndpoint = "https://api.asgardeo.io/t//oauth2/token/.well-known/openid-configuration", authnEndpoint = "https://api.asgardeo.io/t//oauth2/authn", - redirectUri = "wso2sample://oauth2", + redirectUri = "wso2.apiauth.sample.android://oauth2", clientId = "", scope = "openid profile email" ) @@ -39,7 +39,7 @@ val authenticationProvider: AuthenticationProvider = asgardeoAuth.getAuthenticationProvider() ``` -AuthenticationProvider handles the authentication process using [SharedFlow](https://developer.android.com/kotlin/flow/stateflow-and-sharedflow#sharedflow). This will help you to handle each state of the authentication process easily. There are four states in the authentication process (AuthenticationState): +AuthenticationProvider handles the authentication process using [StateFlow](https://developer.android.com/kotlin/flow/stateflow-and-sharedflow#stateflow). This will help you to handle each state of the authentication process easily. There are four states in the authentication process (AuthenticationState): - **AuthenticationState.Initial**: Initial state of the authentication process. - **AuthenticationState.Loading**: SDK is calling an API to handle the authentication and waiting for the result. @@ -64,10 +64,11 @@ Then call the `authenticationProvider.initializeAuthentication` to initialize th ```kotlin @Composable internal fun LandingScreen() { + val context: Context = LocalContext.current val authenticationStateFlow = authenticationProvider.getAuthenticationStateFlow() - IsLoggedInStateFlow() - HandleAuthenticationState(authenticationStateFlow) + IsLoggedInStateFlow(context) + HandleAuthenticationState(authenticationStateFlow, context) } @Composable @@ -80,7 +81,7 @@ private fun IsLoggedInStateFlow(context: Context) { } @Composable -private fun HandleAuthenticationState(authenticationStateFlow: SharedFlow) { +private fun HandleAuthenticationState(authenticationStateFlow: StateFlow) { LaunchedEffect(key1 = Unit) { GlobalScope.launch { authenticationStateFlow.collect {