2014-09-29 14:23:42 +02:00
|
|
|
<?php
|
|
|
|
// {{{ICINGA_LICENSE_HEADER}}}
|
|
|
|
// {{{ICINGA_LICENSE_HEADER}}}
|
|
|
|
|
|
|
|
namespace Icinga\Application;
|
|
|
|
|
2014-10-06 16:49:29 +02:00
|
|
|
use Exception;
|
|
|
|
use Zend_Config;
|
2014-10-06 09:30:51 +02:00
|
|
|
use PDOException;
|
|
|
|
use Icinga\Web\Setup\DbTool;
|
2014-10-07 17:08:50 +02:00
|
|
|
use Icinga\Application\Icinga;
|
2014-10-06 09:30:51 +02:00
|
|
|
use Icinga\Application\Config;
|
2014-09-29 14:23:42 +02:00
|
|
|
use Icinga\Web\Setup\Installer;
|
2014-10-08 10:26:12 +02:00
|
|
|
use Icinga\Data\ResourceFactory;
|
2014-10-06 16:49:29 +02:00
|
|
|
use Icinga\Config\PreservingIniWriter;
|
2014-10-08 10:26:12 +02:00
|
|
|
use Icinga\Authentication\Backend\DbUserBackend;
|
2014-09-29 14:23:42 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Icinga Web 2 Installer
|
|
|
|
*/
|
|
|
|
class WebInstaller implements Installer
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* The setup wizard's page data
|
|
|
|
*
|
|
|
|
* @var array
|
|
|
|
*/
|
|
|
|
protected $pageData;
|
|
|
|
|
2014-10-06 16:49:29 +02:00
|
|
|
/**
|
|
|
|
* The report entries
|
|
|
|
*
|
|
|
|
* @var array
|
|
|
|
*/
|
|
|
|
protected $report;
|
|
|
|
|
2014-09-29 14:23:42 +02:00
|
|
|
/**
|
|
|
|
* Create a new web installer
|
|
|
|
*
|
|
|
|
* @param array $pageData The setup wizard's page data
|
|
|
|
*/
|
|
|
|
public function __construct(array $pageData)
|
|
|
|
{
|
|
|
|
$this->pageData = $pageData;
|
2014-10-06 16:49:29 +02:00
|
|
|
$this->report = array();
|
2014-09-29 14:23:42 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @see Installer::run()
|
|
|
|
*/
|
|
|
|
public function run()
|
|
|
|
{
|
2014-10-06 16:49:29 +02:00
|
|
|
$success = true;
|
|
|
|
|
2014-10-07 17:08:50 +02:00
|
|
|
if (isset($this->pageData['setup_db_resource']) && ! $this->pageData['setup_db_resource']['skip_validation']) {
|
|
|
|
try {
|
|
|
|
$this->setupDatabase();
|
|
|
|
} catch (Exception $e) {
|
|
|
|
$this->log(sprintf(t('Failed to set up the database: %s'), $e->getMessage()), false);
|
|
|
|
return false; // Bail out as early as possible as not being able to setup the database is fatal
|
|
|
|
}
|
|
|
|
|
|
|
|
$this->log(t('The database has been successfully set up!'));
|
|
|
|
}
|
|
|
|
|
2014-10-06 16:49:29 +02:00
|
|
|
$configIniPath = Config::resolvePath('config.ini');
|
|
|
|
try {
|
|
|
|
$this->writeConfigIni($configIniPath);
|
2014-10-07 17:05:55 +02:00
|
|
|
$this->log(sprintf(t('Successfully created: %s'), $configIniPath));
|
2014-10-06 16:49:29 +02:00
|
|
|
} catch (Exception $e) {
|
|
|
|
$success = false;
|
2014-10-07 17:05:55 +02:00
|
|
|
$this->log(sprintf(t('Unable to create: %s (%s)'), $configIniPath, $e->getMessage()), false);
|
2014-10-06 16:49:29 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
$resourcesIniPath = Config::resolvePath('resources.ini');
|
|
|
|
try {
|
|
|
|
$this->writeResourcesIni($resourcesIniPath);
|
2014-10-07 17:05:55 +02:00
|
|
|
$this->log(sprintf(t('Successfully created: %s'), $resourcesIniPath));
|
2014-10-06 16:49:29 +02:00
|
|
|
} catch (Exception $e) {
|
|
|
|
$success = false;
|
2014-10-07 17:05:55 +02:00
|
|
|
$this->log(sprintf(t('Unable to create: %s (%s)'), $resourcesIniPath, $e->getMessage()), false);
|
2014-10-06 16:49:29 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
$authenticationIniPath = Config::resolvePath('authentication.ini');
|
|
|
|
try {
|
|
|
|
$this->writeAuthenticationIni($authenticationIniPath);
|
2014-10-07 17:05:55 +02:00
|
|
|
$this->log(sprintf(t('Successfully created: %s'), $authenticationIniPath));
|
2014-10-06 16:49:29 +02:00
|
|
|
} catch (Exception $e) {
|
|
|
|
$success = false;
|
2014-10-07 17:05:55 +02:00
|
|
|
$this->log(sprintf(t('Unable to create: %s (%s)'), $authenticationIniPath, $e->getMessage()), false);
|
2014-10-06 16:49:29 +02:00
|
|
|
}
|
|
|
|
|
2014-10-08 10:26:12 +02:00
|
|
|
try {
|
|
|
|
$this->setupAdminAccount();
|
|
|
|
$this->log(t('Successfully created initial administrative account.'));
|
|
|
|
} catch (Exception $e) {
|
|
|
|
$success = false;
|
|
|
|
$this->log(sprintf(t('Failed to create initial administrative account: %s'), $e->getMessage()));
|
|
|
|
}
|
|
|
|
|
2014-10-06 16:49:29 +02:00
|
|
|
return $success;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Write application configuration to the given filepath
|
|
|
|
*
|
|
|
|
* @param string $configPath
|
|
|
|
*/
|
|
|
|
protected function writeConfigIni($configPath)
|
|
|
|
{
|
|
|
|
$preferencesConfig = array();
|
|
|
|
$preferencesConfig['type'] = $this->pageData['setup_preferences_type']['type'];
|
|
|
|
if ($this->pageData['setup_preferences_type']['type'] === 'db') {
|
|
|
|
$preferencesConfig['resource'] = $this->pageData['setup_db_resource']['name'];
|
|
|
|
}
|
|
|
|
|
|
|
|
$loggingConfig = array();
|
|
|
|
$loggingConfig['type'] = $this->pageData['setup_general_config']['logging_type'];
|
|
|
|
$loggingConfig['level'] = $this->pageData['setup_general_config']['logging_level'];
|
|
|
|
if ($this->pageData['setup_general_config']['logging_type'] === 'syslog') {
|
|
|
|
$loggingConfig['application'] = $this->pageData['setup_general_config']['logging_application'];
|
|
|
|
$loggingConfig['facility'] = $this->pageData['setup_general_config']['logging_facility'];
|
|
|
|
} else { // $this->pageData['setup_general_config']['logging_type'] === 'file'
|
|
|
|
$loggingConfig['target'] = $this->pageData['setup_general_config']['logging_target'];
|
|
|
|
}
|
|
|
|
|
|
|
|
$config = array(
|
|
|
|
'global' => array(
|
|
|
|
'modulepath' => $this->pageData['setup_general_config']['global_modulePath']
|
|
|
|
),
|
|
|
|
'preferences' => $preferencesConfig,
|
|
|
|
'logging' => $loggingConfig
|
|
|
|
);
|
|
|
|
|
|
|
|
$writer = new PreservingIniWriter(array('config' => new Zend_Config($config), 'filename' => $configPath));
|
|
|
|
$writer->write();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Write resource configuration to the given filepath
|
|
|
|
*
|
|
|
|
* @param string $configPath
|
|
|
|
*/
|
|
|
|
protected function writeResourcesIni($configPath)
|
|
|
|
{
|
|
|
|
$resourceConfig = array();
|
|
|
|
if (isset($this->pageData['setup_db_resource'])) {
|
|
|
|
$resourceConfig[$this->pageData['setup_db_resource']['name']] = array(
|
|
|
|
'type' => $this->pageData['setup_db_resource']['type'],
|
|
|
|
'db' => $this->pageData['setup_db_resource']['db'],
|
|
|
|
'host' => $this->pageData['setup_db_resource']['host'],
|
|
|
|
'port' => $this->pageData['setup_db_resource']['port'],
|
|
|
|
'dbname' => $this->pageData['setup_db_resource']['dbname'],
|
|
|
|
'username' => $this->pageData['setup_db_resource']['username'],
|
|
|
|
'password' => $this->pageData['setup_db_resource']['password']
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (isset($this->pageData['setup_ldap_resource'])) {
|
|
|
|
$resourceConfig[$this->pageData['setup_ldap_resource']['name']] = array(
|
|
|
|
'hostname' => $this->pageData['setup_ldap_resource']['hostname'],
|
|
|
|
'port' => $this->pageData['setup_ldap_resource']['port'],
|
|
|
|
'bind_dn' => $this->pageData['setup_ldap_resource']['bind_dn'],
|
|
|
|
'bind_pw' => $this->pageData['setup_ldap_resource']['bind_pw']
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (empty($resourceConfig)) {
|
|
|
|
return; // No need to write nothing :)
|
|
|
|
}
|
|
|
|
|
|
|
|
$writer = new PreservingIniWriter(array(
|
|
|
|
'config' => new Zend_Config($resourceConfig),
|
|
|
|
'filename' => $configPath
|
|
|
|
));
|
|
|
|
$writer->write();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Write authentication backend configuration to the given filepath
|
|
|
|
*
|
|
|
|
* @param string $configPath
|
|
|
|
*/
|
|
|
|
protected function writeAuthenticationIni($configPath)
|
|
|
|
{
|
|
|
|
$backendConfig = array();
|
|
|
|
if ($this->pageData['setup_authentication_type']['type'] === 'db') {
|
|
|
|
$backendConfig[$this->pageData['setup_authentication_backend']['name']] = array(
|
|
|
|
'backend' => $this->pageData['setup_authentication_backend']['backend'],
|
|
|
|
'resource' => $this->pageData['setup_db_resource']['name']
|
|
|
|
);
|
|
|
|
} elseif ($this->pageData['setup_authentication_type']['type'] === 'ldap') {
|
|
|
|
$backendConfig[$this->pageData['setup_authentication_backend']['backend']] = array(
|
|
|
|
'backend' => $this->pageData['setup_authentication_backend']['backend'],
|
|
|
|
'resource' => $this->pageData['setup_ldap_resource']['name'],
|
|
|
|
//'root_dn' => $this->pageData['setup_ldap_resource']['root_dn'],
|
|
|
|
'user_class' => $this->pageData['setup_authentication_backend']['user_class'],
|
|
|
|
'user_name_attribute' => $this->pageData['setup_authentication_backend']['user_name_attribute']
|
|
|
|
);
|
|
|
|
} else { // $this->pageData['setup_authentication_type']['type'] === 'autologin'
|
|
|
|
$backendConfig[$this->pageData['setup_authentication_backend']['name']] = array(
|
|
|
|
'backend' => $this->pageData['setup_authentication_backend']['backend'],
|
|
|
|
'strip_username_regexp' => $this->pageData['setup_authentication_backend']['strip_username_regexp']
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
$writer = new PreservingIniWriter(array(
|
|
|
|
'config' => new Zend_Config($backendConfig),
|
|
|
|
'filename' => $configPath
|
|
|
|
));
|
|
|
|
$writer->write();
|
2014-09-29 14:23:42 +02:00
|
|
|
}
|
|
|
|
|
2014-10-07 17:08:50 +02:00
|
|
|
/**
|
|
|
|
* Setup the database
|
|
|
|
*/
|
|
|
|
protected function setupDatabase()
|
|
|
|
{
|
|
|
|
$resourceConfig = $this->pageData['setup_db_resource'];
|
|
|
|
if (isset($this->pageData['setup_database_creation'])) {
|
|
|
|
$resourceConfig['username'] = $this->pageData['setup_database_creation']['username'];
|
|
|
|
$resourceConfig['password'] = $this->pageData['setup_database_creation']['password'];
|
|
|
|
}
|
|
|
|
|
|
|
|
$db = new DbTool($resourceConfig);
|
|
|
|
if ($resourceConfig['db'] === 'mysql') {
|
|
|
|
$this->setupMysqlDatabase($db);
|
|
|
|
} elseif ($resourceConfig['db'] === 'pgsql') {
|
|
|
|
$this->setupPgsqlDatabase($db);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Setup a MySQL database
|
|
|
|
*
|
|
|
|
* @param DbTool $db The database connection wrapper to use
|
|
|
|
*
|
|
|
|
* @todo Escape user input or make use of prepared statements!
|
|
|
|
*/
|
|
|
|
private function setupMysqlDatabase(DbTool $db)
|
|
|
|
{
|
|
|
|
try {
|
|
|
|
$db->connectToDb();
|
|
|
|
$this->log(sprintf(
|
|
|
|
t('Successfully connected to existing database "%s"...'),
|
|
|
|
$this->pageData['setup_db_resource']['dbname']
|
|
|
|
));
|
|
|
|
} catch (PDOException $e) {
|
|
|
|
$db->connectToHost();
|
|
|
|
$this->log(sprintf(
|
|
|
|
t('Creating new database "%s"...'),
|
|
|
|
$this->pageData['setup_db_resource']['dbname']
|
|
|
|
));
|
|
|
|
$db->exec('CREATE DATABASE ' . $this->pageData['setup_db_resource']['dbname']);
|
|
|
|
$db->reconnect($this->pageData['setup_db_resource']['dbname']);
|
|
|
|
}
|
|
|
|
|
|
|
|
$loginIdent = "'" . $this->pageData['setup_db_resource']['username'] . "'@'" . Platform::getFqdn() . "'";
|
|
|
|
if (false === array_search($loginIdent, $db->listLogins())) {
|
|
|
|
$this->log(sprintf(
|
|
|
|
t('Creating login "%s"...'),
|
|
|
|
$this->pageData['setup_db_resource']['username']
|
|
|
|
));
|
|
|
|
$db->exec(
|
|
|
|
"CREATE USER $loginIdent IDENTIFIED BY '" .
|
|
|
|
$this->pageData['setup_db_resource']['password'] . "'"
|
|
|
|
);
|
|
|
|
} else {
|
|
|
|
$this->log(sprintf(
|
|
|
|
t('Login "%s" already exists...'),
|
|
|
|
$this->pageData['setup_db_resource']['username']
|
|
|
|
));
|
|
|
|
}
|
|
|
|
|
|
|
|
$diff = array_diff(array('account', 'preference'), $db->listTables());
|
|
|
|
if (empty($diff)) {
|
|
|
|
$this->log(t('Database schema already exists...'));
|
|
|
|
} else {
|
|
|
|
$this->log(t('Creating database schema...'));
|
|
|
|
$db->import(Icinga::app()->getApplicationDir() . '/../etc/schema/mysql.sql');
|
|
|
|
}
|
|
|
|
|
|
|
|
$privileges = array('SELECT', 'INSERT', 'UPDATE', 'DELETE', 'EXECUTE', 'CREATE TEMPORARY TABLES');
|
|
|
|
if ($db->checkPrivileges(array_merge($privileges, array('GRANT OPTION')))) {
|
|
|
|
$this->log(sprintf(
|
|
|
|
t('Granting required privileges to login "%s"...'),
|
|
|
|
$this->pageData['setup_db_resource']['username']
|
|
|
|
));
|
|
|
|
$db->exec(sprintf(
|
|
|
|
"GRANT %s ON %s.* TO %s",
|
|
|
|
join(',', $privileges),
|
|
|
|
$this->pageData['setup_db_resource']['dbname'],
|
|
|
|
$loginIdent
|
|
|
|
));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Setup a PostgreSQL database
|
|
|
|
*
|
|
|
|
* @param DbTool $db The database connection wrapper to use
|
|
|
|
*
|
|
|
|
* @todo Escape user input or make use of prepared statements!
|
|
|
|
*/
|
|
|
|
private function setupPgsqlDatabase(DbTool $db)
|
|
|
|
{
|
|
|
|
try {
|
|
|
|
$db->connectToDb();
|
|
|
|
$this->log(sprintf(
|
|
|
|
t('Successfully connected to existing database "%s"...'),
|
|
|
|
$this->pageData['setup_db_resource']['dbname']
|
|
|
|
));
|
|
|
|
} catch (PDOException $e) {
|
|
|
|
$db->connectToHost();
|
|
|
|
$this->log(sprintf(
|
|
|
|
t('Creating new database "%s"...'),
|
|
|
|
$this->pageData['setup_db_resource']['dbname']
|
|
|
|
));
|
|
|
|
$db->exec('CREATE DATABASE ' . $this->pageData['setup_db_resource']['dbname']);
|
|
|
|
$db->reconnect($this->pageData['setup_db_resource']['dbname']);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (false === array_search($this->pageData['setup_db_resource']['username'], $db->listLogins())) {
|
|
|
|
$this->log(sprintf(
|
|
|
|
t('Creating login "%s"...'),
|
|
|
|
$this->pageData['setup_db_resource']['username']
|
|
|
|
));
|
|
|
|
$db->exec(sprintf(
|
|
|
|
"CREATE USER %s WITH PASSWORD '%s'",
|
|
|
|
$this->pageData['setup_db_resource']['username'],
|
|
|
|
$this->pageData['setup_db_resource']['password']
|
|
|
|
));
|
|
|
|
} else {
|
|
|
|
$this->log(sprintf(
|
|
|
|
t('Login "%s" already exists...'),
|
|
|
|
$this->pageData['setup_db_resource']['username']
|
|
|
|
));
|
|
|
|
}
|
|
|
|
|
|
|
|
$diff = array_diff(array('account', 'preference'), $db->listTables());
|
|
|
|
if (empty($diff)) {
|
|
|
|
$this->log(t('Database schema already exists...'));
|
|
|
|
} else {
|
|
|
|
$this->log(t('Creating database schema...'));
|
|
|
|
$db->import(Icinga::app()->getApplicationDir() . '/../etc/schema/pgsql.sql');
|
|
|
|
}
|
|
|
|
|
|
|
|
$privileges = array('SELECT', 'INSERT', 'UPDATE', 'DELETE');
|
|
|
|
if ($db->checkPrivileges(array_merge($privileges, array('GRANT OPTION')))) {
|
|
|
|
$this->log(sprintf(
|
|
|
|
t('Granting required privileges to login "%s"...'),
|
|
|
|
$this->pageData['setup_db_resource']['username']
|
|
|
|
));
|
|
|
|
$db->exec(sprintf(
|
|
|
|
"GRANT %s ON TABLE account TO %s",
|
|
|
|
join(',', $privileges),
|
|
|
|
$this->pageData['setup_db_resource']['username']
|
|
|
|
));
|
|
|
|
$db->exec(sprintf(
|
|
|
|
"GRANT %s ON TABLE preference TO %s",
|
|
|
|
join(',', $privileges),
|
|
|
|
$this->pageData['setup_db_resource']['username']
|
|
|
|
));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-10-08 10:26:12 +02:00
|
|
|
/**
|
|
|
|
* Create the initial administrative account
|
|
|
|
*/
|
|
|
|
protected function setupAdminAccount()
|
|
|
|
{
|
|
|
|
if ($this->pageData['setup_admin_account']['user_type'] === 'new_user') {
|
|
|
|
$backend = new DbUserBackend(
|
|
|
|
ResourceFactory::createResource(new Zend_Config($this->pageData['setup_db_resource']))
|
|
|
|
);
|
|
|
|
|
|
|
|
if (array_search($this->pageData['setup_admin_account']['new_user'], $backend->listUsers()) === false) {
|
|
|
|
$backend->addUser(
|
|
|
|
$this->pageData['setup_admin_account']['new_user'],
|
|
|
|
$this->pageData['setup_admin_account']['new_user_password']
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-09-29 14:23:42 +02:00
|
|
|
/**
|
|
|
|
* @see Installer::getSummary()
|
|
|
|
*/
|
|
|
|
public function getSummary()
|
|
|
|
{
|
2014-10-06 09:30:51 +02:00
|
|
|
$summary = array();
|
|
|
|
|
|
|
|
$prefType = $this->pageData['setup_preferences_type']['type'];
|
|
|
|
$authType = $this->pageData['setup_authentication_type']['type'];
|
|
|
|
if ($authType !== 'autologin' || $prefType === 'db') {
|
|
|
|
$resourceInfo = array();
|
|
|
|
|
|
|
|
if ($authType === 'db' || $prefType === 'db') {
|
|
|
|
if ($authType === 'db' && $prefType === 'db') {
|
|
|
|
$resourceInfo[] = t(
|
|
|
|
'The following database will be used to authenticate users and to store preferences.'
|
|
|
|
);
|
|
|
|
} elseif ($authType === 'db') {
|
|
|
|
$resourceInfo[] = t('The following database will be used to authenticate users.');
|
|
|
|
} else { // $prefType === 'db'
|
|
|
|
$resourceInfo[] = t('The following database will be used to store preferences.');
|
|
|
|
}
|
|
|
|
|
|
|
|
$resourceInfo[t('Database')] = array(
|
|
|
|
sprintf(t('Resource Name: %s'), $this->pageData['setup_db_resource']['name']),
|
|
|
|
sprintf(t('Database Type: %s'), $this->pageData['setup_db_resource']['db']),
|
|
|
|
sprintf(t('Host: %s'), $this->pageData['setup_db_resource']['host']),
|
|
|
|
sprintf(t('Port: %s'), $this->pageData['setup_db_resource']['port']),
|
|
|
|
sprintf(t('Database Name: %s'), $this->pageData['setup_db_resource']['dbname']),
|
|
|
|
sprintf(t('Username: %s'), $this->pageData['setup_db_resource']['username']),
|
|
|
|
sprintf(
|
|
|
|
t('Password: %s'),
|
|
|
|
str_repeat('*', strlen($this->pageData['setup_db_resource']['password']))
|
|
|
|
)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($authType === 'ldap') {
|
|
|
|
$resourceInfo[] = t('The following LDAP connection will be used to authenticate users.');
|
|
|
|
$resourceInfo['LDAP'] = array(
|
|
|
|
sprintf(t('Resource Name: %s'), $this->pageData['setup_ldap_resource']['name']),
|
|
|
|
sprintf(t('Host: %s'), $this->pageData['setup_ldap_resource']['hostname']),
|
|
|
|
sprintf(t('Port: %s'), $this->pageData['setup_ldap_resource']['port']),
|
|
|
|
sprintf(t('Root DN: %s'), $this->pageData['setup_ldap_resource']['root_dn']),
|
|
|
|
sprintf(t('Bind DN: %s'), $this->pageData['setup_ldap_resource']['bind_dn']),
|
|
|
|
sprintf(
|
|
|
|
t('Bind Password: %s'),
|
|
|
|
str_repeat('*', strlen($this->pageData['setup_ldap_resource']['bind_pw']))
|
|
|
|
)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
$summary[tp('Resource', 'Resources', count($resourceInfo) / 2)] = $resourceInfo;
|
|
|
|
}
|
|
|
|
|
|
|
|
$adminType = $this->pageData['setup_admin_account']['user_type'];
|
|
|
|
$summary[t('Authentication')] = array(
|
|
|
|
sprintf(
|
|
|
|
t('Users will authenticate using %s.', 'setup.summary.auth'),
|
|
|
|
$authType === 'db' ? t('a database', 'setup.summary.auth.type') : (
|
|
|
|
$authType === 'ldap' ? 'LDAP' : t('webserver authentication', 'setup.summary.auth.type')
|
|
|
|
)
|
|
|
|
),
|
|
|
|
t('Backend Configuration') => $authType === 'db' ? array(
|
|
|
|
sprintf(t('Backend Name: %s'), $this->pageData['setup_authentication_backend']['name'])
|
|
|
|
) : ($authType === 'ldap' ? array(
|
|
|
|
sprintf(t('Backend Name: %s'), $this->pageData['setup_authentication_backend']['name']),
|
|
|
|
sprintf(
|
|
|
|
t('LDAP User Object Class: %s'),
|
|
|
|
$this->pageData['setup_authentication_backend']['user_class']
|
|
|
|
),
|
|
|
|
sprintf(
|
|
|
|
t('LDAP User Name Attribute: %s'),
|
|
|
|
$this->pageData['setup_authentication_backend']['user_name_attribute']
|
|
|
|
)
|
|
|
|
) : array(
|
|
|
|
sprintf(t('Backend Name: %s'), $this->pageData['setup_authentication_backend']['name']),
|
|
|
|
sprintf(
|
|
|
|
t('Backend Domain Pattern: %s'),
|
|
|
|
$this->pageData['setup_authentication_backend']['strip_username_regexp']
|
|
|
|
)
|
|
|
|
)
|
|
|
|
),
|
|
|
|
t('Initial Administrative Account') => $adminType === 'by_name' || $adminType === 'existing_user'
|
|
|
|
? sprintf(
|
|
|
|
t('Administrative rights will initially be granted to an existing account called "%s".'),
|
|
|
|
$this->pageData['setup_admin_account'][$adminType]
|
|
|
|
) : sprintf(
|
|
|
|
t('Administrative rights will initially be granted to a new account called "%s".'),
|
|
|
|
$this->pageData['setup_admin_account'][$adminType]
|
|
|
|
)
|
|
|
|
);
|
|
|
|
|
2014-10-06 13:52:32 +02:00
|
|
|
$loggingLevel = $this->pageData['setup_general_config']['logging_level'];
|
|
|
|
$loggingType = $this->pageData['setup_general_config']['logging_type'];
|
2014-10-06 09:30:51 +02:00
|
|
|
$summary[t('Application Configuration')] = array(
|
|
|
|
t('General', 'app.config') => array(
|
|
|
|
sprintf(
|
|
|
|
t('Icinga Web 2 will look for modules at: %s'),
|
2014-10-06 13:52:32 +02:00
|
|
|
$this->pageData['setup_general_config']['global_modulePath']
|
2014-10-06 09:30:51 +02:00
|
|
|
),
|
|
|
|
sprintf(
|
|
|
|
$prefType === 'ini' ? sprintf(
|
|
|
|
t('Preferences will be stored per user account in INI files at: %s'),
|
|
|
|
Config::$configDir . '/preferences'
|
|
|
|
) : (
|
|
|
|
$prefType === 'db' ? t('Preferences will be stored using a database.') : (
|
|
|
|
t('Preferences will not be persisted across browser sessions.')
|
|
|
|
)
|
|
|
|
)
|
|
|
|
)
|
|
|
|
),
|
|
|
|
t('Logging', 'app.config') => array_merge(
|
|
|
|
array(
|
|
|
|
sprintf(
|
|
|
|
t('Level: %s', 'app.config.logging'),
|
|
|
|
$loggingLevel === 0 ? t('None', 'app.config.logging.level') : (
|
|
|
|
$loggingLevel === 1 ? t('Error', 'app.config.logging.level') : (
|
|
|
|
$loggingLevel === 2 ? t('Warning', 'app.config.logging.level') : (
|
|
|
|
$loggingLevel === 3 ? t('Information', 'app.config.logging.level') : (
|
|
|
|
t('Debug', 'app.config.logging.level')
|
|
|
|
)
|
|
|
|
)
|
|
|
|
)
|
|
|
|
)
|
|
|
|
),
|
|
|
|
sprintf(
|
|
|
|
t('Type: %s', 'app.config.logging'),
|
|
|
|
$loggingType === 'syslog' ? 'Syslog' : t('File', 'app.config.logging.type')
|
|
|
|
)
|
|
|
|
),
|
2014-10-06 13:52:32 +02:00
|
|
|
$this->pageData['setup_general_config']['logging_type'] === 'syslog' ? array(
|
2014-10-06 09:30:51 +02:00
|
|
|
sprintf(
|
|
|
|
t('Application Prefix: %s'),
|
2014-10-06 13:52:32 +02:00
|
|
|
$this->pageData['setup_general_config']['logging_application']
|
2014-10-06 09:30:51 +02:00
|
|
|
),
|
|
|
|
sprintf(
|
|
|
|
t('Facility: %s'),
|
2014-10-06 13:52:32 +02:00
|
|
|
$this->pageData['setup_general_config']['logging_facility']
|
2014-10-06 09:30:51 +02:00
|
|
|
)
|
|
|
|
) : array(
|
|
|
|
sprintf(
|
|
|
|
t('Filepath: %s'),
|
2014-10-06 13:52:32 +02:00
|
|
|
$this->pageData['setup_general_config']['logging_target']
|
2014-10-06 09:30:51 +02:00
|
|
|
)
|
|
|
|
)
|
|
|
|
)
|
|
|
|
);
|
|
|
|
|
|
|
|
if (isset($this->pageData['setup_database_creation'])) {
|
|
|
|
$resourceConfig = $this->pageData['setup_db_resource'];
|
|
|
|
$resourceConfig['username'] = $this->pageData['setup_database_creation']['username'];
|
|
|
|
$resourceConfig['password'] = $this->pageData['setup_database_creation']['password'];
|
|
|
|
$db = new DbTool($resourceConfig);
|
|
|
|
|
|
|
|
try {
|
|
|
|
$db->connectToDb();
|
|
|
|
$message = sprintf(
|
2014-10-07 17:05:55 +02:00
|
|
|
t(
|
|
|
|
'The database user "%s" will be used to setup the missing'
|
|
|
|
. ' schema required by Icinga Web 2 in database "%s".'
|
|
|
|
),
|
2014-10-06 09:30:51 +02:00
|
|
|
$this->pageData['setup_database_creation']['username'],
|
|
|
|
$resourceConfig['dbname']
|
|
|
|
);
|
|
|
|
} catch (PDOException $e) {
|
|
|
|
$message = sprintf(
|
|
|
|
t(
|
|
|
|
'The database user "%s" will be used to create the missing database "%s" '
|
|
|
|
. 'with the schema required by Icinga Web 2 and a new login called "%s".'
|
|
|
|
),
|
|
|
|
$this->pageData['setup_database_creation']['username'],
|
|
|
|
$resourceConfig['dbname'],
|
2014-10-07 17:06:51 +02:00
|
|
|
$this->pageData['setup_db_resource']['username']
|
2014-10-06 09:30:51 +02:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
$summary[t('Database Setup')] = $message;
|
|
|
|
}
|
|
|
|
|
|
|
|
return $summary;
|
2014-09-29 14:23:42 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @see Installer::getReport()
|
|
|
|
*/
|
|
|
|
public function getReport()
|
|
|
|
{
|
2014-10-06 16:49:29 +02:00
|
|
|
return $this->report;
|
2014-09-29 14:23:42 +02:00
|
|
|
}
|
2014-10-07 17:05:55 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Add a message to the report
|
|
|
|
*
|
|
|
|
* @param string $message The message to add
|
|
|
|
* @param bool $success Whether the message represents a success (true) or a failure (false)
|
|
|
|
*/
|
|
|
|
protected function log($message, $success = true)
|
|
|
|
{
|
|
|
|
$this->report[] = (object) array(
|
|
|
|
'state' => (bool) $success,
|
|
|
|
'message' => $message
|
|
|
|
);
|
|
|
|
}
|
2014-09-29 14:23:42 +02:00
|
|
|
}
|