| 
									
										
										
										
											2004-03-09 14:29:47 +00:00
										 |  |  | <?php | 
					
						
							|  |  |  | /* | 
					
						
							|  |  |  | $Id$ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   This code is part of LDAP Account Manager (http://www.sourceforge.net/projects/lam) | 
					
						
							|  |  |  |   Copyright (C) 2003  Roland Gruber | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   This program is free software; you can redistribute it and/or modify | 
					
						
							|  |  |  |   it under the terms of the GNU General Public License as published by | 
					
						
							|  |  |  |   the Free Software Foundation; either version 2 of the License, or | 
					
						
							|  |  |  |   (at your option) any later version. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   This program is distributed in the hope that it will be useful, | 
					
						
							|  |  |  |   but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  |   GNU General Public License for more details. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   You should have received a copy of the GNU General Public License | 
					
						
							|  |  |  |   along with this program; if not, write to the Free Software | 
					
						
							|  |  |  |   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-06-10 22:13:39 +00:00
										 |  |  | */ | 
					
						
							| 
									
										
										
										
											2004-03-09 14:29:47 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-06-10 22:13:39 +00:00
										 |  |  | /** | 
					
						
							|  |  |  | * Manages creating/changing of profiles. | 
					
						
							|  |  |  | * | 
					
						
							| 
									
										
										
										
											2004-10-09 11:04:20 +00:00
										 |  |  | * @package profiles | 
					
						
							| 
									
										
										
										
											2004-06-10 22:13:39 +00:00
										 |  |  | * @author Roland Gruber | 
					
						
							| 
									
										
										
										
											2004-03-09 14:29:47 +00:00
										 |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-06-10 22:13:39 +00:00
										 |  |  | /** helper functions for profiles */ | 
					
						
							| 
									
										
										
										
											2004-03-09 14:29:47 +00:00
										 |  |  | include_once("../../lib/profiles.inc"); | 
					
						
							| 
									
										
										
										
											2004-06-10 22:13:39 +00:00
										 |  |  | /** access to LDAP server */ | 
					
						
							| 
									
										
										
										
											2004-03-09 14:29:47 +00:00
										 |  |  | include_once("../../lib/ldap.inc"); | 
					
						
							| 
									
										
										
										
											2004-06-10 22:13:39 +00:00
										 |  |  | /** access to configuration options */ | 
					
						
							| 
									
										
										
										
											2004-03-09 14:29:47 +00:00
										 |  |  | include_once("../../lib/config.inc"); | 
					
						
							| 
									
										
										
										
											2004-06-10 22:13:39 +00:00
										 |  |  | /** access to account modules */ | 
					
						
							| 
									
										
										
										
											2004-03-09 14:29:47 +00:00
										 |  |  | include_once("../../lib/modules.inc"); | 
					
						
							| 
									
										
										
										
											2005-07-12 15:52:15 +00:00
										 |  |  | /** Used to display status messages */ | 
					
						
							|  |  |  | include_once("../../lib/status.inc"); | 
					
						
							| 
									
										
										
										
											2004-03-09 14:29:47 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | // start session
 | 
					
						
							|  |  |  | session_save_path("../../sess"); | 
					
						
							|  |  |  | @session_start(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | setlanguage(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // check if user is logged in, if not go to login
 | 
					
						
							|  |  |  | if (!$_SESSION['ldap'] || !$_SESSION['ldap']->server()) { | 
					
						
							|  |  |  | 	metaRefresh("../login.php"); | 
					
						
							|  |  |  | 	exit; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-07-12 15:52:15 +00:00
										 |  |  | // copy type and profile name from POST to GET
 | 
					
						
							|  |  |  | if (isset($_POST['profname'])) $_GET['edit'] = $_POST['profname']; | 
					
						
							|  |  |  | if (isset($_POST['accounttype'])) $_GET['type'] = $_POST['accounttype']; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // abort button was pressed
 | 
					
						
							|  |  |  | // back to profile editor
 | 
					
						
							|  |  |  | if ($_POST['abort']) { | 
					
						
							|  |  |  | 	metaRefresh("profilemain.php"); | 
					
						
							|  |  |  | 	exit; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2004-03-14 15:34:53 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-03-09 14:29:47 +00:00
										 |  |  | // print header
 | 
					
						
							|  |  |  | echo $_SESSION['header']; | 
					
						
							|  |  |  | echo "<title></title>\n<link rel=\"stylesheet\" type=\"text/css\" href=\"../../style/layout.css\">\n"; | 
					
						
							|  |  |  | echo "</head><body><br>\n"; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-07-12 15:52:15 +00:00
										 |  |  | // save button was presed
 | 
					
						
							|  |  |  | if ($_POST['save']) { | 
					
						
							|  |  |  | 	// create option array to check and save
 | 
					
						
							|  |  |  | 	$options = array(); | 
					
						
							|  |  |  | 	$opt_keys = array_keys($_SESSION['profile_types']); | 
					
						
							|  |  |  | 	foreach ($opt_keys as $element) { | 
					
						
							|  |  |  | 		// text fields
 | 
					
						
							|  |  |  | 		if ($_SESSION['profile_types'][$element] == "text") { | 
					
						
							|  |  |  | 			$options[$element] = array($_POST[$element]); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		// checkboxes
 | 
					
						
							|  |  |  | 		elseif ($_SESSION['profile_types'][$element] == "checkbox") { | 
					
						
							|  |  |  | 			if ($_POST[$element] == "on") $options[$element] = array('true'); | 
					
						
							|  |  |  | 			else $options[$element] = array('false'); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		// dropdownbox
 | 
					
						
							|  |  |  | 		elseif ($_SESSION['profile_types'][$element] == "select") { | 
					
						
							|  |  |  | 			$options[$element] = array($_POST[$element]); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		// multiselect
 | 
					
						
							|  |  |  | 		elseif ($_SESSION['profile_types'][$element] == "multiselect") { | 
					
						
							|  |  |  | 			$options[$element] = $_POST[$element];  // value is already an array
 | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	// remove double slashes if magic quotes are on
 | 
					
						
							|  |  |  | 	if (get_magic_quotes_gpc() == 1) { | 
					
						
							|  |  |  | 		foreach ($opt_keys as $element) { | 
					
						
							|  |  |  | 			if (is_string($options[$element][0])) $options[$element][0] = stripslashes($options[$element][0]); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	// check options
 | 
					
						
							|  |  |  | 	$errors = checkProfileOptions($_POST['accounttype'], $options); | 
					
						
							|  |  |  | 	// print error messages if any
 | 
					
						
							|  |  |  | 	if (sizeof($errors) > 0) { | 
					
						
							|  |  |  | 		for ($i = 0; $i < sizeof($errors); $i++) { | 
					
						
							|  |  |  | 			if (sizeof($errors[$i]) > 3) {  // messages with additional variables
 | 
					
						
							|  |  |  | 				StatusMessage($errors[$i][0], $errors[$i][1], $errors[$i][2], $errors[$i][3]); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			else { | 
					
						
							|  |  |  | 				StatusMessage($errors[$i][0], $errors[$i][1], $errors[$i][2]); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		echo "<br>\n"; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else {  // input data is valid, save profile
 | 
					
						
							|  |  |  | 		// save profile
 | 
					
						
							|  |  |  | 		if (saveAccountProfile($options, $_POST['profname'], $_POST['accounttype'])) { | 
					
						
							|  |  |  | 			echo StatusMessage("INFO", _("Profile was saved."), $_POST['profname']); | 
					
						
							|  |  |  | 			echo ("<br><p><a href=\"profilemain.php\">" . _("Back to Profile Editor") . "</a></p>"); | 
					
						
							|  |  |  | 			echo "</body></html>"; | 
					
						
							|  |  |  | 			exit(); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else StatusMessage("ERROR", _("Unable to save profile!"), $_POST['profname']); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // empty list of attribute types
 | 
					
						
							|  |  |  | $_SESSION['profile_types'] = array(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-03-09 14:29:47 +00:00
										 |  |  | // check if account type is valid
 | 
					
						
							|  |  |  | $type = $_GET['type']; | 
					
						
							|  |  |  | if (!(($type == 'user') || ($type == 'group') || ($type == 'host'))) meta_refresh('profilemain.php'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // get module options
 | 
					
						
							|  |  |  | $options = getProfileOptions($type); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-07-12 15:52:15 +00:00
										 |  |  | // load old profile or POST values if needed
 | 
					
						
							| 
									
										
										
										
											2004-03-15 16:34:16 +00:00
										 |  |  | $old_options = array(); | 
					
						
							| 
									
										
										
										
											2005-07-12 15:52:15 +00:00
										 |  |  | if (isset($_POST['save'])) { | 
					
						
							|  |  |  | 	$postKeys = array_keys($_POST); | 
					
						
							|  |  |  | 	for ($i = 0; $i < sizeof($postKeys); $i++) { | 
					
						
							|  |  |  | 		if (!is_array($_POST[$postKeys[$i]])) { | 
					
						
							|  |  |  | 			$old_options[$postKeys[$i]] = array($_POST[$postKeys[$i]]); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else { | 
					
						
							|  |  |  | 			$old_options[$postKeys[$i]] = $_POST[$postKeys[$i]]; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | elseif (isset($_GET['edit'])) { | 
					
						
							| 
									
										
										
										
											2004-10-06 20:00:17 +00:00
										 |  |  | 	$old_options = loadAccountProfile($_GET['edit'], $type); | 
					
						
							| 
									
										
										
										
											2004-03-09 14:29:47 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // display formular
 | 
					
						
							| 
									
										
										
										
											2005-07-12 15:52:15 +00:00
										 |  |  | echo ("<form action=\"profilepage.php?type=$type\" method=\"post\">\n"); | 
					
						
							| 
									
										
										
										
											2004-03-09 14:29:47 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-06-27 18:07:43 +00:00
										 |  |  | // suffix box
 | 
					
						
							|  |  |  | // get root suffix
 | 
					
						
							| 
									
										
										
										
											2005-03-10 20:20:00 +00:00
										 |  |  | $rootsuffix = $_SESSION['config']->get_Suffix($type); | 
					
						
							| 
									
										
										
										
											2004-06-27 18:07:43 +00:00
										 |  |  | // get subsuffixes
 | 
					
						
							|  |  |  | $suffixes = array(); | 
					
						
							|  |  |  | foreach ($_SESSION['ldap']->search_units($rootsuffix) as $suffix) { | 
					
						
							|  |  |  | 	$suffixes[] = $suffix; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2005-05-21 14:35:14 +00:00
										 |  |  | // get RDNs
 | 
					
						
							|  |  |  | $rdns = getRDNAttributes($type); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | echo "<fieldset class=\"" . $type . "edit\">\n<legend><b>" . _("LDAP") . "</b></legend>\n"; | 
					
						
							|  |  |  | 	echo "<table border=0>"; | 
					
						
							|  |  |  | 	echo "<tr><td>"; | 
					
						
							|  |  |  | 	// LDAP suffix
 | 
					
						
							|  |  |  | 	echo _("LDAP suffix") . ":"; | 
					
						
							|  |  |  | 	echo "</td><td>"; | 
					
						
							|  |  |  | 	echo "<select name=\"ldap_suffix\" tabindex=\"1\">"; | 
					
						
							|  |  |  | 	for ($i = 0; $i < sizeof($suffixes); $i++) { | 
					
						
							|  |  |  | 		if ($old_options['ldap_suffix'][0] == $suffixes[$i]) { | 
					
						
							|  |  |  | 			echo "<option selected>" . $suffixes[$i] . "</option>\n"; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else { | 
					
						
							|  |  |  | 			echo "<option>" . $suffixes[$i] . "</option>\n"; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2004-06-27 18:07:43 +00:00
										 |  |  | 	echo "</select>\n"; | 
					
						
							| 
									
										
										
										
											2005-05-21 14:35:14 +00:00
										 |  |  | 	echo "</td><td>"; | 
					
						
							| 
									
										
										
										
											2005-04-24 12:42:20 +00:00
										 |  |  | 	// help link
 | 
					
						
							|  |  |  | 	echo " <a href=\"../help.php?HelpNumber=361\" target=\"lamhelp\">"; | 
					
						
							|  |  |  | 	echo "<img src=\"../../graphics/help.png\" alt=\"" . _('Help') . "\" title=\"" . _('Help') . "\">"; | 
					
						
							| 
									
										
										
										
											2005-05-21 14:35:14 +00:00
										 |  |  | 	echo "</a><br>\n"; | 
					
						
							|  |  |  | 	echo "</td></tr>"; | 
					
						
							|  |  |  | 	// LDAP RDN
 | 
					
						
							|  |  |  | 	echo "<tr><td>"; | 
					
						
							|  |  |  | 	echo _("RDN identifier") . ":"; | 
					
						
							|  |  |  | 	echo "</td><td>"; | 
					
						
							|  |  |  | 	echo "<select name=\"ldap_rdn\" tabindex=\"1\">"; | 
					
						
							|  |  |  | 	for ($i = 0; $i < sizeof($rdns); $i++) { | 
					
						
							|  |  |  | 		if ($old_options['ldap_rdn'][0] == $rdns[$i]) { | 
					
						
							|  |  |  | 			echo "<option selected>" . $rdns[$i] . "</option>\n"; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else { | 
					
						
							|  |  |  | 			echo "<option>" . $rdns[$i] . "</option>\n"; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	echo "</select>\n"; | 
					
						
							|  |  |  | 	echo "</td><td>"; | 
					
						
							|  |  |  | 	// help link
 | 
					
						
							|  |  |  | 	echo " <a href=\"../help.php?HelpNumber=301\" target=\"lamhelp\">"; | 
					
						
							|  |  |  | 	echo "<img src=\"../../graphics/help.png\" alt=\"" . _('Help') . "\" title=\"" . _('Help') . "\">"; | 
					
						
							|  |  |  | 	echo "</a><br>\n"; | 
					
						
							|  |  |  | 	echo "</td></tr>"; | 
					
						
							|  |  |  | 	echo "</table>"; | 
					
						
							| 
									
										
										
										
											2004-06-27 18:07:43 +00:00
										 |  |  | echo "</fieldset>\n<br>\n"; | 
					
						
							| 
									
										
										
										
											2005-05-21 14:35:14 +00:00
										 |  |  | $_SESSION['profile_types']['ldap_suffix'] = 'select'; | 
					
						
							|  |  |  | $_SESSION['profile_types']['ldap_rdn'] = 'select'; | 
					
						
							| 
									
										
										
										
											2004-06-27 18:07:43 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-07-02 15:27:14 +00:00
										 |  |  | // index for tab order (1 is LDAP suffix)
 | 
					
						
							|  |  |  | $tabindex = 2; | 
					
						
							| 
									
										
										
										
											2005-03-29 16:13:44 +00:00
										 |  |  | $tabindexLink = 1000;	// links are at the end
 | 
					
						
							| 
									
										
										
										
											2004-07-02 15:27:14 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-03-09 14:29:47 +00:00
										 |  |  | // display module options
 | 
					
						
							|  |  |  | $modules = array_keys($options); | 
					
						
							|  |  |  | for ($m = 0; $m < sizeof($modules); $m++) { | 
					
						
							|  |  |  | 	// ignore modules without options
 | 
					
						
							|  |  |  | 	if (sizeof($options[$modules[$m]]) < 1) continue; | 
					
						
							| 
									
										
										
										
											2005-04-24 12:42:20 +00:00
										 |  |  | 	echo "<fieldset class=\"" . $type . "edit\">\n"; | 
					
						
							| 
									
										
										
										
											2004-03-09 14:29:47 +00:00
										 |  |  | 		echo "<legend><b>" . getModuleAlias($modules[$m], $type) . "</b></legend>\n"; | 
					
						
							| 
									
										
										
										
											2005-03-29 16:13:44 +00:00
										 |  |  | 	$profileTypes = parseHtml($modules[$m], $options[$modules[$m]], $old_options, true, $tabindex, $tabindexLink, $type); | 
					
						
							|  |  |  | 	$_SESSION['profile_types'] = array_merge($profileTypes, $_SESSION['profile_types']); | 
					
						
							| 
									
										
										
										
											2004-03-09 14:29:47 +00:00
										 |  |  | 	echo "</fieldset>\n"; | 
					
						
							| 
									
										
										
										
											2004-06-23 19:14:07 +00:00
										 |  |  | 	echo "<br>"; | 
					
						
							| 
									
										
										
										
											2004-03-09 14:29:47 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // profile name and submit/abort buttons
 | 
					
						
							| 
									
										
										
										
											2005-04-24 12:42:20 +00:00
										 |  |  | echo ("<b>" . _("Profile name") . ":</b> \n"); | 
					
						
							| 
									
										
										
										
											2004-07-14 12:57:11 +00:00
										 |  |  | $tabindex++; | 
					
						
							| 
									
										
										
										
											2005-04-24 12:42:20 +00:00
										 |  |  | echo ("<input tabindex=\"$tabindex\" type=\"text\" name=\"profname\" value=\"" . $_GET['edit'] . "\">\n"); | 
					
						
							|  |  |  | // help link
 | 
					
						
							|  |  |  | echo "<a href=\"../help.php?HelpNumber=360\" target=\"lamhelp\">"; | 
					
						
							|  |  |  | echo "<img src=\"../../graphics/help.png\" alt=\"" . _('Help') . "\" title=\"" . _('Help') . "\">"; | 
					
						
							|  |  |  | echo "</a><br><br>\n"; | 
					
						
							| 
									
										
										
										
											2004-07-14 12:57:11 +00:00
										 |  |  | $tabindex++; | 
					
						
							| 
									
										
										
										
											2005-07-12 15:52:15 +00:00
										 |  |  | echo ("<input tabindex=\"$tabindex\" type=\"submit\" name=\"save\" value=\"" . _("Save") . "\">\n"); | 
					
						
							| 
									
										
										
										
											2004-07-14 12:57:11 +00:00
										 |  |  | $tabindex++; | 
					
						
							| 
									
										
										
										
											2005-04-24 12:42:20 +00:00
										 |  |  | echo ("<input tabindex=\"$tabindex\" type=\"reset\" name=\"reset\" value=\"" . _("Reset") . "\">\n"); | 
					
						
							| 
									
										
										
										
											2004-07-14 12:57:11 +00:00
										 |  |  | $tabindex++; | 
					
						
							| 
									
										
										
										
											2005-04-24 12:42:20 +00:00
										 |  |  | echo ("<input tabindex=\"$tabindex\" type=\"submit\" name=\"abort\" value=\"" . _("Abort") . "\">\n"); | 
					
						
							| 
									
										
										
										
											2004-03-15 16:34:16 +00:00
										 |  |  | echo "<input type=\"hidden\" name=\"accounttype\" value=\"$type\">\n";
 | 
					
						
							| 
									
										
										
										
											2004-03-09 14:29:47 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | echo ("</form></body></html>\n"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ?>
 |