- Fix import of vCard entries with params (#1485453)

release-0.6
alecpl 15 years ago
parent 3b7e00fbda
commit 93af155f64

@ -1,6 +1,7 @@
CHANGELOG RoundCube Webmail CHANGELOG RoundCube Webmail
=========================== ===========================
- Fix import of vCard entries with params (#1485453)
- Fix HTML messages output with empty block elements (#1485974) - Fix HTML messages output with empty block elements (#1485974)
- Added hook when killing a session - Added hook when killing a session
- Added hook to write_log function (#1485971) - Added hook to write_log function (#1485971)

@ -264,13 +264,13 @@ class rcube_vcard
} }
if (!preg_match('/^(BEGIN|END)$/i', $line[1]) && preg_match_all('/([^\\;]+);?/', $line[1], $regs2)) { if (!preg_match('/^(BEGIN|END)$/i', $line[1]) && preg_match_all('/([^\\;]+);?/', $line[1], $regs2)) {
$entry = array(''); $entry = array();
$field = strtoupper($regs2[1][0]); $field = strtoupper($regs2[1][0]);
foreach($regs2[1] as $attrid => $attr) { foreach($regs2[1] as $attrid => $attr) {
if ((list($key, $value) = explode('=', $attr)) && $value) { if ((list($key, $value) = explode('=', $attr)) && $value) {
if ($key == 'ENCODING') { if ($key == 'ENCODING') {
# add next line(s) to value string if QP line end detected // add next line(s) to value string if QP line end detected
while ($value == 'QUOTED-PRINTABLE' && preg_match('/=$/', $lines[$i])) while ($value == 'QUOTED-PRINTABLE' && preg_match('/=$/', $lines[$i]))
$line[2] .= "\n" . $lines[++$i]; $line[2] .= "\n" . $lines[++$i];
@ -280,17 +280,16 @@ class rcube_vcard
$entry[strtolower($key)] = array_merge((array)$entry[strtolower($key)], (array)self::vcard_unquote($value, ',')); $entry[strtolower($key)] = array_merge((array)$entry[strtolower($key)], (array)self::vcard_unquote($value, ','));
} }
else if ($attrid > 0) { else if ($attrid > 0) {
$entry[$key] = true; # true means attr without =value $entry[$key] = true; // true means attr without =value
} }
} }
$entry[0] = self::vcard_unquote($line[2]); $entry = array_merge($entry, (array)self::vcard_unquote($line[2]));
$data[$field][] = count($entry) > 1 ? $entry : $entry[0]; $data[$field][] = count($entry) > 1 ? $entry : $entry[0];
} }
} }
unset($data['VERSION']); unset($data['VERSION']);
return $data; return $data;
} }
@ -360,7 +359,7 @@ class rcube_vcard
if (is_int($attrname)) if (is_int($attrname))
$value[] = $attrvalues; $value[] = $attrvalues;
elseif ($attrvalues === true) elseif ($attrvalues === true)
$attr .= ";$attrname"; # true means just tag, not tag=value, as in PHOTO;BASE64:... $attr .= ";$attrname"; // true means just tag, not tag=value, as in PHOTO;BASE64:...
else { else {
foreach((array)$attrvalues as $attrvalue) foreach((array)$attrvalues as $attrvalue)
$attr .= ";$attrname=" . self::vcard_quote($attrvalue, ','); $attr .= ";$attrname=" . self::vcard_quote($attrvalue, ',');

Loading…
Cancel
Save