2013-06-03 17:02:08 +02:00
|
|
|
<?php
|
2013-06-07 13:29:11 +02:00
|
|
|
// {{{ICINGA_LICENSE_HEADER}}}
|
|
|
|
// {{{ICINGA_LICENSE_HEADER}}}
|
2013-06-03 17:02:08 +02:00
|
|
|
|
|
|
|
namespace Icinga\Protocol\Ldap;
|
2013-06-07 13:29:11 +02:00
|
|
|
|
2014-08-27 16:03:15 +02:00
|
|
|
use Icinga\Exception\IcingaException;
|
|
|
|
|
2013-06-03 17:02:08 +02:00
|
|
|
/**
|
|
|
|
* This class is a special node object, representing your connections root node
|
|
|
|
*
|
|
|
|
* @copyright Copyright (c) 2013 Icinga-Web Team <info@icinga.org>
|
|
|
|
* @author Icinga-Web Team <info@icinga.org>
|
|
|
|
* @package Icinga\Protocol\Ldap
|
|
|
|
* @license http://www.gnu.org/copyleft/gpl.html GNU General Public License
|
2013-06-07 13:29:11 +02:00
|
|
|
* @package Icinga\Protocol\Ldap
|
2013-06-03 17:02:08 +02:00
|
|
|
*/
|
|
|
|
class Root
|
|
|
|
{
|
2013-06-07 13:29:11 +02:00
|
|
|
/**
|
|
|
|
* @var string
|
|
|
|
*/
|
2013-06-03 17:02:08 +02:00
|
|
|
protected $rdn;
|
2013-06-07 13:29:11 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @var Connection
|
|
|
|
*/
|
2013-06-03 17:02:08 +02:00
|
|
|
protected $connection;
|
2013-06-07 13:29:11 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @var array
|
|
|
|
*/
|
2013-06-03 17:02:08 +02:00
|
|
|
protected $children = array();
|
2013-06-07 13:29:11 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @var array
|
|
|
|
*/
|
2013-06-03 17:02:08 +02:00
|
|
|
protected $props = array();
|
|
|
|
|
2013-06-07 13:29:11 +02:00
|
|
|
/**
|
|
|
|
* @param Connection $connection
|
|
|
|
*/
|
2013-06-03 17:02:08 +02:00
|
|
|
protected function __construct(Connection $connection)
|
|
|
|
{
|
|
|
|
$this->connection = $connection;
|
|
|
|
}
|
|
|
|
|
2013-06-07 13:29:11 +02:00
|
|
|
/**
|
|
|
|
* @return bool
|
|
|
|
*/
|
2013-06-03 17:02:08 +02:00
|
|
|
public function hasParent()
|
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2013-06-07 13:29:11 +02:00
|
|
|
/**
|
|
|
|
* @param Connection $connection
|
|
|
|
* @return Root
|
|
|
|
*/
|
2013-06-03 17:02:08 +02:00
|
|
|
public static function forConnection(Connection $connection)
|
|
|
|
{
|
|
|
|
$root = new Root($connection);
|
|
|
|
return $root;
|
|
|
|
}
|
|
|
|
|
2013-06-07 13:29:11 +02:00
|
|
|
/**
|
|
|
|
* @param $dn
|
|
|
|
* @param array $props
|
|
|
|
* @return Node
|
|
|
|
*/
|
2013-06-03 17:02:08 +02:00
|
|
|
public function createChildByDN($dn, $props = array())
|
|
|
|
{
|
|
|
|
$dn = $this->stripMyDN($dn);
|
|
|
|
$parts = array_reverse(LdapUtils::explodeDN($dn));
|
|
|
|
$parent = $this;
|
2013-06-07 13:29:11 +02:00
|
|
|
while ($rdn = array_shift($parts)) {
|
2013-06-03 17:02:08 +02:00
|
|
|
if ($parent->hasChildRDN($rdn)) {
|
|
|
|
$child = $parent->getChildByRDN($rdn);
|
|
|
|
} else {
|
2013-06-07 13:29:11 +02:00
|
|
|
$child = Node::createWithRDN($parent, $rdn, (array)$props);
|
2013-06-03 17:02:08 +02:00
|
|
|
$parent->addChild($child);
|
|
|
|
}
|
|
|
|
$parent = $child;
|
|
|
|
}
|
|
|
|
return $child;
|
|
|
|
}
|
|
|
|
|
2013-06-07 13:29:11 +02:00
|
|
|
/**
|
|
|
|
* @param $rdn
|
|
|
|
* @return bool
|
|
|
|
*/
|
2013-06-03 17:02:08 +02:00
|
|
|
public function hasChildRDN($rdn)
|
|
|
|
{
|
|
|
|
return array_key_exists(strtolower($rdn), $this->children);
|
|
|
|
}
|
|
|
|
|
2013-06-07 13:29:11 +02:00
|
|
|
/**
|
|
|
|
* @param $rdn
|
|
|
|
* @return mixed
|
2014-08-27 16:03:15 +02:00
|
|
|
* @throws IcingaException
|
2013-06-07 13:29:11 +02:00
|
|
|
*/
|
2013-06-03 17:02:08 +02:00
|
|
|
public function getChildByRDN($rdn)
|
|
|
|
{
|
2013-06-07 13:29:11 +02:00
|
|
|
if (!$this->hasChildRDN($rdn)) {
|
2014-08-27 16:03:15 +02:00
|
|
|
throw new IcingaException(
|
|
|
|
'The child RDN "%s" is not available',
|
|
|
|
$rdn
|
2013-06-07 13:29:11 +02:00
|
|
|
);
|
2013-06-03 17:02:08 +02:00
|
|
|
}
|
|
|
|
return $this->children[strtolower($rdn)];
|
|
|
|
}
|
|
|
|
|
2013-06-07 13:29:11 +02:00
|
|
|
/**
|
|
|
|
* @return array
|
|
|
|
*/
|
2013-06-03 17:02:08 +02:00
|
|
|
public function children()
|
|
|
|
{
|
|
|
|
return $this->children;
|
|
|
|
}
|
|
|
|
|
2014-03-20 16:45:36 +01:00
|
|
|
public function countChildren()
|
|
|
|
{
|
|
|
|
return count($this->children);
|
|
|
|
}
|
|
|
|
|
2013-06-07 13:29:11 +02:00
|
|
|
/**
|
|
|
|
* @return bool
|
|
|
|
*/
|
2013-06-03 17:02:08 +02:00
|
|
|
public function hasChildren()
|
|
|
|
{
|
2013-06-07 13:29:11 +02:00
|
|
|
return !empty($this->children);
|
2013-06-03 17:02:08 +02:00
|
|
|
}
|
|
|
|
|
2013-06-07 13:29:11 +02:00
|
|
|
/**
|
|
|
|
* @param Node $child
|
|
|
|
* @return $this
|
|
|
|
*/
|
2013-06-03 17:02:08 +02:00
|
|
|
public function addChild(Node $child)
|
|
|
|
{
|
|
|
|
$this->children[strtolower($child->getRDN())] = $child;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2013-06-07 13:29:11 +02:00
|
|
|
/**
|
|
|
|
* @param $dn
|
|
|
|
* @return string
|
|
|
|
*/
|
2013-06-03 17:02:08 +02:00
|
|
|
protected function stripMyDN($dn)
|
|
|
|
{
|
|
|
|
$this->assertSubDN($dn);
|
|
|
|
return substr($dn, 0, strlen($dn) - strlen($this->getDN()) - 1);
|
|
|
|
}
|
|
|
|
|
2013-06-07 13:29:11 +02:00
|
|
|
/**
|
|
|
|
* @param $dn
|
|
|
|
* @return $this
|
2014-08-27 16:03:15 +02:00
|
|
|
* @throws IcingaException
|
2013-06-07 13:29:11 +02:00
|
|
|
*/
|
2013-06-03 17:02:08 +02:00
|
|
|
protected function assertSubDN($dn)
|
|
|
|
{
|
|
|
|
$mydn = $this->getDN();
|
|
|
|
$end = substr($dn, -1 * strlen($mydn));
|
|
|
|
if (strtolower($end) !== strtolower($mydn)) {
|
2014-08-27 16:03:15 +02:00
|
|
|
throw new IcingaException(
|
|
|
|
'"%s" is not a child of "%s"',
|
|
|
|
$dn,
|
|
|
|
$mydn
|
2013-06-07 13:29:11 +02:00
|
|
|
);
|
2013-06-03 17:02:08 +02:00
|
|
|
}
|
|
|
|
if (strlen($dn) === strlen($mydn)) {
|
2014-08-27 16:03:15 +02:00
|
|
|
throw new IcingaException(
|
|
|
|
'"%s" is not a child of "%s", they are equal',
|
|
|
|
$dn,
|
|
|
|
$mydn
|
2013-06-07 13:29:11 +02:00
|
|
|
);
|
2013-06-03 17:02:08 +02:00
|
|
|
}
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2013-06-07 13:29:11 +02:00
|
|
|
/**
|
|
|
|
* @param Connection $connection
|
|
|
|
* @return $this
|
|
|
|
*/
|
2013-06-03 17:02:08 +02:00
|
|
|
public function setConnection(Connection $connection)
|
|
|
|
{
|
|
|
|
$this->connection = $connection;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2013-06-07 13:29:11 +02:00
|
|
|
/**
|
|
|
|
* @return Connection
|
|
|
|
*/
|
2013-06-03 17:02:08 +02:00
|
|
|
public function getConnection()
|
|
|
|
{
|
|
|
|
return $this->connection;
|
|
|
|
}
|
|
|
|
|
2013-06-07 13:29:11 +02:00
|
|
|
/**
|
|
|
|
* @return bool
|
|
|
|
*/
|
2013-06-03 17:02:08 +02:00
|
|
|
public function hasBeenChanged()
|
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2013-06-07 13:29:11 +02:00
|
|
|
/**
|
|
|
|
* @return mixed
|
|
|
|
*/
|
2013-06-03 17:02:08 +02:00
|
|
|
public function getRDN()
|
|
|
|
{
|
|
|
|
return $this->getDN();
|
|
|
|
}
|
|
|
|
|
2013-06-07 13:29:11 +02:00
|
|
|
/**
|
|
|
|
* @return mixed
|
|
|
|
*/
|
2013-06-03 17:02:08 +02:00
|
|
|
public function getDN()
|
|
|
|
{
|
|
|
|
return $this->connection->getDN();
|
|
|
|
}
|
|
|
|
|
2013-06-07 13:29:11 +02:00
|
|
|
/**
|
|
|
|
* @param $key
|
|
|
|
* @return null
|
|
|
|
*/
|
2013-06-03 17:02:08 +02:00
|
|
|
public function __get($key)
|
|
|
|
{
|
2013-06-07 13:29:11 +02:00
|
|
|
if (!array_key_exists($key, $this->props)) {
|
2013-06-03 17:02:08 +02:00
|
|
|
return null;
|
|
|
|
}
|
|
|
|
return $this->props[$key];
|
|
|
|
}
|
|
|
|
|
2013-06-07 13:29:11 +02:00
|
|
|
/**
|
|
|
|
* @param $key
|
|
|
|
* @return bool
|
|
|
|
*/
|
2013-06-03 17:02:08 +02:00
|
|
|
public function __isset($key)
|
|
|
|
{
|
|
|
|
return array_key_exists($key, $this->props);
|
|
|
|
}
|
|
|
|
}
|