193 lines
		
	
	
		
			6.1 KiB
		
	
	
	
		
			PHP
		
	
	
	
			
		
		
	
	
			193 lines
		
	
	
		
			6.1 KiB
		
	
	
	
		
			PHP
		
	
	
	
<?php
 | 
						|
/*
 | 
						|
$Id$
 | 
						|
 | 
						|
  This code is part of LDAP Account Manager (http://www.sourceforge.net/projects/lam)
 | 
						|
  Copyright (C) 2003 - 2006  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 main suffixes if they are missing.
 | 
						|
*
 | 
						|
* @author Roland Gruber
 | 
						|
* @package main
 | 
						|
*/
 | 
						|
 | 
						|
/** security functions */
 | 
						|
include_once("../lib/security.inc");
 | 
						|
/** access to configuration settings */
 | 
						|
include_once("../lib/config.inc");
 | 
						|
/** LDAP access */
 | 
						|
include_once("../lib/ldap.inc");
 | 
						|
/** status messages */
 | 
						|
include_once("../lib/status.inc");
 | 
						|
 | 
						|
// start session
 | 
						|
startSecureSession();
 | 
						|
 | 
						|
setlanguage();
 | 
						|
 | 
						|
// check if user already pressed button
 | 
						|
if ($_POST['add_suff'] || $_POST['cancel']) {
 | 
						|
	if ($_POST['add_suff']) {
 | 
						|
		$fail = array();
 | 
						|
		$errors = array();
 | 
						|
		$new_suff = $_POST['new_suff'];
 | 
						|
		$new_suff = str_replace("\\", "", $new_suff);
 | 
						|
		$new_suff = str_replace("'", "", $new_suff);
 | 
						|
		$new_suff = explode(";", $new_suff);
 | 
						|
		// add entries
 | 
						|
		for ($i = 0; $i < sizeof($new_suff); $i++) {
 | 
						|
			// check if entry is already present
 | 
						|
			$info = @ldap_search($_SESSION['ldap']->server(), $new_suff[$i], "", array());
 | 
						|
			$res = @ldap_get_entries($_SESSION['ldap']->server(), $info);
 | 
						|
			if ($res) continue;
 | 
						|
			$suff = $new_suff[$i];
 | 
						|
			// generate DN and attributes
 | 
						|
			$tmp = explode(",", $suff);
 | 
						|
			$name = explode("=", $tmp[0]);
 | 
						|
			array_shift($tmp);
 | 
						|
			$end = implode(",", $tmp);
 | 
						|
			if ($name[0] != "ou") {  // add root entry
 | 
						|
				$attr = array();
 | 
						|
				$attr[$name[0]] = $name[1];
 | 
						|
				$attr['objectClass'] = 'organization';
 | 
						|
				$dn = $suff;
 | 
						|
				if (!@ldap_add($_SESSION['ldap']->server(), $dn, $attr)) {
 | 
						|
					$fail[] = $suff;
 | 
						|
					continue;
 | 
						|
				}
 | 
						|
			}
 | 
						|
			else {  // add organizational unit
 | 
						|
				$name = $name[1];
 | 
						|
				$attr = array();
 | 
						|
				$attr['objectClass'] = "organizationalunit";
 | 
						|
				$attr['ou'] = $name;
 | 
						|
				$dn = $suff;
 | 
						|
				if (!@ldap_add($_SESSION['ldap']->server(), $dn, $attr)) {
 | 
						|
					// check if we have to add parent entries
 | 
						|
					if (ldap_errno($_SESSION['ldap']->server()) == 32) {
 | 
						|
						$temp = explode(",", $suff);
 | 
						|
						$subsuffs = array();
 | 
						|
						// make list of subsuffixes
 | 
						|
						for ($k = 0; $k < sizeof($temp); $k++) {
 | 
						|
							$part = explode("=", $temp[$k]);
 | 
						|
							if ($part[0] == "ou") $subsuffs[] = implode(",", array_slice($temp, $k));
 | 
						|
							else {
 | 
						|
								$subsuffs[] = implode(",", array_slice($temp, $k));
 | 
						|
								break;
 | 
						|
							}
 | 
						|
						}
 | 
						|
						// create missing entries
 | 
						|
						for ($k = sizeof($subsuffs) - 1; $k >= 0; $k--) {
 | 
						|
							// check if subsuffix is present
 | 
						|
							$info = @ldap_search($_SESSION['ldap']->server(), $subsuffs[$k], "", array());
 | 
						|
							$res = @ldap_get_entries($_SESSION['ldap']->server(), $info);
 | 
						|
							if (!$res) {
 | 
						|
								$suffarray = explode(",", $subsuffs[$k]);
 | 
						|
								$headarray = explode("=", $suffarray[0]);
 | 
						|
								if ($headarray[0] == "ou") {  // add ou entry
 | 
						|
									$attr = array();
 | 
						|
									$attr['objectClass'] = 'organizationalunit';
 | 
						|
									$attr['ou'] = $headarray[1];
 | 
						|
									$dn = $subsuffs[$k];
 | 
						|
									if (!@ldap_add($_SESSION['ldap']->server(), $dn, $attr)) {
 | 
						|
										$fail[] = $suff;
 | 
						|
										$error[] = ldap_error($_SESSION['ldap']->server());
 | 
						|
										break;
 | 
						|
									}
 | 
						|
								}
 | 
						|
								else {  // add root entry
 | 
						|
									$attr = array();
 | 
						|
									$attr['objectClass'][] = 'organization';
 | 
						|
									$attr[$headarray[0]] = $headarray[1];
 | 
						|
									if ($headarray[0] == "dc") {
 | 
						|
										$attr['o'] = $headarray[1];
 | 
						|
										$attr['objectClass'][] = 'dcObject';
 | 
						|
									}
 | 
						|
									$dn = $subsuffs[$k];
 | 
						|
									if (!@ldap_add($_SESSION['ldap']->server(), $dn, $attr)) {
 | 
						|
										$fail[] = $suff;
 | 
						|
										$error[] = ldap_error($_SESSION['ldap']->server());
 | 
						|
										break;
 | 
						|
									}
 | 
						|
								}
 | 
						|
							}
 | 
						|
						}
 | 
						|
					}
 | 
						|
					else {
 | 
						|
						$fail[] = $suff;
 | 
						|
						$error[] = ldap_error($_SESSION['ldap']->server());
 | 
						|
					}
 | 
						|
				}
 | 
						|
			}
 | 
						|
		}
 | 
						|
	}
 | 
						|
	echo $_SESSION['header'];
 | 
						|
	echo "<title>initsuff</title>\n";
 | 
						|
	echo "<link rel=\"stylesheet\" type=\"text/css\" href=\"../style/layout.css\">\n";
 | 
						|
	echo "</head>\n<body>\n";
 | 
						|
	// print error/success messages
 | 
						|
	if ($_POST['add_suff']) {
 | 
						|
		if (sizeof($fail) > 0) {
 | 
						|
			// print error messages
 | 
						|
			for ($i = 0; $i < sizeof($fail); $i++) {
 | 
						|
				StatusMessage("ERROR", _("Failed to create entry!") . "<br>" . $error[$i], $fail[$i]);
 | 
						|
			}
 | 
						|
			echo "</body></html>\n";
 | 
						|
		}
 | 
						|
		else {
 | 
						|
			// print success message
 | 
						|
			StatusMessage("INFO", "", _("All changes were successful."));
 | 
						|
			echo "</body></html>\n";
 | 
						|
		}
 | 
						|
	}
 | 
						|
	else {
 | 
						|
		// no suffixes were created
 | 
						|
		StatusMessage("INFO", "", _("No changes were made."));
 | 
						|
		echo "</body></html>\n";
 | 
						|
	}
 | 
						|
	exit;
 | 
						|
}
 | 
						|
 | 
						|
