diff options
| author | alec <alec@208e9e7b-5314-0410-a742-e7e81cd9613c> | 2011-02-28 17:59:13 +0000 |
|---|---|---|
| committer | alec <alec@208e9e7b-5314-0410-a742-e7e81cd9613c> | 2011-02-28 17:59:13 +0000 |
| commit | bdf3abb107eb0b56a7b4613327eeda62a8ff057a (patch) | |
| tree | cf2bed041c735662eb659df78c195efbd3f75d29 /roundcubemail/program/steps/settings/func.inc | |
| parent | 1ab92f17679a82f2fabab83fec90058f5b600cf0 (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.inc | 40 |
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', |
