AdminLogic.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372
  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\adminapi\logic\auth;
  15. use app\adminapi\logic\jobs_rules\JobsRulesLogic;
  16. use app\common\cache\AdminAuthCache;
  17. use app\common\enum\YesNoEnum;
  18. use app\common\logic\BaseLogic;
  19. use app\common\model\auth\Admin;
  20. use app\common\model\auth\AdminDept;
  21. use app\common\model\auth\AdminJobs;
  22. use app\common\model\auth\AdminRole;
  23. use app\common\model\auth\AdminSession;
  24. use app\common\cache\AdminTokenCache;
  25. use app\common\model\dept\Jobs;
  26. use app\common\service\FileService;
  27. use think\facade\Config;
  28. use think\facade\Db;
  29. /**
  30. * 管理员逻辑
  31. * Class AdminLogic
  32. * @package app\adminapi\logic\auth
  33. */
  34. class AdminLogic extends BaseLogic
  35. {
  36. /**
  37. * @notes 添加管理员
  38. * @param array $params
  39. * @author 段誉
  40. * @date 2021/12/29 10:23
  41. */
  42. public static function add(array $params)
  43. {
  44. Db::startTrans();
  45. try {
  46. $passwordSalt = Config::get('project.unique_identification');
  47. $password = create_password($params['password'], $passwordSalt);
  48. $defaultAvatar = config('project.default_image.admin_avatar');
  49. $avatar = !empty($params['avatar']) ? FileService::setFileUrl($params['avatar']) : $defaultAvatar;
  50. $admin = Admin::create([
  51. 'name' => $params['name'],
  52. 'account' => $params['account'],
  53. 'avatar' => $avatar,
  54. 'password' => $password,
  55. 'create_time' => time(),
  56. 'disable' => $params['disable'],
  57. 'multipoint_login' => $params['multipoint_login'],
  58. ]);
  59. // 角色
  60. self::insertRole($admin['id'], $params['role_id'] ?? []);
  61. // 部门
  62. self::insertDept($admin['id'], $params['dept_id'] ?? []);
  63. // 岗位
  64. self::insertJobs($admin['id'], $params['jobs_id'] ?? []);
  65. Db::commit();
  66. return true;
  67. } catch (\Exception $e) {
  68. Db::rollback();
  69. self::setError($e->getMessage());
  70. return false;
  71. }
  72. }
  73. /**
  74. * @notes 编辑管理员
  75. * @param array $params
  76. * @return bool
  77. * @author 段誉
  78. * @date 2021/12/29 10:43
  79. */
  80. public static function edit(array $params): bool
  81. {
  82. Db::startTrans();
  83. try {
  84. // 基础信息
  85. $data = [
  86. 'id' => $params['id'],
  87. 'name' => $params['name'],
  88. 'account' => $params['account'],
  89. 'disable' => $params['disable'],
  90. 'multipoint_login' => $params['multipoint_login']
  91. ];
  92. // 头像
  93. $data['avatar'] = !empty($params['avatar']) ? FileService::setFileUrl($params['avatar']) : '';
  94. // 密码
  95. if (!empty($params['password'])) {
  96. $passwordSalt = Config::get('project.unique_identification');
  97. $data['password'] = create_password($params['password'], $passwordSalt);
  98. }
  99. // 禁用或更换角色后.设置token过期
  100. $roleId = AdminRole::where('admin_id', $params['id'])->column('role_id');
  101. $editRole = false;
  102. if (!empty(array_diff_assoc($roleId, $params['role_id']))) {
  103. $editRole = true;
  104. }
  105. if ($params['disable'] == 1 || $editRole) {
  106. $tokenArr = AdminSession::where('admin_id', $params['id'])->select()->toArray();
  107. foreach ($tokenArr as $token) {
  108. self::expireToken($token['token']);
  109. }
  110. }
  111. Admin::update($data);
  112. (new AdminAuthCache($params['id']))->clearAuthCache();
  113. // 删除旧的关联信息
  114. AdminRole::delByUserId($params['id']);
  115. AdminDept::delByUserId($params['id']);
  116. AdminJobs::delByUserId($params['id']);
  117. // 角色
  118. self::insertRole($params['id'], $params['role_id']);
  119. // 部门
  120. self::insertDept($params['id'], $params['dept_id'] ?? []);
  121. // 岗位
  122. self::insertJobs($params['id'], $params['jobs_id'] ?? []);
  123. Db::commit();
  124. return true;
  125. } catch (\Exception $e) {
  126. Db::rollback();
  127. self::setError($e->getMessage());
  128. return false;
  129. }
  130. }
  131. /**
  132. * @notes 删除管理员
  133. * @param array $params
  134. * @return bool
  135. * @author 段誉
  136. * @date 2021/12/29 10:45
  137. */
  138. public static function delete(array $params): bool
  139. {
  140. Db::startTrans();
  141. try {
  142. $admin = Admin::findOrEmpty($params['id']);
  143. if ($admin->root == YesNoEnum::YES) {
  144. throw new \Exception("超级管理员不允许被删除");
  145. }
  146. Admin::destroy($params['id']);
  147. //设置token过期
  148. $tokenArr = AdminSession::where('admin_id', $params['id'])->select()->toArray();
  149. foreach ($tokenArr as $token) {
  150. self::expireToken($token['token']);
  151. }
  152. (new AdminAuthCache($params['id']))->clearAuthCache();
  153. // 删除旧的关联信息
  154. AdminRole::delByUserId($params['id']);
  155. AdminDept::delByUserId($params['id']);
  156. AdminJobs::delByUserId($params['id']);
  157. Db::commit();
  158. return true;
  159. } catch (\Exception $e) {
  160. Db::rollback();
  161. self::setError($e->getMessage());
  162. return false;
  163. }
  164. }
  165. /**
  166. * @notes 过期token
  167. * @param $token
  168. * @return bool
  169. * @throws \think\db\exception\DataNotFoundException
  170. * @throws \think\db\exception\DbException
  171. * @throws \think\db\exception\ModelNotFoundException
  172. * @author 段誉
  173. * @date 2021/12/29 10:46
  174. */
  175. public static function expireToken($token): bool
  176. {
  177. $adminSession = AdminSession::where('token', '=', $token)
  178. ->with('admin')
  179. ->find();
  180. if (empty($adminSession)) {
  181. return false;
  182. }
  183. $time = time();
  184. $adminSession->expire_time = $time;
  185. $adminSession->update_time = $time;
  186. $adminSession->save();
  187. return (new AdminTokenCache())->deleteAdminInfo($token);
  188. }
  189. /**
  190. * @notes 查看管理员详情
  191. * @param $params
  192. * @return array
  193. * @author 段誉
  194. * @date 2021/12/29 11:07
  195. */
  196. public static function detail($params, $action = 'detail'): array
  197. {
  198. $admin = Admin::field([
  199. 'id', 'account', 'name', 'disable', 'root',
  200. 'multipoint_login', 'avatar',
  201. ])->findOrEmpty($params['id'])->toArray();
  202. if ($action == 'detail') {
  203. return $admin;
  204. }
  205. $result['user'] = $admin;
  206. // 当前管理员角色拥有的菜单
  207. $result['menu'] = MenuLogic::getMenuByAdminId($params['id']);
  208. // 当前管理员橘色拥有的按钮权限
  209. $result['permissions'] = AuthLogic::getBtnAuthByRoleId($admin);
  210. return $result;
  211. }
  212. /**
  213. * @notes 编辑超级管理员
  214. * @param $params
  215. * @return Admin
  216. * @author 段誉
  217. * @date 2022/4/8 17:54
  218. */
  219. public static function editSelf($params)
  220. {
  221. $data = [
  222. 'id' => $params['admin_id'],
  223. 'name' => $params['name'],
  224. 'avatar' => FileService::setFileUrl($params['avatar']),
  225. ];
  226. if (!empty($params['password'])) {
  227. $passwordSalt = Config::get('project.unique_identification');
  228. $data['password'] = create_password($params['password'], $passwordSalt);
  229. }
  230. return Admin::update($data);
  231. }
  232. /**
  233. * @notes 新增角色
  234. * @param $adminId
  235. * @param $roleIds
  236. * @throws \Exception
  237. * @author 段誉
  238. * @date 2022/11/25 14:23
  239. */
  240. public static function insertRole($adminId, $roleIds)
  241. {
  242. if (!empty($roleIds)) {
  243. // 角色
  244. $roleData = [];
  245. foreach ($roleIds as $roleId) {
  246. $roleData[] = [
  247. 'admin_id' => $adminId,
  248. 'role_id' => $roleId,
  249. ];
  250. }
  251. (new AdminRole())->saveAll($roleData);
  252. }
  253. }
  254. /**
  255. * @notes 新增部门
  256. * @param $adminId
  257. * @param $deptIds
  258. * @throws \Exception
  259. * @author 段誉
  260. * @date 2022/11/25 14:22
  261. */
  262. public static function insertDept($adminId, $deptIds)
  263. {
  264. // 部门
  265. if (!empty($deptIds)) {
  266. $deptData = [];
  267. foreach ($deptIds as $deptId) {
  268. $deptData[] = [
  269. 'admin_id' => $adminId,
  270. 'dept_id' => $deptId
  271. ];
  272. }
  273. (new AdminDept())->saveAll($deptData);
  274. }
  275. }
  276. /**
  277. * @notes 新增岗位
  278. * @param $adminId
  279. * @param $jobsIds
  280. * @throws \Exception
  281. * @author 段誉
  282. * @date 2022/11/25 14:22
  283. */
  284. public static function insertJobs($adminId, $jobsIds)
  285. {
  286. // 岗位
  287. if (!empty($jobsIds)) {
  288. $jobsData = [];
  289. foreach ($jobsIds as $jobsId) {
  290. $jobsData[] = [
  291. 'admin_id' => $adminId,
  292. 'jobs_id' => $jobsId
  293. ];
  294. }
  295. (new AdminJobs())->saveAll($jobsData);
  296. }
  297. }
  298. /**
  299. * 获取当前登录管理员岗位数据权限信息
  300. * @param $adminId
  301. * @param $jobsIds
  302. * @return void
  303. * @throws \Exception
  304. */
  305. public static function getDataPermissions($adminId) : array
  306. {
  307. $jobsIds = AdminJobs::where('admin_id', $adminId)->column('jobs_id');
  308. $rules = [];
  309. if (!empty($jobsIds)) {
  310. $list = Jobs::whereIn('id', $jobsIds)->where('status', YesNoEnum::YES)->select()->toArray();
  311. foreach ($list as $item) {
  312. //$item['rules_data']
  313. /*[{"block_key":"1","rule_id":"1","value_lists":[],"rule_value":["self","37"]},
  314. {"block_key":"2","rule_id":"2","value_lists":[],"rule_value":["self","124"]},
  315. {"block_key":"3","rule_id":"4","value_lists":[],"rule_value":["self","4"]},
  316. {"block_key":"4","rule_id":"5","value_lists":[],"rule_value":["2","6","5"]}]*/
  317. $rules_data = array_column($item['rules_data'], 'rule_value', 'rule_id');
  318. foreach ($rules_data as $rule_id => $rule_value) {
  319. if(isset($rules[$rule_id])){
  320. $rules[$rule_id] = array_unique(array_merge($rules[$rule_id],$rule_value));
  321. }else{
  322. $rules[$rule_id] = $rule_value;
  323. }
  324. }
  325. }
  326. $rules = JobsRulesLogic::ruleSelfValue($adminId,$rules);
  327. }
  328. return $rules??[];
  329. }
  330. }