DirectorObjectForm: do not allow to store...
...IcingaHost objects you wouldn't be allowed to see afterwards fixes #1451
This commit is contained in:
parent
3e46602802
commit
8c7897ee46
|
@ -13,6 +13,7 @@ before switching to a new version.
|
|||
### Permissions and Restrictions
|
||||
* FEATURE: Showing the executed SQL query now requires the `showsql` permission
|
||||
* FEATURE: Grant access to Service Set in a controlled way
|
||||
* FIX: do not allow a user to create hosts he wouldn't be allowed to see #1451
|
||||
|
||||
### User Interface
|
||||
* FEATURE: Admins have now access to JSON download links in many places
|
||||
|
|
|
@ -4,14 +4,17 @@ namespace Icinga\Module\Director\Web\Form;
|
|||
|
||||
use Exception;
|
||||
use Icinga\Authentication\Auth;
|
||||
use Icinga\Exception\AuthenticationException;
|
||||
use Icinga\Module\Director\Db;
|
||||
use Icinga\Module\Director\Data\Db\DbObject;
|
||||
use Icinga\Module\Director\Data\Db\DbObjectWithSettings;
|
||||
use Icinga\Module\Director\Exception\NestingError;
|
||||
use Icinga\Module\Director\IcingaConfig\StateFilterSet;
|
||||
use Icinga\Module\Director\IcingaConfig\TypeFilterSet;
|
||||
use Icinga\Module\Director\Objects\IcingaHost;
|
||||
use Icinga\Module\Director\Objects\IcingaTemplateChoice;
|
||||
use Icinga\Module\Director\Objects\IcingaObject;
|
||||
use Icinga\Module\Director\Restriction\HostgroupRestriction;
|
||||
use Icinga\Module\Director\Util;
|
||||
use Icinga\Module\Director\Web\Form\Validate\NamePattern;
|
||||
use Zend_Form_Element as ZfElement;
|
||||
|
@ -630,6 +633,15 @@ abstract class DirectorObjectForm extends DirectorForm
|
|||
{
|
||||
$object = $this->object();
|
||||
if ($object->hasBeenModified()) {
|
||||
if ($object instanceof IcingaHost && $this->hasHostGroupRestriction()) {
|
||||
$restriction = new HostgroupRestriction($this->db, $this->auth);
|
||||
if (! $restriction->allowsHost($object)) {
|
||||
throw new AuthenticationException($this->translate(
|
||||
'Unable to store a host with the given properties because of insufficient permissions'
|
||||
));
|
||||
}
|
||||
}
|
||||
|
||||
if (! $object->hasBeenLoadedFromDb()) {
|
||||
$this->setHttpResponseCode(201);
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue