Skip to content

Commit

Permalink
servicegroups: Preserve filters in details
Browse files Browse the repository at this point in the history
  • Loading branch information
nilmerg committed Jul 19, 2024
1 parent 2c9e182 commit 82802ed
Show file tree
Hide file tree
Showing 2 changed files with 111 additions and 24 deletions.
114 changes: 97 additions & 17 deletions application/controllers/ServicegroupController.php
Original file line number Diff line number Diff line change
Expand Up @@ -4,49 +4,60 @@

namespace Icinga\Module\Icingadb\Controllers;

use Icinga\Exception\NotFoundError;
use Icinga\Module\Icingadb\Common\Links;
use Icinga\Module\Icingadb\Model\Service;
use Icinga\Module\Icingadb\Model\ServicegroupSummary;
use Icinga\Module\Icingadb\Redis\VolatileStateResults;
use Icinga\Module\Icingadb\Web\Control\SearchBar\ObjectSuggestions;
use Icinga\Module\Icingadb\Web\Control\ViewModeSwitcher;
use Icinga\Module\Icingadb\Web\Controller;
use Icinga\Module\Icingadb\Widget\ItemList\ServiceList;
use Icinga\Module\Icingadb\Widget\ItemTable\ServicegroupTableRow;
use ipl\Html\Html;
use ipl\Stdlib\Filter;
use ipl\Web\Control\LimitControl;
use ipl\Web\Control\SortControl;
use ipl\Web\Url;

class ServicegroupController extends Controller
{
/** @var ServicegroupSummary The service group object */
protected $servicegroup;
/** @var string */
protected $servicegroupName;

public function init()
{
$this->assertRouteAccess('servicegroups');
$this->servicegroupName = $this->params->shiftRequired('name');
}

$this->addTitleTab(t('Service Group'));

$name = $this->params->getRequired('name');

/**
* Fetch the service group object
*
* @return ServicegroupSummary
*/
protected function fetchServicegroup(): ServicegroupSummary
{
$query = ServicegroupSummary::on($this->getDb());

foreach ($query->getUnions() as $unionPart) {
$unionPart->filter(Filter::equal('servicegroup.name', $name));
$unionPart->filter(Filter::equal('servicegroup.name', $this->servicegroupName));
}

$this->applyRestrictions($query);

/** @var ServicegroupSummary $servicegroup */
$servicegroup = $query->first();
if ($servicegroup === null) {
throw new NotFoundError(t('Service group not found'));
$this->httpNotFound(t('Service group not found'));
}

$this->servicegroup = $servicegroup;
$this->setTitle($servicegroup->display_name);
return $servicegroup;
}

public function indexAction()
{
$db = $this->getDb();
$servicegroup = $this->fetchServicegroup();

$services = Service::on($db)->with([
'state',
Expand All @@ -57,33 +68,102 @@ public function indexAction()
]);
$services
->setResultSetClass(VolatileStateResults::class)
->filter(Filter::equal('servicegroup.id', $this->servicegroup->id));
->filter(Filter::equal('servicegroup.id', $servicegroup->id));

$this->applyRestrictions($services);

$limitControl = $this->createLimitControl();
$paginationControl = $this->createPaginationControl($services);
$sortControl = $this->createSortControl(
$services,
[
'service.display_name' => t('Name'),
'service.state.severity desc,service.state.last_state_change desc' => t('Severity'),
'service.state.soft_state' => t('Current State'),
'service.state.last_state_change desc' => t('Last State Change'),
'host.display_name' => t('Host')
]
);
$viewModeSwitcher = $this->createViewModeSwitcher($paginationControl, $limitControl);

$serviceList = (new ServiceList($services->execute()))
->setViewMode($viewModeSwitcher->getViewMode());
$searchBar = $this->createSearchBar($services, [
$limitControl->getLimitParam(),
$sortControl->getSortParam(),
$viewModeSwitcher->getViewModeParam(),
'name'
])->setSuggestionUrl(Url::fromPath(
'icingadb/servicegroup/complete',
[
'name' => $this->servicegroupName,
'_disableLayout' => true,
'showCompact' => true
]
));

if ($searchBar->hasBeenSent() && ! $searchBar->isValid()) {
if ($searchBar->hasBeenSubmitted()) {
$filter = $this->getFilter();
} else {
$this->addControl($searchBar);
$this->sendMultipartUpdate();
return;
}
} else {
$filter = $searchBar->getFilter();
}

$services->filter($filter);

yield $this->export($services);

$serviceList = (new ServiceList($services->execute()))
->setViewMode($viewModeSwitcher->getViewMode());

// ICINGAWEB_EXPORT_FORMAT is not set yet and $this->format is inaccessible, yeah...
if ($this->getRequest()->getParam('format') === 'pdf') {
$this->addContent(new ServicegroupTableRow($this->servicegroup));
$this->addContent(new ServicegroupTableRow($servicegroup));
$this->addContent(Html::tag('h2', null, t('Services')));
} else {
$this->addControl(new ServicegroupTableRow($this->servicegroup));
$this->addControl(new ServicegroupTableRow($servicegroup));
}

$this->addControl($paginationControl);
$this->addControl($viewModeSwitcher);
$this->addControl($sortControl);
$this->addControl($limitControl);
$this->addControl($viewModeSwitcher);
$this->addControl($searchBar);
$continueWith = $this->createContinueWith(Links::servicesDetails(), $searchBar);

$this->addContent($serviceList);

if (! $searchBar->hasBeenSubmitted() && $searchBar->hasBeenSent()) {
$this->sendMultipartUpdate($continueWith);
}

$this->addTitleTab(t('Service Group'));
$this->setTitle($servicegroup->display_name);
$this->setAutorefreshInterval(10);
}

public function completeAction()
{
$suggestions = new ObjectSuggestions();
$suggestions->setModel(Service::class);
$suggestions->setBaseFilter(Filter::equal('servicegroup.name', $this->servicegroupName));
$suggestions->forRequest($this->getServerRequest());
$this->getDocument()->add($suggestions);
}

public function searchEditorAction()
{
$editor = $this->createSearchEditor(Service::on($this->getDb()), [
LimitControl::DEFAULT_LIMIT_PARAM,
SortControl::DEFAULT_SORT_PARAM,
ViewModeSwitcher::DEFAULT_VIEW_MODE_PARAM,
'name'
]);

$this->getDocument()->add($editor);
$this->setTitle(t('Adjust Filter'));
}
}
21 changes: 14 additions & 7 deletions library/Icingadb/Widget/ItemTable/BaseServiceGroupItem.php
Original file line number Diff line number Diff line change
Expand Up @@ -34,8 +34,8 @@ protected function init(): void

protected function createSubject(): BaseHtmlElement
{
return isset($this->table)
? new Link(
if (isset($this->table)) {
$link = new Link(
$this->item->display_name,
Links::servicegroup($this->item),
[
Expand All @@ -45,12 +45,19 @@ protected function createSubject(): BaseHtmlElement
$this->item->display_name
)
]
)
: new HtmlElement(
'span',
Attributes::create(['class' => 'subject']),
Text::create($this->item->display_name)
);
if ($this->table->hasBaseFilter()) {
$link->getUrl()->setFilter($this->table->getBaseFilter());
}

return $link;
}

return new HtmlElement(
'span',
Attributes::create(['class' => 'subject']),
Text::create($this->item->display_name)
);
}

protected function createCaption(): BaseHtmlElement
Expand Down

0 comments on commit 82802ed

Please sign in to comment.