// first show of page
 | 
						|
$new_suff = $_GET['suffs'];
 | 
						|
$new_suff = str_replace("\\", "", $new_suff);
 | 
						|
$new_suff = str_replace("'", "", $new_suff);
 | 
						|
$new_suff = explode(";", $new_suff);
 | 
						|
 | 
						|
echo $_SESSION['header'];
 | 
						|
echo "<title>initsuff</title>\n";
 | 
						|
echo "<link rel=\"stylesheet\" type=\"text/css\" href=\"../style/layout.css\">\n";
 | 
						|
echo "</head><body>\n";
 | 
						|
	echo "<p> </p>\n";
 | 
						|
	echo "<p><font color=\"red\"><b>" . _("The following suffix(es) are missing in LDAP. LAM can create them for you.") . "</b></font></p>\n";
 | 
						|
	echo "<p> </p>\n";
 | 
						|
	// print missing suffixes
 | 
						|
	for ($i = 0; $i < sizeof($new_suff); $i++) {
 | 
						|
		echo "<p><b>" . $new_suff[$i] . "</b></p>\n";
 | 
						|
	}
 | 
						|
	echo "<p> </p>\n";
 | 
						|
	echo "<form action=\"initsuff.php\" method=\"post\">\n";
 | 
						|
	echo "<input type=\"hidden\" name=\"new_suff\" value=\"" . implode(";", $new_suff) . "\">\n";
 | 
						|
	echo "<input type=\"submit\" name=\"add_suff\" value=\"" . _("Create") . "\">";
 | 
						|
	echo "<input type=\"submit\" name=\"cancel\" value=\"" . _("Cancel") . "\">";
 | 
						|
	echo "</form>\n";
 | 
						|
echo "</body></html>\n";
 | 
						|
?>
 |