X-Git-Url: https://git.tokkee.org/?a=blobdiff_plain;f=plugins%2Fadmin%2Fsystems%2Fclass_phoneGeneric.inc;h=76718175b7e3a42f7933ce8ac1d0bf54b27b05e3;hb=afecd435ef601ea27a281cc6667f94d7273b40e2;hp=2ac553d1bd03cd43a291bda7148aef5a2204aa69;hpb=3ce6d741726b64b96f460eac75a79a60b782e5fc;p=gosa.git diff --git a/plugins/admin/systems/class_phoneGeneric.inc b/plugins/admin/systems/class_phoneGeneric.inc index 2ac553d1b..76718175b 100644 --- a/plugins/admin/systems/class_phoneGeneric.inc +++ b/plugins/admin/systems/class_phoneGeneric.inc @@ -53,10 +53,10 @@ class phoneGeneric extends plugin var $objectclasses= array("top", "goFonHardware"); - function phonegeneric ($config, $dn= NULL) + function phonegeneric ($config, $dn= NULL, $parent= NULL) { - plugin::plugin ($config, $dn); - $this->netConfigDNS = new termDNS($this->config,$this->dn,$this->objectclasses); + plugin::plugin ($config, $dn, $parent); + $this->netConfigDNS = new termDNS($this->config,$this->dn,$this->objectclasses, true); /* Set base */ if ($this->dn == "new"){ @@ -220,6 +220,7 @@ class phoneGeneric extends plugin $smarty->assign($attr."ACL", chkacl($this->acl, $attr)); } $smarty->assign("base_select", $this->base); + $smarty->assign("baseACL", chkacl($this->acl,"base")); $smarty->assign("goFonDefaultIPs",array("dynamic"=>_("dynamic"),"network"=>_("Networksettings"))); @@ -243,7 +244,7 @@ class phoneGeneric extends plugin $this->netConfigDNS->remove_from_parent(); $ldap->rmdir($this->dn); - show_ldap_error($ldap->get_error()); + show_ldap_error($ldap->get_error(), _("Removing phone failed")); $this->handle_post_events("remove"); /* Delete references to object groups */ @@ -272,24 +273,20 @@ class phoneGeneric extends plugin /* Check supplied data */ function check() { - $message= $this->netConfigDNS->check(); + /* Call common method to give check the hook */ + $message= plugin::check(); + $message= array_merge($message, $this->netConfigDNS->check()); + $this->dn= "cn=".$this->cn.",ou=phones,ou=systems,".$this->base; /* To check for valid ip*/ - $num="(\\d|[1-9]\\d|1\\d\\d|2[0-4]\\d|25[0-5])"; - -// if(in_array("goFonDefaultIP",$this->usedattrs[$this->selected_categorie])){ -// if (!preg_match("/^$num\\.$num\\.$num\\.$num$/", $this->goFonDefaultIP)){ -// $message[]= _("Wrong IP format in field goFonDefaultIP."); -// } -// } - -// /* Check for valid number */ -// if(in_array("goFonDefaultIP",$this->usedattrs[$this->selected_categorie])){ -// if((strlen($this->goFonQualify))!=(strlen((int)($this->goFonQualify)))){ -// $message[]= _("The given value for 'Response timeout' is not a valid number."); -// } -// } + if($this->netConfigDNS->ipHostNumber == ""){ + $message[]= _("The required field IP address is empty."); + } else { + if (!is_ip($this->netConfigDNS->ipHostNumber)){ + $message[]= _("The field IP address contains an invalid address."); + } + } if ($this->cn == "" && chkacl ($this->acl, "cn") == ""){ $message[]= _("The required field 'Phone name' is not set."); @@ -382,7 +379,7 @@ class phoneGeneric extends plugin $ldap->cd($this->dn); $this->cleanup(); -$ldap->modify ($this->attrs); + $ldap->modify ($this->attrs); // $user_phone_reload $ldap->cd ($this->config->current['BASE']); @@ -397,8 +394,8 @@ $ldap->modify ($this->attrs); } $this->netConfigDNS->cn = $this->cn; $this->netConfigDNS->save($this->dn); + show_ldap_error($ldap->get_error(), _("Saving phone failed")); - show_ldap_error($ldap->get_error()); /* Optionally execute a command after we're done */ $this->postcreate(); }