2015-07-30 15:08:55 +02:00
|
|
|
<?php
|
|
|
|
|
2015-10-20 22:34:04 +02:00
|
|
|
namespace Icinga\Module\Director\Controllers;
|
|
|
|
|
2015-07-30 15:08:55 +02:00
|
|
|
use Icinga\Module\Director\Web\Controller\ActionController;
|
2019-05-02 13:23:06 +02:00
|
|
|
use ipl\Html\Html;
|
|
|
|
use gipfl\IcingaWeb2\Link;
|
2015-07-30 15:08:55 +02:00
|
|
|
|
2015-10-20 22:34:04 +02:00
|
|
|
class SchemaController extends ActionController
|
2015-07-30 15:08:55 +02:00
|
|
|
{
|
2017-08-16 19:13:07 +02:00
|
|
|
protected $schemas;
|
2015-07-30 15:08:55 +02:00
|
|
|
|
|
|
|
public function init()
|
|
|
|
{
|
2017-08-16 19:13:07 +02:00
|
|
|
$this->schemas = [
|
2015-07-30 15:08:55 +02:00
|
|
|
'mysql' => $this->translate('MySQL schema'),
|
|
|
|
'pgsql' => $this->translate('PostgreSQL schema'),
|
2017-08-16 19:13:07 +02:00
|
|
|
];
|
2015-07-30 15:08:55 +02:00
|
|
|
}
|
|
|
|
|
2018-05-08 19:54:00 +02:00
|
|
|
/**
|
|
|
|
* @throws \Icinga\Exception\IcingaException
|
|
|
|
*/
|
2015-07-30 15:08:55 +02:00
|
|
|
public function mysqlAction()
|
|
|
|
{
|
|
|
|
$this->serveSchema('mysql');
|
|
|
|
}
|
|
|
|
|
2018-05-08 19:54:00 +02:00
|
|
|
/**
|
|
|
|
* @throws \Icinga\Exception\IcingaException
|
|
|
|
*/
|
2015-07-30 15:08:55 +02:00
|
|
|
public function pgsqlAction()
|
|
|
|
{
|
|
|
|
$this->serveSchema('pgsql');
|
|
|
|
}
|
|
|
|
|
2018-05-08 19:54:00 +02:00
|
|
|
/**
|
|
|
|
* @param $type
|
|
|
|
* @throws \Icinga\Exception\IcingaException
|
|
|
|
*/
|
2015-07-30 15:08:55 +02:00
|
|
|
protected function serveSchema($type)
|
|
|
|
{
|
2017-08-16 19:13:07 +02:00
|
|
|
$schema = $this->loadSchema($type);
|
2015-07-30 15:08:55 +02:00
|
|
|
|
|
|
|
if ($this->params->get('format') === 'sql') {
|
|
|
|
header('Content-type: application/octet-stream');
|
|
|
|
header('Content-Disposition: attachment; filename=' . $type . '.sql');
|
|
|
|
echo $schema;
|
|
|
|
exit;
|
|
|
|
// TODO: Shutdown
|
|
|
|
}
|
2017-08-16 19:13:07 +02:00
|
|
|
|
|
|
|
$this
|
|
|
|
->addSchemaTabs($type)
|
|
|
|
->addTitle($this->schemas[$type])
|
|
|
|
->addDownloadAction()
|
2018-05-08 19:54:00 +02:00
|
|
|
->content()->add(Html::tag('pre', null, $schema));
|
2017-08-16 19:13:07 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
protected function loadSchema($type)
|
|
|
|
{
|
|
|
|
return file_get_contents(
|
|
|
|
sprintf(
|
|
|
|
'%s/schema/%s.sql',
|
2024-01-17 13:25:54 +01:00
|
|
|
$this->Module()->getBaseDir(),
|
2017-08-16 19:13:07 +02:00
|
|
|
$type
|
|
|
|
)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2018-05-08 19:54:00 +02:00
|
|
|
/**
|
|
|
|
* @return $this
|
|
|
|
* @throws \Icinga\Exception\IcingaException
|
|
|
|
* @throws \Icinga\Exception\ProgrammingError
|
|
|
|
*/
|
2017-08-16 19:13:07 +02:00
|
|
|
protected function addDownloadAction()
|
|
|
|
{
|
|
|
|
$this->actions()->add(
|
|
|
|
Link::create(
|
|
|
|
$this->translate('Download'),
|
|
|
|
$this->url()->with('format', 'sql'),
|
|
|
|
null,
|
|
|
|
[
|
|
|
|
'target' => '_blank',
|
|
|
|
'class' => 'icon-download',
|
|
|
|
]
|
|
|
|
)
|
|
|
|
);
|
|
|
|
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2018-05-08 19:54:00 +02:00
|
|
|
/**
|
|
|
|
* @param $active
|
|
|
|
* @return $this
|
|
|
|
* @throws \Icinga\Exception\Http\HttpNotFoundException
|
|
|
|
* @throws \Icinga\Exception\ProgrammingError
|
|
|
|
*/
|
2017-08-16 19:13:07 +02:00
|
|
|
protected function addSchemaTabs($active)
|
|
|
|
{
|
|
|
|
$tabs = $this->tabs();
|
|
|
|
foreach ($this->schemas as $type => $title) {
|
|
|
|
$tabs->add($type, [
|
|
|
|
'url' => 'director/schema/' . $type,
|
|
|
|
'label' => $title,
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
|
|
|
|
$tabs->activate($active);
|
|
|
|
|
|
|
|
return $this;
|
2015-07-30 15:08:55 +02:00
|
|
|
}
|
|
|
|
}
|