https://github.com/fusionauth/fusionauth-android-sdk
Android SDK for FusionAuth
https://github.com/fusionauth/fusionauth-android-sdk
android authentication oauth oidc
Last synced: 6 months ago
JSON representation
Android SDK for FusionAuth
- Host: GitHub
- URL: https://github.com/fusionauth/fusionauth-android-sdk
- Owner: FusionAuth
- License: other
- Created: 2023-11-27T10:46:04.000Z (almost 2 years ago)
- Default Branch: main
- Last Pushed: 2024-10-29T08:02:07.000Z (11 months ago)
- Last Synced: 2024-10-29T08:16:49.026Z (11 months ago)
- Topics: android, authentication, oauth, oidc
- Language: CSS
- Homepage: https://fusionauth.io
- Size: 976 KB
- Stars: 3
- Watchers: 13
- Forks: 1
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Codeowners: .github/CODEOWNERS
- Security: SECURITY.md
Awesome Lists containing this project
README
[](https://github.com/FusionAuth/fusionauth-android-sdk/tags)
[](https://github.com/FusionAuth/fusionauth-android-sdk/network/updates)
[](https://github.com/FusionAuth/fusionauth-android-sdk/pulls)An SDK for using FusionAuth in Android Apps.
# Table of Contents
- [Overview](#overview)
- [Getting Started](#getting-started)
- [Usage](#usage)
- [Example App](#example-app)
- [Quickstart](#quickstart)
- [Documentation](#documentation)
- [Upgrade Policy](#upgrade-policy)
# Overview
This SDK allows you to use OAuth 2.0 and OpenId Connect functionality in an Android app with FusionAuth as the
authorization server. It also provides a Token Manager to store, refresh, and retrieve tokens.It's a highly standardized and simplified starting point for developers to easily integrate FusionAuth into their own custom mobile apps by taking care of all the dependencies.
The following OAuth 2.0 and OpenID Connect functionality are covered:
- OAuth 2.0 Authorization Code Grant
- OAuth 2.0 Refresh Token Grant
- OpenID Connect UserInfo
- OpenID Connect End Session[AppAuth-Android](https://github.com/openid/AppAuth-Android) is used for the OAuth 2.0 Authorization Code Grant flow and OpenID Connect functionality.
The SDK is written in Kotlin and is compatible with Java.
# Getting Started
To use the FusionAuth Android SDK, add the following dependency to your `build.gradle.kts` file:
```kotlin
dependencies {
implementation('io.fusionauth:fusionauth-android-sdk:')
}
```After adding the dependency, you will need to initialize the `AuthorizationManager` with
the `AuthorizationConfiguration`:```kotlin
AuthorizationManager.initialize(
AuthorizationConfiguration(
fusionAuthUrl = "http://10.0.2.2:9011",
clientId = "e9fdb985-9173-4e01-9d73-ac2d60d1dc8e",
allowUnsecureConnection = true
)
)
```This will initialize the `AuthorizationManager` with the provided `AuthorizationConfiguration`.
The `AuthorizationManager` is a singleton and can be accessed from anywhere in your app.
The example configuration uses the IP address for your local machine, which is the default for the Android Emulator. If
you are running the FusionAuth server on a different machine, you will need to replace the `fusionAuthUrl` with the
correct URL.Instead of specifying the `AuthorizationConfiguration` in code, you could also read it from a resource file:
```kotlin
AuthorizationManager.initialize(
AuthorizationConfiguration.fromResources(this, R.raw.fusionauth_config)
)
```The `fusionauth_config.json` file should be placed in the `res/raw` directory and should look like this:
```json
{
"fusionAuthUrl": "http://10.0.2.2:9011",
"clientId": "e9fdb985-9173-4e01-9d73-ac2d60d1dc8e",
"allowUnsecureConnection": true
}
```By default, the SDK uses the `MemoryStorage` for storing tokens. This means that tokens will be lost when the app is
closed.
To persist tokens, you can use the `SharedPreferencesStorage` or implement your own `TokenStorage`.# Usage
To start the OAuth 2.0 Authorization Code Grant, you can use the `oAuth()` function on the `AuthorizationManager` to
retrieve the `OAuthAuthorizationService`:```kotlin
AuthorizationManager
.oAuth(this@LoginActivity)
.authorize(
Intent(this@LoginActivity, TokenActivity::class.java),
OAuthAuthorizeOptions(
cancelIntent = Intent(this@LoginActivity, LoginActivity::class.java)
.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP),
state = "state-${System.currentTimeMillis()}"
)
)
```The `authorize` function will start the OAuth 2.0 Authorization Code Grant flow and open the provided `Intent` when the
flow is completed.
The `OAuthAuthorizeOptions` allows you to specify additional options for the flow, such as the `cancelIntent` and
the `state`.If the user completes the flow, the `TokenActivity` will be opened, and you are required to handle the redirect:
```kotlin
AuthorizationManager.oAuth(this@TokenActivity)
.handleRedirect(intent)
```This will retrieve the authorization response, validates the `state` if it was provided, and exchanges the authorization
code for an access token.
The result of the exchange will be stored in the `TokenManager`.After the user is authorized, you can use `getUserInfo()` to retrieve the [User Info](https://openid.net/specs/openid-connect-core-1_0.html#UserInfo):
```kotlin
AuthorizationManager.oAuth(this@TokenActivity).getUserInfo()
```To call your API with an access token, you can use the `AuthorizationManager` to retrieve a valid access token:
```kotlin
val accessToken = AuthorizationManager.freshAccessToken(this@TokenActivity)
```This will retrieve a fresh access token from the `TokenManager` and return it. If the access token is expired,
the `TokenManager` will refresh it automatically.Finally, you can use the `AuthorizationManager` to sign out the user and remove the tokens from the `TokenManager`:
```kotlin
AuthorizationManager
.oAuth(this@TokenActivity)
.logout(
Intent(this@TokenActivity, LoginActivity::class.java)
.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP)
)
```If the user is signed out, the `LoginActivity` will be opened.
# Example App
See the [FusionAuth Android SDK Example](https://github.com/FusionAuth/fusionauth-quickstart-kotlin-android-native) for a functional example of an Android client that uses the SDK.
# Quickstart
See the [FusionAuth Android Quickstart](https://fusionauth.io/docs/quickstarts/quickstart-kotlin-android-native) for a full tutorial on using FusionAuth and Android.
# Documentation
See the latest [Full library documentation](https://github.com/FusionAuth/fusionauth-android-sdk/blob/main/library/docs/index.md) for the complete documentation of the SDK.
# Contributing
We hope you love using FusionAuth Android SDK, but in case you encounter a bug or an issue with the SDK, please do let us know.
Please follow the detailed [Contributing](CONTRIBUTING.md) documentation.
# Upgrade Policy
This library may periodically receive updates with bug fixes, security patches, tests, code samples, or documentation changes.
These releases may also update dependencies, language engines, and operating systems, as we\'ll follow the deprecation and sunsetting policies of the underlying technologies that the libraries use.
This means that after a dependency (e.g. language, framework, or operating system) is deprecated by its maintainer, this library will also be deprecated by us, and may eventually be updated to use a newer version.