summaryrefslogtreecommitdiff
path: root/roundcubemail/program/steps
diff options
context:
space:
mode:
authoralec <alec@208e9e7b-5314-0410-a742-e7e81cd9613c>2011-07-24 10:16:07 +0000
committeralec <alec@208e9e7b-5314-0410-a742-e7e81cd9613c>2011-07-24 10:16:07 +0000
commit115fd802c9b15e7156cece026e55826dd7053ddf (patch)
tree324d94827d603394deb43109a494c6db0e701829 /roundcubemail/program/steps
parent5eaf58a69f4b52885854e079f9075e137ced866c (diff)
- On contact copy check for existing record by name if email field is empty
git-svn-id: https://svn.roundcube.net/trunk@4960 208e9e7b-5314-0410-a742-e7e81cd9613c
Diffstat (limited to 'roundcubemail/program/steps')
-rw-r--r--roundcubemail/program/steps/addressbook/copy.inc14
1 files changed, 10 insertions, 4 deletions
diff --git a/roundcubemail/program/steps/addressbook/copy.inc b/roundcubemail/program/steps/addressbook/copy.inc
index 5bfe5b400..e07d62af9 100644
--- a/roundcubemail/program/steps/addressbook/copy.inc
+++ b/roundcubemail/program/steps/addressbook/copy.inc
@@ -57,8 +57,14 @@ foreach ($cids as $source => $cid)
foreach ($cid as $cid) {
$a_record = $CONTACTS->get_record($cid, true);
- // check if contact exists, if so, we'll need it's ID
- $result = $TARGET->search('email', $a_record['email'], true, true);
+ // Check if contact exists, if so, we'll need it's ID
+ // Note: Some addressbooks allows empty email address field
+ if (!empty($a_record['email']))
+ $result = $TARGET->search('email', $a_record['email'], true, true, true);
+ else if (!empty($a_record['name']))
+ $result = $TARGET->search('name', $a_record['name'], true, true, true);
+ else
+ $result = new rcube_result_set();
// insert contact record
if (!$result->count) {
@@ -79,7 +85,7 @@ foreach ($cids as $source => $cid)
else {
$record = $result->first();
$ids[] = $record['ID'];
- $errormsg = 'contactexists';
+ $errormsg = empty($a_record['email']) ? 'contactnameexists' : 'contactexists';
}
}
@@ -103,7 +109,7 @@ foreach ($cids as $source => $cid)
else if ($plugin['result']) {
$success = $plugin['result'];
}
-
+
$errormsg = $plugin['message'] ? $plugin['message'] : 'copyerror';
}
}