class LdapQuery in Lightweight Directory Access Protocol (LDAP) 7.2
Same name and namespace in other branches
- 8.2 ldap_query/LdapQuery.class.php \LdapQuery
- 7 ldap_query/LdapQuery.class.php \LdapQuery
LDAP Server Class.
This class is used to create, work with, and eventually destroy ldap_server objects.
@todo make bindpw protected
Hierarchy
- class \LdapQuery
Expanded class hierarchy of LdapQuery
1 string reference to 'LdapQuery'
- LdapQueryAdmin::getLdapQueryObjects in ldap_query/
LdapQueryAdmin.class.php
File
- ldap_query/
LdapQuery.class.php, line 16 - Defines server classes and related functions.
View source
class LdapQuery {
/**
* LDAP Settings.
*/
public $query_numeric_id;
public $qid;
public $name;
public $sid;
public $status;
public $baseDn = [];
public $base_dn_str = NULL;
public $filter;
public $attributes_str = NULL;
public $attributes = [];
public $sizelimit = 0;
public $timelimit = 0;
public $deref = LDAP_DEREF_NEVER;
public $scope = LDAP_SCOPE_SUBTREE;
public $inDatabase = FALSE;
public $detailedWatchdogLog = FALSE;
/**
* Constructor Method.
*/
public function __construct($qid) {
if (!is_scalar($qid)) {
return;
}
$query_records = [];
if (module_exists('ctools')) {
ctools_include('export');
$result = ctools_export_load_object('ldap_query', 'names', [
$qid,
]);
if (isset($result[$qid])) {
$query_record = $result[$qid];
foreach ($query_record as $property_name => $value) {
$this->{$property_name} = $value;
}
}
}
else {
$select = db_select('ldap_query')
->fields('ldap_query')
->condition('ldap_query.qid', $qid)
->execute();
foreach ($select as $record) {
$query_records[$record->qid] = $record;
}
if (!isset($query_records[$qid])) {
$this->inDatabase = FALSE;
return;
}
$query_record = $query_records[$qid];
foreach ($this
->fields() as $field_id => $field) {
if (isset($query_record->{$field_id})) {
$this->{$field['property_name']} = @$query_record->{$field_id};
}
}
}
// Special properties that don't map directly from storage and defaults.
$this->inDatabase = TRUE;
$this->detailedWatchdogLog = variable_get('ldap_help_watchdog_detail', 0);
$this->baseDn = $this
->linesToArray($this->base_dn_str);
$this->attributes = $this->attributes_str ? $this
->csvToArray($this->attributes_str, TRUE) : [];
}
/**
* Destructor Method.
*/
public function __destruct() {
}
/**
* Invoke Method.
*/
public function __invoke() {
}
/**
* Function search($base_dn = NULL, $filter, $attributes = array(), $attrsonly = 0, $sizelimit = 0, $timelimit = 0, $deref = LDAP_DEREF_NEVER) {.
*/
public function query() {
ldap_servers_module_load_include('php', 'ldap_servers', 'LdapServer.class');
$ldap_server = new LdapServer($this->sid);
$ldap_server
->connect();
$ldap_server
->bind();
$results = [];
$count = 0;
foreach ($this->baseDn as $base_dn) {
$result = $ldap_server
->search($base_dn, $this->filter, $this->attributes, 0, $this->sizelimit, $this->timelimit, $this->deref, $this->scope);
if ($result !== FALSE && $result['count'] > 0) {
$count = $count + $result['count'];
$results = array_merge($results, $result);
}
}
$results['count'] = $count;
return $results;
}
/**
* Error methods and properties.
*/
protected $_errorMsg = NULL;
protected $_hasError = FALSE;
protected $_errorName = NULL;
/**
*
*/
public function setError($_errorName, $_errorMsgText = NULL) {
$this->_errorMsgText = $_errorMsgText;
$this->_errorName = $_errorName;
$this->_hasError = TRUE;
}
/**
*
*/
public function clearError() {
$this->_hasError = FALSE;
$this->_errorMsg = NULL;
$this->_errorName = NULL;
}
/**
*
*/
public function hasError() {
return $this->_hasError || $this
->ldapErrorNumber();
}
/**
* @param null $type
*
* @return string|null
*/
public function errorMsg($type = NULL) {
if ($type == 'ldap' && $this->connection) {
return ldap_err2str(ldap_errno($this->connection));
}
elseif ($type == NULL) {
return $this->_errorMsg;
}
else {
return NULL;
}
}
/**
* @param null $type
*
* @return string|null
*/
public function errorName($type = NULL) {
if ($type == 'ldap' && $this->connection) {
return "LDAP Error: " . ldap_error($this->connection);
}
elseif ($type == NULL) {
return $this->_errorName;
}
else {
return NULL;
}
}
/**
*
*/
public function ldapErrorNumber() {
return FALSE;
}
/**
*
*/
protected function linesToArray($lines) {
$lines = trim($lines);
if ($lines) {
$array = preg_split('/[\\n\\r]+/', $lines);
foreach ($array as $i => $value) {
$array[$i] = trim($value);
}
}
else {
$array = [];
}
return $array;
}
/**
*
*/
protected function csvToArray($string, $strip_quotes = FALSE) {
$items = explode(',', $string);
foreach ($items as $i => $item) {
$items[$i] = trim($item);
if ($strip_quotes) {
$items[$i] = trim($items[$i], '"');
}
}
return $items;
}
/**
*
*/
public static function fields() {
$fields = [
'query_numeric_id' => [
'property_name' => 'query_numeric_id',
'schema' => [
'type' => 'serial',
'unsigned' => TRUE,
'not null' => TRUE,
'description' => 'Primary ID field for the table. Only used internally.',
'no export' => TRUE,
],
],
'qid' => [
'property_name' => 'qid',
'schema' => [
'type' => 'varchar',
'length' => 20,
'description' => 'Machine name for query.',
'not null' => TRUE,
],
'form' => [
'field_group' => 'basic',
'#type' => 'textfield',
'#title' => t('Machine name for this query configuration.'),
'#size' => 20,
'#maxlength' => 20,
'#description' => t('May only contain alphanumeric characters (a-z, A-Z, 0-9, and _)'),
'#required' => TRUE,
],
'form_to_prop_functions' => [
'trim',
],
],
'name' => [
'property_name' => 'name',
'schema' => [
'type' => 'varchar',
'length' => '60',
'not null' => TRUE,
],
'form' => [
'field_group' => 'basic',
'#type' => 'textfield',
'#title' => t('Name'),
'#description' => t('Choose a name for this query configuration.'),
'#size' => 50,
'#maxlength' => 255,
'#required' => TRUE,
],
'form_to_prop_functions' => [
'trim',
],
],
'sid' => [
'property_name' => 'sid',
'schema' => [
'type' => 'varchar',
'length' => 20,
'not null' => TRUE,
],
'form' => [
'field_group' => 'basic',
'#type' => 'radios',
'#title' => t('LDAP Server used for query.'),
'#required' => 1,
],
'form_to_prop_functions' => [
'trim',
],
],
'status' => [
'property_name' => 'status',
'schema' => [
'type' => 'int',
'size' => 'tiny',
'not null' => TRUE,
'default' => 0,
],
'form' => [
'field_group' => 'basic',
'#type' => 'checkbox',
'#title' => t('Enabled'),
'#description' => t('Disable in order to keep configuration without having it active.'),
],
'form_to_prop_functions' => [
'trim',
],
],
'base_dn_str' => [
'property_name' => 'base_dn_str',
'schema' => [
'type' => 'text',
'not null' => FALSE,
],
'form' => [
'field_group' => 'query',
'#type' => 'textarea',
'#title' => t('Base DNs to search in query.'),
'#description' => t('Each Base DN will be queried and results merged. e.g. <code>ou=groups,dc=hogwarts,dc=edu</code>') . t('Enter one per line in case if you need more than one.'),
'#cols' => 50,
'#rows' => 6,
'#required' => TRUE,
],
'form_to_prop_functions' => [
'trim',
],
],
'baseDn' => [
'property_name' => 'baseDn',
'exportable' => FALSE,
],
'filter' => [
'property_name' => 'filter',
'schema' => [
'type' => 'text',
'not null' => FALSE,
],
'form' => [
'field_group' => 'query',
'#type' => 'textarea',
'#title' => t('Filter'),
'#description' => t('LDAP query filter such as <code>(objectClass=group)</code> or <code>(&(objectClass=user)(homePhone=*))
</code>'),
'#cols' => 50,
'#rows' => 1,
'#required' => TRUE,
],
'form_to_prop_functions' => [
'trim',
],
],
'attributes_str' => [
'property_name' => 'attributes_str',
'schema' => [
'type' => 'text',
'not null' => FALSE,
],
'form' => [
'field_group' => 'query',
'#type' => 'textarea',
'#title' => t('Attributes to return.'),
'#description' => t('Enter as comma separated list. DN is automatically returned. Leave empty to return all attributes. e.g. <code>objectclass,name,cn,samaccountname</code>'),
'#cols' => 50,
'#rows' => 6,
],
'form_to_prop_functions' => [
'trim',
],
],
'attributes' => [
'property_name' => 'attributes',
'exportable' => FALSE,
],
'sizelimit' => [
'property_name' => 'sizelimit',
'schema' => [
'type' => 'int',
'size' => 'small',
'not null' => TRUE,
'default' => 0,
],
'form' => [
'field_group' => 'query_advanced',
'#type' => 'textfield',
'#title' => t('Size Limit of returned data'),
'#description' => t('This limit may be already set by the ldap server. 0 signifies no limit'),
'#size' => 7,
'#maxlength' => 5,
'#required' => TRUE,
],
'form_to_prop_functions' => [
'trim',
],
],
'timelimit' => [
'property_name' => 'timelimit',
'schema' => [
'type' => 'int',
'size' => 'small',
'not null' => TRUE,
'default' => 0,
],
'form' => [
'field_group' => 'query_advanced',
'#type' => 'textfield',
'#title' => t('Time Limit in Seconds'),
'#description' => t('The time limitset on this query. This may be already set by the ldap server. 0 signifies no limit'),
'#size' => 7,
'#maxlength' => 5,
'#required' => TRUE,
],
'form_to_prop_functions' => [
'trim',
],
],
'deref' => [
'property_name' => 'deref',
'schema' => [
'type' => 'int',
'size' => 'tiny',
'not null' => TRUE,
'default' => LDAP_DEREF_NEVER,
],
'form' => [
'field_group' => 'query_advanced',
'#type' => 'radios',
'#title' => t('How aliases should be handled during the search.'),
'#required' => 1,
'#options' => [
LDAP_DEREF_NEVER => t('(default) aliases are never dereferenced.'),
LDAP_DEREF_SEARCHING => t('aliases should be dereferenced during the search but not when locating the base object of the search.'),
LDAP_DEREF_FINDING => t('aliases should be dereferenced when locating the base object but not during the search.'),
LDAP_DEREF_ALWAYS => t('aliases should be dereferenced always.'),
],
],
'form_to_prop_functions' => [
'trim',
],
],
'scope' => [
'property_name' => 'scope',
'schema' => [
'type' => 'int',
'size' => 'tiny',
'not null' => TRUE,
'default' => LDAP_SCOPE_SUBTREE,
],
'form' => [
'field_group' => 'query_advanced',
'#type' => 'radios',
'#title' => t('Scope of search.'),
'#required' => 1,
'#options' => [
LDAP_SCOPE_BASE => t('BASE. This value is used to indicate searching only the entry at the base DN, resulting in only that entry being returned (keeping in mind that it also has to meet the search filter criteria!).'),
LDAP_SCOPE_ONELEVEL => t('ONELEVEL. This value is used to indicate searching all entries one level under the base DN - but not including the base DN and not including any entries under that one level under the base DN.'),
LDAP_SCOPE_SUBTREE => t('SUBTREE. (default) This value is used to indicate searching of all entries at all levels under and including the specified base DN.'),
],
],
'form_to_prop_functions' => [
'trim',
],
],
];
return $fields;
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
LdapQuery:: |
public | property | ||
LdapQuery:: |
public | property | ||
LdapQuery:: |
public | property | ||
LdapQuery:: |
public | property | ||
LdapQuery:: |
public | property | ||
LdapQuery:: |
public | property | ||
LdapQuery:: |
public | property | ||
LdapQuery:: |
public | property | ||
LdapQuery:: |
public | property | ||
LdapQuery:: |
public | property | ||
LdapQuery:: |
public | property | LDAP Settings. | |
LdapQuery:: |
public | property | ||
LdapQuery:: |
public | property | ||
LdapQuery:: |
public | property | ||
LdapQuery:: |
public | property | ||
LdapQuery:: |
public | property | ||
LdapQuery:: |
protected | property | Error methods and properties. | |
LdapQuery:: |
protected | property | ||
LdapQuery:: |
protected | property | ||
LdapQuery:: |
public | function | ||
LdapQuery:: |
protected | function | ||
LdapQuery:: |
public | function | ||
LdapQuery:: |
public | function | ||
LdapQuery:: |
public static | function | ||
LdapQuery:: |
public | function | ||
LdapQuery:: |
public | function | ||
LdapQuery:: |
protected | function | ||
LdapQuery:: |
public | function | Function search($base_dn = NULL, $filter, $attributes = array(), $attrsonly = 0, $sizelimit = 0, $timelimit = 0, $deref = LDAP_DEREF_NEVER) {. | |
LdapQuery:: |
public | function | ||
LdapQuery:: |
public | function | Constructor Method. | 1 |
LdapQuery:: |
public | function | Destructor Method. | |
LdapQuery:: |
public | function | Invoke Method. |