icingaweb2/modules/setup/application/forms/DatabaseCreationPage.php

226 lines
6.5 KiB
PHP
Raw Normal View History

2014-10-01 09:16:53 +02:00
<?php
/* Icinga Web 2 | (c) 2013-2015 Icinga Development Team | http://www.gnu.org/licenses/gpl-2.0.txt */
2014-10-01 09:16:53 +02:00
namespace Icinga\Module\Setup\Forms;
2014-10-01 09:16:53 +02:00
use PDOException;
use Icinga\Web\Form;
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;
/**
* The required privileges to setup the database
2014-10-01 09:16:53 +02:00
*
* @var array
*/
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()
{
$this->setName('setup_database_creation');
}
/**
* Set the resource configuration to use
*
* @param array $config
*
* @return self
*/
public function setResourceConfig(array $config)
{
$this->config = $config;
return $this;
}
/**
* Set the required privileges to setup the database
*
* @param array $privileges The privileges
*
* @return self
*/
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
*
* @param array $privileges The privileges
2014-10-01 09:16:53 +02:00
*
* @return self
*/
public function setDatabaseUsagePrivileges(array $privileges)
2014-10-01 09:16:53 +02:00
{
$this->databaseUsagePrivileges = $privileges;
2014-10-01 09:16:53 +02:00
return $this;
}
/**
* @see Form::createElements()
*/
public function createElements(array $formData)
{
2014-11-11 15:27:14 +01:00
$this->addElement(
'note',
'title',
array(
'value' => $this->translate('Database Setup', 'setup.page.title'),
'decorators' => array(
'ViewHelper',
array('HtmlTag', array('tag' => 'h2'))
2014-11-11 15:27:14 +01:00
)
)
);
2014-10-01 09:16:53 +02:00
$this->addElement(
'note',
'description',
array(
'value' => $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
)
)
);
$skipValidation = isset($formData['skip_validation']) && $formData['skip_validation'];
2014-10-01 09:16:53 +02:00
$this->addElement(
'text',
'username',
array(
'required' => false === $skipValidation,
'label' => $this->translate('Username'),
'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(
'label' => $this->translate('Password'),
'description' => $this->translate('The password for the database user defined above')
2014-10-01 09:16:53 +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;
}
if (isset($data['skip_validation']) && $data['skip_validation']) {
return true;
}
$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 {
$db->connectToDb(); // Are we able to login on the database?
} catch (PDOException $_) {
2014-10-01 09:16:53 +02:00
try {
$db->connectToHost(); // Are we able to login on the server?
2014-10-01 09:16:53 +02:00
} catch (PDOException $e) {
// We are NOT able to login on the server..
2014-10-01 09:16:53 +02:00
$this->addError($e->getMessage());
$this->addSkipValidationCheckbox();
2014-10-01 09:16:53 +02:00
return false;
}
}
// 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)) {
$this->addError(
$this->translate('The provided credentials cannot be used to create the database and/or the user.')
);
$this->addSkipValidationCheckbox();
return false;
}
// ...and to grant all required usage privileges to others
if (false === $db->isGrantable($this->databaseUsagePrivileges)) {
$this->addError(sprintf(
$this->translate(
'The provided credentials cannot be used to grant all required privileges to the login "%s".'
),
$this->config['username']
));
$this->addSkipValidationCheckbox();
return false;
}
2014-10-01 09:16:53 +02:00
return true;
}
/**
* 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(
2014-11-11 15:27:14 +01:00
'order' => 2,
'required' => true,
'label' => $this->translate('Skip Validation'),
'description' => $this->translate(
'Check this to not to validate the ability to login and required privileges'
)
)
);
}
2014-10-01 09:16:53 +02:00
}