Add possibility to define date format in write operations for ldap attributes (#1488741)

pull/299/merge
Aleksander Machniak 9 years ago
parent bb1ed2740d
commit c8c4cafb1f

@ -1,6 +1,7 @@
CHANGELOG Roundcube Webmail CHANGELOG Roundcube Webmail
=========================== ===========================
- Add possibility to define date format in write operations for ldap attributes (#1488741)
- Display attachment size in compose (#1484774) - Display attachment size in compose (#1484774)
- Added possibility to drag-n-drop attachments from mail preview to compose window - Added possibility to drag-n-drop attachments from mail preview to compose window
- Implemented mail messages searching with predefined date interval - Implemented mail messages searching with predefined date interval

@ -853,8 +853,11 @@ $config['ldap_public']['Verisign'] = array(
'required_fields' => array('cn', 'sn', 'mail'), 'required_fields' => array('cn', 'sn', 'mail'),
'search_fields' => array('mail', 'cn'), // fields to search in 'search_fields' => array('mail', 'cn'), // fields to search in
// mapping of contact fields to directory attributes // mapping of contact fields to directory attributes
// for every attribute one can specify the number of values (limit) allowed. // 1. for every attribute one can specify the number of values (limit) allowed.
// default is 1, a wildcard * means unlimited // default is 1, a wildcard * means unlimited
// 2. another possible parameter is separator character for composite fields
// 3. it's possible to define field format for write operations, e.g. for date fields
// example: 'birthday:date[YmdHis\\Z]'
'fieldmap' => array( 'fieldmap' => array(
// Roundcube => LDAP:limit // Roundcube => LDAP:limit
'name' => 'cn', 'name' => 'cn',

@ -38,6 +38,7 @@ class rcube_ldap extends rcube_addressbook
// private properties // private properties
protected $ldap; protected $ldap;
protected $formats = array();
protected $prop = array(); protected $prop = array();
protected $fieldmap = array(); protected $fieldmap = array();
protected $filter = ''; protected $filter = '';
@ -45,7 +46,7 @@ class rcube_ldap extends rcube_addressbook
protected $result; protected $result;
protected $ldap_result; protected $ldap_result;
protected $mail_domain = ''; protected $mail_domain = '';
protected $debug = false; protected $debug = false;
/** /**
* Group objectclass (lowercase) to member attribute mapping * Group objectclass (lowercase) to member attribute mapping
@ -119,22 +120,38 @@ class rcube_ldap extends rcube_addressbook
if (is_array($p['fieldmap'])) { if (is_array($p['fieldmap'])) {
$p['fieldmap'] = array_filter($p['fieldmap']); $p['fieldmap'] = array_filter($p['fieldmap']);
foreach ($p['fieldmap'] as $rf => $lf) foreach ($p['fieldmap'] as $rf => $lf)
$this->fieldmap[$rf] = $this->_attr_name(strtolower($lf)); $this->fieldmap[$rf] = $this->_attr_name($lf);
} }
else if (!empty($p)) { else if (!empty($p)) {
// read deprecated *_field properties to remain backwards compatible // read deprecated *_field properties to remain backwards compatible
foreach ($p as $prop => $value) foreach ($p as $prop => $value)
if (!empty($value) && preg_match('/^(.+)_field$/', $prop, $matches)) if (!empty($value) && preg_match('/^(.+)_field$/', $prop, $matches))
$this->fieldmap[$matches[1]] = $this->_attr_name(strtolower($value)); $this->fieldmap[$matches[1]] = $this->_attr_name($value);
} }
// use fieldmap to advertise supported coltypes to the application // use fieldmap to advertise supported coltypes to the application
foreach ($this->fieldmap as $colv => $lfv) { foreach ($this->fieldmap as $colv => $lfv) {
list($col, $type) = explode(':', $colv); list($col, $type) = explode(':', $colv);
list($lf, $limit, $delim) = explode(':', $lfv); $params = explode(':', $lfv);
if ($limit == '*') $limit = null; $lf = array_shift($params);
else $limit = max(1, intval($limit)); $limit = 1;
foreach ($params as $idx => $param) {
// field format specification
if (preg_match('/^(date)\[(.+)\]$/i', $param, $m)) {
$this->formats[$lf] = array('type' => strtolower($m[1]), 'format' => $m[2]);
}
// first argument is a limit
else if ($idx === 0) {
if ($param == '*') $limit = null;
else $limit = max(1, intval($param));
}
// second is a composite field separator
else if ($idx === 1 && $param) {
$this->coltypes[$col]['serialized'][$type] = $param;
}
}
if (!is_array($this->coltypes[$col])) { if (!is_array($this->coltypes[$col])) {
$subtypes = $type ? array($type) : null; $subtypes = $type ? array($type) : null;
@ -146,10 +163,7 @@ class rcube_ldap extends rcube_addressbook
$this->coltypes[$col]['limit'] += $limit; $this->coltypes[$col]['limit'] += $limit;
} }
if ($delim) $this->fieldmap[$colv] = $lf;
$this->coltypes[$col]['serialized'][$type] = $delim;
$this->fieldmap[$colv] = $lf;
} }
// support for composite address // support for composite address
@ -195,7 +209,7 @@ class rcube_ldap extends rcube_addressbook
} }
foreach ($this->prop['required_fields'] as $key => $val) { foreach ($this->prop['required_fields'] as $key => $val) {
$this->prop['required_fields'][$key] = $this->_attr_name(strtolower($val)); $this->prop['required_fields'][$key] = $this->_attr_name($val);
} }
// Build sub_fields filter // Build sub_fields filter
@ -1536,6 +1550,20 @@ class rcube_ldap extends rcube_addressbook
} }
} }
foreach ($this->formats as $fld => $format) {
if (empty($ldap_data[$fld])) {
continue;
}
switch ($format['type']) {
case 'date':
if ($dt = rcube_utils::anytodatetime($ldap_data[$fld])) {
$ldap_data[$fld] = $dt->format($format['format']);
}
break;
}
}
return $ldap_data; return $ldap_data;
} }
@ -1555,6 +1583,7 @@ class rcube_ldap extends rcube_addressbook
list($name, $limit) = explode(':', $namev, 2); list($name, $limit) = explode(':', $namev, 2);
$suffix = $limit ? ':'.$limit : ''; $suffix = $limit ? ':'.$limit : '';
$name = strtolower($name);
return (isset($aliases[$name]) ? $aliases[$name] : $name) . $suffix; return (isset($aliases[$name]) ? $aliases[$name] : $name) . $suffix;
} }

Loading…
Cancel
Save