2009-06-30 18:09:20 +10:00
< ? php
2009-06-30 20:46:00 +10:00
// $Header: /cvsroot/phpldapadmin/phpldapadmin/htdocs/create.php,v 1.48 2007/12/15 07:50:30 wurley Exp $
2009-06-30 19:22:30 +10:00
2009-06-30 19:29:51 +10:00
/**
2009-06-30 18:05:37 +10:00
* Creates a new object .
*
* Variables that come in as POST vars :
* - new_dn
* - required_attrs ( an array with indices being the attributes ,
* and the values being their respective values )
* - object_classes ( rawurlencoded , and serialized array of objectClasses )
2009-06-30 19:29:51 +10:00
*
* @ package phpLDAPadmin
*/
/**
* @ todo : posixgroup with empty memberlist generates an error .
2009-06-30 18:05:37 +10:00
*/
2009-06-30 19:29:51 +10:00
require './common.php' ;
if ( $ldapserver -> isReadOnly ())
2009-06-30 20:46:00 +10:00
pla_error ( _ ( 'You cannot perform updates while server is in read-only mode' ), null , - 1 , true );
2009-06-30 18:05:37 +10:00
2009-06-30 20:46:00 +10:00
if ( ! $_SESSION [ 'plaConfig' ] -> isCommandAvailable ( 'entry_create' ))
pla_error ( sprintf ( '%s%s %s' , _ ( 'This operation is not permitted by the configuration' ), _ ( ':' ), _ ( 'create entry' )));
2009-06-30 19:29:51 +10:00
2009-06-30 20:46:00 +10:00
$rdn_attr = isset ( $_POST [ 'rdn_attribute' ]) ? $_POST [ 'rdn_attribute' ] : null ;
2009-06-30 19:29:51 +10:00
2009-06-30 20:46:00 +10:00
$entryfactoryclass = $_SESSION [ 'plaConfig' ] -> GetValue ( 'appearance' , 'entry_factory' );
eval ( '$entry_factory = new ' . $entryfactoryclass . '();' );
$entry = $entry_factory -> newCreatingEntry ( '' );
2009-06-30 18:05:37 +10:00
2009-06-30 20:46:00 +10:00
eval ( '$reader = new ' . $_SESSION [ 'plaConfig' ] -> GetValue ( 'appearance' , 'entry_reader' ) . '($ldapserver);' );
$entry -> accept ( $reader );
2009-06-30 20:26:08 +10:00
2009-06-30 20:46:00 +10:00
$container = $entry -> getContainer ();
2009-06-30 18:05:37 +10:00
2009-06-30 20:46:00 +10:00
if ( ! $container || ! $ldapserver -> dnExists ( $container ))
pla_error ( sprintf ( _ ( 'The container you specified (%s) does not exist. Please try again.' ), htmlspecialchars ( $container )), null , - 1 , true );
2009-06-30 20:26:08 +10:00
2009-06-30 20:46:00 +10:00
$tree = get_cached_item ( $ldapserver -> server_id , 'tree' );
if ( $tree ) {
$container_entry = $tree -> getEntry ( $container );
if ( ! $container_entry )
$tree -> addEntry ( $container );
2009-06-30 19:29:51 +10:00
2009-06-30 20:46:00 +10:00
$container_entry = $tree -> getEntry ( $container );
if ( $container_entry -> isLeaf ())
pla_error ( sprintf ( _ ( 'The container (%s) is a leaf.' ), htmlspecialchars ( $container )), null , - 1 , true );
}
2009-06-30 19:29:51 +10:00
2009-06-30 20:46:00 +10:00
$entry -> setRdnAttributeName ( $rdn_attr );
if ( ! $entry -> getRdnAttribute ())
pla_error ( sprintf ( _ ( 'The Rdn attribute (%s) does not exist.' ), htmlspecialchars ( $rdn_attr )), null , - 1 , true );
2009-06-30 20:26:45 +10:00
2009-06-30 20:46:00 +10:00
$new_dn = $entry -> getDn ();
if ( ! $new_dn )
pla_error ( _ ( 'You left the RDN field blank.' ));
2009-06-30 19:29:51 +10:00
2009-06-30 20:46:00 +10:00
$redirect = isset ( $_POST [ 'redirect' ]) ? $_POST [ 'redirect' ] : false ;
2009-06-30 19:29:51 +10:00
2009-06-30 20:46:00 +10:00
$new_entry = array ();
$attrs = $entry -> getAttributes ();
foreach ( $attrs as $attr ) {
$vals = $attr -> getValues ();
$new_vals = array ();
foreach ( $vals as $val ) {
if ( strlen ( $val ) > 0 )
$new_vals [] = $val ;
}
2009-06-30 20:26:08 +10:00
2009-06-30 20:46:00 +10:00
if ( $attr -> isRequired () && ! $new_vals )
pla_error ( sprintf ( _ ( 'You left the value blank for required attribute (%s).' ), htmlspecialchars ( $attr -> getName ())));
2009-06-30 19:29:51 +10:00
2009-06-30 20:46:00 +10:00
if ( $new_vals )
$new_entry [ $attr -> getName ()] = $new_vals ;
2009-06-30 18:05:37 +10:00
}
2009-06-30 20:46:00 +10:00
if ( ! in_array ( 'top' , $new_entry [ 'objectClass' ]))
2009-06-30 18:05:37 +10:00
$new_entry [ 'objectClass' ][] = 'top' ;
2009-06-30 20:26:08 +10:00
foreach ( $new_entry as $attr => $vals ) {
# Check to see if this is a unique Attribute
if ( $badattr = $ldapserver -> checkUniqueAttr ( $new_dn , $attr , $vals )) {
2009-06-30 20:46:00 +10:00
$search_href = sprintf ( '?cmd=search&search=true&form=advanced&server_id=%s&filter=%s=%s' , $ldapserver -> server_id , $attr , $badattr );
2009-06-30 20:26:08 +10:00
pla_error ( sprintf ( _ ( 'Your attempt to add <b>%s</b> (<i>%s</i>) to <br><b>%s</b><br> is NOT allowed. That attribute/value belongs to another entry.<p>You might like to <a href=\'%s\'>search</a> for that entry.' ), $attr , $badattr , $new_dn , $search_href ));
2009-06-30 19:22:30 +10:00
}
}
2009-06-30 18:07:14 +10:00
2009-06-30 20:26:08 +10:00
# Check the user-defined custom call back first
if ( run_hook ( 'pre_entry_create' , array ( 'server_id' => $ldapserver -> server_id , 'dn' => $new_dn , 'attrs' => $new_entry )))
$add_result = $ldapserver -> add ( $new_dn , $new_entry );
2009-06-30 19:29:51 +10:00
2009-06-30 20:26:08 +10:00
if ( $add_result ) {
run_hook ( 'post_entry_create' , array ( 'server_id' => $ldapserver -> server_id , 'dn' => $new_dn , 'attrs' => $new_entry ));
2009-06-30 19:29:51 +10:00
2009-06-30 20:46:00 +10:00
$action_number = $_SESSION [ 'plaConfig' ] -> GetValue ( 'appearance' , 'action_after_creation' );
2009-06-30 18:05:37 +10:00
2009-06-30 20:46:00 +10:00
$container = get_container ( $new_dn , false );
//$container_container = get_container($container);
2009-06-30 18:05:37 +10:00
2009-06-30 20:46:00 +10:00
if ( $redirect ) {
$redirect_url = $redirect ;
} else if ( $action_number == 2 ) {
$redirect_url = sprintf ( 'cmd.php?cmd=template_engine&server_id=%s&container=%s' , $ldapserver -> server_id , rawurlencode ( $container ));
} else {
$redirect_url = sprintf ( 'cmd.php?cmd=template_engine&server_id=%s&dn=%s' , $ldapserver -> server_id , rawurlencode ( $new_dn ));
2009-06-30 18:05:37 +10:00
}
2009-06-30 19:29:51 +10:00
2009-06-30 20:46:00 +10:00
if ( $action_number == 1 || $action_number == 2 )
printf ( '<meta http-equiv="refresh" content="0; url=%s" />' , $redirect_url );
if ( $action_number == 1 || $action_number == 2 ) {
$create_message = sprintf ( '%s DN%s <b>%s</b> %s' , _ ( 'Creation successful!' ), _ ( ':' ), htmlspecialchars ( $new_dn ), _ ( 'has been created.' ));
system_message ( array (
'title' => _ ( 'Create Entry' ),
'body' => $create_message ,
'type' => 'info' ),
$redirect_url );
} else {
printf ( '<h3 class="title">%s</h3>' , _ ( 'Entry created' ));
echo '<br />' ;
echo '<center>' ;
printf ( '<a href="cmd.php?cmd=template_engine&server_id=%s&dn=%s">%s</a>.' , $ldapserver -> server_id , rawurlencode ( $new_dn ), _ ( 'Display the new created entry' ));
echo '<br />' ;
printf ( '<a href="cmd.php?cmd=template_engine&server_id=%s&container=%s">%s</a>.' , $ldapserver -> server_id , rawurlencode ( $container ), _ ( 'Create another entry' ));
echo '</center>' ;
}
2009-06-30 18:05:37 +10:00
2009-06-30 20:26:08 +10:00
} else {
pla_error ( _ ( 'Could not add the object to the LDAP server.' ), $ldapserver -> error (), $ldapserver -> errno ());
2009-06-30 19:29:51 +10:00
}
2009-06-30 18:05:37 +10:00
?>