AdminLogic.php 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | likeadmin快速开发前后端分离管理后台(PHP版)
  4. // +----------------------------------------------------------------------
  5. // | 欢迎阅读学习系统程序代码,建议反馈是我们前进的动力
  6. // | 开源版本可自由商用,可去除界面版权logo
  7. // | gitee下载:https://gitee.com/likeshop_gitee/likeadmin
  8. // | github下载:https://github.com/likeshop-github/likeadmin
  9. // | 访问官网:https://www.likeadmin.cn
  10. // | likeadmin团队 版权所有 拥有最终解释权
  11. // +----------------------------------------------------------------------
  12. // | author: likeadminTeam
  13. // +----------------------------------------------------------------------
  14. namespace app\tenantapi\logic\auth;
  15. use app\common\cache\TenantAdminAuthCache;
  16. use app\common\enum\YesNoEnum;
  17. use app\common\logic\BaseLogic;
  18. use app\common\model\auth\TenantAdmin;
  19. use app\common\model\auth\TenantAdminDept;
  20. use app\common\model\auth\TenantAdminJobs;
  21. use app\common\model\auth\TenantAdminRole;
  22. use app\common\model\auth\TenantAdminSession;
  23. use app\common\cache\TenantAdminTokenCache;
  24. use app\common\service\FileService;
  25. use think\facade\Config;
  26. use think\facade\Db;
  27. /**
  28. * 管理员逻辑
  29. * Class AdminLogic
  30. * @package app\tenantapi\logic\auth
  31. */
  32. class AdminLogic extends BaseLogic
  33. {
  34. /**
  35. * @notes 添加管理员
  36. * @param array $params
  37. * @author 段誉
  38. * @date 2021/12/29 10:23
  39. */
  40. public static function add(array $params)
  41. {
  42. Db::startTrans();
  43. try {
  44. $passwordSalt = Config::get('project.unique_identification');
  45. $password = create_password($params['password'], $passwordSalt);
  46. $defaultAvatar = config('project.default_image.admin_avatar');
  47. $avatar = !empty($params['avatar']) ? FileService::setFileUrl($params['avatar']) : $defaultAvatar;
  48. $admin = TenantAdmin::create([
  49. 'name' => $params['name'],
  50. 'account' => $params['account'],
  51. 'avatar' => $avatar,
  52. 'password' => $password,
  53. 'create_time' => time(),
  54. 'disable' => $params['disable'],
  55. 'multipoint_login' => $params['multipoint_login'],
  56. ]);
  57. // 角色
  58. self::insertRole($admin['id'], $params['role_id'] ?? []);
  59. // 部门
  60. self::insertDept($admin['id'], $params['dept_id'] ?? []);
  61. // 岗位
  62. self::insertJobs($admin['id'], $params['jobs_id'] ?? []);
  63. Db::commit();
  64. return true;
  65. } catch (\Exception $e) {
  66. Db::rollback();
  67. self::setError($e->getMessage());
  68. return false;
  69. }
  70. }
  71. /**
  72. * @notes 编辑管理员
  73. * @param array $params
  74. * @return bool
  75. * @author 段誉
  76. * @date 2021/12/29 10:43
  77. */
  78. public static function edit(array $params): bool
  79. {
  80. Db::startTrans();
  81. try {
  82. // 基础信息
  83. $data = [
  84. 'name' => $params['name'],
  85. 'account' => $params['account'],
  86. 'disable' => $params['disable'],
  87. 'multipoint_login' => $params['multipoint_login']
  88. ];
  89. // 头像
  90. $data['avatar'] = !empty($params['avatar']) ? FileService::setFileUrl($params['avatar']) : '';
  91. // 密码
  92. if (!empty($params['password'])) {
  93. $passwordSalt = Config::get('project.unique_identification');
  94. $data['password'] = create_password($params['password'], $passwordSalt);
  95. }
  96. // 禁用或更换角色后.设置token过期
  97. $roleId = TenantAdminRole::where('admin_id', $params['id'])->column('role_id');
  98. $editRole = false;
  99. if (!empty(array_diff_assoc($roleId, $params['role_id']))) {
  100. $editRole = true;
  101. }
  102. if ($params['disable'] == 1 || $editRole) {
  103. $tokenArr = TenantAdminSession::where('admin_id', $params['id'])->select()->toArray();
  104. foreach ($tokenArr as $token) {
  105. self::expireToken($token['token']);
  106. }
  107. }
  108. TenantAdmin::update($data, ['id' => $params['id']]);
  109. (new TenantAdminAuthCache($params['id']))->clearAuthCache();
  110. // 删除旧的关联信息
  111. TenantAdminRole::delByUserId($params['id']);
  112. TenantAdminDept::delByUserId($params['id']);
  113. TenantAdminJobs::delByUserId($params['id']);
  114. // 角色
  115. self::insertRole($params['id'], $params['role_id']);
  116. // 部门
  117. self::insertDept($params['id'], $params['dept_id'] ?? []);
  118. // 岗位
  119. self::insertJobs($params['id'], $params['jobs_id'] ?? []);
  120. Db::commit();
  121. return true;
  122. } catch (\Exception $e) {
  123. Db::rollback();
  124. self::setError($e->getMessage());
  125. return false;
  126. }
  127. }
  128. /**
  129. * @notes 删除管理员
  130. * @param array $params
  131. * @return bool
  132. * @author 段誉
  133. * @date 2021/12/29 10:45
  134. */
  135. public static function delete(array $params): bool
  136. {
  137. Db::startTrans();
  138. try {
  139. $admin = TenantAdmin::findOrEmpty($params['id']);
  140. if ($admin->root == YesNoEnum::YES) {
  141. throw new \Exception("超级管理员不允许被删除");
  142. }
  143. TenantAdmin::destroy($params['id']);
  144. //设置token过期
  145. $tokenArr = TenantAdminSession::where('admin_id', $params['id'])->select()->toArray();
  146. foreach ($tokenArr as $token) {
  147. self::expireToken($token['token']);
  148. }
  149. (new TenantAdminAuthCache($params['id']))->clearAuthCache();
  150. // 删除旧的关联信息
  151. TenantAdminRole::delByUserId($params['id']);
  152. TenantAdminDept::delByUserId($params['id']);
  153. TenantAdminJobs::delByUserId($params['id']);
  154. Db::commit();
  155. return true;
  156. } catch (\Exception $e) {
  157. Db::rollback();
  158. self::setError($e->getMessage());
  159. return false;
  160. }
  161. }
  162. /**
  163. * @notes 过期token
  164. * @param $token
  165. * @return bool
  166. * @throws \think\db\exception\DataNotFoundException
  167. * @throws \think\db\exception\DbException
  168. * @throws \think\db\exception\ModelNotFoundException
  169. * @author 段誉
  170. * @date 2021/12/29 10:46
  171. */
  172. public static function expireToken($token): bool
  173. {
  174. $adminSession = TenantAdminSession::where('token', '=', $token)
  175. ->with('admin')
  176. ->find();
  177. if (empty($adminSession)) {
  178. return false;
  179. }
  180. $time = time();
  181. $adminSession->expire_time = $time;
  182. $adminSession->update_time = $time;
  183. $adminSession->save();
  184. return (new TenantAdminTokenCache())->deleteAdminInfo($token);
  185. }
  186. /**
  187. * @notes 查看管理员详情
  188. * @param $params
  189. * @return array
  190. * @author 段誉
  191. * @date 2021/12/29 11:07
  192. */
  193. public static function detail($params, $action = 'detail'): array
  194. {
  195. $admin = TenantAdmin::field([
  196. 'id', 'account', 'name', 'disable', 'root',
  197. 'multipoint_login', 'avatar',
  198. ])->findOrEmpty($params['id'])->toArray();
  199. if ($action == 'detail') {
  200. return $admin;
  201. }
  202. $result['user'] = $admin;
  203. // 当前管理员角色拥有的菜单
  204. $result['menu'] = MenuLogic::getMenuByAdminId($params['id']);
  205. // 当前管理员橘色拥有的按钮权限
  206. $result['permissions'] = AuthLogic::getBtnAuthByRoleId($admin);
  207. return $result;
  208. }
  209. /**
  210. * @notes 编辑超级管理员
  211. * @param $params
  212. * @author 段誉
  213. * @date 2022/4/8 17:54
  214. */
  215. public static function editSelf($params)
  216. {
  217. $data = [
  218. 'name' => $params['name'],
  219. 'avatar' => FileService::setFileUrl($params['avatar']),
  220. ];
  221. if (!empty($params['password'])) {
  222. $passwordSalt = Config::get('project.unique_identification');
  223. $data['password'] = create_password($params['password'], $passwordSalt);
  224. }
  225. return TenantAdmin::update($data, ['id' => $params['admin_id']]);
  226. }
  227. /**
  228. * @notes 新增角色
  229. * @param $adminId
  230. * @param $roleIds
  231. * @throws \Exception
  232. * @author 段誉
  233. * @date 2022/11/25 14:23
  234. */
  235. public static function insertRole($adminId, $roleIds)
  236. {
  237. if (!empty($roleIds)) {
  238. // 角色
  239. $roleData = [];
  240. foreach ($roleIds as $roleId) {
  241. $roleData[] = [
  242. 'admin_id' => $adminId,
  243. 'role_id' => $roleId,
  244. ];
  245. }
  246. (new TenantAdminRole())->saveAll($roleData);
  247. }
  248. }
  249. /**
  250. * @notes 新增部门
  251. * @param $adminId
  252. * @param $deptIds
  253. * @throws \Exception
  254. * @author 段誉
  255. * @date 2022/11/25 14:22
  256. */
  257. public static function insertDept($adminId, $deptIds)
  258. {
  259. // 部门
  260. if (!empty($deptIds)) {
  261. $deptData = [];
  262. foreach ($deptIds as $deptId) {
  263. $deptData[] = [
  264. 'admin_id' => $adminId,
  265. 'dept_id' => $deptId
  266. ];
  267. }
  268. (new TenantAdminDept())->saveAll($deptData);
  269. }
  270. }
  271. /**
  272. * @notes 新增岗位
  273. * @param $adminId
  274. * @param $jobsIds
  275. * @throws \Exception
  276. * @author 段誉
  277. * @date 2022/11/25 14:22
  278. */
  279. public static function insertJobs($adminId, $jobsIds)
  280. {
  281. // 岗位
  282. if (!empty($jobsIds)) {
  283. $jobsData = [];
  284. foreach ($jobsIds as $jobsId) {
  285. $jobsData[] = [
  286. 'admin_id' => $adminId,
  287. 'jobs_id' => $jobsId
  288. ];
  289. }
  290. (new TenantAdminJobs())->saveAll($jobsData);
  291. }
  292. }
  293. }