Staff.php 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165
  1. <?php
  2. namespace app\controller\merchant;
  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\saas\UserValidate;
  9. use DI\Attribute\Inject;
  10. use LinFly\Annotation\Route\Controller;
  11. use LinFly\Annotation\Route\Middleware;
  12. use LinFly\Annotation\Route\Route;
  13. use support\Request;
  14. use support\Response;
  15. #[Controller(prefix: "/api/mer/staff"),Middleware(AuthMiddleware::class)]
  16. class Staff extends Base
  17. {
  18. #[Inject]
  19. protected SystemUser $model;
  20. #[Inject]
  21. protected UserService $service;
  22. #[Inject]
  23. protected UserValidate $validate;
  24. #[Route(path: "list",methods: "get")]
  25. public function getPrintList(Request $request): Response
  26. {
  27. try {
  28. $param = $request->get();
  29. $param['agent'] = $request->user['agent_id'];
  30. $list = $this->service->getList($param);
  31. return successTrans("success.data",pageFormat($list),200);
  32. } catch (\Throwable $throwable) {
  33. return error($throwable->getMessage());
  34. }
  35. }
  36. /**
  37. * 修改密码
  38. * @param Request $request
  39. * @return Response
  40. */
  41. #[Route(path: "passwd",methods: "post")]
  42. public function setUserPasswd(Request $request): Response
  43. {
  44. try {
  45. $param = $this->_valid([
  46. "id.require" => trans(20010),
  47. "password.require" => trans(20010)
  48. ],"post");
  49. if (!is_array($param)) return error($param);
  50. $user = $this->model->where("id",$param['id'])->findOrEmpty();
  51. if ($user->isEmpty()) return errorTrans("empty.error");
  52. $user->password = md5($param['password'].$user['salt']);
  53. $state = $user->save();
  54. if (!$state) return errorTrans("error.data");
  55. return successTrans("success.data");
  56. } catch (\Throwable $throwable) {
  57. return error($throwable->getMessage());
  58. }
  59. }
  60. /**
  61. * 新增/编辑用户
  62. * @param Request $request
  63. * @return Response
  64. */
  65. #[Route(path: "save",methods: "post")]
  66. public function save(Request $request): Response
  67. {
  68. try {
  69. $param = $request->post();
  70. $param['agent_id'] = $request->user['agent_id'];
  71. $param['type'] = 2;
  72. $param['salt'] = strtoupper(CodeExtend::random(10,3));
  73. $param['password'] = md5($param['password'].$param['salt']);
  74. $param['create_ip'] = request()->getRealIp();
  75. if (!$this->validate->check($param)) return error($this->validate->getError());
  76. $user = $this->model->where("username",$param['username'])->findOrEmpty();
  77. if (!$user->isEmpty()) return errorTrans("error.user-exist");
  78. $state = $this->model->setAutoData($param);
  79. if (!$state) return errorTrans("error.data");
  80. return successTrans("success.data");
  81. } catch (\Throwable $throwable) {
  82. echo $throwable->getMessage()."\n";
  83. echo $throwable->getFile()."\n";
  84. echo $throwable->getLine()."\n";
  85. return error($throwable->getMessage());
  86. }
  87. }
  88. /**
  89. * 删除
  90. * @param Request $request
  91. * @return Response
  92. */
  93. #[Route(path: "del",methods: "post")]
  94. public function delUser(Request $request): Response
  95. {
  96. try {
  97. $param = $this->_valid([
  98. "id.require" => trans("empty.require"),
  99. "type.default" => "one",
  100. ],"post");
  101. if (!is_array($param)) return error($param);
  102. if ($param['type'] == "batch") {
  103. $state = $this->model->where("id","in",$param['id'])->delete();
  104. } else {
  105. $data = $this->model->where("id",$param['id'])->findOrEmpty();
  106. if ($data->isEmpty()) return errorTrans("empty.data");
  107. if ($data['agent_id'] <> $request->user['agent_id']) return errorTrans("empty.data");
  108. // 删除其他相关数据
  109. $state = $data->delete();
  110. }
  111. if (!$state) return errorTrans("error.data");
  112. return successTrans("success.data");
  113. } catch (\Throwable $throwable) {
  114. return error($throwable->getMessage());
  115. }
  116. }
  117. /**
  118. * @param Request $request
  119. * @return Response
  120. */
  121. #[Route(path: "batch",methods: "post")]
  122. public function setBatchData(Request $request): Response
  123. {
  124. try {
  125. $param = $this->_valid([
  126. "id.require" => trans("empty.require"),
  127. "value.require" => trans("empty.require"),
  128. "field.require" => trans("empty.require"),
  129. "type.require" => trans("empty.require"),
  130. ],"post");
  131. if (!is_array($param)) return error($param);
  132. if ($param['type'] == "batch") {
  133. $state = $this->model->where("id","in",$param['id'])->save([$param['field'] => $param['value']]);
  134. } else {
  135. $state = $this->model->where("id",$param['id'])->save([$param['field'] => $param['value']]);
  136. }
  137. if (!$state) return errorTrans("error.data");
  138. return successTrans("success.data");
  139. } catch (\Throwable $throwable) {
  140. return error($throwable->getMessage());
  141. }
  142. }
  143. }