réinit course

This commit is contained in:
Fred Tempez 2023-10-02 22:18:13 +02:00
parent 997408cf0f
commit 930a876194

View File

@ -306,35 +306,31 @@ class course extends common
public function swap() public function swap()
{ {
$courseId = $this->getUrl(2); $courseId = $this->getUrl(2);
$userId = $this->getUser('id'); $userId = $this->getuser('id');
$message = ''; $message = '';
$redirect = helper::baseUrl(); $redirect = helper::baseUrl();
$state = true; $state = true;
if ( if (
// Sortir du cours et afficher l'accueil // Sortir du cours et afficher l'accueil
$courseId === 'home' || $courseId === 'home'
// Un admin ou l'auteur du cours demande l'accès
( $userId &&
$this->getUser('group') === self::GROUP_ADMIN || $this->getUser('id') === $this->getData(['user', $courseId, 'author']))
) { ) {
$_SESSION['ZWII_SITE_CONTENT'] = $courseId; $_SESSION['ZWII_SITE_CONTENT'] = $courseId;
} }
// l'étudiant est inscrit dans le cours ET le cours est ouvert // l'étudiant est inscrit dans le cours ET le cours est ouvert
// ou un admin est connecté ou le prof du cours // ou un admin est connecté ou le prof du cours
elseif ( elseif (
$userId $this->courseIsUserEnroled($courseId)
&& $this->courseIsUserEnroled($courseId)
&& $this->courseIsAvailable($courseId) && $this->courseIsAvailable($courseId)
) { ) {
$_SESSION['ZWII_SITE_CONTENT'] = $courseId; $_SESSION['ZWII_SITE_CONTENT'] = $courseId;
$message = sprintf(helper::translate('Bienvenue dans le cours %s'), $this->getData(['course', $courseId, 'shortTitle'])); $message = sprintf(helper::translate('Bienvenue dans le cours %s'), $this->getData(['course', $courseId, 'shortTitle']));
// Récupérer la dernière page visitée par cet utilisateur si elle existe // Récupérer la dernière page visitée par cet utilisateur si elle existe
if (empty($this->getData(['enrolment', $courseId, $userId, 'lastPageId']))) { if ($this->getData(['enrolment', $courseId, $userId, 'lastPageId'])) {
// Sinon la page d'accueil par défaut du module $redirect .= $this->getData(['enrolment', $courseId, $userId, 'lastPageId']);
$redirect = $redirect . $this->getData(['course', $courseId, 'homePageId']);
} else { } else {
$redirect = $redirect . $this->getData(['enrolment', $courseId, $userId, 'lastPageId']); // Sinon la page d'accueil par défaut du module
$redirect .= $this->getData(['course', $courseId, 'homePageId']);
} }
} }
// Le cours est fermé // Le cours est fermé
@ -364,7 +360,7 @@ class course extends common
case self::COURSE_ENROLMENT_SELF_KEY: case self::COURSE_ENROLMENT_SELF_KEY:
//L'étudiant dispsoe d'un compte //L'étudiant dispsoe d'un compte
if ($this->getUser('id')) { if ($this->getUser('id')) {
$redirect = $redirect . 'course/enrol/' . $courseId; $redirect .= 'course/enrol/' . $courseId;
$message = helper::translate('Veuillez vous inscrire'); $message = helper::translate('Veuillez vous inscrire');
$state = true; $state = true;
} else { } else {
@ -514,6 +510,13 @@ class course extends common
if ($courseId === 'home') { if ($courseId === 'home') {
return true; return true;
} }
// Si un utilisateur connecté est admin aou auteur, c'est autorisé
if (
$this->getUser('password') === $this->getInput('ZWII_USER_PASSWORD') &&
$this->getUser('group') === self::GROUP_ADMIN || $this->getUser('id') === $this->getData(['user', $courseId, 'author'])
) {
return true;
}
// Retourne le statut du cours dans les autres cas // Retourne le statut du cours dans les autres cas
$access = $this->getData(['course', $courseId, 'access']); $access = $this->getData(['course', $courseId, 'access']);
switch ($access) { switch ($access) {