86 lines
2.2 KiB
PHP
Executable File
86 lines
2.2 KiB
PHP
Executable File
<?php
|
|
/**
|
|
* Page des events
|
|
*/
|
|
class events extends Controller
|
|
{
|
|
/**
|
|
* Cette fonction est appelée avant toute les autres :
|
|
* Elle vérifie que l'utilisateur est bien connecté
|
|
* @return void;
|
|
*/
|
|
public function before()
|
|
{
|
|
internalTools::verifyConnect();
|
|
}
|
|
|
|
/**
|
|
* Cette fonction est alias de showAll()
|
|
*/
|
|
public function byDefault()
|
|
{
|
|
$this->showAll();
|
|
}
|
|
|
|
/**
|
|
* Cette fonction retourne tous les événements, sous forme d'un tableau permettant l'administration de ces événements
|
|
* @param int $page : La page à consulter. Par défaut 0
|
|
* @return void;
|
|
*/
|
|
public function showAll($page = 0)
|
|
{
|
|
//Creation de l'object de base de données
|
|
global $db;
|
|
|
|
$page = (int)($page < 0 ? $page = 0 : $page);
|
|
$limit = 25;
|
|
$offset = $limit * $page;
|
|
|
|
//Récupération des évènements triés par date, du plus récent au plus ancien, par paquets de $limit, en ignorant les $offset premiers
|
|
$events = $db->getFromTableWhere('events', [], 'at', true, $limit, $offset);
|
|
|
|
$this->render('events/showAll', array(
|
|
'events' => $events,
|
|
'page' => $page,
|
|
'limit' => $limit,
|
|
'nbResults' => count($events),
|
|
));
|
|
}
|
|
|
|
/**
|
|
* Cette fonction supprimer une liste de sms reçus
|
|
* @param $csrf : Le jeton CSRF
|
|
* @param int... $ids : Les id des sms à supprimer
|
|
* @return boolean;
|
|
*/
|
|
public function delete($csrf)
|
|
{
|
|
//On vérifie que le jeton csrf est bon
|
|
if (!internalTools::verifyCSRF($csrf))
|
|
{
|
|
$_SESSION['errormessage'] = 'Jeton CSRF invalide !';
|
|
header('Location: ' . $this->generateUrl('events'));
|
|
return false;
|
|
}
|
|
|
|
//On récupère les ids comme étant tous les arguments de la fonction et on supprime le premier (csrf)
|
|
$ids = func_get_args();
|
|
unset($ids[0]);
|
|
|
|
//Create de l'object de base de données
|
|
global $db;
|
|
|
|
//Si on est pas admin
|
|
if (!$_SESSION['admin'])
|
|
{
|
|
$_SESSION['errormessage'] = 'Vous devez être administrateur pour effectuer cette action.';
|
|
header('Location: ' . $this->generateUrl('events'));
|
|
return false;
|
|
}
|
|
|
|
$db->deleteEventsIn($ids);
|
|
header('Location: ' . $this->generateUrl('events'));
|
|
return true;
|
|
}
|
|
}
|