diff --git a/plugins/admin/systems/class_phoneGeneric.inc b/plugins/admin/systems/class_phoneGeneric.inc
index dd0ca0ed08ae50b12edf6616943b5bbf7ca180ac..13fa101e9c681bb199396f27ecff570115becbf0 100644 (file)
var $goFonType = "";
var $goFonDmtfMode = "";
var $goFonHost = "";
- var $goFonDefaultIP = "";
+ var $goFonDefaultIP = "dynamic";
var $goFonQualify = "";
var $goFonAuth = "";
var $goFonSecret = "";
} else {
$this->selected_categorie = 0;
}
-
+
+ if($this->goFonDefaultIP!="dynamic"){
+ $this->goFonDefaultIP = "network";
+ }
+
/* Save dn for later references */
$this->orig_dn= $this->dn;
}
function execute()
{
-
-
+ /* Call parent execute */
+ plugin::execute();
+
/* Do we represent a valid phone? */
if (!$this->is_account && $this->parent == NULL){
$display= "<img alt=\"\" src=\"images/stop.png\" align=middle> <b>".
$smarty->assign($attr."ACL", chkacl($this->acl, $attr));
}
$smarty->assign("base_select", $this->base);
-
+
+ $smarty->assign("goFonDefaultIPs",array("dynamic"=>_("dynamic"),"network"=>_("Networksettings")));
+
/* Show Asterisk for required attribute ipHostNumber and macAddress */
$smarty->assign("staticAddress", "<font class=\"must\">*</font>");
function remove_from_parent()
{
$ldap= $this->config->get_ldap_link();
+ $ldap->cd($this->config->current['BASE']);
+
+ $ldap->search ("(&(objectClass=goFonAccount)(goFonHardware=".$this->cn."))", array("uid","cn"));
+ while ($attr = $ldap->fetch()){
+ print_red(sprintf(_("Can't delete because there are user which are depending on this phone. One of them is user '%s'."),
+ ($attr['uid'][0]." - ".$attr['cn'][0])));
+ return;
+ }
+
$ldap->rmdir($this->dn);
show_ldap_error($ldap->get_error());
$this->handle_post_events("remove");
/* 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.");
- }
- }
+// 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 goFonQualify is not a valid number.");
- }
- }
+// /* 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.");
+// }
+// }
/* must: cn, macAddress, ipHostNumber */
if ($this->cn == "" && chkacl ($this->acl, "cn") == ""){
if (!preg_match("/^$num\\.$num\\.$num\\.$num$/", $this->ipHostNumber)){
$message[]= _("Wrong IP format in field IP-address.");
}
+
+ $tr = count(split(":",$this->macAddress));
+ if($tr!=6){
+ $message[]=(_("The given macaddress is invalid. There must be 6 2byte segments seperated by ':'."));
+ }
$ui= get_userinfo();
$acl= get_permissions ($this->dn, $ui->subtreeACL);
}
$this->attrs= $attrs;
}
-
+
+ if($this->goFonDefaultIP!="dynamic"){
+ $this->attrs['goFonDefaultIP'] = $this->ipHostNumber;
+ }
+
/* Write back to ldap */
$ldap= $this->config->get_ldap_link();
if ($this->orig_dn == 'new'){
$ldap->cd($this->dn);
$ldap->modify($this->attrs);
+ // $user_phone_reload
+ $ldap->cd ($this->config->current['BASE']);
+ $user_phone_assignment = $ldap->fetch($ldap->search("(&(objectClass=goFonAccount)(goFonHardware=".$this->cn."))",array("uid")));
+ if($user_phone_assignment){
+ $usertab= new usertabs($this->config,$this->config->data['TABS']['USERTABS'], $user_phone_assignment['dn']);
+ $usertab->by_object['phoneAccount']->is_modified = true;
+ $usertab->save();
+ unset($usertab);
+ }
$this->handle_post_events("modify");
}
show_ldap_error($ldap->get_error());