| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289 |
- <?php
- namespace App\Http\Controllers;
- use App\Http\Requests\User\DeleteUser;
- use App\Http\Requests\User\StoreProfile;
- use App\Http\Requests\User\StoreUser;
- use App\Models\Order;
- use App\Models\Reclamation;
- use App\Models\ReclamationStatus;
- use App\Models\User;
- use App\Models\UserNotificationSetting;
- use Illuminate\Http\Request;
- use Illuminate\Support\Facades\Auth;
- use Illuminate\Support\Facades\Hash;
- class UserController extends Controller
- {
- protected array $data = [
- 'active' => 'users',
- 'title' => 'Пользователи',
- 'id' => 'users',
- 'header' => [
- 'id' => 'ID',
- 'email' => 'Логин/email',
- 'name' => 'ФИО',
- 'phone' => 'Телефон',
- 'role' => 'Роль',
- 'created_at' => 'Дата создания',
- 'deleted_at' => 'Дата Удаления',
- ],
- 'searchFields' => [
- 'name',
- 'phone',
- 'email',
- ],
- 'ranges' => [],
- 'filters' => [],
- ];
- /**
- * Display a listing of the resource.
- */
- public function index(Request $request)
- {
- session(['gp_users' => $request->query()]);
- $model = new User;
- $this->createFilters($model, 'role');
- $this->createDateFilters($model, 'created_at');
- $q = $model::query();
- $this->acceptFilters($q, $request);
- $this->acceptSearch($q, $request);
- $this->setSortAndOrderBy($model, $request);
- // $q->withTrashed();
- $this->applyStableSorting($q);
- $this->data['users'] = $q->paginate($this->data['per_page'])->withQueryString();
- return view('users.index', $this->data);
- }
- /**
- * Show the form for creating a new resource.
- */
- public function create()
- {
- $this->data['user'] = null;
- $this->prepareNotificationSettingsData(null);
- return view('users.edit', $this->data);
- }
- /**
- * Store a newly or update existing created resource in storage.
- */
- public function store(StoreUser $request)
- {
- $validated = $request->validated();
- $settingsData = $this->extractNotificationSettings($request);
- unset($validated['notification_settings']);
- if(!empty($validated['password'])) {
- $validated['password'] = Hash::make($validated['password']);
- } else {
- unset($validated['password']);
- }
- $user = null;
- if(isset($validated['id'])) {
- User::query()
- ->where('id', $validated['id'])
- ->update($validated);
- $user = User::query()->find($validated['id']);
- } else {
- $user = User::query()->create($validated);
- }
- if ($user) {
- UserNotificationSetting::query()->updateOrCreate(
- ['user_id' => $user->id],
- $settingsData,
- );
- }
- return redirect()->route('user.index')->with(['success' => 'Пользователь ' . $validated['name'] . ' сохранён!']);
- }
- /**
- * Display the specified resource.
- */
- public function show(int $userId)
- {
- $this->data['user'] = User::query()
- ->where('id', $userId)
- ->withTrashed()
- ->first();
- $this->prepareNotificationSettingsData($this->data['user']);
- return view('users.edit', $this->data);
- }
- /**
- * Remove the specified resource from storage.
- */
- public function destroy(User $user, DeleteUser $request)
- {
- if($user->is($request->user())) {
- return redirect()->route('user.index')->with(['danger' => 'Нельзя удалить самого себя!']);
- } else {
- $user->delete();
- return redirect()->route('user.index')->with(['success' => 'Пользователь ' . $user->name . ' удалён!']);
- }
- }
- public function profile(Request $request)
- {
- $this->data['current_menu'] = 'profile';
- $this->data['user'] = $request->user();
- return view('users.profile', $this->data);
- }
- public function storeProfile(StoreProfile $request)
- {
- $data = $request->validated();
- unset($data['current_password'], $data['password']);
- if(
- isset($request->current_password)
- && isset($request->password)
- && (Hash::check($request->current_password, $request->user()->password))) {
- $data['password'] = Hash::make($request->password);
- }
- User::query()->where('id', '=', $request->user()->id)->update($data);
- return redirect()->route('user.profile')->with(['success' => 'Профиль обновлён!']);
- }
- public function deleteProfile(Request $request)
- {
- User::query()->where('id', '=', $request->user()->id)->delete();
- Auth::logout();
- return redirect()->route('login')->with(['success' => 'Профиль удалён!']);
- }
- public function undelete(int $userId)
- {
- User::query()->where('id', '=', $userId)->restore();
- return redirect()->route('user.show', $userId)->with(['success' => 'Пользователь восстановлен!']);
- }
- public function impersonate(Request $request, User $user)
- {
- $currentUser = $request->user();
- if ($currentUser->id === $user->id) {
- return redirect()->back()->with(['danger' => 'Нельзя войти от имени самого себя!']);
- }
- if ($user->trashed()) {
- return redirect()->back()->with(['danger' => 'Нельзя войти от имени удалённого пользователя!']);
- }
- if (session()->has('impersonator_id')) {
- return redirect()->back()->with(['danger' => 'Вы уже вошли от имени другого пользователя.']);
- }
- $impersonatorId = $currentUser->id;
- Auth::login($user);
- $request->session()->put('impersonator_id', $impersonatorId);
- $request->session()->regenerate();
- return redirect()->route('home')->with(['success' => 'Вы вошли от имени пользователя ' . $user->name . '.']);
- }
- public function leaveImpersonation(Request $request)
- {
- $impersonatorId = (int) session('impersonator_id');
- if (!$impersonatorId) {
- return redirect()->back()->with(['danger' => 'Режим impersonate не активен.']);
- }
- $impersonator = User::query()->find($impersonatorId);
- if (!$impersonator) {
- Auth::logout();
- $request->session()->invalidate();
- $request->session()->regenerateToken();
- return redirect()->route('login')->with(['danger' => 'Не удалось вернуться к исходному пользователю.']);
- }
- Auth::login($impersonator);
- $request->session()->forget('impersonator_id');
- $request->session()->regenerate();
- return redirect()->route('user.index')->with(['success' => 'Вы вернулись в аккаунт администратора.']);
- }
- private function prepareNotificationSettingsData(?User $user): void
- {
- $this->data['orderStatusOptions'] = Order::STATUS_NAMES;
- $this->data['orderStatusColors'] = Order::STATUS_COLOR;
- $this->data['reclamationStatusOptions'] = Reclamation::STATUS_NAMES;
- $this->data['reclamationStatusColors'] = ReclamationStatus::STATUS_COLOR;
- $this->data['scheduleSourceOptions'] = ['platform' => 'Площадки', 'reclamation' => 'Рекламации'];
- $this->data['notificationChannels'] = ['browser' => 'Браузер', 'push' => 'Push', 'email' => 'Email'];
- $this->data['disabledChannels'] = [
- 'browser' => false,
- 'push' => !$user || !$user->token_fcm,
- 'email' => !$user || !$user->notification_email || !filter_var($user->notification_email, FILTER_VALIDATE_EMAIL),
- ];
- if (!$user) {
- $this->data['notificationSettings'] = UserNotificationSetting::defaultsForUser(0);
- return;
- }
- $settings = UserNotificationSetting::query()->firstOrCreate(
- ['user_id' => $user->id],
- UserNotificationSetting::defaultsForUser($user->id),
- );
- $this->data['notificationSettings'] = $settings->toArray();
- }
- private function extractNotificationSettings(Request $request): array
- {
- $input = $request->input('notification_settings', []);
- $settings = [
- 'order_settings' => [],
- 'reclamation_settings' => [],
- 'schedule_settings' => [],
- ];
- $orderStatuses = array_keys(Order::STATUS_NAMES);
- $reclamationStatuses = array_keys(Reclamation::STATUS_NAMES);
- $scheduleSources = ['platform', 'reclamation'];
- $channels = ['browser', 'push', 'email'];
- foreach ($orderStatuses as $statusId) {
- foreach ($channels as $channel) {
- $settings['order_settings'][$statusId][$channel] = isset($input['orders'][$statusId][$channel]);
- }
- }
- foreach ($reclamationStatuses as $statusId) {
- foreach ($channels as $channel) {
- $settings['reclamation_settings'][$statusId][$channel] = isset($input['reclamations'][$statusId][$channel]);
- }
- }
- foreach ($scheduleSources as $source) {
- foreach ($channels as $channel) {
- $settings['schedule_settings'][$source][$channel] = isset($input['schedule'][$source][$channel]);
- }
- }
- return $settings;
- }
- }
|