| 
									
										
										
										
											2003-05-25 10:57:32 +00:00
										 |  |  | <?php | 
					
						
							|  |  |  | /* | 
					
						
							|  |  |  | $Id$ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   This code is part of LDAP Account Manager (http://www.sourceforge.net/projects/lam) | 
					
						
							| 
									
										
										
										
											2006-03-03 17:30:35 +00:00
										 |  |  |   Copyright (C) 2003 - 2006  Roland Gruber | 
					
						
							| 
									
										
										
										
											2003-05-25 10:57:32 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   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
										 |  |  | */ | 
					
						
							| 
									
										
										
										
											2003-05-25 10:57:32 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-06-10 22:13:39 +00:00
										 |  |  | /** | 
					
						
							|  |  |  | * This is the main window of the profile editor. | 
					
						
							|  |  |  | * | 
					
						
							| 
									
										
										
										
											2004-10-09 11:04:20 +00:00
										 |  |  | * @package profiles | 
					
						
							| 
									
										
										
										
											2004-06-10 22:13:39 +00:00
										 |  |  | * @author Roland Gruber | 
					
						
							| 
									
										
										
										
											2003-05-25 10:57:32 +00:00
										 |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-03-26 17:51:25 +00:00
										 |  |  | /** security functions */ | 
					
						
							|  |  |  | include_once("../../lib/security.inc"); | 
					
						
							| 
									
										
										
										
											2004-06-10 22:13:39 +00:00
										 |  |  | /** helper functions for profiles */ | 
					
						
							| 
									
										
										
										
											2003-05-25 10:57:32 +00:00
										 |  |  | include_once("../../lib/profiles.inc"); | 
					
						
							| 
									
										
										
										
											2004-06-10 22:13:39 +00:00
										 |  |  | /** access to LDAP server */ | 
					
						
							| 
									
										
										
										
											2003-05-25 10:57:32 +00:00
										 |  |  | include_once("../../lib/ldap.inc"); | 
					
						
							| 
									
										
										
										
											2004-06-10 22:13:39 +00:00
										 |  |  | /** access to configuration options */ | 
					
						
							| 
									
										
										
										
											2003-08-03 11:05:40 +00:00
										 |  |  | include_once("../../lib/config.inc"); | 
					
						
							| 
									
										
										
										
											2003-05-25 10:57:32 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | // start session
 | 
					
						
							| 
									
										
										
										
											2006-03-26 17:51:25 +00:00
										 |  |  | startSecureSession(); | 
					
						
							| 
									
										
										
										
											2003-05-25 10:57:32 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-12-30 13:15:39 +00:00
										 |  |  | // die if no write access
 | 
					
						
							|  |  |  | if (!checkIfWriteAccessIsAllowed()) die(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-08-03 11:05:40 +00:00
										 |  |  | setlanguage(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-01-01 16:30:05 +00:00
										 |  |  | $types = $_SESSION['config']->get_ActiveTypes(); | 
					
						
							|  |  |  | $profileClasses = array(); | 
					
						
							|  |  |  | for ($i = 0; $i < sizeof($types); $i++) { | 
					
						
							|  |  |  | 	$profileClasses[] = array( | 
					
						
							|  |  |  | 		'scope' => $types[$i], | 
					
						
							|  |  |  | 		'title' => getTypeAlias($types[$i]), | 
					
						
							|  |  |  | 		'profiles' => ""); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-12-12 11:27:57 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-05-25 10:57:32 +00:00
										 |  |  | // check if user is logged in, if not go to login
 | 
					
						
							|  |  |  | if (!$_SESSION['ldap'] || !$_SESSION['ldap']->server()) { | 
					
						
							| 
									
										
										
										
											2003-08-28 12:41:47 +00:00
										 |  |  | 	metaRefresh("../login.php"); | 
					
						
							| 
									
										
										
										
											2003-05-25 10:57:32 +00:00
										 |  |  | 	exit; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-11-06 16:35:39 +00:00
										 |  |  | // on abort go back to main page
 | 
					
						
							|  |  |  | if (isset($_POST['abort'])) { | 
					
						
							|  |  |  | 	metaRefresh("../tools.php"); | 
					
						
							|  |  |  | 	exit; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | // check if user has pressed submit button
 | 
					
						
							|  |  |  | elseif (isset($_POST['submit'])) { | 
					
						
							|  |  |  | 	// forward to other profile pages
 | 
					
						
							|  |  |  | 	if ($_POST['submit']) { | 
					
						
							| 
									
										
										
										
											2004-12-12 11:27:57 +00:00
										 |  |  | 		for ($i = 0; $i < sizeof($profileClasses); $i++) { | 
					
						
							|  |  |  | 			// create new profile
 | 
					
						
							|  |  |  | 			if ($_POST['profile'] == ("new" . $profileClasses[$i]['scope'])) { | 
					
						
							|  |  |  | 				metaRefresh("profilepage.php?type=" . $profileClasses[$i]['scope']); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			// edit profile
 | 
					
						
							|  |  |  | 			elseif($_POST['profile'] == ("edit" . $profileClasses[$i]['scope'])) { | 
					
						
							|  |  |  | 				metaRefresh("profilepage.php?type=" . $profileClasses[$i]['scope'] . | 
					
						
							|  |  |  | 					"&edit=" . $_POST['e_' . $profileClasses[$i]['scope']]); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			// delete profile
 | 
					
						
							|  |  |  | 			elseif($_POST['profile'] == ("del" . $profileClasses[$i]['scope'])) { | 
					
						
							|  |  |  | 				metaRefresh("profiledelete.php?type=" . $profileClasses[$i]['scope'] . | 
					
						
							|  |  |  | 					"&del=" . $_POST['d_' . $profileClasses[$i]['scope']]); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2003-05-25 10:57:32 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	exit; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-12-12 11:27:57 +00:00
										 |  |  | // get list of profiles for each account type
 | 
					
						
							|  |  |  | for ($i = 0; $i < sizeof($profileClasses); $i++) { | 
					
						
							|  |  |  | 	$profileList = getAccountProfiles($profileClasses[$i]['scope']); | 
					
						
							|  |  |  | 	$profiles = ""; | 
					
						
							|  |  |  | 	for ($l = 0; $l < sizeof($profileList); $l++) { | 
					
						
							|  |  |  | 		$profiles = $profiles . "<option>" . $profileList[$l] . "</option>\n"; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	$profileClasses[$i]['profiles'] = $profiles; | 
					
						
							| 
									
										
										
										
											2003-05-25 10:57:32 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-07-29 11:52:26 +00:00
										 |  |  | echo $_SESSION['header']; | 
					
						
							| 
									
										
										
										
											2003-05-25 10:57:32 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-12-12 11:27:57 +00:00
										 |  |  | echo "<title>LDAP Account Manager</title>\n"; | 
					
						
							|  |  |  | echo "<link rel=\"stylesheet\" type=\"text/css\" href=\"../../style/layout.css\">\n"; | 
					
						
							| 
									
										
										
										
											2006-01-01 16:30:05 +00:00
										 |  |  | for ($i = 0; $i < sizeof($profileClasses); $i++) { | 
					
						
							|  |  |  | 	echo "<link rel=\"stylesheet\" type=\"text/css\" href=\"../../style/type_" . $profileClasses[$i]['scope'] . ".css\">\n"; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2004-12-12 11:27:57 +00:00
										 |  |  | echo "</head>\n"; | 
					
						
							|  |  |  | echo "<body>\n"; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-12-31 13:13:37 +00:00
										 |  |  | echo "<br>\n"; | 
					
						
							| 
									
										
										
										
											2004-12-12 11:27:57 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | echo "<form action=\"profilemain.php\" method=\"post\">\n"; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | for ($i = 0; $i < sizeof($profileClasses); $i++) { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-01-01 16:30:05 +00:00
										 |  |  | 	echo "<fieldset class=\"" . $profileClasses[$i]['scope'] . "edit\">\n"; | 
					
						
							| 
									
										
										
										
											2004-12-12 11:27:57 +00:00
										 |  |  | 	echo "<legend>\n"; | 
					
						
							|  |  |  | 	echo "<b>" . $profileClasses[$i]['title'] . "</b>\n"; | 
					
						
							|  |  |  | 	echo "</legend>\n"; | 
					
						
							|  |  |  | 	echo "<table border=0>\n"; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	// new profile
 | 
					
						
							|  |  |  | 	echo "<tr>\n"; | 
					
						
							|  |  |  | 	echo "<td>\n"; | 
					
						
							|  |  |  | 	echo "<input type=\"radio\" name=\"profile\" value=\"new" . $profileClasses[$i]['scope'] . "\">\n"; | 
					
						
							|  |  |  | 	echo "</td>\n"; | 
					
						
							|  |  |  | 	echo "<td colspan=2>" . _("Create a new profile") . "</td>\n"; | 
					
						
							|  |  |  | 	echo "</tr>\n"; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	// edit profile
 | 
					
						
							|  |  |  | 	echo "<tr>\n"; | 
					
						
							|  |  |  | 	echo "<td>\n"; | 
					
						
							|  |  |  | 	echo "<input type=\"radio\" name=\"profile\" value=\"edit" . $profileClasses[$i]['scope'] . "\">\n"; | 
					
						
							|  |  |  | 	echo "</td>\n"; | 
					
						
							|  |  |  | 	echo "<td>\n"; | 
					
						
							| 
									
										
										
										
											2008-05-14 20:27:32 +00:00
										 |  |  | 	echo "<select class=\"" . $profileClasses[$i]['scope'] . "\" name=\"e_" . $profileClasses[$i]['scope'] . "\" size=1>\n"; | 
					
						
							| 
									
										
										
										
											2004-12-12 11:27:57 +00:00
										 |  |  | 	echo $profileClasses[$i]['profiles']; | 
					
						
							|  |  |  | 	echo "</select>\n"; | 
					
						
							|  |  |  | 	echo "</td>\n"; | 
					
						
							|  |  |  | 	echo "<td>" . _("Edit profile") . "</td>\n"; | 
					
						
							|  |  |  | 	echo "</tr>\n"; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	// delete profile
 | 
					
						
							|  |  |  | 	echo "<tr>\n"; | 
					
						
							|  |  |  | 	echo "<td>\n"; | 
					
						
							|  |  |  | 	echo "<input type=\"radio\" name=\"profile\" value=\"del" . $profileClasses[$i]['scope'] . "\">\n"; | 
					
						
							|  |  |  | 	echo "</td>\n"; | 
					
						
							|  |  |  | 	echo "<td>\n"; | 
					
						
							| 
									
										
										
										
											2008-08-10 19:39:56 +00:00
										 |  |  | 	echo "<select class=\"" . $profileClasses[$i]['scope'] . "\" name=\"d_" . $profileClasses[$i]['scope'] . "\" size=1>\n"; | 
					
						
							| 
									
										
										
										
											2004-12-12 11:27:57 +00:00
										 |  |  | 	echo $profileClasses[$i]['profiles']; | 
					
						
							|  |  |  | 	echo "</select>\n"; | 
					
						
							|  |  |  | 	echo "</td>\n"; | 
					
						
							|  |  |  | 	echo "<td>" . _("Delete profile") . "</td>\n"; | 
					
						
							|  |  |  | 	echo "</tr>\n"; | 
					
						
							|  |  |  | 	echo "</table>\n"; | 
					
						
							|  |  |  | 	echo "</fieldset>\n"; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2007-12-31 13:13:37 +00:00
										 |  |  | 	echo "<br>\n"; | 
					
						
							| 
									
										
										
										
											2004-12-12 11:27:57 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2003-05-25 10:57:32 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-12-12 11:27:57 +00:00
										 |  |  | echo "<p>\n"; | 
					
						
							| 
									
										
										
										
											2006-03-04 10:49:55 +00:00
										 |  |  | echo "<input type=\"submit\" name=\"submit\" value=\"" . _("Ok") . "\">\n"; | 
					
						
							|  |  |  | echo "<input type=\"submit\" name=\"abort\" value=\"" . _("Cancel") . "\">\n"; | 
					
						
							| 
									
										
										
										
											2004-12-12 11:27:57 +00:00
										 |  |  | echo "</p>\n"; | 
					
						
							| 
									
										
										
										
											2003-05-25 10:57:32 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-12-12 11:27:57 +00:00
										 |  |  | echo "</form>\n"; | 
					
						
							|  |  |  | echo "</body>\n"; | 
					
						
							|  |  |  | echo "</html>\n"; | 
					
						
							| 
									
										
										
										
											2003-05-25 10:57:32 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-12-12 11:27:57 +00:00
										 |  |  | ?>
 |