$email, 'password' => $password, 'root_admin' => $admin ], [ 'email' => 'required|email|unique:users,email', 'password' => 'required|regex:((?=.*\d)(?=.*[a-z])(?=.*[A-Z]).{8,})', 'root_admin' => 'required|boolean' ]); // Run validator, throw catchable and displayable exception if it fails. // Exception includes a JSON result of failed validation rules. if ($validator->fails()) { throw new DisplayValidationException($validator->errors()); } $user = new Models\User; $uuid = new UuidService; $user->uuid = $uuid->generate('users', 'uuid'); $user->email = $email; $user->password = Hash::make($password); $user->root_admin = ($admin) ? 1 : 0; try { $user->save(); return $user->id; } catch (\Exception $ex) { throw $e; } } /** * Updates a user on the panel. * * @param integer $id * @param array $data An array of columns and their associated values to update for the user. * @return boolean */ public function update($id, array $data) { $validator = Validator::make($data, [ 'email' => 'email|unique:users,email,' . $id, 'password' => 'regex:((?=.*\d)(?=.*[a-z])(?=.*[A-Z]).{8,})', 'root_admin' => 'boolean', 'language' => 'string|min:1|max:5', 'use_totp' => 'boolean', 'totp_secret' => 'size:16' ]); if(array_key_exists('password', $data)) { $user['password'] = Hash::make($data['password']); } return Models\User::find($id)->update($data); } /** * Deletes a user on the panel, returns the number of records deleted. * * @param integer $id * @return integer */ public function delete($id) { if(Models\Server::where('owner', $id)->count() > 0) { throw new DisplayException('Cannot delete a user with active servers attached to thier account.'); } DB::beginTransaction(); Models\Permission::where('user_id', $id)->delete(); Models\Subuser::where('user_id', $id)->delete(); Models\User::destroy($id); try { DB::commit(); return true; } catch (\Exception $ex) { throw $ex; } } }