186 lines
		
	
	
		
			5.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
		
		
			
		
	
	
			186 lines
		
	
	
		
			5.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
|  | <?php | ||
|  | /* | ||
|  | $Id$ | ||
|  | 
 | ||
|  |   This code is part of LDAP Account Manager (http://www.sourceforge.net/projects/lam) | ||
|  |    | ||
|  |   This code is based on phpLDAPadmin. | ||
|  |   Copyright (C) 2004  David Smith and phpLDAPadmin developers | ||
|  |    | ||
|  |   The original code was modified to fit for LDAP Account Manager by Roland Gruber. | ||
|  |   Copyright (C) 2005  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 | ||
|  | 
 | ||
|  | 
 | ||
|  | */ | ||
|  | 
 | ||
|  | 
 | ||
|  | /** | ||
|  |  * Creates a new object. | ||
|  |  * | ||
|  |  * Variables that come in as POST vars: | ||
|  |  *  - new_dn | ||
|  |  *  - attrs (an array of attributes) | ||
|  |  *  - vals (an array of values for the above attrs) | ||
|  |  *  - required_attrs (an array with indices being the attributes, | ||
|  |  *		      and the values being their respective values) | ||
|  |  *  - object_classes (rawurlencoded, and serialized array of objectClasses) | ||
|  |  * | ||
|  |  * @package lists | ||
|  |  * @subpackage tree | ||
|  |  * @author David Smith | ||
|  |  * @author Roland Gruber | ||
|  |  */ | ||
|  | 
 | ||
|  | /** tree functions */ | ||
|  | include_once('../../lib/tree.inc'); | ||
|  | /** access to configuration */ | ||
|  | include_once('../../lib/config.inc'); | ||
|  | /** LDAP functions */ | ||
|  | include_once('../../lib/ldap.inc'); | ||
|  | /** status messages */ | ||
|  | include_once('../../lib/status.inc'); | ||
|  | 
 | ||
|  | // start session
 | ||
|  | session_save_path("../../sess"); | ||
|  | @session_start(); | ||
|  | 
 | ||
|  | setlanguage(); | ||
|  | 
 | ||
|  | $new_dn = isset( $_POST['new_dn'] ) ? $_POST['new_dn'] : null; | ||
|  | $encoded_dn = rawurlencode( $new_dn ); | ||
|  | $vals = isset( $_POST['vals'] ) ? $_POST['vals'] : array(); | ||
|  | $attrs = isset( $_POST['attrs'] ) ? $_POST['attrs'] : array(); | ||
|  | $required_attrs = isset( $_POST['required_attrs'] ) ? $_POST['required_attrs'] : false; | ||
|  | $object_classes = unserialize( rawurldecode( $_POST['object_classes'] ) ); | ||
|  | $container = get_container( $new_dn ); | ||
|  | 
 | ||
|  | // build the new entry
 | ||
|  | $new_entry = array(); | ||
|  | if( isset( $required_attrs ) && is_array( $required_attrs ) ) { | ||
|  | 	foreach( $required_attrs as $attr => $val ) { | ||
|  | 		if( $val == '' ) { | ||
|  | 			echo $_SESSION['header']; | ||
|  | 			echo "<title>LDAP Account Manager</title>\n"; | ||
|  | 			echo "<link rel=\"stylesheet\" type=\"text/css\" href=\"../../style/layout.css\">\n"; | ||
|  | 			echo "</head><body>\n"; | ||
|  | 	 | ||
|  | 			StatusMessage("ERROR", _('You left the value blank for required attribute: %s.'), '', array(htmlspecialchars($attr))); | ||
|  | 			 | ||
|  | 			echo "</body></html>"; | ||
|  | 			exit; | ||
|  | 		} | ||
|  | 		$new_entry[ $attr ][] = $val; | ||
|  | 	} | ||
|  | } | ||
|  | 
 | ||
|  | if( isset( $attrs ) && is_array( $attrs ) ) { | ||
|  | 	foreach( $attrs as $i => $attr ) { | ||
|  | 		if( is_attr_binary( $attr ) ) { | ||
|  | 			if( isset( $_FILES['vals']['name'][$i] ) && $_FILES['vals']['name'][$i] != '' ) { | ||
|  | 				// read in the data from the file
 | ||
|  | 				$file = $_FILES['vals']['tmp_name'][$i]; | ||
|  | 				$f = fopen( $file, 'r' ); | ||
|  | 				$binary_data = fread( $f, filesize( $file ) ); | ||
|  | 				fclose( $f ); | ||
|  | 				$val = $binary_data; | ||
|  | 				$new_entry[ $attr ][] = $val; | ||
|  | 			} | ||
|  | 		} else { | ||
|  |             $val = isset( $vals[$i] ) ? $vals[$i] : ''; | ||
|  | 			if( '' !== trim($val) ) | ||
|  | 			  $new_entry[ $attr ][] = $val; | ||
|  | 		} | ||
|  | 	} | ||
|  | } | ||
|  | 
 | ||
