user_service.py 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117
  1. # app/services/user_service.py
  2. import uuid
  3. from datetime import datetime
  4. from typing import List, Optional
  5. from sqlalchemy.ext.asyncio import AsyncSession
  6. from sqlalchemy import select
  7. from app.utils.search import apply_keyword_search_stmt
  8. from app.utils.pagination import paginate
  9. from app.core.biz_exception import NotFoundError
  10. from app.models.user import VasUser
  11. from app.schemas.user import (
  12. VasUserCreate,
  13. VasUserUpdate,
  14. VasUserSetProfiles,
  15. VasUserOut,
  16. )
  17. class UserService:
  18. @staticmethod
  19. async def create(db: AsyncSession, data: VasUserCreate) -> VasUser:
  20. uid = f"usr-{uuid.uuid4().hex[:8]}"
  21. user = VasUser(
  22. id=uid,
  23. role=data.role,
  24. nickname=data.nickname,
  25. phone=data.phone,
  26. preferred_language="en",
  27. timezone="Asia/Shanghai",
  28. created_at=datetime.utcnow(),
  29. )
  30. db.add(user)
  31. await db.commit()
  32. await db.refresh(user)
  33. return user
  34. @staticmethod
  35. async def get(db: AsyncSession, id: str) -> VasUser:
  36. stmt = select(VasUser).where(VasUser.id == id)
  37. result = await db.execute(stmt)
  38. user = result.scalar_one_or_none()
  39. if not user:
  40. raise NotFoundError("User not exist")
  41. return user
  42. @staticmethod
  43. async def update(
  44. db: AsyncSession,
  45. id: str,
  46. payload: VasUserUpdate
  47. ) -> VasUser:
  48. stmt = select(VasUser).where(VasUser.id == id)
  49. result = await db.execute(stmt)
  50. obj = result.scalar_one_or_none()
  51. if not obj:
  52. raise NotFoundError("User not exist")
  53. data = payload.dict(exclude_unset=True)
  54. for key, value in data.items():
  55. setattr(obj, key, value)
  56. obj.updated_at = datetime.utcnow()
  57. await db.commit()
  58. await db.refresh(obj)
  59. return obj
  60. @staticmethod
  61. async def set_profiles(
  62. db: AsyncSession,
  63. user: VasUser,
  64. payload: VasUserSetProfiles
  65. ) -> VasUser:
  66. """
  67. 更新用户资料(profile)
  68. """
  69. user.phone = payload.phone
  70. user.nickname = payload.nickname
  71. user.avatar_url = payload.avatar_url
  72. user.updated_at = datetime.utcnow()
  73. db.add(user)
  74. await db.commit()
  75. await db.refresh(user)
  76. return user
  77. @staticmethod
  78. async def list_all(
  79. db: AsyncSession,
  80. page: int = 1,
  81. size: int = 20,
  82. keyword: Optional[str] = None,
  83. ):
  84. stmt = select(VasUser)
  85. stmt = apply_keyword_search_stmt(
  86. stmt=stmt,
  87. model=VasUser,
  88. keyword=keyword,
  89. fields=["id", "email", "nickname", "phone"],
  90. )
  91. return await paginate(db, stmt, page, size)