diff --git a/plugins/admin/systems/class_terminalStartup.inc b/plugins/admin/systems/class_terminalStartup.inc
index 0f644245cfd85b8fdcfb94a2a8c3e11a13e8e1f0..7a02964f21b2b15e9cac8df5a262bdbd8d7a387f 100644 (file)
/* Generic terminal attributes */
var $bootmode= "G";
- var $goLdapServerList= array("default");
- var $gotoBootKernel= "default";
+ var $goLdapServerList= array();
+ var $gotoBootKernel= "";
var $gotoKernelParameters= "";
var $gotoLdapServer= "";
var $gotoModules= array();
var $gotoTerminalPath= "";
+ var $gotoBootKernels= array();
/* Share */
var $gotoShares = array();// Currently Share Option
{
plugin::plugin ($config, $dn);
+ $this->gotoBootKernels = array("default"=>"["._("inherited")."]");
+
/* Get arrays */
foreach (array("gotoModules") as $val){
if (isset($this->attrs["$val"]["count"])){
$this->gotoAvailableShares= $config->getShareList(false);
$this->orig_dn= $this->dn;
+
+ /* Get list of boot kernels */
+ if (isset($this->config->data['TABS'])){
+ $command= search_config($this->config->data['TABS'], get_class($this), "KERNELS");
+
+ if (!check_command($command)){
+ $message[]= sprintf(_("Command '%s', specified as KERNELS hook for plugin '%s' doesn't seem to exist."), $command,
+ get_class($this));
+ } else {
+ $fh= popen($command, "r");
+ while (!feof($fh)) {
+ $buffer= fgets($fh, 256);
+ if(!empty($buffer)){
+ $this->gotoBootKernels[]= $buffer;
+ }
+ }
+ pclose($fh);
+ }
+
+ }
+ $tmp = $this->config->data['SERVERS']['LDAP'];
+ foreach($tmp as $server){
+ $visible = $server;
+ if($server == "default"){
+ $visible = "["._("inherited")."]";
+ }
+ $this->goLdapServerList[$server] = $visible;
+ }
+
+ /* Load hardware list */
+ $ldap= $this->config->get_ldap_link();
+ $ldap->cd($this->config->current['BASE']);
+ $ldap->search("(&(objectClass=gotoWorkstationTemplate)(member=".$this->dn."))");
+ if ($ldap->count() == 1){
+ $map= array("gotoLdapServer");
+ $attrs= $ldap->fetch();
+
+ foreach ($map as $name){
+ if (!isset($attrs[$name][0])){
+ continue;
+ }
+
+ switch ($name){
+ case 'gotoLdapServer':
+ $this->goLdapServerList= array_merge(array('default' => _("inherited").' ['.$attrs[$name][0].']' ), $this->goLdapServerList);
+ break;
+ }
+ }
+ }
}
function execute()
*/
$smarty->assign("gotoShareSelections", $this->gotoShareSelections);
$smarty->assign("gotoShareSelectionKeys", array_flip($this->gotoShareSelections));
+ $smarty->assign("gotoBootKernels",$this->gotoBootKernels);
/* if $_POST['gotoShareAdd'] is set, we will try to add a new entry
* This entry will be, a combination of mountPoint and sharedefinitions
$smarty->assign("gotoShares",$this->printOutAssignedShares());
$smarty->assign("gotoShareKeys",array_flip($this->printOutAssignedShares()));
+ /* Create divSelectBox for ldap server selection
+ */
+ $SelectBoxLdapServer = new divSelectBox("LdapServer");
+ $SelectBoxLdapServer->SetHeight(80);
+
+ /* Set first entry as selected, if $this->gotoLdapServer is empty
+ * or given entry is no longer available ...
+ */
+ $found = false;
+ foreach($this->goLdapServerList as $server => $name){
+ if($this->gotoLdapServer==$server){
+ $found = true;
+ }
+ }
+
+ /* Add Entries
+ */
+ foreach($this->goLdapServerList as $server => $visible){
+ $use ="";
+ if(($this->gotoLdapServer == $server) || ($found == false)) {
+ $found = true;
+ $use = " checked ";
+ };
+
+ $SelectBoxLdapServer->AddEntry(
+ array(
+ array("string"=>"<input type='radio' name='gotoLdapServer' value='".$server."' ".$use.">",
+ "attach"=>"style='border-left:0px;'"),
+ array("string"=>$visible)
+ ));
+ }
+ $smarty->assign("SelectBoxLdapServer",$SelectBoxLdapServer->DrawList());
- /* Arrays */
- $smarty->assign("ldapservers", $this->config->data['SERVERS']['LDAP']);
- $smarty->assign("gotoLdapServer_select", $this->gotoLdapServer);
- $smarty->assign("gotoLdapServerACL", chkacl($this->acl, "gotoLdapServer"));
$smarty->assign("gotoShareACL", chkacl($this->acl, "gotoShareACL"));
foreach (array("gotoModules" ) as $val){
$smarty->assign("$val", $this->$val);
$tmp= preg_replace ("/^[^,]+,/", "", $tmp);
$ldap->cat("cn=default,ou=terminals,ou=systems,$tmp".
- $this->config->current['BASE']);
+ $this->config->current['BASE'], array('gotoTerminalPath'));
$attrs= $ldap->fetch();
if (isset($attrs['gotoTerminalPath'])){
$this->gotoTerminalPath= $attrs['gotoTerminalPath'][0];
}
/* Strip out 'default' values */
- if ($this->attrs['gotoLdapServer'] == "default"){
- unset ($this->attrs['gotoLdapServer']);
+ foreach(array("gotoBootKernel","gotoLdapServer") as $value){
+ if (!isset($this->attrs[$value]) || $this->attrs[$value] == "default"){
+ $this->attrs[$value] = array();
+ }
}
/* prepare share settings */
$ldap= $this->config->get_ldap_link();
$ldap->cd($this->dn);
$this->cleanup();
-$ldap->modify ($this->attrs);
+ $ldap->modify ($this->attrs);
- show_ldap_error($ldap->get_error());
+ show_ldap_error($ldap->get_error(), _("Saving terminal startup settings failed"));
$this->handle_post_events("modify");
}