You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
roundcubemail/program/lib/Roundcube/rcube_ldap_result.php

131 lines
3.8 KiB
PHP

<?php
/*
+-----------------------------------------------------------------------+
| Roundcube/rcube_ldap_result.php |
| |
| This file is part of the Roundcube Webmail client |
| Copyright (C) 2006-2013, The Roundcube Dev Team |
| Copyright (C) 2013, Kolab Systems AG |
| |
| Licensed under the GNU General Public License version 3 or |
| any later version with exceptions for skins & plugins. |
| See the README file for a full license statement. |
| |
| PURPOSE: |
| Model class that represents an LDAP search result |
| |
+-----------------------------------------------------------------------+
| Author: Thomas Bruederli <roundcube@gmail.com> |
+-----------------------------------------------------------------------+
*/
/**
* Model class representing an LDAP search result
*
* @package Framework
* @subpackage LDAP
*/
class rcube_ldap_result implements Iterator
{
public $conn;
public $ldap;
public $base_dn;
public $filter;
private $count = null;
private $current = null;
private $iteratorkey = 0;
/**
* Default constructor
*
* @param resource $conn LDAP link identifier
* @param resource $ldap LDAP result entry identifier
* @param string $base_dn Base DN used to get this result
* @param string $filter Filter query used to get this result
* @param integer $count Record count value (pre-calculated)
*/
function __construct($conn, $ldap, $base_dn, $filter, $count = null)
{
$this->conn = $conn;
$this->ldap = $ldap;
$this->base_dn = $base_dn;
$this->filter = $filter;
$this->count = $count;
}
/**
* Wrapper for ldap_sort()
*/
public function sort($attr)
{
return ldap_sort($this->conn, $this->ldap, $attr);
}
/**
* Get entries count
*/
public function count()
{
if (!isset($this->count))
$this->count = ldap_count_entries($this->conn, $this->ldap);
return $this->count;
}
/**
* Wrapper for ldap_get_entries()
*
* @param boolean $normalize Optionally normalize the entries to a list of hash arrays
* @return array List of LDAP entries
*/
public function entries($normalize = false)
{
$entries = ldap_get_entries($this->conn, $this->ldap);
return $normalize ? rcube_ldap_generic::normalize_result($entries) : $entries;
}
/**
* Wrapper for ldap_get_dn() using the current entry pointer
*/
public function get_dn()
{
return $this->current ? ldap_get_dn($this->conn, $this->current) : null;
}
/*** Implements the PHP 5 Iterator interface to make foreach work ***/
function current()
{
$attrib = ldap_get_attributes($this->conn, $this->current);
$attrib['dn'] = ldap_get_dn($this->conn, $this->current);
return $attrib;
}
function key()
{
return $this->iteratorkey;
}
function rewind()
{
$this->iteratorkey = 0;
$this->current = ldap_first_entry($this->conn, $this->ldap);
}
function next()
{
$this->iteratorkey++;
$this->current = ldap_next_entry($this->conn, $this->current);
}
function valid()
{
return (bool)$this->current;
}
}