config/module: Show library dependencies and unmet ones
This commit is contained in:
parent
05d74dd980
commit
32f9ce8b7c
|
@ -138,6 +138,8 @@ class ConfigController extends Controller
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->view->module = $module;
|
$this->view->module = $module;
|
||||||
|
$this->view->libraries = $app->getLibraries();
|
||||||
|
$this->view->moduleManager = $manager;
|
||||||
$this->view->toggleForm = $toggleForm;
|
$this->view->toggleForm = $toggleForm;
|
||||||
$this->view->title = $module->getName();
|
$this->view->title = $module->getName();
|
||||||
$this->view->tabs = $module->getConfigTabs()->activate('info');
|
$this->view->tabs = $module->getConfigTabs()->activate('info');
|
||||||
|
|
|
@ -6,9 +6,11 @@
|
||||||
<?= $this->translate('There is no such module installed.') ?>
|
<?= $this->translate('There is no such module installed.') ?>
|
||||||
<?php return; endif ?>
|
<?php return; endif ?>
|
||||||
<?php
|
<?php
|
||||||
$dependencies = $module->getDependencies();
|
$requiredMods = $module->getRequiredModules();
|
||||||
|
$requiredLibs = $module->getRequiredLibraries();
|
||||||
$restrictions = $module->getProvidedRestrictions();
|
$restrictions = $module->getProvidedRestrictions();
|
||||||
$permissions = $module->getProvidedPermissions();
|
$permissions = $module->getProvidedPermissions();
|
||||||
|
$unmetDependencies = $moduleManager->hasUnmetDependencies($module->getName());
|
||||||
$state = $moduleData->enabled ? ($moduleData->loaded ? 'enabled' : 'failed') : 'disabled'
|
$state = $moduleData->enabled ? ($moduleData->loaded ? 'enabled' : 'failed') : 'disabled'
|
||||||
?>
|
?>
|
||||||
<table class="name-value-table">
|
<table class="name-value-table">
|
||||||
|
@ -21,7 +23,11 @@
|
||||||
<td>
|
<td>
|
||||||
<?= $state ?>
|
<?= $state ?>
|
||||||
<?php if (isset($this->toggleForm)): ?>
|
<?php if (isset($this->toggleForm)): ?>
|
||||||
|
<?php if ($moduleData->enabled || ! $unmetDependencies): ?>
|
||||||
<?= $this->toggleForm ?>
|
<?= $this->toggleForm ?>
|
||||||
|
<?php else: ?>
|
||||||
|
<?= $this->icon('attention-alt', $this->translate('Module can\'t be enabled due to unmet dependencies')) ?>
|
||||||
|
<?php endif ?>
|
||||||
<?php endif ?>
|
<?php endif ?>
|
||||||
</td>
|
</td>
|
||||||
<tr>
|
<tr>
|
||||||
|
@ -43,13 +49,58 @@
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<th><?= $this->escape($this->translate('Dependencies')) ?></th>
|
<th><?= $this->escape($this->translate('Dependencies')) ?></th>
|
||||||
|
<td class="module-dependencies">
|
||||||
|
<?php if (empty($requiredLibs) && empty($requiredMods)): ?>
|
||||||
|
<?= $this->translate('This module has no dependencies') ?>
|
||||||
|
<?php else: ?>
|
||||||
|
<?php if ($unmetDependencies): ?>
|
||||||
|
<strong class="unmet-dependencies">
|
||||||
|
<?= $this->translate('Unmet dependencies found! Module can\'t be enabled unless all dependencies are met.') ?>
|
||||||
|
</strong>
|
||||||
|
<?php endif ?>
|
||||||
|
<?php if (! empty($requiredLibs)): ?>
|
||||||
|
<table class="name-value-table">
|
||||||
|
<caption><?= $this->translate('Libraries') ?></caption>
|
||||||
|
<?php foreach ($requiredLibs as $libraryName => $versionString): ?>
|
||||||
|
<tr>
|
||||||
|
<th><?= $this->escape($libraryName) ?></th>
|
||||||
<td>
|
<td>
|
||||||
<?php
|
<?php if ($libraries->has($libraryName, $versionString === true ? null : $versionString)): ?>
|
||||||
if (empty($dependencies)):
|
<?= $versionString === true ? '*' : $this->escape($versionString) ?>
|
||||||
echo $this->translate('This module has no dependencies');
|
<?php else: ?>
|
||||||
else: foreach ($dependencies as $name => $versionString): ?>
|
<span class="missing"><?= $versionString === true ? '*' : $this->escape($versionString) ?></span>
|
||||||
<strong><?= $this->escape($name) ?></strong><?php if ($versionString !== true): ?>: <?= $this->escape($versionString) ?><?php endif ?><br />
|
<?php if (($library = $libraries->get($libraryName)) !== null): ?>
|
||||||
<?php endforeach; endif ?>
|
(<?= $library->getVersion() ?>)
|
||||||
|
<?php endif ?>
|
||||||
|
<?php endif ?>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
<?php endforeach ?>
|
||||||
|
</table>
|
||||||
|
<?php endif ?>
|
||||||
|
<?php if (! empty($requiredMods)): ?>
|
||||||
|
<table class="name-value-table">
|
||||||
|
<caption><?= $this->translate('Modules') ?></caption>
|
||||||
|
<?php foreach ($requiredMods as $moduleName => $versionString): ?>
|
||||||
|
<tr>
|
||||||
|
<th><?= $this->escape($moduleName) ?></th>
|
||||||
|
<td>
|
||||||
|
<?php if ($moduleManager->has($moduleName, $versionString === true ? null : $versionString)): ?>
|
||||||
|
<?= $versionString === true ? '*' : $this->escape($versionString) ?>
|
||||||
|
<?php else: ?>
|
||||||
|
<span class="missing"><?= $versionString === true ? '*' : $this->escape($versionString) ?></span>
|
||||||
|
<?php if (! $moduleManager->hasInstalled($moduleName)): ?>
|
||||||
|
(<?= $this->translate('not installed') ?>)
|
||||||
|
<?php else: ?>
|
||||||
|
(<?= $moduleManager->getModule($moduleName, false)->getVersion() ?><?= $moduleManager->hasEnabled($moduleName) ? '' : ', ' . $this->translate('disabled') ?>)
|
||||||
|
<?php endif ?>
|
||||||
|
<?php endif ?>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
<?php endforeach ?>
|
||||||
|
</table>
|
||||||
|
<?php endif ?>
|
||||||
|
<?php endif ?>
|
||||||
</td>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
<?php if (! empty($permissions)): ?>
|
<?php if (! empty($permissions)): ?>
|
||||||
|
|
|
@ -178,6 +178,12 @@ a:hover > .icon-cancel {
|
||||||
width: 100%;
|
width: 100%;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.name-value-table > caption {
|
||||||
|
margin-top: .5em;
|
||||||
|
text-align: left;
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
|
||||||
.name-value-table > tbody > tr > th {
|
.name-value-table > tbody > tr > th {
|
||||||
color: @text-color-light;
|
color: @text-color-light;
|
||||||
// Reset default font-weight
|
// Reset default font-weight
|
||||||
|
@ -351,3 +357,29 @@ a:hover > .icon-cancel {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.module-dependencies {
|
||||||
|
.unmet-dependencies {
|
||||||
|
background-color: @color-warning;
|
||||||
|
color: @text-color-on-icinga-blue;
|
||||||
|
padding: .25em .5em;
|
||||||
|
margin-left: -.5em;
|
||||||
|
}
|
||||||
|
|
||||||
|
.name-value-table {
|
||||||
|
> caption {
|
||||||
|
font-weight: normal;
|
||||||
|
color: @text-color-light;
|
||||||
|
}
|
||||||
|
|
||||||
|
> tbody > tr > th {
|
||||||
|
font-weight: bold;
|
||||||
|
color: @text-color;
|
||||||
|
}
|
||||||
|
|
||||||
|
.missing {
|
||||||
|
color: @color-critical;
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue