2009-06-30 18:05:37 +10:00
< ? php
2009-06-30 20:40:03 +10:00
// $Header: /cvsroot/phpldapadmin/phpldapadmin/htdocs/add_oclass.php,v 1.18 2005/12/10 10:34:54 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
* Adds an objectClass to the specified dn .
*
* Note , this does not do any schema violation checking . That is
* performed in add_oclass_form . php .
*
2009-06-30 19:29:51 +10:00
* Variables that come in via common . php
2009-06-30 18:05:37 +10:00
* - server_id
2009-06-30 19:29:51 +10:00
* Variables that come in as POST vars :
* - dn ( rawurlencoded )
2009-06-30 18:05:37 +10:00
* - new_oclass
* - new_attrs ( array , if any )
2009-06-30 19:29:51 +10:00
*
* @ package phpLDAPadmin
*/
/**
2009-06-30 18:05:37 +10:00
*/
2009-06-30 19:22:30 +10:00
require './common.php' ;
2009-06-30 18:05:37 +10:00
2009-06-30 19:29:51 +10:00
if ( $ldapserver -> isReadOnly () )
2009-06-30 20:26:08 +10:00
pla_error ( _ ( 'You cannot perform updates while server is in read-only mode' ) );
2009-06-30 19:29:51 +10:00
if ( ! $ldapserver -> haveAuthInfo ())
2009-06-30 20:26:08 +10:00
pla_error ( _ ( 'Not enough information to login to server. Please check your configuration.' ) );
2009-06-30 19:29:51 +10:00
2009-06-30 18:07:14 +10:00
$dn = rawurldecode ( $_POST [ 'dn' ] );
2009-06-30 19:29:51 +10:00
$new_oclass = unserialize ( rawurldecode ( $_POST [ 'new_oclass' ] ) );
2009-06-30 18:05:37 +10:00
$new_attrs = $_POST [ 'new_attrs' ];
2009-06-30 19:29:51 +10:00
$encoded_dn = rawurlencode ( $dn );
2009-06-30 18:07:14 +10:00
2009-06-30 20:26:08 +10:00
if ( $ldapserver -> isAttrReadOnly ( 'objectClass' ))
2009-06-30 19:29:51 +10:00
pla_error ( " ObjectClasses are flagged as read only in the phpLDAPadmin configuration. " );
2009-06-30 18:05:37 +10:00
$new_entry = array ();
$new_entry [ 'objectClass' ] = $new_oclass ;
$new_attrs_entry = array ();
$new_oclass_entry = array ( 'objectClass' => $new_oclass );
if ( is_array ( $new_attrs ) && count ( $new_attrs ) > 0 )
2009-06-30 19:22:30 +10:00
foreach ( $new_attrs as $attr => $val ) {
// Check to see if this is a unique Attribute
2009-06-30 20:26:08 +10:00
if ( $badattr = $ldapserver -> checkUniqueAttr ( $dn , $attr , array ( $val ))) {
2009-06-30 19:29:51 +10:00
$search_href = sprintf ( 'search.php?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 , $dn , $search_href ) );
2009-06-30 19:22:30 +10:00
}
2009-06-30 18:05:37 +10:00
$new_entry [ $attr ] = $val ;
2009-06-30 19:22:30 +10:00
}
2009-06-30 18:05:37 +10:00
2009-06-30 20:26:08 +10:00
$add_res = $ldapserver -> attrModify ( $dn , $new_entry );
2009-06-30 18:05:37 +10:00
2009-06-30 19:29:51 +10:00
if ( ! $add_res )
2009-06-30 20:26:08 +10:00
pla_error ( _ ( 'Could not perform ldap_mod_add operation.' ), $ldapserver -> error (), $ldapserver -> errno ());
2009-06-30 18:05:37 +10:00
else
2009-06-30 20:26:08 +10:00
header ( sprintf ( 'Location: template_engine.php?server_id=%s&dn=%s&modified_attrs[]=objectclass' , $ldapserver -> server_id , $encoded_dn ));
2009-06-30 18:05:37 +10:00
?>