From: hickert Date: Wed, 28 May 2008 10:04:24 +0000 (+0000) Subject: Added checks && permssion checks to acl roles X-Git-Url: https://git.tokkee.org/?a=commitdiff_plain;h=68c8df5e34cf726c4ffe74b5708aade53220dfbe;p=gosa.git Added checks && permssion checks to acl roles git-svn-id: https://oss.gonicus.de/repositories/gosa/trunk@11075 594d385d-05f5-0310-b6e9-bd551577e9d8 --- diff --git a/gosa-core/plugins/admin/acl/class_aclRole.inc b/gosa-core/plugins/admin/acl/class_aclRole.inc index f77c9361f..809d057c5 100644 --- a/gosa-core/plugins/admin/acl/class_aclRole.inc +++ b/gosa-core/plugins/admin/acl/class_aclRole.inc @@ -51,6 +51,7 @@ class aclrole extends acl var $cn = ""; var $description = ""; var $orig_dn; + var $orig_base; var $base =""; function aclrole (&$config, $dn= NULL) @@ -136,6 +137,8 @@ class aclrole extends acl /* Finally - we want to get saved... */ $this->is_account= TRUE; + $this->orig_base = $this->base; + $this->orig_dn = $this->dn; } @@ -706,6 +709,29 @@ class aclrole extends acl )); } + function check() + { + $message = plugin::check(); + + if(empty($this->cn)){ + $message[] = msgPool::required(_("Name")); + } + + if(!count($this->gosaAclTemplate)){ + $message[] = msgPool::required(_("ACL")); + } + + /* Check if we are allowed to create or move this object + */ + if($this->orig_dn == "new" && !$this->acl_is_createable($this->base)){ + $message[] = msgPool::permCreate(); + }elseif($this->base != $this->orig_base && !$this->acl_is_moveable($this->base)){ + $message[] = msgPool::permMove(); + } + + return($message); + } + } // vim:tabstop=2:expandtab:shiftwidth=2:filetype=php:syntax:ruler: