Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/mahmoudelsayed7/auth-with-refresh-token

User authentication with login, signup, OTP verification, automatic token refresh, and secure storage using Dio HTTP client and Flutter Secure Storage.
https://github.com/mahmoudelsayed7/auth-with-refresh-token

access-token api api-client api-rest auth-helper authentication dio dio-interceptor flutter flutter-apis-implementation flutter-apps flutter-package interceptor interceptor-http pub-dev refresh-access-token refresh-token secure-storage token tokens

Last synced: 1 day ago
JSON representation

User authentication with login, signup, OTP verification, automatic token refresh, and secure storage using Dio HTTP client and Flutter Secure Storage.

Awesome Lists containing this project

README

        

# Flutter Authentication with Refresh Token

## Overview
This Flutter project demonstrates handling authentication processes such as login, signup, OTP verification, and automatic token refresh using the [Dio HTTP client](https://pub.dev/packages/dio), with secure storage management using [Flutter Secure Storage](https://pub.dev/packages/flutter_secure_storage).

## Features
- User Authentication (Login, Signup)
- OTP Verification
- Automatic Token Refresh using Interceptors
- Secure Token Storage

## Usage

### Authentication
- **Login**: Use `ApiService().login(email, password)` to authenticate users.
- **Signup**: Use `ApiService().signUp(name, email, password)` to register new users.
- **Verify OTP**: Use `ApiService().verifyOtp(email, otp)` for OTP verification.

### Token Management
- **Securely Store Tokens**: Use `SecureStorageManager.writeData('accessToken', token)` to store tokens securely.
- **Read Tokens**: Use `SecureStorageManager.readData('accessToken')` to retrieve tokens securely.

### Secure API Requests
Ensure all API requests are authenticated using the access token retrieved from secure storage:
```dart
Future getProductByToken() async {
final token = await SecureStorageManager.readData('accessToken');
final response = await _dio.get('/product/1',
options: Options(headers: {'Authorization': 'Bearer $token'}));
return response;
}
```
## Handling Token Expiry

The `RefreshTokenInterceptor` automatically handles token expiration by refreshing the token and retrying the original request seamlessly when encountering 401 or 403 errors.

intain secure sessions across multiple services or APIs.

## Contribution

Contributions to the project are welcome! Please fork the repository and submit a pull request with your features or fixes.

## Issues

If you encounter any issues while using this project, please open an issue in the repository with a detailed description of the problem, steps to reproduce it, and the expected behavior. We appreciate your contributions to improving this project.

## Contact

For any questions or feedback, please reach out via email: [[email protected]]([email protected])