UserController.php 5.2KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197
  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. 'initialSearch' => request('search'),
  25. 'users' => User::filter(request()->only('search'))
  26. ->latest()
  27. ->paginate(10)
  28. ->withQueryString()
  29. ->through(fn($user) => [
  30. 'id' => $user->id,
  31. 'name' => $user->name,
  32. 'username' => $user->username,
  33. 'role' => $user->role->name,
  34. 'role_id' => $user->role_id,
  35. 'status' => $user->status
  36. ])
  37. ]);
  38. }
  39. /**
  40. * Show the form for creating a new resource.
  41. *
  42. * @return \Inertia\Response
  43. */
  44. public function create()
  45. {
  46. return inertia('Users/Create', [
  47. 'roles' => Role::whereNotIn('id', [1])
  48. ->get()
  49. ->transform(fn($role) => [
  50. 'label' => $role->name,
  51. 'value' => $role->id
  52. ])
  53. ]);
  54. }
  55. /**
  56. * Store a newly created resource in storage.
  57. *
  58. * @param \Illuminate\Http\Request $request
  59. * @return \Illuminate\Http\Response
  60. */
  61. public function store(StoreUserRequest $request)
  62. {
  63. User::create($request->validated());
  64. return back()->with('success', __('messages.success.store.user'));
  65. }
  66. /**
  67. * Display the specified resource.
  68. *
  69. * @param User $user
  70. * @return \Inertia\Response
  71. */
  72. public function show(User $user)
  73. {
  74. return inertia('Users/Show', [
  75. 'user' => [
  76. 'id' => $user->id,
  77. 'name' => $user->name,
  78. 'username' => $user->username,
  79. 'role_id' => $user->role_id
  80. ],
  81. 'roles' => Role::whereNotIn('id', [1])
  82. ->get()
  83. ->transform(fn($role) => [
  84. 'label' => $role->name,
  85. 'value' => $role->id
  86. ])
  87. ]);
  88. }
  89. /**
  90. * Show the form for editing the specified resource.
  91. *
  92. * @param User $user
  93. * @return \Inertia\Response
  94. */
  95. public function edit(User $user)
  96. {
  97. return inertia('Users/Edit', [
  98. 'user' => [
  99. 'id' => $user->id,
  100. 'name' => $user->name,
  101. 'username' => $user->username,
  102. 'role_id' => $user->role_id
  103. ],
  104. 'roles' => Role::whereNotIn('id', [1])
  105. ->get()
  106. ->transform(fn($role) => [
  107. 'label' => $role->name,
  108. 'value' => $role->id
  109. ])
  110. ]);
  111. }
  112. /**
  113. * Update the specified resource in storage.
  114. *
  115. * @param \Illuminate\Http\Request $request
  116. * @param User $user
  117. * @return \Illuminate\Http\Response
  118. */
  119. public function update(UpdateUserRequest $request, User $user)
  120. {
  121. $user->update([
  122. 'name' => $request->name,
  123. 'username' => $request->username,
  124. 'role_id' => $request->role_id
  125. ]);
  126. return back()->with('success', __('messages.success.update.user'));
  127. }
  128. /**
  129. * Remove the specified resource from storage.
  130. *
  131. * @param User $user
  132. * @return \Illuminate\Http\Response
  133. */
  134. public function destroy(User $user)
  135. {
  136. $user->delete();
  137. return to_route('users.index')->with('success', __('messages.success.destroy.user'));
  138. }
  139. /**
  140. * Block user
  141. *
  142. * @param User $user
  143. * @return \Illuminate\Http\Response
  144. */
  145. public function block(User $user)
  146. {
  147. $user->status = !$user->getRawOriginal('status');
  148. $user->update();
  149. if ($user->getRawOriginal('status')) {
  150. $msg = __('messages.user.active_user');
  151. } else {
  152. $msg = __('messages.user.no_active_user');
  153. }
  154. return back()->with('success', $msg);
  155. }
  156. /**
  157. * Change Password
  158. *
  159. * @param \Illuminate\Http\Request $request
  160. * @return \Illuminate\Http\Response
  161. */
  162. public function changePassword(ChangePasswordRequest $request)
  163. {
  164. if (!Hash::check($request->old_password, $request->user()->password)) {
  165. return back()->with('error', __('messages.error.store.change_password'));
  166. }
  167. $request->user()->update(['password' => bcrypt($request->new_password)]);
  168. return back()->with('success', __('messages.success.update.change_password'));
  169. }
  170. public function resetPassword(User $user)
  171. {
  172. $user->update(['password' => bcrypt('12345678')]);
  173. return back()->with('success', __('passwords.reset'));
  174. }
  175. }