User.php 5.1 KB

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