auth_http_client 1.2.2 auth_http_client: ^1.2.2 copied to clipboard
A package that provides an HttpClient with some useful Authorization capabilities
auth_http_client #
A package that provides an HttpClient with some useful Authorization capabilities.
Getting Started #
To use this package, add auth_http_client
as a dependency in your pubspec.yaml
file:
dependencies:
auth_http_client: ^1.2.0
Usage #
Import the package in your Dart code:
import 'package:auth_http_client/auth_http_client.dart';
Create an instance of the HttpAuthClient
:
final client = HttpAuthClient(
client: http.Client(),
sharedPreferences: sharedPreferences,
refreshTokenUrl: (token, decodedToken) => 'https://example.com/refresh',
);
Now, you can use the client to make API calls with Authorization capabilities:
final response = await client.get('https://api.example.com/data');
Features #
- Automatically adds an "Authorization" header with the "Bearer" scheme for authenticated requests.
- Supports token refresh mechanisms.
- Provides custom hooks for refreshing tokens and handling refresh failures.
Configuration #
The HttpAuthClient
constructor accepts several optional parameters for customization:
client
: An instance ofhttp.Client
to be used for making HTTP requests. Defaults to a new instance ofhttp.Client
.sharedPreferences
: An instance ofSharedPreferences
to be used for storing and retrieving tokens.refreshTokenUrl
: A function that returns the URL for refreshing tokens.customRefreshTokenResponseParser
: A custom function for parsing the response from the refresh token API.refreshTokenMethod
: The HTTP method to use when requesting a new token. Defaults to 'POST'.maxAge
: The maximum age of a token before it's considered expired.refreshTokenTimeout
: The maximum time to wait for the refresh token API to respond. Defaults to 15 seconds.customRefreshTokenRequestBodyMapper
: A custom function for mapping the refresh token request body.onRefreshToken
: A callback that's called when a refresh token has been successfully retrieved.onRefreshTokenFailure
: A callback that's called when a refresh token fails to be retrieved.
Example #
Here's a complete example of how to use the auth_http_client
package:
import 'package:auth_http_client/auth_http_client.dart';
import 'package:http/http.dart' as http;
import 'package:shared_preferences/shared_preferences.dart';
Future<void> main() async {
final sharedPreferences = await SharedPreferences.getInstance();
final client = HttpAuthClient(
client: http.Client(),
sharedPreferences: sharedPreferences,
refreshTokenUrl: (token, decodedToken) => 'https://example.com/refresh',
);
final response = await client.get('https://api.example.com/data');
print(response.body);
}
License #
This package is licensed under the MIT License. See the LICENSE file for more information.