new PLA release
This commit is contained in:
parent
30667d5823
commit
dd091ab9df
|
@ -1,311 +0,0 @@
|
|||
<?php
|
||||
/*
|
||||
$Id$
|
||||
|
||||
This code is part of LDAP Account Manager (http://www.ldap-account-manager.org/)
|
||||
|
||||
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 custom LDAP objects.
|
||||
*
|
||||
* @package lists
|
||||
* @subpackage tree
|
||||
* @author David Smith
|
||||
* @author Roland Gruber
|
||||
*/
|
||||
|
||||
// Common to all templates
|
||||
$rdn = isset( $_POST['rdn'] ) ? $_POST['rdn'] : null;
|
||||
$container = $_POST['container'];
|
||||
|
||||
// Unique to this template
|
||||
$step = isset( $_POST['step'] ) ? $_POST['step'] : 1;
|
||||
|
||||
if( $step == 1 )
|
||||
{
|
||||
$oclasses = get_schema_objectClasses();
|
||||
if( ! $oclasses || ! is_array( $oclasses ) ) {
|
||||
StatusMessage("ERROR", "Unable to retrieve the schema from your LDAP server. Cannot continue with creation.", '');
|
||||
}
|
||||
?>
|
||||
|
||||
<h4><?php echo _('Step 1 of 2: Name and object class(es)'); ?></h4>
|
||||
|
||||
<form action="creation_template.php" method="post" name="creation_form">
|
||||
<input type="hidden" name="step" value="2" />
|
||||
<input type="hidden" name="template" value="<?php echo htmlspecialchars( $_POST['template'] ); ?>" />
|
||||
|
||||
<table class="create">
|
||||
<tr>
|
||||
<td class="heading"><acronym title="<?php echo _('Relative distinguished name'); ?>"><?php echo _('RDN'); ?></acronym>:</td>
|
||||
<td><input type="text" name="rdn" value="<?php echo htmlspecialchars( $rdn ); ?>" size="30" /> <?php echo _('(example: cn=MyNewPerson)'); ?></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td class="heading"><?php echo _('Container'); ?></td>
|
||||
<td><input type="text" name="container" size="40" value="<?php echo htmlspecialchars( $container ); ?>" /></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td class="heading"><?php echo _('Object classes'); ?></td>
|
||||
<td>
|
||||
<select name="object_classes[]" multiple="true" size="15">
|
||||
<?php foreach( $oclasses as $name => $oclass ) {
|
||||
if( 0 == strcasecmp( "top", $name ) ) continue; ?>
|
||||
<option <?php if( $oclass->getType() == 'structural' ) echo 'style="font-weight: bold" '; ?>
|
||||
value="<?php echo htmlspecialchars($oclass->getName()); ?>">
|
||||
<?php echo htmlspecialchars($oclass->getName()); ?>
|
||||
</option>
|
||||
<?php } ?>
|
||||
</select>
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
<tr>
|
||||
<td></td>
|
||||
<td><input type="submit" value="<?php echo _('Next'); ?>" /></td>
|
||||
</tr>
|
||||
</table>
|
||||
</form>
|
||||
|
||||
<?php
|
||||
}
|
||||
if( $step == 2 )
|
||||
{
|
||||
strlen( trim( $rdn ) ) != 0 or
|
||||
StatusMessage("ERROR", _("Data field for RDN is empty!"), '');
|
||||
|
||||
if ((strlen( trim( $container ) ) == 0) || !(dn_exists( $container ))) {
|
||||
StatusMessage("ERROR", _('The container you specified (%s) does not exist. Please try again.'), "", array(htmlspecialchars($container)));
|
||||
echo "</body></html>";
|
||||
exit;
|
||||
}
|
||||
|
||||
$oclasses = isset( $_POST['object_classes'] ) ? $_POST['object_classes'] : null;
|
||||
if( count( $oclasses ) == 0 ) {
|
||||
StatusMessage("ERROR", _('You did not select any object classes for this object. Please go back and do so.'), '');
|
||||
echo "</body></html>";
|
||||
exit;
|
||||
}
|
||||
$dn = trim( $container ) ? $rdn . ',' . $container : $rdn;
|
||||
|
||||
// incrementally build up the all_attrs and required_attrs arrays
|
||||
$schema_oclasses = get_schema_objectclasses();
|
||||
$required_attrs = array();
|
||||
$all_attrs = array();
|
||||
foreach( $oclasses as $oclass_name ) {
|
||||
$oclass = get_schema_objectclass( $oclass_name );
|
||||
if( $oclass ) {
|
||||
$required_attrs = array_merge( $required_attrs,
|
||||
$oclass->getMustAttrNames( $schema_oclasses ) );
|
||||
$all_attrs = array_merge( $all_attrs,
|
||||
$oclass->getMustAttrNames( $schema_oclasses ),
|
||||
$oclass->getMayAttrNames( $schema_oclasses ) );
|
||||
}
|
||||
}
|
||||
|
||||
$required_attrs = array_unique( $required_attrs );
|
||||
$all_attrs = array_unique( $all_attrs );
|
||||
remove_aliases( $required_attrs);
|
||||
remove_aliases( $all_attrs);
|
||||
sort( $required_attrs );
|
||||
sort( $all_attrs );
|
||||
|
||||
// if for some reason "ObjectClass" ends up in the list of
|
||||
// $all_attrs or $required_attrs, remove it! This is a fix
|
||||
// for bug 927487
|
||||
foreach( $all_attrs as $i => $attr_name )
|
||||
if( 0 == strcasecmp( $attr_name, 'objectClass' ) ) {
|
||||
unset( $all_attrs[$i] );
|
||||
$all_attrs = array_values( $all_attrs );
|
||||
break;
|
||||
}
|
||||
|
||||
foreach( $required_attrs as $i => $attr_name )
|
||||
if( 0 == strcasecmp( $attr_name, 'objectClass' ) ) {
|
||||
unset( $required_attrs[$i] );
|
||||
$required_attrs = array_values( $required_attrs );
|
||||
break;
|
||||
}
|
||||
|
||||
// remove binary attributes and add them to the binary_attrs array
|
||||
$binary_attrs = array();
|
||||
foreach( $all_attrs as $i => $attr_name ) {
|
||||
if( is_attr_binary( $attr_name ) ) {
|
||||
unset( $all_attrs[ $i ] );
|
||||
$binary_attrs[] = $attr_name;
|
||||
}
|
||||
}
|
||||
|
||||
// If we trim any attrs out above, then we will have a gap in the index
|
||||
// sequence and will get an "undefined index" error below. This prevents
|
||||
// that from happening.
|
||||
$all_attrs = array_values( $all_attrs );
|
||||
|
||||
// add the required attribute based on the RDN provided by the user
|
||||
// (ie, if the user specifies "cn=Bob" for their RDN, make sure "cn" is
|
||||
// in the list of required attributes.
|
||||
$rdn_attr = trim( substr( $rdn, 0, strpos( $rdn, '=' ) ) );
|
||||
$rdn_value = trim( substr( $rdn, strpos( $rdn, '=' ) + 1 ) );
|
||||
$rdn_value = @pla_explode_dn( $rdn );
|
||||
$rdn_value = @explode( '=', $rdn_value[0], 2 );
|
||||
$rdn_value = @$rdn_value[1];
|
||||
if( in_array( $rdn_attr, $all_attrs ) && ! in_array( $rdn_attr, $required_attrs ) )
|
||||
$required_attrs[] = $rdn_attr;
|
||||
?>
|
||||
|
||||
<h4><?php echo _('Step 2 of 2: Specify attributes and values'); ?></h4>
|
||||
|
||||
<form action="create.php" method="post" enctype="multipart/form-data">
|
||||
<input type="hidden" name="step" value="2" />
|
||||
<input type="hidden" name="new_dn" value="<?php echo htmlspecialchars( $dn ); ?>" />
|
||||
<input type="hidden" name="new_rdn" value="<?php echo htmlspecialchars( $rdn ); ?>" />
|
||||
<input type="hidden" name="container" value="<?php echo htmlspecialchars( $container ); ?>" />
|
||||
<input type="hidden" name="object_classes" value="<?php echo rawurlencode(serialize($oclasses)); ?>" />
|
||||
|
||||
<table class="edit_dn" cellspacing="0">
|
||||
<tr><th colspan="2"><?php echo _('Required attributes'); ?></th></tr>
|
||||
<?php if( count( $required_attrs ) == 0 ) {
|
||||
echo "<tr class=\"row1\"><td colspan=\"2\"><center>(" . _('none') . ")</center></td></tr>\n";
|
||||
} else
|
||||
|
||||
foreach( $required_attrs as $count => $attr ) { ?>
|
||||
<tr>
|
||||
<td class="attr"><b><?php
|
||||
|
||||
$attr_display = htmlspecialchars( $attr );
|
||||
|
||||
echo $attr_display;
|
||||
|
||||
?></b></td></tr>
|
||||
<tr>
|
||||
<td class="val"><input type="<?php echo (is_attr_binary( $attr ) ? "file" : "text"); ?>"
|
||||
name="required_attrs[<?php echo htmlspecialchars($attr); ?>]"
|
||||
value="<?php echo ($attr == $rdn_attr ? htmlspecialchars($rdn_value) : '') ?>" size="40" />
|
||||
</tr>
|
||||
<?php } ?>
|
||||
|
||||
<tr><th colspan="2"> </th></tr>
|
||||
<tr><th colspan="2"><?php echo _('Optional attributes'); ?></th></tr>
|
||||
|
||||
<?php if( count( $all_attrs ) == 0 ) { ?>
|
||||
<tr><td colspan="2"><center>(<?php echo _('none'); ?>)</center></td></tr>
|
||||
<?php } else { ?>
|
||||
<?php for($i=0; $i<min( count( $all_attrs ), 10 ); $i++ ) { $attr = $all_attrs[$i] ?>
|
||||
<tr>
|
||||
<td class="attr"><select style="background-color: #ddd; font-weight: bold" name="attrs[<?php echo $i; ?>]"><?php echo get_attr_select_html( $all_attrs, $attr ); ?></select></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td class="val"><input type="text" name="vals[<?php echo $i; ?>]" value="" size="40" />
|
||||
</tr>
|
||||
<?php } ?>
|
||||
<?php } ?>
|
||||
|
||||
<?php if( count( $binary_attrs ) > 0 ) { ?>
|
||||
<tr><th colspan="2"><?php echo _('Optional binary attributes'); ?></th></tr>
|
||||
<?php for( $k=$i; $k<$i+count($binary_attrs); $k++ ) { $attr = $binary_attrs[$k-$i]; ?>
|
||||
<tr><td class="attr"><select style="background-color: #ddd; font-weight: bold" name="attrs[<?php echo $k; ?>]"><?php echo get_binary_attr_select_html( $binary_attrs, $attr );?></select></td></tr>
|
||||
<tr><td class="val"><input type="file" name="vals[<?php echo $k; ?>]" value="" size="25" /></td></tr>
|
||||
<?php } ?>
|
||||
<?php } ?>
|
||||
|
||||
<tr><td>
|
||||
<center>
|
||||
<input type="submit" name="submit" value="<?php echo _('Create'); ?>" />
|
||||
</center>
|
||||
</td></tr>
|
||||
|
||||
</table>
|
||||
|
||||
<?php }
|
||||
|
||||
/**
|
||||
* Returns option values.
|
||||
*/
|
||||
function get_attr_select_html( $all_attrs, $highlight_attr=null )
|
||||
{
|
||||
$attr_select_html = "";
|
||||
if( ! is_array( $all_attrs ) )
|
||||
return null;
|
||||
foreach( $all_attrs as $a ) {
|
||||
$attr_display = htmlspecialchars( $a );
|
||||
$a = htmlspecialchars( $a );
|
||||
$attr_select_html .= "<option value=\"$a\"";
|
||||
if( 0 == strcasecmp( $highlight_attr, $a ) )
|
||||
$attr_select_html .= " selected";
|
||||
$attr_select_html .= ">$attr_display</option>\n";
|
||||
}
|
||||
return $attr_select_html;
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns option values.
|
||||
*/
|
||||
function get_binary_attr_select_html( $binary_attrs, $highlight_attr=null )
|
||||
{
|
||||
$binary_attr_select_html = "";
|
||||
if( ! is_array( $binary_attrs ) )
|
||||
return null;
|
||||
if( count( $binary_attrs ) == 0 )
|
||||
return null;
|
||||
foreach( $binary_attrs as $a ) {
|
||||
$attr_display = htmlspecialchars( $a );
|
||||
$binary_attr_select_html .= "<option";
|
||||
if( 0 == strcasecmp( $highlight_attr, $a ) )
|
||||
$binary_attr_select_html .= " selected";
|
||||
$binary_attr_select_html .= ">$attr_display</option>\n";
|
||||
}
|
||||
return $binary_attr_select_html;
|
||||
}
|
||||
|
||||
/**
|
||||
* Removes attributes from the array that are aliases for eachother
|
||||
* (just removes the second instance of the aliased attr)
|
||||
*/
|
||||
function remove_aliases( &$attribute_list)
|
||||
{
|
||||
// remove aliases from the attribute_list array
|
||||
for( $i=0; $i<count( $attribute_list ); $i++ ) {
|
||||
if( ! isset( $attribute_list[ $i ] ) )
|
||||
continue;
|
||||
$attr_name1 = $attribute_list[ $i ];
|
||||
for( $k=0; $k<count( $attribute_list ); $k++ ) {
|
||||
if( ! isset( $attribute_list[ $k ] ) )
|
||||
continue;
|
||||
if( $i == $k )
|
||||
continue;
|
||||
$attr_name2 = $attribute_list[ $k ];
|
||||
//echo "Comparing $attr_name1 and $attr_name2<br>";
|
||||
$attr1 = get_schema_attribute( $attr_name1 );
|
||||
if( null == $attr1 )
|
||||
continue;
|
||||
if( $attr1->isAliasFor( $attr_name2 ) ) {
|
||||
//echo "* Removing attribute ". $attribute_list[ $k ] . "<br>";
|
||||
unset( $attribute_list[ $k ] );
|
||||
}
|
||||
}
|
||||
}
|
||||
$attribute_list = array_values( $attribute_list );
|
||||
}
|
||||
?>
|
||||
|
|
@ -1,111 +0,0 @@
|
|||
<?php
|
||||
/*
|
||||
$Id$
|
||||
|
||||
This code is part of LDAP Account Manager (http://www.ldap-account-manager.org/)
|
||||
|
||||
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 new OUs.
|
||||
*
|
||||
* @package lists
|
||||
* @subpackage tree
|
||||
* @author David Smith
|
||||
* @author Roland Gruber
|
||||
*/
|
||||
|
||||
// Common to all templates
|
||||
$container = $_POST['container'];
|
||||
|
||||
// Unique to this template: which step of the ou creation process are we on
|
||||
$step = isset( $_POST['step'] ) ? $_POST['step'] : 1;
|
||||
|
||||
?>
|
||||
|
||||
<center><h2><?PHP echo _('New organisational unit');?></h2></center>
|
||||
|
||||
<?php if( $step == 1 ) { ?>
|
||||
|
||||
<form action="creation_template.php" method="post" name="ou_form">
|
||||
<input type="hidden" name="step" value="2" />
|
||||
<input type="hidden" name="template" value="<?php echo htmlspecialchars( $_POST['template'] ); ?>" />
|
||||
|
||||
<center>
|
||||
<table class="confirm">
|
||||
<tr>
|
||||
<td></td>
|
||||
<td class="heading"><?PHP echo _('Name');?>:</td>
|
||||
<td><input type="text" name="ou_name" value="" /> <small><?PHP echo _('(hint: do not include "ou=")');?></small></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td></td>
|
||||
<td class="heading"><?PHP echo _("Container DN") ?>:</td>
|
||||
<td><input type="text" name="container" size="40" value="<?php echo htmlspecialchars( $container ); ?>" />
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td colspan="3"><center><br /><input type="submit" value="<?php echo _('Next'); ?>" /></center></td>
|
||||
</tr>
|
||||
</table>
|
||||
</center>
|
||||
</form>
|
||||
|
||||
<?php } elseif( $step == 2 ) {
|
||||
|
||||
$ou_name = trim( $_POST['ou_name'] );
|
||||
$container = trim( $_POST['container'] );
|
||||
|
||||
if (!dn_exists( $container )) {
|
||||
StatusMessage("ERROR", "The container you specified does not exist. ", $container );
|
||||
echo "</body></html>";
|
||||
exit();
|
||||
}
|
||||
|
||||
?>
|
||||
<form action="create.php" method="post">
|
||||
<input type="hidden" name="new_dn" value="<?php echo htmlspecialchars( 'ou=' . $ou_name . ',' . $container ); ?>" />
|
||||
|
||||
<!-- ObjectClasses -->
|
||||
<?php $object_classes = rawurlencode( serialize( array( 'top', 'organizationalUnit' ) ) ); ?>
|
||||
|
||||
<input type="hidden" name="object_classes" value="<?php echo $object_classes; ?>" />
|
||||
|
||||
<!-- The array of attributes/values -->
|
||||
<input type="hidden" name="attrs[]" value="ou" />
|
||||
<input type="hidden" name="vals[]" value="<?php echo htmlspecialchars($ou_name);?>" />
|
||||
|
||||
<center><?php echo _("Really create this new OU?") ?>
|
||||
<br />
|
||||
<br />
|
||||
|
||||
<table class="confirm">
|
||||
<tr class="even"><td><?PHP echo _('Name'); ?></td><td><b><?php echo htmlspecialchars($ou_name); ?></b></td></tr>
|
||||
<tr class="odd"><td><?PHP echo _('Container'); ?></td><td><b><?php echo htmlspecialchars( $container ); ?></b></td></tr>
|
||||
</table>
|
||||
<br /><input type="submit" value="<?php echo _('Create'); ?>" />
|
||||
</center>
|
||||
|
||||
<?php } ?>
|
||||
|
|
@ -1,56 +0,0 @@
|
|||
<?php
|
||||
/*
|
||||
$Id$
|
||||
|
||||
This code is part of LDAP Account Manager (http://www.ldap-account-manager.org/)
|
||||
|
||||
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
|
||||
|
||||
|
||||
*/
|
||||
|
||||
|
||||
/**
|
||||
* Configuration for creation templates.
|
||||
*
|
||||
* @package lists
|
||||
* @subpackage tree
|
||||
* @author David Smith
|
||||
* @author Roland Gruber
|
||||
*/
|
||||
|
||||
|
||||
// template list
|
||||
|
||||
$templates = array();
|
||||
|
||||
$templates[] = array(
|
||||
'desc' => _('Organizational unit'),
|
||||
'icon' => '../../graphics/ou.png',
|
||||
'handler' => 'new_ou_template.php');
|
||||
|
||||
$templates[] = array(
|
||||
'desc' => _('Custom'),
|
||||
'icon' => '../../graphics/object.png',
|
||||
'handler' => 'custom.php');
|
||||
|
||||
|
||||
?>
|
Loading…
Reference in New Issue