| 
									
										
										
										
											2003-05-25 10:57:32 +00:00
										 |  |  | <?php | 
					
						
							|  |  |  | /* | 
					
						
							|  |  |  | $Id$ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-27 18:47:12 +00:00
										 |  |  |   This code is part of LDAP Account Manager (http://www.ldap-account-manager.org/) | 
					
						
							| 
									
										
										
										
											2010-01-01 17:21:46 +00:00
										 |  |  |   Copyright (C) 2003 - 2010  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; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-16 16:52:20 +00:00
										 |  |  | // check if new profile should be created
 | 
					
						
							|  |  |  | elseif (isset($_POST['createProfileButton'])) { | 
					
						
							|  |  |  | 	metaRefresh("profilepage.php?type=" . $_POST['createProfile']); | 
					
						
							| 
									
										
										
										
											2005-11-06 16:35:39 +00:00
										 |  |  | 	exit; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2008-12-16 16:52:20 +00:00
										 |  |  | // check if a profile should be edited
 | 
					
						
							|  |  |  | for ($i = 0; $i < sizeof($profileClasses); $i++) { | 
					
						
							|  |  |  | 	if (isset($_POST['editProfile_' . $profileClasses[$i]['scope']]) || isset($_POST['editProfile_' . $profileClasses[$i]['scope'] . '_x'])) { | 
					
						
							|  |  |  | 		metaRefresh("profilepage.php?type=" . $profileClasses[$i]['scope'] . | 
					
						
							|  |  |  | 					"&edit=" . $_POST['profile_' . $profileClasses[$i]['scope']]); | 
					
						
							|  |  |  | 		exit; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | // check if a profile should be deleted
 | 
					
						
							|  |  |  | for ($i = 0; $i < sizeof($profileClasses); $i++) { | 
					
						
							|  |  |  | 	if (isset($_POST['deleteProfile_' . $profileClasses[$i]['scope']]) || isset($_POST['deleteProfile_' . $profileClasses[$i]['scope'] . '_x'])) { | 
					
						
							|  |  |  | 		metaRefresh("profiledelete.php?type=" . $profileClasses[$i]['scope'] . | 
					
						
							|  |  |  | 					"&del=" . $_POST['profile_' . $profileClasses[$i]['scope']]); | 
					
						
							|  |  |  | 		exit; | 
					
						
							| 
									
										
										
										
											2003-05-25 10:57:32 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											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
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-01 17:21:46 +00:00
										 |  |  | include '../main_header.php'; | 
					
						
							| 
									
										
										
										
											2003-05-25 10:57:32 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-16 16:52:20 +00:00
										 |  |  | echo "<h1>" . _('Profile editor') . "</h1>\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"; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-16 16:52:20 +00:00
										 |  |  | // new profile
 | 
					
						
							|  |  |  | echo "<fieldset class=\"useredit\">\n"; | 
					
						
							|  |  |  | echo "<legend>\n"; | 
					
						
							|  |  |  | echo "<b>" . _('Create a new profile') . "</b>\n"; | 
					
						
							|  |  |  | echo "</legend>\n"; | 
					
						
							|  |  |  | echo "<br><table border=0>\n"; | 
					
						
							|  |  |  | 	echo "<tr><td>\n"; | 
					
						
							|  |  |  | 		echo "<select class=\"user\" name=\"createProfile\">\n"; | 
					
						
							|  |  |  | 			for ($i = 0; $i < sizeof($profileClasses); $i++) { | 
					
						
							|  |  |  | 				echo "<option value=\"" . $profileClasses[$i]['scope'] . "\">" . $profileClasses[$i]['title'] . "</option>\n"; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		echo "</select>\n"; | 
					
						
							| 
									
										
										
										
											2004-12-12 11:27:57 +00:00
										 |  |  | 	echo "</td>\n"; | 
					
						
							|  |  |  | 	echo "<td>\n"; | 
					
						
							| 
									
										
										
										
											2008-12-16 16:52:20 +00:00
										 |  |  | 		echo "<input type=\"submit\" name=\"createProfileButton\" value=\"" . _('Create') . "\">"; | 
					
						
							|  |  |  | 	echo "</td></tr>\n"; | 
					
						
							|  |  |  | echo "</table>\n"; | 
					
						
							|  |  |  | echo "</fieldset>\n"; | 
					
						
							|  |  |  | echo "<br>\n"; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // existing profiles
 | 
					
						
							|  |  |  | echo "<fieldset class=\"useredit\">\n"; | 
					
						
							|  |  |  | echo "<legend>\n"; | 
					
						
							|  |  |  | echo "<b>" . _('Manage existing profiles') . "</b>\n"; | 
					
						
							|  |  |  | echo "</legend>\n"; | 
					
						
							|  |  |  | echo "<br><table border=0>\n"; | 
					
						
							|  |  |  | for ($i = 0; $i < sizeof($profileClasses); $i++) { | 
					
						
							| 
									
										
										
										
											2008-12-28 13:50:31 +00:00
										 |  |  | 	if ($i > 0) { | 
					
						
							|  |  |  | 		echo "<tr><td colspan=3> </td></tr>\n"; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2004-12-12 11:27:57 +00:00
										 |  |  | 	echo "<tr>\n"; | 
					
						
							| 
									
										
										
										
											2008-12-16 16:52:20 +00:00
										 |  |  | 		echo "<td>"; | 
					
						
							|  |  |  | 			echo "<img alt=\"" . $profileClasses[$i]['title'] . "\" src=\"../../graphics/" . $profileClasses[$i]['scope'] . ".png\"> \n"; | 
					
						
							|  |  |  | 			echo $profileClasses[$i]['title']; | 
					
						
							|  |  |  | 		echo "</td>\n"; | 
					
						
							|  |  |  | 		echo "<td> "; | 
					
						
							|  |  |  | 			echo "<select class=\"user\" style=\"width: 20em;\" name=\"profile_" . $profileClasses[$i]['scope'] . "\">\n"; | 
					
						
							|  |  |  | 				echo $profileClasses[$i]['profiles']; | 
					
						
							|  |  |  | 			echo "</select>\n"; | 
					
						
							|  |  |  | 		echo "</td>\n"; | 
					
						
							|  |  |  | 		echo "<td> "; | 
					
						
							|  |  |  | 			echo "<input type=\"image\" src=\"../../graphics/edit.png\" name=\"editProfile_" . $profileClasses[$i]['scope'] . "\" " . | 
					
						
							|  |  |  | 			 "alt=\"" . _('Edit') . "\" title=\"" . _('Edit') . "\">"; | 
					
						
							|  |  |  | 			echo " "; | 
					
						
							|  |  |  | 			echo "<input type=\"image\" src=\"../../graphics/delete.png\" name=\"deleteProfile_" . $profileClasses[$i]['scope'] . "\" " . | 
					
						
							|  |  |  | 			"alt=\"" . _('Delete') . "\" title=\"" . _('Delete') . "\">"; | 
					
						
							|  |  |  | 		echo "</td>\n"; | 
					
						
							| 
									
										
										
										
											2004-12-12 11:27:57 +00:00
										 |  |  | 	echo "</tr>\n"; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2008-12-16 16:52:20 +00:00
										 |  |  | echo "</table>\n"; | 
					
						
							|  |  |  | echo "</fieldset>\n"; | 
					
						
							|  |  |  | echo "<br>\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
										 |  |  | ?>
 |