diff --git a/plugins/admin/systems/class_servRepository.inc b/plugins/admin/systems/class_servRepository.inc
index 9a3114e80a317c724535f7b809264afb504bc60e..f5359b0b4584bd7eb32a144e3b0248c5167d5dfe 100644 (file)
/* Repositories */
var $repositories = array();
/* Repositories */
var $repositories = array();
- var $FAIrepository = array();
+ var $FAIrepository = array();
- function servrepository ($config, $dn= NULL)
+ var $fai_activated = FALSE;
+
+ function servrepository ($config, $dn= NULL, $parent= NULL)
{
{
- plugin::plugin ($config, $dn);
+ plugin::plugin ($config, $dn, $parent);
+
+ /* Skip this if fai is deactivated */
+ $tmp = search_config($this->config->data,"faiManagement","CLASS");
+ if(!empty($tmp)){
+ $this->fai_activated = TRUE;
+ }else{
+ return;
+ }
+ $ui = get_userinfo();
+ $tmp= get_permissions ($this->dn, $ui->subtreeACL);
+ $this->acl= get_module_permission($tmp, "servrepository", $this->dn);
+
$this->repositories = array();
if(isset($this->attrs['FAIrepository'])){
for($i = 0; $i < $this->attrs['FAIrepository']['count']; $i++){
$this->repositories = array();
if(isset($this->attrs['FAIrepository'])){
for($i = 0; $i < $this->attrs['FAIrepository']['count']; $i++){
/* Call parent execute */
plugin::execute();
/* Call parent execute */
plugin::execute();
+ if(!$this->fai_activated){
+ $str = "<h2>"._("You can't use this plugin until FAI is activated.")."</h2>";
+ return $str;
+ }
+
/* Fill templating stuff */
$smarty= get_smarty();
$display= "";
/* Fill templating stuff */
$smarty= get_smarty();
$display= "";
+ $ui = get_userinfo();
+ $tmp= get_permissions ($this->dn, $ui->subtreeACL);
+ $this->acl= get_module_permission($tmp, "servrepository", $this->dn);
+ $allow_edit = !preg_match("/disabled/i",chkacl($this->acl,"FAIclass"));
+
+
/* Smarty vars*/
$smarty->assign("infoimage", get_template_path('images/info.png'));
$smarty->assign("search_image", get_template_path('images/search.png'));
/* Smarty vars*/
$smarty->assign("infoimage", get_template_path('images/info.png'));
$smarty->assign("search_image", get_template_path('images/search.png'));
/* Do we need to flip is_account state? */
if (isset($_POST['modify_state'])){
/* Do we need to flip is_account state? */
if (isset($_POST['modify_state'])){
- $this->is_account= !$this->is_account;
+
+ /* Only change account state if allowed */
+ if($this->is_account && $this->acl == "#all#"){
+ $this->is_account= !$this->is_account;
+ $this->is_modified = true;
+ }elseif(!$this->is_account && chkacl($this->acl,"create") == ""){
+ $this->is_account= !$this->is_account;
+ $this->is_modified = true;
+ }
}
/* Show tab dialog headers */
}
/* Show tab dialog headers */
if(isset($_POST['servRepository'])){
foreach($_POST as $name => $value){
if(isset($_POST['servRepository'])){
foreach($_POST as $name => $value){
- if(preg_match("/AddRepository/",$name)){
+ if(preg_match("/AddRepository/",$name) && !$once && $allow_edit){
$once = true;
$this->dialog = new servRepositorySetup($this->config,$this->dn);
$this->dialog->acl = $this->acl;
}
$once = true;
$this->dialog = new servRepositorySetup($this->config,$this->dn);
$this->dialog->acl = $this->acl;
}
- if((preg_match("/^delete_/",$name))&&(!$once)){
+ if((preg_match("/^delete_/",$name))&&(!$once) && $allow_edit){
$once = true;
$value = preg_replace("/delete_/","",$name);
$value = base64_decode(preg_replace("/_.*$/","",$value));
$once = true;
$value = preg_replace("/delete_/","",$name);
$value = base64_decode(preg_replace("/_.*$/","",$value));
}
}
}
}
- if((preg_match("/^edit_/",$name))&&(!$once)){
+ if((preg_match("/^edit_/",$name))&&(!$once) && $allow_edit){
$value = preg_replace("/edit_/","",$name);
$value = base64_decode(preg_replace("/_.$/","",$value));
$value = preg_replace("/edit_/","",$name);
$value = base64_decode(preg_replace("/_.$/","",$value));
}
}
}
}
}
}
- if((isset($_GET['act']))&&($_GET['act']=="open")&&(isset($_GET['id']))){
+ if((isset($_GET['act']))&&($_GET['act']=="open")&&(isset($_GET['id'])) && $allow_edit){
$obj = $this->repositories[base64_decode($_GET['id'])];
$obj['initialy_was'] = $obj['Release'];
$this->dialog = new servRepositorySetup($this->config,$this->dn,$obj);
$obj = $this->repositories[base64_decode($_GET['id'])];
$obj['initialy_was'] = $obj['Release'];
$this->dialog = new servRepositorySetup($this->config,$this->dn,$obj);
foreach($this->repositories as $name => $reps){
$str = " ";
foreach($this->repositories as $name => $reps){
$str = " ";
-
if(preg_match("/".str_replace("*",".*",$this->regex)."/",$reps['Release'])){
if(preg_match("/".str_replace("*",".*",$this->regex)."/",$reps['Release'])){
-
foreach($reps['Sections'] as $sec){
$str.=$sec." ";
}
foreach($reps['Sections'] as $sec){
$str.=$sec." ";
}
-
+
+ if($allow_edit){
+ $link_str = sprintf($link,base64_encode($name),$name);
+ $sections = sprintf($link,base64_encode($name),_("Sections")." :".$str);
+ $options = preg_replace("/%s/",base64_encode($name),$edit.$delete);
+ }else{
+ $link_str = $name;
+ $sections = _("Sections")." :".$str;
+ $options = "";
+ }
+
+
$divlist->AddEntry(array(
$divlist->AddEntry(array(
- array("string"=>sprintf($link,base64_encode($name),$name),"attach"=>"style='width:80px;'"),
- array("string"=>sprintf($link,base64_encode($name),_("Sections")." :".$str)),
- array("string"=>preg_replace("/%s/",base64_encode($name),$edit.$delete),"attach"=>"style='border-right:0px;width:55px;text-align:right;'")
- ));
+ array("string"=>$link_str,"attach"=>"style='width:80px;'"),
+ array("string"=>$sections),
+ array("string"=>$options,"attach"=>"style='border-right:0px;width:55px;text-align:right;'")));
}
}
$smarty -> assign("Repositories",$divlist->DrawList());
}
}
$smarty -> assign("Repositories",$divlist->DrawList());
+ $smarty -> assign("FAIclassACL",chkacl($this->acl,"FAIclass"));
$display.= $smarty->fetch(get_template_path('servRepository.tpl', TRUE));
return($display);
$display.= $smarty->fetch(get_template_path('servRepository.tpl', TRUE));
return($display);
function remove_from_parent()
{
function remove_from_parent()
{
+
+ if(!$this->fai_activated) return;
+
+ /* Skip if not allowed */
+ $ui = get_userinfo();
+ $tmp= get_permissions ($this->dn, $ui->subtreeACL);
+ $this->acl= get_module_permission($tmp, "servrepository", $this->dn);
+
+ if(preg_match("/disabled/",chkacl($this->acl,"FAIclass"))) return;
+
plugin::remove_from_parent();
$ldap= $this->config->get_ldap_link();
$ldap->cd ($this->config->current['BASE']);
plugin::remove_from_parent();
$ldap= $this->config->get_ldap_link();
$ldap->cd ($this->config->current['BASE']);
/* Save to LDAP */
function save()
{
/* Save to LDAP */
function save()
{
+ if(!$this->fai_activated) return;
+
+ /* Skip if not allowed */
+ $ui = get_userinfo();
+ $tmp= get_permissions ($this->dn, $ui->subtreeACL);
+ $this->acl= get_module_permission($tmp, "servrepository", $this->dn);
+
+ if(preg_match("/disabled/",chkacl($this->acl,"FAIclass"))) return;
plugin::save();
$arr = array();
plugin::save();
$arr = array();