phpldapadmin/add_attr.php

168 lines
4.9 KiB
PHP
Raw Normal View History

2009-06-30 19:22:30 +10:00
<?php
2009-06-30 19:25:27 +10:00
// $Header: /cvsroot/phpldapadmin/phpldapadmin/add_attr.php,v 1.13 2005/04/15 11:46:41 wurley Exp $
2009-06-30 19:22:30 +10:00
2009-06-30 19:24:29 +10:00
/**
2009-06-30 19:22:30 +10:00
* Adds an attribute/value pair to an object
*
* Variables that come in as POST vars:
* - dn
* - server_id
* - attr
* - val
* - binary
2009-06-30 19:24:29 +10:00
*
* @package phpLDAPadmin
*/
/**
2009-06-30 19:22:30 +10:00
*/
require './common.php';
require 'templates/template_config.php';
2009-06-30 19:24:29 +10:00
$server_id = (isset($_POST['server_id']) ? $_POST['server_id'] : '');
$ldapserver = new LDAPServer($server_id);
if( $ldapserver->isReadOnly() )
pla_error( $lang['no_updates_in_read_only_mode'] );
if( ! $ldapserver->haveAuthInfo())
pla_error( $lang['not_enough_login_info'] );
2009-06-30 19:22:30 +10:00
$attr = $_POST['attr'];
$val = isset( $_POST['val'] ) ? $_POST['val'] : false;;
$dn = $_POST['dn'] ;
2009-06-30 19:24:29 +10:00
$is_binary_val = isset( $_POST['binary'] ) ? true : false;
2009-06-30 19:22:30 +10:00
$encoded_dn = rawurlencode( $dn );
$encoded_attr = rawurlencode( $attr );
if( ! $is_binary_val && $val == "" ) {
pla_error( $lang['left_attr_blank'] );
}
2009-06-30 19:24:29 +10:00
// special case for binary attributes (like jpegPhoto and userCertificate):
2009-06-30 19:22:30 +10:00
// we must go read the data from the file and override $val with the binary data
// Secondly, we must check if the ";binary" option has to be appended to the name
// of the attribute.
// Check to see if this is a unique Attribute
2009-06-30 19:24:29 +10:00
if( $badattr = checkUniqueAttr( $ldapserver, $dn, $attr, array($val) ) ) {
$search_href = sprintf('search.php?search=true&form=advanced&server_id=%s&filter=%s=%s',$server_id,$attr,$badattr);
pla_error(sprintf( $lang['unique_attr_failed'],$attr,$badattr,$dn,$search_href ) );
2009-06-30 19:22:30 +10:00
}
if( $is_binary_val ) {
2009-06-30 19:24:29 +10:00
if( 0 == $_FILES['val']['size'] )
pla_error( $lang['file_empty'] );
if( ! is_uploaded_file( $_FILES['val']['tmp_name'] ) ) {
if( isset( $_FILES['val']['error'] ) )
switch($_FILES['val']['error']) {
case 0: //no error; possible file attack!
pla_error( $lang['invalid_file'] );
break;
case 1: //uploaded file exceeds the upload_max_filesize directive in php.ini
pla_error( $lang['uploaded_file_too_big'] );
break;
case 2: //uploaded file exceeds the MAX_FILE_SIZE directive specified in the html form
pla_error( $lang['uploaded_file_too_big'] );
break;
case 3: //uploaded file was only partially uploaded
pla_error( $lang['uploaded_file_partial'] );
break;
case 4: //no file was uploaded
pla_error( $lang['left_attr_blank'] );
break;
default: //a default error, just in case! :)
pla_error( $lang['invalid_file'] );
break;
}
else
pla_error( $lang['invalid_file'] );
}
2009-06-30 19:22:30 +10:00
$file = $_FILES['val']['tmp_name'];
2009-06-30 19:24:29 +10:00
$f = fopen( $file, 'r' );
$binary_data = fread( $f, filesize( $file ) );
fclose( $f );
$val = $binary_data;
2009-06-30 19:22:30 +10:00
2009-06-30 19:25:27 +10:00
if( is_binary_option_required( $ldapserver, $attr ) )
2009-06-30 19:24:29 +10:00
$attr .= ";binary";
2009-06-30 19:22:30 +10:00
}
2009-06-30 19:24:29 +10:00
// Automagically hash new userPassword attributes according to the
// chosen in config.php.
if( 0 == strcasecmp( $attr, 'userpassword' ) ) {
2009-06-30 19:22:30 +10:00
if( isset( $servers[$server_id]['default_hash'] ) &&
2009-06-30 19:24:29 +10:00
$servers[$server_id]['default_hash'] != '' ) {
2009-06-30 19:22:30 +10:00
$enc_type = $servers[$server_id]['default_hash'];
$val = password_hash( $val, $enc_type );
}
}
2009-06-30 19:24:29 +10:00
elseif( in_array( $attr,array('sambantpassword','sambalmpassword') ) ){
$mkntPassword = new MkntPasswdUtil();
$mkntPassword->createSambaPasswords( $val );
$val = $mkntPassword->valueOf($attr);
2009-06-30 19:22:30 +10:00
}
$new_entry = array( $attr => $val );
2009-06-30 19:24:29 +10:00
$result = @ldap_mod_add( $ldapserver->connect(), $dn, $new_entry );
2009-06-30 19:22:30 +10:00
if( $result )
2009-06-30 19:24:29 +10:00
header( "Location: edit.php?server_id=$server_id&dn=$encoded_dn&modified_attrs[]=$encoded_attr" );
2009-06-30 19:22:30 +10:00
else
2009-06-30 19:24:29 +10:00
pla_error( $lang['failed_to_add_attr'],ldap_error($ldapserver->connect()),ldap_errno($ldapserver->connect()) );
/**
* Check if we need to append the ;binary option to the name
* of some binary attribute
*
* @param int $server_id Server ID that the attribute is in.
* @param attr $attr Attribute to test to see if it requires ;binary added to it.
* @return bool
*/
2009-06-30 19:25:27 +10:00
function is_binary_option_required( $ldapserver, $attr ) {
2009-06-30 19:24:29 +10:00
// list of the binary attributes which need the ";binary" option
$binary_attributes_with_options = array(
// Superior: Ldapv3 Syntaxes (1.3.6.1.4.1.1466.115.121.1)
'1.3.6.1.4.1.1466.115.121.1.8' => "userCertificate",
'1.3.6.1.4.1.1466.115.121.1.8' => "caCertificate",
'1.3.6.1.4.1.1466.115.121.1.10' => "crossCertificatePair",
'1.3.6.1.4.1.1466.115.121.1.9' => "certificateRevocationList",
'1.3.6.1.4.1.1466.115.121.1.9' => "authorityRevocationList",
// Superior: Netscape Ldap attributes types (2.16.840.1.113730.3.1)
'2.16.840.1.113730.3.1.40' => "userSMIMECertificate"
);
// quick check by attr name (short circuits the schema check if possible)
//foreach( $binary_attributes_with_options as $oid => $name )
//if( 0 == strcasecmp( $attr, $name ) )
2009-06-30 19:22:30 +10:00
//return true;
2009-06-30 19:24:29 +10:00
$schema_attr = get_schema_attribute( $ldapserver, $attr );
if( ! $schema_attr )
return false;
2009-06-30 19:22:30 +10:00
2009-06-30 19:24:29 +10:00
$syntax = $schema_attr->getSyntaxOID();
if( isset( $binary_attributes_with_options[ $syntax ] ) )
return true;
2009-06-30 19:22:30 +10:00
2009-06-30 19:24:29 +10:00
return false;
2009-06-30 19:22:30 +10:00
}
?>