Rôles renommés, fonctions pour déterminer les droits d'accès à un cours, le sous ensembles teacher et students sont supprimés dans enrolment, le profil et le groupe moodle comptent
This commit is contained in:
parent
0e6b843b1d
commit
727f8123c0
@ -345,7 +345,7 @@ class layout extends common
|
|||||||
}
|
}
|
||||||
// Affichage de la barre de membre simple
|
// Affichage de la barre de membre simple
|
||||||
if (
|
if (
|
||||||
$this->getUser('group') >= self::GROUP_STUDENT && $this->getUser('group') < self::GROUP_ADMIN
|
$this->getUser('group') >= self::GROUP_TUTOR && $this->getUser('group') < self::GROUP_ADMIN
|
||||||
&& $this->getData(['theme', 'footer', 'memberBar']) === true
|
&& $this->getData(['theme', 'footer', 'memberBar']) === true
|
||||||
) {
|
) {
|
||||||
$items .= '<span id="footerDisplayMemberAccount"';
|
$items .= '<span id="footerDisplayMemberAccount"';
|
||||||
@ -506,11 +506,11 @@ class layout extends common
|
|||||||
}
|
}
|
||||||
// Commandes pour les membres simples
|
// Commandes pour les membres simples
|
||||||
if (
|
if (
|
||||||
$this->getUser('group') >= self::GROUP_STUDENT && $this->getUser('group') < self::GROUP_ADMIN
|
$this->getUser('group') >= self::GROUP_TUTOR && $this->getUser('group') < self::GROUP_ADMIN
|
||||||
&& $this->getData(['theme', 'menu', 'memberBar']) === true
|
&& $this->getData(['theme', 'menu', 'memberBar']) === true
|
||||||
) {
|
) {
|
||||||
if (
|
if (
|
||||||
$this->getUser('group') >= self::GROUP_STUDENT &&
|
$this->getUser('group') >= self::GROUP_TUTOR &&
|
||||||
$this->getUser('permission', 'filemanager') === true
|
$this->getUser('permission', 'filemanager') === true
|
||||||
) {
|
) {
|
||||||
$itemsRight .= '<li>' . template::ico('folder', [
|
$itemsRight .= '<li>' . template::ico('folder', [
|
||||||
|
@ -527,7 +527,7 @@ class core extends common
|
|||||||
$access = null;
|
$access = null;
|
||||||
if ($this->getData(['page', $this->getUrl(0)]) !== null) {
|
if ($this->getData(['page', $this->getUrl(0)]) !== null) {
|
||||||
if (
|
if (
|
||||||
$this->getData(['page', $this->getUrl(0), 'group']) === self::GROUP_VISITOR
|
$this->getData(['page', $this->getUrl(0), 'group']) === self::GROUP_STUDENT
|
||||||
or ($this->getUser('password') === $this->getInput('ZWII_USER_PASSWORD')
|
or ($this->getUser('password') === $this->getInput('ZWII_USER_PASSWORD')
|
||||||
// and $this->getUser('group') >= $this->getData(['page', $this->getUrl(0), 'group'])
|
// and $this->getUser('group') >= $this->getData(['page', $this->getUrl(0), 'group'])
|
||||||
// Modification qui tient compte du profil de la page
|
// Modification qui tient compte du profil de la page
|
||||||
@ -705,7 +705,7 @@ class core extends common
|
|||||||
$output = $module->output;
|
$output = $module->output;
|
||||||
// Check le groupe de l'utilisateur
|
// Check le groupe de l'utilisateur
|
||||||
if (
|
if (
|
||||||
($module::$actions[$action] === self::GROUP_VISITOR
|
($module::$actions[$action] === self::GROUP_STUDENT
|
||||||
or ($this->getUser('password') === $this->getInput('ZWII_USER_PASSWORD')
|
or ($this->getUser('password') === $this->getInput('ZWII_USER_PASSWORD')
|
||||||
and $this->getUser('group') >= $module::$actions[$action]
|
and $this->getUser('group') >= $module::$actions[$action]
|
||||||
and $this->getUser('permission', $moduleId, $action)
|
and $this->getUser('permission', $moduleId, $action)
|
||||||
|
@ -25,8 +25,8 @@ class common
|
|||||||
const DISPLAY_LAYOUT_MAIN = 4;
|
const DISPLAY_LAYOUT_MAIN = 4;
|
||||||
const DISPLAY_LAYOUT_LIGHT = 5;
|
const DISPLAY_LAYOUT_LIGHT = 5;
|
||||||
const GROUP_BANNED = -1;
|
const GROUP_BANNED = -1;
|
||||||
const GROUP_VISITOR = 0;
|
const GROUP_STUDENT = 0;
|
||||||
const GROUP_STUDENT = 1;
|
const GROUP_TUTOR = 1;
|
||||||
const GROUP_TEACHER = 2;
|
const GROUP_TEACHER = 2;
|
||||||
// Groupe MODERATOR, compatibilité avec les anciens modules :
|
// Groupe MODERATOR, compatibilité avec les anciens modules :
|
||||||
const GROUP_ADMIN = 3;
|
const GROUP_ADMIN = 3;
|
||||||
@ -94,14 +94,6 @@ class common
|
|||||||
'theme',
|
'theme',
|
||||||
'user'
|
'user'
|
||||||
];
|
];
|
||||||
/*
|
|
||||||
Cette variable est supprimée du test dans le routeur.
|
|
||||||
public static $accessExclude = [
|
|
||||||
'login',
|
|
||||||
'logout',
|
|
||||||
'maintenance',
|
|
||||||
];
|
|
||||||
*/
|
|
||||||
private $data = [];
|
private $data = [];
|
||||||
private $hierarchy = [
|
private $hierarchy = [
|
||||||
'all' => [],
|
'all' => [],
|
||||||
@ -153,25 +145,25 @@ class common
|
|||||||
];
|
];
|
||||||
public static $groups = [
|
public static $groups = [
|
||||||
self::GROUP_BANNED => 'Banni',
|
self::GROUP_BANNED => 'Banni',
|
||||||
self::GROUP_VISITOR => 'Visiteur',
|
|
||||||
self::GROUP_STUDENT => 'Apprenant',
|
self::GROUP_STUDENT => 'Apprenant',
|
||||||
|
self::GROUP_TUTOR => 'Tuteur',
|
||||||
self::GROUP_TEACHER => 'Enseignant',
|
self::GROUP_TEACHER => 'Enseignant',
|
||||||
self::GROUP_ADMIN => 'Administrateur'
|
self::GROUP_ADMIN => 'Administrateur'
|
||||||
];
|
];
|
||||||
public static $groupEdits = [
|
public static $groupEdits = [
|
||||||
self::GROUP_BANNED => 'Banni',
|
self::GROUP_BANNED => 'Banni',
|
||||||
self::GROUP_STUDENT => 'Apprenant',
|
self::GROUP_TUTOR => 'Tuteur',
|
||||||
self::GROUP_TEACHER => 'Enseignant',
|
self::GROUP_TEACHER => 'Enseignant',
|
||||||
self::GROUP_ADMIN => 'Administrateur'
|
self::GROUP_ADMIN => 'Administrateur'
|
||||||
];
|
];
|
||||||
public static $groupNews = [
|
public static $groupNews = [
|
||||||
self::GROUP_STUDENT => 'Apprenant',
|
self::GROUP_TUTOR => 'Tuteur',
|
||||||
self::GROUP_TEACHER => 'Enseignant',
|
self::GROUP_TEACHER => 'Enseignant',
|
||||||
self::GROUP_ADMIN => 'Administrateur'
|
self::GROUP_ADMIN => 'Administrateur'
|
||||||
];
|
];
|
||||||
public static $groupPublics = [
|
public static $groupPublics = [
|
||||||
self::GROUP_VISITOR => 'Visiteur',
|
|
||||||
self::GROUP_STUDENT => 'Apprenant',
|
self::GROUP_STUDENT => 'Apprenant',
|
||||||
|
self::GROUP_TUTOR => 'Tuteur',
|
||||||
self::GROUP_TEACHER => 'Enseignant',
|
self::GROUP_TEACHER => 'Enseignant',
|
||||||
self::GROUP_ADMIN => 'Administrateur'
|
self::GROUP_ADMIN => 'Administrateur'
|
||||||
];
|
];
|
||||||
@ -453,7 +445,6 @@ class common
|
|||||||
|
|
||||||
// Mise à jour des données core
|
// Mise à jour des données core
|
||||||
include('core/include/update.inc.php');
|
include('core/include/update.inc.php');
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -720,7 +711,7 @@ class common
|
|||||||
// Page parent
|
// Page parent
|
||||||
$this->getData(['page', $pageId, 'parentPageId']) === ''
|
$this->getData(['page', $pageId, 'parentPageId']) === ''
|
||||||
// Ignore les pages dont l'utilisateur n'a pas accès
|
// Ignore les pages dont l'utilisateur n'a pas accès
|
||||||
and ($this->getData(['page', $pageId, 'group']) === self::GROUP_VISITOR
|
and ($this->getData(['page', $pageId, 'group']) === self::GROUP_STUDENT
|
||||||
or ($this->getUser('password') === $this->getInput('ZWII_USER_PASSWORD')
|
or ($this->getUser('password') === $this->getInput('ZWII_USER_PASSWORD')
|
||||||
//and $this->getUser('group') >= $this->getData(['page', $pageId, 'group'])
|
//and $this->getUser('group') >= $this->getData(['page', $pageId, 'group'])
|
||||||
// Modification qui tient compte du profil de la page
|
// Modification qui tient compte du profil de la page
|
||||||
@ -745,8 +736,8 @@ class common
|
|||||||
$parentId = $this->getData(['page', $pageId, 'parentPageId'])
|
$parentId = $this->getData(['page', $pageId, 'parentPageId'])
|
||||||
// Ignore les pages dont l'utilisateur n'a pas accès
|
// Ignore les pages dont l'utilisateur n'a pas accès
|
||||||
and (
|
and (
|
||||||
($this->getData(['page', $pageId, 'group']) === self::GROUP_VISITOR
|
($this->getData(['page', $pageId, 'group']) === self::GROUP_STUDENT
|
||||||
and $this->getData(['page', $parentId, 'group']) === self::GROUP_VISITOR
|
and $this->getData(['page', $parentId, 'group']) === self::GROUP_STUDENT
|
||||||
)
|
)
|
||||||
or ($this->getUser('password') === $this->getInput('ZWII_USER_PASSWORD')
|
or ($this->getUser('password') === $this->getInput('ZWII_USER_PASSWORD')
|
||||||
//and $this->getUser('group') >= $this->getData(['page', $parentId, 'group'])
|
//and $this->getUser('group') >= $this->getData(['page', $parentId, 'group'])
|
||||||
@ -1439,11 +1430,12 @@ class common
|
|||||||
return $c;
|
return $c;
|
||||||
case self::GROUP_TEACHER:
|
case self::GROUP_TEACHER:
|
||||||
foreach ($c as $courseId => $value) {
|
foreach ($c as $courseId => $value) {
|
||||||
if ($this->getData(['enrolment', $courseId, 'teacher']) !== $userId) {
|
if ($this->getData(['enrolment', $courseId]) !== $userId) {
|
||||||
unset($c[$courseId]);
|
unset($c[$courseId]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return $c;
|
return $c;
|
||||||
|
case self::GROUP_TUTOR:
|
||||||
case self::GROUP_STUDENT:
|
case self::GROUP_STUDENT:
|
||||||
foreach ($c as $courseId => $value) {
|
foreach ($c as $courseId => $value) {
|
||||||
$students = $this->getData(['enrolment', $courseId, 'students']);
|
$students = $this->getData(['enrolment', $courseId, 'students']);
|
||||||
@ -1463,45 +1455,31 @@ class common
|
|||||||
* @param string $userId identifiant de l'utilisateur
|
* @param string $userId identifiant de l'utilisateur
|
||||||
* @param string $courseId identifiant du cours sollicité
|
* @param string $courseId identifiant du cours sollicité
|
||||||
*/
|
*/
|
||||||
public function courseUserEnrolment($courseId, $userId)
|
public function courseUserEnrolment($courseId, $userId = null)
|
||||||
{
|
{
|
||||||
// Modalité d'ouverture du cours
|
$group = $userId ? $this->getData(['user', $userId, 'group']) : false;
|
||||||
// L'utilisateur n'est pas admin
|
switch ($group) {
|
||||||
switch ($this->getData(['user', $userId, 'group'])) {
|
|
||||||
case self::GROUP_ADMIN:
|
case self::GROUP_ADMIN:
|
||||||
return true;
|
$r = true;
|
||||||
|
break;
|
||||||
case self::GROUP_TEACHER:
|
case self::GROUP_TEACHER:
|
||||||
return ($userId === $this->getData(['enrolment', $courseId, 'teacher']));
|
$r = in_array($userId, array_keys($this->getData(['enrolment', $courseId])));
|
||||||
|
break;
|
||||||
|
case self::GROUP_TUTOR:
|
||||||
case self::GROUP_STUDENT:
|
case self::GROUP_STUDENT:
|
||||||
return (
|
$r = $this->courseIsAvailable($courseId) &&
|
||||||
// Le cours est-il ouvert ?
|
(in_array($userId, array_keys($this->getData(['enrolment', $courseId]))) ||
|
||||||
$this->courseIsAvailable($courseId) &&
|
$this->getData(['course', $courseId, 'enrolment']) <= self::COURSE_ENROLMENT_SELF);
|
||||||
// L'étudiant est inscrit ?
|
break;
|
||||||
array_search($userId, $this->getData(['enrolment', $courseId, 'students']))
|
// Visiteur non connecté
|
||||||
);
|
case false:
|
||||||
case self::GROUP_VISITOR:
|
$r = $this->courseIsAvailable($courseId) &&
|
||||||
// Le cours est-il ouvert ?
|
$this->getData(['course', $courseId, 'enrolment']) === self::COURSE_ENROLMENT_GUEST;
|
||||||
return (
|
break;
|
||||||
$this->courseIsAvailable($courseId) &&
|
|
||||||
$this->getData(['course', $courseId, 'enrolment']) === self::COURSE_ENROLMENT_GUEST
|
|
||||||
);
|
|
||||||
default:
|
default:
|
||||||
return false;
|
$r = false;
|
||||||
}
|
|
||||||
if ($this->getData(['user', $userId, 'group']) < self::GROUP_ADMIN) {
|
|
||||||
if (
|
|
||||||
// le cours est fermé
|
|
||||||
$this->getData(['course', $courseId, 'access']) === self::COURSE_ACCESS_CLOSE
|
|
||||||
||
|
|
||||||
// Le cours ets ouvert entre deux dates
|
|
||||||
($this->getData(['course', $courseId, 'access']) &&
|
|
||||||
($this->getData(['course', $courseId, 'openingDate']) >= time() ||
|
|
||||||
$this->getData(['course', $courseId, 'clodingDate']) <= time())
|
|
||||||
)
|
|
||||||
) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
return $r;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -32,7 +32,7 @@
|
|||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<!-- Barre d'administration -->
|
<!-- Barre d'administration -->
|
||||||
<?php if ($this->getUser('group') > self::GROUP_STUDENT) : ?>
|
<?php if ($this->getUser('group') > self::GROUP_TUTOR) : ?>
|
||||||
<?php $layout->showBar(); ?>
|
<?php $layout->showBar(); ?>
|
||||||
<?php endif; ?>
|
<?php endif; ?>
|
||||||
<!-- Notifications -->
|
<!-- Notifications -->
|
||||||
@ -45,7 +45,7 @@
|
|||||||
$this->getData(['theme', 'menu', 'position']) === 'top'
|
$this->getData(['theme', 'menu', 'position']) === 'top'
|
||||||
and $this->getData(['theme', 'menu', 'fixed']) === true
|
and $this->getData(['theme', 'menu', 'fixed']) === true
|
||||||
and $this->getUser('password') === $this->getInput('ZWII_USER_PASSWORD')
|
and $this->getUser('password') === $this->getInput('ZWII_USER_PASSWORD')
|
||||||
and $this->getUser('group') > self::GROUP_STUDENT
|
and $this->getUser('group') > self::GROUP_TUTOR
|
||||||
) {
|
) {
|
||||||
echo '<nav id="navfixedconnected" >';
|
echo '<nav id="navfixedconnected" >';
|
||||||
} else {
|
} else {
|
||||||
|
@ -21,8 +21,8 @@ class course extends common
|
|||||||
'edit' => self::GROUP_ADMIN,
|
'edit' => self::GROUP_ADMIN,
|
||||||
'add' => self::GROUP_ADMIN,
|
'add' => self::GROUP_ADMIN,
|
||||||
'delete' => self::GROUP_ADMIN,
|
'delete' => self::GROUP_ADMIN,
|
||||||
'swap' => self::GROUP_VISITOR,
|
'swap' => self::GROUP_STUDENT,
|
||||||
'change' => self::GROUP_VISITOR,
|
'change' => self::GROUP_STUDENT,
|
||||||
];
|
];
|
||||||
|
|
||||||
public static $courseAccess = [
|
public static $courseAccess = [
|
||||||
@ -42,6 +42,7 @@ class course extends common
|
|||||||
|
|
||||||
public static $courses = [];
|
public static $courses = [];
|
||||||
|
|
||||||
|
public static $changeMessages = [];
|
||||||
|
|
||||||
|
|
||||||
public function index()
|
public function index()
|
||||||
@ -115,10 +116,7 @@ class course extends common
|
|||||||
$this->setData([
|
$this->setData([
|
||||||
'enrolment',
|
'enrolment',
|
||||||
$courseId,
|
$courseId,
|
||||||
[
|
[]
|
||||||
'teacher' => $author,
|
|
||||||
'students' => []
|
|
||||||
]
|
|
||||||
]);
|
]);
|
||||||
|
|
||||||
// Valeurs en sortie
|
// Valeurs en sortie
|
||||||
@ -205,17 +203,6 @@ class course extends common
|
|||||||
]
|
]
|
||||||
]);
|
]);
|
||||||
|
|
||||||
// BDD des inscrits
|
|
||||||
$students = is_null($this->getData(['enrolment', $courseId, 'students'])) ? [] : $this->getData(['enrolment', $courseId, 'students']);
|
|
||||||
$this->setData([
|
|
||||||
'enrolment',
|
|
||||||
$courseId,
|
|
||||||
[
|
|
||||||
'teacher' => $author,
|
|
||||||
'students' => $students
|
|
||||||
]
|
|
||||||
]);
|
|
||||||
|
|
||||||
// Valeurs en sortie
|
// Valeurs en sortie
|
||||||
$this->addOutput([
|
$this->addOutput([
|
||||||
'redirect' => helper::baseUrl() . 'course',
|
'redirect' => helper::baseUrl() . 'course',
|
||||||
@ -249,14 +236,21 @@ class course extends common
|
|||||||
if (
|
if (
|
||||||
$this->isPost() ||
|
$this->isPost() ||
|
||||||
$this->getUrl(2) === 'home'
|
$this->getUrl(2) === 'home'
|
||||||
|
|
||||||
) {
|
) {
|
||||||
$this->swap();
|
$this->swap();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Bouton de connexion ou d'inscription
|
||||||
|
// C'est un prof ou un admin
|
||||||
|
self::$changeMessages = $this->getUser('group') >= self::GROUP_TEACHER
|
||||||
|
? 'Se connecter'
|
||||||
|
// C'est un étudiant ou un visiteur
|
||||||
|
: '';
|
||||||
|
|
||||||
// Valeurs en sortie
|
// Valeurs en sortie
|
||||||
$this->addOutput([
|
$this->addOutput([
|
||||||
'title' => sprintf(helper::translate('Accéder au cours %s'), $this->getData(['course', $this->getUrl(2), 'shortTitle' ])),
|
'title' => sprintf(helper::translate('Accéder au cours %s'), $this->getData(['course', $this->getUrl(2), 'shortTitle'])),
|
||||||
'view' => 'change',
|
'view' => 'change',
|
||||||
'display' => self::DISPLAY_LAYOUT_LIGHT,
|
'display' => self::DISPLAY_LAYOUT_LIGHT,
|
||||||
]);
|
]);
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
<div class="col12">
|
<div class="col12">
|
||||||
<?php echo "<h3>Auteur : " . $this->getData(['course', $this->getUrl(2), 'author' ]) . "</h3>"; ?>
|
<?php echo "<h3>Auteur : " . $this->getData(['course', $this->getUrl(2), 'author' ]) . "</h3>"; ?>
|
||||||
<?php echo "<p> Description : " . $this->getData(['course', $this->getUrl(2), 'description' ]) . "</p>"; ?>
|
<?php echo "<p> Description : " . $this->getData(['course', $this->getUrl(2), 'description' ]) . "</p>"; ?>
|
||||||
<?php echo "<p> Disponibilité : " . $module::$courseAccess[$this->getData(['course', $this->getUrl(2), 'access' ])]. "</p>";?>
|
<?php echo "<p> Disponibilité : " . $module::$courseAccess[$this->getData(['course', $this->getUrl(2), 'access' ])] . "</p>";?>
|
||||||
<?php echo "<p> Inscription : " . $module::$courseEnrolment[$this->getData(['course', $this->getUrl(2), 'enrolment' ])]. "</p>";?>
|
<?php echo "<p> Inscription : " . $module::$courseEnrolment[$this->getData(['course', $this->getUrl(2), 'enrolment' ])]. "</p>";?>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
@ -18,6 +18,7 @@
|
|||||||
<div class="col3 offset7">
|
<div class="col3 offset7">
|
||||||
<?php echo template::submit('courseChangeSubmit', [
|
<?php echo template::submit('courseChangeSubmit', [
|
||||||
'value' => 'Se connecter',
|
'value' => 'Se connecter',
|
||||||
|
'disabled' => !$this->courseIsAvailable($this->getUrl(2)),
|
||||||
'ico' => ''
|
'ico' => ''
|
||||||
]); ?>
|
]); ?>
|
||||||
</div>
|
</div>
|
||||||
|
@ -18,8 +18,8 @@ class install extends common
|
|||||||
{
|
{
|
||||||
|
|
||||||
public static $actions = [
|
public static $actions = [
|
||||||
'index' => self::GROUP_VISITOR,
|
'index' => self::GROUP_STUDENT,
|
||||||
"postinstall" => self::GROUP_VISITOR,
|
"postinstall" => self::GROUP_STUDENT,
|
||||||
'steps' => self::GROUP_ADMIN,
|
'steps' => self::GROUP_ADMIN,
|
||||||
'update' => self::GROUP_ADMIN
|
'update' => self::GROUP_ADMIN
|
||||||
];
|
];
|
||||||
|
@ -323,7 +323,7 @@ class init extends common
|
|||||||
'comment' => 'Accès désactivé',
|
'comment' => 'Accès désactivé',
|
||||||
],
|
],
|
||||||
'0' => [
|
'0' => [
|
||||||
'name' => 'Visiteur',
|
'name' => 'Apprenant',
|
||||||
'readonly' => true,
|
'readonly' => true,
|
||||||
'permanent' => true,
|
'permanent' => true,
|
||||||
'comment' => 'Accède au site',
|
'comment' => 'Accède au site',
|
||||||
@ -687,7 +687,7 @@ class init extends common
|
|||||||
'modulePosition' => 'bottom',
|
'modulePosition' => 'bottom',
|
||||||
'parentPageId' => '',
|
'parentPageId' => '',
|
||||||
'position' => 1,
|
'position' => 1,
|
||||||
'group' => self::GROUP_VISITOR,
|
'group' => self::GROUP_STUDENT,
|
||||||
'profil' => 0,
|
'profil' => 0,
|
||||||
'targetBlank' => false,
|
'targetBlank' => false,
|
||||||
'title' => 'Accueil',
|
'title' => 'Accueil',
|
||||||
@ -718,7 +718,7 @@ class init extends common
|
|||||||
'modulePosition' => 'bottom',
|
'modulePosition' => 'bottom',
|
||||||
'parentPageId' => '',
|
'parentPageId' => '',
|
||||||
'position' => 6,
|
'position' => 6,
|
||||||
'group' => self::GROUP_VISITOR,
|
'group' => self::GROUP_STUDENT,
|
||||||
'profil' => 0,
|
'profil' => 0,
|
||||||
'targetBlank' => false,
|
'targetBlank' => false,
|
||||||
'title' => 'Contact',
|
'title' => 'Contact',
|
||||||
@ -749,7 +749,7 @@ class init extends common
|
|||||||
'modulePosition' => 'bottom',
|
'modulePosition' => 'bottom',
|
||||||
'parentPageId' => '',
|
'parentPageId' => '',
|
||||||
'position' => 0,
|
'position' => 0,
|
||||||
'group' => self::GROUP_VISITOR,
|
'group' => self::GROUP_STUDENT,
|
||||||
'profil' => 0,
|
'profil' => 0,
|
||||||
'targetBlank' => false,
|
'targetBlank' => false,
|
||||||
'title' => 'Mentions légales',
|
'title' => 'Mentions légales',
|
||||||
@ -781,7 +781,7 @@ class init extends common
|
|||||||
'modulePosition' => '',
|
'modulePosition' => '',
|
||||||
'parentPageId' => '',
|
'parentPageId' => '',
|
||||||
'position' => 0,
|
'position' => 0,
|
||||||
'group' => self::GROUP_VISITOR,
|
'group' => self::GROUP_STUDENT,
|
||||||
'profil' => 0,
|
'profil' => 0,
|
||||||
'targetBlank' => false,
|
'targetBlank' => false,
|
||||||
'title' => 'Maintenance en cours',
|
'title' => 'Maintenance en cours',
|
||||||
@ -813,7 +813,7 @@ class init extends common
|
|||||||
'modulePosition' => 'bottom',
|
'modulePosition' => 'bottom',
|
||||||
'parentPageId' => '',
|
'parentPageId' => '',
|
||||||
'position' => 0,
|
'position' => 0,
|
||||||
'group' => self::GROUP_VISITOR,
|
'group' => self::GROUP_STUDENT,
|
||||||
'profil' => 0,
|
'profil' => 0,
|
||||||
'targetBlank' => false,
|
'targetBlank' => false,
|
||||||
'title' => 'Erreur 403',
|
'title' => 'Erreur 403',
|
||||||
@ -844,7 +844,7 @@ class init extends common
|
|||||||
'modulePosition' => 'bottom',
|
'modulePosition' => 'bottom',
|
||||||
'parentPageId' => '',
|
'parentPageId' => '',
|
||||||
'position' => 0,
|
'position' => 0,
|
||||||
'group' => self::GROUP_VISITOR,
|
'group' => self::GROUP_STUDENT,
|
||||||
'profil' => 0,
|
'profil' => 0,
|
||||||
'targetBlank' => false,
|
'targetBlank' => false,
|
||||||
'title' => 'Erreur 404',
|
'title' => 'Erreur 404',
|
||||||
@ -989,7 +989,7 @@ class init extends common
|
|||||||
'modulePosition' => 'bottom',
|
'modulePosition' => 'bottom',
|
||||||
'parentPageId' => '',
|
'parentPageId' => '',
|
||||||
'position' => 1,
|
'position' => 1,
|
||||||
'group' => self::GROUP_VISITOR,
|
'group' => self::GROUP_STUDENT,
|
||||||
'profil' => 0,
|
'profil' => 0,
|
||||||
'targetBlank' => false,
|
'targetBlank' => false,
|
||||||
'title' => 'Accueil',
|
'title' => 'Accueil',
|
||||||
|
@ -17,7 +17,7 @@ class maintenance extends common
|
|||||||
{
|
{
|
||||||
|
|
||||||
public static $actions = [
|
public static $actions = [
|
||||||
'index' => self::GROUP_VISITOR
|
'index' => self::GROUP_STUDENT
|
||||||
];
|
];
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -155,7 +155,7 @@ class page extends common
|
|||||||
'parentPageId' => '',
|
'parentPageId' => '',
|
||||||
'modulePosition' => 'bottom',
|
'modulePosition' => 'bottom',
|
||||||
'position' => 0,
|
'position' => 0,
|
||||||
'group' => self::GROUP_VISITOR,
|
'group' => self::GROUP_STUDENT,
|
||||||
'targetBlank' => false,
|
'targetBlank' => false,
|
||||||
'title' => $pageTitle,
|
'title' => $pageTitle,
|
||||||
'shortTitle' => $pageTitle,
|
'shortTitle' => $pageTitle,
|
||||||
@ -564,7 +564,7 @@ class page extends common
|
|||||||
// Profils installés
|
// Profils installés
|
||||||
// Profils disponibles
|
// Profils disponibles
|
||||||
foreach ($this->getData(['profil']) as $profilId => $profilData) {
|
foreach ($this->getData(['profil']) as $profilId => $profilData) {
|
||||||
if ($profilId < self::GROUP_STUDENT) {
|
if ($profilId < self::GROUP_TUTOR) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if ($profilId === self::GROUP_ADMIN) {
|
if ($profilId === self::GROUP_ADMIN) {
|
||||||
|
@ -389,8 +389,8 @@
|
|||||||
</div>
|
</div>
|
||||||
<div class="col6">
|
<div class="col6">
|
||||||
<div class="pageEditGroupProfil displayNone"
|
<div class="pageEditGroupProfil displayNone"
|
||||||
id="pageEditGroupProfil<?php echo self::GROUP_STUDENT; ?>">
|
id="pageEditGroupProfil<?php echo self::GROUP_TUTOR; ?>">
|
||||||
<?php echo template::select('pageEditProfil' . self::GROUP_STUDENT, $module::$userProfils[self::GROUP_STUDENT], [
|
<?php echo template::select('pageEditProfil' . self::GROUP_TUTOR, $module::$userProfils[self::GROUP_TUTOR], [
|
||||||
'label' => 'Profil minimal pour accéder à la page',
|
'label' => 'Profil minimal pour accéder à la page',
|
||||||
'selected' => $this->getData(['page', $this->getUrl(2), 'profil']),
|
'selected' => $this->getData(['page', $this->getUrl(2), 'profil']),
|
||||||
'help' => 'Les profils de niveau supérieur accèdent à la page.',
|
'help' => 'Les profils de niveau supérieur accèdent à la page.',
|
||||||
|
@ -16,7 +16,7 @@
|
|||||||
class sitemap extends common
|
class sitemap extends common
|
||||||
{
|
{
|
||||||
public static $actions = [
|
public static $actions = [
|
||||||
'index' => self::GROUP_VISITOR
|
'index' => self::GROUP_STUDENT
|
||||||
];
|
];
|
||||||
|
|
||||||
public static $siteMap = '';
|
public static $siteMap = '';
|
||||||
|
@ -22,11 +22,11 @@ class user extends common
|
|||||||
'import' => self::GROUP_ADMIN,
|
'import' => self::GROUP_ADMIN,
|
||||||
'index' => self::GROUP_ADMIN,
|
'index' => self::GROUP_ADMIN,
|
||||||
'template' => self::GROUP_ADMIN,
|
'template' => self::GROUP_ADMIN,
|
||||||
'edit' => self::GROUP_STUDENT,
|
'edit' => self::GROUP_TUTOR,
|
||||||
'logout' => self::GROUP_STUDENT,
|
'logout' => self::GROUP_TUTOR,
|
||||||
'forgot' => self::GROUP_VISITOR,
|
'forgot' => self::GROUP_STUDENT,
|
||||||
'login' => self::GROUP_VISITOR,
|
'login' => self::GROUP_STUDENT,
|
||||||
'reset' => self::GROUP_VISITOR,
|
'reset' => self::GROUP_STUDENT,
|
||||||
'profil' => self::GROUP_ADMIN,
|
'profil' => self::GROUP_ADMIN,
|
||||||
'profilEdit' => self::GROUP_ADMIN,
|
'profilEdit' => self::GROUP_ADMIN,
|
||||||
'profilAdd' => self::GROUP_ADMIN,
|
'profilAdd' => self::GROUP_ADMIN,
|
||||||
@ -65,7 +65,7 @@ class user extends common
|
|||||||
];
|
];
|
||||||
|
|
||||||
public static $groupProfils = [
|
public static $groupProfils = [
|
||||||
self::GROUP_STUDENT => 'Membre',
|
self::GROUP_TUTOR => 'Membre',
|
||||||
self::GROUP_TEACHER => 'Éditeur'
|
self::GROUP_TEACHER => 'Éditeur'
|
||||||
];
|
];
|
||||||
|
|
||||||
@ -162,7 +162,7 @@ class user extends common
|
|||||||
|
|
||||||
// Profils disponibles
|
// Profils disponibles
|
||||||
foreach ($this->getData(['profil']) as $profilId => $profilData) {
|
foreach ($this->getData(['profil']) as $profilId => $profilData) {
|
||||||
if ($profilId < self::GROUP_STUDENT) {
|
if ($profilId < self::GROUP_TUTOR) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if ($profilId === self::GROUP_ADMIN) {
|
if ($profilId === self::GROUP_ADMIN) {
|
||||||
@ -242,7 +242,7 @@ class user extends common
|
|||||||
and (
|
and (
|
||||||
// Impossible de s'auto-éditer
|
// Impossible de s'auto-éditer
|
||||||
($this->getUser('id') === $this->getUrl(2)
|
($this->getUser('id') === $this->getUrl(2)
|
||||||
and $this->getUrl('group') <= self::GROUP_VISITOR
|
and $this->getUrl('group') <= self::GROUP_STUDENT
|
||||||
)
|
)
|
||||||
// Impossible d'éditer un autre utilisateur
|
// Impossible d'éditer un autre utilisateur
|
||||||
or ($this->getUrl('group') < self::GROUP_TEACHER)
|
or ($this->getUrl('group') < self::GROUP_TEACHER)
|
||||||
@ -354,7 +354,7 @@ class user extends common
|
|||||||
|
|
||||||
// Profils disponibles
|
// Profils disponibles
|
||||||
foreach ($this->getData(['profil']) as $profilId => $profilData) {
|
foreach ($this->getData(['profil']) as $profilId => $profilData) {
|
||||||
if ($profilId < self::GROUP_STUDENT) {
|
if ($profilId < self::GROUP_TUTOR) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if ($profilId === self::GROUP_ADMIN) {
|
if ($profilId === self::GROUP_ADMIN) {
|
||||||
@ -473,7 +473,7 @@ class user extends common
|
|||||||
// Membres sans permissions spécifiques
|
// Membres sans permissions spécifiques
|
||||||
if (
|
if (
|
||||||
$groupId == self::GROUP_BANNED ||
|
$groupId == self::GROUP_BANNED ||
|
||||||
$groupId == self::GROUP_VISITOR ||
|
$groupId == self::GROUP_STUDENT ||
|
||||||
$groupId == self::GROUP_ADMIN
|
$groupId == self::GROUP_ADMIN
|
||||||
) {
|
) {
|
||||||
self::$userGroups[$groupId] = [
|
self::$userGroups[$groupId] = [
|
||||||
@ -492,7 +492,7 @@ class user extends common
|
|||||||
])
|
])
|
||||||
];
|
];
|
||||||
} elseif (
|
} elseif (
|
||||||
$groupId == self::GROUP_STUDENT ||
|
$groupId == self::GROUP_TUTOR ||
|
||||||
$groupId == self::GROUP_TEACHER
|
$groupId == self::GROUP_TEACHER
|
||||||
) {
|
) {
|
||||||
// Enumérer les sous groupes MEMBER et MODERATOR
|
// Enumérer les sous groupes MEMBER et MODERATOR
|
||||||
@ -871,7 +871,7 @@ class user extends common
|
|||||||
($this->getData(['user', $userId, 'connectTimeout']) + $this->getData(['config', 'connect', 'timeout'])) < time()
|
($this->getData(['user', $userId, 'connectTimeout']) + $this->getData(['config', 'connect', 'timeout'])) < time()
|
||||||
and $this->getData(['user', $userId, 'connectFail']) < $this->getData(['config', 'connect', 'attempt'])
|
and $this->getData(['user', $userId, 'connectFail']) < $this->getData(['config', 'connect', 'attempt'])
|
||||||
and password_verify(html_entity_decode($this->getInput('userLoginPassword', helper::FILTER_STRING_SHORT, true)), $this->getData(['user', $userId, 'password']))
|
and password_verify(html_entity_decode($this->getInput('userLoginPassword', helper::FILTER_STRING_SHORT, true)), $this->getData(['user', $userId, 'password']))
|
||||||
and $this->getData(['user', $userId, 'group']) >= self::GROUP_STUDENT
|
and $this->getData(['user', $userId, 'group']) >= self::GROUP_TUTOR
|
||||||
and $captcha === true
|
and $captcha === true
|
||||||
) {
|
) {
|
||||||
// RAZ
|
// RAZ
|
||||||
|
@ -91,13 +91,13 @@
|
|||||||
<div class="col6">
|
<div class="col6">
|
||||||
<?php echo template::select('userAddGroup', self::$groupNews, [
|
<?php echo template::select('userAddGroup', self::$groupNews, [
|
||||||
'label' => 'Groupe',
|
'label' => 'Groupe',
|
||||||
'selected' => self::GROUP_STUDENT
|
'selected' => self::GROUP_TUTOR
|
||||||
]); ?>
|
]); ?>
|
||||||
</div>
|
</div>
|
||||||
<div class="col6">
|
<div class="col6">
|
||||||
<div class="userAddGroupProfil displayNone"
|
<div class="userAddGroupProfil displayNone"
|
||||||
id="userAddGroupProfil<?php echo self::GROUP_STUDENT; ?>">
|
id="userAddGroupProfil<?php echo self::GROUP_TUTOR; ?>">
|
||||||
<?php echo template::select('userAddProfil' . self::GROUP_STUDENT, $module::$userProfils[self::GROUP_STUDENT], [
|
<?php echo template::select('userAddProfil' . self::GROUP_TUTOR, $module::$userProfils[self::GROUP_TUTOR], [
|
||||||
'label' => 'Profil',
|
'label' => 'Profil',
|
||||||
]); ?>
|
]); ?>
|
||||||
</div>
|
</div>
|
||||||
@ -110,9 +110,9 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div id="userCommentProfil<?php echo self::GROUP_STUDENT; ?>" class="col12 displayNone userCommentProfil">
|
<div id="userCommentProfil<?php echo self::GROUP_TUTOR; ?>" class="col12 displayNone userCommentProfil">
|
||||||
<?php echo template::textarea('useraddProfilComment' . self::GROUP_STUDENT, [
|
<?php echo template::textarea('useraddProfilComment' . self::GROUP_TUTOR, [
|
||||||
"value" => implode("\n",$module::$userProfilsComments[self::GROUP_STUDENT])
|
"value" => implode("\n",$module::$userProfilsComments[self::GROUP_TUTOR])
|
||||||
]);
|
]);
|
||||||
?>
|
?>
|
||||||
</div>
|
</div>
|
||||||
|
@ -116,8 +116,8 @@
|
|||||||
</div>
|
</div>
|
||||||
<div class="col6">
|
<div class="col6">
|
||||||
<div class="userEditGroupProfil displayNone"
|
<div class="userEditGroupProfil displayNone"
|
||||||
id="userEditGroupProfil<?php echo self::GROUP_STUDENT; ?>">
|
id="userEditGroupProfil<?php echo self::GROUP_TUTOR; ?>">
|
||||||
<?php echo template::select('userEditProfil' . self::GROUP_STUDENT, $module::$userProfils[self::GROUP_STUDENT], [
|
<?php echo template::select('userEditProfil' . self::GROUP_TUTOR, $module::$userProfils[self::GROUP_TUTOR], [
|
||||||
'label' => 'Profil',
|
'label' => 'Profil',
|
||||||
'selected' => $this->getData(['user', $this->getUrl(2), 'profil']),
|
'selected' => $this->getData(['user', $this->getUrl(2), 'profil']),
|
||||||
'disabled' => $this->getUser('group') !== self::GROUP_ADMIN,
|
'disabled' => $this->getUser('group') !== self::GROUP_ADMIN,
|
||||||
@ -135,10 +135,10 @@
|
|||||||
</div>
|
</div>
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col12">
|
<div class="col12">
|
||||||
<div id="userCommentProfil<?php echo self::GROUP_STUDENT; ?>"
|
<div id="userCommentProfil<?php echo self::GROUP_TUTOR; ?>"
|
||||||
class="col12 userCommentProfil">
|
class="col12 userCommentProfil">
|
||||||
<?php echo template::textarea('userEditProfilComment' . self::GROUP_STUDENT, [
|
<?php echo template::textarea('userEditProfilComment' . self::GROUP_TUTOR, [
|
||||||
"value" => implode("\n", $module::$userProfilsComments[self::GROUP_STUDENT]),
|
"value" => implode("\n", $module::$userProfilsComments[self::GROUP_TUTOR]),
|
||||||
'disabled' => $this->getUser('group') !== self::GROUP_ADMIN,
|
'disabled' => $this->getUser('group') !== self::GROUP_ADMIN,
|
||||||
]);
|
]);
|
||||||
?>
|
?>
|
||||||
|
@ -36,8 +36,8 @@ class blog extends common
|
|||||||
'option' => self::GROUP_TEACHER,
|
'option' => self::GROUP_TEACHER,
|
||||||
'delete' => self::GROUP_TEACHER,
|
'delete' => self::GROUP_TEACHER,
|
||||||
'edit' => self::GROUP_TEACHER,
|
'edit' => self::GROUP_TEACHER,
|
||||||
'index' => self::GROUP_VISITOR,
|
'index' => self::GROUP_STUDENT,
|
||||||
'rss' => self::GROUP_VISITOR
|
'rss' => self::GROUP_STUDENT
|
||||||
];
|
];
|
||||||
|
|
||||||
public static $articles = [];
|
public static $articles = [];
|
||||||
|
@ -27,7 +27,7 @@ class form extends common
|
|||||||
'data' => self::GROUP_TEACHER,
|
'data' => self::GROUP_TEACHER,
|
||||||
'delete' => self::GROUP_TEACHER,
|
'delete' => self::GROUP_TEACHER,
|
||||||
'deleteall' => self::GROUP_TEACHER,
|
'deleteall' => self::GROUP_TEACHER,
|
||||||
'index' => self::GROUP_VISITOR,
|
'index' => self::GROUP_STUDENT,
|
||||||
'export2csv' => self::GROUP_TEACHER,
|
'export2csv' => self::GROUP_TEACHER,
|
||||||
];
|
];
|
||||||
|
|
||||||
|
@ -53,7 +53,7 @@ class gallery extends common
|
|||||||
'add' => self::GROUP_TEACHER,
|
'add' => self::GROUP_TEACHER,
|
||||||
'theme' => self::GROUP_TEACHER,
|
'theme' => self::GROUP_TEACHER,
|
||||||
'option' => self::GROUP_TEACHER,
|
'option' => self::GROUP_TEACHER,
|
||||||
'index' => self::GROUP_VISITOR
|
'index' => self::GROUP_STUDENT
|
||||||
];
|
];
|
||||||
|
|
||||||
public static $sort = [
|
public static $sort = [
|
||||||
|
@ -28,8 +28,8 @@ class news extends common
|
|||||||
// paramétrage des news
|
// paramétrage des news
|
||||||
'delete' => self::GROUP_TEACHER,
|
'delete' => self::GROUP_TEACHER,
|
||||||
'edit' => self::GROUP_TEACHER,
|
'edit' => self::GROUP_TEACHER,
|
||||||
'index' => self::GROUP_VISITOR,
|
'index' => self::GROUP_STUDENT,
|
||||||
'rss' => self::GROUP_VISITOR
|
'rss' => self::GROUP_STUDENT
|
||||||
];
|
];
|
||||||
|
|
||||||
public static $news = [];
|
public static $news = [];
|
||||||
|
@ -22,7 +22,7 @@ class redirection extends common
|
|||||||
|
|
||||||
public static $actions = [
|
public static $actions = [
|
||||||
'config' => self::GROUP_TEACHER,
|
'config' => self::GROUP_TEACHER,
|
||||||
'index' => self::GROUP_VISITOR
|
'index' => self::GROUP_STUDENT
|
||||||
];
|
];
|
||||||
|
|
||||||
|
|
||||||
|
@ -25,7 +25,7 @@ class search extends common
|
|||||||
const DATADIRECTORY = self::DATA_DIR . 'search/';
|
const DATADIRECTORY = self::DATA_DIR . 'search/';
|
||||||
|
|
||||||
public static $actions = [
|
public static $actions = [
|
||||||
'index' => self::GROUP_VISITOR,
|
'index' => self::GROUP_STUDENT,
|
||||||
'config' => self::GROUP_TEACHER
|
'config' => self::GROUP_TEACHER
|
||||||
];
|
];
|
||||||
|
|
||||||
|
@ -24,7 +24,7 @@ class slider extends common
|
|||||||
'theme' => self::GROUP_MODERATOR,
|
'theme' => self::GROUP_MODERATOR,
|
||||||
'delete' => self::GROUP_MODERATOR,
|
'delete' => self::GROUP_MODERATOR,
|
||||||
'dirs' => self::GROUP_MODERATOR,
|
'dirs' => self::GROUP_MODERATOR,
|
||||||
'index' => self::GROUP_VISITOR
|
'index' => self::GROUP_STUDENT
|
||||||
];
|
];
|
||||||
|
|
||||||
const VERSION = '6.0';
|
const VERSION = '6.0';
|
||||||
|
11
notes.txt
11
notes.txt
@ -22,13 +22,10 @@ BDD contenant les informations sur le cours
|
|||||||
- 3 manuel, le prof inscrits
|
- 3 manuel, le prof inscrits
|
||||||
- enrolmentKey clé d'inscription, si non vide
|
- enrolmentKey clé d'inscription, si non vide
|
||||||
|
|
||||||
data/course/enrolment.json
|
data/enrolment.json
|
||||||
Détermine la liste des inscrits
|
Détermine la liste des inscrits
|
||||||
- userid
|
- userid
|
||||||
- userGroup
|
- lastPageId derrière page visitée
|
||||||
- userProfil
|
- lastDate date de la dernière vue
|
||||||
- lastPageId derrière page visitée
|
Le profil Zwii détermine le rôle de l'utilisateur
|
||||||
- lastDate date de la dernière vue
|
|
||||||
|
|
||||||
Règle de gestion :
|
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user