UserController.php 8.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268
  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. $company_id = $request->input('company_id',Auth::user()->company_id);
  78. $user=User::query()
  79. ->where('company_id',$company_id)
  80. ->filter($request->all())->orderBy('created_at',$sort)->paginate($pageSize);
  81. return UserSimpleResource::collection($user);
  82. }
  83. /**
  84. * add a new User
  85. * @return \Illuminate\Http\Response
  86. */
  87. public function store(CreateRequest $request){
  88. $password = Hash::make($request->password);
  89. $userRequest=$request->all();
  90. $userRequest['password']=$password;
  91. $user=User::create([
  92. ...$userRequest,
  93. 'created_by' => Auth::id(),
  94. ]);
  95. // TODO:发送邮箱给目标用户
  96. $roleId = $request->get('role_id');
  97. $role = Role::query()->findOrFail($roleId);
  98. $user->syncRoles($role);
  99. return $this->created();
  100. }
  101. /**
  102. * batchCreate User,为ditto时参考上一条
  103. * @return \Illuminate\Http\Response
  104. */
  105. public function batchStore(BatchCreateRequest $request){
  106. $userData = $request->users;
  107. DB::transaction(function () use ($userData) {
  108. foreach ($userData as $k => $data) {
  109. $user = new User();
  110. if ($k != 0) {
  111. // $userData[$k]["department_id"] = $userData[$k]["department_id"] == 'ditto' ? $userData[$k - 1]["department_id"] : $userData[$k]["department_id"];
  112. $userData[$k]["role_id"] = $userData[$k]["role_id"] == 'ditto' ? $userData[$k - 1]["role_id"] : $userData[$k]["role_id"];
  113. }
  114. $userData[$k]['password'] = Hash::make($userData[$k]['password']);
  115. $role = Role::query()->findOrFail($userData[$k]["role_id"]);
  116. $user->syncRoles($role);
  117. $user->fill([
  118. ...$userData[$k],
  119. 'created_by' => Auth::id(),
  120. ]);
  121. // TODO:发送邮箱给目标用户
  122. $user->save();
  123. }
  124. });
  125. // TODO:发送邮箱给目标用户
  126. return $this->created();
  127. }
  128. /**
  129. * enable or ban users 启用或禁用用户
  130. * @param Request $request
  131. * @return \Illuminate\Http\Response
  132. */
  133. public function status(Request $request,string $status){
  134. User::query()->allowed()->whereIn('id', $request->user_id)->update(['status' => $status]);
  135. return $this->created();
  136. }
  137. public function destroy(string $id)
  138. {
  139. $user = User::query()->allowed()->findOrFail($id);
  140. $user->delete();
  141. return $this->noContent();
  142. }
  143. public function show(string $id)
  144. {
  145. $user = User::query()->allowed()->findOrFail($id);
  146. return new UserInfoResource($user);
  147. }
  148. public function update(UpdateRequest $request,string $id)
  149. {
  150. $user = User::allowed()->findOrFail($id);
  151. $newPassword=null;
  152. // 如果用户是超级管理员或具有相应权限
  153. if (Auth::user()->super_admin || Auth::user()->can('user.assign-role')) {
  154. $user->fill([
  155. ...$request->except(['username']),
  156. 'password' => $request->password ? Hash::make($request->password) : $user->password,
  157. ]);
  158. $roleId = $request->get('role_id');
  159. if ($roleId) {
  160. $role = Role::findOrFail($roleId);
  161. $user->syncRoles([$role]);
  162. }
  163. } else {
  164. // 如果用户不是超级管理员且没有编辑角色的权限
  165. $user->fill([
  166. ...$request->except(['role_id', 'department_id', 'company_id']),
  167. 'password' => $request->password ? Hash::make($request->password) : $user->password,
  168. ]);
  169. }
  170. $user->save();
  171. return $this->noContent();
  172. }
  173. // public function byDepartment(Request $request){
  174. // $departmentIds = $request->get("department", []);
  175. //
  176. // $emptyResponse = $this->success([
  177. // 'data' => [],
  178. // ]);
  179. //
  180. // if (! $departmentIds) {
  181. // return $emptyResponse;
  182. // }
  183. //
  184. // $users = User::query()->filter($request->all())->where('company_id',Auth::user()->company_id)->whereIn("department_id",$departmentIds)->get();
  185. //
  186. // return UserSimpleResource::collection($users);
  187. //
  188. // }
  189. // /**
  190. // * @param CreateRequest $request
  191. // * @return \Illuminate\Http\Response
  192. // * 修改个人信息
  193. // */
  194. // public function updateInfo(UpdateRequest $request)
  195. // {
  196. // $user = User::findOrFail(Auth::user()->id);
  197. // $user->fill([
  198. // ...$request->except(['username','role_id','department_id','company_id'])
  199. // ]);
  200. // $user->save();
  201. // return $this->noContent();
  202. // }
  203. //
  204. // /**
  205. // * @param AdminUpdateRequest $request 修改主体
  206. // * @param string $id 用户id
  207. // * @return \Illuminate\Http\Response
  208. // * 超管修改用户的信息
  209. // */
  210. // public function updateUserInfo(AdminUpdateRequest $request, string $id)
  211. // {
  212. // $user = User::findOrFail($id);
  213. // $user->fill([
  214. // ...$request->all()
  215. // ]);
  216. // $user->save();
  217. // return $this->noContent();
  218. //
  219. // }
  220. // /**
  221. // * 注册用户
  222. // * @return \Illuminate\Http\Response
  223. // */
  224. // public function registerCompanyUser(CreateCompanyUserRequest $request){
  225. // $password = Hash::make($request->password);
  226. // $userRequest=$request->all();
  227. // $userRequest['password']=$password;
  228. // User::create([
  229. // ...$userRequest,
  230. // 'created_by' => Auth::id(),
  231. // ]);
  232. // return $this->created();
  233. // }
  234. }