mirror of
https://github.com/devcode-it/openstamanager.git
synced 2025-01-01 10:37:31 +01:00
fdad40cb2b
Generalizzazione della gestione delle query di Moduli e Plugin. Miglioramento della gestione degli assets (ora gestiti dalla classe App e personalizzabili nella configurazione). Miglioramento del nome della gestione di alcune variabili, con relativa individuazione (classe App). Rimozione codice deprecato nel core.
221 lines
7.2 KiB
PHP
221 lines
7.2 KiB
PHP
<?php
|
|
|
|
// Impostazioni per la corretta interpretazione di UTF-8
|
|
header('Content-Type: text/html; charset=UTF-8');
|
|
ob_start();
|
|
|
|
// Impostazioni di configurazione PHP
|
|
date_default_timezone_set('Europe/Rome');
|
|
|
|
// Caricamento delle impostazioni personalizzabili
|
|
if (file_exists(__DIR__.'/config.inc.php')) {
|
|
include_once __DIR__.'/config.inc.php';
|
|
}
|
|
|
|
// Caricamento delle dipendenze e delle librerie del progetto
|
|
require_once __DIR__.'/vendor/autoload.php';
|
|
|
|
// Individuazione dei percorsi di base
|
|
App::definePaths(__DIR__);
|
|
|
|
$docroot = DOCROOT;
|
|
$rootdir = ROOTDIR;
|
|
$baseurl = BASEURL;
|
|
|
|
// Redirect al percorso HTTPS se impostato nella configurazione
|
|
if (!empty($redirectHTTPS) && !isHTTPS(true)) {
|
|
header('HTTP/1.1 301 Moved Permanently');
|
|
header('Location: https://'.$_SERVER['HTTP_HOST'].$_SERVER['REQUEST_URI']);
|
|
exit();
|
|
}
|
|
|
|
// Forzamento del debug
|
|
// $debug = true;
|
|
|
|
// Logger per la segnalazione degli errori
|
|
$logger = new Monolog\Logger('Logs');
|
|
$logger->pushProcessor(new Monolog\Processor\UidProcessor());
|
|
$logger->pushProcessor(new Monolog\Processor\WebProcessor());
|
|
|
|
// Registrazione globale del logger
|
|
Monolog\Registry::addLogger($logger, 'logs');
|
|
|
|
use Monolog\Handler\StreamHandler;
|
|
use Monolog\Handler\FilterHandler;
|
|
use Monolog\Handler\RotatingFileHandler;
|
|
|
|
$handlers = [];
|
|
if (!API::isAPIRequest()) {
|
|
// File di log di base (logs/error.log)
|
|
$handlers[] = new StreamHandler($docroot.'/logs/error.log', Monolog\Logger::ERROR);
|
|
$handlers[] = new StreamHandler($docroot.'/logs/setup.log', Monolog\Logger::EMERGENCY);
|
|
|
|
// Impostazione dei log estesi (per monitorare in modo completo le azioni degli utenti)
|
|
$handlers[] = new StreamHandler($docroot.'/logs/info.log', Monolog\Logger::INFO);
|
|
|
|
// Impostazioni di debug
|
|
if (!empty($debug)) {
|
|
// Ignoramento degli avvertimenti e delle informazioni relative alla deprecazione di componenti
|
|
error_reporting(E_ALL & ~E_WARNING & ~E_NOTICE & ~E_USER_DEPRECATED);
|
|
|
|
// File di log ordinato in base alla data
|
|
$handlers[] = new RotatingFileHandler($docroot.'/logs/error.log', 0, Monolog\Logger::ERROR);
|
|
$handlers[] = new RotatingFileHandler($docroot.'/logs/setup.log', 0, Monolog\Logger::EMERGENCY);
|
|
|
|
$prettyPageHandler = new Whoops\Handler\PrettyPageHandler();
|
|
|
|
// Imposta Whoops come gestore delle eccezioni di default
|
|
$whoops = new Whoops\Run();
|
|
$whoops->pushHandler($prettyPageHandler);
|
|
|
|
// Abilita la gestione degli errori nel caso la richiesta sia di tipo AJAX
|
|
if (Whoops\Util\Misc::isAjaxRequest()) {
|
|
$whoops->pushHandler(new Whoops\Handler\JsonResponseHandler());
|
|
}
|
|
|
|
$whoops->register();
|
|
}
|
|
} else {
|
|
$handlers[] = new StreamHandler($docroot.'/logs/api.log', Monolog\Logger::ERROR);
|
|
}
|
|
|
|
// Disabilita la segnalazione degli errori (se il debug è disabilitato)
|
|
if (empty($debug)) {
|
|
error_reporting(0);
|
|
}
|
|
|
|
// Imposta il formato di salvataggio dei log
|
|
$monologFormatter = new Monolog\Formatter\LineFormatter('[%datetime%] %channel%.%level_name%: %message%'.PHP_EOL.'%extra% '.PHP_EOL);
|
|
foreach ($handlers as $handler) {
|
|
$handler->setFormatter($monologFormatter);
|
|
$logger->pushHandler(new FilterHandler($handler, [$handler->getLevel()]));
|
|
}
|
|
|
|
// Imposta Monolog come gestore degli errori
|
|
Monolog\ErrorHandler::register($logger);
|
|
|
|
// Istanziamento del gestore delle traduzioni del progetto
|
|
$lang = !empty($lang) ? $lang : 'it';
|
|
$formatter = !empty($formatter) ? $formatter : [];
|
|
$translator = Translator::getInstance();
|
|
$translator->addLocalePath($docroot.'/locale');
|
|
$translator->addLocalePath($docroot.'/modules/*/locale');
|
|
$translator->setLocale($lang, $formatter);
|
|
|
|
// Individuazione di versione e revisione del progetto
|
|
$version = Update::getVersion();
|
|
$revision = Update::getRevision();
|
|
|
|
// Inizializzazione della sessione
|
|
if (!API::isAPIRequest()) {
|
|
session_set_cookie_params(0, $rootdir);
|
|
session_start();
|
|
}
|
|
|
|
$dbo = Database::getConnection();
|
|
|
|
// Controllo sulla presenza dei permessi di accesso basilari
|
|
$continue = $dbo->isInstalled() && !Update::isUpdateAvailable() && (Auth::check() || API::isAPIRequest());
|
|
|
|
if (!$continue && getURLPath() != slashes(ROOTDIR.'/index.php')) {
|
|
if (Auth::check()) {
|
|
Auth::logout();
|
|
}
|
|
|
|
redirect(ROOTDIR.'/index.php');
|
|
exit();
|
|
}
|
|
|
|
// Operazione aggiuntive (richieste non API)
|
|
if (!API::isAPIRequest()) {
|
|
/*
|
|
// Controllo CSRF
|
|
if(!CSRF::getInstance()->validate()){
|
|
die(tr('Constrollo CSRF fallito!'));
|
|
}*/
|
|
|
|
// Aggiunta del wrapper personalizzato per la generazione degli input
|
|
if (!empty($HTMLWrapper)) {
|
|
HTMLBuilder\HTMLBuilder::setWrapper($HTMLWrapper);
|
|
}
|
|
|
|
// Aggiunta dei gestori personalizzati per la generazione degli input
|
|
foreach ((array) $HTMLHandlers as $key => $value) {
|
|
HTMLBuilder\HTMLBuilder::setHandler($key, $value);
|
|
}
|
|
|
|
// Aggiunta dei gestori per componenti personalizzate
|
|
foreach ((array) $HTMLManagers as $key => $value) {
|
|
HTMLBuilder\HTMLBuilder::setManager($key, $value);
|
|
}
|
|
|
|
// Registrazione globale del template per gli input HTML
|
|
register_shutdown_function('translateTemplate');
|
|
|
|
// Impostazione della sessione di base
|
|
$_SESSION['infos'] = array_unique((array) $_SESSION['infos']);
|
|
$_SESSION['warnings'] = array_unique((array) $_SESSION['warnings']);
|
|
$_SESSION['errors'] = array_unique((array) $_SESSION['errors']);
|
|
|
|
// Imposto il periodo di visualizzazione dei record dal 01-01-yyy al 31-12-yyyy
|
|
if (!empty($_GET['period_start'])) {
|
|
$_SESSION['period_start'] = $_GET['period_start'];
|
|
$_SESSION['period_end'] = $_GET['period_end'];
|
|
} elseif (!isset($_SESSION['period_start'])) {
|
|
$_SESSION['period_start'] = date('Y').'-01-01';
|
|
$_SESSION['period_end'] = date('Y').'-12-31';
|
|
}
|
|
|
|
// Impostazione del tema grafico di default
|
|
$theme = !empty($theme) ? $theme : 'default';
|
|
|
|
$assets = App::getAssets();
|
|
|
|
// CSS di base del progetto
|
|
$css_modules = $assets['css'];
|
|
|
|
// JS di base del progetto
|
|
$jscript_modules = $assets['js'];
|
|
|
|
if ($continue) {
|
|
// Istanziamento della barra di debug
|
|
if (!empty($debug)) {
|
|
$debugbar = new DebugBar\DebugBar();
|
|
|
|
$debugbar->addCollector(new DebugBar\DataCollector\MemoryCollector());
|
|
$debugbar->addCollector(new DebugBar\DataCollector\PhpInfoCollector());
|
|
|
|
$debugbar->addCollector(new DebugBar\DataCollector\RequestDataCollector());
|
|
$debugbar->addCollector(new DebugBar\DataCollector\TimeDataCollector());
|
|
|
|
$debugbar->addCollector(new DebugBar\Bridge\MonologCollector($logger));
|
|
$debugbar->addCollector(new DebugBar\DataCollector\PDO\PDOCollector($dbo->getPDO()));
|
|
}
|
|
|
|
$id_module = filter('id_module');
|
|
$id_record = filter('id_record');
|
|
$id_plugin = filter('id_plugin');
|
|
$id_parent = filter('id_parent');
|
|
|
|
$user = Auth::user();
|
|
|
|
if (!empty($id_module)) {
|
|
$module = Modules::get($id_module);
|
|
|
|
$pageTitle = $module['title'];
|
|
|
|
Permissions::addModule($id_module);
|
|
}
|
|
|
|
if (!empty($skip_permissions)) {
|
|
Permissions::skip();
|
|
}
|
|
|
|
Permissions::check();
|
|
}
|
|
|
|
// Variabili GET e POST
|
|
$post = Filter::getPOST();
|
|
$get = Filter::getGET();
|
|
}
|