You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
85 lines
2.5 KiB
85 lines
2.5 KiB
<?php
|
|
|
|
namespace controller;
|
|
use config\Validation;
|
|
use model\MdlStudent;
|
|
use Exception;
|
|
|
|
class StudentController
|
|
{
|
|
|
|
public function affAllVocab(): void
|
|
{
|
|
global $twig;
|
|
$mdl = new MdlStudent();
|
|
$voc = $mdl->getAll();
|
|
echo $twig->render('manageVocabListView.html', ['vocabularies' => $voc]);
|
|
|
|
}
|
|
|
|
public function affAllStudent(): void
|
|
{
|
|
global $twig;
|
|
$mdl = new MdlStudent();
|
|
$student = $mdl->getAll();
|
|
echo $twig->render('usersView.html', ['users' => $student]);
|
|
|
|
}
|
|
|
|
public function getByName(): void
|
|
{
|
|
global $twig;
|
|
$mdl = new MdlStudent();
|
|
$name = Validation::filter_str_simple($_GET['listName'] ?? null);
|
|
$vocab = $mdl->getVocabByName($name);
|
|
echo $twig->render('manageVocabView.html', ['vocabularies' => $vocab]);
|
|
}
|
|
|
|
public function showAccountInfos(): void {
|
|
try {
|
|
global $twig;
|
|
$userID = Validation::filter_int($_GET['user'] ?? null);
|
|
$mdl = new MdlStudent();
|
|
$user = $mdl->getUser($userID);
|
|
echo $twig->render('myAccountView.html', ['user' => $user]);
|
|
}
|
|
catch (Exception $e){
|
|
throw new Exception("invalid user ID");
|
|
}
|
|
}
|
|
|
|
public function modifyNickname(): void {
|
|
try {
|
|
$userID = Validation::filter_int($_GET['user']);
|
|
$newNickname = Validation::filter_str_nospecialchar($_GET['newNickname'] ?? null);
|
|
$mdl = new MdlStudent();
|
|
$mdl->modifyNickname($userID, $newNickname);
|
|
$_GET['user'] = $userID;
|
|
$this->showAccountInfos();
|
|
}
|
|
catch (Exception $e){
|
|
throw new Exception("invalid entries");
|
|
}
|
|
}
|
|
|
|
public function modifyPassword(): void {
|
|
try {
|
|
$userID = $_GET['user'];
|
|
$currentPassword = Validation::val_password($_GET['currentPassword'] ?? null);
|
|
$newPassword = Validation::val_password($_GET['newPassword'] ?? null);
|
|
$confirmNewPassword = Validation::val_password($_GET['confirmNewPassword'] ?? null);
|
|
$mdl = new MdlStudent();
|
|
$user = $mdl->getUser($userID);
|
|
|
|
if ($user->getPassword() != $currentPassword || $newPassword != $confirmNewPassword)
|
|
throw new Exception("");
|
|
|
|
$mdl->ModifyPassword($userID, $newPassword);
|
|
$_GET['user'] = $userID;
|
|
$this->showAccountInfos();
|
|
}
|
|
catch (Exception $e){
|
|
throw new Exception("invalid entries");
|
|
}
|
|
}
|
|
} |