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! 🚀