2014-10-01 09:16:53 +02:00
|
|
|
<?php
|
2015-02-04 10:46:36 +01:00
|
|
|
/* Icinga Web 2 | (c) 2013-2015 Icinga Development Team | GPLv2+ */
|
2014-10-01 09:16:53 +02:00
|
|
|
|
2014-11-14 11:01:16 +01:00
|
|
|
namespace Icinga\Module\Setup\Forms;
|
2014-10-01 09:16:53 +02:00
|
|
|
|
|
|
|
use PDOException;
|
|
|
|
use Icinga\Web\Form;
|
2014-11-10 16:31:40 +01:00
|
|
|
use Icinga\Module\Setup\Utils\DbTool;
|
2014-10-01 09:16:53 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Wizard page to define a database user that is able to create databases and tables
|
|
|
|
*/
|
|
|
|
class DatabaseCreationPage extends Form
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* The resource configuration to use
|
|
|
|
*
|
|
|
|
* @var array
|
|
|
|
*/
|
|
|
|
protected $config;
|
|
|
|
|
|
|
|
/**
|
2014-11-04 13:51:15 +01:00
|
|
|
* The required privileges to setup the database
|
2014-10-01 09:16:53 +02:00
|
|
|
*
|
|
|
|
* @var array
|
|
|
|
*/
|
2014-11-04 13:51:15 +01:00
|
|
|
protected $databaseSetupPrivileges;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The required privileges to operate the database
|
|
|
|
*
|
|
|
|
* @var array
|
|
|
|
*/
|
|
|
|
protected $databaseUsagePrivileges;
|
2014-10-01 09:16:53 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Initialize this page
|
|
|
|
*/
|
|
|
|
public function init()
|
|
|
|
{
|
2015-03-02 18:36:04 +01:00
|
|
|
$this->setTitle($this->translate('Database Setup', 'setup.page.title'));
|
|
|
|
$this->addDescription($this->translate(
|
|
|
|
'It seems that either the database you defined earlier does not yet exist and cannot be created'
|
|
|
|
. ' using the provided access credentials, the database does not have the required schema to be'
|
|
|
|
. ' operated by Icinga Web 2 or the provided access credentials do not have the sufficient '
|
|
|
|
. 'permissions to access the database. Please provide appropriate access credentials to solve this.'
|
|
|
|
));
|
2014-10-01 09:16:53 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the resource configuration to use
|
|
|
|
*
|
|
|
|
* @param array $config
|
|
|
|
*
|
2015-04-07 14:23:26 +02:00
|
|
|
* @return $this
|
2014-10-01 09:16:53 +02:00
|
|
|
*/
|
|
|
|
public function setResourceConfig(array $config)
|
|
|
|
{
|
|
|
|
$this->config = $config;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2014-11-04 13:51:15 +01:00
|
|
|
* Set the required privileges to setup the database
|
|
|
|
*
|
|
|
|
* @param array $privileges The privileges
|
|
|
|
*
|
2015-04-07 14:23:26 +02:00
|
|
|
* @return $this
|
2014-11-04 13:51:15 +01:00
|
|
|
*/
|
|
|
|
public function setDatabaseSetupPrivileges(array $privileges)
|
|
|
|
{
|
|
|
|
$this->databaseSetupPrivileges = $privileges;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the required privileges to operate the database
|
2014-10-01 09:16:53 +02:00
|
|
|
*
|
2014-11-04 13:51:15 +01:00
|
|
|
* @param array $privileges The privileges
|
2014-10-01 09:16:53 +02:00
|
|
|
*
|
2015-04-07 14:23:26 +02:00
|
|
|
* @return $this
|
2014-10-01 09:16:53 +02:00
|
|
|
*/
|
2014-11-04 13:51:15 +01:00
|
|
|
public function setDatabaseUsagePrivileges(array $privileges)
|
2014-10-01 09:16:53 +02:00
|
|
|
{
|
2014-11-04 13:51:15 +01:00
|
|
|
$this->databaseUsagePrivileges = $privileges;
|
2014-10-01 09:16:53 +02:00
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @see Form::createElements()
|
|
|
|
*/
|
|
|
|
public function createElements(array $formData)
|
|
|
|
{
|
2014-10-08 15:34:28 +02:00
|
|
|
$skipValidation = isset($formData['skip_validation']) && $formData['skip_validation'];
|
2014-10-01 09:16:53 +02:00
|
|
|
$this->addElement(
|
|
|
|
'text',
|
|
|
|
'username',
|
|
|
|
array(
|
2014-10-08 15:34:28 +02:00
|
|
|
'required' => false === $skipValidation,
|
2015-01-19 11:07:39 +01:00
|
|
|
'label' => $this->translate('Username'),
|
2015-02-02 16:55:21 +01:00
|
|
|
'description' => $this->translate(
|
|
|
|
'A user which is able to create databases and/or touch the database schema'
|
|
|
|
)
|
2014-10-01 09:16:53 +02:00
|
|
|
)
|
|
|
|
);
|
|
|
|
$this->addElement(
|
|
|
|
'password',
|
|
|
|
'password',
|
|
|
|
array(
|
2015-07-02 11:50:23 +02:00
|
|
|
'renderPassword' => true,
|
|
|
|
'label' => $this->translate('Password'),
|
|
|
|
'description' => $this->translate('The password for the database user defined above')
|
2014-10-01 09:16:53 +02:00
|
|
|
)
|
|
|
|
);
|
2014-10-08 15:34:28 +02:00
|
|
|
|
|
|
|
if ($skipValidation) {
|
|
|
|
$this->addSkipValidationCheckbox();
|
|
|
|
} else {
|
|
|
|
$this->addElement(
|
|
|
|
'hidden',
|
|
|
|
'skip_validation',
|
|
|
|
array(
|
|
|
|
'required' => true,
|
|
|
|
'value' => 0
|
|
|
|
)
|
|
|
|
);
|
|
|
|
}
|
2014-10-01 09:16:53 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Validate the given form data and check whether the defined user has sufficient access rights
|
|
|
|
*
|
|
|
|
* @param array $data The data to validate
|
|
|
|
*
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public function isValid($data)
|
|
|
|
{
|
|
|
|
if (false === parent::isValid($data)) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2014-10-08 15:34:28 +02:00
|
|
|
if (isset($data['skip_validation']) && $data['skip_validation']) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2014-11-04 13:51:15 +01:00
|
|
|
$config = $this->config;
|
|
|
|
$config['username'] = $this->getValue('username');
|
|
|
|
$config['password'] = $this->getValue('password');
|
|
|
|
$db = new DbTool($config);
|
2014-10-01 09:16:53 +02:00
|
|
|
|
|
|
|
try {
|
2014-11-04 13:51:15 +01:00
|
|
|
$db->connectToDb(); // Are we able to login on the database?
|
|
|
|
} catch (PDOException $_) {
|
2014-10-01 09:16:53 +02:00
|
|
|
try {
|
2014-11-04 13:51:15 +01:00
|
|
|
$db->connectToHost(); // Are we able to login on the server?
|
2014-10-01 09:16:53 +02:00
|
|
|
} catch (PDOException $e) {
|
2014-11-04 13:51:15 +01:00
|
|
|
// We are NOT able to login on the server..
|
2015-07-02 11:18:29 +02:00
|
|
|
$this->error($e->getMessage());
|
2014-10-08 15:34:28 +02:00
|
|
|
$this->addSkipValidationCheckbox();
|
2014-10-01 09:16:53 +02:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-11-04 13:51:15 +01:00
|
|
|
// In case we are connected the credentials filled into this
|
|
|
|
// form need to be granted to create databases, users...
|
|
|
|
if (false === $db->checkPrivileges($this->databaseSetupPrivileges)) {
|
2015-07-02 11:18:29 +02:00
|
|
|
$this->error(
|
2015-01-19 11:07:39 +01:00
|
|
|
$this->translate('The provided credentials cannot be used to create the database and/or the user.')
|
2014-11-11 09:24:53 +01:00
|
|
|
);
|
2014-11-04 13:51:15 +01:00
|
|
|
$this->addSkipValidationCheckbox();
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
// ...and to grant all required usage privileges to others
|
|
|
|
if (false === $db->isGrantable($this->databaseUsagePrivileges)) {
|
2015-07-02 11:18:29 +02:00
|
|
|
$this->error(sprintf(
|
2015-01-19 11:07:39 +01:00
|
|
|
$this->translate(
|
2014-11-11 09:24:53 +01:00
|
|
|
'The provided credentials cannot be used to grant all required privileges to the login "%s".'
|
|
|
|
),
|
2014-11-04 13:51:15 +01:00
|
|
|
$this->config['username']
|
|
|
|
));
|
|
|
|
$this->addSkipValidationCheckbox();
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2014-10-01 09:16:53 +02:00
|
|
|
return true;
|
|
|
|
}
|
2014-10-08 15:34:28 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Add a checkbox to the form by which the user can skip the login and privilege validation
|
|
|
|
*/
|
|
|
|
protected function addSkipValidationCheckbox()
|
|
|
|
{
|
|
|
|
$this->addElement(
|
|
|
|
'checkbox',
|
|
|
|
'skip_validation',
|
|
|
|
array(
|
2015-03-02 18:36:04 +01:00
|
|
|
'order' => 0,
|
2014-10-08 15:34:28 +02:00
|
|
|
'required' => true,
|
2015-01-19 11:07:39 +01:00
|
|
|
'label' => $this->translate('Skip Validation'),
|
|
|
|
'description' => $this->translate(
|
2014-11-11 09:24:53 +01:00
|
|
|
'Check this to not to validate the ability to login and required privileges'
|
|
|
|
)
|
2014-10-08 15:34:28 +02:00
|
|
|
)
|
|
|
|
);
|
|
|
|
}
|
2014-10-01 09:16:53 +02:00
|
|
|
}
|