<?php
// $Header: /cvsroot/phpldapadmin/phpldapadmin/htdocs/add_oclass_form.php,v 1.25 2007/12/15 07:50:30 wurley Exp $

/**
 * This page may simply add the objectClass and take you back to the edit page,
 * but, in one condition it may prompt the user for input. That condition is this:
 *
 *    If the user has requested to add an objectClass that requires a set of
 *    attributes with 1 or more not defined by the object. In that case, we will
 *    present a form for the user to add those attributes to the object.
 *
 * Variables that come in as REQUEST vars:
 *  - dn (rawurlencoded)
 *  - new_oclass
 *
 * @package phpLDAPadmin
 * @todo If an attribute expects a DN, show the dn browser.
 */
/**
 */
require './common.php';

$entry['oclass']['new'] = get_request('new_oclass','REQUEST');
$entry['dn']['string'] = get_request('dn','REQUEST');

if ($ldapserver->isReadOnly())
	pla_error(_('You cannot perform updates while server is in read-only mode'));

if (! $entry['oclass']['new'])
	pla_error(_('You did not select any ObjectClasses for this object. Please go back and do so.'));

/* Ensure that the object has defined all MUST attrs for this objectClass.
 * If it hasn't, present a form to have the user enter values for all the
 * newly required attrs.
 */

$entry['dn']['attrs'] = $ldapserver->getDNAttrs($entry['dn']['string'],true);

$entry['attrs']['current'] = array();
foreach ($entry['dn']['attrs'] as $attr => $junk)
	$entry['attrs']['current'][] = strtolower($attr);

# Grab the required attributes for the new objectClass
$ldap['oclasses'] = $ldapserver->SchemaObjectClasses();
$ldap['attrs']['must'] = array();
foreach ($entry['oclass']['new'] as $oclass_name) {
	$ldap['oclass'] = $ldapserver->getSchemaObjectClass($oclass_name);

	if ($ldap['oclass'])
		$ldap['attrs']['must'] = array_merge($ldap['attrs']['must'],$ldap['oclass']->getMustAttrNames($ldap['oclasses']));
}
$ldap['attrs']['must'] = array_unique($ldap['attrs']['must']);

/* Build a list of the attributes that this new objectClass requires,
 * but that the object does not currently contain
 */
$ldap['attrs']['need'] = array();
foreach ($ldap['attrs']['must'] as $attr) {
	$attr = $ldapserver->getSchemaAttribute($attr);

	# First, check if one of this attr's aliases is already an attribute of this entry
	foreach ($attr->getAliases() as $alias_attr_name)
		if (in_array(strtolower($alias_attr_name),$entry['attrs']['current']))
			continue;

	if (in_array(strtolower($attr->getName()),$entry['attrs']['current']))
		continue;

	/* We made it this far, so the attribute needs to be added to this entry in order
	 * to add this objectClass */
	$ldap['attrs']['need'][] = $attr;
}

if (count($ldap['attrs']['need']) > 0) {
	printf('<h3 class="title">%s</h3>',_('New Required Attributes'));
	printf('<h3 class="subtitle">%s %s %s</h3>',_('This action requires you to add'),count($ldap['attrs']['need']),_('new attributes'));

	printf('<small><b>%s: </b>%s <b>%s</b> %s %s</small>',
		_('Instructions'),
		_('In order to add these objectClass(es) to this entry, you must specify'),
		count($ldap['attrs']['need']),_('new attributes'),
		_('that this objectClass requires.'));

	echo '<br /><br />';

	echo '<form action="cmd.php" method="post">';
	echo '<input type="hidden" name="cmd" value="add_oclass" />';
	printf('<input type="hidden" name="new_oclass" value="%s" />',rawurlencode(serialize($entry['oclass']['new'])));
	printf('<input type="hidden" name="dn" value="%s" />',rawurlencode($entry['dn']['string']));
	printf('<input type="hidden" name="server_id" value="%s" />',$ldapserver->server_id);

	echo '<table class="edit_dn" cellspacing="0">';
	printf('<tr><th colspan="2">%s</th></tr>',_('New Required Attributes'));

	foreach ($ldap['attrs']['need'] as $count => $attr) {
		printf('<tr><td class="attr">%s</td></tr>',htmlspecialchars($attr->getName()));
		printf('<tr><td class="val"><input type="text" name="new_attrs[%s]" value="" size="40" /></td></tr>',htmlspecialchars($attr->getName()));
	}

	echo '</table>';

	echo '<br /><br />';

	printf('<center><input type="submit" value="%s" /></center>',_('Add ObjectClass and Attributes'));
	echo '</form>';

} else {
	$result = $ldapserver->attrModify($entry['dn']['string'],array('objectClass'=>$entry['oclass']['new']));

	if (! $result)
		pla_error('Could not perform ldap_mod_add operation.',$ldapserver->error(),$ldapserver->errno());

	else {
		$href = sprintf('cmd.php?cmd=template_engine&server_id=%s&dn=%s&modified_attrs[]=objectClass',
			$ldapserver->server_id,rawurlencode($entry['dn']['string']));

		header(sprintf('Location: %s',$href));
		die();
	}
}
?>