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";
|
||
|
}
|
||
|
|
||
|
?>
|