only(['name', 'email', 'phone']); $admin = CompanyAdmin::where('user_id', auth()->id()); if (!$admin->count()) { abort(404); return; } $admin = $admin->first(); $user = User::where('email', $request->email)->orWhere('phone', $request->phone)->first(); if ($user) { if ($user->id !== auth()->id()) //если это не текущий пользователь-админ, который хочет себя сделать агентом, то ошибка { if (Agent::where('user_id', $user->id)->count()) // и если этот пользователь уже агент { return back()->with('error', __('Agent is not unique')); } } } else { $user = $user = User::create($request->all()); $user->setForcedPassword(); } if ($user) { Agent::where('user_id', $user->id)->delete(); //на случай, если где-то этот пользователь уже был агентом $agent = Agent::create([ 'user_id' => $user->id, 'company_id' => $admin->company_id ]); } return to_route('company.agents.table'); } }