diff options
author | alecpl <alec@alec.pl> | 2010-09-30 13:24:33 +0000 |
---|---|---|
committer | alecpl <alec@alec.pl> | 2010-09-30 13:24:33 +0000 |
commit | ce92ba767a9557daf7f18be94882dd7e6f4591fb (patch) | |
tree | f018b3c42d2d452948bc240c3d9aa8a7aaff08a3 /program/steps/addressbook/groups.inc | |
parent | 66c674cc5716364cd6b450d8398b0a26aba0a2ae (diff) |
- Plugin API: improved 'abort' flag handling, added 'result' item in some hooks: group_*, contact_*, identity_* (#1486914)
Diffstat (limited to 'program/steps/addressbook/groups.inc')
-rw-r--r-- | program/steps/addressbook/groups.inc | 31 |
1 files changed, 27 insertions, 4 deletions
diff --git a/program/steps/addressbook/groups.inc b/program/steps/addressbook/groups.inc index 542628e1c..66619fa7d 100644 --- a/program/steps/addressbook/groups.inc +++ b/program/steps/addressbook/groups.inc @@ -33,9 +33,18 @@ if ($RCMAIL->action == 'group-addmembers') { $CONTACTS->set_group($gid); $num2add = count(explode(',', $plugin['ids'])); - if (!$plugin['abort'] && ($maxnum = $RCMAIL->config->get('max_group_members', 0)) && ($CONTACTS->count()->count + $num2add > $maxnum)) - $OUTPUT->show_message('maxgroupmembersreached', 'warning', array('max' => $maxnum)); - else if (!$plugin['abort'] && $CONTACTS->add_to_group($gid, $plugin['ids'])) + if (!$plugin['abort']) { + if (($maxnum = $RCMAIL->config->get('max_group_members', 0)) && ($CONTACTS->count()->count + $num2add > $maxnum)) { + $OUTPUT->show_message('maxgroupmembersreached', 'warning', array('max' => $maxnum)); + $OUTPUT->send(); + } + $result = $CONTACTS->add_to_group($gid, $plugin['ids']); + } + else { + $result = $plugin['result']; + } + + if ($result) $OUTPUT->show_message('contactaddedtogroup'); else if ($plugin['message']) $OUTPUT->show_message($plugin['message'], 'warning'); @@ -46,7 +55,12 @@ else if ($RCMAIL->action == 'group-delmembers') { if (($gid = get_input_value('_gid', RCUBE_INPUT_POST)) && ($ids = get_input_value('_cid', RCUBE_INPUT_POST))) { $plugin = $RCMAIL->plugins->exec_hook('group_delmembers', array('group_id' => $gid, 'ids' => $ids, 'source' => $source)); - if (!$plugin['abort'] && $CONTACTS->remove_from_group($gid, $plugin['ids'])) + if (!$plugin['abort']) + $result = $CONTACTS->remove_from_group($gid, $plugin['ids']); + else + $result = $plugin['result']; + + if ($result) $OUTPUT->show_message('contactremovedfromgroup'); else if ($plugin['message']) $OUTPUT->show_message($plugin['message'], 'warning'); @@ -56,8 +70,11 @@ else if ($RCMAIL->action == 'group-delmembers') { else if ($RCMAIL->action == 'group-create') { if ($name = trim(get_input_value('_name', RCUBE_INPUT_POST))) { $plugin = $RCMAIL->plugins->exec_hook('group_create', array('name' => $name, 'source' => $source)); + if (!$plugin['abort']) $created = $CONTACTS->create_group($plugin['name']); + else + $created = $plugin['result']; } if ($created && $OUTPUT->ajax_call) { @@ -72,8 +89,11 @@ else if ($RCMAIL->action == 'group-create') { else if ($RCMAIL->action == 'group-rename') { if (($gid = get_input_value('_gid', RCUBE_INPUT_POST)) && ($name = trim(get_input_value('_name', RCUBE_INPUT_POST)))) { $plugin = $RCMAIL->plugins->exec_hook('group_rename', array('group_id' => $gid, 'name' => $name, 'source' => $source)); + if (!$plugin['abort']) $newname = $CONTACTS->rename_group($gid, $plugin['name']); + else + $newname = $plugin['result']; } if ($newname && $OUTPUT->ajax_call) @@ -85,8 +105,11 @@ else if ($RCMAIL->action == 'group-rename') { else if ($RCMAIL->action == 'group-delete') { if ($gid = get_input_value('_gid', RCUBE_INPUT_POST)) { $plugin = $RCMAIL->plugins->exec_hook('group_delete', array('group_id' => $gid, 'source' => $source)); + if (!$plugin['abort']) $deleted = $CONTACTS->delete_group($gid); + else + $deleted = $plugin['result']; } if ($deleted) |