UserController.php 8.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267
  1. <?php
  2. namespace App\Http\Controllers\API;
  3. use App\Http\Controllers\Controller;
  4. use App\Http\Requests\API\User\AdminUpdateRequest;
  5. use App\Http\Requests\API\User\BatchCreateRequest;
  6. use App\Http\Requests\API\User\CreateCompanyUserRequest;
  7. use App\Http\Requests\API\User\CreateRequest;
  8. use App\Http\Requests\API\User\UpdateRequest;
  9. use App\Http\Resources\API\UserInfoResource;
  10. use App\Http\Resources\API\UserSimpleResource;
  11. use App\Models\Department;
  12. use App\Models\Enums\RequirementStatus;
  13. use App\Models\Menu;
  14. use App\Models\Permission;
  15. use App\Models\Role;
  16. use App\Models\Scopes\CompanyScope;
  17. use App\Models\User;
  18. use Illuminate\Contracts\Encryption\DecryptException;
  19. use Illuminate\Http\Request;
  20. use Illuminate\Support\Facades\Auth;
  21. use Illuminate\Support\Facades\Cache;
  22. use Illuminate\Support\Facades\Crypt;
  23. use Illuminate\Support\Facades\DB;
  24. use Illuminate\Support\Facades\Hash;
  25. use function Laravel\Prompts\password;
  26. use function Nette\Utils\isEmpty;
  27. class UserController extends Controller
  28. {
  29. public function details()
  30. {
  31. $user = Auth::user();
  32. $menus = Menu::query()->where("group", \request("group", "web"))
  33. ->get();
  34. // ->filter(fn(Menu $menu) => Auth::user()->can($menu->permission));
  35. $userPerminssion=$user->role->permissions->pluck('name')->toArray();
  36. $flattenedPaths = [];
  37. foreach ($menus as $index=> $menu) {
  38. if(in_array($menu->permission,$userPerminssion)){
  39. $individualPaths = explode(',', $menu->path);
  40. $flattenedPaths = array_merge($flattenedPaths, $individualPaths);
  41. }
  42. }
  43. $userHasMenu=Menu::query()->whereIn('id',$flattenedPaths)->pluck('name')->toArray();
  44. $user->menus = $userHasMenu;
  45. return new UserInfoResource($user);
  46. }
  47. public function assignRole(Request $request, string $id)
  48. {
  49. $user = User::query()->findOrFail($id);
  50. $roleName = $request->get('role_name');
  51. if ($roleName) {
  52. $role = Role::query()->where("guard_name", "api")->where('name', $roleName)->firstOrFail();
  53. $user->role_id = $role->id;
  54. $user->save();
  55. }
  56. $roles = $roleName ? [$roleName] : [];
  57. $user->syncRoles($roles);
  58. return $this->noContent();
  59. }
  60. public function index(Request $request){
  61. $pageSize=$request->get('page_size') ?? 10;
  62. $sort=$request->input('sort','desc');
  63. $users = User::query()->allowed()->with(['department'])->filter($request->all())->orderBy('created_at',$sort)->paginate($pageSize);
  64. if(Auth::user()->super_admin){
  65. $users->transform(function (User $user) {
  66. $user->display_id = $user->id;
  67. return $user;
  68. });
  69. return UserSimpleResource::collection($users);
  70. }
  71. return UserSimpleResource::collection($users);
  72. }
  73. public function publicSearch(Request $request){
  74. $pageSize=$request->get('page_size') ?? 10;
  75. $sort=$request->input('sort','desc');
  76. //这里公共查询如超级管理员在邮件抄送时会看到其他公司用户不合适
  77. $user=User::query()
  78. ->where('company_id',Auth::user()->company_id)
  79. ->filter($request->all())->orderBy('created_at',$sort)->paginate($pageSize);
  80. return UserSimpleResource::collection($user);
  81. }
  82. /**
  83. * add a new User
  84. * @return \Illuminate\Http\Response
  85. */
  86. public function store(CreateRequest $request){
  87. $password = Hash::make($request->password);
  88. $userRequest=$request->all();
  89. $userRequest['password']=$password;
  90. $user=User::create([
  91. ...$userRequest,
  92. 'created_by' => Auth::id(),
  93. ]);
  94. // TODO:发送邮箱给目标用户
  95. $roleId = $request->get('role_id');
  96. $role = Role::query()->findOrFail($roleId);
  97. $user->syncRoles($role);
  98. return $this->created();
  99. }
  100. /**
  101. * batchCreate User,为ditto时参考上一条
  102. * @return \Illuminate\Http\Response
  103. */
  104. public function batchStore(BatchCreateRequest $request){
  105. $userData = $request->users;
  106. DB::transaction(function () use ($userData) {
  107. foreach ($userData as $k => $data) {
  108. $user = new User();
  109. if ($k != 0) {
  110. // $userData[$k]["department_id"] = $userData[$k]["department_id"] == 'ditto' ? $userData[$k - 1]["department_id"] : $userData[$k]["department_id"];
  111. $userData[$k]["role_id"] = $userData[$k]["role_id"] == 'ditto' ? $userData[$k - 1]["role_id"] : $userData[$k]["role_id"];
  112. }
  113. $userData[$k]['password'] = Hash::make($userData[$k]['password']);
  114. $role = Role::query()->findOrFail($userData[$k]["role_id"]);
  115. $user->syncRoles($role);
  116. $user->fill([
  117. ...$userData[$k],
  118. 'created_by' => Auth::id(),
  119. ]);
  120. // TODO:发送邮箱给目标用户
  121. $user->save();
  122. }
  123. });
  124. // TODO:发送邮箱给目标用户
  125. return $this->created();
  126. }
  127. /**
  128. * enable or ban users 启用或禁用用户
  129. * @param Request $request
  130. * @return \Illuminate\Http\Response
  131. */
  132. public function status(Request $request,string $status){
  133. User::query()->allowed()->whereIn('id', $request->user_id)->update(['status' => $status]);
  134. return $this->created();
  135. }
  136. public function destroy(string $id)
  137. {
  138. $user = User::query()->allowed()->findOrFail($id);
  139. $user->delete();
  140. return $this->noContent();
  141. }
  142. public function show(string $id)
  143. {
  144. $user = User::query()->allowed()->findOrFail($id);
  145. return new UserInfoResource($user);
  146. }
  147. public function update(UpdateRequest $request,string $id)
  148. {
  149. $user = User::allowed()->findOrFail($id);
  150. $newPassword=null;
  151. // 如果用户是超级管理员或具有相应权限
  152. if (Auth::user()->super_admin || Auth::user()->can('user.assign-role')) {
  153. $user->fill([
  154. ...$request->except(['username']),
  155. 'password' => $request->password ? Hash::make($request->password) : $user->password,
  156. ]);
  157. $roleId = $request->get('role_id');
  158. if ($roleId) {
  159. $role = Role::findOrFail($roleId);
  160. $user->syncRoles([$role]);
  161. }
  162. } else {
  163. // 如果用户不是超级管理员且没有编辑角色的权限
  164. $user->fill([
  165. ...$request->except(['role_id', 'department_id', 'company_id']),
  166. 'password' => $request->password ? Hash::make($request->password) : $user->password,
  167. ]);
  168. }
  169. $user->save();
  170. return $this->noContent();
  171. }
  172. // public function byDepartment(Request $request){
  173. // $departmentIds = $request->get("department", []);
  174. //
  175. // $emptyResponse = $this->success([
  176. // 'data' => [],
  177. // ]);
  178. //
  179. // if (! $departmentIds) {
  180. // return $emptyResponse;
  181. // }
  182. //
  183. // $users = User::query()->filter($request->all())->where('company_id',Auth::user()->company_id)->whereIn("department_id",$departmentIds)->get();
  184. //
  185. // return UserSimpleResource::collection($users);
  186. //
  187. // }
  188. // /**
  189. // * @param CreateRequest $request
  190. // * @return \Illuminate\Http\Response
  191. // * 修改个人信息
  192. // */
  193. // public function updateInfo(UpdateRequest $request)
  194. // {
  195. // $user = User::findOrFail(Auth::user()->id);
  196. // $user->fill([
  197. // ...$request->except(['username','role_id','department_id','company_id'])
  198. // ]);
  199. // $user->save();
  200. // return $this->noContent();
  201. // }
  202. //
  203. // /**
  204. // * @param AdminUpdateRequest $request 修改主体
  205. // * @param string $id 用户id
  206. // * @return \Illuminate\Http\Response
  207. // * 超管修改用户的信息
  208. // */
  209. // public function updateUserInfo(AdminUpdateRequest $request, string $id)
  210. // {
  211. // $user = User::findOrFail($id);
  212. // $user->fill([
  213. // ...$request->all()
  214. // ]);
  215. // $user->save();
  216. // return $this->noContent();
  217. //
  218. // }
  219. // /**
  220. // * 注册用户
  221. // * @return \Illuminate\Http\Response
  222. // */
  223. // public function registerCompanyUser(CreateCompanyUserRequest $request){
  224. // $password = Hash::make($request->password);
  225. // $userRequest=$request->all();
  226. // $userRequest['password']=$password;
  227. // User::create([
  228. // ...$userRequest,
  229. // 'created_by' => Auth::id(),
  230. // ]);
  231. // return $this->created();
  232. // }
  233. }