summaryrefslogtreecommitdiff
path: root/roundcubemail/program/steps/settings/func.inc
diff options
context:
space:
mode:
authoralec <alec@208e9e7b-5314-0410-a742-e7e81cd9613c>2011-02-28 17:59:13 +0000
committeralec <alec@208e9e7b-5314-0410-a742-e7e81cd9613c>2011-02-28 17:59:13 +0000
commitbdf3abb107eb0b56a7b4613327eeda62a8ff057a (patch)
treecf2bed041c735662eb659df78c195efbd3f75d29 /roundcubemail/program/steps/settings/func.inc
parent1ab92f17679a82f2fabab83fec90058f5b600cf0 (diff)
- Add simple ACL rights/namespace handling in folder manager (display folder's namespace, modify edit form fields according to MYRIGHTS)
git-svn-id: https://svn.roundcube.net/trunk@4581 208e9e7b-5314-0410-a742-e7e81cd9613c
Diffstat (limited to 'roundcubemail/program/steps/settings/func.inc')
-rw-r--r--roundcubemail/program/steps/settings/func.inc40
1 files changed, 40 insertions, 0 deletions
diff --git a/roundcubemail/program/steps/settings/func.inc b/roundcubemail/program/steps/settings/func.inc
index 271ee408a..6d3919faa 100644
--- a/roundcubemail/program/steps/settings/func.inc
+++ b/roundcubemail/program/steps/settings/func.inc
@@ -756,6 +756,46 @@ function rcmail_get_skins()
return $skins;
}
+
+function rcube_folder_options($mailbox)
+{
+ global $RCMAIL;
+
+ $acl = $RCMAIL->imap->get_capability('ACL');
+ $default_folders = (array) $RCMAIL->config->get('default_imap_folders');
+ $options = array();
+
+ $options['name'] = $mailbox;
+ $options['options'] = $RCMAIL->imap->mailbox_options($mailbox, true);
+ $options['namespace'] = $RCMAIL->imap->mailbox_namespace($mailbox);
+ $options['rights'] = $acl ? (array)$RCMAIL->imap->my_rights($mailbox) : array();
+ $options['special'] = in_array($mailbox, $default_folders);
+ $options['protected'] = $options['special'] && $RCMAIL->config->get('protect_default_folders');
+
+ if (is_array($options['options'])) {
+ foreach ($options['options'] as $opt) {
+ $opt = strtolower($opt);
+ if ($opt == '\noselect' || $opt == '\nonexistent') {
+ $options['noselect'] = true;
+ }
+ }
+ }
+ else {
+ $options['noselect'] = true;
+ }
+
+ if (!empty($options['rights'])) {
+ $options['norename'] = !in_array('x', $options['rights']) &&
+ (!in_array('c', $options['rights']) || !in_array('d', $options['rights']));
+ if (!$options['noselect']) {
+ $options['noselect'] = !in_array('r', $options['rights']);
+ }
+ }
+
+ return $options;
+}
+
+
// register UI objects
$OUTPUT->add_handlers(array(
'prefsframe' => 'rcmail_preferences_frame',