2026-05-06 17:43:47 +08:00
|
|
|
from sqlalchemy.orm import Session
|
|
|
|
|
|
2026-05-06 22:23:42 +08:00
|
|
|
from app.core.logging import get_logger
|
2026-05-06 17:43:47 +08:00
|
|
|
from app.models.employee import Employee
|
|
|
|
|
from app.repositories.employee import EmployeeRepository
|
|
|
|
|
from app.schemas.employee import EmployeeCreate
|
|
|
|
|
|
2026-05-06 22:23:42 +08:00
|
|
|
logger = get_logger("app.services.employee")
|
|
|
|
|
|
2026-05-06 17:43:47 +08:00
|
|
|
|
|
|
|
|
class EmployeeService:
|
|
|
|
|
def __init__(self, db: Session) -> None:
|
|
|
|
|
self.repository = EmployeeRepository(db)
|
|
|
|
|
|
|
|
|
|
def list_employees(self) -> list[Employee]:
|
2026-05-06 22:23:42 +08:00
|
|
|
employees = self.repository.list()
|
|
|
|
|
logger.info("Listed employees (count=%d)", len(employees))
|
|
|
|
|
return employees
|
2026-05-06 17:43:47 +08:00
|
|
|
|
|
|
|
|
def get_employee(self, employee_id: str) -> Employee | None:
|
2026-05-06 22:23:42 +08:00
|
|
|
employee = self.repository.get(employee_id)
|
|
|
|
|
if employee:
|
|
|
|
|
logger.info("Fetched employee id=%s name=%s", employee_id, employee.name)
|
|
|
|
|
else:
|
|
|
|
|
logger.warning("Employee not found id=%s", employee_id)
|
|
|
|
|
return employee
|
2026-05-06 17:43:47 +08:00
|
|
|
|
|
|
|
|
def create_employee(self, payload: EmployeeCreate) -> Employee:
|
|
|
|
|
employee = Employee(**payload.model_dump())
|
2026-05-06 22:23:42 +08:00
|
|
|
created = self.repository.create(employee)
|
|
|
|
|
logger.info(
|
|
|
|
|
"Created employee id=%s no=%s name=%s", created.id, created.employee_no, created.name
|
|
|
|
|
)
|
|
|
|
|
return created
|