isConnected()) { return; } $pageTitle = _('Configurazione'); if (file_exists($docroot.'/include/custom/top.php')) { include_once $docroot.'/include/custom/top.php'; } else { include_once $docroot.'/include/top.php'; } // Controllo sull'esistenza di nuovi parametri di configurazione if (post('db_host') !== null) { $db_host = post('db_host'); $db_name = post('db_name'); $db_username = post('db_username'); $db_password = post('db_password'); $valid_config = isset($db_host) && isset($db_name) && isset($db_username) && isset($db_password); // Generazione di una nuova connessione al database $dbo = Database::getConnection(true); // Test della configurazione if (post('test') !== null) { ob_end_clean(); $state = 2; if ($dbo->isConnected()) { $requirements = [ 'SELECT', 'INSERT', 'UPDATE', 'CREATE', 'ALTER', 'DROP', 'CREATE VIEW', ]; $db_host = str_replace('_', '\_', $db_name); $db_name = str_replace('_', '\_', $db_name); $db_username = str_replace('_', '\_', $db_name); $user = " TO '".$db_username."'"; $db = ' ON `'.$db_name.'`.*'; $results = $dbo->fetchArray('SHOW GRANTS FOR CURRENT_USER'); foreach ($results as $result) { if ( str_contains($result, $find) && ( str_contains($result, $db) || str_contains($result, str_replace('`'.$db_name.'`', '*', $db)) ) ) { $pieces = explode(', ', explode(' ON ', str_replace('GRANT ', '', current($result)))[0]); if (in_array('ALL', $pieces) || in_array('ALL PRIVILEGES', $pieces)) { break; } foreach ($requirements as $key => $value) { if (!in_array($value, $pieces)) { $state = 1; break 2; } else { unset($requirements[$key]); } } } } } else { $state = 0; } echo $state; exit(); } // Salvataggio dei valori da salvare successivamente $_SESSION['osm_password'] = post('osm_password'); $_SESSION['osm_email'] = post('osm_email'); // Creazione della configurazione if ($dbo->isConnected()) { // Impostazioni di configurazione strettamente necessarie al funzionamento del progetto $backup_config = ' $db_host, '|username|' => $db_username, '|password|' => $db_password, '|database|' => $db_name, ]; $new_config = str_replace(array_keys($values), $values, $new_config); // Controlla che la scrittura del file di configurazione sia andata a buon fine $creation = file_put_contents('config.inc.php', $new_config); if (!$creation) { echo '

'._('Permessi di scrittura mancanti').'

'.str_replace('_FILE_', 'config.inc.php', _('Sembra che non ci siano i permessi di scrittura sul file _FILE_')).'

;
'._('Torna indietro').'

'.str_replace('_FILE_', 'config.inc.php', _('Inserire il seguente testo nel file _FILE_')).'

'.htmlentities($new_config).'
'; } // Continua con l'esecuzione delle operazioni previste else { redirect(ROOTDIR.'/index.php'); exit(); } } } // Controlla che i parametri di configurazione permettano l'accesso al database if ((file_exists('config.inc.php') || $valid_config) && !$dbo->isConnected()) { echo '

'._('Impossibile connettersi al database').'

'._("Si è verificato un'errore durante la connessione al database").'.

'._('Controllare di aver inserito correttamente i dati di accesso, e che il database atto ad ospitare i dati del gestionale sia esistente').'.

