User.php 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146
  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['type'] = 2;
  60. $param['user_id'] = CodeExtend::random(16,1,date("md"));
  61. }
  62. $param['salt'] = strtoupper(CodeExtend::random(10,3));
  63. if (!empty($param['password'])) {
  64. $param['password'] = md5($param['password'].$param['salt']);
  65. }
  66. if (!empty($param['username'])) {
  67. $userName = $this->model->where("username",$param['username'])->findOrEmpty();
  68. if (!$userName->isEmpty()) return errorTrans("error.user-exist");
  69. }
  70. if (!$this->validate->scene($this->scene)->check($request->post())) return error($this->validate->getError());
  71. $state = $this->model->setAutoData($param);
  72. if (!$state) return errorTrans("error.data");
  73. return successTrans("success.data");
  74. } catch (\Throwable $throwable) {
  75. return error($throwable->getMessage());
  76. }
  77. }
  78. /**
  79. * @param Request $request
  80. * @return Response
  81. */
  82. #[Route(path: "batch",methods: "post")]
  83. public function setBatchData(Request $request): Response
  84. {
  85. try {
  86. $param = $this->_valid([
  87. "id.require" => trans("empty.require"),
  88. "value.require" => trans("empty.require"),
  89. "field.require" => trans("empty.require"),
  90. "type.require" => trans("empty.require"),
  91. ],"post");
  92. if (!is_array($param)) return error($param);
  93. if ($param['type'] == "batch") {
  94. $state = $this->model->where("id","in",$param['id'])->save([$param['field'] => $param['value']]);
  95. } else {
  96. $state = $this->model->where("id",$param['id'])->save([$param['field'] => $param['value']]);
  97. }
  98. if (!$state) return errorTrans("error.data");
  99. return successTrans("success.data");
  100. } catch (\Throwable $throwable) {
  101. return error($throwable->getMessage());
  102. }
  103. }
  104. /**
  105. * 删除
  106. * @param Request $request
  107. * @return Response
  108. */
  109. #[Route(path: "del",methods: "post")]
  110. public function delUser(Request $request): Response
  111. {
  112. try {
  113. $param = $this->_valid([
  114. "id.require" => trans("empty.require"),
  115. "type.default" => "one",
  116. ],"post");
  117. if (!is_array($param)) return error($param);
  118. if ($param['type'] == "batch") {
  119. $state = $this->model->where("id","in",$param['id'])->delete();
  120. } else {
  121. $data = $this->model->where("id",$param['id'])->findOrEmpty();
  122. if ($data->isEmpty()) return errorTrans("empty.data");
  123. // 删除其他相关数据
  124. $state = $data->delete();
  125. }
  126. if (!$state) return errorTrans("error.data");
  127. return successTrans("success.data");
  128. } catch (\Throwable $throwable) {
  129. return error($throwable->getMessage());
  130. }
  131. }
  132. }