User.php 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145
  1. <?php
  2. namespace app\controller\admin;
  3. use app\extra\basic\Base;
  4. use app\extra\service\system\UserService;
  5. use app\extra\tools\CodeExtend;
  6. use app\middleware\AuthMiddleware;
  7. use app\model\system\SystemUser;
  8. use app\validate\user\UserValidate;
  9. use DI\Attribute\Inject;
  10. use Hzdad\Codecheck\Codecheck;
  11. use LinFly\Annotation\Route\Controller;
  12. use LinFly\Annotation\Route\Route;
  13. use support\Request;
  14. use support\Response;
  15. use Webman\Annotation\Middleware;
  16. /**
  17. * 用户
  18. */
  19. #[Controller(prefix: "/api/user"),Middleware(AuthMiddleware::class)]
  20. class User extends Base
  21. {
  22. #[Inject]
  23. protected UserService $service;
  24. #[Inject]
  25. protected UserValidate $validate;
  26. #[Inject]
  27. protected SystemUser $model;
  28. protected string $scene = "edit";
  29. /**
  30. * 用户列表
  31. * @param Request $request
  32. * @return Response
  33. */
  34. #[Route(path: "list",methods: "get")]
  35. public function getUserList(Request $request): Response
  36. {
  37. try {
  38. $param = $request->get();
  39. $list = $this->service->getList($param);
  40. return successTrans("success.data",pageFormat($list),200);
  41. } catch (\Throwable $throwable) {
  42. return error($throwable->getMessage());
  43. }
  44. }
  45. /**
  46. * 新增/编辑代理
  47. * @param Request $request
  48. * @return Response
  49. */
  50. #[Route(path: "save",methods: "post")]
  51. public function save(Request $request): Response
  52. {
  53. try {
  54. $param = $request->post();
  55. if (!isset($param['id'])) {
  56. $this->scene = "add";
  57. $code = (new Codecheck)->mobile($param['mobile'])->scene($param['scene'])->code($param['yzm'])->check();
  58. if (!$code) return errorTrans("error.sms-err");
  59. $param['user_id'] = CodeExtend::random(16,1,date("md"));
  60. }
  61. $param['salt'] = strtoupper(CodeExtend::random(10,3));
  62. if (!empty($param['password'])) {
  63. $param['password'] = md5($param['password'].$param['salt']);
  64. }
  65. if (!empty($param['username'])) {
  66. $userName = $this->model->where("username",$param['username'])->findOrEmpty();
  67. if (!$userName->isEmpty()) return errorTrans("error.user-exist");
  68. }
  69. if (!$this->validate->scene($this->scene)->check($request->post())) return error($this->validate->getError());
  70. $state = $this->model->setAutoData($param);
  71. if (!$state) return errorTrans("error.data");
  72. return successTrans("success.data");
  73. } catch (\Throwable $throwable) {
  74. return error($throwable->getMessage());
  75. }
  76. }
  77. /**
  78. * @param Request $request
  79. * @return Response
  80. */
  81. #[Route(path: "batch",methods: "post")]
  82. public function setBatchData(Request $request): Response
  83. {
  84. try {
  85. $param = $this->_valid([
  86. "id.require" => trans("empty.require"),
  87. "value.require" => trans("empty.require"),
  88. "field.require" => trans("empty.require"),
  89. "type.require" => trans("empty.require"),
  90. ],"post");
  91. if (!is_array($param)) return error($param);
  92. if ($param['type'] == "batch") {
  93. $state = $this->model->where("id","in",$param['id'])->save([$param['field'] => $param['value']]);
  94. } else {
  95. $state = $this->model->where("id",$param['id'])->save([$param['field'] => $param['value']]);
  96. }
  97. if (!$state) return errorTrans("error.data");
  98. return successTrans("success.data");
  99. } catch (\Throwable $throwable) {
  100. return error($throwable->getMessage());
  101. }
  102. }
  103. /**
  104. * 删除
  105. * @param Request $request
  106. * @return Response
  107. */
  108. #[Route(path: "del",methods: "post")]
  109. public function delUser(Request $request): Response
  110. {
  111. try {
  112. $param = $this->_valid([
  113. "id.require" => trans("empty.require"),
  114. "type.default" => "one",
  115. ],"post");
  116. if (!is_array($param)) return error($param);
  117. if ($param['type'] == "batch") {
  118. $state = $this->model->where("id","in",$param['id'])->delete();
  119. } else {
  120. $data = $this->model->where("id",$param['id'])->findOrEmpty();
  121. if ($data->isEmpty()) return errorTrans("empty.data");
  122. // 删除其他相关数据
  123. $state = $data->delete();
  124. }
  125. if (!$state) return errorTrans("error.data");
  126. return successTrans("success.data");
  127. } catch (\Throwable $throwable) {
  128. return error($throwable->getMessage());
  129. }
  130. }
  131. }