106 lines
2.3 KiB
PHP

<?php
class LDAP {
private $link;
private $bind;
public function __construct($ldaphost, $binddn, $bindpw) {
$this->link = ldap_connect($ldaphost) or exit('Error: ldap_connect()');
ldap_set_option($this->link, LDAP_OPT_PROTOCOL_VERSION, 3);
ldap_set_option($this->link, LDAP_OPT_REFERRALS, 0);
if(@ldap_bind($this->link, $binddn, $bindpw)) {
$this->bind = 1;
}
else {
$this->bind = 0;
}
return $this->link;
}
public function is_bind_ok() {
return $this->bind;
}
public function query($basedn, $filter, $justthese) {
$i = 0;
$data = array();
$sr = ldap_search($this->link, $basedn, $filter, $justthese);
$results = ldap_get_entries($this->link, $sr);
if(ENABLE_SYSLOG == 1) { syslog(LOG_INFO, sprintf("ldap query: base dn='%s', filter='%s', attr='%s', %d hits", $basedn, $filter, implode(" ", $justthese), $results['count'])); }
for($i=0; $i < $results['count']; $i++) {
for($k=0; $k < $results[$i]['count']; $k++) {
$attr = $results[$i][$k];
if($results[$i][$attr]['count'] == 1) {
$data[$i][$attr] = isset($results[$i][$attr][0]) ? $results[$i][$attr][0] : "";
}
else {
$data[$i][$attr] = isset($results[$i][$attr]) ? $results[$i][$attr] : "";
}
}
$data[$i]['dn'] = $results[$i]['dn'];
}
$query = new stdClass();
$query->filter = $filter;
$query->row = isset($data[0]) ? $data[0] : array();
$query->dn = isset($results[0]['dn']) ? $results[0]['dn'] : "";
$query->rows = $data;
$query->num_rows = $results['count'];
unset($data);
return $query;
}
public function add($dn, $entry) {
return ldap_add($this->link, $dn, $entry);
}
public function modify($dn, $entry) {
return ldap_modify($this->link, $dn, $entry);
}
public function rename($dn, $newrdn, $newparent) {
return ldap_rename($this->link, $dn, $newrdn, $newparent, TRUE);
}
public function replace($dn, $entry) {
return ldap_mod_replace($this->link, $dn, $entry);
}
public function delete($dn) {
return ldap_delete($this->link, $dn);
}
public function __destruct() {
ldap_unbind($this->link);
}
}
?>