1
0
mirror of https://github.com/devcode-it/openstamanager.git synced 2025-01-22 12:00:19 +01:00
openstamanager/src/App.php

505 lines
14 KiB
PHP
Raw Normal View History

<?php
/**
* Classe per la gestione delle utenze.
*
* @since 2.4
*/
class App
{
2018-06-26 16:33:15 +02:00
/** @var array Identificativo del modulo corrente */
protected static $current_module;
/** @var int Identificativo dell'elemento corrente */
protected static $current_element;
/** @var \Util\Messages Gestione dei messaggi flash */
protected static $flash = null;
2018-07-03 15:39:29 +02:00
/** @var bool Stato di debug */
protected static $config = [];
2018-06-26 16:33:15 +02:00
/** @var array Elenco degli assets del progetto */
protected static $assets = [
// CSS
'css' => [
'app.min.css',
'style.min.css',
'themes.min.css',
2018-06-23 15:41:32 +02:00
],
// Print CSS
'print' => [
'print.min.css',
],
// JS
'js' => [
'app.min.js',
'custom.min.js',
'i18n/parsleyjs/|lang|.min.js',
'i18n/select2/|lang|.min.js',
'i18n/moment/|lang|.min.js',
'i18n/fullcalendar/|lang|.min.js',
],
];
/**
* Restituisce il modulo attualmente in utilizzo.
*
2018-06-26 16:33:15 +02:00
* @return array
*/
public static function getCurrentModule()
{
2018-06-23 18:35:08 +02:00
$id = filter('id_module');
if (empty(self::$current_module) && !empty($id)) {
self::$current_module = Modules::get($id);
}
return self::$current_module;
}
/**
* Restituisce l'identificativo dell'elemento attualmente in utilizzo.
*
* @return int
*/
public static function getCurrentElement()
{
if (empty(self::$current_element)) {
2018-06-26 16:33:15 +02:00
self::$current_element = intval(filter('id_record'));
}
return self::$current_element;
}
/**
* Restituisce la configurazione di default del progetto.
*
* @return array
*/
protected static function getDefaultConfig()
{
if (file_exists(DOCROOT.'/config.example.php')) {
include DOCROOT.'/config.example.php';
}
2018-07-03 15:39:29 +02:00
$db_host = '';
$db_username = '';
$db_password = '';
$db_name = '';
$port = '';
return get_defined_vars();
}
/**
* Restituisce la configurazione dell'installazione in utilizzo del progetto.
*
* @return array
*/
public static function getConfig()
{
2018-07-03 15:39:29 +02:00
if (empty(self::$config['db_host'])) {
if (file_exists(DOCROOT.'/config.inc.php')) {
include DOCROOT.'/config.inc.php';
2018-07-03 15:39:29 +02:00
$config = get_defined_vars();
} else {
$config = [];
}
2018-07-03 15:39:29 +02:00
$defaultConfig = self::getDefaultConfig();
2018-07-03 15:39:29 +02:00
$result = array_merge($defaultConfig, $config);
2018-03-02 19:01:30 +01:00
2018-07-03 15:39:29 +02:00
// Operazioni di normalizzazione sulla configurazione
$result['debug'] = isset(self::$config['debug']) ? self::$config['debug'] : !empty($result['debug']);
self::$config = $result;
}
return self::$config;
}
/**
* Imposta e restituisce lo stato di debug del progetto.
*
* @param bool $value
*
* @return bool
*/
public static function debug($value = null)
{
if (is_bool($value)) {
self::$config['debug'] = $value;
}
2018-03-02 19:01:30 +01:00
if (!isset(self::$config['debug'])) {
App::getConfig();
}
2018-07-03 15:39:29 +02:00
return self::$config['debug'];
}
/**
* Restituisce l'oggetto dedicato alla gestione dei messaggi per l'utente.
*
* @return \Util\Messages
*/
public static function flash()
{
if (empty(self::$flash)) {
$storage = null;
self::$flash = new \Util\Messages($storage, 'messages');
}
return self::$flash;
}
/**
* Individua i percorsi di base necessari per il funzionamento del gestionale.
* <b>Attenzione<b>: questo metodo deve essere eseguito all'interno di un file nella cartella principale del progetto per permettere il corretto funzionamento degli URL.
*
* @return array
*/
public static function definePaths($docroot)
{
if (!defined('DOCROOT')) {
// Individuazione di $rootdir
$rootdir = substr($_SERVER['SCRIPT_NAME'], 0, strrpos($_SERVER['SCRIPT_NAME'], '/')).'/';
if (strrpos($rootdir, '/'.basename($docroot).'/') !== false) {
$rootdir = substr($rootdir, 0, strrpos($rootdir, '/'.basename($docroot).'/')).'/'.basename($docroot);
} else {
$rootdir = '/';
}
$rootdir = rtrim($rootdir, '/');
$rootdir = str_replace('%2F', '/', rawurlencode($rootdir));
// Individuazione di $baseurl
$baseurl = (isHTTPS(true) ? 'https' : 'http').'://'.$_SERVER['HTTP_HOST'].$rootdir;
// Impostazione delle variabili globali
define('DOCROOT', $docroot);
define('ROOTDIR', $rootdir);
define('BASEURL', $baseurl);
}
}
/**
* Individua i percorsi principali del progetto.
*
* @return array
*/
public static function getPaths()
{
$assets = ROOTDIR.'/assets/dist';
return [
'assets' => $assets,
'css' => $assets.'/css',
'js' => $assets.'/js',
'img' => $assets.'/img',
];
}
/**
* Restituisce l'elenco degli assets del progetto.
*
* @return array
*/
public static function getAssets()
{
// Assets aggiuntivi
$config = self::getConfig();
// Impostazione dei percorsi
$paths = self::getPaths();
$lang = Translator::getInstance()->getCurrentLocale();
2018-06-23 15:41:32 +02:00
// Sezioni: nome - percorso
$sections = [
'css' => 'css',
'print' => 'css',
'js' => 'js',
];
2018-06-23 15:41:32 +02:00
$assets = [];
2018-06-23 15:41:32 +02:00
foreach ($sections as $section => $dir) {
$result = array_unique(array_merge(self::$assets[$section], $config['assets'][$section]));
2018-06-23 15:41:32 +02:00
foreach ($result as $key => $element) {
$element = $paths[$dir].'/'.$element;
$element = str_replace('|lang|', $lang, $element);
2018-06-23 15:41:32 +02:00
$result[$key] = $element;
}
2018-06-23 15:41:32 +02:00
$assets[$section] = $result;
}
// JS aggiuntivi per gli utenti connessi
if (Auth::check()) {
2018-06-23 15:41:32 +02:00
$assets['js'][] = ROOTDIR.'/lib/functions.js';
$assets['js'][] = ROOTDIR.'/lib/init.js';
}
2018-06-23 15:41:32 +02:00
return $assets;
}
/**
* Restituisce un'insieme di array comprendenti le informazioni per la costruzione della query del modulo indicato.
*
2018-06-26 16:33:15 +02:00
* @param array $element
*
* @return array
*/
public static function readQuery($element)
{
if (str_contains($element['option'], '|select|')) {
$result = self::readNewQuery($element);
} else {
$result = self::readOldQuery($element);
}
return $result;
}
/**
* Interpreta lo standard modulare per l'individuazione delle query di un modulo/plugin del progetto.
*
* @param array $element
*
* @return array
*/
protected static function readNewQuery($element)
{
$fields = [];
$summable = [];
$search_inside = [];
$search = [];
2018-06-26 16:33:15 +02:00
$format = [];
$slow = [];
$order_by = [];
$query = $element['option'];
$views = self::getViews($element);
$select = [];
foreach ($views as $view) {
$select[] = $view['query'].(!empty($view['name']) ? " AS '".$view['name']."'" : '');
if (!empty($view['visible'])) {
$view['name'] = trim($view['name']);
$view['search_inside'] = trim($view['search_inside']);
$view['order_by'] = trim($view['order_by']);
$fields[] = trim($view['name']);
2018-07-14 13:34:00 +02:00
$search_inside[] = !empty($view['search_inside']) ? $view['search_inside'] : '`'.$view['name'].'`';
2018-02-22 12:35:22 +01:00
$order_by[] = !empty($view['order_by']) ? $view['order_by'] : '`'.$view['name'].'`';
$search[] = $view['search'];
$slow[] = $view['slow'];
$format[] = $view['format'];
if ($view['summable']) {
$summable[] = 'SUM(`'.trim($view['name']."`) AS 'sum_".(count($fields) - 1)."'");
}
}
}
$select = empty($select) ? '*' : implode(', ', $select);
$query = str_replace('|select|', $select, $query);
return [
2018-02-17 14:32:40 +01:00
'query' => self::replacePlaceholder($query),
'fields' => $fields,
'search_inside' => $search_inside,
'order_by' => $order_by,
'search' => $search,
'slow' => $slow,
'format' => $format,
'summable' => $summable,
];
}
/**
* Interpreta lo standard JSON per l'individuazione delle query di un modulo/plugin del progetto.
*
* @param array $element
*
* @return array
*/
protected static function readOldQuery($element)
{
$options = str_replace(["\r", "\n", "\t"], ' ', $element['option']);
$options = json_decode($options, true);
$options = $options['main_query'][0];
2018-03-02 19:01:30 +01:00
$fields = [];
$order_by = [];
$search = [];
$slow = [];
$format = [];
$query = $options['query'];
2018-03-02 19:01:30 +01:00
$views = explode(',', $options['fields']);
foreach ($views as $view) {
$fields[] = trim($view);
$order_by[] = '`'.trim($view).'`';
$search[] = 1;
$slow[] = 0;
$format[] = 0;
}
2018-07-14 13:34:00 +02:00
$search_inside = $order_by;
return [
2018-02-17 14:32:40 +01:00
'query' => self::replacePlaceholder($query),
'fields' => $fields,
'search_inside' => $search_inside,
'order_by' => $order_by,
'search' => $search,
'slow' => $slow,
'format' => $format,
'summable' => [],
];
}
/**
* Restituisce le singole componenti delle query per un determinato modulo/plugin.
*
* @param array $element
*
* @return array
*/
protected static function getViews($element)
{
$database = Database::getConnection();
$user = Auth::user();
$views = $database->fetchArray('SELECT * FROM `zz_views` WHERE `id_module`='.prepare($element['id']).' AND
`id` IN (
SELECT `id_vista` FROM `zz_group_view` WHERE `id_gruppo`=(
SELECT `idgruppo` FROM `zz_users` WHERE `id`='.prepare($user['id']).'
))
ORDER BY `order` ASC');
return $views;
}
/**
* Sostituisce i valori previsti all'interno delle query di moduli/plugin.
*
* @param string $query
* @param int $custom
*
* @return string
*/
public static function replacePlaceholder($query, $custom = null)
{
2018-03-22 15:40:20 +01:00
$id_module = filter('id_module');
$user = Auth::user();
2018-02-17 14:32:40 +01:00
// Sostituzione degli identificatori
$id = empty($custom) ? $user['idanagrafica'] : $custom;
$query = str_replace(['|idagente|', '|idtecnico|', '|idanagrafica|'], prepare($id), $query);
2018-02-17 14:32:40 +01:00
// Sostituzione delle date
$query = str_replace(['|period_start|', '|period_end|'], [$_SESSION['period_start'], $_SESSION['period_end']], $query);
2018-03-21 19:33:33 +01:00
// Sostituzione dei segmenti
$query = str_replace('|segment|', !empty($_SESSION['module_'.$id_module]['id_segment']) ? ' AND id_segment = '.prepare($_SESSION['module_'.$id_module]['id_segment']) : '', $query);
// Sostituzione dei formati
$patterns = formatter()->getSQLPatterns();
$replace = [];
foreach ($patterns as $key => $value) {
$replace['|'.$key.'_format|'] = "'".$value."'";
}
$query = replace($query, $replace);
2018-03-22 15:40:20 +01:00
return $query;
}
/**
* Restituisce il codice HTML per il form contenente il file indicato.
*
* @param string $path
* @param array $result
* @param array $options
*
* @return string
*/
public static function load($file, $result, $options)
{
$form = self::internalLoad('form.php', $result, $options);
$response = self::internalLoad($file, $result, $options);
$form = str_replace('|response|', $response, $form);
return $form;
}
/**
* Restituisce il codice HTML generato del file indicato.
*
* @param string $path
* @param array $result
* @param array $options
* @param string $directory
*
* @return string
*/
protected static function internalLoad($file, $result, $options, $directory = null)
{
$module = self::getCurrentModule();
$id_module = filter('id_module');
$id_record = filter('id_record');
$directory = empty($directory) ? 'include|custom|/common/' : $directory;
ob_start();
include self::filepath($directory, $file);
$response = ob_get_clean();
return $response;
}
2018-06-26 09:41:43 +02:00
/**
* Individua il percorso per il file da includere considerando gli eventuali custom.
*
* @param string $path
* @param string $file
2018-06-26 09:41:43 +02:00
*
* @return string|null
*/
public static function filepath($path, $file = null)
{
$path = str_contains($path, DOCROOT) ? $path : DOCROOT.'/'.ltrim($path, '/');
$path = empty($file) ? $path : rtrim($path, '/').'/'.$file;
$original_file = str_replace('|custom|', '', $path);
$custom_file = str_replace('|custom|', '/custom', $path);
2018-06-26 16:33:15 +02:00
$result = '';
2018-06-26 09:41:43 +02:00
if (file_exists($custom_file)) {
$result = $custom_file;
} elseif (file_exists($original_file)) {
$result = $original_file;
}
return slashes($result);
2018-06-26 09:41:43 +02:00
}
}