2020-09-13 23:41:26 +10:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace App\Ldap;
|
|
|
|
|
2020-09-23 22:14:38 +10:00
|
|
|
use Illuminate\Support\Arr;
|
2020-09-21 22:20:59 +10:00
|
|
|
use Illuminate\Support\Collection;
|
2020-09-13 23:41:26 +10:00
|
|
|
use LdapRecord\Models\Model;
|
2020-09-21 22:20:59 +10:00
|
|
|
use LdapRecord\Models\ModelNotFoundException;
|
|
|
|
use LdapRecord\Query\Model\Builder;
|
2020-09-13 23:41:26 +10:00
|
|
|
|
|
|
|
class Entry extends Model
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* The object classes of the LDAP model.
|
|
|
|
*
|
|
|
|
* @var array
|
|
|
|
*/
|
|
|
|
public static $objectClasses = [];
|
2020-09-19 00:08:00 +10:00
|
|
|
|
2020-09-21 22:20:59 +10:00
|
|
|
/**
|
|
|
|
* Gets the root DN of the specified LDAPServer, or throws an exception if it
|
|
|
|
* can't find it.
|
|
|
|
*
|
|
|
|
* @param null $connection
|
|
|
|
* @return Collection
|
|
|
|
* @throws ModelNotFoundException
|
|
|
|
* @testedin GetBaseDNTest::testBaseDNExists();
|
|
|
|
*/
|
|
|
|
public function baseDN($connection = NULL): ?Collection
|
|
|
|
{
|
|
|
|
$base = static::on($connection ?? (new static)->getConnectionName())
|
|
|
|
->in(NULL)
|
|
|
|
->read()
|
|
|
|
->select(['namingcontexts'])
|
|
|
|
->whereHas('objectclass')
|
|
|
|
->firstOrFail();
|
|
|
|
|
2020-09-23 22:14:38 +10:00
|
|
|
$result = collect();
|
|
|
|
foreach ($base->namingcontexts as $dn) {
|
|
|
|
$result->push((new self)->findOrFail($dn));
|
|
|
|
}
|
|
|
|
|
|
|
|
return $result;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return an icon for a DN based on objectClass
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function icon(): string
|
|
|
|
{
|
|
|
|
$objectclasses = array_map('strtolower',$this->objectclass);
|
|
|
|
|
|
|
|
// Return icon based upon objectClass value
|
|
|
|
if (in_array('person',$objectclasses) ||
|
|
|
|
in_array('organizationalperson',$objectclasses) ||
|
|
|
|
in_array('inetorgperson',$objectclasses) ||
|
|
|
|
in_array('account',$objectclasses) ||
|
|
|
|
in_array('posixaccount',$objectclasses))
|
|
|
|
|
|
|
|
return 'fas fa-user';
|
|
|
|
|
|
|
|
elseif (in_array('organization',$objectclasses))
|
|
|
|
return 'fas fa-university';
|
|
|
|
|
|
|
|
elseif (in_array('organizationalunit',$objectclasses))
|
|
|
|
return 'fas fa-object-group';
|
|
|
|
|
|
|
|
elseif (in_array('posixgroup',$objectclasses) ||
|
|
|
|
in_array('groupofnames',$objectclasses) ||
|
|
|
|
in_array('groupofuniquenames',$objectclasses) ||
|
|
|
|
in_array('group',$objectclasses))
|
|
|
|
|
|
|
|
return 'fas fa-users';
|
|
|
|
|
|
|
|
elseif (in_array('dcobject',$objectclasses) ||
|
|
|
|
in_array('domainrelatedobject',$objectclasses) ||
|
|
|
|
in_array('domain',$objectclasses) ||
|
|
|
|
in_array('builtindomain',$objectclasses))
|
|
|
|
|
|
|
|
return 'fas fa-network-wired';
|
|
|
|
|
|
|
|
elseif (in_array('alias',$objectclasses))
|
|
|
|
return 'fas fa-theater-masks';
|
|
|
|
|
|
|
|
elseif (in_array('country',$objectclasses))
|
|
|
|
return sprintf('flag %s',strtolower(Arr::get($this->c,0)));
|
|
|
|
|
|
|
|
elseif (in_array('device',$objectclasses))
|
|
|
|
return 'fas fa-mobile-alt';
|
|
|
|
|
|
|
|
elseif (in_array('document',$objectclasses))
|
|
|
|
return 'fas fa-file-alt';
|
|
|
|
|
|
|
|
elseif (in_array('iphost',$objectclasses))
|
|
|
|
return 'fas fa-wifi';
|
|
|
|
|
|
|
|
elseif (in_array('room',$objectclasses))
|
|
|
|
return 'fas fa-door-open';
|
|
|
|
|
|
|
|
elseif (in_array('server',$objectclasses))
|
|
|
|
return 'fas fa-server';
|
|
|
|
|
|
|
|
// Default
|
|
|
|
return 'fa-fw fas fa-cog';
|
2020-09-21 22:20:59 +10:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Obtain the rootDSE for the server, that gives us server information
|
|
|
|
*
|
|
|
|
* @param null $connection
|
|
|
|
* @return Entry|null
|
|
|
|
* @throws ModelNotFoundException
|
|
|
|
* @testedin TranslateOidTest::testRootDSE();
|
|
|
|
*/
|
|
|
|
public function rootDSE($connection = NULL): ?Entry
|
2020-09-19 00:08:00 +10:00
|
|
|
{
|
|
|
|
return static::on($connection ?? (new static)->getConnectionName())
|
2020-09-21 22:20:59 +10:00
|
|
|
->in(NULL)
|
2020-09-19 00:08:00 +10:00
|
|
|
->read()
|
|
|
|
->select(['+'])
|
|
|
|
->whereHas('objectclass')
|
|
|
|
->firstOrFail();
|
|
|
|
}
|
2020-09-13 23:41:26 +10:00
|
|
|
}
|