Database->users()->createRow(array( 'username' => $username, 'first_name' => $firstName, 'last_name' => $lastName, 'password' => password_hash($password, PASSWORD_DEFAULT) )); $newUserRow->save(); } public function EditUser(int $userId, string $username, string $firstName, string $lastName, string $password) { if (!$this->UserExists($userId)) { throw new \Exception('User does not exist'); } $user = $this->Database->users($userId); $user->update(array( 'username' => $username, 'first_name' => $firstName, 'last_name' => $lastName, 'password' => password_hash($password, PASSWORD_DEFAULT) )); } public function DeleteUser($userId) { $row = $this->Database->users($userId); $row->delete(); } public function GetUsersAsDto() { $users = $this->Database->users(); $returnUsers = array(); foreach ($users as $user) { unset($user->password); $user->display_name = GetUserDisplayName($user); $returnUsers[] = $user; } return $returnUsers; } private function UserExists($userId) { $userRow = $this->Database->users()->where('id = :1', $userId)->fetch(); return $userRow !== null; } }