X-Git-Url: https://git.tokkee.org/?a=blobdiff_plain;f=plugins%2Fadmin%2Fsystems%2Fclass_phoneGeneric.inc;h=76718175b7e3a42f7933ce8ac1d0bf54b27b05e3;hb=7f51b7c557fe5fb3c73b5bde15856fbfdb08efbb;hp=c0d2d8ba23ac567bc819a51488a85df0135c09fc;hpb=994120dfb703051aa24b57fea2192a39e169499d;p=gosa.git diff --git a/plugins/admin/systems/class_phoneGeneric.inc b/plugins/admin/systems/class_phoneGeneric.inc index c0d2d8ba2..76718175b 100644 --- a/plugins/admin/systems/class_phoneGeneric.inc +++ b/plugins/admin/systems/class_phoneGeneric.inc @@ -9,22 +9,54 @@ class phoneGeneric extends plugin /* Generic terminal attributes */ var $interfaces= array(); + var $ignore_account= TRUE; /* Needed values and lists */ - var $base= ""; - var $cn= ""; - var $macAddress= ""; - var $ipHostNumber= ""; - var $description= ""; - var $orig_dn= ""; + var $base = ""; + var $cn = ""; + var $description = ""; + var $orig_dn = ""; + var $goFonType = ""; + var $goFonDmtfMode = ""; + var $goFonHost = ""; + var $goFonDefaultIP = "dynamic"; + var $goFonQualify = ""; + var $goFonAuth = ""; + var $goFonSecret = ""; + var $goFonInkeys = ""; + var $goFonPermit = array(); + var $goFonDeny = array(); + var $goFonOutkey = ""; + var $goFonTrunk = ""; + var $goFonAccountCode = ""; + var $goFonMSN = ""; + var $selected_categorie = 0; + var $netConfigDNS; /* attribute list for save action */ - var $attributes= array("cn", "description", "macAddress", "ipHostNumber"); + var $attributes= array("cn", "description", + "goFonType","goFonDmtfMode","goFonHost","goFonDefaultIP", + "goFonQualify","goFonAuth","goFonSecret","goFonInkeys","goFonOutkey", + "goFonTrunk","goFonAccountCode","goFonMSN","selected_categorie","goFonPermit","goFonDeny" + ); + + /* this array defines which attributes are schown / saved for the different type of phones */ + var $usedattrs = array( "0"=>array("cn", "description", + "goFonType","goFonDmtfMode","goFonHost","goFonDefaultIP", + "goFonQualify"), + "1"=>array("cn", "description", + "goFonType","goFonHost","goFonDefaultIP", + "goFonQualify","goFonAuth","goFonSecret","goFonInkeys","goFonOutkey", + "goFonTrunk","goFonAccountCode","selected_categorie","goFonPermit","goFonDeny"), + "2"=>array("cn", "description", "goFonMSN")); + + var $objectclasses= array("top", "goFonHardware"); - function phonegeneric ($config, $dn= NULL) + function phonegeneric ($config, $dn= NULL, $parent= NULL) { - plugin::plugin ($config, $dn); + plugin::plugin ($config, $dn, $parent); + $this->netConfigDNS = new termDNS($this->config,$this->dn,$this->objectclasses, true); /* Set base */ if ($this->dn == "new"){ @@ -34,6 +66,29 @@ class phoneGeneric extends plugin } else { $this->base= preg_replace ("/^[^,]+,[^,]+,[^,]+,/", "", $this->dn); } + + if($this->goFonMSN != ""){ + $this->selected_categorie = 2; + }elseif($this->goFonAccountCode != ""){ + $this->selected_categorie = 1 ; + + if(isset($this->attrs['goFonPermit']['count'])){ + unset ($this->attrs['goFonPermit']['count']); + $this->goFonPermit=$this->attrs['goFonPermit']; + } + + if(isset($this->attrs['goFonDeny']['count'])){ + unset ($this->attrs['goFonDeny']['count']) ; + $this->goFonDeny=$this->attrs['goFonDeny']; + } + + } else { + $this->selected_categorie = 0; + } + + if($this->goFonDefaultIP!="dynamic"){ + $this->goFonDefaultIP = "network"; + } /* Save dn for later references */ $this->orig_dn= $this->dn; @@ -41,6 +96,9 @@ class phoneGeneric extends plugin function execute() { + /* Call parent execute */ + plugin::execute(); + /* Do we represent a valid phone? */ if (!$this->is_account && $this->parent == NULL){ $display= "\"\" ". @@ -48,27 +106,145 @@ class phoneGeneric extends plugin return($display); } + /* Base select dialog */ + $once = true; + foreach($_POST as $name => $value){ + if(preg_match("/^chooseBase/",$name) && $once){ + $once = false; + $this->dialog = new baseSelectDialog($this->config); + $this->dialog->setCurrentBase($this->base); + } + } + + /* Dialog handling */ + if(is_object($this->dialog)){ + /* Must be called before save_object */ + $this->dialog->save_object(); + + if($this->dialog->isClosed()){ + $this->dialog = false; + }elseif($this->dialog->isSelected()){ + $this->base = $this->dialog->isSelected(); + $this->dialog= false; + }else{ + return($this->dialog->execute()); + } + } + + /* handle Permit Add*/ + if(isset($_POST['goFonPermitAdd'])){ + if(isset($_POST['goFonPermitNew'])){ + if(is_string($this->goFonPermit)){ + $this->goFonPermit=array(); + } + $new = $_POST['goFonPermitNew']; + if(strlen($new)> 1) { + $this->goFonPermit[]= $new; + } + } + } + + /* handle Deny Add*/ + if(isset($_POST['goFonDenyAdd'])){ + if(isset($_POST['goFonDenyNew'])){ + if(is_string($this->goFonDeny)){ + $this->goFonDeny=array(); + } + $new = $_POST['goFonDenyNew']; + if(strlen($new)> 1) { + $this->goFonDeny[]= $new; + } + } + } + + /* Handle Permit Deletion*/ + if(isset($_POST['goFonPermitDel'])){ + if(isset($_POST['goFonPermitS'])){ + if(is_string($this->goFonPermit)){ + $this->goFonPermit=array(); + } + $new = $_POST['goFonPermitS']; + $tmp = array_flip($this->goFonPermit); + unset($tmp[$new]); + $this->goFonPermit=array(); + foreach(array_flip($tmp) as $tm){ + $this->goFonPermit[]=$tm; + } + } + } + + + /* Handle Permit Deletion*/ + if(isset($_POST['goFonDenyDel'])){ + if(isset($_POST['goFonDenyS'])){ + if(is_string($this->goFonDeny)){ + $this->goFonDeny=array(); + } + $new = $_POST['goFonDenyS']; + $tmp = array_flip($this->goFonDeny); + unset($tmp[$new]); + $this->goFonDeny=array(); + foreach(array_flip($tmp) as $tm){ + $this->goFonDeny[]=$tm; + } + } + } + /* Fill templating stuff */ $smarty= get_smarty(); $smarty->assign("bases", $this->config->idepartments); + $smarty->assign("staticAddress","*");// $this->config->idepartments); + + /* Create Arrays for samrty select boxes */ + $smarty->assign("categories", array("SIP","IAX","CAPI")); + $smarty->assign("goFonTypes", array("peer" =>"peer" ,"user" =>"user" ,"friend" =>"friend")); + $smarty->assign("goFonDmtfModes", array("inband" =>"inband" ,"rfc2833"=>"rfc2833" ,"info" =>"info")); + $smarty->assign("goFonAuths", array("plaintext" =>"plaintext" ,"md5" =>"md5" /*,"rsa" =>"rsa"*/)); + $smarty->assign("goFonTrunks", array("yes" =>_("yes") ,"no" => _("no"))); + + /* deativate all fields that are not used by the specified type */ + foreach($this->attributes as $att){ + if((!in_array($att,$this->usedattrs[$this->selected_categorie]))||(chkacl($this->acl,$att)!="")){ + $smarty->assign($att."USED", "disabled" ); + $smarty->assign($att, ""); + }else{ + $smarty->assign($att."USED", "" ); + $smarty->assign($att, $this->$att); + } + } + + $smarty->assign("selected_categorie",$this->selected_categorie); /* Assign attributes */ foreach ($this->attributes as $attr){ $smarty->assign($attr."ACL", chkacl($this->acl, $attr)); - $smarty->assign("$attr", $this->$attr); } $smarty->assign("base_select", $this->base); - + $smarty->assign("baseACL", chkacl($this->acl,"base")); + + $smarty->assign("goFonDefaultIPs",array("dynamic"=>_("dynamic"),"network"=>_("Networksettings"))); + /* Show main page */ - $smarty->assign("netconfig", dirname(__FILE__)."/network.tpl"); + $smarty->assign("netconfig", $this->netConfigDNS->execute()); + $smarty->assign("phonesettings", dirname(__FILE__)."/phonesettings.tpl"); return($smarty->fetch (get_template_path('phone.tpl', TRUE))); } 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; + } + + $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 */ @@ -79,7 +255,6 @@ class phoneGeneric extends plugin unset($og->member[$this->dn]); $og->save (); } - } @@ -87,7 +262,7 @@ class phoneGeneric extends plugin function save_object() { plugin::save_object(); - + $this->netConfigDNS->save_object(); /* Save base, since this is no LDAP attribute */ if (isset($_POST['base']) && chkacl($this->acl, "create") == ""){ $this->base= $_POST['base']; @@ -98,18 +273,26 @@ class phoneGeneric extends plugin /* Check supplied data */ function check() { - $message= array(); + /* 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; - /* must: cn, macAddress */ + /* To check for valid ip*/ + 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."; + $message[]= _("The required field 'Phone name' is not set."); } if ($this->cn == "0" && chkacl ($this->acl, "cn") == ""){ - $message[]= "The 'Phone name' '0' is reserved and cannot be used."; - } - if ($this->macAddress == "" && chkacl ($this->acl, "macAddresscn") == ""){ - $message[]= "The required field 'MAC-address' is not set."; + $message[]= _("The 'Phone name' '0' is reserved and cannot be used."); } $ui= get_userinfo(); @@ -141,7 +324,28 @@ class phoneGeneric extends plugin function save() { plugin::save(); + + + /* only to define which attrs to save*/ + $mode = $this->attrs['selected_categorie']; + + /* Remove all unwanted attrs */ + foreach($this->attributes as $att){ + + /* Check all attributes, if they are needed for this type of phone */ + if(!in_array($att,$this->usedattrs[$mode])){ + $this->attrs[$att] = array(); + } + + /* Test rights of this user ... */ + if(chkacl($this->acl,$att)!=""){ + unset($this->attrs[$att]); + } + } + /* unset the categorie*/ + unset($this->attrs['selected_categorie']); + /* Remove all empty values */ if ($this->orig_dn == 'new'){ $attrs= array(); @@ -154,6 +358,12 @@ class phoneGeneric extends plugin $this->attrs= $attrs; } + if($this->goFonDefaultIP!="dynamic"){ + $this->attrs['goFonDefaultIP'] = $this->netConfigDNS->ipHostNumber; + } + + $this->attrs = $this->netConfigDNS->getVarsForSaving($this->attrs); + /* Write back to ldap */ $ldap= $this->config->get_ldap_link(); if ($this->orig_dn == 'new'){ @@ -168,10 +378,23 @@ class phoneGeneric extends plugin } $ldap->cd($this->dn); - $ldap->modify($this->attrs); + $this->cleanup(); + $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()); + $this->netConfigDNS->cn = $this->cn; + $this->netConfigDNS->save($this->dn); + show_ldap_error($ldap->get_error(), _("Saving phone failed")); /* Optionally execute a command after we're done */ $this->postcreate();