X-Git-Url: https://git.tokkee.org/?a=blobdiff_plain;f=include%2Fclass_plugin.inc;h=24863ac16eb744738e38fdaea9bd1db22f7c90e1;hb=ac39e67e18bc613177d6f5a7229929f7e930a22a;hp=e9a9493f0d12541817c3af5d1ba3b1c013ccba41;hpb=96d436dc3deacb9fcf82bdb569d95485c81cc1dd;p=gosa.git
diff --git a/include/class_plugin.inc b/include/class_plugin.inc
index e9a9493f0..24863ac16 100644
--- a/include/class_plugin.inc
+++ b/include/class_plugin.inc
@@ -105,9 +105,12 @@ class plugin
/* attribute list for save action */
var $attributes= array();
var $objectclasses= array();
- var $new= TRUE;
+ var $is_new= TRUE;
var $saved_attributes= array();
+ var $acl_base= "";
+ var $acl_category= "";
+
/* Plugin identifier */
var $plHeadline= "";
var $plDescription= "";
@@ -130,6 +133,9 @@ class plugin
return;
}
+ /* Save current dn as acl_base */
+ $this->acl_base= $dn;
+
/* Get LDAP descriptor */
$ldap= $this->config->get_ldap_link();
if ($dn != NULL){
@@ -212,7 +218,7 @@ class plugin
*/
function execute()
{
- # This one is empty currently. Fabian - please fill in the docu code
+ /* This one is empty currently. Fabian - please fill in the docu code */
$_SESSION['current_class_for_help'] = get_class($this);
/* Reset Lock message POST/GET check array, to prevent perg_match errors*/
$_SESSION['LOCK_VARS_TO_USE'] =array();
@@ -267,7 +273,7 @@ class plugin
{
/* Save values to object */
foreach ($this->attributes as $val){
- if (chkacl ($this->acl, "$val") == "" && isset ($_POST["$val"])){
+ if ($this->acl_is_writeable($val) && isset ($_POST["$val"])){
/* Check for modifications */
if (get_magic_quotes_gpc()) {
$data= stripcslashes($_POST["$val"]);
@@ -289,6 +295,9 @@ class plugin
$data = "";
}
$this->$val= $data;
+ //echo "".$val."
";
+ }else{
+ //echo "".$val."
";
}
}
}
@@ -310,10 +319,10 @@ class plugin
if (isset($tmp['objectClass'])){
$oc= $tmp["objectClass"];
- $this->new= FALSE;
+ $this->is_new= FALSE;
} else {
$oc= array("count" => 0);
- $this->new= TRUE;
+ $this->is_new= TRUE;
}
/* Load (minimum) attributes, add missing ones */
@@ -328,7 +337,7 @@ class plugin
foreach ($this->attributes as $val){
if ($this->$val != ""){
$this->attrs["$val"]= $this->$val;
- } elseif (!$this->new) {
+ } elseif (!$this->is_new) {
$this->attrs["$val"]= array();
}
}
@@ -504,9 +513,43 @@ class plugin
return FALSE;
}
+
+ /* Show header message for tab dialogs */
+ function show_enable_header($button_text, $text, $disabled= FALSE)
+ {
+ if (($disabled == TRUE) || (!$this->acl_is_createable())){
+ $state= "disabled";
+ } else {
+ $state= "";
+ }
+ $display= "
$text \n"; + $display.= "
|
$text \n"; + $display.= "
|
$text \n"; $display.= "acl, "all")." ".$state. + ($this->acl_is_createable()?'':'disabled')." ".$state. ">
|