2021-06-26 11:23:15 -04:00
|
|
|
<?php
|
|
|
|
|
2023-05-17 12:56:55 -04:00
|
|
|
namespace BookStack\Access;
|
2016-01-15 18:21:47 -05:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Class Ldap
|
|
|
|
* An object-orientated thin abstraction wrapper for common PHP LDAP functions.
|
|
|
|
* Allows the standard LDAP functions to be mocked for testing.
|
|
|
|
*/
|
|
|
|
class Ldap
|
|
|
|
{
|
|
|
|
/**
|
2021-11-05 20:32:01 -04:00
|
|
|
* Connect to an LDAP server.
|
2021-11-06 18:00:33 -04:00
|
|
|
*
|
2023-05-30 08:10:05 -04:00
|
|
|
* @return resource|\LDAP\Connection|false
|
2016-01-15 18:21:47 -05:00
|
|
|
*/
|
2023-05-30 08:10:05 -04:00
|
|
|
public function connect(string $hostName)
|
2016-01-15 18:21:47 -05:00
|
|
|
{
|
2023-05-30 08:10:05 -04:00
|
|
|
return ldap_connect($hostName);
|
2016-01-15 18:21:47 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2023-05-30 08:10:05 -04:00
|
|
|
* Set the value of an LDAP option for the given connection.
|
2021-06-26 11:23:15 -04:00
|
|
|
*
|
2023-05-30 08:10:05 -04:00
|
|
|
* @param resource|\LDAP\Connection|null $ldapConnection
|
2016-01-15 18:21:47 -05:00
|
|
|
*/
|
2023-05-30 08:10:05 -04:00
|
|
|
public function setOption($ldapConnection, int $option, mixed $value): bool
|
2016-01-15 18:21:47 -05:00
|
|
|
{
|
|
|
|
return ldap_set_option($ldapConnection, $option, $value);
|
|
|
|
}
|
|
|
|
|
2021-02-07 15:00:04 -05:00
|
|
|
/**
|
|
|
|
* Start TLS on the given LDAP connection.
|
|
|
|
*/
|
|
|
|
public function startTls($ldapConnection): bool
|
|
|
|
{
|
|
|
|
return ldap_start_tls($ldapConnection);
|
|
|
|
}
|
|
|
|
|
2016-05-02 06:38:07 -04:00
|
|
|
/**
|
2023-05-30 08:10:05 -04:00
|
|
|
* Set the version number for the given LDAP connection.
|
2021-06-26 11:23:15 -04:00
|
|
|
*
|
2023-05-30 08:10:05 -04:00
|
|
|
* @param resource|\LDAP\Connection $ldapConnection
|
2016-05-02 06:38:07 -04:00
|
|
|
*/
|
2021-11-05 20:32:01 -04:00
|
|
|
public function setVersion($ldapConnection, int $version): bool
|
2016-05-02 06:38:07 -04:00
|
|
|
{
|
|
|
|
return $this->setOption($ldapConnection, LDAP_OPT_PROTOCOL_VERSION, $version);
|
|
|
|
}
|
|
|
|
|
2016-01-15 18:21:47 -05:00
|
|
|
/**
|
|
|
|
* Search LDAP tree using the provided filter.
|
2021-06-26 11:23:15 -04:00
|
|
|
*
|
2023-05-30 08:10:05 -04:00
|
|
|
* @param resource|\LDAP\Connection $ldapConnection
|
2021-06-26 11:23:15 -04:00
|
|
|
*
|
2024-08-28 10:39:05 -04:00
|
|
|
* @return \LDAP\Result|array|false
|
2016-01-15 18:21:47 -05:00
|
|
|
*/
|
2023-05-30 08:10:05 -04:00
|
|
|
public function search($ldapConnection, string $baseDn, string $filter, array $attributes = null)
|
2016-01-15 18:21:47 -05:00
|
|
|
{
|
|
|
|
return ldap_search($ldapConnection, $baseDn, $filter, $attributes);
|
|
|
|
}
|
|
|
|
|
2024-08-28 10:39:05 -04:00
|
|
|
/**
|
|
|
|
* Read an entry from the LDAP tree.
|
|
|
|
*
|
|
|
|
* @param resource|\Ldap\Connection $ldapConnection
|
|
|
|
*
|
|
|
|
* @return \LDAP\Result|array|false
|
|
|
|
*/
|
|
|
|
public function read($ldapConnection, string $baseDn, string $filter, array $attributes = null)
|
|
|
|
{
|
|
|
|
return ldap_read($ldapConnection, $baseDn, $filter, $attributes);
|
|
|
|
}
|
|
|
|
|
2016-01-15 18:21:47 -05:00
|
|
|
/**
|
2023-05-30 08:10:05 -04:00
|
|
|
* Get entries from an LDAP search result.
|
2021-06-26 11:23:15 -04:00
|
|
|
*
|
2023-05-30 08:10:05 -04:00
|
|
|
* @param resource|\LDAP\Connection $ldapConnection
|
|
|
|
* @param resource|\LDAP\Result $ldapSearchResult
|
2016-01-15 18:21:47 -05:00
|
|
|
*/
|
2023-05-30 08:10:05 -04:00
|
|
|
public function getEntries($ldapConnection, $ldapSearchResult): array|false
|
2016-01-15 18:21:47 -05:00
|
|
|
{
|
|
|
|
return ldap_get_entries($ldapConnection, $ldapSearchResult);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Search and get entries immediately.
|
2021-06-26 11:23:15 -04:00
|
|
|
*
|
2023-05-30 08:10:05 -04:00
|
|
|
* @param resource|\LDAP\Connection $ldapConnection
|
2016-01-15 18:21:47 -05:00
|
|
|
*/
|
2023-05-30 08:10:05 -04:00
|
|
|
public function searchAndGetEntries($ldapConnection, string $baseDn, string $filter, array $attributes = null): array|false
|
2016-01-15 18:21:47 -05:00
|
|
|
{
|
|
|
|
$search = $this->search($ldapConnection, $baseDn, $filter, $attributes);
|
2021-06-26 11:23:15 -04:00
|
|
|
|
2016-01-15 18:21:47 -05:00
|
|
|
return $this->getEntries($ldapConnection, $search);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Bind to LDAP directory.
|
2021-06-26 11:23:15 -04:00
|
|
|
*
|
2023-05-30 08:10:05 -04:00
|
|
|
* @param resource|\LDAP\Connection $ldapConnection
|
2016-01-15 18:21:47 -05:00
|
|
|
*/
|
2023-05-30 08:10:05 -04:00
|
|
|
public function bind($ldapConnection, string $bindRdn = null, string $bindPassword = null): bool
|
2016-01-15 18:21:47 -05:00
|
|
|
{
|
|
|
|
return ldap_bind($ldapConnection, $bindRdn, $bindPassword);
|
|
|
|
}
|
2018-12-20 15:04:09 -05:00
|
|
|
|
|
|
|
/**
|
2023-05-30 08:10:05 -04:00
|
|
|
* Explode an LDAP dn string into an array of components.
|
2018-12-20 15:04:09 -05:00
|
|
|
*/
|
2023-05-30 08:10:05 -04:00
|
|
|
public function explodeDn(string $dn, int $withAttrib): array|false
|
2018-12-20 15:04:09 -05:00
|
|
|
{
|
|
|
|
return ldap_explode_dn($dn, $withAttrib);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Escape a string for use in an LDAP filter.
|
|
|
|
*/
|
2023-05-30 08:10:05 -04:00
|
|
|
public function escape(string $value, string $ignore = '', int $flags = 0): string
|
2018-12-20 15:04:09 -05:00
|
|
|
{
|
|
|
|
return ldap_escape($value, $ignore, $flags);
|
|
|
|
}
|
2016-11-15 05:10:12 -05:00
|
|
|
}
|