Retrofit & Dio Networking
Priority: P0 (CRITICAL)
Type-safe REST API communication using Dio and Retrofit.
Structure
infrastructure/
├── data_sources/
│ ├── remote/ # Retrofit abstract classes
│ └── local/ # Cache/Storage
└── network/
├── dio_client.dart # Custom Dio setup
└── interceptors/ # Auth, Logging, Cache
Implementation Guidelines
- Retrofit Clients: Define abstract classes with
@RestApi(). Use standard HTTP annotations (@GET,@POST). - DTOs (Data Transfer Objects): Use
@freezedandjson_serializablefor all response/request bodies. - Mapping: Data sources MUST map DTOs to Domain Entities (e.g.,
userDto.toDomain()). - AuthInterceptor: Logic for
Authorization: Bearer <token>injection inonRequest. - Token Refresh: Handle
401 UnauthorizedinonErrorby locking Dio, refreshing, and retrying. - Failures: Map
DioExceptionto customFailureobjects (ServerFailure, NetworkFailure).
Anti-Patterns
- No Manual JSON Parsing: Do not use
jsonDecode(response.body); use Retrofit's generated mappers. - No Global Dio: Do not use a static global Dio instance; use dependency injection.
- No Try-Catch in API: Do not put
try-catchinside the Retrofit interface methods.
Reference & Examples
For RestClient definitions and Auth Interceptor implementation: See references/REFERENCE.md.
Related Topics
feature-based-clean-architecture | error-handling
