diff --git a/plugins/admin/systems/class_terminalStartup.inc b/plugins/admin/systems/class_terminalStartup.inc
index 67a8e6bf87fb0af5cd520b4db03e51624d2fd5f7..6a80c0de5786968a146b954f092c94394105cf5b 100644 (file)
var $gotoKernelParameters= "";
var $gotoLdapServer= "";
var $gotoModules= array();
- var $gotoAutoFs= array();
- var $gotoFilesystem= array();
var $gotoTerminalPath= "";
+ /* Share */
+ var $gotoShares = array();// Currently Share Option
+ var $gotoShare = ""; // currently selected Share Option
+ var $gotoShareSelections= array();// Available Shares for this account in Listbox format
+ var $gotoAvailableShares= array();// Available Shares for this account
+
+
/* attribute list for save action */
var $attributes= array("gotoLdapServer", "gotoBootKernel", "gotoKernelParameters");
var $objectclasses= array("GOhard");
plugin::plugin ($config, $dn);
/* Get arrays */
- foreach (array("gotoModules", "gotoAutoFs", "gotoFilesystem") as $val){
+ foreach (array("gotoModules") as $val){
if (isset($this->attrs["$val"]["count"])){
for ($i= 0; $i<$this->attrs["count"]; $i++){
if (isset($this->attrs["$val"][$i])){
$this->customParameters= "";
}
+ /* Prepare Shares */
+ if((isset($this->attrs['gotoShare']))&&(is_array($this->attrs['gotoShare']))){
+ unset($this->attrs['gotoShare']['count']);
+ foreach($this->attrs['gotoShare'] as $share){
+ $tmp = $tmp2 = array();
+ $tmp = split("\|",$share);
+ $tmp2['server'] =$tmp[0];
+ $tmp2['name'] =$tmp[1];
+ $tmp2['mountPoint'] =$tmp[2];
+ $this->gotoShares[$tmp[1]."|".$tmp[0]]=$tmp2;
+ }
+ }
+
+ $this->gotoShareSelections= $config->getShareList(true);
+ $this->gotoAvailableShares= $config->getShareList(false);
+
$this->orig_dn= $this->dn;
}
function execute()
{
+ /* Call parent execute */
+ plugin::execute();
+
/* Do we need to flip is_account state? */
if (isset($_POST['modify_state'])){
$this->is_account= !$this->is_account;
}
}
- /* Add autofs */
- if (isset ($_POST['add_autofs'])){
- if ($_POST['autofs'] != "" && chkacl ($this->acl, "gotoAutoFs") == ""){
- $this->add_list ($this->gotoAutoFs, $_POST['autofs']);
- }
- }
+ /* Show main page */
+ $smarty= get_smarty();
- /* Delete autofs */
- if (isset ($_POST['delete_autofs'])){
- if (count($_POST['autofs_list']) && chkacl ($this->acl, "gotoAutoFs") == ""){
- $this->del_list ($this->gotoAutoFs, $_POST['autofs_list']);
- }
- }
- /* Add filesystem */
- if (isset ($_POST['add_fs'])){
- if ($_POST['fstab'] != "" && chkacl ($this->acl, "gotoFilesystem") == ""){
- $this->add_list ($this->gotoFilesystem, $_POST['fstab']);
+ /* In this section server shares will be defined
+ * A user can select one of the given shares and a mount point
+ * and attach this combination to his setup.
+ */
+ $smarty->assign("gotoShareSelections", $this->gotoShareSelections);
+ $smarty->assign("gotoShareSelectionKeys", array_flip($this->gotoShareSelections));
+
+ /* if $_POST['gotoShareAdd'] is set, we will try to add a new entry
+ * This entry will be, a combination of mountPoint and sharedefinitions
+ */
+ if(isset($_POST['gotoShareAdd'])){
+ /* We assign a share to this user, if we don't know where to mount the share */
+ if((!isset($_POST['gotoShareMountPoint']))||(empty($_POST['gotoShareMountPoint']))||(preg_match("/[\|]/i",$_POST['gotoShareMountPoint']))){
+ print_red(_("You must specify a valid mount point."));
+ }else{
+ $a_share = $this->gotoAvailableShares[$_POST['gotoShareSelection']];
+ $s_mount = $_POST['gotoShareMountPoint'];
+ /* Preparing the new assignment */
+ $this->gotoShares[$a_share['name']."|".$a_share['server']]=$a_share;
+ $this->gotoShares[$a_share['name']."|".$a_share['server']]['mountPoint']=$s_mount;
}
}
- /* Delete filesystem */
- if (isset ($_POST['delete_fs'])){
- if (count($_POST['fstab_list']) && chkacl ($this->acl, "gotoFilesystem") == ""){
- $this->del_list ($this->gotoFilesystem, $_POST['fstab_list']);
- }
+ /* if the Post gotoShareDel is set, someone asked GOsa to delete the selected entry (if there is one selected)
+ * If there is no defined share selected, we will abort the deletion without any message
+ */
+ if((isset($_POST['gotoShareDel']))&&(isset($_POST['gotoShare']))){
+ unset($this->gotoShares[$_POST['gotoShare']]);
}
- /* Show main page */
- $smarty= get_smarty();
+ $smarty->assign("gotoShares",$this->printOutAssignedShares());
+ $smarty->assign("gotoShareKeys",array_flip($this->printOutAssignedShares()));
+
+
/* Arrays */
$smarty->assign("ldapservers", $this->config->data['SERVERS']['LDAP']);
$smarty->assign("gotoLdapServer_select", $this->gotoLdapServer);
$smarty->assign("gotoLdapServerACL", chkacl($this->acl, "gotoLdapServer"));
- foreach (array("gotoModules", "gotoAutoFs", "gotoFilesystem") as $val){
+ $smarty->assign("gotoShareACL", chkacl($this->acl, "gotoShareACL"));
+ foreach (array("gotoModules" ) as $val){
$smarty->assign("$val", $this->$val);
}
}
/* ACL's */
- foreach (array("gotoKernelParameters", "gotoModules", "gotoFilesystem") as $value){
+ foreach (array("gotoKernelParameters", "gotoModules") as $value){
$smarty->assign($value."ACL", chkacl($this->acl, "$value"));
}
/* Show main page */
- return($smarty->fetch (get_template_path('startup.tpl', TRUE)));
+ return($smarty->fetch (get_template_path('terminalStartup.tpl', TRUE)));
}
function remove_from_parent()
{
- $ldap= $this->config->get_ldap_link();
- $ldap->rmdir($this->dn);
- show_ldap_error($ldap->get_error());
- $this->handle_post_events("remove");
+ $this->handle_post_events("remove");
}
plugin::save();
/* Add missing arrays */
- foreach (array("gotoFilesystem", "gotoAutoFs", "gotoModules") as $val){
+ foreach (array("gotoModules") as $val){
if (isset ($this->$val) && count ($this->$val) != 0){
$this->attrs["$val"]= array_unique($this->$val);
unset ($this->attrs['gotoLdapServer']);
}
+ /* prepare share settings */
+ $tmp = array();
+ foreach($this->gotoShares as $name => $settings){
+ $tmp2 = split("\|",$name);
+ $name = $tmp2[0];
+ $tmp[] = $settings['server']."|".$name."|".$settings['mountPoint'];
+ }
+ $this->attrs['gotoShare']=$tmp;
+
/* Write back to ldap */
$ldap= $this->config->get_ldap_link();
$ldap->cd($this->dn);
$array= $tmp;
}
+ /* Generate ListBox frindly output for the defined shares
+ * Possibly Add or remove an attribute here,
+ */
+ function printOutAssignedShares()
+ {
+ $a_return = array();
+ if(is_array($this->gotoShares)){
+ foreach($this->gotoShares as $share){
+ $a_return[$share['name']."|".$share['server']]= $share['name']." [".$share['server']."]";
+ }
+ }
+ return($a_return);
+ }
+
}