Spring Boot Architecture Standards
Priority: P0 (CRITICAL)
Organize by Feature
- Package by Feature: Prefer
com.app.feature(e.g.,user,order) over technical layers (controllers) for scalability. - Dependency Rule: Outer layers (Web) depend on Inner (Service). Inner layers MUST NOT depend on Outer.
- DTO Pattern: ALWAYS use DTOs for API inputs/outputs. NEVER return
@Entitydirectly. - Java Records: Use
recordfor DTOs to ensure immutability (Java 17+).
See implementation examples for Java Record DTOs, controller patterns, and global exception handling.
Define Layer Responsibilities
- Controller (Web): Handle HTTP, Validation (
@Valid), DTO mapping. Delegate logic to Service. - Service (Business): Transaction boundaries, orchestration. Returns Domain/DTOs.
- Repository (Data): Database interactions only. Returns Entities/Projections.
Design API Layer
- Global Error Handling: Use
@RestControllerAdvicewithProblemDetails(RFC 7807). - Validation: Use Jakarta Bean Validation (
@NotNull,@Size) on DTOs. - Response: Use
ResponseEntityfor explicit status orResponseStatusException.
Verification Checklist (Mandatory)
- [ ] No Entities in API: Are all API responses using DTOs/Records instead of JPA Entities?
- [ ] Validation: Are
@Validand Jakarta Bean Validation constraints present on all input DTOs? - [ ] Layer coupling: Do Services depend on Controllers? (Prohibited)
- [ ] Transactionality: Are business transactions correctly bounded with
@Transactionalin the Service layer? - [ ] Error Details: Is
ProblemDetailsused for consistent error responses?
Anti-Patterns
- No Fat Controllers: Move business logic to Services.
- No Leaking Entities: Use DTOs instead of JPA Entities in APIs.
- No Circular Dependencies: Use Events or refactor to decouple services.
- No God Classes: Split large services into single-responsibility components.