From 6c766dff43950bdb935997ccc6d708617bfa0711 Mon Sep 17 00:00:00 2001 From: raviks789 Date: Tue, 23 Jul 2024 11:21:48 +0200 Subject: [PATCH] Allow cloning service sets in Director Branches --- application/forms/IcingaCloneObjectForm.php | 21 ++++++++++++++++--- .../Web/Controller/ObjectController.php | 12 ++++++----- 2 files changed, 25 insertions(+), 8 deletions(-) diff --git a/application/forms/IcingaCloneObjectForm.php b/application/forms/IcingaCloneObjectForm.php index d2f826cc..13d8de56 100644 --- a/application/forms/IcingaCloneObjectForm.php +++ b/application/forms/IcingaCloneObjectForm.php @@ -29,7 +29,12 @@ class IcingaCloneObjectForm extends DirectorForm { $isBranch = $this->branch && $this->branch->isBranch(); $branchOnly = $this->object->get('id') === null; - if ($isBranch && $this->object instanceof IcingaObject && $this->object->isTemplate()) { + + if ( + $isBranch + && $this->object->isTemplate() + && ! $this->object instanceof IcingaServiceSet + ) { $this->addHtml(Hint::error($this->translate( 'Templates cannot be cloned in Configuration Branches' ))); @@ -149,7 +154,12 @@ class IcingaCloneObjectForm extends DirectorForm ); $isBranch = $this->branch && $this->branch->isBranch(); - if ($object->isTemplate() && $isBranch) { + + if ( + $isBranch + && $this->object->isTemplate() + && ! $this->object instanceof IcingaServiceSet + ) { throw new IcingaException('Cloning templates is not available for Branches'); } @@ -218,8 +228,13 @@ class IcingaCloneObjectForm extends DirectorForm $clone->set('host_id', $newId); } } elseif ($new instanceof IcingaServiceSet) { - $clone->set('service_set_id', $newId); + if ($isBranch) { + $clone->set('service_set', $newName); + } else { + $clone->set('service_set_id', $newId); + } } + $store->store($clone); } diff --git a/library/Director/Web/Controller/ObjectController.php b/library/Director/Web/Controller/ObjectController.php index 7c1acd63..88e38a45 100644 --- a/library/Director/Web/Controller/ObjectController.php +++ b/library/Director/Web/Controller/ObjectController.php @@ -218,12 +218,14 @@ abstract class ObjectController extends ActionController $this->addTitle($this->translate('Clone: %s'), $object->getObjectName()) ->addBackToObjectLink(); - if ($object->isTemplate() && $this->showNotInBranch($this->translate('Cloning Templates'))) { - return; - } + if (! $object instanceof IcingaServiceSet) { + if ($object->isTemplate() && $this->showNotInBranch($this->translate('Cloning Templates'))) { + return; + } - if ($object->isTemplate() && $this->showNotInBranch($this->translate('Cloning Apply Rules'))) { - return; + if ($object->isTemplate() && $this->showNotInBranch($this->translate('Cloning Apply Rules'))) { + return; + } } $form = IcingaCloneObjectForm::load()