A comprehensive Flutter package providing clean, type-safe local storage solutions and robust network infrastructure with advanced token management and refresh strategies.
- π― Multiple Storage Backends: SharedPreferences, FlutterSecureStorage, and Hive support
- π Security First: Clear separation between normal and secure storage operations
- π§© Type Safety: Built-in support for JSON, lists, DateTime, and custom objects
- β‘ Performance: Optional caching and optimized storage implementations
- π Dual HTTP Clients: Built-in support for both dart:io HTTP and Dio implementations
- π Token Management: Automatic token injection and secure storage integration
- π Refresh Token Strategy: Configurable token refresh with Strategy design pattern
- π‘ Interceptor System: LoggerInterceptor, TokenInterceptor, and CacheInterceptor with extensible design
- π§ Dependency Injection: Clean DI support with flexible configuration
- π± Cross Platform: Works on iOS, Android, Web, Windows, macOS, and Linux
- π§ͺ Fully Tested: Comprehensive test coverage with mock support
dependencies:
flutter_infra: ^0.0.1import 'package:flutter_infra/flutter_infra.dart';
void main() async {
WidgetsFlutterBinding.ensureInitialized();
// Storage operations
final storageService = await StorageService.create();
await storageService.setString('username', 'john_doe');
await storageService.setSecureString('api_token', 'secret_token');
// Network operations
final networkService = await NetworkService.create(
config: NetworkConfig(baseUrl: 'https://api.example.com'),
);
final response = await networkService.getJson('/users/profile');
runApp(MyApp());
}// Create network service with automatic token management
final networkService = await NetworkService.createWithTokenSupport(
config: NetworkConfig(baseUrl: 'https://api.example.com'),
tokenManager: DefaultTokenManager(storage: storageService),
);
// Tokens are automatically handled
final userProfile = await networkService.getJson('/protected/profile');// Create network service with caching enabled
final networkService = await NetworkService.createWithCache(
config: NetworkConfig(baseUrl: 'https://api.example.com'),
cacheConfig: CacheConfig(
defaultCacheDuration: Duration(minutes: 5),
maxCacheSize: 100,
customCacheDurations: {
'/users': Duration(hours: 1),
'/posts': Duration(minutes: 30),
},
),
);
// Responses are automatically cached
final users = await networkService.getJson('/users'); // Network call
final usersAgain = await networkService.getJson('/users'); // Cached response- π Quick Start Guide - Get up and running in minutes
- ποΈ Architecture Overview - System design and component relationships
- βοΈ Configuration Guide - Advanced setup and customization options
- πΎ Storage Service - Complete storage documentation with implementations and typed extensions
- π Network Service - Network client documentation with interceptors and configuration
- ποΈ Cache Interceptor - HTTP response caching with configurable options
- π Token Management - Token manager, refresh strategies, and security
- π Complete Examples - Real-world usage patterns and implementation examples
- π Best Practices - Recommended patterns, security guidelines, and performance tips
// JSON operations with both normal and secure versions
await storageService.setJson('user_profile', userData);
await storageService.setSecureJson('auth_tokens', tokenData);
// DateTime and list operations
await storageService.setDateTime('last_login', DateTime.now());
await storageService.setStringList('interests', ['tech', 'music']);// JSON convenience methods
final users = await networkService.getJson('/users');
await networkService.postJson('/users', jsonBody: newUser);
// Automatic token management and refresh
final profile = await networkService.getJson('/protected/profile');Flutter Infra follows a layered architecture with clear separation of concerns:
- Application Layer: Your Flutter app, repositories, and services
- Flutter Infra Layer: StorageService, NetworkService, TokenManager
- Implementation Layer: Storage implementations, network clients, interceptors
- Platform Layer: SharedPreferences, FlutterSecureStorage, Hive, HTTP clients
Check out the example directory for a complete Flutter app demonstrating:
- Default Usage: Basic storage and network operations
- Common Usage: Token management and API integration
- Advanced Usage: Custom configurations and interceptors
dart testThe package includes comprehensive test coverage with unit tests, integration tests, and mock support for testing your own code.
- π Documentation: Browse the doc directory for detailed guides
- π Issues: GitHub Issues
- π¬ Discussions: GitHub Discussions
This project is licensed under the MIT License - see the LICENSE file for details.
Flutter Infra - Building robust Flutter applications with confidence! π