1
0

AdminLogic.php 11 KB

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