diff --git a/gosa-plugins/fai/admin/fai/class_faiManagement.inc b/gosa-plugins/fai/admin/fai/class_faiManagement.inc
index 7c08866ca461bca487610de3e28dce4ff11c6b75..e5f1bd8c6a3287afc75c055bbf8754e2bed563e2 100644 (file)
{
/* Definitions */
var $plHeadline = "Software deployment";
- var $plDescription = "Manage software packages and deployment reciepes";
+ var $plDescription = "Manage software packages and deployment reciepes";
+ var $plIcon = "plugins/fai/images/plugin.png";
/* Headpage attributes */
var $lock_type = ""; // should be branch/freeze
var $allow_freeze_object_attach = TRUE;
var $no_save;
+ var $acl_base ="";
var $fai_base ="";
var $fai_release ="";
var $acl_module = array("fai");
+ var $opsi = NULL;
+
/* construction/reconstruction
*/
function faiManagement (&$config, $ui)
$this->dn = "";
$this->config = $config;
$this->ui = $ui;
+
+ /* Check if the opsi plugin is installed.
+ */
+ if(class_available("opsi")){
+ $this->opsi = new opsi($this->config);;
+ }
/* Creat dialog object */
$this->DivListFai = new divListFai($this->config,$this);
/* Copy & Paste handler */
- if ($this->config->boolValueIsTrue("main", "enableCopyPaste")){
+ if ($this->config->boolValueIsTrue("main", "copyPaste")){
$this->CopyPasteHandler= new CopyPasteHandler($this->config);
}
- /* Set default release */
- $this->fai_base = get_ou("faiou").$this->config->current['BASE'];
+ /* Set default release
+ */
+ $this->acl_base = $this->config->current['BASE'];
+ $this->fai_base = get_ou("faiBaseRDN").$this->config->current['BASE'];
+
if(!session::is_set("fai_filter")){
- session::set("fai_filter",array("fai_release" => $this->fai_base));
+
+ /* Set intial release */
+ $rel = $config->search("faiManagement","DEFAULTFAIRELEASE",array("menu"));
+ $rels = array_flip($this->getBranches());
+ if(isset($rels[$rel])){
+ $rel = $rels[$rel];
+ }else{
+ $rel = $this->fai_base;
+ }
+
+ session::set("fai_filter",array("fai_release" => $rel));
}
$fai_filter = session::get("fai_filter");
/* Call parent execute */
plugin::execute();
+
/* Initialise vars and smarty */
$smarty = get_smarty();
$smarty->assign("BranchName","");
$s_action = $act;
$s_entry = ltrim(preg_replace($reg,"",$name),"_");
$s_entry = preg_replace("/_.*$/","",$s_entry);
+ break;
}
}
if(preg_match("/^entry_edit_.*/",$name)){
$s_entry = preg_replace("/^entry_edit_/","",$name);
$s_entry = preg_replace("/_.*$/","",$s_entry);
- $s_action = "edit";
- }elseif(preg_match("/^entry_freeze_edit_.*/",$name)){
- $s_entry = preg_replace("/^entry_freeze_edit_/","",$name);
- $s_entry = preg_replace("/_.*$/","",$s_entry);
- $s_action = "edit";
+ $s_action = "edit";
+ break;
+ }elseif(preg_match("/^entry_freeze_edit_.*/",$name)){
+ $s_entry = preg_replace("/^entry_freeze_edit_/","",$name);
+ $s_entry = preg_replace("/_.*$/","",$s_entry);
+ $s_action = "edit";
$no_save = TRUE;
- }elseif(preg_match("/^entry_delete_.*/",$name)){
- $s_entry = preg_replace("/^entry_delete_/","",$name);
- $s_entry = preg_replace("/_.*$/","",$s_entry);
+ break;
+ }elseif(preg_match("/^entry_delete_.*/",$name)){
+ $s_entry = preg_replace("/^entry_delete_/","",$name);
+ $s_entry = preg_replace("/_.*$/","",$s_entry);
$s_action = "delete";
+ break;
+ }
+
+ /* Get posts from opsi onjects
+ */
+ if($this->opsi instanceof opsi && $this->opsi->enabled()){
+ if(preg_match("/^entry_opsi_edit_/",$name)){
+ $s_entry = preg_replace("/^entry_opsi_edit_([0-9]*).*$/","\\1",$name);
+ $s_action = "opsi_edit";
+ break;
+ }
}
}
+ /* Get posts from opsi objects
+ */
+ if($this->opsi instanceof opsi && $this->opsi->enabled() && isset($_GET['edit_opsi_entry'])){
+ $s_entry = $_GET['edit_opsi_entry'];
+ $s_action = "opsi_edit";
+ }
+
if(isset($_GET['edit_entry'])){
$s_entry = $_GET['edit_entry'];
$s_action = "edit";
}
+ /*******************
+ Opsi extension
+ *******************/
+
+ if($this->opsi instanceof opsi && $this->opsi->enabled()){
+ if($s_action == "opsi_edit"){
+ $name = $this->objects[$s_entry]['cn'];
+ $cfg = $this->opsi->get_product_properties($name);
+ $this->dialog = new tabs_opsiProdConfig($this->config, $this->config->data['TABS']['OPSIPRODCONFIG'],"","opsi");
+ if(isset($this->dialog->by_object['opsiProperties'])){
+ $this->dialog->by_object['opsiProperties']->set_cfg($cfg);
+ $this->dialog->by_object['opsiProperties']->set_product($name);
+ }else{
+ trigger_error("Unknown tab, please check config.");
+ }
+ }
+ if($this->dialog instanceof tabs_opsiProdConfig && isset($_POST['cancel_properties'])){
+ $this->dialog = NULL;
+ }
+ if($this->dialog instanceof tabs_opsiProdConfig && isset($_POST['save_properties'])){
+ $this->dialog->save_object();
+ $op = $this->dialog->by_object['opsiProperties'];
+ $name = $op->get_product();
+ $cfg = $op->get_cfg();
+ $this->opsi->set_product_properties($name,$cfg);
+ if($this->opsi->is_error()){
+ msg_dialog::display(_("Error"),msgPool::siError($this->opsi->get_error()),ERROR_DIALOG);
+ }else{
+ $this->dialog = NULL;
+ }
+ }
+ if($this->dialog instanceof tabs_opsiProdConfig){
+ $this->dialog->save_object();
+ return($this->dialog->execute());
+ }
+ }
+
+
/****************
Delete confirme dialog
****************/
/* Lock the current entry, so nobody will edit it during deletion */
add_lock ($this->dn, $this->ui->dn);
- $smarty->assign("warning",msgPool::deleteInfo(@LDAP::fix($this->dn),_("FAI object")));
+ $smarty->assign("warning",msgPool::deleteInfo(LDAP::fix($this->dn),_("FAI object")));
$smarty->assign("multiple", false);
return($smarty->fetch(get_template_path('remove.tpl', TRUE)));
} else {
$dns_names = array();
foreach($this->dns as $dn){
add_lock ($dn, $this->ui->dn);
- $dns_names[] = @LDAP::fix($dn);
+ $dns_names[] = LDAP::fix($dn);
}
/* Lock the current entry, so nobody will edit it during deletion */
Delete confirmed
****************/
- /* Deltetion was confirmed, so delete this entry
+ /* Deletion was confirmed, so delete this entry
*/
if (isset($_POST['delete_terminal_confirm'])){
if("" != $this->config->search("faiManagement", "POSTREMOVE",array('menu','tabs'))){
/* Load permissions for selected 'dn' and check if
we're allowed to remove this 'dn' */
- if($this->acl_is_removeable()){
+ if(preg_match("/d/",$this->ui->get_permissions($this->acl_base,"fai/faiManagement"))){
$smarty->assign("release_hidden",base64_encode($this->fai_release));
- $smarty->assign("info", msgPool::deleteInfo(@LDAP::fix($this->fai_release),_("FAI branch/freeze")));
+ $smarty->assign("info", msgPool::deleteInfo(LDAP::fix($this->fai_release),_("FAI branch/freeze")));
return($smarty->fetch(get_template_path('remove_branch.tpl',TRUE)));
} else {
msg_dialog::display(_("Permission error"), _("You have no permission to delete this release!"), ERROR_DIALOG);
$br = $this->getBranches();
- if(isset($br[$bb]) && $this->acl_is_removeable()){
+ if(isset($br[$bb]) && preg_match("/d/",$this->ui->get_permissions($this->acl_base,"fai/faiManagement"))){
$name = $br[$bb];
$ldap->cd($bb);
$ldap->recursive_remove();
- $ldap->cd(preg_replace('/,'.normalizePreg(get_ou('faiou')).'/', ','.get_ou('applicationou'), $bb));
+ $ldap->cd(preg_replace('/,'.preg_quote(get_ou('faiBaseRDN'), '/').'/', ','.get_ou('applicationRDN'), $bb));
$ldap->recursive_remove();
- $ldap->cd(preg_replace('/,'.normalizePreg(get_ou('faiou')).'/', ','.get_ou('mimetypeou'), $bb));
+ $ldap->cd(preg_replace('/,'.preg_quote(get_ou('faiBaseRDN'), '/').'/', ','.get_ou('mimetypeRDN'), $bb));
$ldap->recursive_remove();
/* Search for all groups with configured application menus.
- The search für menu configuration for the specified release and collect all those dns.
- Remove entries
*/
- $release_ou = preg_replace("/".normalizePreg(get_ou("faiou")).".*$/","",$bb);
+ $release_ou = preg_replace("/".preg_quote(get_ou("faiBaseRDN"), '/').".*$/","",$bb);
$ldap->cd($this->config->current['BASE']);
$ldap->search("(objectClass=posixGroup)",array("dn"));
$ldap->cd($dn);
$ldap->search("(objectClass=FAIbranch)",array("dn"));
while($attrs = $ldap->fetch()){
- if(preg_match("/^".normalizePreg($release_ou)."/",$attrs['dn'])){
+ if(preg_match("/^".preg_quote($release_ou, '/')."/",$attrs['dn'])){
$dns[] = $attrs['dn'];
}
}
if(isset($_GET['PerformBranch'])){
- if(!$this->acl_is_createable()){
+ if(!preg_match("/c/",$this->ui->get_permissions($this->acl_base,"fai/faiManagement"))){
msg_dialog::display(_("Permission error"), msgPool::permCreate(_("Branch")), ERROR_DIALOG);
}else{
}
}
- $appsrc = preg_replace("/".normalizePreg(get_ou('faiou'))."/",get_ou('applicationou'),$baseToUse);
- $appdst = preg_replace("/".normalizePreg(get_ou('faiou'))."/",get_ou('applicationou'),"ou=".$name.",".$baseToUse) ;
+ $appsrc = preg_replace("/".preg_quote(get_ou('faiBaseRDN'), '/')."/",get_ou('applicationRDN'),$baseToUse);
+ $appdst = preg_replace("/".preg_quote(get_ou('faiBaseRDN'), '/')."/",get_ou('applicationRDN'),"ou=".$name.",".$baseToUse) ;
- $mimesrc = preg_replace("/".normalizePreg(get_ou('faiou'))."/",get_ou('mimetypeou'),$baseToUse);
- $mimedst = preg_replace("/".normalizePreg(get_ou('faiou'))."/",get_ou('mimetypeou'),"ou=".$name.",".$baseToUse) ;
+ $mimesrc = preg_replace("/".preg_quote(get_ou('faiBaseRDN'), '/')."/",get_ou('mimetypeRDN'),$baseToUse);
+ $mimedst = preg_replace("/".preg_quote(get_ou('faiBaseRDN'), '/')."/",get_ou('mimetypeRDN'),"ou=".$name.",".$baseToUse) ;
/* Check if source depeartments exist */
foreach(array($baseToUse,$appsrc,$mimesrc) as $dep){
echo "<div style='width:100%;text-align:right;'><form name='form' method='post' action='?plug=".$_GET['plug']."' target='_parent'>
<br><input type='submit' name='CloseIFrame' value='"._("Continue")."'>
+ <input type='hidden' name='php_c_check' value='1'>
</form></div>";
echo "<script language=\"javascript\" type=\"text/javascript\">scrollDown2();</script>" ;
$evt = $events['TRIGGERED']['DaemonEvent_recreate_fai_release_db'];
$tmp = new $evt['CLASS_NAME']($this->config);
$tmp->set_type(TRIGGERED_EVENT);
- $tmp->add_targets(array("GOsa"));
+ $tmp->add_targets(array("GOSA"));
$o_queue = new gosaSupportDaemon();
if(!$o_queue->append($tmp)){
msg_dialog::display(_("Service infrastructure"),msgPool::siError($o_queue->get_error()),ERROR_DIALOG);
}
}else{
trigger_error("Unknown class DaemonEvent / gosaSupportDaemon");
+ msg_dialog::display(_("Fatal error"),
+ "Daemon events called but classes where not accessible, DaemonEvent gosaSupportDaemon",
+ FATAL_ERROR_DIALOG);
}
exit();
}
*/
if("" != $this->config->search("faiManagement", "POSTCREATE",array('menu','tabs'))){
if(($s_action == "branch_branch")||($this->dispNewBranch)){
- if(!$this->acl_is_createable()){
- msg_dialog::display(_("Permission error"), msgPool::permCreate(_("Branch")), ERROR_DIALOG);
+ if(!preg_match("/c/",$this->ui->get_permissions($this->acl_base,"fai/faiManagement"))){
+ msg_dialog::display(_("Permission error"), msgPool::permCreate(_("Branch")), ERROR_DIALOG);
}else{
$this->dispNewBranch=true;
$smarty->assign("iframe",false);
*/
if("" != $this->config->search("faiManagement", "POSTCREATE",array('menu','tabs'))){
if(($s_action == "freeze_branch")||($this->dispNewFreeze)){
- if(!$this->acl_is_createable()){
+ if(!preg_match("/c/",$this->ui->get_permissions($this->acl_base,"fai/faiManagement"))){
msg_dialog::display(_("Permission error"), msgPool::permCreate(_("Branch")), ERROR_DIALOG);
}else{
$this->dispNewFreeze = true;
"new_package" => _("package list"));
if(isset($types[$s_action])){
- $acl = $this->ui->get_permissions($this->fai_base,"fai/".$type_acl_mapping[$types[$s_action]]);
+ $acl = $this->ui->get_permissions($this->acl_base,"fai/".$type_acl_mapping[$types[$s_action]]);
if(preg_match("/c/",$acl)){
$this->dialog = new askClassName($this->config,$this->dn,$this->ui,$types[$s_action]);
$this->dialog->parent = &$this;
if($s_action == "new_profile"){
$this->dn = "new" ;
- $acl = $this->ui->get_permissions($this->fai_base,"fai/faiProfile");
+ $acl = $this->ui->get_permissions($this->acl_base,"fai/faiProfile");
if(preg_match("/c/",$acl)){
$a_setup= $this->get_type(array("objectClass"=>array("FAIprofile")));
$this->dialog = new $a_setup[0]($this->config,$this->config->data['TABS'][$a_setup[2]],$this->dn,"fai");
function get_used_snapshot_bases()
{
$tmp = array();
- $types = array("faipartitionou","faiscriptou","faitemplateou","faihookou","faiprofileou","faivariableou","faipackageou");
+ $types = array("faiPartitionRDN","faiScriptRDN","faiTemplateRDN","faiHookRDN","faiProfileRDN","faiVariableRDN","faiPackageRDN");
foreach($types as $type){
$tmp[] = get_ou($type).$this->fai_release;
}
}
}
$this->base = $base;
- $this->set_acl_base($this->base);
+ $this->set_acl_base($this->acl_base);
$this->lock_type = FAI::get_release_tag(FAI::get_release_dn($base));
* Generate List of Partitions,Hooks,Scripts,Templates,Profiles ...
*/
$ObjectTypes = array(
- "FAIpartitionTable" => array("OU"=> get_ou('faipartitionou') , "CHKBOX"=>"ShowPartitions" ,"ACL" => "faiPartitionTable"),
- "FAIpackageList" => array("OU"=> get_ou('faipackageou') , "CHKBOX"=>"ShowPackages" ,"ACL" => "faiPackage"),
- "FAIscript" => array("OU"=> get_ou('faiscriptou') , "CHKBOX"=>"ShowScripts" ,"ACL" => "faiScript"),
- "FAIvariable" => array("OU"=> get_ou('faivariableou') , "CHKBOX"=>"ShowVariables" ,"ACL" => "faiVariable"),
- "FAIhook" => array("OU"=> get_ou('faihookou') , "CHKBOX"=>"ShowHooks" ,"ACL" => "faiHook"),
- "FAIprofile" => array("OU"=> get_ou('faiprofileou') , "CHKBOX"=>"ShowProfiles" ,"ACL" => "faiProfile"),
- "FAItemplate" => array("OU"=> get_ou('faitemplateou') , "CHKBOX"=>"ShowTemplates" ,"ACL" => "faiTemplate"));
+ "FAIpartitionTable" => array("OU"=> get_ou('faiPartitionRDN') , "CHKBOX"=>"ShowPartitions" ,"ACL" => "faiPartitionTable"),
+ "FAIpackageList" => array("OU"=> get_ou('faiPackageRDN') , "CHKBOX"=>"ShowPackages" ,"ACL" => "faiPackage"),
+ "FAIscript" => array("OU"=> get_ou('faiScriptRDN') , "CHKBOX"=>"ShowScripts" ,"ACL" => "faiScript"),
+ "FAIvariable" => array("OU"=> get_ou('faiVariableRDN') , "CHKBOX"=>"ShowVariables" ,"ACL" => "faiVariable"),
+ "FAIhook" => array("OU"=> get_ou('faiHookRDN') , "CHKBOX"=>"ShowHooks" ,"ACL" => "faiHook"),
+ "FAIprofile" => array("OU"=> get_ou('faiProfileRDN') , "CHKBOX"=>"ShowProfiles" ,"ACL" => "faiProfile"),
+ "FAItemplate" => array("OU"=> get_ou('faiTemplateRDN') , "CHKBOX"=>"ShowTemplates" ,"ACL" => "faiTemplate"));
$filter = "";
foreach($ObjectTypes as $key => $data){
}
}
+ /* Append opsi objects, if opsi is available and if we are on the fai_base
+ */
+ if($this->opsi instanceof opsi && $this->opsi->enabled()){
+ $opsi_acl = $this->ui->get_permissions($base,"opsi/opsiProperties");
+ if(preg_match("/r/",$opsi_acl)){
+ $err = FALSE;
+ if(!$err && $this->DivListFai->ShowOpsiNetboot){
+ $n_pro = $this->opsi->get_netboot_products();
+ $err |= $this->opsi->is_error();
+ foreach($n_pro as $name => $data){
+ $entry = array("cn" => $name,
+ "description" => $data['DESC'],
+ "type" => "opsi_netboot");
+ $this->objects[$name."_opsi_netboot"] = $entry;
+ }
+ }
+ if(!$err && $this->DivListFai->ShowOpsiLocal){
+ $l_pro = $this->opsi->get_local_products();
+ $err |= $this->opsi->is_error();
+ foreach($l_pro as $name => $data){
+ $entry = array("cn" => $name,
+ "description" => $data['DESC'],
+ "type" => "opsi_local");
+ $this->objects[$name."_opsi_local"] = $entry;
+ }
+ }
+ if($err){
+ msg_dialog::display(_("Error"),msgPool::siError($this->opsi->get_error()),ERROR_DIALOG);
+ }
+ }
+ }
+
ksort($this->objects);
reset ($this->objects);
static function check_class_name($oc,$name,$dn)
{
$base = FAI::get_release_dn($dn);
- $res = FAI::get_all_objects_for_given_base($base,"(objectClass=".$oc.")",TRUE);
+
+ if($oc == "FAIprofile"){
+ $f = "";
+ $ocs = array("FAIprofile","FAItemplate","FAIhook","FAIpartitionTable","FAIpackageList","FAIscript","FAIvariable");
+ foreach($ocs as $oc){
+ $f .= "(objectClass=".$oc.")";
+ }
+ $res = FAI::get_all_objects_for_given_base($base,"(|".$f.")",TRUE);
+ }else{
+ $res = FAI::get_all_objects_for_given_base($base,"(objectClass=".$oc.")",TRUE);
+ }
$delete = array();
$used = array();
foreach($res as $object){