'._('Riprova').'
'; } // Visualizzazione dell'interfaccia di impostazione iniziale, nel caso il file di configurazione sia mancante oppure i paramentri non siano sufficienti if (empty($creation) && (!file_exists('config.inc.php') || !$valid_config)) { if (file_exists('config.inc.php')) { echo '

'._('Parametri non sufficienti!').'

'._("L'avvio del software è fallito a causa dell'assenza di alcuni paramentri nella configurazione di base").'.

'.str_replace('_CONFIG_', 'config.inc.php', _("Si prega di controllare che il file _CONFIG_ contenga tutti i dati inseriti durante la configurazione iniziale (con l'eccezione di password e indirizzo email amministrativi)")).'.

'._("Nel caso il problema persista, rivolgersi all'assistenza ufficiale").'.

'._('Riprova').'
'; } // Controlli per essere sicuro che l'utente abbia letto la licenza echo ' '; echo '
'._('OSM Logo').'

'._('OpenSTAManager').'

'; // REQUISITI PER IL CORRETTO FUNZIONAMENTO echo '

'._('Un benvenuto da OpenSTAManager!').'

'._("Prima di procedere alla configurazione e all'installazione del software, sono necessari alcuni accorgimenti per garantire il corretto funzionamento del gestionale").'.


'; // Estensioni di PHP echo '

'.str_replace('_FILE_', 'php.ini', _('Le seguenti estensioni PHP devono essere abilitate dal file di configurazione _FILE_')).':

'; $extensions = [ 'zip' => _("Necessario per l'utilizzo delle funzioni di aggiornamento automatico e backup, oltre che per eventuali moduli aggiuntivi"), 'pdo_mysql' => _('Necessario per la connessione al database'), 'openssl' => _('Utile per la generazione di chiavi complesse (non obbligatorio)'), ]; foreach ($extensions as $key => $value) { $check = extension_loaded($key); echo '

'.$key; if ($check) { echo ' '; } else { echo ' '; } echo '

'.$value.'

'; } echo '

'; // Impostazione di valore per PHP echo '

'.str_replace('_FILE_', 'php.ini', _('Le seguenti impostazioni PHP devono essere modificate nel file di configurazione _FILE_')).':

'; $values = [ 'display_errors' => true, 'upload_max_filesize' => '>16M', 'post_max_size' => '>16M', ]; foreach ($values as $key => $value) { $ini = str_replace(['k', 'M'], ['000', '000000'], ini_get($key)); $real = str_replace(['k', 'M'], ['000', '000000'], $value); if (starts_with($real, '>')) { $check = $ini >= substr($real, 1); } elseif (starts_with($real, '<')) { $check = $ini <= substr($real, 1); } else { $check = ($real == $ini); } if (is_bool($value)) { $value = !empty($value) ? 'On' : 'Off'; } else { $value = str_replace(['>', '<'], '', $value); } echo '

'.$key; if ($check) { echo ' '; } else { echo ' '; } echo '

'._('Valore consigliato').': '.$value.'

'; } echo '

'; // Percorsi necessari echo '

'._('Le seguenti cartelle devono risultare scrivibili da parte del gestionale').':

'; $dirs = [ 'backup' => _('Necessario per il salvataggio dei backup'), 'files' => _('Necessario per il salvataggio di file inseriti dagli utenti'), 'logs' => _('Necessario per la gestione dei file di log'), ]; foreach ($dirs as $key => $value) { $check = is_writable($docroot.DIRECTORY_SEPARATOR.$key); echo '

'.$key; if ($check) { echo ' '; } else { echo ' '; } echo '

'.$value.'

'; } echo '

'; // LICENZA echo '

'.str_replace('_LICENSE_', 'GPL 3.0', _('OpenSTAManager è tutelato dalla licenza _LICENSE_!')).'

'._('Accetti la licenza GPLv3 di OpenSTAManager?').'*


[ '._('Versioni tradotte').' ]

'; $host = !empty($db_host) ? $db_host : ''; $username = !empty($db_username) ? $db_username : ''; $password = !empty($db_password) ? $db_password : ''; $name = !empty($db_name) ? $db_name : ''; $osm_password = !empty($_SESSION['osm_password']) ? $_SESSION['osm_password'] : ''; $osm_email = !empty($_SESSION['osm_email']) ? $_SESSION['osm_email'] : ''; // PARAMETRI echo '
'._('Aiuto').'

'._('Non hai ancora configurato OpenSTAManager').'.

'.str_replace('_CONFIG_', 'config.inc.php', _('Configura correttamente il software con i seguenti parametri (modificabili successivamente dal file _CONFIG_)')).'

'; // Form dei parametri echo '
'; // db_host echo '
{[ "type": "text", "label": "'._('Host del database').'", "name": "db_host", "placeholder": "'._("Indirizzo dell'host del database").'", "value": "'.$host.'", "help": "'._('Esempio').': localhost", "show-help": 1, "required": 1 ]}
'; // db_username echo '
{[ "type": "text", "label": "'._("Username dell'utente MySQL").'", "name": "db_username", "placeholder": "'._("Username dell'utente MySQL").'", "value": "'.$username.'", "help": "'._('Esempio').': root", "show-help": 1, "required": 1 ]}
'; // db_password echo '
{[ "type": "password", "label": "'._("Password dell'utente MySQL").'", "name": "db_password", "placeholder": "'._("Password dell'utente MySQL").'", "value": "'.$password.'", "help": "'._('Esempio').': mysql", "show-help": 1 ]}
'; // db_name echo '
{[ "type": "text", "label": "'._('Nome del database').'", "name": "db_name", "placeholder": "'._('Nome del database').'", "value": "'.$name.'", "help": "'._('Esempio').': openstamanager", "show-help": 1, "required": 1 ]}
'; // Password utente admin echo '
{[ "type": "password", "label": "'._("Password dell'amministratore").'", "name": "osm_password", "placeholder": "'._('Scegli la password di amministratore').'", "value": "'.$osm_password.'", "help": "'._('Valore di default').': admin", "show-help": 1 ]}
'; // Email utente admin echo '
{[ "type": "email", "label": "'._("Email dell'amministratore").'", "name": "osm_email", "placeholder": "'._("Digita l'indirizzo email dell'amministratore").'", "value": "'.$osm_email.'" ]}
'; echo ' '; echo '
*'._('Campi obbligatori').'
'; } if (file_exists($docroot.'/include/custom/bottom.php')) { include_once $docroot.'/include/custom/bottom.php'; } else { include_once $docroot.'/include/bottom.php'; } exit();