AdminUser.php 9.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241
  1. <?php
  2. namespace App\Http\Controllers\Manager;
  3. use App\Http\Requests\Manager\AdminUser as Request;
  4. use App\Models\Manager\AdminUser as Model;
  5. use App\Models\Manager\AuthGroupAccess;
  6. use App\Models\Manager\AuthGroup;
  7. /**
  8. * 系统用户
  9. * @author 唐远望
  10. * @version 1.0
  11. * @date 2025-12-02
  12. *
  13. */
  14. class AdminUser extends Manager
  15. {
  16. /**
  17. * 列表页
  18. *
  19. * */
  20. public function get_list(Model $Model, AuthGroupAccess $AuthGroupAccess)
  21. {
  22. // 接收参数
  23. $phone = request('phone', '');
  24. $username = request('username', '');
  25. $status = request('status');
  26. $limit = request('limit', config('page_num', 10));
  27. // 查询数据
  28. $map = [];
  29. // 组合条件
  30. if ($phone) $map[] = ['phone', '=', $phone];
  31. if ($username) $map[] = ['username', '=', $username];
  32. if (!is_null($status)) $map[] = ['status', '=', $status];
  33. // 查询系统用户
  34. $Paginator = $Model->query()->where($map)->orderByDesc('uid')->paginate($limit, ['uid', 'username', 'phone', 'status', 'insert_time', 'update_time']);
  35. // 循环处理
  36. foreach ($Paginator as $key => $value) {
  37. // 切成字符串
  38. $value['group'] = $AuthGroupAccess->getGroupByUid($value['uid']);
  39. // 重组
  40. $Paginator[$key] = $value;
  41. }
  42. // 获取数据
  43. $data['total'] = $Paginator->total();
  44. $data['current_page'] = $Paginator->currentPage();
  45. $data['per_page'] = (int)$Paginator->perPage();
  46. $data['last_page'] = $Paginator->lastPage();
  47. $data['data'] = $Paginator->items();
  48. // 告知结果
  49. return json_send(['code' => 'success', 'msg' => '获取成功', 'data' => $data]);
  50. }
  51. /**
  52. * 添加
  53. * @author 唐远望
  54. * @version 1.0
  55. * @date 2025-12-02
  56. * */
  57. public function add(Request $request, Model $Model, AuthGroupAccess $AuthGroupAccess, AuthGroup $AuthGroup)
  58. {
  59. if (request()->isMethod('post')) {
  60. // 验证参数
  61. $request->scene('add')->validate();
  62. // 接收数据
  63. $data['username'] = request('username', '');
  64. $data['phone'] = request('phone', '');
  65. $data['password'] = request('password', '');
  66. $data['password'] = md5($data['password']);
  67. $groups = (array) request('groups', []);
  68. // 写入数据表
  69. $uid = $Model->add($data);
  70. // 如果操作失败
  71. if (!$uid) return json_send(['code' => 'error', 'msg' => '新增失败']);
  72. // 权限组
  73. $access = [];
  74. // 循环数据
  75. foreach ($groups as $group_id) {
  76. // 追加数据
  77. $access[] = ['group_id' => $group_id, 'user_uid' => $uid];
  78. }
  79. // 写入用户权限组
  80. $result = $AuthGroupAccess->query()->insert($access);
  81. // 如果操作失败
  82. if (!$result) {
  83. // 告知错误
  84. return json_send(['code' => 'error', 'msg' => '权限分配失败']);
  85. }
  86. }
  87. // 查询用户组
  88. $group = $AuthGroup->query()->where(['status' => 0])->select(['id', 'name'])->get()->toArray();
  89. // 错误告知
  90. if (!$group) json_send(['code' => 'error', 'msg' => '请先添加用户组']);
  91. // 告知结果
  92. return json_send(['code' => 'success', 'msg' => '新增成功', 'data' => ['group' => $group]]);
  93. }
  94. /**
  95. * 查看
  96. * @author 唐远望
  97. * @version 1.0
  98. * @date 2025-12-02
  99. * */
  100. public function get_detail(Request $request, Model $Model)
  101. {
  102. // 验证参数
  103. $request->scene('get_detail')->validate();
  104. // 接收参数
  105. $id = request('uid', 0);
  106. // 查询数据
  107. $oldData = $Model->getOne($id);
  108. // 未查询到对应的数据
  109. if (!$oldData) return json_send(['code' => 'error', 'msg' => '未查询到对应的数据']);
  110. // 隐私规范,删除密码
  111. unset($oldData['password']);
  112. // 结果
  113. return json_send(['code' => 'success', 'msg' => '获取成功', 'data' => $oldData]);
  114. }
  115. /**
  116. * 编辑
  117. * @author 唐远望
  118. * @version 1.0
  119. * @date 2025-12-02
  120. * */
  121. public function edit(Request $request, Model $Model, AuthGroupAccess $AuthGroupAccess, AuthGroup $AuthGroup)
  122. {
  123. // 接收参数
  124. $id = request('uid', 0);
  125. // 如果账号是超管
  126. if (is_super($id, 'manager')) {
  127. // 当前登录的账号不是超管
  128. if (!is_super(request('access_token.uid', 0), 'manager')) return json_send(['code' => 'error', 'msg' => '您没有权限修改该超管账号的信息']);
  129. }
  130. // 查询数据
  131. $oldData = $Model->getOne($id);
  132. // 未查询到对应的数据
  133. if (!$oldData) return json_send(['code' => 'error', 'msg' => '未查询到对应的数据']);
  134. if (request()->isMethod('post')) {
  135. // 验证参数
  136. $request->scene('edit')->validate();
  137. // 接收数据
  138. $data['username'] = request('username', '');
  139. $data['phone'] = request('phone', '');
  140. $password = request('password', '');
  141. if ($password) $data['password'] = md5($password);
  142. $groups = (array) request('groups', []);
  143. // 写入数据表
  144. $uid = $Model->edit($id, $data);
  145. // 如果操作失败
  146. if (!$uid) return json_send(['code' => 'error', 'msg' => '编辑失败']);
  147. // 清空权限组
  148. $AuthGroupAccess->query()->where([['admin_uid', '=', $id]])->delete();
  149. // 权限组
  150. $access = [];
  151. // 循环数据
  152. foreach ($groups as $group_id) {
  153. // 追加数据
  154. $access[] = ['group_id' => $group_id, 'admin_uid' => $id];
  155. }
  156. // 写入用户权限组
  157. $result = $AuthGroupAccess->query()->insert($access);
  158. // 如果操作失败
  159. if (!$result) {
  160. // 告知错误
  161. return json_send(['code' => 'error', 'msg' => '权限分配失败']);
  162. }
  163. }
  164. // 查询用户的用户组
  165. $oldData['group'] = $AuthGroupAccess->query()->where([['group_id', '=', $id]])->pluck('group_id')->toArray();
  166. // 查询用户组
  167. $group = $AuthGroup->query()->where(['status' => 0])->select(['id', 'name'])->get()->toArray();
  168. // 错误告知
  169. if (!$group) json_send(['code' => 'error', 'msg' => '请先添加用户组']);
  170. // 告知结果
  171. return json_send(['code' => 'success', 'msg' => '编辑成功', 'data' => ['group' => $group, 'oldData' => $oldData]]);
  172. }
  173. /**
  174. * 修改状态
  175. * @author 唐远望
  176. * @version 1.0
  177. * @date 2025-12-02
  178. * */
  179. public function set_status(Request $request, Model $Model)
  180. {
  181. // 验证参数
  182. $request->scene('set_status')->validate();
  183. // 设置状态
  184. $id = request('uid', 0);
  185. $status = request('status', 0);
  186. // 如果账号是超管
  187. if (is_super($id, 'manager')) {
  188. // 当前登录的账号不是超管
  189. if (!is_super(request('access_token.uid', 0), 'manager')) return json_send(['code' => 'error', 'msg' => '您没有权限修改该超管账号的状态']);
  190. }
  191. // 查询用户
  192. $oldData = $Model->getOne($id);
  193. // 如果用户不存在
  194. if (!$oldData) return json_send(['code' => 'error', 'msg' => '用户不存在']);
  195. // 执行修改
  196. $result = $Model->edit($id, ['status' => $status]);
  197. // 提示新增失败
  198. if (!$result) return json_send(['code' => 'error', 'msg' => '设置失败']);
  199. // 告知结果
  200. return json_send(['code' => 'success', 'msg' => '设置成功', 'data' => ['uid' => $id]]);
  201. }
  202. /**
  203. * 修改密码
  204. * @author 唐远望
  205. * @version 1.0
  206. * @date 2025-12-02
  207. */
  208. public function alter_password(Request $request, Model $Model)
  209. {
  210. // 验证参数
  211. $request->scene('alter_password')->validate();
  212. // 获取参数
  213. $uid = request('access_token.uid', 0);
  214. $oldpass = request('oldpass', '');
  215. $password = request('password', '');
  216. // 查询用户
  217. $oldData = $Model->getOne($uid);
  218. // 如果用户不存在
  219. if (!$oldData) return json_send(['code' => 'error', 'msg' => '用户不存在']);
  220. // 比对密码
  221. if (md5($oldpass) != $oldData['password']) return json_send(['code' => 'error', 'msg' => '原密码有误,请核对密码']);
  222. // 执行修改
  223. $result = $Model->edit($uid, ['password' => md5($password)]);
  224. // 提示新增失败
  225. if (!$result) return json_send(['code' => 'error', 'msg' => '修改失败']);
  226. // 退出登录
  227. $Model->LoginOut($uid, 'manager');
  228. // 告知结果
  229. return json_send(['code' => 'success', 'msg' => '修改成功', 'data' => ['uid' => $uid]]);
  230. }
  231. }