AdminLogic.php 12 KB

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