summaryrefslogtreecommitdiff
path: root/program
diff options
context:
space:
mode:
authoralecpl <alec@alec.pl>2012-04-10 07:47:15 +0000
committeralecpl <alec@alec.pl>2012-04-10 07:47:15 +0000
commitd6eb7c0fbb189d342c624c5c53cd1e3c68d20b28 (patch)
tree1bf42045cd93473c2afdb1fba945479c1e951967 /program
parenta274fb2e20215716389ec3709f0726b7002521f3 (diff)
- Fix removing all folders on import to LDAP addressbook (added rcube_ldap::delete_all())
- Fix removing sub-entries in delete()
Diffstat (limited to 'program')
-rw-r--r--program/include/rcube_ldap.php21
1 files changed, 19 insertions, 2 deletions
diff --git a/program/include/rcube_ldap.php b/program/include/rcube_ldap.php
index 61c66f340..9f8086bd9 100644
--- a/program/include/rcube_ldap.php
+++ b/program/include/rcube_ldap.php
@@ -1284,7 +1284,7 @@ class rcube_ldap extends rcube_addressbook
// Need to delete all sub-entries first
if ($this->sub_filter) {
- if ($entries = $this->ldap_list($dn, $this->sub_filter, array_keys($this->props['sub_fields']))) {
+ if ($entries = $this->ldap_list($dn, $this->sub_filter)) {
foreach ($entries as $entry) {
if (!$this->ldap_delete($entry['dn'])) {
$this->set_error(self::ERROR_SAVING, 'errorsaving');
@@ -1315,6 +1315,23 @@ class rcube_ldap extends rcube_addressbook
/**
+ * Remove all contact records
+ */
+ function delete_all()
+ {
+ //searching for contact entries
+ $dn_list = $this->ldap_list($this->base_dn, $this->prop['filter'] ? $this->prop['filter'] : '(objectclass=*)');
+
+ if (!empty($dn_list)) {
+ foreach ($dn_list as $idx => $entry) {
+ $dn_list[$idx] = self::dn_encode($entry['dn']);
+ }
+ $this->delete($dn_list);
+ }
+ }
+
+
+ /**
* Execute the LDAP search based on the stored credentials
*/
private function _exec_search($count = false)
@@ -2172,7 +2189,7 @@ class rcube_ldap extends rcube_addressbook
/**
* Wrapper for ldap_list()
*/
- protected function ldap_list($dn, $filter, $attrs)
+ protected function ldap_list($dn, $filter, $attrs = array(''))
{
$list = array();
$this->_debug("C: List [dn: $dn] [{$filter}]");