sys_user.py 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489
  1. # -*- coding: utf-8 -*-
  2. # @Author : YY
  3. from typing import List, Literal, Optional
  4. from ruoyi_common.constant import UserConstants
  5. from ruoyi_common.exception import ServiceException
  6. from ruoyi_common.sqlalchemy.transaction import Transactional
  7. from ruoyi_common.domain.entity import SysRole, SysUser
  8. from ruoyi_common.utils import security_util
  9. from ruoyi_common.utils.base import LogUtil, StringUtil
  10. from ruoyi_framework.descriptor.datascope import DataScope
  11. from ruoyi_system.domain.entity import SysPost, SysUserPost, SysUserRole
  12. from ruoyi_system.mapper import SysUserMapper
  13. from ruoyi_system.mapper.sys_post import SysPostMapper
  14. from ruoyi_system.mapper.sys_role import SysRoleMapper
  15. from ruoyi_system.mapper.sys_user_post import SysUserPostMapper
  16. from ruoyi_system.mapper.sys_user_role import SysUserRoleMapper
  17. from ruoyi_admin.ext import db
  18. from ruoyi_system.service.sys_config import SysConfigService
  19. class SysUserService:
  20. @classmethod
  21. @DataScope(dept=True, user=True)
  22. def select_user_list(cls, query: SysUser) -> List[SysUser]:
  23. """
  24. 查询用户列表
  25. Args:
  26. query (SysUser): 包含查询条件的传输对象
  27. Returns:
  28. List[SysUser]: 用户列表
  29. """
  30. return SysUserMapper.select_user_list(query)
  31. @classmethod
  32. @DataScope(dept=True, user=True)
  33. def select_allocated_list(cls, query: SysUser) -> List[SysUser]:
  34. """
  35. 查询已分配用户列表
  36. Args:
  37. query (SysUser): 包含查询条件的传输对象
  38. Returns:
  39. List[SysUser]: 已分配用户列表
  40. """
  41. return SysUserMapper.select_allocated_list(query)
  42. @classmethod
  43. @DataScope(dept=True, user=True)
  44. def select_unallocated_list(cls, query: SysUser) -> List[SysUser]:
  45. """
  46. 查询未分配用户列表
  47. Args:
  48. query (SysUser): 包含查询条件的传输对象
  49. Returns:
  50. List[SysUser]: 已分配用户列表
  51. """
  52. return SysUserMapper.select_unallocated_list(query)
  53. @classmethod
  54. def select_user_by_user_name(cls, user_name: str) -> Optional[SysUser]:
  55. """
  56. 根据用户名,查询用户
  57. Args:
  58. user_name (str): 用户名
  59. Returns:
  60. Optional[SysUser]: 用户信息
  61. """
  62. return SysUserMapper.select_user_by_user_name(user_name)
  63. @classmethod
  64. def select_user_by_id(cls, user_id: int) -> Optional[SysUser]:
  65. """
  66. 根据用户ID,查询用户
  67. Args:
  68. user_id (int): 用户ID
  69. Returns:
  70. Optional[SysUser]: 用户信息
  71. """
  72. return SysUserMapper.select_user_by_id(user_id)
  73. @classmethod
  74. def select_user_role_group(cls, user_name: str) -> str:
  75. """
  76. 查询用户角色组
  77. Args:
  78. user_name (str): 用户名
  79. Returns:
  80. str: 角色组
  81. """
  82. eos: List[SysRole] = SysRoleMapper.select_role_list_by_user_name(user_name)
  83. if not eos:
  84. return StringUtil.EMPTY
  85. return ",".join([eo.role_name for eo in eos])
  86. @classmethod
  87. def select_user_post_group(cls, user_name: str) -> str:
  88. """
  89. 查询用户岗位组
  90. Args:
  91. user_name (str): 用户名
  92. Returns:
  93. str: 岗位组
  94. """
  95. eos: List[SysPost] = SysPostMapper.select_posts_by_user_name(user_name)
  96. if not eos:
  97. return StringUtil.EMPTY
  98. return ",".join([eo.post_name for eo in eos])
  99. @classmethod
  100. def check_user_name_unique(cls, user: SysUser) -> Literal["0", "1"]:
  101. """
  102. 校验用户名是否唯一
  103. Args:
  104. user (SysUser): 用户信息
  105. Returns:
  106. str: 唯一标识符, 0-唯一, 1-不唯一
  107. """
  108. user_name = -1 if user.user_name is None else user.user_name
  109. num = SysUserMapper.check_user_name_unique(user_name)
  110. if num > 0:
  111. return UserConstants.NOT_UNIQUE
  112. return UserConstants.UNIQUE
  113. @classmethod
  114. def check_phone_unique(cls, user: SysUser) -> Literal["0", "1"]:
  115. """
  116. 校验手机号是否唯一
  117. Args:
  118. user (SysUser): 用户信息
  119. Returns:
  120. str: 唯一标识符, 0-唯一, 1-不唯一
  121. """
  122. user_id = -1 if user.user_id is None else user.user_id
  123. eo: SysUser = SysUserMapper.check_phone_unique(user.phonenumber)
  124. if eo and eo.user_id != user_id:
  125. return UserConstants.NOT_UNIQUE
  126. return UserConstants.UNIQUE
  127. @classmethod
  128. def check_email_unique(cls, user: SysUser) -> str:
  129. """
  130. 校验邮箱是否唯一
  131. Args:
  132. user (SysUser): 用户信息
  133. Returns:
  134. str: 唯一标识符, 0-唯一, 1-不唯一
  135. """
  136. user_email = -1 if user.email is None else user.email
  137. eo: SysUser = SysUserMapper.check_email_unique(user.email)
  138. if eo and eo.email != user_email:
  139. return UserConstants.NOT_UNIQUE
  140. return UserConstants.UNIQUE
  141. @classmethod
  142. def check_user_allowed(cls, user: SysUser):
  143. """
  144. 检查用户是否允许操作
  145. Args:
  146. user (SysUser): 用户信息
  147. Raises:
  148. ServiceException: 超级管理员用户不允许操作
  149. """
  150. if user.is_admin():
  151. raise ServiceException("不允许操作超级管理员用户")
  152. @classmethod
  153. def check_user_data_scope(cls, user_id: Optional[int]):
  154. """
  155. 检查用户数据权限
  156. Args:
  157. user_id (Optional[int]): 用户ID
  158. Raises:
  159. ServiceException: 无权限访问用户数据
  160. """
  161. if not security_util.login_user_is_admin():
  162. user = SysUser(user_id=user_id) if user_id else SysUser()
  163. users: List[SysUser] = cls.select_user_list(user)
  164. if not users:
  165. raise ServiceException("没有权限访问用户数据")
  166. @classmethod
  167. @Transactional(db.session)
  168. def insert_user(cls, user: SysUser) -> bool:
  169. """
  170. 新增用户
  171. Args:
  172. user (SysUser): 用户信息
  173. Returns:
  174. bool: 操作结果
  175. """
  176. last_pid = SysUserMapper.insert_user(user)
  177. user.user_id = last_pid
  178. cls.insert_user_post_by_user(user)
  179. cls.insert_user_role_by_user(user)
  180. return last_pid > 0
  181. @classmethod
  182. def register_user(cls, user: SysUser) -> bool:
  183. """
  184. 注册用户
  185. Args:
  186. user (SysUser): 用户信息
  187. Returns:
  188. bool: 操作结果
  189. """
  190. flag = SysUserMapper.insert_user(user)
  191. return flag > 0
  192. @classmethod
  193. @Transactional(db.session)
  194. def update_user(cls, user: SysUser) -> bool:
  195. """
  196. 更新用户
  197. Args:
  198. user (SysUser): 用户信息
  199. Returns:
  200. bool: 操作结果
  201. """
  202. # 删除用户角色关联
  203. SysRoleMapper.delete_user_role_by_user_id(user.user_id)
  204. # 新增用户和角色的关联
  205. cls.insert_user_role_by_user(user)
  206. # 删除用户岗位关联
  207. SysUserPostMapper.delete_user_post_by_user_id(user.user_id)
  208. # 新增用户岗位关联
  209. cls.insert_user_post_by_user(user)
  210. return SysUserMapper.update_user(user)
  211. @classmethod
  212. @Transactional(db.session)
  213. def insert_user_auth(cls, user_id: int, role_ids: List[int]):
  214. """
  215. 新增用户角色
  216. Args:
  217. user_id: 用户id
  218. role_ids: 角色id列表
  219. """
  220. cls.insert_user_role(user_id, role_ids)
  221. @classmethod
  222. def delete_users_by_id(cls, id: int) -> bool:
  223. """
  224. 根据用户ID,删除用户
  225. Args:
  226. id (int): 用户ID
  227. Returns:
  228. bool: 操作结果
  229. """
  230. return SysUserMapper.delete_user_by_id(id) > 0
  231. @classmethod
  232. def delete_users_by_ids(cls, ids: List[int]) -> bool:
  233. """
  234. 根据用户ID列表,批量删除用户
  235. Args:
  236. ids (List[int]): 用户ID列表
  237. Returns:
  238. bool: 操作结果
  239. """
  240. return SysUserMapper.delete_user_by_ids(ids) > 0
  241. @classmethod
  242. def update_user_status(cls, user: SysUser) -> bool:
  243. """
  244. 更新用户状态
  245. Args:
  246. user (SysUser): 用户信息
  247. Returns:
  248. bool: 操作结果
  249. """
  250. return SysUserMapper.update_user(user) > 0
  251. @classmethod
  252. def update_user_profile(cls, user: SysUser) -> bool:
  253. """
  254. 更新用户个人信息
  255. Args:
  256. user (SysUser): 用户信息
  257. Returns:
  258. bool: 操作结果
  259. """
  260. return SysUserMapper.update_user(user) > 0
  261. @classmethod
  262. def update_user_avatar(cls, user_name: str, avatar: str) -> bool:
  263. """
  264. 更新用户头像
  265. Args:
  266. user_name (str): 用户名
  267. avatar (str): 头像
  268. Returns:
  269. bool: 操作结果
  270. """
  271. return SysUserMapper.update_user_avatar(user_name, avatar) > 0
  272. @classmethod
  273. def reset_pwd(cls, user: SysUser) -> bool:
  274. """
  275. 重置用户密码
  276. Args:
  277. user (SysUser): 用户信息
  278. Returns:
  279. bool: 操作结果
  280. """
  281. return SysUserMapper.update_user(user) > 0
  282. @classmethod
  283. def reset_user_pwd(cls, username: str, password: str) -> bool:
  284. """
  285. 重置用户密码
  286. Args:
  287. username (str): 用户名
  288. password (str): 密码
  289. Returns:
  290. bool: 操作结果
  291. """
  292. return SysUserMapper.reset_user_pwd(username, password) > 0
  293. @classmethod
  294. def insert_user_role_by_user(cls, user: SysUser):
  295. """
  296. 新增用户角色
  297. Args:
  298. user: 用户信息
  299. """
  300. cls.insert_user_role(user.user_id, user.role_ids)
  301. @classmethod
  302. @Transactional(db.session)
  303. def insert_user_role(cls, user_id: int, role_ids: List[int]):
  304. """
  305. 新增用户角色
  306. Args:
  307. user_id: 用户id
  308. role_ids: 角色id列表
  309. """
  310. if role_ids:
  311. lists = [
  312. SysUserRole(user_id=user_id, role_id=role_id)
  313. for role_id in role_ids
  314. ]
  315. SysUserRoleMapper.batch_user_role(lists)
  316. @classmethod
  317. def insert_user_post_by_user(cls, user: SysUser):
  318. """
  319. 新增用户岗位
  320. Args:
  321. user: 用户信息
  322. """
  323. cls.insert_user_post(user.user_id, user.post_ids)
  324. @classmethod
  325. @Transactional(db.session)
  326. def insert_user_post(cls, user_id: int, post_ids: List[int]):
  327. """
  328. 新增用户岗位
  329. Args:
  330. user_id: 用户id
  331. post_ids: 岗位id列表
  332. """
  333. if post_ids:
  334. lists = [
  335. SysUserPost(user_id=user_id, post_id=post_id)
  336. for post_id in post_ids
  337. ]
  338. SysUserPostMapper.batch_user_post(lists)
  339. @classmethod
  340. @Transactional(db.session)
  341. def update_user_roles(cls, user_id: int, role_ids: List[int]) -> bool:
  342. """
  343. 更新用户角色
  344. Args:
  345. user_id: 用户id
  346. role_ids: 角色id列表
  347. Returns:
  348. bool: 操作结果
  349. """
  350. SysUserRoleMapper.delete_user_role_by_user_id(user_id)
  351. cls.insert_user_role(user_id, role_ids)
  352. return True
  353. @classmethod
  354. def import_user(cls, users: List[SysUser], is_update: bool = False) -> str:
  355. """
  356. 导入用户
  357. Args:
  358. users (List[SysUser]): 用户列表
  359. is_update (bool): 是否更新
  360. Returns:
  361. str: 导入消息结果
  362. """
  363. if not users:
  364. raise ServiceException("导入用户不能为空")
  365. success_count = 0
  366. fail_count = 0
  367. success_msg = ""
  368. fail_msg = ""
  369. default_password = SysConfigService.select_config_by_key("sys.user.initPassword")
  370. for user in users:
  371. try:
  372. dto = SysUserMapper.select_user_by_user_name(user.user_name)
  373. if not dto:
  374. user.password = security_util.encrypt_password(default_password)
  375. user.create_by_user(security_util.get_user_id())
  376. cls.insert_user(user)
  377. success_count += 1
  378. success_msg += f"<br/> 第{success_count}个账号,导入成功:{user.user_name}"
  379. elif is_update:
  380. user.update_by_user(security_util.get_user_id())
  381. cls.update_user(user)
  382. success_count += 1
  383. success_msg += f"<br/> 第{success_count}个账号,更新成功:{user.user_name}"
  384. else:
  385. fail_count += 1
  386. fail_msg += f"<br/> 第{fail_count}个账号,已存在:{user.user_name}"
  387. except Exception as e:
  388. fail_count += 1
  389. fail_msg += f"<br/> 第{fail_count}个账号,导入失败:{user.user_name},\
  390. 原因:{e.__class__.__name__}"
  391. LogUtil.logger.error(f"导入用户失败,原因:{e}")
  392. if fail_count > 0:
  393. if success_msg:
  394. fail_msg = f"导入成功{success_count}个,失败{fail_count}个。{success_msg} \
  395. <br/>" + fail_msg
  396. else:
  397. fail_msg = f"导入成功{success_count}个,失败{fail_count}个。{fail_msg}"
  398. raise ServiceException(fail_msg)
  399. else:
  400. success_msg = f"恭喜您,数据已全部导入成功!共 {success_count} 条,数据如下:" \
  401. + success_msg
  402. return success_msg