StoreUser.php 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. <?php
  2. namespace app\controller\admin;
  3. use app\extra\basic\Base;
  4. use app\extra\tools\CodeExtend;
  5. use app\middleware\AuthMiddleware;
  6. use app\model\system\SystemUser;
  7. use app\service\system\UserService;
  8. use DI\Attribute\Inject;
  9. use LinFly\Annotation\Attributes\Route\Controller;
  10. use LinFly\Annotation\Attributes\Route\GetMapping;
  11. use LinFly\Annotation\Attributes\Route\Middleware;
  12. use LinFly\Annotation\Attributes\Route\PostMapping;
  13. use support\Request;
  14. use support\Response;
  15. #[Controller("/api/store/user"),Middleware(AuthMiddleware::class)]
  16. class StoreUser extends Base
  17. {
  18. #[Inject]
  19. protected UserService $service;
  20. #[Inject]
  21. protected SystemUser $model;
  22. #[GetMapping('list')]
  23. public function getDataList(Request $request): Response
  24. {
  25. try {
  26. $data = $this->service->setModel()->getList($request->all(),"account");
  27. return successTrans(100010,pageFormat($data),200);
  28. } catch (\Throwable $th) {
  29. return error($th->getMessage());
  30. }
  31. }
  32. /**
  33. * 账户列表
  34. * @param Request $request
  35. * @return Response
  36. */
  37. #[PostMapping("save")]
  38. public function setUserData(Request $request): Response
  39. {
  40. try {
  41. $param = $request->post();
  42. if(!isset($param['id'])) // 新增
  43. {
  44. $param['salt'] = CodeExtend::random(6,3);
  45. $param['password'] = md5($param['password'].$param['salt']);
  46. $param['create_ip'] = $request->getRealIp();
  47. $user = $this->model->where("username",$param['username'])->findOrEmpty();
  48. if (!$user->isEmpty()) return errorTrans(20011);
  49. }
  50. if (isset($param['app_id'])) {
  51. $param['app_id'] = json_encode($param['app_id']);
  52. }
  53. if(isset($param['role_path']) && is_array($param['role_path'])){
  54. $parent = $param['role_path'];
  55. $param['role_path'] = implode(",",$parent);
  56. $param['role_id'] = $parent[count($parent) - 1];
  57. }
  58. $state = $this->model->setAutoData($param);
  59. if (!$state) return errorTrans(100011);
  60. return successTrans(100010);
  61. } catch (\Throwable $throwable) {
  62. return error($throwable->getMessage());
  63. }
  64. }
  65. /**
  66. * 修改密码
  67. * @param Request $request
  68. * @return Response
  69. */
  70. #[PostMapping("passwd")]
  71. public function setUserPasswd(Request $request): Response
  72. {
  73. try {
  74. $param = $this->_valid([
  75. "id.require" => trans(20010),
  76. "password.require" => trans(20010)
  77. ],"post");
  78. if (!is_array($param)) return error($param);
  79. $user = $this->model->where("id",$param['id'])->findOrEmpty();
  80. if ($user->isEmpty()) return errorTrans("empty.error");
  81. $user->password = md5($param['password'].$user['salt']);
  82. $state = $user->save();
  83. if (!$state) return errorTrans(100102);
  84. return successTrans(100010);
  85. } catch (\Throwable $throwable) {
  86. return error($throwable->getMessage());
  87. }
  88. }
  89. }