UserController.php 5.5KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Http\Controllers\Controller;
  4. use App\Http\Requests\User\ChangePasswordRequest;
  5. use App\Http\Requests\User\StoreUserRequest;
  6. use App\Http\Requests\User\UpdateUserRequest;
  7. use App\Models\Role;
  8. use App\Models\User;
  9. use Illuminate\Support\Facades\Hash;
  10. class UserController extends Controller
  11. {
  12. public function __construct()
  13. {
  14. $this->authorizeResource(User::class);
  15. }
  16. /**
  17. * Display a listing of the resource.
  18. *
  19. * @return \Inertia\Response
  20. */
  21. public function index()
  22. {
  23. return inertia("Users/Index", [
  24. "initialFilters" => request()->only("search"),
  25. "users" => User::search(request()->only("search"))
  26. ->latest()
  27. ->paginate(10)
  28. ->withQueryString()
  29. ->through(
  30. fn($user) => [
  31. "id" => $user->id,
  32. "name" => $user->name,
  33. "username" => $user->username,
  34. "role" => $user->role->name,
  35. "role_id" => $user->role_id,
  36. "status" => $user->status,
  37. ]
  38. ),
  39. ]);
  40. }
  41. /**
  42. * Show the form for creating a new resource.
  43. *
  44. * @return \Inertia\Response
  45. */
  46. public function create()
  47. {
  48. return inertia("Users/Create", [
  49. "roles" => Role::whereNotIn("id", [1])
  50. ->get()
  51. ->transform(
  52. fn($role) => [
  53. "label" => $role->name,
  54. "value" => $role->id,
  55. ]
  56. ),
  57. ]);
  58. }
  59. /**
  60. * Store a newly created resource in storage.
  61. *
  62. * @param \Illuminate\Http\Request $request
  63. * @return \Illuminate\Http\Response
  64. */
  65. public function store(StoreUserRequest $request)
  66. {
  67. $validated = $request
  68. ->safe()
  69. ->merge(["password" => bcrypt($request->username)])
  70. ->all();
  71. User::create($validated);
  72. return back()->with("success", __("messages.success.store.user"));
  73. }
  74. /**
  75. * Display the specified resource.
  76. *
  77. * @param User $user
  78. * @return \Inertia\Response
  79. */
  80. public function show(User $user)
  81. {
  82. return inertia("Users/Show", [
  83. "user" => $user,
  84. "roles" => Role::whereNotIn("id", [1])
  85. ->get()
  86. ->transform(
  87. fn($role) => [
  88. "label" => $role->name,
  89. "value" => $role->id,
  90. ]
  91. ),
  92. ]);
  93. }
  94. /**
  95. * Show the form for editing the specified resource.
  96. *
  97. * @param User $user
  98. * @return \Inertia\Response
  99. */
  100. public function edit(User $user)
  101. {
  102. return inertia("Users/Edit", [
  103. "user" => [
  104. "id" => $user->id,
  105. "name" => $user->name,
  106. "username" => $user->username,
  107. "role_id" => $user->role_id,
  108. "status" => $user->getRawOriginal("status"),
  109. ],
  110. "roles" => Role::whereNotIn("id", [1])
  111. ->get()
  112. ->transform(
  113. fn($role) => [
  114. "label" => $role->name,
  115. "value" => $role->id,
  116. ]
  117. ),
  118. ]);
  119. }
  120. /**
  121. * Update the specified resource in storage.
  122. *
  123. * @param \Illuminate\Http\Request $request
  124. * @param User $user
  125. * @return \Illuminate\Http\Response
  126. */
  127. public function update(UpdateUserRequest $request, User $user)
  128. {
  129. $user->update($request->validated());
  130. return back()->with("success", __("messages.success.update.user"));
  131. }
  132. /**
  133. * Remove the specified resource from storage.
  134. *
  135. * @param User $user
  136. * @return \Illuminate\Http\Response
  137. */
  138. public function destroy(User $user)
  139. {
  140. $user->delete();
  141. return to_route("users.index")->with(
  142. "success",
  143. __("messages.success.destroy.user")
  144. );
  145. }
  146. /**
  147. * Block user
  148. *
  149. * @param User $user
  150. * @return \Illuminate\Http\Response
  151. */
  152. public function block(User $user)
  153. {
  154. $user->status = !$user->getRawOriginal("status");
  155. $user->update();
  156. if ($user->getRawOriginal("status")) {
  157. $msg = __("messages.user.active_user");
  158. } else {
  159. $msg = __("messages.user.no_active_user");
  160. }
  161. return back()->with("success", $msg);
  162. }
  163. /**
  164. * Change Password
  165. *
  166. * @param \Illuminate\Http\Request $request
  167. * @return \Illuminate\Http\Response
  168. */
  169. public function changePassword(ChangePasswordRequest $request)
  170. {
  171. if (!Hash::check($request->old_password, $request->user()->password)) {
  172. return back()->with(
  173. "error",
  174. __("messages.error.store.change_password")
  175. );
  176. }
  177. $request
  178. ->user()
  179. ->update(["password" => bcrypt($request->new_password)]);
  180. return back()->with(
  181. "success",
  182. __("messages.success.update.change_password")
  183. );
  184. }
  185. public function resetPassword(User $user)
  186. {
  187. $user->update(["password" => bcrypt($user->username)]);
  188. return back()->with(
  189. "success",
  190. __("messages.success.store.reset_password")
  191. );
  192. }
  193. }