Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
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.
- Host: GitHub
- URL: https://github.com/mahmoudelsayed7/auth-with-refresh-token
- Owner: MAHMOUDELSAYED7
- Created: 2024-11-19T17:40:21.000Z (about 2 months ago)
- Default Branch: main
- Last Pushed: 2024-11-24T00:18:18.000Z (about 2 months ago)
- Last Synced: 2024-12-06T06:30:25.933Z (about 1 month ago)
- Topics: 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
- Language: Dart
- Homepage:
- Size: 26.4 KB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
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 ExpiryThe `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])