From 47d8d39cf49310b688967f7571b0d66b5971b39c Mon Sep 17 00:00:00 2001
From: thomascube <thomas@roundcube.net>
Date: Sun, 21 Feb 2010 11:44:39 -0500
Subject: [PATCH] Use rcmail::imap_connect() to establish IMAP connections; always initialize rcube_imap object in mail steps

---
 plugins/subscriptions_option/subscriptions_option.php |   50 +++++++++++++++++++++++++++++---------------------
 1 files changed, 29 insertions(+), 21 deletions(-)

diff --git a/plugins/subscriptions_option/subscriptions_option.php b/plugins/subscriptions_option/subscriptions_option.php
index ba7236c..4d471b8 100644
--- a/plugins/subscriptions_option/subscriptions_option.php
+++ b/plugins/subscriptions_option/subscriptions_option.php
@@ -11,7 +11,7 @@
  * The user option can be hidden and set globally by adding 'use_subscriptions'
  * to the the 'dont_override' configure line:
  * $rcmail_config['dont_override'] = array('use_subscriptions');
- * and then set the global preference"
+ * and then set the global preference
  * $rcmail_config['use_subscriptions'] = true; // or false
  *
  * Roundcube caches folder lists.  When a user changes this option or visits
@@ -24,57 +24,65 @@
  */
 class subscriptions_option extends rcube_plugin
 {
-
+    public $task = 'mail|settings';
+    
     function init()
     {
         $this->add_texts('localization/', false);
         $dont_override = rcmail::get_instance()->config->get('dont_override', array());
-        if (!in_array('use_subscriptions', $dont_override)){
-            $this->add_hook('user_preferences', array($this, 'settings_table'));
+        if (!in_array('use_subscriptions', $dont_override)) {
+            $this->add_hook('user_preferences', array($this, 'settings_blocks'));
             $this->add_hook('save_preferences', array($this, 'save_prefs'));
         }
         $this->add_hook('list_mailboxes', array($this, 'list_mailboxes'));
         $this->add_hook('manage_folders', array($this, 'manage_folders'));
     }
 
-    function settings_table($args)
+    function settings_blocks($args)
     {
         if ($args['section'] == 'server') {
             $use_subscriptions = rcmail::get_instance()->config->get('use_subscriptions');
             $field_id = 'rcmfd_use_subscriptions';
-            $use_subscriptions = new html_checkbox(array('name' => '_use_subscriptions', 'id' => $field_id, 'value' => 1));
+            $checkbox = new html_checkbox(array('name' => '_use_subscriptions', 'id' => $field_id, 'value' => 1));
 
-            $args['table']->add('title', html::label($field_id, Q($this->gettext('useimapsubscriptions'))));
-            $args['table']->add(null, $use_subscriptions->show($use_subscriptions?1:0));
+            $args['blocks']['main']['options']['use_subscriptions'] = array(
+                'title' => html::label($field_id, Q($this->gettext('useimapsubscriptions'))),
+                'content' => $checkbox->show($use_subscriptions?1:0),
+            );
         }
 
         return $args;
     }
 
-    function save_prefs($args){
-        $rcmail = rcmail::get_instance();
-        $use_subscriptions = $rcmail->config->get('use_subscriptions');
+    function save_prefs($args)
+    {
+        if ($args['section'] == 'server') {
+            $rcmail = rcmail::get_instance();
+            $use_subscriptions = $rcmail->config->get('use_subscriptions');
 
-        $args['prefs']['use_subscriptions'] = isset($_POST['_use_subscriptions']) ? true : false;
-        // if the use_subscriptions preference changes, flush the folder cache
-        if (($use_subscriptions && !isset($_POST['_use_subscriptions'])) ||
-            (!$use_subscriptions && isset($_POST['_use_subscriptions']))) {
-                $rcmail->imap_init(true);
-                $rcmail->imap->clear_cache('mailboxes');
+            $args['prefs']['use_subscriptions'] = isset($_POST['_use_subscriptions']) ? true : false;
+
+            // if the use_subscriptions preference changes, flush the folder cache
+            if (($use_subscriptions && !isset($_POST['_use_subscriptions'])) ||
+                (!$use_subscriptions && isset($_POST['_use_subscriptions']))) {
+                    $rcmail->imap_connect();
+                    $rcmail->imap->clear_cache('mailboxes');
             }
-
+        }
         return $args;
     }
 
-    function list_mailboxes($args){
+    function list_mailboxes($args)
+    {
         $rcmail = rcmail::get_instance();
         if (!$rcmail->config->get('use_subscriptions', true)) {
-            $args['folders'] = iil_C_ListMailboxes($rcmail->imap->conn, $rcmail->imap->_mod_mailbox($args['root']), $args['filter']);
+            $args['folders'] = iil_C_ListMailboxes($rcmail->imap->conn, $rcmail->imap->mod_mailbox($args['root']), $args['filter']);
         }
         return $args;
     }
 
-    function manage_folders($args){
+    function manage_folders($args)
+    {
         $rcmail = rcmail::get_instance();
         if (!$rcmail->config->get('use_subscriptions', true)) {
             $args['table']->remove_column('subscribed');

--
Gitblit v1.9.1