diff --git a/plugins/admin/systems/class_printGeneric.inc b/plugins/admin/systems/class_printGeneric.inc
index 28c81aac41d883ca50cca244646e60d658a87f5e..dea5899fdd2f1881f367cf2c323c6eaa12630a83 100644 (file)
var $AdminMember ="";
var $AdminMembers =array();
var $AdminMemberKeys =array();
-
+
+ var $is_terminalBased = false;
+
var $member =array();
var $strings = "";
var $type = "";
}
}
}
+
+ $ldap->search("(&(cn=".$this->cn.")(|(objectClass=gotoTerminal)(objectClass=gotoWorkstation)))",array("cn","objectClass"));
+ if($attrs = $ldap->fetch()){
+ if(in_array("gotoTerminal",$attrs['objectClass'])){
+ $this->is_terminalBased = "Terminal";
+ }else{
+ $this->is_terminalBased = "Workstation";
+ }
+ }
+
+
+
}
function execute()
if($this->is_terminal){
if(empty($this->cn)){
- $display= $this->show_header(_("Add printer extension"),
+ if(!in_array("gotoPrinter",$this->objectclasses)){
+ $display= $this->show_header(_("Add printer extension"),
_("This workstation has printer extension disabled. You can't enable it while 'cn' is not present in entry. Possibly you are currently creating a new terminal template"),TRUE,TRUE);
- $this->is_account= false;
- return $display;
- }
-
- if ($this->is_account){
- if($this->type=="station"){
- $display= $this->show_header(_("Remove printer extension"),
- _("This workstation has printer extension enabled.You can disable it by clicking below."));
+ $this->is_account= false;
+ return $display;
}else{
- $display= $this->show_header(_("Remove printer extension"),
- _("This terminal has printer extension enabled. You can disable it by clicking below."));
+ $smarty->assign("is_terminal","false");
+ $skip = true;
}
- }else{
- if($this->type=="station"){
- $display= $this->show_header(_("Add printer extension"),
- _("This workstation has printer extension disabled. You can enable it by clicking below."));
+ }
+
+ if(!isset($skip)){
+ if (($this->is_account)){
+ if($this->type=="station"){
+ $display= $this->show_header(_("Remove printer extension"),
+ _("This workstation has printer extension enabled.You can disable it by clicking below."));
+ }else{
+ $display= $this->show_header(_("Remove printer extension"),
+ _("This terminal has printer extension enabled. You can disable it by clicking below."));
+ }
}else{
- $display= $this->show_header(_("Add printer extension"),
- _("This terminal has printer extension disabled. You can enable it by clicking below."));
- }
- return ($display);
+ if($this->type=="station"){
+ $display= $this->show_header(_("Add printer extension"),
+ _("This workstation has printer extension disabled. You can enable it by clicking below."));
+ }else{
+ $display= $this->show_header(_("Add printer extension"),
+ _("This terminal has printer extension disabled. You can enable it by clicking below."));
+ }
+ return ($display);
+ }
}
}
$smarty->assign($attr."ACL", chkacl($this->acl, $attr));
$smarty->assign("$attr", $this->$attr);
}
-
+
if(isset($_POST['AddUser'])){
$this->dialog = new selectUserToPrinterDialog($this->config, get_userinfo(),"AddUser");
}
}
}
-
+
if(isset($_POST['ClosePPD'])){
unset($this->dialog);
$this->dialog=NULL;
asort($userlist);
asort($adminlist);
-
+ if($this->is_terminalBased){
+ if($this->is_terminalBased == "Terminal"){
+ $smarty->assign("desc" ,sprintf(_("This printer belongs to terminal %s. You can't rename this printer."),"<b>".$this->cn."</b>"));
+ }else{
+ $smarty->assign("desc" ,sprintf(_("This printer belongs to workstation %s. You can't rename this printer."),"<b>".$this->cn."</b>"));
+ }
+ $smarty->assign("cnACL" ," disabled ");
+ }else{
+ $smarty->assign("desc" ,"");
+ }
$smarty->assign("UserMember" ,$this->UserMember);
$smarty->assign("UserMembers" ,$userlist);
$smarty->assign("UserMemberKeys",array_flip($userlist));