NxTIC/index.php

124 lines
3.3 KiB
PHP
Raw Normal View History

<?php define('__ROOT__', dirname(__FILE__) );
require_once __ROOT__.'/manager/autoloader.php';
use \router\Router;
use \manager\ResourceDispatcher;
use \manager\ModuleRequest;
use \manager\ManagerError;
use \manager\Database;
use \manager\MenuManager;
/*******************************************/
/* DEBUGGER */
/*******************************************/
debug();
/*******************************************/
2016-06-02 16:52:12 +00:00
define('__REDIRECT__', 'Location: /dashboard/');
/* [x] Gestion des utilisateurs
=========================================================*/
/* (1) Valeurs par defaut */
if( !isset($_SESSION['userid']) ) $_SESSION['userid'] = null;
if( !isset($_SESSION['username']) ) $_SESSION['username'] = null;
if( !isset($_SESSION['permission']) ) $_SESSION['permission'] = array();
/* (2) Gestion de la connection */
2016-04-13 13:20:57 +00:00
$login_vars = isset($_POST['login-sub']);
2016-04-17 16:01:23 +00:00
$login_vars = $login_vars && isset($_POST['login']) && Database::check('varchar(3,50)', $_POST['login']);
$login_vars = $login_vars && isset($_POST['password']) && Database::check('text', $_POST['password']);
// Status de login
$_SESSION['login_status'] = 'no';
// Si les parametres de connection, on essaie de connecter
if( $login_vars ){
2016-04-17 16:01:23 +00:00
$login = new ModuleRequest('user/login', array( 'login' => $_POST['login'], 'password' => $_POST['password'] ));
$login_ans = $login->dispatch();
2016-06-02 16:52:12 +00:00
// Si aucune erreur, on dit qu'on vient de se connecter
if( $login_ans->error == ManagerError::Success )
$_SESSION['login_status'] = 'logged';
else // Si on n'a pas les bonnes donnees
$_SESSION['login_status'] = 'error';
}
2016-04-04 12:04:36 +00:00
/* (3) Gestion de le deconnexion */
2016-04-13 13:20:57 +00:00
$logout_vars = isset($_POST['logout-sub']);
2016-06-02 16:52:12 +00:00
// Si on se deconnecte
2016-04-13 13:20:57 +00:00
if( $logout_vars ){
$logout = new ModuleRequest('user/logout');
2016-04-13 13:20:57 +00:00
$logout_ans = $logout->dispatch();
// Si aucune erreur, on dit qu'on vient de se deconnecter
if( $logout_ans->error == ManagerError::Success )
$_SESSION['login_status'] = 'unlogged';
}
2016-04-17 16:01:23 +00:00
/* [0] On initialise le routeur
===================================================*/
$R = new Router( $_GET['url'] );
/* [1] On cree les regles de routage
===================================================*/
// Racine -> page d'accueil
2016-06-02 16:52:12 +00:00
$R->get('/?', function(){ header(__REDIRECT__); });
2016-04-04 12:04:36 +00:00
/* [2] On recupere la liste des pages du site
=========================================================*/
$temporaryMenuInflater = new MenuManager();
$views = $temporaryMenuInflater->getCategories();
2016-04-04 12:04:36 +00:00
// nomPage/arg1/arg2 -> inclusion de la page
2016-04-04 12:04:36 +00:00
$R->get('(?:'.implode('|', $views).')(?:/[\w-]+)*/?', function(){ include __ROOT__.'/view.php'; });
// Dispatcher
2016-04-04 12:04:36 +00:00
$R->get('f(?:/([\w-]+))*/?', function(){ new ResourceDispatcher($_GET['url'], true); });
// Api
$R->post('api(?:/(.*))?', function($url){
$request = ModuleRequest::fromPost($url, $_POST);
$answer = $request->dispatch();
// Si c'est une réponse
if( $answer instanceof ModuleResponse )
echo $answer->serialize();
});
// N'importe -> page d'accueil
2016-06-02 16:52:12 +00:00
$R->get('.+', function(){ header(__REDIRECT__); });
$R->post('.+', function(){ header(__REDIRECT__); });
2016-04-04 12:04:36 +00:00
/* [3] On lance le routeur
===================================================*/
$R->run();
?>