Flutter Infra ποΈ
A comprehensive Flutter package providing clean, type-safe local storage solutions and robust network infrastructure with advanced token management and refresh strategies.
β¨ Features
πΎ Storage Infrastructure
- π― 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
π Network Infrastructure
- π 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 and TokenInterceptor with extensible design
π§ Common Features
- π§ 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
π Quick Start
Installation
dependencies:
flutter_infra: ^0.0.1
Basic Usage
import '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());
}
With Authentication
// 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');
π Documentation
π Getting Started
- π Quick Start Guide - Get up and running in minutes
- ποΈ Architecture Overview - System design and component relationships
- βοΈ Configuration Guide - Advanced setup and customization options
π Service Documentation
- πΎ Storage Service - Complete storage documentation with implementations and typed extensions
- π Network Service - Network client documentation with interceptors and configuration
- π Token Management - Token manager, refresh strategies, and security
π‘ Guides & Best Practices
- π Complete Examples - Real-world usage patterns and implementation examples
- π Best Practices - Recommended patterns, security guidelines, and performance tips
π§© Key Capabilities
Typed Storage Extensions
// 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']);
Smart Network Client
// 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');
ποΈ Architecture
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
π± Example App
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
π§ͺ Testing
dart test
The package includes comprehensive test coverage with unit tests, integration tests, and mock support for testing your own code.
π€ Getting Help
- π Documentation: Browse the doc directory for detailed guides
- π Issues: GitHub Issues
- π¬ Discussions: GitHub Discussions
π License
This project is licensed under the MIT License - see the LICENSE file for details.
Flutter Infra - Building robust Flutter applications with confidence! π
Libraries
- flutter_infra
- Flutter Infrastructure Package