xpeditis2.0/apps/backend/src/domain/ports/out/user.repository.ts
David ee38ee6961
Some checks failed
CI/CD Pipeline / Integration Tests (push) Blocked by required conditions
CI/CD Pipeline / Deployment Summary (push) Blocked by required conditions
CI/CD Pipeline / Backend - Build, Test & Push (push) Failing after 2m11s
CI/CD Pipeline / Frontend - Build, Test & Push (push) Has been cancelled
fix: add missing domain ports files that were gitignored
Root cause: The .gitignore had 'out/' which was ignoring ALL directories
named 'out', including 'src/domain/ports/out/' which contains critical
port interfaces for hexagonal architecture.

Changes:
- Modified .gitignore to only ignore Next.js output directories
- Added all 17 missing files from src/domain/ports/out/
  - audit-log.repository.ts
  - booking.repository.ts
  - cache.port.ts
  - carrier-connector.port.ts
  - carrier.repository.ts
  - csv-booking.repository.ts
  - csv-rate-loader.port.ts
  - email.port.ts
  - index.ts
  - notification.repository.ts
  - organization.repository.ts
  - pdf.port.ts
  - port.repository.ts
  - rate-quote.repository.ts
  - storage.port.ts
  - user.repository.ts
  - webhook.repository.ts

This resolves all "Cannot find module '@domain/ports/out/*'" TypeScript errors.

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-11-17 01:50:05 +01:00

63 lines
1.2 KiB
TypeScript

/**
* User Repository Port
*
* Defines the interface for User persistence operations.
* This is a secondary port (output port) in hexagonal architecture.
*/
import { User } from '../../entities/user.entity';
export const USER_REPOSITORY = 'UserRepository';
export interface UserRepository {
/**
* Save a user entity
*/
save(user: User): Promise<User>;
/**
* Find user by ID
*/
findById(id: string): Promise<User | null>;
/**
* Find user by email address
*/
findByEmail(email: string): Promise<User | null>;
/**
* Find all users belonging to an organization
*/
findByOrganization(organizationId: string): Promise<User[]>;
/**
* Find all users with a specific role
*/
findByRole(role: string): Promise<User[]>;
/**
* Find all active users
*/
findAllActive(): Promise<User[]>;
/**
* Update a user entity
*/
update(user: User): Promise<User>;
/**
* Delete user by ID
*/
deleteById(id: string): Promise<void>;
/**
* Count users in an organization
*/
countByOrganization(organizationId: string): Promise<number>;
/**
* Check if email exists
*/
emailExists(email: string): Promise<boolean>;
}