diff --git a/gosa-core/plugins/admin/ogroups/class_ogroup.inc b/gosa-core/plugins/admin/ogroups/class_ogroup.inc
index c68ac83f4794400b9ef91abd7e136b2624b591c0..cb719055c989632e07a5c4f0f0aaeae6bc304644 100644 (file)
var $view_logged = FALSE;
var $copyMembers = TRUE;
-
+ var $wasDyGroup = FALSE;
var $baseSelector;
/* Already assigned Workstations. Will be hidden in selection.
$data[$key] = $dn;
$lData[$key] = array('data'=> array(image($image),$name));
}
+
+ if($this->isRestrictedByDynGroup()){
+ $this->memberListing->setDeleteable(false);
+ $smarty->assign("memberACL", preg_replace("/[^r]/", "", $this->getacl("member")));
+ $smarty->assign("isRestrictedByDynGroup", TRUE);
+
+ }else{
+ $this->memberListing->setDeleteable(true);
+ $smarty->assign("isRestrictedByDynGroup", FALSE);
+ }
+
$this->memberListing->setListData($data,$lData);
$this->memberListing->update();
$smarty->assign("memberList",$this->memberListing->render());
}
+ function isRestrictedByDynGroup()
+ {
+ $bool = FALSE;
+ if(isset($this->parent->by_object['DynamicLdapGroup'])){
+ $bool = $this->parent->by_object['DynamicLdapGroup']->isAttributeDynamic('member');
+ }
+ $this->wasDyGroup |= $bool;
+ return($bool);
+ }
+
+
function set_acl_base($base)
{
plugin::set_acl_base($base);
plugin::save();
/* Move members to target array */
- $this->attrs['member'] =array();
- foreach ($this->member as $key => $desc){
- $this->attrs['member'][]= LDAP::fix($key);
+ if(!$this->wasDyGroup && !$this->isRestrictedByDynGroup()){
+ $this->attrs['member'] =array();
+ foreach ($this->member as $key => $desc){
+ $this->attrs['member'][]= LDAP::fix($key);
+ }
}
$ldap= $this->config->get_ldap_link();