|  | $new_entry['objectClass'] = $object_classes; | ||
|  | if( ! in_array( 'top', $new_entry['objectClass'] ) ) | ||
|  | 	$new_entry['objectClass'][] = 'top'; | ||
|  | 
 | ||
|  | foreach( $new_entry as $attr => $vals ) { | ||
|  | 	if( ! is_attr_binary( $attr ) ) | ||
|  | 		if( is_array( $vals ) ) { | ||
|  | 			foreach( $vals as $i => $v ) { | ||
|  |                            $new_entry[ $attr ][ $i ] = $v; | ||
|  | 			} | ||
|  | 		} | ||
|  | 		else { | ||
|  | 			$new_entry[ $attr ] = $vals; | ||
|  | 		} | ||
|  | } | ||
|  | 
 | ||
|  | //echo "<pre>"; var_dump( $new_dn );print_r( $new_entry ); echo "</pre>";
 | ||
|  | 
 | ||
|  | $ds = $_SESSION['ldap']->server; | ||
|  | 
 | ||
|  | // Check the user-defined custom call back first
 | ||
|  | $add_result = @ldap_add( $ds, $new_dn, $new_entry ); | ||
|  | if( $add_result ) | ||
|  | { | ||
|  |     $redirect_url = "edit.php?dn=" . rawurlencode( $new_dn ); | ||
|  | 
 | ||
|  | 	if( array_key_exists( 'tree', $_SESSION ) ) | ||
|  | 	{ | ||
|  | 		$tree = $_SESSION['tree']; | ||
|  | 		$tree_icons = $_SESSION['tree_icons']; | ||
|  | 
 | ||
|  | 		if( isset( $tree[$container] ) ) { | ||
|  | 			$tree[$container][] = $new_dn; | ||
|  | 			sort( $tree[$container] ); | ||
|  | 			$tree_icons[$new_dn] = get_icon( $new_dn ); | ||
|  | 		} | ||
|  | 
 | ||
|  | 		$_SESSION['tree'] = $tree; | ||
|  | 		$_SESSION['tree_icons'] = $tree_icons; | ||
|  | 		session_write_close(); | ||
|  | 	} | ||
|  | 
 | ||
|  | 	?>
 | ||
|  | 	<?php | ||
|  | 	if( isset( $tree[$container])) { | ||
|  | 		echo $_SESSION['header']; | ||
|  | 		echo "<meta http-equiv=\"refresh\" content=\"0; URL=" . $redirect_url . "\">\n"; | ||
|  | 		echo "<title></title>\n"; | ||
|  | 		echo "</head>\n"; | ||
|  | 		echo "<body>\n"; | ||
|  | 		echo "<script language=\"javascript\">"; | ||
|  | 			echo "parent.left_frame.location.reload();"; | ||
|  | 		echo "</script>"; | ||
|  | 		// print link if refresh does not work
 | ||
|  | 		echo "<p>\n"; | ||
|  | 		echo "<a href=\"" . $redirect_url . "\">" . _("Click here if you are not directed to the next page.") . "</a>\n"; | ||
|  | 		echo "</p>\n"; | ||
|  | 		echo "</body>\n"; | ||
|  | 		echo "</html>\n"; | ||
|  | 	} | ||
|  | 	?>
 | ||
|  | 
 | ||
|  | <?PHP | ||
|  | 	} | ||
|  | 	else { | ||
|  | 		echo $_SESSION['header']; | ||
|  | 		echo "<title>LDAP Account Manager</title>\n"; | ||
|  | 		echo "<link rel=\"stylesheet\" type=\"text/css\" href=\"../../style/layout.css\">\n"; | ||
|  | 		echo "</head><body>\n"; | ||
|  | 
 | ||
|  | 		StatusMessage("ERROR", _("LAM was unable to create account %s! An LDAP error occured."), ldap_error($ds), array($new_dn)); | ||
|  | 
 | ||
|  | 		echo "</body></html>\n"; | ||
|  | 	} | ||
|  | 	 | ||
|  | ?>
 |