Files
puaros/packages/guardian/examples/repository-pattern/bad-concrete-repository-in-use-case.ts
imfozilbek 0534fdf1bd feat: add repository pattern validation (v0.5.0)
Add comprehensive Repository Pattern validation to detect violations
and ensure proper domain-infrastructure separation.

Features:
- ORM type detection in repository interfaces (25+ patterns)
- Concrete repository usage detection in use cases
- Repository instantiation detection (new Repository())
- Domain language validation for repository methods
- Smart violation reporting with fix suggestions

Tests:
- 31 new tests for repository pattern detection
- 292 total tests passing (100% pass rate)
- 96.77% statement coverage, 83.82% branch coverage

Examples:
- 8 example files (4 bad patterns, 4 good patterns)
- Demonstrates Clean Architecture and SOLID principles
2025-11-24 20:11:43 +05:00

68 lines
1.4 KiB
TypeScript

/**
* ❌ BAD EXAMPLE: Concrete repository in use case
*
* Use case depends on concrete repository implementation instead of interface.
* This violates Dependency Inversion Principle.
*/
class CreateUser {
constructor(private userRepo: PrismaUserRepository) {}
async execute(data: CreateUserRequest): Promise<UserResponseDto> {
const user = User.create(data.email, data.name)
await this.userRepo.save(user)
return UserMapper.toDto(user)
}
}
class PrismaUserRepository {
constructor(private prisma: any) {}
async save(user: User): Promise<void> {
await this.prisma.user.create({
data: {
email: user.getEmail(),
name: user.getName(),
},
})
}
}
class User {
static create(email: string, name: string): User {
return new User(email, name)
}
constructor(
private email: string,
private name: string,
) {}
getEmail(): string {
return this.email
}
getName(): string {
return this.name
}
}
interface CreateUserRequest {
email: string
name: string
}
interface UserResponseDto {
email: string
name: string
}
class UserMapper {
static toDto(user: User): UserResponseDto {
return {
email: user.getEmail(),
name: user.getName(),
}
}
}